UNPKG

@ng-flexy/form-bootstrap

Version:

Flexy components and tools to build Angular 8+ applications

200 lines 20.8 kB
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" #select [ngClass]="{ 'ng-select-multiple': multiple }" [formControl]="selectControl" [items]="optionsData" [placeholder]="placeholder" bindLabel="text" bindValue="value" [multiple]="multiple" [addTag]="addItem" [hideSelected]="hideSelected" [searchFn]="enableSearchByValue ? customSearchFn : null" [virtualScroll]="virtualScroll" [loading]="loading" [loadingText]="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"]}