@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,110 @@
1
+ <div [style.height]="scrollHeight === 'flex' ? 'calc(100vh - ' + descriptor.tableFullHeightOffset + 'px)' : null">
2
+ <!-- MUST NOT use observable for value when using virtual scroll - does not work for some reason -->
3
+ <p-table *ngIf="!useQueryParams || useQueryParamsInitialized"
4
+ [value]="infiniteScroll ? dataProviderInfiniteScrollItems : ((queryResult$ | async)?.pageData ?? [])"
5
+ [dataKey]="$any(descriptor.dataKeyProperty)"
6
+ [lazy]="useDataProvider"
7
+ [loading]="(loading$ | async) ?? false"
8
+ [paginator]="useDataProvider && !infiniteScroll"
9
+ [rows]="$any(infiniteScroll ? 20 : rows)"
10
+ [first]="$any(infiniteScroll ? 0 : offset)"
11
+ [totalRecords]="$any(infiniteScroll ? null : (queryResult$ | async)?.allDataCount ?? 0)"
12
+ [rowsPerPageOptions]="$any(infiniteScroll ? null : rowsPerPageOptions)"
13
+ [showCurrentPageReport]="!infiniteScroll"
14
+ [currentPageReportTemplate]="'mngTable.paginationMsg' | translate"
15
+ [multiSortMeta]="$any(multiSortMeta)"
16
+ [filters]="filterMetadata"
17
+ [(selection)]="selection"
18
+ (selectionChange)="onSelectionChange($event)"
19
+ [scrollable]="infiniteScroll"
20
+ [virtualScroll]="infiniteScroll"
21
+ [virtualRowHeight]="$any(rowHeight)"
22
+ [scrollHeight]="$any(scrollHeight)"
23
+ [rowHover]="true"
24
+ (onLazyLoad)="onTableLazyLoad($event)"
25
+ (onSort)="onTableSort($event)"
26
+ (onFilter)="onTableFilter($event)"
27
+ sortMode="multiple"
28
+ responsiveLayout="scroll">
29
+
30
+ <ng-template *ngIf="captionTemplate || descriptor.title" pTemplate="caption">
31
+ <ng-container *ngIf="captionTemplate; else defaultCaption">
32
+ <ng-container *ngTemplateOutlet="captionTemplate"></ng-container>
33
+ </ng-container>
34
+ <ng-template #defaultCaption>
35
+ <h5 class="p-m-0">{{ descriptor.title }}</h5>
36
+ </ng-template>
37
+ </ng-template>
38
+
39
+ <ng-template pTemplate="header">
40
+ <tr>
41
+ <th *ngIf="selectionEnabled">
42
+ <p-tableHeaderCheckbox></p-tableHeaderCheckbox>
43
+ </th>
44
+ <ng-container *ngFor="let col of descriptor.columns">
45
+ <th *ngIf="col.isSortEnabled" [pSortableColumn]="col.property">
46
+ <div class="flex justify-content-between align-items-center">
47
+ {{ descriptor.model.typeName + ".properties." + col.property | translate }}
48
+ <p-sortIcon [field]="col.property"></p-sortIcon>
49
+ <mng-table-column-filter *ngIf="col.filterDescriptor && descriptor.filterDisplay === filterDisplayMenu"
50
+ class="ml-auto"
51
+ [display]="descriptor.filterDisplay"
52
+ [descriptor]="col.filterDescriptor">
53
+ </mng-table-column-filter>
54
+ </div>
55
+ </th>
56
+ <th *ngIf="!col.isSortEnabled">
57
+ {{ descriptor.model.typeName + ".properties." + col.property | translate }}
58
+ <ng-container>
59
+ <mng-table-column-filter *ngIf="col.filterDescriptor && descriptor.filterDisplay === filterDisplayMenu"
60
+ class="ml-auto"
61
+ [display]="descriptor.filterDisplay"
62
+ [descriptor]="col.filterDescriptor">
63
+ </mng-table-column-filter>
64
+ </ng-container>
65
+ </th>
66
+ </ng-container>
67
+ <th *ngIf="columnActionTemplate"></th>
68
+ </tr>
69
+ <tr *ngIf="descriptor.filterDisplay === filterDisplayRow">
70
+ <th *ngFor="let col of descriptor.columns">
71
+ <div class="flex" *ngIf="col.filterDescriptor">
72
+ <mng-table-column-filter [display]="descriptor.filterDisplay" [descriptor]="col.filterDescriptor"></mng-table-column-filter>
73
+ </div>
74
+ </th>
75
+ <th *ngIf="columnActionTemplate"></th>
76
+ </tr>
77
+ </ng-template>
78
+
79
+ <ng-template pTemplate="body" let-item let-idx="rowIndex">
80
+ <tr [style.height.px]="descriptor.rowHeight">
81
+ <td *ngIf="selectionEnabled">
82
+ <p-tableCheckbox [value]="item"></p-tableCheckbox>
83
+ </td>
84
+ <td *ngFor="let col of descriptor.columns" (click)="onCellClick(col, item, idx)" class="clickable">
85
+ <mng-table-column-value [descriptor]="col" [item]="item"></mng-table-column-value>
86
+ </td>
87
+ <td *ngIf="columnActionTemplate" class="text-right">
88
+ <ng-container *ngTemplateOutlet="columnActionTemplate; context: { rowItem: item, rowIndex: idx }"></ng-container>
89
+ </td>
90
+ </tr>
91
+ </ng-template>
92
+
93
+ <ng-template pTemplate="loadingbody">
94
+ <tr [style.height.px]="descriptor.rowHeight">
95
+ <td [attr.colspan]="descriptor.columns.length + (columnActionTemplate ? 1 : 0) + (selectionEnabled ? 1 : 0)">
96
+ <div class="loading-text"></div>
97
+ <p-skeleton [ngStyle]="{'width': '100%'}"></p-skeleton>
98
+ </td>
99
+ </tr>
100
+ </ng-template>
101
+
102
+ <ng-template pTemplate="emptymessage">
103
+ <tr [style.height.px]="rowHeight">
104
+ <td [attr.colspan]="descriptor.columns.length + (columnActionTemplate ? 1 : 0) + (selectionEnabled ? 1 : 0)">
105
+ {{ 'mngTable.noItems' | translate }}
106
+ </td>
107
+ </tr>
108
+ </ng-template>
109
+ </p-table>
110
+ </div>
@@ -0,0 +1,327 @@
1
+ import {AfterContentInit, ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Injector, Input, OnDestroy, OnInit, Optional, Output, QueryList, TemplateRef, ViewChild} from '@angular/core';
2
+ import {ActivatedRoute, Params, Router} from '@angular/router';
3
+
4
+ import {Table} from 'primeng/table';
5
+ import {LazyLoadEvent, SortMeta} from 'primeng/api';
6
+ import {FilterMetadata} from 'primeng/api/filtermetadata';
7
+ import {Observable, of, ReplaySubject, Subscription} from 'rxjs';
8
+ import {finalize, first, map} from 'rxjs/operators';
9
+ import {TranslateService} from '@ngx-translate/core';
10
+
11
+ import {MediusQueryParam, MediusQueryParamBuilder, MediusQueryResult} from '../../../api/models';
12
+ import {MediusRestUtil} from '../../../api/utils';
13
+ import {ColumnDescriptor, FilterDescriptor, TableDescriptor} from '../../../descriptors';
14
+ import {ITableDataProvider} from '../../../data-providers';
15
+ import {MngTableCellClickEvent, MngTableLoadEvent} from '../models';
16
+ import {MngTemplateDirective} from '../../../directives';
17
+ import {ToastUtil} from '../../../utils';
18
+ import {TableviewComponentService} from '../services';
19
+
20
+ import TypeEnum = FilterDescriptor.TypeEnum;
21
+ import PaginationModeEnum = TableDescriptor.PaginationModeEnum;
22
+
23
+ @Component({
24
+ selector: 'mng-table',
25
+ templateUrl: './table.component.html',
26
+ changeDetection: ChangeDetectionStrategy.OnPush
27
+ })
28
+ export class MngTableComponent<T, S> implements OnInit, AfterContentInit, OnDestroy {
29
+
30
+ public readonly filterDisplayRow: TableDescriptor.FilterDisplayEnum = TableDescriptor.FilterDisplayEnum.Row;
31
+ public readonly filterDisplayMenu: TableDescriptor.FilterDisplayEnum = TableDescriptor.FilterDisplayEnum.Menu;
32
+
33
+ // metadata input
34
+ @Input() public descriptor!: TableDescriptor<T>;
35
+
36
+ // data source inputs
37
+ @Input() public items?: Observable<Array<T>>|Array<T>;
38
+ @Input() public queryResult?: Observable<MediusQueryResult<T>>|MediusQueryResult<T>;
39
+ @Input() public loading?: Observable<boolean>|boolean;
40
+ @Input() public dataProvider?: ITableDataProvider<T, any>;
41
+ @Input() public useQueryParams = false;
42
+
43
+ // extra features input
44
+ @Input() public selectionEnabled: boolean = false;
45
+
46
+ // event outputs
47
+ @Output('onLoad') private loadEventEmitter = new EventEmitter<MngTableLoadEvent>();
48
+ @Output('onCellClick') private cellClickEventEmitter = new EventEmitter<MngTableCellClickEvent<T>>();
49
+ @Output('onSelectionChange') private selectionChangeEventEmitter = new EventEmitter<Array<T>>();
50
+
51
+ // content and view queries
52
+ @ContentChildren(MngTemplateDirective) templates!: QueryList<MngTemplateDirective>;
53
+ @ViewChild(Table) private primeTable!: Table;
54
+
55
+ // templates
56
+ public captionTemplate?: TemplateRef<any>;
57
+ public columnActionTemplate?: TemplateRef<any>;
58
+
59
+ // data provider and items
60
+ public useDataProvider: boolean = false;
61
+ public useQueryParamsInitialized: boolean = false;
62
+ public queryResult$?: Observable<MediusQueryResult<T>>;
63
+ public loading$?: Observable<boolean>;
64
+ public dataProviderInfiniteScrollItems: Array<T> = [];
65
+ private dataProviderService: any = null;
66
+ private dataProviderQueryResultSubject = new ReplaySubject<MediusQueryResult<T>>(1);
67
+ private dataProviderLoadingSubject = new ReplaySubject<boolean>(1);
68
+ private dataProviderLatestLazyLoadEvent?: LazyLoadEvent;
69
+ private dataProviderLatestLazyLoadEventVersion: number = 0;
70
+ private dataProviderLatestQueryParam?: MediusQueryParam;
71
+ private dataProviderLatestQueryParamVersion: number = 0;
72
+ private dataProviderSubscription?: Subscription;
73
+
74
+ // pagination, sort and filters
75
+ public readonly rowsPerPageOptions = [25, 50, 100];
76
+ public rows = this.rowsPerPageOptions[0];
77
+ public offset = 0;
78
+ public multiSortMeta: SortMeta[]|null = null;
79
+ public filterMetadata: { [s: string]: FilterMetadata | FilterMetadata[] } = {};
80
+ private isFilterChanged = false;
81
+ private isSortChanged = false;
82
+
83
+ // infinite scroll
84
+ public infiniteScroll = false;
85
+ public scrollHeight: 'flex'|null = null;
86
+ public rowHeight: number|null = null;
87
+
88
+ public selection: Array<T> = [];
89
+ private subscriptions: Subscription[] = [];
90
+ private filterDescriptors: Array<FilterDescriptor<any>> = [];
91
+
92
+ constructor(private injector: Injector,
93
+ private router: Router,
94
+ private activatedRoute: ActivatedRoute,
95
+ private translate: TranslateService,
96
+ @Optional() private tableviewService: TableviewComponentService<T, S>
97
+ ) { }
98
+
99
+ public ngOnInit() {
100
+
101
+ // @ts-ignore
102
+ this.filterDescriptors = this.descriptor.columns.filter(c => typeof c.filterDescriptor !== 'undefined').map(c => c.filterDescriptor);
103
+
104
+ if (this.descriptor.paginationMode === PaginationModeEnum.InfiniteScroll) {
105
+ this.infiniteScroll = true;
106
+ this.scrollHeight = 'flex';
107
+ this.rowHeight = this.descriptor.rowHeight;
108
+ this.useQueryParams = false;
109
+ }
110
+
111
+ // check if data provider is supplied, if is, use it primarily
112
+ if (this.dataProvider) {
113
+ // map subjects to observables and initiate data
114
+ this.useDataProvider = true;
115
+ this.queryResult$ = this.dataProviderQueryResultSubject.asObservable();
116
+ this.loading$ = this.dataProviderLoadingSubject.asObservable();
117
+ const emptyQueryResult = new MediusQueryResult<T>();
118
+ emptyQueryResult.pageData = [];
119
+ emptyQueryResult.allDataCount = 0;
120
+ this.dataProviderLoadingSubject.next(false);
121
+ this.dataProviderQueryResultSubject.next(emptyQueryResult)
122
+
123
+ // inject service
124
+ if (this.dataProvider.serviceType) {
125
+ this.dataProviderService = this.injector.get<any>(this.dataProvider.serviceType);
126
+ }
127
+ } else {
128
+ // if query result is provided, use it as secondary source or else try to use items
129
+ if (this.queryResult) {
130
+ this.queryResult$ = this.queryResult instanceof Observable ? this.queryResult : of(this.queryResult);
131
+ } else if (!this.queryResult && this.items) {
132
+ this.queryResult$ = (this.items instanceof Observable ? this.items : of(this.items)).pipe(
133
+ // distinctUntilChanged((v1, v2) => v1.length === v2.length &&
134
+ // v1.every((v1i, idx) => v1i[this.descriptor.dataKeyProperty] === v2[idx][this.descriptor.dataKeyProperty])),
135
+ map(items => {
136
+ const queryResult = new MediusQueryResult<T>();
137
+ queryResult.pageData = items;
138
+ queryResult.allDataCount = items.length;
139
+ return queryResult;
140
+ }));
141
+ }
142
+ if (typeof this.loading !== 'undefined') {
143
+ this.loading$ = this.loading instanceof Observable ? this.loading : of(this.loading);
144
+ }
145
+ }
146
+
147
+ if (this.useQueryParams) {
148
+ const subscription = this.activatedRoute.queryParams.subscribe(qp => {
149
+ this.loadTableFromRouteUpdate(qp);
150
+ });
151
+ this.subscriptions.push(subscription);
152
+ } else {
153
+ // initialize default sort if present
154
+ const defaultSort = this.getDefaultSortMeta();
155
+ if (defaultSort.length > 0) {
156
+ this.multiSortMeta = defaultSort;
157
+ }
158
+ }
159
+ }
160
+
161
+ public ngAfterContentInit() {
162
+ this.templates.forEach(template => {
163
+ switch(template.getType()) {
164
+ case 'caption':
165
+ this.captionTemplate = template.template;
166
+ break;
167
+ case 'columnAction':
168
+ this.columnActionTemplate = template.template;
169
+ break;
170
+ }
171
+ });
172
+ }
173
+
174
+ public ngOnDestroy() {
175
+ this.subscriptions.forEach(s => s.unsubscribe());
176
+ }
177
+
178
+ public reload(emitEvent: boolean = false, resetParams: boolean = false) {
179
+ this.loadTableWithDataProvider(resetParams
180
+ ? MediusQueryParamBuilder.create(this.rowsPerPageOptions[0], 0).build()
181
+ : (this.dataProviderLatestQueryParam ?? new MediusQueryParam()), emitEvent);
182
+ }
183
+
184
+ public onTableLazyLoad(event: LazyLoadEvent) {
185
+ this.dataProviderLatestLazyLoadEvent = event;
186
+ this.dataProviderLatestLazyLoadEventVersion++;
187
+
188
+ if (this.useQueryParams) {
189
+ if (!event.multiSortMeta || event.multiSortMeta.length === 0) {
190
+ // add default sort meta to event if not multisort meta is present
191
+ event.multiSortMeta = this.getDefaultSortMeta();
192
+ }
193
+ this.router.navigate([], {
194
+ relativeTo: this.activatedRoute,
195
+ replaceUrl: true,
196
+ queryParams: MediusRestUtil.fromPrimeLazyLoadEventToAngularQueryParams(event, this.rowsPerPageOptions[0])
197
+ });
198
+ } else {
199
+ const mediusQueryParams = event ? MediusRestUtil.fromPrimeLazyLoadEventToMediusQueryParams(event) : new MediusQueryParam();
200
+ this.loadTableWithDataProvider(mediusQueryParams);
201
+ }
202
+ }
203
+
204
+ public onTableSort(event: any) {
205
+ this.isSortChanged = true;
206
+ }
207
+
208
+ public onTableFilter(event: any) {
209
+ this.isFilterChanged = true;
210
+ }
211
+
212
+ public onCellClick(col: ColumnDescriptor<any, T>, item: T, idx: number) {
213
+ const mngEvent = new MngTableCellClickEvent<T>(col, item, idx);
214
+ this.cellClickEventEmitter.next(mngEvent);
215
+ }
216
+
217
+ public onSelectionChange(event: Array<T>) {
218
+ this.selectionChangeEventEmitter.emit(event);
219
+ }
220
+
221
+ private loadTableWithDataProvider(queryParam: MediusQueryParam|null = null, emitEvent: boolean = true) {
222
+ if (!this.useDataProvider) {
223
+ return;
224
+ }
225
+ if (this.dataProviderSubscription) {
226
+ this.dataProviderSubscription.unsubscribe();
227
+ }
228
+
229
+ this.dataProviderLoadingSubject.next(true);
230
+
231
+ if (!queryParam) {
232
+ queryParam = MediusQueryParamBuilder.create(this.rowsPerPageOptions[0]).build();
233
+ }
234
+ this.dataProviderLatestQueryParam = queryParam;
235
+ this.dataProviderLatestQueryParamVersion++;
236
+
237
+ this.dataProviderSubscription = this.dataProvider?.getAll(queryParam, this.dataProviderService)
238
+ .pipe(
239
+ first(),
240
+ finalize(() => this.dataProviderLoadingSubject.next(false))
241
+ )
242
+ .subscribe((res) => {
243
+ if (this.infiniteScroll) {
244
+ if (this.isFilterChanged || this.isSortChanged) {
245
+ this.dataProviderInfiniteScrollItems = [];
246
+ }
247
+ // @ts-ignore
248
+ this.dataProviderInfiniteScrollItems.splice(queryParam.itemsOffset ?? 0, queryParam.itemsPerPage ?? this.rows, ...res.pageData)
249
+ this.dataProviderInfiniteScrollItems = [...this.dataProviderInfiniteScrollItems];
250
+ } else {
251
+ this.dataProviderQueryResultSubject.next(res);
252
+ }
253
+ this.isFilterChanged = false;
254
+ this.isSortChanged = false;
255
+ }, err => {
256
+ ToastUtil.tableNotificationError(this.translate, this.descriptor, err, this.tableviewService);
257
+ const emptyQueryResult = new MediusQueryResult<T>();
258
+ emptyQueryResult.pageData = [];
259
+ emptyQueryResult.allDataCount = 0;
260
+ this.dataProviderQueryResultSubject.next(emptyQueryResult);
261
+ });
262
+
263
+ if (emitEvent) {
264
+ const mngEvent = new MngTableLoadEvent();
265
+ mngEvent.originalEvent = this.dataProviderLatestLazyLoadEvent ?? undefined;
266
+ mngEvent.queryParam = queryParam;
267
+ this.loadEventEmitter.next(mngEvent);
268
+ }
269
+ }
270
+
271
+ private loadTableFromRouteUpdate(params: Params) {
272
+ const mediusQueryParam = MediusRestUtil.fromAngularQueryParamsToMediusQueryParams(params, this.filterDescriptors, this.rowsPerPageOptions[0]);
273
+ if (this.dataProviderLatestLazyLoadEventVersion < this.dataProviderLatestQueryParamVersion + 1) {
274
+ // update only if new version from query params will be higher
275
+ this.updatePrimeSortAndFilter(mediusQueryParam);
276
+ }
277
+ this.useQueryParamsInitialized = true;
278
+ this.loadTableWithDataProvider(mediusQueryParam);
279
+ }
280
+
281
+ private updatePrimeSortAndFilter(mediusQueryParam: MediusQueryParam) {
282
+ const primeSortMeta: SortMeta[] = [];
283
+ const primeFilterMeta: { [s: string]: FilterMetadata | FilterMetadata[] } = {};
284
+
285
+ this.filterDescriptors.forEach(f => {
286
+ // @ts-ignore
287
+ primeFilterMeta[f.property] = {
288
+ value: null,
289
+ matchMode: f.filterType === TypeEnum.String ? 'contains' : 'equals'
290
+ };
291
+ });
292
+
293
+ mediusQueryParam?.sortProperty?.forEach((s, idx) => {
294
+ primeSortMeta.push({
295
+ field: s,
296
+ order: (mediusQueryParam?.sortAsc?.[idx] ?? true) ? 1 : -1
297
+ });
298
+ });
299
+
300
+ mediusQueryParam?.filterParams?.forEach((f, idx) => {
301
+ const descriptor = this.filterDescriptors.find(fd => fd.filterProperty === f.property || fd.property === f.property);
302
+ const operator = MediusRestUtil.matchModeMapping.find(mapping => mapping[2] === f.filterMatchType);
303
+ if (descriptor && operator) {
304
+ primeFilterMeta[descriptor.property] = {
305
+ value: f.filterValue,
306
+ matchMode: operator[0]
307
+ };
308
+ }
309
+ });
310
+
311
+ this.multiSortMeta = primeSortMeta;
312
+ this.filterMetadata = primeFilterMeta;
313
+ this.rows = mediusQueryParam?.itemsPerPage ?? this.rowsPerPageOptions[0];
314
+ this.offset = mediusQueryParam?.itemsOffset ?? 0;
315
+ }
316
+
317
+ private getDefaultSortMeta(): SortMeta[] {
318
+ if (this.descriptor.hasDefaultSort) {
319
+ return this.descriptor.defaultSortProperty.map((p, idx) => <SortMeta>{
320
+ field: p,
321
+ order: this.descriptor.defaultSortAsc[idx] ? 1 : -1
322
+ });
323
+ } else {
324
+ return [];
325
+ }
326
+ }
327
+ }
@@ -0,0 +1,37 @@
1
+ <div class="mng-tableview">
2
+ <p-toast></p-toast>
3
+
4
+ <div class="card">
5
+ <p-toolbar styleClass="mb-4" *ngIf="toolbarLeftActions.length > 0 || toolbarRightActions.length > 0">
6
+ <ng-template pTemplate="left">
7
+ <mng-action *ngFor="let action of toolbarLeftActions"
8
+ [action]="action">
9
+ </mng-action>
10
+ </ng-template>
11
+
12
+ <ng-template pTemplate="right">
13
+ <mng-action *ngFor="let action of toolbarRightActions"
14
+ [action]="action">
15
+ </mng-action>
16
+ </ng-template>
17
+ </p-toolbar>
18
+
19
+ <mng-table [descriptor]="descriptor.table"
20
+ [dataProvider]="dataProvider"
21
+ [useQueryParams]="true"
22
+ (onCellClick)="onTableCellClick($event)">
23
+ <ng-template mngTemplate="caption">
24
+ <div class="flex flex-column md:flex-row md:justify-content-between table-header">
25
+ <h5 class="p-m-0">{{ descriptor.tableTitle | translate }}</h5>
26
+ </div>
27
+ </ng-template>
28
+ <ng-template mngTemplate="columnAction" let-item="rowItem">
29
+ <mng-action *ngFor="let action of rowInlineActions"
30
+ [action]="action" [item]="item" [itemId]="descriptor.model.idPropertyName ? item[descriptor.model.idPropertyName] : null">
31
+ </mng-action>
32
+ </ng-template>
33
+ </mng-table>
34
+ </div>
35
+
36
+ <router-outlet></router-outlet>
37
+ </div>
@@ -0,0 +1,78 @@
1
+ import {Component, Input, OnInit, ViewChild} from '@angular/core';
2
+ import {ActivatedRoute} from '@angular/router';
3
+
4
+ import {TranslateService} from '@ngx-translate/core';
5
+ import {ConfirmationService, MessageService} from 'primeng/api';
6
+ import {DialogService} from 'primeng/dynamicdialog';
7
+
8
+ import {MngActionService} from '../../services';
9
+ import {TableviewDescriptor, ActionDescriptor, ActionPositionEnum} from '../../descriptors';
10
+ import {ITableviewDataProvider} from '../../data-providers';
11
+ import {MngTableCellClickEvent} from './models';
12
+ import {TableviewComponentService} from './services';
13
+ import {MngTableComponent} from './table/table.component';
14
+
15
+ @Component({
16
+ selector: 'mng-tableview',
17
+ templateUrl: './tableview.component.html',
18
+ providers: [MessageService, ConfirmationService, TableviewComponentService]
19
+ })
20
+ export class MngTableviewComponent<T, S> implements OnInit {
21
+
22
+ @Input() descriptor!: TableviewDescriptor<T>;
23
+ @Input() dataProvider?: ITableviewDataProvider<T, S>;
24
+ @Input() actions: Array<ActionDescriptor<T>> = [];
25
+
26
+ @ViewChild(MngTableComponent) tableComponent: MngTableComponent<T, S>|null = null;
27
+
28
+ public rowClickActions: ActionDescriptor<T>[] = [];
29
+ public rowInlineActions: ActionDescriptor<T>[] = [];
30
+ public toolbarLeftActions: ActionDescriptor<T>[] = [];
31
+ public toolbarRightActions: ActionDescriptor<T>[] = [];
32
+
33
+ constructor(
34
+ private route: ActivatedRoute,
35
+ private messageService: MessageService,
36
+ private translateService: TranslateService,
37
+ private dialogService: DialogService,
38
+ private confirmationService: ConfirmationService,
39
+ private actionService: MngActionService,
40
+ private tableviewService: TableviewComponentService<T, S>
41
+ ) {
42
+ }
43
+
44
+ ngOnInit() {
45
+
46
+ this.tableviewService.actions = this.actions;
47
+ this.tableviewService.dataProvider = this.dataProvider;
48
+ this.tableviewService.messageService = this.messageService;
49
+ for (const action of this.actions) {
50
+ switch (action.position) {
51
+ case ActionPositionEnum.RowClick:
52
+ this.rowClickActions.push(action);
53
+ break;
54
+ case ActionPositionEnum.RowInline:
55
+ this.rowInlineActions.push(action);
56
+ break;
57
+ case ActionPositionEnum.ToolbarLeft:
58
+ this.toolbarLeftActions.push(action);
59
+ break;
60
+ case ActionPositionEnum.ToolbarRight:
61
+ this.toolbarRightActions.push(action);
62
+ break;
63
+ }
64
+ }
65
+ }
66
+
67
+ public reloadTable() {
68
+ this.tableComponent?.reload();
69
+ }
70
+
71
+ public onTableCellClick(event: MngTableCellClickEvent<T>) {
72
+ if (this.rowClickActions.length) {
73
+ for (const action of this.rowClickActions) {
74
+ this.actionService.triggerRowClickAction(action, event, this.route);
75
+ }
76
+ }
77
+ }
78
+ }