@firestitch/list 13.0.4 → 13.0.5

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 (193) hide show
  1. package/app/classes/actions-controller.d.ts +20 -20
  2. package/app/classes/columns-controller.d.ts +71 -71
  3. package/app/classes/data-controller.d.ts +91 -91
  4. package/app/classes/external-params-controller.d.ts +32 -32
  5. package/app/classes/index.d.ts +2 -2
  6. package/app/classes/list-controller.d.ts +191 -191
  7. package/app/classes/pagination-controller.d.ts +198 -198
  8. package/app/classes/persistance-controller.d.ts +10 -10
  9. package/app/classes/reorder-controller.d.ts +68 -68
  10. package/app/classes/selection-controller.d.ts +155 -155
  11. package/app/classes/sorting-controller.d.ts +65 -65
  12. package/app/components/body/body.component.d.ts +28 -28
  13. package/app/components/body/row/actions/actions.component.d.ts +36 -36
  14. package/app/components/body/row/cell/cell.component.d.ts +22 -22
  15. package/app/components/body/row/inline-action/inline-action.component.d.ts +13 -13
  16. package/app/components/body/row/menu-action/menu-action.component.d.ts +20 -20
  17. package/app/components/body/row/row.component.d.ts +85 -85
  18. package/app/components/customize-cols/customize-cols.component.d.ts +17 -17
  19. package/app/components/footer/footer-row/footer-cell/footer-cell.component.d.ts +7 -7
  20. package/app/components/footer/footer-row/footer-row.component.d.ts +14 -14
  21. package/app/components/footer/footer.component.d.ts +15 -15
  22. package/app/components/head/head-cell/head-cell.component.d.ts +14 -14
  23. package/app/components/head/head.component.d.ts +49 -49
  24. package/app/components/list/list.component.d.ts +128 -128
  25. package/app/components/loader/loader.component.d.ts +14 -14
  26. package/app/components/manage-saved-filters/manage-saved-filters.component.d.ts +13 -13
  27. package/app/components/pagination/pagination.component.d.ts +14 -14
  28. package/app/components/saved-filters/saved-filters.component.d.ts +15 -15
  29. package/app/components/status/status.component.d.ts +21 -21
  30. package/app/directives/cell/cell.directive.d.ts +8 -8
  31. package/app/directives/column/column.directive.d.ts +37 -33
  32. package/app/directives/content/content.directive.d.ts +5 -5
  33. package/app/directives/content-init/content-init.directive.d.ts +9 -9
  34. package/app/directives/draggable-list/draggable-list.directive.d.ts +95 -95
  35. package/app/directives/draggable-row/draggable-row.directive.d.ts +23 -23
  36. package/app/directives/empty-state/empty-state.directive.d.ts +5 -5
  37. package/app/directives/footer/footer.directive.d.ts +8 -8
  38. package/app/directives/group-expand-trigger/group-expand-trigger.directive.d.ts +10 -10
  39. package/app/directives/group-footer/group-footer.directive.d.ts +6 -6
  40. package/app/directives/group-header/group-header.directive.d.ts +6 -6
  41. package/app/directives/header/header.directive.d.ts +8 -8
  42. package/app/directives/heading/heading.directive.d.ts +5 -5
  43. package/app/directives/heading-container/heading-container.directive.d.ts +5 -5
  44. package/app/directives/index.d.ts +3 -3
  45. package/app/directives/subheading/subheading.directive.d.ts +5 -5
  46. package/app/enums/button-type.enum.d.ts +7 -7
  47. package/app/enums/page-change-type.enum.d.ts +4 -4
  48. package/app/enums/pagination-strategy.enum.d.ts +5 -5
  49. package/app/enums/row-type.enum.d.ts +6 -6
  50. package/app/enums/state.enum.d.ts +9 -9
  51. package/app/fs-list.module.d.ts +60 -60
  52. package/app/fs-list.providers.d.ts +3 -3
  53. package/app/interfaces/cellconfig.interface.d.ts +5 -5
  54. package/app/interfaces/column-config.interface.d.ts +2 -2
  55. package/app/interfaces/draggable-list.interface.d.ts +7 -7
  56. package/app/interfaces/external-params.interface.d.ts +13 -13
  57. package/app/interfaces/index.d.ts +4 -4
  58. package/app/interfaces/listconfig.interface.d.ts +247 -247
  59. package/app/interfaces/pagination-state.interface.d.ts +9 -9
  60. package/app/interfaces/pagination.interface.d.ts +13 -13
  61. package/app/interfaces/sorting-change-event.interface.d.ts +4 -4
  62. package/app/models/column-async-attribute.d.ts +5 -5
  63. package/app/models/column-attributes.d.ts +39 -39
  64. package/app/models/column.model.d.ts +61 -60
  65. package/app/models/row/base-row.d.ts +13 -13
  66. package/app/models/row/child-row.d.ts +12 -12
  67. package/app/models/row/group-footer-row.d.ts +10 -10
  68. package/app/models/row/group-row.d.ts +16 -16
  69. package/app/models/row/simple-row.d.ts +5 -5
  70. package/app/models/row-action.model.d.ts +29 -29
  71. package/app/models/row.d.ts +34 -34
  72. package/app/models/styleConfig.model.d.ts +31 -31
  73. package/app/pipes/action-label.d.ts +8 -8
  74. package/app/pipes/index.d.ts +1 -1
  75. package/app/services/group-expand-notifier.service.d.ts +11 -11
  76. package/{esm2015/app/classes/actions-controller.js → esm2020/app/classes/actions-controller.mjs} +55 -55
  77. package/{esm2015/app/classes/columns-controller.js → esm2020/app/classes/columns-controller.mjs} +205 -205
  78. package/esm2020/app/classes/data-controller.mjs +367 -0
  79. package/esm2020/app/classes/external-params-controller.mjs +147 -0
  80. package/{esm2015/app/classes/index.js → esm2020/app/classes/index.mjs} +3 -3
  81. package/esm2020/app/classes/list-controller.mjs +752 -0
  82. package/{esm2015/app/classes/pagination-controller.js → esm2020/app/classes/pagination-controller.mjs} +478 -479
  83. package/{esm2015/app/classes/persistance-controller.js → esm2020/app/classes/persistance-controller.mjs} +19 -19
  84. package/esm2020/app/classes/reorder-controller.mjs +182 -0
  85. package/esm2020/app/classes/selection-controller.mjs +468 -0
  86. package/{esm2015/app/classes/sorting-controller.js → esm2020/app/classes/sorting-controller.mjs} +183 -183
  87. package/esm2020/app/components/body/body.component.mjs +64 -0
  88. package/esm2020/app/components/body/row/actions/actions.component.mjs +97 -0
  89. package/esm2020/app/components/body/row/cell/cell.component.mjs +107 -0
  90. package/esm2020/app/components/body/row/inline-action/inline-action.component.mjs +33 -0
  91. package/esm2020/app/components/body/row/menu-action/menu-action.component.mjs +46 -0
  92. package/esm2020/app/components/body/row/row.component.mjs +323 -0
  93. package/esm2020/app/components/customize-cols/customize-cols.component.mjs +68 -0
  94. package/esm2020/app/components/footer/footer-row/footer-cell/footer-cell.component.mjs +16 -0
  95. package/esm2020/app/components/footer/footer-row/footer-row.component.mjs +28 -0
  96. package/esm2020/app/components/footer/footer.component.mjs +31 -0
  97. package/esm2020/app/components/head/head-cell/head-cell.component.mjs +29 -0
  98. package/esm2020/app/components/head/head.component.mjs +103 -0
  99. package/esm2020/app/components/list/list.component.mjs +391 -0
  100. package/esm2020/app/components/loader/loader.component.mjs +40 -0
  101. package/esm2020/app/components/manage-saved-filters/manage-saved-filters.component.mjs +76 -0
  102. package/esm2020/app/components/pagination/pagination.component.mjs +37 -0
  103. package/esm2020/app/components/saved-filters/saved-filters.component.mjs +29 -0
  104. package/esm2020/app/components/status/status.component.mjs +66 -0
  105. package/{esm2015/app/directives/cell/cell.directive.js → esm2020/app/directives/cell/cell.directive.mjs} +18 -18
  106. package/esm2020/app/directives/column/column.directive.mjs +121 -0
  107. package/{esm2015/app/directives/content/content.directive.js → esm2020/app/directives/content/content.directive.mjs} +13 -13
  108. package/{esm2015/app/directives/content-init/content-init.directive.js → esm2020/app/directives/content-init/content-init.directive.mjs} +22 -22
  109. package/esm2020/app/directives/draggable-list/draggable-list.directive.mjs +328 -0
  110. package/esm2020/app/directives/draggable-row/draggable-row.directive.mjs +78 -0
  111. package/{esm2015/app/directives/empty-state/empty-state.directive.js → esm2020/app/directives/empty-state/empty-state.directive.mjs} +13 -13
  112. package/{esm2015/app/directives/footer/footer.directive.js → esm2020/app/directives/footer/footer.directive.mjs} +18 -18
  113. package/{esm2015/app/directives/group-expand-trigger/group-expand-trigger.directive.js → esm2020/app/directives/group-expand-trigger/group-expand-trigger.directive.mjs} +26 -26
  114. package/{esm2015/app/directives/group-footer/group-footer.directive.js → esm2020/app/directives/group-footer/group-footer.directive.mjs} +14 -14
  115. package/{esm2015/app/directives/group-header/group-header.directive.js → esm2020/app/directives/group-header/group-header.directive.mjs} +14 -14
  116. package/{esm2015/app/directives/header/header.directive.js → esm2020/app/directives/header/header.directive.mjs} +18 -18
  117. package/{esm2015/app/directives/heading/heading.directive.js → esm2020/app/directives/heading/heading.directive.mjs} +13 -13
  118. package/{esm2015/app/directives/heading-container/heading-container.directive.js → esm2020/app/directives/heading-container/heading-container.directive.mjs} +13 -13
  119. package/{esm2015/app/directives/index.js → esm2020/app/directives/index.mjs} +4 -4
  120. package/{esm2015/app/directives/subheading/subheading.directive.js → esm2020/app/directives/subheading/subheading.directive.mjs} +13 -13
  121. package/{esm2015/app/enums/button-type.enum.js → esm2020/app/enums/button-type.enum.mjs} +9 -9
  122. package/{esm2015/app/enums/page-change-type.enum.js → esm2020/app/enums/page-change-type.enum.mjs} +6 -6
  123. package/{esm2015/app/enums/pagination-strategy.enum.js → esm2020/app/enums/pagination-strategy.enum.mjs} +7 -7
  124. package/{esm2015/app/enums/row-type.enum.js → esm2020/app/enums/row-type.enum.mjs} +7 -7
  125. package/{esm2015/app/enums/state.enum.js → esm2020/app/enums/state.enum.mjs} +11 -11
  126. package/{esm2015/app/fs-list.module.js → esm2020/app/fs-list.module.mjs} +246 -246
  127. package/{esm2015/app/fs-list.providers.js → esm2020/app/fs-list.providers.mjs} +4 -4
  128. package/{esm2015/app/interfaces/cellconfig.interface.js → esm2020/app/interfaces/cellconfig.interface.mjs} +2 -2
  129. package/{esm2015/app/interfaces/column-config.interface.js → esm2020/app/interfaces/column-config.interface.mjs} +1 -1
  130. package/{esm2015/app/interfaces/draggable-list.interface.js → esm2020/app/interfaces/draggable-list.interface.mjs} +2 -2
  131. package/esm2020/app/interfaces/external-params.interface.mjs +2 -0
  132. package/{esm2015/app/interfaces/index.js → esm2020/app/interfaces/index.mjs} +5 -5
  133. package/{esm2015/app/interfaces/listconfig.interface.js → esm2020/app/interfaces/listconfig.interface.mjs} +1 -1
  134. package/{esm2015/app/interfaces/pagination-state.interface.js → esm2020/app/interfaces/pagination-state.interface.mjs} +1 -1
  135. package/esm2020/app/interfaces/pagination.interface.mjs +2 -0
  136. package/{esm2015/app/interfaces/sorting-change-event.interface.js → esm2020/app/interfaces/sorting-change-event.interface.mjs} +2 -2
  137. package/{esm2015/app/models/column-async-attribute.js → esm2020/app/models/column-async-attribute.mjs} +13 -13
  138. package/esm2020/app/models/column-attributes.mjs +132 -0
  139. package/esm2020/app/models/column.model.mjs +164 -0
  140. package/{esm2015/app/models/row/base-row.js → esm2020/app/models/row/base-row.mjs} +23 -23
  141. package/{esm2015/app/models/row/child-row.js → esm2020/app/models/row/child-row.mjs} +28 -28
  142. package/{esm2015/app/models/row/group-footer-row.js → esm2020/app/models/row/group-footer-row.mjs} +20 -20
  143. package/{esm2015/app/models/row/group-row.js → esm2020/app/models/row/group-row.mjs} +44 -44
  144. package/{esm2015/app/models/row/simple-row.js → esm2020/app/models/row/simple-row.mjs} +10 -10
  145. package/esm2020/app/models/row-action.model.mjs +90 -0
  146. package/{esm2015/app/models/row.js → esm2020/app/models/row.mjs} +88 -88
  147. package/{esm2015/app/models/styleConfig.model.js → esm2020/app/models/styleConfig.model.mjs} +75 -75
  148. package/{esm2015/app/pipes/action-label.js → esm2020/app/pipes/action-label.mjs} +17 -17
  149. package/{esm2015/app/pipes/index.js → esm2020/app/pipes/index.mjs} +1 -1
  150. package/{esm2015/app/services/group-expand-notifier.service.js → esm2020/app/services/group-expand-notifier.service.mjs} +26 -26
  151. package/{esm2015/firestitch-list.js → esm2020/firestitch-list.mjs} +4 -4
  152. package/{esm2015/public_api.js → esm2020/public_api.mjs} +45 -45
  153. package/fesm2015/{firestitch-list.js → firestitch-list.mjs} +5739 -5805
  154. package/fesm2015/firestitch-list.mjs.map +1 -0
  155. package/fesm2020/firestitch-list.mjs +5871 -0
  156. package/fesm2020/firestitch-list.mjs.map +1 -0
  157. package/firestitch-list.d.ts +5 -5
  158. package/package.json +20 -7
  159. package/public_api.d.ts +41 -41
  160. package/bundles/firestitch-list.umd.js +0 -7222
  161. package/bundles/firestitch-list.umd.js.map +0 -1
  162. package/esm2015/app/classes/data-controller.js +0 -365
  163. package/esm2015/app/classes/external-params-controller.js +0 -147
  164. package/esm2015/app/classes/list-controller.js +0 -754
  165. package/esm2015/app/classes/reorder-controller.js +0 -183
  166. package/esm2015/app/classes/selection-controller.js +0 -468
  167. package/esm2015/app/components/body/body.component.js +0 -69
  168. package/esm2015/app/components/body/row/actions/actions.component.js +0 -102
  169. package/esm2015/app/components/body/row/cell/cell.component.js +0 -113
  170. package/esm2015/app/components/body/row/inline-action/inline-action.component.js +0 -37
  171. package/esm2015/app/components/body/row/menu-action/menu-action.component.js +0 -50
  172. package/esm2015/app/components/body/row/row.component.js +0 -330
  173. package/esm2015/app/components/customize-cols/customize-cols.component.js +0 -72
  174. package/esm2015/app/components/footer/footer-row/footer-cell/footer-cell.component.js +0 -20
  175. package/esm2015/app/components/footer/footer-row/footer-row.component.js +0 -33
  176. package/esm2015/app/components/footer/footer.component.js +0 -36
  177. package/esm2015/app/components/head/head-cell/head-cell.component.js +0 -34
  178. package/esm2015/app/components/head/head.component.js +0 -108
  179. package/esm2015/app/components/list/list.component.js +0 -397
  180. package/esm2015/app/components/loader/loader.component.js +0 -45
  181. package/esm2015/app/components/manage-saved-filters/manage-saved-filters.component.js +0 -79
  182. package/esm2015/app/components/pagination/pagination.component.js +0 -42
  183. package/esm2015/app/components/saved-filters/saved-filters.component.js +0 -32
  184. package/esm2015/app/components/status/status.component.js +0 -72
  185. package/esm2015/app/directives/column/column.directive.js +0 -112
  186. package/esm2015/app/directives/draggable-list/draggable-list.directive.js +0 -330
  187. package/esm2015/app/directives/draggable-row/draggable-row.directive.js +0 -79
  188. package/esm2015/app/interfaces/external-params.interface.js +0 -2
  189. package/esm2015/app/interfaces/pagination.interface.js +0 -2
  190. package/esm2015/app/models/column-attributes.js +0 -131
  191. package/esm2015/app/models/column.model.js +0 -163
  192. package/esm2015/app/models/row-action.model.js +0 -90
  193. package/fesm2015/firestitch-list.js.map +0 -1
