UNPKG

@c-standard/angular-devui-extension

Version:

an extensional components lib for devui

145 lines 23.4 kB
import { Component, ContentChildren, EventEmitter, forwardRef, Input, Output, ViewChild, } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { DropDownDirective } from 'ng-devui'; import { TemplateDirective } from '@c-standard/angular-devui-extension/template'; import { ObjToValuePipe } from '@c-standard/angular-devui-extension/utils'; import * as i0 from "@angular/core"; import * as i1 from "@c-standard/angular-devui-extension/utils"; import * as i2 from "ng-devui"; import * as i3 from "@angular/common"; import * as i4 from "@c-standard/angular-devui-extension/template"; const SELECT_BOX_PRO_CONTROL_VALUE_ACCESSOR = { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => SelectBoxProComponent), multi: true, }; export class SelectBoxProComponent { constructor(_ref, _obj2value) { this._ref = _ref; this._obj2value = _obj2value; this.disabled = false; this.contentTemplate = 'template'; this.valueChange = new EventEmitter(); this.initialized = new EventEmitter(); this.expanded = new EventEmitter(); this.collapsed = new EventEmitter(); this.options = []; this.expand = false; this.displayValue = null; this.onTouchedCallback = () => { }; this.onChangeCallback = (_v) => { }; } get value() { return this._value; } set value(value) { this._value = value; if (this._value) { this.onChangeCallback(value); this.writeDisplayText(); } } get dataSource() { return this._dataSource || []; } set dataSource(value) { this._dataSource = value; if (this.dataSource instanceof Array) { this.options = this.dataSource; } } ngOnInit() { this.initialized.emit({ element: this._ref.nativeElement, component: this, }); } registerOnChange(fn) { this.onChangeCallback = fn; } registerOnTouched(fn) { this.onTouchedCallback = fn; } setDisabledState(isDisabled) { this.disabled = isDisabled; } writeValue(value) { this._value = value; this.writeDisplayText(); } onDropDownBoxToggle(expanded) { if (expanded) { this.expand = true; this.expanded.emit(); } else { this.expand = false; this.collapsed.emit(); } } collapse() { if (this.dropDownBox?.isOpen) { this.expand = false; return this.dropDownBox.toggle(); } return false; } get templates() { if (this.definitions != null) { const templates = {}; for (const definition of this.definitions.toArray()) { templates[definition.template] = definition.templateRef; } return templates; } else { return {}; } } writeDisplayText() { if (this.value instanceof Object && this.displayExpr != undefined) { this.displayValue = this.value[this.displayExpr]; } else { this.displayValue = this.value; } } } SelectBoxProComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SelectBoxProComponent, deps: [{ token: i0.ElementRef }, { token: i1.ObjToValuePipe }], target: i0.ɵɵFactoryTarget.Component }); SelectBoxProComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: SelectBoxProComponent, selector: "d-select-box-pro", inputs: { value: "value", dataSource: "dataSource", disabled: "disabled", valueExpr: "valueExpr", displayExpr: "displayExpr", placeholder: "placeholder", contentTemplate: "contentTemplate" }, outputs: { valueChange: "valueChange", initialized: "initialized", expanded: "expanded", collapsed: "collapsed" }, providers: [ObjToValuePipe, SELECT_BOX_PRO_CONTROL_VALUE_ACCESSOR], queries: [{ propertyName: "definitions", predicate: TemplateDirective }], viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }, { propertyName: "dropDownBox", first: true, predicate: ["dropDownBox"], descendants: true, read: DropDownDirective }], ngImport: i0, template: "<div\r\n dDropDown\r\n #dropDownBox=\"d-dropdown\"\r\n class=\"dropdown-box devui-input-group devui-dropdown-origin\"\r\n [trigger]=\"'manually'\"\r\n [closeScope]=\"'blank'\"\r\n (toggleEvent)=\"onDropDownBoxToggle($event)\"\r\n>\r\n <input\r\n #input\r\n dDropDownToggle\r\n class=\"devui-form-control devui-select-input devui-input\"\r\n autocomplete=\"off\"\r\n readonly=\"readonly\"\r\n [placeholder]=\"placeholder\"\r\n (click)=\"dropDownBox.toggle()\"\r\n [value]=\"displayValue\"\r\n />\r\n <div\r\n class=\"devui-input-group-addon\"\r\n (click)=\"dropDownBox.toggle()\"\r\n >\r\n <i\r\n class=\"icon-chevron-down dropdown-icon\"\r\n [ngClass]=\"{ 'expand':expand, 'collapse': !expand }\"\r\n ></i>\r\n </div>\r\n\r\n <div\r\n dDropDownMenu\r\n class=\"devui-dropdown-menu\"\r\n >\r\n <ng-container\r\n *ngIf=\"options.length > 0\"\r\n [ngTemplateOutletContext]=\"{ $implicit: {data:options, value:value} }\"\r\n [ngTemplateOutlet]=\"templates[contentTemplate]\"\r\n >\r\n <!-- todo \u4F18\u5316\u9ED8\u8BA4\u9009\u9879\u7684\u5C55\u793A\u65B9\u5F0F -->\r\n <div *xTemplate=\"let data of 'template'\">{{ options.length }}</div>\r\n </ng-container>\r\n <div *ngIf=\"options.length <= 0\" class=\"x-no-data-tip\">\u65E0\u6570\u636E</div>\r\n </div>\r\n</div>\r\n", styles: [".dropdown-box{width:100%;display:flex;align-items:center}.dropdown-box .dropdown-icon{transition:all .3s}.dropdown-box .devui-dropdown-menu{width:100%}.x-no-data-tip{-webkit-user-select:none;user-select:none;cursor:not-allowed;padding:10px;color:var(--devui-disabled-text, #cfd0d3);background-color:var(--devui-disabled-bg, #f5f5f5)}.expand{transform:rotate(180deg)}.collapse{transform:rotate(0)}\n"], directives: [{ type: i2.DropDownDirective, selector: "[dDropDown]", inputs: ["isOpen", "disabled", "showAnimation", "trigger", "closeScope", "closeOnMouseLeaveMenu"], outputs: ["toggleEvent"], exportAs: ["d-dropdown"] }, { type: i2.DropDownToggleDirective, selector: "[dDropDownToggle]", inputs: ["toggleOnFocus", "autoFocus"], exportAs: ["d-dropdown-toggle"] }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i2.DropDownMenuDirective, selector: "[dDropDownMenu]", exportAs: ["d-dropdown-menu"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i4.TemplateDirective, selector: "[xTemplate][xTemplateOf]", inputs: ["xTemplateOf"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SelectBoxProComponent, decorators: [{ type: Component, args: [{ selector: 'd-select-box-pro', providers: [ObjToValuePipe, SELECT_BOX_PRO_CONTROL_VALUE_ACCESSOR], template: "<div\r\n dDropDown\r\n #dropDownBox=\"d-dropdown\"\r\n class=\"dropdown-box devui-input-group devui-dropdown-origin\"\r\n [trigger]=\"'manually'\"\r\n [closeScope]=\"'blank'\"\r\n (toggleEvent)=\"onDropDownBoxToggle($event)\"\r\n>\r\n <input\r\n #input\r\n dDropDownToggle\r\n class=\"devui-form-control devui-select-input devui-input\"\r\n autocomplete=\"off\"\r\n readonly=\"readonly\"\r\n [placeholder]=\"placeholder\"\r\n (click)=\"dropDownBox.toggle()\"\r\n [value]=\"displayValue\"\r\n />\r\n <div\r\n class=\"devui-input-group-addon\"\r\n (click)=\"dropDownBox.toggle()\"\r\n >\r\n <i\r\n class=\"icon-chevron-down dropdown-icon\"\r\n [ngClass]=\"{ 'expand':expand, 'collapse': !expand }\"\r\n ></i>\r\n </div>\r\n\r\n <div\r\n dDropDownMenu\r\n class=\"devui-dropdown-menu\"\r\n >\r\n <ng-container\r\n *ngIf=\"options.length > 0\"\r\n [ngTemplateOutletContext]=\"{ $implicit: {data:options, value:value} }\"\r\n [ngTemplateOutlet]=\"templates[contentTemplate]\"\r\n >\r\n <!-- todo \u4F18\u5316\u9ED8\u8BA4\u9009\u9879\u7684\u5C55\u793A\u65B9\u5F0F -->\r\n <div *xTemplate=\"let data of 'template'\">{{ options.length }}</div>\r\n </ng-container>\r\n <div *ngIf=\"options.length <= 0\" class=\"x-no-data-tip\">\u65E0\u6570\u636E</div>\r\n </div>\r\n</div>\r\n", styles: [".dropdown-box{width:100%;display:flex;align-items:center}.dropdown-box .dropdown-icon{transition:all .3s}.dropdown-box .devui-dropdown-menu{width:100%}.x-no-data-tip{-webkit-user-select:none;user-select:none;cursor:not-allowed;padding:10px;color:var(--devui-disabled-text, #cfd0d3);background-color:var(--devui-disabled-bg, #f5f5f5)}.expand{transform:rotate(180deg)}.collapse{transform:rotate(0)}\n"] }] }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.ObjToValuePipe }]; }, propDecorators: { value: [{ type: Input }], dataSource: [{ type: Input }], disabled: [{ type: Input }], valueExpr: [{ type: Input }], displayExpr: [{ type: Input }], placeholder: [{ type: Input }], contentTemplate: [{ type: Input }], valueChange: [{ type: Output }], initialized: [{ type: Output }], expanded: [{ type: Output }], collapsed: [{ type: Output }], input: [{ type: ViewChild, args: ['input'] }], dropDownBox: [{ type: ViewChild, args: ['dropDownBox', { read: DropDownDirective }] }], definitions: [{ type: ContentChildren, args: [TemplateDirective] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-box-pro.component.js","sourceRoot":"","sources":["../../../../projects/components/select/select-box-pro.component.ts","../../../../projects/components/select/select-box-pro.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,eAAe,EAAc,YAAY,EAAE,UAAU,EAAE,KAAK,EAAU,MAAM,EAA0B,SAAS,GAAG,MAAM,eAAe,CAAC;AAC5J,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAE7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,8CAA8C,CAAC;AACjF,OAAO,EAAE,cAAc,EAAE,MAAM,2CAA2C,CAAC;;;;;;AAE3E,MAAM,qCAAqC,GAAQ;IAE/C,OAAO,EAAE,iBAAiB;IAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC;IACpD,KAAK,EAAE,IAAI;CACd,CAAC;AAQF,MAAM,OAAO,qBAAqB;IAiD9B,YAAoB,IAAgB,EAAU,UAA0B;QAApD,SAAI,GAAJ,IAAI,CAAY;QAAU,eAAU,GAAV,UAAU,CAAgB;QArB/D,aAAQ,GAAY,KAAK,CAAC;QAI1B,oBAAe,GAAW,UAAU,CAAC;QACpC,gBAAW,GAAsB,IAAI,YAAY,EAAO,CAAC;QACzD,gBAAW,GAAsB,IAAI,YAAY,EAAO,CAAC;QACzD,aAAQ,GAAsB,IAAI,YAAY,EAAO,CAAC;QACtD,cAAS,GAAsB,IAAI,YAAY,EAAO,CAAC;QAMjE,YAAO,GAAU,EAAE,CAAC;QACpB,WAAM,GAAY,KAAK,CAAC;QACxB,iBAAY,GAAkB,IAAI,CAAC;QAE3B,sBAAiB,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;QAC7B,qBAAgB,GAAG,CAAC,EAAO,EAAE,EAAE,GAAE,CAAC,CAAC;IAEgC,CAAC;IA/C5E,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED,IACI,KAAK,CAAC,KAAU;QAChB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,IAAI,CAAC,MAAM,EAAE;YACb,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;YAC7B,IAAI,CAAC,gBAAgB,EAAE,CAAC;SAC3B;IACL,CAAC;IAGD,IAAI,UAAU;QACV,OAAO,IAAI,CAAC,WAAW,IAAI,EAAE,CAAC;IAClC,CAAC;IAED,IACI,UAAU,CAAC,KAA8B;QACzC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,IAAI,CAAC,UAAU,YAAY,KAAK,EAAE;YAClC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC;SAClC;IACL,CAAC;IAyBD,QAAQ;QACJ,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;YAClB,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,aAAa;YAChC,SAAS,EAAE,IAAI;SAClB,CAAC,CAAC;IACP,CAAC;IAED,gBAAgB,CAAC,EAAO;QACpB,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;IAC/B,CAAC;IAED,iBAAiB,CAAC,EAAO;QACrB,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;IAChC,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAChC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC/B,CAAC;IAED,UAAU,CAAC,KAAU;QACjB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC5B,CAAC;IAED,mBAAmB,CAAC,QAAiB;QACjC,IAAI,QAAQ,EAAE;YACV,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;YACnB,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;SACxB;aAAM;YACH,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;YACpB,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;SACzB;IACL,CAAC;IAED,QAAQ;QACJ,IAAI,IAAI,CAAC,WAAW,EAAE,MAAM,EAAE;YAC1B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;YACpB,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;SACpC;QACD,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,IAAW,SAAS;QAChB,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,EAAE;YAC1B,MAAM,SAAS,GAAwC,EAAE,CAAC;YAC1D,KAAK,MAAM,UAAU,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,EAAE;gBACjD,SAAS,CAAC,UAAU,CAAC,QAAQ,CAAC,GAAG,UAAU,CAAC,WAAW,CAAC;aAC3D;YACD,OAAO,SAAS,CAAC;SACpB;aAAM;YACH,OAAO,EAAE,CAAC;SACb;IACL,CAAC;IAED,gBAAgB;QACZ,IAAI,IAAI,CAAC,KAAK,YAAY,MAAM,IAAI,IAAI,CAAC,WAAW,IAAI,SAAS,EAAE;YAC/D,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SACpD;aAAM;YACH,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC;SAClC;IACL,CAAC;;kHA/GQ,qBAAqB;sGAArB,qBAAqB,8VAFnB,CAAC,cAAc,EAAE,qCAAqC,CAAC,sDA0CjD,iBAAiB,qMADD,iBAAiB,6BC3DtD,2+CA2CA;2FDvBa,qBAAqB;kBANjC,SAAS;+BACI,kBAAkB,aAGjB,CAAC,cAAc,EAAE,qCAAqC,CAAC;8HAS9D,KAAK;sBADR,KAAK;gBAeF,UAAU;sBADb,KAAK;gBAQG,QAAQ;sBAAhB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACI,WAAW;sBAApB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,QAAQ;sBAAjB,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBAEa,KAAK;sBAAxB,SAAS;uBAAC,OAAO;gBACmC,WAAW;sBAA/D,SAAS;uBAAC,aAAa,EAAE,EAAC,IAAI,EAAE,iBAAiB,EAAC;gBACf,WAAW;sBAA9C,eAAe;uBAAC,iBAAiB","sourcesContent":["import { Component, ContentChildren, ElementRef, EventEmitter, forwardRef, Input, OnInit, Output, QueryList, TemplateRef, ViewChild, } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { DropDownDirective } from 'ng-devui';\r\nimport { Observable } from 'rxjs';\r\nimport { TemplateDirective } from '@c-standard/angular-devui-extension/template';\r\nimport { ObjToValuePipe } from '@c-standard/angular-devui-extension/utils';\r\n\r\nconst SELECT_BOX_PRO_CONTROL_VALUE_ACCESSOR: any = {\r\n\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => SelectBoxProComponent),\r\n    multi: true,\r\n};\r\n\r\n@Component({\r\n    selector: 'd-select-box-pro',\r\n    templateUrl: './select-box-pro.component.html',\r\n    styleUrls: ['./select-box-pro.component.less'],\r\n    providers: [ObjToValuePipe, SELECT_BOX_PRO_CONTROL_VALUE_ACCESSOR],\r\n})\r\nexport class SelectBoxProComponent implements OnInit, ControlValueAccessor {\r\n    private _value: any;\r\n    get value(): any {\r\n        return this._value;\r\n    }\r\n\r\n    @Input()\r\n    set value(value: any) {\r\n        this._value = value;\r\n        if (this._value) {\r\n            this.onChangeCallback(value);\r\n            this.writeDisplayText();\r\n        }\r\n    }\r\n\r\n    private _dataSource?: any[] | Observable<any>;\r\n    get dataSource(): any[] | Observable<any> {\r\n        return this._dataSource || [];\r\n    }\r\n\r\n    @Input()\r\n    set dataSource(value: any[] | Observable<any>) {\r\n        this._dataSource = value;\r\n        if (this.dataSource instanceof Array) {\r\n            this.options = this.dataSource;\r\n        }\r\n    }\r\n\r\n    @Input() disabled: boolean = false;\r\n    @Input() valueExpr?: string;\r\n    @Input() displayExpr?: string;\r\n    @Input() placeholder?: string;\r\n    @Input() contentTemplate: string = 'template';\r\n    @Output() valueChange: EventEmitter<any> = new EventEmitter<any>();\r\n    @Output() initialized: EventEmitter<any> = new EventEmitter<any>();\r\n    @Output() expanded: EventEmitter<any> = new EventEmitter<any>();\r\n    @Output() collapsed: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n    @ViewChild('input') input?: ElementRef;\r\n    @ViewChild('dropDownBox', {read: DropDownDirective}) dropDownBox?: DropDownDirective;\r\n    @ContentChildren(TemplateDirective) definitions?: QueryList<TemplateDirective>;\r\n\r\n    options: any[] = [];\r\n    expand: boolean = false;\r\n    displayValue: string | null = null;\r\n\r\n    private onTouchedCallback = () => {};\r\n    private onChangeCallback = (_v: any) => {};\r\n\r\n    constructor(private _ref: ElementRef, private _obj2value: ObjToValuePipe) {}\r\n\r\n    ngOnInit(): void {\r\n        this.initialized.emit({\r\n            element: this._ref.nativeElement,\r\n            component: this,\r\n        });\r\n    }\r\n\r\n    registerOnChange(fn: any): void {\r\n        this.onChangeCallback = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any): void {\r\n        this.onTouchedCallback = fn;\r\n    }\r\n\r\n    setDisabledState(isDisabled: boolean): void {\r\n        this.disabled = isDisabled;\r\n    }\r\n\r\n    writeValue(value: any): void {\r\n        this._value = value;\r\n        this.writeDisplayText();\r\n    }\r\n\r\n    onDropDownBoxToggle(expanded: boolean) {\r\n        if (expanded) {\r\n            this.expand = true;\r\n            this.expanded.emit();\r\n        } else {\r\n            this.expand = false;\r\n            this.collapsed.emit();\r\n        }\r\n    }\r\n\r\n    collapse() {\r\n        if (this.dropDownBox?.isOpen) {\r\n            this.expand = false;\r\n            return this.dropDownBox.toggle();\r\n        }\r\n        return false;\r\n    }\r\n\r\n    public get templates(): { [key: string]: TemplateRef<any> } {\r\n        if (this.definitions != null) {\r\n            const templates: { [key: string]: TemplateRef<any> } = {};\r\n            for (const definition of this.definitions.toArray()) {\r\n                templates[definition.template] = definition.templateRef;\r\n            }\r\n            return templates;\r\n        } else {\r\n            return {};\r\n        }\r\n    }\r\n\r\n    writeDisplayText() {\r\n        if (this.value instanceof Object && this.displayExpr != undefined) {\r\n            this.displayValue = this.value[this.displayExpr];\r\n        } else {\r\n            this.displayValue = this.value;\r\n        }\r\n    }\r\n}\r\n","<div\r\n    dDropDown\r\n    #dropDownBox=\"d-dropdown\"\r\n    class=\"dropdown-box devui-input-group devui-dropdown-origin\"\r\n    [trigger]=\"'manually'\"\r\n    [closeScope]=\"'blank'\"\r\n    (toggleEvent)=\"onDropDownBoxToggle($event)\"\r\n>\r\n    <input\r\n        #input\r\n        dDropDownToggle\r\n        class=\"devui-form-control devui-select-input devui-input\"\r\n        autocomplete=\"off\"\r\n        readonly=\"readonly\"\r\n        [placeholder]=\"placeholder\"\r\n        (click)=\"dropDownBox.toggle()\"\r\n        [value]=\"displayValue\"\r\n    />\r\n    <div\r\n        class=\"devui-input-group-addon\"\r\n        (click)=\"dropDownBox.toggle()\"\r\n    >\r\n        <i\r\n            class=\"icon-chevron-down dropdown-icon\"\r\n            [ngClass]=\"{ 'expand':expand, 'collapse': !expand }\"\r\n        ></i>\r\n    </div>\r\n\r\n    <div\r\n        dDropDownMenu\r\n        class=\"devui-dropdown-menu\"\r\n    >\r\n        <ng-container\r\n            *ngIf=\"options.length > 0\"\r\n            [ngTemplateOutletContext]=\"{ $implicit: {data:options, value:value} }\"\r\n            [ngTemplateOutlet]=\"templates[contentTemplate]\"\r\n        >\r\n            <!-- todo 优化默认选项的展示方式 -->\r\n            <div *xTemplate=\"let data of 'template'\">{{ options.length }}</div>\r\n        </ng-container>\r\n        <div *ngIf=\"options.length <= 0\" class=\"x-no-data-tip\">无数据</div>\r\n    </div>\r\n</div>\r\n"]}