@datarailsshared/datarailsshared 1.6.234 → 1.6.238
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.
- package/assets/styles/_storybook-styles.scss +3 -0
- package/assets/styles/_styles.scss +3 -0
- package/datarailsshared-datarailsshared-1.6.238.tgz +0 -0
- package/esm2022/lib/decorators/decorators.mjs +26 -0
- package/esm2022/lib/dr-grid/components/cells/cell-action/cell-action.component.mjs +95 -0
- package/esm2022/lib/dr-grid/components/cells/cell-badge-status/cell-badge-status.component.mjs +49 -0
- package/esm2022/lib/dr-grid/components/cells/cell-button/cell-button.component.mjs +38 -0
- package/esm2022/lib/dr-grid/components/cells/cell-checkbox/cell-checkbox.component.mjs +50 -0
- package/esm2022/lib/dr-grid/components/cells/cell-children-list/cell-children-list.component.mjs +141 -0
- package/esm2022/lib/dr-grid/components/cells/cell-custom-template/cell-custom-template.component.mjs +28 -0
- package/esm2022/lib/dr-grid/components/cells/cell-icon-actions/cell-icon-actions.component.mjs +101 -0
- package/esm2022/lib/dr-grid/components/cells/cell-icon-text-edit/cell-icon-text-edit.component.mjs +130 -0
- package/esm2022/lib/dr-grid/components/cells/cell-link/cell-link.component.mjs +94 -0
- package/esm2022/lib/dr-grid/components/cells/cell-select/cell-select.component.mjs +45 -0
- package/esm2022/lib/dr-grid/components/cells/cell-set-as-default/cell-set-as-default.component.mjs +48 -0
- package/esm2022/lib/dr-grid/components/cells/cell-split-rows/cell-split-rows.component.mjs +99 -0
- package/esm2022/lib/dr-grid/components/cells/cell-toggle/cell-toggle.component.mjs +38 -0
- package/esm2022/lib/dr-grid/components/cells/tbl-header/tbl-header.component.mjs +169 -0
- package/esm2022/lib/dr-grid/components/dr-grid-columns-filter-popover/dr-grid-columns-filter-popover.component.mjs +87 -0
- package/esm2022/lib/dr-grid/components/dr-grid-no-rows/dr-grid-no-rows.component.mjs +10 -0
- package/esm2022/lib/dr-grid/components/dr-grid-pagination/dr-grid-pagination.component.mjs +150 -0
- package/esm2022/lib/dr-grid/components/dr-grid-toolbar/dr-grid-toolbar.component.mjs +194 -0
- package/esm2022/lib/dr-grid/components/tbl-toggle-button-header/tbl-toggle-button-header.component.mjs +46 -0
- package/esm2022/lib/dr-grid/dr-grid.component.mjs +364 -0
- package/esm2022/lib/dr-grid/dr-grid.mjs +26 -0
- package/esm2022/lib/dr-grid/models/dr-grid-events.mjs +9 -0
- package/esm2022/lib/dr-grid/models/dr-grid-theme.mjs +27 -0
- package/esm2022/lib/dr-grid/models/interfaces.mjs +6 -0
- package/esm2022/lib/dr-grid/services/abstract-single-grid.mjs +136 -0
- package/esm2022/lib/dr-grid/services/grid-utils.mjs +53 -0
- package/esm2022/lib/emoji-picker/emoji-picker.component.mjs +2 -2
- package/esm2022/lib/pipes/indeterminate/indeterminate.pipe.mjs +38 -0
- package/esm2022/local-api.mjs +6 -2
- package/fesm2022/datarailsshared-datarailsshared.mjs +2335 -265
- package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
- package/lib/decorators/decorators.d.ts +2 -0
- package/lib/dr-grid/components/cells/cell-action/cell-action.component.d.ts +37 -0
- package/lib/dr-grid/components/cells/cell-badge-status/cell-badge-status.component.d.ts +22 -0
- package/lib/dr-grid/components/cells/cell-button/cell-button.component.d.ts +19 -0
- package/lib/dr-grid/components/cells/cell-checkbox/cell-checkbox.component.d.ts +24 -0
- package/lib/dr-grid/components/cells/cell-children-list/cell-children-list.component.d.ts +21 -0
- package/lib/dr-grid/components/cells/cell-custom-template/cell-custom-template.component.d.ts +23 -0
- package/lib/dr-grid/components/cells/cell-icon-actions/cell-icon-actions.component.d.ts +35 -0
- package/lib/dr-grid/components/cells/cell-icon-text-edit/cell-icon-text-edit.component.d.ts +34 -0
- package/lib/dr-grid/components/cells/cell-link/cell-link.component.d.ts +33 -0
- package/lib/dr-grid/components/cells/cell-select/cell-select.component.d.ts +22 -0
- package/lib/dr-grid/components/cells/cell-set-as-default/cell-set-as-default.component.d.ts +16 -0
- package/lib/dr-grid/components/cells/cell-split-rows/cell-split-rows.component.d.ts +19 -0
- package/lib/dr-grid/components/cells/cell-toggle/cell-toggle.component.d.ts +15 -0
- package/lib/dr-grid/components/cells/tbl-header/tbl-header.component.d.ts +23 -0
- package/lib/dr-grid/components/dr-grid-columns-filter-popover/dr-grid-columns-filter-popover.component.d.ts +18 -0
- package/lib/dr-grid/components/dr-grid-no-rows/dr-grid-no-rows.component.d.ts +6 -0
- package/lib/dr-grid/components/dr-grid-pagination/dr-grid-pagination.component.d.ts +25 -0
- package/lib/dr-grid/components/dr-grid-toolbar/dr-grid-toolbar.component.d.ts +37 -0
- package/lib/dr-grid/components/tbl-toggle-button-header/tbl-toggle-button-header.component.d.ts +31 -0
- package/lib/dr-grid/dr-grid.component.d.ts +86 -0
- package/lib/dr-grid/dr-grid.d.ts +25 -0
- package/lib/dr-grid/models/dr-grid-events.d.ts +7 -0
- package/lib/dr-grid/models/dr-grid-theme.d.ts +3 -0
- package/lib/dr-grid/models/interfaces.d.ts +125 -0
- package/lib/dr-grid/services/abstract-single-grid.d.ts +37 -0
- package/lib/dr-grid/services/grid-utils.d.ts +11 -0
- package/lib/pipes/indeterminate/indeterminate.pipe.d.ts +12 -0
- package/local-api.d.ts +4 -1
- package/package.json +4 -2
- package/styles.css +7995 -0
- package/datarailsshared-datarailsshared-1.6.234.tgz +0 -0
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { Subject } from 'rxjs';
|
|
3
|
+
import { debounceTime, distinctUntilChanged, filter, map } from 'rxjs/operators';
|
|
4
|
+
import { CommonModule } from '@angular/common';
|
|
5
|
+
import { DrInputsModule } from '../../../dr-inputs/dr-inputs.module';
|
|
6
|
+
import { FormsModule } from '@angular/forms';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@angular/common";
|
|
9
|
+
import * as i2 from "@angular/forms";
|
|
10
|
+
import * as i3 from "../../../dr-inputs/dr-input/dr-input.component";
|
|
11
|
+
function DrGridPaginationComponent_span_22_Template(rf, ctx) { if (rf & 1) {
|
|
12
|
+
i0.ɵɵelementStart(0, "span", 16);
|
|
13
|
+
i0.ɵɵtext(1);
|
|
14
|
+
i0.ɵɵelementStart(2, "abbr", 17);
|
|
15
|
+
i0.ɵɵtext(3, "- ");
|
|
16
|
+
i0.ɵɵelementEnd();
|
|
17
|
+
i0.ɵɵtext(4);
|
|
18
|
+
i0.ɵɵelementEnd();
|
|
19
|
+
} if (rf & 2) {
|
|
20
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
21
|
+
i0.ɵɵadvance(1);
|
|
22
|
+
i0.ɵɵtextInterpolate1(" ", ctx_r0.fromRow, " ");
|
|
23
|
+
i0.ɵɵadvance(3);
|
|
24
|
+
i0.ɵɵtextInterpolate2("", ctx_r0.toRow, " of ", ctx_r0.count, " items ");
|
|
25
|
+
} }
|
|
26
|
+
const _c0 = function (a0) { return { disable: a0 }; };
|
|
27
|
+
export class DrGridPaginationComponent {
|
|
28
|
+
constructor() {
|
|
29
|
+
this.perPage = 50;
|
|
30
|
+
this.page = 1;
|
|
31
|
+
this.pageChange = new EventEmitter();
|
|
32
|
+
this.fromRow = 0;
|
|
33
|
+
this.toRow = 0;
|
|
34
|
+
this.inputPager$ = new Subject();
|
|
35
|
+
}
|
|
36
|
+
get showPrev() {
|
|
37
|
+
return this.page <= 1;
|
|
38
|
+
}
|
|
39
|
+
get showNext() {
|
|
40
|
+
return this.totalPages === this.page || this.count < this.perPage;
|
|
41
|
+
}
|
|
42
|
+
set setPage(p) {
|
|
43
|
+
this.page = p;
|
|
44
|
+
}
|
|
45
|
+
set setCount(c) {
|
|
46
|
+
this.count = c;
|
|
47
|
+
}
|
|
48
|
+
ngOnChanges(changes) {
|
|
49
|
+
if (changes.count?.currentValue >= 0) {
|
|
50
|
+
this.updatePagination();
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
ngOnInit() {
|
|
54
|
+
this.inputPager$
|
|
55
|
+
.pipe(filter((f) => f > 0), map((p) => (p <= this.totalPages ? p : this.totalPages)), debounceTime(200), distinctUntilChanged())
|
|
56
|
+
.subscribe((p) => {
|
|
57
|
+
this.goPage(p);
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
goPage(page) {
|
|
61
|
+
this.page = page <= this.totalPages ? page : this.totalPages;
|
|
62
|
+
this.pageChange.emit(this.page);
|
|
63
|
+
this.updatePagination();
|
|
64
|
+
}
|
|
65
|
+
toPage(page) {
|
|
66
|
+
if (page < 0 && this.page === 1) {
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
if (page > this.totalPages) {
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
if (this.page < 0) {
|
|
73
|
+
this.page = 0;
|
|
74
|
+
}
|
|
75
|
+
this.page += page;
|
|
76
|
+
this.pageChange.emit(this.page);
|
|
77
|
+
this.updatePagination();
|
|
78
|
+
}
|
|
79
|
+
updatePagination() {
|
|
80
|
+
this.totalPages = Math.ceil(this.count / this.perPage) || 1;
|
|
81
|
+
const to = this.page * this.perPage;
|
|
82
|
+
this.toRow = to > this.count ? this.count : to;
|
|
83
|
+
this.fromRow = (this.page - 1) * this.perPage + 1;
|
|
84
|
+
}
|
|
85
|
+
/** @nocollapse */ static { this.ɵfac = function DrGridPaginationComponent_Factory(t) { return new (t || DrGridPaginationComponent)(); }; }
|
|
86
|
+
/** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrGridPaginationComponent, selectors: [["dr-grid-pagination"]], inputs: { count: "count", perPage: "perPage", page: "page" }, outputs: { pageChange: "pageChange" }, standalone: true, features: [i0.ɵɵNgOnChangesFeature, i0.ɵɵStandaloneFeature], decls: 23, vars: 17, consts: [[1, "pager-wrapper"], [1, "pager-container"], [1, "pager-control"], ["aria-label", "Page to first", "title", "Page to first", 1, "pager-first", 3, "ngClass", "click"], [1, "triangle"], [1, "bar"], ["aria-label", "Page back", "title", "Page back", 1, "pager-previous", 3, "ngClass", "click"], ["data-analytics", "tables_tbl-pagination_input-0", "aria-label", "Selected page", "min", "1", "required", "", "step", "1", "title", "Selected page", "type", "number", 1, "pager-control-input", 3, "ngModel", "max", "ngModelChange"], [1, "pager-max-pages-number", "ng-binding"], ["title", "of"], ["title", "Page forward", 1, "pager-next", 3, "ngClass", "click"], ["aria-label", "Page to last", "title", "Page to last", 1, "pager-last", 3, "ngClass", "click"], [1, "ng-binding", "ng-scope"], [1, "pager-count-container"], [1, "pager-count"], ["class", "ng-binding", 4, "ngIf"], [1, "ng-binding"], ["title", "through"]], template: function DrGridPaginationComponent_Template(rf, ctx) { if (rf & 1) {
|
|
87
|
+
i0.ɵɵelementStart(0, "div", 0)(1, "div", 1)(2, "div", 2)(3, "div", 3);
|
|
88
|
+
i0.ɵɵlistener("click", function DrGridPaginationComponent_Template_div_click_3_listener() { return ctx.goPage(1); });
|
|
89
|
+
i0.ɵɵelementStart(4, "div", 4);
|
|
90
|
+
i0.ɵɵelement(5, "div", 5);
|
|
91
|
+
i0.ɵɵelementEnd()();
|
|
92
|
+
i0.ɵɵelementStart(6, "div", 6);
|
|
93
|
+
i0.ɵɵlistener("click", function DrGridPaginationComponent_Template_div_click_6_listener() { return ctx.toPage(-1); });
|
|
94
|
+
i0.ɵɵelement(7, "div", 4);
|
|
95
|
+
i0.ɵɵelementEnd();
|
|
96
|
+
i0.ɵɵelementStart(8, "dr-input", 7);
|
|
97
|
+
i0.ɵɵlistener("ngModelChange", function DrGridPaginationComponent_Template_dr_input_ngModelChange_8_listener($event) { return ctx.inputPager$.next($event); })("ngModelChange", function DrGridPaginationComponent_Template_dr_input_ngModelChange_8_listener($event) { return ctx.page = $event; });
|
|
98
|
+
i0.ɵɵelementEnd();
|
|
99
|
+
i0.ɵɵelementStart(9, "span", 8)(10, "abbr", 9);
|
|
100
|
+
i0.ɵɵtext(11, "/ ");
|
|
101
|
+
i0.ɵɵelementEnd();
|
|
102
|
+
i0.ɵɵtext(12);
|
|
103
|
+
i0.ɵɵelementEnd();
|
|
104
|
+
i0.ɵɵelementStart(13, "div", 10);
|
|
105
|
+
i0.ɵɵlistener("click", function DrGridPaginationComponent_Template_div_click_13_listener() { return ctx.toPage(1); });
|
|
106
|
+
i0.ɵɵelement(14, "div", 4);
|
|
107
|
+
i0.ɵɵelementEnd();
|
|
108
|
+
i0.ɵɵelementStart(15, "div", 11);
|
|
109
|
+
i0.ɵɵlistener("click", function DrGridPaginationComponent_Template_div_click_15_listener() { return ctx.goPage(ctx.totalPages); });
|
|
110
|
+
i0.ɵɵelementStart(16, "div", 4);
|
|
111
|
+
i0.ɵɵelement(17, "div", 5);
|
|
112
|
+
i0.ɵɵelementEnd()();
|
|
113
|
+
i0.ɵɵelementStart(18, "span", 12);
|
|
114
|
+
i0.ɵɵtext(19);
|
|
115
|
+
i0.ɵɵelementEnd()()();
|
|
116
|
+
i0.ɵɵelementStart(20, "div", 13)(21, "div", 14);
|
|
117
|
+
i0.ɵɵtemplate(22, DrGridPaginationComponent_span_22_Template, 5, 3, "span", 15);
|
|
118
|
+
i0.ɵɵelementEnd()()();
|
|
119
|
+
} if (rf & 2) {
|
|
120
|
+
i0.ɵɵadvance(3);
|
|
121
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(9, _c0, ctx.showPrev));
|
|
122
|
+
i0.ɵɵadvance(3);
|
|
123
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(11, _c0, ctx.showPrev));
|
|
124
|
+
i0.ɵɵadvance(2);
|
|
125
|
+
i0.ɵɵproperty("ngModel", ctx.page)("max", ctx.totalPages);
|
|
126
|
+
i0.ɵɵadvance(4);
|
|
127
|
+
i0.ɵɵtextInterpolate1("", ctx.totalPages, " ");
|
|
128
|
+
i0.ɵɵadvance(1);
|
|
129
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(13, _c0, ctx.showNext));
|
|
130
|
+
i0.ɵɵadvance(2);
|
|
131
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(15, _c0, ctx.showNext));
|
|
132
|
+
i0.ɵɵadvance(4);
|
|
133
|
+
i0.ɵɵtextInterpolate1("", ctx.perPage, "\u00A0items per page");
|
|
134
|
+
i0.ɵɵadvance(3);
|
|
135
|
+
i0.ɵɵproperty("ngIf", ctx.count > 0);
|
|
136
|
+
} }, dependencies: [CommonModule, i1.NgClass, i1.NgIf, FormsModule, i2.NgControlStatus, i2.RequiredValidator, i2.NgModel, DrInputsModule, i3.DrInputComponent], styles: [".pager-wrapper[_ngcontent-%COMP%]{display:flex;align-items:center;justify-content:space-between;font-size:14px}.pager-control[_ngcontent-%COMP%]{padding:5px 0;display:flex;flex-flow:row nowrap;align-items:center;justify-content:space-between;margin-right:10px;margin-left:10px;min-width:135px}.pager-control[_ngcontent-%COMP%] > div[_ngcontent-%COMP%]{height:25px;min-width:26px;display:inline-block;text-align:center;vertical-align:middle;background:#f0f1f4;border:1px solid #f0f1f4;white-space:nowrap;padding:6px 12px;margin:3px;border-radius:4px;color:#aeabac;cursor:pointer}.pager-control[_ngcontent-%COMP%] > div.disable[_ngcontent-%COMP%]{border:1px solid transparent;cursor:not-allowed;opacity:.65;filter:alpha(opacity=65);box-shadow:none;pointer-events:none}.pager-control[_ngcontent-%COMP%] dr-input[_ngcontent-%COMP%]{width:50px;height:25px;outline:none!important;font-size:12px}.pager-first[_ngcontent-%COMP%] .triangle[_ngcontent-%COMP%], .pager-last[_ngcontent-%COMP%] .triangle[_ngcontent-%COMP%], .pager-next[_ngcontent-%COMP%] .triangle[_ngcontent-%COMP%], .pager-previous[_ngcontent-%COMP%] .triangle[_ngcontent-%COMP%]{width:0;height:0;border-style:solid;border-width:5px 8.7px 5px 0;border-color:transparent #6d6e6f transparent transparent;margin-left:2px}.pager-first[_ngcontent-%COMP%] .triangle[_ngcontent-%COMP%] .bar[_ngcontent-%COMP%], .pager-last[_ngcontent-%COMP%] .triangle[_ngcontent-%COMP%] .bar[_ngcontent-%COMP%], .pager-next[_ngcontent-%COMP%] .triangle[_ngcontent-%COMP%] .bar[_ngcontent-%COMP%], .pager-previous[_ngcontent-%COMP%] .triangle[_ngcontent-%COMP%] .bar[_ngcontent-%COMP%]{width:10px;border-left:2px solid #6d6e6f;margin-top:-6px;height:12px;margin-left:-3px}.pager-last[_ngcontent-%COMP%], .pager-next[_ngcontent-%COMP%]{transform:rotate(180deg)}.pager-row-count-label[_ngcontent-%COMP%]{margin-top:3px}.pager-max-pages-number[_ngcontent-%COMP%]{margin-left:5px;padding-top:3px}input[_ngcontent-%COMP%]::-webkit-outer-spin-button, input[_ngcontent-%COMP%]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number][_ngcontent-%COMP%]{-moz-appearance:textfield}"], changeDetection: 0 }); }
|
|
137
|
+
}
|
|
138
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrGridPaginationComponent, [{
|
|
139
|
+
type: Component,
|
|
140
|
+
args: [{ selector: 'dr-grid-pagination', standalone: true, imports: [CommonModule, FormsModule, DrInputsModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"pager-wrapper\">\n <div class=\"pager-container\">\n <div class=\"pager-control\">\n <div\n (click)=\"goPage(1)\"\n [ngClass]=\"{ disable: showPrev }\"\n aria-label=\"Page to first\"\n class=\"pager-first\"\n title=\"Page to first\">\n <div class=\"triangle\">\n <div class=\"bar\"></div>\n </div>\n </div>\n <div\n (click)=\"toPage(-1)\"\n [ngClass]=\"{ disable: showPrev }\"\n aria-label=\"Page back\"\n class=\"pager-previous\"\n title=\"Page back\">\n <div class=\"triangle\"></div>\n </div>\n <dr-input\n data-analytics=\"tables_tbl-pagination_input-0\"\n (ngModelChange)=\"inputPager$.next($event)\"\n [(ngModel)]=\"page\"\n [max]=\"totalPages\"\n aria-label=\"Selected page\"\n class=\"pager-control-input\"\n min=\"1\"\n required=\"\"\n step=\"1\"\n title=\"Selected page\"\n type=\"number\"></dr-input>\n <span class=\"pager-max-pages-number ng-binding\"> <abbr title=\"of\">/ </abbr>{{ totalPages }} </span>\n <div (click)=\"toPage(1)\" [ngClass]=\"{ disable: showNext }\" class=\"pager-next\" title=\"Page forward\">\n <div class=\"triangle\"></div>\n </div>\n <div\n (click)=\"goPage(totalPages)\"\n [ngClass]=\"{ disable: showNext }\"\n aria-label=\"Page to last\"\n class=\"pager-last\"\n title=\"Page to last\">\n <div class=\"triangle\">\n <div class=\"bar\"></div>\n </div>\n </div>\n <span class=\"ng-binding ng-scope\">{{ perPage }} items per page</span>\n </div>\n </div>\n <div class=\"pager-count-container\">\n <div class=\"pager-count\">\n <span *ngIf=\"count > 0\" class=\"ng-binding\">\n {{ fromRow }} <abbr title=\"through\">- </abbr>{{ toRow }} of {{ count }} items\n </span>\n </div>\n </div>\n</div>\n", styles: [".pager-wrapper{display:flex;align-items:center;justify-content:space-between;font-size:14px}.pager-control{padding:5px 0;display:flex;flex-flow:row nowrap;align-items:center;justify-content:space-between;margin-right:10px;margin-left:10px;min-width:135px}.pager-control>div{height:25px;min-width:26px;display:inline-block;text-align:center;vertical-align:middle;background:#f0f1f4;border:1px solid #f0f1f4;white-space:nowrap;padding:6px 12px;margin:3px;border-radius:4px;color:#aeabac;cursor:pointer}.pager-control>div.disable{border:1px solid transparent;cursor:not-allowed;opacity:.65;filter:alpha(opacity=65);box-shadow:none;pointer-events:none}.pager-control dr-input{width:50px;height:25px;outline:none!important;font-size:12px}.pager-first .triangle,.pager-last .triangle,.pager-next .triangle,.pager-previous .triangle{width:0;height:0;border-style:solid;border-width:5px 8.7px 5px 0;border-color:transparent #6d6e6f transparent transparent;margin-left:2px}.pager-first .triangle .bar,.pager-last .triangle .bar,.pager-next .triangle .bar,.pager-previous .triangle .bar{width:10px;border-left:2px solid #6d6e6f;margin-top:-6px;height:12px;margin-left:-3px}.pager-last,.pager-next{transform:rotate(180deg)}.pager-row-count-label{margin-top:3px}.pager-max-pages-number{margin-left:5px;padding-top:3px}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}\n"] }]
|
|
141
|
+
}], function () { return []; }, { count: [{
|
|
142
|
+
type: Input
|
|
143
|
+
}], perPage: [{
|
|
144
|
+
type: Input
|
|
145
|
+
}], page: [{
|
|
146
|
+
type: Input
|
|
147
|
+
}], pageChange: [{
|
|
148
|
+
type: Output
|
|
149
|
+
}] }); })();
|
|
150
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-grid-pagination.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-grid/components/dr-grid-pagination/dr-grid-pagination.component.ts","../../../../../../../projects/datarailsshared/src/lib/dr-grid/components/dr-grid-pagination/dr-grid-pagination.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, filter, map } from 'rxjs/operators';\nimport { CommonModule } from '@angular/common';\nimport { DrInputsModule } from '../../../dr-inputs/dr-inputs.module';\nimport { FormsModule } from '@angular/forms';\n\n@Component({\n    selector: 'dr-grid-pagination',\n    templateUrl: './dr-grid-pagination.component.html',\n    styleUrls: ['./dr-grid-pagination.component.scss'],\n    standalone: true,\n    imports: [CommonModule, FormsModule, DrInputsModule],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrGridPaginationComponent implements OnInit, OnChanges {\n    @Input() count: number;\n    @Input() perPage = 50;\n    @Input() page = 1;\n    @Output() pageChange = new EventEmitter<number>();\n    totalPages: number;\n    fromRow = 0;\n    toRow = 0;\n    inputPager$ = new Subject();\n\n    constructor() {}\n\n    get showPrev(): boolean {\n        return this.page <= 1;\n    }\n\n    get showNext(): boolean {\n        return this.totalPages === this.page || this.count < this.perPage;\n    }\n\n    set setPage(p) {\n        this.page = p;\n    }\n\n    set setCount(c) {\n        this.count = c;\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.count?.currentValue >= 0) {\n            this.updatePagination();\n        }\n    }\n\n    ngOnInit(): void {\n        this.inputPager$\n            .pipe(\n                filter((f) => f > 0),\n                map((p) => (p <= this.totalPages ? p : this.totalPages)),\n                debounceTime(200),\n                distinctUntilChanged(),\n            )\n            .subscribe((p: number) => {\n                this.goPage(p);\n            });\n    }\n\n    goPage(page: number): void {\n        this.page = page <= this.totalPages ? page : this.totalPages;\n        this.pageChange.emit(this.page);\n        this.updatePagination();\n    }\n\n    toPage(page: number): void {\n        if (page < 0 && this.page === 1) {\n            return;\n        }\n        if (page > this.totalPages) {\n            return;\n        }\n        if (this.page < 0) {\n            this.page = 0;\n        }\n        this.page += page;\n        this.pageChange.emit(this.page);\n        this.updatePagination();\n    }\n\n    updatePagination(): void {\n        this.totalPages = Math.ceil(this.count / this.perPage) || 1;\n        const to = this.page * this.perPage;\n        this.toRow = to > this.count ? this.count : to;\n        this.fromRow = (this.page - 1) * this.perPage + 1;\n    }\n}\n","<div class=\"pager-wrapper\">\n    <div class=\"pager-container\">\n        <div class=\"pager-control\">\n            <div\n                (click)=\"goPage(1)\"\n                [ngClass]=\"{ disable: showPrev }\"\n                aria-label=\"Page to first\"\n                class=\"pager-first\"\n                title=\"Page to first\">\n                <div class=\"triangle\">\n                    <div class=\"bar\"></div>\n                </div>\n            </div>\n            <div\n                (click)=\"toPage(-1)\"\n                [ngClass]=\"{ disable: showPrev }\"\n                aria-label=\"Page back\"\n                class=\"pager-previous\"\n                title=\"Page back\">\n                <div class=\"triangle\"></div>\n            </div>\n            <dr-input\n                data-analytics=\"tables_tbl-pagination_input-0\"\n                (ngModelChange)=\"inputPager$.next($event)\"\n                [(ngModel)]=\"page\"\n                [max]=\"totalPages\"\n                aria-label=\"Selected page\"\n                class=\"pager-control-input\"\n                min=\"1\"\n                required=\"\"\n                step=\"1\"\n                title=\"Selected page\"\n                type=\"number\"></dr-input>\n            <span class=\"pager-max-pages-number ng-binding\"> <abbr title=\"of\">/ </abbr>{{ totalPages }} </span>\n            <div (click)=\"toPage(1)\" [ngClass]=\"{ disable: showNext }\" class=\"pager-next\" title=\"Page forward\">\n                <div class=\"triangle\"></div>\n            </div>\n            <div\n                (click)=\"goPage(totalPages)\"\n                [ngClass]=\"{ disable: showNext }\"\n                aria-label=\"Page to last\"\n                class=\"pager-last\"\n                title=\"Page to last\">\n                <div class=\"triangle\">\n                    <div class=\"bar\"></div>\n                </div>\n            </div>\n            <span class=\"ng-binding ng-scope\">{{ perPage }}&nbsp;items per page</span>\n        </div>\n    </div>\n    <div class=\"pager-count-container\">\n        <div class=\"pager-count\">\n            <span *ngIf=\"count > 0\" class=\"ng-binding\">\n                {{ fromRow }} <abbr title=\"through\">- </abbr>{{ toRow }} of {{ count }} items\n            </span>\n        </div>\n    </div>\n</div>\n"]}
|
|
@@ -0,0 +1,194 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
|
+
};
|
|
10
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
|
11
|
+
import { CommonModule } from '@angular/common';
|
|
12
|
+
import { FormsModule } from '@angular/forms';
|
|
13
|
+
import { ActivatedRoute, NavigationEnd, Router } from '@angular/router';
|
|
14
|
+
import { Subject } from 'rxjs';
|
|
15
|
+
import { filter, takeUntil } from 'rxjs/operators';
|
|
16
|
+
import { DrPopoverModule } from '../../../dr-popover/dr-popover.module';
|
|
17
|
+
import { DrTooltipModule } from '../../../dr-tooltip/dr-tooltip.module';
|
|
18
|
+
import { DrInputsModule } from '../../../dr-inputs/dr-inputs.module';
|
|
19
|
+
import { DrDropdownModule } from '../../../dr-dropdown/dr-dropdown.module';
|
|
20
|
+
import { Debounce } from '../../../decorators/decorators';
|
|
21
|
+
import { DrGridColumnsFilterPopoverComponent } from '../dr-grid-columns-filter-popover/dr-grid-columns-filter-popover.component';
|
|
22
|
+
import * as i0 from "@angular/core";
|
|
23
|
+
import * as i1 from "@angular/router";
|
|
24
|
+
import * as i2 from "@angular/common";
|
|
25
|
+
import * as i3 from "@angular/forms";
|
|
26
|
+
import * as i4 from "../../../dr-inputs/dr-input/dr-input.component";
|
|
27
|
+
import * as i5 from "../../../dr-inputs/button/button.component";
|
|
28
|
+
import * as i6 from "../../../dr-dropdown/dr-dropdown.directive";
|
|
29
|
+
import * as i7 from "../../../dr-tooltip/dr-tooltip.directive";
|
|
30
|
+
import * as i8 from "../../../dr-popover/dr-popover.directive";
|
|
31
|
+
function DrGridToolbarComponent_dr_input_3_Template(rf, ctx) { if (rf & 1) {
|
|
32
|
+
const _r6 = i0.ɵɵgetCurrentView();
|
|
33
|
+
i0.ɵɵelementStart(0, "dr-input", 7);
|
|
34
|
+
i0.ɵɵlistener("ngModelChange", function DrGridToolbarComponent_dr_input_3_Template_dr_input_ngModelChange_0_listener($event) { i0.ɵɵrestoreView(_r6); const ctx_r5 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r5.searchInput = $event); })("ngModelChange", function DrGridToolbarComponent_dr_input_3_Template_dr_input_ngModelChange_0_listener() { i0.ɵɵrestoreView(_r6); const ctx_r7 = i0.ɵɵnextContext(); ctx_r7.searchDone = false; return i0.ɵɵresetView(ctx_r7.reactiveSearch && ctx_r7.onSearch(ctx_r7.searchInput)); })("search", function DrGridToolbarComponent_dr_input_3_Template_dr_input_search_0_listener($event) { $event.stopPropagation(); return $event.preventDefault(); })("blur", function DrGridToolbarComponent_dr_input_3_Template_dr_input_blur_0_listener() { i0.ɵɵrestoreView(_r6); const ctx_r9 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r9.searchDone ? null : ctx_r9.onSearch(ctx_r9.searchInput)); })("searchHandler", function DrGridToolbarComponent_dr_input_3_Template_dr_input_searchHandler_0_listener() { i0.ɵɵrestoreView(_r6); const ctx_r10 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r10.onSearch(ctx_r10.searchInput)); })("clearHandler", function DrGridToolbarComponent_dr_input_3_Template_dr_input_clearHandler_0_listener() { i0.ɵɵrestoreView(_r6); const ctx_r11 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r11.onSearch(null)); })("keyup.enter", function DrGridToolbarComponent_dr_input_3_Template_dr_input_keyup_enter_0_listener() { i0.ɵɵrestoreView(_r6); const ctx_r12 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r12.searchDone ? null : ctx_r12.onSearch(ctx_r12.searchInput)); });
|
|
35
|
+
i0.ɵɵelementEnd();
|
|
36
|
+
} if (rf & 2) {
|
|
37
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
38
|
+
i0.ɵɵproperty("ngModel", ctx_r0.searchInput)("searchMini", ctx_r0.searchMini)("clearable", true);
|
|
39
|
+
} }
|
|
40
|
+
const _c0 = function (a0, a1) { return { gridApi: a0, gridColumnApi: a1 }; };
|
|
41
|
+
function DrGridToolbarComponent_dr_button_4_Template(rf, ctx) { if (rf & 1) {
|
|
42
|
+
i0.ɵɵelement(0, "dr-button", 8);
|
|
43
|
+
} if (rf & 2) {
|
|
44
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
45
|
+
i0.ɵɵproperty("drPopover", ctx_r1.ColumnsFilterPopover)("drPopoverPosition", "bottom-right")("drPopoverContext", i0.ɵɵpureFunction2(3, _c0, ctx_r1.gridApi, ctx_r1.gridColumnApi));
|
|
46
|
+
} }
|
|
47
|
+
function DrGridToolbarComponent_dr_button_5_Template(rf, ctx) { if (rf & 1) {
|
|
48
|
+
const _r14 = i0.ɵɵgetCurrentView();
|
|
49
|
+
i0.ɵɵelementStart(0, "dr-button", 9);
|
|
50
|
+
i0.ɵɵlistener("click", function DrGridToolbarComponent_dr_button_5_Template_dr_button_click_0_listener($event) { i0.ɵɵrestoreView(_r14); const ctx_r13 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r13.onContextMenuClick($event)); });
|
|
51
|
+
i0.ɵɵelementEnd();
|
|
52
|
+
} if (rf & 2) {
|
|
53
|
+
const ctx_r2 = i0.ɵɵnextContext();
|
|
54
|
+
i0.ɵɵproperty("drTooltip", ctx_r2.menuActionsTooltip)("drDropdown", ctx_r2.menuActions);
|
|
55
|
+
} }
|
|
56
|
+
function DrGridToolbarComponent_dr_button_7_Template(rf, ctx) { if (rf & 1) {
|
|
57
|
+
const _r16 = i0.ɵɵgetCurrentView();
|
|
58
|
+
i0.ɵɵelementStart(0, "dr-button", 10);
|
|
59
|
+
i0.ɵɵlistener("click", function DrGridToolbarComponent_dr_button_7_Template_dr_button_click_0_listener() { i0.ɵɵrestoreView(_r16); const ctx_r15 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r15.refresh.emit()); });
|
|
60
|
+
i0.ɵɵelementEnd();
|
|
61
|
+
} }
|
|
62
|
+
function DrGridToolbarComponent_dr_button_8_Template(rf, ctx) { if (rf & 1) {
|
|
63
|
+
const _r18 = i0.ɵɵgetCurrentView();
|
|
64
|
+
i0.ɵɵelementStart(0, "dr-button", 11);
|
|
65
|
+
i0.ɵɵlistener("click", function DrGridToolbarComponent_dr_button_8_Template_dr_button_click_0_listener() { i0.ɵɵrestoreView(_r18); const ctx_r17 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r17.onExport()); });
|
|
66
|
+
i0.ɵɵelementEnd();
|
|
67
|
+
} }
|
|
68
|
+
const _c1 = ["*"];
|
|
69
|
+
export class DrGridToolbarComponent {
|
|
70
|
+
constructor(router, activatedRoute) {
|
|
71
|
+
this.router = router;
|
|
72
|
+
this.activatedRoute = activatedRoute;
|
|
73
|
+
this.destroy$ = new Subject();
|
|
74
|
+
this.showSearch = true;
|
|
75
|
+
this.searchMini = true;
|
|
76
|
+
this.reactiveSearch = false;
|
|
77
|
+
this.searchInput = '';
|
|
78
|
+
this.searchDone = true;
|
|
79
|
+
this.search = new EventEmitter();
|
|
80
|
+
this.showColumnSettings = false;
|
|
81
|
+
this.ColumnsFilterPopover = DrGridColumnsFilterPopoverComponent;
|
|
82
|
+
this.menuActionsTooltip = 'Action';
|
|
83
|
+
this.menuActionsClick = new EventEmitter();
|
|
84
|
+
this.showRefresh = false;
|
|
85
|
+
this.refresh = new EventEmitter();
|
|
86
|
+
}
|
|
87
|
+
ngOnInit() {
|
|
88
|
+
this.searchInput = this.activatedRoute.snapshot?.queryParams?.search || '';
|
|
89
|
+
this.updateTitleIfNeeded();
|
|
90
|
+
this.router.events
|
|
91
|
+
.pipe(takeUntil(this.destroy$), filter((event) => event instanceof NavigationEnd))
|
|
92
|
+
.subscribe(() => this.updateTitleIfNeeded(true));
|
|
93
|
+
}
|
|
94
|
+
updateTitleIfNeeded(routeTitlePriority = false) {
|
|
95
|
+
const titleFromRoute = this.activatedRoute.snapshot?.data?.title || this.activatedRoute.snapshot?.data?.breadcrumb;
|
|
96
|
+
this.title = routeTitlePriority ? titleFromRoute || this.title : this.title || titleFromRoute;
|
|
97
|
+
}
|
|
98
|
+
onSearch($event) {
|
|
99
|
+
this.search.emit($event);
|
|
100
|
+
this.searchDone = true;
|
|
101
|
+
}
|
|
102
|
+
onExport() {
|
|
103
|
+
if (this.csvParams.fromServer) {
|
|
104
|
+
this.csvParams.request();
|
|
105
|
+
}
|
|
106
|
+
else {
|
|
107
|
+
this.gridApi.exportDataAsCsv(this.csvParams);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
onContextMenuClick($event) {
|
|
111
|
+
this.menuActionsClick.emit($event);
|
|
112
|
+
}
|
|
113
|
+
ngOnDestroy() {
|
|
114
|
+
this.destroy$.next();
|
|
115
|
+
this.destroy$.complete();
|
|
116
|
+
}
|
|
117
|
+
/** @nocollapse */ static { this.ɵfac = function DrGridToolbarComponent_Factory(t) { return new (t || DrGridToolbarComponent)(i0.ɵɵdirectiveInject(i1.Router), i0.ɵɵdirectiveInject(i1.ActivatedRoute)); }; }
|
|
118
|
+
/** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrGridToolbarComponent, selectors: [["dr-grid-toolbar"]], inputs: { gridApi: "gridApi", gridColumnApi: "gridColumnApi", title: "title", showSearch: "showSearch", searchMini: "searchMini", reactiveSearch: "reactiveSearch", showColumnSettings: "showColumnSettings", menuActions: "menuActions", menuActionsTooltip: "menuActionsTooltip", showRefresh: "showRefresh", csvParams: "csvParams" }, outputs: { search: "search", menuActionsClick: "menuActionsClick", refresh: "refresh" }, standalone: true, features: [i0.ɵɵStandaloneFeature], ngContentSelectors: _c1, decls: 9, vars: 6, consts: [["data-test", "table_title", 1, "dr-grid-toolbar__title"], [1, "dr-grid-toolbar__actions"], ["class", "dr-grid-toolbar__actions__search", "data-analytics", "admin_admin-table-header_input-0", "type", "search", 3, "ngModel", "searchMini", "clearable", "ngModelChange", "search", "blur", "searchHandler", "clearHandler", "keyup.enter", 4, "ngIf"], ["class", "dr-grid-toolbar__actions__columns-settings", "data-analytics", "admin_admin-table-header_button-1", "theme", "icon-primary", "drTooltip", "Columns Menu", "drTooltipPosition", "top", "icon", "dr-icon-bars", 3, "drPopover", "drPopoverPosition", "drPopoverContext", 4, "ngIf"], ["class", "dr-grid-toolbar__actions__more-actions", "drTooltipPosition", "top", "data-analytics", "admin_admin-table-header_button-3", "theme", "icon-primary", "drDropdownPosition", "bottom-right", "icon", "dr-icon-more", 3, "drTooltip", "drDropdown", "click", 4, "ngIf"], ["class", "dr-grid-toolbar__actions__refresh", "data-analytics", "admin_admin-table-header_button-5", "theme", "icon-secondary", "icon", "dr-icon-refresh", "drTooltip", "Refresh", "drTooltipPosition", "top", 3, "click", 4, "ngIf"], ["class", "dr-grid-toolbar__actions__export", "drTooltip", "Export table to csv file", "drTooltipPosition", "top-right", "data-analytics", "admin_admin-table-header_button-6", "theme", "icon-secondary", "icon", "dr-icon-export-excel", 3, "click", 4, "ngIf"], ["data-analytics", "admin_admin-table-header_input-0", "type", "search", 1, "dr-grid-toolbar__actions__search", 3, "ngModel", "searchMini", "clearable", "ngModelChange", "search", "blur", "searchHandler", "clearHandler", "keyup.enter"], ["data-analytics", "admin_admin-table-header_button-1", "theme", "icon-primary", "drTooltip", "Columns Menu", "drTooltipPosition", "top", "icon", "dr-icon-bars", 1, "dr-grid-toolbar__actions__columns-settings", 3, "drPopover", "drPopoverPosition", "drPopoverContext"], ["drTooltipPosition", "top", "data-analytics", "admin_admin-table-header_button-3", "theme", "icon-primary", "drDropdownPosition", "bottom-right", "icon", "dr-icon-more", 1, "dr-grid-toolbar__actions__more-actions", 3, "drTooltip", "drDropdown", "click"], ["data-analytics", "admin_admin-table-header_button-5", "theme", "icon-secondary", "icon", "dr-icon-refresh", "drTooltip", "Refresh", "drTooltipPosition", "top", 1, "dr-grid-toolbar__actions__refresh", 3, "click"], ["drTooltip", "Export table to csv file", "drTooltipPosition", "top-right", "data-analytics", "admin_admin-table-header_button-6", "theme", "icon-secondary", "icon", "dr-icon-export-excel", 1, "dr-grid-toolbar__actions__export", 3, "click"]], template: function DrGridToolbarComponent_Template(rf, ctx) { if (rf & 1) {
|
|
119
|
+
i0.ɵɵprojectionDef();
|
|
120
|
+
i0.ɵɵelementStart(0, "div", 0);
|
|
121
|
+
i0.ɵɵtext(1);
|
|
122
|
+
i0.ɵɵelementEnd();
|
|
123
|
+
i0.ɵɵelementStart(2, "div", 1);
|
|
124
|
+
i0.ɵɵtemplate(3, DrGridToolbarComponent_dr_input_3_Template, 1, 3, "dr-input", 2);
|
|
125
|
+
i0.ɵɵtemplate(4, DrGridToolbarComponent_dr_button_4_Template, 1, 6, "dr-button", 3);
|
|
126
|
+
i0.ɵɵtemplate(5, DrGridToolbarComponent_dr_button_5_Template, 1, 2, "dr-button", 4);
|
|
127
|
+
i0.ɵɵprojection(6);
|
|
128
|
+
i0.ɵɵtemplate(7, DrGridToolbarComponent_dr_button_7_Template, 1, 0, "dr-button", 5);
|
|
129
|
+
i0.ɵɵtemplate(8, DrGridToolbarComponent_dr_button_8_Template, 1, 0, "dr-button", 6);
|
|
130
|
+
i0.ɵɵelementEnd();
|
|
131
|
+
} if (rf & 2) {
|
|
132
|
+
i0.ɵɵadvance(1);
|
|
133
|
+
i0.ɵɵtextInterpolate(ctx.title);
|
|
134
|
+
i0.ɵɵadvance(2);
|
|
135
|
+
i0.ɵɵproperty("ngIf", ctx.showSearch);
|
|
136
|
+
i0.ɵɵadvance(1);
|
|
137
|
+
i0.ɵɵproperty("ngIf", ctx.showColumnSettings);
|
|
138
|
+
i0.ɵɵadvance(1);
|
|
139
|
+
i0.ɵɵproperty("ngIf", ctx.menuActions);
|
|
140
|
+
i0.ɵɵadvance(2);
|
|
141
|
+
i0.ɵɵproperty("ngIf", ctx.showRefresh);
|
|
142
|
+
i0.ɵɵadvance(1);
|
|
143
|
+
i0.ɵɵproperty("ngIf", ctx.csvParams);
|
|
144
|
+
} }, dependencies: [CommonModule, i2.NgIf, FormsModule, i3.NgControlStatus, i3.NgModel, DrInputsModule, i4.DrInputComponent, i5.DrButtonComponent, DrDropdownModule, i6.DrDropdownDirective, DrTooltipModule, i7.DrTooltipDirective, DrPopoverModule, i8.DrPopoverDirective], styles: ["[_nghost-%COMP%]{display:flex;align-items:center}[_nghost-%COMP%] .dr-grid-toolbar__title[_ngcontent-%COMP%]{flex-grow:1;font-size:16px;line-height:24px;font-weight:500}[_nghost-%COMP%] .dr-grid-toolbar__actions[_ngcontent-%COMP%]{display:flex;align-items:center;gap:8px;flex-shrink:0}[_nghost-%COMP%] .dr-grid-toolbar__actions__columns-settings[_ngcontent-%COMP%]{order:20}[_nghost-%COMP%] .dr-grid-toolbar__actions__more-actions[_ngcontent-%COMP%]{order:30}[_nghost-%COMP%] .dr-grid-toolbar__actions__refresh[_ngcontent-%COMP%]{order:40}[_nghost-%COMP%] .dr-grid-toolbar__actions__export[_ngcontent-%COMP%]{order:50}[_nghost-%COMP%] .table-view-form__add-new-integration-btn.icon-primary button{width:unset!important;padding:4px 16px 4px 8px!important}"], changeDetection: 0 }); }
|
|
145
|
+
}
|
|
146
|
+
__decorate([
|
|
147
|
+
Debounce(100),
|
|
148
|
+
__metadata("design:type", Function),
|
|
149
|
+
__metadata("design:paramtypes", [String]),
|
|
150
|
+
__metadata("design:returntype", void 0)
|
|
151
|
+
], DrGridToolbarComponent.prototype, "onSearch", null);
|
|
152
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrGridToolbarComponent, [{
|
|
153
|
+
type: Component,
|
|
154
|
+
args: [{ selector: 'dr-grid-toolbar', standalone: true, imports: [
|
|
155
|
+
CommonModule,
|
|
156
|
+
FormsModule,
|
|
157
|
+
DrInputsModule,
|
|
158
|
+
DrDropdownModule,
|
|
159
|
+
DrTooltipModule,
|
|
160
|
+
DrPopoverModule,
|
|
161
|
+
DrGridColumnsFilterPopoverComponent,
|
|
162
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"dr-grid-toolbar__title\" data-test=\"table_title\">{{ title }}</div>\n<div class=\"dr-grid-toolbar__actions\">\n <dr-input\n class=\"dr-grid-toolbar__actions__search\"\n data-analytics=\"admin_admin-table-header_input-0\"\n *ngIf=\"showSearch\"\n [(ngModel)]=\"searchInput\"\n (ngModelChange)=\"searchDone = false; reactiveSearch && onSearch(this.searchInput)\"\n type=\"search\"\n (search)=\"$event.stopPropagation(); $event.preventDefault()\"\n (blur)=\"searchDone ? null : onSearch(this.searchInput)\"\n (searchHandler)=\"onSearch(this.searchInput)\"\n (clearHandler)=\"onSearch(null)\"\n (keyup.enter)=\"searchDone ? null : onSearch(this.searchInput)\"\n [searchMini]=\"searchMini\"\n [clearable]=\"true\">\n </dr-input>\n <dr-button\n *ngIf=\"showColumnSettings\"\n class=\"dr-grid-toolbar__actions__columns-settings\"\n data-analytics=\"admin_admin-table-header_button-1\"\n theme=\"icon-primary\"\n drTooltip=\"Columns Menu\"\n drTooltipPosition=\"top\"\n [drPopover]=\"ColumnsFilterPopover\"\n [drPopoverPosition]=\"'bottom-right'\"\n [drPopoverContext]=\"{ gridApi, gridColumnApi }\"\n icon=\"dr-icon-bars\">\n </dr-button>\n <dr-button\n *ngIf=\"menuActions\"\n class=\"dr-grid-toolbar__actions__more-actions\"\n [drTooltip]=\"menuActionsTooltip\"\n drTooltipPosition=\"top\"\n data-analytics=\"admin_admin-table-header_button-3\"\n theme=\"icon-primary\"\n (click)=\"onContextMenuClick($event)\"\n [drDropdown]=\"menuActions\"\n drDropdownPosition=\"bottom-right\"\n icon=\"dr-icon-more\">\n </dr-button>\n <ng-content></ng-content>\n <dr-button\n *ngIf=\"showRefresh\"\n class=\"dr-grid-toolbar__actions__refresh\"\n data-analytics=\"admin_admin-table-header_button-5\"\n theme=\"icon-secondary\"\n icon=\"dr-icon-refresh\"\n drTooltip=\"Refresh\"\n drTooltipPosition=\"top\"\n (click)=\"refresh.emit()\">\n </dr-button>\n <dr-button\n *ngIf=\"csvParams\"\n class=\"dr-grid-toolbar__actions__export\"\n drTooltip=\"Export table to csv file\"\n drTooltipPosition=\"top-right\"\n data-analytics=\"admin_admin-table-header_button-6\"\n theme=\"icon-secondary\"\n icon=\"dr-icon-export-excel\"\n (click)=\"onExport()\">\n </dr-button>\n</div>\n", styles: [":host{display:flex;align-items:center}:host .dr-grid-toolbar__title{flex-grow:1;font-size:16px;line-height:24px;font-weight:500}:host .dr-grid-toolbar__actions{display:flex;align-items:center;gap:8px;flex-shrink:0}:host .dr-grid-toolbar__actions__columns-settings{order:20}:host .dr-grid-toolbar__actions__more-actions{order:30}:host .dr-grid-toolbar__actions__refresh{order:40}:host .dr-grid-toolbar__actions__export{order:50}:host ::ng-deep .table-view-form__add-new-integration-btn.icon-primary button{width:unset!important;padding:4px 16px 4px 8px!important}\n"] }]
|
|
163
|
+
}], function () { return [{ type: i1.Router }, { type: i1.ActivatedRoute }]; }, { gridApi: [{
|
|
164
|
+
type: Input,
|
|
165
|
+
args: [{ required: true }]
|
|
166
|
+
}], gridColumnApi: [{
|
|
167
|
+
type: Input,
|
|
168
|
+
args: [{ required: true }]
|
|
169
|
+
}], title: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], showSearch: [{
|
|
172
|
+
type: Input
|
|
173
|
+
}], searchMini: [{
|
|
174
|
+
type: Input
|
|
175
|
+
}], reactiveSearch: [{
|
|
176
|
+
type: Input
|
|
177
|
+
}], search: [{
|
|
178
|
+
type: Output
|
|
179
|
+
}], showColumnSettings: [{
|
|
180
|
+
type: Input
|
|
181
|
+
}], menuActions: [{
|
|
182
|
+
type: Input
|
|
183
|
+
}], menuActionsTooltip: [{
|
|
184
|
+
type: Input
|
|
185
|
+
}], menuActionsClick: [{
|
|
186
|
+
type: Output
|
|
187
|
+
}], showRefresh: [{
|
|
188
|
+
type: Input
|
|
189
|
+
}], refresh: [{
|
|
190
|
+
type: Output
|
|
191
|
+
}], csvParams: [{
|
|
192
|
+
type: Input
|
|
193
|
+
}], onSearch: [] }); })();
|
|
194
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-grid-toolbar.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-grid/components/dr-grid-toolbar/dr-grid-toolbar.component.ts","../../../../../../../projects/datarailsshared/src/lib/dr-grid/components/dr-grid-toolbar/dr-grid-toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { ActivatedRoute, NavigationEnd, Router } from '@angular/router';\nimport { Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\nimport { GridApi, GridColumnApi, IGridCsvExportParams } from '../../models/interfaces';\nimport { DrPopoverModule } from '../../../dr-popover/dr-popover.module';\nimport { DrTooltipModule } from '../../../dr-tooltip/dr-tooltip.module';\nimport { DrInputsModule } from '../../../dr-inputs/dr-inputs.module';\nimport { DrDropdownModule } from '../../../dr-dropdown/dr-dropdown.module';\nimport { IDropdownItem } from '../../../models/dropdown';\nimport { Debounce } from '../../../decorators/decorators';\nimport { DrGridColumnsFilterPopoverComponent } from '../dr-grid-columns-filter-popover/dr-grid-columns-filter-popover.component';\n\n@Component({\n    selector: 'dr-grid-toolbar',\n    templateUrl: './dr-grid-toolbar.component.html',\n    styleUrls: ['./dr-grid-toolbar.component.scss'],\n    standalone: true,\n    imports: [\n        CommonModule,\n        FormsModule,\n        DrInputsModule,\n        DrDropdownModule,\n        DrTooltipModule,\n        DrPopoverModule,\n        DrGridColumnsFilterPopoverComponent,\n    ],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrGridToolbarComponent implements OnInit, OnDestroy {\n    private readonly destroy$ = new Subject<void>();\n    @Input({ required: true }) gridApi: GridApi;\n    @Input({ required: true }) gridColumnApi: GridColumnApi;\n\n    @Input() title: string;\n\n    @Input() showSearch = true;\n    @Input() searchMini = true;\n    @Input() reactiveSearch = false;\n    searchInput = '';\n    searchDone = true;\n    @Output() search = new EventEmitter<string>();\n\n    @Input() showColumnSettings = false;\n    ColumnsFilterPopover = DrGridColumnsFilterPopoverComponent;\n\n    @Input() menuActions: IDropdownItem<unknown>[];\n    @Input() menuActionsTooltip = 'Action';\n    @Output() menuActionsClick = new EventEmitter<Event>();\n\n    @Input() showRefresh = false;\n    @Output() refresh = new EventEmitter<null>();\n\n    @Input() csvParams: IGridCsvExportParams;\n\n    constructor(\n        private router: Router,\n        private activatedRoute: ActivatedRoute,\n    ) {}\n\n    ngOnInit(): void {\n        this.searchInput = this.activatedRoute.snapshot?.queryParams?.search || '';\n        this.updateTitleIfNeeded();\n        this.router.events\n            .pipe(\n                takeUntil(this.destroy$),\n                filter((event) => event instanceof NavigationEnd),\n            )\n            .subscribe(() => this.updateTitleIfNeeded(true));\n    }\n\n    private updateTitleIfNeeded(routeTitlePriority = false) {\n        const titleFromRoute = this.activatedRoute.snapshot?.data?.title || this.activatedRoute.snapshot?.data?.breadcrumb;\n        this.title = routeTitlePriority ? titleFromRoute || this.title : this.title || titleFromRoute;\n    }\n\n    @Debounce(100)\n    public onSearch($event: string) {\n        this.search.emit($event);\n        this.searchDone = true;\n    }\n\n    onExport() {\n        if (this.csvParams.fromServer) {\n            this.csvParams.request();\n        } else {\n            this.gridApi.exportDataAsCsv(this.csvParams);\n        }\n    }\n\n    onContextMenuClick($event: any): void {\n        this.menuActionsClick.emit($event);\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n","<div class=\"dr-grid-toolbar__title\" data-test=\"table_title\">{{ title }}</div>\n<div class=\"dr-grid-toolbar__actions\">\n    <dr-input\n        class=\"dr-grid-toolbar__actions__search\"\n        data-analytics=\"admin_admin-table-header_input-0\"\n        *ngIf=\"showSearch\"\n        [(ngModel)]=\"searchInput\"\n        (ngModelChange)=\"searchDone = false; reactiveSearch && onSearch(this.searchInput)\"\n        type=\"search\"\n        (search)=\"$event.stopPropagation(); $event.preventDefault()\"\n        (blur)=\"searchDone ? null : onSearch(this.searchInput)\"\n        (searchHandler)=\"onSearch(this.searchInput)\"\n        (clearHandler)=\"onSearch(null)\"\n        (keyup.enter)=\"searchDone ? null : onSearch(this.searchInput)\"\n        [searchMini]=\"searchMini\"\n        [clearable]=\"true\">\n    </dr-input>\n    <dr-button\n        *ngIf=\"showColumnSettings\"\n        class=\"dr-grid-toolbar__actions__columns-settings\"\n        data-analytics=\"admin_admin-table-header_button-1\"\n        theme=\"icon-primary\"\n        drTooltip=\"Columns Menu\"\n        drTooltipPosition=\"top\"\n        [drPopover]=\"ColumnsFilterPopover\"\n        [drPopoverPosition]=\"'bottom-right'\"\n        [drPopoverContext]=\"{ gridApi, gridColumnApi }\"\n        icon=\"dr-icon-bars\">\n    </dr-button>\n    <dr-button\n        *ngIf=\"menuActions\"\n        class=\"dr-grid-toolbar__actions__more-actions\"\n        [drTooltip]=\"menuActionsTooltip\"\n        drTooltipPosition=\"top\"\n        data-analytics=\"admin_admin-table-header_button-3\"\n        theme=\"icon-primary\"\n        (click)=\"onContextMenuClick($event)\"\n        [drDropdown]=\"menuActions\"\n        drDropdownPosition=\"bottom-right\"\n        icon=\"dr-icon-more\">\n    </dr-button>\n    <ng-content></ng-content>\n    <dr-button\n        *ngIf=\"showRefresh\"\n        class=\"dr-grid-toolbar__actions__refresh\"\n        data-analytics=\"admin_admin-table-header_button-5\"\n        theme=\"icon-secondary\"\n        icon=\"dr-icon-refresh\"\n        drTooltip=\"Refresh\"\n        drTooltipPosition=\"top\"\n        (click)=\"refresh.emit()\">\n    </dr-button>\n    <dr-button\n        *ngIf=\"csvParams\"\n        class=\"dr-grid-toolbar__actions__export\"\n        drTooltip=\"Export table to csv file\"\n        drTooltipPosition=\"top-right\"\n        data-analytics=\"admin_admin-table-header_button-6\"\n        theme=\"icon-secondary\"\n        icon=\"dr-icon-export-excel\"\n        (click)=\"onExport()\">\n    </dr-button>\n</div>\n"]}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import { FormsModule } from '@angular/forms';
|
|
3
|
+
import { AsyncPipe } from '@angular/common';
|
|
4
|
+
import { ToggleButtonMode } from '../../../dr-inputs/dr-toggle-button/toggle-button-mode';
|
|
5
|
+
import { DrInputsModule } from '../../../dr-inputs/dr-inputs.module';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "../../../dr-inputs/dr-toggle-button/dr-toggle-button.component";
|
|
8
|
+
import * as i2 from "@angular/forms";
|
|
9
|
+
export class TblToggleButtonHeaderComponent {
|
|
10
|
+
constructor() {
|
|
11
|
+
this.bindLabel = null;
|
|
12
|
+
this.bindValue = null;
|
|
13
|
+
this.bindHidden = null;
|
|
14
|
+
}
|
|
15
|
+
agInit(params) {
|
|
16
|
+
this.params = params;
|
|
17
|
+
this.items = params.items || [];
|
|
18
|
+
const tableWidth = this.params?.api?.gridBodyCtrl?.eGridBody?.clientWidth;
|
|
19
|
+
this.bindLabel = tableWidth < params.minTableWidth ? null : (params.bindLabel ?? null);
|
|
20
|
+
this.bindValue = params.bindValue || null;
|
|
21
|
+
this.bindHidden = params.bindHidden || null;
|
|
22
|
+
this.mode = tableWidth < params.minTableWidth ? ToggleButtonMode.ICON_ONLY : params.mode || ToggleButtonMode.DEFAULT;
|
|
23
|
+
this.selectedValue = params.selectedValue || null;
|
|
24
|
+
this.selectedValue$ = params.selectedValue$ || null;
|
|
25
|
+
}
|
|
26
|
+
refresh() {
|
|
27
|
+
return false;
|
|
28
|
+
}
|
|
29
|
+
onSelectionChanged(selectedValue) {
|
|
30
|
+
this.params.onSelectionChanged(selectedValue);
|
|
31
|
+
}
|
|
32
|
+
/** @nocollapse */ static { this.ɵfac = function TblToggleButtonHeaderComponent_Factory(t) { return new (t || TblToggleButtonHeaderComponent)(); }; }
|
|
33
|
+
/** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: TblToggleButtonHeaderComponent, selectors: [["dr-tbl-toggle-button-header"]], standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 2, vars: 7, consts: [["data-analytics", "tables_dr-grid_tbl-toggle-button-header_toggle-button-0", 3, "ngModel", "items", "bindValue", "bindLabel", "mode", "ngModelChange"]], template: function TblToggleButtonHeaderComponent_Template(rf, ctx) { if (rf & 1) {
|
|
34
|
+
i0.ɵɵelementStart(0, "dr-toggle-button", 0);
|
|
35
|
+
i0.ɵɵlistener("ngModelChange", function TblToggleButtonHeaderComponent_Template_dr_toggle_button_ngModelChange_0_listener($event) { return ctx.onSelectionChanged($event); });
|
|
36
|
+
i0.ɵɵpipe(1, "async");
|
|
37
|
+
i0.ɵɵelementEnd();
|
|
38
|
+
} if (rf & 2) {
|
|
39
|
+
i0.ɵɵproperty("ngModel", i0.ɵɵpipeBind1(1, 5, ctx.selectedValue$) || ctx.selectedValue)("items", ctx.items)("bindValue", ctx.bindValue)("bindLabel", ctx.bindLabel)("mode", ctx.mode);
|
|
40
|
+
} }, dependencies: [DrInputsModule, i1.DrToggleButtonComponent, FormsModule, i2.NgControlStatus, i2.NgModel, AsyncPipe], styles: ["[_nghost-%COMP%]{position:absolute;top:0;right:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center} .ag-header-cell:has(dr-tbl-toggle-button-header){overflow:visible}"] }); }
|
|
41
|
+
}
|
|
42
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TblToggleButtonHeaderComponent, [{
|
|
43
|
+
type: Component,
|
|
44
|
+
args: [{ selector: 'dr-tbl-toggle-button-header', standalone: true, imports: [DrInputsModule, FormsModule, AsyncPipe], template: "<dr-toggle-button\n data-analytics=\"tables_dr-grid_tbl-toggle-button-header_toggle-button-0\"\n [ngModel]=\"(selectedValue$ | async) || selectedValue\"\n (ngModelChange)=\"onSelectionChanged($event)\"\n [items]=\"items\"\n [bindValue]=\"bindValue\"\n [bindLabel]=\"bindLabel\"\n [mode]=\"mode\">\n</dr-toggle-button>\n", styles: [":host{position:absolute;top:0;right:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center}::ng-deep .ag-header-cell:has(dr-tbl-toggle-button-header){overflow:visible}\n"] }]
|
|
45
|
+
}], null, null); })();
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGJsLXRvZ2dsZS1idXR0b24taGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWdyaWQvY29tcG9uZW50cy90YmwtdG9nZ2xlLWJ1dHRvbi1oZWFkZXIvdGJsLXRvZ2dsZS1idXR0b24taGVhZGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWdyaWQvY29tcG9uZW50cy90YmwtdG9nZ2xlLWJ1dHRvbi1oZWFkZXIvdGJsLXRvZ2dsZS1idXR0b24taGVhZGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUc1QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx3REFBd0QsQ0FBQztBQUMxRixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0scUNBQXFDLENBQUM7Ozs7QUFzQnJFLE1BQU0sT0FBTyw4QkFBOEI7SUFQM0M7UUFXSSxjQUFTLEdBQWtCLElBQUksQ0FBQztRQUNoQyxjQUFTLEdBQWtCLElBQUksQ0FBQztRQUNoQyxlQUFVLEdBQWtCLElBQUksQ0FBQztLQXdCcEM7SUFuQkcsTUFBTSxDQUFDLE1BQW1DO1FBQ3RDLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxLQUFLLEdBQUcsTUFBTSxDQUFDLEtBQUssSUFBSSxFQUFFLENBQUM7UUFDaEMsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRSxHQUFHLEVBQUUsWUFBWSxFQUFFLFNBQVMsRUFBRSxXQUFXLENBQUM7UUFDMUUsSUFBSSxDQUFDLFNBQVMsR0FBRyxVQUFVLEdBQUcsTUFBTSxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxTQUFTLElBQUksSUFBSSxDQUFDLENBQUM7UUFDdkYsSUFBSSxDQUFDLFNBQVMsR0FBRyxNQUFNLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQztRQUMxQyxJQUFJLENBQUMsVUFBVSxHQUFHLE1BQU0sQ0FBQyxVQUFVLElBQUksSUFBSSxDQUFDO1FBQzVDLElBQUksQ0FBQyxJQUFJLEdBQUcsVUFBVSxHQUFHLE1BQU0sQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDLGdCQUFnQixDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLElBQUksSUFBSSxnQkFBZ0IsQ0FBQyxPQUFPLENBQUM7UUFDckgsSUFBSSxDQUFDLGFBQWEsR0FBRyxNQUFNLENBQUMsYUFBYSxJQUFJLElBQUksQ0FBQztRQUNsRCxJQUFJLENBQUMsY0FBYyxHQUFHLE1BQU0sQ0FBQyxjQUFjLElBQUksSUFBSSxDQUFDO0lBQ3hELENBQUM7SUFFRCxPQUFPO1FBQ0gsT0FBTyxLQUFLLENBQUM7SUFDakIsQ0FBQztJQUVELGtCQUFrQixDQUFDLGFBQWE7UUFDNUIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUNsRCxDQUFDO2tIQTdCUSw4QkFBOEI7bUdBQTlCLDhCQUE4QjtZQzVCM0MsMkNBT2tCO1lBSmQsMklBQWlCLDhCQUEwQixJQUFDOztZQUtoRCxpQkFBbUI7O1lBTmYsdUZBQXFELG9CQUFBLDRCQUFBLDRCQUFBLGtCQUFBOzRCRHdCM0MsY0FBYyw4QkFBRSxXQUFXLGtDQUFFLFNBQVM7O3VGQUV2Qyw4QkFBOEI7Y0FQMUMsU0FBUzsyQkFDSSw2QkFBNkIsY0FHM0IsSUFBSSxXQUNQLENBQUMsY0FBYyxFQUFFLFdBQVcsRUFBRSxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgQXN5bmNQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuaW1wb3J0IHsgSUdyaWRIZWFkZXJBbmd1bGFyQ29tcG9uZW50LCBJR3JpZEhlYWRlclBhcmFtcyB9IGZyb20gJy4uLy4uL21vZGVscy9pbnRlcmZhY2VzJztcbmltcG9ydCB7IFRvZ2dsZUJ1dHRvbk1vZGUgfSBmcm9tICcuLi8uLi8uLi9kci1pbnB1dHMvZHItdG9nZ2xlLWJ1dHRvbi90b2dnbGUtYnV0dG9uLW1vZGUnO1xuaW1wb3J0IHsgRHJJbnB1dHNNb2R1bGUgfSBmcm9tICcuLi8uLi8uLi9kci1pbnB1dHMvZHItaW5wdXRzLm1vZHVsZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5cbmludGVyZmFjZSBUYmxUb2dnbGVCdXR0b25IZWFkZXJQYXJhbXMgZXh0ZW5kcyBJR3JpZEhlYWRlclBhcmFtcyB7XG4gICAgaXRlbXM6IHN0cmluZ1tdIHwgYW55W107XG4gICAgYmluZExhYmVsPzogc3RyaW5nIHwgbnVsbDtcbiAgICBiaW5kVmFsdWU/OiBzdHJpbmcgfCBudWxsO1xuICAgIGJpbmRIaWRkZW4/OiBzdHJpbmcgfCBudWxsO1xuICAgIG1vZGU/OiBUb2dnbGVCdXR0b25Nb2RlO1xuICAgIG1pblRhYmxlV2lkdGg6IG51bWJlciB8IG51bGw7XG4gICAgc2VsZWN0ZWRWYWx1ZT86IGFueSB8IHN0cmluZztcbiAgICBzZWxlY3RlZFZhbHVlJD86IE9ic2VydmFibGU8YW55IHwgc3RyaW5nPjtcbiAgICBvblNlbGVjdGlvbkNoYW5nZWQ6IChzZWxlY3RlZFZhbHVlOiBzdHJpbmcgfCBhbnkpID0+IHZvaWQ7XG59XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZHItdGJsLXRvZ2dsZS1idXR0b24taGVhZGVyJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vdGJsLXRvZ2dsZS1idXR0b24taGVhZGVyLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi90YmwtdG9nZ2xlLWJ1dHRvbi1oZWFkZXIuY29tcG9uZW50LnNjc3MnXSxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtEcklucHV0c01vZHVsZSwgRm9ybXNNb2R1bGUsIEFzeW5jUGlwZV0sXG59KVxuZXhwb3J0IGNsYXNzIFRibFRvZ2dsZUJ1dHRvbkhlYWRlckNvbXBvbmVudCBpbXBsZW1lbnRzIElHcmlkSGVhZGVyQW5ndWxhckNvbXBvbmVudCB7XG4gICAgcGFyYW1zOiBhbnk7XG5cbiAgICBpdGVtczogc3RyaW5nW10gfCBhbnlbXTtcbiAgICBiaW5kTGFiZWw6IHN0cmluZyB8IG51bGwgPSBudWxsO1xuICAgIGJpbmRWYWx1ZTogc3RyaW5nIHwgbnVsbCA9IG51bGw7XG4gICAgYmluZEhpZGRlbjogc3RyaW5nIHwgbnVsbCA9IG51bGw7XG4gICAgbW9kZTogVG9nZ2xlQnV0dG9uTW9kZTtcbiAgICBzZWxlY3RlZFZhbHVlOiBhbnkgfCBzdHJpbmc7XG4gICAgc2VsZWN0ZWRWYWx1ZSQ6IE9ic2VydmFibGU8YW55IHwgc3RyaW5nPjtcblxuICAgIGFnSW5pdChwYXJhbXM6IFRibFRvZ2dsZUJ1dHRvbkhlYWRlclBhcmFtcyk6IHZvaWQge1xuICAgICAgICB0aGlzLnBhcmFtcyA9IHBhcmFtcztcbiAgICAgICAgdGhpcy5pdGVtcyA9IHBhcmFtcy5pdGVtcyB8fCBbXTtcbiAgICAgICAgY29uc3QgdGFibGVXaWR0aCA9IHRoaXMucGFyYW1zPy5hcGk/LmdyaWRCb2R5Q3RybD8uZUdyaWRCb2R5Py5jbGllbnRXaWR0aDtcbiAgICAgICAgdGhpcy5iaW5kTGFiZWwgPSB0YWJsZVdpZHRoIDwgcGFyYW1zLm1pblRhYmxlV2lkdGggPyBudWxsIDogKHBhcmFtcy5iaW5kTGFiZWwgPz8gbnVsbCk7XG4gICAgICAgIHRoaXMuYmluZFZhbHVlID0gcGFyYW1zLmJpbmRWYWx1ZSB8fCBudWxsO1xuICAgICAgICB0aGlzLmJpbmRIaWRkZW4gPSBwYXJhbXMuYmluZEhpZGRlbiB8fCBudWxsO1xuICAgICAgICB0aGlzLm1vZGUgPSB0YWJsZVdpZHRoIDwgcGFyYW1zLm1pblRhYmxlV2lkdGggPyBUb2dnbGVCdXR0b25Nb2RlLklDT05fT05MWSA6IHBhcmFtcy5tb2RlIHx8IFRvZ2dsZUJ1dHRvbk1vZGUuREVGQVVMVDtcbiAgICAgICAgdGhpcy5zZWxlY3RlZFZhbHVlID0gcGFyYW1zLnNlbGVjdGVkVmFsdWUgfHwgbnVsbDtcbiAgICAgICAgdGhpcy5zZWxlY3RlZFZhbHVlJCA9IHBhcmFtcy5zZWxlY3RlZFZhbHVlJCB8fCBudWxsO1xuICAgIH1cblxuICAgIHJlZnJlc2goKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICBvblNlbGVjdGlvbkNoYW5nZWQoc2VsZWN0ZWRWYWx1ZSkge1xuICAgICAgICB0aGlzLnBhcmFtcy5vblNlbGVjdGlvbkNoYW5nZWQoc2VsZWN0ZWRWYWx1ZSk7XG4gICAgfVxufVxuIiwiPGRyLXRvZ2dsZS1idXR0b25cbiAgICBkYXRhLWFuYWx5dGljcz1cInRhYmxlc19kci1ncmlkX3RibC10b2dnbGUtYnV0dG9uLWhlYWRlcl90b2dnbGUtYnV0dG9uLTBcIlxuICAgIFtuZ01vZGVsXT1cIihzZWxlY3RlZFZhbHVlJCB8IGFzeW5jKSB8fCBzZWxlY3RlZFZhbHVlXCJcbiAgICAobmdNb2RlbENoYW5nZSk9XCJvblNlbGVjdGlvbkNoYW5nZWQoJGV2ZW50KVwiXG4gICAgW2l0ZW1zXT1cIml0ZW1zXCJcbiAgICBbYmluZFZhbHVlXT1cImJpbmRWYWx1ZVwiXG4gICAgW2JpbmRMYWJlbF09XCJiaW5kTGFiZWxcIlxuICAgIFttb2RlXT1cIm1vZGVcIj5cbjwvZHItdG9nZ2xlLWJ1dHRvbj5cbiJdfQ==
|