@mediusinc/mng-commons 0.0.1-rc.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (187) hide show
  1. package/README.md +19 -0
  2. package/esm2020/lib/api/models/builders/query-param.builder.mjs +49 -0
  3. package/esm2020/lib/api/models/filter-match-type.model.mjs +24 -0
  4. package/esm2020/lib/api/models/filter-param.model.mjs +46 -0
  5. package/esm2020/lib/api/models/index.mjs +9 -0
  6. package/esm2020/lib/api/models/mappers.mjs +17 -0
  7. package/esm2020/lib/api/models/query-mode.model.mjs +19 -0
  8. package/esm2020/lib/api/models/query-param.model.mjs +69 -0
  9. package/esm2020/lib/api/models/query-result.model.mjs +45 -0
  10. package/esm2020/lib/api/models/serialization.model.mjs +2 -0
  11. package/esm2020/lib/api/services/abstract-crud-api.service.mjs +72 -0
  12. package/esm2020/lib/api/services/index.mjs +2 -0
  13. package/esm2020/lib/api/utils/index.mjs +3 -0
  14. package/esm2020/lib/api/utils/medius-rest.util.mjs +70 -0
  15. package/esm2020/lib/api/utils/object-serializer.util.mjs +226 -0
  16. package/esm2020/lib/components/action/action.component.mjs +63 -0
  17. package/esm2020/lib/components/action/dialog/action-dialog.component.mjs +148 -0
  18. package/esm2020/lib/components/action/index.mjs +4 -0
  19. package/esm2020/lib/components/action/route/action-route.component.mjs +144 -0
  20. package/esm2020/lib/components/form/editor/form-editor.component.mjs +140 -0
  21. package/esm2020/lib/components/form/formly/fields/formly-field-autocomplete/formly-field-autocomplete.component.mjs +58 -0
  22. package/esm2020/lib/components/form/formly/fields/formly-field-dropdown/formly-field-dropdown.component.mjs +51 -0
  23. package/esm2020/lib/components/form/formly/fields/formly-field-fieldset/formly-field-fieldset.component.mjs +16 -0
  24. package/esm2020/lib/components/form/formly/fields/formly-field-input/formly-field-input.component.mjs +26 -0
  25. package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +94 -0
  26. package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +124 -0
  27. package/esm2020/lib/components/form/formly/fields/formly-field-tabs/formly-field-tabs.component.mjs +17 -0
  28. package/esm2020/lib/components/form/formly/fields/index.mjs +8 -0
  29. package/esm2020/lib/components/form/formly/wrappers/formly-field-wrapper/formly-field-wrapper.component.mjs +17 -0
  30. package/esm2020/lib/components/form/formly/wrappers/formly-table-wrapper/formly-table-wrapper.component.mjs +16 -0
  31. package/esm2020/lib/components/form/formly/wrappers/index.mjs +3 -0
  32. package/esm2020/lib/components/form/index.mjs +2 -0
  33. package/esm2020/lib/components/layout/app.breadcrumb.component.mjs +27 -0
  34. package/esm2020/lib/components/layout/app.footer.component.mjs +35 -0
  35. package/esm2020/lib/components/layout/app.main.component.mjs +25 -0
  36. package/esm2020/lib/components/layout/app.main.component.service.mjs +133 -0
  37. package/esm2020/lib/components/layout/app.menu.component.mjs +38 -0
  38. package/esm2020/lib/components/layout/app.menuitem.component.mjs +243 -0
  39. package/esm2020/lib/components/layout/app.topbar.component.mjs +135 -0
  40. package/esm2020/lib/components/layout/index.mjs +7 -0
  41. package/esm2020/lib/components/tableview/index.mjs +4 -0
  42. package/esm2020/lib/components/tableview/route/tableview-route.abstract.component.mjs +31 -0
  43. package/esm2020/lib/components/tableview/table/table.component.mjs +173 -0
  44. package/esm2020/lib/components/tableview/tableview.component.mjs +82 -0
  45. package/esm2020/lib/components/tableview/tableview.component.service.mjs +18 -0
  46. package/esm2020/lib/config/formly.config.mjs +165 -0
  47. package/esm2020/lib/config/index.mjs +2 -0
  48. package/esm2020/lib/directives/index.mjs +2 -0
  49. package/esm2020/lib/directives/template.directive.mjs +25 -0
  50. package/esm2020/lib/mng-commons.module.mjs +338 -0
  51. package/esm2020/lib/models/action/action.model.mjs +58 -0
  52. package/esm2020/lib/models/action/index.mjs +2 -0
  53. package/esm2020/lib/models/config/index.mjs +2 -0
  54. package/esm2020/lib/models/config/mng-config.model.mjs +3 -0
  55. package/esm2020/lib/models/descriptors/action-descriptor.model.mjs +283 -0
  56. package/esm2020/lib/models/descriptors/editor-descriptor.model.mjs +647 -0
  57. package/esm2020/lib/models/descriptors/index.mjs +6 -0
  58. package/esm2020/lib/models/descriptors/model-descriptor.model.mjs +34 -0
  59. package/esm2020/lib/models/descriptors/table-descriptor.model.mjs +123 -0
  60. package/esm2020/lib/models/descriptors/tableview-descriptor.model.mjs +124 -0
  61. package/esm2020/lib/models/events/editor-event.model.mjs +14 -0
  62. package/esm2020/lib/models/events/index.mjs +3 -0
  63. package/esm2020/lib/models/events/table-event.model.mjs +16 -0
  64. package/esm2020/lib/models/interfaces/confirmation-service.model.mjs +2 -0
  65. package/esm2020/lib/models/interfaces/index.mjs +2 -0
  66. package/esm2020/lib/models/providers/data-provider.model.mjs +86 -0
  67. package/esm2020/lib/models/providers/index.mjs +2 -0
  68. package/esm2020/lib/models/types/index.mjs +3 -0
  69. package/esm2020/lib/models/types/type.decorator.mjs +8 -0
  70. package/esm2020/lib/models/types/type.model.mjs +2 -0
  71. package/esm2020/lib/models/validators/field.validator.mjs +21 -0
  72. package/esm2020/lib/models/validators/index.mjs +2 -0
  73. package/esm2020/lib/pipes/index.mjs +2 -0
  74. package/esm2020/lib/pipes/property-path.pipe.mjs +36 -0
  75. package/esm2020/lib/services/action.service.mjs +239 -0
  76. package/esm2020/lib/services/breadcrumb.service.mjs +21 -0
  77. package/esm2020/lib/services/configuration.service.mjs +77 -0
  78. package/esm2020/lib/services/index.mjs +7 -0
  79. package/esm2020/lib/services/menu.service.mjs +26 -0
  80. package/esm2020/lib/services/navigation.service.mjs +49 -0
  81. package/esm2020/lib/services/providers/config-service.provider.mjs +12 -0
  82. package/esm2020/lib/services/providers/formly-config.provider.mjs +31 -0
  83. package/esm2020/lib/services/providers/index.mjs +3 -0
  84. package/esm2020/lib/services/settings.service.mjs +40 -0
  85. package/esm2020/lib/utils/editor-formly.util.mjs +165 -0
  86. package/esm2020/lib/utils/i18n.util.mjs +75 -0
  87. package/esm2020/lib/utils/index.mjs +5 -0
  88. package/esm2020/lib/utils/model.util.mjs +38 -0
  89. package/esm2020/lib/utils/type.util.mjs +43 -0
  90. package/esm2020/mediusinc-mng-commons.mjs +5 -0
  91. package/esm2020/public-api.mjs +33 -0
  92. package/fesm2015/mediusinc-mng-commons.mjs +5056 -0
  93. package/fesm2015/mediusinc-mng-commons.mjs.map +1 -0
  94. package/fesm2020/mediusinc-mng-commons.mjs +5012 -0
  95. package/fesm2020/mediusinc-mng-commons.mjs.map +1 -0
  96. package/lib/api/models/builders/query-param.builder.d.ts +11 -0
  97. package/lib/api/models/filter-match-type.model.d.ts +21 -0
  98. package/lib/api/models/filter-param.model.d.ts +23 -0
  99. package/lib/api/models/index.d.ts +8 -0
  100. package/lib/api/models/mappers.d.ts +6 -0
  101. package/lib/api/models/query-mode.model.d.ts +16 -0
  102. package/lib/api/models/query-param.model.d.ts +31 -0
  103. package/lib/api/models/query-result.model.d.ts +36 -0
  104. package/lib/api/models/serialization.model.d.ts +8 -0
  105. package/lib/api/services/abstract-crud-api.service.d.ts +23 -0
  106. package/lib/api/services/index.d.ts +1 -0
  107. package/lib/api/utils/index.d.ts +2 -0
  108. package/lib/api/utils/medius-rest.util.d.ts +6 -0
  109. package/lib/api/utils/object-serializer.util.d.ts +30 -0
  110. package/lib/components/action/action.component.d.ts +36 -0
  111. package/lib/components/action/dialog/action-dialog.component.d.ts +48 -0
  112. package/lib/components/action/index.d.ts +3 -0
  113. package/lib/components/action/route/action-route.component.d.ts +32 -0
  114. package/lib/components/form/editor/form-editor.component.d.ts +37 -0
  115. package/lib/components/form/formly/fields/formly-field-autocomplete/formly-field-autocomplete.component.d.ts +21 -0
  116. package/lib/components/form/formly/fields/formly-field-dropdown/formly-field-dropdown.component.d.ts +19 -0
  117. package/lib/components/form/formly/fields/formly-field-fieldset/formly-field-fieldset.component.d.ts +6 -0
  118. package/lib/components/form/formly/fields/formly-field-input/formly-field-input.component.d.ts +12 -0
  119. package/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.d.ts +17 -0
  120. package/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.d.ts +36 -0
  121. package/lib/components/form/formly/fields/formly-field-tabs/formly-field-tabs.component.d.ts +6 -0
  122. package/lib/components/form/formly/fields/index.d.ts +7 -0
  123. package/lib/components/form/formly/wrappers/formly-field-wrapper/formly-field-wrapper.component.d.ts +8 -0
  124. package/lib/components/form/formly/wrappers/formly-table-wrapper/formly-table-wrapper.component.d.ts +8 -0
  125. package/lib/components/form/formly/wrappers/index.d.ts +2 -0
  126. package/lib/components/form/index.d.ts +1 -0
  127. package/lib/components/layout/app.breadcrumb.component.d.ts +16 -0
  128. package/lib/components/layout/app.footer.component.d.ts +8 -0
  129. package/lib/components/layout/app.main.component.d.ts +12 -0
  130. package/lib/components/layout/app.main.component.service.d.ts +40 -0
  131. package/lib/components/layout/app.menu.component.d.ts +14 -0
  132. package/lib/components/layout/app.menuitem.component.d.ts +31 -0
  133. package/lib/components/layout/app.topbar.component.d.ts +16 -0
  134. package/lib/components/layout/index.d.ts +6 -0
  135. package/lib/components/tableview/index.d.ts +3 -0
  136. package/lib/components/tableview/route/tableview-route.abstract.component.d.ts +15 -0
  137. package/lib/components/tableview/table/table.component.d.ts +47 -0
  138. package/lib/components/tableview/tableview.component.d.ts +36 -0
  139. package/lib/components/tableview/tableview.component.service.d.ts +11 -0
  140. package/lib/config/formly.config.d.ts +8 -0
  141. package/lib/config/index.d.ts +1 -0
  142. package/lib/directives/index.d.ts +1 -0
  143. package/lib/directives/template.directive.d.ts +11 -0
  144. package/lib/mng-commons.module.d.ts +74 -0
  145. package/lib/models/action/action.model.d.ts +53 -0
  146. package/lib/models/action/index.d.ts +1 -0
  147. package/lib/models/config/index.d.ts +1 -0
  148. package/lib/models/config/mng-config.model.d.ts +19 -0
  149. package/lib/models/descriptors/action-descriptor.model.d.ts +124 -0
  150. package/lib/models/descriptors/editor-descriptor.model.d.ts +248 -0
  151. package/lib/models/descriptors/index.d.ts +5 -0
  152. package/lib/models/descriptors/model-descriptor.model.d.ts +15 -0
  153. package/lib/models/descriptors/table-descriptor.model.d.ts +45 -0
  154. package/lib/models/descriptors/tableview-descriptor.model.d.ts +38 -0
  155. package/lib/models/events/editor-event.model.d.ts +11 -0
  156. package/lib/models/events/index.d.ts +2 -0
  157. package/lib/models/events/table-event.model.d.ts +17 -0
  158. package/lib/models/interfaces/confirmation-service.model.d.ts +6 -0
  159. package/lib/models/interfaces/index.d.ts +1 -0
  160. package/lib/models/providers/data-provider.model.d.ts +62 -0
  161. package/lib/models/providers/index.d.ts +1 -0
  162. package/lib/models/types/index.d.ts +2 -0
  163. package/lib/models/types/type.decorator.d.ts +2 -0
  164. package/lib/models/types/type.model.d.ts +10 -0
  165. package/lib/models/validators/field.validator.d.ts +18 -0
  166. package/lib/models/validators/index.d.ts +1 -0
  167. package/lib/pipes/index.d.ts +1 -0
  168. package/lib/pipes/property-path.pipe.d.ts +7 -0
  169. package/lib/services/action.service.d.ts +92 -0
  170. package/lib/services/breadcrumb.service.d.ts +9 -0
  171. package/lib/services/configuration.service.d.ts +35 -0
  172. package/lib/services/index.d.ts +6 -0
  173. package/lib/services/menu.service.d.ts +11 -0
  174. package/lib/services/navigation.service.d.ts +14 -0
  175. package/lib/services/providers/config-service.provider.d.ts +5 -0
  176. package/lib/services/providers/formly-config.provider.d.ts +4 -0
  177. package/lib/services/providers/index.d.ts +2 -0
  178. package/lib/services/settings.service.d.ts +18 -0
  179. package/lib/utils/editor-formly.util.d.ts +9 -0
  180. package/lib/utils/i18n.util.d.ts +14 -0
  181. package/lib/utils/index.d.ts +4 -0
  182. package/lib/utils/model.util.d.ts +5 -0
  183. package/lib/utils/type.util.d.ts +15 -0
  184. package/mediusinc-mng-commons-0.0.1-rc.2.tgz +0 -0
  185. package/mediusinc-mng-commons.d.ts +5 -0
  186. package/package.json +38 -0
  187. package/public-api.d.ts +22 -0
