@wavemaker/app-ng-runtime 12.0.0-next.140535 → 12.0.0-next.141131

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (170) hide show
  1. app-ng-runtime/build-task/advanced/custom-widget-container/custom-widget-container.build.d.ts +2 -0
  2. app-ng-runtime/build-task/advanced/custom-widget-wrapper/custom-widget-wrapper.build.d.ts +2 -0
  3. app-ng-runtime/build-task/bundles/index.umd.js +451 -405
  4. app-ng-runtime/build-task/esm2022/advanced/custom-widget-container/custom-widget-container.build.mjs +15 -0
  5. app-ng-runtime/build-task/esm2022/advanced/custom-widget-wrapper/custom-widget-wrapper.build.mjs +26 -0
  6. app-ng-runtime/build-task/esm2022/data/form/form-field/form-field.build.mjs +3 -2
  7. app-ng-runtime/build-task/esm2022/public_api.mjs +3 -1
  8. app-ng-runtime/build-task/fesm2022/index.mjs +454 -406
  9. app-ng-runtime/build-task/fesm2022/index.mjs.map +1 -1
  10. app-ng-runtime/build-task/public_api.d.ts +2 -0
  11. app-ng-runtime/components/advanced/custom/.npmignore +2 -0
  12. app-ng-runtime/components/advanced/custom/bundles/index.umd.js +232 -0
  13. app-ng-runtime/components/advanced/custom/custom-widget-container/custom-widget-container.directive.d.ts +19 -0
  14. app-ng-runtime/components/advanced/custom/custom-widget-container/custom-widget.props.d.ts +2 -0
  15. app-ng-runtime/components/advanced/custom/custom-widget-prop.d.ts +1 -0
  16. app-ng-runtime/components/advanced/custom/custom-widget.directive.d.ts +19 -0
  17. app-ng-runtime/components/advanced/custom/custom-widget.module.d.ts +10 -0
  18. app-ng-runtime/components/advanced/custom/esm2022/custom-widget-container/custom-widget-container.directive.mjs +102 -0
  19. app-ng-runtime/components/advanced/custom/esm2022/custom-widget-container/custom-widget.props.mjs +12 -0
  20. app-ng-runtime/components/advanced/custom/esm2022/custom-widget-prop.mjs +8 -0
  21. app-ng-runtime/components/advanced/custom/esm2022/custom-widget.directive.mjs +68 -0
  22. app-ng-runtime/components/advanced/custom/esm2022/custom-widget.module.mjs +32 -0
  23. app-ng-runtime/components/advanced/custom/esm2022/index.mjs +5 -0
  24. app-ng-runtime/components/advanced/custom/esm2022/public_api.mjs +4 -0
  25. app-ng-runtime/components/advanced/custom/fesm2022/index.mjs +215 -0
  26. app-ng-runtime/components/advanced/custom/fesm2022/index.mjs.map +1 -0
  27. app-ng-runtime/components/advanced/custom/index.d.ts +5 -0
  28. app-ng-runtime/components/advanced/custom/package.json +23 -0
  29. app-ng-runtime/components/advanced/custom/public_api.d.ts +3 -0
  30. app-ng-runtime/components/base/bundles/index.umd.js +63 -21
  31. app-ng-runtime/components/base/components.module.d.ts +12 -11
  32. app-ng-runtime/components/base/esm2022/components.module.mjs +5 -1
  33. app-ng-runtime/components/base/esm2022/public_api.mjs +2 -1
  34. app-ng-runtime/components/base/esm2022/utils/live-utils.mjs +2 -8
  35. app-ng-runtime/components/base/esm2022/widgets/common/base/base.component.mjs +25 -15
  36. app-ng-runtime/components/base/esm2022/widgets/common/base/custom-widget-container.directive.mjs +39 -0
  37. app-ng-runtime/components/base/fesm2022/index.mjs +63 -22
  38. app-ng-runtime/components/base/fesm2022/index.mjs.map +1 -1
  39. app-ng-runtime/components/base/public_api.d.ts +1 -0
  40. app-ng-runtime/components/base/widgets/common/base/base.component.d.ts +10 -5
  41. app-ng-runtime/components/base/widgets/common/base/custom-widget-container.directive.d.ts +14 -0
  42. app-ng-runtime/components/basic/search/bundles/index.umd.js +36 -24
  43. app-ng-runtime/components/basic/search/esm2022/search.component.mjs +33 -24
  44. app-ng-runtime/components/basic/search/esm2022/search.props.mjs +5 -2
  45. app-ng-runtime/components/basic/search/fesm2022/index.mjs +36 -24
  46. app-ng-runtime/components/basic/search/fesm2022/index.mjs.map +1 -1
  47. app-ng-runtime/components/basic/search/search.component.d.ts +3 -0
  48. app-ng-runtime/components/containers/tabs/bundles/index.umd.js +14 -6
  49. app-ng-runtime/components/containers/tabs/esm2022/tabs.component.mjs +14 -7
  50. app-ng-runtime/components/containers/tabs/esm2022/tabs.props.mjs +3 -2
  51. app-ng-runtime/components/containers/tabs/fesm2022/index.mjs +14 -6
  52. app-ng-runtime/components/containers/tabs/fesm2022/index.mjs.map +1 -1
  53. app-ng-runtime/components/containers/tabs/tabs.component.d.ts +1 -0
  54. app-ng-runtime/components/containers/wizard/bundles/index.umd.js +0 -17
  55. app-ng-runtime/components/containers/wizard/esm2022/wizard.component.mjs +1 -18
  56. app-ng-runtime/components/containers/wizard/fesm2022/index.mjs +0 -17
  57. app-ng-runtime/components/containers/wizard/fesm2022/index.mjs.map +1 -1
  58. app-ng-runtime/components/containers/wizard/wizard.component.d.ts +0 -1
  59. app-ng-runtime/components/data/form/bundles/index.umd.js +0 -4
  60. app-ng-runtime/components/data/form/esm2022/form-field/form-field.directive.mjs +3 -5
  61. app-ng-runtime/components/data/form/fesm2022/index.mjs +2 -4
  62. app-ng-runtime/components/data/form/fesm2022/index.mjs.map +1 -1
  63. app-ng-runtime/components/data/form/form-field/form-field.directive.d.ts +0 -1
  64. app-ng-runtime/components/data/table/bundles/index.umd.js +2 -2
  65. app-ng-runtime/components/data/table/esm2022/table.component.mjs +3 -3
  66. app-ng-runtime/components/data/table/fesm2022/index.mjs +2 -2
  67. app-ng-runtime/components/data/table/fesm2022/index.mjs.map +1 -1
  68. app-ng-runtime/components/data/table/table.component.d.ts +1 -1
  69. app-ng-runtime/components/dialogs/default/base-dialog.d.ts +2 -0
  70. app-ng-runtime/components/dialogs/default/bundles/index.umd.js +17 -17
  71. app-ng-runtime/components/dialogs/default/esm2022/base-dialog.mjs +1 -12
  72. app-ng-runtime/components/dialogs/default/esm2022/dialog-body/dialog-body.directive.mjs +14 -2
  73. app-ng-runtime/components/dialogs/default/esm2022/dialog-header/dialog-header.component.mjs +6 -7
  74. app-ng-runtime/components/dialogs/default/fesm2022/index.mjs +18 -18
  75. app-ng-runtime/components/dialogs/default/fesm2022/index.mjs.map +1 -1
  76. app-ng-runtime/components/dialogs/design-dialog/bundles/index.umd.js +21 -3
  77. app-ng-runtime/components/dialogs/design-dialog/dialog.component.d.ts +3 -2
  78. app-ng-runtime/components/dialogs/design-dialog/esm2022/dialog.component.mjs +22 -4
  79. app-ng-runtime/components/dialogs/design-dialog/fesm2022/index.mjs +21 -3
  80. app-ng-runtime/components/dialogs/design-dialog/fesm2022/index.mjs.map +1 -1
  81. app-ng-runtime/components/input/default/bundles/index.umd.js +116 -115
  82. app-ng-runtime/components/input/default/checkboxset/checkboxset.component.d.ts +1 -0
  83. app-ng-runtime/components/input/default/esm2022/checkboxset/checkboxset.component.mjs +8 -5
  84. app-ng-runtime/components/input/default/esm2022/radioset/radioset.component.mjs +8 -5
  85. app-ng-runtime/components/input/default/esm2022/select/select.component.mjs +29 -59
  86. app-ng-runtime/components/input/default/esm2022/switch/switch.component.mjs +64 -38
  87. app-ng-runtime/components/input/default/esm2022/switch/switch.props.mjs +2 -1
  88. app-ng-runtime/components/input/default/esm2022/text/base/base-input.mjs +4 -1
  89. app-ng-runtime/components/input/default/esm2022/text/locale/number-locale.mjs +2 -2
  90. app-ng-runtime/components/input/default/esm2022/textarea/textarea.component.mjs +1 -4
  91. app-ng-runtime/components/input/default/fesm2022/index.mjs +117 -116
  92. app-ng-runtime/components/input/default/fesm2022/index.mjs.map +1 -1
  93. app-ng-runtime/components/input/default/radioset/radioset.component.d.ts +1 -0
  94. app-ng-runtime/components/input/default/select/select.component.d.ts +4 -2
  95. app-ng-runtime/components/input/default/switch/switch.component.d.ts +2 -0
  96. app-ng-runtime/components/input/default/textarea/textarea.component.d.ts +2 -3
  97. app-ng-runtime/components/input/epoch/bundles/index.umd.js +0 -3
  98. app-ng-runtime/components/input/epoch/esm2022/date-time/date-time.component.mjs +1 -4
  99. app-ng-runtime/components/input/epoch/fesm2022/index.mjs +0 -3
  100. app-ng-runtime/components/input/epoch/fesm2022/index.mjs.map +1 -1
  101. app-ng-runtime/components/input/file-upload/bundles/index.umd.js +5 -31
  102. app-ng-runtime/components/input/file-upload/esm2022/file-upload.component.mjs +8 -34
  103. app-ng-runtime/components/input/file-upload/fesm2022/index.mjs +6 -32
  104. app-ng-runtime/components/input/file-upload/fesm2022/index.mjs.map +1 -1
  105. app-ng-runtime/components/input/file-upload/file-upload.component.d.ts +2 -6
  106. app-ng-runtime/components/input/rating/bundles/index.umd.js +26 -35
  107. app-ng-runtime/components/input/rating/esm2022/rating.component.mjs +26 -37
  108. app-ng-runtime/components/input/rating/esm2022/rating.props.mjs +3 -1
  109. app-ng-runtime/components/input/rating/fesm2022/index.mjs +27 -36
  110. app-ng-runtime/components/input/rating/fesm2022/index.mjs.map +1 -1
  111. app-ng-runtime/components/input/rating/rating.component.d.ts +3 -1
  112. app-ng-runtime/components/navigation/menu/bundles/index.umd.js +2 -2
  113. app-ng-runtime/components/navigation/menu/esm2022/menu.component.mjs +2 -2
  114. app-ng-runtime/components/navigation/menu/esm2022/nav/nav.component.mjs +2 -2
  115. app-ng-runtime/components/navigation/menu/fesm2022/index.mjs +2 -2
  116. app-ng-runtime/components/navigation/menu/fesm2022/index.mjs.map +1 -1
  117. app-ng-runtime/components/page/left-panel/bundles/index.umd.js +6 -2
  118. app-ng-runtime/components/page/left-panel/esm2022/left-panel.directive.mjs +9 -5
  119. app-ng-runtime/components/page/left-panel/fesm2022/index.mjs +8 -4
  120. app-ng-runtime/components/page/left-panel/fesm2022/index.mjs.map +1 -1
  121. app-ng-runtime/components/page/left-panel/left-panel.directive.d.ts +2 -2
  122. app-ng-runtime/components/page/right-panel/bundles/index.umd.js +6 -2
  123. app-ng-runtime/components/page/right-panel/esm2022/right-panel.directive.mjs +9 -5
  124. app-ng-runtime/components/page/right-panel/fesm2022/index.mjs +8 -4
  125. app-ng-runtime/components/page/right-panel/fesm2022/index.mjs.map +1 -1
  126. app-ng-runtime/components/page/right-panel/right-panel.directive.d.ts +2 -2
  127. app-ng-runtime/core/bundles/index.umd.js +28 -6
  128. app-ng-runtime/core/enums/enums.d.ts +2 -1
  129. app-ng-runtime/core/esm2022/enums/enums.mjs +2 -1
  130. app-ng-runtime/core/esm2022/public_api.mjs +2 -2
  131. app-ng-runtime/core/esm2022/types/types.mjs +4 -1
  132. app-ng-runtime/core/esm2022/utils/build-utils.mjs +6 -1
  133. app-ng-runtime/core/esm2022/utils/utils.mjs +11 -4
  134. app-ng-runtime/core/fesm2022/index.mjs +22 -4
  135. app-ng-runtime/core/fesm2022/index.mjs.map +1 -1
  136. app-ng-runtime/core/public_api.d.ts +1 -1
  137. app-ng-runtime/core/types/types.d.ts +5 -1
  138. app-ng-runtime/core/utils/utils.d.ts +2 -1
  139. app-ng-runtime/mobile/core/bundles/index.umd.js +2 -18
  140. app-ng-runtime/mobile/core/esm2022/native.xhr.mjs +3 -19
  141. app-ng-runtime/mobile/core/fesm2022/index.mjs +2 -18
  142. app-ng-runtime/mobile/core/fesm2022/index.mjs.map +1 -1
  143. app-ng-runtime/package.json +1 -1
  144. app-ng-runtime/runtime/base/bundles/index.umd.js +296 -5
  145. app-ng-runtime/runtime/base/components/base-custom-widget.component.d.ts +73 -0
  146. app-ng-runtime/runtime/base/esm2022/components/base-custom-widget.component.mjs +294 -0
  147. app-ng-runtime/runtime/base/esm2022/public_api.mjs +2 -1
  148. app-ng-runtime/runtime/base/esm2022/runtime-base.module.mjs +6 -1
  149. app-ng-runtime/runtime/base/esm2022/services/i18n.service.mjs +2 -2
  150. app-ng-runtime/runtime/base/esm2022/types/types.mjs +4 -1
  151. app-ng-runtime/runtime/base/fesm2022/index.mjs +294 -4
  152. app-ng-runtime/runtime/base/fesm2022/index.mjs.map +1 -1
  153. app-ng-runtime/runtime/base/public_api.d.ts +1 -0
  154. app-ng-runtime/runtime/base/runtime-base.module.d.ts +9 -8
  155. app-ng-runtime/runtime/base/types/types.d.ts +5 -1
  156. app-ng-runtime/runtime/dynamic/app/services/customwidget-config-provider.service.d.ts +8 -0
  157. app-ng-runtime/runtime/dynamic/bundles/index.umd.js +49 -13
  158. app-ng-runtime/runtime/dynamic/esm2022/app/app.module.mjs +8 -3
  159. app-ng-runtime/runtime/dynamic/esm2022/app/services/component-ref-provider.service.mjs +23 -7
  160. app-ng-runtime/runtime/dynamic/esm2022/app/services/customwidget-config-provider.service.mjs +22 -0
  161. app-ng-runtime/runtime/dynamic/fesm2022/index.mjs +50 -11
  162. app-ng-runtime/runtime/dynamic/fesm2022/index.mjs.map +1 -1
  163. app-ng-runtime/scripts/@wavemaker/nvd3/build/nv.d3.min.js +1 -1
  164. app-ng-runtime/scripts/datatable/datatable.js +4 -7
  165. app-ng-runtime/scripts/summernote/dist/summernote-lite.min.js +3 -2
  166. app-ng-runtime/transpiler/bundles/index.umd.js +5 -0
  167. app-ng-runtime/transpiler/esm2022/build.mjs +4 -1
  168. app-ng-runtime/transpiler/esm2022/imports.mjs +3 -1
  169. app-ng-runtime/transpiler/fesm2022/index.mjs +5 -0
  170. app-ng-runtime/transpiler/fesm2022/index.mjs.map +1 -1
