@mediusinc/mng-commons 5.0.0-rc.2 → 5.0.0-rc.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (204) hide show
  1. package/core/data-providers/base-data-provider.factory.d.ts +13 -0
  2. package/core/data-providers/base.data-provider.d.ts +2 -14
  3. package/core/descriptors/editor.descriptor.d.ts +1 -1
  4. package/core/descriptors/tableview.descriptor.d.ts +5 -5
  5. package/core/directives/component.directive.d.ts +2 -2
  6. package/core/index.d.ts +1 -0
  7. package/core/security/permission.service.d.ts +1 -0
  8. package/core/services/commons-router.service.d.ts +3 -3
  9. package/core/services/commons.service.d.ts +31 -42
  10. package/core/services/tokens/module-config.token.d.ts +2 -2
  11. package/esm2022/core/components/notification/notification-wrapper.component.mjs +3 -3
  12. package/esm2022/core/components/pages/error/error.page.component.mjs +3 -3
  13. package/esm2022/core/components/pages/not-found/not-found.page.component.mjs +3 -3
  14. package/esm2022/core/data-providers/base-data-provider.factory.mjs +28 -0
  15. package/esm2022/core/data-providers/base.data-provider.mjs +1 -31
  16. package/esm2022/core/descriptors/editor.descriptor.mjs +1 -1
  17. package/esm2022/core/descriptors/tableview.descriptor.mjs +1 -1
  18. package/esm2022/core/directives/component.directive.mjs +10 -7
  19. package/esm2022/core/index.mjs +2 -1
  20. package/esm2022/core/security/permission.service.mjs +4 -2
  21. package/esm2022/core/services/commons-init.service.mjs +2 -2
  22. package/esm2022/core/services/commons-router.service.mjs +16 -15
  23. package/esm2022/core/services/commons.service.mjs +109 -166
  24. package/esm2022/core/services/tokens/module-config.token.mjs +1 -1
  25. package/esm2022/filter/descriptors/filter-lookup.descriptor.mjs +4 -4
  26. package/esm2022/form/api/data-providers/lookup-data-provider.factory.mjs +31 -0
  27. package/esm2022/form/api/data-providers/lookup.data-provider.mjs +1 -31
  28. package/esm2022/form/api/index.mjs +2 -1
  29. package/esm2022/form/components/autocomplete/autocomplete.component.mjs +92 -83
  30. package/esm2022/form/components/dropdown/dropdown.component.mjs +145 -87
  31. package/esm2022/model/data-providers/base-from-type-data-provider.factory.mjs +8 -0
  32. package/esm2022/model/descriptors/enum.descriptor.mjs +3 -6
  33. package/esm2022/model/descriptors/model.descriptor.mjs +22 -9
  34. package/esm2022/model/descriptors/type.descriptor.mjs +3 -9
  35. package/esm2022/model/index.mjs +3 -1
  36. package/esm2022/table/api/data-providers/table-data-provider.factory.mjs +33 -0
  37. package/esm2022/table/api/data-providers/table.data-provider.mjs +1 -31
  38. package/esm2022/table/api/descriptors/sort.descriptor.mjs +2 -2
  39. package/esm2022/table/api/descriptors/table-descriptor.factory.mjs +89 -0
  40. package/esm2022/table/api/descriptors/table.descriptor.mjs +4 -139
  41. package/esm2022/table/api/helpers/table-descriptor-helpers.mjs +97 -0
  42. package/esm2022/table/api/index.mjs +4 -1
  43. package/esm2022/table/components/column-filter-full/column-filter-full.component.mjs +6 -7
  44. package/esm2022/table/components/column-value/column-value.component.mjs +2 -2
  45. package/esm2022/table/components/table/table.component.mjs +5 -5
  46. package/esm2022/table/pipes/locale-default-row-class.pipe.mjs +2 -2
  47. package/esm2022/table/services/data-list.service.mjs +1 -1
  48. package/esm2022/tableview/action/components/action/action.component.mjs +140 -188
  49. package/esm2022/tableview/action/components/editor/action-editor.component.mjs +56 -66
  50. package/esm2022/tableview/action/components/editor/injector-context/action-editor-injector-context.component.mjs +119 -141
  51. package/esm2022/tableview/action/components/localization/data-language-dropdown.component.mjs +21 -39
  52. package/esm2022/tableview/action/components/route/action-route.component.mjs +17 -23
  53. package/esm2022/tableview/action/components/table/action-table.component.mjs +1 -1
  54. package/esm2022/tableview/action/services/action-executor.service.mjs +9 -9
  55. package/esm2022/tableview/action/services/navigation.service.mjs +3 -2
  56. package/esm2022/tableview/action/services/view-container.service.mjs +5 -21
  57. package/esm2022/tableview/api/action/descriptors/action-descriptor.factory.mjs +119 -0
  58. package/esm2022/tableview/api/action/descriptors/action-editor-descriptor.factory.mjs +77 -0
  59. package/esm2022/tableview/api/action/descriptors/action-editor.descriptor.mjs +20 -80
  60. package/esm2022/tableview/api/action/descriptors/action-link-descriptor.factory.mjs +45 -0
  61. package/esm2022/tableview/api/action/descriptors/action-link.descriptor.mjs +1 -32
  62. package/esm2022/tableview/api/action/descriptors/action.descriptor.mjs +3 -69
  63. package/esm2022/tableview/api/action/models/action-component.model.mjs +1 -1
  64. package/esm2022/tableview/api/action/models/execution/view-container.model.mjs +1 -1
  65. package/esm2022/tableview/api/editor/data-providers/editor-data-provider.factory.mjs +33 -0
  66. package/esm2022/tableview/api/editor/data-providers/editor.data-provider.mjs +1 -31
  67. package/esm2022/tableview/api/editor/descriptors/editor-descriptor.factory.mjs +81 -0
  68. package/esm2022/tableview/api/editor/descriptors/editor.descriptor.mjs +7 -133
  69. package/esm2022/tableview/api/editor/descriptors/field-action.descriptor.mjs +1 -1
  70. package/esm2022/tableview/api/editor/descriptors/field-base.descriptor.mjs +13 -5
  71. package/esm2022/tableview/api/editor/descriptors/field-group.descriptor.mjs +1 -1
  72. package/esm2022/tableview/api/editor/descriptors/field-lookup.descriptor.mjs +4 -4
  73. package/esm2022/tableview/api/editor/descriptors/field-many.descriptor.mjs +3 -3
  74. package/esm2022/tableview/api/editor/descriptors/field-validation.descriptor.mjs +1 -1
  75. package/esm2022/tableview/api/editor/descriptors/field.descriptor.mjs +1 -1
  76. package/esm2022/tableview/api/editor/helpers/editor-descriptor-helpers.mjs +95 -0
  77. package/esm2022/tableview/api/editor/helpers/field-validators.mjs +7 -7
  78. package/esm2022/tableview/api/editor/models/editor-fields.model.mjs +1 -1
  79. package/esm2022/tableview/api/editor/models/field-action-context.model.mjs +1 -1
  80. package/esm2022/tableview/api/editor/models/field-validation.model.mjs +2 -0
  81. package/esm2022/tableview/api/editor/models/field.model.mjs +1 -1
  82. package/esm2022/tableview/api/editor/models/form-editor.event.mjs +1 -1
  83. package/esm2022/tableview/api/editor/models/form-editor.interface.mjs +1 -1
  84. package/esm2022/tableview/api/editor/models/formly-field.model.mjs +1 -1
  85. package/esm2022/tableview/api/index.mjs +11 -1
  86. package/esm2022/tableview/api/tableview/data-providers/tableview-data-provider.factory.mjs +47 -0
  87. package/esm2022/tableview/api/tableview/data-providers/tableview.data-provider.mjs +5 -46
  88. package/esm2022/tableview/api/tableview/descriptors/tableview-descriptor.factory.mjs +111 -0
  89. package/esm2022/tableview/api/tableview/descriptors/tableview.descriptor.mjs +15 -168
  90. package/esm2022/tableview/api/tableview/helpers/files-export.mjs +2 -2
  91. package/esm2022/tableview/api/tableview/helpers/tableview-create.mjs +5 -5
  92. package/esm2022/tableview/api/tableview/helpers/tableview-default-actions.mjs +53 -18
  93. package/esm2022/tableview/api/tableview/helpers/tableview-descriptor-helpers.mjs +110 -0
  94. package/esm2022/tableview/api/tableview/helpers/tableview-input-builder.mjs +2 -2
  95. package/esm2022/tableview/editor/components/editor/form-editor.component.mjs +16 -11
  96. package/esm2022/tableview/editor/components/formly/fields/formly-field-action/formly-field-action.component.mjs +6 -2
  97. package/esm2022/tableview/editor/components/formly/fields/formly-field-autocomplete/formly-field-autocomplete.component.mjs +10 -11
  98. package/esm2022/tableview/editor/components/formly/fields/formly-field-custom/formly-field-custom.component.mjs +1 -1
  99. package/esm2022/tableview/editor/components/formly/fields/formly-field-datepicker/formly-field-datepicker.component.mjs +4 -4
  100. package/esm2022/tableview/editor/components/formly/fields/formly-field-dropdown/formly-field-dropdown.component.mjs +9 -11
  101. package/esm2022/tableview/editor/components/formly/fields/formly-field-input/formly-field-input.component.mjs +4 -4
  102. package/esm2022/tableview/editor/components/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.mjs +16 -18
  103. package/esm2022/tableview/editor/components/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +20 -22
  104. package/esm2022/tableview/editor/components/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +18 -20
  105. package/esm2022/tableview/editor/helpers/editor-formly.mjs +27 -6
  106. package/esm2022/tableview/editor/services/form-editor.service.mjs +96 -0
  107. package/esm2022/tableview/index.mjs +2 -1
  108. package/esm2022/tableview/tableview/components/tableview/tableview.component.mjs +3 -3
  109. package/fesm2022/mediusinc-mng-commons-core.mjs +155 -210
  110. package/fesm2022/mediusinc-mng-commons-core.mjs.map +1 -1
  111. package/fesm2022/mediusinc-mng-commons-filter.mjs +3 -3
  112. package/fesm2022/mediusinc-mng-commons-filter.mjs.map +1 -1
  113. package/fesm2022/mediusinc-mng-commons-form-api.mjs +18 -18
  114. package/fesm2022/mediusinc-mng-commons-form-api.mjs.map +1 -1
  115. package/fesm2022/mediusinc-mng-commons-form.mjs +236 -169
  116. package/fesm2022/mediusinc-mng-commons-form.mjs.map +1 -1
  117. package/fesm2022/mediusinc-mng-commons-model.mjs +43 -33
  118. package/fesm2022/mediusinc-mng-commons-model.mjs.map +1 -1
  119. package/fesm2022/mediusinc-mng-commons-table-api.mjs +192 -146
  120. package/fesm2022/mediusinc-mng-commons-table-api.mjs.map +1 -1
  121. package/fesm2022/mediusinc-mng-commons-table.mjs +11 -12
  122. package/fesm2022/mediusinc-mng-commons-table.mjs.map +1 -1
  123. package/fesm2022/mediusinc-mng-commons-tableview-api.mjs +822 -590
  124. package/fesm2022/mediusinc-mng-commons-tableview-api.mjs.map +1 -1
  125. package/fesm2022/mediusinc-mng-commons-tableview.mjs +564 -571
  126. package/fesm2022/mediusinc-mng-commons-tableview.mjs.map +1 -1
  127. package/form/api/data-providers/lookup-data-provider.factory.d.ts +18 -0
  128. package/form/api/data-providers/lookup.data-provider.d.ts +2 -14
  129. package/form/api/index.d.ts +1 -0
  130. package/form/components/autocomplete/autocomplete.component.d.ts +31 -23
  131. package/form/components/dropdown/dropdown.component.d.ts +38 -25
  132. package/model/data-providers/base-from-type-data-provider.factory.d.ts +8 -0
  133. package/model/descriptors/enum.descriptor.d.ts +1 -2
  134. package/model/descriptors/model.descriptor.d.ts +11 -4
  135. package/model/descriptors/type.descriptor.d.ts +2 -4
  136. package/model/index.d.ts +1 -0
  137. package/package.json +1 -1
  138. package/table/api/data-providers/table-data-provider.factory.d.ts +18 -0
  139. package/table/api/data-providers/table.data-provider.d.ts +2 -14
  140. package/table/api/descriptors/table-descriptor.factory.d.ts +44 -0
  141. package/table/api/descriptors/table.descriptor.d.ts +4 -65
  142. package/table/api/helpers/table-descriptor-helpers.d.ts +44 -0
  143. package/table/api/index.d.ts +3 -0
  144. package/table/components/column-filter-full/column-filter-full.component.d.ts +5 -4
  145. package/table/components/table/table.component.d.ts +11 -11
  146. package/table/services/data-list.service.d.ts +9 -10
  147. package/tableview/action/components/action/action.component.d.ts +37 -44
  148. package/tableview/action/components/editor/action-editor.component.d.ts +20 -18
  149. package/tableview/action/components/editor/injector-context/action-editor-injector-context.component.d.ts +23 -23
  150. package/tableview/action/components/localization/data-language-dropdown.component.d.ts +11 -14
  151. package/tableview/action/components/route/action-route.component.d.ts +6 -11
  152. package/tableview/action/components/table/action-table.component.d.ts +3 -3
  153. package/tableview/action/services/view-container.service.d.ts +3 -9
  154. package/tableview/api/action/descriptors/action-descriptor.factory.d.ts +36 -0
  155. package/tableview/api/action/descriptors/action-editor-descriptor.factory.d.ts +31 -0
  156. package/tableview/api/action/descriptors/action-editor.descriptor.d.ts +17 -37
  157. package/tableview/api/action/descriptors/action-link-descriptor.factory.d.ts +15 -0
  158. package/tableview/api/action/descriptors/action-link.descriptor.d.ts +1 -9
  159. package/tableview/api/action/descriptors/action.descriptor.d.ts +4 -27
  160. package/tableview/api/action/models/action-component.model.d.ts +8 -8
  161. package/tableview/api/action/models/execution/view-container.model.d.ts +4 -3
  162. package/tableview/api/editor/data-providers/editor-data-provider.factory.d.ts +18 -0
  163. package/tableview/api/editor/data-providers/editor.data-provider.d.ts +2 -14
  164. package/tableview/api/editor/descriptors/editor-descriptor.factory.d.ts +44 -0
  165. package/tableview/api/editor/descriptors/editor.descriptor.d.ts +34 -90
  166. package/tableview/api/editor/descriptors/field-action.descriptor.d.ts +3 -3
  167. package/tableview/api/editor/descriptors/field-base.descriptor.d.ts +15 -13
  168. package/tableview/api/editor/descriptors/field-group.descriptor.d.ts +7 -6
  169. package/tableview/api/editor/descriptors/field-lookup.descriptor.d.ts +2 -2
  170. package/tableview/api/editor/descriptors/field-many.descriptor.d.ts +8 -8
  171. package/tableview/api/editor/descriptors/field-validation.descriptor.d.ts +6 -6
  172. package/tableview/api/editor/descriptors/field.descriptor.d.ts +1 -1
  173. package/tableview/api/editor/helpers/editor-descriptor-helpers.d.ts +43 -0
  174. package/tableview/api/editor/helpers/field-validators.d.ts +1 -1
  175. package/tableview/api/editor/models/editor-fields.model.d.ts +24 -22
  176. package/tableview/api/editor/models/field-action-context.model.d.ts +10 -8
  177. package/tableview/api/editor/models/field-validation.model.d.ts +26 -0
  178. package/tableview/api/editor/models/field.model.d.ts +0 -19
  179. package/tableview/api/editor/models/form-editor.event.d.ts +24 -16
  180. package/tableview/api/editor/models/form-editor.interface.d.ts +2 -1
  181. package/tableview/api/editor/models/formly-custom-field.model.d.ts +1 -1
  182. package/tableview/api/editor/models/formly-field.model.d.ts +4 -4
  183. package/tableview/api/index.d.ts +10 -0
  184. package/tableview/api/tableview/data-providers/tableview-data-provider.factory.d.ts +25 -0
  185. package/tableview/api/tableview/data-providers/tableview.data-provider.d.ts +3 -20
  186. package/tableview/api/tableview/descriptors/tableview-descriptor.factory.d.ts +49 -0
  187. package/tableview/api/tableview/descriptors/tableview.descriptor.d.ts +40 -100
  188. package/tableview/api/tableview/helpers/tableview-create.d.ts +2 -2
  189. package/tableview/api/tableview/helpers/tableview-default-actions.d.ts +4 -2
  190. package/tableview/api/tableview/helpers/tableview-descriptor-helpers.d.ts +42 -0
  191. package/tableview/api/tableview/helpers/tableview-input-builder.d.ts +1 -1
  192. package/tableview/editor/components/editor/form-editor.component.d.ts +6 -4
  193. package/tableview/editor/components/formly/fields/formly-field-action/formly-field-action.component.d.ts +5 -3
  194. package/tableview/editor/components/formly/fields/formly-field-autocomplete/formly-field-autocomplete.component.d.ts +1 -0
  195. package/tableview/editor/components/formly/fields/formly-field-dropdown/formly-field-dropdown.component.d.ts +1 -1
  196. package/tableview/editor/components/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.d.ts +1 -1
  197. package/tableview/editor/components/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.d.ts +3 -4
  198. package/tableview/editor/components/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.d.ts +3 -4
  199. package/tableview/editor/helpers/editor-formly.d.ts +1 -1
  200. package/tableview/editor/services/form-editor.service.d.ts +39 -0
  201. package/tableview/index.d.ts +1 -0
  202. package/tableview/tableview/components/route/tableview-route.component.d.ts +1 -1
  203. package/tableview/tableview/components/tableview/tableview.component.d.ts +1 -1
  204. package/version-info.json +4 -4
