@wavemaker/app-ng-runtime 12.0.0-next.45031 → 12.0.0-next.45501

Sign up to get free protection for your applications and to get access to all the features.
Files changed (119) hide show
  1. app-ng-runtime/build-task/bundles/index.umd.js +405 -451
  2. app-ng-runtime/build-task/esm2022/data/form/form-field/form-field.build.mjs +2 -3
  3. app-ng-runtime/build-task/esm2022/public_api.mjs +1 -3
  4. app-ng-runtime/build-task/fesm2022/index.mjs +406 -454
  5. app-ng-runtime/build-task/fesm2022/index.mjs.map +1 -1
  6. app-ng-runtime/build-task/public_api.d.ts +0 -2
  7. app-ng-runtime/components/base/bundles/index.umd.js +14 -62
  8. app-ng-runtime/components/base/components.module.d.ts +11 -12
  9. app-ng-runtime/components/base/esm2022/components.module.mjs +1 -5
  10. app-ng-runtime/components/base/esm2022/public_api.mjs +1 -2
  11. app-ng-runtime/components/base/esm2022/widgets/common/base/base.component.mjs +15 -25
  12. app-ng-runtime/components/base/fesm2022/index.mjs +15 -62
  13. app-ng-runtime/components/base/fesm2022/index.mjs.map +1 -1
  14. app-ng-runtime/components/base/public_api.d.ts +0 -1
  15. app-ng-runtime/components/base/widgets/common/base/base.component.d.ts +5 -10
  16. app-ng-runtime/components/containers/wizard/bundles/index.umd.js +17 -0
  17. app-ng-runtime/components/containers/wizard/esm2022/wizard.component.mjs +18 -1
  18. app-ng-runtime/components/containers/wizard/fesm2022/index.mjs +17 -0
  19. app-ng-runtime/components/containers/wizard/fesm2022/index.mjs.map +1 -1
  20. app-ng-runtime/components/containers/wizard/wizard.component.d.ts +1 -0
  21. app-ng-runtime/components/data/form/esm2022/form-field/form-field.directive.mjs +1 -3
  22. app-ng-runtime/components/data/form/fesm2022/index.mjs +0 -2
  23. app-ng-runtime/components/data/form/fesm2022/index.mjs.map +1 -1
  24. app-ng-runtime/components/dialogs/default/bundles/index.umd.js +11 -0
  25. app-ng-runtime/components/dialogs/default/esm2022/base-dialog.mjs +12 -1
  26. app-ng-runtime/components/dialogs/default/fesm2022/index.mjs +11 -0
  27. app-ng-runtime/components/dialogs/default/fesm2022/index.mjs.map +1 -1
  28. app-ng-runtime/components/input/default/bundles/index.umd.js +63 -39
  29. app-ng-runtime/components/input/default/checkboxset/checkboxset.component.d.ts +0 -1
  30. app-ng-runtime/components/input/default/esm2022/checkboxset/checkboxset.component.mjs +5 -8
  31. app-ng-runtime/components/input/default/esm2022/radioset/radioset.component.mjs +5 -8
  32. app-ng-runtime/components/input/default/esm2022/select/select.component.mjs +57 -29
  33. app-ng-runtime/components/input/default/esm2022/text/base/base-input.mjs +1 -4
  34. app-ng-runtime/components/input/default/esm2022/text/locale/number-locale.mjs +2 -2
  35. app-ng-runtime/components/input/default/esm2022/textarea/textarea.component.mjs +4 -1
  36. app-ng-runtime/components/input/default/fesm2022/index.mjs +63 -39
  37. app-ng-runtime/components/input/default/fesm2022/index.mjs.map +1 -1
  38. app-ng-runtime/components/input/default/radioset/radioset.component.d.ts +0 -1
  39. app-ng-runtime/components/input/default/select/select.component.d.ts +2 -4
  40. app-ng-runtime/components/input/default/textarea/textarea.component.d.ts +3 -2
  41. app-ng-runtime/components/input/epoch/bundles/index.umd.js +3 -0
  42. app-ng-runtime/components/input/epoch/esm2022/date-time/date-time.component.mjs +4 -1
  43. app-ng-runtime/components/input/epoch/fesm2022/index.mjs +3 -0
  44. app-ng-runtime/components/input/epoch/fesm2022/index.mjs.map +1 -1
  45. app-ng-runtime/components/input/file-upload/bundles/index.umd.js +31 -5
  46. app-ng-runtime/components/input/file-upload/esm2022/file-upload.component.mjs +34 -8
  47. app-ng-runtime/components/input/file-upload/fesm2022/index.mjs +32 -6
  48. app-ng-runtime/components/input/file-upload/fesm2022/index.mjs.map +1 -1
  49. app-ng-runtime/components/input/file-upload/file-upload.component.d.ts +6 -2
  50. app-ng-runtime/components/navigation/menu/bundles/index.umd.js +2 -2
  51. app-ng-runtime/components/navigation/menu/esm2022/menu.component.mjs +2 -2
  52. app-ng-runtime/components/navigation/menu/esm2022/nav/nav.component.mjs +2 -2
  53. app-ng-runtime/components/navigation/menu/fesm2022/index.mjs +2 -2
  54. app-ng-runtime/components/navigation/menu/fesm2022/index.mjs.map +1 -1
  55. app-ng-runtime/core/bundles/index.umd.js +6 -16
  56. app-ng-runtime/core/enums/enums.d.ts +1 -2
  57. app-ng-runtime/core/esm2022/enums/enums.mjs +1 -2
  58. app-ng-runtime/core/esm2022/types/types.mjs +1 -4
  59. app-ng-runtime/core/esm2022/utils/build-utils.mjs +1 -6
  60. app-ng-runtime/core/esm2022/utils/utils.mjs +4 -3
  61. app-ng-runtime/core/fesm2022/index.mjs +4 -12
  62. app-ng-runtime/core/fesm2022/index.mjs.map +1 -1
  63. app-ng-runtime/core/types/types.d.ts +1 -5
  64. app-ng-runtime/core/utils/utils.d.ts +1 -0
  65. app-ng-runtime/mobile/core/bundles/index.umd.js +18 -2
  66. app-ng-runtime/mobile/core/esm2022/native.xhr.mjs +19 -3
  67. app-ng-runtime/mobile/core/fesm2022/index.mjs +18 -2
  68. app-ng-runtime/mobile/core/fesm2022/index.mjs.map +1 -1
  69. app-ng-runtime/package.json +1 -1
  70. app-ng-runtime/runtime/base/bundles/index.umd.js +5 -288
  71. app-ng-runtime/runtime/base/esm2022/public_api.mjs +1 -2
  72. app-ng-runtime/runtime/base/esm2022/runtime-base.module.mjs +1 -6
  73. app-ng-runtime/runtime/base/esm2022/services/i18n.service.mjs +2 -2
  74. app-ng-runtime/runtime/base/esm2022/types/types.mjs +1 -2
  75. app-ng-runtime/runtime/base/fesm2022/index.mjs +4 -287
  76. app-ng-runtime/runtime/base/fesm2022/index.mjs.map +1 -1
  77. app-ng-runtime/runtime/base/public_api.d.ts +0 -1
  78. app-ng-runtime/runtime/base/runtime-base.module.d.ts +8 -9
  79. app-ng-runtime/runtime/base/types/types.d.ts +1 -2
  80. app-ng-runtime/runtime/dynamic/bundles/index.umd.js +9 -27
  81. app-ng-runtime/runtime/dynamic/esm2022/app/app.module.mjs +2 -5
  82. app-ng-runtime/runtime/dynamic/esm2022/app/services/component-ref-provider.service.mjs +7 -23
  83. app-ng-runtime/runtime/dynamic/fesm2022/index.mjs +7 -26
  84. app-ng-runtime/runtime/dynamic/fesm2022/index.mjs.map +1 -1
  85. app-ng-runtime/scripts/@wavemaker/nvd3/build/nv.d3.min.js +1 -1
  86. app-ng-runtime/scripts/datatable/datatable.js +6 -3
  87. app-ng-runtime/scripts/summernote/dist/summernote-lite.min.js +2 -3
  88. app-ng-runtime/transpiler/bundles/index.umd.js +0 -5
  89. app-ng-runtime/transpiler/esm2022/build.mjs +1 -4
  90. app-ng-runtime/transpiler/esm2022/imports.mjs +1 -3
  91. app-ng-runtime/transpiler/fesm2022/index.mjs +0 -5
  92. app-ng-runtime/transpiler/fesm2022/index.mjs.map +1 -1
  93. app-ng-runtime/build-task/advanced/custom-widget-container/custom-widget-container.build.d.ts +0 -2
  94. app-ng-runtime/build-task/advanced/custom-widget-wrapper/custom-widget-wrapper.build.d.ts +0 -2
  95. app-ng-runtime/build-task/esm2022/advanced/custom-widget-container/custom-widget-container.build.mjs +0 -15
  96. app-ng-runtime/build-task/esm2022/advanced/custom-widget-wrapper/custom-widget-wrapper.build.mjs +0 -26
  97. app-ng-runtime/components/advanced/custom/.npmignore +0 -2
  98. app-ng-runtime/components/advanced/custom/bundles/index.umd.js +0 -232
  99. app-ng-runtime/components/advanced/custom/custom-widget-container/custom-widget-container.directive.d.ts +0 -19
  100. app-ng-runtime/components/advanced/custom/custom-widget-container/custom-widget.props.d.ts +0 -2
  101. app-ng-runtime/components/advanced/custom/custom-widget-prop.d.ts +0 -1
  102. app-ng-runtime/components/advanced/custom/custom-widget.directive.d.ts +0 -19
  103. app-ng-runtime/components/advanced/custom/custom-widget.module.d.ts +0 -10
  104. app-ng-runtime/components/advanced/custom/esm2022/custom-widget-container/custom-widget-container.directive.mjs +0 -102
  105. app-ng-runtime/components/advanced/custom/esm2022/custom-widget-container/custom-widget.props.mjs +0 -12
  106. app-ng-runtime/components/advanced/custom/esm2022/custom-widget-prop.mjs +0 -8
  107. app-ng-runtime/components/advanced/custom/esm2022/custom-widget.directive.mjs +0 -68
  108. app-ng-runtime/components/advanced/custom/esm2022/custom-widget.module.mjs +0 -32
  109. app-ng-runtime/components/advanced/custom/esm2022/index.mjs +0 -5
  110. app-ng-runtime/components/advanced/custom/esm2022/public_api.mjs +0 -4
  111. app-ng-runtime/components/advanced/custom/fesm2022/index.mjs +0 -215
  112. app-ng-runtime/components/advanced/custom/fesm2022/index.mjs.map +0 -1
  113. app-ng-runtime/components/advanced/custom/index.d.ts +0 -5
  114. app-ng-runtime/components/advanced/custom/package.json +0 -23
  115. app-ng-runtime/components/advanced/custom/public_api.d.ts +0 -3
  116. app-ng-runtime/components/base/esm2022/widgets/common/base/custom-widget-container.directive.mjs +0 -39
  117. app-ng-runtime/components/base/widgets/common/base/custom-widget-container.directive.d.ts +0 -14
  118. app-ng-runtime/runtime/base/components/base-custom-widget.component.d.ts +0 -72
  119. 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.triggerInvokeOnChange(keys, $event);
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.triggerInvokeOnChange(key, $event);
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":"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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    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 { App, DataSource, removeAttr, setAttr } from '@wm/core';
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 "@wm/core";
10
- import * as i2 from "@angular/common";
11
- import * as i3 from "@angular/forms";
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, app, explicitContext) {
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 (!includes(['blur', 'change'], eventName)) {
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
- if ($event.type === 'focus' && (!this.datavalue || (this.datavalue && $(this.selectEl).find('select option:selected').text() === '' && this.placeholder))) {
128
- if (!(this.datavalue || this.placeholder)) {
129
- this.removePlaceholderOption();
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
- $(this.selectEl.nativeElement).find('option:selected').text('');
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 apple devices and safari option is showing.
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.selectEl.nativeElement.value = '';
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(i1.App), i0.ɵɵdirectiveInject('EXPLICIT_CONTEXT', 8)); }; }
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", "focus", "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) {
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)); })("focus", function SelectComponent_Template_select_focus_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)); });
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: [i2.NgClass, i2.NgForOf, i2.NgIf, i3.NgSelectOption, i3.ɵNgSelectMultipleOption, i3.SelectMultipleControlValueAccessor, i3.NgControlStatus, i3.RequiredValidator, i3.NgModel, i4.TextContentDirective], encapsulation: 2 }); }
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 (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" }]
193
- }], () => [{ type: i0.Injector }, { type: i1.App }, { type: undefined, decorators: [{
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: 22 }); })();
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,{"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        if (key === 'updateon') {\n            this.ngModelOptions.updateOn = nv === 'default' ? 'change' : ov;\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"]}
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"]}