@firestitch/list 12.3.3 → 12.4.0

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 (143) 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 +90 -90
  4. package/app/classes/external-params-controller.d.ts +31 -31
  5. package/app/classes/index.d.ts +2 -2
  6. package/app/classes/list-controller.d.ts +174 -168
  7. package/app/classes/pagination-controller.d.ts +189 -189
  8. package/app/classes/persistance-controller.d.ts +10 -10
  9. package/app/classes/reorder-controller.d.ts +62 -61
  10. package/app/classes/selection-controller.d.ts +141 -141
  11. package/app/classes/sorting-controller.d.ts +64 -64
  12. package/app/components/body/body.component.d.ts +32 -32
  13. package/app/components/body/row/actions/actions.component.d.ts +35 -35
  14. package/app/components/body/row/cell/cell.component.d.ts +23 -23
  15. package/app/components/body/row/inline-action/inline-action.component.d.ts +16 -16
  16. package/app/components/body/row/menu-action/menu-action.component.d.ts +12 -12
  17. package/app/components/body/row/row.component.d.ts +72 -72
  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 +11 -11
  21. package/app/components/footer/footer.component.d.ts +11 -11
  22. package/app/components/head/head-cell/head-cell.component.d.ts +14 -14
  23. package/app/components/head/head.component.d.ts +43 -43
  24. package/app/components/list/list.component.d.ts +114 -113
  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 +33 -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 +80 -80
  35. package/app/directives/draggable-row/draggable-row.directive.d.ts +21 -21
  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/enums/button-type.enum.d.ts +7 -7
  43. package/app/enums/page-change-type.enum.d.ts +4 -4
  44. package/app/enums/pagination-strategy.enum.d.ts +5 -5
  45. package/app/enums/row-type.enum.d.ts +6 -6
  46. package/app/enums/state.enum.d.ts +9 -9
  47. package/app/fs-list.module.d.ts +57 -57
  48. package/app/fs-list.providers.d.ts +3 -3
  49. package/app/interfaces/cellconfig.interface.d.ts +5 -5
  50. package/app/interfaces/column-config.interface.d.ts +2 -2
  51. package/app/interfaces/draggable-list.interface.d.ts +7 -7
  52. package/app/interfaces/external-params.interface.d.ts +13 -13
  53. package/app/interfaces/index.d.ts +3 -3
  54. package/app/interfaces/listconfig.interface.d.ts +250 -250
  55. package/app/interfaces/pagination.interface.d.ts +13 -13
  56. package/app/models/column-async-attribute.d.ts +5 -5
  57. package/app/models/column-attributes.d.ts +39 -39
  58. package/app/models/column.model.d.ts +59 -59
  59. package/app/models/row/base-row.d.ts +13 -13
  60. package/app/models/row/child-row.d.ts +12 -12
  61. package/app/models/row/group-footer-row.d.ts +10 -10
  62. package/app/models/row/group-row.d.ts +15 -15
  63. package/app/models/row/simple-row.d.ts +5 -5
  64. package/app/models/row-action.model.d.ts +31 -31
  65. package/app/models/row.d.ts +30 -30
  66. package/app/models/styleConfig.model.d.ts +31 -31
  67. package/app/services/group-expand-notifier.service.d.ts +11 -11
  68. package/bundles/firestitch-list.umd.js +6545 -6512
  69. package/bundles/firestitch-list.umd.js.map +1 -1
  70. package/esm2015/app/classes/actions-controller.js +55 -55
  71. package/esm2015/app/classes/columns-controller.js +205 -205
  72. package/esm2015/app/classes/data-controller.js +333 -333
  73. package/esm2015/app/classes/external-params-controller.js +153 -153
  74. package/esm2015/app/classes/index.js +3 -3
  75. package/esm2015/app/classes/list-controller.js +715 -700
  76. package/esm2015/app/classes/pagination-controller.js +460 -460
  77. package/esm2015/app/classes/persistance-controller.js +19 -19
  78. package/esm2015/app/classes/reorder-controller.js +173 -170
  79. package/esm2015/app/classes/selection-controller.js +445 -445
  80. package/esm2015/app/classes/sorting-controller.js +180 -180
  81. package/esm2015/app/components/body/body.component.js +76 -76
  82. package/esm2015/app/components/body/row/actions/actions.component.js +100 -100
  83. package/esm2015/app/components/body/row/cell/cell.component.js +92 -92
  84. package/esm2015/app/components/body/row/inline-action/inline-action.component.js +40 -40
  85. package/esm2015/app/components/body/row/menu-action/menu-action.component.js +31 -31
  86. package/esm2015/app/components/body/row/row.component.js +254 -254
  87. package/esm2015/app/components/customize-cols/customize-cols.component.js +72 -72
  88. package/esm2015/app/components/footer/footer-row/footer-cell/footer-cell.component.js +20 -20
  89. package/esm2015/app/components/footer/footer-row/footer-row.component.js +27 -27
  90. package/esm2015/app/components/footer/footer.component.js +26 -26
  91. package/esm2015/app/components/head/head-cell/head-cell.component.js +33 -33
  92. package/esm2015/app/components/head/head.component.js +91 -91
  93. package/esm2015/app/components/list/list.component.js +370 -364
  94. package/esm2015/app/components/loader/loader.component.js +47 -47
  95. package/esm2015/app/components/manage-saved-filters/manage-saved-filters.component.js +79 -79
  96. package/esm2015/app/components/pagination/pagination.component.js +45 -45
  97. package/esm2015/app/components/saved-filters/saved-filters.component.js +33 -33
  98. package/esm2015/app/components/status/status.component.js +74 -74
  99. package/esm2015/app/directives/cell/cell.directive.js +18 -18
  100. package/esm2015/app/directives/column/column.directive.js +111 -111
  101. package/esm2015/app/directives/content/content.directive.js +12 -12
  102. package/esm2015/app/directives/content-init/content-init.directive.js +21 -21
  103. package/esm2015/app/directives/draggable-list/draggable-list.directive.js +256 -256
  104. package/esm2015/app/directives/draggable-row/draggable-row.directive.js +73 -73
  105. package/esm2015/app/directives/empty-state/empty-state.directive.js +13 -13
  106. package/esm2015/app/directives/footer/footer.directive.js +18 -18
  107. package/esm2015/app/directives/group-expand-trigger/group-expand-trigger.directive.js +26 -26
  108. package/esm2015/app/directives/group-footer/group-footer.directive.js +13 -13
  109. package/esm2015/app/directives/group-header/group-header.directive.js +13 -13
  110. package/esm2015/app/directives/header/header.directive.js +18 -18
  111. package/esm2015/app/enums/button-type.enum.js +9 -9
  112. package/esm2015/app/enums/page-change-type.enum.js +6 -6
  113. package/esm2015/app/enums/pagination-strategy.enum.js +7 -7
  114. package/esm2015/app/enums/row-type.enum.js +7 -7
  115. package/esm2015/app/enums/state.enum.js +11 -11
  116. package/esm2015/app/fs-list.module.js +231 -231
  117. package/esm2015/app/fs-list.providers.js +4 -4
  118. package/esm2015/app/interfaces/cellconfig.interface.js +2 -2
  119. package/esm2015/app/interfaces/column-config.interface.js +1 -1
  120. package/esm2015/app/interfaces/draggable-list.interface.js +2 -2
  121. package/esm2015/app/interfaces/external-params.interface.js +2 -2
  122. package/esm2015/app/interfaces/index.js +4 -4
  123. package/esm2015/app/interfaces/listconfig.interface.js +1 -1
  124. package/esm2015/app/interfaces/pagination.interface.js +2 -2
  125. package/esm2015/app/models/column-async-attribute.js +13 -13
  126. package/esm2015/app/models/column-attributes.js +130 -130
  127. package/esm2015/app/models/column.model.js +166 -166
  128. package/esm2015/app/models/row/base-row.js +23 -23
  129. package/esm2015/app/models/row/child-row.js +28 -28
  130. package/esm2015/app/models/row/group-footer-row.js +20 -20
  131. package/esm2015/app/models/row/group-row.js +40 -40
  132. package/esm2015/app/models/row/simple-row.js +10 -10
  133. package/esm2015/app/models/row-action.model.js +108 -108
  134. package/esm2015/app/models/row.js +80 -80
  135. package/esm2015/app/models/styleConfig.model.js +75 -75
  136. package/esm2015/app/services/group-expand-notifier.service.js +26 -26
  137. package/esm2015/firestitch-list.js +4 -4
  138. package/esm2015/public_api.js +44 -44
  139. package/fesm2015/firestitch-list.js +5381 -5357
  140. package/fesm2015/firestitch-list.js.map +1 -1
  141. package/firestitch-list.d.ts +5 -5
  142. package/package.json +1 -1
  143. package/public_api.d.ts +38 -38
