@wavemaker/app-ng-runtime 12.0.0-next.45078 → 12.0.0-next.45080

Sign up to get free protection for your applications and to get access to all the features.
Files changed (47) hide show
  1. app-ng-runtime/build-task/bundles/index.umd.js +8 -1
  2. app-ng-runtime/build-task/esm2022/data/form/form-field/form-field.build.mjs +9 -2
  3. app-ng-runtime/build-task/fesm2022/index.mjs +8 -1
  4. app-ng-runtime/build-task/fesm2022/index.mjs.map +1 -1
  5. app-ng-runtime/components/advanced/custom/bundles/index.umd.js +49 -12
  6. app-ng-runtime/components/advanced/custom/custom-widget-container/custom-widget-container.directive.d.ts +11 -4
  7. app-ng-runtime/components/advanced/custom/esm2022/custom-widget-container/custom-widget-container.directive.mjs +51 -11
  8. app-ng-runtime/components/advanced/custom/fesm2022/index.mjs +50 -10
  9. app-ng-runtime/components/advanced/custom/fesm2022/index.mjs.map +1 -1
  10. app-ng-runtime/components/base/bundles/index.umd.js +13 -3
  11. app-ng-runtime/components/base/esm2022/widgets/common/base/base.component.mjs +14 -4
  12. app-ng-runtime/components/base/esm2022/widgets/framework/property-change-handler.mjs +2 -2
  13. app-ng-runtime/components/base/fesm2022/index.mjs +14 -4
  14. app-ng-runtime/components/base/fesm2022/index.mjs.map +1 -1
  15. app-ng-runtime/components/base/widgets/common/base/base.component.d.ts +1 -0
  16. app-ng-runtime/components/basic/search/bundles/index.umd.js +36 -24
  17. app-ng-runtime/components/basic/search/esm2022/search.component.mjs +33 -24
  18. app-ng-runtime/components/basic/search/esm2022/search.props.mjs +5 -2
  19. app-ng-runtime/components/basic/search/fesm2022/index.mjs +36 -24
  20. app-ng-runtime/components/basic/search/fesm2022/index.mjs.map +1 -1
  21. app-ng-runtime/components/basic/search/search.component.d.ts +3 -0
  22. app-ng-runtime/components/data/form/bundles/index.umd.js +23 -11
  23. app-ng-runtime/components/data/form/esm2022/form-field/form-field.directive.mjs +24 -12
  24. app-ng-runtime/components/data/form/fesm2022/index.mjs +23 -11
  25. app-ng-runtime/components/data/form/fesm2022/index.mjs.map +1 -1
  26. app-ng-runtime/components/data/form/form-field/form-field.directive.d.ts +1 -0
  27. app-ng-runtime/components/input/default/base-form-custom.component.d.ts +2 -1
  28. app-ng-runtime/components/input/default/bundles/index.umd.js +13 -4
  29. app-ng-runtime/components/input/default/dataset-aware-form.component.d.ts +2 -2
  30. app-ng-runtime/components/input/default/esm2022/base-form-custom.component.mjs +6 -1
  31. app-ng-runtime/components/input/default/esm2022/checkboxset/checkboxset.component.mjs +3 -1
  32. app-ng-runtime/components/input/default/esm2022/dataset-aware-form.component.mjs +5 -5
  33. app-ng-runtime/components/input/default/esm2022/radioset/radioset.component.mjs +3 -1
  34. app-ng-runtime/components/input/default/fesm2022/index.mjs +13 -4
  35. app-ng-runtime/components/input/default/fesm2022/index.mjs.map +1 -1
  36. app-ng-runtime/core/bundles/index.umd.js +6 -6
  37. app-ng-runtime/core/enums/enums.d.ts +2 -2
  38. app-ng-runtime/core/esm2022/enums/enums.mjs +2 -2
  39. app-ng-runtime/core/esm2022/utils/build-utils.mjs +6 -6
  40. app-ng-runtime/core/fesm2022/index.mjs +6 -6
  41. app-ng-runtime/core/fesm2022/index.mjs.map +1 -1
  42. app-ng-runtime/package.json +1 -1
  43. app-ng-runtime/runtime/base/bundles/index.umd.js +9 -0
  44. app-ng-runtime/runtime/base/components/base-custom-widget.component.d.ts +2 -0
  45. app-ng-runtime/runtime/base/esm2022/components/base-custom-widget.component.mjs +10 -1
  46. app-ng-runtime/runtime/base/fesm2022/index.mjs +9 -0
  47. app-ng-runtime/runtime/base/fesm2022/index.mjs.map +1 -1
@@ -107,6 +107,7 @@ export declare class FormFieldDirective extends StylableComponent implements OnI
107
107
  triggerUploadEvent($event: any, eventName: any): void;
108
108
  private registerFormField;
109
109
  ngOnInit(): void;
110
+ prepareFormWidget(): void;
110
111
  ngAfterContentInit(): void;
111
112
  static ɵfac: i0.ɵɵFactoryDeclaration<FormFieldDirective, [null, null, null, null, null, { optional: true; }, { attribute: "chipclass.bind"; }, { attribute: "dataset.bind"; }, { attribute: "displayexpression.bind"; }, { attribute: "displaylabel.bind"; }, { attribute: "widgettype"; }, { attribute: "name"; }, { attribute: "displayimagesrc.bind"; }, { attribute: "key"; }, { attribute: "is-range"; }, { attribute: "pc-display"; }, { attribute: "mobile-display"; }, { attribute: "tablet-display"; }, { self: true; }, { optional: true; }]>;
112
113
  static ɵdir: i0.ɵɵDirectiveDeclaration<FormFieldDirective, "[wmFormField]", ["wmFormField"], {}, {}, ["formWidget", "formWidgetMax"], never, false, never>;
@@ -1,4 +1,4 @@
1
- import { ControlValueAccessor, Validator, AbstractControl } from '@angular/forms';
1
+ import { ControlValueAccessor, FormControlName, Validator, AbstractControl } from '@angular/forms';
2
2
  import { OnInit } from '@angular/core';
3
3
  import { BaseFormComponent } from './base-form.component';
4
4
  import * as i0 from "@angular/core";
@@ -10,6 +10,7 @@ export declare abstract class BaseFormCustomComponent extends BaseFormComponent
10
10
  registerOnChange(fn: any): void;
11
11
  registerOnTouched(fn: any): void;
12
12
  writeValue(value: any): void;
13
+ get formControl(): FormControlName;
13
14
  invokeOnChange(value: any, $event?: Event | any, valid?: boolean): void;
14
15
  invokeOnTouched($event?: Event): void;
15
16
  invokeOnFocus($event: Event): void;
@@ -331,6 +331,8 @@
331
331
  return;
332
332
  }
333
333
  if (this._formControl) {
334
+ if (this._formControl.valueAccessor["widgetSubType"].startsWith('wm-custom-'))
335
+ return;
334
336
  this.datavalue = value;
335
337
  this.onPropertyChange('datavalue', value);
336
338
  this.updatePrevDatavalue(value);
@@ -342,6 +344,9 @@
342
344
  */
343
345
  (value !== this.datavalue) && this._onChange(this.datavalue);
344
346
  }
347
+ get formControl() {
348
+ return this._formControl;
349
+ }
345
350
  invokeOnChange(value, $event, valid) {
346
351
  // let the angular know about the change
347
352
  this._onChange(value);
@@ -591,8 +596,8 @@
591
596
  // invoke on datavalue change.
592
597
  this.invokeOnChange(val, undefined, true);
593
598
  }
594
- constructor(inj, config, explicitContext, groupby) {
595
- super(inj, config, explicitContext);
599
+ constructor(inj, config, explicitContext, groupby, initPromise) {
600
+ super(inj, config, explicitContext, initPromise);
596
601
  this.groupby = groupby;
597
602
  this.datasetItems = [];
598
603
  this.acceptsArray = false; // set to true if proxyModel on widget accepts array type.
@@ -844,7 +849,7 @@
844
849
  this.cancelLocaleChangeSubscription();
845
850
  }
846
851
  }
847
- static { this.ɵfac = function DatasetAwareFormComponent_Factory(t) { return new (t || DatasetAwareFormComponent)(i0__namespace.ɵɵinject(i0__namespace.Injector), i0__namespace.ɵɵinject(i2.WidgetConfig), i0__namespace.ɵɵinject('EXPLICIT_CONTEXT', 8), i0__namespace.ɵɵinjectAttribute('groupby')); }; }
852
+ static { this.ɵfac = function DatasetAwareFormComponent_Factory(t) { return new (t || DatasetAwareFormComponent)(i0__namespace.ɵɵinject(i0__namespace.Injector), i0__namespace.ɵɵinject(i2.WidgetConfig), i0__namespace.ɵɵinject('EXPLICIT_CONTEXT', 8), i0__namespace.ɵɵinjectAttribute('groupby'), i0__namespace.ɵɵinject(Promise)); }; }
848
853
  static { this.ɵprov = /*@__PURE__*/ i0__namespace.ɵɵdefineInjectable({ token: DatasetAwareFormComponent, factory: DatasetAwareFormComponent.ɵfac }); }
