@wavemaker/app-ng-runtime 12.0.0-next.45032 → 12.0.0-next.45501
Sign up to get free protection for your applications and to get access to all the features.
- app-ng-runtime/build-task/bundles/index.umd.js +405 -451
- app-ng-runtime/build-task/esm2022/data/form/form-field/form-field.build.mjs +2 -3
- app-ng-runtime/build-task/esm2022/public_api.mjs +1 -3
- app-ng-runtime/build-task/fesm2022/index.mjs +406 -454
- app-ng-runtime/build-task/fesm2022/index.mjs.map +1 -1
- app-ng-runtime/build-task/public_api.d.ts +0 -2
- app-ng-runtime/components/base/bundles/index.umd.js +14 -62
- app-ng-runtime/components/base/components.module.d.ts +11 -12
- app-ng-runtime/components/base/esm2022/components.module.mjs +1 -5
- app-ng-runtime/components/base/esm2022/public_api.mjs +1 -2
- app-ng-runtime/components/base/esm2022/widgets/common/base/base.component.mjs +15 -25
- app-ng-runtime/components/base/fesm2022/index.mjs +15 -62
- app-ng-runtime/components/base/fesm2022/index.mjs.map +1 -1
- app-ng-runtime/components/base/public_api.d.ts +0 -1
- app-ng-runtime/components/base/widgets/common/base/base.component.d.ts +5 -10
- app-ng-runtime/components/containers/wizard/bundles/index.umd.js +17 -0
- app-ng-runtime/components/containers/wizard/esm2022/wizard.component.mjs +18 -1
- app-ng-runtime/components/containers/wizard/fesm2022/index.mjs +17 -0
- app-ng-runtime/components/containers/wizard/fesm2022/index.mjs.map +1 -1
- app-ng-runtime/components/containers/wizard/wizard.component.d.ts +1 -0
- app-ng-runtime/components/data/form/esm2022/form-field/form-field.directive.mjs +1 -3
- app-ng-runtime/components/data/form/fesm2022/index.mjs +0 -2
- app-ng-runtime/components/data/form/fesm2022/index.mjs.map +1 -1
- app-ng-runtime/components/dialogs/default/bundles/index.umd.js +11 -0
- app-ng-runtime/components/dialogs/default/esm2022/base-dialog.mjs +12 -1
- app-ng-runtime/components/dialogs/default/fesm2022/index.mjs +11 -0
- app-ng-runtime/components/dialogs/default/fesm2022/index.mjs.map +1 -1
- app-ng-runtime/components/input/default/bundles/index.umd.js +63 -39
- app-ng-runtime/components/input/default/checkboxset/checkboxset.component.d.ts +0 -1
- app-ng-runtime/components/input/default/esm2022/checkboxset/checkboxset.component.mjs +5 -8
- app-ng-runtime/components/input/default/esm2022/radioset/radioset.component.mjs +5 -8
- app-ng-runtime/components/input/default/esm2022/select/select.component.mjs +57 -29
- app-ng-runtime/components/input/default/esm2022/text/base/base-input.mjs +1 -4
- app-ng-runtime/components/input/default/esm2022/text/locale/number-locale.mjs +2 -2
- app-ng-runtime/components/input/default/esm2022/textarea/textarea.component.mjs +4 -1
- app-ng-runtime/components/input/default/fesm2022/index.mjs +63 -39
- app-ng-runtime/components/input/default/fesm2022/index.mjs.map +1 -1
- app-ng-runtime/components/input/default/radioset/radioset.component.d.ts +0 -1
- app-ng-runtime/components/input/default/select/select.component.d.ts +2 -4
- app-ng-runtime/components/input/default/textarea/textarea.component.d.ts +3 -2
- app-ng-runtime/components/input/epoch/bundles/index.umd.js +3 -0
- app-ng-runtime/components/input/epoch/esm2022/date-time/date-time.component.mjs +4 -1
- app-ng-runtime/components/input/epoch/fesm2022/index.mjs +3 -0
- app-ng-runtime/components/input/epoch/fesm2022/index.mjs.map +1 -1
- app-ng-runtime/components/input/file-upload/bundles/index.umd.js +31 -5
- app-ng-runtime/components/input/file-upload/esm2022/file-upload.component.mjs +34 -8
- app-ng-runtime/components/input/file-upload/fesm2022/index.mjs +32 -6
- app-ng-runtime/components/input/file-upload/fesm2022/index.mjs.map +1 -1
- app-ng-runtime/components/input/file-upload/file-upload.component.d.ts +6 -2
- app-ng-runtime/components/navigation/menu/bundles/index.umd.js +2 -2
- app-ng-runtime/components/navigation/menu/esm2022/menu.component.mjs +2 -2
- app-ng-runtime/components/navigation/menu/esm2022/nav/nav.component.mjs +2 -2
- app-ng-runtime/components/navigation/menu/fesm2022/index.mjs +2 -2
- app-ng-runtime/components/navigation/menu/fesm2022/index.mjs.map +1 -1
- app-ng-runtime/core/bundles/index.umd.js +6 -16
- app-ng-runtime/core/enums/enums.d.ts +1 -2
- app-ng-runtime/core/esm2022/enums/enums.mjs +1 -2
- app-ng-runtime/core/esm2022/types/types.mjs +1 -4
- app-ng-runtime/core/esm2022/utils/build-utils.mjs +1 -6
- app-ng-runtime/core/esm2022/utils/utils.mjs +4 -3
- app-ng-runtime/core/fesm2022/index.mjs +4 -12
- app-ng-runtime/core/fesm2022/index.mjs.map +1 -1
- app-ng-runtime/core/types/types.d.ts +1 -5
- app-ng-runtime/core/utils/utils.d.ts +1 -0
- app-ng-runtime/mobile/core/bundles/index.umd.js +18 -2
- app-ng-runtime/mobile/core/esm2022/native.xhr.mjs +19 -3
- app-ng-runtime/mobile/core/fesm2022/index.mjs +18 -2
- app-ng-runtime/mobile/core/fesm2022/index.mjs.map +1 -1
- app-ng-runtime/package.json +1 -1
- app-ng-runtime/runtime/base/bundles/index.umd.js +5 -288
- app-ng-runtime/runtime/base/esm2022/public_api.mjs +1 -2
- app-ng-runtime/runtime/base/esm2022/runtime-base.module.mjs +1 -6
- app-ng-runtime/runtime/base/esm2022/services/i18n.service.mjs +2 -2
- app-ng-runtime/runtime/base/esm2022/types/types.mjs +1 -2
- app-ng-runtime/runtime/base/fesm2022/index.mjs +4 -287
- app-ng-runtime/runtime/base/fesm2022/index.mjs.map +1 -1
- app-ng-runtime/runtime/base/public_api.d.ts +0 -1
- app-ng-runtime/runtime/base/runtime-base.module.d.ts +8 -9
- app-ng-runtime/runtime/base/types/types.d.ts +1 -2
- app-ng-runtime/runtime/dynamic/bundles/index.umd.js +9 -27
- app-ng-runtime/runtime/dynamic/esm2022/app/app.module.mjs +2 -5
- app-ng-runtime/runtime/dynamic/esm2022/app/services/component-ref-provider.service.mjs +7 -23
- app-ng-runtime/runtime/dynamic/fesm2022/index.mjs +7 -26
- app-ng-runtime/runtime/dynamic/fesm2022/index.mjs.map +1 -1
- app-ng-runtime/scripts/@wavemaker/nvd3/build/nv.d3.min.js +1 -1
- app-ng-runtime/scripts/datatable/datatable.js +6 -3
- app-ng-runtime/scripts/summernote/dist/summernote-lite.min.js +2 -3
- app-ng-runtime/transpiler/bundles/index.umd.js +0 -5
- app-ng-runtime/transpiler/esm2022/build.mjs +1 -4
- app-ng-runtime/transpiler/esm2022/imports.mjs +1 -3
- app-ng-runtime/transpiler/fesm2022/index.mjs +0 -5
- app-ng-runtime/transpiler/fesm2022/index.mjs.map +1 -1
- app-ng-runtime/build-task/advanced/custom-widget-container/custom-widget-container.build.d.ts +0 -2
- app-ng-runtime/build-task/advanced/custom-widget-wrapper/custom-widget-wrapper.build.d.ts +0 -2
- app-ng-runtime/build-task/esm2022/advanced/custom-widget-container/custom-widget-container.build.mjs +0 -15
- app-ng-runtime/build-task/esm2022/advanced/custom-widget-wrapper/custom-widget-wrapper.build.mjs +0 -26
- app-ng-runtime/components/advanced/custom/.npmignore +0 -2
- app-ng-runtime/components/advanced/custom/bundles/index.umd.js +0 -232
- app-ng-runtime/components/advanced/custom/custom-widget-container/custom-widget-container.directive.d.ts +0 -19
- app-ng-runtime/components/advanced/custom/custom-widget-container/custom-widget.props.d.ts +0 -2
- app-ng-runtime/components/advanced/custom/custom-widget-prop.d.ts +0 -1
- app-ng-runtime/components/advanced/custom/custom-widget.directive.d.ts +0 -19
- app-ng-runtime/components/advanced/custom/custom-widget.module.d.ts +0 -10
- app-ng-runtime/components/advanced/custom/esm2022/custom-widget-container/custom-widget-container.directive.mjs +0 -102
- app-ng-runtime/components/advanced/custom/esm2022/custom-widget-container/custom-widget.props.mjs +0 -12
- app-ng-runtime/components/advanced/custom/esm2022/custom-widget-prop.mjs +0 -8
- app-ng-runtime/components/advanced/custom/esm2022/custom-widget.directive.mjs +0 -68
- app-ng-runtime/components/advanced/custom/esm2022/custom-widget.module.mjs +0 -32
- app-ng-runtime/components/advanced/custom/esm2022/index.mjs +0 -5
- app-ng-runtime/components/advanced/custom/esm2022/public_api.mjs +0 -4
- app-ng-runtime/components/advanced/custom/fesm2022/index.mjs +0 -215
- app-ng-runtime/components/advanced/custom/fesm2022/index.mjs.map +0 -1
- app-ng-runtime/components/advanced/custom/index.d.ts +0 -5
- app-ng-runtime/components/advanced/custom/package.json +0 -23
- app-ng-runtime/components/advanced/custom/public_api.d.ts +0 -3
- app-ng-runtime/components/base/esm2022/widgets/common/base/custom-widget-container.directive.mjs +0 -39
- app-ng-runtime/components/base/widgets/common/base/custom-widget-container.directive.d.ts +0 -14
- app-ng-runtime/runtime/base/components/base-custom-widget.component.d.ts +0 -72
- app-ng-runtime/runtime/base/esm2022/components/base-custom-widget.component.mjs +0 -288
@@ -167,12 +167,6 @@ export class CheckboxsetComponent extends DatasetAwareFormComponent {
|
|
167
167
|
styler(this.nativeElement, this);
|
168
168
|
this.multiple = true;
|
169
169
|
}
|
170
|
-
triggerInvokeOnChange(keys, $event) {
|
171
|
-
this.modelByKey = keys;
|
172
|
-
this.invokeOnTouched();
|
173
|
-
// invoke on datavalue change.
|
174
|
-
this.invokeOnChange(this.datavalue, $event || {}, true);
|
175
|
-
}
|
176
170
|
onCheckboxLabelClick($event, key) {
|
177
171
|
if (!$($event.target).is('input')) {
|
178
172
|
return;
|
@@ -184,7 +178,10 @@ export class CheckboxsetComponent extends DatasetAwareFormComponent {
|
|
184
178
|
// @ts-ignore
|
185
179
|
keys.push($el.value);
|
186
180
|
});
|
187
|
-
this.
|
181
|
+
this.modelByKey = keys;
|
182
|
+
this.invokeOnTouched();
|
183
|
+
// invoke on datavalue change.
|
184
|
+
this.invokeOnChange(this.datavalue, $event || {}, true);
|
188
185
|
}
|
189
186
|
// change and blur events are added from the template
|
190
187
|
handleEvent(node, eventName, callback, locals) {
|
@@ -257,4 +254,4 @@ export class CheckboxsetComponent extends DatasetAwareFormComponent {
|
|
257
254
|
args: ['keydown.enter', ['$event', '"ENTER"']]
|
258
255
|
}] }); })();
|
259
256
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(CheckboxsetComponent, { className: "CheckboxsetComponent", filePath: "checkboxset/checkboxset.component.ts", lineNumber: 27 }); })();
|
260
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkboxset.component.js","sourceRoot":"","sources":["../../../../../../projects/components/widgets/input/default/src/checkboxset/checkboxset.component.ts","../../../../../../projects/components/widgets/input/default/src/checkboxset/checkboxset.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Attribute, Component, HostListener, Inject, Injector, Optional} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, NG_VALIDATORS } from '@angular/forms';\n\nimport {AppDefaults, noop, setListClass, switchClass} from '@wm/core';\nimport { convertDataToObject, IWidgetConfig, groupData, handleHeaderClick, provideAs, provideAsWidgetRef, styler, toggleAllHeaders } from '@wm/components/base';\nimport { DatasetAwareFormComponent } from '../dataset-aware-form.component';\n\nimport { registerProps } from '../checkboxset/checkboxset.props';\nimport {forEach, includes} from \"lodash-es\";\n\ndeclare const $;\n\nconst DEFAULT_CLS = 'app-checkboxset list-group inline';\nconst WIDGET_CONFIG: IWidgetConfig = {widgetType: 'wm-checkboxset', hostClass: DEFAULT_CLS};\n\n@Component({\n    selector: '[wmCheckboxset]',\n    exportAs: 'wmCheckboxset',\n    templateUrl: 'checkboxset.component.html',\n    providers: [\n        provideAs(CheckboxsetComponent, NG_VALUE_ACCESSOR, true),\n        provideAs(CheckboxsetComponent, NG_VALIDATORS, true),\n        provideAsWidgetRef(CheckboxsetComponent)\n    ]\n})\n\nexport class CheckboxsetComponent extends DatasetAwareFormComponent {\n    static initializeProps = registerProps();\n\n    public layout = '';\n    public collapsible: boolean;\n\n    protected match: string;\n    protected dateformat: string;\n\n    public disabled: boolean;\n    public itemsperrow: string;\n    private itemsPerRowClass: string;\n\n    constructor(inj: Injector, @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any) {\n        super(inj, WIDGET_CONFIG, explicitContext);\n        styler(this.nativeElement, this);\n        this.multiple = true;\n    }\n\n    triggerInvokeOnChange(keys, $event) {\n        this.modelByKey = keys;\n\n        this.invokeOnTouched();\n        // invoke on datavalue change.\n        this.invokeOnChange(this.datavalue, $event || {}, true);\n    }\n\n    onCheckboxLabelClick($event, key) {\n        if (!$($event.target).is('input')) {\n            return;\n        }\n\n        // construct the _model from the checked elements.\n        const inputElements = this.nativeElement.querySelectorAll('input:checked');\n        const keys = [];\n        forEach(inputElements, ($el) => {\n            // @ts-ignore\n            keys.push($el.value);\n        });\n\n        this.triggerInvokeOnChange(keys, $event);\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 === 'click') {\n            this.eventManager.addEventListener(\n                node,\n                eventName,\n                e => {\n                    if (!$(e.target).is('input')) {\n                        return;\n                    }\n                    locals.$event = e;\n                    return callback();\n                }\n            );\n        } else if (!includes(['change'], eventName)) {\n            super.handleEvent(node, eventName, callback, locals);\n        }\n    }\n\n    @HostListener('keydown.enter', ['$event', '\"ENTER\"'])\n    onKeyDown($event) {\n        $event.preventDefault();\n        $event.target.click();\n    }\n\n    onPropertyChange(key, nv, ov?) {\n\n        if (key === 'tabindex') {\n            return;\n        }\n        if (key === 'required') {\n            this._onChange(this.datavalue);\n            return;\n        }\n        if (key === 'itemsperrow') {\n            setListClass(this);\n        } else {\n            super.onPropertyChange(key, nv, ov);\n        }\n    }\n}\n","<ng-template [ngIf]=\"!groupby\" [ngIfElse]=\"groupedListTemplate\">\n    <li [ngClass]=\"['checkbox', 'app-checkbox', itemclass, itemsPerRowClass]\"\n        [class.active]=\"item.selected\"\n        *ngFor=\"let item of datasetItems; let i = index\"\n        [wmItemTemplate]=\"content\" [userComponentParams]=\"item\" partialContainer\n        (click)=\"onCheckboxLabelClick($event, item.key)\" role=\"presentation\">\n        <!-- Default item template -->\n        <label *ngIf=\"!content\" class=\"app-checkboxset-label\" [ngClass]=\"{'disabled':disabled || readonly}\" [title]=\"item.label\">\n            <input [name]=\"'checkboxset_' + widgetId\" type=\"checkbox\" [attr.aria-label]=\"item.key\"\n                   [tabindex]=\"tabindex\" [attr.aria-checked]=\"item.selected\"\n                   [disabled]=\"disabled || readonly\" [attr.data-attr-index]=\"i\"\n                   [value]=\"item.key\" [tabindex]=\"tabindex\" [checked]=\"item.selected\"/>\n            <span class=\"caption\" [textContent]=\"item.label\"></span>\n        </label>\n        <!-- Custom partial template -->\n        <label *ngIf=\"content\" class=\"app-checkboxset-label\" [ngClass]=\"{'disabled':disabled || readonly}\" >\n            <input [name]=\"'checkboxset_' + widgetId\" type=\"checkbox\" [attr.aria-label]=\"item.key\"\n                   [tabindex]=\"tabindex\" [attr.aria-checked]=\"item.selected\"\n                   [disabled]=\"disabled || readonly\" [attr.data-attr-index]=\"i\"\n                   [value]=\"item.key\" [tabindex]=\"tabindex\" [checked]=\"item.selected\"/>\n            <span class=\"caption customTemplate\" partial-container-target></span>\n        </label>\n    </li>\n</ng-template>\n<input [disabled]=\"disabled || readonly\" hidden class=\"model-holder\">\n<div *ngIf=\"readonly || disabled\" class=\"readonly-wrapper\"></div>\n\n<!-- This template will be displayed when groupby is specified. -->\n<ng-template #groupedListTemplate>\n    <li *ngFor=\"let groupObj of groupedData\" class=\"app-list-item-group\" role=\"presentation\">\n        <ul class=\"item-group\">\n            <li class=\"list-group-header\" (click)=\"handleHeaderClick($event)\" [title]=\"groupObj.key\" [ngClass]=\"{'collapsible-content': collapsible}\">\n                <h4 class=\"group-title\">{{groupObj.key}}\n                    <div class=\"header-action\">\n                        <i class=\"app-icon wi action wi-chevron-up\" *ngIf=\"collapsible\" title=\"{{appLocale.LABEL_COLLAPSE}}/{{appLocale.LABEL_EXPAND}}\"></i>\n                        <span *ngIf=\"showcount\" class=\"label label-default\" [textContent]=\"groupObj.data.length\"></span>\n                    </div>\n                </h4>\n            </li>\n            <li *ngFor=\"let item of groupObj.data; let i = index;\"\n                [ngClass]=\"['checkbox', 'app-checkbox', 'group-list-item', itemclass, itemsPerRowClass]\"\n                [class.active]=\"item.selected\"\n                [wmItemTemplate]=\"content\" [userComponentParams]=\"item\" partialContainer\n                (click)=\"onCheckboxLabelClick($event, item)\">\n                <!-- Default item template -->\n                <label *ngIf=\"!content\" class=\"app-checkboxset-label\" [ngClass]=\"{'disabled':disabled || readonly}\" [title]=\"item.label\">\n                    <input [name]=\"'checkboxset_' + widgetId\" type=\"checkbox\" aria-label=\"checkbox group\"\n                           [tabindex]=\"tabindex\"\n                           [disabled]=\"disabled || readonly\" [attr.data-attr-index]=\"i\"\n                           [value]=\"item.key\" [tabindex]=\"tabindex\" [checked]=\"item.selected\"/>\n                    <span class=\"caption\" [textContent]=\"item.label\"></span>\n                </label>\n                <!-- Custom partial template -->\n                <label *ngIf=\"content\" class=\"app-checkboxset-label\" [ngClass]=\"{'disabled':disabled || readonly}\" >\n                    <input [name]=\"'checkboxset_' + widgetId\" type=\"checkbox\" aria-label=\"checkbox group\"\n                           [tabindex]=\"tabindex\"\n                           [disabled]=\"disabled || readonly\" [attr.data-attr-index]=\"i\"\n                           [value]=\"item.key\" [tabindex]=\"tabindex\" [checked]=\"item.selected\"/>\n                    <span class=\"caption\" partial-container-target></span>\n                </label>\n            </li>\n        </ul>\n    </li>\n</ng-template>\n"]}
|
257
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkboxset.component.js","sourceRoot":"","sources":["../../../../../../projects/components/widgets/input/default/src/checkboxset/checkboxset.component.ts","../../../../../../projects/components/widgets/input/default/src/checkboxset/checkboxset.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Attribute, Component, HostListener, Inject, Injector, Optional} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, NG_VALIDATORS } from '@angular/forms';\n\nimport {AppDefaults, noop, setListClass, switchClass} from '@wm/core';\nimport { convertDataToObject, IWidgetConfig, groupData, handleHeaderClick, provideAs, provideAsWidgetRef, styler, toggleAllHeaders } from '@wm/components/base';\nimport { DatasetAwareFormComponent } from '../dataset-aware-form.component';\n\nimport { registerProps } from '../checkboxset/checkboxset.props';\nimport {forEach, includes} from \"lodash-es\";\n\ndeclare const $;\n\nconst DEFAULT_CLS = 'app-checkboxset list-group inline';\nconst WIDGET_CONFIG: IWidgetConfig = {widgetType: 'wm-checkboxset', hostClass: DEFAULT_CLS};\n\n@Component({\n    selector: '[wmCheckboxset]',\n    exportAs: 'wmCheckboxset',\n    templateUrl: 'checkboxset.component.html',\n    providers: [\n        provideAs(CheckboxsetComponent, NG_VALUE_ACCESSOR, true),\n        provideAs(CheckboxsetComponent, NG_VALIDATORS, true),\n        provideAsWidgetRef(CheckboxsetComponent)\n    ]\n})\n\nexport class CheckboxsetComponent extends DatasetAwareFormComponent {\n    static initializeProps = registerProps();\n\n    public layout = '';\n    public collapsible: boolean;\n\n    protected match: string;\n    protected dateformat: string;\n\n    public disabled: boolean;\n    public itemsperrow: string;\n    private itemsPerRowClass: string;\n\n    constructor(inj: Injector, @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any) {\n        super(inj, WIDGET_CONFIG, explicitContext);\n        styler(this.nativeElement, this);\n        this.multiple = true;\n    }\n\n    onCheckboxLabelClick($event, key) {\n        if (!$($event.target).is('input')) {\n            return;\n        }\n\n        // construct the _model from the checked elements.\n        const inputElements = this.nativeElement.querySelectorAll('input:checked');\n        const keys = [];\n        forEach(inputElements, ($el) => {\n            // @ts-ignore\n            keys.push($el.value);\n        });\n\n        this.modelByKey = keys;\n\n        this.invokeOnTouched();\n        // invoke on datavalue change.\n        this.invokeOnChange(this.datavalue, $event || {}, true);\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 === 'click') {\n            this.eventManager.addEventListener(\n                node,\n                eventName,\n                e => {\n                    if (!$(e.target).is('input')) {\n                        return;\n                    }\n                    locals.$event = e;\n                    return callback();\n                }\n            );\n        } else if (!includes(['change'], eventName)) {\n            super.handleEvent(node, eventName, callback, locals);\n        }\n    }\n\n    @HostListener('keydown.enter', ['$event', '\"ENTER\"'])\n    onKeyDown($event) {\n        $event.preventDefault();\n        $event.target.click();\n    }\n\n    onPropertyChange(key, nv, ov?) {\n\n        if (key === 'tabindex') {\n            return;\n        }\n        if (key === 'required') {\n            this._onChange(this.datavalue);\n            return;\n        }\n        if (key === 'itemsperrow') {\n            setListClass(this);\n        } else {\n            super.onPropertyChange(key, nv, ov);\n        }\n    }\n}\n","<ng-template [ngIf]=\"!groupby\" [ngIfElse]=\"groupedListTemplate\">\n    <li [ngClass]=\"['checkbox', 'app-checkbox', itemclass, itemsPerRowClass]\"\n        [class.active]=\"item.selected\"\n        *ngFor=\"let item of datasetItems; let i = index\"\n        [wmItemTemplate]=\"content\" [userComponentParams]=\"item\" partialContainer\n        (click)=\"onCheckboxLabelClick($event, item.key)\" role=\"presentation\">\n        <!-- Default item template -->\n        <label *ngIf=\"!content\" class=\"app-checkboxset-label\" [ngClass]=\"{'disabled':disabled || readonly}\" [title]=\"item.label\">\n            <input [name]=\"'checkboxset_' + widgetId\" type=\"checkbox\" [attr.aria-label]=\"item.key\"\n                   [tabindex]=\"tabindex\" [attr.aria-checked]=\"item.selected\"\n                   [disabled]=\"disabled || readonly\" [attr.data-attr-index]=\"i\"\n                   [value]=\"item.key\" [tabindex]=\"tabindex\" [checked]=\"item.selected\"/>\n            <span class=\"caption\" [textContent]=\"item.label\"></span>\n        </label>\n        <!-- Custom partial template -->\n        <label *ngIf=\"content\" class=\"app-checkboxset-label\" [ngClass]=\"{'disabled':disabled || readonly}\" >\n            <input [name]=\"'checkboxset_' + widgetId\" type=\"checkbox\" [attr.aria-label]=\"item.key\"\n                   [tabindex]=\"tabindex\" [attr.aria-checked]=\"item.selected\"\n                   [disabled]=\"disabled || readonly\" [attr.data-attr-index]=\"i\"\n                   [value]=\"item.key\" [tabindex]=\"tabindex\" [checked]=\"item.selected\"/>\n            <span class=\"caption customTemplate\" partial-container-target></span>\n        </label>\n    </li>\n</ng-template>\n<input [disabled]=\"disabled || readonly\" hidden class=\"model-holder\">\n<div *ngIf=\"readonly || disabled\" class=\"readonly-wrapper\"></div>\n\n<!-- This template will be displayed when groupby is specified. -->\n<ng-template #groupedListTemplate>\n    <li *ngFor=\"let groupObj of groupedData\" class=\"app-list-item-group\" role=\"presentation\">\n        <ul class=\"item-group\">\n            <li class=\"list-group-header\" (click)=\"handleHeaderClick($event)\" [title]=\"groupObj.key\" [ngClass]=\"{'collapsible-content': collapsible}\">\n                <h4 class=\"group-title\">{{groupObj.key}}\n                    <div class=\"header-action\">\n                        <i class=\"app-icon wi action wi-chevron-up\" *ngIf=\"collapsible\" title=\"{{appLocale.LABEL_COLLAPSE}}/{{appLocale.LABEL_EXPAND}}\"></i>\n                        <span *ngIf=\"showcount\" class=\"label label-default\" [textContent]=\"groupObj.data.length\"></span>\n                    </div>\n                </h4>\n            </li>\n            <li *ngFor=\"let item of groupObj.data; let i = index;\"\n                [ngClass]=\"['checkbox', 'app-checkbox', 'group-list-item', itemclass, itemsPerRowClass]\"\n                [class.active]=\"item.selected\"\n                [wmItemTemplate]=\"content\" [userComponentParams]=\"item\" partialContainer\n                (click)=\"onCheckboxLabelClick($event, item)\">\n                <!-- Default item template -->\n                <label *ngIf=\"!content\" class=\"app-checkboxset-label\" [ngClass]=\"{'disabled':disabled || readonly}\" [title]=\"item.label\">\n                    <input [name]=\"'checkboxset_' + widgetId\" type=\"checkbox\" aria-label=\"checkbox group\"\n                           [tabindex]=\"tabindex\"\n                           [disabled]=\"disabled || readonly\" [attr.data-attr-index]=\"i\"\n                           [value]=\"item.key\" [tabindex]=\"tabindex\" [checked]=\"item.selected\"/>\n                    <span class=\"caption\" [textContent]=\"item.label\"></span>\n                </label>\n                <!-- Custom partial template -->\n                <label *ngIf=\"content\" class=\"app-checkboxset-label\" [ngClass]=\"{'disabled':disabled || readonly}\" >\n                    <input [name]=\"'checkboxset_' + widgetId\" type=\"checkbox\" aria-label=\"checkbox group\"\n                           [tabindex]=\"tabindex\"\n                           [disabled]=\"disabled || readonly\" [attr.data-attr-index]=\"i\"\n                           [value]=\"item.key\" [tabindex]=\"tabindex\" [checked]=\"item.selected\"/>\n                    <span class=\"caption\" partial-container-target></span>\n                </label>\n            </li>\n        </ul>\n    </li>\n</ng-template>\n"]}
|
@@ -167,12 +167,6 @@ export class RadiosetComponent extends DatasetAwareFormComponent {
|
|
167
167
|
styler(this.nativeElement, this);
|
168
168
|
this.multiple = false;
|
169
169
|
}
|
170
|
-
triggerInvokeOnChange(key, $event) {
|
171
|
-
this.modelByKey = key;
|
172
|
-
this.invokeOnTouched();
|
173
|
-
// invoke on datavalue change.
|
174
|
-
this.invokeOnChange(this.datavalue, $event || {}, true);
|
175
|
-
}
|
176
170
|
/**
|
177
171
|
* On click of the option, update the datavalue
|
178
172
|
*/
|
@@ -180,7 +174,10 @@ export class RadiosetComponent extends DatasetAwareFormComponent {
|
|
180
174
|
if (!$($event.target).is('input')) {
|
181
175
|
return;
|
182
176
|
}
|
183
|
-
this.
|
177
|
+
this.modelByKey = key;
|
178
|
+
this.invokeOnTouched();
|
179
|
+
// invoke on datavalue change.
|
180
|
+
this.invokeOnChange(this.datavalue, $event || {}, true);
|
184
181
|
}
|
185
182
|
// change and blur events are added from the template
|
186
183
|
handleEvent(node, eventName, callback, locals) {
|
@@ -240,4 +237,4 @@ export class RadiosetComponent extends DatasetAwareFormComponent {
|
|
240
237
|
type: Optional
|
241
238
|
}] }], null); })();
|
242
239
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(RadiosetComponent, { className: "RadiosetComponent", filePath: "radioset/radioset.component.ts", lineNumber: 26 }); })();
|
243
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radioset.component.js","sourceRoot":"","sources":["../../../../../../projects/components/widgets/input/default/src/radioset/radioset.component.ts","../../../../../../projects/components/widgets/input/default/src/radioset/radioset.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAC,MAAM,eAAe,CAAC;AACpE,OAAO,EAAE,iBAAiB,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAElE,OAAO,EAAC,YAAY,EAAC,MAAM,UAAU,CAAC;AAEtC,OAAO,EAAE,kBAAkB,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAC5E,OAAO,EAAE,yBAAyB,EAAE,MAAM,iCAAiC,CAAC;AAC5E,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,EAAE,QAAQ,EAAC,MAAM,WAAW,CAAC;;;;;;;;;;ICD5B,gCACqD;IAIjD,AAHA,2BAEqC,cACmB;IAC5D,iBAAQ;;;;;;IALD,yFAA6C;IACzC,cAA+B;IAC4C,AAAtB,AAAlC,AAAnB,AADA,oDAA+B,sBACb,gDAAkC,6BAAsB,6BAA0B;;IAErF,cAA0B;IAA1B,2CAA0B;;;IAGpD,gCACqD;IAIjD,AAHA,2BAEqC,eACgC;IACzE,iBAAQ;;;;;;IALD,wFAA6C;IACzC,cAA+B;IAC4C,AAAtB,AAAlC,AAAnB,AADA,oDAA+B,sBACb,gDAAkC,6BAAsB,6BAA0B;;;;;IAjBnH,6BAIsE;IAAlE,uNAAS,6CAAmC,KAAC;IAU7C,AARA,0FACqD,6EAQA;IAMzD,iBAAK;;;;IApBD,0CAA8B;IAEH,AAA3B,AAHA,+FAA+D,kCAGrC,gCAA6B;IAG/C,cAAc;IAAd,sCAAc;IAQd,cAAa;IAAb,qCAAa;;;IAdzB,+EAIsE;;;IAFjD,6CAAgB;;;IAuBzC,0BAAsF;;;IAS9D,wBAAoI;;;IAApE,+GAA+D;;;IAC/H,2BAAgG;;;IAA5C,qDAAoC;;;IAUhG,gCACqD;IAGjD,AAFA,2BAC6G,cACrD;IAC5D,iBAAQ;;;;;;IAJD,wFAA6C;IACzC,cAA+B;IAC4C,AAAtB,AAAlC,AAAnB,AADA,oDAA+B,sBACb,gDAAkC,6BAAsB,6BAA0B;;IACrF,cAA0B;IAA1B,2CAA0B;;;IAGpD,gCACqD;IAGjD,AAFA,2BAC6G,eACxC;IACzE,iBAAQ;;;;;;IAJD,wFAA6C;IACzC,cAA+B;IAC4C,AAAtB,AAAlC,AAAnB,AADA,oDAA+B,sBACb,gDAAkC,6BAAsB,6BAA0B;;;;;IAhBnH,8BAI8C;IAA1C,4NAAS,yCAA+B,KAAC;IASzC,AAPA,+FACqD,kFAOA;IAKzD,iBAAK;;;;IAjBD,0CAA8B;IACH,AAA3B,AAFA,+FAAkF,kCAExD,gCAA6B;IAG/C,cAAc;IAAd,sCAAc;IAOd,cAAa;IAAb,qCAAa;;;;IArBzB,AADJ,AADJ,8BAAqE,aAC1C,aACuH;IAA5G,6LAAS,gCAAyB,KAAC;IAC7D,8BAAwB;IAAA,YACpB;IAAA,+BAA2B;IAEvB,AADA,kFAAgI,2EACvC;IAGrG,AADI,AADI,iBAAM,EACL,EACJ;IACL,qFAI8C;IAiBtD,AADI,iBAAK,EACJ;;;;IA7BqE,eAAsB;IAAC,AAAvB,uCAAsB,2DAAiD;IAC7G,eACpB;IADoB,+CACpB;IACiD,eAAiB;IAAjB,yCAAiB;IACvD,cAAe;IAAf,uCAAe;IAIb,cAAkB;IAAlB,0CAAkB;;;IAV/C,+EAAqE;;;IAA5C,4CAAc;;ADlB3C,MAAM,WAAW,GAAG,gCAAgC,CAAC;AACrD,MAAM,aAAa,GAAG,EAAC,UAAU,EAAE,aAAa,EAAE,SAAS,EAAE,WAAW,EAAC,CAAC;AAY1E,MAAM,OAAO,iBAAkB,SAAQ,yBAAyB;aACrD,oBAAe,GAAG,aAAa,EAAE,AAAlB,CAAmB;IAOzC,YAAY,GAAa,EAA0C,eAAoB;QACnF,KAAK,CAAC,GAAG,EAAE,aAAa,EAAE,eAAe,CAAC,CAAC;QANxC,WAAM,GAAG,EAAE,CAAC;QAOf,MAAM,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;QACjC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IAC1B,CAAC;IAED,qBAAqB,CAAC,GAAG,EAAE,MAAM;QAC7B,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC;QAEtB,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,8BAA8B;QAC9B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM,IAAI,EAAE,EAAE,IAAI,CAAC,CAAC;IAC5D,CAAC;IAED;;OAEG;IACH,iBAAiB,CAAC,MAAM,EAAE,GAAG;QACzB,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC;YAChC,OAAO;QACX,CAAC;QAED,IAAI,CAAC,qBAAqB,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;IAC5C,CAAC;IAED,qDAAqD;IAC3C,WAAW,CAAC,IAAiB,EAAE,SAAiB,EAAE,QAAkB,EAAE,MAAW;QACvF,IAAI,SAAS,KAAK,OAAO,EAAE,CAAC;YACxB,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAC9B,IAAI,EACJ,SAAS,EACT,CAAC,CAAC,EAAE;gBACA,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC;oBAC3B,OAAO;gBACX,CAAC;gBACD,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;gBAClB,OAAO,QAAQ,EAAE,CAAC;YACtB,CAAC,CACJ,CAAC;QACN,CAAC;aAAM,IAAI,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,EAAE,SAAS,CAAC,EAAE,CAAC;YAC1C,KAAK,CAAC,WAAW,CAAC,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;QACzD,CAAC;IACL,CAAC;IAED,gBAAgB,CAAC,GAAG,EAAE,EAAE,EAAE,EAAG;QACzB,IAAI,GAAG,KAAK,UAAU,EAAE,CAAC;YACrB,OAAO;QACX,CAAC;QACD,IAAI,GAAG,KAAK,aAAa,EAAE,CAAC;YACxB,YAAY,CAAC,IAAI,CAAC,CAAC;QACvB,CAAC;aAAM,CAAC;YACJ,KAAK,CAAC,gBAAgB,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QACxC,CAAC;IACL,CAAC;kFA7DQ,iBAAiB,0DAQS,kBAAkB;oEAR5C,iBAAiB,kGANf;gBACP,SAAS,CAAC,iBAAiB,EAAE,iBAAiB,EAAE,IAAI,CAAC;gBACrD,SAAS,CAAC,iBAAiB,EAAE,aAAa,EAAE,IAAI,CAAC;gBACjD,kBAAkB,CAAC,iBAAiB,CAAC;aACxC;YCvBL,kFAAgE;YAyBhE,2BAAqE;YAIrE,AAHA,kEAAgF,sGAG9C;;;YA7BH,AAAlB,mCAAiB,qCAAiC;YAyBxD,cAAiC;YAAjC,uDAAiC;YAClC,cAA0B;YAA1B,mDAA0B;;;iFDDnB,iBAAiB;cAV7B,SAAS;2BACI,cAAc,YACd,YAAY,aAEX;oBACP,SAAS,oBAAoB,iBAAiB,EAAE,IAAI,CAAC;oBACrD,SAAS,oBAAoB,aAAa,EAAE,IAAI,CAAC;oBACjD,kBAAkB,mBAAmB;iBACxC;;sBAU2B,MAAM;uBAAC,kBAAkB;;sBAAG,QAAQ;;kFARvD,iBAAiB","sourcesContent":["import {Component, Inject, Injector, Optional} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, NG_VALIDATORS } from '@angular/forms';\n\nimport {setListClass} from '@wm/core';\n\nimport { provideAsWidgetRef, styler, provideAs } from '@wm/components/base';\nimport { DatasetAwareFormComponent } from '../dataset-aware-form.component';\nimport { registerProps } from './radioset.props';\nimport { includes} from \"lodash-es\";\n\ndeclare const $;\n\nconst DEFAULT_CLS = 'app-radioset list-group inline';\nconst WIDGET_CONFIG = {widgetType: 'wm-radioset', hostClass: DEFAULT_CLS};\n\n@Component({\n    selector: '[wmRadioset]',\n    exportAs: 'wmRadioset',\n    templateUrl: './radioset.component.html',\n    providers: [\n        provideAs(RadiosetComponent, NG_VALUE_ACCESSOR, true),\n        provideAs(RadiosetComponent, NG_VALIDATORS, true),\n        provideAsWidgetRef(RadiosetComponent)\n    ]\n})\nexport class RadiosetComponent extends DatasetAwareFormComponent {\n    static initializeProps = registerProps();\n\n    public layout = '';\n    public disabled: boolean;\n    public itemsperrow: string;\n    private itemsPerRowClass: string;\n\n    constructor(inj: Injector, @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any) {\n        super(inj, WIDGET_CONFIG, explicitContext);\n        styler(this.nativeElement, this);\n        this.multiple = false;\n    }\n\n    triggerInvokeOnChange(key, $event) {\n        this.modelByKey = key;\n\n        this.invokeOnTouched();\n        // invoke on datavalue change.\n        this.invokeOnChange(this.datavalue, $event || {}, true);\n    }\n\n    /**\n     * On click of the option, update the datavalue\n     */\n    onRadioLabelClick($event, key) {\n        if (!$($event.target).is('input')) {\n            return;\n        }\n\n        this.triggerInvokeOnChange(key, $event);\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 === 'click') {\n            this.eventManager.addEventListener(\n                node,\n                eventName,\n                e => {\n                    if (!$(e.target).is('input')) {\n                        return;\n                    }\n                    locals.$event = e;\n                    return callback();\n                }\n            );\n        } else if (!includes(['change'], eventName)) {\n            super.handleEvent(node, eventName, callback, locals);\n        }\n    }\n\n    onPropertyChange(key, nv, ov?) {\n        if (key === 'tabindex') {\n            return;\n        }\n        if (key === 'itemsperrow') {\n            setListClass(this);\n        } else {\n            super.onPropertyChange(key, nv, ov);\n        }\n    }\n}\n","<ng-template [ngIf]=\"!groupby\" [ngIfElse]=\"groupedListTemplate\">\n    <li [ngClass]=\"['radio', 'app-radio', itemclass, itemsPerRowClass]\"\n        [class.active]=\"item.selected\"\n        *ngFor=\"let item of datasetItems;let i = index\"\n        [wmItemTemplate]=\"content\" [userComponentParams]=\"item\" partialContainer\n        (click)=\"onRadioLabelClick($event, item.key)\" role=\"presentation\">\n        <!-- Default item template -->\n        <label *ngIf=\"!content\" class=\"app-radioset-label\"\n               [ngClass]=\"{'disabled':disabled || readonly}\">\n            <input [name]=\"'radioset_' + widgetId\" type=\"radio\" [attr.aria-checked]=\"item.selected\" [attr.data-attr-index]=\"i\"\n                   [value]=\"item.key\" [disabled]=\"disabled || readonly\" [tabindex]=\"tabindex\" [checked]=\"item.selected\"\n                   [attr.aria-label]=\"item.key\"/>\n            <span class=\"caption\" [textContent]=\"item.label\"></span>\n        </label>\n        <!-- Custom partial template -->\n        <label *ngIf=\"content\" class=\"app-radioset-label\"\n               [ngClass]=\"{'disabled':disabled || readonly}\">\n            <input [name]=\"'radioset_' + widgetId\" type=\"radio\" [attr.aria-checked]=\"item.selected\" [attr.data-attr-index]=\"i\"\n                   [value]=\"item.key\" [disabled]=\"disabled || readonly\" [tabindex]=\"tabindex\" [checked]=\"item.selected\"\n                   [attr.aria-label]=\"item.key\"/>\n            <span class=\"caption customTemplate\" partial-container-target></span>\n        </label>\n    </li>\n</ng-template>\n\n<input [disabled]=\"disabled || readonly\" hidden class=\"model-holder\">\n<div *ngIf=\"readonly || disabled\" aria-readonly=\"true\" class=\"readonly-wrapper\"></div>\n\n<!-- This template will be displayed when groupby is specified. -->\n<ng-template #groupedListTemplate>\n    <li *ngFor=\"let groupObj of groupedData\" class=\"app-list-item-group\">\n        <ul class=\"item-group\">\n            <li class=\"list-group-header\" (click)=\"handleHeaderClick($event)\" [title]=\"groupObj.key\" [ngClass]=\"{'collapsible-content': collapsible}\">\n                <h4 class=\"group-title\">{{groupObj.key}}\n                    <div class=\"header-action\">\n                        <i class=\"app-icon wi action wi-chevron-up\" *ngIf=\"collapsible\" title=\"{{appLocale.LABEL_COLLAPSE}}/{{appLocale.LABEL_EXPAND}}\"></i>\n                        <span *ngIf=\"showcount\" class=\"label label-default\" [textContent]=\"groupObj.data.length\"></span>\n                    </div>\n                </h4>\n            </li>\n            <li *ngFor=\"let item of groupObj.data; let i = index;\"\n                [ngClass]=\"['radio', 'app-radio', 'group-list-item', itemclass, itemsPerRowClass]\"\n                [class.active]=\"item.selected\"\n                [wmItemTemplate]=\"content\" [userComponentParams]=\"item\" partialContainer\n                (click)=\"onRadioLabelClick($event, item)\">\n                <!-- Default item template -->\n                <label *ngIf=\"!content\" class=\"app-radioset-label\"\n                       [ngClass]=\"{'disabled':disabled || readonly}\">\n                    <input [name]=\"'radioset_' + widgetId\" type=\"radio\" [attr.aria-checked]=\"item.selected\" [attr.data-attr-index]=\"i\"\n                           [value]=\"item.key\" [disabled]=\"disabled || readonly\" [tabindex]=\"tabindex\" [checked]=\"item.selected\"/>\n                    <span class=\"caption\" [textContent]=\"item.label\"></span>\n                </label>\n                <!-- Custom partial template -->\n                <label *ngIf=\"content\" class=\"app-radioset-label\"\n                       [ngClass]=\"{'disabled':disabled || readonly}\">\n                    <input [name]=\"'radioset_' + widgetId\" type=\"radio\" [attr.aria-checked]=\"item.selected\" [attr.data-attr-index]=\"i\"\n                           [value]=\"item.key\" [disabled]=\"disabled || readonly\" [tabindex]=\"tabindex\" [checked]=\"item.selected\"/>\n                    <span class=\"caption customTemplate\" partial-container-target></span>\n                </label>\n            </li>\n        </ul>\n    </li>\n</ng-template>\n"]}
|
240
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radioset.component.js","sourceRoot":"","sources":["../../../../../../projects/components/widgets/input/default/src/radioset/radioset.component.ts","../../../../../../projects/components/widgets/input/default/src/radioset/radioset.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject, Injector, Optional} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, NG_VALIDATORS } from '@angular/forms';\n\nimport {setListClass} from '@wm/core';\n\nimport { provideAsWidgetRef, styler, provideAs } from '@wm/components/base';\nimport { DatasetAwareFormComponent } from '../dataset-aware-form.component';\nimport { registerProps } from './radioset.props';\nimport {includes} from \"lodash-es\";\n\ndeclare const $;\n\nconst DEFAULT_CLS = 'app-radioset list-group inline';\nconst WIDGET_CONFIG = {widgetType: 'wm-radioset', hostClass: DEFAULT_CLS};\n\n@Component({\n    selector: '[wmRadioset]',\n    exportAs: 'wmRadioset',\n    templateUrl: './radioset.component.html',\n    providers: [\n        provideAs(RadiosetComponent, NG_VALUE_ACCESSOR, true),\n        provideAs(RadiosetComponent, NG_VALIDATORS, true),\n        provideAsWidgetRef(RadiosetComponent)\n    ]\n})\nexport class RadiosetComponent extends DatasetAwareFormComponent {\n    static initializeProps = registerProps();\n\n    public layout = '';\n    public disabled: boolean;\n    public itemsperrow: string;\n    private itemsPerRowClass: string;\n\n    constructor(inj: Injector, @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any) {\n        super(inj, WIDGET_CONFIG, explicitContext);\n        styler(this.nativeElement, this);\n        this.multiple = false;\n    }\n\n    /**\n     * On click of the option, update the datavalue\n     */\n    onRadioLabelClick($event, key) {\n        if (!$($event.target).is('input')) {\n            return;\n        }\n\n        this.modelByKey = key;\n\n        this.invokeOnTouched();\n        // invoke on datavalue change.\n        this.invokeOnChange(this.datavalue, $event || {}, true);\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 === 'click') {\n            this.eventManager.addEventListener(\n                node,\n                eventName,\n                e => {\n                    if (!$(e.target).is('input')) {\n                        return;\n                    }\n                    locals.$event = e;\n                    return callback();\n                }\n            );\n        } else if (!includes(['change'], eventName)) {\n            super.handleEvent(node, eventName, callback, locals);\n        }\n    }\n\n    onPropertyChange(key, nv, ov?) {\n        if (key === 'tabindex') {\n            return;\n        }\n        if (key === 'itemsperrow') {\n            setListClass(this);\n        } else {\n            super.onPropertyChange(key, nv, ov);\n        }\n    }\n}\n","<ng-template [ngIf]=\"!groupby\" [ngIfElse]=\"groupedListTemplate\">\n    <li [ngClass]=\"['radio', 'app-radio', itemclass, itemsPerRowClass]\"\n        [class.active]=\"item.selected\"\n        *ngFor=\"let item of datasetItems;let i = index\"\n        [wmItemTemplate]=\"content\" [userComponentParams]=\"item\" partialContainer\n        (click)=\"onRadioLabelClick($event, item.key)\" role=\"presentation\">\n        <!-- Default item template -->\n        <label *ngIf=\"!content\" class=\"app-radioset-label\"\n               [ngClass]=\"{'disabled':disabled || readonly}\">\n            <input [name]=\"'radioset_' + widgetId\" type=\"radio\" [attr.aria-checked]=\"item.selected\" [attr.data-attr-index]=\"i\"\n                   [value]=\"item.key\" [disabled]=\"disabled || readonly\" [tabindex]=\"tabindex\" [checked]=\"item.selected\"\n                   [attr.aria-label]=\"item.key\"/>\n            <span class=\"caption\" [textContent]=\"item.label\"></span>\n        </label>\n        <!-- Custom partial template -->\n        <label *ngIf=\"content\" class=\"app-radioset-label\"\n               [ngClass]=\"{'disabled':disabled || readonly}\">\n            <input [name]=\"'radioset_' + widgetId\" type=\"radio\" [attr.aria-checked]=\"item.selected\" [attr.data-attr-index]=\"i\"\n                   [value]=\"item.key\" [disabled]=\"disabled || readonly\" [tabindex]=\"tabindex\" [checked]=\"item.selected\"\n                   [attr.aria-label]=\"item.key\"/>\n            <span class=\"caption customTemplate\" partial-container-target></span>\n        </label>\n    </li>\n</ng-template>\n\n<input [disabled]=\"disabled || readonly\" hidden class=\"model-holder\">\n<div *ngIf=\"readonly || disabled\" aria-readonly=\"true\" class=\"readonly-wrapper\"></div>\n\n<!-- This template will be displayed when groupby is specified. -->\n<ng-template #groupedListTemplate>\n    <li *ngFor=\"let groupObj of groupedData\" class=\"app-list-item-group\">\n        <ul class=\"item-group\">\n            <li class=\"list-group-header\" (click)=\"handleHeaderClick($event)\" [title]=\"groupObj.key\" [ngClass]=\"{'collapsible-content': collapsible}\">\n                <h4 class=\"group-title\">{{groupObj.key}}\n                    <div class=\"header-action\">\n                        <i class=\"app-icon wi action wi-chevron-up\" *ngIf=\"collapsible\" title=\"{{appLocale.LABEL_COLLAPSE}}/{{appLocale.LABEL_EXPAND}}\"></i>\n                        <span *ngIf=\"showcount\" class=\"label label-default\" [textContent]=\"groupObj.data.length\"></span>\n                    </div>\n                </h4>\n            </li>\n            <li *ngFor=\"let item of groupObj.data; let i = index;\"\n                [ngClass]=\"['radio', 'app-radio', 'group-list-item', itemclass, itemsPerRowClass]\"\n                [class.active]=\"item.selected\"\n                [wmItemTemplate]=\"content\" [userComponentParams]=\"item\" partialContainer\n                (click)=\"onRadioLabelClick($event, item)\">\n                <!-- Default item template -->\n                <label *ngIf=\"!content\" class=\"app-radioset-label\"\n                       [ngClass]=\"{'disabled':disabled || readonly}\">\n                    <input [name]=\"'radioset_' + widgetId\" type=\"radio\" [attr.aria-checked]=\"item.selected\" [attr.data-attr-index]=\"i\"\n                           [value]=\"item.key\" [disabled]=\"disabled || readonly\" [tabindex]=\"tabindex\" [checked]=\"item.selected\"/>\n                    <span class=\"caption\" [textContent]=\"item.label\"></span>\n                </label>\n                <!-- Custom partial template -->\n                <label *ngIf=\"content\" class=\"app-radioset-label\"\n                       [ngClass]=\"{'disabled':disabled || readonly}\">\n                    <input [name]=\"'radioset_' + widgetId\" type=\"radio\" [attr.aria-checked]=\"item.selected\" [attr.data-attr-index]=\"i\"\n                           [value]=\"item.key\" [disabled]=\"disabled || readonly\" [tabindex]=\"tabindex\" [checked]=\"item.selected\"/>\n                    <span class=\"caption customTemplate\" partial-container-target></span>\n                </label>\n            </li>\n        </ul>\n    </li>\n</ng-template>\n"]}
|
@@ -1,15 +1,13 @@
|
|
1
1
|
import { Component, ElementRef, Inject, Injector, Optional, ViewChild } from '@angular/core';
|
2
2
|
import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
|
3
|
-
import {
|
3
|
+
import { DataSource, removeAttr, setAttr } from '@wm/core';
|
4
4
|
import { provideAs, provideAsWidgetRef, styler } from '@wm/components/base';
|
5
5
|
import { DatasetAwareFormComponent } from '../dataset-aware-form.component';
|
6
6
|
import { registerProps } from './select.props';
|
7
|
-
import { includes } from "lodash-es";
|
8
7
|
import * as i0 from "@angular/core";
|
9
|
-
import * as i1 from "@
|
10
|
-
import * as i2 from "@angular/
|
11
|
-
import * as i3 from "@
|
12
|
-
import * as i4 from "@wm/components/base";
|
8
|
+
import * as i1 from "@angular/common";
|
9
|
+
import * as i2 from "@angular/forms";
|
10
|
+
import * as i3 from "@wm/components/base";
|
13
11
|
const _c0 = ["select"];
|
14
12
|
const _c1 = a0 => ["app-select form-control", a0];
|
15
13
|
const _c2 = () => ({ standalone: true });
|
@@ -61,10 +59,36 @@ export class SelectComponent extends DatasetAwareFormComponent {
|
|
61
59
|
this.datavalue = ds.execute(DataSource.Operation.GET_DEFAULT_LOCALE);
|
62
60
|
}
|
63
61
|
}
|
64
|
-
constructor(inj,
|
62
|
+
constructor(inj, explicitContext) {
|
65
63
|
super(inj, WIDGET_CONFIG, explicitContext);
|
66
|
-
this.app = app;
|
67
64
|
this.acceptsArray = true;
|
65
|
+
/*
|
66
|
+
* When the dataset for a select element is updated and no longer includes the previously selected value:
|
67
|
+
* The select element becomes empty, and the ngModel value is updated to reflect this change.
|
68
|
+
* However, the change event is not triggered, preventing the form control from recognizing the update and applying necessary validations.
|
69
|
+
* As this widget implements ControlValueAccessor, manually updating the ngModel (or modelByKey) is necessary to ensure correct form behavior.
|
70
|
+
* */
|
71
|
+
const datasetSubscription = this.dataset$.subscribe(() => {
|
72
|
+
if (this.datavalue) {
|
73
|
+
const selectedItem = this.datasetItems.find(item => item.selected);
|
74
|
+
if (!selectedItem) {
|
75
|
+
setTimeout(() => {
|
76
|
+
if (!this.placeholder) {
|
77
|
+
this.selectEl.nativeElement.value = '';
|
78
|
+
}
|
79
|
+
this.modelByKey = undefined;
|
80
|
+
}, 100);
|
81
|
+
}
|
82
|
+
}
|
83
|
+
else {
|
84
|
+
setTimeout(() => {
|
85
|
+
if (!this.placeholder) {
|
86
|
+
this.selectEl.nativeElement.value = '';
|
87
|
+
}
|
88
|
+
}, 100);
|
89
|
+
}
|
90
|
+
});
|
91
|
+
this.registerDestroyListener(() => datasetSubscription.unsubscribe());
|
68
92
|
}
|
69
93
|
ngAfterViewInit() {
|
70
94
|
super.ngAfterViewInit();
|
@@ -72,7 +96,7 @@ export class SelectComponent extends DatasetAwareFormComponent {
|
|
72
96
|
}
|
73
97
|
// Change event is registered from the template, Prevent the framework from registering one more event
|
74
98
|
handleEvent(node, eventName, eventCallback, locals) {
|
75
|
-
if (!
|
99
|
+
if (!['blur', 'change'].includes(eventName)) {
|
76
100
|
super.handleEvent(this.selectEl.nativeElement, eventName, eventCallback, locals);
|
77
101
|
}
|
78
102
|
}
|
@@ -123,36 +147,40 @@ export class SelectComponent extends DatasetAwareFormComponent {
|
|
123
147
|
*/
|
124
148
|
checkForFloatingLabel($event) {
|
125
149
|
const captionEl = $(this.selectEl.nativeElement).closest('.app-composite-widget.caption-floating');
|
150
|
+
if (!this.placeholder) {
|
151
|
+
this.removePlaceholderOption();
|
152
|
+
}
|
126
153
|
if (captionEl.length > 0) {
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
else {
|
132
|
-
$(this.selectEl.nativeElement).find('option:first').text(this.placeholder);
|
154
|
+
const placeholderOption = this.selectEl.nativeElement.querySelector('#placeholderOption');
|
155
|
+
if ($event.type === 'mousedown' && (!this.datavalue || (this.datavalue && $(this.selectEl).find('select option:selected').text() === '' && this.placeholder))) {
|
156
|
+
if (this.placeholder) {
|
157
|
+
placeholderOption.textContent = this.placeholder;
|
133
158
|
}
|
134
159
|
}
|
135
160
|
else if (!this.datavalue) {
|
136
|
-
|
161
|
+
if (this.placeholder) {
|
162
|
+
placeholderOption.textContent = '';
|
163
|
+
}
|
137
164
|
captionEl.removeClass('float-active');
|
138
165
|
}
|
139
166
|
}
|
140
|
-
else if (!(this.datavalue || this.placeholder)) {
|
141
|
-
this.removePlaceholderOption();
|
142
|
-
}
|
143
167
|
}
|
144
168
|
/*
|
145
169
|
* Removing the placeholder option if no placeholder is provided.
|
146
|
-
* In html we are hiding the placeholder option using css but in
|
170
|
+
* In html we are hiding the placeholder option using css but in Apple devices and safari option is showing.
|
171
|
+
* Styles are not allowed on option tag in ios safari
|
172
|
+
* After removing the option, if no datavalue is present and native select element sets value to the first option by default, so we are setting it to empty
|
147
173
|
* */
|
148
174
|
removePlaceholderOption() {
|
149
175
|
const hiddenEle = $(this.selectEl.nativeElement).find('#placeholderOption');
|
150
176
|
if (hiddenEle.length) {
|
151
177
|
hiddenEle.remove();
|
152
|
-
this.
|
178
|
+
if (!this.datavalue) {
|
179
|
+
this.selectEl.nativeElement.value = '';
|
180
|
+
}
|
153
181
|
}
|
154
182
|
}
|
155
|
-
static { this.ɵfac = function SelectComponent_Factory(t) { return new (t || SelectComponent)(i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(
|
183
|
+
static { this.ɵfac = function SelectComponent_Factory(t) { return new (t || SelectComponent)(i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject('EXPLICIT_CONTEXT', 8)); }; }
|
156
184
|
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SelectComponent, selectors: [["wm-select"]], viewQuery: function SelectComponent_Query(rf, ctx) { if (rf & 1) {
|
157
185
|
i0.ɵɵviewQuery(_c0, 7, ElementRef);
|
158
186
|
} if (rf & 2) {
|
@@ -162,11 +190,11 @@ export class SelectComponent extends DatasetAwareFormComponent {
|
|
162
190
|
provideAs(SelectComponent, NG_VALUE_ACCESSOR, true),
|
163
191
|
provideAs(SelectComponent, NG_VALIDATORS, true),
|
164
192
|
provideAsWidgetRef(SelectComponent)
|
165
|
-
]), i0.ɵɵInheritDefinitionFeature], decls: 5, vars: 18, consts: [["select", ""], ["role", "listbox", "aria-haspopup", "true", "aria-expanded", "false", "focus-target", "", 3, "ngModelChange", "change", "
|
193
|
+
]), i0.ɵɵInheritDefinitionFeature], decls: 5, vars: 18, consts: [["select", ""], ["role", "listbox", "aria-haspopup", "true", "aria-expanded", "false", "focus-target", "", 3, "ngModelChange", "change", "mousedown", "blur", "ngClass", "disabled", "required", "tabindex", "ngModel", "ngModelOptions", "multiple", "autofocus"], ["selected", "", "value", "undefined", "id", "placeholderOption", 3, "textContent", "hidden"], [4, "ngIf"], [3, "label", 4, "ngFor", "ngForOf"], [3, "label"], ["role", "option", 3, "value", "selected", "textContent", 4, "ngFor", "ngForOf"], ["role", "option", 3, "value", "selected", "textContent"]], template: function SelectComponent_Template(rf, ctx) { if (rf & 1) {
|
166
194
|
const _r1 = i0.ɵɵgetCurrentView();
|
167
195
|
i0.ɵɵelementStart(0, "select", 1, 0);
|
168
196
|
i0.ɵɵtwoWayListener("ngModelChange", function SelectComponent_Template_select_ngModelChange_0_listener($event) { i0.ɵɵrestoreView(_r1); i0.ɵɵtwoWayBindingSet(ctx.modelByKey, $event) || (ctx.modelByKey = $event); return i0.ɵɵresetView($event); });
|
169
|
-
i0.ɵɵlistener("change", function SelectComponent_Template_select_change_0_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onSelectValueChange($event)); })("
|
197
|
+
i0.ɵɵlistener("change", function SelectComponent_Template_select_change_0_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onSelectValueChange($event)); })("mousedown", function SelectComponent_Template_select_mousedown_0_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.checkForFloatingLabel($event)); })("blur", function SelectComponent_Template_select_blur_0_listener($event) { i0.ɵɵrestoreView(_r1); ctx.invokeOnTouched($event); return i0.ɵɵresetView(ctx.checkForFloatingLabel($event)); });
|
170
198
|
i0.ɵɵelement(2, "option", 2);
|
171
199
|
i0.ɵɵtemplate(3, SelectComponent_ng_container_3_Template, 2, 1, "ng-container", 3)(4, SelectComponent_ng_container_4_Template, 2, 1, "ng-container", 3);
|
172
200
|
i0.ɵɵelementEnd();
|
@@ -181,7 +209,7 @@ export class SelectComponent extends DatasetAwareFormComponent {
|
|
181
209
|
i0.ɵɵproperty("ngIf", ctx.groupby);
|
182
210
|
i0.ɵɵadvance();
|
183
211
|
i0.ɵɵproperty("ngIf", !ctx.groupby);
|
184
|
-
} }, dependencies: [
|
212
|
+
} }, dependencies: [i1.NgClass, i1.NgForOf, i1.NgIf, i2.NgSelectOption, i2.ɵNgSelectMultipleOption, i2.SelectMultipleControlValueAccessor, i2.NgControlStatus, i2.RequiredValidator, i2.NgModel, i3.TextContentDirective], encapsulation: 2 }); }
|
185
213
|
}
|
186
214
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SelectComponent, [{
|
187
215
|
type: Component,
|
@@ -189,8 +217,8 @@ export class SelectComponent extends DatasetAwareFormComponent {
|
|
189
217
|
provideAs(SelectComponent, NG_VALUE_ACCESSOR, true),
|
190
218
|
provideAs(SelectComponent, NG_VALIDATORS, true),
|
191
219
|
provideAsWidgetRef(SelectComponent)
|
192
|
-
], template: "<select role=\"listbox\" aria-haspopup=\"true\" aria-expanded=\"false\" #select\n focus-target\n [ngClass]=\"['app-select form-control', class]\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [tabindex]=\"tabindex\"\n [(ngModel)]=\"modelByKey\"\n [ngModelOptions]=\"{standalone: true}\"\n [multiple]=\"multiple\"\n (change)=\"onSelectValueChange($event)\"\n (
|
193
|
-
}], () => [{ type: i0.Injector }, { type:
|
220
|
+
], template: "<!--Updated focus with mousedown event. IOS devices not allow update of option value after opening dropdown-->\n<select role=\"listbox\" aria-haspopup=\"true\" aria-expanded=\"false\" #select\n focus-target\n [ngClass]=\"['app-select form-control', class]\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [tabindex]=\"tabindex\"\n [(ngModel)]=\"modelByKey\"\n [ngModelOptions]=\"{standalone: true}\"\n [multiple]=\"multiple\"\n (change)=\"onSelectValueChange($event)\"\n (mousedown)=\"checkForFloatingLabel($event)\"\n (blur)=\"invokeOnTouched($event); checkForFloatingLabel($event)\"\n [attr.name]=\"name\"\n [attr.aria-label]=\"hint\"\n [attr.aria-multiselectable]=\"multiple\"\n [autofocus]=\"autofocus\">\n\n <option selected\n value=\"undefined\"\n [textContent]=\"placeholder\"\n id=\"placeholderOption\"\n [hidden]=\"!placeholder\"></option>\n\n <ng-container *ngIf=\"groupby\">\n <optgroup *ngFor=\"let groupObj of groupedData\"\n [label]=\"groupObj.key\">\n <option *ngFor=\"let item of groupObj.data;\"\n [value]=\"item.key\"\n [selected]=\"item.selected\"\n [textContent]=\"item.label\"\n role=\"option\"></option>\n </optgroup>\n </ng-container>\n\n <ng-container *ngIf=\"!groupby\">\n <option *ngFor=\"let item of datasetItems\"\n [value]=\"item.key\"\n [selected]=\"item.selected\"\n [textContent]=\"item.label\"\n role=\"option\"></option>\n </ng-container>\n</select>\n" }]
|
221
|
+
}], () => [{ type: i0.Injector }, { type: undefined, decorators: [{
|
194
222
|
type: Inject,
|
195
223
|
args: ['EXPLICIT_CONTEXT']
|
196
224
|
}, {
|
@@ -199,5 +227,5 @@ export class SelectComponent extends DatasetAwareFormComponent {
|
|
199
227
|
type: ViewChild,
|
200
228
|
args: ['select', { static: true, read: ElementRef }]
|
201
229
|
}] }); })();
|
202
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SelectComponent, { className: "SelectComponent", filePath: "select/select.component.ts", lineNumber:
|
203
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../projects/components/widgets/input/default/src/select/select.component.ts","../../../../../../projects/components/widgets/input/default/src/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, ElementRef, Inject, Injector, Optional, ViewChild} from '@angular/core';\nimport {NG_VALIDATORS, NG_VALUE_ACCESSOR} from '@angular/forms';\n\nimport {App, DataSource, removeAttr, setAttr} from '@wm/core';\nimport {provideAs, provideAsWidgetRef, styler} from '@wm/components/base';\nimport {DatasetAwareFormComponent} from '../dataset-aware-form.component';\n\nimport {registerProps} from './select.props';\nimport {includes} from \"lodash-es\";\n\nconst WIDGET_CONFIG = {widgetType: 'wm-select', hostClass: 'app-select-wrapper'};\n\n@Component({\n    selector: 'wm-select',\n    templateUrl: './select.component.html',\n    providers: [\n        provideAs(SelectComponent, NG_VALUE_ACCESSOR, true),\n        provideAs(SelectComponent, NG_VALIDATORS, true),\n        provideAsWidgetRef(SelectComponent)\n    ]\n})\nexport class SelectComponent extends DatasetAwareFormComponent implements AfterViewInit {\n    static initializeProps = registerProps();\n\n    public readonly: boolean;\n    public placeholder: string;\n    public navsearchbar: any;\n    public class: any;\n    public required: boolean;\n    public disabled: boolean;\n    public tabindex: any;\n    public name: string;\n    public autofocus: boolean;\n    public hint: string;\n    private app: App;\n\n    @ViewChild('select', { static: true, read: ElementRef }) selectEl: ElementRef;\n\n    set datasource(ds) {\n        if (ds && ds.execute && ds.execute(DataSource.Operation.IS_BOUND_TO_LOCALE)) {\n            this.datavalue = ds.execute(DataSource.Operation.GET_DEFAULT_LOCALE);\n        }\n    }\n\n    constructor(inj: Injector, app: App, @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any) {\n        super(inj, WIDGET_CONFIG, explicitContext);\n        this.app = app;\n        this.acceptsArray = true;\n    }\n\n    ngAfterViewInit() {\n        super.ngAfterViewInit();\n        styler(this.selectEl.nativeElement as HTMLElement, this);\n    }\n\n    // Change event is registered from the template, Prevent the framework from registering one more event\n    protected handleEvent(node: HTMLElement, eventName: string, eventCallback: Function, locals: any) {\n        if (!includes(['blur', 'change'], eventName)) {\n            super.handleEvent(this.selectEl.nativeElement, eventName, eventCallback, locals);\n        }\n    }\n\n    onSelectValueChange($event) {\n        if (this.readonly) {\n            if (this.placeholder) {\n                this.selectEl.nativeElement.value = this.placeholder;\n            } else {\n                this.selectEl.nativeElement.value = '';\n            }\n            this.datavalue = (this as any).prevDatavalue;\n            return;\n        }\n        this.invokeOnTouched();\n        // invoke on datavalue change.\n        this.invokeOnChange(this.datavalue, $event || {}, true);\n    }\n\n    onPropertyChange(key: string, nv: any, ov?: any) {\n        if (key === 'required')  {\n            this._onChange(this.datavalue);\n            return;\n        }\n        if (key === 'class' ||  key === 'tabindex') {\n            if(key === 'class') {\n                // After NG15 upgrade ng-invalid class is added even the field is valid, so we are removing the ng-invalid manually\n                const isNgUntouchedValid = this.selectEl.nativeElement.classList.contains('ng-untouched') && this.selectEl.nativeElement.classList.contains('ng-valid')\n                if(isNgUntouchedValid && nv.includes('ng-untouched') && nv.includes('ng-invalid')) {\n                    setTimeout(()=> {\n                        if(this.selectEl.nativeElement.classList.contains('ng-untouched') && this.selectEl.nativeElement.classList.contains('ng-valid') && this.selectEl.nativeElement.classList.contains('ng-invalid')) {\n                            this.selectEl.nativeElement.classList.remove('ng-invalid');\n                        }\n                    });\n                }\n            }\n            return;\n        } else if (key === 'readonly') {\n             (nv === true) ? setAttr(this.selectEl.nativeElement, 'readonly', 'readonly') : removeAttr(this.selectEl.nativeElement, 'readonly') ;\n        }\n        super.onPropertyChange(key, nv, ov);\n    }\n\n    /**\n     * When caption floating is enabled and placeholder is given, do not show placeholder until user focuses on the field\n     * When focused add the placeholder to the option which is selected\n     * On blur, remove the placeholder and do not animate the label\n     * @param $event event received will be either a blur or focus event\n     */\n    checkForFloatingLabel($event) {\n        const captionEl = $(this.selectEl.nativeElement).closest('.app-composite-widget.caption-floating');\n        if (captionEl.length > 0) {\n            if ($event.type === 'focus' && (!this.datavalue || (this.datavalue && $(this.selectEl).find('select option:selected').text() === '' && this.placeholder))) {\n                if(!(this.datavalue || this.placeholder)) {\n                    this.removePlaceholderOption();\n                } else {\n                    $(this.selectEl.nativeElement).find('option:first').text(this.placeholder);\n                }\n            } else if (!this.datavalue) {\n                $(this.selectEl.nativeElement).find('option:selected').text('');\n                captionEl.removeClass('float-active');\n            }\n        } else if(!(this.datavalue || this.placeholder)) {\n            this.removePlaceholderOption();\n        }\n    }\n\n    /*\n    * Removing the placeholder option if no placeholder is provided.\n    * In html we are hiding the placeholder option using css but in apple devices and safari option is showing.\n    * */\n    private removePlaceholderOption() {\n        const hiddenEle = $(this.selectEl.nativeElement).find('#placeholderOption');\n        if (hiddenEle.length) {\n            hiddenEle.remove();\n            this.selectEl.nativeElement.value = '';\n        }\n    }\n}\n","<select role=\"listbox\" aria-haspopup=\"true\" aria-expanded=\"false\" #select\n        focus-target\n        [ngClass]=\"['app-select form-control', class]\"\n        [disabled]=\"disabled\"\n        [required]=\"required\"\n        [tabindex]=\"tabindex\"\n        [(ngModel)]=\"modelByKey\"\n        [ngModelOptions]=\"{standalone: true}\"\n        [multiple]=\"multiple\"\n        (change)=\"onSelectValueChange($event)\"\n        (focus)=\"checkForFloatingLabel($event)\"\n        (blur)=\"invokeOnTouched($event); checkForFloatingLabel($event)\"\n        [attr.name]=\"name\"\n        [attr.aria-label]=\"hint\"\n        [attr.aria-multiselectable]=\"multiple\"\n        [autofocus]=\"autofocus\">\n\n        <option selected\n                value=\"undefined\"\n                [textContent]=\"placeholder\"\n                id=\"placeholderOption\"\n                [hidden]=\"!placeholder\"></option>\n\n    <ng-container *ngIf=\"groupby\">\n        <optgroup *ngFor=\"let groupObj of groupedData\"\n            [label]=\"groupObj.key\">\n            <option *ngFor=\"let item of groupObj.data;\"\n                [value]=\"item.key\"\n                [selected]=\"item.selected\"\n                [textContent]=\"item.label\"\n                role=\"option\"></option>\n        </optgroup>\n    </ng-container>\n\n    <ng-container *ngIf=\"!groupby\">\n        <option *ngFor=\"let item of datasetItems\"\n            [value]=\"item.key\"\n            [selected]=\"item.selected\"\n            [textContent]=\"item.label\"\n            role=\"option\"></option>\n    </ng-container>\n</select>\n"]}
|
230
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SelectComponent, { className: "SelectComponent", filePath: "select/select.component.ts", lineNumber: 21 }); })();
|
231
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../projects/components/widgets/input/default/src/select/select.component.ts","../../../../../../projects/components/widgets/input/default/src/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, ElementRef, Inject, Injector, Optional, ViewChild} from '@angular/core';\nimport {NG_VALIDATORS, NG_VALUE_ACCESSOR} from '@angular/forms';\n\nimport {DataSource, removeAttr, setAttr} from '@wm/core';\nimport {provideAs, provideAsWidgetRef, styler} from '@wm/components/base';\nimport {DatasetAwareFormComponent} from '../dataset-aware-form.component';\n\nimport {registerProps} from './select.props';\n\nconst WIDGET_CONFIG = {widgetType: 'wm-select', hostClass: 'app-select-wrapper'};\n\n@Component({\n    selector: 'wm-select',\n    templateUrl: './select.component.html',\n    providers: [\n        provideAs(SelectComponent, NG_VALUE_ACCESSOR, true),\n        provideAs(SelectComponent, NG_VALIDATORS, true),\n        provideAsWidgetRef(SelectComponent)\n    ]\n})\nexport class SelectComponent extends DatasetAwareFormComponent implements AfterViewInit {\n    static initializeProps = registerProps();\n\n    public readonly: boolean;\n    public placeholder: string;\n    public navsearchbar: any;\n    public class: any;\n    public required: boolean;\n    public disabled: boolean;\n    public tabindex: any;\n    public name: string;\n    public autofocus: boolean;\n    public hint: string;\n\n    @ViewChild('select', { static: true, read: ElementRef }) selectEl: ElementRef;\n\n    set datasource(ds) {\n        if (ds && ds.execute && ds.execute(DataSource.Operation.IS_BOUND_TO_LOCALE)) {\n            this.datavalue = ds.execute(DataSource.Operation.GET_DEFAULT_LOCALE);\n        }\n    }\n\n    constructor(inj: Injector, @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any) {\n        super(inj, WIDGET_CONFIG, explicitContext);\n        this.acceptsArray = true;\n\n        /*\n        * When the dataset for a select element is updated and no longer includes the previously selected value:\n        * The select element becomes empty, and the ngModel value is updated to reflect this change.\n        * However, the change event is not triggered, preventing the form control from recognizing the update and applying necessary validations.\n        * As this widget implements ControlValueAccessor, manually updating the ngModel (or modelByKey) is necessary to ensure correct form behavior.\n        * */\n        const datasetSubscription = this.dataset$.subscribe(() => {\n            if (this.datavalue) {\n                const selectedItem = this.datasetItems.find(item => item.selected);\n                if (!selectedItem) {\n                    setTimeout(() => {\n                        if(!this.placeholder) {\n                            this.selectEl.nativeElement.value = '';\n                        }\n                        this.modelByKey = undefined;\n                    }, 100);\n                }\n            } else {\n                setTimeout(() => {\n                    if(!this.placeholder) {\n                        this.selectEl.nativeElement.value = '';\n                    }\n                }, 100);\n            }\n        });\n        this.registerDestroyListener(() => datasetSubscription.unsubscribe());\n    }\n\n    ngAfterViewInit() {\n        super.ngAfterViewInit();\n        styler(this.selectEl.nativeElement as HTMLElement, this);\n    }\n\n    // Change event is registered from the template, Prevent the framework from registering one more event\n    protected handleEvent(node: HTMLElement, eventName: string, eventCallback: Function, locals: any) {\n        if (!['blur', 'change'].includes(eventName)) {\n            super.handleEvent(this.selectEl.nativeElement, eventName, eventCallback, locals);\n        }\n    }\n\n    onSelectValueChange($event) {\n        if (this.readonly) {\n            if (this.placeholder) {\n                this.selectEl.nativeElement.value = this.placeholder;\n            } else {\n                this.selectEl.nativeElement.value = '';\n            }\n            this.datavalue = (this as any).prevDatavalue;\n            return;\n        }\n        this.invokeOnTouched();\n        // invoke on datavalue change.\n        this.invokeOnChange(this.datavalue, $event || {}, true);\n    }\n\n    onPropertyChange(key: string, nv: any, ov?: any) {\n        if (key === 'required')  {\n            this._onChange(this.datavalue);\n            return;\n        }\n        if (key === 'class' ||  key === 'tabindex') {\n            if(key === 'class') {\n                // After NG15 upgrade ng-invalid class is added even the field is valid, so we are removing the ng-invalid manually\n                const isNgUntouchedValid = this.selectEl.nativeElement.classList.contains('ng-untouched') && this.selectEl.nativeElement.classList.contains('ng-valid')\n                if(isNgUntouchedValid && nv.includes('ng-untouched') && nv.includes('ng-invalid')) {\n                    setTimeout(()=> {\n                        if(this.selectEl.nativeElement.classList.contains('ng-untouched') && this.selectEl.nativeElement.classList.contains('ng-valid') && this.selectEl.nativeElement.classList.contains('ng-invalid')) {\n                            this.selectEl.nativeElement.classList.remove('ng-invalid');\n                        }\n                    });\n                }\n            }\n            return;\n        } else if (key === 'readonly') {\n             (nv === true) ? setAttr(this.selectEl.nativeElement, 'readonly', 'readonly') : removeAttr(this.selectEl.nativeElement, 'readonly') ;\n        }\n        super.onPropertyChange(key, nv, ov);\n    }\n\n    /**\n     * When caption floating is enabled and placeholder is given, do not show placeholder until user focuses on the field\n     * When focused add the placeholder to the option which is selected\n     * On blur, remove the placeholder and do not animate the label\n     * @param $event event received will be either a blur or focus event\n     */\n    checkForFloatingLabel($event) {\n        const captionEl = $(this.selectEl.nativeElement).closest('.app-composite-widget.caption-floating');\n        if(!this.placeholder) {\n            this.removePlaceholderOption();\n        }\n        if (captionEl.length > 0) {\n            const placeholderOption = this.selectEl.nativeElement.querySelector('#placeholderOption');\n            if ($event.type === 'mousedown' && (!this.datavalue || (this.datavalue && $(this.selectEl).find('select option:selected').text() === '' && this.placeholder))) {\n                if(this.placeholder) {\n                    placeholderOption.textContent = this.placeholder;\n                }\n            } else if (!this.datavalue) {\n                if(this.placeholder) {\n                    placeholderOption.textContent = '';\n                }\n                captionEl.removeClass('float-active');\n            }\n        }\n    }\n\n    /*\n    * Removing the placeholder option if no placeholder is provided.\n    * In html we are hiding the placeholder option using css but in Apple devices and safari option is showing.\n    * Styles are not allowed on option tag in ios safari\n    * After removing the option, if no datavalue is present and native select element sets value to the first option by default, so we are setting it to empty\n    * */\n    private removePlaceholderOption() {\n        const hiddenEle = $(this.selectEl.nativeElement).find('#placeholderOption');\n        if (hiddenEle.length) {\n            hiddenEle.remove();\n            if(!this.datavalue) {\n                this.selectEl.nativeElement.value = '';\n            }\n        }\n    }\n}\n","<!--Updated focus with mousedown event. IOS devices not allow update of option value after opening dropdown-->\n<select role=\"listbox\" aria-haspopup=\"true\" aria-expanded=\"false\" #select\n        focus-target\n        [ngClass]=\"['app-select form-control', class]\"\n        [disabled]=\"disabled\"\n        [required]=\"required\"\n        [tabindex]=\"tabindex\"\n        [(ngModel)]=\"modelByKey\"\n        [ngModelOptions]=\"{standalone: true}\"\n        [multiple]=\"multiple\"\n        (change)=\"onSelectValueChange($event)\"\n        (mousedown)=\"checkForFloatingLabel($event)\"\n        (blur)=\"invokeOnTouched($event); checkForFloatingLabel($event)\"\n        [attr.name]=\"name\"\n        [attr.aria-label]=\"hint\"\n        [attr.aria-multiselectable]=\"multiple\"\n        [autofocus]=\"autofocus\">\n\n        <option selected\n                value=\"undefined\"\n                [textContent]=\"placeholder\"\n                id=\"placeholderOption\"\n                [hidden]=\"!placeholder\"></option>\n\n    <ng-container *ngIf=\"groupby\">\n        <optgroup *ngFor=\"let groupObj of groupedData\"\n            [label]=\"groupObj.key\">\n            <option *ngFor=\"let item of groupObj.data;\"\n                [value]=\"item.key\"\n                [selected]=\"item.selected\"\n                [textContent]=\"item.label\"\n                role=\"option\"></option>\n        </optgroup>\n    </ng-container>\n\n    <ng-container *ngIf=\"!groupby\">\n        <option *ngFor=\"let item of datasetItems\"\n            [value]=\"item.key\"\n            [selected]=\"item.selected\"\n            [textContent]=\"item.label\"\n            role=\"option\"></option>\n    </ng-container>\n</select>\n"]}
|
@@ -14,9 +14,6 @@ export class BaseInput extends BaseFormCustomComponent {
|
|
14
14
|
/* WMS-18269 | Update Angular about the required attr value change */
|
15
15
|
this._onChange(this.datavalue);
|
16
16
|
}
|
17
|
-
if (key === 'updateon') {
|
18
|
-
this.ngModelOptions.updateOn = nv === 'default' ? 'change' : ov;
|
19
|
-
}
|
20
17
|
if (key === 'class') {
|
21
18
|
if (this.inputEl.nativeElement) {
|
22
19
|
switchClass(this.inputEl.nativeElement, nv, ov);
|
@@ -90,4 +87,4 @@ export class BaseInput extends BaseFormCustomComponent {
|
|
90
87
|
}, {
|
91
88
|
type: Optional
|
92
89
|
}] }], null); })();
|
93
|
-
//# sourceMappingURL=data:application/json;base64,
|
90
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-input.js","sourceRoot":"","sources":["../../../../../../../projects/components/widgets/input/default/src/text/base/base-input.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, ElementRef, Inject, Injectable, Injector, Optional} from '@angular/core';\nimport {NgModel} from '@angular/forms';\n\nimport {$appDigest, addClass, switchClass} from '@wm/core';\nimport {IWidgetConfig, styler, WidgetConfig} from '@wm/components/base';\nimport {BaseFormCustomComponent} from '../../base-form-custom.component';\nimport {get, isString} from \"lodash-es\";\n\n@Injectable()\nexport abstract class BaseInput extends BaseFormCustomComponent implements AfterViewInit {\n    public class: string;\n    public autotrim: boolean;\n    public imask;\n\n    // possible values for ngModelOptions are 'blur' and 'change'\n    // default is 'blur'\n    public ngModelOptions = {\n        updateOn: '',\n        standalone: true\n    };\n\n    /**\n     * Reference to the input element. All the styles and classes will be applied on this node.\n     * Input components must override this\n     */\n    protected abstract inputEl: ElementRef;\n\n    /**\n     * Reference to the ngModel directive instance.\n     * Used to check the validity of the input\n     */\n    protected abstract ngModel: NgModel;\n\n    protected onPropertyChange(key: string, nv: any, ov: any) {\n        // set the class on the input element\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        }\n\n        if (key === 'class') {\n            if (this.inputEl.nativeElement) {\n                switchClass(this.inputEl.nativeElement, nv, ov);\n            }\n        } else if (key === 'datavalue') {\n            // update the oldDataValue when the datavalue is modified programmatically\n            this.updatePrevDatavalue(nv);\n            this._onChange(this.datavalue);\n        } else {\n            super.onPropertyChange(key, nv, ov);\n        }\n    }\n\n    // invoke the change callback\n    handleChange(newValue: any) {\n        if (this.autotrim && this.datavalue && isString(this.datavalue)) {\n            this.datavalue = this.datavalue.trim();\n        }\n\n        this.invokeOnChange(this.datavalue, {type: 'change'}, this.ngModel.valid);\n    }\n\n    // Change event is registered from the template, Prevent the framework from registering one more event\n    protected handleEvent(node: HTMLElement, eventName: string, eventCallback: Function, locals: any) {\n        if (eventName !== 'change' && eventName !== 'blur') {\n            super.handleEvent(this.inputEl.nativeElement, eventName, eventCallback, locals);\n        }\n    }\n\n    // invoke the blur callback\n    handleBlur($event) {\n        this.invokeOnTouched($event);\n    }\n\n    // Update the model on enter key press\n    flushViewChanges(val) {\n        // when val contains masked value, update the model with unmasked value\n        const unMaskedVal = get(this.imask, 'maskRef.unmaskedValue');\n        val = unMaskedVal ? unMaskedVal : val;\n        this.ngModel.update.next(val);\n        $appDigest();\n    }\n\n    ngAfterViewInit() {\n        super.ngAfterViewInit();\n\n        // add the class on the input element\n        if (this.class) {\n            addClass(this.inputEl.nativeElement, this.class);\n        }\n        styler(this.inputEl.nativeElement, this);\n    }\n\n    protected constructor(\n        inj: Injector,\n        @Inject(WidgetConfig) config: IWidgetConfig,\n        @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any\n    ) {\n        super(inj, config, explicitContext);\n        let updateOn = this.nativeElement.getAttribute('updateon') || 'blur';\n        updateOn = updateOn === 'default' ? 'change' : updateOn;\n        this.ngModelOptions.updateOn = updateOn;\n    }\n}\n"]}
|