@@ -0,0 +1,135 @@
1
+ import { Component } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "../../services/settings.service";
4
+ import * as i2 from "@ngx-translate/core";
5
+ import * as i3 from "./app.main.component.service";
6
+ import * as i4 from "./app.breadcrumb.component";
7
+ import * as i5 from "./app.menu.component";
8
+ import * as i6 from "primeng/dropdown";
9
+ import * as i7 from "@angular/common";
10
+ export class AppTopbarComponent {
11
+ constructor(appSettings, translateService, appMainService
12
+ // private userService: UserApiService TODO
13
+ ) {
14
+ this.appSettings = appSettings;
15
+ this.translateService = translateService;
16
+ this.appMainService = appMainService;
17
+ this.languages = translateService.getLangs();
18
+ }
19
+ switchLanguage(language) {
20
+ this.translateService.use(language);
21
+ }
22
+ ngOnInit() {
23
+ // this.userService.getCurrentUser().subscribe(obj => this.user = obj);
24
+ }
25
+ }
26
+ AppTopbarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AppTopbarComponent, deps: [{ token: i1.AppSettingsService }, { token: i2.TranslateService }, { token: i3.AppMainComponentService }], target: i0.ɵɵFactoryTarget.Component });
27
+ AppTopbarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: AppTopbarComponent, selector: "app-topbar", ngImport: i0, template: `
28
+ <div class="layout-topbar">
29
+ <div class="layout-topbar-left">
30
+ <a href="#" class="topbar-menu-button" (click)="appMainService.onMenuButtonClick($event)" *ngIf="appSettings.isOverlay() || appMainService.isMobile()">
31
+ <i class="pi pi-bars"></i>
32
+ </a>
33
+
34
+ <app-breadcrumb></app-breadcrumb>
35
+ </div>
36
+
37
+ <app-menu></app-menu>
38
+
39
+ <div class="layout-topbar-right">
40
+ <ul class="layout-topbar-right-items">
41
+ <li #profile class="profile-item" [ngClass]="{'active-topmenuitem':appMainService.activeTopbarItem === profile}">
42
+ <!-- {{user?.name}} TODO -->
43
+ <a href="#" (click)="appMainService.onTopbarItemClick($event,profile)">
44
+ <i class="pi pi-fw pi-user"></i>
45
+ </a>
46
+
47
+ <ul class="fadeInDown">
48
+ <li role="menuitem">
49
+ <a href="#" (click)="appMainService.onTopbarSubItemClick($event)">
50
+ <i class="pi pi-fw pi-user"></i>
51
+ <span>{{ 'topbar.profile' | translate }}</span>
52
+ </a>
53
+ </li>
54
+ <li role="menuitem">
55
+ <a href="#" (click)="appMainService.onTopbarSubItemClick($event)">
56
+ <i class="pi pi-fw pi-globe"></i>
57
+ <p-dropdown [options]=languages (onChange)="switchLanguage($event.value)"></p-dropdown>
58
+ </a>
59
+ </li>
60
+ <li role="menuitem">
61
+ <a href="#" (click)="appMainService.onTopbarSubItemClick($event)">
62
+ <i class="pi pi-fw pi-cog"></i>
63
+ <span>{{ 'topbar.settings' | translate }}</span>
64
+ </a>
65
+ </li>
66
+ <li role="menuitem">
67
+ <a href="#" (click)="appMainService.onTopbarSubItemClick($event)">
68
+ <i class="pi pi-fw pi-sign-out"></i>
69
+ <span>{{ 'topbar.logout' | translate }}</span>
70
+ </a>
71
+ </li>
72
+ </ul>
73
+ </li>
74
+ </ul>
75
+ </div>
76
+ </div>
77
+ `, isInline: true, components: [{ type: i4.AppBreadcrumbComponent, selector: "app-breadcrumb" }, { type: i5.AppMenuComponent, selector: "app-menu" }, { type: i6.Dropdown, selector: "p-dropdown", inputs: ["scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "selectId", "dataKey", "filterBy", "autofocus", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "virtualScroll", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "ariaFilterLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "disabled", "options", "filterValue"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "translate": i2.TranslatePipe } });
78
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AppTopbarComponent, decorators: [{
79
+ type: Component,
80
+ args: [{
81
+ selector: 'app-topbar',
82
+ template: `
83
+ <div class="layout-topbar">
84
+ <div class="layout-topbar-left">
85
+ <a href="#" class="topbar-menu-button" (click)="appMainService.onMenuButtonClick($event)" *ngIf="appSettings.isOverlay() || appMainService.isMobile()">
86
+ <i class="pi pi-bars"></i>
87
+ </a>
88
+
89
+ <app-breadcrumb></app-breadcrumb>
90
+ </div>
91
+
92
+ <app-menu></app-menu>
93
+
94
+ <div class="layout-topbar-right">
95
+ <ul class="layout-topbar-right-items">
96
+ <li #profile class="profile-item" [ngClass]="{'active-topmenuitem':appMainService.activeTopbarItem === profile}">
97
+ <!-- {{user?.name}} TODO -->
98
+ <a href="#" (click)="appMainService.onTopbarItemClick($event,profile)">
99
+ <i class="pi pi-fw pi-user"></i>
100
+ </a>
101
+
102
+ <ul class="fadeInDown">
103
+ <li role="menuitem">
104
+ <a href="#" (click)="appMainService.onTopbarSubItemClick($event)">
105
+ <i class="pi pi-fw pi-user"></i>
106
+ <span>{{ 'topbar.profile' | translate }}</span>
107
+ </a>
108
+ </li>
109
+ <li role="menuitem">
110
+ <a href="#" (click)="appMainService.onTopbarSubItemClick($event)">
111
+ <i class="pi pi-fw pi-globe"></i>
112
+ <p-dropdown [options]=languages (onChange)="switchLanguage($event.value)"></p-dropdown>
113
+ </a>
114
+ </li>
115
+ <li role="menuitem">
116
+ <a href="#" (click)="appMainService.onTopbarSubItemClick($event)">
117
+ <i class="pi pi-fw pi-cog"></i>
118
+ <span>{{ 'topbar.settings' | translate }}</span>
119
+ </a>
120
+ </li>
121
+ <li role="menuitem">
122
+ <a href="#" (click)="appMainService.onTopbarSubItemClick($event)">
123
+ <i class="pi pi-fw pi-sign-out"></i>
124
+ <span>{{ 'topbar.logout' | translate }}</span>
125
+ </a>
126
+ </li>
127
+ </ul>
128
+ </li>
129
+ </ul>
130
+ </div>
131
+ </div>
132
+ `
133
+ }]
134
+ }], ctorParameters: function () { return [{ type: i1.AppSettingsService }, { type: i2.TranslateService }, { type: i3.AppMainComponentService }]; } });
135
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLnRvcGJhci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tbmctY29tbW9ucy9zcmMvbGliL2NvbXBvbmVudHMvbGF5b3V0L2FwcC50b3BiYXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQVMsTUFBTSxlQUFlLENBQUM7Ozs7Ozs7OztBQTREaEQsTUFBTSxPQUFPLGtCQUFrQjtJQUszQixZQUFtQixXQUErQixFQUMvQixnQkFBa0MsRUFDbEMsY0FBdUM7SUFDOUMsMkNBQTJDOztRQUhwQyxnQkFBVyxHQUFYLFdBQVcsQ0FBb0I7UUFDL0IscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtRQUNsQyxtQkFBYyxHQUFkLGNBQWMsQ0FBeUI7UUFHdEQsSUFBSSxDQUFDLFNBQVMsR0FBRyxnQkFBZ0IsQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUNqRCxDQUFDO0lBRUQsY0FBYyxDQUFDLFFBQWdCO1FBQzNCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVELFFBQVE7UUFDSix1RUFBdUU7SUFDM0UsQ0FBQzs7K0dBbkJRLGtCQUFrQjttR0FBbEIsa0JBQWtCLGtEQXBEakI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0tBa0RUOzJGQUVRLGtCQUFrQjtrQkF0RDlCLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLFlBQVk7b0JBQ3RCLFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7S0FrRFQ7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgT25Jbml0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHtUcmFuc2xhdGVTZXJ2aWNlfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7QXBwU2V0dGluZ3NTZXJ2aWNlfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9zZXR0aW5ncy5zZXJ2aWNlJztcbmltcG9ydCB7QXBwTWFpbkNvbXBvbmVudFNlcnZpY2V9IGZyb20gJy4vYXBwLm1haW4uY29tcG9uZW50LnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2FwcC10b3BiYXInLFxuICAgIHRlbXBsYXRlOiBgXG4gICAgICAgIDxkaXYgY2xhc3M9XCJsYXlvdXQtdG9wYmFyXCI+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwibGF5b3V0LXRvcGJhci1sZWZ0XCI+XG4gICAgICAgICAgICAgICAgPGEgaHJlZj1cIiNcIiBjbGFzcz1cInRvcGJhci1tZW51LWJ1dHRvblwiIChjbGljayk9XCJhcHBNYWluU2VydmljZS5vbk1lbnVCdXR0b25DbGljaygkZXZlbnQpXCIgKm5nSWY9XCJhcHBTZXR0aW5ncy5pc092ZXJsYXkoKSB8fCBhcHBNYWluU2VydmljZS5pc01vYmlsZSgpXCI+XG4gICAgICAgICAgICAgICAgICAgIDxpIGNsYXNzPVwicGkgcGktYmFyc1wiPjwvaT5cbiAgICAgICAgICAgICAgICA8L2E+XG5cbiAgICAgICAgICAgICAgICA8YXBwLWJyZWFkY3J1bWI+PC9hcHAtYnJlYWRjcnVtYj5cbiAgICAgICAgICAgIDwvZGl2PlxuXG4gICAgICAgICAgICA8YXBwLW1lbnU+PC9hcHAtbWVudT5cblxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImxheW91dC10b3BiYXItcmlnaHRcIj5cbiAgICAgICAgICAgICAgICA8dWwgY2xhc3M9XCJsYXlvdXQtdG9wYmFyLXJpZ2h0LWl0ZW1zXCI+XG4gICAgICAgICAgICAgICAgICAgIDxsaSAjcHJvZmlsZSBjbGFzcz1cInByb2ZpbGUtaXRlbVwiIFtuZ0NsYXNzXT1cInsnYWN0aXZlLXRvcG1lbnVpdGVtJzphcHBNYWluU2VydmljZS5hY3RpdmVUb3BiYXJJdGVtID09PSBwcm9maWxlfVwiPlxuPCEtLSAgICAgICAgICAgICAgICAgICAgICAgIHt7dXNlcj8ubmFtZX19IFRPRE8gLS0+XG4gICAgICAgICAgICAgICAgICAgICAgICA8YSBocmVmPVwiI1wiIChjbGljayk9XCJhcHBNYWluU2VydmljZS5vblRvcGJhckl0ZW1DbGljaygkZXZlbnQscHJvZmlsZSlcIj5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8aSBjbGFzcz1cInBpIHBpLWZ3IHBpLXVzZXJcIj48L2k+XG4gICAgICAgICAgICAgICAgICAgICAgICA8L2E+XG5cbiAgICAgICAgICAgICAgICAgICAgICAgIDx1bCBjbGFzcz1cImZhZGVJbkRvd25cIj5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8bGkgcm9sZT1cIm1lbnVpdGVtXCI+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxhIGhyZWY9XCIjXCIgKGNsaWNrKT1cImFwcE1haW5TZXJ2aWNlLm9uVG9wYmFyU3ViSXRlbUNsaWNrKCRldmVudClcIj5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxpIGNsYXNzPVwicGkgcGktZncgcGktdXNlclwiPjwvaT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxzcGFuPnt7ICd0b3BiYXIucHJvZmlsZScgfCB0cmFuc2xhdGUgfX08L3NwYW4+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvYT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8L2xpPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxsaSByb2xlPVwibWVudWl0ZW1cIj5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPGEgaHJlZj1cIiNcIiAoY2xpY2spPVwiYXBwTWFpblNlcnZpY2Uub25Ub3BiYXJTdWJJdGVtQ2xpY2soJGV2ZW50KVwiPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPGkgY2xhc3M9XCJwaSBwaS1mdyBwaS1nbG9iZVwiPjwvaT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxwLWRyb3Bkb3duIFtvcHRpb25zXT1sYW5ndWFnZXMgKG9uQ2hhbmdlKT1cInN3aXRjaExhbmd1YWdlKCRldmVudC52YWx1ZSlcIj48L3AtZHJvcGRvd24+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvYT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8L2xpPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxsaSByb2xlPVwibWVudWl0ZW1cIj5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPGEgaHJlZj1cIiNcIiAoY2xpY2spPVwiYXBwTWFpblNlcnZpY2Uub25Ub3BiYXJTdWJJdGVtQ2xpY2soJGV2ZW50KVwiPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPGkgY2xhc3M9XCJwaSBwaS1mdyBwaS1jb2dcIj48L2k+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8c3Bhbj57eyAndG9wYmFyLnNldHRpbmdzJyB8IHRyYW5zbGF0ZSB9fTwvc3Bhbj5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPC9hPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvbGk+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPGxpIHJvbGU9XCJtZW51aXRlbVwiPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8YSBocmVmPVwiI1wiIChjbGljayk9XCJhcHBNYWluU2VydmljZS5vblRvcGJhclN1Ykl0ZW1DbGljaygkZXZlbnQpXCI+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8aSBjbGFzcz1cInBpIHBpLWZ3IHBpLXNpZ24tb3V0XCI+PC9pPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPHNwYW4+e3sgJ3RvcGJhci5sb2dvdXQnIHwgdHJhbnNsYXRlIH19PC9zcGFuPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8L2E+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPC9saT5cbiAgICAgICAgICAgICAgICAgICAgICAgIDwvdWw+XG4gICAgICAgICAgICAgICAgICAgIDwvbGk+XG4gICAgICAgICAgICAgICAgPC91bD5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L2Rpdj5cbiAgICBgXG59KVxuZXhwb3J0IGNsYXNzIEFwcFRvcGJhckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgICAvLyBwdWJsaWMgdXNlcjogVXNlckR0bzsgVE9ET1xuICAgIHB1YmxpYyBsYW5ndWFnZXM6IEFycmF5PHN0cmluZz47XG5cbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgYXBwU2V0dGluZ3M6IEFwcFNldHRpbmdzU2VydmljZSxcbiAgICAgICAgICAgICAgICBwdWJsaWMgdHJhbnNsYXRlU2VydmljZTogVHJhbnNsYXRlU2VydmljZSxcbiAgICAgICAgICAgICAgICBwdWJsaWMgYXBwTWFpblNlcnZpY2U6IEFwcE1haW5Db21wb25lbnRTZXJ2aWNlXG4gICAgICAgICAgICAgICAgLy8gcHJpdmF0ZSB1c2VyU2VydmljZTogVXNlckFwaVNlcnZpY2UgVE9ET1xuICAgICkge1xuICAgICAgICB0aGlzLmxhbmd1YWdlcyA9IHRyYW5zbGF0ZVNlcnZpY2UuZ2V0TGFuZ3MoKTtcbiAgICB9XG5cbiAgICBzd2l0Y2hMYW5ndWFnZShsYW5ndWFnZTogc3RyaW5nKSB7XG4gICAgICAgIHRoaXMudHJhbnNsYXRlU2VydmljZS51c2UobGFuZ3VhZ2UpO1xuICAgIH1cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICAvLyB0aGlzLnVzZXJTZXJ2aWNlLmdldEN1cnJlbnRVc2VyKCkuc3Vic2NyaWJlKG9iaiA9PiB0aGlzLnVzZXIgPSBvYmopO1xuICAgIH1cbn1cbiJdfQ==
@@ -0,0 +1,7 @@
1
+ export * from './app.breadcrumb.component';
2
+ export * from './app.footer.component';
3
+ export * from './app.main.component';
4
+ export * from './app.menu.component';
5
+ export * from './app.menuitem.component';
6
+ export * from './app.topbar.component';
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tbmctY29tbW9ucy9zcmMvbGliL2NvbXBvbmVudHMvbGF5b3V0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHdCQUF3QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hcHAuYnJlYWRjcnVtYi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9hcHAuZm9vdGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2FwcC5tYWluLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2FwcC5tZW51LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2FwcC5tZW51aXRlbS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9hcHAudG9wYmFyLmNvbXBvbmVudCc7XG4iXX0=
@@ -0,0 +1,4 @@
1
+ export * from './tableview.component';
2
+ export * from './route/tableview-route.abstract.component';
3
+ export * from './table/table.component';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tbmctY29tbW9ucy9zcmMvbGliL2NvbXBvbmVudHMvdGFibGV2aWV3L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLHlCQUF5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi90YWJsZXZpZXcuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcm91dGUvdGFibGV2aWV3LXJvdXRlLmFic3RyYWN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3RhYmxlL3RhYmxlLmNvbXBvbmVudCc7XG4iXX0=
@@ -0,0 +1,31 @@
1
+ import { Directive } from '@angular/core';
2
+ import { ActionDeleteDescriptor, ActionEditorAddDescriptor, ActionEditorEditDescriptor, ActionEditorDetailsDescriptor } from '../../../models/descriptors';
3
+ import * as i0 from "@angular/core";
4
+ export const mngTableviewRouteComponentTemplate = `
5
+ <div class="grid">
6
+ <div class="col-12">
7
+ <mng-tableview [descriptor]="descriptor" [dataProvider]="dataProvider" [actions]="actions"></mng-tableview>
8
+ </div>
9
+ </div>
10
+ `;
11
+ export class AMngTableviewRouteComponent {
12
+ constructor() {
13
+ this.descriptor = this.createTableviewDescriptor();
14
+ this.dataProvider = this.createTableviewDataProvider();
15
+ this.actions = this.createActionDescriptors();
16
+ }
17
+ createActionDescriptors() {
18
+ const actions = [];
19
+ actions.push(new ActionEditorDetailsDescriptor(this.descriptor.viewEditor));
20
+ actions.push(new ActionEditorAddDescriptor(this.descriptor.addEditor));
21
+ actions.push(new ActionEditorEditDescriptor(this.descriptor.editEditor));
22
+ actions.push(new ActionDeleteDescriptor(this.descriptor.model));
23
+ return actions;
24
+ }
25
+ }
26
+ AMngTableviewRouteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AMngTableviewRouteComponent, deps: [], target: i0.ɵɵFactoryTarget.Directive });
27
+ AMngTableviewRouteComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.1.1", type: AMngTableviewRouteComponent, ngImport: i0 });
28
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AMngTableviewRouteComponent, decorators: [{
29
+ type: Directive
30
+ }], ctorParameters: function () { return []; } });
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGV2aWV3LXJvdXRlLmFic3RyYWN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21uZy1jb21tb25zL3NyYy9saWIvY29tcG9uZW50cy90YWJsZXZpZXcvcm91dGUvdGFibGV2aWV3LXJvdXRlLmFic3RyYWN0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRXhDLE9BQU8sRUFBc0Isc0JBQXNCLEVBQW9CLHlCQUF5QixFQUFFLDBCQUEwQixFQUFFLDZCQUE2QixFQUFDLE1BQU0sNkJBQTZCLENBQUM7O0FBR2hNLE1BQU0sQ0FBQyxNQUFNLGtDQUFrQyxHQUFXOzs7Ozs7Q0FNekQsQ0FBQztBQUdGLE1BQU0sT0FBZ0IsMkJBQTJCO0lBTTdDO1FBRUksSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMseUJBQXlCLEVBQUUsQ0FBQztRQUNuRCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQywyQkFBMkIsRUFBRSxDQUFDO1FBQ3ZELElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLHVCQUF1QixFQUFFLENBQUM7SUFDbEQsQ0FBQztJQUtTLHVCQUF1QjtRQUM3QixNQUFNLE9BQU8sR0FBK0IsRUFBRSxDQUFDO1FBQy9DLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSw2QkFBNkIsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7UUFDNUUsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLHlCQUF5QixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQztRQUN2RSxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksMEJBQTBCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO1FBQ3pFLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxzQkFBc0IsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7UUFDaEUsT0FBTyxPQUFPLENBQUM7SUFDbkIsQ0FBQzs7d0hBdkJpQiwyQkFBMkI7NEdBQTNCLDJCQUEyQjsyRkFBM0IsMkJBQTJCO2tCQURoRCxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQge1RhYmxldmlld0Rlc2NyaXB0b3IsIEFjdGlvbkRlbGV0ZURlc2NyaXB0b3IsIEFjdGlvbkRlc2NyaXB0b3IsIEFjdGlvbkVkaXRvckFkZERlc2NyaXB0b3IsIEFjdGlvbkVkaXRvckVkaXREZXNjcmlwdG9yLCBBY3Rpb25FZGl0b3JEZXRhaWxzRGVzY3JpcHRvcn0gZnJvbSAnLi4vLi4vLi4vbW9kZWxzL2Rlc2NyaXB0b3JzJztcbmltcG9ydCB7SVRhYmxldmlld0RhdGFQcm92aWRlcn0gZnJvbSAnLi4vLi4vLi4vbW9kZWxzL3Byb3ZpZGVycyc7XG5cbmV4cG9ydCBjb25zdCBtbmdUYWJsZXZpZXdSb3V0ZUNvbXBvbmVudFRlbXBsYXRlOiBzdHJpbmcgPSBgXG48ZGl2IGNsYXNzPVwiZ3JpZFwiPlxuICAgIDxkaXYgY2xhc3M9XCJjb2wtMTJcIj5cbiAgICAgICAgPG1uZy10YWJsZXZpZXcgW2Rlc2NyaXB0b3JdPVwiZGVzY3JpcHRvclwiIFtkYXRhUHJvdmlkZXJdPVwiZGF0YVByb3ZpZGVyXCIgW2FjdGlvbnNdPVwiYWN0aW9uc1wiPjwvbW5nLXRhYmxldmlldz5cbiAgICA8L2Rpdj5cbjwvZGl2PlxuYDtcblxuQERpcmVjdGl2ZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQU1uZ1RhYmxldmlld1JvdXRlQ29tcG9uZW50PFQsIFM+IHtcblxuICAgIHB1YmxpYyBkZXNjcmlwdG9yOiBUYWJsZXZpZXdEZXNjcmlwdG9yPFQ+O1xuICAgIHB1YmxpYyBkYXRhUHJvdmlkZXI6IElUYWJsZXZpZXdEYXRhUHJvdmlkZXI8VCwgUz47XG4gICAgcHVibGljIGFjdGlvbnM6IEFycmF5PEFjdGlvbkRlc2NyaXB0b3I8VD4+O1xuXG4gICAgcHJvdGVjdGVkIGNvbnN0cnVjdG9yKFxuICAgICkge1xuICAgICAgICB0aGlzLmRlc2NyaXB0b3IgPSB0aGlzLmNyZWF0ZVRhYmxldmlld0Rlc2NyaXB0b3IoKTtcbiAgICAgICAgdGhpcy5kYXRhUHJvdmlkZXIgPSB0aGlzLmNyZWF0ZVRhYmxldmlld0RhdGFQcm92aWRlcigpO1xuICAgICAgICB0aGlzLmFjdGlvbnMgPSB0aGlzLmNyZWF0ZUFjdGlvbkRlc2NyaXB0b3JzKCk7XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIGFic3RyYWN0IGNyZWF0ZVRhYmxldmlld0Rlc2NyaXB0b3IoKTogVGFibGV2aWV3RGVzY3JpcHRvcjxUPjtcbiAgICBwcm90ZWN0ZWQgYWJzdHJhY3QgY3JlYXRlVGFibGV2aWV3RGF0YVByb3ZpZGVyKCk6IElUYWJsZXZpZXdEYXRhUHJvdmlkZXI8VCwgUz47XG5cbiAgICBwcm90ZWN0ZWQgY3JlYXRlQWN0aW9uRGVzY3JpcHRvcnMoKTogQXJyYXk8QWN0aW9uRGVzY3JpcHRvcjxUPj4ge1xuICAgICAgICBjb25zdCBhY3Rpb25zOiBBcnJheTxBY3Rpb25EZXNjcmlwdG9yPFQ+PiA9IFtdO1xuICAgICAgICBhY3Rpb25zLnB1c2gobmV3IEFjdGlvbkVkaXRvckRldGFpbHNEZXNjcmlwdG9yKHRoaXMuZGVzY3JpcHRvci52aWV3RWRpdG9yKSk7XG4gICAgICAgIGFjdGlvbnMucHVzaChuZXcgQWN0aW9uRWRpdG9yQWRkRGVzY3JpcHRvcih0aGlzLmRlc2NyaXB0b3IuYWRkRWRpdG9yKSk7XG4gICAgICAgIGFjdGlvbnMucHVzaChuZXcgQWN0aW9uRWRpdG9yRWRpdERlc2NyaXB0b3IodGhpcy5kZXNjcmlwdG9yLmVkaXRFZGl0b3IpKTtcbiAgICAgICAgYWN0aW9ucy5wdXNoKG5ldyBBY3Rpb25EZWxldGVEZXNjcmlwdG9yKHRoaXMuZGVzY3JpcHRvci5tb2RlbCkpO1xuICAgICAgICByZXR1cm4gYWN0aW9ucztcbiAgICB9XG59XG4iXX0=
@@ -0,0 +1,173 @@
1
+ import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, Output, ViewChild } from '@angular/core';
2
+ import { Table } from 'primeng/table';
3
+ import { Observable, of, ReplaySubject } from 'rxjs';
4
+ import { finalize, first, map } from 'rxjs/operators';
5
+ import { QueryParam, QueryResult } from '../../../api/models';
6
+ import { MediusRestUtil } from '../../../api/utils';
7
+ import { MngTableCellClickEvent, MngTableLoadEvent } from '../../../models/events';
8
+ import { TemplateDirective } from '../../../directives';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "primeng/table";
11
+ import * as i2 from "@angular/common";
12
+ import * as i3 from "primeng/api";
13
+ import * as i4 from "@ngx-translate/core";
14
+ import * as i5 from "../../../pipes/property-path.pipe";
15
+ export class TableComponent {
16
+ constructor(injector) {
17
+ this.injector = injector;
18
+ // extra features input
19
+ this.selectionEnabled = false;
20
+ // event outputs
21
+ this.loadEventEmitter = new EventEmitter();
22
+ this.cellClickEventEmitter = new EventEmitter();
23
+ this.selectionChangeEventEmitter = new EventEmitter();
24
+ this.useDataProvider = false;
25
+ this.dataProviderService = null;
26
+ this.dataProviderQueryResultSubject = new ReplaySubject(1);
27
+ this.dataProviderLoadingSubject = new ReplaySubject(1);
28
+ this.rowsPerPageOptions = [10, 25, 50];
29
+ this.selection = [];
30
+ this.subscriptions = [];
31
+ }
32
+ ngOnInit() {
33
+ // initalize if default sort is set
34
+ if (this.descriptor.hasDefaultSort) {
35
+ this.multiSortMeta = this.descriptor.defaultSortProperty.map((p, idx) => ({
36
+ field: p,
37
+ order: this.descriptor.defaultSortAsc[idx] ? 1 : -1
38
+ }));
39
+ }
40
+ // check if data provider is supplied, if is, use it primarily
41
+ if (this.dataProvider) {
42
+ // map subjects to observables and initiate data
43
+ this.useDataProvider = true;
44
+ this.queryResult$ = this.dataProviderQueryResultSubject.asObservable();
45
+ this.loading$ = this.dataProviderLoadingSubject.asObservable();
46
+ const emptyQueryResult = new QueryResult();
47
+ emptyQueryResult.pageData = [];
48
+ emptyQueryResult.allDataCount = 0;
49
+ this.dataProviderLoadingSubject.next(false);
50
+ this.dataProviderQueryResultSubject.next(emptyQueryResult);
51
+ // inject service
52
+ if (this.dataProvider.serviceType) {
53
+ this.dataProviderService = this.injector.get(this.dataProvider.serviceType);
54
+ }
55
+ }
56
+ else {
57
+ // if query result is provided, use it as secondary source or else try to use items
58
+ if (this.queryResult) {
59
+ this.queryResult$ = this.queryResult instanceof Observable ? this.queryResult : of(this.queryResult);
60
+ }
61
+ else if (!this.queryResult && this.items) {
62
+ this.queryResult$ = (this.items instanceof Observable ? this.items : of(this.items)).pipe(
63
+ // distinctUntilChanged((v1, v2) => v1.length === v2.length &&
64
+ // v1.every((v1i, idx) => v1i[this.descriptor.dataKeyProperty] === v2[idx][this.descriptor.dataKeyProperty])),
65
+ map(items => {
66
+ const queryResult = new QueryResult();
67
+ queryResult.pageData = items;
68
+ queryResult.allDataCount = items.length;
69
+ return queryResult;
70
+ }));
71
+ }
72
+ if (typeof this.loading !== 'undefined') {
73
+ this.loading$ = this.loading instanceof Observable ? this.loading : of(this.loading);
74
+ }
75
+ }
76
+ }
77
+ ngAfterContentInit() {
78
+ this.templates.forEach(template => {
79
+ switch (template.getType()) {
80
+ case 'caption':
81
+ this.captionTemplate = template.template;
82
+ break;
83
+ case 'columnAction':
84
+ this.columnActionTemplate = template.template;
85
+ break;
86
+ }
87
+ });
88
+ }
89
+ ngOnDestroy() {
90
+ this.subscriptions.forEach(s => s.unsubscribe());
91
+ }
92
+ reload(emitEvent = false, resetParams = false) {
93
+ this.loadTableWithDataProvider(resetParams ? null : (this.dataProviderLatestLazyLoadEvent ?? null), emitEvent);
94
+ }
95
+ onTableLazyLoad(event) {
96
+ if (this.useDataProvider) {
97
+ this.loadTableWithDataProvider(event);
98
+ }
99
+ }
100
+ onCellClick(col, item, idx) {
101
+ const mngEvent = new MngTableCellClickEvent(col, item, idx);
102
+ this.cellClickEventEmitter.next(mngEvent);
103
+ }
104
+ onSelectionChange(event) {
105
+ this.selectionChangeEventEmitter.emit(event);
106
+ }
107
+ loadTableWithDataProvider(lazyLoadEvent, emitEvent = true) {
108
+ if (!this.useDataProvider) {
109
+ return;
110
+ }
111
+ if (this.dataProviderSubscription) {
112
+ this.dataProviderSubscription.unsubscribe();
113
+ }
114
+ this.dataProviderLoadingSubject.next(true);
115
+ this.multiSortMeta = lazyLoadEvent?.multiSortMeta;
116
+ const queryParams = lazyLoadEvent
117
+ ? MediusRestUtil.fromLazyLoadEventToQueryParams(lazyLoadEvent)
118
+ : new QueryParam();
119
+ if (!queryParams.sortProperty && this.descriptor.hasDefaultSort) {
120
+ queryParams.sortProperty = [...this.descriptor.defaultSortProperty];
121
+ queryParams.sortAsc = [...this.descriptor.defaultSortAsc];
122
+ }
123
+ this.dataProviderSubscription = this.dataProvider?.getAll(queryParams, this.dataProviderService)
124
+ .pipe(first(), finalize(() => this.dataProviderLoadingSubject.next(false)))
125
+ .subscribe(res => {
126
+ this.dataProviderLatestLazyLoadEvent = lazyLoadEvent ?? undefined;
127
+ this.dataProviderQueryResultSubject.next(res);
128
+ }, err => {
129
+ // this.messageService.add({severity: 'error', summary: 'Error', detail: 'Failed to fetch table items', life: 3000});
130
+ console.error(err);
131
+ });
132
+ if (emitEvent) {
133
+ const mngEvent = new MngTableLoadEvent();
134
+ mngEvent.originalEvent = lazyLoadEvent ?? undefined;
135
+ mngEvent.queryParam = queryParams;
136
+ this.loadEventEmitter.next(mngEvent);
137
+ }
138
+ }
139
+ }
140
+ TableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: TableComponent, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
141
+ TableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: TableComponent, selector: "mng-table", inputs: { descriptor: "descriptor", items: "items", queryResult: "queryResult", loading: "loading", dataProvider: "dataProvider", selectionEnabled: "selectionEnabled" }, outputs: { loadEventEmitter: "onLoad", cellClickEventEmitter: "onCellClick", selectionChangeEventEmitter: "onSelectionChange" }, queries: [{ propertyName: "templates", predicate: TemplateDirective }], viewQueries: [{ propertyName: "primeTable", first: true, predicate: Table, descendants: true }], ngImport: i0, template: "<p-table [value]=\"(queryResult$ | async)?.pageData ?? []\"\n [dataKey]=\"$any(descriptor.dataKeyProperty)\"\n [lazy]=\"useDataProvider\"\n (onLazyLoad)=\"onTableLazyLoad($event)\"\n [loading]=\"(loading$ | async) ?? false\"\n [paginator]=\"useDataProvider\"\n [rows]=\"rowsPerPageOptions[0]\"\n [totalRecords]=\"(queryResult$ | async)?.allDataCount ?? 0\"\n [rowsPerPageOptions]=\"rowsPerPageOptions\"\n [showCurrentPageReport]=\"true\"\n [currentPageReportTemplate]=\"'mngTable.paginationMsg' | translate\"\n [multiSortMeta]=\"$any(multiSortMeta)\"\n sortMode=\"multiple\"\n [(selection)]=\"selection\"\n (selectionChange)=\"onSelectionChange($event)\"\n responsiveLayout=\"scroll\">\n {{ descriptor.hasDefaultSort}}\n\n <ng-template *ngIf=\"captionTemplate || descriptor.title\" pTemplate=\"caption\">\n <ng-container *ngIf=\"captionTemplate; else defaultCaption\">\n <ng-container *ngTemplateOutlet=\"captionTemplate\"></ng-container>\n </ng-container>\n <ng-template #defaultCaption>\n <h5 class=\"p-m-0\">{{ descriptor.title }}</h5>\n </ng-template>\n </ng-template>\n\n <ng-template pTemplate=\"header\">\n <tr>\n <th *ngIf=\"selectionEnabled\">\n <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n </th>\n <ng-container *ngFor=\"let col of descriptor.columns\">\n <th *ngIf=\"col.isSortEnabled\" [pSortableColumn]=\"col.property\">\n <div class=\"flex justify-content-between align-items-center\">\n {{ descriptor.model.typeName + \".properties.\" + col.property | translate }}\n <p-sortIcon [field]=\"col.property\"></p-sortIcon>\n <p-columnFilter *ngIf=\"col.isFilterEnabled\" class=\"ml-auto\" type=\"text\" display=\"menu\" matchMode=\"equals\"\n [field]=\"col.property\"\n [showOperator]=\"false\" [showAddButton]=\"false\" [hideOnClear]=\"true\">\n </p-columnFilter>\n </div>\n </th>\n <th *ngIf=\"!col.isSortEnabled\">\n <div class=\"flex justify-content-between align-items-center\">\n {{ descriptor.model.typeName + \".properties.\" + col.property | translate }}\n <p-columnFilter *ngIf=\"col.isFilterEnabled\" class=\"ml-auto\" type=\"text\" display=\"menu\" matchMode=\"equals\"\n [field]=\"col.property\"\n [showOperator]=\"false\" [showAddButton]=\"false\" [hideOnClear]=\"true\">\n </p-columnFilter>\n </div>\n </th>\n </ng-container>\n <th *ngIf=\"columnActionTemplate\"></th>\n </tr>\n </ng-template>\n\n <ng-template pTemplate=\"body\" let-item let-idx=\"rowIndex\">\n <tr>\n <td *ngIf=\"selectionEnabled\">\n <p-tableCheckbox [value]=\"item\"></p-tableCheckbox>\n </td>\n <td *ngFor=\"let col of descriptor.columns\" (click)=\"onCellClick(col, item, idx)\" class=\"clickable\">\n {{ col.displayPropertyPath ? (item | propertyPath: col.displayPropertyPath) : item[col.property] }}\n </td>\n <td *ngIf=\"columnActionTemplate\" class=\"text-right\">\n <ng-container *ngTemplateOutlet=\"columnActionTemplate; context: { rowItem: item, rowIndex: idx }\"></ng-container>\n </td>\n </tr>\n </ng-template>\n\n <ng-template pTemplate=\"emptymessage\">\n <tr>\n <td [attr.colspan]=\"descriptor.columns.length + (columnActionTemplate ? 1 : 0) + (selectionEnabled ? 1 : 0)\">\n {{ 'mngTable.noItems' | translate }}\n </td>\n </tr>\n </ng-template>\n</p-table>\n", components: [{ type: i1.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showJumpToPageInput", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "selectionPageOnly", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowSelectable", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollDelay", "virtualRowHeight", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "stateKey", "stateStorage", "editMode", "groupRowsBy", "groupRowsByOrder", "minBufferPx", "maxBufferPx", "responsiveLayout", "breakpoint", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "selectAll"], outputs: ["selectAllChange", "selectionChange", "contextMenuSelectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { type: i1.TableHeaderCheckbox, selector: "p-tableHeaderCheckbox", inputs: ["disabled", "inputId", "name", "ariaLabel"] }, { type: i1.SortIcon, selector: "p-sortIcon", inputs: ["field"] }, { type: i1.ColumnFilter, selector: "p-columnFilter", inputs: ["field", "type", "display", "showMenu", "matchMode", "operator", "showOperator", "showClearButton", "showApplyButton", "showMatchModes", "showAddButton", "hideOnClear", "placeholder", "matchModeOptions", "maxConstraints", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "locale", "localeMatcher", "currency", "currencyDisplay", "useGrouping"] }, { type: i1.TableCheckbox, selector: "p-tableCheckbox", inputs: ["disabled", "value", "index", "inputId", "name", "required", "ariaLabel"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.SortableColumn, selector: "[pSortableColumn]", inputs: ["pSortableColumn", "pSortableColumnDisabled"] }], pipes: { "async": i2.AsyncPipe, "translate": i4.TranslatePipe, "propertyPath": i5.PropertyPathPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
142
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: TableComponent, decorators: [{
143
+ type: Component,
144
+ args: [{ selector: 'mng-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "<p-table [value]=\"(queryResult$ | async)?.pageData ?? []\"\n [dataKey]=\"$any(descriptor.dataKeyProperty)\"\n [lazy]=\"useDataProvider\"\n (onLazyLoad)=\"onTableLazyLoad($event)\"\n [loading]=\"(loading$ | async) ?? false\"\n [paginator]=\"useDataProvider\"\n [rows]=\"rowsPerPageOptions[0]\"\n [totalRecords]=\"(queryResult$ | async)?.allDataCount ?? 0\"\n [rowsPerPageOptions]=\"rowsPerPageOptions\"\n [showCurrentPageReport]=\"true\"\n [currentPageReportTemplate]=\"'mngTable.paginationMsg' | translate\"\n [multiSortMeta]=\"$any(multiSortMeta)\"\n sortMode=\"multiple\"\n [(selection)]=\"selection\"\n (selectionChange)=\"onSelectionChange($event)\"\n responsiveLayout=\"scroll\">\n {{ descriptor.hasDefaultSort}}\n\n <ng-template *ngIf=\"captionTemplate || descriptor.title\" pTemplate=\"caption\">\n <ng-container *ngIf=\"captionTemplate; else defaultCaption\">\n <ng-container *ngTemplateOutlet=\"captionTemplate\"></ng-container>\n </ng-container>\n <ng-template #defaultCaption>\n <h5 class=\"p-m-0\">{{ descriptor.title }}</h5>\n </ng-template>\n </ng-template>\n\n <ng-template pTemplate=\"header\">\n <tr>\n <th *ngIf=\"selectionEnabled\">\n <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n </th>\n <ng-container *ngFor=\"let col of descriptor.columns\">\n <th *ngIf=\"col.isSortEnabled\" [pSortableColumn]=\"col.property\">\n <div class=\"flex justify-content-between align-items-center\">\n {{ descriptor.model.typeName + \".properties.\" + col.property | translate }}\n <p-sortIcon [field]=\"col.property\"></p-sortIcon>\n <p-columnFilter *ngIf=\"col.isFilterEnabled\" class=\"ml-auto\" type=\"text\" display=\"menu\" matchMode=\"equals\"\n [field]=\"col.property\"\n [showOperator]=\"false\" [showAddButton]=\"false\" [hideOnClear]=\"true\">\n </p-columnFilter>\n </div>\n </th>\n <th *ngIf=\"!col.isSortEnabled\">\n <div class=\"flex justify-content-between align-items-center\">\n {{ descriptor.model.typeName + \".properties.\" + col.property | translate }}\n <p-columnFilter *ngIf=\"col.isFilterEnabled\" class=\"ml-auto\" type=\"text\" display=\"menu\" matchMode=\"equals\"\n [field]=\"col.property\"\n [showOperator]=\"false\" [showAddButton]=\"false\" [hideOnClear]=\"true\">\n </p-columnFilter>\n </div>\n </th>\n </ng-container>\n <th *ngIf=\"columnActionTemplate\"></th>\n </tr>\n </ng-template>\n\n <ng-template pTemplate=\"body\" let-item let-idx=\"rowIndex\">\n <tr>\n <td *ngIf=\"selectionEnabled\">\n <p-tableCheckbox [value]=\"item\"></p-tableCheckbox>\n </td>\n <td *ngFor=\"let col of descriptor.columns\" (click)=\"onCellClick(col, item, idx)\" class=\"clickable\">\n {{ col.displayPropertyPath ? (item | propertyPath: col.displayPropertyPath) : item[col.property] }}\n </td>\n <td *ngIf=\"columnActionTemplate\" class=\"text-right\">\n <ng-container *ngTemplateOutlet=\"columnActionTemplate; context: { rowItem: item, rowIndex: idx }\"></ng-container>\n </td>\n </tr>\n </ng-template>\n\n <ng-template pTemplate=\"emptymessage\">\n <tr>\n <td [attr.colspan]=\"descriptor.columns.length + (columnActionTemplate ? 1 : 0) + (selectionEnabled ? 1 : 0)\">\n {{ 'mngTable.noItems' | translate }}\n </td>\n </tr>\n </ng-template>\n</p-table>\n" }]
145
+ }], ctorParameters: function () { return [{ type: i0.Injector }]; }, propDecorators: { descriptor: [{
146
+ type: Input
147
+ }], items: [{
148
+ type: Input
149
+ }], queryResult: [{
150
+ type: Input
151
+ }], loading: [{
152
+ type: Input
153
+ }], dataProvider: [{
154
+ type: Input
155
+ }], selectionEnabled: [{
156
+ type: Input
157
+ }], loadEventEmitter: [{
158
+ type: Output,
159
+ args: ['onLoad']
160
+ }], cellClickEventEmitter: [{
161
+ type: Output,
162
+ args: ['onCellClick']
163
+ }], selectionChangeEventEmitter: [{
164
+ type: Output,
165
+ args: ['onSelectionChange']
166
+ }], templates: [{
167
+ type: ContentChildren,
168
+ args: [TemplateDirective]
169
+ }], primeTable: [{
170
+ type: ViewChild,
171
+ args: [Table]
172
+ }] } });
173
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../../projects/mng-commons/src/lib/components/tableview/table/table.component.ts","../../../../../../../projects/mng-commons/src/lib/components/tableview/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterContentInit, ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Injector, Input, OnDestroy, OnInit, Output, QueryList, TemplateRef, ViewChild} from '@angular/core';\n\nimport {Table} from 'primeng/table';\nimport {LazyLoadEvent, SortMeta} from 'primeng/api';\nimport {Observable, of, ReplaySubject, Subscription} from 'rxjs';\nimport {finalize, first, map} from 'rxjs/operators';\n\nimport {QueryParam, QueryResult} from '../../../api/models';\nimport {MediusRestUtil} from '../../../api/utils';\n\nimport {TableDescriptor, ColumnDescriptor} from '../../../models/descriptors';\nimport {ITableDataProvider} from '../../../models/providers';\nimport {MngTableCellClickEvent, MngTableLoadEvent} from '../../../models/events';\nimport {TemplateDirective} from '../../../directives';\n\n@Component({\n    selector: 'mng-table',\n    templateUrl: './table.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TableComponent<T> implements OnInit, AfterContentInit, OnDestroy {\n\n    // metadata input\n    @Input() public descriptor!: TableDescriptor<T>;\n    \n    // data source inputs\n    @Input() public items?: Observable<Array<T>>|Array<T>;\n    @Input() public queryResult?: Observable<QueryResult<T>>|QueryResult<T>;\n    @Input() public loading?: Observable<boolean>|boolean;\n    @Input() public dataProvider?: ITableDataProvider<T, any>;\n    \n    // extra features input\n    @Input() public selectionEnabled: boolean = false;\n\n    // event outputs\n    @Output('onLoad') private loadEventEmitter = new EventEmitter<MngTableLoadEvent>();\n    @Output('onCellClick') private cellClickEventEmitter = new EventEmitter<MngTableCellClickEvent<T>>();\n    @Output('onSelectionChange') private selectionChangeEventEmitter = new EventEmitter<Array<T>>();\n\n    // content and view queries\n    @ContentChildren(TemplateDirective) templates!: QueryList<TemplateDirective>;\n    @ViewChild(Table) private primeTable!: Table;\n\n    public captionTemplate?: TemplateRef<any>;\n    public columnActionTemplate?: TemplateRef<any>;\n\n    public useDataProvider: boolean = false;\n    public queryResult$?: Observable<QueryResult<T>>;\n    public loading$?: Observable<boolean>;\n    private dataProviderService: any = null;\n    private dataProviderQueryResultSubject = new ReplaySubject<QueryResult<T>>(1);\n    private dataProviderLoadingSubject = new ReplaySubject<boolean>(1);\n    private dataProviderLatestLazyLoadEvent?: LazyLoadEvent;\n    private dataProviderSubscription?: Subscription;\n\n    public readonly rowsPerPageOptions = [10, 25, 50];\n    public multiSortMeta?: SortMeta[];\n\n    public selection: Array<T> = [];\n\n    private subscriptions: Subscription[] = [];\n\n    constructor(private injector: Injector) {\n    }\n\n    public ngOnInit() {\n\n        // initalize if default sort is set\n        if (this.descriptor.hasDefaultSort) {\n            this.multiSortMeta = this.descriptor.defaultSortProperty.map((p, idx) => <SortMeta>{\n                field: p,\n                order: this.descriptor.defaultSortAsc[idx] ? 1 : -1\n            });\n        }\n        // check if data provider is supplied, if is, use it primarily\n        if (this.dataProvider) {\n            // map subjects to observables and initiate data\n            this.useDataProvider = true;\n            this.queryResult$ = this.dataProviderQueryResultSubject.asObservable();\n            this.loading$ = this.dataProviderLoadingSubject.asObservable();\n            const emptyQueryResult = new QueryResult<T>();\n            emptyQueryResult.pageData = [];\n            emptyQueryResult.allDataCount = 0;\n            this.dataProviderLoadingSubject.next(false);\n            this.dataProviderQueryResultSubject.next(emptyQueryResult)\n\n            // inject service\n            if (this.dataProvider.serviceType) {\n                this.dataProviderService = this.injector.get<any>(this.dataProvider.serviceType);\n            }\n        } else {\n            // if query result is provided, use it as secondary source or else try to use items\n            if (this.queryResult) {\n                this.queryResult$ = this.queryResult instanceof Observable ? this.queryResult : of(this.queryResult);\n            } else if (!this.queryResult && this.items) {\n                this.queryResult$ = (this.items instanceof Observable ? this.items : of(this.items)).pipe(\n                    // distinctUntilChanged((v1, v2) => v1.length === v2.length &&\n                    //     v1.every((v1i, idx) => v1i[this.descriptor.dataKeyProperty] === v2[idx][this.descriptor.dataKeyProperty])),\n                    map(items => {\n                        const queryResult = new QueryResult<T>();\n                        queryResult.pageData = items;\n                        queryResult.allDataCount = items.length;\n                        return queryResult;\n                    }));\n            }\n            if (typeof this.loading !== 'undefined') {\n                this.loading$ = this.loading instanceof Observable ? this.loading : of(this.loading);\n            }\n        }\n    }\n\n    public ngAfterContentInit() {\n        this.templates.forEach(template => {\n            switch(template.getType()) {\n                case 'caption':\n                    this.captionTemplate = template.template;\n                    break;\n                case 'columnAction':\n                    this.columnActionTemplate = template.template;\n                    break;\n            }\n        });\n    }\n\n    public ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\n\n    public reload(emitEvent: boolean = false, resetParams: boolean = false) {\n        this.loadTableWithDataProvider(resetParams ? null : (this.dataProviderLatestLazyLoadEvent ?? null), emitEvent);\n    }\n\n    public onTableLazyLoad(event: LazyLoadEvent) {\n        if (this.useDataProvider) {\n            this.loadTableWithDataProvider(event);\n        }\n    }\n\n    public onCellClick(col: ColumnDescriptor<any>, item: T, idx: number) {\n        const mngEvent = new MngTableCellClickEvent<T>(col, item, idx);\n        this.cellClickEventEmitter.next(mngEvent);\n    }\n\n    public onSelectionChange(event: Array<T>) {\n        this.selectionChangeEventEmitter.emit(event);\n    }\n\n    private loadTableWithDataProvider(lazyLoadEvent: LazyLoadEvent|null, emitEvent: boolean = true) {\n        if (!this.useDataProvider) {\n            return;\n        }\n        if (this.dataProviderSubscription) {\n            this.dataProviderSubscription.unsubscribe();\n        }\n        this.dataProviderLoadingSubject.next(true);\n\n        this.multiSortMeta = lazyLoadEvent?.multiSortMeta;\n        const queryParams = lazyLoadEvent\n            ? MediusRestUtil.fromLazyLoadEventToQueryParams(lazyLoadEvent)\n            : new QueryParam();\n        if (!queryParams.sortProperty && this.descriptor.hasDefaultSort) {\n            queryParams.sortProperty = [...this.descriptor.defaultSortProperty];\n            queryParams.sortAsc = [...this.descriptor.defaultSortAsc];\n        }\n\n        this.dataProviderSubscription = this.dataProvider?.getAll(queryParams, this.dataProviderService)\n            .pipe(\n                first(),\n                finalize(() => this.dataProviderLoadingSubject.next(false))\n            )\n            .subscribe(res => {\n                this.dataProviderLatestLazyLoadEvent = lazyLoadEvent ?? undefined;\n                this.dataProviderQueryResultSubject.next(res);\n            }, err => {\n                // this.messageService.add({severity: 'error', summary: 'Error', detail: 'Failed to fetch table items', life: 3000});\n                console.error(err);\n            });\n\n        if (emitEvent) {\n            const mngEvent = new MngTableLoadEvent();\n            mngEvent.originalEvent = lazyLoadEvent ?? undefined;\n            mngEvent.queryParam = queryParams;\n            this.loadEventEmitter.next(mngEvent);\n        }\n    }\n}\n","<p-table [value]=\"(queryResult$ | async)?.pageData ?? []\"\n         [dataKey]=\"$any(descriptor.dataKeyProperty)\"\n         [lazy]=\"useDataProvider\"\n         (onLazyLoad)=\"onTableLazyLoad($event)\"\n         [loading]=\"(loading$ | async) ?? false\"\n         [paginator]=\"useDataProvider\"\n         [rows]=\"rowsPerPageOptions[0]\"\n         [totalRecords]=\"(queryResult$ | async)?.allDataCount ?? 0\"\n         [rowsPerPageOptions]=\"rowsPerPageOptions\"\n         [showCurrentPageReport]=\"true\"\n         [currentPageReportTemplate]=\"'mngTable.paginationMsg' | translate\"\n         [multiSortMeta]=\"$any(multiSortMeta)\"\n         sortMode=\"multiple\"\n         [(selection)]=\"selection\"\n         (selectionChange)=\"onSelectionChange($event)\"\n         responsiveLayout=\"scroll\">\n    {{ descriptor.hasDefaultSort}}\n\n    <ng-template *ngIf=\"captionTemplate || descriptor.title\" pTemplate=\"caption\">\n        <ng-container *ngIf=\"captionTemplate; else defaultCaption\">\n            <ng-container *ngTemplateOutlet=\"captionTemplate\"></ng-container>\n        </ng-container>\n        <ng-template #defaultCaption>\n            <h5 class=\"p-m-0\">{{ descriptor.title }}</h5>\n        </ng-template>\n    </ng-template>\n\n    <ng-template pTemplate=\"header\">\n        <tr>\n            <th *ngIf=\"selectionEnabled\">\n                <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n            </th>\n            <ng-container *ngFor=\"let col of descriptor.columns\">\n                <th *ngIf=\"col.isSortEnabled\" [pSortableColumn]=\"col.property\">\n                    <div class=\"flex justify-content-between align-items-center\">\n                        {{ descriptor.model.typeName + \".properties.\" + col.property | translate }}\n                        <p-sortIcon [field]=\"col.property\"></p-sortIcon>\n                        <p-columnFilter *ngIf=\"col.isFilterEnabled\" class=\"ml-auto\" type=\"text\" display=\"menu\" matchMode=\"equals\"\n                                        [field]=\"col.property\"\n                                        [showOperator]=\"false\" [showAddButton]=\"false\" [hideOnClear]=\"true\">\n                        </p-columnFilter>\n                    </div>\n                </th>\n                <th *ngIf=\"!col.isSortEnabled\">\n                    <div class=\"flex justify-content-between align-items-center\">\n                        {{ descriptor.model.typeName + \".properties.\" + col.property | translate }}\n                        <p-columnFilter *ngIf=\"col.isFilterEnabled\" class=\"ml-auto\" type=\"text\" display=\"menu\" matchMode=\"equals\"\n                                        [field]=\"col.property\"\n                                        [showOperator]=\"false\" [showAddButton]=\"false\" [hideOnClear]=\"true\">\n                        </p-columnFilter>\n                    </div>\n                </th>\n            </ng-container>\n            <th *ngIf=\"columnActionTemplate\"></th>\n        </tr>\n    </ng-template>\n\n    <ng-template pTemplate=\"body\" let-item let-idx=\"rowIndex\">\n        <tr>\n            <td *ngIf=\"selectionEnabled\">\n                <p-tableCheckbox [value]=\"item\"></p-tableCheckbox>\n            </td>\n            <td *ngFor=\"let col of descriptor.columns\" (click)=\"onCellClick(col, item, idx)\"  class=\"clickable\">\n                {{ col.displayPropertyPath ? (item | propertyPath: col.displayPropertyPath) : item[col.property] }}\n            </td>\n            <td *ngIf=\"columnActionTemplate\" class=\"text-right\">\n                <ng-container *ngTemplateOutlet=\"columnActionTemplate; context: { rowItem: item, rowIndex: idx }\"></ng-container>\n            </td>\n        </tr>\n    </ng-template>\n\n    <ng-template pTemplate=\"emptymessage\">\n        <tr>\n            <td [attr.colspan]=\"descriptor.columns.length + (columnActionTemplate ? 1 : 0) + (selectionEnabled ? 1 : 0)\">\n                {{ 'mngTable.noItems' | translate }}\n            </td>\n        </tr>\n    </ng-template>\n</p-table>\n"]}
@@ -0,0 +1,82 @@
1
+ import { Component, Input, ViewChild } from '@angular/core';
2
+ import { ConfirmationService, MessageService } from 'primeng/api';
3
+ import { ActionPositionEnum } from '../../models/descriptors';
4
+ import { TableComponent } from './table/table.component';
5
+ import { TableviewComponentService } from './tableview.component.service';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/router";
8
+ import * as i2 from "primeng/api";
9
+ import * as i3 from "@ngx-translate/core";
10
+ import * as i4 from "primeng/dynamicdialog";
11
+ import * as i5 from "../../services";
12
+ import * as i6 from "./tableview.component.service";
13
+ import * as i7 from "primeng/toast";
14
+ import * as i8 from "primeng/toolbar";
15
+ import * as i9 from "../action/action.component";
16
+ import * as i10 from "./table/table.component";
17
+ import * as i11 from "@angular/common";
18
+ import * as i12 from "../../directives/template.directive";
19
+ import * as i13 from "primeng/inputtext";
20
+ export class TableviewComponent {
21
+ constructor(route, messageService, translateService, dialogService, confirmationService, actionService, tableviewService) {
22
+ this.route = route;
23
+ this.messageService = messageService;
24
+ this.translateService = translateService;
25
+ this.dialogService = dialogService;
26
+ this.confirmationService = confirmationService;
27
+ this.actionService = actionService;
28
+ this.tableviewService = tableviewService;
29
+ this.actions = [];
30
+ this.tableComponent = null;
31
+ this.rowClickActions = [];
32
+ this.rowInlineActions = [];
33
+ this.toolbarLeftActions = [];
34
+ this.toolbarRightActions = [];
35
+ }
36
+ ngOnInit() {
37
+ this.tableviewService.actions = this.actions;
38
+ this.tableviewService.dataProvider = this.dataProvider;
39
+ for (const action of this.actions) {
40
+ switch (action.position) {
41
+ case ActionPositionEnum.RowClick:
42
+ this.rowClickActions.push(action);
43
+ break;
44
+ case ActionPositionEnum.RowInline:
45
+ this.rowInlineActions.push(action);
46
+ break;
47
+ case ActionPositionEnum.ToolbarLeft:
48
+ this.toolbarLeftActions.push(action);
49
+ break;
50
+ case ActionPositionEnum.ToolbarRight:
51
+ this.toolbarRightActions.push(action);
52
+ break;
53
+ }
54
+ }
55
+ }
56
+ reloadTable() {
57
+ this.tableComponent?.reload();
58
+ }
59
+ onTableCellClick(event) {
60
+ if (this.rowClickActions.length) {
61
+ for (const action of this.rowClickActions) {
62
+ this.actionService.triggerRowClickAction(action, event, this.route);
63
+ }
64
+ }
65
+ }
66
+ }
67
+ TableviewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: TableviewComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.MessageService }, { token: i3.TranslateService }, { token: i4.DialogService }, { token: i2.ConfirmationService }, { token: i5.ActionService }, { token: i6.TableviewComponentService }], target: i0.ɵɵFactoryTarget.Component });
68
+ TableviewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: TableviewComponent, selector: "mng-tableview", inputs: { descriptor: "descriptor", dataProvider: "dataProvider", actions: "actions" }, providers: [MessageService, ConfirmationService, TableviewComponentService], viewQueries: [{ propertyName: "tableComponent", first: true, predicate: TableComponent, descendants: true }], ngImport: i0, template: "<div class=\"mng-tableview\">\n\t<p-toast></p-toast>\n\n\t<div class=\"card\">\n\t\t<p-toolbar styleClass=\"mb-4\">\n\t\t\t<ng-template pTemplate=\"left\">\n\t\t\t\t<mng-action *ngFor=\"let action of toolbarLeftActions\"\n\t\t\t\t\t\t\t[action]=\"action\">\n\t\t\t\t</mng-action>\n\t\t\t</ng-template>\n\n\t\t\t<ng-template pTemplate=\"right\">\n\t\t\t\t<mng-action *ngFor=\"let action of toolbarRightActions\"\n\t\t\t\t\t\t\t[action]=\"action\">\n\t\t\t\t</mng-action>\n\t\t\t</ng-template>\n\t\t</p-toolbar>\n\n\t\t<mng-table [descriptor]=\"descriptor.table\"\n\t\t\t\t [dataProvider]=\"dataProvider\"\n\t\t\t\t (onCellClick)=\"onTableCellClick($event)\">\n\t\t\t<ng-template mngTemplate=\"caption\">\n\t\t\t\t<div class=\"flex flex-column md:flex-row md:justify-content-between table-header\">\n\t\t\t\t\t<h5 class=\"p-m-0\">{{ descriptor.tableTitle | translate }}</h5>\n\t\t\t\t\t<span class=\"p-input-icon-left\">\n\t\t\t\t\t\t<i class=\"pi pi-search\"></i>\n\t\t\t\t\t\t<input pInputText type=\"text\" [placeholder]=\"'mngTable.search' | translate\" />\n\t\t\t\t\t</span>\n\t\t\t\t</div>\n\t\t\t</ng-template>\n\t\t\t<ng-template mngTemplate=\"columnAction\" let-item=\"rowItem\">\n\t\t\t\t<mng-action *ngFor=\"let action of rowInlineActions\"\n\t\t\t\t\t\t\t[action]=\"action\" [item]=\"item\" [itemId]=\"descriptor.model.idPropertyName ? item[descriptor.model.idPropertyName] : null\">\n\t\t\t\t</mng-action>\n\t\t\t</ng-template>\n\t\t</mng-table>\n\t</div>\n\n\t<router-outlet></router-outlet>\n</div>\n", components: [{ type: i7.Toast, selector: "p-toast", inputs: ["key", "autoZIndex", "baseZIndex", "style", "styleClass", "position", "preventOpenDuplicates", "preventDuplicates", "showTransformOptions", "hideTransformOptions", "showTransitionOptions", "hideTransitionOptions", "breakpoints"], outputs: ["onClose"] }, { type: i8.Toolbar, selector: "p-toolbar", inputs: ["style", "styleClass"] }, { type: i9.ActionComponent, selector: "mng-action", inputs: ["action", "item", "itemId", "actionData"] }, { type: i10.TableComponent, selector: "mng-table", inputs: ["descriptor", "items", "queryResult", "loading", "dataProvider", "selectionEnabled"], outputs: ["onLoad", "onCellClick", "onSelectionChange"] }], directives: [{ type: i2.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i11.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i12.TemplateDirective, selector: "[mngTemplate]", inputs: ["type", "mngTemplate"] }, { type: i13.InputText, selector: "[pInputText]" }, { type: i1.RouterOutlet, selector: "router-outlet", outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }], pipes: { "translate": i3.TranslatePipe } });
69
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: TableviewComponent, decorators: [{
70
+ type: Component,
71
+ args: [{ selector: 'mng-tableview', providers: [MessageService, ConfirmationService, TableviewComponentService], template: "<div class=\"mng-tableview\">\n\t<p-toast></p-toast>\n\n\t<div class=\"card\">\n\t\t<p-toolbar styleClass=\"mb-4\">\n\t\t\t<ng-template pTemplate=\"left\">\n\t\t\t\t<mng-action *ngFor=\"let action of toolbarLeftActions\"\n\t\t\t\t\t\t\t[action]=\"action\">\n\t\t\t\t</mng-action>\n\t\t\t</ng-template>\n\n\t\t\t<ng-template pTemplate=\"right\">\n\t\t\t\t<mng-action *ngFor=\"let action of toolbarRightActions\"\n\t\t\t\t\t\t\t[action]=\"action\">\n\t\t\t\t</mng-action>\n\t\t\t</ng-template>\n\t\t</p-toolbar>\n\n\t\t<mng-table [descriptor]=\"descriptor.table\"\n\t\t\t\t [dataProvider]=\"dataProvider\"\n\t\t\t\t (onCellClick)=\"onTableCellClick($event)\">\n\t\t\t<ng-template mngTemplate=\"caption\">\n\t\t\t\t<div class=\"flex flex-column md:flex-row md:justify-content-between table-header\">\n\t\t\t\t\t<h5 class=\"p-m-0\">{{ descriptor.tableTitle | translate }}</h5>\n\t\t\t\t\t<span class=\"p-input-icon-left\">\n\t\t\t\t\t\t<i class=\"pi pi-search\"></i>\n\t\t\t\t\t\t<input pInputText type=\"text\" [placeholder]=\"'mngTable.search' | translate\" />\n\t\t\t\t\t</span>\n\t\t\t\t</div>\n\t\t\t</ng-template>\n\t\t\t<ng-template mngTemplate=\"columnAction\" let-item=\"rowItem\">\n\t\t\t\t<mng-action *ngFor=\"let action of rowInlineActions\"\n\t\t\t\t\t\t\t[action]=\"action\" [item]=\"item\" [itemId]=\"descriptor.model.idPropertyName ? item[descriptor.model.idPropertyName] : null\">\n\t\t\t\t</mng-action>\n\t\t\t</ng-template>\n\t\t</mng-table>\n\t</div>\n\n\t<router-outlet></router-outlet>\n</div>\n" }]
72
+ }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.MessageService }, { type: i3.TranslateService }, { type: i4.DialogService }, { type: i2.ConfirmationService }, { type: i5.ActionService }, { type: i6.TableviewComponentService }]; }, propDecorators: { descriptor: [{
73
+ type: Input
74
+ }], dataProvider: [{
75
+ type: Input
76
+ }], actions: [{
77
+ type: Input
78
+ }], tableComponent: [{
79
+ type: ViewChild,
80
+ args: [TableComponent]
81
+ }] } });
82
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tableview.component.js","sourceRoot":"","sources":["../../../../../../projects/mng-commons/src/lib/components/tableview/tableview.component.ts","../../../../../../projects/mng-commons/src/lib/components/tableview/tableview.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,KAAK,EAAU,SAAS,EAAC,MAAM,eAAe,CAAC;AAIlE,OAAO,EAAC,mBAAmB,EAAE,cAAc,EAAC,MAAM,aAAa,CAAC;AAOhE,OAAO,EAAmB,kBAAkB,EAAC,MAAM,0BAA0B,CAAC;AAC9E,OAAO,EAAC,cAAc,EAAC,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAC,yBAAyB,EAAC,MAAM,+BAA+B,CAAC;;;;;;;;;;;;;;;AAOxE,MAAM,OAAO,kBAAkB;IAa3B,YACY,KAAqB,EACrB,cAA8B,EAC9B,gBAAkC,EAClC,aAA4B,EAC5B,mBAAwC,EACxC,aAA4B,EAC5B,gBAAiD;QANjD,UAAK,GAAL,KAAK,CAAgB;QACrB,mBAAc,GAAd,cAAc,CAAgB;QAC9B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,kBAAa,GAAb,aAAa,CAAe;QAC5B,wBAAmB,GAAnB,mBAAmB,CAAqB;QACxC,kBAAa,GAAb,aAAa,CAAe;QAC5B,qBAAgB,GAAhB,gBAAgB,CAAiC;QAhBpD,YAAO,GAA+B,EAAE,CAAC;QAEvB,mBAAc,GAA2B,IAAI,CAAC;QAElE,oBAAe,GAA0B,EAAE,CAAC;QAC5C,qBAAgB,GAA0B,EAAE,CAAC;QAC7C,uBAAkB,GAA0B,EAAE,CAAC;QAC/C,wBAAmB,GAA0B,EAAE,CAAC;IAWvD,CAAC;IAED,QAAQ;QAEJ,IAAI,CAAC,gBAAgB,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC7C,IAAI,CAAC,gBAAgB,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC;QACvD,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,OAAO,EAAE;YAC/B,QAAQ,MAAM,CAAC,QAAQ,EAAE;gBACrB,KAAK,kBAAkB,CAAC,QAAQ;oBAC5B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBAClC,MAAM;gBACV,KAAK,kBAAkB,CAAC,SAAS;oBAC7B,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBACnC,MAAM;gBACV,KAAK,kBAAkB,CAAC,WAAW;oBAC/B,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBACrC,MAAM;gBACV,KAAK,kBAAkB,CAAC,YAAY;oBAChC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBACtC,MAAM;aACb;SACJ;IACL,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,cAAc,EAAE,MAAM,EAAE,CAAC;IAClC,CAAC;IAEM,gBAAgB,CAAC,KAAgC;QACpD,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE;YAC7B,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,eAAe,EAAE;gBACvC,IAAI,CAAC,aAAa,CAAC,qBAAqB,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;aACvE;SACJ;IACL,CAAC;;+GAxDQ,kBAAkB;mGAAlB,kBAAkB,gIAFhB,CAAC,cAAc,EAAE,mBAAmB,EAAE,yBAAyB,CAAC,0EAQhE,cAAc,gDC1B7B,++CAwCA;2FDpBa,kBAAkB;kBAL9B,SAAS;+BACI,eAAe,aAEd,CAAC,cAAc,EAAE,mBAAmB,EAAE,yBAAyB,CAAC;mSAIlE,UAAU;sBAAlB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBAEqB,cAAc;sBAAxC,SAAS;uBAAC,cAAc","sourcesContent":["import {Component, Input, OnInit, ViewChild} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\n\nimport {TranslateService} from '@ngx-translate/core';\nimport {ConfirmationService, MessageService} from 'primeng/api';\nimport {DialogService} from 'primeng/dynamicdialog';\n\nimport {ActionService} from '../../services';\nimport {TableviewDescriptor} from '../../models/descriptors';\nimport {ITableviewDataProvider} from '../../models/providers';\nimport {MngTableCellClickEvent} from '../../models/events';\nimport {ActionDescriptor, ActionPositionEnum} from '../../models/descriptors';\nimport {TableComponent} from './table/table.component';\nimport {TableviewComponentService} from './tableview.component.service';\n\n@Component({\n    selector: 'mng-tableview',\n    templateUrl: './tableview.component.html',\n    providers: [MessageService, ConfirmationService, TableviewComponentService]\n})\nexport class TableviewComponent<T, S> implements OnInit {\n\n    @Input() descriptor!: TableviewDescriptor<T>;\n    @Input() dataProvider?: ITableviewDataProvider<T, S>;\n    @Input() actions: Array<ActionDescriptor<T>> = [];\n\n    @ViewChild(TableComponent) tableComponent: TableComponent<T>|null = null;\n\n    public rowClickActions: ActionDescriptor<T>[] = [];\n    public rowInlineActions: ActionDescriptor<T>[] = [];\n    public toolbarLeftActions: ActionDescriptor<T>[] = [];\n    public toolbarRightActions: ActionDescriptor<T>[] = [];\n\n    constructor(\n        private route: ActivatedRoute,\n        private messageService: MessageService,\n        private translateService: TranslateService,\n        private dialogService: DialogService,\n        private confirmationService: ConfirmationService,\n        private actionService: ActionService,\n        private tableviewService: TableviewComponentService<T, S>\n    ) {\n    }\n\n    ngOnInit() {\n\n        this.tableviewService.actions = this.actions;\n        this.tableviewService.dataProvider = this.dataProvider;\n        for (const action of this.actions) {\n            switch (action.position) {\n                case ActionPositionEnum.RowClick:\n                    this.rowClickActions.push(action);\n                    break;\n                case ActionPositionEnum.RowInline:\n                    this.rowInlineActions.push(action);\n                    break;\n                case ActionPositionEnum.ToolbarLeft:\n                    this.toolbarLeftActions.push(action);\n                    break;\n                case ActionPositionEnum.ToolbarRight:\n                    this.toolbarRightActions.push(action);\n                    break;\n            }\n        }\n    }\n\n    public reloadTable() {\n        this.tableComponent?.reload();\n    }\n\n    public onTableCellClick(event: MngTableCellClickEvent<T>) {\n        if (this.rowClickActions.length) {\n            for (const action of this.rowClickActions) {\n                this.actionService.triggerRowClickAction(action, event, this.route);\n            }\n        }\n    }\n}\n","<div class=\"mng-tableview\">\n\t<p-toast></p-toast>\n\n\t<div class=\"card\">\n\t\t<p-toolbar styleClass=\"mb-4\">\n\t\t\t<ng-template pTemplate=\"left\">\n\t\t\t\t<mng-action *ngFor=\"let action of toolbarLeftActions\"\n\t\t\t\t\t\t\t[action]=\"action\">\n\t\t\t\t</mng-action>\n\t\t\t</ng-template>\n\n\t\t\t<ng-template pTemplate=\"right\">\n\t\t\t\t<mng-action *ngFor=\"let action of toolbarRightActions\"\n\t\t\t\t\t\t\t[action]=\"action\">\n\t\t\t\t</mng-action>\n\t\t\t</ng-template>\n\t\t</p-toolbar>\n\n\t\t<mng-table [descriptor]=\"descriptor.table\"\n\t\t\t\t   [dataProvider]=\"dataProvider\"\n\t\t\t\t   (onCellClick)=\"onTableCellClick($event)\">\n\t\t\t<ng-template mngTemplate=\"caption\">\n\t\t\t\t<div class=\"flex flex-column md:flex-row md:justify-content-between table-header\">\n\t\t\t\t\t<h5 class=\"p-m-0\">{{ descriptor.tableTitle | translate }}</h5>\n\t\t\t\t\t<span class=\"p-input-icon-left\">\n\t\t\t\t\t\t<i class=\"pi pi-search\"></i>\n\t\t\t\t\t\t<input pInputText type=\"text\" [placeholder]=\"'mngTable.search' | translate\" />\n\t\t\t\t\t</span>\n\t\t\t\t</div>\n\t\t\t</ng-template>\n\t\t\t<ng-template mngTemplate=\"columnAction\" let-item=\"rowItem\">\n\t\t\t\t<mng-action *ngFor=\"let action of rowInlineActions\"\n\t\t\t\t\t\t\t[action]=\"action\" [item]=\"item\" [itemId]=\"descriptor.model.idPropertyName ? item[descriptor.model.idPropertyName] : null\">\n\t\t\t\t</mng-action>\n\t\t\t</ng-template>\n\t\t</mng-table>\n\t</div>\n\n\t<router-outlet></router-outlet>\n</div>\n"]}
@@ -0,0 +1,18 @@
1
+ import { Injectable } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ // TODO: check if legit solution
4
+ export class TableviewComponentService {
5
+ constructor() {
6
+ this.actions = [];
7
+ console.log('TableviewComponentService init.');
8
+ }
9
+ reloadTable() {
10
+ // TODO: add callback functions to implement
11
+ }
12
+ }
13
+ TableviewComponentService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: TableviewComponentService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
14
+ TableviewComponentService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: TableviewComponentService });
15
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: TableviewComponentService, decorators: [{
16
+ type: Injectable
17
+ }], ctorParameters: function () { return []; } });
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGV2aWV3LmNvbXBvbmVudC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbW5nLWNvbW1vbnMvc3JjL2xpYi9jb21wb25lbnRzL3RhYmxldmlldy90YWJsZXZpZXcuY29tcG9uZW50LnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLGVBQWUsQ0FBQzs7QUFLekMsZ0NBQWdDO0FBRWhDLE1BQU0sT0FBTyx5QkFBeUI7SUFLbEM7UUFGQSxZQUFPLEdBQStCLEVBQUUsQ0FBQztRQUdyQyxPQUFPLENBQUMsR0FBRyxDQUFDLGlDQUFpQyxDQUFDLENBQUM7SUFDbkQsQ0FBQztJQUVELFdBQVc7UUFDUCw0Q0FBNEM7SUFDaEQsQ0FBQzs7c0hBWFEseUJBQXlCOzBIQUF6Qix5QkFBeUI7MkZBQXpCLHlCQUF5QjtrQkFEckMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0YWJsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7SVRhYmxldmlld0RhdGFQcm92aWRlcn0gZnJvbSAnLi4vLi4vbW9kZWxzL3Byb3ZpZGVycyc7XG5pbXBvcnQge0FjdGlvbkRlc2NyaXB0b3J9IGZyb20gJy4uLy4uL21vZGVscy9kZXNjcmlwdG9ycyc7XG5cbi8vIFRPRE86IGNoZWNrIGlmIGxlZ2l0IHNvbHV0aW9uXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgVGFibGV2aWV3Q29tcG9uZW50U2VydmljZTxULCBTPiB7XG5cbiAgICBkYXRhUHJvdmlkZXI/OiBJVGFibGV2aWV3RGF0YVByb3ZpZGVyPFQsIFM+O1xuICAgIGFjdGlvbnM6IEFycmF5PEFjdGlvbkRlc2NyaXB0b3I8VD4+ID0gW107XG5cbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgY29uc29sZS5sb2coJ1RhYmxldmlld0NvbXBvbmVudFNlcnZpY2UgaW5pdC4nKTtcbiAgICB9XG5cbiAgICByZWxvYWRUYWJsZSgpIHtcbiAgICAgICAgLy8gVE9ETzogYWRkIGNhbGxiYWNrIGZ1bmN0aW9ucyB0byBpbXBsZW1lbnRcbiAgICB9XG59XG4iXX0=