@ng-flexy/form-bootstrap
Version:
Flexy components and tools to build Angular 8+ applications
200 lines • 20.8 kB
JavaScript
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
import { FormControl } from '@angular/forms';
import { findRawValue, prepareControlValue } from '@ng-flexy/form';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "@ng-select/ng-select";
import * as i3 from "@angular/forms";
import * as i4 from "./readonly.component";
function FlexyControlSelect2Component_ng_select_0_ng_template_2_span_0_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵelement(0, "span", 9);
} if (rf & 2) {
const item_r5 = i0.ɵɵnextContext().item;
i0.ɵɵproperty("innerHTML", item_r5["prefixHtml"], i0.ɵɵsanitizeHtml);
} }
function FlexyControlSelect2Component_ng_select_0_ng_template_2_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵtemplate(0, FlexyControlSelect2Component_ng_select_0_ng_template_2_span_0_Template, 1, 1, "span", 6);
i0.ɵɵelementStart(1, "span", 7);
i0.ɵɵtext(2);
i0.ɵɵelementEnd();
i0.ɵɵelementStart(3, "span", 8);
i0.ɵɵlistener("click", function FlexyControlSelect2Component_ng_select_0_ng_template_2_Template_span_click_3_listener() { const item_r5 = ctx.item; const clear_r6 = ctx.clear; return clear_r6(item_r5); });
i0.ɵɵtext(4, "\u00D7");
i0.ɵɵelementEnd();
} if (rf & 2) {
const item_r5 = ctx.item;
i0.ɵɵproperty("ngIf", item_r5["prefixHtml"]);
i0.ɵɵadvance(1);
i0.ɵɵpropertyInterpolate("title", item_r5.text);
i0.ɵɵadvance(1);
i0.ɵɵtextInterpolate(item_r5.text);
} }
function FlexyControlSelect2Component_ng_select_0_ng_template_3_span_0_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵelement(0, "span", 9);
} if (rf & 2) {
const item_r10 = i0.ɵɵnextContext().item;
i0.ɵɵproperty("innerHTML", item_r10["prefixHtml"], i0.ɵɵsanitizeHtml);
} }
function FlexyControlSelect2Component_ng_select_0_ng_template_3_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵtemplate(0, FlexyControlSelect2Component_ng_select_0_ng_template_3_span_0_Template, 1, 1, "span", 6);
i0.ɵɵelementStart(1, "span", 7);
i0.ɵɵtext(2);
i0.ɵɵelementEnd();
} if (rf & 2) {
const item_r10 = ctx.item;
i0.ɵɵproperty("ngIf", item_r10["prefixHtml"]);
i0.ɵɵadvance(1);
i0.ɵɵpropertyInterpolate("title", item_r10.text);
i0.ɵɵadvance(1);
i0.ɵɵtextInterpolate(item_r10.text);
} }
const _c0 = function (a0) { return { "ng-select-multiple": a0 }; };
function FlexyControlSelect2Component_ng_select_0_Template(rf, ctx) { if (rf & 1) {
const _r15 = i0.ɵɵgetCurrentView();
i0.ɵɵelementStart(0, "ng-select", 2, 3);
i0.ɵɵlistener("change", function FlexyControlSelect2Component_ng_select_0_Template_ng_select_change_0_listener($event) { i0.ɵɵrestoreView(_r15); const ctx_r14 = i0.ɵɵnextContext(); return ctx_r14.onChange($event); });
i0.ɵɵtemplate(2, FlexyControlSelect2Component_ng_select_0_ng_template_2_Template, 5, 3, "ng-template", 4);
i0.ɵɵtemplate(3, FlexyControlSelect2Component_ng_select_0_ng_template_3_Template, 3, 3, "ng-template", 5);
i0.ɵɵelementEnd();
} if (rf & 2) {
const ctx_r0 = i0.ɵɵnextContext();
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(11, _c0, ctx_r0.multiple))("formControl", ctx_r0.selectControl)("items", ctx_r0.optionsData)("placeholder", ctx_r0.placeholder)("multiple", ctx_r0.multiple)("addTag", ctx_r0.addItem)("hideSelected", ctx_r0.hideSelected)("searchFn", ctx_r0.enableSearchByValue ? ctx_r0.customSearchFn : null)("virtualScroll", ctx_r0.virtualScroll)("loading", ctx_r0.loading)("loadingText", ctx_r0.loadingText);
} }
function FlexyControlSelect2Component_flexy_control_readonly_1_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵelement(0, "flexy-control-readonly", 10);
} if (rf & 2) {
const ctx_r1 = i0.ɵɵnextContext();
i0.ɵɵproperty("value", ctx_r1.getReadonlyInfo(ctx_r1.control == null ? null : ctx_r1.control.value))("default", ctx_r1.default);
} }
export class FlexyControlSelect2Component {
constructor() {
this.loading = false; // no You can set the loading state from the outside (e.g. async items loading)
this.loadingText = 'Loading...'; // Loading... no Set custom text when for loading items
this.focused = new EventEmitter();
this.clicked = new EventEmitter();
this.changed = new EventEmitter();
this.virtualScroll = false; // Enable virtual scroll for better performance when rendering a lot of data
}
ngOnInit() {
this.selectControl = new FormControl(findRawValue(this.optionsRawId, this.control.value, this.options));
}
ngOnChanges(changes) {
if (changes.options) {
const optionsData = [];
if (this.options) {
optionsData.push(...this.options.map(item => {
let itemData;
if (typeof item === 'object' && item.hasOwnProperty('value')) {
itemData = item;
}
else {
itemData = {
value: item,
text: '' + item
};
}
return itemData;
}));
}
this.virtualScroll = optionsData.length > 100;
this.optionsData = optionsData;
}
}
onChange(data) {
const value = prepareControlValue(this.optionsRawId, data);
this.control.setValue(value);
this.changed.emit(value);
}
getReadonlyInfo(value) {
if (value && this.addItem) {
return value;
}
if ((value || value === 0) && this.optionsData) {
const opt = this.optionsData.find((item) => '' + item.value === '' + value);
return opt ? opt.text : '';
}
else if (value === null || value === '' || value === void 0) {
return null;
}
}
customSearchFn(term, item) {
return ((item.text && item.text.toLowerCase().includes(term.toLowerCase())) ||
(item.value && item.value.toLowerCase().includes(term.toLowerCase())));
}
}
FlexyControlSelect2Component.ɵfac = function FlexyControlSelect2Component_Factory(t) { return new (t || FlexyControlSelect2Component)(); };
FlexyControlSelect2Component.ɵcmp = i0.ɵɵdefineComponent({ type: FlexyControlSelect2Component, selectors: [["flexy-control-select2"]], inputs: { control: "control", options: "options", optionsRawId: "optionsRawId", default: "default", readonly: "readonly", multiple: "multiple", addItem: "addItem", placeholder: "placeholder", hideSelected: "hideSelected", enableSearchByValue: "enableSearchByValue", loading: "loading", loadingText: "loadingText" }, outputs: { focused: "focused", clicked: "clicked", changed: "changed" }, features: [i0.ɵɵNgOnChangesFeature], decls: 2, vars: 2, consts: [["bindLabel", "text", "bindValue", "value", 3, "ngClass", "formControl", "items", "placeholder", "multiple", "addTag", "hideSelected", "searchFn", "virtualScroll", "loading", "loadingText", "change", 4, "ngIf"], [3, "value", "default", 4, "ngIf"], ["bindLabel", "text", "bindValue", "value", 3, "ngClass", "formControl", "items", "placeholder", "multiple", "addTag", "hideSelected", "searchFn", "virtualScroll", "loading", "loadingText", "change"], ["select", ""], ["ng-label-tmp", ""], ["ng-option-tmp", ""], [3, "innerHTML", 4, "ngIf"], [3, "title"], [1, "ng-value-icon", "right", "t2e-unselect-value", 3, "click"], [3, "innerHTML"], [3, "value", "default"]], template: function FlexyControlSelect2Component_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵtemplate(0, FlexyControlSelect2Component_ng_select_0_Template, 4, 13, "ng-select", 0);
i0.ɵɵtemplate(1, FlexyControlSelect2Component_flexy_control_readonly_1_Template, 1, 2, "flexy-control-readonly", 1);
} if (rf & 2) {
i0.ɵɵproperty("ngIf", !ctx.readonly && ctx.optionsData);
i0.ɵɵadvance(1);
i0.ɵɵproperty("ngIf", ctx.readonly);
} }, directives: [i1.NgIf, i2.NgSelectComponent, i1.NgClass, i3.NgControlStatus, i3.FormControlDirective, i2.ɵh, i2.ɵf, i4.FlexyControlReadonlyComponent], encapsulation: 2, changeDetection: 0 });
/*@__PURE__*/ (function () { i0.ɵsetClassMetadata(FlexyControlSelect2Component, [{
type: Component,
args: [{
template: `
<ng-select
*ngIf="!readonly && optionsData"
[ ]="{ 'ng-select-multiple': multiple }"
[ ]="selectControl"
[ ]="optionsData"
[ ]="placeholder"
bindLabel="text"
bindValue="value"
[ ]="multiple"
[ ]="addItem"
[ ]="hideSelected"
[ ]="enableSearchByValue ? customSearchFn : null"
[ ]="virtualScroll"
[ ]="loading"
[ ]="loadingText"
(change)="onChange($event)"
>
<ng-template ng-label-tmp let-item="item" let-clear="clear">
<span *ngIf="item['prefixHtml']" [innerHTML]="item['prefixHtml']"></span> <span title="{{ item.text }}">{{ item.text }}</span>
<span class="ng-value-icon right t2e-unselect-value" (click)="clear(item)">×</span>
</ng-template>
<ng-template ng-option-tmp let-item="item" let-index="index">
<span *ngIf="item['prefixHtml']" [innerHTML]="item['prefixHtml']"></span> <span title="{{ item.text }}">{{ item.text }}</span>
</ng-template>
</ng-select>
<flexy-control-readonly *ngIf="readonly" [value]="getReadonlyInfo(control?.value)" [default]="default"> </flexy-control-readonly>
`,
selector: 'flexy-control-select2',
changeDetection: ChangeDetectionStrategy.OnPush
}]
}], null, { control: [{
type: Input
}], options: [{
type: Input
}], optionsRawId: [{
type: Input
}], default: [{
type: Input
}], readonly: [{
type: Input
}], multiple: [{
type: Input
}], addItem: [{
type: Input
}], placeholder: [{
type: Input
}], hideSelected: [{
type: Input
}], enableSearchByValue: [{
type: Input
}], loading: [{
type: Input
}], loadingText: [{
type: Input
}], focused: [{
type: Output
}], clicked: [{
type: Output
}], changed: [{
type: Output
}] }); })();
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select2.component.js","sourceRoot":"","sources":["../../../../../projects/form-bootstrap/src/lib/controls/select2.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnChanges, OnInit, Output } from '@angular/core';\nimport { FormControl } from '@angular/forms';\nimport { findRawValue, prepareControlValue, SelectOption, SelectOptionData } from '@ng-flexy/form';\n\n@Component({\n  template: `\n    <ng-select\n      *ngIf=\"!readonly && optionsData\"\n      #select\n      [ngClass]=\"{ 'ng-select-multiple': multiple }\"\n      [formControl]=\"selectControl\"\n      [items]=\"optionsData\"\n      [placeholder]=\"placeholder\"\n      bindLabel=\"text\"\n      bindValue=\"value\"\n      [multiple]=\"multiple\"\n      [addTag]=\"addItem\"\n      [hideSelected]=\"hideSelected\"\n      [searchFn]=\"enableSearchByValue ? customSearchFn : null\"\n      [virtualScroll]=\"virtualScroll\"\n      [loading]=\"loading\"\n      [loadingText]=\"loadingText\"\n      (change)=\"onChange($event)\"\n    >\n      <ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\">\n        <span *ngIf=\"item['prefixHtml']\" [innerHTML]=\"item['prefixHtml']\"></span> <span title=\"{{ item.text }}\">{{ item.text }}</span>\n        <span class=\"ng-value-icon right t2e-unselect-value\" (click)=\"clear(item)\">×</span>\n      </ng-template>\n      <ng-template ng-option-tmp let-item=\"item\" let-index=\"index\">\n        <span *ngIf=\"item['prefixHtml']\" [innerHTML]=\"item['prefixHtml']\"></span> <span title=\"{{ item.text }}\">{{ item.text }}</span>\n      </ng-template>\n    </ng-select>\n    <flexy-control-readonly *ngIf=\"readonly\" [value]=\"getReadonlyInfo(control?.value)\" [default]=\"default\"> </flexy-control-readonly>\n  `,\n  selector: 'flexy-control-select2',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class FlexyControlSelect2Component implements OnInit, OnChanges {\n  @Input() control: FormControl;\n  @Input() options: SelectOption[];\n  @Input() optionsRawId: string;\n  @Input() default: string;\n  @Input() readonly: boolean;\n  @Input() multiple: boolean;\n  @Input() addItem: boolean;\n  @Input() placeholder: string;\n  @Input() hideSelected: boolean;\n  @Input() enableSearchByValue: boolean;\n\n  @Input() loading = false; // no\tYou can set the loading state from the outside (e.g. async items loading)\n  @Input() loadingText = 'Loading...'; // Loading...\tno\tSet custom text when for loading items\n\n  @Output() focused = new EventEmitter<Event>();\n  @Output() clicked = new EventEmitter<Event>();\n  @Output() changed = new EventEmitter<any>();\n\n  selectControl: FormControl;\n\n  virtualScroll = false; // Enable virtual scroll for better performance when rendering a lot of data\n  optionsData: SelectOptionData[];\n\n  ngOnInit() {\n    this.selectControl = new FormControl(findRawValue(this.optionsRawId, this.control.value, this.options));\n  }\n\n  ngOnChanges(changes) {\n    if (changes.options) {\n      const optionsData = [];\n      if (this.options) {\n        optionsData.push(\n          ...this.options.map(item => {\n            let itemData: SelectOptionData;\n            if (typeof item === 'object' && item.hasOwnProperty('value')) {\n              itemData = item;\n            } else {\n              itemData = {\n                value: item,\n                text: '' + item\n              };\n            }\n            return itemData;\n          })\n        );\n      }\n      this.virtualScroll = optionsData.length > 100;\n      this.optionsData = optionsData;\n    }\n  }\n\n  onChange(data: SelectOptionData | SelectOptionData[]) {\n    const value = prepareControlValue(this.optionsRawId, data);\n    this.control.setValue(value);\n    this.changed.emit(value);\n  }\n\n  getReadonlyInfo(value): string {\n    if (value && this.addItem) {\n      return value;\n    }\n    if ((value || value === 0) && this.optionsData) {\n      const opt: SelectOption = this.optionsData.find((item: SelectOption) => '' + item.value === '' + value);\n      return opt ? opt.text : '';\n    } else if (value === null || value === '' || value === void 0) {\n      return null;\n    }\n  }\n\n  customSearchFn(term: string, item: SelectOption) {\n    return (\n      (item.text && item.text.toLowerCase().includes(term.toLowerCase())) ||\n      (item.value && item.value.toLowerCase().includes(term.toLowerCase()))\n    );\n  }\n}\n"]}