@@ -167,6 +167,12 @@ 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
+ }
170
176
  /**
171
177
  * On click of the option, update the datavalue
172
178
  */
@@ -174,10 +180,7 @@ export class RadiosetComponent extends DatasetAwareFormComponent {
174
180
  if (!$($event.target).is('input')) {
175
181
  return;
176
182
  }
177
- this.modelByKey = key;
178
- this.invokeOnTouched();
179
- // invoke on datavalue change.
180
- this.invokeOnChange(this.datavalue, $event || {}, true);
183
+ this.triggerInvokeOnChange(key, $event);
181
184
  }
182
185
  // change and blur events are added from the template
183
186
  handleEvent(node, eventName, callback, locals) {
@@ -237,4 +240,4 @@ export class RadiosetComponent extends DatasetAwareFormComponent {
237
240
  type: Optional
238
241
  }] }], null); })();
239
242
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(RadiosetComponent, { className: "RadiosetComponent", filePath: "radioset/radioset.component.ts", lineNumber: 26 }); })();
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"]}
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"]}
@@ -1,13 +1,15 @@
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 { DataSource, removeAttr, setAttr, isIos } from '@wm/core';
3
+ import { App, 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";
7
8
  import * as i0 from "@angular/core";
8
- import * as i1 from "@angular/common";
9
- import * as i2 from "@angular/forms";
10
- import * as i3 from "@wm/components/base";
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";
11
13
  const _c0 = ["select"];
12
14
  const _c1 = a0 => ["app-select form-control", a0];
13
15
  const _c2 = () => ({ standalone: true });
@@ -59,38 +61,10 @@ export class SelectComponent extends DatasetAwareFormComponent {
59
61
  this.datavalue = ds.execute(DataSource.Operation.GET_DEFAULT_LOCALE);
60
62
  }
61
63
  }
