@wavemaker/app-ng-runtime 11.9.0-next.24956 → 11.9.0-next.27453
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- app-ng-runtime/build-task/bundles/index.umd.js +1 -1
- app-ng-runtime/build-task/esm2022/input/default/switch/switch.build.mjs +2 -2
- app-ng-runtime/build-task/fesm2022/index.mjs +1 -1
- app-ng-runtime/build-task/fesm2022/index.mjs.map +1 -1
- app-ng-runtime/components/input/color-picker/bundles/index.umd.js +1 -0
- app-ng-runtime/components/input/color-picker/esm2022/color-picker.component.mjs +2 -1
- app-ng-runtime/components/input/color-picker/fesm2022/index.mjs +1 -0
- app-ng-runtime/components/input/color-picker/fesm2022/index.mjs.map +1 -1
- app-ng-runtime/components/input/default/bundles/index.umd.js +5 -4
- app-ng-runtime/components/input/default/esm2022/switch/switch.component.mjs +6 -5
- app-ng-runtime/components/input/default/fesm2022/index.mjs +5 -4
- app-ng-runtime/components/input/default/fesm2022/index.mjs.map +1 -1
- app-ng-runtime/package.json +1 -1
|
@@ -68,6 +68,7 @@
|
|
|
68
68
|
}
|
|
69
69
|
}
|
|
70
70
|
colorPickerOpen(value) {
|
|
71
|
+
$('.hex-text input').attr('placeholder', 'Enter hex color code');
|
|
71
72
|
// Whenever autoclose property is set to 'always', adding the onclick listener to the colorPicker container to close the picker.
|
|
72
73
|
if (this.autoclose === base.AUTOCLOSE_TYPE.ALWAYS) {
|
|
73
74
|
const colorPickerContainer = this.nativeElement.querySelector(`.color-picker`);
|
|
@@ -31,6 +31,7 @@ export class ColorPickerComponent extends BaseFormCustomComponent {
|
|
|
31
31
|
}
|
|
32
32
|
}
|
|
33
33
|
colorPickerOpen(value) {
|
|
34
|
+
$('.hex-text input').attr('placeholder', 'Enter hex color code');
|
|
34
35
|
// Whenever autoclose property is set to 'always', adding the onclick listener to the colorPicker container to close the picker.
|
|
35
36
|
if (this.autoclose === AUTOCLOSE_TYPE.ALWAYS) {
|
|
36
37
|
const colorPickerContainer = this.nativeElement.querySelector(`.color-picker`);
|
|
@@ -130,4 +131,4 @@ export class ColorPickerComponent extends BaseFormCustomComponent {
|
|
|
130
131
|
args: [ColorPickerDirective]
|
|
131
132
|
}] }); })();
|
|
132
133
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ColorPickerComponent, { className: "ColorPickerComponent", filePath: "color-picker.component.ts", lineNumber: 27 }); })();
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-picker.component.js","sourceRoot":"","sources":["../../../../../projects/components/widgets/input/color-picker/src/color-picker.component.ts","../../../../../projects/components/widgets/input/color-picker/src/color-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, Inject, Injector, Optional, ViewChild} from '@angular/core';\nimport {NG_VALIDATORS, NG_VALUE_ACCESSOR, NgModel} from '@angular/forms';\nimport {ColorPickerDirective} from 'ngx-color-picker';\n\nimport {addClass, removeClass} from '@wm/core';\nimport {AUTOCLOSE_TYPE, IWidgetConfig, provideAs, provideAsWidgetRef, styler} from '@wm/components/base';\nimport {BaseFormCustomComponent} from '@wm/components/input';\nimport {registerProps} from './color-picker.props';\n\n\nconst DEFAULT_CLS = 'input-group app-colorpicker';\nconst WIDGET_CONFIG: IWidgetConfig = {\n    widgetType: 'wm-colorpicker',\n    hostClass: DEFAULT_CLS,\n    displayType: 'inline-block'\n};\n\n@Component({\n    selector: '[wmColorPicker]',\n    templateUrl: './color-picker.component.html',\n    providers: [\n        provideAs(ColorPickerComponent, NG_VALUE_ACCESSOR, true),\n        provideAs(ColorPickerComponent, NG_VALIDATORS, true),\n        provideAsWidgetRef(ColorPickerComponent)\n    ]\n})\nexport class ColorPickerComponent extends BaseFormCustomComponent {\n    static initializeProps = registerProps();\n\n    public required: boolean;\n    public readonly: boolean;\n    public disabled: boolean;\n    public name: string;\n    public placeholder: any;\n    public tabindex: any;\n    public shortcutkey: string;\n    public outsideclick: boolean;\n    public autoclose: string;\n    public hint: string;\n    public arialabel: string;\n\n\n    @ViewChild(NgModel) ngModel: NgModel;\n    @ViewChild('input', { static: true, read: ElementRef }) inputEl: ElementRef;\n    @ViewChild(ColorPickerDirective) cpDirective: ColorPickerDirective;\n\n    constructor(inj: Injector, @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any) {\n        super(inj, WIDGET_CONFIG, explicitContext);\n        styler(this.nativeElement, this);\n    }\n\n    // To remove space occupied by colorpicker when it is closed\n    public colorPickerToggleChange(isOpen: boolean) {\n        const colorPickerContainer = this.nativeElement.querySelector(`.color-picker`) as HTMLElement;\n        if (colorPickerContainer) {\n            (!isOpen) ? addClass(colorPickerContainer, 'hidden') : removeClass(colorPickerContainer, 'hidden');\n        }\n    }\n\n    colorPickerOpen(value: string) {\n        // Whenever autoclose property is set to 'always', adding the onclick listener to the colorPicker container to close the picker.\n        if (this.autoclose === AUTOCLOSE_TYPE.ALWAYS) {\n            const colorPickerContainer = this.nativeElement.querySelector(`.color-picker`) as HTMLElement;\n            colorPickerContainer.onclick = () => this.cpDirective.closeDialog();\n        }\n    }\n\n    // This mehtod is used to show/open the colorpicker popup.\n    open() {\n        this.cpDirective.openDialog();\n    }\n\n    // This mehtod is used to hide/close the colorpicker popup.\n    close() {\n        this.cpDirective.closeDialog();\n    }\n\n\n    // change and blur events are added from the template\n    protected handleEvent(node: HTMLElement, eventName: string, callback: Function, locals: any) {\n        if (eventName !== 'change' && eventName !== 'blur') {\n            super.handleEvent(this.inputEl.nativeElement, eventName, callback, locals);\n        }\n    }\n\n    public handleChange(newVal: boolean) {\n        this.invokeOnChange(this.datavalue, {type: 'change'}, this.ngModel.valid);\n    }\n\n    protected onPropertyChange(key: string, nv: any, ov: any) {\n        if (key === 'tabindex') {\n            return;\n        }\n        if (key === 'required') {\n            /* WMS-18269 | Update Angular about the required attr value change */\n            this._onChange(this.datavalue);\n            return;\n        }\n        if (key === 'datavalue') {\n            this._onChange(nv);\n            return;\n        }\n        if (key === 'autoclose') {\n            this.outsideclick = (nv === AUTOCLOSE_TYPE.OUTSIDECLICK || nv === AUTOCLOSE_TYPE.ALWAYS) ? true : false;\n        }\n        super.onPropertyChange(key, nv, ov);\n    }\n}\n","<input aria-haspopup=\"true\" class=\"form-control app-textbox\"\n       #input\n       focus-target\n       [attr.name]=\"name\"\n       [attr.aria-label]=\"arialabel\"\n       [(colorPicker)]=\"datavalue\"\n       (colorPickerChange)=\"handleChange($event);\"\n       (cpToggleChange)=\"colorPickerToggleChange($event)\"\n       [cpPosition]=\"'bottom'\"\n       [cpCloseClickOutside]=\"outsideclick\"\n       (colorPickerOpen)=\"colorPickerOpen($event)\"\n       [attr.placeholder]=\"placeholder\"\n       [disabled]=\"readonly || disabled\"\n       [required]=\"required\"\n       [tabindex]=\"tabindex\"\n       [(ngModel)]=\"datavalue\"\n       (ngModelChange)=\"handleChange($event);\"\n       [ngModelOptions]=\"{updateOn: 'change', standalone: true}\"\n       (blur)=\"invokeOnTouched($event)\"\n       [attr.accesskey]=\"shortcutkey\">\n<span class=\"input-group-addon colorpicker-container\">\n    <i class=\"colored-box\" [style.backgroundColor]=\"datavalue\">&nbsp;</i>\n</span>\n"]}
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-picker.component.js","sourceRoot":"","sources":["../../../../../projects/components/widgets/input/color-picker/src/color-picker.component.ts","../../../../../projects/components/widgets/input/color-picker/src/color-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, Inject, Injector, Optional, ViewChild} from '@angular/core';\nimport {NG_VALIDATORS, NG_VALUE_ACCESSOR, NgModel} from '@angular/forms';\nimport {ColorPickerDirective} from 'ngx-color-picker';\n\nimport {addClass, removeClass} from '@wm/core';\nimport {AUTOCLOSE_TYPE, IWidgetConfig, provideAs, provideAsWidgetRef, styler} from '@wm/components/base';\nimport {BaseFormCustomComponent} from '@wm/components/input';\nimport {registerProps} from './color-picker.props';\n\n\nconst DEFAULT_CLS = 'input-group app-colorpicker';\nconst WIDGET_CONFIG: IWidgetConfig = {\n    widgetType: 'wm-colorpicker',\n    hostClass: DEFAULT_CLS,\n    displayType: 'inline-block'\n};\n\n@Component({\n    selector: '[wmColorPicker]',\n    templateUrl: './color-picker.component.html',\n    providers: [\n        provideAs(ColorPickerComponent, NG_VALUE_ACCESSOR, true),\n        provideAs(ColorPickerComponent, NG_VALIDATORS, true),\n        provideAsWidgetRef(ColorPickerComponent)\n    ]\n})\nexport class ColorPickerComponent extends BaseFormCustomComponent {\n    static initializeProps = registerProps();\n\n    public required: boolean;\n    public readonly: boolean;\n    public disabled: boolean;\n    public name: string;\n    public placeholder: any;\n    public tabindex: any;\n    public shortcutkey: string;\n    public outsideclick: boolean;\n    public autoclose: string;\n    public hint: string;\n    public arialabel: string;\n\n\n    @ViewChild(NgModel) ngModel: NgModel;\n    @ViewChild('input', { static: true, read: ElementRef }) inputEl: ElementRef;\n    @ViewChild(ColorPickerDirective) cpDirective: ColorPickerDirective;\n\n    constructor(inj: Injector, @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any) {\n        super(inj, WIDGET_CONFIG, explicitContext);\n        styler(this.nativeElement, this);\n    }\n\n    // To remove space occupied by colorpicker when it is closed\n    public colorPickerToggleChange(isOpen: boolean) {\n        const colorPickerContainer = this.nativeElement.querySelector(`.color-picker`) as HTMLElement;\n        if (colorPickerContainer) {\n            (!isOpen) ? addClass(colorPickerContainer, 'hidden') : removeClass(colorPickerContainer, 'hidden');\n        }\n    }\n\n    colorPickerOpen(value: string) {\n        $('.hex-text input').attr('placeholder', 'Enter hex color code')\n        // Whenever autoclose property is set to 'always', adding the onclick listener to the colorPicker container to close the picker.\n        if (this.autoclose === AUTOCLOSE_TYPE.ALWAYS) {\n            const colorPickerContainer = this.nativeElement.querySelector(`.color-picker`) as HTMLElement;\n            colorPickerContainer.onclick = () => this.cpDirective.closeDialog();\n        }\n    }\n\n    // This mehtod is used to show/open the colorpicker popup.\n    open() {\n        this.cpDirective.openDialog();\n    }\n\n    // This mehtod is used to hide/close the colorpicker popup.\n    close() {\n        this.cpDirective.closeDialog();\n    }\n\n\n    // change and blur events are added from the template\n    protected handleEvent(node: HTMLElement, eventName: string, callback: Function, locals: any) {\n        if (eventName !== 'change' && eventName !== 'blur') {\n            super.handleEvent(this.inputEl.nativeElement, eventName, callback, locals);\n        }\n    }\n\n    public handleChange(newVal: boolean) {\n        this.invokeOnChange(this.datavalue, {type: 'change'}, this.ngModel.valid);\n    }\n\n    protected onPropertyChange(key: string, nv: any, ov: any) {\n        if (key === 'tabindex') {\n            return;\n        }\n        if (key === 'required') {\n            /* WMS-18269 | Update Angular about the required attr value change */\n            this._onChange(this.datavalue);\n            return;\n        }\n        if (key === 'datavalue') {\n            this._onChange(nv);\n            return;\n        }\n        if (key === 'autoclose') {\n            this.outsideclick = (nv === AUTOCLOSE_TYPE.OUTSIDECLICK || nv === AUTOCLOSE_TYPE.ALWAYS) ? true : false;\n        }\n        super.onPropertyChange(key, nv, ov);\n    }\n}\n","<input aria-haspopup=\"true\" class=\"form-control app-textbox\"\n       #input\n       focus-target\n       [attr.name]=\"name\"\n       [attr.aria-label]=\"arialabel\"\n       [(colorPicker)]=\"datavalue\"\n       (colorPickerChange)=\"handleChange($event);\"\n       (cpToggleChange)=\"colorPickerToggleChange($event)\"\n       [cpPosition]=\"'bottom'\"\n       [cpCloseClickOutside]=\"outsideclick\"\n       (colorPickerOpen)=\"colorPickerOpen($event)\"\n       [attr.placeholder]=\"placeholder\"\n       [disabled]=\"readonly || disabled\"\n       [required]=\"required\"\n       [tabindex]=\"tabindex\"\n       [(ngModel)]=\"datavalue\"\n       (ngModelChange)=\"handleChange($event);\"\n       [ngModelOptions]=\"{updateOn: 'change', standalone: true}\"\n       (blur)=\"invokeOnTouched($event)\"\n       [attr.accesskey]=\"shortcutkey\">\n<span class=\"input-group-addon colorpicker-container\">\n    <i class=\"colored-box\" [style.backgroundColor]=\"datavalue\">&nbsp;</i>\n</span>\n"]}
|
|
@@ -52,6 +52,7 @@ class ColorPickerComponent extends BaseFormCustomComponent {
|
|
|
52
52
|
}
|
|
53
53
|
}
|
|
54
54
|
colorPickerOpen(value) {
|
|
55
|
+
$('.hex-text input').attr('placeholder', 'Enter hex color code');
|
|
55
56
|
// Whenever autoclose property is set to 'always', adding the onclick listener to the colorPicker container to close the picker.
|
|
56
57
|
if (this.autoclose === AUTOCLOSE_TYPE.ALWAYS) {
|
|
57
58
|
const colorPickerContainer = this.nativeElement.querySelector(`.color-picker`);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../../../../projects/components/widgets/input/color-picker/src/color-picker.props.ts","../../../../../projects/components/widgets/input/color-picker/src/color-picker.component.ts","../../../../../projects/components/widgets/input/color-picker/src/color-picker.component.html","../../../../../projects/components/widgets/input/color-picker/src/color-picker.module.ts","../../../../../projects/components/widgets/input/color-picker/src/index.ts"],"sourcesContent":["import {PROP_BOOLEAN, PROP_NUMBER, PROP_STRING, register, registerFormWidget} from '@wm/components/base';\nimport {FormWidgetType} from '@wm/core';\n\nexport const colorPickerProps = new Map(\n [\n ['autoclose', {value: 'outsideClick', ...PROP_STRING}],\n ['class', PROP_STRING],\n ['datavalue', PROP_STRING],\n ['disabled', PROP_BOOLEAN],\n ['hint', PROP_STRING],\n ['arialabel', PROP_STRING],\n ['name', PROP_STRING],\n ['placeholder', {value: 'Select Color', ...PROP_STRING}],\n ['readonly', PROP_BOOLEAN],\n ['required', PROP_BOOLEAN],\n ['shortcutkey', PROP_STRING],\n ['show', {value: true, ...PROP_BOOLEAN}],\n ['tabindex', {value: 0, ...PROP_NUMBER}]\n ]\n);\n\nexport const registerProps = () => {\n register(\n 'wm-colorpicker',\n colorPickerProps\n );\n registerFormWidget(\n FormWidgetType.COLORPICKER,\n new Map(colorPickerProps)\n );\n};\n","import {Component, ElementRef, Inject, Injector, Optional, ViewChild} from '@angular/core';\nimport {NG_VALIDATORS, NG_VALUE_ACCESSOR, NgModel} from '@angular/forms';\nimport {ColorPickerDirective} from 'ngx-color-picker';\n\nimport {addClass, removeClass} from '@wm/core';\nimport {AUTOCLOSE_TYPE, IWidgetConfig, provideAs, provideAsWidgetRef, styler} from '@wm/components/base';\nimport {BaseFormCustomComponent} from '@wm/components/input';\nimport {registerProps} from './color-picker.props';\n\n\nconst DEFAULT_CLS = 'input-group app-colorpicker';\nconst WIDGET_CONFIG: IWidgetConfig = {\n widgetType: 'wm-colorpicker',\n hostClass: DEFAULT_CLS,\n displayType: 'inline-block'\n};\n\n@Component({\n selector: '[wmColorPicker]',\n templateUrl: './color-picker.component.html',\n providers: [\n provideAs(ColorPickerComponent, NG_VALUE_ACCESSOR, true),\n provideAs(ColorPickerComponent, NG_VALIDATORS, true),\n provideAsWidgetRef(ColorPickerComponent)\n ]\n})\nexport class ColorPickerComponent extends BaseFormCustomComponent {\n static initializeProps = registerProps();\n\n public required: boolean;\n public readonly: boolean;\n public disabled: boolean;\n public name: string;\n public placeholder: any;\n public tabindex: any;\n public shortcutkey: string;\n public outsideclick: boolean;\n public autoclose: string;\n public hint: string;\n public arialabel: string;\n\n\n @ViewChild(NgModel) ngModel: NgModel;\n @ViewChild('input', { static: true, read: ElementRef }) inputEl: ElementRef;\n @ViewChild(ColorPickerDirective) cpDirective: ColorPickerDirective;\n\n constructor(inj: Injector, @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any) {\n super(inj, WIDGET_CONFIG, explicitContext);\n styler(this.nativeElement, this);\n }\n\n // To remove space occupied by colorpicker when it is closed\n public colorPickerToggleChange(isOpen: boolean) {\n const colorPickerContainer = this.nativeElement.querySelector(`.color-picker`) as HTMLElement;\n if (colorPickerContainer) {\n (!isOpen) ? addClass(colorPickerContainer, 'hidden') : removeClass(colorPickerContainer, 'hidden');\n }\n }\n\n colorPickerOpen(value: string) {\n // Whenever autoclose property is set to 'always', adding the onclick listener to the colorPicker container to close the picker.\n if (this.autoclose === AUTOCLOSE_TYPE.ALWAYS) {\n const colorPickerContainer = this.nativeElement.querySelector(`.color-picker`) as HTMLElement;\n colorPickerContainer.onclick = () => this.cpDirective.closeDialog();\n }\n }\n\n // This mehtod is used to show/open the colorpicker popup.\n open() {\n this.cpDirective.openDialog();\n }\n\n // This mehtod is used to hide/close the colorpicker popup.\n close() {\n this.cpDirective.closeDialog();\n }\n\n\n // change and blur events are added from the template\n protected handleEvent(node: HTMLElement, eventName: string, callback: Function, locals: any) {\n if (eventName !== 'change' && eventName !== 'blur') {\n super.handleEvent(this.inputEl.nativeElement, eventName, callback, locals);\n }\n }\n\n public handleChange(newVal: boolean) {\n this.invokeOnChange(this.datavalue, {type: 'change'}, this.ngModel.valid);\n }\n\n protected onPropertyChange(key: string, nv: any, ov: any) {\n if (key === 'tabindex') {\n return;\n }\n if (key === 'required') {\n /* WMS-18269 | Update Angular about the required attr value change */\n this._onChange(this.datavalue);\n return;\n }\n if (key === 'datavalue') {\n this._onChange(nv);\n return;\n }\n if (key === 'autoclose') {\n this.outsideclick = (nv === AUTOCLOSE_TYPE.OUTSIDECLICK || nv === AUTOCLOSE_TYPE.ALWAYS) ? true : false;\n }\n super.onPropertyChange(key, nv, ov);\n }\n}\n","<input aria-haspopup=\"true\" class=\"form-control app-textbox\"\n #input\n focus-target\n [attr.name]=\"name\"\n [attr.aria-label]=\"arialabel\"\n [(colorPicker)]=\"datavalue\"\n (colorPickerChange)=\"handleChange($event);\"\n (cpToggleChange)=\"colorPickerToggleChange($event)\"\n [cpPosition]=\"'bottom'\"\n [cpCloseClickOutside]=\"outsideclick\"\n (colorPickerOpen)=\"colorPickerOpen($event)\"\n [attr.placeholder]=\"placeholder\"\n [disabled]=\"readonly || disabled\"\n [required]=\"required\"\n [tabindex]=\"tabindex\"\n [(ngModel)]=\"datavalue\"\n (ngModelChange)=\"handleChange($event);\"\n [ngModelOptions]=\"{updateOn: 'change', standalone: true}\"\n (blur)=\"invokeOnTouched($event)\"\n [attr.accesskey]=\"shortcutkey\">\n<span class=\"input-group-addon colorpicker-container\">\n <i class=\"colored-box\" [style.backgroundColor]=\"datavalue\"> </i>\n</span>\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\n\nimport { ColorPickerModule as ngxColorPickerModule } from 'ngx-color-picker';\n\nimport { WmComponentsModule } from '@wm/components/base';\n\nimport { ColorPickerComponent } from './color-picker.component';\n\nconst components = [\n ColorPickerComponent\n];\n\n@NgModule({\n imports: [\n CommonModule,\n ngxColorPickerModule,\n FormsModule,\n WmComponentsModule\n ],\n declarations: [...components],\n exports: [...components]\n})\nexport class ColorPickerModule {\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public_api';\n"],"names":["ngxColorPickerModule"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../../../../projects/components/widgets/input/color-picker/src/color-picker.props.ts","../../../../../projects/components/widgets/input/color-picker/src/color-picker.component.ts","../../../../../projects/components/widgets/input/color-picker/src/color-picker.component.html","../../../../../projects/components/widgets/input/color-picker/src/color-picker.module.ts","../../../../../projects/components/widgets/input/color-picker/src/index.ts"],"sourcesContent":["import {PROP_BOOLEAN, PROP_NUMBER, PROP_STRING, register, registerFormWidget} from '@wm/components/base';\nimport {FormWidgetType} from '@wm/core';\n\nexport const colorPickerProps = new Map(\n [\n ['autoclose', {value: 'outsideClick', ...PROP_STRING}],\n ['class', PROP_STRING],\n ['datavalue', PROP_STRING],\n ['disabled', PROP_BOOLEAN],\n ['hint', PROP_STRING],\n ['arialabel', PROP_STRING],\n ['name', PROP_STRING],\n ['placeholder', {value: 'Select Color', ...PROP_STRING}],\n ['readonly', PROP_BOOLEAN],\n ['required', PROP_BOOLEAN],\n ['shortcutkey', PROP_STRING],\n ['show', {value: true, ...PROP_BOOLEAN}],\n ['tabindex', {value: 0, ...PROP_NUMBER}]\n ]\n);\n\nexport const registerProps = () => {\n register(\n 'wm-colorpicker',\n colorPickerProps\n );\n registerFormWidget(\n FormWidgetType.COLORPICKER,\n new Map(colorPickerProps)\n );\n};\n","import {Component, ElementRef, Inject, Injector, Optional, ViewChild} from '@angular/core';\nimport {NG_VALIDATORS, NG_VALUE_ACCESSOR, NgModel} from '@angular/forms';\nimport {ColorPickerDirective} from 'ngx-color-picker';\n\nimport {addClass, removeClass} from '@wm/core';\nimport {AUTOCLOSE_TYPE, IWidgetConfig, provideAs, provideAsWidgetRef, styler} from '@wm/components/base';\nimport {BaseFormCustomComponent} from '@wm/components/input';\nimport {registerProps} from './color-picker.props';\n\n\nconst DEFAULT_CLS = 'input-group app-colorpicker';\nconst WIDGET_CONFIG: IWidgetConfig = {\n widgetType: 'wm-colorpicker',\n hostClass: DEFAULT_CLS,\n displayType: 'inline-block'\n};\n\n@Component({\n selector: '[wmColorPicker]',\n templateUrl: './color-picker.component.html',\n providers: [\n provideAs(ColorPickerComponent, NG_VALUE_ACCESSOR, true),\n provideAs(ColorPickerComponent, NG_VALIDATORS, true),\n provideAsWidgetRef(ColorPickerComponent)\n ]\n})\nexport class ColorPickerComponent extends BaseFormCustomComponent {\n static initializeProps = registerProps();\n\n public required: boolean;\n public readonly: boolean;\n public disabled: boolean;\n public name: string;\n public placeholder: any;\n public tabindex: any;\n public shortcutkey: string;\n public outsideclick: boolean;\n public autoclose: string;\n public hint: string;\n public arialabel: string;\n\n\n @ViewChild(NgModel) ngModel: NgModel;\n @ViewChild('input', { static: true, read: ElementRef }) inputEl: ElementRef;\n @ViewChild(ColorPickerDirective) cpDirective: ColorPickerDirective;\n\n constructor(inj: Injector, @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any) {\n super(inj, WIDGET_CONFIG, explicitContext);\n styler(this.nativeElement, this);\n }\n\n // To remove space occupied by colorpicker when it is closed\n public colorPickerToggleChange(isOpen: boolean) {\n const colorPickerContainer = this.nativeElement.querySelector(`.color-picker`) as HTMLElement;\n if (colorPickerContainer) {\n (!isOpen) ? addClass(colorPickerContainer, 'hidden') : removeClass(colorPickerContainer, 'hidden');\n }\n }\n\n colorPickerOpen(value: string) {\n $('.hex-text input').attr('placeholder', 'Enter hex color code')\n // Whenever autoclose property is set to 'always', adding the onclick listener to the colorPicker container to close the picker.\n if (this.autoclose === AUTOCLOSE_TYPE.ALWAYS) {\n const colorPickerContainer = this.nativeElement.querySelector(`.color-picker`) as HTMLElement;\n colorPickerContainer.onclick = () => this.cpDirective.closeDialog();\n }\n }\n\n // This mehtod is used to show/open the colorpicker popup.\n open() {\n this.cpDirective.openDialog();\n }\n\n // This mehtod is used to hide/close the colorpicker popup.\n close() {\n this.cpDirective.closeDialog();\n }\n\n\n // change and blur events are added from the template\n protected handleEvent(node: HTMLElement, eventName: string, callback: Function, locals: any) {\n if (eventName !== 'change' && eventName !== 'blur') {\n super.handleEvent(this.inputEl.nativeElement, eventName, callback, locals);\n }\n }\n\n public handleChange(newVal: boolean) {\n this.invokeOnChange(this.datavalue, {type: 'change'}, this.ngModel.valid);\n }\n\n protected onPropertyChange(key: string, nv: any, ov: any) {\n if (key === 'tabindex') {\n return;\n }\n if (key === 'required') {\n /* WMS-18269 | Update Angular about the required attr value change */\n this._onChange(this.datavalue);\n return;\n }\n if (key === 'datavalue') {\n this._onChange(nv);\n return;\n }\n if (key === 'autoclose') {\n this.outsideclick = (nv === AUTOCLOSE_TYPE.OUTSIDECLICK || nv === AUTOCLOSE_TYPE.ALWAYS) ? true : false;\n }\n super.onPropertyChange(key, nv, ov);\n }\n}\n","<input aria-haspopup=\"true\" class=\"form-control app-textbox\"\n #input\n focus-target\n [attr.name]=\"name\"\n [attr.aria-label]=\"arialabel\"\n [(colorPicker)]=\"datavalue\"\n (colorPickerChange)=\"handleChange($event);\"\n (cpToggleChange)=\"colorPickerToggleChange($event)\"\n [cpPosition]=\"'bottom'\"\n [cpCloseClickOutside]=\"outsideclick\"\n (colorPickerOpen)=\"colorPickerOpen($event)\"\n [attr.placeholder]=\"placeholder\"\n [disabled]=\"readonly || disabled\"\n [required]=\"required\"\n [tabindex]=\"tabindex\"\n [(ngModel)]=\"datavalue\"\n (ngModelChange)=\"handleChange($event);\"\n [ngModelOptions]=\"{updateOn: 'change', standalone: true}\"\n (blur)=\"invokeOnTouched($event)\"\n [attr.accesskey]=\"shortcutkey\">\n<span class=\"input-group-addon colorpicker-container\">\n <i class=\"colored-box\" [style.backgroundColor]=\"datavalue\"> </i>\n</span>\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\n\nimport { ColorPickerModule as ngxColorPickerModule } from 'ngx-color-picker';\n\nimport { WmComponentsModule } from '@wm/components/base';\n\nimport { ColorPickerComponent } from './color-picker.component';\n\nconst components = [\n ColorPickerComponent\n];\n\n@NgModule({\n imports: [\n CommonModule,\n ngxColorPickerModule,\n FormsModule,\n WmComponentsModule\n ],\n declarations: [...components],\n exports: [...components]\n})\nexport class ColorPickerModule {\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public_api';\n"],"names":["ngxColorPickerModule"],"mappings":"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"}
|
|
@@ -2448,7 +2448,8 @@
|
|
|
2448
2448
|
} if (rf & 2) {
|
|
2449
2449
|
const opt_r3 = ctx.$implicit;
|
|
2450
2450
|
const ctx_r4 = i0__namespace.ɵɵnextContext();
|
|
2451
|
-
i0__namespace.ɵɵproperty("name", "wm-switch-" + opt_r3.key)("ngClass", i0__namespace.ɵɵpureFunction2(
|
|
2451
|
+
i0__namespace.ɵɵproperty("name", "wm-switch-" + opt_r3.key)("ngClass", i0__namespace.ɵɵpureFunction2(5, _c1$5, opt_r3.selected, ctx_r4.disabled));
|
|
2452
|
+
i0__namespace.ɵɵattribute("aria-pressed", opt_r3.selected ? true : false);
|
|
2452
2453
|
i0__namespace.ɵɵadvance();
|
|
2453
2454
|
i0__namespace.ɵɵproperty("ngIf", opt_r3.dataObject && opt_r3.dataObject[ctx_r4.iconclass]);
|
|
2454
2455
|
i0__namespace.ɵɵadvance();
|
|
@@ -2572,9 +2573,9 @@
|
|
|
2572
2573
|
static { this.ɵcmp = /*@__PURE__*/ i0__namespace.ɵɵdefineComponent({ type: SwitchComponent, selectors: [["", "wmSwitch", ""]], exportAs: ["wmSwitch"], features: [i0__namespace.ɵɵProvidersFeature([
|
|
2573
2574
|
i2.provideAs(SwitchComponent, i2$1.NG_VALUE_ACCESSOR, true),
|
|
2574
2575
|
i2.provideAsWidgetRef(SwitchComponent)
|
|
2575
|
-
]), i0__namespace.ɵɵInheritDefinitionFeature], attrs: _c0$6, decls: 6, vars: 8, consts: [[
|
|
2576
|
+
]), i0__namespace.ɵɵInheritDefinitionFeature], attrs: _c0$6, decls: 6, vars: 8, consts: [[1, "btn-group", "btn-group-justified"], ["focus-target", "", "href", "javascript:void(0);", "class", "btn btn-default", "role", "button", 3, "name", "ngClass", "click", 4, "ngFor", "ngForOf"], ["aria-hidden", "true", 1, "btn", "btn-primary", "app-switch-overlay", "switch-handle", 3, "title"], [3, "class", 4, "ngIf"], ["aria-hidden", "true", 1, "model-holder", "ng-hide", 3, "name", "disabled", "value", "required"], ["focus-target", "", "href", "javascript:void(0);", "role", "button", 1, "btn", "btn-default", 3, "click", "name", "ngClass"], ["aria-hidden", "true", 3, "ngClass", 4, "ngIf"], [1, "caption", 3, "textContent"], ["aria-hidden", "true", 3, "ngClass"]], template: function SwitchComponent_Template(rf, ctx) { if (rf & 1) {
|
|
2576
2577
|
i0__namespace.ɵɵelementStart(0, "div", 0);
|
|
2577
|
-
i0__namespace.ɵɵtemplate(1, SwitchComponent_a_1_Template, 3,
|
|
2578
|
+
i0__namespace.ɵɵtemplate(1, SwitchComponent_a_1_Template, 3, 8, "a", 1);
|
|
2578
2579
|
i0__namespace.ɵɵelementEnd();
|
|
2579
2580
|
i0__namespace.ɵɵelementStart(2, "span", 2);
|
|
2580
2581
|
i0__namespace.ɵɵtemplate(3, SwitchComponent_i_3_Template, 1, 3, "i", 3);
|
|
@@ -2599,7 +2600,7 @@
|
|
|
2599
2600
|
args: [{ selector: '[wmSwitch]', providers: [
|
|
2600
2601
|
i2.provideAs(SwitchComponent, i2$1.NG_VALUE_ACCESSOR, true),
|
|
2601
2602
|
i2.provideAsWidgetRef(SwitchComponent)
|
|
2602
|
-
], exportAs: 'wmSwitch', template: "<div
|
|
2603
|
+
], exportAs: 'wmSwitch', template: "<div class=\"btn-group btn-group-justified\">\n <a *ngFor=\"let opt of datasetItems; let $index = index;\"\n focus-target\n href=\"javascript:void(0);\"\n class=\"btn btn-default\"\n [name]=\"'wm-switch-' + opt.key\"\n role=\"button\"\n [ngClass]=\"{'selected': opt.selected, 'disabled': disabled}\"\n [attr.aria-pressed]=\"opt.selected ? true : false\"\n (click)=\"selectOpt($event, $index, opt)\"\n >\n <i *ngIf=\"opt.dataObject && opt.dataObject[iconclass]\" aria-hidden=\"true\" [ngClass]=\"['app-icon', opt.dataObject[iconclass] || opt['icon']]\"></i>\n <span class=\"caption\" [textContent]=\"opt[displayfield] || opt.label\"></span>\n </a>\n</div>\n<span aria-hidden=\"true\" [title]=\"selectedItem ? selectedItem.label : modelByKey\"\n class=\"btn btn-primary app-switch-overlay switch-handle\">\n <i *ngIf=\"iconclass\"\n class=\"app-icon {{(selectedItem && selectedItem.dataObject) && selectedItem.dataObject[iconclass]}}\"></i>\n {{selectedItem ? selectedItem.label : modelByKey}}\n</span>\n<input [name]=\"name\" class=\"model-holder ng-hide\" [disabled]=\"disabled\" [value]=\"modelByKey\" [required]=\"required\" aria-hidden=\"true\">\n" }]
|
|
2603
2604
|
}], () => [{ type: i0__namespace.Injector }, { type: undefined, decorators: [{
|
|
2604
2605
|
type: i0.Inject,
|
|
2605
2606
|
args: ['EXPLICIT_CONTEXT']
|
|
@@ -28,7 +28,8 @@ function SwitchComponent_a_1_Template(rf, ctx) { if (rf & 1) {
|
|
|
28
28
|
} if (rf & 2) {
|
|
29
29
|
const opt_r3 = ctx.$implicit;
|
|
30
30
|
const ctx_r4 = i0.ɵɵnextContext();
|
|
31
|
-
i0.ɵɵproperty("name", "wm-switch-" + opt_r3.key)("ngClass", i0.ɵɵpureFunction2(
|
|
31
|
+
i0.ɵɵproperty("name", "wm-switch-" + opt_r3.key)("ngClass", i0.ɵɵpureFunction2(5, _c1, opt_r3.selected, ctx_r4.disabled));
|
|
32
|
+
i0.ɵɵattribute("aria-pressed", opt_r3.selected ? true : false);
|
|
32
33
|
i0.ɵɵadvance();
|
|
33
34
|
i0.ɵɵproperty("ngIf", opt_r3.dataObject && opt_r3.dataObject[ctx_r4.iconclass]);
|
|
34
35
|
i0.ɵɵadvance();
|
|
@@ -152,9 +153,9 @@ export class SwitchComponent extends DatasetAwareFormComponent {
|
|
|
152
153
|
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SwitchComponent, selectors: [["", "wmSwitch", ""]], exportAs: ["wmSwitch"], features: [i0.ɵɵProvidersFeature([
|
|
153
154
|
provideAs(SwitchComponent, NG_VALUE_ACCESSOR, true),
|
|
154
155
|
provideAsWidgetRef(SwitchComponent)
|
|
155
|
-
]), i0.ɵɵInheritDefinitionFeature], attrs: _c0, decls: 6, vars: 8, consts: [[
|
|
156
|
+
]), i0.ɵɵInheritDefinitionFeature], attrs: _c0, decls: 6, vars: 8, consts: [[1, "btn-group", "btn-group-justified"], ["focus-target", "", "href", "javascript:void(0);", "class", "btn btn-default", "role", "button", 3, "name", "ngClass", "click", 4, "ngFor", "ngForOf"], ["aria-hidden", "true", 1, "btn", "btn-primary", "app-switch-overlay", "switch-handle", 3, "title"], [3, "class", 4, "ngIf"], ["aria-hidden", "true", 1, "model-holder", "ng-hide", 3, "name", "disabled", "value", "required"], ["focus-target", "", "href", "javascript:void(0);", "role", "button", 1, "btn", "btn-default", 3, "click", "name", "ngClass"], ["aria-hidden", "true", 3, "ngClass", 4, "ngIf"], [1, "caption", 3, "textContent"], ["aria-hidden", "true", 3, "ngClass"]], template: function SwitchComponent_Template(rf, ctx) { if (rf & 1) {
|
|
156
157
|
i0.ɵɵelementStart(0, "div", 0);
|
|
157
|
-
i0.ɵɵtemplate(1, SwitchComponent_a_1_Template, 3,
|
|
158
|
+
i0.ɵɵtemplate(1, SwitchComponent_a_1_Template, 3, 8, "a", 1);
|
|
158
159
|
i0.ɵɵelementEnd();
|
|
159
160
|
i0.ɵɵelementStart(2, "span", 2);
|
|
160
161
|
i0.ɵɵtemplate(3, SwitchComponent_i_3_Template, 1, 3, "i", 3);
|
|
@@ -179,7 +180,7 @@ export class SwitchComponent extends DatasetAwareFormComponent {
|
|
|
179
180
|
args: [{ selector: '[wmSwitch]', providers: [
|
|
180
181
|
provideAs(SwitchComponent, NG_VALUE_ACCESSOR, true),
|
|
181
182
|
provideAsWidgetRef(SwitchComponent)
|
|
182
|
-
], exportAs: 'wmSwitch', template: "<div
|
|
183
|
+
], exportAs: 'wmSwitch', template: "<div class=\"btn-group btn-group-justified\">\n <a *ngFor=\"let opt of datasetItems; let $index = index;\"\n focus-target\n href=\"javascript:void(0);\"\n class=\"btn btn-default\"\n [name]=\"'wm-switch-' + opt.key\"\n role=\"button\"\n [ngClass]=\"{'selected': opt.selected, 'disabled': disabled}\"\n [attr.aria-pressed]=\"opt.selected ? true : false\"\n (click)=\"selectOpt($event, $index, opt)\"\n >\n <i *ngIf=\"opt.dataObject && opt.dataObject[iconclass]\" aria-hidden=\"true\" [ngClass]=\"['app-icon', opt.dataObject[iconclass] || opt['icon']]\"></i>\n <span class=\"caption\" [textContent]=\"opt[displayfield] || opt.label\"></span>\n </a>\n</div>\n<span aria-hidden=\"true\" [title]=\"selectedItem ? selectedItem.label : modelByKey\"\n class=\"btn btn-primary app-switch-overlay switch-handle\">\n <i *ngIf=\"iconclass\"\n class=\"app-icon {{(selectedItem && selectedItem.dataObject) && selectedItem.dataObject[iconclass]}}\"></i>\n {{selectedItem ? selectedItem.label : modelByKey}}\n</span>\n<input [name]=\"name\" class=\"model-holder ng-hide\" [disabled]=\"disabled\" [value]=\"modelByKey\" [required]=\"required\" aria-hidden=\"true\">\n" }]
|
|
183
184
|
}], () => [{ type: i0.Injector }, { type: undefined, decorators: [{
|
|
184
185
|
type: Inject,
|
|
185
186
|
args: ['EXPLICIT_CONTEXT']
|
|
@@ -187,4 +188,4 @@ export class SwitchComponent extends DatasetAwareFormComponent {
|
|
|
187
188
|
type: Optional
|
|
188
189
|
}] }], null); })();
|
|
189
190
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SwitchComponent, { className: "SwitchComponent", filePath: "switch/switch.component.ts", lineNumber: 25 }); })();
|
|
190
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"switch.component.js","sourceRoot":"","sources":["../../../../../../projects/components/widgets/input/default/src/switch/switch.component.ts","../../../../../../projects/components/widgets/input/default/src/switch/switch.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAgB,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAC,MAAM,eAAe,CAAC;AACnF,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAEnD,OAAO,EAAC,UAAU,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAC,MAAM,UAAU,CAAC;AAC5E,OAAO,EAAe,SAAS,EAAE,kBAAkB,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AACzF,OAAO,EAAE,yBAAyB,EAAE,MAAM,iCAAiC,CAAC;AAE5E,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAC,IAAI,EAAE,SAAS,EAAC,MAAM,WAAW,CAAC;;;;;;;;ICClC,uBAAiJ;;;;IAAvE,2GAAkE;;;;IARhJ,4BAOC;IADE,0PAAS,2CAA8B,KAAC;IAEvC,gEAA6I;IAC7I,0BAA4E;IAChF,iBAAI;;;;IALD,AADA,gDAA+B,yEAC6B;IAGvD,cAAiD;IAAjD,+EAAiD;IAC/B,cAA8C;IAA9C,yEAA8C;;;IAKxE,oBAC4G;;;IAAzG,qJAAoG;;ADJ3G,MAAM,WAAW,GAAG,YAAY,CAAC;AACjC,MAAM,aAAa,GAAG,EAAC,UAAU,EAAE,WAAW,EAAE,SAAS,EAAE,WAAW,EAAC,CAAC;AAWxE,MAAM,OAAO,eAAgB,SAAQ,yBAAyB;aACnD,oBAAe,GAAG,aAAa,EAAE,AAAlB,CAAmB;IAWzC,YAAY,GAAa,EAA0C,eAAoB;QACnF,KAAK,CAAC,GAAG,EAAE,aAAa,EAAE,eAAe,CAAC,CAAC;QAV/C,YAAO,GAAG,EAAE,CAAC;QAYT,IAAI,CAAC,yBAAyB,GAAG,QAAQ,CAAC,CAAC,GAAG,EAAE,EAAE;YAC9C,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;YAC5B,sEAAsE;YACtE,IAAI,GAAG,EAAE,CAAC;gBACN,UAAU,EAAE,CAAC;YACjB,CAAC;QACL,CAAC,EAAE,GAAG,CAAC,CAAC;QAER,MAAM,mBAAmB,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,mBAAmB,EAAE,CAAC,CAAC;QAEtF,IAAI,CAAC,uBAAuB,CAAC,GAAG,EAAE,CAAC,mBAAmB,CAAC,WAAW,EAAE,CAAC,CAAC;QAEtE,MAAM,qBAAqB,GAAG,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,GAAG,EAAE;YACzD,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,CAAC;QACzC,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,uBAAuB,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC,WAAW,EAAE,CAAC,CAAC;IAC5E,CAAC;IAED,eAAe;QACX,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,MAAM,CAAC,IAAI,CAAC,aAA4B,EAAE,IAAI,CAAC,CAAC;IACpD,CAAC;IAED,aAAa,CAAC,GAAW,EAAE,EAAO,EAAE,EAAQ;QACxC,IAAI,GAAG,KAAK,QAAQ,EAAE,CAAC;YACnB,MAAM,CAAC,IAAI,CAAC,aAAa,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAC7D,CAAC;aAAM,CAAC;YACJ,KAAK,CAAC,aAAa,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QACrC,CAAC;IACL,CAAC;IAED,yGAAyG;IACjG,gBAAgB;QACpB,IAAI,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,SAAS,CAAC,IAAI,CAAC,sBAAsB,CAAC,EAAE,CAAC;YACtE,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAC;YAC9D,OAAO;QACX,CAAC;QAED,2GAA2G;QAC3G,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;IAC7B,CAAC;IAED,0CAA0C;IAC1C,sFAAsF;IAC9E,mBAAmB;QACvB,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;YAC3B,IAAI,CAAC,QAAQ,GAAG,CAAC,GAAG,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;YACjD,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,qBAAqB,CAAgB,EAAE,OAAO,EAAE,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC;QACjH,CAAC;QAED,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,CAAC;IACzC,CAAC;IAED,wEAAwE;IAChE,iBAAiB,CAAC,aAAc;QACpC,MAAM,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;QAEtE,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAExB,IAAI,IAAI,EACJ,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,EAAE,EAAC,GAAG,EAAE,IAAI,CAAC,YAAY,CAAC,GAAG,EAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAEhG,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YACxC,KAAK,GAAG,CAAC,CAAC,CAAC;QACf,CAAC;QACD,IAAI,GAAG,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC7B,IAAI,aAAa,EAAE,CAAC;YAChB,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,GAAG,GAAG,CAAC,CAAC;QACpC,CAAC;aAAM,CAAC;YACJ,OAAO,CAAC,OAAO,CAAC;gBACZ,IAAI,EAAE,IAAI,GAAG,GAAG;aACnB,EAAE,GAAG,CAAC,CAAC;QACZ,CAAC;IACL,CAAC;IAED,gBAAgB,CAAC,MAAM;QACnB,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;YAC5B,OAAO;QACX,CAAC;QACD,MAAM,GAAG,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QACtC,IAAI,CAAC,aAAa,GAAG,GAAG,CAAC,KAAK,CAAC;IACnC,CAAC;IAED,oDAAoD;IACpD,gFAAgF;IAChF,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM;QAC5B,MAAM,CAAC,cAAc,EAAE,CAAC;QAExB,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChB,OAAO;QACX,CAAC;QAED,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,GAAG,CAAC;QAC7B,IAAI,CAAC,eAAe,EAAE,CAAC;QAEvB,IAAI,IAAI,CAAC,YAAY,IAAI,MAAM,KAAK,SAAS,CAAC,IAAI,CAAC,YAAY,EAAE,EAAC,GAAG,EAAE,IAAI,CAAC,YAAY,CAAC,GAAG,EAAC,CAAC,EAAE,CAAC;YAC7F,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACjC,MAAM,GAAG,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAClC,CAAC;iBAAM,CAAC;gBACJ,OAAO;YACX,CAAC;QACL,CAAC;QACD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QAC9C,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAEzB,8BAA8B;QAC9B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM,IAAI,EAAE,EAAE,IAAI,CAAC,CAAC;QACxD,UAAU,EAAE,CAAC;IACjB,CAAC;IAED,gBAAgB,CAAC,GAAG,EAAE,EAAE,EAAE,EAAG;QACzB,IAAI,GAAG,KAAK,UAAU,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,EAAE,CAAC;YACvC,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC;QAC5C,CAAC;aAAM,CAAC;YACJ,KAAK,CAAC,gBAAgB,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QACxC,CAAC;IACL,CAAC;gFApIQ,eAAe,0DAYW,kBAAkB;oEAZ5C,eAAe,8FANb;gBACP,SAAS,CAAC,eAAe,EAAE,iBAAiB,EAAE,IAAI,CAAC;gBACnD,kBAAkB,CAAC,eAAe,CAAC;aACtC;YCrBL,8BAAwD;YACpD,4DAOC;YAIL,iBAAM;YACN,+BAC+D;YAC3D,4DACwG;YACxG,YACJ;YAAA,iBAAO;YACP,2BAAsI;;YAlB/G,cAAiB;YAAjB,0CAAiB;YAYlC,cAAwD;YAAxD,kFAAwD;YAEtD,cAAe;YAAf,oCAAe;YAEnB,cACJ;YADI,4FACJ;YACO,cAAa;YAAyE,AAArB,AAAtB,AAA3C,+BAAa,0BAAmD,yBAAqB,0BAAsB;;;iFDKrG,eAAe;cAT3B,SAAS;2BACI,YAAY,aAEX;oBACP,SAAS,kBAAkB,iBAAiB,EAAE,IAAI,CAAC;oBACnD,kBAAkB,iBAAiB;iBACtC,YACS,UAAU;;sBAcQ,MAAM;uBAAC,kBAAkB;;sBAAG,QAAQ;;kFAZvD,eAAe","sourcesContent":["import {AfterViewInit, Component, Inject, Injector, Optional} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport {$appDigest, debounce, isDefined, setCSS, toBoolean} from '@wm/core';\nimport { DataSetItem, provideAs, provideAsWidgetRef, styler } from '@wm/components/base';\nimport { DatasetAwareFormComponent } from '../dataset-aware-form.component';\n\nimport { registerProps } from './switch.props';\nimport {find, findIndex} from \"lodash-es\";\n\ndeclare const $;\n\nconst DEFAULT_CLS = 'app-switch';\nconst WIDGET_CONFIG = {widgetType: 'wm-switch', hostClass: DEFAULT_CLS};\n\n@Component({\n    selector: '[wmSwitch]',\n    templateUrl: './switch.component.html',\n    providers: [\n        provideAs(SwitchComponent, NG_VALUE_ACCESSOR, true),\n        provideAsWidgetRef(SwitchComponent)\n    ],\n    exportAs: 'wmSwitch'\n})\nexport class SwitchComponent extends DatasetAwareFormComponent implements AfterViewInit {\n    static initializeProps = registerProps();\n\n    options = [];\n    selectedItem: DataSetItem;\n    iconclass;\n    private btnwidth;\n    public disabled: boolean;\n    public required: boolean;\n    private _debounceSetSelectedValue: Function;\n    public name: string;\n\n    constructor(inj: Injector, @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any) {\n        super(inj, WIDGET_CONFIG, explicitContext);\n\n        this._debounceSetSelectedValue = debounce((val) => {\n            this.setSelectedValue();\n            this.updateHighlighter(val);\n            // only for default value trigger app digest to apply the selectedItem\n            if (val) {\n                $appDigest();\n            }\n        }, 200);\n\n        const datasetSubscription = this.dataset$.subscribe(() => this.updateSwitchOptions());\n\n        this.registerDestroyListener(() => datasetSubscription.unsubscribe());\n\n        const datavalueSubscription = this.datavalue$.subscribe(() => {\n            this._debounceSetSelectedValue(true);\n        });\n        this.registerDestroyListener(() => datavalueSubscription.unsubscribe());\n    }\n\n    ngAfterViewInit() {\n        super.ngAfterViewInit();\n        styler(this.nativeElement as HTMLElement, this);\n    }\n\n    onStyleChange(key: string, nv: any, ov?: any) {\n        if (key === 'height') {\n            setCSS(this.nativeElement, 'overflow', nv ? 'auto' : '');\n        } else {\n            super.onStyleChange(key, nv, ov);\n        }\n    }\n\n    // This function sets the selectedItem by either using compareby fields or selected flag on datasetItems.\n    private setSelectedValue() {\n        if (isDefined(this.datavalue) || isDefined(this.toBeProcessedDatavalue)) {\n            this.selectedItem = find(this.datasetItems, {selected: true});\n            return;\n        }\n\n        // If no value is provided, set first value as default if options are available else set -1 ie no selection\n        this.selectOptAtIndex(0);\n    }\n\n    // set the css for switch overlay element.\n    // set the selected index from the datasetItems and highlight the datavalue on switch.\n    private updateSwitchOptions() {\n        if (this.datasetItems.length) {\n            this.btnwidth = (100 / this.datasetItems.length);\n            setCSS(this.nativeElement.querySelector('.app-switch-overlay') as HTMLElement, 'width', this.btnwidth + '%');\n        }\n\n        this._debounceSetSelectedValue(true);\n    }\n\n    // This function animates the highlighted span on to the selected value.\n    private updateHighlighter(skipAnimation?) {\n        const handler = $(this.nativeElement).find('span.app-switch-overlay');\n\n        this.setSelectedValue();\n\n        let left,\n            index = this.selectedItem ? findIndex(this.datasetItems, {key: this.selectedItem.key}) : -1;\n\n        if (index === undefined || index === null) {\n            index = -1;\n        }\n        left = index * this.btnwidth;\n        if (skipAnimation) {\n            handler.css('left', left + '%');\n        } else {\n            handler.animate({\n                left: left + '%'\n            }, 300);\n        }\n    }\n\n    selectOptAtIndex($index) {\n        if (!this.datasetItems.length) {\n            return;\n        }\n        const opt = this.datasetItems[$index];\n        this._modelByValue = opt.value;\n    }\n\n    // Triggered on selected the option from the switch.\n    // set the index and highlight the default value. Invoke onchange event handler.\n    selectOpt($event, $index, option) {\n        $event.preventDefault();\n\n        if (this.disabled) {\n            return;\n        }\n\n        this.modelByKey = option.key;\n        this.invokeOnTouched();\n\n        if (this.selectedItem && $index === findIndex(this.datasetItems, {key: this.selectedItem.key})) {\n            if (this.datasetItems.length === 2) {\n                $index = $index === 1 ? 0 : 1;\n            } else {\n                return;\n            }\n        }\n        this.selectedItem = this.datasetItems[$index];\n        this.updateHighlighter();\n\n        // invoke on datavalue change.\n        this.invokeOnChange(this.datavalue, $event || {}, true);\n        $appDigest();\n    }\n\n    onPropertyChange(key, nv, ov?) {\n        if (key === 'disabled' && !toBoolean(nv)) {\n            this.nativeElement.removeAttribute(key);\n        } else {\n            super.onPropertyChange(key, nv, ov);\n        }\n    }\n}\n","<div role=\"group\" class=\"btn-group btn-group-justified\">\n    <a *ngFor=\"let opt of datasetItems; let $index = index;\"\n       focus-target\n       href=\"javascript:void(0);\"\n       class=\"btn btn-default\"\n       [name]=\"'wm-switch-' + opt.key\"\n       [ngClass]=\"{'selected': opt.selected, 'disabled': disabled}\"\n       (click)=\"selectOpt($event, $index, opt)\"\n    >\n        <i *ngIf=\"opt.dataObject && opt.dataObject[iconclass]\" aria-hidden=\"true\" [ngClass]=\"['app-icon', opt.dataObject[iconclass] || opt['icon']]\"></i>\n        <span class=\"caption\" [textContent]=\"opt[displayfield] || opt.label\"></span>\n    </a>\n</div>\n<span [title]=\"selectedItem ? selectedItem.label : modelByKey\"\n      class=\"btn btn-primary app-switch-overlay switch-handle\">\n    <i *ngIf=\"iconclass\"\n       class=\"app-icon {{(selectedItem && selectedItem.dataObject) && selectedItem.dataObject[iconclass]}}\"></i>\n    {{selectedItem ? selectedItem.label : modelByKey}}\n</span>\n<input [name]=\"name\" class=\"model-holder ng-hide\" [disabled]=\"disabled\" [value]=\"modelByKey\" [required]=\"required\" aria-hidden=\"true\">\n"]}
|
|
191
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"switch.component.js","sourceRoot":"","sources":["../../../../../../projects/components/widgets/input/default/src/switch/switch.component.ts","../../../../../../projects/components/widgets/input/default/src/switch/switch.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, Inject, Injector, Optional} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport {$appDigest, debounce, isDefined, setCSS, toBoolean} from '@wm/core';\nimport { DataSetItem, provideAs, provideAsWidgetRef, styler } from '@wm/components/base';\nimport { DatasetAwareFormComponent } from '../dataset-aware-form.component';\n\nimport { registerProps } from './switch.props';\nimport {find, findIndex} from \"lodash-es\";\n\ndeclare const $;\n\nconst DEFAULT_CLS = 'app-switch';\nconst WIDGET_CONFIG = {widgetType: 'wm-switch', hostClass: DEFAULT_CLS};\n\n@Component({\n    selector: '[wmSwitch]',\n    templateUrl: './switch.component.html',\n    providers: [\n        provideAs(SwitchComponent, NG_VALUE_ACCESSOR, true),\n        provideAsWidgetRef(SwitchComponent)\n    ],\n    exportAs: 'wmSwitch'\n})\nexport class SwitchComponent extends DatasetAwareFormComponent implements AfterViewInit {\n    static initializeProps = registerProps();\n\n    options = [];\n    selectedItem: DataSetItem;\n    iconclass;\n    private btnwidth;\n    public disabled: boolean;\n    public required: boolean;\n    private _debounceSetSelectedValue: Function;\n    public name: string;\n\n    constructor(inj: Injector, @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any) {\n        super(inj, WIDGET_CONFIG, explicitContext);\n\n        this._debounceSetSelectedValue = debounce((val) => {\n            this.setSelectedValue();\n            this.updateHighlighter(val);\n            // only for default value trigger app digest to apply the selectedItem\n            if (val) {\n                $appDigest();\n            }\n        }, 200);\n\n        const datasetSubscription = this.dataset$.subscribe(() => this.updateSwitchOptions());\n\n        this.registerDestroyListener(() => datasetSubscription.unsubscribe());\n\n        const datavalueSubscription = this.datavalue$.subscribe(() => {\n            this._debounceSetSelectedValue(true);\n        });\n        this.registerDestroyListener(() => datavalueSubscription.unsubscribe());\n    }\n\n    ngAfterViewInit() {\n        super.ngAfterViewInit();\n        styler(this.nativeElement as HTMLElement, this);\n    }\n\n    onStyleChange(key: string, nv: any, ov?: any) {\n        if (key === 'height') {\n            setCSS(this.nativeElement, 'overflow', nv ? 'auto' : '');\n        } else {\n            super.onStyleChange(key, nv, ov);\n        }\n    }\n\n    // This function sets the selectedItem by either using compareby fields or selected flag on datasetItems.\n    private setSelectedValue() {\n        if (isDefined(this.datavalue) || isDefined(this.toBeProcessedDatavalue)) {\n            this.selectedItem = find(this.datasetItems, {selected: true});\n            return;\n        }\n\n        // If no value is provided, set first value as default if options are available else set -1 ie no selection\n        this.selectOptAtIndex(0);\n    }\n\n    // set the css for switch overlay element.\n    // set the selected index from the datasetItems and highlight the datavalue on switch.\n    private updateSwitchOptions() {\n        if (this.datasetItems.length) {\n            this.btnwidth = (100 / this.datasetItems.length);\n            setCSS(this.nativeElement.querySelector('.app-switch-overlay') as HTMLElement, 'width', this.btnwidth + '%');\n        }\n\n        this._debounceSetSelectedValue(true);\n    }\n\n    // This function animates the highlighted span on to the selected value.\n    private updateHighlighter(skipAnimation?) {\n        const handler = $(this.nativeElement).find('span.app-switch-overlay');\n\n        this.setSelectedValue();\n\n        let left,\n            index = this.selectedItem ? findIndex(this.datasetItems, {key: this.selectedItem.key}) : -1;\n\n        if (index === undefined || index === null) {\n            index = -1;\n        }\n        left = index * this.btnwidth;\n        if (skipAnimation) {\n            handler.css('left', left + '%');\n        } else {\n            handler.animate({\n                left: left + '%'\n            }, 300);\n        }\n    }\n\n    selectOptAtIndex($index) {\n        if (!this.datasetItems.length) {\n            return;\n        }\n        const opt = this.datasetItems[$index];\n        this._modelByValue = opt.value;\n    }\n\n    // Triggered on selected the option from the switch.\n    // set the index and highlight the default value. Invoke onchange event handler.\n    selectOpt($event, $index, option) {\n        $event.preventDefault();\n\n        if (this.disabled) {\n            return;\n        }\n\n        this.modelByKey = option.key;\n        this.invokeOnTouched();\n\n        if (this.selectedItem && $index === findIndex(this.datasetItems, {key: this.selectedItem.key})) {\n            if (this.datasetItems.length === 2) {\n                $index = $index === 1 ? 0 : 1;\n            } else {\n                return;\n            }\n        }\n        this.selectedItem = this.datasetItems[$index];\n        this.updateHighlighter();\n\n        // invoke on datavalue change.\n        this.invokeOnChange(this.datavalue, $event || {}, true);\n        $appDigest();\n    }\n\n    onPropertyChange(key, nv, ov?) {\n        if (key === 'disabled' && !toBoolean(nv)) {\n            this.nativeElement.removeAttribute(key);\n        } else {\n            super.onPropertyChange(key, nv, ov);\n        }\n    }\n}\n","<div class=\"btn-group btn-group-justified\">\n    <a *ngFor=\"let opt of datasetItems; let $index = index;\"\n       focus-target\n       href=\"javascript:void(0);\"\n       class=\"btn btn-default\"\n       [name]=\"'wm-switch-' + opt.key\"\n       role=\"button\"\n       [ngClass]=\"{'selected': opt.selected, 'disabled': disabled}\"\n       [attr.aria-pressed]=\"opt.selected ? true : false\"\n       (click)=\"selectOpt($event, $index, opt)\"\n    >\n        <i *ngIf=\"opt.dataObject && opt.dataObject[iconclass]\" aria-hidden=\"true\" [ngClass]=\"['app-icon', opt.dataObject[iconclass] || opt['icon']]\"></i>\n        <span class=\"caption\" [textContent]=\"opt[displayfield] || opt.label\"></span>\n    </a>\n</div>\n<span aria-hidden=\"true\" [title]=\"selectedItem ? selectedItem.label : modelByKey\"\n      class=\"btn btn-primary app-switch-overlay switch-handle\">\n    <i *ngIf=\"iconclass\"\n       class=\"app-icon {{(selectedItem && selectedItem.dataObject) && selectedItem.dataObject[iconclass]}}\"></i>\n    {{selectedItem ? selectedItem.label : modelByKey}}\n</span>\n<input [name]=\"name\" class=\"model-holder ng-hide\" [disabled]=\"disabled\" [value]=\"modelByKey\" [required]=\"required\" aria-hidden=\"true\">\n"]}
|
|
@@ -2434,7 +2434,8 @@ function SwitchComponent_a_1_Template(rf, ctx) { if (rf & 1) {
|
|
|
2434
2434
|
} if (rf & 2) {
|
|
2435
2435
|
const opt_r3 = ctx.$implicit;
|
|
2436
2436
|
const ctx_r4 = i0.ɵɵnextContext();
|
|
2437
|
-
i0.ɵɵproperty("name", "wm-switch-" + opt_r3.key)("ngClass", i0.ɵɵpureFunction2(
|
|
2437
|
+
i0.ɵɵproperty("name", "wm-switch-" + opt_r3.key)("ngClass", i0.ɵɵpureFunction2(5, _c1$5, opt_r3.selected, ctx_r4.disabled));
|
|
2438
|
+
i0.ɵɵattribute("aria-pressed", opt_r3.selected ? true : false);
|
|
2438
2439
|
i0.ɵɵadvance();
|
|
2439
2440
|
i0.ɵɵproperty("ngIf", opt_r3.dataObject && opt_r3.dataObject[ctx_r4.iconclass]);
|
|
2440
2441
|
i0.ɵɵadvance();
|
|
@@ -2558,9 +2559,9 @@ class SwitchComponent extends DatasetAwareFormComponent {
|
|
|
2558
2559
|
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SwitchComponent, selectors: [["", "wmSwitch", ""]], exportAs: ["wmSwitch"], features: [i0.ɵɵProvidersFeature([
|
|
2559
2560
|
provideAs(SwitchComponent, NG_VALUE_ACCESSOR, true),
|
|
2560
2561
|
provideAsWidgetRef(SwitchComponent)
|
|
2561
|
-
]), i0.ɵɵInheritDefinitionFeature], attrs: _c0$6, decls: 6, vars: 8, consts: [[
|
|
2562
|
+
]), i0.ɵɵInheritDefinitionFeature], attrs: _c0$6, decls: 6, vars: 8, consts: [[1, "btn-group", "btn-group-justified"], ["focus-target", "", "href", "javascript:void(0);", "class", "btn btn-default", "role", "button", 3, "name", "ngClass", "click", 4, "ngFor", "ngForOf"], ["aria-hidden", "true", 1, "btn", "btn-primary", "app-switch-overlay", "switch-handle", 3, "title"], [3, "class", 4, "ngIf"], ["aria-hidden", "true", 1, "model-holder", "ng-hide", 3, "name", "disabled", "value", "required"], ["focus-target", "", "href", "javascript:void(0);", "role", "button", 1, "btn", "btn-default", 3, "click", "name", "ngClass"], ["aria-hidden", "true", 3, "ngClass", 4, "ngIf"], [1, "caption", 3, "textContent"], ["aria-hidden", "true", 3, "ngClass"]], template: function SwitchComponent_Template(rf, ctx) { if (rf & 1) {
|
|
2562
2563
|
i0.ɵɵelementStart(0, "div", 0);
|
|
2563
|
-
i0.ɵɵtemplate(1, SwitchComponent_a_1_Template, 3,
|
|
2564
|
+
i0.ɵɵtemplate(1, SwitchComponent_a_1_Template, 3, 8, "a", 1);
|
|
2564
2565
|
i0.ɵɵelementEnd();
|
|
2565
2566
|
i0.ɵɵelementStart(2, "span", 2);
|
|
2566
2567
|
i0.ɵɵtemplate(3, SwitchComponent_i_3_Template, 1, 3, "i", 3);
|
|
@@ -2585,7 +2586,7 @@ class SwitchComponent extends DatasetAwareFormComponent {
|
|
|
2585
2586
|
args: [{ selector: '[wmSwitch]', providers: [
|
|
2586
2587
|
provideAs(SwitchComponent, NG_VALUE_ACCESSOR, true),
|
|
2587
2588
|
provideAsWidgetRef(SwitchComponent)
|
|
2588
|
-
], exportAs: 'wmSwitch', template: "<div
|
|
2589
|
+
], exportAs: 'wmSwitch', template: "<div class=\"btn-group btn-group-justified\">\n <a *ngFor=\"let opt of datasetItems; let $index = index;\"\n focus-target\n href=\"javascript:void(0);\"\n class=\"btn btn-default\"\n [name]=\"'wm-switch-' + opt.key\"\n role=\"button\"\n [ngClass]=\"{'selected': opt.selected, 'disabled': disabled}\"\n [attr.aria-pressed]=\"opt.selected ? true : false\"\n (click)=\"selectOpt($event, $index, opt)\"\n >\n <i *ngIf=\"opt.dataObject && opt.dataObject[iconclass]\" aria-hidden=\"true\" [ngClass]=\"['app-icon', opt.dataObject[iconclass] || opt['icon']]\"></i>\n <span class=\"caption\" [textContent]=\"opt[displayfield] || opt.label\"></span>\n </a>\n</div>\n<span aria-hidden=\"true\" [title]=\"selectedItem ? selectedItem.label : modelByKey\"\n class=\"btn btn-primary app-switch-overlay switch-handle\">\n <i *ngIf=\"iconclass\"\n class=\"app-icon {{(selectedItem && selectedItem.dataObject) && selectedItem.dataObject[iconclass]}}\"></i>\n {{selectedItem ? selectedItem.label : modelByKey}}\n</span>\n<input [name]=\"name\" class=\"model-holder ng-hide\" [disabled]=\"disabled\" [value]=\"modelByKey\" [required]=\"required\" aria-hidden=\"true\">\n" }]
|
|
2589
2590
|
}], () => [{ type: i0.Injector }, { type: undefined, decorators: [{
|
|
2590
2591
|
type: Inject,
|
|
2591
2592
|
args: ['EXPLICIT_CONTEXT']
|