@acorex/components 6.0.15 → 6.1.0

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 (213) hide show
  1. package/alert/src/alert.component.d.ts +4 -4
  2. package/avatar/src/avatar.component.d.ts +6 -9
  3. package/badge/src/badge.component.d.ts +1 -1
  4. package/breadcrumbs/src/breadcrumbs-item.component.d.ts +4 -4
  5. package/button/src/button-group.component.d.ts +4 -4
  6. package/button/src/button-item.class.d.ts +2 -1
  7. package/button/src/button-item.component.d.ts +4 -4
  8. package/button/src/button.component.d.ts +3 -1
  9. package/calendar/src/calendar.component.d.ts +20 -20
  10. package/color-picker/src/color-picker.component.d.ts +14 -14
  11. package/common/src/auto-focus.directive.d.ts +2 -1
  12. package/common/src/events.class.d.ts +1 -1
  13. package/date-picker/src/datepicker.component.d.ts +23 -23
  14. package/decorators/public-api.d.ts +1 -0
  15. package/decorators/src/decorators.module.d.ts +3 -2
  16. package/decorators/src/text.component.d.ts +9 -0
  17. package/dialog/src/dialog.service.d.ts +3 -1
  18. package/dropdown/src/dropdown-panel.component.d.ts +1 -0
  19. package/dropdown/src/dropdown.module.d.ts +7 -5
  20. package/esm2020/action-sheet/src/action-sheet-item.component.mjs +1 -1
  21. package/esm2020/alert/src/alert.component.mjs +4 -8
  22. package/esm2020/avatar/src/avatar.component.mjs +14 -21
  23. package/esm2020/badge/src/badge.component.mjs +3 -3
  24. package/esm2020/button/src/button-item.class.mjs +1 -1
  25. package/esm2020/button/src/button-item.component.mjs +3 -3
  26. package/esm2020/button/src/button.component.mjs +9 -6
  27. package/esm2020/calendar/src/calendar.component.mjs +7 -4
  28. package/esm2020/collapse/src/collapse.component.mjs +3 -3
  29. package/esm2020/color-palette/src/color-palette-input.component.mjs +1 -1
  30. package/esm2020/color-picker/src/color-picker.component.mjs +1 -1
  31. package/esm2020/common/src/auto-focus.directive.mjs +7 -3
  32. package/esm2020/common/src/events.class.mjs +1 -1
  33. package/esm2020/data-pager/src/data-pager-next-buttons.components.mjs +1 -1
  34. package/esm2020/data-pager/src/data-pager-numeric-selector.component.mjs +1 -1
  35. package/esm2020/data-pager/src/data-pager-pagesize-dropdown.component.mjs +1 -1
  36. package/esm2020/data-pager/src/data-pager-prev-buttons.component.mjs +1 -1
  37. package/esm2020/date-picker/src/datepicker.component.mjs +9 -7
  38. package/esm2020/decorators/public-api.mjs +2 -1
  39. package/esm2020/decorators/src/decorators.module.mjs +8 -4
  40. package/esm2020/decorators/src/icon.component.mjs +3 -2
  41. package/esm2020/decorators/src/text.component.mjs +21 -0
  42. package/esm2020/dialog/src/dialog.class.mjs +1 -1
  43. package/esm2020/dialog/src/dialog.component.mjs +1 -1
  44. package/esm2020/dialog/src/dialog.service.mjs +11 -7
  45. package/esm2020/dropdown/src/dropdown-panel.component.mjs +14 -3
  46. package/esm2020/dropdown/src/dropdown.module.mjs +6 -4
  47. package/esm2020/form/src/form.component.mjs +10 -3
  48. package/esm2020/form/src/validation-summary.component.mjs +1 -1
  49. package/esm2020/image/src/image.component.mjs +36 -9
  50. package/esm2020/menu/src/menu.component.mjs +5 -3
  51. package/esm2020/number-box/src/number-box.component.mjs +10 -4
  52. package/esm2020/password-box/src/password-box.component.mjs +11 -5
  53. package/esm2020/popover/src/popover.component.mjs +9 -18
  54. package/esm2020/popup/src/popup.component.mjs +14 -6
  55. package/esm2020/popup/src/popup.module.mjs +4 -3
  56. package/esm2020/popup/src/popup.service.mjs +8 -4
  57. package/esm2020/search-box/src/search-box.component.mjs +1 -1
  58. package/esm2020/select-box/src/selectbox.component.mjs +3 -3
  59. package/esm2020/textarea/src/textarea.component.mjs +11 -5
  60. package/esm2020/textbox/public-api.mjs +2 -1
  61. package/esm2020/textbox/src/mask-settings.directive.mjs +23 -0
  62. package/esm2020/textbox/src/textbox.component.mjs +46 -9
  63. package/esm2020/textbox/src/textbox.module.mjs +7 -10
  64. package/esm2020/time-box/src/time-box.component.mjs +10 -4
  65. package/esm2020/toast/src/toast.component.mjs +1 -1
  66. package/esm2020/uploader/src/uploader.component.mjs +19 -6
  67. package/fesm2015/acorex-components-action-sheet.mjs +1 -1
  68. package/fesm2015/acorex-components-action-sheet.mjs.map +1 -1
  69. package/fesm2015/acorex-components-alert.mjs +3 -7
  70. package/fesm2015/acorex-components-alert.mjs.map +1 -1
  71. package/fesm2015/acorex-components-avatar.mjs +13 -20
  72. package/fesm2015/acorex-components-avatar.mjs.map +1 -1
  73. package/fesm2015/acorex-components-badge.mjs +2 -2
  74. package/fesm2015/acorex-components-badge.mjs.map +1 -1
  75. package/fesm2015/acorex-components-button.mjs +10 -7
  76. package/fesm2015/acorex-components-button.mjs.map +1 -1
  77. package/fesm2015/acorex-components-calendar.mjs +5 -3
  78. package/fesm2015/acorex-components-calendar.mjs.map +1 -1
  79. package/fesm2015/acorex-components-collapse.mjs +2 -2
  80. package/fesm2015/acorex-components-collapse.mjs.map +1 -1
  81. package/fesm2015/acorex-components-color-palette.mjs +1 -1
  82. package/fesm2015/acorex-components-color-palette.mjs.map +1 -1
  83. package/fesm2015/acorex-components-color-picker.mjs +1 -1
  84. package/fesm2015/acorex-components-color-picker.mjs.map +1 -1
  85. package/fesm2015/acorex-components-common.mjs +6 -2
  86. package/fesm2015/acorex-components-common.mjs.map +1 -1
  87. package/fesm2015/acorex-components-data-pager.mjs +4 -4
  88. package/fesm2015/acorex-components-data-pager.mjs.map +1 -1
  89. package/fesm2015/acorex-components-date-picker.mjs +10 -7
  90. package/fesm2015/acorex-components-date-picker.mjs.map +1 -1
  91. package/fesm2015/acorex-components-decorators.mjs +27 -5
  92. package/fesm2015/acorex-components-decorators.mjs.map +1 -1
  93. package/fesm2015/acorex-components-dialog.mjs +11 -7
  94. package/fesm2015/acorex-components-dialog.mjs.map +1 -1
  95. package/fesm2015/acorex-components-dropdown.mjs +18 -5
  96. package/fesm2015/acorex-components-dropdown.mjs.map +1 -1
  97. package/fesm2015/acorex-components-form.mjs +10 -3
  98. package/fesm2015/acorex-components-form.mjs.map +1 -1
  99. package/fesm2015/acorex-components-image.mjs +35 -8
  100. package/fesm2015/acorex-components-image.mjs.map +1 -1
  101. package/fesm2015/acorex-components-menu.mjs +5 -3
  102. package/fesm2015/acorex-components-menu.mjs.map +1 -1
  103. package/fesm2015/acorex-components-number-box.mjs +10 -4
  104. package/fesm2015/acorex-components-number-box.mjs.map +1 -1
  105. package/fesm2015/acorex-components-password-box.mjs +10 -4
  106. package/fesm2015/acorex-components-password-box.mjs.map +1 -1
  107. package/fesm2015/acorex-components-popover.mjs +9 -18
  108. package/fesm2015/acorex-components-popover.mjs.map +1 -1
  109. package/fesm2015/acorex-components-popup.mjs +23 -11
  110. package/fesm2015/acorex-components-popup.mjs.map +1 -1
  111. package/fesm2015/acorex-components-search-box.mjs +1 -1
  112. package/fesm2015/acorex-components-search-box.mjs.map +1 -1
  113. package/fesm2015/acorex-components-select-box.mjs +2 -2
  114. package/fesm2015/acorex-components-select-box.mjs.map +1 -1
  115. package/fesm2015/acorex-components-textarea.mjs +10 -4
  116. package/fesm2015/acorex-components-textarea.mjs.map +1 -1
  117. package/fesm2015/acorex-components-textbox.mjs +71 -18
  118. package/fesm2015/acorex-components-textbox.mjs.map +1 -1
  119. package/fesm2015/acorex-components-time-box.mjs +10 -4
  120. package/fesm2015/acorex-components-time-box.mjs.map +1 -1
  121. package/fesm2015/acorex-components-toast.mjs +1 -1
  122. package/fesm2015/acorex-components-toast.mjs.map +1 -1
  123. package/fesm2015/acorex-components-uploader.mjs +18 -5
  124. package/fesm2015/acorex-components-uploader.mjs.map +1 -1
  125. package/fesm2020/acorex-components-action-sheet.mjs +1 -1
  126. package/fesm2020/acorex-components-action-sheet.mjs.map +1 -1
  127. package/fesm2020/acorex-components-alert.mjs +3 -7
  128. package/fesm2020/acorex-components-alert.mjs.map +1 -1
  129. package/fesm2020/acorex-components-avatar.mjs +13 -20
  130. package/fesm2020/acorex-components-avatar.mjs.map +1 -1
  131. package/fesm2020/acorex-components-badge.mjs +2 -2
  132. package/fesm2020/acorex-components-badge.mjs.map +1 -1
  133. package/fesm2020/acorex-components-button.mjs +10 -7
  134. package/fesm2020/acorex-components-button.mjs.map +1 -1
  135. package/fesm2020/acorex-components-calendar.mjs +5 -3
  136. package/fesm2020/acorex-components-calendar.mjs.map +1 -1
  137. package/fesm2020/acorex-components-collapse.mjs +2 -2
  138. package/fesm2020/acorex-components-collapse.mjs.map +1 -1
  139. package/fesm2020/acorex-components-color-palette.mjs +1 -1
  140. package/fesm2020/acorex-components-color-palette.mjs.map +1 -1
  141. package/fesm2020/acorex-components-color-picker.mjs +1 -1
  142. package/fesm2020/acorex-components-color-picker.mjs.map +1 -1
  143. package/fesm2020/acorex-components-common.mjs +6 -2
  144. package/fesm2020/acorex-components-common.mjs.map +1 -1
  145. package/fesm2020/acorex-components-data-pager.mjs +4 -4
  146. package/fesm2020/acorex-components-data-pager.mjs.map +1 -1
  147. package/fesm2020/acorex-components-date-picker.mjs +9 -7
  148. package/fesm2020/acorex-components-date-picker.mjs.map +1 -1
  149. package/fesm2020/acorex-components-decorators.mjs +27 -5
  150. package/fesm2020/acorex-components-decorators.mjs.map +1 -1
  151. package/fesm2020/acorex-components-dialog.mjs +11 -7
  152. package/fesm2020/acorex-components-dialog.mjs.map +1 -1
  153. package/fesm2020/acorex-components-dropdown.mjs +18 -5
  154. package/fesm2020/acorex-components-dropdown.mjs.map +1 -1
  155. package/fesm2020/acorex-components-form.mjs +10 -3
  156. package/fesm2020/acorex-components-form.mjs.map +1 -1
  157. package/fesm2020/acorex-components-image.mjs +35 -8
  158. package/fesm2020/acorex-components-image.mjs.map +1 -1
  159. package/fesm2020/acorex-components-menu.mjs +5 -3
  160. package/fesm2020/acorex-components-menu.mjs.map +1 -1
  161. package/fesm2020/acorex-components-number-box.mjs +10 -4
  162. package/fesm2020/acorex-components-number-box.mjs.map +1 -1
  163. package/fesm2020/acorex-components-password-box.mjs +10 -4
  164. package/fesm2020/acorex-components-password-box.mjs.map +1 -1
  165. package/fesm2020/acorex-components-popover.mjs +8 -17
  166. package/fesm2020/acorex-components-popover.mjs.map +1 -1
  167. package/fesm2020/acorex-components-popup.mjs +23 -11
  168. package/fesm2020/acorex-components-popup.mjs.map +1 -1
  169. package/fesm2020/acorex-components-search-box.mjs +1 -1
  170. package/fesm2020/acorex-components-search-box.mjs.map +1 -1
  171. package/fesm2020/acorex-components-select-box.mjs +2 -2
  172. package/fesm2020/acorex-components-select-box.mjs.map +1 -1
  173. package/fesm2020/acorex-components-textarea.mjs +10 -4
  174. package/fesm2020/acorex-components-textarea.mjs.map +1 -1
  175. package/fesm2020/acorex-components-textbox.mjs +71 -18
  176. package/fesm2020/acorex-components-textbox.mjs.map +1 -1
  177. package/fesm2020/acorex-components-time-box.mjs +10 -4
  178. package/fesm2020/acorex-components-time-box.mjs.map +1 -1
  179. package/fesm2020/acorex-components-toast.mjs +1 -1
  180. package/fesm2020/acorex-components-toast.mjs.map +1 -1
  181. package/fesm2020/acorex-components-uploader.mjs +18 -5
  182. package/fesm2020/acorex-components-uploader.mjs.map +1 -1
  183. package/form/src/form.component.d.ts +2 -0
  184. package/image/src/image.component.d.ts +16 -7
  185. package/menu/src/menu.component.d.ts +1 -0
  186. package/mixin/src/base-components.class.d.ts +1 -1
  187. package/mixin/src/base-menu-mixin.class.d.ts +4 -4
  188. package/mixin/src/button-mixin.class.d.ts +1 -1
  189. package/mixin/src/clickable-mixin.class.d.ts +1 -1
  190. package/mixin/src/color-look-mixing.class.d.ts +1 -1
  191. package/mixin/src/datalist-component.class.d.ts +9 -9
  192. package/mixin/src/dropdown-mixin.class.d.ts +1 -1
  193. package/mixin/src/interactive-mixin.class.d.ts +3 -3
  194. package/mixin/src/loading-mixin.class.d.ts +1 -1
  195. package/mixin/src/mixin.class.d.ts +42 -42
  196. package/mixin/src/page-component.class.d.ts +1 -1
  197. package/mixin/src/selection-component.class.d.ts +1 -1
  198. package/mixin/src/sizable-mixin.class.d.ts +1 -1
  199. package/mixin/src/textbox-mixin.class.d.ts +3 -3
  200. package/mixin/src/value-mixin.class.d.ts +7 -7
  201. package/number-box/src/number-box.component.d.ts +2 -0
  202. package/package.json +1 -1
  203. package/password-box/src/password-box.component.d.ts +3 -1
  204. package/popover/src/popover.component.d.ts +2 -2
  205. package/popup/src/popup.module.d.ts +7 -6
  206. package/tabs/src/tab-item.component.d.ts +1 -1
  207. package/textarea/src/textarea.component.d.ts +2 -0
  208. package/textbox/public-api.d.ts +1 -0
  209. package/textbox/src/mask-settings.directive.d.ts +8 -0
  210. package/textbox/src/textbox.component.d.ts +6 -1
  211. package/textbox/src/textbox.module.d.ts +6 -6
  212. package/time-box/src/time-box.component.d.ts +2 -0
  213. package/uploader/src/uploader.component.d.ts +5 -1