849
854
  }
850
855
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0__namespace.ɵsetClassMetadata(DatasetAwareFormComponent, [{
@@ -860,7 +865,7 @@
860
865
  }] }, { type: undefined, decorators: [{
861
866
  type: i0.Attribute,
862
867
  args: ['groupby']
863
- }] }], null); })();
868
+ }] }, { type: Promise }], null); })();
864
869
 
865
870
  const checkboxsetProps = new Map([
866
871
  ['class', i2.PROP_STRING],
@@ -1056,6 +1061,8 @@
1056
1061
  }
1057
1062
  triggerInvokeOnChange(keys, $event) {
1058
1063
  this.modelByKey = keys;
1064
+ if (this.viewParent.containerWidget)
1065
+ this.viewParent.containerWidget.updateDataValue(this.datavalue);
1059
1066
  this.invokeOnTouched();
1060
1067
  // invoke on datavalue change.
1061
1068
  this.invokeOnChange(this.datavalue, $event || {}, true);
@@ -2042,6 +2049,8 @@
2042
2049
  }
2043
2050
  triggerInvokeOnChange(key, $event) {
2044
2051
  this.modelByKey = key;
2052
+ if (this.viewParent.containerWidget)
2053
+ this.viewParent.containerWidget.updateDataValue(this.datavalue);
2045
2054
  this.invokeOnTouched();
2046
2055
  // invoke on datavalue change.
2047
2056
  this.invokeOnChange(this.datavalue, $event || {}, true);
@@ -44,7 +44,7 @@ export declare abstract class DatasetAwareFormComponent extends BaseFormCustomCo
44
44
  set modelByKey(val: any);
45
45
  get datavalue(): any;
46
46
  set datavalue(val: any);
47
- protected constructor(inj: Injector, config: IWidgetConfig, explicitContext: any, groupby?: string);
47
+ protected constructor(inj: Injector, config: IWidgetConfig, explicitContext: any, groupby?: string, initPromise?: Promise<any>);
48
48
  /**
49
49
  * This function sets the _datavalue value from the model and sets the selected flag when item is found.
50
50
  * Here model is the value obtained from ngModel.
@@ -71,6 +71,6 @@ export declare abstract class DatasetAwareFormComponent extends BaseFormCustomCo
71
71
  onPropertyChange(key: string, nv: any, ov?: any): void;
72
72
  ngOnInit(): void;
73
73
  ngOnDestroy(): void;
74
- static ɵfac: i0.ɵɵFactoryDeclaration<DatasetAwareFormComponent, [null, null, { optional: true; }, { attribute: "groupby"; }]>;
74
+ static ɵfac: i0.ɵɵFactoryDeclaration<DatasetAwareFormComponent, [null, null, { optional: true; }, { attribute: "groupby"; }, null]>;
75
75
  static ɵprov: i0.ɵɵInjectableDeclaration<DatasetAwareFormComponent>;
76
76
  }
@@ -45,6 +45,8 @@ export class BaseFormCustomComponent extends BaseFormComponent {
45
45
  return;
46
46
  }
47
47
  if (this._formControl) {
48
+ if (this._formControl.valueAccessor["widgetSubType"].startsWith('wm-custom-'))
49
+ return;
48
50
  this.datavalue = value;
49
51
  this.onPropertyChange('datavalue', value);
50
52
  this.updatePrevDatavalue(value);
@@ -56,6 +58,9 @@ export class BaseFormCustomComponent extends BaseFormComponent {
56
58
  */
57
59
  (value !== this.datavalue) && this._onChange(this.datavalue);
58
60
  }
61
+ get formControl() {
62
+ return this._formControl;
63
+ }
59
64
  invokeOnChange(value, $event, valid) {
60
65
  // let the angular know about the change
61
66
  this._onChange(value);
@@ -86,4 +91,4 @@ export class BaseFormCustomComponent extends BaseFormComponent {
86
91
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(BaseFormCustomComponent, [{
87
92
  type: Injectable
88
93
  }], null, null); })();
89
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1mb3JtLWN1c3RvbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnRzL3dpZGdldHMvaW5wdXQvZGVmYXVsdC9zcmMvYmFzZS1mb3JtLWN1c3RvbS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUF3QixlQUFlLEVBQTJDLE1BQU0sZ0JBQWdCLENBQUM7QUFDaEgsT0FBTyxFQUFFLFVBQVUsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUVuRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQzs7QUFFMUQ7Ozs7Ozs7R0FPRztBQUNILFNBQVMsWUFBWSxDQUFDLEdBQUc7SUFDckIsUUFBTyxPQUFPLEdBQUcsRUFBRSxDQUFDO1FBQ2hCLEtBQUssUUFBUSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO1FBQzdFLEtBQUssUUFBUSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDO1FBQ3ZDLE9BQU8sQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLEdBQUcsS0FBSyxTQUFTLElBQUksR0FBRyxLQUFLLElBQUksSUFBSSxHQUFHLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDM0UsQ0FBQztBQUNMLENBQUM7QUFDRCxTQUFTLG9CQUFvQixDQUFDLFFBQWlCO0lBQzNDLE9BQU8sQ0FBQyxPQUF3QixFQUFFLEVBQUUsQ0FDaEMsUUFBUTtRQUNKLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDO1lBQzFCLENBQUMsQ0FBQyxJQUFJO1lBQ04sQ0FBQyxDQUFDLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDO1FBQ3pCLENBQUMsQ0FBQyxJQUFJLENBQUM7QUFDbkIsQ0FBQztBQUdELE1BQU0sT0FBZ0IsdUJBQXdCLFNBQVEsaUJBQWlCO0lBRHZFOztRQUljLGNBQVMsR0FBUSxHQUFHLEVBQUUsR0FBRSxDQUFDLENBQUM7UUFDNUIsZUFBVSxHQUFRLEdBQUcsRUFBRSxHQUFFLENBQUMsQ0FBQztLQTBEdEM7SUF4REcsUUFBUTtRQUNKLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQixJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLGVBQWUsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUM1RCxDQUFDO0lBRU0sZ0JBQWdCLENBQUMsRUFBRTtRQUN0QixJQUFJLENBQUMsU0FBUyxHQUFHLEVBQUUsQ0FBQztJQUN4QixDQUFDO0lBRU0saUJBQWlCLENBQUMsRUFBRTtRQUN2QixJQUFJLENBQUMsVUFBVSxHQUFHLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBRU0sVUFBVSxDQUFDLEtBQUs7UUFDbkIsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDbkIsT0FBTztRQUNYLENBQUM7UUFDRCxJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztZQUNwQixJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQztZQUN2QixJQUFJLENBQUMsZ0JBQWdCLENBQUMsV0FBVyxFQUFFLEtBQUssQ0FBQyxDQUFDO1lBQzFDLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNwQyxDQUFDO1FBQ0Q7Ozs7V0FJRztRQUNILENBQUMsS0FBSyxLQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUMvRCxDQUFDO0lBRU0sY0FBYyxDQUFDLEtBQUssRUFBRSxNQUFvQixFQUFFLEtBQWU7UUFDOUQsd0NBQXdDO1FBQ3hDLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDdEIsSUFBSSxNQUFNLEVBQUUsQ0FBQztZQUNULEtBQUssQ0FBQyxjQUFjLENBQUMsS0FBSyxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQ3hDLENBQUM7YUFBTSxJQUFJLEtBQUssRUFBRSxDQUFDO1lBQ2YsNEZBQTRGO1lBQzVGLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNwQyxDQUFDO0lBQ0wsQ0FBQztJQUVNLGVBQWUsQ0FBQyxNQUFjO1FBQ2pDLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztRQUVsQixJQUFJLE1BQU0sRUFBRSxDQUFDO1lBQ1QsSUFBSSxDQUFDLG1CQUFtQixDQUFDLE1BQU0sRUFBRSxFQUFDLE1BQU0sRUFBQyxDQUFDLENBQUM7UUFDL0MsQ0FBQztJQUNMLENBQUM7SUFFTSxhQUFhLENBQUMsTUFBYTtRQUM5QixJQUFJLENBQUMsbUJBQW1CLENBQUMsT0FBTyxFQUFFLEVBQUMsTUFBTSxFQUFDLENBQUMsQ0FBQztJQUNoRCxDQUFDO0lBQ0QsZUFBZTtJQUNmLFFBQVEsQ0FBQyxPQUF3QjtRQUM3QixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsb0JBQW9CLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztJQUNqRixDQUFDO2dRQTdEaUIsdUJBQXVCLFNBQXZCLHVCQUF1Qjt1RUFBdkIsdUJBQXVCLFdBQXZCLHVCQUF1Qjs7aUZBQXZCLHVCQUF1QjtjQUQ1QyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29udHJvbFZhbHVlQWNjZXNzb3IsIEZvcm1Db250cm9sTmFtZSwgVmFsaWRhdG9yLCBWYWxpZGF0b3JGbiwgQWJzdHJhY3RDb250cm9sIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgSW5qZWN0YWJsZSwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEJhc2VGb3JtQ29tcG9uZW50IH0gZnJvbSAnLi9iYXNlLWZvcm0uY29tcG9uZW50JztcblxuLypcbiAqIFdNUy0xODI2OVxuICogY3VzdG9tICdyZXF1aXJlZCcgdmFsaWRhdG9yIGZvciBjb21wb25lbnRzLFxuICogYXMgdGhlIGJvdW5kIHZhbHVlcyBhcmUgcmVzb2x2ZWQgYXQgcnVudGltZVxuICogQ2FsbGVkIG9uICdyZXF1aXJlZCcgcHJvcGVydHkgY2hhbmdlXG4gKlxuICogTm90ZTogQ29tcG9uZW50IG5lZWRzIE5HX1ZBTElEQVRPUiBwcm92aWRlciBmb3IgdGhpcyB0byB3b3JrXG4gKi9cbmZ1bmN0aW9uIGlzVmFsaWRWYWx1ZSh2YWwpOiBCb29sZWFuIHtcbiAgICBzd2l0Y2godHlwZW9mIHZhbCkge1xuICAgICAgICBjYXNlICdvYmplY3QnOiByZXR1cm4gKCEhdmFsICYmICghIXZhbC5sZW5ndGggfHwgISFPYmplY3Qua2V5cyh2YWwpLmxlbmd0aCkpO1xuICAgICAgICBjYXNlICdudW1iZXInOiByZXR1cm4gKCEhdmFsIHx8IHZhbCA9PT0gMCk7XG4gICAgICAgICAgICBkZWZhdWx0OiByZXR1cm4gISh2YWwgPT09IHVuZGVmaW5lZCB8fCB2YWwgPT09IG51bGwgfHwgdmFsID09PSAnJyk7XG4gICAgfVxufVxuZnVuY3Rpb24gdmFsaWRhdGVSZXF1aXJlZEJpbmQocmVxdWlyZWQ6IGJvb2xlYW4pOiBWYWxpZGF0b3JGbiB7XG4gICAgcmV0dXJuIChjb250cm9sOiBBYnN0cmFjdENvbnRyb2wpID0+XG4gICAgICAgIHJlcXVpcmVkXG4gICAgICAgICAgICA/IChpc1ZhbGlkVmFsdWUoY29udHJvbC52YWx1ZSlcbiAgICAgICAgICAgICAgICA/IG51bGxcbiAgICAgICAgICAgICAgICA6IHsgcmVxdWlyZWQ6IHRydWUgfSlcbiAgICAgICAgICAgIDogbnVsbDtcbn1cblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEJhc2VGb3JtQ3VzdG9tQ29tcG9uZW50IGV4dGVuZHMgQmFzZUZvcm1Db21wb25lbnQgaW1wbGVtZW50cyBDb250cm9sVmFsdWVBY2Nlc3NvciwgT25Jbml0LCBWYWxpZGF0b3Ige1xuXG4gICAgcHJpdmF0ZSBfZm9ybUNvbnRyb2w6IEZvcm1Db250cm9sTmFtZTtcbiAgICBwcm90ZWN0ZWQgX29uQ2hhbmdlOiBhbnkgPSAoKSA9PiB7fTtcbiAgICBwcml2YXRlIF9vblRvdWNoZWQ6IGFueSA9ICgpID0+IHt9O1xuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIHN1cGVyLm5nT25Jbml0KCk7XG4gICAgICAgIHRoaXMuX2Zvcm1Db250cm9sID0gdGhpcy5pbmouZ2V0KEZvcm1Db250cm9sTmFtZSwgbnVsbCk7XG4gICAgfVxuXG4gICAgcHVibGljIHJlZ2lzdGVyT25DaGFuZ2UoZm4pIHtcbiAgICAgICAgdGhpcy5fb25DaGFuZ2UgPSBmbjtcbiAgICB9XG5cbiAgICBwdWJsaWMgcmVnaXN0ZXJPblRvdWNoZWQoZm4pIHtcbiAgICAgICAgdGhpcy5fb25Ub3VjaGVkID0gZm47XG4gICAgfVxuXG4gICAgcHVibGljIHdyaXRlVmFsdWUodmFsdWUpIHtcbiAgICAgICAgaWYgKHRoaXMuaXNEZXN0cm95ZWQpIHtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuICAgICAgICBpZiAodGhpcy5fZm9ybUNvbnRyb2wpIHtcbiAgICAgICAgICAgIHRoaXMuZGF0YXZhbHVlID0gdmFsdWU7XG4gICAgICAgICAgICB0aGlzLm9uUHJvcGVydHlDaGFuZ2UoJ2RhdGF2YWx1ZScsIHZhbHVlKTtcbiAgICAgICAgICAgIHRoaXMudXBkYXRlUHJldkRhdGF2YWx1ZSh2YWx1ZSk7XG4gICAgICAgIH1cbiAgICAgICAgLypcbiAgICAgICAgICogV01TOjE4MjQ2XG4gICAgICAgICAqIENhbGwgb25DaGFuZ2Ugb24gZGVmYXVsdCB2YWx1ZSwgc28gdGhhdCB0aGUgQ29tcG9uZW50IE1vZGVsIGlzIHVwZGF0ZWRcbiAgICAgICAgICogRG8gb25seSBXaGVuIHRoZSBNb2RlbCBWYWx1ZSBpcyBkaWZmZXJlbnQgZnJvbSBkYXRhdmFsdWVcbiAgICAgICAgICovXG4gICAgICAgICh2YWx1ZSE9PXRoaXMuZGF0YXZhbHVlKSAmJiB0aGlzLl9vbkNoYW5nZSh0aGlzLmRhdGF2YWx1ZSk7XG4gICAgfVxuXG4gICAgcHVibGljIGludm9rZU9uQ2hhbmdlKHZhbHVlLCAkZXZlbnQ/OiBFdmVudCB8IGFueSwgdmFsaWQ/OiBib29sZWFuKSB7XG4gICAgICAgIC8vIGxldCB0aGUgYW5ndWxhciBrbm93IGFib3V0IHRoZSBjaGFuZ2VcbiAgICAgICAgdGhpcy5fb25DaGFuZ2UodmFsdWUpO1xuICAgICAgICBpZiAoJGV2ZW50KSB7XG4gICAgICAgICAgICBzdXBlci5pbnZva2VPbkNoYW5nZSh2YWx1ZSwgJGV2ZW50KTtcbiAgICAgICAgfSBlbHNlIGlmICh2YWxpZCkge1xuICAgICAgICAgICAgLy8gRml4IGZvciBbV01TLTI0ODY5XTogdXBkYXRpbmcgUHJldkRhdGF2YWx1ZSB3aGVuIHRoZXJlIGlzIGEgZGVmYXVsdCB2YWx1ZSBmb3IgdGhlIHdpZGdldC5cbiAgICAgICAgICAgIHRoaXMudXBkYXRlUHJldkRhdGF2YWx1ZSh2YWx1ZSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwdWJsaWMgaW52b2tlT25Ub3VjaGVkKCRldmVudD86IEV2ZW50KSB7XG4gICAgICAgIHRoaXMuX29uVG91Y2hlZCgpO1xuXG4gICAgICAgIGlmICgkZXZlbnQpIHtcbiAgICAgICAgICAgIHRoaXMuaW52b2tlRXZlbnRDYWxsYmFjaygnYmx1cicsIHskZXZlbnR9KTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHB1YmxpYyBpbnZva2VPbkZvY3VzKCRldmVudDogRXZlbnQpIHtcbiAgICAgICAgdGhpcy5pbnZva2VFdmVudENhbGxiYWNrKCdmb2N1cycsIHskZXZlbnR9KTtcbiAgICB9XG4gICAgLyogV01TLTE4MjY5ICovXG4gICAgdmFsaWRhdGUoY29udHJvbDogQWJzdHJhY3RDb250cm9sKTp7W2tleTogc3RyaW5nXTphbnl9IHtcbiAgICAgICAgcmV0dXJuIHRoaXNbJ3Nob3cnXSA/IHZhbGlkYXRlUmVxdWlyZWRCaW5kKHRoaXNbJ3JlcXVpcmVkJ10pKGNvbnRyb2wpIDogbnVsbDtcbiAgICB9XG59XG4iXX0=
94
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1mb3JtLWN1c3RvbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnRzL3dpZGdldHMvaW5wdXQvZGVmYXVsdC9zcmMvYmFzZS1mb3JtLWN1c3RvbS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUF3QixlQUFlLEVBQTJDLE1BQU0sZ0JBQWdCLENBQUM7QUFDaEgsT0FBTyxFQUFFLFVBQVUsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUVuRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQzs7QUFFMUQ7Ozs7Ozs7R0FPRztBQUNILFNBQVMsWUFBWSxDQUFDLEdBQUc7SUFDckIsUUFBTyxPQUFPLEdBQUcsRUFBRSxDQUFDO1FBQ2hCLEtBQUssUUFBUSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO1FBQzdFLEtBQUssUUFBUSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDO1FBQ3ZDLE9BQU8sQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLEdBQUcsS0FBSyxTQUFTLElBQUksR0FBRyxLQUFLLElBQUksSUFBSSxHQUFHLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDM0UsQ0FBQztBQUNMLENBQUM7QUFDRCxTQUFTLG9CQUFvQixDQUFDLFFBQWlCO0lBQzNDLE9BQU8sQ0FBQyxPQUF3QixFQUFFLEVBQUUsQ0FDaEMsUUFBUTtRQUNKLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDO1lBQzFCLENBQUMsQ0FBQyxJQUFJ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aW1wb3J0IHsgQ29udHJvbFZhbHVlQWNjZXNzb3IsIEZvcm1Db250cm9sTmFtZSwgVmFsaWRhdG9yLCBWYWxpZGF0b3JGbiwgQWJzdHJhY3RDb250cm9sIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgSW5qZWN0YWJsZSwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEJhc2VGb3JtQ29tcG9uZW50IH0gZnJvbSAnLi9iYXNlLWZvcm0uY29tcG9uZW50JztcblxuLypcbiAqIFdNUy0xODI2OVxuICogY3VzdG9tICdyZXF1aXJlZCcgdmFsaWRhdG9yIGZvciBjb21wb25lbnRzLFxuICogYXMgdGhlIGJvdW5kIHZhbHVlcyBhcmUgcmVzb2x2ZWQgYXQgcnVudGltZVxuICogQ2FsbGVkIG9uICdyZXF1aXJlZCcgcHJvcGVydHkgY2hhbmdlXG4gKlxuICogTm90ZTogQ29tcG9uZW50IG5lZWRzIE5HX1ZBTElEQVRPUiBwcm92aWRlciBmb3IgdGhpcyB0byB3b3JrXG4gKi9cbmZ1bmN0aW9uIGlzVmFsaWRWYWx1ZSh2YWwpOiBCb29sZWFuIHtcbiAgICBzd2l0Y2godHlwZW9mIHZhbCkge1xuICAgICAgICBjYXNlICdvYmplY3QnOiByZXR1cm4gKCEhdmFsICYmICghIXZhbC5sZW5ndGggfHwgISFPYmplY3Qua2V5cyh2YWwpLmxlbmd0aCkpO1xuICAgICAgICBjYXNlICdudW1iZXInOiByZXR1cm4gKCEhdmFsIHx8IHZhbCA9PT0gMCk7XG4gICAgICAgICAgICBkZWZhdWx0OiByZXR1cm4gISh2YWwgPT09IHVuZGVmaW5lZCB8fCB2YWwgPT09IG51bGwgfHwgdmFsID09PSAnJyk7XG4gICAgfVxufVxuZnVuY3Rpb24gdmFsaWRhdGVSZXF1aXJlZEJpbmQocmVxdWlyZWQ6IGJvb2xlYW4pOiBWYWxpZGF0b3JGbiB7XG4gICAgcmV0dXJuIChjb250cm9sOiBBYnN0cmFjdENvbnRyb2wpID0+XG4gICAgICAgIHJlcXVpcmVkXG4gICAgICAgICAgICA/IChpc1ZhbGlkVmFsdWUoY29udHJvbC52YWx1ZSlcbiAgICAgICAgICAgICAgICA/IG51bGxcbiAgICAgICAgICAgICAgICA6IHsgcmVxdWlyZWQ6IHRydWUgfSlcbiAgICAgICAgICAgIDogbnVsbDtcbn1cblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEJhc2VGb3JtQ3VzdG9tQ29tcG9uZW50IGV4dGVuZHMgQmFzZUZvcm1Db21wb25lbnQgaW1wbGVtZW50cyBDb250cm9sVmFsdWVBY2Nlc3NvciwgT25Jbml0LCBWYWxpZGF0b3Ige1xuXG4gICAgcHJpdmF0ZSBfZm9ybUNvbnRyb2w6IEZvcm1Db250cm9sTmFtZTtcbiAgICBwcm90ZWN0ZWQgX29uQ2hhbmdlOiBhbnkgPSAoKSA9PiB7fTtcbiAgICBwcml2YXRlIF9vblRvdWNoZWQ6IGFueSA9ICgpID0+IHt9O1xuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIHN1cGVyLm5nT25Jbml0KCk7XG4gICAgICAgIHRoaXMuX2Zvcm1Db250cm9sID0gdGhpcy5pbmouZ2V0KEZvcm1Db250cm9sTmFtZSwgbnVsbCk7XG4gICAgfVxuXG4gICAgcHVibGljIHJlZ2lzdGVyT25DaGFuZ2UoZm4pIHtcbiAgICAgICAgdGhpcy5fb25DaGFuZ2UgPSBmbjtcbiAgICB9XG5cbiAgICBwdWJsaWMgcmVnaXN0ZXJPblRvdWNoZWQoZm4pIHtcbiAgICAgICAgdGhpcy5fb25Ub3VjaGVkID0gZm47XG4gICAgfVxuXG4gICAgcHVibGljIHdyaXRlVmFsdWUodmFsdWUpIHtcbiAgICAgICAgaWYgKHRoaXMuaXNEZXN0cm95ZWQpIHtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuICAgICAgICBpZiAodGhpcy5fZm9ybUNvbnRyb2wpIHtcblxuICAgICAgICAgICAgaWYodGhpcy5fZm9ybUNvbnRyb2wudmFsdWVBY2Nlc3NvcltcIndpZGdldFN1YlR5cGVcIl0uc3RhcnRzV2l0aCgnd20tY3VzdG9tLScpKVxuICAgICAgICAgICAgICAgIHJldHVybjtcblxuICAgICAgICAgICAgdGhpcy5kYXRhdmFsdWUgPSB2YWx1ZTtcbiAgICAgICAgICAgIHRoaXMub25Qcm9wZXJ0eUNoYW5nZSgnZGF0YXZhbHVlJywgdmFsdWUpO1xuICAgICAgICAgICAgdGhpcy51cGRhdGVQcmV2RGF0YXZhbHVlKHZhbHVlKTtcbiAgICAgICAgfVxuICAgICAgICAvKlxuICAgICAgICAgKiBXTVM6MTgyNDZcbiAgICAgICAgICogQ2FsbCBvbkNoYW5nZSBvbiBkZWZhdWx0IHZhbHVlLCBzbyB0aGF0IHRoZSBDb21wb25lbnQgTW9kZWwgaXMgdXBkYXRlZFxuICAgICAgICAgKiBEbyBvbmx5IFdoZW4gdGhlIE1vZGVsIFZhbHVlIGlzIGRpZmZlcmVudCBmcm9tIGRhdGF2YWx1ZVxuICAgICAgICAgKi9cbiAgICAgICAgKHZhbHVlIT09dGhpcy5kYXRhdmFsdWUpICYmIHRoaXMuX29uQ2hhbmdlKHRoaXMuZGF0YXZhbHVlKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0IGZvcm1Db250cm9sKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5fZm9ybUNvbnRyb2w7XG4gICAgfVxuXG4gICAgcHVibGljIGludm9rZU9uQ2hhbmdlKHZhbHVlLCAkZXZlbnQ/OiBFdmVudCB8IGFueSwgdmFsaWQ/OiBib29sZWFuKSB7XG4gICAgICAgIC8vIGxldCB0aGUgYW5ndWxhciBrbm93IGFib3V0IHRoZSBjaGFuZ2VcbiAgICAgICAgdGhpcy5fb25DaGFuZ2UodmFsdWUpO1xuICAgICAgICBpZiAoJGV2ZW50KSB7XG4gICAgICAgICAgICBzdXBlci5pbnZva2VPbkNoYW5nZSh2YWx1ZSwgJGV2ZW50KTtcbiAgICAgICAgfSBlbHNlIGlmICh2YWxpZCkge1xuICAgICAgICAgICAgLy8gRml4IGZvciBbV01TLTI0ODY5XTogdXBkYXRpbmcgUHJldkRhdGF2YWx1ZSB3aGVuIHRoZXJlIGlzIGEgZGVmYXVsdCB2YWx1ZSBmb3IgdGhlIHdpZGdldC5cbiAgICAgICAgICAgIHRoaXMudXBkYXRlUHJldkRhdGF2YWx1ZSh2YWx1ZSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwdWJsaWMgaW52b2tlT25Ub3VjaGVkKCRldmVudD86IEV2ZW50KSB7XG4gICAgICAgIHRoaXMuX29uVG91Y2hlZCgpO1xuXG4gICAgICAgIGlmICgkZXZlbnQpIHtcbiAgICAgICAgICAgIHRoaXMuaW52b2tlRXZlbnRDYWxsYmFjaygnYmx1cicsIHskZXZlbnR9KTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHB1YmxpYyBpbnZva2VPbkZvY3VzKCRldmVudDogRXZlbnQpIHtcbiAgICAgICAgdGhpcy5pbnZva2VFdmVudENhbGxiYWNrKCdmb2N1cycsIHskZXZlbnR9KTtcbiAgICB9XG4gICAgLyogV01TLTE4MjY5ICovXG4gICAgdmFsaWRhdGUoY29udHJvbDogQWJzdHJhY3RDb250cm9sKTp7W2tleTogc3RyaW5nXTphbnl9IHtcbiAgICAgICAgcmV0dXJuIHRoaXNbJ3Nob3cnXSA/IHZhbGlkYXRlUmVxdWlyZWRCaW5kKHRoaXNbJ3JlcXVpcmVkJ10pKGNvbnRyb2wpIDogbnVsbDtcbiAgICB9XG59XG4iXX0=
@@ -169,6 +169,8 @@ export class CheckboxsetComponent extends DatasetAwareFormComponent {
169
169
  }
170
170
  triggerInvokeOnChange(keys, $event) {
171
171
  this.modelByKey = keys;
172
+ if (this.viewParent.containerWidget)
173
+ this.viewParent.containerWidget.updateDataValue(this.datavalue);
172
174
  this.invokeOnTouched();
173
175
  // invoke on datavalue change.
174
176
  this.invokeOnChange(this.datavalue, $event || {}, true);
@@ -257,4 +259,4 @@ export class CheckboxsetComponent extends DatasetAwareFormComponent {
257
259
  args: ['keydown.enter', ['$event', '"ENTER"']]
258
260
  }] }); })();
