UNPKG

@ohayojp/form

Version:
167 lines 15.9 kB
/** * @fileoverview added by tsickle * Generated from: src/widgets/autocomplete/autocomplete.widget.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ViewChild, ViewEncapsulation } from '@angular/core'; import { NgModel } from '@angular/forms'; import { of } from 'rxjs'; import { debounceTime, map, mergeMap, startWith } from 'rxjs/operators'; import { getCopyEnum, getEnum, toBool } from '../../utils'; import { ControlUIWidget } from '../../widget'; export class AutoCompleteWidget extends ControlUIWidget { constructor() { super(...arguments); this.i = {}; this.typing = ''; this.isAsync = false; this.fixData = []; } /** * @param {?} item * @return {?} */ updateValue(item) { this.typing = (/** @type {?} */ (item.nzLabel)); /** @type {?} */ const data = item.nzValue; this.setValue(data.value); if (this.ui.change) { this.ui.change(item, data); } } /** * @param {?} item * @return {?} */ _setValue(item) { /** @type {?} */ let val = item.toString(); if (typeof item !== 'string') { val = item.value; } this.setValue(val); } /** * @return {?} */ afterViewInit() { const { backfill, defaultActiveFirstOption, nzWidth, filterOption, asyncData } = this.ui; this.i = { backfill: toBool(backfill, false), defaultActiveFirstOption: toBool(defaultActiveFirstOption, true), width: nzWidth || undefined, }; /** @type {?} */ let filterOptionValue = filterOption == null ? true : filterOption; if (typeof filterOptionValue === 'boolean') { filterOptionValue = (/** * @param {?} input * @param {?} option * @return {?} */ (input, option) => option.label.toLowerCase().indexOf((input || '').toLowerCase()) > -1); } this.filterOption = filterOptionValue; this.isAsync = !!asyncData; /** @type {?} */ const orgTime = +(this.ui.debounceTime || 0); /** @type {?} */ const time = Math.max(0, this.isAsync ? Math.max(50, orgTime) : orgTime); this.list = (/** @type {?} */ (this.ngModel.valueChanges)).pipe(debounceTime(time), startWith(''), mergeMap((/** * @param {?} input * @return {?} */ input => (this.isAsync ? (/** @type {?} */ (asyncData))(input) : this.filterData(input)))), map((/** * @param {?} res * @return {?} */ res => getEnum(res, null, (/** @type {?} */ (this.schema.readOnly)))))); } /** * @param {?} value * @return {?} */ reset(value) { this.typing = this.value; if (this.isAsync) return; switch (this.ui.type) { case 'email': this.fixData = getCopyEnum((/** @type {?} */ (this.schema.enum)) || this.formProperty.options.uiEmailSuffixes, null, (/** @type {?} */ (this.schema.readOnly))); break; default: this.fixData = getCopyEnum((/** @type {?} */ (this.schema.enum)), value, (/** @type {?} */ (this.schema.readOnly))); break; } } /** * @private * @param {?} input * @return {?} */ filterData(input) { switch (this.ui.type) { case 'email': return this.addEmailSuffix(input); default: return of(this.fixData.filter((/** * @param {?} option * @return {?} */ option => this.filterOption(input, option)))); } } /** * @private * @param {?} value * @return {?} */ addEmailSuffix(value) { return of(!value || ~value.indexOf('@') ? [] : this.fixData.map((/** * @param {?} domain * @return {?} */ domain => `${value}@${domain.label}`))); } } AutoCompleteWidget.decorators = [ { type: Component, args: [{ selector: 'sf-autocomplete', template: "<sf-item-wrap [id]=\"id\" [schema]=\"schema\" [ui]=\"ui\" [showError]=\"showError\" [error]=\"error\" [showTitle]=\"schema.title\">\n <input\n nz-input\n [nzAutocomplete]=\"auto\"\n [attr.id]=\"id\"\n [disabled]=\"disabled\"\n [attr.disabled]=\"disabled\"\n [nzSize]=\"ui.size\"\n [(ngModel)]=\"typing\"\n (ngModelChange)=\"_setValue($event)\"\n [attr.maxLength]=\"schema.maxLength || null\"\n [attr.placeholder]=\"ui.placeholder\"\n autocomplete=\"off\"\n />\n <nz-autocomplete\n #auto\n [nzBackfill]=\"i.backfill\"\n [nzDefaultActiveFirstOption]=\"i.defaultActiveFirstOption\"\n [nzWidth]=\"i.width\"\n (selectionChange)=\"updateValue($event)\"\n >\n <nz-auto-option *ngFor=\"let i of list | async\" [nzValue]=\"i\" [nzLabel]=\"i.label\">\n {{i.label}}\n </nz-auto-option>\n </nz-autocomplete>\n</sf-item-wrap>\n", preserveWhitespaces: false, encapsulation: ViewEncapsulation.None }] } ]; AutoCompleteWidget.propDecorators = { ngModel: [{ type: ViewChild, args: [NgModel, { static: false },] }] }; if (false) { /** @type {?} */ AutoCompleteWidget.prototype.i; /** @type {?} */ AutoCompleteWidget.prototype.list; /** @type {?} */ AutoCompleteWidget.prototype.typing; /** * @type {?} * @private */ AutoCompleteWidget.prototype.ngModel; /** * @type {?} * @private */ AutoCompleteWidget.prototype.filterOption; /** * @type {?} * @private */ AutoCompleteWidget.prototype.isAsync; /** * @type {?} * @private */ AutoCompleteWidget.prototype.fixData; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.widget.js","sourceRoot":"../../../../packages/form/","sources":["src/widgets/autocomplete/autocomplete.widget.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { NgModel } from '@angular/forms';\nimport { NzAutocompleteOptionComponent } from 'ng-zorro-antd/auto-complete';\nimport { Observable, of } from 'rxjs';\nimport { debounceTime, map, mergeMap, startWith } from 'rxjs/operators';\nimport { SFValue } from '../../interface';\nimport { SFSchemaEnum } from '../../schema';\nimport { getCopyEnum, getEnum, toBool } from '../../utils';\nimport { ControlUIWidget } from '../../widget';\nimport { SFAutoCompleteWidgetSchema } from './schema';\n\n@Component({\n  selector: 'sf-autocomplete',\n  templateUrl: './autocomplete.widget.html',\n  preserveWhitespaces: false,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class AutoCompleteWidget extends ControlUIWidget<SFAutoCompleteWidgetSchema> {\n  i: any = {};\n  list: Observable<SFSchemaEnum[]>;\n  typing: string = '';\n  @ViewChild(NgModel, { static: false }) private ngModel: NgModel;\n  private filterOption: (input: string, option: SFSchemaEnum) => boolean;\n  private isAsync = false;\n  private fixData: SFSchemaEnum[] = [];\n\n  updateValue(item: NzAutocompleteOptionComponent): void {\n    this.typing = item.nzLabel!;\n    const data: SFSchemaEnum = item.nzValue;\n    this.setValue(data.value);\n    if (this.ui.change) {\n      this.ui.change(item, data);\n    }\n  }\n\n  _setValue(item: SFSchemaEnum): void {\n    let val = item.toString();\n    if (typeof item !== 'string') {\n      val = item.value;\n    }\n    this.setValue(val);\n  }\n\n  afterViewInit(): void {\n    const { backfill, defaultActiveFirstOption, nzWidth, filterOption, asyncData } = this.ui;\n    this.i = {\n      backfill: toBool(backfill, false),\n      defaultActiveFirstOption: toBool(defaultActiveFirstOption, true),\n      width: nzWidth || undefined,\n    };\n\n    let filterOptionValue = filterOption == null ? true : filterOption;\n    if (typeof filterOptionValue === 'boolean') {\n      filterOptionValue = (input: string, option: SFSchemaEnum) => option.label.toLowerCase().indexOf((input || '').toLowerCase()) > -1;\n    }\n    this.filterOption = filterOptionValue;\n\n    this.isAsync = !!asyncData;\n    const orgTime = +(this.ui.debounceTime || 0);\n    const time = Math.max(0, this.isAsync ? Math.max(50, orgTime) : orgTime);\n\n    this.list = this.ngModel.valueChanges!.pipe(\n      debounceTime(time),\n      startWith(''),\n      mergeMap(input => (this.isAsync ? asyncData!(input) : this.filterData(input))),\n      map(res => getEnum(res, null, this.schema.readOnly!)),\n    );\n  }\n\n  reset(value: SFValue): void {\n    this.typing = this.value;\n    if (this.isAsync) return;\n    switch (this.ui.type) {\n      case 'email':\n        this.fixData = getCopyEnum(this.schema.enum! || this.formProperty.options.uiEmailSuffixes, null, this.schema.readOnly!);\n        break;\n      default:\n        this.fixData = getCopyEnum(this.schema.enum!, value, this.schema.readOnly!);\n        break;\n    }\n  }\n\n  private filterData(input: string): Observable<SFSchemaEnum[]> | Observable<string[]> {\n    switch (this.ui.type) {\n      case 'email':\n        return this.addEmailSuffix(input);\n      default:\n        return of(this.fixData.filter(option => this.filterOption(input, option)));\n    }\n  }\n\n  private addEmailSuffix(value: string): Observable<string[]> {\n    return of(!value || ~value.indexOf('@') ? [] : this.fixData.map(domain => `${value}@${domain.label}`));\n  }\n}\n"]}