@@ -5,19 +5,21 @@ import { AXButtonModule } from '@acorex/components/button';
5
5
  import { AXDecoratorModule } from '@acorex/components/decorators';
6
6
  import { AXPopoverModule } from '@acorex/components/popover';
7
7
  import { AXDropdownPanelComponent } from './dropdown-panel.component';
8
+ import { A11yModule } from '@angular/cdk/a11y';
9
+ import { AXCommonModule } from '@acorex/components/common';
8
10
  import * as i0 from "@angular/core";
9
11
  export class AXDropdownModule {
10
12
  }
11
13
  AXDropdownModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXDropdownModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
12
- AXDropdownModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.2", ngImport: i0, type: AXDropdownModule, declarations: [AXDropdownPanelComponent], imports: [CommonModule, AXButtonModule, OverlayModule, AXDecoratorModule, AXPopoverModule], exports: [AXDropdownPanelComponent] });
13
- AXDropdownModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXDropdownModule, imports: [CommonModule, AXButtonModule, OverlayModule, AXDecoratorModule, AXPopoverModule] });
14
+ AXDropdownModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.2", ngImport: i0, type: AXDropdownModule, declarations: [AXDropdownPanelComponent], imports: [CommonModule, AXCommonModule, A11yModule, AXButtonModule, OverlayModule, AXDecoratorModule, AXPopoverModule], exports: [AXDropdownPanelComponent] });
15
+ AXDropdownModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXDropdownModule, imports: [CommonModule, AXCommonModule, A11yModule, AXButtonModule, OverlayModule, AXDecoratorModule, AXPopoverModule] });
14
16
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXDropdownModule, decorators: [{
15
17
  type: NgModule,
16
18
  args: [{
17
- imports: [CommonModule, AXButtonModule, OverlayModule, AXDecoratorModule, AXPopoverModule],
19
+ imports: [CommonModule, AXCommonModule, A11yModule, AXButtonModule, OverlayModule, AXDecoratorModule, AXPopoverModule],
18
20
  exports: [AXDropdownPanelComponent],
19
21
  declarations: [AXDropdownPanelComponent],
20
22
  providers: [],
21
23
  }]
22
24
  }] });
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWNvcmV4L2NvbXBvbmVudHMvZHJvcGRvd24vc3JjL2Ryb3Bkb3duLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDckQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzNELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7QUFRdEUsTUFBTSxPQUFPLGdCQUFnQjs7NkdBQWhCLGdCQUFnQjs4R0FBaEIsZ0JBQWdCLGlCQUhULHdCQUF3QixhQUY5QixZQUFZLEVBQUUsY0FBYyxFQUFFLGFBQWEsRUFBRyxpQkFBaUIsRUFBRSxlQUFlLGFBQy9FLHdCQUF3Qjs4R0FJMUIsZ0JBQWdCLFlBTGYsWUFBWSxFQUFFLGNBQWMsRUFBRSxhQUFhLEVBQUcsaUJBQWlCLEVBQUUsZUFBZTsyRkFLakYsZ0JBQWdCO2tCQU41QixRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxjQUFjLEVBQUUsYUFBYSxFQUFHLGlCQUFpQixFQUFFLGVBQWUsQ0FBQztvQkFDM0YsT0FBTyxFQUFFLENBQUUsd0JBQXdCLENBQUM7b0JBQ3BDLFlBQVksRUFBRSxDQUFFLHdCQUF3QixDQUFDO29CQUN6QyxTQUFTLEVBQUUsRUFBRTtpQkFDaEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPdmVybGF5TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBWEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9idXR0b24nO1xyXG5pbXBvcnQgeyBBWERlY29yYXRvck1vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9kZWNvcmF0b3JzJztcclxuaW1wb3J0IHsgQVhQb3BvdmVyTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL3BvcG92ZXInO1xyXG5pbXBvcnQgeyBBWERyb3Bkb3duUGFuZWxDb21wb25lbnQgfSBmcm9tICcuL2Ryb3Bkb3duLXBhbmVsLmNvbXBvbmVudCc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgQVhCdXR0b25Nb2R1bGUsIE92ZXJsYXlNb2R1bGUsICBBWERlY29yYXRvck1vZHVsZSwgQVhQb3BvdmVyTW9kdWxlXSxcclxuICAgIGV4cG9ydHM6IFsgQVhEcm9wZG93blBhbmVsQ29tcG9uZW50XSxcclxuICAgIGRlY2xhcmF0aW9uczogWyBBWERyb3Bkb3duUGFuZWxDb21wb25lbnRdLFxyXG4gICAgcHJvdmlkZXJzOiBbXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIEFYRHJvcGRvd25Nb2R1bGUgeyB9XHJcbiJdfQ==
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWNvcmV4L2NvbXBvbmVudHMvZHJvcGRvd24vc3JjL2Ryb3Bkb3duLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDckQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzNELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUN0RSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDL0MsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLDJCQUEyQixDQUFDOztBQVEzRCxNQUFNLE9BQU8sZ0JBQWdCOzs2R0FBaEIsZ0JBQWdCOzhHQUFoQixnQkFBZ0IsaUJBSFYsd0JBQXdCLGFBRjdCLFlBQVksRUFBQyxjQUFjLEVBQUUsVUFBVSxFQUFFLGNBQWMsRUFBRSxhQUFhLEVBQUUsaUJBQWlCLEVBQUUsZUFBZSxhQUMxRyx3QkFBd0I7OEdBSXpCLGdCQUFnQixZQUxmLFlBQVksRUFBQyxjQUFjLEVBQUUsVUFBVSxFQUFFLGNBQWMsRUFBRSxhQUFhLEVBQUUsaUJBQWlCLEVBQUUsZUFBZTsyRkFLM0csZ0JBQWdCO2tCQU41QixRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBQyxjQUFjLEVBQUUsVUFBVSxFQUFFLGNBQWMsRUFBRSxhQUFhLEVBQUUsaUJBQWlCLEVBQUUsZUFBZSxDQUFDO29CQUNySCxPQUFPLEVBQUUsQ0FBQyx3QkFBd0IsQ0FBQztvQkFDbkMsWUFBWSxFQUFFLENBQUMsd0JBQXdCLENBQUM7b0JBQ3hDLFNBQVMsRUFBRSxFQUFFO2lCQUNoQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE92ZXJsYXlNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEFYQnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2J1dHRvbic7XHJcbmltcG9ydCB7IEFYRGVjb3JhdG9yTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2RlY29yYXRvcnMnO1xyXG5pbXBvcnQgeyBBWFBvcG92ZXJNb2R1bGUgfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMvcG9wb3Zlcic7XHJcbmltcG9ydCB7IEFYRHJvcGRvd25QYW5lbENvbXBvbmVudCB9IGZyb20gJy4vZHJvcGRvd24tcGFuZWwuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQTExeU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9hMTF5JztcclxuaW1wb3J0IHsgQVhDb21tb25Nb2R1bGUgfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMvY29tbW9uJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLEFYQ29tbW9uTW9kdWxlLCBBMTF5TW9kdWxlLCBBWEJ1dHRvbk1vZHVsZSwgT3ZlcmxheU1vZHVsZSwgQVhEZWNvcmF0b3JNb2R1bGUsIEFYUG9wb3Zlck1vZHVsZV0sXHJcbiAgICBleHBvcnRzOiBbQVhEcm9wZG93blBhbmVsQ29tcG9uZW50XSxcclxuICAgIGRlY2xhcmF0aW9uczogW0FYRHJvcGRvd25QYW5lbENvbXBvbmVudF0sXHJcbiAgICBwcm92aWRlcnM6IFtdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQVhEcm9wZG93bk1vZHVsZSB7IH1cclxuIl19
@@ -38,6 +38,13 @@ export class AXFormComponent extends AXBaseComponentMixin {
38
38
  },
39
39
  });
40
40
  }
41
+ _handleSubmit(e) {
42
+ e.preventDefault();
43
+ this.validate();
44
+ }
45
+ _handleReset(e) {
46
+ this.clear();
47
+ }
41
48
  _getComponenets() {
42
49
  return Array.from(this._getHostElement().querySelectorAll('[ax-form-input="true"]')).map((c) => c.__axContext__);
43
50
  }
@@ -130,12 +137,12 @@ export class AXFormComponent extends AXBaseComponentMixin {
130
137
  }
131
138
  }
132
139
  AXFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXFormComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
133
- AXFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: AXFormComponent, selector: "ax-form", inputs: { updateOn: "updateOn", validateInitValues: "validateInitValues" }, outputs: { onValidate: "onValidate", updateOnChange: "updateOnChange" }, usesInheritance: true, ngImport: i0, template: '<form ><ng-content></ng-content></form>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
140
+ AXFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: AXFormComponent, selector: "ax-form", inputs: { updateOn: "updateOn", validateInitValues: "validateInitValues" }, outputs: { onValidate: "onValidate", updateOnChange: "updateOnChange" }, usesInheritance: true, ngImport: i0, template: '<form (submit)="_handleSubmit($event)" (reset)="_handleReset($event)"><ng-content></ng-content></form>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
134
141
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXFormComponent, decorators: [{
135
142
  type: Component,
136
143
  args: [{
137
144
  selector: 'ax-form',
138
- template: '<form ><ng-content></ng-content></form>',
145
+ template: '<form (submit)="_handleSubmit($event)" (reset)="_handleReset($event)"><ng-content></ng-content></form>',
139
146
  encapsulation: ViewEncapsulation.None,
140
147
  changeDetection: ChangeDetectionStrategy.OnPush,
141
148
  }]
@@ -148,4 +155,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
148
155
  }], validateInitValues: [{
149
156
  type: Input
150
157
  }] } });