259
261
  (() => { (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"]}
262
+ //# 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        if(this.viewParent.containerWidget)\n            this.viewParent.containerWidget.updateDataValue(this.datavalue);\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"]}
@@ -32,8 +32,8 @@ export class DatasetAwareFormComponent extends BaseFormCustomComponent {
32
32
  // invoke on datavalue change.
33
33
  this.invokeOnChange(val, undefined, true);
34
34
  }
35
- constructor(inj, config, explicitContext, groupby) {
36
- super(inj, config, explicitContext);
35
+ constructor(inj, config, explicitContext, groupby, initPromise) {
36
+ super(inj, config, explicitContext, initPromise);
37
37
  this.groupby = groupby;
38
38
  this.datasetItems = [];
39
39
  this.acceptsArray = false; // set to true if proxyModel on widget accepts array type.
@@ -285,7 +285,7 @@ export class DatasetAwareFormComponent extends BaseFormCustomComponent {
285
285
  this.cancelLocaleChangeSubscription();
286
286
  }
287
287
  }
288
- static { this.ɵfac = function DatasetAwareFormComponent_Factory(t) { return new (t || DatasetAwareFormComponent)(i0.ɵɵinject(i0.Injector), i0.ɵɵinject(WidgetConfig), i0.ɵɵinject('EXPLICIT_CONTEXT', 8), i0.ɵɵinjectAttribute('groupby')); }; }
288
+ static { this.ɵfac = function DatasetAwareFormComponent_Factory(t) { return new (t || DatasetAwareFormComponent)(i0.ɵɵinject(i0.Injector), i0.ɵɵinject(WidgetConfig), i0.ɵɵinject('EXPLICIT_CONTEXT', 8), i0.ɵɵinjectAttribute('groupby'), i0.ɵɵinject(Promise)); }; }
289
289
  static { this.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: DatasetAwareFormComponent, factory: DatasetAwareFormComponent.ɵfac }); }
290
290
  }
291
291
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DatasetAwareFormComponent, [{
@@ -301,5 +301,5 @@ export class DatasetAwareFormComponent extends BaseFormCustomComponent {
301
301
  }] }, { type: undefined, decorators: [{
302
302
  type: Attribute,
303
303
  args: ['groupby']
304
- }] }], null); })();
305
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dataset-aware-form.component.js","sourceRoot":"","sources":["../../../../../projects/components/widgets/input/default/src/dataset-aware-form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Attribute, Inject, Injectable, Injector, OnDestroy, OnInit, Optional} from '@angular/core';\nimport {Subject} from 'rxjs';\nimport {$appDigest, AppDefaults, debounce, isDefined, isEqualWithFields, noop, toBoolean} from '@wm/core';\nimport { ALLFIELDS, convertDataToObject, DataSetItem, extractDataAsArray, getOrderedDataset, getUniqObjsByDataField, handleHeaderClick, toggleAllHeaders, transformFormData, transformDataWithKeys, groupData, ToDatePipe, IWidgetConfig, WidgetConfig } from '@wm/components/base';\nimport { BaseFormCustomComponent } from './base-form-custom.component';\nimport {debounce as _debounce, find, isArray, isEmpty, isEqual, isNull, isObject, toString} from \"lodash-es\";\n\n@Injectable()\nexport abstract class DatasetAwareFormComponent extends BaseFormCustomComponent implements OnInit, OnDestroy {\n    public dataset: any;\n    public datafield: string;\n    public displayfield: string;\n    public displaylabel: string;\n    public displayimagesrc: string;\n    public displayexpression: string;\n    public usekeys: boolean;\n    public orderby: string;\n    public multiple: boolean;\n    public readonly: boolean;\n    public content: string;\n    public collapsible: boolean;\n    public datePipe;\n\n    public handleHeaderClick: ($event) => void;\n    private toggleAllHeaders: void;\n    public appDefaults;\n\n    public binddisplayexpression: string;\n    public binddisplayimagesrc: string;\n    public binddisplaylabel: string;\n\n    public displayValue: Array<string> | string;\n\n    public datasetItems: DataSetItem[] = [];\n    public acceptsArray = false; // set to true if proxyModel on widget accepts array type.\n    protected dataset$ = new Subject();\n    protected datavalue$ = new Subject();\n\n    protected match: string;\n    protected dateformat: string;\n    public groupedData: any[];\n\n    protected _modelByKey: any;\n    public _modelByValue: any;\n    public _defaultQueryInvoked: boolean; // for search/chips if datavalue is obtained from the default n/w call then set to true and do not update the modelByKeys.\n\n    // this field contains the initial datavalue which needs to be processed once the dataset is available\n    public toBeProcessedDatavalue: any;\n    private readonly _debouncedInitDatasetItems: Function;\n    protected allowempty = true;\n    public compareby: any;\n\n    private cancelLocaleChangeSubscription;\n\n    public get modelByKey() {\n        return this._modelByKey;\n    }\n\n    // triggers on ngModel change. This function extracts the datavalue value.\n    public set modelByKey(val: any) {\n        this.selectByKey(val);\n\n        // invoke on datavalue change.\n        this.invokeOnChange(this._modelByValue);\n    }\n\n    // @ts-ignore\n    public get datavalue() {\n        return this._modelByValue;\n    }\n\n    // triggers on setting the datavalue. This function extracts the model value.\n    // @ts-ignore\n    public set datavalue(val: any) {\n        if (this.multiple) {\n            val = extractDataAsArray(val);\n        }\n        this._modelByValue = val;\n\n        this.selectByValue(val);\n\n        // changes on the datavalue can be subscribed using listenToDatavalue\n        this.datavalue$.next(val);\n\n        // invoke on datavalue change.\n        this.invokeOnChange(val, undefined, true);\n    }\n\n    protected constructor(inj: Injector,  @Inject(WidgetConfig) config: IWidgetConfig,\n                          @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any, @Attribute('groupby') public groupby?: string) {\n        super(inj, config, explicitContext);\n        this.datePipe = this.inj.get(ToDatePipe);\n        this.appDefaults = this.inj.get(AppDefaults);\n        this.binddisplayexpression = this.nativeElement.getAttribute('displayexpression.bind');\n        this.binddisplayimagesrc = this.nativeElement.getAttribute('displayimagesrc.bind');\n        this.binddisplaylabel = this.nativeElement.getAttribute('displaylabel.bind');\n\n        this._debouncedInitDatasetItems = debounce(() => {\n            this.initDatasetItems();\n            $appDigest();\n        }, 150);\n        this.handleHeaderClick = noop;\n\n        this.cancelLocaleChangeSubscription = this.getAppInstance().subscribe(\"locale-changed\", () => {\n            this._debouncedInitDatasetItems();\n        });\n    }\n\n    /**\n     * This function sets the _datavalue value from the model and sets the selected flag when item is found.\n     * Here model is the value obtained from ngModel.\n     * @param keys represent the model.\n     */\n    protected selectByKey(keys) {\n        this.resetDatasetItems();\n\n        if (!this.datasetItems.length) {\n            return;\n        }\n\n        if (this.multiple && !isArray(keys)) {\n            keys = [keys];\n        }\n\n        // Set the _modelByKey to the modified keys.\n        this._modelByKey = keys;\n\n        if (this.multiple) {\n            this._modelByValue = [];\n            keys.forEach(key => {\n                const itemByKey = find(this.datasetItems, item => {\n                    // not triple equal, as the instance type can be different.\n                    // only value comparison should be done.\n                    return toString(item.key) === toString(key);\n                });\n                if (itemByKey) {\n                    itemByKey.selected = true;\n                    this._modelByValue = [...this._modelByValue, itemByKey.value];\n                }\n            });\n        } else {\n            this._modelByValue = '';\n            const itemByKey = find(this.datasetItems, item => {\n                // not triple equal, as the instance type can be different.\n                // only value comparison should be done.\n                return toString(item.key) === toString(keys);\n            });\n            if (itemByKey) {\n                itemByKey.selected = true;\n                this._modelByValue = itemByKey.value;\n            }\n        }\n        this.initDisplayValues();\n    }\n\n    /**\n     * This function sets the _model value from the datavalue (selectedvalues) and sets the selected flag when item is found.\n     * datavalue is the default value or a value representing the displayField (for suppose: object in case of ALLFIELDS).\n     * If acceptsArray is true, the model always accepts an array.\n     * For example, select always accepts model as array whether multiple select is true or false.\n     * @param values represent the datavalue.\n     */\n    protected selectByValue(values: Array<any> | any) {\n        this.resetDatasetItems();\n\n        // if datavalue is not defined or empty then set the model as undefined.\n        if (!isDefined(values) || values === '' || isNull(values) || (values instanceof Array && !values.length)) {\n            this._modelByKey = undefined;\n            // do not return when allowempty is set to true.\n            if (!this.allowempty || !isDefined(values)) {\n                return;\n            }\n        }\n\n        if (this.acceptsArray && !isArray(values)) {\n            values = this.allowempty ? [values] : extractDataAsArray(values);\n        }\n\n        // preserve the datavalue if datasetItems are empty.\n        if (!this.datasetItems.length && isDefined(values)) {\n            this.toBeProcessedDatavalue = values;\n            return;\n        }\n\n        const filterField = this.datafield === ALLFIELDS ? 'dataObject' : 'key';\n\n        if (isArray(values)) {\n            this._modelByKey = [];\n            values.forEach(val => {\n                const itemByValue = find(this.datasetItems, item => {\n                    if (filterField === 'dataObject') {\n                        if (this.compareby && this.compareby.length) {\n                            return isEqualWithFields(item[filterField], val, this.compareby);\n                        }\n                    }\n                    return (isObject(item.value) ? isEqual(item.value, val) : (toString(item.value)).toLowerCase() === (toString(val)).toLowerCase());\n                });\n                if (itemByValue) {\n                    itemByValue.selected = true;\n                    this._modelByKey.push(itemByValue.key);\n                }\n            });\n        } else {\n            this._modelByKey = undefined;\n            const itemByValue = find(this.datasetItems, item => {\n                if (filterField === 'dataObject') {\n                    if (this.compareby && this.compareby.length) {\n                        return isEqualWithFields(item[filterField], values, this.compareby);\n                    }\n                }\n                return (isObject(item.value) ? isEqual(item.value, values) : (toString(item.value)).toLowerCase() === (toString(values)).toLowerCase());\n            });\n            if (itemByValue) {\n                itemByValue.selected = true;\n                this._modelByKey = itemByValue.key;\n            }\n        }\n        // delaying the datavalue update as the widgets in liveform are having datavalue as undefined and not the default provided value\n        // because datavalue is updated later when new dataset is available.\n        this._debounceDatavalueUpdation(values);\n    }\n\n    protected readonly _debounceDatavalueUpdation = _debounce((values) => {\n        // if no item is found in datasetItems, wait untill the dataset updates by preserving the datavalue in toBeProcessedDatavalue.\n        if (!isDefined(this._modelByKey) || (isArray(this._modelByKey) && !this._modelByKey.length)) {\n            this.toBeProcessedDatavalue = values;\n            this._modelByValue = '';\n        } else if (isDefined(this.toBeProcessedDatavalue)) {\n            // obtain the first array value when multiple is set to false.\n            // set the modelByValue only when undefined.\n            if (!isDefined(this._modelByValue)) {\n                this._modelByValue = (!this.multiple && isArray(this.toBeProcessedDatavalue)) ? this.toBeProcessedDatavalue[0] : this.toBeProcessedDatavalue;\n            }\n            this.toBeProcessedDatavalue = undefined;\n        }\n\n        this.initDisplayValues();\n    }, 150);\n\n    // Updates the displayValue property.\n    protected initDisplayValues() {\n        const displayValues = [];\n        this.datasetItems.forEach(item => {\n            if (item.selected) {\n                displayValues.push(item.label);\n            }\n        });\n\n        this.displayValue = this.multiple ? displayValues : displayValues[0] || '';\n    }\n\n    // This function parses the dataset and extracts the displayOptions from parsed dataset.\n    protected initDatasetItems() {\n        if (!this.dataset || isEmpty(this.dataset)) {\n            this.datasetItems = [];\n            // notify the dataset listeners\n            this.dataset$.next(this.datasetItems);\n            return;\n        }\n\n        // convert any dataset to the object format.\n        const orderedDataset = getOrderedDataset(convertDataToObject(this.dataset), this.orderby);\n\n        if (this.usekeys) {\n            this.datasetItems = transformDataWithKeys(orderedDataset);\n        } else {\n            const displayOptions = transformFormData(this.viewParent, orderedDataset, this.datafield, {\n                displayField: this.displayfield || this.displaylabel,\n                displayExpr: this.displayexpression,\n                bindDisplayExpr: this.binddisplayexpression || this.binddisplaylabel,\n                bindDisplayImgSrc: this.binddisplayimagesrc,\n                displayImgSrc: this.displayimagesrc\n            });\n            // get the unique objects out of the extracted data. Notify change in datasetItems using [...datasetItems] notation\n            this.datasetItems = [...getUniqObjsByDataField(displayOptions, this.datafield, this.displayfield || this.displaylabel, toBoolean(this.allowempty))];\n        }\n\n        this.postDatasetItemsInit();\n    }\n\n    // Once the datasetItems are ready, set the proxyModel by using datavalue.\n    protected postDatasetItemsInit() {\n        if (this.datasetItems.length && !this._defaultQueryInvoked) {\n            // use the latest of toBeProcessedDatavalue, datavalue\n            const _datavalue = isEmpty(this.toBeProcessedDatavalue) ? this.datavalue : this.toBeProcessedDatavalue;\n            this.selectByValue(_datavalue);\n        }\n        // notify the dataset listeners\n        this.dataset$.next(this.datasetItems);\n    }\n\n    // Reset the selected flag on datasetItems to false.\n    protected resetDatasetItems() {\n        this.datasetItems.forEach(item => item.selected = false);\n    }\n\n    protected setTemplate(partialName) {\n        this.content = partialName;\n        if (this.viewParent && this.viewParent.prefabName) {\n            this['prefabName'] = this.viewParent.prefabName;\n        }\n    }\n\n\n    private getGroupedData() {\n        return this.datasetItems.length ? groupData(this, convertDataToObject(this.datasetItems), this.groupby, this.match, this.orderby, this.dateformat, this.datePipe, 'dataObject', this.appDefaults) : [];\n    }\n\n    private datasetSubscription() {\n        const datasetSubscription = this.dataset$.subscribe(() => {\n            this.groupedData = this.getGroupedData();\n        });\n        this.registerDestroyListener(() => datasetSubscription.unsubscribe());\n    }\n\n    protected setGroupData() {\n        this.datasetSubscription();\n        // If groupby is set, get the groupedData from the datasetItems.\n        this.groupedData = this.getGroupedData();\n    }\n\n\n    onPropertyChange(key: string, nv: any, ov?: any) {\n        super.onPropertyChange(key, nv, ov);\n        switch (key) {\n            case 'dataset':\n            case 'datafield':\n            case 'displayfield':\n            case 'displaylabel':\n            case 'displayexpression':\n            case 'orderby':\n            case 'usekeys':\n                this._debouncedInitDatasetItems();\n                break;\n            case 'required':\n            case 'datavalue':\n                this._onChange(this.datavalue);\n                break;\n            case 'groupby':\n            case 'match':\n                if (this.widgetType !== 'wm-search' && this.widgetType !== 'wm-chips') {\n                    this.setGroupData();\n                }\n            break;\n        }\n    }\n\n    ngOnInit() {\n        super.ngOnInit();\n        if (this.groupby && (this.widgetType !== 'wm-search' && this.widgetType !== 'wm-chips')) {\n            this.setGroupData();\n        }\n        // adding the handler for header click and toggle headers.\n        if (this.groupby && this.collapsible) {\n            this.handleHeaderClick = handleHeaderClick;\n            this.toggleAllHeaders = toggleAllHeaders.bind(undefined, this);\n        }\n    }\n\n    ngOnDestroy() {\n        if(this.cancelLocaleChangeSubscription) {\n            this.cancelLocaleChangeSubscription();\n        }\n    }\n}\n"]}
304
+ }] }, { type: Promise }], null); })();
305
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dataset-aware-form.component.js","sourceRoot":"","sources":["../../../../../projects/components/widgets/input/default/src/dataset-aware-form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Attribute, Inject, Injectable, Injector, OnDestroy, OnInit, Optional} from '@angular/core';\nimport {Subject} from 'rxjs';\nimport {$appDigest, AppDefaults, debounce, isDefined, isEqualWithFields, noop, toBoolean} from '@wm/core';\nimport { ALLFIELDS, convertDataToObject, DataSetItem, extractDataAsArray, getOrderedDataset, getUniqObjsByDataField, handleHeaderClick, toggleAllHeaders, transformFormData, transformDataWithKeys, groupData, ToDatePipe, IWidgetConfig, WidgetConfig } from '@wm/components/base';\nimport { BaseFormCustomComponent } from './base-form-custom.component';\nimport {debounce as _debounce, find, isArray, isEmpty, isEqual, isNull, isObject, toString} from \"lodash-es\";\n\n@Injectable()\nexport abstract class DatasetAwareFormComponent extends BaseFormCustomComponent implements OnInit, OnDestroy {\n    public dataset: any;\n    public datafield: string;\n    public displayfield: string;\n    public displaylabel: string;\n    public displayimagesrc: string;\n    public displayexpression: string;\n    public usekeys: boolean;\n    public orderby: string;\n    public multiple: boolean;\n    public readonly: boolean;\n    public content: string;\n    public collapsible: boolean;\n    public datePipe;\n\n    public handleHeaderClick: ($event) => void;\n    private toggleAllHeaders: void;\n    public appDefaults;\n\n    public binddisplayexpression: string;\n    public binddisplayimagesrc: string;\n    public binddisplaylabel: string;\n\n    public displayValue: Array<string> | string;\n\n    public datasetItems: DataSetItem[] = [];\n    public acceptsArray = false; // set to true if proxyModel on widget accepts array type.\n    protected dataset$ = new Subject();\n    protected datavalue$ = new Subject();\n\n    protected match: string;\n    protected dateformat: string;\n    public groupedData: any[];\n\n    protected _modelByKey: any;\n    public _modelByValue: any;\n    public _defaultQueryInvoked: boolean; // for search/chips if datavalue is obtained from the default n/w call then set to true and do not update the modelByKeys.\n\n    // this field contains the initial datavalue which needs to be processed once the dataset is available\n    public toBeProcessedDatavalue: any;\n    private readonly _debouncedInitDatasetItems: Function;\n    protected allowempty = true;\n    public compareby: any;\n\n    private cancelLocaleChangeSubscription;\n\n    public get modelByKey() {\n        return this._modelByKey;\n    }\n\n    // triggers on ngModel change. This function extracts the datavalue value.\n    public set modelByKey(val: any) {\n        this.selectByKey(val);\n\n        // invoke on datavalue change.\n        this.invokeOnChange(this._modelByValue);\n    }\n\n    // @ts-ignore\n    public get datavalue() {\n        return this._modelByValue;\n    }\n\n    // triggers on setting the datavalue. This function extracts the model value.\n    // @ts-ignore\n    public set datavalue(val: any) {\n        if (this.multiple) {\n            val = extractDataAsArray(val);\n        }\n        this._modelByValue = val;\n\n        this.selectByValue(val);\n\n        // changes on the datavalue can be subscribed using listenToDatavalue\n        this.datavalue$.next(val);\n\n        // invoke on datavalue change.\n        this.invokeOnChange(val, undefined, true);\n    }\n\n    protected constructor(inj: Injector,  @Inject(WidgetConfig) config: IWidgetConfig,\n                          @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any,\n                          @Attribute('groupby') public groupby?: string, initPromise?: Promise<any>) {\n        super(inj, config, explicitContext, initPromise);\n        this.datePipe = this.inj.get(ToDatePipe);\n        this.appDefaults = this.inj.get(AppDefaults);\n        this.binddisplayexpression = this.nativeElement.getAttribute('displayexpression.bind');\n        this.binddisplayimagesrc = this.nativeElement.getAttribute('displayimagesrc.bind');\n        this.binddisplaylabel = this.nativeElement.getAttribute('displaylabel.bind');\n\n        this._debouncedInitDatasetItems = debounce(() => {\n            this.initDatasetItems();\n            $appDigest();\n        }, 150);\n        this.handleHeaderClick = noop;\n\n        this.cancelLocaleChangeSubscription = this.getAppInstance().subscribe(\"locale-changed\", () => {\n            this._debouncedInitDatasetItems();\n        });\n    }\n\n    /**\n     * This function sets the _datavalue value from the model and sets the selected flag when item is found.\n     * Here model is the value obtained from ngModel.\n     * @param keys represent the model.\n     */\n    protected selectByKey(keys) {\n        this.resetDatasetItems();\n\n        if (!this.datasetItems.length) {\n            return;\n        }\n\n        if (this.multiple && !isArray(keys)) {\n            keys = [keys];\n        }\n\n        // Set the _modelByKey to the modified keys.\n        this._modelByKey = keys;\n\n        if (this.multiple) {\n            this._modelByValue = [];\n            keys.forEach(key => {\n                const itemByKey = find(this.datasetItems, item => {\n                    // not triple equal, as the instance type can be different.\n                    // only value comparison should be done.\n                    return toString(item.key) === toString(key);\n                });\n                if (itemByKey) {\n                    itemByKey.selected = true;\n                    this._modelByValue = [...this._modelByValue, itemByKey.value];\n                }\n            });\n        } else {\n            this._modelByValue = '';\n            const itemByKey = find(this.datasetItems, item => {\n                // not triple equal, as the instance type can be different.\n                // only value comparison should be done.\n                return toString(item.key) === toString(keys);\n            });\n            if (itemByKey) {\n                itemByKey.selected = true;\n                this._modelByValue = itemByKey.value;\n            }\n        }\n        this.initDisplayValues();\n    }\n\n    /**\n     * This function sets the _model value from the datavalue (selectedvalues) and sets the selected flag when item is found.\n     * datavalue is the default value or a value representing the displayField (for suppose: object in case of ALLFIELDS).\n     * If acceptsArray is true, the model always accepts an array.\n     * For example, select always accepts model as array whether multiple select is true or false.\n     * @param values represent the datavalue.\n     */\n    protected selectByValue(values: Array<any> | any) {\n        this.resetDatasetItems();\n\n        // if datavalue is not defined or empty then set the model as undefined.\n        if (!isDefined(values) || values === '' || isNull(values) || (values instanceof Array && !values.length)) {\n            this._modelByKey = undefined;\n            // do not return when allowempty is set to true.\n            if (!this.allowempty || !isDefined(values)) {\n                return;\n            }\n        }\n\n        if (this.acceptsArray && !isArray(values)) {\n            values = this.allowempty ? [values] : extractDataAsArray(values);\n        }\n\n        // preserve the datavalue if datasetItems are empty.\n        if (!this.datasetItems.length && isDefined(values)) {\n            this.toBeProcessedDatavalue = values;\n            return;\n        }\n\n        const filterField = this.datafield === ALLFIELDS ? 'dataObject' : 'key';\n\n        if (isArray(values)) {\n            this._modelByKey = [];\n            values.forEach(val => {\n                const itemByValue = find(this.datasetItems, item => {\n                    if (filterField === 'dataObject') {\n                        if (this.compareby && this.compareby.length) {\n                            return isEqualWithFields(item[filterField], val, this.compareby);\n                        }\n                    }\n                    return (isObject(item.value) ? isEqual(item.value, val) : (toString(item.value)).toLowerCase() === (toString(val)).toLowerCase());\n                });\n                if (itemByValue) {\n                    itemByValue.selected = true;\n                    this._modelByKey.push(itemByValue.key);\n                }\n            });\n        } else {\n            this._modelByKey = undefined;\n            const itemByValue = find(this.datasetItems, item => {\n                if (filterField === 'dataObject') {\n                    if (this.compareby && this.compareby.length) {\n                        return isEqualWithFields(item[filterField], values, this.compareby);\n                    }\n                }\n                return (isObject(item.value) ? isEqual(item.value, values) : (toString(item.value)).toLowerCase() === (toString(values)).toLowerCase());\n            });\n            if (itemByValue) {\n                itemByValue.selected = true;\n                this._modelByKey = itemByValue.key;\n            }\n        }\n        // delaying the datavalue update as the widgets in liveform are having datavalue as undefined and not the default provided value\n        // because datavalue is updated later when new dataset is available.\n        this._debounceDatavalueUpdation(values);\n    }\n\n    protected readonly _debounceDatavalueUpdation = _debounce((values) => {\n        // if no item is found in datasetItems, wait untill the dataset updates by preserving the datavalue in toBeProcessedDatavalue.\n        if (!isDefined(this._modelByKey) || (isArray(this._modelByKey) && !this._modelByKey.length)) {\n            this.toBeProcessedDatavalue = values;\n            this._modelByValue = '';\n        } else if (isDefined(this.toBeProcessedDatavalue)) {\n            // obtain the first array value when multiple is set to false.\n            // set the modelByValue only when undefined.\n            if (!isDefined(this._modelByValue)) {\n                this._modelByValue = (!this.multiple && isArray(this.toBeProcessedDatavalue)) ? this.toBeProcessedDatavalue[0] : this.toBeProcessedDatavalue;\n            }\n            this.toBeProcessedDatavalue = undefined;\n        }\n\n        this.initDisplayValues();\n    }, 150);\n\n    // Updates the displayValue property.\n    protected initDisplayValues() {\n        const displayValues = [];\n        this.datasetItems.forEach(item => {\n            if (item.selected) {\n                displayValues.push(item.label);\n            }\n        });\n\n        this.displayValue = this.multiple ? displayValues : displayValues[0] || '';\n    }\n\n    // This function parses the dataset and extracts the displayOptions from parsed dataset.\n    protected initDatasetItems() {\n        if (!this.dataset || isEmpty(this.dataset)) {\n            this.datasetItems = [];\n            // notify the dataset listeners\n            this.dataset$.next(this.datasetItems);\n            return;\n        }\n\n        // convert any dataset to the object format.\n        const orderedDataset = getOrderedDataset(convertDataToObject(this.dataset), this.orderby);\n\n        if (this.usekeys) {\n            this.datasetItems = transformDataWithKeys(orderedDataset);\n        } else {\n            const displayOptions = transformFormData(this.viewParent, orderedDataset, this.datafield, {\n                displayField: this.displayfield || this.displaylabel,\n                displayExpr: this.displayexpression,\n                bindDisplayExpr: this.binddisplayexpression || this.binddisplaylabel,\n                bindDisplayImgSrc: this.binddisplayimagesrc,\n                displayImgSrc: this.displayimagesrc\n            });\n            // get the unique objects out of the extracted data. Notify change in datasetItems using [...datasetItems] notation\n            this.datasetItems = [...getUniqObjsByDataField(displayOptions, this.datafield, this.displayfield || this.displaylabel, toBoolean(this.allowempty))];\n        }\n\n        this.postDatasetItemsInit();\n    }\n\n    // Once the datasetItems are ready, set the proxyModel by using datavalue.\n    protected postDatasetItemsInit() {\n        if (this.datasetItems.length && !this._defaultQueryInvoked) {\n            // use the latest of toBeProcessedDatavalue, datavalue\n            const _datavalue = isEmpty(this.toBeProcessedDatavalue) ? this.datavalue : this.toBeProcessedDatavalue;\n            this.selectByValue(_datavalue);\n        }\n        // notify the dataset listeners\n        this.dataset$.next(this.datasetItems);\n    }\n\n    // Reset the selected flag on datasetItems to false.\n    protected resetDatasetItems() {\n        this.datasetItems.forEach(item => item.selected = false);\n    }\n\n    protected setTemplate(partialName) {\n        this.content = partialName;\n        if (this.viewParent && this.viewParent.prefabName) {\n            this['prefabName'] = this.viewParent.prefabName;\n        }\n    }\n\n\n    private getGroupedData() {\n        return this.datasetItems.length ? groupData(this, convertDataToObject(this.datasetItems), this.groupby, this.match, this.orderby, this.dateformat, this.datePipe, 'dataObject', this.appDefaults) : [];\n    }\n\n    private datasetSubscription() {\n        const datasetSubscription = this.dataset$.subscribe(() => {\n            this.groupedData = this.getGroupedData();\n        });\n        this.registerDestroyListener(() => datasetSubscription.unsubscribe());\n    }\n\n    protected setGroupData() {\n        this.datasetSubscription();\n        // If groupby is set, get the groupedData from the datasetItems.\n        this.groupedData = this.getGroupedData();\n    }\n\n\n    onPropertyChange(key: string, nv: any, ov?: any) {\n        super.onPropertyChange(key, nv, ov);\n        switch (key) {\n            case 'dataset':\n            case 'datafield':\n            case 'displayfield':\n            case 'displaylabel':\n            case 'displayexpression':\n            case 'orderby':\n            case 'usekeys':\n                this._debouncedInitDatasetItems();\n                break;\n            case 'required':\n            case 'datavalue':\n                this._onChange(this.datavalue);\n                break;\n            case 'groupby':\n            case 'match':\n                if (this.widgetType !== 'wm-search' && this.widgetType !== 'wm-chips') {\n                    this.setGroupData();\n                }\n            break;\n        }\n    }\n\n    ngOnInit() {\n        super.ngOnInit();\n        if (this.groupby && (this.widgetType !== 'wm-search' && this.widgetType !== 'wm-chips')) {\n            this.setGroupData();\n        }\n        // adding the handler for header click and toggle headers.\n        if (this.groupby && this.collapsible) {\n            this.handleHeaderClick = handleHeaderClick;\n            this.toggleAllHeaders = toggleAllHeaders.bind(undefined, this);\n        }\n    }\n\n    ngOnDestroy() {\n        if(this.cancelLocaleChangeSubscription) {\n            this.cancelLocaleChangeSubscription();\n        }\n    }\n}\n"]}
@@ -169,6 +169,8 @@ export class RadiosetComponent extends DatasetAwareFormComponent {
169
169
  }