@@ -1,255 +1,255 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, ElementRef, EventEmitter, KeyValueDiffers, Renderer2, Component, HostBinding, Input, ViewChildren, } from '@angular/core';
2
- import { Subject } from 'rxjs';
3
- import { takeUntil } from 'rxjs/operators';
4
- import { ReorderController, ReorderPosition, ReorderStrategy } from '../../../classes/reorder-controller';
5
- import { SelectionController } from '../../../classes/selection-controller';
6
- import { RowAction } from '../../../models/row-action.model';
7
- import { Row } from '../../../models/row';
8
- import { FsListDraggableListDirective } from '../../../directives/draggable-list/draggable-list.directive';
9
- import * as i0 from "@angular/core";
10
- import * as i1 from "../../../classes/reorder-controller";
11
- import * as i2 from "../../../directives/draggable-list/draggable-list.directive";
12
- import * as i3 from "@angular/material/checkbox";
13
- import * as i4 from "./cell/cell.component";
14
- import * as i5 from "./actions/actions.component";
15
- import * as i6 from "@angular/material/icon";
16
- import * as i7 from "@angular/common";
17
- import * as i8 from "@angular/flex-layout/extended";
18
- export class FsRowComponent {
19
- constructor(el, reorderController, _cdRef, _differs, _renderer, _draggableList) {
20
- this.el = el;
21
- this.reorderController = reorderController;
22
- this._cdRef = _cdRef;
23
- this._differs = _differs;
24
- this._renderer = _renderer;
25
- this._draggableList = _draggableList;
26
- this.role = 'row';
27
- this.rowActionsRaw = [];
28
- this.groupActionsRaw = [];
29
- this.hasRowActions = false;
30
- this.rowEvents = {};
31
- this.restoreMode = false;
32
- this.ReorderPosition = ReorderPosition;
33
- this.ReorderStrategy = ReorderStrategy;
34
- this.rowActions = [];
35
- this.menuRowActions = [];
36
- this.inlineRowActions = [];
37
- this.selected = false;
38
- this.indeterminateSelected = false;
39
- this._eventListeners = [];
40
- this._destroy$ = new Subject();
41
- this._rowDiffer = _differs.find({}).create();
42
- }
43
- get isGroupRow() {
44
- return this.row.isGroup;
45
- }
46
- get isChildRow() {
47
- return this.row.isChild;
48
- }
49
- get isGroupFooterRow() {
50
- return this.row.isFooter;
51
- }
52
- get rowCssClass() {
53
- let cls = 'fs-list-row';
54
- if (this.rowIndex % 2 !== 0)
55
- cls += ' fs-list-row-odd';
56
- if (this.rowIndex % 2 === 0)
57
- cls += ' fs-list-row-even';
58
- if (this.row && this.row.isGroup)
59
- cls += ' fs-list-row-group';
60
- if (this.rowClass) {
61
- const options = {
62
- index: this.rowIndex,
63
- };
64
- if (this.row.isGroup) {
65
- options.groupIndex = this.row.index;
66
- }
67
- else if (this.row.isChild) {
68
- options.groupChildIndex = this.row.index;
69
- }
70
- const resultClass = this.rowClass(this.row.data, options);
71
- if (typeof resultClass === 'string') {
72
- cls += ` ${resultClass}`;
73
- }
74
- else if (typeof resultClass === 'object') {
75
- const keys = Object.keys(resultClass);
76
- for (const k of keys) {
77
- if (resultClass[k] === true)
78
- cls += ` ${k}`;
79
- }
80
- }
81
- }
82
- return cls;
83
- }
84
- get dragCellVisible() {
85
- return !this.row.isGroup;
86
- }
87
- ngOnInit() {
88
- this.initRowEvents();
89
- this.initSelection();
90
- if (this.row && this.row.isGroup) {
91
- if (this.row && this.row.isGroup && this.groupActionsRaw) {
92
- this.rowActions = this.groupActionsRaw.map((action) => new RowAction(action));
93
- this.filterActionsByCategories();
94
- }
95
- }
96
- else if (this.rowActionsRaw) {
97
- this.rowActions = this.rowActionsRaw.map((action) => new RowAction(action));
98
- this.filterActionsByCategories();
99
- }
100
- }
101
- ngDoCheck() {
102
- if (this._rowDiffer.diff(this.row)) {
103
- if (this.rowActions) {
104
- this.rowActions.forEach((action) => {
105
- action.checkShowStatus(this.row.data, this.rowIndex);
106
- action.updateLink(this.row.data);
107
- });
108
- this.filterActionsByCategories();
109
- }
110
- this._cdRef.markForCheck();
111
- }
112
- }
113
- ngOnDestroy() {
114
- this._eventListeners.forEach((listener) => { listener(); });
115
- this._destroy$.next();
116
- this._destroy$.complete();
117
- }
118
- /**
119
- * Select row by checkbox
120
- * @param event
121
- */
122
- selectRow(event) {
123
- this.selection.rowSelectionChange(this.row, event.checked);
124
- this._cdRef.markForCheck();
125
- }
126
- /**
127
- * Track By for improve change detection
128
- * @param index
129
- */
130
- trackByFn(index) {
131
- return index;
132
- }
133
- dragStart(event) {
134
- if (this.reorderController.enabled) {
135
- event.preventDefault();
136
- event.stopPropagation();
137
- this._draggableList.dragStart(this.el.nativeElement);
138
- }
139
- }
140
- /**
141
- * Set event listeners for row
142
- */
143
- initRowEvents() {
144
- for (const event in this.rowEvents) {
145
- if (this.rowEvents.hasOwnProperty(event)) {
146
- const listener = this._renderer.listen(this.el.nativeElement, event, (evt) => {
147
- // evt.preventDefault();
148
- // evt.stopPropagation();
149
- if (!this.reorderController.enabled) {
150
- this.rowEvents[event]({
151
- event: evt,
152
- row: this.row.data,
153
- rowIndex: this.rowIndex
154
- });
155
- }
156
- });
157
- this._eventListeners.push(listener);
158
- }
159
- }
160
- }
161
- /**
162
- * Subscribe to selection change events
163
- */
164
- initSelection() {
165
- if (this.selection) {
166
- this.selected = this.row && this.selection.isRowSelected(this.row.data);
167
- this.selection.selectionChange$
168
- .pipe(
169
- // // Would like to respond only when checkbox on top is changed
170
- // // or was clicked "Select All" in selection dialog
171
- // filter(({type}) => {
172
- // return type === SelectionChangeType.AllVisibleSelectionChange
173
- // || type === SelectionChangeType.SelectedAll;
174
- // }),
175
- takeUntil(this._destroy$))
176
- .subscribe(() => {
177
- var _a;
178
- this.selected = this.row && this.selection.isRowSelected(this.row.data);
179
- if ((_a = this.row) === null || _a === void 0 ? void 0 : _a.isGroup) {
180
- const groupSelection = this.selection.isGroupSelected(this.row);
181
- if (groupSelection === 'indeterminate') {
182
- this.selected = true;
183
- this.indeterminateSelected = true;
184
- }
185
- else {
186
- this.selected = groupSelection;
187
- this.indeterminateSelected = false;
188
- }
189
- }
190
- this._cdRef.markForCheck();
191
- });
192
- }
193
- }
194
- filterActionsByCategories() {
195
- this.menuRowActions = [];
196
- this.inlineRowActions = [];
197
- this.restoreAction = null;
198
- this.rowActions.forEach((action) => {
199
- if (!action.isShown) {
200
- return;
201
- }
202
- if (action.menu && !action.restore) {
203
- this.menuRowActions.push(action);
204
- }
205
- else if (!action.menu && !action.restore) {
206
- this.inlineRowActions.push(action);
207
- }
208
- else if (action.restore) {
209
- this.restoreAction = action;
210
- }
211
- });
212
- }
213
- }
214
- FsRowComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsRowComponent, deps: [{ token: i0.ElementRef }, { token: i1.ReorderController }, { token: i0.ChangeDetectorRef }, { token: i0.KeyValueDiffers }, { token: i0.Renderer2 }, { token: i2.FsListDraggableListDirective }], target: i0.ɵɵFactoryTarget.Component });
215
- FsRowComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: FsRowComponent, selector: "[fs-list-row]", inputs: { row: "row", rowActionsRaw: "rowActionsRaw", groupActionsRaw: "groupActionsRaw", hasRowActions: "hasRowActions", rowEvents: "rowEvents", rowClass: "rowClass", restoreMode: "restoreMode", rowIndex: "rowIndex", columns: "columns", selection: "selection", rowRemoved: "rowRemoved" }, host: { properties: { "attr.role": "this.role", "class": "this.rowCssClass" } }, viewQueries: [{ propertyName: "cellRefs", predicate: ["td"], descendants: true }], ngImport: i0, template: "<!-- Drag -->\n<ng-container *ngIf=\"reorderController.leftReorderActivated$ | async\">\n <ng-container *ngTemplateOutlet=\"dragCell\"></ng-container>\n</ng-container>\n\n<!-- Selection -->\n<ng-container *ngIf=\"selection\">\n <td class=\"fs-list-col fs-list-col-selection\">\n <ng-container *ngIf=\"!row.isFooter\">\n <mat-checkbox (change)=\"selectRow($event)\"\n [checked]=\"selected\"\n [indeterminate]=\"indeterminateSelected\">\n </mat-checkbox>\n </ng-container>\n </td>\n</ng-container>\n\n<!-- Content -->\n<ng-container *ngFor=\"let column of columns; trackBy: trackByFn; let isFirst = first\">\n <td fs-cell\n *ngIf=\"(isGroupRow && !column.groupHeaderColspanned)\n || (isGroupFooterRow && !column.groupFooterColspanned)\n || (!isGroupRow && !isGroupFooterRow && !column.cellColspanned)\"\n [column]=\"column\"\n [row]=\"row\"\n [rowIndex]=\"rowIndex\"\n [class]=\"(isGroupRow && column.groupHeaderConfigs.classesString)\n || (isGroupFooterRow && column.groupFooterConfigs.classesString)\n || (!isGroupFooterRow && column.cellConfigs.classesString)\"\n [ngClass]=\"{ 'primary-col': isFirst }\"\n [attr.colspan]=\"(isGroupRow && column.groupHeaderConfigs.colspan)\n || (isGroupFooterRow && column.groupFooterConfigs.colspan)\n || column.cellConfigs.colspan\"\n [attr.width]=\"column.width\"\n >\n </td>\n</ng-container>\n\n<!-- Drag -->\n<ng-container *ngIf=\"reorderController.rightReorderActivated$ | async\">\n <ng-container *ngTemplateOutlet=\"dragCell\"></ng-container>\n</ng-container>\n\n<!-- Row Actions -->\n<td *ngIf=\"hasRowActions && !(reorderController.manualReorderActivated$ | async)\" class=\"fs-list-col row-actions\">\n <ng-container *ngIf=\"!isGroupFooterRow\">\n <fs-list-row-actions [row]=\"row\"\n [index]=\"rowIndex\"\n [rowActions]=\"rowActions\"\n [menuRowActions]=\"menuRowActions\"\n [inlineRowActions]=\"inlineRowActions\"\n [restoreAction]=\"restoreAction\"\n [restoreMode]=\"restoreMode\"\n [rowRemoved]=\"rowRemoved\"\n ></fs-list-row-actions>\n </ng-container>\n</td>\n\n<ng-template #dragCell>\n <ng-container *ngIf=\"dragCellVisible && !isGroupFooterRow; else emptyCell\">\n <td class=\"fs-list-col drag-col\"\n (mousedown)=\"dragStart($event)\"\n (touchstart)=\"dragStart($event)\"\n >\n <mat-icon>drag_handle</mat-icon>\n </td>\n </ng-container>\n <ng-template #emptyCell>\n <td class=\"fs-list-col drag-col\"></td>\n </ng-template>\n</ng-template>\n", components: [{ type: i3.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex", "aria-label", "aria-labelledby", "id", "labelPosition", "name", "required", "checked", "disabled", "indeterminate", "aria-describedby", "value"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { type: i4.FsCellComponent, selector: "[fs-cell]", inputs: ["column", "row", "rowIndex"] }, { type: i5.FsRowActionsComponent, selector: "fs-list-row-actions", inputs: ["row", "index", "restoreMode", "rowActions", "rowRemoved", "menuRowActions", "inlineRowActions", "restoreAction"] }, { type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i8.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }], pipes: { "async": i7.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
216
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsRowComponent, decorators: [{
217
- type: Component,
218
- args: [{
219
- selector: '[fs-list-row]',
220
- templateUrl: 'row.component.html',
221
- changeDetection: ChangeDetectionStrategy.OnPush
222
- }]
223
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.ReorderController }, { type: i0.ChangeDetectorRef }, { type: i0.KeyValueDiffers }, { type: i0.Renderer2 }, { type: i2.FsListDraggableListDirective }]; }, propDecorators: { role: [{
224
- type: HostBinding,
225
- args: ['attr.role']
226
- }], row: [{
227
- type: Input
228
- }], rowActionsRaw: [{
229
- type: Input
230
- }], groupActionsRaw: [{
231
- type: Input
232
- }], hasRowActions: [{
233
- type: Input
234
- }], rowEvents: [{
235
- type: Input
236
- }], rowClass: [{
237
- type: Input
238
- }], restoreMode: [{
239
- type: Input
240
- }], rowIndex: [{
241
- type: Input
242
- }], columns: [{
243
- type: Input
244
- }], selection: [{
245
- type: Input
246
- }], rowRemoved: [{
247
- type: Input
248
- }], cellRefs: [{
249
- type: ViewChildren,
250
- args: ['td']
251
- }], rowCssClass: [{
252
- type: HostBinding,
253
- args: ['class']
254
- }] } });
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, ElementRef, EventEmitter, KeyValueDiffers, Renderer2, Component, HostBinding, Input, ViewChildren, } from '@angular/core';
2
+ import { Subject } from 'rxjs';
3
+ import { takeUntil } from 'rxjs/operators';
4
+ import { ReorderController, ReorderPosition, ReorderStrategy } from '../../../classes/reorder-controller';
5
+ import { SelectionController } from '../../../classes/selection-controller';
6
+ import { RowAction } from '../../../models/row-action.model';
7
+ import { Row } from '../../../models/row';
8
+ import { FsListDraggableListDirective } from '../../../directives/draggable-list/draggable-list.directive';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "../../../classes/reorder-controller";
11
+ import * as i2 from "../../../directives/draggable-list/draggable-list.directive";
12
+ import * as i3 from "@angular/material/checkbox";
13
+ import * as i4 from "./cell/cell.component";
14
+ import * as i5 from "./actions/actions.component";
15
+ import * as i6 from "@angular/material/icon";
16
+ import * as i7 from "@angular/common";
17
+ import * as i8 from "@angular/flex-layout/extended";
18
+ export class FsRowComponent {
19
+ constructor(el, reorderController, _cdRef, _differs, _renderer, _draggableList) {
20
+ this.el = el;
21
+ this.reorderController = reorderController;
22
+ this._cdRef = _cdRef;
23
+ this._differs = _differs;
24
+ this._renderer = _renderer;
25
+ this._draggableList = _draggableList;
26
+ this.role = 'row';
27
+ this.rowActionsRaw = [];
28
+ this.groupActionsRaw = [];
29
+ this.hasRowActions = false;
30
+ this.rowEvents = {};
31
+ this.restoreMode = false;
32
+ this.ReorderPosition = ReorderPosition;
33
+ this.ReorderStrategy = ReorderStrategy;
34
+ this.rowActions = [];
35
+ this.menuRowActions = [];
36
+ this.inlineRowActions = [];
37
+ this.selected = false;
38
+ this.indeterminateSelected = false;
39
+ this._eventListeners = [];
40
+ this._destroy$ = new Subject();
41
+ this._rowDiffer = _differs.find({}).create();
42
+ }
43
+ get isGroupRow() {
44
+ return this.row.isGroup;
45
+ }
46
+ get isChildRow() {
47
+ return this.row.isChild;
48
+ }
49
+ get isGroupFooterRow() {
50
+ return this.row.isFooter;
51
+ }
52
+ get rowCssClass() {
53
+ let cls = 'fs-list-row';
54
+ if (this.rowIndex % 2 !== 0)
55
+ cls += ' fs-list-row-odd';
56
+ if (this.rowIndex % 2 === 0)
57
+ cls += ' fs-list-row-even';
58
+ if (this.row && this.row.isGroup)
59
+ cls += ' fs-list-row-group';
60
+ if (this.rowClass) {
61
+ const options = {
62
+ index: this.rowIndex,
63
+ };
64
+ if (this.row.isGroup) {
65
+ options.groupIndex = this.row.index;
66
+ }
67
+ else if (this.row.isChild) {
68
+ options.groupChildIndex = this.row.index;
69
+ }
70
+ const resultClass = this.rowClass(this.row.data, options);
71
+ if (typeof resultClass === 'string') {
72
+ cls += ` ${resultClass}`;
73
+ }
74
+ else if (typeof resultClass === 'object') {
75
+ const keys = Object.keys(resultClass);
76
+ for (const k of keys) {
77
+ if (resultClass[k] === true)
78
+ cls += ` ${k}`;
79
+ }
80
+ }
81
+ }
82
+ return cls;
83
+ }
84
+ get dragCellVisible() {
85
+ return !this.row.isGroup;
86
+ }
87
+ ngOnInit() {
88
+ this.initRowEvents();
89
+ this.initSelection();
90
+ if (this.row && this.row.isGroup) {
91
+ if (this.row && this.row.isGroup && this.groupActionsRaw) {
92
+ this.rowActions = this.groupActionsRaw.map((action) => new RowAction(action));
93
+ this.filterActionsByCategories();
94
+ }
95
+ }
96
+ else if (this.rowActionsRaw) {
97
+ this.rowActions = this.rowActionsRaw.map((action) => new RowAction(action));
98
+ this.filterActionsByCategories();
99
+ }
100
+ }
101
+ ngDoCheck() {
102
+ if (this._rowDiffer.diff(this.row)) {
103
+ if (this.rowActions) {
104
+ this.rowActions.forEach((action) => {
105
+ action.checkShowStatus(this.row.data, this.rowIndex);
106
+ action.updateLink(this.row.data);
107
+ });
108
+ this.filterActionsByCategories();
109
+ }
110
+ this._cdRef.markForCheck();
111
+ }
112
+ }
113
+ ngOnDestroy() {
114
+ this._eventListeners.forEach((listener) => { listener(); });
115
+ this._destroy$.next();
116
+ this._destroy$.complete();
117
+ }
118
+ /**
119
+ * Select row by checkbox
120
+ * @param event
121
+ */
122
+ selectRow(event) {
123
+ this.selection.rowSelectionChange(this.row, event.checked);
124
+ this._cdRef.markForCheck();
125
+ }
126
+ /**
127
+ * Track By for improve change detection
128
+ * @param index
129
+ */
130
+ trackByFn(index) {
131
+ return index;
132
+ }
133
+ dragStart(event) {
134
+ if (this.reorderController.enabled) {
135
+ event.preventDefault();
136
+ event.stopPropagation();
137
+ this._draggableList.dragStart(this.el.nativeElement);
138
+ }
139
+ }
140
+ /**
141
+ * Set event listeners for row
142
+ */
143
+ initRowEvents() {
144
+ for (const event in this.rowEvents) {
145
+ if (this.rowEvents.hasOwnProperty(event)) {
146
+ const listener = this._renderer.listen(this.el.nativeElement, event, (evt) => {
147
+ // evt.preventDefault();
148
+ // evt.stopPropagation();
149
+ if (!this.reorderController.enabled) {
150
+ this.rowEvents[event]({
151
+ event: evt,
152
+ row: this.row.data,
153
+ rowIndex: this.rowIndex
154
+ });
155
+ }
156
+ });
157
+ this._eventListeners.push(listener);
158
+ }
159
+ }
160
+ }
161
+ /**
162
+ * Subscribe to selection change events
163
+ */
164
+ initSelection() {
165
+ if (this.selection) {
166
+ this.selected = this.row && this.selection.isRowSelected(this.row.data);
167
+ this.selection.selectionChange$
168
+ .pipe(
169
+ // // Would like to respond only when checkbox on top is changed
170
+ // // or was clicked "Select All" in selection dialog
171
+ // filter(({type}) => {
172
+ // return type === SelectionChangeType.AllVisibleSelectionChange
173
+ // || type === SelectionChangeType.SelectedAll;
174
+ // }),
175
+ takeUntil(this._destroy$))
176
+ .subscribe(() => {
177
+ var _a;
178
+ this.selected = this.row && this.selection.isRowSelected(this.row.data);
179
+ if ((_a = this.row) === null || _a === void 0 ? void 0 : _a.isGroup) {
180
+ const groupSelection = this.selection.isGroupSelected(this.row);
181
+ if (groupSelection === 'indeterminate') {
182
+ this.selected = true;
183
+ this.indeterminateSelected = true;
184
+ }
185
+ else {
186
+ this.selected = groupSelection;
187
+ this.indeterminateSelected = false;
188
+ }
189
+ }
190
+ this._cdRef.markForCheck();
191
+ });
192
+ }
193
+ }
194
+ filterActionsByCategories() {
195
+ this.menuRowActions = [];
196
+ this.inlineRowActions = [];
197
+ this.restoreAction = null;
198
+ this.rowActions.forEach((action) => {
199
+ if (!action.isShown) {
200
+ return;
201
+ }
202
+ if (action.menu && !action.restore) {
203
+ this.menuRowActions.push(action);
204
+ }
205
+ else if (!action.menu && !action.restore) {
206
+ this.inlineRowActions.push(action);
207
+ }
208
+ else if (action.restore) {
209
+ this.restoreAction = action;
210
+ }
211
+ });
212
+ }
213
+ }
214
+ FsRowComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsRowComponent, deps: [{ token: i0.ElementRef }, { token: i1.ReorderController }, { token: i0.ChangeDetectorRef }, { token: i0.KeyValueDiffers }, { token: i0.Renderer2 }, { token: i2.FsListDraggableListDirective }], target: i0.ɵɵFactoryTarget.Component });
215
+ FsRowComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: FsRowComponent, selector: "[fs-list-row]", inputs: { row: "row", rowActionsRaw: "rowActionsRaw", groupActionsRaw: "groupActionsRaw", hasRowActions: "hasRowActions", rowEvents: "rowEvents", rowClass: "rowClass", restoreMode: "restoreMode", rowIndex: "rowIndex", columns: "columns", selection: "selection", rowRemoved: "rowRemoved" }, host: { properties: { "attr.role": "this.role", "class": "this.rowCssClass" } }, viewQueries: [{ propertyName: "cellRefs", predicate: ["td"], descendants: true }], ngImport: i0, template: "<!-- Drag -->\n<ng-container *ngIf=\"reorderController.leftReorderActivated$ | async\">\n <ng-container *ngTemplateOutlet=\"dragCell\"></ng-container>\n</ng-container>\n\n<!-- Selection -->\n<ng-container *ngIf=\"selection\">\n <td class=\"fs-list-col fs-list-col-selection\">\n <ng-container *ngIf=\"!row.isFooter\">\n <mat-checkbox (change)=\"selectRow($event)\"\n [checked]=\"selected\"\n [indeterminate]=\"indeterminateSelected\">\n </mat-checkbox>\n </ng-container>\n </td>\n</ng-container>\n\n<!-- Content -->\n<ng-container *ngFor=\"let column of columns; trackBy: trackByFn; let isFirst = first\">\n <td fs-cell\n *ngIf=\"(isGroupRow && !column.groupHeaderColspanned)\n || (isGroupFooterRow && !column.groupFooterColspanned)\n || (!isGroupRow && !isGroupFooterRow && !column.cellColspanned)\"\n [column]=\"column\"\n [row]=\"row\"\n [rowIndex]=\"rowIndex\"\n [class]=\"(isGroupRow && column.groupHeaderConfigs.classesString)\n || (isGroupFooterRow && column.groupFooterConfigs.classesString)\n || (!isGroupFooterRow && column.cellConfigs.classesString)\"\n [ngClass]=\"{ 'primary-col': isFirst }\"\n [attr.colspan]=\"(isGroupRow && column.groupHeaderConfigs.colspan)\n || (isGroupFooterRow && column.groupFooterConfigs.colspan)\n || column.cellConfigs.colspan\"\n [attr.width]=\"column.width\"\n >\n </td>\n</ng-container>\n\n<!-- Drag -->\n<ng-container *ngIf=\"reorderController.rightReorderActivated$ | async\">\n <ng-container *ngTemplateOutlet=\"dragCell\"></ng-container>\n</ng-container>\n\n<!-- Row Actions -->\n<td *ngIf=\"hasRowActions && !(reorderController.manualReorderActivated$ | async)\" class=\"fs-list-col row-actions\">\n <ng-container *ngIf=\"!isGroupFooterRow\">\n <fs-list-row-actions [row]=\"row\"\n [index]=\"rowIndex\"\n [rowActions]=\"rowActions\"\n [menuRowActions]=\"menuRowActions\"\n [inlineRowActions]=\"inlineRowActions\"\n [restoreAction]=\"restoreAction\"\n [restoreMode]=\"restoreMode\"\n [rowRemoved]=\"rowRemoved\"\n ></fs-list-row-actions>\n </ng-container>\n</td>\n\n<ng-template #dragCell>\n <ng-container *ngIf=\"dragCellVisible && !isGroupFooterRow; else emptyCell\">\n <td class=\"fs-list-col drag-col\"\n (mousedown)=\"dragStart($event)\"\n (touchstart)=\"dragStart($event)\"\n >\n <mat-icon>drag_handle</mat-icon>\n </td>\n </ng-container>\n <ng-template #emptyCell>\n <td class=\"fs-list-col drag-col\"></td>\n </ng-template>\n</ng-template>\n", components: [{ type: i3.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex", "aria-label", "aria-labelledby", "id", "labelPosition", "name", "required", "checked", "disabled", "indeterminate", "aria-describedby", "value"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { type: i4.FsCellComponent, selector: "[fs-cell]", inputs: ["column", "row", "rowIndex"] }, { type: i5.FsRowActionsComponent, selector: "fs-list-row-actions", inputs: ["row", "index", "restoreMode", "rowActions", "rowRemoved", "menuRowActions", "inlineRowActions", "restoreAction"] }, { type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i8.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }], pipes: { "async": i7.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
216
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsRowComponent, decorators: [{
217
+ type: Component,
218
+ args: [{
219
+ selector: '[fs-list-row]',
220
+ templateUrl: 'row.component.html',
221
+ changeDetection: ChangeDetectionStrategy.OnPush
222
+ }]
223
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.ReorderController }, { type: i0.ChangeDetectorRef }, { type: i0.KeyValueDiffers }, { type: i0.Renderer2 }, { type: i2.FsListDraggableListDirective }]; }, propDecorators: { role: [{
224
+ type: HostBinding,
225
+ args: ['attr.role']
226
+ }], row: [{
227
+ type: Input
228
+ }], rowActionsRaw: [{
229
+ type: Input
230
+ }], groupActionsRaw: [{
231
+ type: Input
232
+ }], hasRowActions: [{
233
+ type: Input
234
+ }], rowEvents: [{
235
+ type: Input
236
+ }], rowClass: [{
237
+ type: Input
238
+ }], restoreMode: [{
239
+ type: Input
240
+ }], rowIndex: [{
241
+ type: Input
242
+ }], columns: [{
243
+ type: Input
244
+ }], selection: [{
245
+ type: Input
246
+ }], rowRemoved: [{
247
+ type: Input
248
+ }], cellRefs: [{
249
+ type: ViewChildren,
250
+ args: ['td']
251
+ }], rowCssClass: [{
252
+ type: HostBinding,
253
+ args: ['class']
254
+ }] } });
255
255
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm93LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9ib2R5L3Jvdy9yb3cuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2FwcC9jb21wb25lbnRzL2JvZHkvcm93L3Jvdy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLGlCQUFpQixFQUNqQixVQUFVLEVBQ1YsWUFBWSxFQUNaLGVBQWUsRUFDZixTQUFTLEVBQ1QsU0FBUyxFQUVULFdBQVcsRUFDWCxLQUFLLEVBSUwsWUFBWSxHQUNiLE1BQU0sZUFBZSxDQUFDO0FBR3ZCLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDL0IsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRzNDLE9BQU8sRUFDTCxpQkFBaUIsRUFDakIsZUFBZSxFQUNmLGVBQWUsRUFDaEIsTUFBTSxxQ0FBcUMsQ0FBQztBQUM3QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUM1RSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFDN0QsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQzFDLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLDZEQUE2RCxDQUFDOzs7Ozs7Ozs7O0FBUTNHLE1BQU0sT0FBTyxjQUFjO0lBeUN6QixZQUNTLEVBQWMsRUFDZCxpQkFBb0MsRUFDbkMsTUFBeUIsRUFDekIsUUFBeUIsRUFDekIsU0FBb0IsRUFDcEIsY0FBNEM7UUFMN0MsT0FBRSxHQUFGLEVBQUUsQ0FBWTtRQUNkLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBbUI7UUFDbkMsV0FBTSxHQUFOLE1BQU0sQ0FBbUI7UUFDekIsYUFBUSxHQUFSLFFBQVEsQ0FB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QkFDekIsSUFBSSxDQUFDLGFBQWEsR0FBRyxNQUFNLENBQUM7YUFDN0I7UUFDSCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7OzRHQXRQVSxjQUFjO2dHQUFkLGNBQWMsMmZDdEMzQixpc0ZBdUVBOzRGRGpDYSxjQUFjO2tCQUwxQixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxlQUFlO29CQUN6QixXQUFXLEVBQUUsb0JBQW9CO29CQUNqQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQ7a1FBSVEsSUFBSTtzQkFEVixXQUFXO3VCQUFDLFdBQVc7Z0JBR1IsR0FBRztzQkFBbEIsS0FBSztnQkFDVSxhQUFhO3NCQUE1QixLQUFLO2dCQUNVLGVBQWU7c0JBQTlCLEtBQUs7Z0JBQ1UsYUFBYTtzQkFBNUIsS0FBSztnQkFDVSxTQUFTO3NCQUF4QixLQUFLO2dCQUNVLFFBQVE7c0JBQXZCLEtBQUs7Z0JBQ1UsV0FBVztzQkFBMUIsS0FBSztnQkFFVSxRQUFRO3NCQUF2QixLQUFLO2dCQUNVLE9BQU87c0JBQXRCLEtBQUs7Z0JBQ1UsU0FBUztzQkFBeEIsS0FBSztnQkFFVSxVQUFVO3NCQUF6QixLQUFLO2dCQUlDLFFBQVE7c0JBRGQsWUFBWTt1QkFBQyxJQUFJO2dCQTZDZCxXQUFXO3NCQURkLFdBQVc7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDaGFuZ2VEZXRlY3RvclJlZixcbiAgRWxlbWVudFJlZixcbiAgRXZlbnRFbWl0dGVyLFxuICBLZXlWYWx1ZURpZmZlcnMsXG4gIFJlbmRlcmVyMixcbiAgQ29tcG9uZW50LFxuICBEb0NoZWNrLFxuICBIb3N0QmluZGluZyxcbiAgSW5wdXQsXG4gIEtleVZhbHVlRGlmZmVyLFxuICBPbkRlc3Ryb3ksXG4gIE9uSW5pdCxcbiAgVmlld0NoaWxkcmVuLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdENoZWNrYm94Q2hhbmdlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY2hlY2tib3gnO1xuXG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyB0YWtlVW50aWwgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmltcG9ydCB7IENvbHVtbiB9IGZyb20gJy4uLy4uLy4uL21vZGVscy9jb2x1bW4ubW9kZWwnO1xuaW1wb3J0IHtcbiAgUmVvcmRlckNvbnRyb2xsZXIsXG4gIFJlb3JkZXJQb3NpdGlvbixcbiAgUmVvcmRlclN0cmF0ZWd5XG59IGZyb20gJy4uLy4uLy4uL2NsYXNzZXMvcmVvcmRlci1jb250cm9sbGVyJztcbmltcG9ydCB7IFNlbGVjdGlvbkNvbnRyb2xsZXIgfSBmcm9tICcuLi8uLi8uLi9jbGFzc2VzL3NlbGVjdGlvbi1jb250cm9sbGVyJztcbmltcG9ydCB7IFJvd0FjdGlvbiB9IGZyb20gJy4uLy4uLy4uL21vZGVscy9yb3ctYWN0aW9uLm1vZGVsJztcbmltcG9ydCB7IFJvdyB9IGZyb20gJy4uLy4uLy4uL21vZGVscy9yb3cnO1xuaW1wb3J0IHsgRnNMaXN0RHJhZ2dhYmxlTGlzdERpcmVjdGl2ZSB9IGZyb20gJy4uLy4uLy4uL2RpcmVjdGl2ZXMvZHJhZ2dhYmxlLWxpc3QvZHJhZ2dhYmxlLWxpc3QuZGlyZWN0aXZlJztcblxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdbZnMtbGlzdC1yb3ddJyxcbiAgdGVtcGxhdGVVcmw6ICdyb3cuY29tcG9uZW50Lmh0bWwnLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBGc1Jvd0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgRG9DaGVjaywgT25EZXN0cm95IHtcblxuICBASG9zdEJpbmRpbmcoJ2F0dHIucm9sZScpXG4gIHB1YmxpYyByb2xlID0gJ3Jvdyc7XG5cbiAgQElucHV0KCkgcHVibGljIHJvdzogUm93O1xuICBASW5wdXQoKSBwdWJsaWMgcm93QWN0aW9uc1JhdzogYW55IFtdID0gW107XG4gIEBJbnB1dCgpIHB1YmxpYyBncm91cEFjdGlvbnNSYXc6IGFueSBbXSA9IFtdO1xuICBASW5wdXQoKSBwdWJsaWMgaGFzUm93QWN0aW9ucyA9IGZhbHNlO1xuICBASW5wdXQoKSBwdWJsaWMgcm93RXZlbnRzID0ge307XG4gIEBJbnB1dCgpIHB1YmxpYyByb3dDbGFzcztcbiAgQElucHV0KCkgcHVibGljIHJlc3RvcmVNb2RlID0gZmFsc2U7XG5cbiAgQElucHV0KCkgcHVibGljIHJvd0luZGV4OiBudW1iZXI7XG4gIEBJbnB1dCgpIHB1YmxpYyBjb2x1bW5zOiBDb2x1bW5bXTtcbiAgQElucHV0KCkgcHVibGljIHNlbGVjdGlvbjogU2VsZWN0aW9uQ29udHJvbGxlcjtcblxuICBASW5wdXQoKSBwdWJsaWMgcm93UmVtb3ZlZDogRXZlbnRFbWl0dGVyPGFueT47XG5cblxuICBAVmlld0NoaWxkcmVuKCd0ZCcpXG4gIHB1YmxpYyBjZWxsUmVmcztcblxuICBwdWJsaWMgcmVhZG9ubHkgUmVvcmRlclBvc2l0aW9uID0gUmVvcmRlclBvc2l0aW9uO1xuICBwdWJsaWMgcmVhZG9ubHkgUmVvcmRlclN0cmF0ZWd5ID0gUmVvcmRlclN0cmF0ZWd5O1xuXG4gIHB1YmxpYyByb3dBY3Rpb25zOiBSb3dBY3Rpb25bXSA9IFtdO1xuXG4gIHB1YmxpYyBtZW51Um93QWN0aW9uczogUm93QWN0aW9uW10gPSBbXTtcbiAgcHVibGljIGlubGluZVJvd0FjdGlvbnM6IFJvd0FjdGlvbltdID0gW107XG4gIHB1YmxpYyByZXN0b3JlQWN0aW9uOiBSb3dBY3Rpb247XG5cbiAgcHVibGljIHNlbGVjdGVkID0gZmFsc2U7XG4gIHB1YmxpYyBpbmRldGVybWluYXRlU2VsZWN0ZWQ6IGJvb2xlYW4gfCAnaW5kZXRlcm1pbmF0ZScgPSBmYWxzZTtcblxuICBwcml2YXRlIF9yb3dEaWZmZXI6IEtleVZhbHVlRGlmZmVyPGFueSwgYW55PjtcblxuICBwcml2YXRlIF9ldmVudExpc3RlbmVycyA9IFtdO1xuXG4gIHByaXZhdGUgX2Rlc3Ryb3kkID0gbmV3IFN1YmplY3QoKTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgZWw6IEVsZW1lbnRSZWYsXG4gICAgcHVibGljIHJlb3JkZXJDb250cm9sbGVyOiBSZW9yZGVyQ29udHJvbGxlcixcbiAgICBwcml2YXRlIF9jZFJlZjogQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gICAgcHJpdmF0ZSBfZGlmZmVyczogS2V5VmFsdWVEaWZmZXJzLFxuICAgIHByaXZhdGUgX3JlbmRlcmVyOiBSZW5kZXJlcjIsXG4gICAgcHJpdmF0ZSBfZHJhZ2dhYmxlTGlzdDogRnNMaXN0RHJhZ2dhYmxlTGlzdERpcmVjdGl2ZSxcbiAgKSB7XG4gICAgdGhpcy5fcm93RGlmZmVyID0gX2RpZmZlcnMuZmluZCh7fSkuY3JlYXRlKCk7XG4gIH1cblxuICBwdWJsaWMgZ2V0IGlzR3JvdXBSb3coKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMucm93LmlzR3JvdXA7XG4gIH1cblxuICBwdWJsaWMgZ2V0IGlzQ2hpbGRSb3coKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMucm93LmlzQ2hpbGQ7XG4gIH1cblxuICBwdWJsaWMgZ2V0IGlzR3JvdXBGb290ZXJSb3coKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMucm93LmlzRm9vdGVyO1xuICB9XG5cbiAgQEhvc3RCaW5kaW5nKCdjbGFzcycpXG4gIGdldCByb3dDc3NDbGFzcygpIHtcbiAgICBsZXQgY2xzID0gJ2ZzLWxpc3Qtcm93JztcblxuICAgIGlmICh0aGlzLnJvd0luZGV4ICUgMiAhPT0gMCkgY2xzICs9ICcgZnMtbGlzdC1yb3ctb2RkJztcbiAgICBpZiAodGhpcy5yb3dJbmRleCAlIDIgPT09IDApIGNscyArPSAnIGZzLWxpc3Qtcm93LWV2ZW4nO1xuXG4gICAgaWYgKHRoaXMucm93ICYmIHRoaXMucm93LmlzR3JvdXApIGNscyArPSAnIGZzLWxpc3Qtcm93LWdyb3VwJztcblxuICAgIGlmICh0aGlzLnJvd0NsYXNzKSB7XG4gICAgICBjb25zdCBvcHRpb25zOiBhbnkgPSB7XG4gICAgICAgIGluZGV4OiB0aGlzLnJvd0luZGV4LFxuICAgICAgfTtcblxuICAgICAgaWYgKHRoaXMucm93LmlzR3JvdXApIHtcbiAgICAgICAgb3B0aW9ucy5ncm91cEluZGV4ID0gdGhpcy5yb3cuaW5kZXg7XG4gICAgICB9IGVsc2UgaWYgKHRoaXMucm93LmlzQ2hpbGQpIHtcbiAgICAgICAgb3B0aW9ucy5ncm91cENoaWxkSW5kZXggPSB0aGlzLnJvdy5pbmRleDtcbiAgICAgIH1cblxuICAgICAgY29uc3QgcmVzdWx0Q2xhc3MgPSB0aGlzLnJvd0NsYXNzKHRoaXMucm93LmRhdGEsIG9wdGlvbnMpO1xuXG4gICAgICBpZiAodHlwZW9mIHJlc3VsdENsYXNzID09PSAnc3RyaW5nJykge1xuICAgICAgICBjbHMgKz0gYCAke3Jlc3VsdENsYXNzfWA7XG4gICAgICB9IGVsc2UgaWYgKHR5cGVvZiByZXN1bHRDbGFzcyA9PT0gJ29iamVjdCcpIHtcbiAgICAgICAgY29uc3Qga2V5cyA9IE9iamVjdC5rZXlzKHJlc3VsdENsYXNzKTtcbiAgICAgICAgZm9yIChjb25zdCBrIG9mIGtleXMpIHtcbiAgICAgICAgICBpZiAocmVzdWx0Q2xhc3Nba10gPT09IHRydWUpIGNscyArPSBgICR7a31gO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIGNscztcbiAgfVxuXG4gIHB1YmxpYyBnZXQgZHJhZ0NlbGxWaXNpYmxlKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiAhdGhpcy5yb3cuaXNHcm91cDtcbiAgfVxuXG4gIHB1YmxpYyBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLmluaXRSb3dFdmVudHMoKTtcbiAgICB0aGlzLmluaXRTZWxlY3Rpb24oKTtcblxuICAgIGlmICh0aGlzLnJvdyAmJiB0aGlzLnJvdy5pc0dyb3VwKSB7XG4gICAgICBpZiAodGhpcy5yb3cgJiYgdGhpcy5yb3cuaXNHcm91cCAmJiB0aGlzLmdyb3VwQWN0aW9uc1Jhdykge1xuICAgICAgICB0aGlzLnJvd0FjdGlvbnMgPSB0aGlzLmdyb3VwQWN0aW9uc1Jhdy5tYXAoKGFjdGlvbikgPT4gbmV3IFJvd0FjdGlvbihhY3Rpb24pKTtcblxuICAgICAgICB0aGlzLmZpbHRlckFjdGlvbnNCeUNhdGVnb3JpZXMoKTtcbiAgICAgIH1cbiAgICB9IGVsc2UgaWYgKHRoaXMucm93QWN0aW9uc1Jhdykge1xuICAgICAgdGhpcy5yb3dBY3Rpb25zID0gdGhpcy5yb3dBY3Rpb25zUmF3Lm1hcCgoYWN0aW9uKSA9PiBuZXcgUm93QWN0aW9uKGFjdGlvbikpO1xuXG4gICAgICB0aGlzLmZpbHRlckFjdGlvbnNCeUNhdGVnb3JpZXMoKTtcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgbmdEb0NoZWNrKCkge1xuICAgIGlmICh0aGlzLl9yb3dEaWZmZXIuZGlmZih0aGlzLnJvdykpIHtcbiAgICAgIGlmICh0aGlzLnJvd0FjdGlvbnMpIHtcbiAgICAgICAgdGhpcy5yb3dBY3Rpb25zLmZvckVhY2goKGFjdGlvbikgPT4ge1xuICAgICAgICAgIGFjdGlvbi5jaGVja1Nob3dTdGF0dXModGhpcy5yb3cuZGF0YSwgdGhpcy5yb3dJbmRleCk7XG4gICAgICAgICAgYWN0aW9uLnVwZGF0ZUxpbmsodGhpcy5yb3cuZGF0YSk7XG4gICAgICAgIH0pO1xuICAgICAgICB0aGlzLmZpbHRlckFjdGlvbnNCeUNhdGVnb3JpZXMoKTtcbiAgICAgIH1cblxuICAgICAgdGhpcy5fY2RSZWYubWFya0ZvckNoZWNrKCk7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIG5nT25EZXN0cm95KCkge1xuICAgIHRoaXMuX2V2ZW50TGlzdGVuZXJzLmZvckVhY2goKGxpc3RlbmVyKSA9PiB7IGxpc3RlbmVyKCkgfSk7XG5cbiAgICB0aGlzLl9kZXN0cm95JC5uZXh0KCk7XG4gICAgdGhpcy5fZGVzdHJveSQuY29tcGxldGUoKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBTZWxlY3Qgcm93IGJ5IGNoZWNrYm94XG4gICAqIEBwYXJhbSBldmVudFxuICAgKi9cbiAgcHVibGljIHNlbGVjdFJvdyhldmVudDogTWF0Q2hlY2tib3hDaGFuZ2UpIHtcbiAgICB0aGlzLnNlbGVjdGlvbi5yb3dTZWxlY3Rpb25DaGFuZ2UodGhpcy5yb3csIGV2ZW50LmNoZWNrZWQpO1xuICAgIHRoaXMuX2NkUmVmLm1hcmtGb3JDaGVjaygpO1xuICB9XG5cbiAgLyoqXG4gICAqIFRyYWNrIEJ5IGZvciBpbXByb3ZlIGNoYW5nZSBkZXRlY3Rpb25cbiAgICogQHBhcmFtIGluZGV4XG4gICAqL1xuICBwdWJsaWMgdHJhY2tCeUZuKGluZGV4KSB7XG4gICAgcmV0dXJuIGluZGV4O1xuICB9XG5cbiAgcHVibGljIGRyYWdTdGFydChldmVudCkge1xuICAgIGlmICh0aGlzLnJlb3JkZXJDb250cm9sbGVyLmVuYWJsZWQpIHtcbiAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcblxuICAgICAgdGhpcy5fZHJhZ2dhYmxlTGlzdC5kcmFnU3RhcnQodGhpcy5lbC5uYXRpdmVFbGVtZW50KTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogU2V0IGV2ZW50IGxpc3RlbmVycyBmb3Igcm93XG4gICAqL1xuICBwcml2YXRlIGluaXRSb3dFdmVudHMoKSB7XG4gICAgZm9yIChjb25zdCBldmVudCBpbiB0aGlzLnJvd0V2ZW50cykge1xuICAgICAgaWYgKHRoaXMucm93RXZlbnRzLmhhc093blByb3BlcnR5KGV2ZW50KSkge1xuICAgICAgICBjb25zdCBsaXN0ZW5lciA9IHRoaXMuX3JlbmRlcmVyLmxpc3Rlbih0aGlzLmVsLm5hdGl2ZUVsZW1lbnQsIGV2ZW50LCAoZXZ0KSA9PiB7XG4gICAgICAgICAgLy8gZXZ0LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgLy8gZXZ0LnN0b3BQcm9wYWdhdGlvbigpO1xuXG4gICAgICAgICAgaWYgKCF0aGlzLnJlb3JkZXJDb250cm9sbGVyLmVuYWJsZWQpIHtcbiAgICAgICAgICAgIHRoaXMucm93RXZlbnRzW2V2ZW50XSh7XG4gICAgICAgICAgICAgIGV2ZW50OiBldnQsXG4gICAgICAgICAgICAgIHJvdzogdGhpcy5yb3cuZGF0YSxcbiAgICAgICAgICAgICAgcm93SW5kZXg6IHRoaXMucm93SW5kZXhcbiAgICAgICAgICAgIH0pO1xuICAgICAgICAgIH1cbiAgICAgICAgfSk7XG5cbiAgICAgICAgdGhpcy5fZXZlbnRMaXN0ZW5lcnMucHVzaChsaXN0ZW5lcik7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFN1YnNjcmliZSB0byBzZWxlY3Rpb24gY2hhbmdlIGV2ZW50c1xuICAgKi9cbiAgcHJpdmF0ZSBpbml0U2VsZWN0aW9uKCkge1xuICAgIGlmICh0aGlzLnNlbGVjdGlvbikge1xuXG4gICAgICB0aGlzLnNlbGVjdGVkID0gdGhpcy5yb3cgJiYgdGhpcy5zZWxlY3Rpb24uaXNSb3dTZWxlY3RlZCh0aGlzLnJvdy5kYXRhKTtcblxuICAgICAgdGhpcy5zZWxlY3Rpb24uc2VsZWN0aW9uQ2hhbmdlJFxuICAgICAgICAucGlwZShcbiAgICAgICAgICAvLyAvLyBXb3VsZCBsaWtlIHRvIHJlc3BvbmQgb25seSB3aGVuIGNoZWNrYm94IG9uIHRvcCBpcyBjaGFuZ2VkXG4gICAgICAgICAgLy8gLy8gb3Igd2FzIGNsaWNrZWQgXCJTZWxlY3QgQWxsXCIgaW4gc2VsZWN0aW9uIGRpYWxvZ1xuICAgICAgICAgIC8vIGZpbHRlcigoe3R5cGV9KSA9PiB7XG4gICAgICAgICAgLy8gICByZXR1cm4gdHlwZSA9PT0gU2VsZWN0aW9uQ2hhbmdlVHlwZS5BbGxWaXNpYmxlU2VsZWN0aW9uQ2hhbmdlXG4gICAgICAgICAgLy8gICAgIHx8IHR5cGUgPT09IFNlbGVjdGlvbkNoYW5nZVR5cGUuU2VsZWN0ZWRBbGw7XG4gICAgICAgICAgLy8gfSksXG4gICAgICAgICAgdGFrZVVudGlsKHRoaXMuX2Rlc3Ryb3kkKSxcbiAgICAgICAgKVxuICAgICAgICAuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICB0aGlzLnNlbGVjdGVkID0gdGhpcy5yb3cgJiYgdGhpcy5zZWxlY3Rpb24uaXNSb3dTZWxlY3RlZCh0aGlzLnJvdy5kYXRhKTtcblxuICAgICAgICAgIGlmICh0aGlzLnJvdz8uaXNHcm91cCkge1xuICAgICAgICAgICAgY29uc3QgZ3JvdXBTZWxlY3Rpb24gPSB0aGlzLnNlbGVjdGlvbi5pc0dyb3VwU2VsZWN0ZWQodGhpcy5yb3cpO1xuXG4gICAgICAgICAgICBpZiAoZ3JvdXBTZWxlY3Rpb24gPT09ICdpbmRldGVybWluYXRlJykge1xuICAgICAgICAgICAgICB0aGlzLnNlbGVjdGVkID0gdHJ1ZTtcbiAgICAgICAgICAgICAgdGhpcy5pbmRldGVybWluYXRlU2VsZWN0ZWQgPSB0cnVlO1xuICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgdGhpcy5zZWxlY3RlZCA9IGdyb3VwU2VsZWN0aW9uO1xuICAgICAgICAgICAgICB0aGlzLmluZGV0ZXJtaW5hdGVTZWxlY3RlZCA9IGZhbHNlO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cblxuICAgICAgICAgIHRoaXMuX2NkUmVmLm1hcmtGb3JDaGVjaygpO1xuICAgICAgICB9KTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGZpbHRlckFjdGlvbnNCeUNhdGVnb3JpZXMoKSB7XG4gICAgdGhpcy5tZW51Um93QWN0aW9ucyA9IFtdO1xuICAgIHRoaXMuaW5saW5lUm93QWN0aW9ucyA9IFtdO1xuICAgIHRoaXMucmVzdG9yZUFjdGlvbiA9IG51bGw7XG5cbiAgICB0aGlzLnJvd0FjdGlvbnMuZm9yRWFjaCgoYWN0aW9uKSA9PiB7XG5cbiAgICAgIGlmICghYWN0aW9uLmlzU2hvd24pIHsgcmV0dXJuIH1cblxuICAgICAgaWYgKGFjdGlvbi5tZW51ICYmICFhY3Rpb24ucmVzdG9yZSkge1xuICAgICAgICB0aGlzLm1lbnVSb3dBY3Rpb25zLnB1c2goYWN0aW9uKTtcbiAgICAgIH0gZWxzZSBpZiAoIWFjdGlvbi5tZW51ICYmICFhY3Rpb24ucmVzdG9yZSkge1xuICAgICAgICB0aGlzLmlubGluZVJvd0FjdGlvbnMucHVzaChhY3Rpb24pO1xuICAgICAgfSBlbHNlIGlmIChhY3Rpb24ucmVzdG9yZSkge1xuICAgICAgICB0aGlzLnJlc3RvcmVBY3Rpb24gPSBhY3Rpb247XG4gICAgICB9XG4gICAgfSk7XG4gIH1cbn1cbiIsIjwhLS0gRHJhZyAtLT5cbjxuZy1jb250YWluZXIgKm5nSWY9XCJyZW9yZGVyQ29udHJvbGxlci5sZWZ0UmVvcmRlckFjdGl2YXRlZCQgfCBhc3luY1wiPlxuICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwiZHJhZ0NlbGxcIj48L25nLWNvbnRhaW5lcj5cbjwvbmctY29udGFpbmVyPlxuXG48IS0tIFNlbGVjdGlvbiAtLT5cbjxuZy1jb250YWluZXIgKm5nSWY9XCJzZWxlY3Rpb25cIj5cbiAgPHRkIGNsYXNzPVwiZnMtbGlzdC1jb2wgZnMtbGlzdC1jb2wtc2VsZWN0aW9uXCI+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cIiFyb3cuaXNGb290ZXJcIj5cbiAgICAgIDxtYXQtY2hlY2tib3ggKGNoYW5nZSk9XCJzZWxlY3RSb3coJGV2ZW50KVwiXG4gICAgICAgICAgICAgICAgICAgIFtjaGVja2VkXT1cInNlbGVjdGVkXCJcbiAgICAgICAgICAgICAgICAgICAgW2luZGV0ZXJtaW5hdGVdPVwiaW5kZXRlcm1pbmF0ZVNlbGVjdGVkXCI+XG4gICAgICA8L21hdC1jaGVja2JveD5cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgPC90ZD5cbjwvbmctY29udGFpbmVyPlxuXG48IS0tIENvbnRlbnQgLS0+XG48bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBjb2x1bW4gb2YgY29sdW1uczsgdHJhY2tCeTogdHJhY2tCeUZuOyBsZXQgaXNGaXJzdCA9IGZpcnN0XCI+XG4gIDx0ZCBmcy1jZWxsXG4gICAgICAqbmdJZj1cIihpc0dyb3VwUm93ICYmICFjb2x1bW4uZ3JvdXBIZWFkZXJDb2xzcGFubmVkKVxuICAgICAgICB8fCAoaXNHcm91cEZvb3RlclJvdyAmJiAhY29sdW1uLmdyb3VwRm9vdGVyQ29sc3Bhbm5lZClcbiAgICAgICAgfHwgKCFpc0dyb3VwUm93ICYmICFpc0dyb3VwRm9vdGVyUm93ICYmICFjb2x1bW4uY2VsbENvbHNwYW5uZWQpXCJcbiAgICAgIFtjb2x1bW5dPVwiY29sdW1uXCJcbiAgICAgIFtyb3ddPVwicm93XCJcbiAgICAgIFtyb3dJbmRleF09XCJyb3dJbmRleFwiXG4gICAgICBbY2xhc3NdPVwiKGlzR3JvdXBSb3cgJiYgY29sdW1uLmdyb3VwSGVhZGVyQ29uZmlncy5jbGFzc2VzU3RyaW5nKVxuICAgICAgICB8fCAoaXNHcm91cEZvb3RlclJvdyAmJiBjb2x1bW4uZ3JvdXBGb290ZXJDb25maWdzLmNsYXNzZXNTdHJpbmcpXG4gICAgICAgIHx8ICghaXNHcm91cEZvb3RlclJvdyAmJiBjb2x1bW4uY2VsbENvbmZpZ3MuY2xhc3Nlc1N0cmluZylcIlxuICAgICAgW25nQ2xhc3NdPVwieyAncHJpbWFyeS1jb2wnOiBpc0ZpcnN0IH1cIlxuICAgICAgW2F0dHIuY29sc3Bhbl09XCIoaXNHcm91cFJvdyAmJiBjb2x1bW4uZ3JvdXBIZWFkZXJDb25maWdzLmNvbHNwYW4pXG4gICAgICAgIHx8IChpc0dyb3VwRm9vdGVyUm93ICYmIGNvbHVtbi5ncm91cEZvb3RlckNvbmZpZ3MuY29sc3BhbilcbiAgICAgICAgfHwgY29sdW1uLmNlbGxDb25maWdzLmNvbHNwYW5cIlxuICAgICAgW2F0dHIud2lkdGhdPVwiY29sdW1uLndpZHRoXCJcbiAgPlxuICA8L3RkPlxuPC9uZy1jb250YWluZXI+XG5cbjwhLS0gRHJhZyAtLT5cbjxuZy1jb250YWluZXIgKm5nSWY9XCJyZW9yZGVyQ29udHJvbGxlci5yaWdodFJlb3JkZXJBY3RpdmF0ZWQkIHwgYXN5bmNcIj5cbiAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImRyYWdDZWxsXCI+PC9uZy1jb250YWluZXI+XG48L25nLWNvbnRhaW5lcj5cblxuPCEtLSBSb3cgQWN0aW9ucyAtLT5cbjx0ZCAqbmdJZj1cImhhc1Jvd0FjdGlvbnMgJiYgIShyZW9yZGVyQ29udHJvbGxlci5tYW51YWxSZW9yZGVyQWN0aXZhdGVkJCB8IGFzeW5jKVwiIGNsYXNzPVwiZnMtbGlzdC1jb2wgcm93LWFjdGlvbnNcIj5cbiAgPG5nLWNvbnRhaW5lciAqbmdJZj1cIiFpc0dyb3VwRm9vdGVyUm93XCI+XG4gICAgPGZzLWxpc3Qtcm93LWFjdGlvbnMgW3Jvd109XCJyb3dcIlxuICAgICAgICAgICAgICAgICAgICAgICAgIFtpbmRleF09XCJyb3dJbmRleFwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgW3Jvd0FjdGlvbnNdPVwicm93QWN0aW9uc1wiXG4gICAgICAgICAgICAgICAgICAgICAgICAgW21lbnVSb3dBY3Rpb25zXT1cIm1lbnVSb3dBY3Rpb25zXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICBbaW5saW5lUm93QWN0aW9uc109XCJpbmxpbmVSb3dBY3Rpb25zXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICBbcmVzdG9yZUFjdGlvbl09XCJyZXN0b3JlQWN0aW9uXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICBbcmVzdG9yZU1vZGVdPVwicmVzdG9yZU1vZGVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgIFtyb3dSZW1vdmVkXT1cInJvd1JlbW92ZWRcIlxuICAgID48L2ZzLWxpc3Qtcm93LWFjdGlvbnM+XG4gIDwvbmctY29udGFpbmVyPlxuPC90ZD5cblxuPG5nLXRlbXBsYXRlICNkcmFnQ2VsbD5cbiAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImRyYWdDZWxsVmlzaWJsZSAmJiAhaXNHcm91cEZvb3RlclJvdzsgZWxzZSBlbXB0eUNlbGxcIj5cbiAgICA8dGQgY2xhc3M9XCJmcy1saXN0LWNvbCBkcmFnLWNvbFwiXG4gICAgICAgIChtb3VzZWRvd24pPVwiZHJhZ1N0YXJ0KCRldmVudClcIlxuICAgICAgICAodG91Y2hzdGFydCk9XCJkcmFnU3RhcnQoJGV2ZW50KVwiXG4gICAgPlxuICAgICAgPG1hdC1pY29uPmRyYWdfaGFuZGxlPC9tYXQtaWNvbj5cbiAgICA8L3RkPlxuICA8L25nLWNvbnRhaW5lcj5cbiAgPG5nLXRlbXBsYXRlICNlbXB0eUNlbGw+XG4gICAgPHRkIGNsYXNzPVwiZnMtbGlzdC1jb2wgZHJhZy1jb2xcIj48L3RkPlxuICA8L25nLXRlbXBsYXRlPlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==