@mediusinc/mng-commons 0.0.1-rc.2

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 (187) hide show
  1. package/README.md +19 -0
  2. package/esm2020/lib/api/models/builders/query-param.builder.mjs +49 -0
  3. package/esm2020/lib/api/models/filter-match-type.model.mjs +24 -0
  4. package/esm2020/lib/api/models/filter-param.model.mjs +46 -0
  5. package/esm2020/lib/api/models/index.mjs +9 -0
  6. package/esm2020/lib/api/models/mappers.mjs +17 -0
  7. package/esm2020/lib/api/models/query-mode.model.mjs +19 -0
  8. package/esm2020/lib/api/models/query-param.model.mjs +69 -0
  9. package/esm2020/lib/api/models/query-result.model.mjs +45 -0
  10. package/esm2020/lib/api/models/serialization.model.mjs +2 -0
  11. package/esm2020/lib/api/services/abstract-crud-api.service.mjs +72 -0
  12. package/esm2020/lib/api/services/index.mjs +2 -0
  13. package/esm2020/lib/api/utils/index.mjs +3 -0
  14. package/esm2020/lib/api/utils/medius-rest.util.mjs +70 -0
  15. package/esm2020/lib/api/utils/object-serializer.util.mjs +226 -0
  16. package/esm2020/lib/components/action/action.component.mjs +63 -0
  17. package/esm2020/lib/components/action/dialog/action-dialog.component.mjs +148 -0
  18. package/esm2020/lib/components/action/index.mjs +4 -0
  19. package/esm2020/lib/components/action/route/action-route.component.mjs +144 -0
  20. package/esm2020/lib/components/form/editor/form-editor.component.mjs +140 -0
  21. package/esm2020/lib/components/form/formly/fields/formly-field-autocomplete/formly-field-autocomplete.component.mjs +58 -0
  22. package/esm2020/lib/components/form/formly/fields/formly-field-dropdown/formly-field-dropdown.component.mjs +51 -0
  23. package/esm2020/lib/components/form/formly/fields/formly-field-fieldset/formly-field-fieldset.component.mjs +16 -0
  24. package/esm2020/lib/components/form/formly/fields/formly-field-input/formly-field-input.component.mjs +26 -0
  25. package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +94 -0
  26. package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +124 -0
  27. package/esm2020/lib/components/form/formly/fields/formly-field-tabs/formly-field-tabs.component.mjs +17 -0
  28. package/esm2020/lib/components/form/formly/fields/index.mjs +8 -0
  29. package/esm2020/lib/components/form/formly/wrappers/formly-field-wrapper/formly-field-wrapper.component.mjs +17 -0
  30. package/esm2020/lib/components/form/formly/wrappers/formly-table-wrapper/formly-table-wrapper.component.mjs +16 -0
  31. package/esm2020/lib/components/form/formly/wrappers/index.mjs +3 -0
  32. package/esm2020/lib/components/form/index.mjs +2 -0
  33. package/esm2020/lib/components/layout/app.breadcrumb.component.mjs +27 -0
  34. package/esm2020/lib/components/layout/app.footer.component.mjs +35 -0
  35. package/esm2020/lib/components/layout/app.main.component.mjs +25 -0
  36. package/esm2020/lib/components/layout/app.main.component.service.mjs +133 -0
  37. package/esm2020/lib/components/layout/app.menu.component.mjs +38 -0
  38. package/esm2020/lib/components/layout/app.menuitem.component.mjs +243 -0
  39. package/esm2020/lib/components/layout/app.topbar.component.mjs +135 -0
  40. package/esm2020/lib/components/layout/index.mjs +7 -0
  41. package/esm2020/lib/components/tableview/index.mjs +4 -0
  42. package/esm2020/lib/components/tableview/route/tableview-route.abstract.component.mjs +31 -0
  43. package/esm2020/lib/components/tableview/table/table.component.mjs +173 -0
  44. package/esm2020/lib/components/tableview/tableview.component.mjs +82 -0
  45. package/esm2020/lib/components/tableview/tableview.component.service.mjs +18 -0
  46. package/esm2020/lib/config/formly.config.mjs +165 -0
  47. package/esm2020/lib/config/index.mjs +2 -0
  48. package/esm2020/lib/directives/index.mjs +2 -0
  49. package/esm2020/lib/directives/template.directive.mjs +25 -0
  50. package/esm2020/lib/mng-commons.module.mjs +338 -0
  51. package/esm2020/lib/models/action/action.model.mjs +58 -0
  52. package/esm2020/lib/models/action/index.mjs +2 -0
  53. package/esm2020/lib/models/config/index.mjs +2 -0
  54. package/esm2020/lib/models/config/mng-config.model.mjs +3 -0
  55. package/esm2020/lib/models/descriptors/action-descriptor.model.mjs +283 -0
  56. package/esm2020/lib/models/descriptors/editor-descriptor.model.mjs +647 -0
  57. package/esm2020/lib/models/descriptors/index.mjs +6 -0
  58. package/esm2020/lib/models/descriptors/model-descriptor.model.mjs +34 -0
  59. package/esm2020/lib/models/descriptors/table-descriptor.model.mjs +123 -0
  60. package/esm2020/lib/models/descriptors/tableview-descriptor.model.mjs +124 -0
  61. package/esm2020/lib/models/events/editor-event.model.mjs +14 -0
  62. package/esm2020/lib/models/events/index.mjs +3 -0
  63. package/esm2020/lib/models/events/table-event.model.mjs +16 -0
  64. package/esm2020/lib/models/interfaces/confirmation-service.model.mjs +2 -0
  65. package/esm2020/lib/models/interfaces/index.mjs +2 -0
  66. package/esm2020/lib/models/providers/data-provider.model.mjs +86 -0
  67. package/esm2020/lib/models/providers/index.mjs +2 -0
  68. package/esm2020/lib/models/types/index.mjs +3 -0
  69. package/esm2020/lib/models/types/type.decorator.mjs +8 -0
  70. package/esm2020/lib/models/types/type.model.mjs +2 -0
  71. package/esm2020/lib/models/validators/field.validator.mjs +21 -0
  72. package/esm2020/lib/models/validators/index.mjs +2 -0
  73. package/esm2020/lib/pipes/index.mjs +2 -0
  74. package/esm2020/lib/pipes/property-path.pipe.mjs +36 -0
  75. package/esm2020/lib/services/action.service.mjs +239 -0
  76. package/esm2020/lib/services/breadcrumb.service.mjs +21 -0
  77. package/esm2020/lib/services/configuration.service.mjs +77 -0
  78. package/esm2020/lib/services/index.mjs +7 -0
  79. package/esm2020/lib/services/menu.service.mjs +26 -0
  80. package/esm2020/lib/services/navigation.service.mjs +49 -0
  81. package/esm2020/lib/services/providers/config-service.provider.mjs +12 -0
  82. package/esm2020/lib/services/providers/formly-config.provider.mjs +31 -0
  83. package/esm2020/lib/services/providers/index.mjs +3 -0
  84. package/esm2020/lib/services/settings.service.mjs +40 -0
  85. package/esm2020/lib/utils/editor-formly.util.mjs +165 -0
  86. package/esm2020/lib/utils/i18n.util.mjs +75 -0
  87. package/esm2020/lib/utils/index.mjs +5 -0
  88. package/esm2020/lib/utils/model.util.mjs +38 -0
  89. package/esm2020/lib/utils/type.util.mjs +43 -0
  90. package/esm2020/mediusinc-mng-commons.mjs +5 -0
  91. package/esm2020/public-api.mjs +33 -0
  92. package/fesm2015/mediusinc-mng-commons.mjs +5056 -0
  93. package/fesm2015/mediusinc-mng-commons.mjs.map +1 -0
  94. package/fesm2020/mediusinc-mng-commons.mjs +5012 -0
  95. package/fesm2020/mediusinc-mng-commons.mjs.map +1 -0
  96. package/lib/api/models/builders/query-param.builder.d.ts +11 -0
  97. package/lib/api/models/filter-match-type.model.d.ts +21 -0
  98. package/lib/api/models/filter-param.model.d.ts +23 -0
  99. package/lib/api/models/index.d.ts +8 -0
  100. package/lib/api/models/mappers.d.ts +6 -0
  101. package/lib/api/models/query-mode.model.d.ts +16 -0
  102. package/lib/api/models/query-param.model.d.ts +31 -0
  103. package/lib/api/models/query-result.model.d.ts +36 -0
  104. package/lib/api/models/serialization.model.d.ts +8 -0
  105. package/lib/api/services/abstract-crud-api.service.d.ts +23 -0
  106. package/lib/api/services/index.d.ts +1 -0
  107. package/lib/api/utils/index.d.ts +2 -0
  108. package/lib/api/utils/medius-rest.util.d.ts +6 -0
  109. package/lib/api/utils/object-serializer.util.d.ts +30 -0
  110. package/lib/components/action/action.component.d.ts +36 -0
  111. package/lib/components/action/dialog/action-dialog.component.d.ts +48 -0
  112. package/lib/components/action/index.d.ts +3 -0
  113. package/lib/components/action/route/action-route.component.d.ts +32 -0
  114. package/lib/components/form/editor/form-editor.component.d.ts +37 -0
  115. package/lib/components/form/formly/fields/formly-field-autocomplete/formly-field-autocomplete.component.d.ts +21 -0
  116. package/lib/components/form/formly/fields/formly-field-dropdown/formly-field-dropdown.component.d.ts +19 -0
  117. package/lib/components/form/formly/fields/formly-field-fieldset/formly-field-fieldset.component.d.ts +6 -0
  118. package/lib/components/form/formly/fields/formly-field-input/formly-field-input.component.d.ts +12 -0
  119. package/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.d.ts +17 -0
  120. package/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.d.ts +36 -0
  121. package/lib/components/form/formly/fields/formly-field-tabs/formly-field-tabs.component.d.ts +6 -0
  122. package/lib/components/form/formly/fields/index.d.ts +7 -0
  123. package/lib/components/form/formly/wrappers/formly-field-wrapper/formly-field-wrapper.component.d.ts +8 -0
  124. package/lib/components/form/formly/wrappers/formly-table-wrapper/formly-table-wrapper.component.d.ts +8 -0
  125. package/lib/components/form/formly/wrappers/index.d.ts +2 -0
  126. package/lib/components/form/index.d.ts +1 -0
  127. package/lib/components/layout/app.breadcrumb.component.d.ts +16 -0
  128. package/lib/components/layout/app.footer.component.d.ts +8 -0
  129. package/lib/components/layout/app.main.component.d.ts +12 -0
  130. package/lib/components/layout/app.main.component.service.d.ts +40 -0
  131. package/lib/components/layout/app.menu.component.d.ts +14 -0
  132. package/lib/components/layout/app.menuitem.component.d.ts +31 -0
  133. package/lib/components/layout/app.topbar.component.d.ts +16 -0
  134. package/lib/components/layout/index.d.ts +6 -0
  135. package/lib/components/tableview/index.d.ts +3 -0
  136. package/lib/components/tableview/route/tableview-route.abstract.component.d.ts +15 -0
  137. package/lib/components/tableview/table/table.component.d.ts +47 -0
  138. package/lib/components/tableview/tableview.component.d.ts +36 -0
  139. package/lib/components/tableview/tableview.component.service.d.ts +11 -0
  140. package/lib/config/formly.config.d.ts +8 -0
  141. package/lib/config/index.d.ts +1 -0
  142. package/lib/directives/index.d.ts +1 -0
  143. package/lib/directives/template.directive.d.ts +11 -0
  144. package/lib/mng-commons.module.d.ts +74 -0
  145. package/lib/models/action/action.model.d.ts +53 -0
  146. package/lib/models/action/index.d.ts +1 -0
  147. package/lib/models/config/index.d.ts +1 -0
  148. package/lib/models/config/mng-config.model.d.ts +19 -0
  149. package/lib/models/descriptors/action-descriptor.model.d.ts +124 -0
  150. package/lib/models/descriptors/editor-descriptor.model.d.ts +248 -0
  151. package/lib/models/descriptors/index.d.ts +5 -0
  152. package/lib/models/descriptors/model-descriptor.model.d.ts +15 -0
  153. package/lib/models/descriptors/table-descriptor.model.d.ts +45 -0
  154. package/lib/models/descriptors/tableview-descriptor.model.d.ts +38 -0
  155. package/lib/models/events/editor-event.model.d.ts +11 -0
  156. package/lib/models/events/index.d.ts +2 -0
  157. package/lib/models/events/table-event.model.d.ts +17 -0
  158. package/lib/models/interfaces/confirmation-service.model.d.ts +6 -0
  159. package/lib/models/interfaces/index.d.ts +1 -0
  160. package/lib/models/providers/data-provider.model.d.ts +62 -0
  161. package/lib/models/providers/index.d.ts +1 -0
  162. package/lib/models/types/index.d.ts +2 -0
  163. package/lib/models/types/type.decorator.d.ts +2 -0
  164. package/lib/models/types/type.model.d.ts +10 -0
  165. package/lib/models/validators/field.validator.d.ts +18 -0
  166. package/lib/models/validators/index.d.ts +1 -0
  167. package/lib/pipes/index.d.ts +1 -0
  168. package/lib/pipes/property-path.pipe.d.ts +7 -0
  169. package/lib/services/action.service.d.ts +92 -0
  170. package/lib/services/breadcrumb.service.d.ts +9 -0
  171. package/lib/services/configuration.service.d.ts +35 -0
  172. package/lib/services/index.d.ts +6 -0
  173. package/lib/services/menu.service.d.ts +11 -0
  174. package/lib/services/navigation.service.d.ts +14 -0
  175. package/lib/services/providers/config-service.provider.d.ts +5 -0
  176. package/lib/services/providers/formly-config.provider.d.ts +4 -0
  177. package/lib/services/providers/index.d.ts +2 -0
  178. package/lib/services/settings.service.d.ts +18 -0
  179. package/lib/utils/editor-formly.util.d.ts +9 -0
  180. package/lib/utils/i18n.util.d.ts +14 -0
  181. package/lib/utils/index.d.ts +4 -0
  182. package/lib/utils/model.util.d.ts +5 -0
  183. package/lib/utils/type.util.d.ts +15 -0
  184. package/mediusinc-mng-commons-0.0.1-rc.2.tgz +0 -0
  185. package/mediusinc-mng-commons.d.ts +5 -0
  186. package/package.json +38 -0
  187. package/public-api.d.ts +22 -0