62
- constructor(inj, explicitContext) {
64
+ constructor(inj, app, explicitContext) {
63
65
  super(inj, WIDGET_CONFIG, explicitContext);
66
+ this.app = app;
64
67
  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 (isIos()) {
73
- if (this.datavalue) {
74
- const selectedItem = this.datasetItems.find(item => item.selected);
75
- if (!selectedItem) {
76
- setTimeout(() => {
77
- if (!this.placeholder) {
78
- this.selectEl.nativeElement.value = '';
79
- }
80
- this.modelByKey = undefined;
81
- }, 100);
82
- }
83
- }
84
- else {
85
- setTimeout(() => {
86
- if (!this.placeholder) {
87
- this.selectEl.nativeElement.value = '';
88
- }
89
- }, 100);
90
- }
91
- }
92
- });
93
- this.registerDestroyListener(() => datasetSubscription.unsubscribe());
94
68
  }
95
69
  ngAfterViewInit() {
96
70
  super.ngAfterViewInit();
@@ -98,7 +72,7 @@ export class SelectComponent extends DatasetAwareFormComponent {
98
72
  }
99
73
  // Change event is registered from the template, Prevent the framework from registering one more event
100
74
  handleEvent(node, eventName, eventCallback, locals) {
101
- if (!['blur', 'change'].includes(eventName)) {
75
+ if (!includes(['blur', 'change'], eventName)) {
102
76
  super.handleEvent(this.selectEl.nativeElement, eventName, eventCallback, locals);
103
77
  }
104
78
  }
@@ -149,40 +123,36 @@ export class SelectComponent extends DatasetAwareFormComponent {
149
123
  */
150
124
  checkForFloatingLabel($event) {
151
125
  const captionEl = $(this.selectEl.nativeElement).closest('.app-composite-widget.caption-floating');
152
- if (!this.placeholder && isIos()) {
153
- this.removePlaceholderOption();
154
- }
155
126
  if (captionEl.length > 0) {
156
- const placeholderOption = this.selectEl.nativeElement.querySelector('#placeholderOption');
157
- if ($event.type === 'mousedown' && (!this.datavalue || (this.datavalue && $(this.selectEl).find('select option:selected').text() === '' && this.placeholder))) {
158
- if (this.placeholder) {
159
- placeholderOption.textContent = this.placeholder;
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);
160
133
  }
161
134
  }
162
135
  else if (!this.datavalue) {
163
- if (this.placeholder) {
164
- placeholderOption.textContent = '';
165
- }
136
+ $(this.selectEl.nativeElement).find('option:selected').text('');
166
137
  captionEl.removeClass('float-active');
167
138
  }
168
139
  }
140
+ else if (!(this.datavalue || this.placeholder)) {
141
+ this.removePlaceholderOption();
142
+ }
169
143
  }
170
144
  /*
171
145
  * Removing the placeholder option if no placeholder is provided.
172
- * In html we are hiding the placeholder option using css but in Apple devices and safari option is showing.
173
- * Styles are not allowed on option tag in ios safari
174
- * 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
146
+ * In html we are hiding the placeholder option using css but in apple devices and safari option is showing.
175
147
  * */
176
148
  removePlaceholderOption() {
177
149
  const hiddenEle = $(this.selectEl.nativeElement).find('#placeholderOption');
178
150
  if (hiddenEle.length) {
179
151
  hiddenEle.remove();
180
- if (!this.datavalue) {
181
- this.selectEl.nativeElement.value = '';
182
- }
152
+ this.selectEl.nativeElement.value = '';
183
153
  }
184
154
  }
185
- static { this.ɵfac = function SelectComponent_Factory(t) { return new (t || SelectComponent)(i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject('EXPLICIT_CONTEXT', 8)); }; }
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)); }; }
186
156
  static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SelectComponent, selectors: [["wm-select"]], viewQuery: function SelectComponent_Query(rf, ctx) { if (rf & 1) {
187
157
  i0.ɵɵviewQuery(_c0, 7, ElementRef);
188
158
  } if (rf & 2) {
@@ -192,11 +162,11 @@ export class SelectComponent extends DatasetAwareFormComponent {
192
162
  provideAs(SelectComponent, NG_VALUE_ACCESSOR, true),
193
163
  provideAs(SelectComponent, NG_VALIDATORS, true),
194
164
  provideAsWidgetRef(SelectComponent)
195
- ]), 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) {
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) {
196
166
  const _r1 = i0.ɵɵgetCurrentView();
197
167
  i0.ɵɵelementStart(0, "select", 1, 0);
198
168
  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); });