170
170
  triggerInvokeOnChange(key, $event) {
171
171
  this.modelByKey = key;
172
+ if (this.viewParent.containerWidget)
173
+ this.viewParent.containerWidget.updateDataValue(this.datavalue);
172
174
  this.invokeOnTouched();
173
175
  // invoke on datavalue change.
174
176
  this.invokeOnChange(this.datavalue, $event || {}, true);
@@ -240,4 +242,4 @@ export class RadiosetComponent extends DatasetAwareFormComponent {
240
242
  type: Optional
241
243
  }] }], null); })();
242
244
  (() => { (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"]}
245
+ //# 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        if(this.viewParent.containerWidget)\n            this.viewParent.containerWidget.updateDataValue(this.datavalue);\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"]}
@@ -317,6 +317,8 @@ class BaseFormCustomComponent extends BaseFormComponent {
317
317
  return;
318
318
  }
319
319
  if (this._formControl) {
320
+ if (this._formControl.valueAccessor["widgetSubType"].startsWith('wm-custom-'))
321
+ return;
320
322
  this.datavalue = value;
321
323
  this.onPropertyChange('datavalue', value);
322
324
  this.updatePrevDatavalue(value);
@@ -328,6 +330,9 @@ class BaseFormCustomComponent extends BaseFormComponent {
328
330
  */
329
331
  (value !== this.datavalue) && this._onChange(this.datavalue);
330
332
  }
333
+ get formControl() {
334
+ return this._formControl;
335
+ }
331
336
  invokeOnChange(value, $event, valid) {
332
337
  // let the angular know about the change
333
338
  this._onChange(value);
@@ -577,8 +582,8 @@ class DatasetAwareFormComponent extends BaseFormCustomComponent {
577
582
  // invoke on datavalue change.
578
583
  this.invokeOnChange(val, undefined, true);
579
584
  }
580
- constructor(inj, config, explicitContext, groupby) {
581
- super(inj, config, explicitContext);
585
+ constructor(inj, config, explicitContext, groupby, initPromise) {
586
+ super(inj, config, explicitContext, initPromise);
582
587
  this.groupby = groupby;
583
588
  this.datasetItems = [];
584
589
  this.acceptsArray = false; // set to true if proxyModel on widget accepts array type.
@@ -830,7 +835,7 @@ class DatasetAwareFormComponent extends BaseFormCustomComponent {
830
835
  this.cancelLocaleChangeSubscription();
831
836
  }
832
837
  }
833
- static { this.ɵfac = function DatasetAwareFormComponent_Factory(t) { return new (t || DatasetAwareFormComponent)(i0.ɵɵinject(i0.Injector), i0.ɵɵinject(WidgetConfig), i0.ɵɵinject('EXPLICIT_CONTEXT', 8), i0.ɵɵinjectAttribute('groupby')); }; }
838
+ static { this.ɵfac = function DatasetAwareFormComponent_Factory(t) { return new (t || DatasetAwareFormComponent)(i0.ɵɵinject(i0.Injector), i0.ɵɵinject(WidgetConfig), i0.ɵɵinject('EXPLICIT_CONTEXT', 8), i0.ɵɵinjectAttribute('groupby'), i0.ɵɵinject(Promise)); }; }
834
839
  static { this.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: DatasetAwareFormComponent, factory: DatasetAwareFormComponent.ɵfac }); }
835
840
  }
836
841
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DatasetAwareFormComponent, [{
@@ -846,7 +851,7 @@ class DatasetAwareFormComponent extends BaseFormCustomComponent {
846
851
  }] }, { type: undefined, decorators: [{
847
852
  type: Attribute,
848
853
  args: ['groupby']
849
- }] }], null); })();
854
+ }] }, { type: Promise }], null); })();
850
855
 
851
856
  const checkboxsetProps = new Map([
852
857
  ['class', PROP_STRING],
@@ -1042,6 +1047,8 @@ class CheckboxsetComponent extends DatasetAwareFormComponent {
1042
1047
  }
1043
1048
  triggerInvokeOnChange(keys, $event) {
1044
1049
  this.modelByKey = keys;
1050
+ if (this.viewParent.containerWidget)
1051
+ this.viewParent.containerWidget.updateDataValue(this.datavalue);
1045
1052
  this.invokeOnTouched();
1046
1053
  // invoke on datavalue change.
1047
1054
  this.invokeOnChange(this.datavalue, $event || {}, true);
@@ -2028,6 +2035,8 @@ class RadiosetComponent extends DatasetAwareFormComponent {
2028
2035
  }
2029
2036
  triggerInvokeOnChange(key, $event) {
2030
2037
  this.modelByKey = key;
2038
+ if (this.viewParent.containerWidget)
2039
+ this.viewParent.containerWidget.updateDataValue(this.datavalue);
2031
2040
  this.invokeOnTouched();
2032
2041
  // invoke on datavalue change.
2033
2042
  this.invokeOnChange(this.datavalue, $event || {}, true);