151
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/form/src/form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';\r\nimport { AXEvent } from '@acorex/components/common';\r\nimport { AXFormValidationResult } from './validation.class';\r\nimport { AXBaseComponentMixin } from '@acorex/components/mixin';\r\nimport { Subscription } from 'rxjs';\r\n\r\n/**\r\n*  Contains native event\r\n* @category Events\r\n*/\r\nexport class AXFormValidationEvent extends AXEvent {\r\n    result: AXFormValidationResult;\r\n}\r\n\r\n/**\r\n*  Contains native event\r\n* @category Events\r\n*/\r\nexport type AXFormUpdateOn = 'change' | 'blur' | 'manual';\r\n\r\n\r\n/**\r\n * The Button is a component which detects user interaction and triggers a corresponding event\r\n *\r\n * @category Components\r\n */\r\n@Component({\r\n    selector: 'ax-form',\r\n    template: '<form  ><ng-content></ng-content></form>',\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class AXFormComponent extends AXBaseComponentMixin {\r\n\r\n\r\n    @Output()\r\n    onValidate: EventEmitter<AXFormValidationEvent> = new EventEmitter<AXFormValidationEvent>();\r\n\r\n\r\n    @Output()\r\n    updateOnChange: EventEmitter<AXFormUpdateOn> = new EventEmitter<AXFormUpdateOn>();\r\n\r\n    private _updateOn: AXFormUpdateOn = 'blur';\r\n    @Input()\r\n    public get updateOn(): AXFormUpdateOn {\r\n        return this._updateOn;\r\n    }\r\n    public set updateOn(v: AXFormUpdateOn) {\r\n        this._setOption({\r\n            name: 'updateOn',\r\n            value: v,\r\n            afterCallback: (oldValue?, newValue?) => {\r\n                this._bindEvents();\r\n            },\r\n        })\r\n    }\r\n\r\n    @Input()\r\n    validateInitValues: boolean = false;\r\n\r\n\r\n    private _observer: MutationObserver;\r\n    private _subs: Subscription[] = [];\r\n\r\n\r\n\r\n    /**\r\n    *  @ignore\r\n    */\r\n    constructor(\r\n        elementRef: ElementRef,\r\n        private cdr: ChangeDetectorRef\r\n    ) {\r\n        super(elementRef, cdr);\r\n    }\r\n\r\n    private _getComponenets() {\r\n        return Array.from(\r\n            this._getHostElement().querySelectorAll('[ax-form-input=\"true\"]')\r\n        ).map((c) => (c as any).__axContext__);\r\n    }\r\n\r\n    onViewInit(): void {\r\n        if (this.validateInitValues) {\r\n            this._validateInitValues();\r\n        }\r\n        this._bindEvents();\r\n\r\n        const config = { attributes: false, childList: true, subtree: true };\r\n        const callback = (mutationList, observer) => {\r\n            this._bindEvents();\r\n        };\r\n\r\n        // Create an observer instance linked to the callback function\r\n        this._observer = new MutationObserver(callback);\r\n        this._observer.observe(this._getHostElement(), config);\r\n    }\r\n\r\n    private _bindEvents() {\r\n        this._clearSubs();\r\n        const widgets = this._getComponenets()\r\n        //\r\n        widgets.forEach(w => {\r\n            if (this.updateOn == 'change') {\r\n                this._subs.push(w.onValueChanged?.subscribe(v => {\r\n                    w.validate();\r\n                }));\r\n            }\r\n            else if (this.updateOn == 'blur') {\r\n                this._subs.push(w.onBlur?.subscribe(v => {\r\n                    w.validate();\r\n                }));\r\n            }\r\n        })\r\n    }\r\n\r\n    private _clearSubs() {\r\n        this._subs.forEach(c => c.unsubscribe())\r\n        this._subs = [];\r\n    }\r\n\r\n    private _validateInitValues() {\r\n        this._getComponenets()\r\n            .filter(c => c['value'])\r\n            .forEach(c => c.validate());\r\n    }\r\n\r\n\r\n\r\n    validate(...args: string[]): Promise<AXFormValidationResult> {\r\n        const widgets = this._getComponenets();\r\n        if (widgets.length === 0) {\r\n            this._emitOnValidateEvent({ result: true });\r\n            return Promise.resolve({ result: true });\r\n        }\r\n        //\r\n        return new Promise<AXFormValidationResult>((resolve, reject) => {\r\n            Promise.all(widgets\r\n                .filter(c => (args == null || args.length == 0) || args.includes(c.name))\r\n                .map((c) => c.validate()))\r\n                .then((rules: any) => {\r\n                    const failed = rules.filter((c: any) => !c.result);\r\n                    if (failed.length) {\r\n                        this._emitOnValidateEvent({\r\n                            result: false,\r\n                            items: failed\r\n                        });\r\n                        resolve({\r\n                            result: false,\r\n                            items: failed\r\n                        });\r\n                    }\r\n                    else {\r\n                        this._emitOnValidateEvent({ result: true });\r\n                        resolve({ result: true });\r\n                    }\r\n                });\r\n        });\r\n    }\r\n\r\n    private _emitOnValidateEvent(e: AXFormValidationResult) {\r\n        this.onValidate.emit({\r\n            component: this,\r\n            result: e,\r\n            htmlElement: this._getHostElement(),\r\n        })\r\n    }\r\n\r\n    clear() {\r\n        const widgets = this._getComponenets();\r\n        widgets.forEach(w => {\r\n            w.clear();\r\n        });\r\n    }\r\n\r\n    onDestroy(): void {\r\n        this._observer.disconnect();\r\n        this._observer = null;\r\n        this._clearSubs();\r\n    }\r\n}"]}
158
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/form/src/form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';\r\nimport { AXEvent } from '@acorex/components/common';\r\nimport { AXFormValidationResult } from './validation.class';\r\nimport { AXBaseComponentMixin } from '@acorex/components/mixin';\r\nimport { Subscription } from 'rxjs';\r\n\r\n/**\r\n*  Contains native event\r\n* @category Events\r\n*/\r\nexport class AXFormValidationEvent extends AXEvent {\r\n    result: AXFormValidationResult;\r\n}\r\n\r\n/**\r\n*  Contains native event\r\n* @category Events\r\n*/\r\nexport type AXFormUpdateOn = 'change' | 'blur' | 'manual';\r\n\r\n\r\n/**\r\n * The Button is a component which detects user interaction and triggers a corresponding event\r\n *\r\n * @category Components\r\n */\r\n@Component({\r\n    selector: 'ax-form',\r\n    template: '<form (submit)=\"_handleSubmit($event)\" (reset)=\"_handleReset($event)\"><ng-content></ng-content></form>',\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class AXFormComponent extends AXBaseComponentMixin {\r\n\r\n\r\n    @Output()\r\n    onValidate: EventEmitter<AXFormValidationEvent> = new EventEmitter<AXFormValidationEvent>();\r\n\r\n\r\n    @Output()\r\n    updateOnChange: EventEmitter<AXFormUpdateOn> = new EventEmitter<AXFormUpdateOn>();\r\n\r\n    private _updateOn: AXFormUpdateOn = 'blur';\r\n    @Input()\r\n    public get updateOn(): AXFormUpdateOn {\r\n        return this._updateOn;\r\n    }\r\n    public set updateOn(v: AXFormUpdateOn) {\r\n        this._setOption({\r\n            name: 'updateOn',\r\n            value: v,\r\n            afterCallback: (oldValue?, newValue?) => {\r\n                this._bindEvents();\r\n            },\r\n        })\r\n    }\r\n\r\n    @Input()\r\n    validateInitValues: boolean = false;\r\n\r\n\r\n    private _observer: MutationObserver;\r\n    private _subs: Subscription[] = [];\r\n\r\n\r\n\r\n    /**\r\n    *  @ignore\r\n    */\r\n    constructor(\r\n        elementRef: ElementRef,\r\n        private cdr: ChangeDetectorRef\r\n    ) {\r\n        super(elementRef, cdr);\r\n    }\r\n\r\n    _handleSubmit(e:SubmitEvent)\r\n    {\r\n        e.preventDefault();\r\n        this.validate();\r\n    }\r\n\r\n    _handleReset(e:Event)\r\n    {\r\n        this.clear();\r\n    }\r\n\r\n    private _getComponenets() {\r\n        return Array.from(\r\n            this._getHostElement().querySelectorAll('[ax-form-input=\"true\"]')\r\n        ).map((c) => (c as any).__axContext__);\r\n    }\r\n\r\n    onViewInit(): void {\r\n        if (this.validateInitValues) {\r\n            this._validateInitValues();\r\n        }\r\n        this._bindEvents();\r\n\r\n        const config = { attributes: false, childList: true, subtree: true };\r\n        const callback = (mutationList, observer) => {\r\n            this._bindEvents();\r\n        };\r\n\r\n        // Create an observer instance linked to the callback function\r\n        this._observer = new MutationObserver(callback);\r\n        this._observer.observe(this._getHostElement(), config);\r\n    }\r\n\r\n    private _bindEvents() {\r\n        this._clearSubs();\r\n        const widgets = this._getComponenets()\r\n        //\r\n        widgets.forEach(w => {\r\n            if (this.updateOn == 'change') {\r\n                this._subs.push(w.onValueChanged?.subscribe(v => {\r\n                    w.validate();\r\n                }));\r\n            }\r\n            else if (this.updateOn == 'blur') {\r\n                this._subs.push(w.onBlur?.subscribe(v => {\r\n                    w.validate();\r\n                }));\r\n            }\r\n        })\r\n    }\r\n\r\n    private _clearSubs() {\r\n        this._subs.forEach(c => c.unsubscribe())\r\n        this._subs = [];\r\n    }\r\n\r\n    private _validateInitValues() {\r\n        this._getComponenets()\r\n            .filter(c => c['value'])\r\n            .forEach(c => c.validate());\r\n    }\r\n\r\n\r\n\r\n    validate(...args: string[]): Promise<AXFormValidationResult> {\r\n        const widgets = this._getComponenets();\r\n        if (widgets.length === 0) {\r\n            this._emitOnValidateEvent({ result: true });\r\n            return Promise.resolve({ result: true });\r\n        }\r\n        //\r\n        return new Promise<AXFormValidationResult>((resolve, reject) => {\r\n            Promise.all(widgets\r\n                .filter(c => (args == null || args.length == 0) || args.includes(c.name))\r\n                .map((c) => c.validate()))\r\n                .then((rules: any) => {\r\n                    const failed = rules.filter((c: any) => !c.result);\r\n                    if (failed.length) {\r\n                        this._emitOnValidateEvent({\r\n                            result: false,\r\n                            items: failed\r\n                        });\r\n                        resolve({\r\n                            result: false,\r\n                            items: failed\r\n                        });\r\n                    }\r\n                    else {\r\n                        this._emitOnValidateEvent({ result: true });\r\n                        resolve({ result: true });\r\n                    }\r\n                });\r\n        });\r\n    }\r\n\r\n    private _emitOnValidateEvent(e: AXFormValidationResult) {\r\n        this.onValidate.emit({\r\n            component: this,\r\n            result: e,\r\n            htmlElement: this._getHostElement(),\r\n        })\r\n    }\r\n\r\n    clear() {\r\n        const widgets = this._getComponenets();\r\n        widgets.forEach(w => {\r\n            w.clear();\r\n        });\r\n    }\r\n\r\n    onDestroy(): void {\r\n        this._observer.disconnect();\r\n        this._observer = null;\r\n        this._clearSubs();\r\n    }\r\n}"]}
@@ -59,7 +59,7 @@ AXValidationSummaryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14
59
59
  <ax-button text="Dismiss" (onClick)="a.dismiss()"></ax-button>
60
60
  </ax-suffix>
61
61
  </ax-alert>