@@ -0,0 +1,133 @@
1
+ import { Injectable } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "../../services/settings.service";
4
+ import * as i2 from "../../services/menu.service";
5
+ export class AppMainComponentService {
6
+ constructor(appSettings, menuService) {
7
+ this.appSettings = appSettings;
8
+ this.menuService = menuService;
9
+ this.overlayMenuActive = false;
10
+ this.staticMenuDesktopInactive = false;
11
+ this.staticMenuMobileActive = false;
12
+ this.sidebarActive = true;
13
+ this.sidebarStatic = true;
14
+ this.menuClick = false;
15
+ this.menuHoverActive = false;
16
+ this.topbarMenuActive = false;
17
+ this.topbarItemClick = false;
18
+ this.configActive = false;
19
+ this.configClick = false;
20
+ this.rightMenuActive = false;
21
+ this.rightMenuClick = false;
22
+ this.searchActive = false;
23
+ this.searchClick = false;
24
+ this.pinActive = true;
25
+ }
26
+ onLayoutClick() {
27
+ if (!this.topbarItemClick) {
28
+ this.activeTopbarItem = null;
29
+ this.topbarMenuActive = false;
30
+ }
31
+ if (this.configActive && !this.configClick) {
32
+ this.configActive = false;
33
+ }
34
+ if (this.rightMenuActive && !this.rightMenuClick) {
35
+ this.rightMenuActive = false;
36
+ }
37
+ if (this.searchActive && !this.searchClick) {
38
+ this.searchActive = false;
39
+ }
40
+ if (!this.menuClick) {
41
+ if ((this.appSettings.isSlim() || this.appSettings.isHorizontal()) && !this.isMobile()) {
42
+ this.menuService.reset();
43
+ this.menuHoverActive = false;
44
+ }
45
+ if (this.overlayMenuActive || this.staticMenuMobileActive) {
46
+ this.overlayMenuActive = false;
47
+ this.staticMenuMobileActive = false;
48
+ }
49
+ }
50
+ this.configClick = false;
51
+ this.rightMenuClick = false;
52
+ this.searchClick = false;
53
+ this.menuClick = false;
54
+ this.topbarItemClick = false;
55
+ }
56
+ onSidebarClick(event) {
57
+ this.menuClick = true;
58
+ }
59
+ onToggleMenu(event) {
60
+ this.menuClick = true;
61
+ if (this.overlayMenuActive) {
62
+ this.overlayMenuActive = false;
63
+ }
64
+ if (this.sidebarActive) {
65
+ this.sidebarStatic = !this.sidebarStatic;
66
+ }
67
+ event.preventDefault();
68
+ }
69
+ onSidebarMouseOver(event) {
70
+ if (this.appSettings.menuMode === 'sidebar' && !this.sidebarStatic) {
71
+ this.sidebarActive = this.isDesktop();
72
+ setTimeout(() => {
73
+ this.pinActive = this.isDesktop();
74
+ }, 200);
75
+ }
76
+ }
77
+ onSidebarMouseLeave(event) {
78
+ if (this.appSettings.menuMode === 'sidebar' && !this.sidebarStatic) {
79
+ setTimeout(() => {
80
+ this.sidebarActive = false;
81
+ this.pinActive = false;
82
+ }, 250);
83
+ }
84
+ }
85
+ onMenuButtonClick(event) {
86
+ this.menuClick = true;
87
+ if (this.appSettings.isOverlay()) {
88
+ this.overlayMenuActive = !this.overlayMenuActive;
89
+ }
90
+ if (this.isDesktop()) {
91
+ this.staticMenuDesktopInactive = !this.staticMenuDesktopInactive;
92
+ }
93
+ else {
94
+ this.staticMenuMobileActive = !this.staticMenuMobileActive;
95
+ }
96
+ event.preventDefault();
97
+ }
98
+ onTopbarItemClick(event, item) {
99
+ this.topbarItemClick = true;
100
+ if (this.activeTopbarItem === item) {
101
+ this.activeTopbarItem = null;
102
+ }
103
+ else {
104
+ this.activeTopbarItem = item;
105
+ }
106
+ event.preventDefault();
107
+ }
108
+ onTopbarSubItemClick(event) {
109
+ event.preventDefault();
110
+ }
111
+ onConfigClick(event) {
112
+ this.configClick = true;
113
+ }
114
+ onRightMenuButtonClick() {
115
+ this.rightMenuClick = true;
116
+ this.rightMenuActive = true;
117
+ }
118
+ onRightMenuClick(event) {
119
+ this.rightMenuClick = true;
120
+ }
121
+ isDesktop() {
122
+ return window.innerWidth > 991;
123
+ }
124
+ isMobile() {
125
+ return window.innerWidth <= 991;
126
+ }
127
+ }
128
+ AppMainComponentService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AppMainComponentService, deps: [{ token: i1.AppSettingsService }, { token: i2.MenuService }], target: i0.ɵɵFactoryTarget.Injectable });
129
+ AppMainComponentService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AppMainComponentService });
130
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AppMainComponentService, decorators: [{
131
+ type: Injectable
132
+ }], ctorParameters: function () { return [{ type: i1.AppSettingsService }, { type: i2.MenuService }]; } });
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app.main.component.service.js","sourceRoot":"","sources":["../../../../../../projects/mng-commons/src/lib/components/layout/app.main.component.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from '@angular/core';\n\nimport {AppSettingsService} from '../../services/settings.service';\nimport {MenuService} from '../../services/menu.service';\n\n@Injectable()\nexport class AppMainComponentService {\n\n    overlayMenuActive: boolean = false;\n\n    staticMenuDesktopInactive = false;\n\n    staticMenuMobileActive: boolean = false;\n\n    sidebarActive = true;\n\n    sidebarStatic = true;\n\n    menuClick: boolean = false;\n\n    menuHoverActive = false;\n\n    topbarMenuActive: boolean = false;\n\n    topbarItemClick: boolean = false;\n\n    activeTopbarItem: any;\n\n    configActive: boolean = false;\n\n    configClick: boolean = false;\n\n    rightMenuActive: boolean = false;\n\n    rightMenuClick: boolean = false;\n\n    searchActive: boolean = false;\n\n    searchClick: boolean = false;\n\n    pinActive: boolean = true;\n\n    constructor(private appSettings: AppSettingsService, private menuService: MenuService) {}\n\n\n    onLayoutClick() {\n        if (!this.topbarItemClick) {\n            this.activeTopbarItem = null;\n            this.topbarMenuActive = false;\n        }\n\n        if (this.configActive && !this.configClick) {\n            this.configActive = false;\n        }\n\n        if (this.rightMenuActive && !this.rightMenuClick) {\n            this.rightMenuActive = false;\n        }\n\n        if (this.searchActive && !this.searchClick) {\n            this.searchActive = false;\n        }\n\n        if (!this.menuClick) {\n            if ((this.appSettings.isSlim() || this.appSettings.isHorizontal()) && !this.isMobile()) {\n                this.menuService.reset();\n                this.menuHoverActive = false;\n            }\n\n            if (this.overlayMenuActive || this.staticMenuMobileActive) {\n                this.overlayMenuActive = false;\n                this.staticMenuMobileActive = false;\n            }\n        }\n\n        this.configClick = false;\n        this.rightMenuClick = false;\n        this.searchClick = false;\n        this.menuClick = false;\n        this.topbarItemClick = false;\n    }\n\n    onSidebarClick(event: any) {\n        this.menuClick = true;\n    }\n\n    onToggleMenu(event: any) {\n        this.menuClick = true;\n\n        if (this.overlayMenuActive) {\n            this.overlayMenuActive = false;\n        }\n\n        if (this.sidebarActive) {\n            this.sidebarStatic = !this.sidebarStatic;\n        }\n\n        event.preventDefault();\n    }\n\n    onSidebarMouseOver(event: any) {\n        if (this.appSettings.menuMode === 'sidebar' && !this.sidebarStatic) {\n            this.sidebarActive = this.isDesktop();\n            setTimeout(() => {\n                this.pinActive = this.isDesktop();\n            }, 200);\n        }\n    }\n\n    onSidebarMouseLeave(event: any) {\n        if (this.appSettings.menuMode === 'sidebar' && !this.sidebarStatic) {\n            setTimeout(() => {\n                this.sidebarActive = false;\n                this.pinActive = false;\n            }, 250);\n        }\n    }\n\n    onMenuButtonClick(event: any) {\n        this.menuClick = true;\n\n        if (this.appSettings.isOverlay()) {\n            this.overlayMenuActive = !this.overlayMenuActive;\n        }\n\n        if (this.isDesktop()) {\n            this.staticMenuDesktopInactive = !this.staticMenuDesktopInactive;\n        } else {\n            this.staticMenuMobileActive = !this.staticMenuMobileActive;\n        }\n\n        event.preventDefault();\n    }\n\n    onTopbarItemClick(event: any, item: any) {\n        this.topbarItemClick = true;\n\n        if (this.activeTopbarItem === item) {\n            this.activeTopbarItem = null;\n        } else {\n            this.activeTopbarItem = item;\n        }\n\n        event.preventDefault();\n    }\n\n    onTopbarSubItemClick(event: any) {\n        event.preventDefault();\n    }\n\n    onConfigClick(event: any) {\n        this.configClick = true;\n    }\n\n    onRightMenuButtonClick() {\n        this.rightMenuClick = true;\n        this.rightMenuActive = true;\n    }\n\n    onRightMenuClick(event: any) {\n        this.rightMenuClick = true;\n    }\n\n    isDesktop() {\n        return window.innerWidth > 991;\n    }\n\n    isMobile() {\n        return window.innerWidth <= 991;\n    }\n}\n"]}
@@ -0,0 +1,38 @@
1
+ import { Component } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "../../services/settings.service";
4
+ import * as i2 from "./app.main.component.service";
5
+ import * as i3 from "./app.menuitem.component";
6
+ import * as i4 from "@angular/common";
7
+ export class AppMenuComponent {
8
+ constructor(appSettings, appMainService) {
9
+ this.appSettings = appSettings;
10
+ this.appMainService = appMainService;
11
+ this.model = [];
12
+ }
13
+ ngOnInit() {
14
+ this.model = [
15
+ {
16
+ label: 'pages.dashboard.name', icon: 'pi pi-home', routerLink: ['/dashboard'],
17
+ },
18
+ {
19
+ label: 'pages.publicServices.name', icon: 'pi pi-fw pi-book', routerLink: ['/public-services']
20
+ },
21
+ {
22
+ label: 'pages.codelists.name', icon: 'pi pi-fw pi-list', routerLink: ['/codelists'],
23
+ items: [
24
+ {
25
+ label: 'pages.publicOrganizations.name', icon: 'pi pi-fw pi-globe', routerLink: ['/codelists/public-organizations']
26
+ }
27
+ ]
28
+ }
29
+ ];
30
+ }
31
+ }
32
+ AppMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AppMenuComponent, deps: [{ token: i1.AppSettingsService }, { token: i2.AppMainComponentService }], target: i0.ɵɵFactoryTarget.Component });
33
+ AppMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: AppMenuComponent, selector: "app-menu", ngImport: i0, template: "<div class=\"layout-menu-wrapper\" [ngClass]=\"{'layout-sidebar-active': appMainService.sidebarActive}\"\n (click)=\"appMainService.onSidebarClick($event)\" (mouseover)=\"appMainService.onSidebarMouseOver($event)\" (mouseleave)=\"appMainService.onSidebarMouseLeave($event)\">\n <div class=\"menu-logo\" *ngIf=\"!appSettings.isHorizontal() || appMainService.isMobile()\">\n\n <a href=\"#\" class=\"logo\">\n <img [src]=\"'assets/layout/images/logo-'+ (appSettings.colorScheme === 'light' ? 'dark' : 'light') + '.png'\">\n </a>\n\n <a href=\"#\" class=\"app-name\" *ngIf=\"!appSettings.isSlim() || appMainService.isMobile()\">\n <img [src]=\"'assets/layout/images/appname-'+ (appSettings.colorScheme === 'light' ? 'dark' : 'light') + '.png'\"/>\n </a>\n<!-- <a href=\"#\" class=\"menu-pin\" (click)=\"appMain.onToggleMenu($event)\">-->\n<!-- <span *ngIf=\"appMain.isOverlay()\" class=\"pi pi-times\"></span>-->\n<!-- <span *ngIf=\"appMain.isSidebar() && !appMain.sidebarStatic && appMain.pinActive\" class=\"pi pi-unlock\"></span>-->\n<!-- <span *ngIf=\"appMain.isSidebar() && appMain.sidebarStatic && appMain.pinActive\" class=\"pi pi-lock\"></span>-->\n<!-- </a>-->\n </div>\n\n <div class=\"layout-menu-container\">\n <ul class=\"layout-menu\">\n <ng-container *ngFor=\"let item of model; let i = index;\">\n <li app-menuitem *ngIf=\"!item.separator\" [item]=\"item\" [index]=\"i\" [root]=\"true\"></li>\n <li *ngIf=\"item.separator\" class=\"menu-separator\"></li>\n </ng-container>\n </ul>\n </div>\n</div>\n", components: [{ type: i3.AppMenuitemComponent, selector: "[app-menuitem]", inputs: ["item", "index", "root", "parentKey"] }], directives: [{ type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
34
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AppMenuComponent, decorators: [{
35
+ type: Component,
36
+ args: [{ selector: 'app-menu', template: "<div class=\"layout-menu-wrapper\" [ngClass]=\"{'layout-sidebar-active': appMainService.sidebarActive}\"\n (click)=\"appMainService.onSidebarClick($event)\" (mouseover)=\"appMainService.onSidebarMouseOver($event)\" (mouseleave)=\"appMainService.onSidebarMouseLeave($event)\">\n <div class=\"menu-logo\" *ngIf=\"!appSettings.isHorizontal() || appMainService.isMobile()\">\n\n <a href=\"#\" class=\"logo\">\n <img [src]=\"'assets/layout/images/logo-'+ (appSettings.colorScheme === 'light' ? 'dark' : 'light') + '.png'\">\n </a>\n\n <a href=\"#\" class=\"app-name\" *ngIf=\"!appSettings.isSlim() || appMainService.isMobile()\">\n <img [src]=\"'assets/layout/images/appname-'+ (appSettings.colorScheme === 'light' ? 'dark' : 'light') + '.png'\"/>\n </a>\n<!-- <a href=\"#\" class=\"menu-pin\" (click)=\"appMain.onToggleMenu($event)\">-->\n<!-- <span *ngIf=\"appMain.isOverlay()\" class=\"pi pi-times\"></span>-->\n<!-- <span *ngIf=\"appMain.isSidebar() && !appMain.sidebarStatic && appMain.pinActive\" class=\"pi pi-unlock\"></span>-->\n<!-- <span *ngIf=\"appMain.isSidebar() && appMain.sidebarStatic && appMain.pinActive\" class=\"pi pi-lock\"></span>-->\n<!-- </a>-->\n </div>\n\n <div class=\"layout-menu-container\">\n <ul class=\"layout-menu\">\n <ng-container *ngFor=\"let item of model; let i = index;\">\n <li app-menuitem *ngIf=\"!item.separator\" [item]=\"item\" [index]=\"i\" [root]=\"true\"></li>\n <li *ngIf=\"item.separator\" class=\"menu-separator\"></li>\n </ng-container>\n </ul>\n </div>\n</div>\n" }]
37
+ }], ctorParameters: function () { return [{ type: i1.AppSettingsService }, { type: i2.AppMainComponentService }]; } });
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLm1lbnUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbW5nLWNvbW1vbnMvc3JjL2xpYi9jb21wb25lbnRzL2xheW91dC9hcHAubWVudS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tbmctY29tbW9ucy9zcmMvbGliL2NvbXBvbmVudHMvbGF5b3V0L2FwcC5tZW51LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQVMsTUFBTSxlQUFlLENBQUM7Ozs7OztBQVdoRCxNQUFNLE9BQU8sZ0JBQWdCO0lBSXpCLFlBQW1CLFdBQStCLEVBQy9CLGNBQXVDO1FBRHZDLGdCQUFXLEdBQVgsV0FBVyxDQUFvQjtRQUMvQixtQkFBYyxHQUFkLGNBQWMsQ0FBeUI7UUFIbkQsVUFBSyxHQUFlLEVBQUUsQ0FBQztJQUcrQixDQUFDO0lBRTlELFFBQVE7UUFDSixJQUFJLENBQUMsS0FBSyxHQUFHO1lBQ1Q7Z0JBQ0ksS0FBSyxFQUFFLHNCQUFzQixFQUFFLElBQUksRUFBRSxZQUFZLEVBQUUsVUFBVSxFQUFFLENBQUMsWUFBWSxDQUFDO2FBQ2hGO1lBQ0Q7Z0JBQ0ksS0FBSyxFQUFFLDJCQUEyQixFQUFFLElBQUksRUFBRSxrQkFBa0IsRUFBRSxVQUFVLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQzthQUNqRztZQUNEO2dCQUNJLEtBQUssRUFBRSxzQkFBc0IsRUFBRSxJQUFJLEVBQUUsa0JBQWtCLEVBQUUsVUFBVSxFQUFFLENBQUMsWUFBWSxDQUFDO2dCQUNuRixLQUFLLEVBQUU7b0JBQ0g7d0JBQ0ksS0FBSyxFQUFFLGdDQUFnQyxFQUFFLElBQUksRUFBRSxtQkFBbUIsRUFBRSxVQUFVLEVBQUUsQ0FBQyxpQ0FBaUMsQ0FBQztxQkFDdEg7aUJBQ0o7YUFDSjtTQUNKLENBQUM7SUFDTixDQUFDOzs2R0F4QlEsZ0JBQWdCO2lHQUFoQixnQkFBZ0IsZ0RDWDdCLDRwREEyQkE7MkZEaEJhLGdCQUFnQjtrQkFKNUIsU0FBUzsrQkFDSSxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIE9uSW5pdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IE1lbnVJdGVtIH0gZnJvbSAncHJpbWVuZy9hcGknO1xuXG5pbXBvcnQge0FwcFNldHRpbmdzU2VydmljZX0gZnJvbSAnLi4vLi4vc2VydmljZXMvc2V0dGluZ3Muc2VydmljZSc7XG5pbXBvcnQge0FwcE1haW5Db21wb25lbnRTZXJ2aWNlfSBmcm9tICcuL2FwcC5tYWluLmNvbXBvbmVudC5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdhcHAtbWVudScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2FwcC5tZW51LmNvbXBvbmVudC5odG1sJ1xufSlcbmV4cG9ydCBjbGFzcyBBcHBNZW51Q29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICAgIHB1YmxpYyBtb2RlbDogTWVudUl0ZW1bXSA9IFtdO1xuXG4gICAgY29uc3RydWN0b3IocHVibGljIGFwcFNldHRpbmdzOiBBcHBTZXR0aW5nc1NlcnZpY2UsXG4gICAgICAgICAgICAgICAgcHVibGljIGFwcE1haW5TZXJ2aWNlOiBBcHBNYWluQ29tcG9uZW50U2VydmljZSkge31cblxuICAgIG5nT25Jbml0KCkge1xuICAgICAgICB0aGlzLm1vZGVsID0gW1xuICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIGxhYmVsOiAncGFnZXMuZGFzaGJvYXJkLm5hbWUnLCBpY29uOiAncGkgcGktaG9tZScsIHJvdXRlckxpbms6IFsnL2Rhc2hib2FyZCddLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICBsYWJlbDogJ3BhZ2VzLnB1YmxpY1NlcnZpY2VzLm5hbWUnLCBpY29uOiAncGkgcGktZncgcGktYm9vaycsIHJvdXRlckxpbms6IFsnL3B1YmxpYy1zZXJ2aWNlcyddXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIGxhYmVsOiAncGFnZXMuY29kZWxpc3RzLm5hbWUnLCBpY29uOiAncGkgcGktZncgcGktbGlzdCcsIHJvdXRlckxpbms6IFsnL2NvZGVsaXN0cyddLFxuICAgICAgICAgICAgICAgIGl0ZW1zOiBbXG4gICAgICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIGxhYmVsOiAncGFnZXMucHVibGljT3JnYW5pemF0aW9ucy5uYW1lJywgaWNvbjogJ3BpIHBpLWZ3IHBpLWdsb2JlJywgcm91dGVyTGluazogWycvY29kZWxpc3RzL3B1YmxpYy1vcmdhbml6YXRpb25zJ11cbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIF1cbiAgICAgICAgICAgIH1cbiAgICAgICAgXTtcbiAgICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwibGF5b3V0LW1lbnUtd3JhcHBlclwiIFtuZ0NsYXNzXT1cInsnbGF5b3V0LXNpZGViYXItYWN0aXZlJzogYXBwTWFpblNlcnZpY2Uuc2lkZWJhckFjdGl2ZX1cIlxuICAgICAoY2xpY2spPVwiYXBwTWFpblNlcnZpY2Uub25TaWRlYmFyQ2xpY2soJGV2ZW50KVwiIChtb3VzZW92ZXIpPVwiYXBwTWFpblNlcnZpY2Uub25TaWRlYmFyTW91c2VPdmVyKCRldmVudClcIiAobW91c2VsZWF2ZSk9XCJhcHBNYWluU2VydmljZS5vblNpZGViYXJNb3VzZUxlYXZlKCRldmVudClcIj5cbiAgICA8ZGl2IGNsYXNzPVwibWVudS1sb2dvXCIgKm5nSWY9XCIhYXBwU2V0dGluZ3MuaXNIb3Jpem9udGFsKCkgfHwgYXBwTWFpblNlcnZpY2UuaXNNb2JpbGUoKVwiPlxuXG4gICAgICAgIDxhIGhyZWY9XCIjXCIgY2xhc3M9XCJsb2dvXCI+XG4gICAgICAgICAgICA8aW1nIFtzcmNdPVwiJ2Fzc2V0cy9sYXlvdXQvaW1hZ2VzL2xvZ28tJysgKGFwcFNldHRpbmdzLmNvbG9yU2NoZW1lID09PSAnbGlnaHQnID8gJ2RhcmsnIDogJ2xpZ2h0JykgKyAnLnBuZydcIj5cbiAgICAgICAgPC9hPlxuXG4gICAgICAgIDxhIGhyZWY9XCIjXCIgY2xhc3M9XCJhcHAtbmFtZVwiICpuZ0lmPVwiIWFwcFNldHRpbmdzLmlzU2xpbSgpIHx8IGFwcE1haW5TZXJ2aWNlLmlzTW9iaWxlKClcIj5cbiAgICAgICAgICAgIDxpbWcgW3NyY109XCInYXNzZXRzL2xheW91dC9pbWFnZXMvYXBwbmFtZS0nKyAoYXBwU2V0dGluZ3MuY29sb3JTY2hlbWUgPT09ICdsaWdodCcgPyAnZGFyaycgOiAnbGlnaHQnKSArICcucG5nJ1wiLz5cbiAgICAgICAgPC9hPlxuPCEtLSAgICAgICAgPGEgaHJlZj1cIiNcIiBjbGFzcz1cIm1lbnUtcGluXCIgKGNsaWNrKT1cImFwcE1haW4ub25Ub2dnbGVNZW51KCRldmVudClcIj4tLT5cbjwhLS0gICAgICAgICAgICA8c3BhbiAqbmdJZj1cImFwcE1haW4uaXNPdmVybGF5KClcIiBjbGFzcz1cInBpIHBpLXRpbWVzXCI+PC9zcGFuPi0tPlxuPCEtLSAgICAgICAgICAgIDxzcGFuICpuZ0lmPVwiYXBwTWFpbi5pc1NpZGViYXIoKSAmJiAhYXBwTWFpbi5zaWRlYmFyU3RhdGljICYmIGFwcE1haW4ucGluQWN0aXZlXCIgY2xhc3M9XCJwaSBwaS11bmxvY2tcIj48L3NwYW4+LS0+XG48IS0tICAgICAgICAgICAgPHNwYW4gKm5nSWY9XCJhcHBNYWluLmlzU2lkZWJhcigpICYmIGFwcE1haW4uc2lkZWJhclN0YXRpYyAmJiBhcHBNYWluLnBpbkFjdGl2ZVwiIGNsYXNzPVwicGkgcGktbG9ja1wiPjwvc3Bhbj4tLT5cbjwhLS0gICAgICAgIDwvYT4tLT5cbiAgICA8L2Rpdj5cblxuICAgIDxkaXYgY2xhc3M9XCJsYXlvdXQtbWVudS1jb250YWluZXJcIj5cbiAgICAgICAgPHVsIGNsYXNzPVwibGF5b3V0LW1lbnVcIj5cbiAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IGl0ZW0gb2YgbW9kZWw7IGxldCBpID0gaW5kZXg7XCI+XG4gICAgICAgICAgICAgICAgPGxpIGFwcC1tZW51aXRlbSAqbmdJZj1cIiFpdGVtLnNlcGFyYXRvclwiIFtpdGVtXT1cIml0ZW1cIiBbaW5kZXhdPVwiaVwiIFtyb290XT1cInRydWVcIj48L2xpPlxuICAgICAgICAgICAgICAgIDxsaSAqbmdJZj1cIml0ZW0uc2VwYXJhdG9yXCIgY2xhc3M9XCJtZW51LXNlcGFyYXRvclwiPjwvbGk+XG4gICAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgPC91bD5cbiAgICA8L2Rpdj5cbjwvZGl2PlxuIl19
@@ -0,0 +1,243 @@
1
+ import { Component, Input } from '@angular/core';
2
+ import { NavigationEnd } from '@angular/router';
3
+ import { trigger, state, style, transition, animate } from '@angular/animations';
4
+ import { filter } from 'rxjs/operators';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "../../services/settings.service";
7
+ import * as i2 from "./app.main.component.service";
8
+ import * as i3 from "@angular/router";
9
+ import * as i4 from "../../services/menu.service";
10
+ import * as i5 from "@angular/common";
11
+ import * as i6 from "primeng/ripple";
12
+ import * as i7 from "@ngx-translate/core";
13
+ export class AppMenuitemComponent {
14
+ constructor(appSettings, appMainService, router, cd, menuService) {
15
+ this.appSettings = appSettings;
16
+ this.appMainService = appMainService;
17
+ this.router = router;
18
+ this.cd = cd;
19
+ this.menuService = menuService;
20
+ this.index = 0;
21
+ this.root = false;
22
+ this.parentKey = null;
23
+ this.active = false;
24
+ this.hover = false;
25
+ this.key = '';
26
+ // TODO: remove ignore
27
+ // @ts-ignore
28
+ this.menuSourceSubscription = this.menuService.menuSource$.subscribe(key => {
29
+ // deactivate current active menu
30
+ if (this.active && this.key !== key && key.indexOf(this.key) !== 0) {
31
+ this.active = false;
32
+ }
33
+ });
34
+ this.menuResetSubscription = this.menuService.resetSource$.subscribe(() => {
35
+ this.active = false;
36
+ });
37
+ this.router.events.pipe(filter(event => event instanceof NavigationEnd))
38
+ .subscribe(params => {
39
+ if ((this.appSettings.isSlim() || this.appSettings.isHorizontal()) && !this.appMainService.isMobile()) {
40
+ this.active = false;
41
+ }
42
+ else {
43
+ if (this.item.routerLink) {
44
+ this.updateActiveStateFromRoute();
45
+ }
46
+ else {
47
+ this.active = false;
48
+ }
49
+ }
50
+ });
51
+ }
52
+ ngOnInit() {
53
+ if (!(this.appSettings.isSlim() || this.appSettings.isHorizontal()) && this.item.routerLink) {
54
+ this.updateActiveStateFromRoute();
55
+ }
56
+ this.key = this.parentKey ? this.parentKey + '-' + this.index : String(this.index);
57
+ }
58
+ updateActiveStateFromRoute() {
59
+ this.active = this.router.isActive(this.item.routerLink[0], this.item.items ? false : true);
60
+ }
61
+ itemClick(event) {
62
+ // avoid processing disabled items
63
+ if (this.item.disabled) {
64
+ event.preventDefault();
65
+ return;
66
+ }
67
+ // navigate with hover in horizontal mode
68
+ if (this.root) {
69
+ this.appMainService.menuHoverActive = !this.appMainService.menuHoverActive;
70
+ }
71
+ // notify other items
72
+ this.menuService.onMenuStateChange(this.key);
73
+ // execute command
74
+ if (this.item.command) {
75
+ this.item.command({ originalEvent: event, item: this.item });
76
+ }
77
+ // toggle active state
78
+ if (this.item.items) {
79
+ this.active = !this.active;
80
+ }
81
+ else {
82
+ // activate item
83
+ this.active = true;
84
+ if (this.appMainService.isMobile()) {
85
+ this.appMainService.staticMenuMobileActive = false;
86
+ }
87
+ if (this.appSettings.isOverlay()) {
88
+ this.appMainService.overlayMenuActive = false;
89
+ }
90
+ // reset horizontal menu
91
+ if ((this.appSettings.isSlim() || this.appSettings.isHorizontal()) && !this.appMainService.isMobile()) {
92
+ this.menuService.reset();
93
+ this.appMainService.menuHoverActive = false;
94
+ }
95
+ }
96
+ }
97
+ onMouseEnter() {
98
+ // activate item on hover
99
+ if (this.root && this.appMainService.menuHoverActive && (this.appSettings.isSlim() || this.appSettings.isHorizontal()) && this.appMainService.isDesktop()) {
100
+ this.menuService.onMenuStateChange(this.key);
101
+ this.active = true;
102
+ }
103
+ }
104
+ ngOnDestroy() {
105
+ if (this.menuSourceSubscription) {
106
+ this.menuSourceSubscription.unsubscribe();
107
+ }
108
+ if (this.menuResetSubscription) {
109
+ this.menuResetSubscription.unsubscribe();
110
+ }
111
+ }
112
+ }
113
+ AppMenuitemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AppMenuitemComponent, deps: [{ token: i1.AppSettingsService }, { token: i2.AppMainComponentService }, { token: i3.Router }, { token: i0.ChangeDetectorRef }, { token: i4.MenuService }], target: i0.ɵɵFactoryTarget.Component });
114
+ AppMenuitemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: AppMenuitemComponent, selector: "[app-menuitem]", inputs: { item: "item", index: "index", root: "root", parentKey: "parentKey" }, host: { properties: { "class.layout-root-menuitem": "root", "class.active-menuitem": "active" } }, ngImport: i0, template: `
115
+ <ng-container>
116
+ <div *ngIf="root && item.visible !== false" class="layout-menuitem-root-text">{{ item.label | translate }}</div>
117
+ <a [attr.href]="item.url" (click)="itemClick($event)" *ngIf="(!item.routerLink || item.items) && item.visible !== false"
118
+ (mouseenter)="onMouseEnter()" (keydown.enter)="itemClick($event)"
119
+ [attr.target]="item.target" [attr.tabindex]="0" [ngClass]="item.class" pRipple>
120
+ <i [ngClass]="item.icon" class="layout-menuitem-icon"></i>
121
+ <span class="layout-menuitem-text">{{ item.label | translate }}</span>
122
+ <i class="pi pi-fw pi-angle-down layout-submenu-toggler" *ngIf="item.items"></i>
123
+ <span class="menuitem-badge" *ngIf="item.badge">{{item.badge}}</span>
124
+ </a>
125
+ <a (click)="itemClick($event)" (mouseenter)="hover=true" (mouseleave)="hover=false"
126
+ *ngIf="(item.routerLink && !item.items) && item.visible !== false"
127
+ [routerLink]="item.routerLink" routerLinkActive="active-menuitem-routerlink"
128
+ [routerLinkActiveOptions]="{exact: true}" [attr.target]="item.target" [attr.tabindex]="0"
129
+ [ngClass]="item.class" pRipple>
130
+ <i [ngClass]="item.icon" class="layout-menuitem-icon"></i>
131
+ <span class="layout-menuitem-text">{{ item.label | translate }}</span>
132
+ <i class="pi pi-fw pi-angle-down layout-submenu-toggler" *ngIf="item.items"></i>
133
+ <span class="menuitem-badge" *ngIf="item.badge">{{item.badge}}</span>
134
+ </a>
135
+ <ul *ngIf="((item.items && active) || (item.items && appSettings.isStatic() && (root || active))) && item.visible !== false" [@children]="(
136
+ (appSettings.isSlim()||appSettings.isHorizontal()) && !appMainService.isMobile() && root) ?
137
+ (active ? 'visible' : 'hidden') :
138
+ (appSettings.isStatic() && root && !appMainService.isMobile() ? 'visible' : (active ? 'visibleAnimated' : 'hiddenAnimated'))">
139
+ <ng-template ngFor let-child let-i="index" [ngForOf]="item.items">
140
+ <li app-menuitem [item]="child" [index]="i" [parentKey]="key" [class]="child.badgeClass"></li>
141
+ </ng-template>
142
+ </ul>
143
+ </ng-container>
144
+ `, isInline: true, components: [{ type: AppMenuitemComponent, selector: "[app-menuitem]", inputs: ["item", "index", "root", "parentKey"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.Ripple, selector: "[pRipple]" }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo", "routerLink"] }, { type: i3.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": i7.TranslatePipe }, animations: [
145
+ trigger('children', [
146
+ state('void', style({
147
+ height: '0px'
148
+ })),
149
+ state('hiddenAnimated', style({
150
+ height: '0px'
151
+ })),
152
+ state('visibleAnimated', style({
153
+ height: '*'
154
+ })),
155
+ state('visible', style({
156
+ height: '*',
157
+ 'z-index': 100
158
+ })),
159
+ state('hidden', style({
160
+ height: '0px',
161
+ 'z-index': '*'
162
+ })),
163
+ transition('visibleAnimated => hiddenAnimated', animate('400ms cubic-bezier(0.86, 0, 0.07, 1)')),
164
+ transition('hiddenAnimated => visibleAnimated', animate('400ms cubic-bezier(0.86, 0, 0.07, 1)')),
165
+ transition('void => visibleAnimated, visibleAnimated => void', animate('400ms cubic-bezier(0.86, 0, 0.07, 1)'))
166
+ ])
167
+ ] });
168
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AppMenuitemComponent, decorators: [{
169
+ type: Component,
170
+ args: [{
171
+ /* tslint:disable:component-selector */
172
+ selector: '[app-menuitem]',
173
+ /* tslint:enable:component-selector */
174
+ template: `
175
+ <ng-container>
176
+ <div *ngIf="root && item.visible !== false" class="layout-menuitem-root-text">{{ item.label | translate }}</div>
177
+ <a [attr.href]="item.url" (click)="itemClick($event)" *ngIf="(!item.routerLink || item.items) && item.visible !== false"
178
+ (mouseenter)="onMouseEnter()" (keydown.enter)="itemClick($event)"
179
+ [attr.target]="item.target" [attr.tabindex]="0" [ngClass]="item.class" pRipple>
180
+ <i [ngClass]="item.icon" class="layout-menuitem-icon"></i>
181
+ <span class="layout-menuitem-text">{{ item.label | translate }}</span>
182
+ <i class="pi pi-fw pi-angle-down layout-submenu-toggler" *ngIf="item.items"></i>
183
+ <span class="menuitem-badge" *ngIf="item.badge">{{item.badge}}</span>
184
+ </a>
185
+ <a (click)="itemClick($event)" (mouseenter)="hover=true" (mouseleave)="hover=false"
186
+ *ngIf="(item.routerLink && !item.items) && item.visible !== false"
187
+ [routerLink]="item.routerLink" routerLinkActive="active-menuitem-routerlink"
188
+ [routerLinkActiveOptions]="{exact: true}" [attr.target]="item.target" [attr.tabindex]="0"
189
+ [ngClass]="item.class" pRipple>
190
+ <i [ngClass]="item.icon" class="layout-menuitem-icon"></i>
191
+ <span class="layout-menuitem-text">{{ item.label | translate }}</span>
192
+ <i class="pi pi-fw pi-angle-down layout-submenu-toggler" *ngIf="item.items"></i>
193
+ <span class="menuitem-badge" *ngIf="item.badge">{{item.badge}}</span>
194
+ </a>
195
+ <ul *ngIf="((item.items && active) || (item.items && appSettings.isStatic() && (root || active))) && item.visible !== false" [@children]="(
196
+ (appSettings.isSlim()||appSettings.isHorizontal()) && !appMainService.isMobile() && root) ?
197
+ (active ? 'visible' : 'hidden') :
198
+ (appSettings.isStatic() && root && !appMainService.isMobile() ? 'visible' : (active ? 'visibleAnimated' : 'hiddenAnimated'))">
199
+ <ng-template ngFor let-child let-i="index" [ngForOf]="item.items">
200
+ <li app-menuitem [item]="child" [index]="i" [parentKey]="key" [class]="child.badgeClass"></li>
201
+ </ng-template>
202
+ </ul>
203
+ </ng-container>
204
+ `,
205
+ host: {
206
+ '[class.layout-root-menuitem]': 'root',
207
+ '[class.active-menuitem]': 'active'
208
+ },
209
+ animations: [
210
+ trigger('children', [
211
+ state('void', style({
212
+ height: '0px'
213
+ })),
214
+ state('hiddenAnimated', style({
215
+ height: '0px'
216
+ })),
217
+ state('visibleAnimated', style({
218
+ height: '*'
219
+ })),
220
+ state('visible', style({
221
+ height: '*',
222
+ 'z-index': 100
223
+ })),
224
+ state('hidden', style({
225
+ height: '0px',
226
+ 'z-index': '*'
227
+ })),
228
+ transition('visibleAnimated => hiddenAnimated', animate('400ms cubic-bezier(0.86, 0, 0.07, 1)')),
229
+ transition('hiddenAnimated => visibleAnimated', animate('400ms cubic-bezier(0.86, 0, 0.07, 1)')),
230
+ transition('void => visibleAnimated, visibleAnimated => void', animate('400ms cubic-bezier(0.86, 0, 0.07, 1)'))
231
+ ])
232
+ ]
233
+ }]
234
+ }], ctorParameters: function () { return [{ type: i1.AppSettingsService }, { type: i2.AppMainComponentService }, { type: i3.Router }, { type: i0.ChangeDetectorRef }, { type: i4.MenuService }]; }, propDecorators: { item: [{
235
+ type: Input
236
+ }], index: [{
237
+ type: Input
238
+ }], root: [{
239
+ type: Input
240
+ }], parentKey: [{
241
+ type: Input
242
+ }] } });
243
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app.menuitem.component.js","sourceRoot":"","sources":["../../../../../../projects/mng-commons/src/lib/components/layout/app.menuitem.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnInit, ChangeDetectorRef, OnDestroy} from '@angular/core';\nimport {Router, NavigationEnd} from '@angular/router';\nimport {trigger, state, style, transition, animate} from '@angular/animations';\n\nimport {Subscription} from 'rxjs';\nimport {filter} from 'rxjs/operators';\n\nimport {MenuService} from '../../services/menu.service';\nimport {AppSettingsService} from '../../services/settings.service';\nimport {AppMainComponentService} from './app.main.component.service';\n\n@Component({\n    /* tslint:disable:component-selector */\n    selector: '[app-menuitem]',\n    /* tslint:enable:component-selector */\n    template: `\n        <ng-container>\n            <div *ngIf=\"root && item.visible !== false\" class=\"layout-menuitem-root-text\">{{ item.label | translate }}</div>\n            <a [attr.href]=\"item.url\" (click)=\"itemClick($event)\" *ngIf=\"(!item.routerLink || item.items) && item.visible !== false\"\n               (mouseenter)=\"onMouseEnter()\" (keydown.enter)=\"itemClick($event)\"\n               [attr.target]=\"item.target\" [attr.tabindex]=\"0\" [ngClass]=\"item.class\" pRipple>\n                <i [ngClass]=\"item.icon\" class=\"layout-menuitem-icon\"></i>\n                <span class=\"layout-menuitem-text\">{{ item.label | translate }}</span>\n                <i class=\"pi pi-fw pi-angle-down layout-submenu-toggler\" *ngIf=\"item.items\"></i>\n                <span class=\"menuitem-badge\" *ngIf=\"item.badge\">{{item.badge}}</span>\n            </a>\n            <a (click)=\"itemClick($event)\" (mouseenter)=\"hover=true\" (mouseleave)=\"hover=false\"\n               *ngIf=\"(item.routerLink && !item.items) && item.visible !== false\"\n               [routerLink]=\"item.routerLink\" routerLinkActive=\"active-menuitem-routerlink\"\n               [routerLinkActiveOptions]=\"{exact: true}\" [attr.target]=\"item.target\" [attr.tabindex]=\"0\"\n               [ngClass]=\"item.class\" pRipple>\n                <i [ngClass]=\"item.icon\" class=\"layout-menuitem-icon\"></i>\n                <span class=\"layout-menuitem-text\">{{ item.label | translate }}</span>\n                <i class=\"pi pi-fw pi-angle-down layout-submenu-toggler\" *ngIf=\"item.items\"></i>\n                <span class=\"menuitem-badge\" *ngIf=\"item.badge\">{{item.badge}}</span>\n            </a>\n            <ul *ngIf=\"((item.items && active) || (item.items && appSettings.isStatic() && (root || active))) && item.visible !== false\" [@children]=\"(\n            (appSettings.isSlim()||appSettings.isHorizontal()) && !appMainService.isMobile() && root) ?\n            (active ? 'visible' : 'hidden') :\n            (appSettings.isStatic() && root && !appMainService.isMobile() ? 'visible' : (active ? 'visibleAnimated' : 'hiddenAnimated'))\">\n                <ng-template ngFor let-child let-i=\"index\" [ngForOf]=\"item.items\">\n                        <li app-menuitem [item]=\"child\" [index]=\"i\" [parentKey]=\"key\" [class]=\"child.badgeClass\"></li>\n                </ng-template>\n            </ul>\n        </ng-container>\n    `,\n    host: {\n        '[class.layout-root-menuitem]': 'root',\n        '[class.active-menuitem]': 'active'\n    },\n    animations: [\n        trigger('children', [\n            state('void', style({\n                height: '0px'\n            })),\n            state('hiddenAnimated', style({\n                height: '0px'\n            })),\n            state('visibleAnimated', style({\n                height: '*'\n            })),\n            state('visible', style({\n                height: '*',\n                'z-index': 100\n            })),\n            state('hidden', style({\n                height: '0px',\n                'z-index': '*'\n            })),\n            transition('visibleAnimated => hiddenAnimated', animate('400ms cubic-bezier(0.86, 0, 0.07, 1)')),\n            transition('hiddenAnimated => visibleAnimated', animate('400ms cubic-bezier(0.86, 0, 0.07, 1)')),\n            transition('void => visibleAnimated, visibleAnimated => void', animate('400ms cubic-bezier(0.86, 0, 0.07, 1)'))\n        ])\n    ]\n})\nexport class AppMenuitemComponent implements OnInit, OnDestroy {\n\n    @Input() item: any;\n\n    @Input() index: number = 0;\n\n    @Input() root: boolean = false;\n\n    @Input() parentKey: string|null = null;\n\n    active = false;\n\n    hover: boolean = false;\n\n    menuSourceSubscription: Subscription;\n\n    menuResetSubscription: Subscription;\n\n    key: string = '';\n\n    constructor(public appSettings: AppSettingsService, public appMainService: AppMainComponentService, public router: Router, private cd: ChangeDetectorRef, private menuService: MenuService) {\n        // TODO: remove ignore\n        // @ts-ignore\n        this.menuSourceSubscription = this.menuService.menuSource$.subscribe(key => {\n            // deactivate current active menu\n            if (this.active && this.key !== key && key.indexOf(this.key) !== 0) {\n                this.active = false;\n            }\n        });\n\n        this.menuResetSubscription = this.menuService.resetSource$.subscribe(() => {\n            this.active = false;\n        });\n\n        this.router.events.pipe(filter(event => event instanceof NavigationEnd))\n            .subscribe(params => {\n                if ((this.appSettings.isSlim() || this.appSettings.isHorizontal()) && !this.appMainService.isMobile()) {\n                    this.active = false;\n                } else {\n                    if (this.item.routerLink) {\n                        this.updateActiveStateFromRoute();\n                    } else {\n                        this.active = false;\n                    }\n                }\n            });\n    }\n\n    ngOnInit() {\n        if (!(this.appSettings.isSlim() || this.appSettings.isHorizontal()) && this.item.routerLink) {\n            this.updateActiveStateFromRoute();\n        }\n\n        this.key = this.parentKey ? this.parentKey + '-' + this.index : String(this.index);\n    }\n\n    updateActiveStateFromRoute() {\n        this.active = this.router.isActive(this.item.routerLink[0], this.item.items ? false : true);\n    }\n\n    itemClick(event: Event) {\n        // avoid processing disabled items\n        if (this.item.disabled) {\n            event.preventDefault();\n            return;\n        }\n\n        // navigate with hover in horizontal mode\n        if (this.root) {\n            this.appMainService.menuHoverActive = !this.appMainService.menuHoverActive;\n        }\n\n        // notify other items\n        this.menuService.onMenuStateChange(this.key);\n\n        // execute command\n        if (this.item.command) {\n            this.item.command({originalEvent: event, item: this.item});\n        }\n\n        // toggle active state\n        if (this.item.items) {\n            this.active = !this.active;\n        } else {\n            // activate item\n            this.active = true;\n\n            if (this.appMainService.isMobile()) {\n                this.appMainService.staticMenuMobileActive = false;\n            }\n\n            if (this.appSettings.isOverlay()) {\n                this.appMainService.overlayMenuActive = false;\n            }\n\n            // reset horizontal menu\n            if ((this.appSettings.isSlim() || this.appSettings.isHorizontal()) && !this.appMainService.isMobile()){\n                this.menuService.reset();\n                this.appMainService.menuHoverActive = false;\n            }\n        }\n    }\n\n    onMouseEnter() {\n        // activate item on hover\n        if (this.root && this.appMainService.menuHoverActive && (this.appSettings.isSlim() || this.appSettings.isHorizontal()) && this.appMainService.isDesktop()) {\n            this.menuService.onMenuStateChange(this.key);\n            this.active = true;\n        }\n    }\n\n    ngOnDestroy() {\n        if (this.menuSourceSubscription) {\n            this.menuSourceSubscription.unsubscribe();\n        }\n\n        if (this.menuResetSubscription) {\n            this.menuResetSubscription.unsubscribe();\n        }\n    }\n}\n"]}