@@ -1,188 +1,188 @@
1
- import { BehaviorSubject, Subject } from 'rxjs';
2
- import { takeUntil } from 'rxjs/operators';
3
- import { ColumnAttributes } from '../models/column-attributes';
4
- import { Column, SortingDirection } from '../models/column.model';
5
- export class SortingController {
6
- constructor() {
7
- this.sortingColumns = [];
8
- this.fakeSortingColumns = [];
9
- this._initialized = new BehaviorSubject(false);
10
- this._sortingChanged$ = new Subject();
11
- this._onDestroy = new Subject();
12
- }
13
- get sortingChanged$() {
14
- return this._sortingChanged$.pipe(takeUntil(this._onDestroy));
15
- }
16
- get initialized$() {
17
- return this._initialized.pipe(takeUntil(this._onDestroy));
18
- }
19
- get value() {
20
- if (this.sortingColumn) {
21
- return {
22
- value: this.sortingColumn.name,
23
- direction: this.sortingColumn.direction,
24
- };
25
- }
26
- return undefined;
27
- }
28
- get initialization() {
29
- return !this._initialized.getValue();
30
- }
31
- get isDefined() {
32
- return !!this.sortingColumn;
33
- }
34
- set _initialization(value) {
35
- this._initialized.next(!value);
36
- }
37
- addSortableColumn(column) {
38
- this.sortingColumns.push(column);
39
- }
40
- clearSortableColumns() {
41
- this.sortingColumns = [];
42
- }
43
- /**
44
- * Set Sortable Direction
45
- *
46
- * @param direction
47
- */
48
- sortDirection(direction) {
49
- if (this.sortingColumn && this.sortingColumn.sortingDirection !== direction) {
50
- this._setSortingDirection(direction);
51
- this._notifySortChanged();
52
- }
53
- }
54
- /**
55
- * Sort By
56
- *
57
- * @param column
58
- */
59
- sortBy(column) {
60
- if (column.sortable) {
61
- this._setSortingColumn(column);
62
- this._notifySortChanged();
63
- }
64
- }
65
- /**
66
- * Same as sortBy, but need only column name as parameter for sort
67
- *
68
- * @param name
69
- */
70
- sortByColumnWithName(name) {
71
- const column = this.getColumn(name);
72
- if (!column) {
73
- return;
74
- }
75
- this._setSortingColumn(column);
76
- this._notifySortChanged();
77
- }
78
- /**
79
- * Init fake columns for sorting
80
- *
81
- * @param columns
82
- */
83
- initFakeColumns(columns) {
84
- columns.forEach((column) => {
85
- const attributes = new ColumnAttributes({
86
- title: column.name,
87
- name: column.value,
88
- sortable: true,
89
- direction: column.direction,
90
- });
91
- const fakeColumn = new Column({
92
- attributes,
93
- });
94
- this.fakeSortingColumns.push(fakeColumn);
95
- });
96
- }
97
- /**
98
- * Set initial sorting
99
- *
100
- * @param sort
101
- */
102
- initialSortBy(sort) {
103
- this._initialization = true;
104
- if (!sort) {
105
- this._trySortByDefaultSortableColumn();
106
- if (!this.sortingColumn) {
107
- this.sortByFirstSortbale();
108
- }
109
- this._initialization = false;
110
- return;
111
- }
112
- if (!this.getColumn(sort.value)) {
113
- this.sortByFirstSortbale();
1
+ import { BehaviorSubject, Subject } from 'rxjs';
2
+ import { takeUntil } from 'rxjs/operators';
3
+ import { ColumnAttributes } from '../models/column-attributes';
4
+ import { Column, SortingDirection } from '../models/column.model';
5
+ export class SortingController {
6
+ constructor() {
7
+ this.sortingColumns = [];
8
+ this.fakeSortingColumns = [];
9
+ this._initialized = new BehaviorSubject(false);
10
+ this._sortingChanged$ = new Subject();
11
+ this._onDestroy = new Subject();
12
+ }
13
+ get sortingChanged$() {
14
+ return this._sortingChanged$.pipe(takeUntil(this._onDestroy));
15
+ }
16
+ get initialized$() {
17
+ return this._initialized.pipe(takeUntil(this._onDestroy));
18
+ }
19
+ get value() {
20
+ if (this.sortingColumn) {
21
+ return {
22
+ value: this.sortingColumn.name,
23
+ direction: this.sortingColumn.direction,
24
+ };
25
+ }
26
+ return undefined;
27
+ }
28
+ get initialization() {
29
+ return !this._initialized.getValue();
30
+ }
31
+ get isDefined() {
32
+ return !!this.sortingColumn;
33
+ }
34
+ set _initialization(value) {
35
+ this._initialized.next(!value);
36
+ }
37
+ addSortableColumn(column) {
38
+ this.sortingColumns.push(column);
39
+ }
40
+ clearSortableColumns() {
41
+ this.sortingColumns = [];
42
+ }
43
+ /**
44
+ * Set Sortable Direction
45
+ *
46
+ * @param direction
47
+ */
48
+ sortDirection(direction) {
49
+ if (this.sortingColumn && this.sortingColumn.sortingDirection !== direction) {
50
+ this._setSortingDirection(direction);
51
+ this._notifySortChanged();
52
+ }
53
+ }
54
+ /**
55
+ * Sort By
56
+ *
57
+ * @param column
58
+ */
59
+ sortBy(column) {
60
+ if (column.sortable) {
61
+ this._setSortingColumn(column);
62
+ this._notifySortChanged();
63
+ }
64
+ }
65
+ /**
66
+ * Same as sortBy, but need only column name as parameter for sort
67
+ *
68
+ * @param name
69
+ */
70
+ sortByColumnWithName(name) {
71
+ const column = this.getColumn(name);
72
+ if (!column) {
73
+ return;
74
+ }
75
+ this._setSortingColumn(column);
76
+ this._notifySortChanged();
77
+ }
78
+ /**
79
+ * Init fake columns for sorting
80
+ *
81
+ * @param columns
82
+ */
83
+ initFakeColumns(columns) {
84
+ columns.forEach((column) => {
85
+ const attributes = new ColumnAttributes({
86
+ title: column.name,
87
+ name: column.value,
88
+ sortable: true,
89
+ direction: column.direction,
90
+ });
91
+ const fakeColumn = new Column({
92
+ attributes,
93
+ });
94
+ this.fakeSortingColumns.push(fakeColumn);
95
+ });
96
+ }
97
+ /**
98
+ * Set initial sorting
99
+ *
100
+ * @param sort
101
+ */
102
+ initialSortBy(sort) {
103
+ this._initialization = true;
104
+ if (!sort) {
105
+ this._trySortByDefaultSortableColumn();
106
+ if (!this.sortingColumn) {
107
+ this.sortByFirstSortbale();
108
+ }
109
+ this._initialization = false;
110
+ return;
111
+ }
112
+ if (!this.getColumn(sort.value)) {
113
+ this.sortByFirstSortbale();
114
114
  console.warn(`
115
115
  Not possible to do initial sort by "${sort.value}" column.
116
116
  Column with name "${sort.value}" does not exists.
117
117
  Check your lister configuration.
118
- `);
119
- }
120
- else {
121
- this.sortByColumnWithName(sort.value);
122
- const direction = (sort.direction === undefined || sort.direction === 'asc')
123
- ? SortingDirection.asc
124
- : SortingDirection.desc;
125
- this._setSortingDirection(direction);
126
- }
127
- this._initialization = false;
128
- }
129
- /**
130
- * Sort by first of available sorting columns
131
- */
132
- sortByFirstSortbale() {
133
- const column = this.sortingColumns.find((col) => col.sortable);
134
- if (!column) {
135
- return;
136
- }
137
- this.sortBy(column);
138
- this.sortDirection(column.direction || SortingDirection.asc);
139
- }
140
- getColumn(name) {
141
- return [...this.sortingColumns, ...this.fakeSortingColumns]
142
- .find((col) => col.name === name && col.sortable);
143
- }
144
- /**
145
- * Destroy
146
- */
147
- destroy() {
148
- this._onDestroy.next();
149
- this._onDestroy.complete();
150
- }
151
- _setSortingColumn(column) {
152
- // Can't do sort by non sortable column
153
- if (!column.sortable) {
154
- return false;
155
- }
156
- // Column was ordered before
157
- if (column.ordered) {
158
- column.changeDirection();
159
- }
160
- else {
161
- [...this.fakeSortingColumns, ...this.sortingColumns]
162
- .filter((col) => col.ordered)
163
- .forEach((col) => col.ordered = false);
164
- column.ordered = true;
165
- }
166
- this.sortingColumn = column;
167
- }
168
- _setSortingDirection(direction) {
169
- this.sortingColumn.sortingDirection = direction;
170
- }
171
- _notifySortChanged() {
172
- if (this.initialization) {
173
- return;
174
- }
175
- this._sortingChanged$.next({
176
- sortBy: this.sortingColumn.name,
177
- sortDirection: this.sortingColumn.direction,
178
- });
179
- }
180
- _trySortByDefaultSortableColumn() {
181
- const sortableDefault = this.sortingColumns
182
- .find((column) => column.sortableDefault);
183
- if (sortableDefault) {
184
- this.sortByColumnWithName(sortableDefault.name);
185
- }
186
- }
187
- }
118
+ `);
119
+ }
120
+ else {
121
+ this.sortByColumnWithName(sort.value);
122
+ const direction = (sort.direction === undefined || sort.direction === 'asc')
123
+ ? SortingDirection.asc
124
+ : SortingDirection.desc;
125
+ this._setSortingDirection(direction);
126
+ }
127
+ this._initialization = false;
128
+ }
129
+ /**
130
+ * Sort by first of available sorting columns
131
+ */
132
+ sortByFirstSortbale() {
133
+ const column = this.sortingColumns.find((col) => col.sortable);
134
+ if (!column) {
135
+ return;
136
+ }
137
+ this.sortBy(column);
138
+ this.sortDirection(column.direction || SortingDirection.asc);
139
+ }
140
+ getColumn(name) {
141
+ return [...this.sortingColumns, ...this.fakeSortingColumns]
142
+ .find((col) => col.name === name && col.sortable);
143
+ }
144
+ /**
145
+ * Destroy
146
+ */
147
+ destroy() {
148
+ this._onDestroy.next();
149
+ this._onDestroy.complete();
150
+ }
151
+ _setSortingColumn(column) {
152
+ // Can't do sort by non sortable column
153
+ if (!column.sortable) {
154
+ return false;
155
+ }
156
+ // Column was ordered before
157
+ if (column.ordered) {
158
+ column.changeDirection();
159
+ }
160
+ else {
161
+ [...this.fakeSortingColumns, ...this.sortingColumns]
162
+ .filter((col) => col.ordered)
163
+ .forEach((col) => col.ordered = false);
164
+ column.ordered = true;
165
+ }
166
+ this.sortingColumn = column;
167
+ }
168
+ _setSortingDirection(direction) {
169
+ this.sortingColumn.sortingDirection = direction;
170
+ }
171
+ _notifySortChanged() {
172
+ if (this.initialization) {
173
+ return;
174
+ }
175
+ this._sortingChanged$.next({
176
+ sortBy: this.sortingColumn.name,
177
+ sortDirection: this.sortingColumn.direction,
178
+ });
179
+ }
180
+ _trySortByDefaultSortableColumn() {
181
+ const sortableDefault = this.sortingColumns
182
+ .find((column) => column.sortableDefault);
183
+ if (sortableDefault) {
184
+ this.sortByColumnWithName(sortableDefault.name);
185
+ }
186
+ }
187
+ }
188
188
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29ydGluZy1jb250cm9sbGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FwcC9jbGFzc2VzL3NvcnRpbmctY29udHJvbGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFjLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUM1RCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFHM0MsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDL0QsT0FBTyxFQUFFLE1BQU0sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBS2xFLE1BQU0sT0FBTyxpQkFBaUI7SUFXNUI7UUFSTyxtQkFBYyxHQUFhLEVBQUUsQ0FBQztRQUM5Qix1QkFBa0IsR0FBYSxFQUFFLENBQUM7UUFHakMsaUJBQVksR0FBRyxJQUFJLGVBQWUsQ0FBVSxLQUFLLENBQUMsQ0FBQztRQUNuRCxxQkFBZ0IsR0FBRyxJQUFJLE9BQU8sRUFBc0IsQ0FBQztRQUNyRCxlQUFVLEdBQUcsSUFBSSxPQUFPLEVBQUUsQ0FBQztJQUVwQixDQUFDO0lBRWhCLElBQVcsZUFBZTtRQUN4QixPQUFPLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO0lBQ2hFLENBQUM7SUFFRCxJQUFXLFlBQVk7UUFDckIsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7SUFDNUQsQ0FBQztJQUVELElBQVcsS0FBSztRQUNkLElBQUksSUFBSSxDQUFDLGFBQWEsRUFBRTtZQUN0QixPQUFPO2dCQUNMLEtBQUssRUFBRSxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUk7Z0JBQzlCLFNBQVMsRUFBRSxJQUFJLENBQUMsYUFB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QU0sQ0FBQyxlQUFlLENBQUMsQ0FBQztRQUU1QyxJQUFJLGVBQWUsRUFBRTtZQUNuQixJQUFJLENBQUMsb0JBQW9CLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQ2pEO0lBQ0gsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBPYnNlcnZhYmxlLCBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyB0YWtlVW50aWwgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmltcG9ydCB7IEZzTGlzdFNvcnRDb25maWcsIFNvcnRpbmdDaGFuZ2VFdmVudCB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgQ29sdW1uQXR0cmlidXRlcyB9IGZyb20gJy4uL21vZGVscy9jb2x1bW4tYXR0cmlidXRlcyc7XG5pbXBvcnQgeyBDb2x1bW4sIFNvcnRpbmdEaXJlY3Rpb24gfSBmcm9tICcuLi9tb2RlbHMvY29sdW1uLm1vZGVsJztcblxuaW1wb3J0IHsgTGlzdCB9IGZyb20gJy4vbGlzdC1jb250cm9sbGVyJztcblxuXG5leHBvcnQgY2xhc3MgU29ydGluZ0NvbnRyb2xsZXIge1xuICBwdWJsaWMgY29uZmlnOiBMaXN0O1xuXG4gIHB1YmxpYyBzb3J0aW5nQ29sdW1uczogQ29sdW1uW10gPSBbXTtcbiAgcHVibGljIGZha2VTb3J0aW5nQ29sdW1uczogQ29sdW1uW10gPSBbXTtcbiAgcHVibGljIHNvcnRpbmdDb2x1bW46IENvbHVtbjtcblxuICBwcml2YXRlIF9pbml0aWFsaXplZCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4oZmFsc2UpO1xuICBwcml2YXRlIF9zb3J0aW5nQ2hhbmdlZCQgPSBuZXcgU3ViamVjdDxTb3J0aW5nQ2hhbmdlRXZlbnQ+KCk7XG4gIHByaXZhdGUgX29uRGVzdHJveSA9IG5ldyBTdWJqZWN0KCk7XG5cbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIHB1YmxpYyBnZXQgc29ydGluZ0NoYW5nZWQkKCk6IE9ic2VydmFibGU8U29ydGluZ0NoYW5nZUV2ZW50PiB7XG4gICAgcmV0dXJuIHRoaXMuX3NvcnRpbmdDaGFuZ2VkJC5waXBlKHRha2VVbnRpbCh0aGlzLl9vbkRlc3Ryb3kpKTtcbiAgfVxuXG4gIHB1YmxpYyBnZXQgaW5pdGlhbGl6ZWQkKCk6IE9ic2VydmFibGU8Ym9vbGVhbj4ge1xuICAgIHJldHVybiB0aGlzLl9pbml0aWFsaXplZC5waXBlKHRha2VVbnRpbCh0aGlzLl9vbkRlc3Ryb3kpKTtcbiAgfVxuXG4gIHB1YmxpYyBnZXQgdmFsdWUoKTogRnNMaXN0U29ydENvbmZpZyB8IHVuZGVmaW5lZCB7XG4gICAgaWYgKHRoaXMuc29ydGluZ0NvbHVtbikge1xuICAgICAgcmV0dXJuIHtcbiAgICAgICAgdmFsdWU6IHRoaXMuc29ydGluZ0NvbHVtbi5uYW1lLFxuICAgICAgICBkaXJlY3Rpb246IHRoaXMuc29ydGluZ0NvbHVtbi5kaXJlY3Rpb24sXG4gICAgICB9O1xuICAgIH1cblxuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBwdWJsaWMgZ2V0IGluaXRpYWxpemF0aW9uKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiAhdGhpcy5faW5pdGlhbGl6ZWQuZ2V0VmFsdWUoKTtcbiAgfVxuXG4gIHB1YmxpYyBnZXQgaXNEZWZpbmVkKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiAhIXRoaXMuc29ydGluZ0NvbHVtbjtcbiAgfVxuXG4gIHByaXZhdGUgc2V0IF9pbml0aWFsaXphdGlvbih2YWx1ZTogYm9vbGVhbikge1xuICAgIHRoaXMuX2luaXRpYWxpemVkLm5leHQoIXZhbHVlKTtcbiAgfVxuXG4gIHB1YmxpYyBhZGRTb3J0YWJsZUNvbHVtbihjb2x1bW46IENvbHVtbikge1xuICAgIHRoaXMuc29ydGluZ0NvbHVtbnMucHVzaChjb2x1bW4pO1xuICB9XG5cbiAgcHVibGljIGNsZWFyU29ydGFibGVDb2x1bW5zKCk6IHZvaWQge1xuICAgIHRoaXMuc29ydGluZ0NvbHVtbnMgPSBbXTtcbiAgfVxuXG4gIC8qKlxuICAgKiBTZXQgU29ydGFibGUgRGlyZWN0aW9uXG4gICAqXG4gICAqIEBwYXJhbSBkaXJlY3Rpb25cbiAgICovXG4gIHB1YmxpYyBzb3J0RGlyZWN0aW9uKGRpcmVjdGlvbikge1xuICAgIGlmICh0aGlzLnNvcnRpbmdDb2x1bW4gJiYgdGhpcy5zb3J0aW5nQ29sdW1uLnNvcnRpbmdEaXJlY3Rpb24gIT09IGRpcmVjdGlvbikge1xuICAgICAgdGhpcy5fc2V0U29ydGluZ0RpcmVjdGlvbihkaXJlY3Rpb24pO1xuXG4gICAgICB0aGlzLl9ub3RpZnlTb3J0Q2hhbmdlZCgpO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBTb3J0IEJ5XG4gICAqXG4gICAqIEBwYXJhbSBjb2x1bW5cbiAgICovXG4gIHB1YmxpYyBzb3J0QnkoY29sdW1uOiBDb2x1bW4pIHtcbiAgICBpZiAoY29sdW1uLnNvcnRhYmxlKSB7XG4gICAgICB0aGlzLl9zZXRTb3J0aW5nQ29sdW1uKGNvbHVtbik7XG5cbiAgICAgIHRoaXMuX25vdGlmeVNvcnRDaGFuZ2VkKCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFNhbWUgYXMgc29ydEJ5LCBidXQgbmVlZCBvbmx5IGNvbHVtbiBuYW1lIGFzIHBhcmFtZXRlciBmb3Igc29ydFxuICAgKlxuICAgKiBAcGFyYW0gbmFtZVxuICAgKi9cbiAgcHVibGljIHNvcnRCeUNvbHVtbldpdGhOYW1lKG5hbWU6IHN0cmluZykge1xuICAgIGNvbnN0IGNvbHVtbiA9IHRoaXMuZ2V0Q29sdW1uKG5hbWUpO1xuXG4gICAgaWYgKCFjb2x1bW4pIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICB0aGlzLl9zZXRTb3J0aW5nQ29sdW1uKGNvbHVtbik7XG5cbiAgICB0aGlzLl9ub3RpZnlTb3J0Q2hhbmdlZCgpO1xuICB9XG5cbiAgLyoqXG4gICAqIEluaXQgZmFrZSBjb2x1bW5zIGZvciBzb3J0aW5nXG4gICAqXG4gICAqIEBwYXJhbSBjb2x1bW5zXG4gICAqL1xuICBwdWJsaWMgaW5pdEZha2VDb2x1bW5zKGNvbHVtbnMpIHtcbiAgICBjb2x1bW5zLmZvckVhY2goKGNvbHVtbikgPT4ge1xuICAgICAgY29uc3QgYXR0cmlidXRlcyA9IG5ldyBDb2x1bW5BdHRyaWJ1dGVzKHtcbiAgICAgICAgdGl0bGU6IGNvbHVtbi5uYW1lLFxuICAgICAgICBuYW1lOiBjb2x1bW4udmFsdWUsXG4gICAgICAgIHNvcnRhYmxlOiB0cnVlLFxuICAgICAgICBkaXJlY3Rpb246IGNvbHVtbi5kaXJlY3Rpb24sXG4gICAgICB9KTtcblxuICAgICAgY29uc3QgZmFrZUNvbHVtbiA9IG5ldyBDb2x1bW4oe1xuICAgICAgICBhdHRyaWJ1dGVzLFxuICAgICAgfSk7XG5cbiAgICAgIHRoaXMuZmFrZVNvcnRpbmdDb2x1bW5zLnB1c2goZmFrZUNvbHVtbik7XG4gICAgfSk7XG4gIH1cblxuICAvKipcbiAgICogU2V0IGluaXRpYWwgc29ydGluZ1xuICAgKlxuICAgKiBAcGFyYW0gc29ydFxuICAgKi9cbiAgcHVibGljIGluaXRpYWxTb3J0Qnkoc29ydDogRnNMaXN0U29ydENvbmZpZykge1xuICAgIHRoaXMuX2luaXRpYWxpemF0aW9uID0gdHJ1ZTtcblxuICAgIGlmICghc29ydCkge1xuICAgICAgdGhpcy5fdHJ5U29ydEJ5RGVmYXVsdFNvcnRhYmxlQ29sdW1uKCk7XG5cbiAgICAgIGlmICghdGhpcy5zb3J0aW5nQ29sdW1uKSB7XG4gICAgICAgIHRoaXMuc29ydEJ5Rmlyc3RTb3J0YmFsZSgpO1xuICAgICAgfVxuXG4gICAgICB0aGlzLl9pbml0aWFsaXphdGlvbiA9IGZhbHNlO1xuXG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgaWYgKCF0aGlzLmdldENvbHVtbihzb3J0LnZhbHVlKSkge1xuICAgICAgdGhpcy5zb3J0QnlGaXJzdFNvcnRiYWxlKCk7XG5cbiAgICAgIGNvbnNvbGUud2FybihgXG4gICAgICAgIE5vdCBwb3NzaWJsZSB0byBkbyBpbml0aWFsIHNvcnQgYnkgXCIke3NvcnQudmFsdWV9XCIgY29sdW1uLlxuICAgICAgICBDb2x1bW4gd2l0aCBuYW1lIFwiJHtzb3J0LnZhbHVlfVwiIGRvZXMgbm90IGV4aXN0cy5cbiAgICAgICAgQ2hlY2sgeW91ciBsaXN0ZXIgY29uZmlndXJhdGlvbi5cbiAgICAgIGApO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLnNvcnRCeUNvbHVtbldpdGhOYW1lKHNvcnQudmFsdWUpO1xuXG4gICAgICBjb25zdCBkaXJlY3Rpb24gPSAoc29ydC5kaXJlY3Rpb24gPT09IHVuZGVmaW5lZCB8fCBzb3J0LmRpcmVjdGlvbiA9PT0gJ2FzYycpXG4gICAgICAgID8gU29ydGluZ0RpcmVjdGlvbi5hc2NcbiAgICAgICAgOiBTb3J0aW5nRGlyZWN0aW9uLmRlc2M7XG4gICAgICB0aGlzLl9zZXRTb3J0aW5nRGlyZWN0aW9uKGRpcmVjdGlvbik7XG4gICAgfVxuXG4gICAgdGhpcy5faW5pdGlhbGl6YXRpb24gPSBmYWxzZTtcbiAgfVxuXG4gIC8qKlxuICAgKiBTb3J0IGJ5IGZpcnN0IG9mIGF2YWlsYWJsZSBzb3J0aW5nIGNvbHVtbnNcbiAgICovXG4gIHB1YmxpYyBzb3J0QnlGaXJzdFNvcnRiYWxlKCkge1xuICAgIGNvbnN0IGNvbHVtbiA9XG4gICAgICB0aGlzLnNvcnRpbmdDb2x1bW5zLmZpbmQoKGNvbCkgPT4gY29sLnNvcnRhYmxlKTtcblxuICAgIGlmICghY29sdW1uKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgdGhpcy5zb3J0QnkoY29sdW1uKTtcbiAgICB0aGlzLnNvcnREaXJlY3Rpb24oY29sdW1uLmRpcmVjdGlvbiB8fCBTb3J0aW5nRGlyZWN0aW9uLmFzYyk7XG4gIH1cblxuICBwdWJsaWMgZ2V0Q29sdW1uKG5hbWU6IHN0cmluZyk6IENvbHVtbiB7XG4gICAgcmV0dXJuIFsuLi50aGlzLnNvcnRpbmdDb2x1bW5zLCAuLi50aGlzLmZha2VTb3J0aW5nQ29sdW1uc11cbiAgICAgIC5maW5kKChjb2wpID0+IGNvbC5uYW1lID09PSBuYW1lICYmIGNvbC5zb3J0YWJsZSk7XG4gIH1cblxuICAvKipcbiAgICogRGVzdHJveVxuICAgKi9cbiAgcHVibGljIGRlc3Ryb3koKSB7XG4gICAgdGhpcy5fb25EZXN0cm95Lm5leHQoKTtcbiAgICB0aGlzLl9vbkRlc3Ryb3kuY29tcGxldGUoKTtcbiAgfVxuXG4gIHByaXZhdGUgX3NldFNvcnRpbmdDb2x1bW4oY29sdW1uOiBDb2x1bW4pIHtcbiAgICAvLyBDYW4ndCBkbyBzb3J0IGJ5IG5vbiBzb3J0YWJsZSBjb2x1bW5cbiAgICBpZiAoIWNvbHVtbi5zb3J0YWJsZSkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cblxuICAgIC8vIENvbHVtbiB3YXMgb3JkZXJlZCBiZWZvcmVcbiAgICBpZiAoY29sdW1uLm9yZGVyZWQpIHtcbiAgICAgIGNvbHVtbi5jaGFuZ2VEaXJlY3Rpb24oKTtcbiAgICB9IGVsc2Uge1xuICAgICAgWy4uLnRoaXMuZmFrZVNvcnRpbmdDb2x1bW5zLCAuLi50aGlzLnNvcnRpbmdDb2x1bW5zXVxuICAgICAgICAuZmlsdGVyKChjb2wpID0+IGNvbC5vcmRlcmVkKVxuICAgICAgICAuZm9yRWFjaCgoY29sKSA9PiBjb2wub3JkZXJlZCA9IGZhbHNlKTtcblxuICAgICAgY29sdW1uLm9yZGVyZWQgPSB0cnVlO1xuICAgIH1cblxuICAgIHRoaXMuc29ydGluZ0NvbHVtbiA9IGNvbHVtbjtcbiAgfVxuXG4gIHByaXZhdGUgX3NldFNvcnRpbmdEaXJlY3Rpb24oZGlyZWN0aW9uKSB7XG4gICAgdGhpcy5zb3J0aW5nQ29sdW1uLnNvcnRpbmdEaXJlY3Rpb24gPSBkaXJlY3Rpb247XG4gIH1cblxuICBwcml2YXRlIF9ub3RpZnlTb3J0Q2hhbmdlZCgpIHtcbiAgICBpZiAodGhpcy5pbml0aWFsaXphdGlvbikge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIHRoaXMuX3NvcnRpbmdDaGFuZ2VkJC5uZXh0KHtcbiAgICAgIHNvcnRCeTogdGhpcy5zb3J0aW5nQ29sdW1uLm5hbWUsXG4gICAgICBzb3J0RGlyZWN0aW9uOiB0aGlzLnNvcnRpbmdDb2x1bW4uZGlyZWN0aW9uLFxuICAgIH0pO1xuICB9XG5cbiAgcHJpdmF0ZSBfdHJ5U29ydEJ5RGVmYXVsdFNvcnRhYmxlQ29sdW1uKCk6IHZvaWQge1xuICAgIGNvbnN0IHNvcnRhYmxlRGVmYXVsdCA9IHRoaXMuc29ydGluZ0NvbHVtbnNcbiAgICAgIC5maW5kKChjb2x1bW4pID0+IGNvbHVtbi5zb3J0YWJsZURlZmF1bHQpO1xuXG4gICAgaWYgKHNvcnRhYmxlRGVmYXVsdCkge1xuICAgICAgdGhpcy5zb3J0QnlDb2x1bW5XaXRoTmFtZShzb3J0YWJsZURlZmF1bHQubmFtZSk7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -0,0 +1,64 @@
1
+ import { ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Input, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';
2
+ import { ReorderPosition, ReorderStrategy } from '../../classes/reorder-controller';
3
+ import { SelectionController } from '../../classes/selection-controller';
4
+ import { FsRowComponent } from './row/row.component';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "./row/row.component";
7
+ import * as i2 from "@angular/common";
8
+ import * as i3 from "../../directives/draggable-row/draggable-row.directive";
9
+ export class FsBodyComponent {
10
+ constructor() {
11
+ this.columns = [];
12
+ this.hasFooter = false;
13
+ this.rowActionsRaw = [];
14
+ this.groupActionsRaw = [];
15
+ this.rowEvents = {};
16
+ this.hasRowActions = false;
17
+ this.restoreMode = false;
18
+ }
19
+ }
20
+ FsBodyComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: FsBodyComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
21
+ FsBodyComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: FsBodyComponent, selector: "[fs-list-body]", inputs: { rows: "rows", columns: "columns", hasFooter: "hasFooter", rowActionsRaw: "rowActionsRaw", groupActionsRaw: "groupActionsRaw", rowEvents: "rowEvents", rowClass: "rowClass", hasRowActions: "hasRowActions", selection: "selection", restoreMode: "restoreMode", rowRemoved: "rowRemoved", activeFiltersCount: "activeFiltersCount", reorderEnabled: "reorderEnabled", reorderPosition: "reorderPosition", reorderStrategy: "reorderStrategy", reorderMultiple: "reorderMultiple" }, queries: [{ propertyName: "headerTemplate", first: true, predicate: FsRowComponent, descendants: true, read: TemplateRef, static: true }], viewQueries: [{ propertyName: "rowsContainer", first: true, predicate: ["rowsContainer"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<ng-container *ngFor=\"let row of rows; let i = index;\">\n <tr\n fs-list-row\n fsListDraggableRow\n [row]=\"row\"\n [rowIndex]=\"i\"\n [columns]=\"columns\"\n [rowActionsRaw]=\"rowActionsRaw\"\n [groupActionsRaw]=\"groupActionsRaw\"\n [hasRowActions]=\"hasRowActions\"\n [rowEvents]=\"rowEvents\"\n [rowClass]=\"rowClass\"\n [selection]=\"selection\"\n [restoreMode]=\"restoreMode\"\n [rowRemoved]=\"rowRemoved\"\n [activeFiltersCount]=\"activeFiltersCount\"\n [reorderEnabled]=\"reorderEnabled\"\n [reorderPosition]=\"reorderPosition\"\n [reorderStrategy]=\"reorderStrategy\"\n [reorderMultiple]=\"reorderMultiple\">\n </tr>\n</ng-container>\n", styles: [":host.drag-hidden .drag-col{opacity:0!important;cursor:default}:host.disabled{opacity:.4;pointer-events:none}\n"], components: [{ type: i1.FsRowComponent, selector: "[fs-list-row]", inputs: ["row", "rowActionsRaw", "groupActionsRaw", "hasRowActions", "rowEvents", "rowClass", "restoreMode", "rowIndex", "columns", "selection", "rowRemoved", "activeFiltersCount", "reorderEnabled", "reorderPosition", "reorderStrategy", "reorderMultiple"] }], directives: [{ type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.FsListDraggableRowDirective, selector: "[fsListDraggableRow]", inputs: ["row"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
22
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: FsBodyComponent, decorators: [{
23
+ type: Component,
24
+ args: [{ selector: '[fs-list-body]', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngFor=\"let row of rows; let i = index;\">\n <tr\n fs-list-row\n fsListDraggableRow\n [row]=\"row\"\n [rowIndex]=\"i\"\n [columns]=\"columns\"\n [rowActionsRaw]=\"rowActionsRaw\"\n [groupActionsRaw]=\"groupActionsRaw\"\n [hasRowActions]=\"hasRowActions\"\n [rowEvents]=\"rowEvents\"\n [rowClass]=\"rowClass\"\n [selection]=\"selection\"\n [restoreMode]=\"restoreMode\"\n [rowRemoved]=\"rowRemoved\"\n [activeFiltersCount]=\"activeFiltersCount\"\n [reorderEnabled]=\"reorderEnabled\"\n [reorderPosition]=\"reorderPosition\"\n [reorderStrategy]=\"reorderStrategy\"\n [reorderMultiple]=\"reorderMultiple\">\n </tr>\n</ng-container>\n", styles: [":host.drag-hidden .drag-col{opacity:0!important;cursor:default}:host.disabled{opacity:.4;pointer-events:none}\n"] }]
25
+ }], propDecorators: { rows: [{
26
+ type: Input
27
+ }], columns: [{
28
+ type: Input
29
+ }], hasFooter: [{
30
+ type: Input
31
+ }], rowActionsRaw: [{
32
+ type: Input
33
+ }], groupActionsRaw: [{
34
+ type: Input
35
+ }], rowEvents: [{
36
+ type: Input
37
+ }], rowClass: [{
38
+ type: Input
39
+ }], hasRowActions: [{
40
+ type: Input
41
+ }], selection: [{
42
+ type: Input
43
+ }], restoreMode: [{
44
+ type: Input
45
+ }], rowRemoved: [{
46
+ type: Input
47
+ }], activeFiltersCount: [{
48
+ type: Input
49
+ }], reorderEnabled: [{
50
+ type: Input
51
+ }], reorderPosition: [{
52
+ type: Input
53
+ }], reorderStrategy: [{
54
+ type: Input
55
+ }], reorderMultiple: [{
56
+ type: Input
57
+ }], rowsContainer: [{
58
+ type: ViewChild,
59
+ args: ['rowsContainer', { read: ViewContainerRef, static: true }]
60
+ }], headerTemplate: [{
61
+ type: ContentChild,
62
+ args: [FsRowComponent, { read: TemplateRef, static: true }]
63
+ }] } });
64
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9keS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvYXBwL2NvbXBvbmVudHMvYm9keS9ib2R5LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9ib2R5L2JvZHkuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLFlBQVksRUFDWixLQUFLLEVBQ0wsV0FBVyxFQUNYLFNBQVMsRUFDVCxnQkFBZ0IsRUFDakIsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFFLGVBQWUsRUFBRSxlQUFlLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNwRixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUl6RSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0scUJBQXFCLENBQUM7Ozs7O0FBU3JELE1BQU0sT0FBTyxlQUFlO0lBTjVCO1FBU2tCLFlBQU8sR0FBYSxFQUFFLENBQUM7UUFDdkIsY0FBUyxHQUFHLEtBQUssQ0FBQztRQUNsQixrQkFBYSxHQUFVLEVBQUUsQ0FBQztRQUMxQixvQkFBZSxHQUFVLEVBQUUsQ0FBQztRQUM1QixjQUFTLEdBQUcsRUFBRSxDQUFDO1FBRWYsa0JBQWEsR0FBRyxLQUFLLENBQUM7UUFFdEIsZ0JBQVcsR0FBRyxLQUFLLENBQUM7S0FjckM7OzRHQXpCWSxlQUFlO2dHQUFmLGVBQWUsZ2tCQXNCWixjQUFjLDJCQUFVLFdBQVcsc0lBSGIsZ0JBQWdCLDJDQzVDdEQsK3JCQXNCQTsyRkRHYSxlQUFlO2tCQU4zQixTQUFTOytCQUNFLGdCQUFnQixtQkFHVCx1QkFBdUIsQ0FBQyxNQUFNOzhCQUkvQixJQUFJO3NCQUFuQixLQUFLO2dCQUNVLE9BQU87c0JBQXRCLEtBQUs7Z0JBQ1UsU0FBUztzQkFBeEIsS0FBSztnQkFDVSxhQUFhO3NCQUE1QixLQUFLO2dCQUNVLGVBQWU7c0JBQTlCLEtBQUs7Z0JBQ1UsU0FBUztzQkFBeEIsS0FBSztnQkFDVSxRQUFRO3NCQUF2QixLQUFLO2dCQUNVLGFBQWE7c0JBQTVCLEtBQUs7Z0JBQ1UsU0FBUztzQkFBeEIsS0FBSztnQkFDVSxXQUFXO3NCQUExQixLQUFLO2dCQUNVLFVBQVU7c0JBQXpCLEtBQUs7Z0JBQ1Usa0JBQWtCO3NCQUFqQyxLQUFLO2dCQUNVLGNBQWM7c0JBQTdCLEtBQUs7Z0JBQ1UsZUFBZTtzQkFBOUIsS0FBSztnQkFDVSxlQUFlO3NCQUE5QixLQUFLO2dCQUNVLGVBQWU7c0JBQTlCLEtBQUs7Z0JBR0MsYUFBYTtzQkFEbkIsU0FBUzt1QkFBQyxlQUFlLEVBQUUsRUFBRSxJQUFJLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRTtnQkFJN0QsY0FBYztzQkFEcEIsWUFBWTt1QkFBQyxjQUFjLEVBQUUsRUFBRSxJQUFJLEVBQUUsV0FBVyxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBDb250ZW50Q2hpbGQsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIFRlbXBsYXRlUmVmLFxuICBWaWV3Q2hpbGQsXG4gIFZpZXdDb250YWluZXJSZWZcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFJlb3JkZXJQb3NpdGlvbiwgUmVvcmRlclN0cmF0ZWd5IH0gZnJvbSAnLi4vLi4vY2xhc3Nlcy9yZW9yZGVyLWNvbnRyb2xsZXInO1xuaW1wb3J0IHsgU2VsZWN0aW9uQ29udHJvbGxlciB9IGZyb20gJy4uLy4uL2NsYXNzZXMvc2VsZWN0aW9uLWNvbnRyb2xsZXInO1xuaW1wb3J0IHsgQ29sdW1uIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2NvbHVtbi5tb2RlbCc7XG5pbXBvcnQgeyBSb3cgfSBmcm9tICcuLi8uLi9tb2RlbHMvcm93JztcblxuaW1wb3J0IHsgRnNSb3dDb21wb25lbnQgfSBmcm9tICcuL3Jvdy9yb3cuY29tcG9uZW50JztcblxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdbZnMtbGlzdC1ib2R5XScsXG4gIHRlbXBsYXRlVXJsOiAnLi9ib2R5LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vYm9keS5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgRnNCb2R5Q29tcG9uZW50IHtcblxuICBASW5wdXQoKSBwdWJsaWMgcm93czogUm93W107XG4gIEBJbnB1dCgpIHB1YmxpYyBjb2x1bW5zOiBDb2x1bW5bXSA9IFtdO1xuICBASW5wdXQoKSBwdWJsaWMgaGFzRm9vdGVyID0gZmFsc2U7XG4gIEBJbnB1dCgpIHB1YmxpYyByb3dBY3Rpb25zUmF3OiBhbnlbXSA9IFtdO1xuICBASW5wdXQoKSBwdWJsaWMgZ3JvdXBBY3Rpb25zUmF3OiBhbnlbXSA9IFtdO1xuICBASW5wdXQoKSBwdWJsaWMgcm93RXZlbnRzID0ge307XG4gIEBJbnB1dCgpIHB1YmxpYyByb3dDbGFzcztcbiAgQElucHV0KCkgcHVibGljIGhhc1Jvd0FjdGlvbnMgPSBmYWxzZTtcbiAgQElucHV0KCkgcHVibGljIHNlbGVjdGlvbjogU2VsZWN0aW9uQ29udHJvbGxlcjtcbiAgQElucHV0KCkgcHVibGljIHJlc3RvcmVNb2RlID0gZmFsc2U7XG4gIEBJbnB1dCgpIHB1YmxpYyByb3dSZW1vdmVkOiBFdmVudEVtaXR0ZXI8YW55PjtcbiAgQElucHV0KCkgcHVibGljIGFjdGl2ZUZpbHRlcnNDb3VudDogbnVtYmVyO1xuICBASW5wdXQoKSBwdWJsaWMgcmVvcmRlckVuYWJsZWQ6IGJvb2xlYW47XG4gIEBJbnB1dCgpIHB1YmxpYyByZW9yZGVyUG9zaXRpb246IFJlb3JkZXJQb3NpdGlvbiB8IG51bGw7XG4gIEBJbnB1dCgpIHB1YmxpYyByZW9yZGVyU3RyYXRlZ3k6IFJlb3JkZXJTdHJhdGVneSB8IG51bGw7XG4gIEBJbnB1dCgpIHB1YmxpYyByZW9yZGVyTXVsdGlwbGU6IGJvb2xlYW47XG5cbiAgQFZpZXdDaGlsZCgncm93c0NvbnRhaW5lcicsIHsgcmVhZDogVmlld0NvbnRhaW5lclJlZiwgc3RhdGljOiB0cnVlIH0pXG4gIHB1YmxpYyByb3dzQ29udGFpbmVyO1xuXG4gIEBDb250ZW50Q2hpbGQoRnNSb3dDb21wb25lbnQsIHsgcmVhZDogVGVtcGxhdGVSZWYsIHN0YXRpYzogdHJ1ZSB9KVxuICBwdWJsaWMgaGVhZGVyVGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT47XG5cbn1cbiIsIjxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IHJvdyBvZiByb3dzOyBsZXQgaSA9IGluZGV4O1wiPlxuICA8dHJcbiAgICBmcy1saXN0LXJvd1xuICAgIGZzTGlzdERyYWdnYWJsZVJvd1xuICAgIFtyb3ddPVwicm93XCJcbiAgICBbcm93SW5kZXhdPVwiaVwiXG4gICAgW2NvbHVtbnNdPVwiY29sdW1uc1wiXG4gICAgW3Jvd0FjdGlvbnNSYXddPVwicm93QWN0aW9uc1Jhd1wiXG4gICAgW2dyb3VwQWN0aW9uc1Jhd109XCJncm91cEFjdGlvbnNSYXdcIlxuICAgIFtoYXNSb3dBY3Rpb25zXT1cImhhc1Jvd0FjdGlvbnNcIlxuICAgIFtyb3dFdmVudHNdPVwicm93RXZlbnRzXCJcbiAgICBbcm93Q2xhc3NdPVwicm93Q2xhc3NcIlxuICAgIFtzZWxlY3Rpb25dPVwic2VsZWN0aW9uXCJcbiAgICBbcmVzdG9yZU1vZGVdPVwicmVzdG9yZU1vZGVcIlxuICAgIFtyb3dSZW1vdmVkXT1cInJvd1JlbW92ZWRcIlxuICAgIFthY3RpdmVGaWx0ZXJzQ291bnRdPVwiYWN0aXZlRmlsdGVyc0NvdW50XCJcbiAgICBbcmVvcmRlckVuYWJsZWRdPVwicmVvcmRlckVuYWJsZWRcIlxuICAgIFtyZW9yZGVyUG9zaXRpb25dPVwicmVvcmRlclBvc2l0aW9uXCJcbiAgICBbcmVvcmRlclN0cmF0ZWd5XT1cInJlb3JkZXJTdHJhdGVneVwiXG4gICAgW3Jlb3JkZXJNdWx0aXBsZV09XCJyZW9yZGVyTXVsdGlwbGVcIj5cbiAgPC90cj5cbjwvbmctY29udGFpbmVyPlxuIl19
@@ -0,0 +1,97 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, } from '@angular/core';
2
+ import { FsPrompt } from '@firestitch/prompt';
3
+ import { Observable, Subject } from 'rxjs';
4
+ import { take, takeUntil } from 'rxjs/operators';
5
+ import { Row } from '../../../../models/row';
6
+ import { RowAction } from '../../../../models/row-action.model';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@firestitch/prompt";
9
+ import * as i2 from "../inline-action/inline-action.component";
10
+ import * as i3 from "@firestitch/menu";
11
+ import * as i4 from "../menu-action/menu-action.component";
12
+ import * as i5 from "@angular/material/icon";
13
+ import * as i6 from "@angular/common";
14
+ import * as i7 from "../../../../pipes/action-label";
15
+ export class FsRowActionsComponent {
16
+ constructor(_prompt) {
17
+ this._prompt = _prompt;
18
+ this.restoreMode = false;
19
+ this.rowActions = [];
20
+ this.menuRowActions = [];
21
+ this.inlineRowActions = [];
22
+ this._destroy$ = new Subject();
23
+ }
24
+ actionClick(action, row, event, menuRef) {
25
+ if (action.remove) {
26
+ if (typeof action.remove === 'boolean') {
27
+ this._removeAction(action, row.data, event, this.index);
28
+ }
29
+ else {
30
+ this._prompt.confirm({
31
+ title: action.remove.title,
32
+ template: action.remove.template,
33
+ autofocus: true,
34
+ })
35
+ .pipe(take(1), takeUntil(this._destroy$))
36
+ .subscribe(() => {
37
+ this._removeAction(action, row.data, event, this.index);
38
+ });
39
+ }
40
+ }
41
+ else {
42
+ action.click(row.data, event, this.index, menuRef);
43
+ }
44
+ }
45
+ /**
46
+ * Track By for improve change detection
47
+ *
48
+ * @param index
49
+ */
50
+ trackByFn(index) {
51
+ return index;
52
+ }
53
+ /**
54
+ * Emit that some row must be removed
55
+ *
56
+ * @param action
57
+ * @param row
58
+ * @param event
59
+ * @param index
60
+ */
61
+ _removeAction(action, row, event, index) {
62
+ const removeObservable = action.click(row, event, index);
63
+ if (removeObservable && removeObservable instanceof Observable) {
64
+ removeObservable
65
+ .pipe(take(1), takeUntil(this._destroy$))
66
+ .subscribe(() => {
67
+ this.rowRemoved.emit(row);
68
+ });
69
+ }
70
+ else {
71
+ this.rowRemoved.emit(row);
72
+ }
73
+ }
74
+ }
75
+ FsRowActionsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: FsRowActionsComponent, deps: [{ token: i1.FsPrompt }], target: i0.ɵɵFactoryTarget.Component });
76
+ FsRowActionsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: FsRowActionsComponent, selector: "fs-list-row-actions", inputs: { row: "row", index: "index", restoreMode: "restoreMode", rowActions: "rowActions", rowRemoved: "rowRemoved", menuRowActions: "menuRowActions", inlineRowActions: "inlineRowActions", restoreAction: "restoreAction" }, ngImport: i0, template: "<ng-container *ngIf=\"!restoreMode || (restoreMode && !restoreAction)\">\n <ng-container *ngFor=\"let action of inlineRowActions; trackBy: trackByFn\">\n <fs-list-row-inline-action \n class=\"row-inline-action row-inline-action-{{action.type}}\"\n [action]=\"action\"\n [ngClass]=\"{'mobile-hide': action.menu === undefined}\"\n (clicked)=\"actionClick(action, row, $event)\"\n (fileSelect)=\"action.fileConfig.select($event, row, index)\">\n </fs-list-row-inline-action>\n </ng-container>\n</ng-container>\n\n<!-- Menu -->\n<fs-menu \n class=\"row-menu-action\"\n *ngIf=\"menuRowActions.length || (restoreMode && restoreAction)\"\n #menuRef>\n <!-- Case when we have usual menu actions -->\n <ng-container *ngIf=\"!restoreMode || (restoreMode && !restoreAction)\">\n <ng-container *ngFor=\"let action of inlineRowActions; trackBy: trackByFn\">\n <ng-template \n class=\"hidden-mobile-menu-action\"\n fs-menu-item\n [link]=\"action.routerLink?.link\"\n [queryParams]=\"action.routerLink?.queryParams\"\n [target]=\"action.routerLink?.target\"\n [hidden]=\"action.menu !== undefined && !action.isShown\">\n <fs-list-row-menu-action\n [icon]=\"action.icon\"\n [label]=\"action.label\"\n [row]=\"row\"\n [file]=\"action.fileConfig\"\n (fileSelect)=\"action.fileConfig.select($event, row, index)\"\n (fileError)=\"action.fileConfig.error && action.fileConfig.error($event)\">\n </fs-list-row-menu-action>\n </ng-template>\n </ng-container>\n\n <ng-container *ngFor=\"let action of menuRowActions; trackBy: trackByFn\">\n <ng-container *ngIf=\"action.isGroup else simpleMenuItem\">\n <fs-menu-group [label]=\"action.label | actionLabel:row\">\n <ng-container *ngFor=\"let subAction of action.rowActions\">\n <ng-template \n fs-menu-item\n [link]=\"subAction.routerLink?.link\"\n [queryParams]=\"subAction.routerLink?.queryParams\"\n [target]=\"subAction.routerLink?.target\"\n [hidden]=\"!subAction.isShown\"\n (click)=\"actionClick(subAction, row, $event, menuRef);\">\n <fs-list-row-menu-action\n [icon]=\"subAction.icon\"\n [label]=\"subAction.label\"\n [row]=\"row\"\n [file]=\"subAction.fileConfig\"\n (fileSelect)=\"subAction.fileConfig.select($event, row, index)\"\n (fileError)=\"subAction.fileConfig.error && subAction.fileConfig.error($event)\">\n </fs-list-row-menu-action>\n </ng-template>\n </ng-container>\n </fs-menu-group>\n </ng-container>\n <ng-template #simpleMenuItem>\n <ng-template \n fs-menu-item\n [link]=\"action.routerLink?.link\"\n [queryParams]=\"action.routerLink?.queryParams\"\n [target]=\"action.routerLink?.target\"\n [hidden]=\"!action.isShown\"\n (click)=\"actionClick(action, row, $event, menuRef);\">\n <fs-list-row-menu-action\n [icon]=\"action.icon\"\n [label]=\"action.label\"\n [row]=\"row\"\n [file]=\"action.fileConfig\"\n (fileSelect)=\"action.fileConfig.select($event, row, index)\"\n (fileError)=\"action.fileConfig.error && action.fileConfig.error($event)\">\n </fs-list-row-menu-action>\n </ng-template>\n </ng-template>\n </ng-container>\n </ng-container>\n\n <!-- Case when we have restore mode enabled and must hide menu actions -->\n <ng-container *ngIf=\"restoreMode && restoreAction\">\n <ng-template fs-menu-item (click)=\"actionClick(restoreAction, row, $event, menuRef)\">\n <mat-icon *ngIf=\"restoreAction.icon\">{{restoreAction.icon}}</mat-icon>\n {{restoreAction.label | actionLabel:row}}\n </ng-template>\n </ng-container>\n</fs-menu>\n", styles: [":host ::ng-deep fs-list-row-inline-action{margin-left:5px}:host ::ng-deep fs-list-row-inline-action:first-child{margin-left:0}::ng-deep .hidden-mobile-menu-action{display:none!important}\n"], components: [{ type: i2.FsRowInlineActionComponent, selector: "fs-list-row-inline-action", inputs: ["action"], outputs: ["clicked", "fileSelect"] }, { type: i3.FsMenuComponent, selector: "fs-menu", inputs: ["class", "buttonClass", "buttonType", "buttonColor"], outputs: ["opened", "closed"] }, { type: i4.FsRowMenuActionComponent, selector: "fs-list-row-menu-action", inputs: ["row", "icon", "label", "file"], outputs: ["fileSelect", "fileError"] }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.FsMenuItemDirective, selector: "fs-menu-group,[fs-menu-item]" }], pipes: { "actionLabel": i7.ActionLabelPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
77
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: FsRowActionsComponent, decorators: [{
78
+ type: Component,
79
+ args: [{ selector: 'fs-list-row-actions', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"!restoreMode || (restoreMode && !restoreAction)\">\n <ng-container *ngFor=\"let action of inlineRowActions; trackBy: trackByFn\">\n <fs-list-row-inline-action \n class=\"row-inline-action row-inline-action-{{action.type}}\"\n [action]=\"action\"\n [ngClass]=\"{'mobile-hide': action.menu === undefined}\"\n (clicked)=\"actionClick(action, row, $event)\"\n (fileSelect)=\"action.fileConfig.select($event, row, index)\">\n </fs-list-row-inline-action>\n </ng-container>\n</ng-container>\n\n<!-- Menu -->\n<fs-menu \n class=\"row-menu-action\"\n *ngIf=\"menuRowActions.length || (restoreMode && restoreAction)\"\n #menuRef>\n <!-- Case when we have usual menu actions -->\n <ng-container *ngIf=\"!restoreMode || (restoreMode && !restoreAction)\">\n <ng-container *ngFor=\"let action of inlineRowActions; trackBy: trackByFn\">\n <ng-template \n class=\"hidden-mobile-menu-action\"\n fs-menu-item\n [link]=\"action.routerLink?.link\"\n [queryParams]=\"action.routerLink?.queryParams\"\n [target]=\"action.routerLink?.target\"\n [hidden]=\"action.menu !== undefined && !action.isShown\">\n <fs-list-row-menu-action\n [icon]=\"action.icon\"\n [label]=\"action.label\"\n [row]=\"row\"\n [file]=\"action.fileConfig\"\n (fileSelect)=\"action.fileConfig.select($event, row, index)\"\n (fileError)=\"action.fileConfig.error && action.fileConfig.error($event)\">\n </fs-list-row-menu-action>\n </ng-template>\n </ng-container>\n\n <ng-container *ngFor=\"let action of menuRowActions; trackBy: trackByFn\">\n <ng-container *ngIf=\"action.isGroup else simpleMenuItem\">\n <fs-menu-group [label]=\"action.label | actionLabel:row\">\n <ng-container *ngFor=\"let subAction of action.rowActions\">\n <ng-template \n fs-menu-item\n [link]=\"subAction.routerLink?.link\"\n [queryParams]=\"subAction.routerLink?.queryParams\"\n [target]=\"subAction.routerLink?.target\"\n [hidden]=\"!subAction.isShown\"\n (click)=\"actionClick(subAction, row, $event, menuRef);\">\n <fs-list-row-menu-action\n [icon]=\"subAction.icon\"\n [label]=\"subAction.label\"\n [row]=\"row\"\n [file]=\"subAction.fileConfig\"\n (fileSelect)=\"subAction.fileConfig.select($event, row, index)\"\n (fileError)=\"subAction.fileConfig.error && subAction.fileConfig.error($event)\">\n </fs-list-row-menu-action>\n </ng-template>\n </ng-container>\n </fs-menu-group>\n </ng-container>\n <ng-template #simpleMenuItem>\n <ng-template \n fs-menu-item\n [link]=\"action.routerLink?.link\"\n [queryParams]=\"action.routerLink?.queryParams\"\n [target]=\"action.routerLink?.target\"\n [hidden]=\"!action.isShown\"\n (click)=\"actionClick(action, row, $event, menuRef);\">\n <fs-list-row-menu-action\n [icon]=\"action.icon\"\n [label]=\"action.label\"\n [row]=\"row\"\n [file]=\"action.fileConfig\"\n (fileSelect)=\"action.fileConfig.select($event, row, index)\"\n (fileError)=\"action.fileConfig.error && action.fileConfig.error($event)\">\n </fs-list-row-menu-action>\n </ng-template>\n </ng-template>\n </ng-container>\n </ng-container>\n\n <!-- Case when we have restore mode enabled and must hide menu actions -->\n <ng-container *ngIf=\"restoreMode && restoreAction\">\n <ng-template fs-menu-item (click)=\"actionClick(restoreAction, row, $event, menuRef)\">\n <mat-icon *ngIf=\"restoreAction.icon\">{{restoreAction.icon}}</mat-icon>\n {{restoreAction.label | actionLabel:row}}\n </ng-template>\n </ng-container>\n</fs-menu>\n", styles: [":host ::ng-deep fs-list-row-inline-action{margin-left:5px}:host ::ng-deep fs-list-row-inline-action:first-child{margin-left:0}::ng-deep .hidden-mobile-menu-action{display:none!important}\n"] }]
80
+ }], ctorParameters: function () { return [{ type: i1.FsPrompt }]; }, propDecorators: { row: [{
81
+ type: Input
82
+ }], index: [{
83
+ type: Input
84
+ }], restoreMode: [{
85
+ type: Input
86
+ }], rowActions: [{
87
+ type: Input
88
+ }], rowRemoved: [{
89
+ type: Input
90
+ }], menuRowActions: [{
91
+ type: Input
92
+ }], inlineRowActions: [{
93
+ type: Input
94
+ }], restoreAction: [{
95
+ type: Input
96
+ }] } });
97
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9ucy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBwL2NvbXBvbmVudHMvYm9keS9yb3cvYWN0aW9ucy9hY3Rpb25zLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9ib2R5L3Jvdy9hY3Rpb25zL2FjdGlvbnMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLEtBQUssR0FDTixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFOUMsT0FBTyxFQUFFLFVBQVUsRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDM0MsT0FBTyxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUdqRCxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLHFDQUFxQyxDQUFDOzs7Ozs7Ozs7QUFTaEUsTUFBTSxPQUFPLHFCQUFxQjtJQTRCaEMsWUFDVSxPQUFpQjtRQUFqQixZQUFPLEdBQVAsT0FBTyxDQUFVO1FBcEJwQixnQkFBVyxHQUFHLEtBQUssQ0FBQztRQUdwQixlQUFVLEdBQWdCLEVBQUUsQ0FBQztRQU03QixtQkFBYyxHQUFnQixFQUFFLENBQUM7UUFHakMscUJBQWdCLEdBQWdCLEVBQUUsQ0FBQztRQUtsQyxjQUFTLEdBQUcsSUFBSSxPQUFPLEVBQUUsQ0FBQztJQUk5QixDQUFDO0lBRUUsV0FBVyxDQUFDLE1BQWlCLEVBQUUsR0FBUSxFQUFFLEtBQVUsRUFBRSxPQUFRO1FBQ2xFLElBQUksTUFBTSxDQUFDLE1BQU0sRUFBRTtZQUNqQixJQUFJLE9BQU8sTUFBTSxDQUFDLE1BQU0sS0FBSyxTQUFTLEVBQUU7Z0JBQ3RDLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxFQUFFLEdBQUcsQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQzthQUN6RDtpQkFBTTtnQkFDTCxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQztvQkFDbkIsS0FBSyxFQUFFLE1BQU0sQ0FBQyxNQUFNLENBQUMsS0FBSztvQkFDMUIsUUFBUSxFQUFFLE1BQU0sQ0FBQyxNQUFNLENBQUMsUUFBUTtvQkFDaEMsU0FBUyxFQUFFLElBQUk7aUJBQ2hCLENBQUM7cUJBQ0MsSUFBSSxDQUNILElBQUksQ0FBQyxDQUFDLENBQUMsRUFDUCxTQUFTLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUMxQjtxQkFDQSxTQUFTLENBQUMsR0FBRyxFQUFFO29CQUNkLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxFQUFFLEdBQUcsQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztnQkFDMUQsQ0FBQyxDQUFDLENBQUM7YUFDTjtTQUNGO2FBQU07WUFDTCxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLElBQUksQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7U0FDcEQ7SUFDSCxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNJLFNBQVMsQ0FBQyxLQUFLO1FBQ3BCLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUVEOzs7Ozs7O09BT0c7SUFDSyxhQUFhLENBQUMsTUFBTSxFQUFFLEdBQUcsRUFBRSxLQUFLLEVBQUUsS0FBSztRQUM3QyxNQUFNLGdCQUFnQixHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsR0FBRyxFQUFFLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQztRQUV6RCxJQUFJLGdCQUFnQixJQUFJLGdCQUFnQixZQUFZLFVBQVUsRUFBRTtZQUM5RCxnQkFBZ0I7aUJBQ2IsSUFBSSxDQUNILElBQUksQ0FBQyxDQUFDLENBQUMsRUFDUCxTQUFTLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUMxQjtpQkFDQSxTQUFTLENBQUMsR0FBRyxFQUFFO2dCQUNkLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQzVCLENBQUMsQ0FBQyxDQUFDO1NBQ047YUFBTTtZQUNMLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1NBQzNCO0lBQ0gsQ0FBQzs7a0hBdkZVLHFCQUFxQjtzR0FBckIscUJBQXFCLDJSQ3ZCbEMsODhIQTBGQTsyRkRuRWEscUJBQXFCO2tCQU5qQyxTQUFTOytCQUNFLHFCQUFxQixtQkFHZCx1QkFBdUIsQ0FBQyxNQUFNOytGQUt4QyxHQUFHO3NCQURULEtBQUs7Z0JBSUMsS0FBSztzQkFEWCxLQUFLO2dCQUlDLFdBQVc7c0JBRGpCLEtBQUs7Z0JBSUMsVUFBVTtzQkFEaEIsS0FBSztnQkFJQyxVQUFVO3NCQURoQixLQUFLO2dCQUlDLGNBQWM7c0JBRHBCLEtBQUs7Z0JBSUMsZ0JBQWdCO3NCQUR0QixLQUFLO2dCQUlDLGFBQWE7c0JBRG5CLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBFdmVudEVtaXR0ZXIsXG4gIElucHV0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRnNQcm9tcHQgfSBmcm9tICdAZmlyZXN0aXRjaC9wcm9tcHQnO1xuXG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyB0YWtlLCB0YWtlVW50aWwgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cblxuaW1wb3J0IHsgUm93IH0gZnJvbSAnLi4vLi4vLi4vLi4vbW9kZWxzL3Jvdyc7XG5pbXBvcnQgeyBSb3dBY3Rpb24gfSBmcm9tICcuLi8uLi8uLi8uLi9tb2RlbHMvcm93LWFjdGlvbi5tb2RlbCc7XG5cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZnMtbGlzdC1yb3ctYWN0aW9ucycsXG4gIHRlbXBsYXRlVXJsOiAnLi9hY3Rpb25zLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vYWN0aW9ucy5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgRnNSb3dBY3Rpb25zQ29tcG9uZW50IHtcblxuICBASW5wdXQoKVxuICBwdWJsaWMgcm93OiBSb3c7XG5cbiAgQElucHV0KClcbiAgcHVibGljIGluZGV4OiBudW1iZXI7XG5cbiAgQElucHV0KClcbiAgcHVibGljIHJlc3RvcmVNb2RlID0gZmFsc2U7XG5cbiAgQElucHV0KClcbiAgcHVibGljIHJvd0FjdGlvbnM6IFJvd0FjdGlvbltdID0gW107XG5cbiAgQElucHV0KClcbiAgcHVibGljIHJvd1JlbW92ZWQ6IEV2ZW50RW1pdHRlcjxhbnk+O1xuXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBtZW51Um93QWN0aW9uczogUm93QWN0aW9uW10gPSBbXTtcblxuICBASW5wdXQoKVxuICBwdWJsaWMgaW5saW5lUm93QWN0aW9uczogUm93QWN0aW9uW10gPSBbXTtcblxuICBASW5wdXQoKVxuICBwdWJsaWMgcmVzdG9yZUFjdGlvbjogUm93QWN0aW9uO1xuXG4gIHByaXZhdGUgX2Rlc3Ryb3kkID0gbmV3IFN1YmplY3QoKTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIF9wcm9tcHQ6IEZzUHJvbXB0LFxuICApIHsgfVxuXG4gIHB1YmxpYyBhY3Rpb25DbGljayhhY3Rpb246IFJvd0FjdGlvbiwgcm93OiBhbnksIGV2ZW50OiBhbnksIG1lbnVSZWY/KSB7XG4gICAgaWYgKGFjdGlvbi5yZW1vdmUpIHtcbiAgICAgIGlmICh0eXBlb2YgYWN0aW9uLnJlbW92ZSA9PT0gJ2Jvb2xlYW4nKSB7XG4gICAgICAgIHRoaXMuX3JlbW92ZUFjdGlvbihhY3Rpb24sIHJvdy5kYXRhLCBldmVudCwgdGhpcy5pbmRleCk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICB0aGlzLl9wcm9tcHQuY29uZmlybSh7XG4gICAgICAgICAgdGl0bGU6IGFjdGlvbi5yZW1vdmUudGl0bGUsXG4gICAgICAgICAgdGVtcGxhdGU6IGFjdGlvbi5yZW1vdmUudGVtcGxhdGUsXG4gICAgICAgICAgYXV0b2ZvY3VzOiB0cnVlLFxuICAgICAgICB9KVxuICAgICAgICAgIC5waXBlKFxuICAgICAgICAgICAgdGFrZSgxKSxcbiAgICAgICAgICAgIHRha2VVbnRpbCh0aGlzLl9kZXN0cm95JCksXG4gICAgICAgICAgKVxuICAgICAgICAgIC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICAgICAgdGhpcy5fcmVtb3ZlQWN0aW9uKGFjdGlvbiwgcm93LmRhdGEsIGV2ZW50LCB0aGlzLmluZGV4KTtcbiAgICAgICAgICB9KTtcbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgYWN0aW9uLmNsaWNrKHJvdy5kYXRhLCBldmVudCwgdGhpcy5pbmRleCwgbWVudVJlZik7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFRyYWNrIEJ5IGZvciBpbXByb3ZlIGNoYW5nZSBkZXRlY3Rpb25cbiAgICpcbiAgICogQHBhcmFtIGluZGV4XG4gICAqL1xuICBwdWJsaWMgdHJhY2tCeUZuKGluZGV4KSB7XG4gICAgcmV0dXJuIGluZGV4O1xuICB9XG5cbiAgLyoqXG4gICAqIEVtaXQgdGhhdCBzb21lIHJvdyBtdXN0IGJlIHJlbW92ZWRcbiAgICpcbiAgICogQHBhcmFtIGFjdGlvblxuICAgKiBAcGFyYW0gcm93XG4gICAqIEBwYXJhbSBldmVudFxuICAgKiBAcGFyYW0gaW5kZXhcbiAgICovXG4gIHByaXZhdGUgX3JlbW92ZUFjdGlvbihhY3Rpb24sIHJvdywgZXZlbnQsIGluZGV4KSB7XG4gICAgY29uc3QgcmVtb3ZlT2JzZXJ2YWJsZSA9IGFjdGlvbi5jbGljayhyb3csIGV2ZW50LCBpbmRleCk7XG5cbiAgICBpZiAocmVtb3ZlT2JzZXJ2YWJsZSAmJiByZW1vdmVPYnNlcnZhYmxlIGluc3RhbmNlb2YgT2JzZXJ2YWJsZSkge1xuICAgICAgcmVtb3ZlT2JzZXJ2YWJsZVxuICAgICAgICAucGlwZShcbiAgICAgICAgICB0YWtlKDEpLFxuICAgICAgICAgIHRha2VVbnRpbCh0aGlzLl9kZXN0cm95JCksXG4gICAgICAgIClcbiAgICAgICAgLnN1YnNjcmliZSgoKSA9PiB7XG4gICAgICAgICAgdGhpcy5yb3dSZW1vdmVkLmVtaXQocm93KTtcbiAgICAgICAgfSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMucm93UmVtb3ZlZC5lbWl0KHJvdyk7XG4gICAgfVxuICB9XG59XG4iLCI8bmctY29udGFpbmVyICpuZ0lmPVwiIXJlc3RvcmVNb2RlIHx8IChyZXN0b3JlTW9kZSAmJiAhcmVzdG9yZUFjdGlvbilcIj5cbiAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgYWN0aW9uIG9mIGlubGluZVJvd0FjdGlvbnM7IHRyYWNrQnk6IHRyYWNrQnlGblwiPlxuICAgIDxmcy1saXN0LXJvdy1pbmxpbmUtYWN0aW9uIFxuICAgICAgY2xhc3M9XCJyb3ctaW5saW5lLWFjdGlvbiByb3ctaW5saW5lLWFjdGlvbi17e2FjdGlvbi50eXBlfX1cIlxuICAgICAgW2FjdGlvbl09XCJhY3Rpb25cIlxuICAgICAgW25nQ2xhc3NdPVwieydtb2JpbGUtaGlkZSc6IGFjdGlvbi5tZW51ID09PSB1bmRlZmluZWR9XCJcbiAgICAgIChjbGlja2VkKT1cImFjdGlvbkNsaWNrKGFjdGlvbiwgcm93LCAkZXZlbnQpXCJcbiAgICAgIChmaWxlU2VsZWN0KT1cImFjdGlvbi5maWxlQ29uZmlnLnNlbGVjdCgkZXZlbnQsIHJvdywgaW5kZXgpXCI+XG4gICAgPC9mcy1saXN0LXJvdy1pbmxpbmUtYWN0aW9uPlxuICA8L25nLWNvbnRhaW5lcj5cbjwvbmctY29udGFpbmVyPlxuXG48IS0tIE1lbnUgLS0+XG48ZnMtbWVudSBcbiAgICBjbGFzcz1cInJvdy1tZW51LWFjdGlvblwiXG4gICAgKm5nSWY9XCJtZW51Um93QWN0aW9ucy5sZW5ndGggfHwgKHJlc3RvcmVNb2RlICYmIHJlc3RvcmVBY3Rpb24pXCJcbiAgICAjbWVudVJlZj5cbiAgPCEtLSBDYXNlIHdoZW4gd2UgaGF2ZSB1c3VhbCBtZW51IGFjdGlvbnMgLS0+XG4gIDxuZy1jb250YWluZXIgKm5nSWY9XCIhcmVzdG9yZU1vZGUgfHwgKHJlc3RvcmVNb2RlICYmICFyZXN0b3JlQWN0aW9uKVwiPlxuICAgIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IGFjdGlvbiBvZiBpbmxpbmVSb3dBY3Rpb25zOyB0cmFja0J5OiB0cmFja0J5Rm5cIj5cbiAgICAgIDxuZy10ZW1wbGF0ZSBcbiAgICAgICAgICBjbGFzcz1cImhpZGRlbi1tb2JpbGUtbWVudS1hY3Rpb25cIlxuICAgICAgICAgIGZzLW1lbnUtaXRlbVxuICAgICAgICAgIFtsaW5rXT1cImFjdGlvbi5yb3V0ZXJMaW5rPy5saW5rXCJcbiAgICAgICAgICBbcXVlcnlQYXJhbXNdPVwiYWN0aW9uLnJvdXRlckxpbms/LnF1ZXJ5UGFyYW1zXCJcbiAgICAgICAgICBbdGFyZ2V0XT1cImFjdGlvbi5yb3V0ZXJMaW5rPy50YXJnZXRcIlxuICAgICAgICAgIFtoaWRkZW5dPVwiYWN0aW9uLm1lbnUgIT09IHVuZGVmaW5lZCAmJiAhYWN0aW9uLmlzU2hvd25cIj5cbiAgICAgICAgPGZzLWxpc3Qtcm93LW1lbnUtYWN0aW9uXG4gICAgICAgICAgW2ljb25dPVwiYWN0aW9uLmljb25cIlxuICAgICAgICAgIFtsYWJlbF09XCJhY3Rpb24ubGFiZWxcIlxuICAgICAgICAgIFtyb3ddPVwicm93XCJcbiAgICAgICAgICBbZmlsZV09XCJhY3Rpb24uZmlsZUNvbmZpZ1wiXG4gICAgICAgICAgKGZpbGVTZWxlY3QpPVwiYWN0aW9uLmZpbGVDb25maWcuc2VsZWN0KCRldmVudCwgcm93LCBpbmRleClcIlxuICAgICAgICAgIChmaWxlRXJyb3IpPVwiYWN0aW9uLmZpbGVDb25maWcuZXJyb3IgJiYgYWN0aW9uLmZpbGVDb25maWcuZXJyb3IoJGV2ZW50KVwiPlxuICAgICAgICA8L2ZzLWxpc3Qtcm93LW1lbnUtYWN0aW9uPlxuICAgICAgPC9uZy10ZW1wbGF0ZT5cbiAgICA8L25nLWNvbnRhaW5lcj5cblxuICAgIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IGFjdGlvbiBvZiBtZW51Um93QWN0aW9uczsgdHJhY2tCeTogdHJhY2tCeUZuXCI+XG4gICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiYWN0aW9uLmlzR3JvdXAgZWxzZSBzaW1wbGVNZW51SXRlbVwiPlxuICAgICAgICA8ZnMtbWVudS1ncm91cCBbbGFiZWxdPVwiYWN0aW9uLmxhYmVsIHwgYWN0aW9uTGFiZWw6cm93XCI+XG4gICAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgc3ViQWN0aW9uIG9mIGFjdGlvbi5yb3dBY3Rpb25zXCI+XG4gICAgICAgICAgICA8bmctdGVtcGxhdGUgXG4gICAgICAgICAgICAgICAgZnMtbWVudS1pdGVtXG4gICAgICAgICAgICAgICAgW2xpbmtdPVwic3ViQWN0aW9uLnJvdXRlckxpbms/LmxpbmtcIlxuICAgICAgICAgICAgICAgIFtxdWVyeVBhcmFtc109XCJzdWJBY3Rpb24ucm91dGVyTGluaz8ucXVlcnlQYXJhbXNcIlxuICAgICAgICAgICAgICAgIFt0YXJnZXRdPVwic3ViQWN0aW9uLnJvdXRlckxpbms/LnRhcmdldFwiXG4gICAgICAgICAgICAgICAgW2hpZGRlbl09XCIhc3ViQWN0aW9uLmlzU2hvd25cIlxuICAgICAgICAgICAgICAgIChjbGljayk9XCJhY3Rpb25DbGljayhzdWJBY3Rpb24sIHJvdywgJGV2ZW50LCBtZW51UmVmKTtcIj5cbiAgICAgICAgICAgICAgPGZzLWxpc3Qtcm93LW1lbnUtYWN0aW9uXG4gICAgICAgICAgICAgICAgW2ljb25dPVwic3ViQWN0aW9uLmljb25cIlxuICAgICAgICAgICAgICAgIFtsYWJlbF09XCJzdWJBY3Rpb24ubGFiZWxcIlxuICAgICAgICAgICAgICAgIFtyb3ddPVwicm93XCJcbiAgICAgICAgICAgICAgICBbZmlsZV09XCJzdWJBY3Rpb24uZmlsZUNvbmZpZ1wiXG4gICAgICAgICAgICAgICAgKGZpbGVTZWxlY3QpPVwic3ViQWN0aW9uLmZpbGVDb25maWcuc2VsZWN0KCRldmVudCwgcm93LCBpbmRleClcIlxuICAgICAgICAgICAgICAgIChmaWxlRXJyb3IpPVwic3ViQWN0aW9uLmZpbGVDb25maWcuZXJyb3IgJiYgc3ViQWN0aW9uLmZpbGVDb25maWcuZXJyb3IoJGV2ZW50KVwiPlxuICAgICAgICAgICAgICA8L2ZzLWxpc3Qtcm93LW1lbnUtYWN0aW9uPlxuICAgICAgICAgICAgPC9uZy10ZW1wbGF0ZT5cbiAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgPC9mcy1tZW51LWdyb3VwPlxuICAgICAgPC9uZy1jb250YWluZXI+XG4gICAgICA8bmctdGVtcGxhdGUgI3NpbXBsZU1lbnVJdGVtPlxuICAgICAgICA8bmctdGVtcGxhdGUgXG4gICAgICAgICAgICBmcy1tZW51LWl0ZW1cbiAgICAgICAgICAgIFtsaW5rXT1cImFjdGlvbi5yb3V0ZXJMaW5rPy5saW5rXCJcbiAgICAgICAgICAgIFtxdWVyeVBhcmFtc109XCJhY3Rpb24ucm91dGVyTGluaz8ucXVlcnlQYXJhbXNcIlxuICAgICAgICAgICAgW3RhcmdldF09XCJhY3Rpb24ucm91dGVyTGluaz8udGFyZ2V0XCJcbiAgICAgICAgICAgIFtoaWRkZW5dPVwiIWFjdGlvbi5pc1Nob3duXCJcbiAgICAgICAgICAgIChjbGljayk9XCJhY3Rpb25DbGljayhhY3Rpb24sIHJvdywgJGV2ZW50LCBtZW51UmVmKTtcIj5cbiAgICAgICAgICA8ZnMtbGlzdC1yb3ctbWVudS1hY3Rpb25cbiAgICAgICAgICAgIFtpY29uXT1cImFjdGlvbi5pY29uXCJcbiAgICAgICAgICAgIFtsYWJlbF09XCJhY3Rpb24ubGFiZWxcIlxuICAgICAgICAgICAgW3Jvd109XCJyb3dcIlxuICAgICAgICAgICAgW2ZpbGVdPVwiYWN0aW9uLmZpbGVDb25maWdcIlxuICAgICAgICAgICAgKGZpbGVTZWxlY3QpPVwiYWN0aW9uLmZpbGVDb25maWcuc2VsZWN0KCRldmVudCwgcm93LCBpbmRleClcIlxuICAgICAgICAgICAgKGZpbGVFcnJvcik9XCJhY3Rpb24uZmlsZUNvbmZpZy5lcnJvciAmJiBhY3Rpb24uZmlsZUNvbmZpZy5lcnJvcigkZXZlbnQpXCI+XG4gICAgICAgICAgPC9mcy1saXN0LXJvdy1tZW51LWFjdGlvbj5cbiAgICAgICAgPC9uZy10ZW1wbGF0ZT5cbiAgICAgIDwvbmctdGVtcGxhdGU+XG4gICAgPC9uZy1jb250YWluZXI+XG4gIDwvbmctY29udGFpbmVyPlxuXG4gIDwhLS0gQ2FzZSB3aGVuIHdlIGhhdmUgcmVzdG9yZSBtb2RlIGVuYWJsZWQgYW5kIG11c3QgaGlkZSBtZW51IGFjdGlvbnMgLS0+XG4gIDxuZy1jb250YWluZXIgKm5nSWY9XCJyZXN0b3JlTW9kZSAmJiByZXN0b3JlQWN0aW9uXCI+XG4gICAgPG5nLXRlbXBsYXRlIGZzLW1lbnUtaXRlbSAoY2xpY2spPVwiYWN0aW9uQ2xpY2socmVzdG9yZUFjdGlvbiwgcm93LCAkZXZlbnQsIG1lbnVSZWYpXCI+XG4gICAgICA8bWF0LWljb24gKm5nSWY9XCJyZXN0b3JlQWN0aW9uLmljb25cIj57e3Jlc3RvcmVBY3Rpb24uaWNvbn19PC9tYXQtaWNvbj5cbiAgICAgIHt7cmVzdG9yZUFjdGlvbi5sYWJlbCB8IGFjdGlvbkxhYmVsOnJvd319XG4gICAgPC9uZy10ZW1wbGF0ZT5cbiAgPC9uZy1jb250YWluZXI+XG48L2ZzLW1lbnU+XG4iXX0=