@@ -1,10 +1,9 @@
1
- import { AsyncPipe } from '@angular/common';
2
- import { ChangeDetectionStrategy, Component, DestroyRef, EventEmitter, Injector, Output, computed, forwardRef, inject, input, signal, viewChild } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, DestroyRef, Injector, booleanAttribute, computed, effect, forwardRef, inject, input, output, signal, viewChild } from '@angular/core';
3
2
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
- import { FormControl, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
3
+ import { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';
5
4
  import { TranslateModule, TranslateService } from '@ngx-translate/core';
6
5
  import { Dropdown, DropdownModule } from 'primeng/dropdown';
7
- import { MultiSelectModule } from 'primeng/multiselect';
6
+ import { MultiSelect, MultiSelectModule } from 'primeng/multiselect';
8
7
  import { of, switchMap } from 'rxjs';
9
8
  import { map } from 'rxjs/operators';
10
9
  import { CommonsInternalError, LoggerService, fromSubscribeError, getErrorLogLevel, toObservable } from '@mediusinc/mng-commons/core';
@@ -19,46 +18,58 @@ export const DROPDOWN_VALUE_ACCESSOR = {
19
18
  multi: true
20
19
  };
21
20
  export class DropdownComponent {
21
+ get value() {
22
+ return this._value;
23
+ }
22
24
  constructor() {
23
25
  this.logger = inject(LoggerService).create('DropdownComponent');
24
26
  this.injector = inject(Injector);
25
27
  this.destroyRef = inject(DestroyRef);
26
28
  this.translate = inject(TranslateService);
27
- // private readonly formlyWrapper = inject(FormlyFieldWrapperComponent, {optional: true}); TODO: find workarround
28
- this.dropdownFormControl = new FormControl();
29
29
  this.dataProvider = input();
30
30
  this.options = input([]);
31
31
  this.optionsTrackProperty = input();
32
32
  this.optionsLabelPropertyInit = input(undefined, { alias: 'optionsLabelProperty' });
33
- this.optionsLabelTranslate = input(false);
34
- this.optionsValuePropertyInit = input(undefined, { alias: 'optionsValueProperty' });
33
+ this.optionsLabelTranslate = input(false, { transform: booleanAttribute });
34
+ this.optionsValuePropertyInput = input(undefined, { alias: 'optionsValueProperty' });
35
35
  this.optionsDisabledProperty = input();
36
- this.multiselect = input(false);
36
+ this.multiselect = input(false, { transform: booleanAttribute });
37
37
  this.placeholder = input();
38
- this.showClear = input(false);
39
- this.selectFirstItem = input(false);
38
+ this.showClear = input(false, { transform: booleanAttribute });
39
+ this.selectFirstItemInput = input(false, { transform: booleanAttribute, alias: 'selectFirstItem' });
40
40
  this.className = input();
41
41
  this.dropdownClassName = input();
42
- this.changeValueOnBlur = input(false);
43
- this.loading = signal(false);
44
- this.valueChangeEventEmitter = new EventEmitter();
42
+ this.changeValueOnBlur = input(false, { transform: booleanAttribute });
43
+ this.loadingInput = input(false, { alias: 'loading', transform: booleanAttribute });
44
+ this.disabledInput = input(false, { alias: 'disabled', transform: booleanAttribute });
45
+ this.valueChange = output();
46
+ this.blur = output();
45
47
  this.primeDropdown = viewChild(Dropdown);
46
- this.dataProviderService = null;
48
+ this.primeMultiselect = viewChild(MultiSelect);
49
+ this.ngModelValue = signal(undefined);
50
+ this._loading = signal(false);
51
+ this._disabled = signal(false);
52
+ this.loading = computed(() => this.loadingInput() || this._loading());
53
+ this.disabled = computed(() => this.disabledInput() || this._disabled());
54
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
55
+ this.onChangeFn = () => { };
47
56
  // eslint-disable-next-line @typescript-eslint/no-empty-function
48
57
  this.onTouchedFn = () => { };
58
+ this.dataProviderService = null;
49
59
  this.items = signal([]);
50
60
  this.firstTimeSettingItems = true;
61
+ this.isDropdownPanelShown = false;
51
62
  this.optionsLabelProperty = computed(() => {
52
63
  if (this.optionsLabelTranslate()) {
53
64
  // setup translation properties
54
65
  if (this.optionsLabelPropertyInit()) {
55
66
  return `${this.optionsLabelPropertyInit()}_i18n`;
56
67
  }
57
- else if (!this.optionsLabelPropertyInit() && !this.optionsValuePropertyInit()) {
68
+ else if (!this.optionsLabelPropertyInit() && !this.optionsValuePropertyInput()) {
58
69
  return 'title_i18n';
59
70
  }
60
71
  else {
61
- throw new CommonsInternalError(`Invalid use with value (${this.optionsValuePropertyInit()}) and label (${this.optionsLabelPropertyInit()}) property setup.`, {
72
+ throw new CommonsInternalError(`Invalid use with value (${this.optionsValuePropertyInput()}) and label (${this.optionsLabelPropertyInit()}) property setup.`, {
62
73
  name: 'DropdownComponentError'
63
74
  });
64
75
  }
@@ -68,28 +79,87 @@ export class DropdownComponent {
68
79
  this.optionsValueProperty = computed(() => {
69
80
  if (this.optionsLabelTranslate()) {
70
81
  // setup translation properties
71
- if (!this.optionsLabelPropertyInit() && !this.optionsValuePropertyInit()) {
82
+ if (!this.optionsLabelPropertyInit() && !this.optionsValuePropertyInput()) {
72
83
  return 'value';
73
84
  }
74
85
  else if (!this.optionsLabelPropertyInit()) {
75
- throw new CommonsInternalError(`Invalid use with value (${this.optionsValuePropertyInit()}) and label (${this.optionsLabelPropertyInit()}) property setup.`, {
86
+ throw new CommonsInternalError(`Invalid use with value (${this.optionsValuePropertyInput()}) and label (${this.optionsLabelPropertyInit()}) property setup.`, {
76
87
  name: 'DropdownComponentError'
77
88
  });
78
89
  }
79
90
  }
80
- return this.optionsValuePropertyInit();
91
+ return this.optionsValuePropertyInput();
92
+ });
93
+ effect(() => {
94
+ this._value = this.ngModelValue();
81
95
  });
82
96
  }
83
97
  ngOnInit() {
84
- this.dropdownFormControl.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(v => {
85
- if (!this.changeValueOnBlur()) {
86
- this.propagateValueChange(v);
87
- }
88
- });
98
+ this.setDataProviderAndOptions();
99
+ }
100
+ registerOnChange(fn) {
101
+ this.onChangeFn = fn;
102
+ }
103
+ registerOnTouched(fn) {
104
+ this.onTouchedFn = fn;
105
+ }
106
+ setDisabledState(isDisabled) {
107
+ setTimeout(() => this._disabled.set(isDisabled));
108
+ }
109
+ writeValue(value) {
110
+ // this check is required because angular in some cases writes null value
111
+ // before value accessor is initialized
112
+ // if form control value is of primitive type (ex: enums) then write value is not called (we think)
113
+ if (value == null && this._value == null) {
114
+ return;
115
+ }
116
+ // write value immediately - it is important so that first select is not triggered!
117
+ this._value = value;
118
+ this.adjustValueOnItemsValuePropertyTypeMismatch(true);
119
+ }
120
+ onDropdownBlur(event) {
121
+ if (this.isDropdownPanelShown) {
122
+ // ignore this blur event
123
+ return;
124
+ }
125
+ const primeDropdown = this.primeDropdown();
126
+ if (this.changeValueOnBlur() && primeDropdown) {
127
+ this.propagateValueChange(primeDropdown.value);
128
+ }
129
+ this.onTouchedFn();
130
+ this.blur.emit(event);
131
+ }
132
+ onDropdownChange(event) {
133
+ if (!this.changeValueOnBlur()) {
134
+ this.propagateValueChange(event.value);
135
+ }
136
+ }
137
+ onDropdownPanelShow() {
138
+ this.isDropdownPanelShown = true;
139
+ }
140
+ onDropdownPanelHide() {
141
+ this.isDropdownPanelShown = false;
142
+ }
143
+ onMultiselectChange(event) {
144
+ if (!this.changeValueOnBlur()) {
145
+ this.propagateValueChange(event.value);
146
+ }
147
+ }
148
+ onMultiselectBlur(event) {
149
+ this.onTouchedFn();
150
+ this.blur.emit(event.originalEvent);
151
+ }
152
+ onMultiselectPanelHide() {
153
+ const primeMultiselect = this.primeMultiselect();
154
+ if (this.changeValueOnBlur() && primeMultiselect) {
155
+ this.propagateValueChange(primeMultiselect.value);
156
+ }
157
+ }
158
+ setDataProviderAndOptions() {
89
159
  const dataProvider = this.dataProvider();
90
160
  const options = this.options();
91
161
  if (dataProvider) {
92
- this.loading.set(true);
162
+ this._loading.set(true);
93
163
  this.dataProviderService = dataProvider.serviceType ? this.injector.get(dataProvider.serviceType) : null;
94
164
  toObservable(dataProvider.lookup({ limit: 50 }, this.dataProviderService))
95
165
  .pipe(switchMap(items => {
@@ -125,15 +195,12 @@ export class DropdownComponent {
125
195
  .subscribe({
126
196
  next: res => {
127
197
  this.items.set(res);
128
- this.loading.set(false);
129
- if (this.firstTimeSettingItems && this.selectFirstItem() && !this.dropdownFormControl?.value) {
130
- const optionsValueProperty = this.optionsValueProperty();
131
- const value = optionsValueProperty ? res[0][optionsValueProperty] : res[0];
132
- this.dropdownFormControl?.setValue(value);
133
- this.firstTimeSettingItems = false;
134
- }
198
+ this._loading.set(false);
199
+ this.selectFirstItem();
200
+ this.adjustValueOnItemsValuePropertyTypeMismatch();
135
201
  },
136
202
  error: err => {
203
+ this._loading.set(false);
137
204
  const error = fromSubscribeError(err, 'DropdownComponentError');
138
205
  this.logger.log(error, getErrorLogLevel(error));
139
206
  }
@@ -142,72 +209,63 @@ export class DropdownComponent {
142
209
  else {
143
210
  toObservable(options ?? [])
144
211
  .pipe(takeUntilDestroyed(this.destroyRef))
145
- .subscribe(qr => {
146
- this.items.set(qr);
147
- this.loading.set(false);
212
+ .subscribe({
213
+ next: qr => {
214
+ this.items.set(qr);
215
+ this._loading.set(false);
216
+ this.selectFirstItem();
217
+ this.adjustValueOnItemsValuePropertyTypeMismatch();
218
+ },
219
+ error: err => {
220
+ this.items.set([]);
221
+ this._loading.set(false);
222
+ const error = fromSubscribeError(err, 'DropdownComponentError');
223
+ this.logger.log(error, getErrorLogLevel(error));
224
+ }
148
225
  });
149
226
  }
150
227
  }
151
- registerOnChange(fn) {
152
- this.onChangeFn = fn;
153
- }
154
- registerOnTouched(fn) {
155
- this.onTouchedFn = fn;
156
- }
157
- setDisabledState(isDisabled) {
158
- if (isDisabled) {
159
- this.dropdownFormControl.disable();
160
- }
161
- else {
162
- this.dropdownFormControl.enable();
163
- }
164
- }
165
- writeValue(obj) {
166
- // this check is required because angular in some cases writes null value
167
- // before value accessor is initialized
168
- // if form control value is of primitive type (ex: enums) then write value is not called (we think)
169
- if (!this.optionsValuePropertyInit() && obj === null && !this.isValueAccessorInitialized()) {
170
- return;
228
+ selectFirstItem() {
229
+ if (this.firstTimeSettingItems && this.items().length > 0 && this.selectFirstItemInput() && !this._value) {
230
+ const optionsValueProperty = this.optionsValueProperty();
231
+ const value = optionsValueProperty ? this.items()[0][optionsValueProperty] : this.items()[0];
232
+ this.ngModelValue.set(value); // set to write for input
233
+ this.firstTimeSettingItems = false;
234
+ this.propagateValueChange(value);
171
235
  }
172
- this.dropdownFormControl.setValue(obj, { emitEvent: false });
173
236
  }
174
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
175
- onDropdownBlur(event) {
176
- if (this.changeValueOnBlur()) {
177
- this.propagateValueChange(this.dropdownFormControl.value);
237
+ adjustValueOnItemsValuePropertyTypeMismatch(setNgModelValue = false) {
238
+ const optionsValueProp = this.optionsValueProperty();
239
+ if (optionsValueProp &&
240
+ this._value &&
241
+ this.items().length > 0 &&
242
+ this.items()[0][optionsValueProp] != null &&
243
+ typeof this.items()[0][optionsValueProp] !== typeof this._value) {
244
+ // types dont match, search and compare by string
245
+ const selectedOption = this.items().find(i => i[optionsValueProp] != null && i[optionsValueProp].toString() === this._value.toString());
246
+ if (selectedOption) {
247
+ this.ngModelValue.set(selectedOption[optionsValueProp]);
248
+ }
249
+ else if (setNgModelValue) {
250
+ // force write to ngModelValue anyway
251
+ this.ngModelValue.set(this._value);
252
+ }
178
253
  }
179
- }
180
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
181
- onPanelHide(event) {
182
- if (this.changeValueOnBlur()) {
183
- this.propagateValueChange(this.dropdownFormControl.value);
254
+ else if (setNgModelValue) {
255
+ // force write to ngModelValue anyway
256
+ this.ngModelValue.set(this._value);
184
257
  }
185
258
  }
186
259
  propagateValueChange(value) {
187
- if (!this.isValueAccessorInitialized()) {
188
- return;
189
- }
190
- // this.formlyWrapper?.formControl?.markAsTouched(); TODO
260
+ this._value = value;
191
261
  this.onChangeFn(value);
192
- this.valueChangeEventEmitter.next(value);
193
- }
194
- /**
195
- * Prevents executions for writing and outputting value which is sometimes committed as null in cmp initialization stage.
196
- * In dropdown (from ang. 15 and switch to standalone cmp) null value was always committed to dropdown even if default value was set (using ngModel or formControl) which is incorrect.
197
- * Github issue: https://github.com/angular/angular/issues/14988
198
- * @private
199
- */
200
- isValueAccessorInitialized() {
201
- return typeof this.onChangeFn !== 'undefined';
262
+ this.valueChange.emit(value);
202
263
  }
203
264
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: DropdownComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
204
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.4", type: DropdownComponent, isStandalone: true, selector: "mng-dropdown", inputs: { dataProvider: { classPropertyName: "dataProvider", publicName: "dataProvider", isSignal: true, isRequired: false, transformFunction: null }, options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null }, optionsTrackProperty: { classPropertyName: "optionsTrackProperty", publicName: "optionsTrackProperty", isSignal: true, isRequired: false, transformFunction: null }, optionsLabelPropertyInit: { classPropertyName: "optionsLabelPropertyInit", publicName: "optionsLabelProperty", isSignal: true, isRequired: false, transformFunction: null }, optionsLabelTranslate: { classPropertyName: "optionsLabelTranslate", publicName: "optionsLabelTranslate", isSignal: true, isRequired: false, transformFunction: null }, optionsValuePropertyInit: { classPropertyName: "optionsValuePropertyInit", publicName: "optionsValueProperty", isSignal: true, isRequired: false, transformFunction: null }, optionsDisabledProperty: { classPropertyName: "optionsDisabledProperty", publicName: "optionsDisabledProperty", isSignal: true, isRequired: false, transformFunction: null }, multiselect: { classPropertyName: "multiselect", publicName: "multiselect", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, showClear: { classPropertyName: "showClear", publicName: "showClear", isSignal: true, isRequired: false, transformFunction: null }, selectFirstItem: { classPropertyName: "selectFirstItem", publicName: "selectFirstItem", isSignal: true, isRequired: false, transformFunction: null }, className: { classPropertyName: "className", publicName: "className", isSignal: true, isRequired: false, transformFunction: null }, dropdownClassName: { classPropertyName: "dropdownClassName", publicName: "dropdownClassName", isSignal: true, isRequired: false, transformFunction: null }, changeValueOnBlur: { classPropertyName: "changeValueOnBlur", publicName: "changeValueOnBlur", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { valueChangeEventEmitter: "valueChange" }, providers: [DROPDOWN_VALUE_ACCESSOR], viewQueries: [{ propertyName: "primeDropdown", first: true, predicate: Dropdown, descendants: true, isSignal: true }], ngImport: i0, template: "@if (!multiselect()) {\n <p-dropdown\n [formControl]=\"dropdownFormControl\"\n [placeholder]=\"placeholder()\"\n [dataKey]=\"optionsTrackProperty()\"\n [optionLabel]=\"optionsLabelProperty()\"\n [optionValue]=\"optionsValueProperty()\"\n [optionDisabled]=\"optionsDisabledProperty()\"\n [options]=\"items()\"\n [showClear]=\"showClear()\"\n [autoDisplayFirst]=\"false\"\n [styleClass]=\"className()\"\n [panelStyleClass]=\"dropdownClassName()\"\n (onBlur)=\"onDropdownBlur($event)\"\n [dropdownIcon]=\"loading() ? 'pi pi-spinner pi-spin' : 'pi pi-chevron-down'\"\n appendTo=\"body\">\n </p-dropdown>\n} @else {\n <p-multiSelect\n [maxSelectedLabels]=\"1\"\n [selectedItemsLabel]=\"'mngDropdown.multiselectOverMaxDisplayLimit' | translate\"\n [formControl]=\"dropdownFormControl\"\n [placeholder]=\"placeholder()\"\n [dataKey]=\"optionsTrackProperty()\"\n [optionLabel]=\"optionsLabelProperty()\"\n [optionValue]=\"optionsValueProperty()\"\n [optionDisabled]=\"optionsDisabledProperty()\"\n [options]=\"items()\"\n [styleClass]=\"className()\"\n [panelStyleClass]=\"dropdownClassName()\"\n [filter]=\"true\"\n [showToggleAll]=\"false\"\n (onPanelHide)=\"onPanelHide($event)\"\n appendTo=\"body\">\n </p-multiSelect>\n}\n", dependencies: [{ kind: "ngmodule", type: DropdownModule }, { kind: "component", type: i1.Dropdown, selector: "p-dropdown", inputs: ["id", "scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "dataKey", "filterBy", "filterFields", "autofocus", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "focusOnHover", "selectOnFocus", "autoOptionFocus", "autofocusFilter", "disabled", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "filterValue", "options"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "ngmodule", type: MultiSelectModule }, { kind: "component", type: i2.MultiSelect, selector: "p-multiSelect", inputs: ["id", "ariaLabel", "style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "appendTo", "dataKey", "name", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "filterBy", "scrollHeight", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "autocomplete", "showClear", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "defaultLabel", "placeholder", "options", "filterValue", "itemSize", "selectAll", "focusOnHover", "filterFields", "selectOnFocus", "autoOptionFocus"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onClear", "onPanelShow", "onPanelHide", "onLazyLoad", "onRemove", "onSelectAllChange"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
265
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.4", type: DropdownComponent, isStandalone: true, selector: "mng-dropdown", inputs: { dataProvider: { classPropertyName: "dataProvider", publicName: "dataProvider", isSignal: true, isRequired: false, transformFunction: null }, options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null }, optionsTrackProperty: { classPropertyName: "optionsTrackProperty", publicName: "optionsTrackProperty", isSignal: true, isRequired: false, transformFunction: null }, optionsLabelPropertyInit: { classPropertyName: "optionsLabelPropertyInit", publicName: "optionsLabelProperty", isSignal: true, isRequired: false, transformFunction: null }, optionsLabelTranslate: { classPropertyName: "optionsLabelTranslate", publicName: "optionsLabelTranslate", isSignal: true, isRequired: false, transformFunction: null }, optionsValuePropertyInput: { classPropertyName: "optionsValuePropertyInput", publicName: "optionsValueProperty", isSignal: true, isRequired: false, transformFunction: null }, optionsDisabledProperty: { classPropertyName: "optionsDisabledProperty", publicName: "optionsDisabledProperty", isSignal: true, isRequired: false, transformFunction: null }, multiselect: { classPropertyName: "multiselect", publicName: "multiselect", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, showClear: { classPropertyName: "showClear", publicName: "showClear", isSignal: true, isRequired: false, transformFunction: null }, selectFirstItemInput: { classPropertyName: "selectFirstItemInput", publicName: "selectFirstItem", isSignal: true, isRequired: false, transformFunction: null }, className: { classPropertyName: "className", publicName: "className", isSignal: true, isRequired: false, transformFunction: null }, dropdownClassName: { classPropertyName: "dropdownClassName", publicName: "dropdownClassName", isSignal: true, isRequired: false, transformFunction: null }, changeValueOnBlur: { classPropertyName: "changeValueOnBlur", publicName: "changeValueOnBlur", isSignal: true, isRequired: false, transformFunction: null }, loadingInput: { classPropertyName: "loadingInput", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, disabledInput: { classPropertyName: "disabledInput", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { valueChange: "valueChange", blur: "blur" }, providers: [DROPDOWN_VALUE_ACCESSOR], viewQueries: [{ propertyName: "primeDropdown", first: true, predicate: Dropdown, descendants: true, isSignal: true }, { propertyName: "primeMultiselect", first: true, predicate: MultiSelect, descendants: true, isSignal: true }], ngImport: i0, template: "@if (!multiselect()) {\n <p-dropdown\n [ngModel]=\"ngModelValue()\"\n [placeholder]=\"placeholder()\"\n [dataKey]=\"optionsTrackProperty()\"\n [optionLabel]=\"optionsLabelProperty()\"\n [optionValue]=\"optionsValueProperty()\"\n [optionDisabled]=\"optionsDisabledProperty()\"\n [options]=\"items()\"\n [showClear]=\"showClear()\"\n [styleClass]=\"className()\"\n [panelStyleClass]=\"dropdownClassName()\"\n [disabled]=\"disabled()\"\n (onBlur)=\"onDropdownBlur($event)\"\n (onChange)=\"onDropdownChange($event)\"\n (onShow)=\"onDropdownPanelShow()\"\n (onHide)=\"onDropdownPanelHide()\"\n [dropdownIcon]=\"loading() ? 'pi pi-spinner pi-spin' : 'pi pi-chevron-down'\"\n appendTo=\"body\">\n </p-dropdown>\n} @else {\n <p-multiSelect\n [ngModel]=\"ngModelValue()\"\n [maxSelectedLabels]=\"1\"\n [selectedItemsLabel]=\"'mngDropdown.multiselectOverMaxDisplayLimit' | translate\"\n [placeholder]=\"placeholder()\"\n [dataKey]=\"optionsTrackProperty()\"\n [optionLabel]=\"optionsLabelProperty()\"\n [optionValue]=\"optionsValueProperty()\"\n [optionDisabled]=\"optionsDisabledProperty()\"\n [options]=\"items()\"\n [styleClass]=\"className()\"\n [panelStyleClass]=\"dropdownClassName()\"\n [filter]=\"true\"\n [showToggleAll]=\"false\"\n [disabled]=\"disabled()\"\n (onChange)=\"onMultiselectChange($event)\"\n (onPanelHide)=\"onMultiselectPanelHide()\"\n (onBlur)=\"onMultiselectBlur($event)\"\n appendTo=\"body\">\n </p-multiSelect>\n}\n", dependencies: [{ kind: "ngmodule", type: DropdownModule }, { kind: "component", type: i1.Dropdown, selector: "p-dropdown", inputs: ["id", "scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "dataKey", "filterBy", "filterFields", "autofocus", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "focusOnHover", "selectOnFocus", "autoOptionFocus", "autofocusFilter", "disabled", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "filterValue", "options"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "ngmodule", type: MultiSelectModule }, { kind: "component", type: i2.MultiSelect, selector: "p-multiSelect", inputs: ["id", "ariaLabel", "style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "appendTo", "dataKey", "name", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "filterBy", "scrollHeight", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "autocomplete", "showClear", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "defaultLabel", "placeholder", "options", "filterValue", "itemSize", "selectAll", "focusOnHover", "filterFields", "selectOnFocus", "autoOptionFocus"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onClear", "onPanelShow", "onPanelHide", "onLazyLoad", "onRemove", "onSelectAllChange"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
205
266
  }
206
267
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: DropdownComponent, decorators: [{
207
268
  type: Component,
208
- args: [{ standalone: true, selector: 'mng-dropdown', providers: [DROPDOWN_VALUE_ACCESSOR], imports: [DropdownModule, MultiSelectModule, TranslateModule, AsyncPipe, ReactiveFormsModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (!multiselect()) {\n <p-dropdown\n [formControl]=\"dropdownFormControl\"\n [placeholder]=\"placeholder()\"\n [dataKey]=\"optionsTrackProperty()\"\n [optionLabel]=\"optionsLabelProperty()\"\n [optionValue]=\"optionsValueProperty()\"\n [optionDisabled]=\"optionsDisabledProperty()\"\n [options]=\"items()\"\n [showClear]=\"showClear()\"\n [autoDisplayFirst]=\"false\"\n [styleClass]=\"className()\"\n [panelStyleClass]=\"dropdownClassName()\"\n (onBlur)=\"onDropdownBlur($event)\"\n [dropdownIcon]=\"loading() ? 'pi pi-spinner pi-spin' : 'pi pi-chevron-down'\"\n appendTo=\"body\">\n </p-dropdown>\n} @else {\n <p-multiSelect\n [maxSelectedLabels]=\"1\"\n [selectedItemsLabel]=\"'mngDropdown.multiselectOverMaxDisplayLimit' | translate\"\n [formControl]=\"dropdownFormControl\"\n [placeholder]=\"placeholder()\"\n [dataKey]=\"optionsTrackProperty()\"\n [optionLabel]=\"optionsLabelProperty()\"\n [optionValue]=\"optionsValueProperty()\"\n [optionDisabled]=\"optionsDisabledProperty()\"\n [options]=\"items()\"\n [styleClass]=\"className()\"\n [panelStyleClass]=\"dropdownClassName()\"\n [filter]=\"true\"\n [showToggleAll]=\"false\"\n (onPanelHide)=\"onPanelHide($event)\"\n appendTo=\"body\">\n </p-multiSelect>\n}\n" }]
209
- }], propDecorators: { valueChangeEventEmitter: [{
210
- type: Output,
211
- args: ['valueChange']
212
- }] } });
213
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../form/src/components/dropdown/dropdown.component.ts","../../../../../form/src/components/dropdown/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    DestroyRef,\n    EventEmitter,\n    ExistingProvider,\n    Injector,\n    OnInit,\n    Output,\n    computed,\n    forwardRef,\n    inject,\n    input,\n    signal,\n    viewChild\n} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR, ReactiveFormsModule} from '@angular/forms';\n\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {Dropdown, DropdownModule} from 'primeng/dropdown';\nimport {MultiSelectModule} from 'primeng/multiselect';\nimport {Observable, of, switchMap} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\nimport {CommonsInternalError, ILookupDataProvider, LoggerService, fromSubscribeError, getErrorLogLevel, toObservable} from '@mediusinc/mng-commons/core';\n\nexport const DROPDOWN_VALUE_ACCESSOR: ExistingProvider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => DropdownComponent),\n    multi: true\n};\n\n@Component({\n    standalone: true,\n    selector: 'mng-dropdown',\n    templateUrl: './dropdown.component.html',\n    providers: [DROPDOWN_VALUE_ACCESSOR],\n    imports: [DropdownModule, MultiSelectModule, TranslateModule, AsyncPipe, ReactiveFormsModule],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DropdownComponent implements OnInit, ControlValueAccessor {\n    private readonly logger = inject(LoggerService).create('DropdownComponent');\n\n    private readonly injector = inject(Injector);\n    private readonly destroyRef = inject(DestroyRef);\n    private readonly translate = inject(TranslateService);\n    // private readonly formlyWrapper = inject(FormlyFieldWrapperComponent, {optional: true}); TODO: find workarround\n\n    public readonly dropdownFormControl: FormControl = new FormControl();\n\n    public dataProvider = input<ILookupDataProvider<any, any>>();\n    public options = input<Observable<Array<any>> | Array<any>>([]);\n    public optionsTrackProperty = input<string>();\n    public optionsLabelPropertyInit = input<string | undefined>(undefined, {alias: 'optionsLabelProperty'});\n    public optionsLabelTranslate = input<boolean>(false);\n    public optionsValuePropertyInit = input<string | undefined>(undefined, {alias: 'optionsValueProperty'});\n    public optionsDisabledProperty = input<string>();\n    public multiselect = input<boolean>(false);\n    public placeholder = input<string>();\n    public showClear = input<boolean>(false);\n    public selectFirstItem = input<boolean>(false);\n    public className = input<string>();\n    public dropdownClassName = input<string>();\n    public changeValueOnBlur = input<boolean>(false);\n    public loading = signal(false);\n\n    @Output('valueChange') public valueChangeEventEmitter = new EventEmitter();\n\n    public primeDropdown = viewChild(Dropdown);\n\n    private dataProviderService: any = null;\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onChangeFn: any;\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onTouchedFn: any = () => {};\n\n    public items = signal<Array<any>>([]);\n    private firstTimeSettingItems = true;\n\n    public optionsLabelProperty = computed(() => {\n        if (this.optionsLabelTranslate()) {\n            // setup translation properties\n            if (this.optionsLabelPropertyInit()) {\n                return `${this.optionsLabelPropertyInit()}_i18n`;\n            } else if (!this.optionsLabelPropertyInit() && !this.optionsValuePropertyInit()) {\n                return 'title_i18n';\n            } else {\n                throw new CommonsInternalError(`Invalid use with value (${this.optionsValuePropertyInit()}) and label (${this.optionsLabelPropertyInit()}) property setup.`, {\n                    name: 'DropdownComponentError'\n                });\n            }\n        }\n\n        return this.optionsLabelPropertyInit();\n    });\n    public optionsValueProperty = computed(() => {\n        if (this.optionsLabelTranslate()) {\n            // setup translation properties\n            if (!this.optionsLabelPropertyInit() && !this.optionsValuePropertyInit()) {\n                return 'value';\n            } else if (!this.optionsLabelPropertyInit()) {\n                throw new CommonsInternalError(`Invalid use with value (${this.optionsValuePropertyInit()}) and label (${this.optionsLabelPropertyInit()}) property setup.`, {\n                    name: 'DropdownComponentError'\n                });\n            }\n        }\n\n        return this.optionsValuePropertyInit();\n    });\n\n    ngOnInit(): void {\n        this.dropdownFormControl.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(v => {\n            if (!this.changeValueOnBlur()) {\n                this.propagateValueChange(v);\n            }\n        });\n\n        const dataProvider = this.dataProvider();\n        const options = this.options();\n        if (dataProvider) {\n            this.loading.set(true);\n            this.dataProviderService = dataProvider.serviceType ? this.injector.get<any>(dataProvider.serviceType) : null;\n\n            toObservable(dataProvider.lookup({limit: 50}, this.dataProviderService))\n                .pipe(\n                    switchMap(items => {\n                        if (this.optionsLabelTranslate()) {\n                            const translationKeys: string[] = items.map(\n                                item =>\n                                    (typeof item === 'object' && this.optionsLabelPropertyInit()\n                                        ? (item[this.optionsLabelPropertyInit() as keyof object] as string)\n                                        : item) as string\n                            );\n\n                            if (translationKeys.length === 0) {\n                                return of([]);\n                            }\n\n                            return this.translate.stream(translationKeys).pipe(\n                                map(translations =>\n                                    items.map(item => {\n                                        if (typeof item === 'object' && this.optionsLabelPropertyInit()) {\n                                            const label = item[this.optionsLabelPropertyInit() as keyof object] as string;\n                                            const translation: string | undefined = translations[label];\n                                            if (translation) {\n                                                return {...item, [this.optionsLabelProperty()!]: translation};\n                                            }\n                                            return {...item};\n                                        } else {\n                                            const translation = translations[item];\n                                            return {\n                                                [this.optionsLabelProperty()!]: translation ?? item,\n                                                [this.optionsValueProperty()!]: item\n                                            };\n                                        }\n                                    })\n                                )\n                            );\n                        } else {\n                            return of(items);\n                        }\n                    }),\n                    takeUntilDestroyed(this.destroyRef)\n                )\n                .subscribe({\n                    next: res => {\n                        this.items.set(res);\n                        this.loading.set(false);\n\n                        if (this.firstTimeSettingItems && this.selectFirstItem() && !this.dropdownFormControl?.value) {\n                            const optionsValueProperty = this.optionsValueProperty();\n                            const value = optionsValueProperty ? res[0][optionsValueProperty] : res[0];\n                            this.dropdownFormControl?.setValue(value);\n                            this.firstTimeSettingItems = false;\n                        }\n                    },\n                    error: err => {\n                        const error = fromSubscribeError(err, 'DropdownComponentError');\n                        this.logger.log(error, getErrorLogLevel(error));\n                    }\n                });\n        } else {\n            toObservable(options ?? [])\n                .pipe(takeUntilDestroyed(this.destroyRef))\n                .subscribe(qr => {\n                    this.items.set(qr);\n                    this.loading.set(false);\n                });\n        }\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChangeFn = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchedFn = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        if (isDisabled) {\n            this.dropdownFormControl.disable();\n        } else {\n            this.dropdownFormControl.enable();\n        }\n    }\n\n    writeValue(obj: any): void {\n        // this check is required because angular in some cases writes null value\n        // before value accessor is initialized\n        // if form control value is of primitive type (ex: enums) then write value is not called (we think)\n        if (!this.optionsValuePropertyInit() && obj === null && !this.isValueAccessorInitialized()) {\n            return;\n        }\n        this.dropdownFormControl.setValue(obj, {emitEvent: false});\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    onDropdownBlur(event: any) {\n        if (this.changeValueOnBlur()) {\n            this.propagateValueChange(this.dropdownFormControl.value);\n        }\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    onPanelHide(event: any) {\n        if (this.changeValueOnBlur()) {\n            this.propagateValueChange(this.dropdownFormControl.value);\n        }\n    }\n\n    private propagateValueChange(value: any) {\n        if (!this.isValueAccessorInitialized()) {\n            return;\n        }\n\n        // this.formlyWrapper?.formControl?.markAsTouched(); TODO\n\n        this.onChangeFn(value);\n        this.valueChangeEventEmitter.next(value);\n    }\n\n    /**\n     * Prevents executions for writing and outputting value which is sometimes committed as null in cmp initialization stage.\n     * In dropdown (from ang. 15 and switch to standalone cmp) null value was always committed to dropdown even if default value was set (using ngModel or formControl) which is incorrect.\n     * Github issue: https://github.com/angular/angular/issues/14988\n     * @private\n     */\n    private isValueAccessorInitialized() {\n        return typeof this.onChangeFn !== 'undefined';\n    }\n}\n","@if (!multiselect()) {\n    <p-dropdown\n        [formControl]=\"dropdownFormControl\"\n        [placeholder]=\"placeholder()\"\n        [dataKey]=\"optionsTrackProperty()\"\n        [optionLabel]=\"optionsLabelProperty()\"\n        [optionValue]=\"optionsValueProperty()\"\n        [optionDisabled]=\"optionsDisabledProperty()\"\n        [options]=\"items()\"\n        [showClear]=\"showClear()\"\n        [autoDisplayFirst]=\"false\"\n        [styleClass]=\"className()\"\n        [panelStyleClass]=\"dropdownClassName()\"\n        (onBlur)=\"onDropdownBlur($event)\"\n        [dropdownIcon]=\"loading() ? 'pi pi-spinner pi-spin' : 'pi pi-chevron-down'\"\n        appendTo=\"body\">\n    </p-dropdown>\n} @else {\n    <p-multiSelect\n        [maxSelectedLabels]=\"1\"\n        [selectedItemsLabel]=\"'mngDropdown.multiselectOverMaxDisplayLimit' | translate\"\n        [formControl]=\"dropdownFormControl\"\n        [placeholder]=\"placeholder()\"\n        [dataKey]=\"optionsTrackProperty()\"\n        [optionLabel]=\"optionsLabelProperty()\"\n        [optionValue]=\"optionsValueProperty()\"\n        [optionDisabled]=\"optionsDisabledProperty()\"\n        [options]=\"items()\"\n        [styleClass]=\"className()\"\n        [panelStyleClass]=\"dropdownClassName()\"\n        [filter]=\"true\"\n        [showToggleAll]=\"false\"\n        (onPanelHide)=\"onPanelHide($event)\"\n        appendTo=\"body\">\n    </p-multiSelect>\n}\n"]}
269
+ args: [{ standalone: true, selector: 'mng-dropdown', providers: [DROPDOWN_VALUE_ACCESSOR], imports: [DropdownModule, MultiSelectModule, TranslateModule, FormsModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (!multiselect()) {\n <p-dropdown\n [ngModel]=\"ngModelValue()\"\n [placeholder]=\"placeholder()\"\n [dataKey]=\"optionsTrackProperty()\"\n [optionLabel]=\"optionsLabelProperty()\"\n [optionValue]=\"optionsValueProperty()\"\n [optionDisabled]=\"optionsDisabledProperty()\"\n [options]=\"items()\"\n [showClear]=\"showClear()\"\n [styleClass]=\"className()\"\n [panelStyleClass]=\"dropdownClassName()\"\n [disabled]=\"disabled()\"\n (onBlur)=\"onDropdownBlur($event)\"\n (onChange)=\"onDropdownChange($event)\"\n (onShow)=\"onDropdownPanelShow()\"\n (onHide)=\"onDropdownPanelHide()\"\n [dropdownIcon]=\"loading() ? 'pi pi-spinner pi-spin' : 'pi pi-chevron-down'\"\n appendTo=\"body\">\n </p-dropdown>\n} @else {\n <p-multiSelect\n [ngModel]=\"ngModelValue()\"\n [maxSelectedLabels]=\"1\"\n [selectedItemsLabel]=\"'mngDropdown.multiselectOverMaxDisplayLimit' | translate\"\n [placeholder]=\"placeholder()\"\n [dataKey]=\"optionsTrackProperty()\"\n [optionLabel]=\"optionsLabelProperty()\"\n [optionValue]=\"optionsValueProperty()\"\n [optionDisabled]=\"optionsDisabledProperty()\"\n [options]=\"items()\"\n [styleClass]=\"className()\"\n [panelStyleClass]=\"dropdownClassName()\"\n [filter]=\"true\"\n [showToggleAll]=\"false\"\n [disabled]=\"disabled()\"\n (onChange)=\"onMultiselectChange($event)\"\n (onPanelHide)=\"onMultiselectPanelHide()\"\n (onBlur)=\"onMultiselectBlur($event)\"\n appendTo=\"body\">\n </p-multiSelect>\n}\n" }]
270
+ }], ctorParameters: () => [] });
271
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../form/src/components/dropdown/dropdown.component.ts","../../../../../form/src/components/dropdown/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    DestroyRef,\n    ExistingProvider,\n    Injector,\n    OnInit,\n    booleanAttribute,\n    computed,\n    effect,\n    forwardRef,\n    inject,\n    input,\n    output,\n    signal,\n    viewChild\n} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR} from '@angular/forms';\n\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {Dropdown, DropdownChangeEvent, DropdownModule} from 'primeng/dropdown';\nimport {MultiSelect, MultiSelectBlurEvent, MultiSelectChangeEvent, MultiSelectModule} from 'primeng/multiselect';\nimport {Observable, of, switchMap} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\nimport {CommonsInternalError, ILookupDataProvider, LoggerService, fromSubscribeError, getErrorLogLevel, toObservable} from '@mediusinc/mng-commons/core';\n\nexport const DROPDOWN_VALUE_ACCESSOR: ExistingProvider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => DropdownComponent),\n    multi: true\n};\n\n@Component({\n    standalone: true,\n    selector: 'mng-dropdown',\n    templateUrl: './dropdown.component.html',\n    providers: [DROPDOWN_VALUE_ACCESSOR],\n    imports: [DropdownModule, MultiSelectModule, TranslateModule, FormsModule],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DropdownComponent implements ControlValueAccessor, OnInit {\n    private readonly logger = inject(LoggerService).create('DropdownComponent');\n\n    private readonly injector = inject(Injector);\n    private readonly destroyRef = inject(DestroyRef);\n    private readonly translate = inject(TranslateService);\n\n    public dataProvider = input<ILookupDataProvider<any, any>>();\n    public options = input<Observable<Array<any>> | Array<any>>([]);\n    public optionsTrackProperty = input<string>();\n    public optionsLabelPropertyInit = input<string | undefined>(undefined, {alias: 'optionsLabelProperty'});\n    public optionsLabelTranslate = input(false, {transform: booleanAttribute});\n    public optionsValuePropertyInput = input<string | undefined>(undefined, {alias: 'optionsValueProperty'});\n    public optionsDisabledProperty = input<string>();\n    public multiselect = input(false, {transform: booleanAttribute});\n    public placeholder = input<string>();\n    public showClear = input(false, {transform: booleanAttribute});\n    public selectFirstItemInput = input(false, {transform: booleanAttribute, alias: 'selectFirstItem'});\n    public className = input<string>();\n    public dropdownClassName = input<string>();\n    public changeValueOnBlur = input(false, {transform: booleanAttribute});\n    public loadingInput = input(false, {alias: 'loading', transform: booleanAttribute});\n    public disabledInput = input(false, {alias: 'disabled', transform: booleanAttribute});\n\n    public valueChange = output<any>();\n    public blur = output<Event>();\n\n    public primeDropdown = viewChild(Dropdown);\n    public primeMultiselect = viewChild(MultiSelect);\n\n    private _value?: any | null;\n    public ngModelValue = signal<undefined | null | any>(undefined);\n\n    private _loading = signal(false);\n    private _disabled = signal(false);\n    public loading = computed(() => this.loadingInput() || this._loading());\n    public disabled = computed(() => this.disabledInput() || this._disabled());\n\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onChangeFn: any = () => {};\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onTouchedFn: any = () => {};\n\n    private dataProviderService: any = null;\n    public items = signal<Array<any>>([]);\n    private firstTimeSettingItems = true;\n\n    private isDropdownPanelShown = false;\n\n    public optionsLabelProperty = computed(() => {\n        if (this.optionsLabelTranslate()) {\n            // setup translation properties\n            if (this.optionsLabelPropertyInit()) {\n                return `${this.optionsLabelPropertyInit()}_i18n`;\n            } else if (!this.optionsLabelPropertyInit() && !this.optionsValuePropertyInput()) {\n                return 'title_i18n';\n            } else {\n                throw new CommonsInternalError(`Invalid use with value (${this.optionsValuePropertyInput()}) and label (${this.optionsLabelPropertyInit()}) property setup.`, {\n                    name: 'DropdownComponentError'\n                });\n            }\n        }\n\n        return this.optionsLabelPropertyInit();\n    });\n    public optionsValueProperty = computed(() => {\n        if (this.optionsLabelTranslate()) {\n            // setup translation properties\n            if (!this.optionsLabelPropertyInit() && !this.optionsValuePropertyInput()) {\n                return 'value';\n            } else if (!this.optionsLabelPropertyInit()) {\n                throw new CommonsInternalError(`Invalid use with value (${this.optionsValuePropertyInput()}) and label (${this.optionsLabelPropertyInit()}) property setup.`, {\n                    name: 'DropdownComponentError'\n                });\n            }\n        }\n\n        return this.optionsValuePropertyInput();\n    });\n\n    public get value() {\n        return this._value;\n    }\n\n    constructor() {\n        effect(() => {\n            this._value = this.ngModelValue();\n        });\n    }\n\n    ngOnInit() {\n        this.setDataProviderAndOptions();\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChangeFn = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchedFn = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        setTimeout(() => this._disabled.set(isDisabled));\n    }\n\n    writeValue(value: any): void {\n        // this check is required because angular in some cases writes null value\n        // before value accessor is initialized\n        // if form control value is of primitive type (ex: enums) then write value is not called (we think)\n        if (value == null && this._value == null) {\n            return;\n        }\n        // write value immediately - it is important so that first select is not triggered!\n        this._value = value;\n        this.adjustValueOnItemsValuePropertyTypeMismatch(true);\n    }\n\n    onDropdownBlur(event: Event) {\n        if (this.isDropdownPanelShown) {\n            // ignore this blur event\n            return;\n        }\n        const primeDropdown = this.primeDropdown();\n        if (this.changeValueOnBlur() && primeDropdown) {\n            this.propagateValueChange(primeDropdown.value);\n        }\n        this.onTouchedFn();\n        this.blur.emit(event);\n    }\n\n    onDropdownChange(event: DropdownChangeEvent) {\n        if (!this.changeValueOnBlur()) {\n            this.propagateValueChange(event.value);\n        }\n    }\n\n    onDropdownPanelShow() {\n        this.isDropdownPanelShown = true;\n    }\n\n    onDropdownPanelHide() {\n        this.isDropdownPanelShown = false;\n    }\n\n    onMultiselectChange(event: MultiSelectChangeEvent) {\n        if (!this.changeValueOnBlur()) {\n            this.propagateValueChange(event.value);\n        }\n    }\n\n    onMultiselectBlur(event: MultiSelectBlurEvent) {\n        this.onTouchedFn();\n        this.blur.emit(event.originalEvent);\n    }\n\n    onMultiselectPanelHide() {\n        const primeMultiselect = this.primeMultiselect();\n        if (this.changeValueOnBlur() && primeMultiselect) {\n            this.propagateValueChange(primeMultiselect.value);\n        }\n    }\n\n    private setDataProviderAndOptions() {\n        const dataProvider = this.dataProvider();\n        const options = this.options();\n        if (dataProvider) {\n            this._loading.set(true);\n            this.dataProviderService = dataProvider.serviceType ? this.injector.get<any>(dataProvider.serviceType) : null;\n\n            toObservable(dataProvider.lookup({limit: 50}, this.dataProviderService))\n                .pipe(\n                    switchMap(items => {\n                        if (this.optionsLabelTranslate()) {\n                            const translationKeys: string[] = items.map(\n                                item =>\n                                    (typeof item === 'object' && this.optionsLabelPropertyInit()\n                                        ? (item[this.optionsLabelPropertyInit() as keyof object] as string)\n                                        : item) as string\n                            );\n\n                            if (translationKeys.length === 0) {\n                                return of([]);\n                            }\n\n                            return this.translate.stream(translationKeys).pipe(\n                                map(translations =>\n                                    items.map(item => {\n                                        if (typeof item === 'object' && this.optionsLabelPropertyInit()) {\n                                            const label = item[this.optionsLabelPropertyInit() as keyof object] as string;\n                                            const translation: string | undefined = translations[label];\n                                            if (translation) {\n                                                return {...item, [this.optionsLabelProperty()!]: translation};\n                                            }\n                                            return {...item};\n                                        } else {\n                                            const translation = translations[item];\n                                            return {\n                                                [this.optionsLabelProperty()!]: translation ?? item,\n                                                [this.optionsValueProperty()!]: item\n                                            };\n                                        }\n                                    })\n                                )\n                            );\n                        } else {\n                            return of(items);\n                        }\n                    }),\n                    takeUntilDestroyed(this.destroyRef)\n                )\n                .subscribe({\n                    next: res => {\n                        this.items.set(res);\n                        this._loading.set(false);\n                        this.selectFirstItem();\n                        this.adjustValueOnItemsValuePropertyTypeMismatch();\n                    },\n                    error: err => {\n                        this._loading.set(false);\n                        const error = fromSubscribeError(err, 'DropdownComponentError');\n                        this.logger.log(error, getErrorLogLevel(error));\n                    }\n                });\n        } else {\n            toObservable(options ?? [])\n                .pipe(takeUntilDestroyed(this.destroyRef))\n                .subscribe({\n                    next: qr => {\n                        this.items.set(qr);\n                        this._loading.set(false);\n                        this.selectFirstItem();\n                        this.adjustValueOnItemsValuePropertyTypeMismatch();\n                    },\n                    error: err => {\n                        this.items.set([]);\n                        this._loading.set(false);\n                        const error = fromSubscribeError(err, 'DropdownComponentError');\n                        this.logger.log(error, getErrorLogLevel(error));\n                    }\n                });\n        }\n    }\n\n    private selectFirstItem() {\n        if (this.firstTimeSettingItems && this.items().length > 0 && this.selectFirstItemInput() && !this._value) {\n            const optionsValueProperty = this.optionsValueProperty();\n            const value = optionsValueProperty ? this.items()[0][optionsValueProperty] : this.items()[0];\n            this.ngModelValue.set(value); // set to write for input\n            this.firstTimeSettingItems = false;\n            this.propagateValueChange(value);\n        }\n    }\n\n    private adjustValueOnItemsValuePropertyTypeMismatch(setNgModelValue = false) {\n        const optionsValueProp = this.optionsValueProperty();\n        if (\n            optionsValueProp &&\n            this._value &&\n            this.items().length > 0 &&\n            this.items()[0][optionsValueProp] != null &&\n            typeof this.items()[0][optionsValueProp] !== typeof this._value\n        ) {\n            // types dont match, search and compare by string\n            const selectedOption = this.items().find(i => i[optionsValueProp] != null && i[optionsValueProp].toString() === this._value.toString());\n            if (selectedOption) {\n                this.ngModelValue.set(selectedOption[optionsValueProp]);\n            } else if (setNgModelValue) {\n                // force write to ngModelValue anyway\n                this.ngModelValue.set(this._value);\n            }\n        } else if (setNgModelValue) {\n            // force write to ngModelValue anyway\n            this.ngModelValue.set(this._value);\n        }\n    }\n\n    private propagateValueChange(value: any) {\n        this._value = value;\n        this.onChangeFn(value);\n        this.valueChange.emit(value);\n    }\n}\n","@if (!multiselect()) {\n    <p-dropdown\n        [ngModel]=\"ngModelValue()\"\n        [placeholder]=\"placeholder()\"\n        [dataKey]=\"optionsTrackProperty()\"\n        [optionLabel]=\"optionsLabelProperty()\"\n        [optionValue]=\"optionsValueProperty()\"\n        [optionDisabled]=\"optionsDisabledProperty()\"\n        [options]=\"items()\"\n        [showClear]=\"showClear()\"\n        [styleClass]=\"className()\"\n        [panelStyleClass]=\"dropdownClassName()\"\n        [disabled]=\"disabled()\"\n        (onBlur)=\"onDropdownBlur($event)\"\n        (onChange)=\"onDropdownChange($event)\"\n        (onShow)=\"onDropdownPanelShow()\"\n        (onHide)=\"onDropdownPanelHide()\"\n        [dropdownIcon]=\"loading() ? 'pi pi-spinner pi-spin' : 'pi pi-chevron-down'\"\n        appendTo=\"body\">\n    </p-dropdown>\n} @else {\n    <p-multiSelect\n        [ngModel]=\"ngModelValue()\"\n        [maxSelectedLabels]=\"1\"\n        [selectedItemsLabel]=\"'mngDropdown.multiselectOverMaxDisplayLimit' | translate\"\n        [placeholder]=\"placeholder()\"\n        [dataKey]=\"optionsTrackProperty()\"\n        [optionLabel]=\"optionsLabelProperty()\"\n        [optionValue]=\"optionsValueProperty()\"\n        [optionDisabled]=\"optionsDisabledProperty()\"\n        [options]=\"items()\"\n        [styleClass]=\"className()\"\n        [panelStyleClass]=\"dropdownClassName()\"\n        [filter]=\"true\"\n        [showToggleAll]=\"false\"\n        [disabled]=\"disabled()\"\n        (onChange)=\"onMultiselectChange($event)\"\n        (onPanelHide)=\"onMultiselectPanelHide()\"\n        (onBlur)=\"onMultiselectBlur($event)\"\n        appendTo=\"body\">\n    </p-multiSelect>\n}\n"]}
@@ -0,0 +1,8 @@
1
+ import { DataProviderInst } from '@mediusinc/mng-commons/core';
2
+ export function dataProvider(type, serviceType) {
3
+ return new DataProviderInst(undefined, serviceType);
4
+ }
5
+ export function dataProviderFromModel(model, serviceType) {
6
+ return new DataProviderInst(model.type, serviceType);
7
+ }
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1mcm9tLXR5cGUtZGF0YS1wcm92aWRlci5mYWN0b3J5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbW9kZWwvc3JjL2RhdGEtcHJvdmlkZXJzL2Jhc2UtZnJvbS10eXBlLWRhdGEtcHJvdmlkZXIuZmFjdG9yeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQVksZ0JBQWdCLEVBQW1CLE1BQU0sNkJBQTZCLENBQUM7QUFXMUYsTUFBTSxVQUFVLFlBQVksQ0FBaUUsSUFBNEIsRUFBRSxXQUEwQjtJQUNqSixPQUFPLElBQUksZ0JBQWdCLENBQTBDLFNBQVMsRUFBRSxXQUEyQixDQUFDLENBQUM7QUFDakgsQ0FBQztBQU9ELE1BQU0sVUFBVSxxQkFBcUIsQ0FDakMsS0FBeUMsRUFDekMsV0FBMEI7SUFFMUIsT0FBTyxJQUFJLGdCQUFnQixDQUFpRCxLQUFLLENBQUMsSUFBd0IsRUFBRSxXQUEyQixDQUFDLENBQUM7QUFDN0ksQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2xhc3NUeXBlLCBEYXRhUHJvdmlkZXJJbnN0LCBTZXJ2aWNlQ2xhc3NUeXBlfSBmcm9tICdAbWVkaXVzaW5jL21uZy1jb21tb25zL2NvcmUnO1xuXG5pbXBvcnQge01vZGVsRGVzY3JpcHRvcn0gZnJvbSAnLi4vZGVzY3JpcHRvcnMvbW9kZWwuZGVzY3JpcHRvcic7XG5pbXBvcnQge1R5cGVEZXNjcmlwdG9yfSBmcm9tICcuLi9kZXNjcmlwdG9ycy90eXBlLmRlc2NyaXB0b3InO1xuXG5leHBvcnQgZnVuY3Rpb24gZGF0YVByb3ZpZGVyPE1vZGVsPigpOiBEYXRhUHJvdmlkZXJJbnN0PE1vZGVsLCB1bmRlZmluZWQsIHVuZGVmaW5lZCwgdW5kZWZpbmVkPjtcbmV4cG9ydCBmdW5jdGlvbiBkYXRhUHJvdmlkZXI8TW9kZWw+KHR5cGU6IFR5cGVEZXNjcmlwdG9yPE1vZGVsPik6IERhdGFQcm92aWRlckluc3Q8TW9kZWwsIHVuZGVmaW5lZCwgdW5kZWZpbmVkLCB1bmRlZmluZWQ+O1xuZXhwb3J0IGZ1bmN0aW9uIGRhdGFQcm92aWRlcjxNb2RlbCwgU2VydmljZSA9IGFueT4oXG4gICAgdHlwZTogVHlwZURlc2NyaXB0b3I8TW9kZWw+LFxuICAgIHNlcnZpY2VUeXBlOiBTZXJ2aWNlQ2xhc3NUeXBlPFNlcnZpY2U+XG4pOiBEYXRhUHJvdmlkZXJJbnN0PE1vZGVsLCBTZXJ2aWNlLCB1bmRlZmluZWQsIFNlcnZpY2VDbGFzc1R5cGU8U2VydmljZT4+O1xuZXhwb3J0IGZ1bmN0aW9uIGRhdGFQcm92aWRlcjxNb2RlbCwgU2VydmljZSA9IGFueSwgU2VydmljZUNsYXNzID0gU2VydmljZUNsYXNzVHlwZTxTZXJ2aWNlPj4odHlwZT86IFR5cGVEZXNjcmlwdG9yPE1vZGVsPiwgc2VydmljZVR5cGU/OiBTZXJ2aWNlQ2xhc3MpIHtcbiAgICByZXR1cm4gbmV3IERhdGFQcm92aWRlckluc3Q8TW9kZWwsIFNlcnZpY2UsIHVuZGVmaW5lZCwgU2VydmljZUNsYXNzPih1bmRlZmluZWQsIHNlcnZpY2VUeXBlIGFzIFNlcnZpY2VDbGFzcyk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBkYXRhUHJvdmlkZXJGcm9tTW9kZWw8TW9kZWwsIE1vZGVsQ2xhc3MgPSBDbGFzc1R5cGU8TW9kZWw+Pihtb2RlbDogTW9kZWxEZXNjcmlwdG9yPE1vZGVsLCBNb2RlbENsYXNzPik6IERhdGFQcm92aWRlckluc3Q8TW9kZWwsIHVuZGVmaW5lZCwgTW9kZWxDbGFzcywgdW5kZWZpbmVkPjtcbmV4cG9ydCBmdW5jdGlvbiBkYXRhUHJvdmlkZXJGcm9tTW9kZWw8TW9kZWwsIFNlcnZpY2UgPSBhbnksIE1vZGVsQ2xhc3MgPSBDbGFzc1R5cGU8TW9kZWw+PihcbiAgICBtb2RlbDogTW9kZWxEZXNjcmlwdG9yPE1vZGVsLCBNb2RlbENsYXNzPixcbiAgICBTZXJ2aWNlQ2xhc3M6IFNlcnZpY2VDbGFzc1R5cGU8U2VydmljZT5cbik6IERhdGFQcm92aWRlckluc3Q8TW9kZWwsIFNlcnZpY2UsIE1vZGVsQ2xhc3MsIFNlcnZpY2VDbGFzc1R5cGU8U2VydmljZT4+O1xuZXhwb3J0IGZ1bmN0aW9uIGRhdGFQcm92aWRlckZyb21Nb2RlbDxNb2RlbCwgU2VydmljZSA9IGFueSwgTW9kZWxDbGFzcyA9IENsYXNzVHlwZTxNb2RlbD4sIFNlcnZpY2VDbGFzcyA9IFNlcnZpY2VDbGFzc1R5cGU8U2VydmljZT4+KFxuICAgIG1vZGVsOiBNb2RlbERlc2NyaXB0b3I8TW9kZWwsIE1vZGVsQ2xhc3M+LFxuICAgIHNlcnZpY2VUeXBlPzogU2VydmljZUNsYXNzXG4pIHtcbiAgICByZXR1cm4gbmV3IERhdGFQcm92aWRlckluc3Q8TW9kZWwsIFNlcnZpY2UsIENsYXNzVHlwZTxNb2RlbD4sIFNlcnZpY2VDbGFzcz4obW9kZWwudHlwZSBhcyBDbGFzc1R5cGU8TW9kZWw+LCBzZXJ2aWNlVHlwZSBhcyBTZXJ2aWNlQ2xhc3MpO1xufVxuIl19
@@ -18,14 +18,11 @@ export class EnumDescriptor {
18
18
  get nameAsValue() {
19
19
  return this._nameAsValue;
20
20
  }
21
- static create(value, type, i18nBaseKey = null, nameAsValue = false) {
22
- return new EnumDescriptor(value, type, i18nBaseKey, nameAsValue);
23
- }
24
21
  }
25
22
  export function enumModel(value, type, i18nBaseKey = null, nameAsValue = false) {
26
- return EnumDescriptor.create(value, type, i18nBaseKey, nameAsValue);
23
+ return new EnumDescriptor(value, type, i18nBaseKey, nameAsValue);
27
24
  }
28
25
  export function enumModelGeneric(type, i18nBaseKey = null, nameAsValue = false) {
29
- return EnumDescriptor.create(undefined, type, i18nBaseKey, nameAsValue);
26
+ return new EnumDescriptor(undefined, type, i18nBaseKey, nameAsValue);
30
27
  }
31
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW51bS5kZXNjcmlwdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbW9kZWwvc3JjL2Rlc2NyaXB0b3JzL2VudW0uZGVzY3JpcHRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQVcsbUJBQW1CLEVBQUMsTUFBTSw2QkFBNkIsQ0FBQztBQUUxRSxNQUFNLE9BQU8sY0FBYztJQU12QixZQUFzQixLQUFXLEVBQUUsSUFBYyxFQUFFLFdBQTJCLEVBQUUsV0FBVyxHQUFHLEtBQUs7UUFDL0YsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUM7UUFDcEIsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUM7UUFDbEIsSUFBSSxDQUFDLFlBQVksR0FBRyxXQUFXLENBQUM7UUFFaEMsSUFBSSxPQUFPLFdBQVcsS0FBSyxXQUFXLEVBQUUsQ0FBQztZQUNyQyxXQUFXLEdBQUcsbUJBQW1CLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDNUMsQ0FBQztRQUNELElBQUksQ0FBQyxZQUFZLEdBQUcsV0FBVyxDQUFDO0lBQ3BDLENBQUM7SUFFRCxJQUFXLElBQUk7UUFDWCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDdEIsQ0FBQztJQUVELElBQVcsV0FBVztRQUNsQixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUM7SUFDN0IsQ0FBQztJQUVELElBQVcsV0FBVztRQUNsQixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUM7SUFDN0IsQ0FBQztJQUVNLE1BQU0sQ0FBQyxNQUFNLENBQU8sS0FBVyxFQUFFLElBQWMsRUFBRSxjQUF5QyxJQUFJLEVBQUUsV0FBVyxHQUFHLEtBQUs7UUFDdEgsT0FBTyxJQUFJLGNBQWMsQ0FBTyxLQUFLLEVBQUUsSUFBSSxFQUFFLFdBQVcsRUFBRSxXQUFXLENBQUMsQ0FBQztJQUMzRSxDQUFDO0NBQ0o7QUFFRCxNQUFNLFVBQVUsU0FBUyxDQUFPLEtBQVcsRUFBRSxJQUFjLEVBQUUsY0FBeUMsSUFBSSxFQUFFLFdBQVcsR0FBRyxLQUFLO0lBQzNILE9BQU8sY0FBYyxDQUFDLE1BQU0sQ0FBTyxLQUFLLEVBQUUsSUFBSSxFQUFFLFdBQVcsRUFBRSxXQUFXLENBQUMsQ0FBQztBQUM5RSxDQUFDO0FBRUQsTUFBTSxVQUFVLGdCQUFnQixDQUFDLElBQWMsRUFBRSxjQUF5QyxJQUFJLEVBQUUsV0FBVyxHQUFHLEtBQUs7SUFDL0csT0FBTyxjQUFjLENBQUMsTUFBTSxDQUFNLFNBQVMsRUFBRSxJQUFJLEVBQUUsV0FBVyxFQUFFLFdBQVcsQ0FBQyxDQUFDO0FBQ2pGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0VudW1UeXBlLCBmaW5kUmVmbGVjdEVudW1OYW1lfSBmcm9tICdAbWVkaXVzaW5jL21uZy1jb21tb25zL2NvcmUnO1xuXG5leHBvcnQgY2xhc3MgRW51bURlc2NyaXB0b3I8RW51bT4ge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgX3ZhbHVlOiBFbnVtO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgX3R5cGU6IEVudW1UeXBlO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgX25hbWVBc1ZhbHVlO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgX2kxOG5CYXNlS2V5OiBzdHJpbmcgfCBudWxsO1xuXG4gICAgcHJvdGVjdGVkIGNvbnN0cnVjdG9yKHZhbHVlOiBFbnVtLCB0eXBlOiBFbnVtVHlwZSwgaTE4bkJhc2VLZXk/OiBzdHJpbmcgfCBudWxsLCBuYW1lQXNWYWx1ZSA9IGZhbHNlKSB7XG4gICAgICAgIHRoaXMuX3ZhbHVlID0gdmFsdWU7XG4gICAgICAgIHRoaXMuX3R5cGUgPSB0eXBlO1xuICAgICAgICB0aGlzLl9uYW1lQXNWYWx1ZSA9IG5hbWVBc1ZhbHVlO1xuXG4gICAgICAgIGlmICh0eXBlb2YgaTE4bkJhc2VLZXkgPT09ICd1bmRlZmluZWQnKSB7XG4gICAgICAgICAgICBpMThuQmFzZUtleSA9IGZpbmRSZWZsZWN0RW51bU5hbWUodHlwZSk7XG4gICAgICAgIH1cbiAgICAgICAgdGhpcy5faTE4bkJhc2VLZXkgPSBpMThuQmFzZUtleTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0IHR5cGUoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLl90eXBlO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXQgaTE4bkJhc2VLZXkoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLl9pMThuQmFzZUtleTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0IG5hbWVBc1ZhbHVlKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5fbmFtZUFzVmFsdWU7XG4gICAgfVxuXG4gICAgcHVibGljIHN0YXRpYyBjcmVhdGU8RW51bT4odmFsdWU6IEVudW0sIHR5cGU6IEVudW1UeXBlLCBpMThuQmFzZUtleTogc3RyaW5nIHwgdW5kZWZpbmVkIHwgbnVsbCA9IG51bGwsIG5hbWVBc1ZhbHVlID0gZmFsc2UpIHtcbiAgICAgICAgcmV0dXJuIG5ldyBFbnVtRGVzY3JpcHRvcjxFbnVtPih2YWx1ZSwgdHlwZSwgaTE4bkJhc2VLZXksIG5hbWVBc1ZhbHVlKTtcbiAgICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBlbnVtTW9kZWw8RW51bT4odmFsdWU6IEVudW0sIHR5cGU6IEVudW1UeXBlLCBpMThuQmFzZUtleTogc3RyaW5nIHwgdW5kZWZpbmVkIHwgbnVsbCA9IG51bGwsIG5hbWVBc1ZhbHVlID0gZmFsc2UpIHtcbiAgICByZXR1cm4gRW51bURlc2NyaXB0b3IuY3JlYXRlPEVudW0+KHZhbHVlLCB0eXBlLCBpMThuQmFzZUtleSwgbmFtZUFzVmFsdWUpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZW51bU1vZGVsR2VuZXJpYyh0eXBlOiBFbnVtVHlwZSwgaTE4bkJhc2VLZXk6IHN0cmluZyB8IHVuZGVmaW5lZCB8IG51bGwgPSBudWxsLCBuYW1lQXNWYWx1ZSA9IGZhbHNlKSB7XG4gICAgcmV0dXJuIEVudW1EZXNjcmlwdG9yLmNyZWF0ZTxhbnk+KHVuZGVmaW5lZCwgdHlwZSwgaTE4bkJhc2VLZXksIG5hbWVBc1ZhbHVlKTtcbn1cbiJdfQ==
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW51bS5kZXNjcmlwdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbW9kZWwvc3JjL2Rlc2NyaXB0b3JzL2VudW0uZGVzY3JpcHRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQVcsbUJBQW1CLEVBQUMsTUFBTSw2QkFBNkIsQ0FBQztBQUUxRSxNQUFNLE9BQU8sY0FBYztJQU12QixZQUFtQixLQUFXLEVBQUUsSUFBYyxFQUFFLFdBQTJCLEVBQUUsV0FBVyxHQUFHLEtBQUs7UUFDNUYsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUM7UUFDcEIsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUM7UUFDbEIsSUFBSSxDQUFDLFlBQVksR0FBRyxXQUFXLENBQUM7UUFFaEMsSUFBSSxPQUFPLFdBQVcsS0FBSyxXQUFXLEVBQUUsQ0FBQztZQUNyQyxXQUFXLEdBQUcsbUJBQW1CLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDNUMsQ0FBQztRQUNELElBQUksQ0FBQyxZQUFZLEdBQUcsV0FBVyxDQUFDO0lBQ3BDLENBQUM7SUFFRCxJQUFXLElBQUk7UUFDWCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDdEIsQ0FBQztJQUVELElBQVcsV0FBVztRQUNsQixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUM7SUFDN0IsQ0FBQztJQUVELElBQVcsV0FBVztRQUNsQixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUM7SUFDN0IsQ0FBQztDQUNKO0FBRUQsTUFBTSxVQUFVLFNBQVMsQ0FBTyxLQUFXLEVBQUUsSUFBYyxFQUFFLGNBQXlDLElBQUksRUFBRSxXQUFXLEdBQUcsS0FBSztJQUMzSCxPQUFPLElBQUksY0FBYyxDQUFPLEtBQUssRUFBRSxJQUFJLEVBQUUsV0FBVyxFQUFFLFdBQVcsQ0FBQyxDQUFDO0FBQzNFLENBQUM7QUFFRCxNQUFNLFVBQVUsZ0JBQWdCLENBQUMsSUFBYyxFQUFFLGNBQXlDLElBQUksRUFBRSxXQUFXLEdBQUcsS0FBSztJQUMvRyxPQUFPLElBQUksY0FBYyxDQUFNLFNBQVMsRUFBRSxJQUFJLEVBQUUsV0FBVyxFQUFFLFdBQVcsQ0FBQyxDQUFDO0FBQzlFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0VudW1UeXBlLCBmaW5kUmVmbGVjdEVudW1OYW1lfSBmcm9tICdAbWVkaXVzaW5jL21uZy1jb21tb25zL2NvcmUnO1xuXG5leHBvcnQgY2xhc3MgRW51bURlc2NyaXB0b3I8RW51bT4ge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgX3ZhbHVlOiBFbnVtO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgX3R5cGU6IEVudW1UeXBlO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgX25hbWVBc1ZhbHVlO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgX2kxOG5CYXNlS2V5OiBzdHJpbmcgfCBudWxsO1xuXG4gICAgcHVibGljIGNvbnN0cnVjdG9yKHZhbHVlOiBFbnVtLCB0eXBlOiBFbnVtVHlwZSwgaTE4bkJhc2VLZXk/OiBzdHJpbmcgfCBudWxsLCBuYW1lQXNWYWx1ZSA9IGZhbHNlKSB7XG4gICAgICAgIHRoaXMuX3ZhbHVlID0gdmFsdWU7XG4gICAgICAgIHRoaXMuX3R5cGUgPSB0eXBlO1xuICAgICAgICB0aGlzLl9uYW1lQXNWYWx1ZSA9IG5hbWVBc1ZhbHVlO1xuXG4gICAgICAgIGlmICh0eXBlb2YgaTE4bkJhc2VLZXkgPT09ICd1bmRlZmluZWQnKSB7XG4gICAgICAgICAgICBpMThuQmFzZUtleSA9IGZpbmRSZWZsZWN0RW51bU5hbWUodHlwZSk7XG4gICAgICAgIH1cbiAgICAgICAgdGhpcy5faTE4bkJhc2VLZXkgPSBpMThuQmFzZUtleTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0IHR5cGUoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLl90eXBlO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXQgaTE4bkJhc2VLZXkoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLl9pMThuQmFzZUtleTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0IG5hbWVBc1ZhbHVlKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5fbmFtZUFzVmFsdWU7XG4gICAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gZW51bU1vZGVsPEVudW0+KHZhbHVlOiBFbnVtLCB0eXBlOiBFbnVtVHlwZSwgaTE4bkJhc2VLZXk6IHN0cmluZyB8IHVuZGVmaW5lZCB8IG51bGwgPSBudWxsLCBuYW1lQXNWYWx1ZSA9IGZhbHNlKSB7XG4gICAgcmV0dXJuIG5ldyBFbnVtRGVzY3JpcHRvcjxFbnVtPih2YWx1ZSwgdHlwZSwgaTE4bkJhc2VLZXksIG5hbWVBc1ZhbHVlKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGVudW1Nb2RlbEdlbmVyaWModHlwZTogRW51bVR5cGUsIGkxOG5CYXNlS2V5OiBzdHJpbmcgfCB1bmRlZmluZWQgfCBudWxsID0gbnVsbCwgbmFtZUFzVmFsdWUgPSBmYWxzZSkge1xuICAgIHJldHVybiBuZXcgRW51bURlc2NyaXB0b3I8YW55Pih1bmRlZmluZWQsIHR5cGUsIGkxOG5CYXNlS2V5LCBuYW1lQXNWYWx1ZSk7XG59XG4iXX0=