62
- `, isInline: true, dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.AXDecoratorSuffixComponent, selector: "ax-suffix" }, { kind: "component", type: i3.AXDecoratorContentComponent, selector: "ax-content" }, { kind: "component", type: i3.AXDecoratorHeaderComponent, selector: "ax-header" }, { kind: "component", type: i3.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i3.AXDecoratorTitleComponent, selector: "ax-title", inputs: ["text"] }, { kind: "component", type: i4.AXAlertComponent, selector: "ax-alert", inputs: ["color", "look", "timeOut", "visible"], outputs: ["onDismissed"] }, { kind: "component", type: i5.AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
62
+ `, isInline: true, dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.AXDecoratorSuffixComponent, selector: "ax-suffix" }, { kind: "component", type: i3.AXDecoratorContentComponent, selector: "ax-content" }, { kind: "component", type: i3.AXDecoratorHeaderComponent, selector: "ax-header" }, { kind: "component", type: i3.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i3.AXDecoratorTitleComponent, selector: "ax-title", inputs: ["text"] }, { kind: "component", type: i4.AXAlertComponent, selector: "ax-alert", inputs: ["color", "look", "timeOut", "visible"], outputs: ["onDismissed"] }, { kind: "component", type: i5.AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "type"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
63
63
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXValidationSummaryComponent, decorators: [{
64
64
  type: Component,
65
65
  args: [{
@@ -1,25 +1,46 @@
1
- import { Component, HostBinding, Input, ViewEncapsulation, } from '@angular/core';
1
+ import { AXBaseComponent } from '@acorex/components/mixin';
2
+ import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation, } from '@angular/core';
2
3
  import * as i0 from "@angular/core";
3
4
  import * as i1 from "@angular/common";
4
- export class AXImageComponent {
5
- constructor() {
5
+ export class AXImageComponent extends AXBaseComponent {
6
+ /**
7
+ * @ignore
8
+ */
9
+ constructor(elementRef, cdr) {
10
+ super(elementRef, cdr);
11
+ this.cdr = cdr;
12
+ this.priority = 'auto';
6
13
  this.lazy = false;
14
+ this.onLoad = new EventEmitter();
15
+ this.onError = new EventEmitter();
7
16
  this._hasError = false;
8
17
  this._isLoaded = false;
9
18
  this._isLoading = false;
10
19
  }
11
- ngOnInit() {
20
+ onInit() {
12
21
  this._isLoading = this.src != null;
13
22
  }
14
23
  _handleLoadImage(e) {
15
24
  this._isLoaded = true;
16
25
  this._hasError = false;
17
26
  this._isLoading = false;
27
+ this.onLoad.emit({
28
+ component: this,
29
+ htmlElement: this._getHostElement(),
30
+ isUserInteraction: false,
31
+ nativeEvent: e
32
+ });
18
33
  }
19
34
  _handleErrorImage(e) {
20
35
  this._hasError = true;
21
36
  this._isLoaded = false;
22
37
  this._isLoading = false;
38
+ this.onError.emit({
39
+ component: this,
40
+ htmlElement: this._getHostElement(),
41
+ isUserInteraction: false,
42
+ nativeEvent: e
43
+ });
23
44
  }
24
45
  get __stateError() {
25
46
  return this._hasError || !this.src;
@@ -28,17 +49,23 @@ export class AXImageComponent {
28
49
  return this._isLoading;
29
50
  }
30
51
  }
31
- AXImageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXImageComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
32
- AXImageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: AXImageComponent, selector: "ax-image", inputs: { src: "src", alt: "alt", lazy: "lazy" }, host: { properties: { "class.ax-state-empty": "this.__stateError", "class.ax-state-loading": "this.__stateLoading" } }, ngImport: i0, template: "<img class=\"ax-hidden\" *ngIf=\"src\" [class.!ax-block]=\"_isLoaded\" [src]=\"src\" [alt]=\"alt\"\r\n [attr.loading]=\"lazy ? 'lazy' : 'eager'\" (load)=\"_handleLoadImage($event)\" (error)=\"_handleErrorImage($event)\">\r\n<ng-content select=\"ax-overlay\"></ng-content>\r\n<ng-container *ngIf=\"!src || _hasError\">\r\n <ng-content select=\"ax-placeholder\"></ng-content>\r\n</ng-container>\r\n<ng-container *ngIf=\"_isLoading\">\r\n <ng-content select=\"ax-loading\"></ng-content>\r\n</ng-container>", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None });
52
+ AXImageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXImageComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
53
+ AXImageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: AXImageComponent, selector: "ax-image", inputs: { src: "src", alt: "alt", priority: "priority", lazy: "lazy" }, outputs: { onLoad: "onLoad", onError: "onError" }, host: { properties: { "class.ax-state-empty": "this.__stateError", "class.ax-state-loading": "this.__stateLoading" } }, providers: [{ provide: 'ax-image', useValue: AXImageComponent }], usesInheritance: true, ngImport: i0, template: "<img class=\"ax-hidden\" *ngIf=\"src\" [class.!ax-block]=\"_isLoaded\" [src]=\"src\" [alt]=\"alt\" [attr.fetchpriority]=\"priority\"\r\n [attr.loading]=\"lazy ? 'lazy' : 'eager'\" (load)=\"_handleLoadImage($event)\" (error)=\"_handleErrorImage($event)\">\r\n<ng-content select=\"ax-overlay\"></ng-content>\r\n<ng-container *ngIf=\"!src || _hasError\">\r\n <ng-content select=\"ax-placeholder\"></ng-content>\r\n</ng-container>\r\n<ng-container *ngIf=\"_isLoading\">\r\n <ng-content select=\"ax-loading\"></ng-content>\r\n</ng-container>", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
33
54
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXImageComponent, decorators: [{
34
55
  type: Component,
35
- args: [{ selector: 'ax-image', encapsulation: ViewEncapsulation.None, template: "<img class=\"ax-hidden\" *ngIf=\"src\" [class.!ax-block]=\"_isLoaded\" [src]=\"src\" [alt]=\"alt\"\r\n [attr.loading]=\"lazy ? 'lazy' : 'eager'\" (load)=\"_handleLoadImage($event)\" (error)=\"_handleErrorImage($event)\">\r\n<ng-content select=\"ax-overlay\"></ng-content>\r\n<ng-container *ngIf=\"!src || _hasError\">\r\n <ng-content select=\"ax-placeholder\"></ng-content>\r\n</ng-container>\r\n<ng-container *ngIf=\"_isLoading\">\r\n <ng-content select=\"ax-loading\"></ng-content>\r\n</ng-container>" }]
36
- }], ctorParameters: function () { return []; }, propDecorators: { src: [{
56
+ args: [{ selector: 'ax-image', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [{ provide: 'ax-image', useValue: AXImageComponent }], template: "<img class=\"ax-hidden\" *ngIf=\"src\" [class.!ax-block]=\"_isLoaded\" [src]=\"src\" [alt]=\"alt\" [attr.fetchpriority]=\"priority\"\r\n [attr.loading]=\"lazy ? 'lazy' : 'eager'\" (load)=\"_handleLoadImage($event)\" (error)=\"_handleErrorImage($event)\">\r\n<ng-content select=\"ax-overlay\"></ng-content>\r\n<ng-container *ngIf=\"!src || _hasError\">\r\n <ng-content select=\"ax-placeholder\"></ng-content>\r\n</ng-container>\r\n<ng-container *ngIf=\"_isLoading\">\r\n <ng-content select=\"ax-loading\"></ng-content>\r\n</ng-container>" }]
57
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { src: [{
37
58
  type: Input
38
59
  }], alt: [{
39
60
  type: Input
61
+ }], priority: [{
62
+ type: Input
40
63
  }], lazy: [{
41
64
  type: Input
65
+ }], onLoad: [{
66
+ type: Output
67
+ }], onError: [{
68
+ type: Output
42
69
  }], __stateError: [{
43
70
  type: HostBinding,
44
71
  args: ['class.ax-state-empty']
@@ -46,4 +73,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
46
73
  type: HostBinding,
47
74
  args: ['class.ax-state-loading']
48
75
  }] } });
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWNvcmV4L2NvbXBvbmVudHMvaW1hZ2Uvc3JjL2ltYWdlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Fjb3JleC9jb21wb25lbnRzL2ltYWdlL3NyYy9pbWFnZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULFdBQVcsRUFDWCxLQUFLLEVBRUwsaUJBQWlCLEdBQ2xCLE1BQU0sZUFBZSxDQUFDOzs7QUFPdkIsTUFBTSxPQUFPLGdCQUFnQjtJQWMzQjtRQU5BLFNBQUksR0FBWSxLQUFLLENBQUM7UUFFdEIsY0FBUyxHQUFHLEtBQUssQ0FBQztRQUNsQixjQUFTLEdBQUcsS0FBSyxDQUFDO1FBQ2xCLGVBQVUsR0FBRyxLQUFLLENBQUM7SUFFSCxDQUFDO0lBRWpCLFFBQVE7UUFDTixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxHQUFHLElBQUksSUFBSSxDQUFDO0lBQ3JDLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxDQUFNO1FBQ3JCLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO1FBQ3RCLElBQUksQ0FBQyxTQUFTLEdBQUcsS0FBSyxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDO0lBQzFCLENBQUM7SUFFRCxpQkFBaUIsQ0FBQyxDQUFNO1FBQ3RCLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO1FBQ3RCLElBQUksQ0FBQyxTQUFTLEdBQUcsS0FBSyxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDO0lBQzFCLENBQUM7SUFFRCxJQUNJLFlBQVk7UUFDZCxPQUFPLElBQUksQ0FBQyxTQUFTLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDO0lBQ3JDLENBQUM7SUFFRCxJQUNJLGNBQWM7UUFDaEIsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQ3pCLENBQUM7OzZHQXhDVSxnQkFBZ0I7aUdBQWhCLGdCQUFnQiwwTkNiN0IsaWdCQVFlOzJGREtGLGdCQUFnQjtrQkFMNUIsU0FBUzsrQkFDRSxVQUFVLGlCQUVMLGlCQUFpQixDQUFDLElBQUk7MEVBSXJDLEdBQUc7c0JBREYsS0FBSztnQkFJTixHQUFHO3NCQURGLEtBQUs7Z0JBSU4sSUFBSTtzQkFESCxLQUFLO2dCQTBCRixZQUFZO3NCQURmLFdBQVc7dUJBQUMsc0JBQXNCO2dCQU0vQixjQUFjO3NCQURqQixXQUFXO3VCQUFDLHdCQUF3QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ29tcG9uZW50LFxyXG4gIEhvc3RCaW5kaW5nLFxyXG4gIElucHV0LFxyXG4gIE9uSW5pdCxcclxuICBWaWV3RW5jYXBzdWxhdGlvbixcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYXgtaW1hZ2UnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9pbWFnZS5jb21wb25lbnQuaHRtbCcsXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcclxufSlcclxuZXhwb3J0IGNsYXNzIEFYSW1hZ2VDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIEBJbnB1dCgpXHJcbiAgc3JjPzogc3RyaW5nIHwgbnVsbDtcclxuXHJcbiAgQElucHV0KClcclxuICBhbHQ/OiBzdHJpbmcgfCBudWxsO1xyXG5cclxuICBASW5wdXQoKSBcclxuICBsYXp5OiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIF9oYXNFcnJvciA9IGZhbHNlO1xyXG4gIF9pc0xvYWRlZCA9IGZhbHNlO1xyXG4gIF9pc0xvYWRpbmcgPSBmYWxzZTtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICB0aGlzLl9pc0xvYWRpbmcgPSB0aGlzLnNyYyAhPSBudWxsO1xyXG4gIH1cclxuXHJcbiAgX2hhbmRsZUxvYWRJbWFnZShlOiBhbnkpIHtcclxuICAgIHRoaXMuX2lzTG9hZGVkID0gdHJ1ZTtcclxuICAgIHRoaXMuX2hhc0Vycm9yID0gZmFsc2U7XHJcbiAgICB0aGlzLl9pc0xvYWRpbmcgPSBmYWxzZTtcclxuICB9XHJcblxyXG4gIF9oYW5kbGVFcnJvckltYWdlKGU6IGFueSkge1xyXG4gICAgdGhpcy5faGFzRXJyb3IgPSB0cnVlO1xyXG4gICAgdGhpcy5faXNMb2FkZWQgPSBmYWxzZTtcclxuICAgIHRoaXMuX2lzTG9hZGluZyA9IGZhbHNlO1xyXG4gIH1cclxuXHJcbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5heC1zdGF0ZS1lbXB0eScpXHJcbiAgZ2V0IF9fc3RhdGVFcnJvcigpIHtcclxuICAgIHJldHVybiB0aGlzLl9oYXNFcnJvciB8fCAhdGhpcy5zcmM7XHJcbiAgfVxyXG5cclxuICBASG9zdEJpbmRpbmcoJ2NsYXNzLmF4LXN0YXRlLWxvYWRpbmcnKVxyXG4gIGdldCBfX3N0YXRlTG9hZGluZygpIHtcclxuICAgIHJldHVybiB0aGlzLl9pc0xvYWRpbmc7XHJcbiAgfVxyXG59XHJcbiIsIjxpbWcgY2xhc3M9XCJheC1oaWRkZW5cIiAqbmdJZj1cInNyY1wiIFtjbGFzcy4hYXgtYmxvY2tdPVwiX2lzTG9hZGVkXCIgW3NyY109XCJzcmNcIiBbYWx0XT1cImFsdFwiXHJcbiAgICBbYXR0ci5sb2FkaW5nXT1cImxhenkgPyAnbGF6eScgOiAnZWFnZXInXCIgKGxvYWQpPVwiX2hhbmRsZUxvYWRJbWFnZSgkZXZlbnQpXCIgKGVycm9yKT1cIl9oYW5kbGVFcnJvckltYWdlKCRldmVudClcIj5cclxuPG5nLWNvbnRlbnQgc2VsZWN0PVwiYXgtb3ZlcmxheVwiPjwvbmctY29udGVudD5cclxuPG5nLWNvbnRhaW5lciAqbmdJZj1cIiFzcmMgfHwgX2hhc0Vycm9yXCI+XHJcbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJheC1wbGFjZWhvbGRlclwiPjwvbmctY29udGVudD5cclxuPC9uZy1jb250YWluZXI+XHJcbjxuZy1jb250YWluZXIgKm5nSWY9XCJfaXNMb2FkaW5nXCI+XHJcbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJheC1sb2FkaW5nXCI+PC9uZy1jb250ZW50PlxyXG48L25nLWNvbnRhaW5lcj4iXX0=
76
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWNvcmV4L2NvbXBvbmVudHMvaW1hZ2Uvc3JjL2ltYWdlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Fjb3JleC9jb21wb25lbnRzL2ltYWdlL3NyYy9pbWFnZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUNMLHVCQUF1QixFQUV2QixTQUFTLEVBRVQsWUFBWSxFQUNaLFdBQVcsRUFDWCxLQUFLLEVBQ0wsTUFBTSxFQUNOLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQzs7O0FBU3ZCLE1BQU0sT0FBTyxnQkFBaUIsU0FBUSxlQUFlO0lBR25EOztNQUVFO0lBQ0YsWUFDRSxVQUFzQixFQUNkLEdBQXNCO1FBRTlCLEtBQUssQ0FBQyxVQUFVLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFGZixRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQVloQyxhQUFRLEdBQTRCLE1BQU0sQ0FBQztRQUczQyxTQUFJLEdBQVksS0FBSyxDQUFDO1FBSXRCLFdBQU0sR0FBOEIsSUFBSSxZQUFZLEVBQWUsQ0FBQztRQUdwRSxZQUFPLEdBQTBDLElBQUksWUFBWSxFQUEyQixDQUFDO1FBRTdGLGNBQVMsR0FBRyxLQUFLLENBQUM7UUFDbEIsY0FBUyxHQUFHLEtBQUssQ0FBQztRQUNsQixlQUFVLEdBQUcsS0FBSyxDQUFDO0lBdkJuQixDQUFDO0lBMkJELE1BQU07UUFDSixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxHQUFHLElBQUksSUFBSSxDQUFDO0lBQ3JDLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxDQUFRO1FBQ3ZCLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO1FBQ3RCLElBQUksQ0FBQyxTQUFTLEdBQUcsS0FBSyxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDO1FBQ3hCLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDO1lBQ2YsU0FBUyxFQUFFLElBQUk7WUFDZixXQUFXLEVBQUUsSUFBSSxDQUFDLGVBQWUsRUFBRTtZQUNuQyxpQkFBaUIsRUFBRSxLQUFLO1lBQ3hCLFdBQVcsRUFBRSxDQUFDO1NBQ2YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELGlCQUFpQixDQUFDLENBQWE7UUFDN0IsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUM7UUFDdEIsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUM7UUFDdkIsSUFBSSxDQUFDLFVBQVUsR0FBRyxLQUFLLENBQUM7UUFDeEIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7WUFDaEIsU0FBUyxFQUFFLElBQUk7WUFDZixXQUFXLEVBQUUsSUFBSSxDQUFDLGVBQWUsRUFBRTtZQUNuQyxpQkFBaUIsRUFBRSxLQUFLO1lBQ3hCLFdBQVcsRUFBRSxDQUFDO1NBQ2YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELElBQ0ksWUFBWTtRQUNkLE9BQU8sSUFBSSxDQUFDLFNBQVMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUM7SUFDckMsQ0FBQztJQUVELElBQ0ksY0FBYztRQUNoQixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUM7SUFDekIsQ0FBQzs7NkdBMUVVLGdCQUFnQjtpR0FBaEIsZ0JBQWdCLHNSQUZoQixDQUFDLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsZ0JBQWdCLEVBQUUsQ0FBQyxpRENuQmxFLG1pQkFRZTsyRkRhRixnQkFBZ0I7a0JBUDVCLFNBQVM7K0JBQ0UsVUFBVSxpQkFFTCxpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNLGFBQ3BDLENBQUMsRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLFFBQVEsa0JBQWtCLEVBQUUsQ0FBQztpSUFnQmhFLEdBQUc7c0JBREYsS0FBSztnQkFJTixHQUFHO3NCQURGLEtBQUs7Z0JBSU4sUUFBUTtzQkFEUCxLQUFLO2dCQUlOLElBQUk7c0JBREgsS0FBSztnQkFLTixNQUFNO3NCQURMLE1BQU07Z0JBSVAsT0FBTztzQkFETixNQUFNO2dCQXNDSCxZQUFZO3NCQURmLFdBQVc7dUJBQUMsc0JBQXNCO2dCQU0vQixjQUFjO3NCQURqQixXQUFXO3VCQUFDLHdCQUF3QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFYSHRtbEV2ZW50IH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2NvbW1vbic7XHJcbmltcG9ydCB7IEFYQmFzZUNvbXBvbmVudCB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9taXhpbic7XHJcbmltcG9ydCB7XHJcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXHJcbiAgQ2hhbmdlRGV0ZWN0b3JSZWYsXHJcbiAgQ29tcG9uZW50LFxyXG4gIEVsZW1lbnRSZWYsXHJcbiAgRXZlbnRFbWl0dGVyLFxyXG4gIEhvc3RCaW5kaW5nLFxyXG4gIElucHV0LFxyXG4gIE91dHB1dCxcclxuICBWaWV3RW5jYXBzdWxhdGlvbixcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYXgtaW1hZ2UnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9pbWFnZS5jb21wb25lbnQuaHRtbCcsXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICBwcm92aWRlcnM6IFt7IHByb3ZpZGU6ICdheC1pbWFnZScsIHVzZVZhbHVlOiBBWEltYWdlQ29tcG9uZW50IH1dLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQVhJbWFnZUNvbXBvbmVudCBleHRlbmRzIEFYQmFzZUNvbXBvbmVudCB7XHJcblxyXG5cclxuICAvKipcclxuICAqICBAaWdub3JlXHJcbiAgKi9cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYsXHJcbiAgICBwcml2YXRlIGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWZcclxuICApIHtcclxuICAgIHN1cGVyKGVsZW1lbnRSZWYsIGNkcik7XHJcbiAgfVxyXG5cclxuICBASW5wdXQoKVxyXG4gIHNyYz86IHN0cmluZyB8IG51bGw7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgYWx0Pzogc3RyaW5nIHwgbnVsbDtcclxuXHJcbiAgQElucHV0KClcclxuICBwcmlvcml0eTogJ2xvdycgfCAnYXV0bycgfCAnaGlnaCcgPSAnYXV0byc7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgbGF6eTogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuXHJcbiAgQE91dHB1dCgpXHJcbiAgb25Mb2FkOiBFdmVudEVtaXR0ZXI8QVhIdG1sRXZlbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcjxBWEh0bWxFdmVudD4oKTtcclxuXHJcbiAgQE91dHB1dCgpXHJcbiAgb25FcnJvcjogRXZlbnRFbWl0dGVyPEFYSHRtbEV2ZW50PEVycm9yRXZlbnQ+PiA9IG5ldyBFdmVudEVtaXR0ZXI8QVhIdG1sRXZlbnQ8RXJyb3JFdmVudD4+KCk7XHJcblxyXG4gIF9oYXNFcnJvciA9IGZhbHNlO1xyXG4gIF9pc0xvYWRlZCA9IGZhbHNlO1xyXG4gIF9pc0xvYWRpbmcgPSBmYWxzZTtcclxuXHJcblxyXG5cclxuICBvbkluaXQoKTogdm9pZCB7XHJcbiAgICB0aGlzLl9pc0xvYWRpbmcgPSB0aGlzLnNyYyAhPSBudWxsO1xyXG4gIH1cclxuXHJcbiAgX2hhbmRsZUxvYWRJbWFnZShlOiBFdmVudCkge1xyXG4gICAgdGhpcy5faXNMb2FkZWQgPSB0cnVlO1xyXG4gICAgdGhpcy5faGFzRXJyb3IgPSBmYWxzZTtcclxuICAgIHRoaXMuX2lzTG9hZGluZyA9IGZhbHNlO1xyXG4gICAgdGhpcy5vbkxvYWQuZW1pdCh7XHJcbiAgICAgIGNvbXBvbmVudDogdGhpcyxcclxuICAgICAgaHRtbEVsZW1lbnQ6IHRoaXMuX2dldEhvc3RFbGVtZW50KCksXHJcbiAgICAgIGlzVXNlckludGVyYWN0aW9uOiBmYWxzZSxcclxuICAgICAgbmF0aXZlRXZlbnQ6IGVcclxuICAgIH0pO1xyXG4gIH1cclxuXHJcbiAgX2hhbmRsZUVycm9ySW1hZ2UoZTogRXJyb3JFdmVudCkge1xyXG4gICAgdGhpcy5faGFzRXJyb3IgPSB0cnVlO1xyXG4gICAgdGhpcy5faXNMb2FkZWQgPSBmYWxzZTtcclxuICAgIHRoaXMuX2lzTG9hZGluZyA9IGZhbHNlO1xyXG4gICAgdGhpcy5vbkVycm9yLmVtaXQoe1xyXG4gICAgICBjb21wb25lbnQ6IHRoaXMsXHJcbiAgICAgIGh0bWxFbGVtZW50OiB0aGlzLl9nZXRIb3N0RWxlbWVudCgpLFxyXG4gICAgICBpc1VzZXJJbnRlcmFjdGlvbjogZmFsc2UsXHJcbiAgICAgIG5hdGl2ZUV2ZW50OiBlXHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIEBIb3N0QmluZGluZygnY2xhc3MuYXgtc3RhdGUtZW1wdHknKVxyXG4gIGdldCBfX3N0YXRlRXJyb3IoKSB7XHJcbiAgICByZXR1cm4gdGhpcy5faGFzRXJyb3IgfHwgIXRoaXMuc3JjO1xyXG4gIH1cclxuXHJcbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5heC1zdGF0ZS1sb2FkaW5nJylcclxuICBnZXQgX19zdGF0ZUxvYWRpbmcoKSB7XHJcbiAgICByZXR1cm4gdGhpcy5faXNMb2FkaW5nO1xyXG4gIH1cclxuXHJcbn1cclxuIiwiPGltZyBjbGFzcz1cImF4LWhpZGRlblwiICpuZ0lmPVwic3JjXCIgW2NsYXNzLiFheC1ibG9ja109XCJfaXNMb2FkZWRcIiBbc3JjXT1cInNyY1wiIFthbHRdPVwiYWx0XCIgW2F0dHIuZmV0Y2hwcmlvcml0eV09XCJwcmlvcml0eVwiXHJcbiAgICBbYXR0ci5sb2FkaW5nXT1cImxhenkgPyAnbGF6eScgOiAnZWFnZXInXCIgKGxvYWQpPVwiX2hhbmRsZUxvYWRJbWFnZSgkZXZlbnQpXCIgKGVycm9yKT1cIl9oYW5kbGVFcnJvckltYWdlKCRldmVudClcIj5cclxuPG5nLWNvbnRlbnQgc2VsZWN0PVwiYXgtb3ZlcmxheVwiPjwvbmctY29udGVudD5cclxuPG5nLWNvbnRhaW5lciAqbmdJZj1cIiFzcmMgfHwgX2hhc0Vycm9yXCI+XHJcbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJheC1wbGFjZWhvbGRlclwiPjwvbmctY29udGVudD5cclxuPC9uZy1jb250YWluZXI+XHJcbjxuZy1jb250YWluZXIgKm5nSWY9XCJfaXNMb2FkaW5nXCI+XHJcbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJheC1sb2FkaW5nXCI+PC9uZy1jb250ZW50PlxyXG48L25nLWNvbnRhaW5lcj4iXX0=
@@ -1,6 +1,7 @@
1
1
  import { ComponentPortal } from '@angular/cdk/portal';
2
2
  import { Component, ChangeDetectionStrategy, ViewEncapsulation, ContentChild, } from '@angular/core';
3
3
  import { AXBaseMenuMixin } from '@acorex/components/mixin';
4
+ import { AXPlatform } from '@acorex/core/platform';
4
5
  import * as i0 from "@angular/core";
5
6
  import * as i1 from "@angular/cdk/overlay";
6
7
  import * as i2 from "@acorex/core/platform";
@@ -20,6 +21,7 @@ export class AXMenuComponent extends AXBaseMenuMixin {
20
21
  this.cdr = cdr;
21
22
  this._overlay = _overlay;
22
23
  this._platform = _platform;
24
+ this.rtl = new AXPlatform().isRtl();
23
25
  this._levelCount = 0;
24
26
  }
25
27
  get emptyTemplate() {
@@ -308,7 +310,7 @@ export class AXMenuComponent extends AXBaseMenuMixin {
308
310
  }
309
311
  }
310
312
  AXMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXMenuComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.Overlay }, { token: i2.AXPlatform }], target: i0.ɵɵFactoryTarget.Component });
311
- AXMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: AXMenuComponent, selector: "ax-menu", inputs: { disabled: "disabled", tabIndex: "tabIndex", textField: "textField", valueField: "valueField", items: "items", parentId: "parentId", iconField: "iconField", tooltip: "tooltip", isOpen: "isOpen", isActive: "isActive", visibleField: "visibleField", disableField: "disableField", hasChildField: "hasChildField", dividerField: "dividerField", openMode: "openMode", orientation: "orientation", showModal: "showModal" }, outputs: { onBlur: "onBlur", onFocus: "onFocus", onMenuItemClick: "onMenuItemClick" }, host: { classAttribute: "ax-menu" }, queries: [{ propertyName: "_contentEmptyTemplate", first: true, predicate: ["emptyTemplate"], descendants: true }, { propertyName: "_contentItemTemplate", first: true, predicate: ["itemTemplate"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"displayItems.length; else tmpEmpty\">\r\n <ul [ngClass]=\"_getDirection()\">\r\n <ng-container *ngTemplateOutlet=\"recursiveListTmpl; context:{ list: displayItems }\"></ng-container>\r\n </ul>\r\n <ng-template #recursiveListTmpl let-list=\"list\">\r\n <ng-container *ngFor=\"let item of list\">\r\n <li *ngIf=\"item[visibleField] !=false\" [class.ax-state-disabled]=\"item[disableField]\"\r\n (click)=\"_onMenuClick($event,item)\" (mouseenter)=\"_onMenuMouseEnter($event,item)\"\r\n [ngClass]=\"{'ax-state-active ': item.isActive}\">\r\n <div class=\"ax-menu-item\" *ngIf=\"itemTemplate == null else tmpItem\">\r\n <div class=\"ax-menu-item-prefix\">\r\n <ax-icon *ngIf=\"item[iconField]\" [class]=\"item[iconField]\"></ax-icon>\r\n <span>{{_getItemDisplayTextTemplte(item)}}</span>\r\n </div>\r\n <div class=\"ax-menu-item-suffix\">\r\n <ax-icon *ngIf=\"!item.isLoading\"\r\n [ngClass]=\"{'ax-ic-chevron':item?.children?.length > 0,'ax-menu-active-icon': item.isOpen}\">\r\n </ax-icon>\r\n <ax-loading *ngIf=\"item.isLoading\">\r\n </ax-loading>\r\n </div>\r\n </div>\r\n <!--------------- check for custom item template --------------->\r\n <ng-template #tmpItem>\r\n <ng-container *ngIf=\"!isLoading\">\r\n <ng-container *ngTemplateOutlet=\"itemTemplate;context: { $implicit: item }\">\r\n </ng-container>\r\n </ng-container>\r\n </ng-template>\r\n <ul *ngIf=\"item?.children?.length > 0 && item.isOpen &&!_overlayRef\"\r\n [class.ax-state-disabled]=\"item[disableField]\">\r\n <ng-container *ngTemplateOutlet=\"recursiveListTmpl; context:{ list: item.children }\">\r\n </ng-container>\r\n </ul>\r\n </li>\r\n <li class=\"ax-divider\" *ngIf=\"item[this.dividerField]\"></li>\r\n </ng-container>\r\n </ng-template>\r\n</ng-container>\r\n<ng-container *ngIf=\"isLoading\">\r\n <ng-template>\r\n <div class=\"ax-flex ax-items-center ax-justify-center ax-p-4\">\r\n <ax-loading text=\"{{ 'layout.loading.text' | trans }}\"></ax-loading>\r\n </div>\r\n </ng-template>\r\n</ng-container>\r\n\r\n<ng-template #tmpEmpty>\r\n <ng-container *ngIf=\"!isLoading\">\r\n <!--------------- check for custom template --------------->\r\n <ng-container *ngIf=\"emptyTemplate; else elseEmptyTemplate\">\r\n <ng-container *ngTemplateOutlet=\"emptyTemplate\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #elseEmptyTemplate>\r\n <div class=\"ax-list-item\">\r\n {{ 'common.no-result-found' | trans }}\r\n </div>\r\n </ng-template>\r\n </ng-container>\r\n</ng-template>", dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i5.AXLoadingComponent, selector: "ax-loading", inputs: ["visible", "type", "text"], outputs: ["visibleChange"] }, { kind: "pipe", type: i6.AXTranslatorPipe, name: "trans" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
313
+ AXMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: AXMenuComponent, selector: "ax-menu", inputs: { disabled: "disabled", tabIndex: "tabIndex", textField: "textField", valueField: "valueField", items: "items", parentId: "parentId", iconField: "iconField", tooltip: "tooltip", isOpen: "isOpen", isActive: "isActive", visibleField: "visibleField", disableField: "disableField", hasChildField: "hasChildField", dividerField: "dividerField", openMode: "openMode", orientation: "orientation", showModal: "showModal" }, outputs: { onBlur: "onBlur", onFocus: "onFocus", onMenuItemClick: "onMenuItemClick" }, host: { classAttribute: "ax-menu" }, queries: [{ propertyName: "_contentEmptyTemplate", first: true, predicate: ["emptyTemplate"], descendants: true }, { propertyName: "_contentItemTemplate", first: true, predicate: ["itemTemplate"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"displayItems.length; else tmpEmpty\">\r\n <ul [ngClass]=\"_getDirection()\" [class.ax-rtl]=\"rtl\">\r\n <ng-container *ngTemplateOutlet=\"recursiveListTmpl; context:{ list: displayItems }\"></ng-container>\r\n </ul>\r\n <ng-template #recursiveListTmpl let-list=\"list\">\r\n <ng-container *ngFor=\"let item of list\">\r\n <li *ngIf=\"item[visibleField] !=false\" [class.ax-state-disabled]=\"item[disableField]\"\r\n (click)=\"_onMenuClick($event,item)\" (mouseenter)=\"_onMenuMouseEnter($event,item)\"\r\n [ngClass]=\"{'ax-state-active ': item.isActive}\">\r\n <div class=\"ax-menu-item\" *ngIf=\"itemTemplate == null else tmpItem\">\r\n <div class=\"ax-menu-item-prefix\">\r\n <ax-icon *ngIf=\"item[iconField]\" [class]=\"item[iconField]\"></ax-icon>\r\n <span>{{_getItemDisplayTextTemplte(item)}}</span>\r\n </div>\r\n <div class=\"ax-menu-item-suffix\">\r\n <ax-icon *ngIf=\"!item.isLoading\"\r\n [ngClass]=\"{'ax-ic-chevron':item?.children?.length > 0,'ax-menu-active-icon': item.isOpen}\">\r\n </ax-icon>\r\n <ax-loading *ngIf=\"item.isLoading\">\r\n </ax-loading>\r\n </div>\r\n </div>\r\n <!--------------- check for custom item template --------------->\r\n <ng-template #tmpItem>\r\n <ng-container *ngIf=\"!isLoading\">\r\n <ng-container *ngTemplateOutlet=\"itemTemplate;context: { $implicit: item }\">\r\n </ng-container>\r\n </ng-container>\r\n </ng-template>\r\n <ul *ngIf=\"item?.children?.length > 0 && item.isOpen &&!_overlayRef\"\r\n [class.ax-state-disabled]=\"item[disableField]\">\r\n <ng-container *ngTemplateOutlet=\"recursiveListTmpl; context:{ list: item.children }\">\r\n </ng-container>\r\n </ul>\r\n </li>\r\n <li class=\"ax-divider\" *ngIf=\"item[this.dividerField]\"></li>\r\n </ng-container>\r\n </ng-template>\r\n</ng-container>\r\n<ng-container *ngIf=\"isLoading\">\r\n <ng-template>\r\n <div class=\"ax-flex ax-items-center ax-justify-center ax-p-4\">\r\n <ax-loading text=\"{{ 'layout.loading.text' | trans }}\"></ax-loading>\r\n </div>\r\n </ng-template>\r\n</ng-container>\r\n\r\n<ng-template #tmpEmpty>\r\n <ng-container *ngIf=\"!isLoading\">\r\n <!--------------- check for custom template --------------->\r\n <ng-container *ngIf=\"emptyTemplate; else elseEmptyTemplate\">\r\n <ng-container *ngTemplateOutlet=\"emptyTemplate\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #elseEmptyTemplate>\r\n <div class=\"ax-list-item\">\r\n {{ 'common.no-result-found' | trans }}\r\n </div>\r\n </ng-template>\r\n </ng-container>\r\n</ng-template>", dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i5.AXLoadingComponent, selector: "ax-loading", inputs: ["visible", "type", "text"], outputs: ["visibleChange"] }, { kind: "pipe", type: i6.AXTranslatorPipe, name: "trans" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
312
314
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXMenuComponent, decorators: [{
313
315
  type: Component,
314
316
  args: [{ selector: 'ax-menu', inputs: [
@@ -329,7 +331,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
329
331
  'openMode',
330
332
  'orientation',
331
333
  'showModal',
332
- ], outputs: ['onBlur', 'onFocus', 'onMenuItemClick'], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: { class: 'ax-menu' }, template: "<ng-container *ngIf=\"displayItems.length; else tmpEmpty\">\r\n <ul [ngClass]=\"_getDirection()\">\r\n <ng-container *ngTemplateOutlet=\"recursiveListTmpl; context:{ list: displayItems }\"></ng-container>\r\n </ul>\r\n <ng-template #recursiveListTmpl let-list=\"list\">\r\n <ng-container *ngFor=\"let item of list\">\r\n <li *ngIf=\"item[visibleField] !=false\" [class.ax-state-disabled]=\"item[disableField]\"\r\n (click)=\"_onMenuClick($event,item)\" (mouseenter)=\"_onMenuMouseEnter($event,item)\"\r\n [ngClass]=\"{'ax-state-active ': item.isActive}\">\r\n <div class=\"ax-menu-item\" *ngIf=\"itemTemplate == null else tmpItem\">\r\n <div class=\"ax-menu-item-prefix\">\r\n <ax-icon *ngIf=\"item[iconField]\" [class]=\"item[iconField]\"></ax-icon>\r\n <span>{{_getItemDisplayTextTemplte(item)}}</span>\r\n </div>\r\n <div class=\"ax-menu-item-suffix\">\r\n <ax-icon *ngIf=\"!item.isLoading\"\r\n [ngClass]=\"{'ax-ic-chevron':item?.children?.length > 0,'ax-menu-active-icon': item.isOpen}\">\r\n </ax-icon>\r\n <ax-loading *ngIf=\"item.isLoading\">\r\n </ax-loading>\r\n </div>\r\n </div>\r\n <!--------------- check for custom item template --------------->\r\n <ng-template #tmpItem>\r\n <ng-container *ngIf=\"!isLoading\">\r\n <ng-container *ngTemplateOutlet=\"itemTemplate;context: { $implicit: item }\">\r\n </ng-container>\r\n </ng-container>\r\n </ng-template>\r\n <ul *ngIf=\"item?.children?.length > 0 && item.isOpen &&!_overlayRef\"\r\n [class.ax-state-disabled]=\"item[disableField]\">\r\n <ng-container *ngTemplateOutlet=\"recursiveListTmpl; context:{ list: item.children }\">\r\n </ng-container>\r\n </ul>\r\n </li>\r\n <li class=\"ax-divider\" *ngIf=\"item[this.dividerField]\"></li>\r\n </ng-container>\r\n </ng-template>\r\n</ng-container>\r\n<ng-container *ngIf=\"isLoading\">\r\n <ng-template>\r\n <div class=\"ax-flex ax-items-center ax-justify-center ax-p-4\">\r\n <ax-loading text=\"{{ 'layout.loading.text' | trans }}\"></ax-loading>\r\n </div>\r\n </ng-template>\r\n</ng-container>\r\n\r\n<ng-template #tmpEmpty>\r\n <ng-container *ngIf=\"!isLoading\">\r\n <!--------------- check for custom template --------------->\r\n <ng-container *ngIf=\"emptyTemplate; else elseEmptyTemplate\">\r\n <ng-container *ngTemplateOutlet=\"emptyTemplate\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #elseEmptyTemplate>\r\n <div class=\"ax-list-item\">\r\n {{ 'common.no-result-found' | trans }}\r\n </div>\r\n </ng-template>\r\n </ng-container>\r\n</ng-template>" }]
334
+ ], outputs: ['onBlur', 'onFocus', 'onMenuItemClick'], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: { class: 'ax-menu' }, template: "<ng-container *ngIf=\"displayItems.length; else tmpEmpty\">\r\n <ul [ngClass]=\"_getDirection()\" [class.ax-rtl]=\"rtl\">\r\n <ng-container *ngTemplateOutlet=\"recursiveListTmpl; context:{ list: displayItems }\"></ng-container>\r\n </ul>\r\n <ng-template #recursiveListTmpl let-list=\"list\">\r\n <ng-container *ngFor=\"let item of list\">\r\n <li *ngIf=\"item[visibleField] !=false\" [class.ax-state-disabled]=\"item[disableField]\"\r\n (click)=\"_onMenuClick($event,item)\" (mouseenter)=\"_onMenuMouseEnter($event,item)\"\r\n [ngClass]=\"{'ax-state-active ': item.isActive}\">\r\n <div class=\"ax-menu-item\" *ngIf=\"itemTemplate == null else tmpItem\">\r\n <div class=\"ax-menu-item-prefix\">\r\n <ax-icon *ngIf=\"item[iconField]\" [class]=\"item[iconField]\"></ax-icon>\r\n <span>{{_getItemDisplayTextTemplte(item)}}</span>\r\n </div>\r\n <div class=\"ax-menu-item-suffix\">\r\n <ax-icon *ngIf=\"!item.isLoading\"\r\n [ngClass]=\"{'ax-ic-chevron':item?.children?.length > 0,'ax-menu-active-icon': item.isOpen}\">\r\n </ax-icon>\r\n <ax-loading *ngIf=\"item.isLoading\">\r\n </ax-loading>\r\n </div>\r\n </div>\r\n <!--------------- check for custom item template --------------->\r\n <ng-template #tmpItem>\r\n <ng-container *ngIf=\"!isLoading\">\r\n <ng-container *ngTemplateOutlet=\"itemTemplate;context: { $implicit: item }\">\r\n </ng-container>\r\n </ng-container>\r\n </ng-template>\r\n <ul *ngIf=\"item?.children?.length > 0 && item.isOpen &&!_overlayRef\"\r\n [class.ax-state-disabled]=\"item[disableField]\">\r\n <ng-container *ngTemplateOutlet=\"recursiveListTmpl; context:{ list: item.children }\">\r\n </ng-container>\r\n </ul>\r\n </li>\r\n <li class=\"ax-divider\" *ngIf=\"item[this.dividerField]\"></li>\r\n </ng-container>\r\n </ng-template>\r\n</ng-container>\r\n<ng-container *ngIf=\"isLoading\">\r\n <ng-template>\r\n <div class=\"ax-flex ax-items-center ax-justify-center ax-p-4\">\r\n <ax-loading text=\"{{ 'layout.loading.text' | trans }}\"></ax-loading>\r\n </div>\r\n </ng-template>\r\n</ng-container>\r\n\r\n<ng-template #tmpEmpty>\r\n <ng-container *ngIf=\"!isLoading\">\r\n <!--------------- check for custom template --------------->\r\n <ng-container *ngIf=\"emptyTemplate; else elseEmptyTemplate\">\r\n <ng-container *ngTemplateOutlet=\"emptyTemplate\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #elseEmptyTemplate>\r\n <div class=\"ax-list-item\">\r\n {{ 'common.no-result-found' | trans }}\r\n </div>\r\n </ng-template>\r\n </ng-container>\r\n</ng-template>" }]
333
335
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.Overlay }, { type: i2.AXPlatform }]; }, propDecorators: { _contentEmptyTemplate: [{
334
336
  type: ContentChild,
335
337
  args: ['emptyTemplate']
@@ -337,4 +339,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
337
339
  type: ContentChild,
338
340
  args: ['itemTemplate']
339
341
  }] } });
340
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/menu/src/menu.component.ts","../../../../../../projects/acorex/components/menu/src/menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { OverlayRef, Overlay } from '@angular/cdk/overlay';\r\nimport { ComponentPortal } from '@angular/cdk/portal';\r\n\r\nimport {\r\n  Component,\r\n  ChangeDetectionStrategy,\r\n  ViewEncapsulation,\r\n  OnInit,\r\n  ContentChild,\r\n  TemplateRef,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n} from '@angular/core';\r\nimport { AXBaseMenuMixin } from '@acorex/components/mixin';\r\nimport { AXPlatform } from '@acorex/core/platform';\r\n\r\n/**\r\n * The Button is a component which detects user interaction and triggers a corresponding event\r\n *\r\n * @category Components\r\n */\r\n@Component({\r\n  selector: 'ax-menu',\r\n  templateUrl: './menu.component.html',\r\n  inputs: [\r\n    'disabled',\r\n    'tabIndex',\r\n    'textField',\r\n    'valueField',\r\n    'items',\r\n    'parentId',\r\n    'iconField',\r\n    'tooltip',\r\n    'isOpen',\r\n    'isActive',\r\n    'visibleField',\r\n    'disableField',\r\n    'hasChildField',\r\n    'dividerField',\r\n    'openMode',\r\n    'orientation',\r\n    'showModal',\r\n  ],\r\n  outputs: ['onBlur', 'onFocus', 'onMenuItemClick'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n  host: { class: 'ax-menu' },\r\n})\r\nexport class AXMenuComponent extends AXBaseMenuMixin implements OnInit {\r\n  @ContentChild('emptyTemplate')\r\n  private _contentEmptyTemplate: TemplateRef<any>;\r\n\r\n  @ContentChild('itemTemplate')\r\n  private _contentItemTemplate: TemplateRef<any>;\r\n\r\n  public _overlayRef: OverlayRef;\r\n\r\n  get emptyTemplate(): TemplateRef<any> {\r\n    return this._contentEmptyTemplate;\r\n  }\r\n\r\n  get itemTemplate(): TemplateRef<any> {\r\n    return this._contentItemTemplate;\r\n  }\r\n\r\n  private _levelCount: number = 0;\r\n\r\n  private _oldItem: any;\r\n\r\n  constructor(\r\n    private _elementRef: ElementRef,\r\n    private cdr: ChangeDetectorRef,\r\n    private _overlay: Overlay,\r\n    private _platform: AXPlatform\r\n  ) {\r\n    super(_elementRef, cdr);\r\n  }\r\n\r\n  onInit(): void {\r\n    super.onInit();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    super.onViewInit();\r\n  }\r\n\r\n  _onMenuMouseEnter(e: MouseEvent, item: any): void {\r\n    const targetElement = e.target as HTMLDivElement;\r\n\r\n    if (this.isLoading || targetElement.tagName === 'UL') {\r\n      return;\r\n    }\r\n\r\n    if (this.openMode === 'hover') {\r\n      this._handelMenuLogic(e, item);\r\n    }\r\n\r\n    e.stopPropagation();\r\n    e.preventDefault();\r\n  }\r\n\r\n  _onMenuClick(e: MouseEvent, item: any): void {\r\n    const targetElement = e.target as HTMLDivElement;\r\n\r\n    if (this.isLoading || targetElement.tagName === 'UL') {\r\n      return;\r\n    }\r\n\r\n    if (this.openMode === 'click') {\r\n      this._handelMenuLogic(e, item);\r\n    }\r\n\r\n    this.onMenuItemClick.emit({\r\n      component: this,\r\n      item: item,\r\n      nativeEvent: e,\r\n    });\r\n\r\n    e.stopPropagation();\r\n    e.preventDefault();\r\n  }\r\n\r\n  _getDirection(): string {\r\n    if (this.orientation === 'horizontal' && this._levelCount === 0) {\r\n      return 'ax-horizontal';\r\n    } else if (this._levelCount > 0) {\r\n      return 'ax-vertical ax-submenu-ul';\r\n    } else if (this.orientation === 'sidemenu') {\r\n      return 'ax-side-menu';\r\n    } else {\r\n      return 'ax-vertical';\r\n    }\r\n  }\r\n\r\n  private _removeActive(items: any): void {\r\n    items.forEach((element) => {\r\n      element.isActive = false;\r\n      if (element?.children?.length > 0) {\r\n        this._removeActive(element.children);\r\n      }\r\n    });\r\n  }\r\n\r\n  private _closeOpenChild(items: any): void {\r\n    items.forEach((element) => {\r\n      element.isOpen = false;\r\n      if (element?.children?.length > 0) {\r\n        this._closeOpenChild(element.children);\r\n      }\r\n    });\r\n  }\r\n\r\n  private _initParent(items: any, parentId: any): void {\r\n    items.forEach((element) => {\r\n      element.parentId = parentId;\r\n    });\r\n  }\r\n\r\n  private _handelMenuLogic(e: MouseEvent, item: any): void {\r\n    if (!item[this.disableField] || item[this.dividerField] === false) {\r\n      const targetElement = e.target as HTMLDivElement;\r\n      if (\r\n        (targetElement.closest('li') && this.openMode === 'click') ||\r\n        (targetElement.closest('li') && this.openMode === 'hover')\r\n      ) {\r\n        if (this._overlayRef && this._oldItem !== item) {\r\n          this._overlayRef.detach();\r\n        }\r\n        if (this.orientation === 'horizontal') {\r\n          this.displayItems.forEach((element) => {\r\n            if (\r\n              !item.parentId &&\r\n              item[this.valueField] !== element[this.valueField]\r\n            ) {\r\n              element.isOpen = false;\r\n            }\r\n          });\r\n        }\r\n        if (item?.children?.length > 0) {\r\n          if (this.orientation === 'horizontal') {\r\n            this._initParent(item.children, item[this.valueField]);\r\n          }\r\n          if (\r\n            this.orientation === 'horizontal' ||\r\n            this.orientation === 'vertical'\r\n          ) {\r\n            if (this._oldItem !== item) {\r\n              this._openAsOverlay(targetElement.closest('li'), item.children);\r\n            }\r\n          }\r\n          this._closeOpenChild(item.children);\r\n\r\n          if (\r\n            this.orientation === 'horizontal' ||\r\n            this.orientation === 'vertical'\r\n          ) {\r\n            item.isOpen = true;\r\n          } else {\r\n            item.isOpen = !item.isOpen;\r\n          }\r\n        }\r\n\r\n        this._removeActive(this.displayItems);\r\n\r\n        item.isActive = !item.isActive;\r\n\r\n        if (\r\n          this.orientation === 'horizontal' ||\r\n          this.orientation === 'vertical'\r\n        ) {\r\n          if (\r\n            this._oldItem &&\r\n            this._oldItem?.isOpen &&\r\n            item[this.valueField] !== this._oldItem[this.valueField]\r\n          ) {\r\n            this._oldItem.isOpen = false;\r\n          }\r\n          this._oldItem = item;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private _openAsOverlay(targetRef, overlayItems: any[]): void {\r\n    let positions = [];\r\n    if (this.orientation === 'vertical') {\r\n      if (this._levelCount >= 1) {\r\n        positions = [\r\n          {\r\n            originX: 'end',\r\n            originY: 'center',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'center',\r\n            overlayX: 'start',\r\n            overlayY: 'bottom',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'center',\r\n            overlayX: 'center',\r\n            overlayY: 'center',\r\n          },\r\n        ];\r\n      } else {\r\n        positions = [\r\n          {\r\n            originX: 'end',\r\n            originY: 'center',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'top',\r\n            overlayX: 'start',\r\n            overlayY: 'bottom',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'center',\r\n            overlayX: 'center',\r\n            overlayY: 'center',\r\n          },\r\n        ];\r\n      }\r\n    } else {\r\n      if (this._levelCount >= 1) {\r\n        positions = [\r\n          {\r\n            originX: 'end',\r\n            originY: 'center',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'center',\r\n            overlayX: 'start',\r\n            overlayY: 'bottom',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'top',\r\n            overlayX: 'center',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'top',\r\n            overlayX: 'center',\r\n            overlayY: 'top',\r\n          },\r\n        ];\r\n      } else {\r\n        positions = [\r\n          {\r\n            originX: 'start',\r\n            originY: 'bottom',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'center',\r\n            overlayX: 'start',\r\n            overlayY: 'bottom',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'top',\r\n            overlayX: 'center',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'top',\r\n            overlayX: 'center',\r\n            overlayY: 'top',\r\n          },\r\n        ];\r\n      }\r\n    }\r\n\r\n    this._overlayRef = this._overlay.create({\r\n      scrollStrategy: this._overlay.scrollStrategies.close(),\r\n      positionStrategy: this._overlay\r\n        .position()\r\n        .flexibleConnectedTo(targetRef)\r\n        .withPositions([...positions])\r\n        .withPush(false),\r\n      direction: this._platform.isRtl() ? 'rtl' : 'ltr',\r\n      disposeOnNavigation: true,\r\n      panelClass: ['ax-animate-fadeIn', 'ax-animate-faster', 'ax-overlay-menu'],\r\n      maxHeight: 'unset',\r\n      hasBackdrop: false,\r\n      backdropClass: ['cdk-overlay-transparent-backdrop'],\r\n    });\r\n\r\n    const ref = this._overlayRef.attach(new ComponentPortal(AXMenuComponent));\r\n\r\n    ref.instance.items = overlayItems;\r\n\r\n    ref.instance.orientation = this.orientation;\r\n\r\n    ref.instance.openMode = 'hover';\r\n\r\n    ref.instance._levelCount = this._levelCount + 1;\r\n\r\n    ref.instance.disableField = this.disableField;\r\n\r\n    ref.instance.visibleField = this.visibleField;\r\n\r\n    ref.instance.iconField = this.iconField;\r\n\r\n    ref.instance.dividerField = this.dividerField;\r\n\r\n    ref.onDestroy(() => {\r\n      ref.instance?._overlayRef?.dispose();\r\n    });\r\n\r\n    this._overlayRef.outsidePointerEvents().subscribe((e) => {\r\n      if (this._overlayRef && this.openMode === 'click') {\r\n        this._close();\r\n        e.stopPropagation();\r\n      }\r\n    });\r\n\r\n    this._platform.scroll.subscribe(() => {\r\n      if (this._overlayRef) {\r\n        this._close();\r\n      }\r\n    });\r\n\r\n    this._platform.resize.subscribe(() => {\r\n      if (this._overlayRef) {\r\n        this._close();\r\n      }\r\n    });\r\n  }\r\n\r\n  private _close() {\r\n    this._overlayRef.detach();\r\n    this._oldItem = null;\r\n    this.displayItems.forEach((element) => {\r\n      element.isOpen = false;\r\n      element.isActive = false;\r\n    });\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  onDestroy(): void {\r\n    this._overlayRef?.detach();\r\n  }\r\n}\r\n","<ng-container *ngIf=\"displayItems.length; else tmpEmpty\">\r\n    <ul [ngClass]=\"_getDirection()\">\r\n        <ng-container *ngTemplateOutlet=\"recursiveListTmpl; context:{ list: displayItems }\"></ng-container>\r\n    </ul>\r\n    <ng-template #recursiveListTmpl let-list=\"list\">\r\n        <ng-container *ngFor=\"let item of list\">\r\n            <li *ngIf=\"item[visibleField] !=false\" [class.ax-state-disabled]=\"item[disableField]\"\r\n                (click)=\"_onMenuClick($event,item)\" (mouseenter)=\"_onMenuMouseEnter($event,item)\"\r\n                [ngClass]=\"{'ax-state-active ': item.isActive}\">\r\n                <div class=\"ax-menu-item\" *ngIf=\"itemTemplate == null else tmpItem\">\r\n                    <div class=\"ax-menu-item-prefix\">\r\n                        <ax-icon *ngIf=\"item[iconField]\" [class]=\"item[iconField]\"></ax-icon>\r\n                        <span>{{_getItemDisplayTextTemplte(item)}}</span>\r\n                    </div>\r\n                    <div class=\"ax-menu-item-suffix\">\r\n                        <ax-icon *ngIf=\"!item.isLoading\"\r\n                            [ngClass]=\"{'ax-ic-chevron':item?.children?.length > 0,'ax-menu-active-icon': item.isOpen}\">\r\n                        </ax-icon>\r\n                        <ax-loading *ngIf=\"item.isLoading\">\r\n                        </ax-loading>\r\n                    </div>\r\n                </div>\r\n                <!--------------- check for custom  item template  --------------->\r\n                <ng-template #tmpItem>\r\n                    <ng-container *ngIf=\"!isLoading\">\r\n                        <ng-container *ngTemplateOutlet=\"itemTemplate;context: { $implicit: item }\">\r\n                        </ng-container>\r\n                    </ng-container>\r\n                </ng-template>\r\n                <ul *ngIf=\"item?.children?.length > 0 && item.isOpen &&!_overlayRef\"\r\n                    [class.ax-state-disabled]=\"item[disableField]\">\r\n                    <ng-container *ngTemplateOutlet=\"recursiveListTmpl; context:{ list: item.children }\">\r\n                    </ng-container>\r\n                </ul>\r\n            </li>\r\n            <li class=\"ax-divider\" *ngIf=\"item[this.dividerField]\"></li>\r\n        </ng-container>\r\n    </ng-template>\r\n</ng-container>\r\n<ng-container *ngIf=\"isLoading\">\r\n    <ng-template>\r\n        <div class=\"ax-flex ax-items-center ax-justify-center ax-p-4\">\r\n            <ax-loading text=\"{{ 'layout.loading.text' | trans }}\"></ax-loading>\r\n        </div>\r\n    </ng-template>\r\n</ng-container>\r\n\r\n<ng-template #tmpEmpty>\r\n    <ng-container *ngIf=\"!isLoading\">\r\n        <!--------------- check for custom template  --------------->\r\n        <ng-container *ngIf=\"emptyTemplate; else elseEmptyTemplate\">\r\n            <ng-container *ngTemplateOutlet=\"emptyTemplate\">\r\n            </ng-container>\r\n        </ng-container>\r\n        <ng-template #elseEmptyTemplate>\r\n            <div class=\"ax-list-item\">\r\n                {{ 'common.no-result-found' | trans }}\r\n            </div>\r\n        </ng-template>\r\n    </ng-container>\r\n</ng-template>"]}
342
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/menu/src/menu.component.ts","../../../../../../projects/acorex/components/menu/src/menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { OverlayRef, Overlay } from '@angular/cdk/overlay';\r\nimport { ComponentPortal } from '@angular/cdk/portal';\r\n\r\nimport {\r\n  Component,\r\n  ChangeDetectionStrategy,\r\n  ViewEncapsulation,\r\n  OnInit,\r\n  ContentChild,\r\n  TemplateRef,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n} from '@angular/core';\r\nimport { AXBaseMenuMixin } from '@acorex/components/mixin';\r\nimport { AXPlatform } from '@acorex/core/platform';\r\n\r\n/**\r\n * The Button is a component which detects user interaction and triggers a corresponding event\r\n *\r\n * @category Components\r\n */\r\n@Component({\r\n  selector: 'ax-menu',\r\n  templateUrl: './menu.component.html',\r\n  inputs: [\r\n    'disabled',\r\n    'tabIndex',\r\n    'textField',\r\n    'valueField',\r\n    'items',\r\n    'parentId',\r\n    'iconField',\r\n    'tooltip',\r\n    'isOpen',\r\n    'isActive',\r\n    'visibleField',\r\n    'disableField',\r\n    'hasChildField',\r\n    'dividerField',\r\n    'openMode',\r\n    'orientation',\r\n    'showModal',\r\n  ],\r\n  outputs: ['onBlur', 'onFocus', 'onMenuItemClick'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n  host: { class: 'ax-menu' },\r\n})\r\nexport class AXMenuComponent extends AXBaseMenuMixin implements OnInit {\r\n  @ContentChild('emptyTemplate')\r\n  private _contentEmptyTemplate: TemplateRef<any>;\r\n\r\n  @ContentChild('itemTemplate')\r\n  private _contentItemTemplate: TemplateRef<any>;\r\n\r\n  public _overlayRef: OverlayRef;\r\n\r\n  get emptyTemplate(): TemplateRef<any> {\r\n    return this._contentEmptyTemplate;\r\n  }\r\n\r\n  get itemTemplate(): TemplateRef<any> {\r\n    return this._contentItemTemplate;\r\n  }\r\n\r\n  rtl: boolean = new AXPlatform().isRtl();\r\n\r\n  private _levelCount: number = 0;\r\n\r\n  private _oldItem: any;\r\n\r\n  constructor(\r\n    private _elementRef: ElementRef,\r\n    private cdr: ChangeDetectorRef,\r\n    private _overlay: Overlay,\r\n    private _platform: AXPlatform\r\n  ) {\r\n    super(_elementRef, cdr);\r\n  }\r\n\r\n  onInit(): void {\r\n    super.onInit();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    super.onViewInit();\r\n  }\r\n\r\n  _onMenuMouseEnter(e: MouseEvent, item: any): void {\r\n    const targetElement = e.target as HTMLDivElement;\r\n\r\n    if (this.isLoading || targetElement.tagName === 'UL') {\r\n      return;\r\n    }\r\n\r\n    if (this.openMode === 'hover') {\r\n      this._handelMenuLogic(e, item);\r\n    }\r\n\r\n    e.stopPropagation();\r\n    e.preventDefault();\r\n  }\r\n\r\n  _onMenuClick(e: MouseEvent, item: any): void {\r\n    const targetElement = e.target as HTMLDivElement;\r\n\r\n    if (this.isLoading || targetElement.tagName === 'UL') {\r\n      return;\r\n    }\r\n\r\n    if (this.openMode === 'click') {\r\n      this._handelMenuLogic(e, item);\r\n    }\r\n\r\n    this.onMenuItemClick.emit({\r\n      component: this,\r\n      item: item,\r\n      nativeEvent: e,\r\n    });\r\n\r\n    e.stopPropagation();\r\n    e.preventDefault();\r\n  }\r\n\r\n  _getDirection(): string {\r\n    if (this.orientation === 'horizontal' && this._levelCount === 0) {\r\n      return 'ax-horizontal';\r\n    } else if (this._levelCount > 0) {\r\n      return 'ax-vertical ax-submenu-ul';\r\n    } else if (this.orientation === 'sidemenu') {\r\n      return 'ax-side-menu';\r\n    } else {\r\n      return 'ax-vertical';\r\n    }\r\n  }\r\n\r\n  private _removeActive(items: any): void {\r\n    items.forEach((element) => {\r\n      element.isActive = false;\r\n      if (element?.children?.length > 0) {\r\n        this._removeActive(element.children);\r\n      }\r\n    });\r\n  }\r\n\r\n  private _closeOpenChild(items: any): void {\r\n    items.forEach((element) => {\r\n      element.isOpen = false;\r\n      if (element?.children?.length > 0) {\r\n        this._closeOpenChild(element.children);\r\n      }\r\n    });\r\n  }\r\n\r\n  private _initParent(items: any, parentId: any): void {\r\n    items.forEach((element) => {\r\n      element.parentId = parentId;\r\n    });\r\n  }\r\n\r\n  private _handelMenuLogic(e: MouseEvent, item: any): void {\r\n    if (!item[this.disableField] || item[this.dividerField] === false) {\r\n      const targetElement = e.target as HTMLDivElement;\r\n      if (\r\n        (targetElement.closest('li') && this.openMode === 'click') ||\r\n        (targetElement.closest('li') && this.openMode === 'hover')\r\n      ) {\r\n        if (this._overlayRef && this._oldItem !== item) {\r\n          this._overlayRef.detach();\r\n        }\r\n        if (this.orientation === 'horizontal') {\r\n          this.displayItems.forEach((element) => {\r\n            if (\r\n              !item.parentId &&\r\n              item[this.valueField] !== element[this.valueField]\r\n            ) {\r\n              element.isOpen = false;\r\n            }\r\n          });\r\n        }\r\n        if (item?.children?.length > 0) {\r\n          if (this.orientation === 'horizontal') {\r\n            this._initParent(item.children, item[this.valueField]);\r\n          }\r\n          if (\r\n            this.orientation === 'horizontal' ||\r\n            this.orientation === 'vertical'\r\n          ) {\r\n            if (this._oldItem !== item) {\r\n              this._openAsOverlay(targetElement.closest('li'), item.children);\r\n            }\r\n          }\r\n          this._closeOpenChild(item.children);\r\n\r\n          if (\r\n            this.orientation === 'horizontal' ||\r\n            this.orientation === 'vertical'\r\n          ) {\r\n            item.isOpen = true;\r\n          } else {\r\n            item.isOpen = !item.isOpen;\r\n          }\r\n        }\r\n\r\n        this._removeActive(this.displayItems);\r\n\r\n        item.isActive = !item.isActive;\r\n\r\n        if (\r\n          this.orientation === 'horizontal' ||\r\n          this.orientation === 'vertical'\r\n        ) {\r\n          if (\r\n            this._oldItem &&\r\n            this._oldItem?.isOpen &&\r\n            item[this.valueField] !== this._oldItem[this.valueField]\r\n          ) {\r\n            this._oldItem.isOpen = false;\r\n          }\r\n          this._oldItem = item;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private _openAsOverlay(targetRef, overlayItems: any[]): void {\r\n    let positions = [];\r\n    if (this.orientation === 'vertical') {\r\n      if (this._levelCount >= 1) {\r\n        positions = [\r\n          {\r\n            originX: 'end',\r\n            originY: 'center',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'center',\r\n            overlayX: 'start',\r\n            overlayY: 'bottom',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'center',\r\n            overlayX: 'center',\r\n            overlayY: 'center',\r\n          },\r\n        ];\r\n      } else {\r\n        positions = [\r\n          {\r\n            originX: 'end',\r\n            originY: 'center',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'top',\r\n            overlayX: 'start',\r\n            overlayY: 'bottom',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'center',\r\n            overlayX: 'center',\r\n            overlayY: 'center',\r\n          },\r\n        ];\r\n      }\r\n    } else {\r\n      if (this._levelCount >= 1) {\r\n        positions = [\r\n          {\r\n            originX: 'end',\r\n            originY: 'center',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'center',\r\n            overlayX: 'start',\r\n            overlayY: 'bottom',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'top',\r\n            overlayX: 'center',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'top',\r\n            overlayX: 'center',\r\n            overlayY: 'top',\r\n          },\r\n        ];\r\n      } else {\r\n        positions = [\r\n          {\r\n            originX: 'start',\r\n            originY: 'bottom',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'center',\r\n            overlayX: 'start',\r\n            overlayY: 'bottom',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'top',\r\n            overlayX: 'center',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'top',\r\n            overlayX: 'center',\r\n            overlayY: 'top',\r\n          },\r\n        ];\r\n      }\r\n    }\r\n\r\n    this._overlayRef = this._overlay.create({\r\n      scrollStrategy: this._overlay.scrollStrategies.close(),\r\n      positionStrategy: this._overlay\r\n        .position()\r\n        .flexibleConnectedTo(targetRef)\r\n        .withPositions([...positions])\r\n        .withPush(false),\r\n      direction: this._platform.isRtl() ? 'rtl' : 'ltr',\r\n      disposeOnNavigation: true,\r\n      panelClass: ['ax-animate-fadeIn', 'ax-animate-faster', 'ax-overlay-menu'],\r\n      maxHeight: 'unset',\r\n      hasBackdrop: false,\r\n      backdropClass: ['cdk-overlay-transparent-backdrop'],\r\n    });\r\n\r\n    const ref = this._overlayRef.attach(new ComponentPortal(AXMenuComponent));\r\n\r\n    ref.instance.items = overlayItems;\r\n\r\n    ref.instance.orientation = this.orientation;\r\n\r\n    ref.instance.openMode = 'hover';\r\n\r\n    ref.instance._levelCount = this._levelCount + 1;\r\n\r\n    ref.instance.disableField = this.disableField;\r\n\r\n    ref.instance.visibleField = this.visibleField;\r\n\r\n    ref.instance.iconField = this.iconField;\r\n\r\n    ref.instance.dividerField = this.dividerField;\r\n\r\n    ref.onDestroy(() => {\r\n      ref.instance?._overlayRef?.dispose();\r\n    });\r\n\r\n    this._overlayRef.outsidePointerEvents().subscribe((e) => {\r\n      if (this._overlayRef && this.openMode === 'click') {\r\n        this._close();\r\n        e.stopPropagation();\r\n      }\r\n    });\r\n\r\n    this._platform.scroll.subscribe(() => {\r\n      if (this._overlayRef) {\r\n        this._close();\r\n      }\r\n    });\r\n\r\n    this._platform.resize.subscribe(() => {\r\n      if (this._overlayRef) {\r\n        this._close();\r\n      }\r\n    });\r\n  }\r\n\r\n  private _close() {\r\n    this._overlayRef.detach();\r\n    this._oldItem = null;\r\n    this.displayItems.forEach((element) => {\r\n      element.isOpen = false;\r\n      element.isActive = false;\r\n    });\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  onDestroy(): void {\r\n    this._overlayRef?.detach();\r\n  }\r\n}\r\n","<ng-container *ngIf=\"displayItems.length; else tmpEmpty\">\r\n    <ul [ngClass]=\"_getDirection()\" [class.ax-rtl]=\"rtl\">\r\n        <ng-container *ngTemplateOutlet=\"recursiveListTmpl; context:{ list: displayItems }\"></ng-container>\r\n    </ul>\r\n    <ng-template #recursiveListTmpl let-list=\"list\">\r\n        <ng-container *ngFor=\"let item of list\">\r\n            <li *ngIf=\"item[visibleField] !=false\" [class.ax-state-disabled]=\"item[disableField]\"\r\n                (click)=\"_onMenuClick($event,item)\" (mouseenter)=\"_onMenuMouseEnter($event,item)\"\r\n                [ngClass]=\"{'ax-state-active ': item.isActive}\">\r\n                <div class=\"ax-menu-item\" *ngIf=\"itemTemplate == null else tmpItem\">\r\n                    <div class=\"ax-menu-item-prefix\">\r\n                        <ax-icon *ngIf=\"item[iconField]\" [class]=\"item[iconField]\"></ax-icon>\r\n                        <span>{{_getItemDisplayTextTemplte(item)}}</span>\r\n                    </div>\r\n                    <div class=\"ax-menu-item-suffix\">\r\n                        <ax-icon *ngIf=\"!item.isLoading\"\r\n                            [ngClass]=\"{'ax-ic-chevron':item?.children?.length > 0,'ax-menu-active-icon': item.isOpen}\">\r\n                        </ax-icon>\r\n                        <ax-loading *ngIf=\"item.isLoading\">\r\n                        </ax-loading>\r\n                    </div>\r\n                </div>\r\n                <!--------------- check for custom  item template  --------------->\r\n                <ng-template #tmpItem>\r\n                    <ng-container *ngIf=\"!isLoading\">\r\n                        <ng-container *ngTemplateOutlet=\"itemTemplate;context: { $implicit: item }\">\r\n                        </ng-container>\r\n                    </ng-container>\r\n                </ng-template>\r\n                <ul *ngIf=\"item?.children?.length > 0 && item.isOpen &&!_overlayRef\"\r\n                    [class.ax-state-disabled]=\"item[disableField]\">\r\n                    <ng-container *ngTemplateOutlet=\"recursiveListTmpl; context:{ list: item.children }\">\r\n                    </ng-container>\r\n                </ul>\r\n            </li>\r\n            <li class=\"ax-divider\" *ngIf=\"item[this.dividerField]\"></li>\r\n        </ng-container>\r\n    </ng-template>\r\n</ng-container>\r\n<ng-container *ngIf=\"isLoading\">\r\n    <ng-template>\r\n        <div class=\"ax-flex ax-items-center ax-justify-center ax-p-4\">\r\n            <ax-loading text=\"{{ 'layout.loading.text' | trans }}\"></ax-loading>\r\n        </div>\r\n    </ng-template>\r\n</ng-container>\r\n\r\n<ng-template #tmpEmpty>\r\n    <ng-container *ngIf=\"!isLoading\">\r\n        <!--------------- check for custom template  --------------->\r\n        <ng-container *ngIf=\"emptyTemplate; else elseEmptyTemplate\">\r\n            <ng-container *ngTemplateOutlet=\"emptyTemplate\">\r\n            </ng-container>\r\n        </ng-container>\r\n        <ng-template #elseEmptyTemplate>\r\n            <div class=\"ax-list-item\">\r\n                {{ 'common.no-result-found' | trans }}\r\n            </div>\r\n        </ng-template>\r\n    </ng-container>\r\n</ng-template>"]}