@mediusinc/mng-commons 0.0.1-rc.3 → 0.2.1-rc

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 (488) hide show
  1. package/.browserslistrc +16 -0
  2. package/README.md +96 -1
  3. package/assets/i18n/en.json +156 -0
  4. package/assets/i18n/sl.json +156 -0
  5. package/assets/images/effect-ondark.png +0 -0
  6. package/assets/images/effect-ondark.svg +38 -0
  7. package/assets/images/effect-ondark@2x.png +0 -0
  8. package/assets/images/effect-onlight.png +0 -0
  9. package/assets/images/effect-onlight.svg +38 -0
  10. package/assets/images/effect-onlight@2x.png +0 -0
  11. package/assets/images/pages/exception-ondark.png +0 -0
  12. package/assets/images/pages/exception-onlight.png +0 -0
  13. package/assets/images/pages/login-ondark.png +0 -0
  14. package/assets/images/pages/login-onlight.png +0 -0
  15. package/assets/templates/tableview-route.component.html +5 -0
  16. package/karma.conf.js +51 -0
  17. package/ng-package.json +14 -0
  18. package/package.json +3 -24
  19. package/scss/common/layout/_breadcrumb.scss +96 -0
  20. package/scss/common/layout/_config.scss +101 -0
  21. package/scss/common/layout/_dashboard.scss +16 -0
  22. package/scss/common/layout/_exception.scss +131 -0
  23. package/scss/common/layout/_footer.scss +29 -0
  24. package/scss/common/layout/_help.scss +157 -0
  25. package/scss/common/layout/_inlinemenu.scss +55 -0
  26. package/scss/common/layout/_invoice.scss +176 -0
  27. package/scss/common/layout/_landing.scss +639 -0
  28. package/scss/common/layout/_layout_dark.scss +23 -0
  29. package/scss/common/layout/_layout_light.scss +23 -0
  30. package/scss/common/layout/_loader.scss +18 -0
  31. package/scss/common/layout/_login.scss +106 -0
  32. package/scss/common/layout/_main.scss +45 -0
  33. package/scss/common/layout/_mixins.scss +214 -0
  34. package/scss/common/layout/_rightmenu.scss +125 -0
  35. package/scss/common/layout/_topbar.scss +189 -0
  36. package/scss/common/layout/_typography.scss +63 -0
  37. package/scss/common/layout/_utils.scss +96 -0
  38. package/scss/common/layout/_widgets.scss +391 -0
  39. package/scss/common/layout/menu/_menu.scss +7 -0
  40. package/scss/common/layout/menu/_menu_common.scss +183 -0
  41. package/scss/common/layout/menu/_menu_overlay.scss +52 -0
  42. package/scss/common/layout/menu/_menu_sidebar.scss +232 -0
  43. package/scss/common/layout/menu/_menu_slim.scss +138 -0
  44. package/scss/common/layout/menu/_menu_static.scss +70 -0
  45. package/scss/common/layout/menu/_menu_theme.scss +365 -0
  46. package/scss/common/theme/_theme_dark.scss +5 -0
  47. package/scss/common/theme/_theme_light.scss +5 -0
  48. package/scss/common/theme/designer/_colors.scss +18 -0
  49. package/scss/common/theme/designer/_common.scss +40 -0
  50. package/scss/common/theme/designer/_components.scss +101 -0
  51. package/scss/common/theme/designer/_mixins.scss +174 -0
  52. package/scss/common/theme/designer/components/button/_button.scss +560 -0
  53. package/scss/common/theme/designer/components/button/_speeddial.scss +79 -0
  54. package/scss/common/theme/designer/components/button/_splitbutton.scss +1 -0
  55. package/scss/common/theme/designer/components/data/_carousel.scss +37 -0
  56. package/scss/common/theme/designer/components/data/_datatable.scss +266 -0
  57. package/scss/common/theme/designer/components/data/_dataview.scss +55 -0
  58. package/scss/common/theme/designer/components/data/_filter.scss +138 -0
  59. package/scss/common/theme/designer/components/data/_fullcalendar.scss +324 -0
  60. package/scss/common/theme/designer/components/data/_orderlist.scss +91 -0
  61. package/scss/common/theme/designer/components/data/_organizationchart.scss +50 -0
  62. package/scss/common/theme/designer/components/data/_paginator.scss +83 -0
  63. package/scss/common/theme/designer/components/data/_picklist.scss +91 -0
  64. package/scss/common/theme/designer/components/data/_timeline.scss +38 -0
  65. package/scss/common/theme/designer/components/data/_tree.scss +144 -0
  66. package/scss/common/theme/designer/components/data/_treetable.scss +242 -0
  67. package/scss/common/theme/designer/components/data/_virtualscroller.scss +28 -0
  68. package/scss/common/theme/designer/components/file/_fileupload.scss +58 -0
  69. package/scss/common/theme/designer/components/input/_autocomplete.scss +103 -0
  70. package/scss/common/theme/designer/components/input/_calendar.scss +212 -0
  71. package/scss/common/theme/designer/components/input/_cascadeselect.scss +98 -0
  72. package/scss/common/theme/designer/components/input/_checkbox.scss +85 -0
  73. package/scss/common/theme/designer/components/input/_chips.scss +41 -0
  74. package/scss/common/theme/designer/components/input/_colorpicker.scss +19 -0
  75. package/scss/common/theme/designer/components/input/_dropdown.scss +136 -0
  76. package/scss/common/theme/designer/components/input/_editor.scss +122 -0
  77. package/scss/common/theme/designer/components/input/_inputgroup.scss +69 -0
  78. package/scss/common/theme/designer/components/input/_inputmask.scss +3 -0
  79. package/scss/common/theme/designer/components/input/_inputnumber.scss +3 -0
  80. package/scss/common/theme/designer/components/input/_inputswitch.scss +58 -0
  81. package/scss/common/theme/designer/components/input/_inputtext.scss +97 -0
  82. package/scss/common/theme/designer/components/input/_listbox.scss +82 -0
  83. package/scss/common/theme/designer/components/input/_multiselect.scss +164 -0
  84. package/scss/common/theme/designer/components/input/_password.scss +33 -0
  85. package/scss/common/theme/designer/components/input/_radiobutton.scss +78 -0
  86. package/scss/common/theme/designer/components/input/_rating.scss +48 -0
  87. package/scss/common/theme/designer/components/input/_selectbutton.scss +50 -0
  88. package/scss/common/theme/designer/components/input/_slider.scss +69 -0
  89. package/scss/common/theme/designer/components/input/_togglebutton.scss +48 -0
  90. package/scss/common/theme/designer/components/input/_treeselect.scss +89 -0
  91. package/scss/common/theme/designer/components/menu/_breadcrumb.scss +42 -0
  92. package/scss/common/theme/designer/components/menu/_contextmenu.scss +50 -0
  93. package/scss/common/theme/designer/components/menu/_dock.scss +51 -0
  94. package/scss/common/theme/designer/components/menu/_megamenu.scss +102 -0
  95. package/scss/common/theme/designer/components/menu/_menu.scss +41 -0
  96. package/scss/common/theme/designer/components/menu/_menubar.scss +179 -0
  97. package/scss/common/theme/designer/components/menu/_panelmenu.scss +137 -0
  98. package/scss/common/theme/designer/components/menu/_slidemenu.scss +55 -0
  99. package/scss/common/theme/designer/components/menu/_steps.scss +55 -0
  100. package/scss/common/theme/designer/components/menu/_tabmenu.scss +49 -0
  101. package/scss/common/theme/designer/components/menu/_tieredmenu.scss +56 -0
  102. package/scss/common/theme/designer/components/messages/_inlinemessage.scss +64 -0
  103. package/scss/common/theme/designer/components/messages/_message.scss +102 -0
  104. package/scss/common/theme/designer/components/messages/_toast.scss +95 -0
  105. package/scss/common/theme/designer/components/misc/_avatar.scss +30 -0
  106. package/scss/common/theme/designer/components/misc/_badge.scss +48 -0
  107. package/scss/common/theme/designer/components/misc/_blockui.scss +3 -0
  108. package/scss/common/theme/designer/components/misc/_chip.scss +36 -0
  109. package/scss/common/theme/designer/components/misc/_inplace.scss +17 -0
  110. package/scss/common/theme/designer/components/misc/_progressbar.scss +17 -0
  111. package/scss/common/theme/designer/components/misc/_scrolltop.scss +20 -0
  112. package/scss/common/theme/designer/components/misc/_skeleton.scss +8 -0
  113. package/scss/common/theme/designer/components/misc/_tag.scss +33 -0
  114. package/scss/common/theme/designer/components/misc/_terminal.scss +11 -0
  115. package/scss/common/theme/designer/components/multimedia/_galleria.scss +141 -0
  116. package/scss/common/theme/designer/components/overlay/_confirmpopup.scss +67 -0
  117. package/scss/common/theme/designer/components/overlay/_dialog.scss +63 -0
  118. package/scss/common/theme/designer/components/overlay/_overlaypanel.scss +62 -0
  119. package/scss/common/theme/designer/components/overlay/_sidebar.scss +27 -0
  120. package/scss/common/theme/designer/components/overlay/_tooltip.scss +33 -0
  121. package/scss/common/theme/designer/components/panel/_accordion.scss +119 -0
  122. package/scss/common/theme/designer/components/panel/_card.scss +30 -0
  123. package/scss/common/theme/designer/components/panel/_divider.scss +31 -0
  124. package/scss/common/theme/designer/components/panel/_fieldset.scss +47 -0
  125. package/scss/common/theme/designer/components/panel/_panel.scss +42 -0
  126. package/scss/common/theme/designer/components/panel/_scrollpanel.scss +6 -0
  127. package/scss/common/theme/designer/components/panel/_splitter.scss +19 -0
  128. package/scss/common/theme/designer/components/panel/_tabview.scss +66 -0
  129. package/scss/common/theme/designer/components/panel/_toolbar.scss +10 -0
  130. package/scss/common/theme/extensions/_button.scss +99 -0
  131. package/scss/common/theme/extensions/_calendar.scss +18 -0
  132. package/scss/common/theme/extensions/_card.scss +6 -0
  133. package/scss/common/theme/extensions/_carousel.scss +13 -0
  134. package/scss/common/theme/extensions/_checkbox.scss +10 -0
  135. package/scss/common/theme/extensions/_contextmenu.scss +16 -0
  136. package/scss/common/theme/extensions/_datatable.scss +83 -0
  137. package/scss/common/theme/extensions/_dialog.scss +14 -0
  138. package/scss/common/theme/extensions/_fieldset.scss +6 -0
  139. package/scss/common/theme/extensions/_galleria.scss +25 -0
  140. package/scss/common/theme/extensions/_megamenu.scss +18 -0
  141. package/scss/common/theme/extensions/_menu.scss +14 -0
  142. package/scss/common/theme/extensions/_menubar.scss +14 -0
  143. package/scss/common/theme/extensions/_orderlist.scss +38 -0
  144. package/scss/common/theme/extensions/_paginator.scss +19 -0
  145. package/scss/common/theme/extensions/_panelmenu.scss +20 -0
  146. package/scss/common/theme/extensions/_password.scss +5 -0
  147. package/scss/common/theme/extensions/_picklist.scss +38 -0
  148. package/scss/common/theme/extensions/_radiobutton.scss +8 -0
  149. package/scss/common/theme/extensions/_sidebar.scss +19 -0
  150. package/scss/common/theme/extensions/_slidemenu.scss +10 -0
  151. package/scss/common/theme/extensions/_slider.scss +6 -0
  152. package/scss/common/theme/extensions/_steps.scss +50 -0
  153. package/scss/common/theme/extensions/_tieredmenu.scss +14 -0
  154. package/scss/common/theme/extensions/_toast.scss +6 -0
  155. package/scss/common/theme/extensions/_tree.scss +36 -0
  156. package/scss/common/theme/extensions/_treetable.scss +35 -0
  157. package/scss/common/theme/extensions/_vendor_extensions.scss +27 -0
  158. package/scss/common/variables/layout/_common.scss +12 -0
  159. package/scss/common/variables/layout/_layout_dark.scss +71 -0
  160. package/scss/common/variables/layout/_layout_light.scss +71 -0
  161. package/scss/common/variables/theme/_theme_dark.scss +897 -0
  162. package/scss/common/variables/theme/_theme_light.scss +885 -0
  163. package/scss/layout/default/_mng-variables-layout-dark.scss +2 -0
  164. package/scss/layout/default/_mng-variables-layout-light.scss +2 -0
  165. package/scss/layout/default/layout-dark.scss +2 -0
  166. package/scss/layout/default/layout-light.scss +2 -0
  167. package/scss/mng-commons-dark.scss +5 -0
  168. package/scss/mng-commons-light.scss +5 -0
  169. package/scss/mng-overrides/_layout_action.scss +3 -0
  170. package/scss/mng-overrides/_layout_dialog.scss +34 -0
  171. package/scss/mng-overrides/_layout_forms.scss +31 -0
  172. package/scss/mng-overrides/_layout_radio.scss +3 -0
  173. package/scss/mng-overrides/_layout_styles.scss +4 -0
  174. package/scss/mng-overrides/_theme_datatable.scss +9 -0
  175. package/scss/mng-overrides/_theme_dialog.scss +9 -0
  176. package/scss/mng-overrides/_theme_dropdown.scss +6 -0
  177. package/scss/mng-overrides/_theme_styles.scss +9 -0
  178. package/scss/mng-overrides/_theme_tableview.scss +94 -0
  179. package/scss/theme/default/_mng-variables-theme-dark.scss +8 -0
  180. package/scss/theme/default/_mng-variables-theme-light.scss +8 -0
  181. package/scss/theme/default/theme-dark.scss +2 -0
  182. package/scss/theme/default/theme-light.scss +2 -0
  183. package/src/lib/api/models/builders/query-param.builder.ts +54 -0
  184. package/src/lib/api/models/filter-match-type.model.ts +25 -0
  185. package/src/lib/api/models/filter-param.model.ts +59 -0
  186. package/{lib/api/models/index.d.ts → src/lib/api/models/index.ts} +10 -8
  187. package/src/lib/api/models/mappers.ts +18 -0
  188. package/{lib/api/models/query-mode.model.d.ts → src/lib/api/models/query-mode.model.ts} +18 -16
  189. package/src/lib/api/models/query-param.model.ts +99 -0
  190. package/src/lib/api/models/query-result.model.ts +77 -0
  191. package/{lib/api/models/serialization.model.d.ts → src/lib/api/models/serialization.model.ts} +9 -8
  192. package/src/lib/api/services/crud-api.abstract.service.ts +113 -0
  193. package/src/lib/api/services/index.ts +1 -0
  194. package/{lib/api/utils/index.d.ts → src/lib/api/utils/index.ts} +2 -2
  195. package/src/lib/api/utils/medius-rest.util.ts +146 -0
  196. package/src/lib/api/utils/object-serializer.util.ts +227 -0
  197. package/src/lib/components/action/action.component.html +30 -0
  198. package/src/lib/components/action/action.component.ts +77 -0
  199. package/src/lib/components/action/dialog/action-dialog.component.html +26 -0
  200. package/src/lib/components/action/dialog/action-dialog.component.ts +171 -0
  201. package/{lib/components/action/index.d.ts → src/lib/components/action/index.ts} +3 -3
  202. package/src/lib/components/action/models/action-confirmation-service.model.ts +7 -0
  203. package/src/lib/components/action/models/action-execution.model.ts +81 -0
  204. package/src/lib/components/action/models/index.ts +2 -0
  205. package/src/lib/components/action/route/action-route.component.html +1 -0
  206. package/src/lib/components/action/route/action-route.component.ts +159 -0
  207. package/src/lib/components/form/autocomplete/autocomplete.component.html +16 -0
  208. package/src/lib/components/form/autocomplete/autocomplete.component.ts +113 -0
  209. package/src/lib/components/form/dropdown/dropdown.component.html +29 -0
  210. package/src/lib/components/form/dropdown/dropdown.component.ts +109 -0
  211. package/src/lib/components/form/editor/form-editor.component.html +5 -0
  212. package/src/lib/components/form/editor/form-editor.component.ts +149 -0
  213. package/src/lib/components/form/formly/fields/formly-field-autocomplete/formly-field-autocomplete.component.html +7 -0
  214. package/src/lib/components/form/formly/fields/formly-field-autocomplete/formly-field-autocomplete.component.ts +21 -0
  215. package/src/lib/components/form/formly/fields/formly-field-dropdown/formly-field-dropdown.component.html +9 -0
  216. package/src/lib/components/form/formly/fields/formly-field-dropdown/formly-field-dropdown.component.ts +22 -0
  217. package/src/lib/components/form/formly/fields/formly-field-fieldset/formly-field-fieldset.component.html +8 -0
  218. package/src/lib/components/form/formly/fields/formly-field-fieldset/formly-field-fieldset.component.ts +10 -0
  219. package/src/lib/components/form/formly/fields/formly-field-input/formly-field-input.component.html +56 -0
  220. package/src/lib/components/form/formly/fields/formly-field-input/formly-field-input.component.ts +22 -0
  221. package/src/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.html +13 -0
  222. package/src/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.scss +4 -0
  223. package/src/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.ts +114 -0
  224. package/src/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.html +37 -0
  225. package/src/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.ts +133 -0
  226. package/src/lib/components/form/formly/fields/formly-field-tabs/formly-field-tabs.component.html +10 -0
  227. package/src/lib/components/form/formly/fields/formly-field-tabs/formly-field-tabs.component.ts +10 -0
  228. package/{lib/components/form/formly/fields/index.d.ts → src/lib/components/form/formly/fields/index.ts} +7 -7
  229. package/src/lib/components/form/formly/wrappers/formly-field-wrapper/formly-field-wrapper.component.html +7 -0
  230. package/src/lib/components/form/formly/wrappers/formly-field-wrapper/formly-field-wrapper.component.ts +13 -0
  231. package/src/lib/components/form/formly/wrappers/formly-table-wrapper/formly-table-wrapper.component.html +6 -0
  232. package/src/lib/components/form/formly/wrappers/formly-table-wrapper/formly-table-wrapper.component.ts +13 -0
  233. package/{lib/components/form/formly/wrappers/index.d.ts → src/lib/components/form/formly/wrappers/index.ts} +2 -2
  234. package/src/lib/components/form/index.ts +3 -0
  235. package/src/lib/components/form/models/form-editor.event.ts +7 -0
  236. package/src/lib/components/form/models/index.ts +1 -0
  237. package/src/lib/components/layout/breadcrumb.component.html +5 -0
  238. package/src/lib/components/layout/breadcrumb.component.ts +12 -0
  239. package/src/lib/components/layout/footer.component.html +7 -0
  240. package/src/lib/components/layout/footer.component.ts +15 -0
  241. package/src/lib/components/layout/index.ts +6 -0
  242. package/src/lib/components/layout/main-layout.component.html +26 -0
  243. package/src/lib/components/layout/main-layout.component.ts +54 -0
  244. package/src/lib/components/layout/menu-item.component.html +41 -0
  245. package/src/lib/components/layout/menu-item.component.ts +170 -0
  246. package/src/lib/components/layout/menu.component.html +27 -0
  247. package/src/lib/components/layout/menu.component.ts +17 -0
  248. package/src/lib/components/layout/services/index.ts +1 -0
  249. package/src/lib/components/layout/services/main-layout.component.service.ts +231 -0
  250. package/src/lib/components/layout/topbar.component.html +38 -0
  251. package/src/lib/components/layout/topbar.component.ts +62 -0
  252. package/{lib/components/tableview/index.d.ts → src/lib/components/tableview/index.ts} +5 -3
  253. package/src/lib/components/tableview/models/index.ts +1 -0
  254. package/src/lib/components/tableview/models/table.event.ts +22 -0
  255. package/src/lib/components/tableview/route/tableview-route.abstract.component.ts +31 -0
  256. package/src/lib/components/tableview/services/index.ts +1 -0
  257. package/src/lib/components/tableview/services/tableview.component.service.ts +22 -0
  258. package/src/lib/components/tableview/table/column-filter/column-filter.component.html +36 -0
  259. package/src/lib/components/tableview/table/column-filter/column-filter.component.ts +70 -0
  260. package/src/lib/components/tableview/table/column-value/column-value.component.html +14 -0
  261. package/src/lib/components/tableview/table/column-value/column-value.component.ts +19 -0
  262. package/src/lib/components/tableview/table/table.component.html +110 -0
  263. package/src/lib/components/tableview/table/table.component.ts +327 -0
  264. package/src/lib/components/tableview/tableview.component.html +37 -0
  265. package/src/lib/components/tableview/tableview.component.ts +78 -0
  266. package/src/lib/config/formly.config.ts +154 -0
  267. package/{lib/config/index.d.ts → src/lib/config/index.ts} +1 -1
  268. package/{lib/models/config/index.d.ts → src/lib/config/models/index.ts} +1 -1
  269. package/src/lib/config/models/mng-config.model.ts +35 -0
  270. package/src/lib/data-providers/base.data-provider.ts +42 -0
  271. package/src/lib/data-providers/editor.data-provider.ts +60 -0
  272. package/src/lib/data-providers/index.ts +5 -0
  273. package/src/lib/data-providers/lookup.data-provider.ts +29 -0
  274. package/src/lib/data-providers/table.data-provider.ts +8 -0
  275. package/src/lib/data-providers/tableview.data-provider.ts +29 -0
  276. package/src/lib/descriptors/action.descriptor.ts +439 -0
  277. package/src/lib/descriptors/editor.descriptor.ts +880 -0
  278. package/src/lib/descriptors/field.validator.ts +35 -0
  279. package/src/lib/descriptors/index.ts +7 -0
  280. package/src/lib/descriptors/lookup.descriptor.ts +20 -0
  281. package/src/lib/descriptors/model.descriptor.ts +47 -0
  282. package/src/lib/descriptors/table.descriptor.ts +514 -0
  283. package/src/lib/descriptors/tableview.descriptor.ts +180 -0
  284. package/src/lib/directives/component.directive.ts +18 -0
  285. package/src/lib/directives/index.ts +2 -0
  286. package/src/lib/directives/template.directive.ts +24 -0
  287. package/src/lib/mng-commons.module.ts +240 -0
  288. package/src/lib/models/index.ts +2 -0
  289. package/src/lib/models/router.model.ts +16 -0
  290. package/src/lib/models/user.model.ts +9 -0
  291. package/src/lib/pipes/boolean.pipe.ts +17 -0
  292. package/{lib/pipes/index.d.ts → src/lib/pipes/index.ts} +2 -1
  293. package/src/lib/pipes/property-path.pipe.ts +30 -0
  294. package/src/lib/services/action.service.ts +310 -0
  295. package/src/lib/services/commons.service.ts +407 -0
  296. package/src/lib/services/configuration.service.ts +98 -0
  297. package/{lib/services/index.d.ts → src/lib/services/index.ts} +4 -6
  298. package/src/lib/services/navigation.service.ts +42 -0
  299. package/src/lib/services/providers/commons-init.provider.ts +5 -0
  300. package/src/lib/services/providers/config-service.provider.ts +22 -0
  301. package/src/lib/services/providers/formly-config.provider.ts +39 -0
  302. package/{lib/services/providers/index.d.ts → src/lib/services/providers/index.ts} +3 -2
  303. package/src/lib/services/tokens/browser-storage.token.ts +9 -0
  304. package/src/lib/services/tokens/index.ts +2 -0
  305. package/src/lib/services/tokens/module-config.token.ts +5 -0
  306. package/{lib/models/types/index.d.ts → src/lib/types/index.ts} +2 -2
  307. package/src/lib/types/type.decorator.ts +7 -0
  308. package/src/lib/types/type.model.ts +12 -0
  309. package/src/lib/utils/editor-formly.util.ts +193 -0
  310. package/src/lib/utils/i18n.util.ts +148 -0
  311. package/{lib/utils/index.d.ts → src/lib/utils/index.ts} +5 -4
  312. package/src/lib/utils/model.util.ts +66 -0
  313. package/src/lib/utils/toast.util.ts +49 -0
  314. package/src/lib/utils/type.util.ts +44 -0
  315. package/{public-api.d.ts → src/public-api.ts} +42 -22
  316. package/src/test.ts +26 -0
  317. package/tsconfig.lib.json +15 -0
  318. package/tsconfig.lib.prod.json +10 -0
  319. package/tsconfig.spec.json +17 -0
  320. package/esm2020/lib/api/models/builders/query-param.builder.mjs +0 -49
  321. package/esm2020/lib/api/models/filter-match-type.model.mjs +0 -24
  322. package/esm2020/lib/api/models/filter-param.model.mjs +0 -46
  323. package/esm2020/lib/api/models/index.mjs +0 -9
  324. package/esm2020/lib/api/models/mappers.mjs +0 -17
  325. package/esm2020/lib/api/models/query-mode.model.mjs +0 -19
  326. package/esm2020/lib/api/models/query-param.model.mjs +0 -69
  327. package/esm2020/lib/api/models/query-result.model.mjs +0 -45
  328. package/esm2020/lib/api/models/serialization.model.mjs +0 -2
  329. package/esm2020/lib/api/services/abstract-crud-api.service.mjs +0 -72
  330. package/esm2020/lib/api/services/index.mjs +0 -2
  331. package/esm2020/lib/api/utils/index.mjs +0 -3
  332. package/esm2020/lib/api/utils/medius-rest.util.mjs +0 -70
  333. package/esm2020/lib/api/utils/object-serializer.util.mjs +0 -226
  334. package/esm2020/lib/components/action/action.component.mjs +0 -63
  335. package/esm2020/lib/components/action/dialog/action-dialog.component.mjs +0 -148
  336. package/esm2020/lib/components/action/index.mjs +0 -4
  337. package/esm2020/lib/components/action/route/action-route.component.mjs +0 -144
  338. package/esm2020/lib/components/form/editor/form-editor.component.mjs +0 -140
  339. package/esm2020/lib/components/form/formly/fields/formly-field-autocomplete/formly-field-autocomplete.component.mjs +0 -58
  340. package/esm2020/lib/components/form/formly/fields/formly-field-dropdown/formly-field-dropdown.component.mjs +0 -51
  341. package/esm2020/lib/components/form/formly/fields/formly-field-fieldset/formly-field-fieldset.component.mjs +0 -16
  342. package/esm2020/lib/components/form/formly/fields/formly-field-input/formly-field-input.component.mjs +0 -26
  343. package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +0 -94
  344. package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +0 -124
  345. package/esm2020/lib/components/form/formly/fields/formly-field-tabs/formly-field-tabs.component.mjs +0 -17
  346. package/esm2020/lib/components/form/formly/fields/index.mjs +0 -8
  347. package/esm2020/lib/components/form/formly/wrappers/formly-field-wrapper/formly-field-wrapper.component.mjs +0 -17
  348. package/esm2020/lib/components/form/formly/wrappers/formly-table-wrapper/formly-table-wrapper.component.mjs +0 -16
  349. package/esm2020/lib/components/form/formly/wrappers/index.mjs +0 -3
  350. package/esm2020/lib/components/form/index.mjs +0 -2
  351. package/esm2020/lib/components/layout/app.breadcrumb.component.mjs +0 -27
  352. package/esm2020/lib/components/layout/app.footer.component.mjs +0 -35
  353. package/esm2020/lib/components/layout/app.main.component.mjs +0 -25
  354. package/esm2020/lib/components/layout/app.main.component.service.mjs +0 -133
  355. package/esm2020/lib/components/layout/app.menu.component.mjs +0 -38
  356. package/esm2020/lib/components/layout/app.menuitem.component.mjs +0 -243
  357. package/esm2020/lib/components/layout/app.topbar.component.mjs +0 -135
  358. package/esm2020/lib/components/layout/index.mjs +0 -7
  359. package/esm2020/lib/components/tableview/index.mjs +0 -4
  360. package/esm2020/lib/components/tableview/route/tableview-route.abstract.component.mjs +0 -31
  361. package/esm2020/lib/components/tableview/table/table.component.mjs +0 -173
  362. package/esm2020/lib/components/tableview/tableview.component.mjs +0 -82
  363. package/esm2020/lib/components/tableview/tableview.component.service.mjs +0 -18
  364. package/esm2020/lib/config/formly.config.mjs +0 -165
  365. package/esm2020/lib/config/index.mjs +0 -2
  366. package/esm2020/lib/directives/index.mjs +0 -2
  367. package/esm2020/lib/directives/template.directive.mjs +0 -25
  368. package/esm2020/lib/mng-commons.module.mjs +0 -338
  369. package/esm2020/lib/models/action/action.model.mjs +0 -58
  370. package/esm2020/lib/models/action/index.mjs +0 -2
  371. package/esm2020/lib/models/config/index.mjs +0 -2
  372. package/esm2020/lib/models/config/mng-config.model.mjs +0 -3
  373. package/esm2020/lib/models/descriptors/action-descriptor.model.mjs +0 -283
  374. package/esm2020/lib/models/descriptors/editor-descriptor.model.mjs +0 -647
  375. package/esm2020/lib/models/descriptors/index.mjs +0 -6
  376. package/esm2020/lib/models/descriptors/model-descriptor.model.mjs +0 -34
  377. package/esm2020/lib/models/descriptors/table-descriptor.model.mjs +0 -123
  378. package/esm2020/lib/models/descriptors/tableview-descriptor.model.mjs +0 -124
  379. package/esm2020/lib/models/events/editor-event.model.mjs +0 -14
  380. package/esm2020/lib/models/events/index.mjs +0 -3
  381. package/esm2020/lib/models/events/table-event.model.mjs +0 -16
  382. package/esm2020/lib/models/interfaces/confirmation-service.model.mjs +0 -2
  383. package/esm2020/lib/models/interfaces/index.mjs +0 -2
  384. package/esm2020/lib/models/providers/data-provider.model.mjs +0 -86
  385. package/esm2020/lib/models/providers/index.mjs +0 -2
  386. package/esm2020/lib/models/types/index.mjs +0 -3
  387. package/esm2020/lib/models/types/type.decorator.mjs +0 -8
  388. package/esm2020/lib/models/types/type.model.mjs +0 -2
  389. package/esm2020/lib/models/validators/field.validator.mjs +0 -21
  390. package/esm2020/lib/models/validators/index.mjs +0 -2
  391. package/esm2020/lib/pipes/index.mjs +0 -2
  392. package/esm2020/lib/pipes/property-path.pipe.mjs +0 -36
  393. package/esm2020/lib/services/action.service.mjs +0 -239
  394. package/esm2020/lib/services/breadcrumb.service.mjs +0 -21
  395. package/esm2020/lib/services/configuration.service.mjs +0 -77
  396. package/esm2020/lib/services/index.mjs +0 -7
  397. package/esm2020/lib/services/menu.service.mjs +0 -26
  398. package/esm2020/lib/services/navigation.service.mjs +0 -49
  399. package/esm2020/lib/services/providers/config-service.provider.mjs +0 -12
  400. package/esm2020/lib/services/providers/formly-config.provider.mjs +0 -31
  401. package/esm2020/lib/services/providers/index.mjs +0 -3
  402. package/esm2020/lib/services/settings.service.mjs +0 -40
  403. package/esm2020/lib/utils/editor-formly.util.mjs +0 -165
  404. package/esm2020/lib/utils/i18n.util.mjs +0 -75
  405. package/esm2020/lib/utils/index.mjs +0 -5
  406. package/esm2020/lib/utils/model.util.mjs +0 -38
  407. package/esm2020/lib/utils/type.util.mjs +0 -43
  408. package/esm2020/mediusinc-mng-commons.mjs +0 -5
  409. package/esm2020/public-api.mjs +0 -33
  410. package/fesm2015/mediusinc-mng-commons.mjs +0 -5056
  411. package/fesm2015/mediusinc-mng-commons.mjs.map +0 -1
  412. package/fesm2020/mediusinc-mng-commons.mjs +0 -5012
  413. package/fesm2020/mediusinc-mng-commons.mjs.map +0 -1
  414. package/lib/api/models/builders/query-param.builder.d.ts +0 -11
  415. package/lib/api/models/filter-match-type.model.d.ts +0 -21
  416. package/lib/api/models/filter-param.model.d.ts +0 -23
  417. package/lib/api/models/mappers.d.ts +0 -6
  418. package/lib/api/models/query-param.model.d.ts +0 -31
  419. package/lib/api/models/query-result.model.d.ts +0 -36
  420. package/lib/api/services/abstract-crud-api.service.d.ts +0 -23
  421. package/lib/api/services/index.d.ts +0 -1
  422. package/lib/api/utils/medius-rest.util.d.ts +0 -6
  423. package/lib/api/utils/object-serializer.util.d.ts +0 -30
  424. package/lib/components/action/action.component.d.ts +0 -36
  425. package/lib/components/action/dialog/action-dialog.component.d.ts +0 -48
  426. package/lib/components/action/route/action-route.component.d.ts +0 -32
  427. package/lib/components/form/editor/form-editor.component.d.ts +0 -37
  428. package/lib/components/form/formly/fields/formly-field-autocomplete/formly-field-autocomplete.component.d.ts +0 -21
  429. package/lib/components/form/formly/fields/formly-field-dropdown/formly-field-dropdown.component.d.ts +0 -19
  430. package/lib/components/form/formly/fields/formly-field-fieldset/formly-field-fieldset.component.d.ts +0 -6
  431. package/lib/components/form/formly/fields/formly-field-input/formly-field-input.component.d.ts +0 -12
  432. package/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.d.ts +0 -17
  433. package/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.d.ts +0 -36
  434. package/lib/components/form/formly/fields/formly-field-tabs/formly-field-tabs.component.d.ts +0 -6
  435. package/lib/components/form/formly/wrappers/formly-field-wrapper/formly-field-wrapper.component.d.ts +0 -8
  436. package/lib/components/form/formly/wrappers/formly-table-wrapper/formly-table-wrapper.component.d.ts +0 -8
  437. package/lib/components/form/index.d.ts +0 -1
  438. package/lib/components/layout/app.breadcrumb.component.d.ts +0 -16
  439. package/lib/components/layout/app.footer.component.d.ts +0 -8
  440. package/lib/components/layout/app.main.component.d.ts +0 -12
  441. package/lib/components/layout/app.main.component.service.d.ts +0 -40
  442. package/lib/components/layout/app.menu.component.d.ts +0 -14
  443. package/lib/components/layout/app.menuitem.component.d.ts +0 -31
  444. package/lib/components/layout/app.topbar.component.d.ts +0 -16
  445. package/lib/components/layout/index.d.ts +0 -6
  446. package/lib/components/tableview/route/tableview-route.abstract.component.d.ts +0 -15
  447. package/lib/components/tableview/table/table.component.d.ts +0 -47
  448. package/lib/components/tableview/tableview.component.d.ts +0 -36
  449. package/lib/components/tableview/tableview.component.service.d.ts +0 -11
  450. package/lib/config/formly.config.d.ts +0 -8
  451. package/lib/directives/index.d.ts +0 -1
  452. package/lib/directives/template.directive.d.ts +0 -11
  453. package/lib/mng-commons.module.d.ts +0 -74
  454. package/lib/models/action/action.model.d.ts +0 -53
  455. package/lib/models/action/index.d.ts +0 -1
  456. package/lib/models/config/mng-config.model.d.ts +0 -19
  457. package/lib/models/descriptors/action-descriptor.model.d.ts +0 -124
  458. package/lib/models/descriptors/editor-descriptor.model.d.ts +0 -248
  459. package/lib/models/descriptors/index.d.ts +0 -5
  460. package/lib/models/descriptors/model-descriptor.model.d.ts +0 -15
  461. package/lib/models/descriptors/table-descriptor.model.d.ts +0 -45
  462. package/lib/models/descriptors/tableview-descriptor.model.d.ts +0 -38
  463. package/lib/models/events/editor-event.model.d.ts +0 -11
  464. package/lib/models/events/index.d.ts +0 -2
  465. package/lib/models/events/table-event.model.d.ts +0 -17
  466. package/lib/models/interfaces/confirmation-service.model.d.ts +0 -6
  467. package/lib/models/interfaces/index.d.ts +0 -1
  468. package/lib/models/providers/data-provider.model.d.ts +0 -62
  469. package/lib/models/providers/index.d.ts +0 -1
  470. package/lib/models/types/type.decorator.d.ts +0 -2
  471. package/lib/models/types/type.model.d.ts +0 -10
  472. package/lib/models/validators/field.validator.d.ts +0 -18
  473. package/lib/models/validators/index.d.ts +0 -1
  474. package/lib/pipes/property-path.pipe.d.ts +0 -7
  475. package/lib/services/action.service.d.ts +0 -92
  476. package/lib/services/breadcrumb.service.d.ts +0 -9
  477. package/lib/services/configuration.service.d.ts +0 -35
  478. package/lib/services/menu.service.d.ts +0 -11
  479. package/lib/services/navigation.service.d.ts +0 -14
  480. package/lib/services/providers/config-service.provider.d.ts +0 -5
  481. package/lib/services/providers/formly-config.provider.d.ts +0 -4
  482. package/lib/services/settings.service.d.ts +0 -18
  483. package/lib/utils/editor-formly.util.d.ts +0 -9
  484. package/lib/utils/i18n.util.d.ts +0 -14
  485. package/lib/utils/model.util.d.ts +0 -5
  486. package/lib/utils/type.util.d.ts +0 -15
  487. package/mediusinc-mng-commons-0.0.1-rc.3.tgz +0 -0
  488. package/mediusinc-mng-commons.d.ts +0 -5