199
- 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)); });
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)); });
200
170
  i0.ɵɵelement(2, "option", 2);
201
171
  i0.ɵɵtemplate(3, SelectComponent_ng_container_3_Template, 2, 1, "ng-container", 3)(4, SelectComponent_ng_container_4_Template, 2, 1, "ng-container", 3);
202
172
  i0.ɵɵelementEnd();
@@ -211,7 +181,7 @@ export class SelectComponent extends DatasetAwareFormComponent {
211
181
  i0.ɵɵproperty("ngIf", ctx.groupby);
212
182
  i0.ɵɵadvance();
213
183
  i0.ɵɵproperty("ngIf", !ctx.groupby);
214
- } }, dependencies: [i1.NgClass, i1.NgForOf, i1.NgIf, i2.NgSelectOption, i2.ɵNgSelectMultipleOption, i2.SelectMultipleControlValueAccessor, i2.NgControlStatus, i2.RequiredValidator, i2.NgModel, i3.TextContentDirective], encapsulation: 2 }); }
184
+ } }, dependencies: [i2.NgClass, i2.NgForOf, i2.NgIf, i3.NgSelectOption, i3.ɵNgSelectMultipleOption, i3.SelectMultipleControlValueAccessor, i3.NgControlStatus, i3.RequiredValidator, i3.NgModel, i4.TextContentDirective], encapsulation: 2 }); }
215
185
  }
216
186
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SelectComponent, [{
217
187
  type: Component,
@@ -219,8 +189,8 @@ export class SelectComponent extends DatasetAwareFormComponent {
219
189
  provideAs(SelectComponent, NG_VALUE_ACCESSOR, true),
220
190
  provideAs(SelectComponent, NG_VALIDATORS, true),
221
191
  provideAsWidgetRef(SelectComponent)
222
- ], 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" }]
223
- }], () => [{ type: i0.Injector }, { type: undefined, decorators: [{
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: [{
224
194
  type: Inject,
225
195
  args: ['EXPLICIT_CONTEXT']
226
196
  }, {
@@ -229,5 +199,5 @@ export class SelectComponent extends DatasetAwareFormComponent {
229
199
  type: ViewChild,
230
200
  args: ['select', { static: true, read: ElementRef }]
231
201
  }] }); })();
232
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SelectComponent, { className: "SelectComponent", filePath: "select/select.component.ts", lineNumber: 20 }); })();
233
- //# 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';\nimport {DataSource, removeAttr, setAttr, isIos} 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(isIos()) {\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\n                    }, 100);\n                }\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 && isIos()) {\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"]}
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"]}