@@ -0,0 +1,133 @@
1
+ import {ChangeDetectionStrategy, Component, Injector, OnDestroy, OnInit} from '@angular/core';
2
+
3
+ import {FieldType} from '@ngx-formly/core';
4
+ import {Message} from 'primeng/api';
5
+ import {finalize, first, startWith} from 'rxjs/operators';
6
+ import {Observable, ReplaySubject, Subject, Subscription} from 'rxjs';
7
+
8
+ import {MediusFilterMatchType, MediusQueryParamBuilder, MediusQueryResult} from '../../../../../api/models';
9
+ import {FieldManyToManyEditorDescriptor} from '../../../../../descriptors';
10
+
11
+ @Component({
12
+ selector: 'mng-formly-table-multiselect-add-field',
13
+ templateUrl: './formly-field-table-dialog-multiselect.component.html',
14
+ changeDetection: ChangeDetectionStrategy.OnPush
15
+ })
16
+ export class MngFormlyFieldTableDialogMultiselectComponent<T, ET> extends FieldType implements OnInit, OnDestroy {
17
+
18
+ public descriptor!: FieldManyToManyEditorDescriptor<T, ET>;
19
+
20
+ public itemsSubject: Subject<Array<T>> = new ReplaySubject(1);
21
+ public itemsAsync: Observable<Array<T>> = this.itemsSubject.asObservable();
22
+ public addItemsSubject: Subject<MediusQueryResult<T>> = new ReplaySubject(1);
23
+ public addItemsAsync: Observable<MediusQueryResult<T>> = this.addItemsSubject.asObservable();
24
+
25
+ public dialogUseDataProvider: boolean = false;
26
+ private dialogDataProviderService: any = null;
27
+ private dialogIsLoadingSubject = new ReplaySubject<boolean>(1);
28
+
29
+ public isDialogVisible = false;
30
+ public dialogAreItemsLoaded = false;
31
+ public dialogSelectedAddItems: Array<any> = [];
32
+ public dialogMessages: Message[] = [];
33
+ public dialogIsLoading$ = this.dialogIsLoadingSubject.asObservable();
34
+
35
+ public hasAddAction: boolean = false;
36
+ public hasDeleteAction: boolean = false;
37
+
38
+ private subscriptions: Subscription[] = [];
39
+
40
+ constructor(private injector: Injector) {
41
+ super();
42
+ }
43
+
44
+ public ngOnInit() {
45
+
46
+ this.descriptor = this.to['descriptor'];
47
+ if (this.descriptor.lookupTableDataProvider?.serviceType) {
48
+ this.dialogUseDataProvider = true;
49
+ this.dialogDataProviderService = this.injector.get<any>(this.descriptor.lookupTableDataProvider.serviceType);
50
+ }
51
+ this.hasAddAction = this.descriptor.actions.some(a => a === FieldManyToManyEditorDescriptor.ActionEnum.Add);
52
+ this.hasDeleteAction = this.descriptor.actions.some(a => a === FieldManyToManyEditorDescriptor.ActionEnum.Delete);
53
+
54
+ // init values
55
+ if (typeof this.formControl.value === 'undefined' || this.formControl.value === null) {
56
+ this.formControl.patchValue([]);
57
+ }
58
+ const subscription = this.formControl.valueChanges
59
+ .pipe(
60
+ startWith(this.formControl.value)
61
+ )
62
+ .subscribe(v => {
63
+ this.itemsSubject.next(v);
64
+ });
65
+ this.subscriptions.push(subscription);
66
+ }
67
+
68
+ public ngOnDestroy() {
69
+ this.subscriptions.forEach(s => s.unsubscribe());
70
+ }
71
+
72
+ openAddDialog() {
73
+ if (!this.dialogAreItemsLoaded && this.dialogUseDataProvider) {
74
+ this.dialogIsLoadingSubject.next(true);
75
+ const queryParamBuilder = MediusQueryParamBuilder.create(50);
76
+ if (this.descriptor.lookupTableDescriptor.hasDefaultSort) {
77
+ this.descriptor.lookupTableDescriptor.defaultSortProperty.forEach((p, idx) => queryParamBuilder.withSort(p, this.descriptor.lookupTableDescriptor.defaultSortAsc[idx]));
78
+ }
79
+ if (this.descriptor.hasLookupExcludeValues) {
80
+ const filterValues = this.formControl.value.map((i: any) => i[this.descriptor.excludeValueProperty])
81
+ queryParamBuilder.withFilter(this.descriptor.excludeFilterProperty, filterValues, undefined, MediusFilterMatchType.NotIn);
82
+ }
83
+ this.descriptor.lookupTableDataProvider?.getAll(queryParamBuilder.build(), this.dialogDataProviderService)
84
+ .pipe(
85
+ first(),
86
+ finalize(() => this.dialogIsLoadingSubject.next(false))
87
+ )
88
+ .subscribe(res => {
89
+ this.addItemsSubject.next(res);
90
+ this.dialogAreItemsLoaded = true;
91
+ });
92
+ }
93
+ this.dialogSelectedAddItems = [];
94
+ this.isDialogVisible = true;
95
+ }
96
+
97
+ onSelectionChange(items: Array<any>) {
98
+ this.dialogSelectedAddItems = items;
99
+ }
100
+
101
+ hideDialog() {
102
+ this.isDialogVisible = false;
103
+ }
104
+
105
+ addItems() {
106
+ let value = this.formControl.value;
107
+ if (Array.isArray(value)) {
108
+ value = [...value, ...this.dialogSelectedAddItems];
109
+ this.formControl.patchValue(value);
110
+ this.dialogSelectedAddItems = [];
111
+ this.dialogAreItemsLoaded = false;
112
+ this.hideDialog();
113
+ } else {
114
+ console.error("Values are not an valid array, cannot add selected items to array");
115
+ this.dialogMessages = [{ severity: 'error', summary: 'Error', detail: 'Selected items could not be added' }];
116
+ }
117
+ }
118
+
119
+ removeItem(item: any) {
120
+ let value = this.formControl.value;
121
+ if (Array.isArray(value)) {
122
+ const compareProperty = this.descriptor.mainTableDescriptor.dataKeyProperty ? this.descriptor.mainTableDescriptor.dataKeyProperty : this.descriptor.mainTableDescriptor.model.idPropertyName;
123
+ if (!compareProperty) {
124
+ throw new Error('Cannot compare items, please provide main table data key property or model id property.');
125
+ }
126
+ value = value.filter(i => i[compareProperty] !== item[compareProperty]);
127
+ this.formControl.patchValue(value);
128
+ this.dialogAreItemsLoaded = false;
129
+ } else {
130
+ console.error("Values are not an valid array, cannot delete selected item from array");
131
+ }
132
+ }
133
+ }
@@ -0,0 +1,10 @@
1
+ <p-tabView>
2
+ <p-tabPanel *ngFor="let tab of field.fieldGroup; let i = index; let last = last;"
3
+ [header]="tab.templateOptions?.label!"
4
+ [headerStyleClass]="formControl.valid ? 'p-tabview-title' : 'bla'">
5
+ <ng-template pTemplate="header">
6
+ <span class="p-tabview-title" [class.p-tabview-title-error]="formState.submittedOn && formState['tab_' + (tab.id ? tab.id : tab.templateOptions?.label!) + '_invalid']">{{ tab.templateOptions?.label! | translate }}</span>
7
+ </ng-template>
8
+ <formly-field [field]="tab"></formly-field>
9
+ </p-tabPanel>
10
+ </p-tabView>
@@ -0,0 +1,10 @@
1
+ import {Component, ChangeDetectionStrategy} from '@angular/core';
2
+ import { FieldType } from '@ngx-formly/core';
3
+
4
+ @Component({
5
+ selector: 'mng-formly-field-tabs',
6
+ templateUrl: './formly-field-tabs.component.html',
7
+ changeDetection: ChangeDetectionStrategy.OnPush,
8
+ })
9
+ export class MngFormlyFieldTabsComponent extends FieldType {
10
+ }
@@ -1,7 +1,7 @@
1
- export * from './formly-field-autocomplete/formly-field-autocomplete.component';
2
- export * from './formly-field-input/formly-field-input.component';
3
- export * from './formly-field-dropdown/formly-field-dropdown.component';
4
- export * from './formly-field-table-dialog-form/formly-field-table-dialog-form.component';
5
- export * from './formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component';
6
- export * from './formly-field-tabs/formly-field-tabs.component';
7
- export * from './formly-field-fieldset/formly-field-fieldset.component';
1
+ export * from './formly-field-autocomplete/formly-field-autocomplete.component';
2
+ export * from './formly-field-input/formly-field-input.component';
3
+ export * from './formly-field-dropdown/formly-field-dropdown.component';
4
+ export * from './formly-field-table-dialog-form/formly-field-table-dialog-form.component';
5
+ export * from './formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component';
6
+ export * from './formly-field-tabs/formly-field-tabs.component';
7
+ export * from './formly-field-fieldset/formly-field-fieldset.component';
@@ -0,0 +1,7 @@
1
+ <div class="field">
2
+ <label [for]="key">{{ $any(to?.label) | translate }} <span *ngIf="to.required && to['hideRequiredMarker'] !== true">*</span></label>
3
+ <ng-container #fieldComponent></ng-container>
4
+ <small *ngIf="showError" class="p-error">
5
+ <formly-validation-message [field]="field"></formly-validation-message>
6
+ </small>
7
+ </div>
@@ -0,0 +1,13 @@
1
+ import {ChangeDetectionStrategy, Component, OnInit} from '@angular/core';
2
+ import { FieldWrapper } from '@ngx-formly/core';
3
+
4
+ @Component({
5
+ selector: 'mng-formly-field-wrapper',
6
+ templateUrl: './formly-field-wrapper.component.html',
7
+ changeDetection: ChangeDetectionStrategy.OnPush
8
+ })
9
+ export class MngFormlyFieldWrapperComponent extends FieldWrapper implements OnInit {
10
+
11
+ public ngOnInit() {
12
+ }
13
+ }
@@ -0,0 +1,6 @@
1
+ <div class="field table">
2
+ <ng-container #fieldComponent></ng-container>
3
+ <small *ngIf="showError" class="p-error">
4
+ <formly-validation-message [field]="field"></formly-validation-message>
5
+ </small>
6
+ </div>
@@ -0,0 +1,13 @@
1
+ import {ChangeDetectionStrategy, Component, OnInit} from '@angular/core';
2
+ import { FieldWrapper } from '@ngx-formly/core';
3
+
4
+ @Component({
5
+ selector: 'mng-formly-table-wrapper',
6
+ templateUrl: './formly-table-wrapper.component.html',
7
+ changeDetection: ChangeDetectionStrategy.OnPush
8
+ })
9
+ export class MngFormlyTableWrapperComponent extends FieldWrapper implements OnInit {
10
+
11
+ public ngOnInit() {
12
+ }
13
+ }
@@ -1,2 +1,2 @@
1
- export * from './formly-field-wrapper/formly-field-wrapper.component';
2
- export * from './formly-table-wrapper/formly-table-wrapper.component';
1
+ export * from './formly-field-wrapper/formly-field-wrapper.component';
2
+ export * from './formly-table-wrapper/formly-table-wrapper.component';
@@ -0,0 +1,3 @@
1
+ export * from './editor/form-editor.component';
2
+ export * from './autocomplete/autocomplete.component';
3
+ export * from './dropdown/dropdown.component';
@@ -0,0 +1,7 @@
1
+ export class MngFormEditorSubmitEvent<T> {
2
+ public success: boolean = true;
3
+
4
+ constructor(
5
+ public readonly formItem: T
6
+ ) {}
7
+ }
@@ -0,0 +1 @@
1
+ export * from './form-editor.event';
@@ -0,0 +1,5 @@
1
+ <div class="layout-breadcrumb-container">
2
+ <div class="layout-breadcrumb">
3
+ <p-breadcrumb [home]="$any(mngCommons.breadcrumbHome$ | async)" [model]="$any(mngCommons.breadcrumbs$ |async)" styleClass="layout-breadcrumb py-2"></p-breadcrumb>
4
+ </div>
5
+ </div>
@@ -0,0 +1,12 @@
1
+ import {ChangeDetectionStrategy, Component} from '@angular/core';
2
+
3
+ import {MngCommonsService} from '../../services';
4
+
5
+ @Component({
6
+ selector: 'mng-breadcrumb',
7
+ templateUrl: './breadcrumb.component.html',
8
+ changeDetection: ChangeDetectionStrategy.OnPush
9
+ })
10
+ export class MngBreadcrumbComponent {
11
+ constructor(public mngCommons: MngCommonsService) {}
12
+ }
@@ -0,0 +1,7 @@
1
+ <div class="layout-footer">
2
+ <div class="footer-logo-container">
3
+ <img id="footer-logo" [src]="mngCommons.colorSchemeIsLight ? mngCommons.appLogoDark : mngCommons.appLogoLight" alt="atlantis-layout"/>
4
+ <span class="app-name">{{ mngCommons.appName | translate }}</span>
5
+ </div>
6
+ <span class="copyright">&#169; {{ mngCommons.appOwner | translate }} - {{ currentYear }}</span>
7
+ </div>
@@ -0,0 +1,15 @@
1
+ import {ChangeDetectionStrategy, Component} from '@angular/core';
2
+
3
+ import {MngCommonsService} from '../../services';
4
+
5
+ @Component({
6
+ selector: 'mng-footer',
7
+ templateUrl: './footer.component.html',
8
+ changeDetection: ChangeDetectionStrategy.OnPush
9
+ })
10
+ export class MngFooterComponent {
11
+
12
+ public currentYear = new Date().getFullYear();
13
+
14
+ constructor(public mngCommons: MngCommonsService) {}
15
+ }
@@ -0,0 +1,6 @@
1
+ export * from './breadcrumb.component';
2
+ export * from './footer.component';
3
+ export * from './main-layout.component';
4
+ export * from './menu.component';
5
+ export * from './menu-item.component';
6
+ export * from './topbar.component';
@@ -0,0 +1,26 @@
1
+ <div class="layout-wrapper" (click)="mainLayoutService.onLayoutClick()"
2
+ [ngClass]="{'layout-static': mngCommons.menuModeIsStatic$ | async,
3
+ 'layout-overlay': mngCommons.menuModeIsOverlay$ | async,
4
+ 'layout-slim': mngCommons.menuModeIsSlim$ | async,
5
+ 'layout-sidebar': mngCommons.menuModeIsSidebar$ | async,
6
+ 'layout-sidebar-static': (mngCommons.menuModeIsSidebar$ | async) && (mainLayoutService.sidebarStatic$ | async),
7
+ 'layout-overlay-active': mainLayoutService.overlayMenuActive$ | async,
8
+ 'layout-mobile-active': mainLayoutService.staticMenuMobileActive$ | async,
9
+ 'layout-static-inactive': (mainLayoutService.staticMenuDesktopInactive$ | async) && (mngCommons.menuModeIsStatic$ | async) }">
10
+
11
+ <div class="layout-main">
12
+
13
+ <ng-container [mngComponent]="footerComponent"></ng-container>
14
+
15
+ <ng-container *ngIf="!(mainLayoutService.isMobile$ | async) && ((mngCommons.menuModeIsStatic$ | async) || (mngCommons.menuModeIsSlim$ | async) || (mngCommons.menuModeIsSidebar$ | async))"
16
+ [mngComponent]="menuComponent">
17
+ </ng-container>
18
+
19
+ <div class="layout-main-content">
20
+ <router-outlet></router-outlet>
21
+ </div>
22
+
23
+ <ng-container [mngComponent]="footerComponent"></ng-container>
24
+ </div>
25
+
26
+ </div>
@@ -0,0 +1,54 @@
1
+ import {AfterViewInit, ChangeDetectionStrategy, Component, HostListener, QueryList, Type, ViewChildren} from '@angular/core';
2
+ import {ActivatedRoute} from '@angular/router';
3
+
4
+ import {MngCommonsService} from '../../services';
5
+ import {MngMainLayoutComponentService} from './services';
6
+ import {MngTemplateDirective} from '../../directives';
7
+ import {MngRouterData} from '../../models';
8
+ import {MngFooterComponent} from './footer.component';
9
+ import {MngMenuComponent} from './menu.component';
10
+ import {MngTopbarComponent} from './topbar.component';
11
+
12
+ @Component({
13
+ selector: 'mng-main-layout',
14
+ templateUrl: './main-layout.component.html',
15
+ providers: [MngMainLayoutComponentService],
16
+ changeDetection: ChangeDetectionStrategy.OnPush
17
+ })
18
+ export class MngMainLayoutComponent implements AfterViewInit {
19
+
20
+ @ViewChildren(MngTemplateDirective) templates!: QueryList<MngTemplateDirective>;
21
+
22
+ public topbarComponent: Type<any> = MngTopbarComponent;
23
+ public menuComponent: Type<any> = MngMenuComponent;
24
+ public footerComponent: Type<any> = MngFooterComponent;
25
+
26
+ constructor(
27
+ private route: ActivatedRoute,
28
+ public mngCommons: MngCommonsService,
29
+ public mainLayoutService: MngMainLayoutComponentService
30
+ ) {}
31
+
32
+ ngOnInit() {
33
+ const routeData = this.route.snapshot.data as MngRouterData;
34
+ if (routeData?.topbarComponent) {
35
+ this.topbarComponent = routeData.topbarComponent;
36
+ }
37
+ if (routeData?.menuComponent) {
38
+ this.menuComponent = routeData.menuComponent;
39
+ }
40
+ if (routeData?.footerComponent) {
41
+ this.footerComponent = routeData.footerComponent;
42
+ }
43
+ }
44
+
45
+ ngAfterViewInit(): void {
46
+ this.mainLayoutService.innerWidth = window.innerWidth;
47
+ }
48
+
49
+ @HostListener('window:resize', ['$event'])
50
+ onWindowResize(event: UIEvent) {
51
+ const target: any = event.target;
52
+ this.mainLayoutService.innerWidth = target?.innerWidth ?? window.innerWidth;
53
+ }
54
+ }
@@ -0,0 +1,41 @@
1
+ <ng-container>
2
+ <div *ngIf="root && item.visible !== false" class="layout-menuitem-root-text">{{ item.label | translate }}</div>
3
+ <a *ngIf="(!item.routerLink || item.items) && item.visible !== false"
4
+ [attr.href]="item.url"
5
+ (click)="itemClick($event)"
6
+ (mouseenter)="onMouseEnter()"
7
+ (keydown.enter)="itemClick($event)"
8
+ [attr.target]="item.target"
9
+ [attr.tabindex]="0"
10
+ [ngClass]="item.class"
11
+ pRipple>
12
+ <i [ngClass]="item.icon" class="layout-menuitem-icon"></i>
13
+ <span class="layout-menuitem-text">{{ item.label | translate }}</span>
14
+ <i class="pi pi-fw pi-angle-down layout-submenu-toggler" *ngIf="item.items"></i>
15
+ <span class="menuitem-badge" *ngIf="item.badge">{{ item.badge }}</span>
16
+ </a>
17
+ <a *ngIf="(item.routerLink && !item.items) && item.visible !== false"
18
+ (click)="itemClick($event)"
19
+ (mouseenter)="hover=true"
20
+ (mouseleave)="hover=false"
21
+ [routerLink]="item.routerLink"
22
+ routerLinkActive="active-menuitem-routerlink"
23
+ [routerLinkActiveOptions]="{ exact: true }"
24
+ [attr.target]="item.target"
25
+ [attr.tabindex]="0"
26
+ [ngClass]="item.class"
27
+ pRipple>
28
+ <i [ngClass]="item.icon" class="layout-menuitem-icon"></i>
29
+ <span class="layout-menuitem-text">{{ item.label | translate }}</span>
30
+ <i class="pi pi-fw pi-angle-down layout-submenu-toggler" *ngIf="item.items"></i>
31
+ <span class="menuitem-badge" *ngIf="item.badge">{{ item.badge }}</span>
32
+ </a>
33
+ <ul *ngIf="((item.items && active) || (item.items && (mngCommons.menuModeIsStatic$ | async) && (root || active))) && item.visible !== false"
34
+ [@children]="((mngCommons.menuModeIsSlim$ | async) && !(mainLayoutService.isMobile$ | async) && root)
35
+ ? (active ? 'visible' : 'hidden')
36
+ : ((mngCommons.menuModeIsStatic$ | async) && root && !(mainLayoutService.isMobile$ | async) ? 'visible' : (active ? 'visibleAnimated' : 'hiddenAnimated'))">
37
+ <ng-template ngFor let-child let-i="index" [ngForOf]="item.items">
38
+ <li mng-menuitem [item]="child" [index]="i" [parentKey]="key" [class]="child.badgeClass"></li>
39
+ </ng-template>
40
+ </ul>
41
+ </ng-container>
@@ -0,0 +1,170 @@
1
+ import {Component, Input, OnInit, ChangeDetectorRef, OnDestroy, ChangeDetectionStrategy} from '@angular/core';
2
+ import {Router, NavigationEnd} from '@angular/router';
3
+ import {trigger, state, style, transition, animate} from '@angular/animations';
4
+
5
+ import {Subscription} from 'rxjs';
6
+ import {filter} from 'rxjs/operators';
7
+
8
+ import {MngCommonsService} from '../../services';
9
+ import {MngMainLayoutComponentService} from './services';
10
+
11
+ @Component({
12
+ /* tslint:disable:component-selector */
13
+ selector: '[mng-menuitem]',
14
+ /* tslint:enable:component-selector */
15
+ templateUrl: './menu-item.component.html',
16
+ host: {
17
+ '[class.layout-root-menuitem]': 'root',
18
+ '[class.active-menuitem]': 'active'
19
+ },
20
+ animations: [
21
+ trigger('children', [
22
+ state('void', style({
23
+ height: '0px'
24
+ })),
25
+ state('hiddenAnimated', style({
26
+ height: '0px'
27
+ })),
28
+ state('visibleAnimated', style({
29
+ height: '*'
30
+ })),
31
+ state('visible', style({
32
+ height: '*',
33
+ 'z-index': 100
34
+ })),
35
+ state('hidden', style({
36
+ height: '0px',
37
+ 'z-index': '*'
38
+ })),
39
+ transition('visibleAnimated => hiddenAnimated', animate('400ms cubic-bezier(0.86, 0, 0.07, 1)')),
40
+ transition('hiddenAnimated => visibleAnimated', animate('400ms cubic-bezier(0.86, 0, 0.07, 1)')),
41
+ transition('void => visibleAnimated, visibleAnimated => void', animate('400ms cubic-bezier(0.86, 0, 0.07, 1)'))
42
+ ])
43
+ ],
44
+ changeDetection: ChangeDetectionStrategy.OnPush
45
+ })
46
+ export class MngMenuItemComponent implements OnInit, OnDestroy {
47
+
48
+ @Input() item: any;
49
+
50
+ @Input() index: number = 0;
51
+
52
+ @Input() root: boolean = false;
53
+
54
+ @Input() parentKey: string|null = null;
55
+
56
+ active = false;
57
+
58
+ hover: boolean = false;
59
+
60
+ menuSourceSubscription: Subscription;
61
+
62
+ menuResetSubscription: Subscription;
63
+
64
+ key: string = '';
65
+
66
+ constructor(
67
+ public router: Router,
68
+ private cd: ChangeDetectorRef,
69
+ public mngCommons: MngCommonsService,
70
+ public mainLayoutService: MngMainLayoutComponentService
71
+ ) {
72
+ this.menuSourceSubscription = this.mngCommons.menuActiveKey$.subscribe(key => {
73
+ // deactivate current active menu
74
+ if (this.active && this.key !== key && key.indexOf(this.key) !== 0) {
75
+ this.active = false;
76
+ }
77
+ });
78
+
79
+ this.menuResetSubscription = this.mngCommons.menuReset$.subscribe(() => {
80
+ this.active = false;
81
+ });
82
+
83
+ this.router.events
84
+ .pipe(filter(event => event instanceof NavigationEnd))
85
+ .subscribe(params => {
86
+ if (this.mngCommons.menuModeIsSlim && !this.mainLayoutService.isMobile()) {
87
+ this.active = false;
88
+ } else {
89
+ if (this.item.routerLink) {
90
+ this.updateActiveStateFromRoute();
91
+ } else {
92
+ this.active = false;
93
+ }
94
+ }
95
+ });
96
+ }
97
+
98
+ ngOnInit() {
99
+ if (!this.mngCommons.menuModeIsSlim && this.item.routerLink) {
100
+ this.updateActiveStateFromRoute();
101
+ }
102
+
103
+ this.key = this.parentKey ? this.parentKey + '-' + this.index : String(this.index);
104
+ }
105
+
106
+ updateActiveStateFromRoute() {
107
+ this.active = this.router.isActive(this.item.routerLink[0], this.item.items ? false : true);
108
+ }
109
+
110
+ itemClick(event: Event) {
111
+ // avoid processing disabled items
112
+ if (this.item.disabled) {
113
+ event.preventDefault();
114
+ return;
115
+ }
116
+
117
+ // navigate with hover in horizontal mode
118
+ if (this.root) {
119
+ this.mainLayoutService.menuHoverActive = !this.mainLayoutService.menuHoverActive;
120
+ }
121
+
122
+ // notify other items
123
+ this.mngCommons.menuChangeActiveKey(this.key);
124
+
125
+ // execute command
126
+ if (this.item.command) {
127
+ this.item.command({originalEvent: event, item: this.item});
128
+ }
129
+
130
+ // toggle active state
131
+ if (this.item.items) {
132
+ this.active = !this.active;
133
+ } else {
134
+ // activate item
135
+ this.active = true;
136
+
137
+ if (this.mainLayoutService.isMobile()) {
138
+ this.mainLayoutService.staticMenuMobileActive = false;
139
+ }
140
+
141
+ if (this.mngCommons.menuModeIsOverlay) {
142
+ this.mainLayoutService.overlayMenuActive = false;
143
+ }
144
+
145
+ // reset horizontal menu
146
+ if (this.mngCommons.menuModeIsSlim && !this.mainLayoutService.isMobile()){
147
+ this.mngCommons.menuReset();
148
+ this.mainLayoutService.menuHoverActive = false;
149
+ }
150
+ }
151
+ }
152
+
153
+ onMouseEnter() {
154
+ // activate item on hover
155
+ if (this.root && this.mainLayoutService.menuHoverActive && (this.mngCommons.menuModeIsSlim) && this.mainLayoutService.isDesktop()) {
156
+ this.mngCommons.menuChangeActiveKey(this.key);
157
+ this.active = true;
158
+ }
159
+ }
160
+
161
+ ngOnDestroy() {
162
+ if (this.menuSourceSubscription) {
163
+ this.menuSourceSubscription.unsubscribe();
164
+ }
165
+
166
+ if (this.menuResetSubscription) {
167
+ this.menuResetSubscription.unsubscribe();
168
+ }
169
+ }
170
+ }
@@ -0,0 +1,27 @@
1
+ <div class="layout-menu-wrapper" [ngClass]="{ 'layout-sidebar-active': (mainLayoutService.sidebarActive$ | async) }"
2
+ (click)="mainLayoutService.onSidebarClick($event)" (mouseover)="mainLayoutService.onSidebarMouseOver($event)" (mouseleave)="mainLayoutService.onSidebarMouseLeave($event)">
3
+ <div class="menu-logo">
4
+
5
+ <a routerLink="/" class="logo">
6
+ <img [src]="mngCommons.colorSchemeIsLight ? mngCommons.appLogoDark : mngCommons.appLogoLight" />
7
+ </a>
8
+
9
+ <a routerLink="/" class="app-name" *ngIf="!(mngCommons.menuModeIsSlim$ | async) || (mainLayoutService.isMobile$ | async)">
10
+ <img [src]="mngCommons.colorSchemeIsLight ? mngCommons.appLogoNameDark : mngCommons.appLogoNameLight" />
11
+ </a>
12
+ <a *ngIf="mngCommons.menuPinEnabled" class="menu-pin" (click)="mainLayoutService.onToggleMenu($event)">
13
+ <span *ngIf="mngCommons.menuModeIsOverlay$ | async" class="pi pi-times"></span>
14
+ <span *ngIf="(mngCommons.menuModeIsSidebar$ | async) && !(mainLayoutService.sidebarStatic$ | async) && (mainLayoutService.pinActive$ | async)" class="pi pi-unlock"></span>
15
+ <span *ngIf="(mngCommons.menuModeIsSidebar$ | async) && (mainLayoutService.sidebarStatic$ | async) && (mainLayoutService.pinActive$ | async)" class="pi pi-lock"></span>
16
+ </a>
17
+ </div>
18
+
19
+ <div class="layout-menu-container">
20
+ <ul class="layout-menu">
21
+ <ng-container *ngFor="let item of (mngCommons.menuItems); let i = index;">
22
+ <li mng-menuitem *ngIf="!item.separator" [item]="item" [index]="i" [root]="true"></li>
23
+ <li *ngIf="item.separator" class="menu-separator"></li>
24
+ </ng-container>
25
+ </ul>
26
+ </div>
27
+ </div>
@@ -0,0 +1,17 @@
1
+ import {ChangeDetectionStrategy, Component} from '@angular/core';
2
+
3
+ import {MngCommonsService} from '../../services';
4
+ import {MngMainLayoutComponentService} from './services';
5
+
6
+ @Component({
7
+ selector: 'mng-menu',
8
+ templateUrl: './menu.component.html',
9
+ changeDetection: ChangeDetectionStrategy.OnPush
10
+ })
11
+ export class MngMenuComponent {
12
+
13
+ constructor(
14
+ public mngCommons: MngCommonsService,
15
+ public mainLayoutService: MngMainLayoutComponentService
16
+ ) {}
17
+ }
@@ -0,0 +1 @@
1
+ export * from './main-layout.component.service';