@dereekb/dbx-web 9.20.20 → 9.22.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.
- package/calendar/package.json +2 -2
- package/esm2020/lib/action/snackbar/action.snackbar.component.mjs +1 -1
- package/esm2020/lib/action/transition/transition.safety.dialog.component.mjs +1 -1
- package/esm2020/lib/button/button.component.mjs +14 -2
- package/esm2020/lib/button/progress/base.progress.button.directive.mjs +3 -1
- package/esm2020/lib/button/progress/button.progress.config.mjs +1 -1
- package/esm2020/lib/button/progress/spinner.button.component.mjs +7 -4
- package/esm2020/lib/extension/model/model.tracker.view.storage.mjs +2 -3
- package/esm2020/lib/extension/model/model.types.service.mjs +2 -3
- package/esm2020/lib/extension/model/state/effects/tracker.effects.mjs +2 -2
- package/esm2020/lib/interaction/filter/filter.preset.menu.component.mjs +2 -3
- package/esm2020/lib/interaction/filter/filter.preset.mjs +2 -3
- package/esm2020/lib/interaction/filter/filter.wrapper.component.mjs +1 -1
- package/esm2020/lib/interaction/popup/popup.controls.buttons.component.mjs +1 -1
- package/esm2020/lib/layout/column/two/two.column.sref.showright.directive.mjs +2 -3
- package/esm2020/lib/layout/content/content.layout.module.mjs +31 -4
- package/esm2020/lib/layout/content/content.pit.directive.mjs +19 -0
- package/esm2020/lib/layout/content/index.mjs +2 -1
- package/esm2020/lib/layout/list/list.wrapper.mjs +1 -1
- package/esm2020/mapbox/lib/mapbox.change.service.mjs +2 -3
- package/esm2020/table/dereekb-dbx-web-table.mjs +5 -0
- package/esm2020/table/index.mjs +2 -0
- package/esm2020/table/lib/date/date.table.column.header.component.mjs +49 -0
- package/esm2020/table/lib/date/daterange.table.cell.input.component.mjs +166 -0
- package/esm2020/table/lib/date/index.mjs +4 -0
- package/esm2020/table/lib/date/table.date.module.mjs +68 -0
- package/esm2020/table/lib/index.mjs +18 -0
- package/esm2020/table/lib/table.cell.action.component.mjs +28 -0
- package/esm2020/table/lib/table.cell.input.component.mjs +31 -0
- package/esm2020/table/lib/table.cell.summaryend.component.mjs +28 -0
- package/esm2020/table/lib/table.cell.summarystart.component.mjs +31 -0
- package/esm2020/table/lib/table.column.directive.mjs +30 -0
- package/esm2020/table/lib/table.column.footer.component.mjs +35 -0
- package/esm2020/table/lib/table.column.header.component.mjs +35 -0
- package/esm2020/table/lib/table.component.mjs +58 -0
- package/esm2020/table/lib/table.directive.mjs +37 -0
- package/esm2020/table/lib/table.item.action.component.mjs +35 -0
- package/esm2020/table/lib/table.item.cell.component.mjs +39 -0
- package/esm2020/table/lib/table.item.directive.mjs +30 -0
- package/esm2020/table/lib/table.item.header.component.mjs +27 -0
- package/esm2020/table/lib/table.mjs +2 -0
- package/esm2020/table/lib/table.module.mjs +74 -0
- package/esm2020/table/lib/table.store.mjs +53 -0
- package/fesm2015/dereekb-dbx-web-mapbox.mjs +1 -2
- package/fesm2015/dereekb-dbx-web-mapbox.mjs.map +1 -1
- package/fesm2015/dereekb-dbx-web-table.mjs +745 -0
- package/fesm2015/dereekb-dbx-web-table.mjs.map +1 -0
- package/fesm2015/dereekb-dbx-web.mjs +99 -38
- package/fesm2015/dereekb-dbx-web.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-web-mapbox.mjs +1 -2
- package/fesm2020/dereekb-dbx-web-mapbox.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-web-table.mjs +738 -0
- package/fesm2020/dereekb-dbx-web-table.mjs.map +1 -0
- package/fesm2020/dereekb-dbx-web.mjs +97 -38
- package/fesm2020/dereekb-dbx-web.mjs.map +1 -1
- package/lib/button/_button.scss +4 -0
- package/lib/button/button.component.d.ts +5 -2
- package/lib/button/progress/button.progress.config.d.ts +7 -0
- package/lib/button/progress/spinner.button.component.d.ts +1 -0
- package/lib/extension/_extension.scss +19 -0
- package/lib/extension/table/_table.scss +60 -0
- package/lib/layout/content/_content.scss +14 -0
- package/lib/layout/content/content.layout.module.d.ts +3 -2
- package/lib/layout/content/content.pit.directive.d.ts +8 -0
- package/lib/layout/content/index.d.ts +1 -0
- package/lib/layout/list/list.wrapper.d.ts +2 -1
- package/lib/layout/style/_style.scss +4 -0
- package/lib/style/_config.scss +8 -2
- package/mapbox/esm2020/lib/mapbox.change.service.mjs +2 -3
- package/mapbox/fesm2015/dereekb-dbx-web-mapbox.mjs +1 -2
- package/mapbox/fesm2015/dereekb-dbx-web-mapbox.mjs.map +1 -1
- package/mapbox/fesm2020/dereekb-dbx-web-mapbox.mjs +1 -2
- package/mapbox/fesm2020/dereekb-dbx-web-mapbox.mjs.map +1 -1
- package/mapbox/package.json +3 -3
- package/package.json +14 -6
- package/table/README.md +6 -0
- package/table/esm2020/dereekb-dbx-web-table.mjs +5 -0
- package/table/esm2020/index.mjs +2 -0
- package/table/esm2020/lib/date/date.table.column.header.component.mjs +49 -0
- package/table/esm2020/lib/date/daterange.table.cell.input.component.mjs +166 -0
- package/table/esm2020/lib/date/index.mjs +4 -0
- package/table/esm2020/lib/date/table.date.module.mjs +68 -0
- package/table/esm2020/lib/index.mjs +18 -0
- package/table/esm2020/lib/table.cell.action.component.mjs +28 -0
- package/table/esm2020/lib/table.cell.input.component.mjs +31 -0
- package/table/esm2020/lib/table.cell.summaryend.component.mjs +28 -0
- package/table/esm2020/lib/table.cell.summarystart.component.mjs +31 -0
- package/table/esm2020/lib/table.column.directive.mjs +30 -0
- package/table/esm2020/lib/table.column.footer.component.mjs +35 -0
- package/table/esm2020/lib/table.column.header.component.mjs +35 -0
- package/table/esm2020/lib/table.component.mjs +58 -0
- package/table/esm2020/lib/table.directive.mjs +37 -0
- package/table/esm2020/lib/table.item.action.component.mjs +35 -0
- package/table/esm2020/lib/table.item.cell.component.mjs +39 -0
- package/table/esm2020/lib/table.item.directive.mjs +30 -0
- package/table/esm2020/lib/table.item.header.component.mjs +27 -0
- package/table/esm2020/lib/table.mjs +2 -0
- package/table/esm2020/lib/table.module.mjs +74 -0
- package/table/esm2020/lib/table.store.mjs +53 -0
- package/table/fesm2015/dereekb-dbx-web-table.mjs +745 -0
- package/table/fesm2015/dereekb-dbx-web-table.mjs.map +1 -0
- package/table/fesm2020/dereekb-dbx-web-table.mjs +738 -0
- package/table/fesm2020/dereekb-dbx-web-table.mjs.map +1 -0
- package/table/index.d.ts +1 -0
- package/table/lib/date/date.table.column.header.component.d.ts +18 -0
- package/table/lib/date/daterange.table.cell.input.component.d.ts +66 -0
- package/table/lib/date/index.d.ts +3 -0
- package/table/lib/date/table.date.module.d.ts +16 -0
- package/table/lib/index.d.ts +17 -0
- package/table/lib/table.cell.action.component.d.ts +9 -0
- package/table/lib/table.cell.input.component.d.ts +12 -0
- package/table/lib/table.cell.summaryend.component.d.ts +9 -0
- package/table/lib/table.cell.summarystart.component.d.ts +12 -0
- package/table/lib/table.column.directive.d.ts +18 -0
- package/table/lib/table.column.footer.component.d.ts +8 -0
- package/table/lib/table.column.header.component.d.ts +8 -0
- package/table/lib/table.component.d.ts +29 -0
- package/table/lib/table.d.ts +99 -0
- package/table/lib/table.directive.d.ts +16 -0
- package/table/lib/table.item.action.component.d.ts +7 -0
- package/table/lib/table.item.cell.component.d.ts +13 -0
- package/table/lib/table.item.directive.d.ts +17 -0
- package/table/lib/table.item.header.component.d.ts +7 -0
- package/table/lib/table.module.d.ts +22 -0
- package/table/lib/table.store.d.ts +38 -0
- package/table/package.json +35 -0
package/package.json
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@dereekb/dbx-web",
|
|
3
|
-
"version": "9.
|
|
3
|
+
"version": "9.22.0",
|
|
4
4
|
"peerDependencies": {
|
|
5
5
|
"@angular/common": "^14.0.0",
|
|
6
6
|
"@angular/core": "^14.0.0",
|
|
7
7
|
"linkify-string": "4.0.0-beta.5",
|
|
8
8
|
"linkifyjs": "^4.0.0-beta.5",
|
|
9
9
|
"@angular/material": "^14.2.0",
|
|
10
|
-
"@dereekb/rxjs": "9.
|
|
11
|
-
"@dereekb/dbx-core": "9.
|
|
10
|
+
"@dereekb/rxjs": "9.22.0",
|
|
11
|
+
"@dereekb/dbx-core": "9.22.0",
|
|
12
12
|
"change-case": "^4.1.2",
|
|
13
13
|
"@angular/flex-layout": "^14.0.0-beta.41",
|
|
14
14
|
"ng-overlay-container": "^14.0.0",
|
|
@@ -38,9 +38,6 @@
|
|
|
38
38
|
"node": "./fesm2015/dereekb-dbx-web-mapbox.mjs",
|
|
39
39
|
"default": "./fesm2020/dereekb-dbx-web-mapbox.mjs"
|
|
40
40
|
},
|
|
41
|
-
"./package.json": {
|
|
42
|
-
"default": "./package.json"
|
|
43
|
-
},
|
|
44
41
|
"./calendar": {
|
|
45
42
|
"types": "./calendar/index.d.ts",
|
|
46
43
|
"esm2020": "./esm2020/calendar/dereekb-dbx-web-calendar.mjs",
|
|
@@ -48,6 +45,17 @@
|
|
|
48
45
|
"es2015": "./fesm2015/dereekb-dbx-web-calendar.mjs",
|
|
49
46
|
"node": "./fesm2015/dereekb-dbx-web-calendar.mjs",
|
|
50
47
|
"default": "./fesm2020/dereekb-dbx-web-calendar.mjs"
|
|
48
|
+
},
|
|
49
|
+
"./table": {
|
|
50
|
+
"types": "./table/index.d.ts",
|
|
51
|
+
"esm2020": "./esm2020/table/dereekb-dbx-web-table.mjs",
|
|
52
|
+
"es2020": "./fesm2020/dereekb-dbx-web-table.mjs",
|
|
53
|
+
"es2015": "./fesm2015/dereekb-dbx-web-table.mjs",
|
|
54
|
+
"node": "./fesm2015/dereekb-dbx-web-table.mjs",
|
|
55
|
+
"default": "./fesm2020/dereekb-dbx-web-table.mjs"
|
|
56
|
+
},
|
|
57
|
+
"./package.json": {
|
|
58
|
+
"default": "./package.json"
|
|
51
59
|
}
|
|
52
60
|
},
|
|
53
61
|
"module": "fesm2015/dereekb-dbx-web.mjs",
|
package/table/README.md
ADDED
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVyZWVrYi1kYngtd2ViLXRhYmxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi90YWJsZS9zcmMvZGVyZWVrYi1kYngtd2ViLXRhYmxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './lib';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3RhYmxlL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLE9BQU8sQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliJztcbiJdfQ==
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
/**
|
|
5
|
+
* A table header component used for rendering date values on the header.
|
|
6
|
+
*/
|
|
7
|
+
export class DbxTableDateHeaderComponent {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.left = 'E';
|
|
10
|
+
this.right = 'MMM d';
|
|
11
|
+
}
|
|
12
|
+
get date() {
|
|
13
|
+
return this._date;
|
|
14
|
+
}
|
|
15
|
+
set date(date) {
|
|
16
|
+
this._date = date;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
DbxTableDateHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableDateHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
20
|
+
DbxTableDateHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxTableDateHeaderComponent, selector: "ng-component", ngImport: i0, template: `
|
|
21
|
+
<div *ngIf="date" class="dbx-table-date-column-header">
|
|
22
|
+
<span class="dbx-table-date-column-header-left">{{ date | date: left }}</span>
|
|
23
|
+
<span>{{ date | date: right }}</span>
|
|
24
|
+
</div>
|
|
25
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.DatePipe, name: "date" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
26
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableDateHeaderComponent, decorators: [{
|
|
27
|
+
type: Component,
|
|
28
|
+
args: [{
|
|
29
|
+
template: `
|
|
30
|
+
<div *ngIf="date" class="dbx-table-date-column-header">
|
|
31
|
+
<span class="dbx-table-date-column-header-left">{{ date | date: left }}</span>
|
|
32
|
+
<span>{{ date | date: right }}</span>
|
|
33
|
+
</div>
|
|
34
|
+
`,
|
|
35
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
36
|
+
}]
|
|
37
|
+
}], ctorParameters: function () { return []; } });
|
|
38
|
+
export function dbxTableDateHeaderInjectionFactory() {
|
|
39
|
+
return (column) => {
|
|
40
|
+
const config = {
|
|
41
|
+
componentClass: DbxTableDateHeaderComponent,
|
|
42
|
+
init: (x) => {
|
|
43
|
+
x.date = column.meta;
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
return config;
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS50YWJsZS5jb2x1bW4uaGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvdGFibGUvc3JjL2xpYi9kYXRlL2RhdGUudGFibGUuY29sdW1uLmhlYWRlci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBS25FOztHQUVHO0FBVUgsTUFBTSxPQUFPLDJCQUEyQjtJQU10QztRQUxBLFNBQUksR0FBRyxHQUFHLENBQUM7UUFDWCxVQUFLLEdBQUcsT0FBTyxDQUFDO0lBSUQsQ0FBQztJQUVoQixJQUFJLElBQUk7UUFDTixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDcEIsQ0FBQztJQUVELElBQUksSUFBSSxDQUFDLElBQWlCO1FBQ3hCLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO0lBQ3BCLENBQUM7O3lIQWRVLDJCQUEyQjs2R0FBM0IsMkJBQTJCLG9EQVI1Qjs7Ozs7R0FLVDs0RkFHVSwyQkFBMkI7a0JBVHZDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFOzs7OztHQUtUO29CQUNELGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2lCQUNoRDs7QUFrQkQsTUFBTSxVQUFVLGtDQUFrQztJQUNoRCxPQUFPLENBQUMsTUFBNEIsRUFBRSxFQUFFO1FBQ3RDLE1BQU0sTUFBTSxHQUE2RDtZQUN2RSxjQUFjLEVBQUUsMkJBQTJCO1lBQzNDLElBQUksRUFBRSxDQUFDLENBQUMsRUFBRSxFQUFFO2dCQUNWLENBQUMsQ0FBQyxJQUFJLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQztZQUN2QixDQUFDO1NBQ0YsQ0FBQztRQUVGLE9BQU8sTUFBTSxDQUFDO0lBQ2hCLENBQUMsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEYnhJbmplY3Rpb25Db21wb25lbnRDb25maWcsIERieEluamVjdGlvbkNvbXBvbmVudENvbmZpZ0ZhY3RvcnkgfSBmcm9tICdAZGVyZWVrYi9kYngtY29yZSc7XG5pbXBvcnQgeyBNYXliZSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgRGJ4VGFibGVDb2x1bW4gfSBmcm9tICcuLi90YWJsZSc7XG5cbi8qKlxuICogQSB0YWJsZSBoZWFkZXIgY29tcG9uZW50IHVzZWQgZm9yIHJlbmRlcmluZyBkYXRlIHZhbHVlcyBvbiB0aGUgaGVhZGVyLlxuICovXG5AQ29tcG9uZW50KHtcbiAgdGVtcGxhdGU6IGBcbiAgICA8ZGl2ICpuZ0lmPVwiZGF0ZVwiIGNsYXNzPVwiZGJ4LXRhYmxlLWRhdGUtY29sdW1uLWhlYWRlclwiPlxuICAgICAgPHNwYW4gY2xhc3M9XCJkYngtdGFibGUtZGF0ZS1jb2x1bW4taGVhZGVyLWxlZnRcIj57eyBkYXRlIHwgZGF0ZTogbGVmdCB9fTwvc3Bhbj5cbiAgICAgIDxzcGFuPnt7IGRhdGUgfCBkYXRlOiByaWdodCB9fTwvc3Bhbj5cbiAgICA8L2Rpdj5cbiAgYCxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgRGJ4VGFibGVEYXRlSGVhZGVyQ29tcG9uZW50IHtcbiAgbGVmdCA9ICdFJztcbiAgcmlnaHQgPSAnTU1NIGQnO1xuXG4gIHByaXZhdGUgX2RhdGU6IE1heWJlPERhdGU+O1xuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICBnZXQgZGF0ZSgpIHtcbiAgICByZXR1cm4gdGhpcy5fZGF0ZTtcbiAgfVxuXG4gIHNldCBkYXRlKGRhdGU6IE1heWJlPERhdGU+KSB7XG4gICAgdGhpcy5fZGF0ZSA9IGRhdGU7XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGRieFRhYmxlRGF0ZUhlYWRlckluamVjdGlvbkZhY3RvcnkoKTogRGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnRmFjdG9yeTxEYnhUYWJsZUNvbHVtbjxEYXRlPiwgRGJ4VGFibGVEYXRlSGVhZGVyQ29tcG9uZW50PiB7XG4gIHJldHVybiAoY29sdW1uOiBEYnhUYWJsZUNvbHVtbjxEYXRlPikgPT4ge1xuICAgIGNvbnN0IGNvbmZpZzogRGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnPERieFRhYmxlRGF0ZUhlYWRlckNvbXBvbmVudD4gPSB7XG4gICAgICBjb21wb25lbnRDbGFzczogRGJ4VGFibGVEYXRlSGVhZGVyQ29tcG9uZW50LFxuICAgICAgaW5pdDogKHgpID0+IHtcbiAgICAgICAgeC5kYXRlID0gY29sdW1uLm1ldGE7XG4gICAgICB9XG4gICAgfTtcblxuICAgIHJldHVybiBjb25maWc7XG4gIH07XG59XG4iXX0=
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Injectable } from '@angular/core';
|
|
2
|
+
import { isSameDateDay } from '@dereekb/date';
|
|
3
|
+
import { DbxTableStore } from '../table.store';
|
|
4
|
+
import { DateRange, MAT_DATE_RANGE_SELECTION_STRATEGY } from '@angular/material/datepicker';
|
|
5
|
+
import { DateAdapter } from '@angular/material/core';
|
|
6
|
+
import { FormGroup, FormControl } from '@angular/forms';
|
|
7
|
+
import { SubscriptionObject } from '@dereekb/rxjs';
|
|
8
|
+
import { addDays, format as formatDate } from 'date-fns';
|
|
9
|
+
import { BehaviorSubject, distinctUntilChanged, filter, map, of, startWith, switchMap, throttleTime, combineLatest } from 'rxjs';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@angular/material/core";
|
|
12
|
+
import * as i2 from "../table.store";
|
|
13
|
+
import * as i3 from "@angular/forms";
|
|
14
|
+
import * as i4 from "@angular/material/datepicker";
|
|
15
|
+
import * as i5 from "@angular/material/button";
|
|
16
|
+
import * as i6 from "@angular/common";
|
|
17
|
+
export class DbxTableDateRangeDayDistanceInputCellInputRangeSelectionStrategy {
|
|
18
|
+
constructor(_dateAdapter, dbxTableDateRangeDayDistanceInputCellInputComponent) {
|
|
19
|
+
this._dateAdapter = _dateAdapter;
|
|
20
|
+
this.dbxTableDateRangeDayDistanceInputCellInputComponent = dbxTableDateRangeDayDistanceInputCellInputComponent;
|
|
21
|
+
}
|
|
22
|
+
selectionFinished(date) {
|
|
23
|
+
return this._createFiveDayRange(date);
|
|
24
|
+
}
|
|
25
|
+
createPreview(activeDate) {
|
|
26
|
+
return this._createFiveDayRange(activeDate);
|
|
27
|
+
}
|
|
28
|
+
_createFiveDayRange(date) {
|
|
29
|
+
if (date) {
|
|
30
|
+
const start = date;
|
|
31
|
+
const end = this._dateAdapter.addCalendarDays(date, this.dbxTableDateRangeDayDistanceInputCellInputComponent.daysDistance);
|
|
32
|
+
return new DateRange(start, end);
|
|
33
|
+
}
|
|
34
|
+
return new DateRange(null, null);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
DbxTableDateRangeDayDistanceInputCellInputRangeSelectionStrategy.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableDateRangeDayDistanceInputCellInputRangeSelectionStrategy, deps: [{ token: i1.DateAdapter }, { token: DbxTableDateRangeDayDistanceInputCellInputComponent }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
38
|
+
DbxTableDateRangeDayDistanceInputCellInputRangeSelectionStrategy.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableDateRangeDayDistanceInputCellInputRangeSelectionStrategy });
|
|
39
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableDateRangeDayDistanceInputCellInputRangeSelectionStrategy, decorators: [{
|
|
40
|
+
type: Injectable
|
|
41
|
+
}], ctorParameters: function () { return [{ type: i1.DateAdapter }, { type: DbxTableDateRangeDayDistanceInputCellInputComponent }]; } });
|
|
42
|
+
export const DEFAULT_DBX_TABLE_DATE_RANGE_DAY_DISTIANCE_INPUT_CELL_COMPONENT_CONFIG = { daysDistance: 6 };
|
|
43
|
+
export const DEFAULT_DBX_TABLE_DATE_RANGE_DAY_BUTTON_FORMAT = 'MMM dd';
|
|
44
|
+
/**
|
|
45
|
+
* Cell input for a DateRangeDayDistanceInput value.
|
|
46
|
+
*/
|
|
47
|
+
export class DbxTableDateRangeDayDistanceInputCellInputComponent {
|
|
48
|
+
constructor(tableStore) {
|
|
49
|
+
this.tableStore = tableStore;
|
|
50
|
+
this._syncSub = new SubscriptionObject();
|
|
51
|
+
this._valueSub = new SubscriptionObject();
|
|
52
|
+
this._pickerOpened = new BehaviorSubject(false);
|
|
53
|
+
this._config = new BehaviorSubject(DEFAULT_DBX_TABLE_DATE_RANGE_DAY_DISTIANCE_INPUT_CELL_COMPONENT_CONFIG);
|
|
54
|
+
this.range = new FormGroup({
|
|
55
|
+
start: new FormControl(null),
|
|
56
|
+
end: new FormControl(null)
|
|
57
|
+
});
|
|
58
|
+
this.pickerOpened$ = this._pickerOpened.asObservable();
|
|
59
|
+
this.minDate$ = this._config.pipe(map((x) => x.minDate));
|
|
60
|
+
this.maxDate$ = this._config.pipe(map((x) => x.maxDate));
|
|
61
|
+
this.buttonFormat$ = this._config.pipe(map((x) => x.buttonFormat ?? DEFAULT_DBX_TABLE_DATE_RANGE_DAY_BUTTON_FORMAT));
|
|
62
|
+
this.dateRangeString$ = combineLatest([this.buttonFormat$, this.range.valueChanges]).pipe(map(([buttonFormat, { start, end }]) => {
|
|
63
|
+
if (start && end) {
|
|
64
|
+
return `${formatDate(start, buttonFormat)} - ${formatDate(end, buttonFormat)}`;
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
return `Select Date`;
|
|
68
|
+
}
|
|
69
|
+
}));
|
|
70
|
+
}
|
|
71
|
+
ngOnInit() {
|
|
72
|
+
this._syncSub.subscription = this.tableStore.input$.subscribe((x) => {
|
|
73
|
+
const start = x?.date ?? null;
|
|
74
|
+
const end = start ? addDays(start, this.daysDistance) : undefined;
|
|
75
|
+
this.range.setValue({
|
|
76
|
+
start,
|
|
77
|
+
end
|
|
78
|
+
});
|
|
79
|
+
});
|
|
80
|
+
this._valueSub.subscription = this._pickerOpened
|
|
81
|
+
.pipe(distinctUntilChanged(), switchMap((opened) => {
|
|
82
|
+
let obs;
|
|
83
|
+
if (opened) {
|
|
84
|
+
obs = of({});
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
obs = this.range.valueChanges.pipe(startWith(this.range.value));
|
|
88
|
+
}
|
|
89
|
+
return obs;
|
|
90
|
+
}), filter((x) => Boolean(x.start)), distinctUntilChanged((a, b) => isSameDateDay(a.start, b.start)), throttleTime(100, undefined, { trailing: true }))
|
|
91
|
+
.subscribe((x) => {
|
|
92
|
+
if (x.start) {
|
|
93
|
+
this.tableStore.setInput({ date: x.start, distance: this.daysDistance });
|
|
94
|
+
}
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
ngOnDestroy() {
|
|
98
|
+
this._pickerOpened.complete();
|
|
99
|
+
this._config.complete();
|
|
100
|
+
this._syncSub.destroy();
|
|
101
|
+
this._valueSub.destroy();
|
|
102
|
+
}
|
|
103
|
+
get daysDistance() {
|
|
104
|
+
return this._config.value.daysDistance;
|
|
105
|
+
}
|
|
106
|
+
get config() {
|
|
107
|
+
return this._config.value;
|
|
108
|
+
}
|
|
109
|
+
set config(config) {
|
|
110
|
+
this._config.next(config || DEFAULT_DBX_TABLE_DATE_RANGE_DAY_DISTIANCE_INPUT_CELL_COMPONENT_CONFIG);
|
|
111
|
+
}
|
|
112
|
+
pickerOpened() {
|
|
113
|
+
this._pickerOpened.next(true);
|
|
114
|
+
}
|
|
115
|
+
pickerClosed() {
|
|
116
|
+
this._pickerOpened.next(false);
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
DbxTableDateRangeDayDistanceInputCellInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableDateRangeDayDistanceInputCellInputComponent, deps: [{ token: i2.DbxTableStore }], target: i0.ɵɵFactoryTarget.Component });
|
|
120
|
+
DbxTableDateRangeDayDistanceInputCellInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxTableDateRangeDayDistanceInputCellInputComponent, selector: "ng-component", providers: [
|
|
121
|
+
{
|
|
122
|
+
provide: MAT_DATE_RANGE_SELECTION_STRATEGY,
|
|
123
|
+
useClass: DbxTableDateRangeDayDistanceInputCellInputRangeSelectionStrategy
|
|
124
|
+
}
|
|
125
|
+
], ngImport: i0, template: `
|
|
126
|
+
<div class="dbx-table-date-range-distance-input-cell">
|
|
127
|
+
<mat-date-range-input class="dbx-table-date-range-distance-input" [min]="minDate$ | async" [max]="maxDate$ | async" [formGroup]="range" [rangePicker]="picker">
|
|
128
|
+
<input matStartDate formControlName="start" placeholder="Start date" />
|
|
129
|
+
<input matEndDate formControlName="end" placeholder="End date" />
|
|
130
|
+
</mat-date-range-input>
|
|
131
|
+
<button mat-stroked-button color="primary" (click)="picker.open()">{{ dateRangeString$ | async }}</button>
|
|
132
|
+
<mat-date-range-picker #picker (opened)="pickerOpened()" (closed)="pickerClosed()"></mat-date-range-picker>
|
|
133
|
+
</div>
|
|
134
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i4.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { kind: "directive", type: i4.MatStartDate, selector: "input[matStartDate]", inputs: ["errorStateMatcher"], outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i4.MatEndDate, selector: "input[matEndDate]", inputs: ["errorStateMatcher"], outputs: ["dateChange", "dateInput"] }, { kind: "component", type: i4.MatDateRangePicker, selector: "mat-date-range-picker", exportAs: ["matDateRangePicker"] }, { kind: "component", type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
135
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableDateRangeDayDistanceInputCellInputComponent, decorators: [{
|
|
136
|
+
type: Component,
|
|
137
|
+
args: [{
|
|
138
|
+
template: `
|
|
139
|
+
<div class="dbx-table-date-range-distance-input-cell">
|
|
140
|
+
<mat-date-range-input class="dbx-table-date-range-distance-input" [min]="minDate$ | async" [max]="maxDate$ | async" [formGroup]="range" [rangePicker]="picker">
|
|
141
|
+
<input matStartDate formControlName="start" placeholder="Start date" />
|
|
142
|
+
<input matEndDate formControlName="end" placeholder="End date" />
|
|
143
|
+
</mat-date-range-input>
|
|
144
|
+
<button mat-stroked-button color="primary" (click)="picker.open()">{{ dateRangeString$ | async }}</button>
|
|
145
|
+
<mat-date-range-picker #picker (opened)="pickerOpened()" (closed)="pickerClosed()"></mat-date-range-picker>
|
|
146
|
+
</div>
|
|
147
|
+
`,
|
|
148
|
+
providers: [
|
|
149
|
+
{
|
|
150
|
+
provide: MAT_DATE_RANGE_SELECTION_STRATEGY,
|
|
151
|
+
useClass: DbxTableDateRangeDayDistanceInputCellInputRangeSelectionStrategy
|
|
152
|
+
}
|
|
153
|
+
],
|
|
154
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
155
|
+
}]
|
|
156
|
+
}], ctorParameters: function () { return [{ type: i2.DbxTableStore }]; } });
|
|
157
|
+
export function dbxTableDateRangeDayDistanceInputCellInput(componentConfig) {
|
|
158
|
+
const config = {
|
|
159
|
+
componentClass: DbxTableDateRangeDayDistanceInputCellInputComponent,
|
|
160
|
+
init: (x) => {
|
|
161
|
+
x.config = componentConfig;
|
|
162
|
+
}
|
|
163
|
+
};
|
|
164
|
+
return config;
|
|
165
|
+
}
|
|
166
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daterange.table.cell.input.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/table/src/lib/date/daterange.table.cell.input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Injectable, OnDestroy, OnInit } from '@angular/core';\nimport { DateRangeDayDistanceInput, isSameDateDay } from '@dereekb/date';\nimport { DbxTableStore } from '../table.store';\nimport { MatDateRangeSelectionStrategy, DateRange, MAT_DATE_RANGE_SELECTION_STRATEGY } from '@angular/material/datepicker';\nimport { DateAdapter } from '@angular/material/core';\nimport { Days, Maybe } from '@dereekb/util';\nimport { FormGroup, FormControl } from '@angular/forms';\nimport { SubscriptionObject } from '@dereekb/rxjs';\nimport { addDays, format as formatDate } from 'date-fns';\nimport { BehaviorSubject, distinctUntilChanged, filter, map, Observable, of, startWith, switchMap, throttleTime, combineLatest } from 'rxjs';\nimport { DbxInjectionComponentConfig } from '@dereekb/dbx-core';\n\n@Injectable()\nexport class DbxTableDateRangeDayDistanceInputCellInputRangeSelectionStrategy<D> implements MatDateRangeSelectionStrategy<D> {\n  constructor(private _dateAdapter: DateAdapter<D>, private dbxTableDateRangeDayDistanceInputCellInputComponent: DbxTableDateRangeDayDistanceInputCellInputComponent) {}\n\n  selectionFinished(date: D | null): DateRange<D> {\n    return this._createFiveDayRange(date);\n  }\n\n  createPreview(activeDate: D | null): DateRange<D> {\n    return this._createFiveDayRange(activeDate);\n  }\n\n  private _createFiveDayRange(date: D | null): DateRange<D> {\n    if (date) {\n      const start = date;\n      const end = this._dateAdapter.addCalendarDays(date, this.dbxTableDateRangeDayDistanceInputCellInputComponent.daysDistance);\n      return new DateRange<D>(start, end);\n    }\n\n    return new DateRange<D>(null, null);\n  }\n}\n\nexport interface DbxTableDateRangeDayDistanceInputCellInputComponentConfig {\n  /**\n   * Button format for the dates\n   */\n  buttonFormat?: string;\n  /**\n   * Distance from the start to span.\n   */\n  daysDistance: Days;\n  minDate?: Maybe<Date>;\n  maxDate?: Maybe<Date>;\n}\n\nexport const DEFAULT_DBX_TABLE_DATE_RANGE_DAY_DISTIANCE_INPUT_CELL_COMPONENT_CONFIG = { daysDistance: 6 };\n\nexport const DEFAULT_DBX_TABLE_DATE_RANGE_DAY_BUTTON_FORMAT = 'MMM dd';\n\n/**\n * Cell input for a DateRangeDayDistanceInput value.\n */\n@Component({\n  template: `\n    <div class=\"dbx-table-date-range-distance-input-cell\">\n      <mat-date-range-input class=\"dbx-table-date-range-distance-input\" [min]=\"minDate$ | async\" [max]=\"maxDate$ | async\" [formGroup]=\"range\" [rangePicker]=\"picker\">\n        <input matStartDate formControlName=\"start\" placeholder=\"Start date\" />\n        <input matEndDate formControlName=\"end\" placeholder=\"End date\" />\n      </mat-date-range-input>\n      <button mat-stroked-button color=\"primary\" (click)=\"picker.open()\">{{ dateRangeString$ | async }}</button>\n      <mat-date-range-picker #picker (opened)=\"pickerOpened()\" (closed)=\"pickerClosed()\"></mat-date-range-picker>\n    </div>\n  `,\n  providers: [\n    {\n      provide: MAT_DATE_RANGE_SELECTION_STRATEGY,\n      useClass: DbxTableDateRangeDayDistanceInputCellInputRangeSelectionStrategy\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DbxTableDateRangeDayDistanceInputCellInputComponent implements OnInit, OnDestroy {\n  private _syncSub = new SubscriptionObject();\n  private _valueSub = new SubscriptionObject();\n\n  private _pickerOpened = new BehaviorSubject<boolean>(false);\n  private _config = new BehaviorSubject<DbxTableDateRangeDayDistanceInputCellInputComponentConfig>(DEFAULT_DBX_TABLE_DATE_RANGE_DAY_DISTIANCE_INPUT_CELL_COMPONENT_CONFIG);\n\n  readonly range = new FormGroup({\n    start: new FormControl<Maybe<Date>>(null),\n    end: new FormControl<Maybe<Date>>(null)\n  });\n\n  readonly pickerOpened$ = this._pickerOpened.asObservable();\n\n  readonly minDate$ = this._config.pipe(map((x) => x.minDate));\n  readonly maxDate$ = this._config.pipe(map((x) => x.maxDate));\n\n  readonly buttonFormat$ = this._config.pipe(map((x) => x.buttonFormat ?? DEFAULT_DBX_TABLE_DATE_RANGE_DAY_BUTTON_FORMAT));\n\n  readonly dateRangeString$ = combineLatest([this.buttonFormat$, this.range.valueChanges]).pipe(\n    map(([buttonFormat, { start, end }]) => {\n      if (start && end) {\n        return `${formatDate(start, buttonFormat)} - ${formatDate(end, buttonFormat)}`;\n      } else {\n        return `Select Date`;\n      }\n    })\n  );\n\n  constructor(readonly tableStore: DbxTableStore<DateRangeDayDistanceInput>) {}\n\n  ngOnInit(): void {\n    this._syncSub.subscription = this.tableStore.input$.subscribe((x) => {\n      const start = x?.date ?? null;\n      const end = start ? addDays(start, this.daysDistance) : undefined;\n\n      this.range.setValue({\n        start,\n        end\n      });\n    });\n\n    this._valueSub.subscription = this._pickerOpened\n      .pipe(\n        distinctUntilChanged(),\n        switchMap((opened) => {\n          let obs: Observable<{ start?: Maybe<Date> }>;\n\n          if (opened) {\n            obs = of({});\n          } else {\n            obs = this.range.valueChanges.pipe(startWith(this.range.value));\n          }\n\n          return obs;\n        }),\n        filter((x) => Boolean(x.start)),\n        distinctUntilChanged((a, b) => isSameDateDay(a.start, b.start)),\n        throttleTime(100, undefined, { trailing: true })\n      )\n      .subscribe((x) => {\n        if (x.start) {\n          this.tableStore.setInput({ date: x.start, distance: this.daysDistance });\n        }\n      });\n  }\n\n  ngOnDestroy(): void {\n    this._pickerOpened.complete();\n    this._config.complete();\n    this._syncSub.destroy();\n    this._valueSub.destroy();\n  }\n\n  get daysDistance() {\n    return this._config.value.daysDistance;\n  }\n\n  get config() {\n    return this._config.value;\n  }\n\n  set config(config: Maybe<DbxTableDateRangeDayDistanceInputCellInputComponentConfig>) {\n    this._config.next(config || DEFAULT_DBX_TABLE_DATE_RANGE_DAY_DISTIANCE_INPUT_CELL_COMPONENT_CONFIG);\n  }\n\n  pickerOpened() {\n    this._pickerOpened.next(true);\n  }\n\n  pickerClosed() {\n    this._pickerOpened.next(false);\n  }\n}\n\nexport function dbxTableDateRangeDayDistanceInputCellInput(componentConfig?: DbxTableDateRangeDayDistanceInputCellInputComponentConfig): DbxInjectionComponentConfig<DbxTableDateRangeDayDistanceInputCellInputComponent> {\n  const config: DbxInjectionComponentConfig<DbxTableDateRangeDayDistanceInputCellInputComponent> = {\n    componentClass: DbxTableDateRangeDayDistanceInputCellInputComponent,\n    init: (x) => {\n      x.config = componentConfig;\n    }\n  };\n\n  return config;\n}\n"]}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export * from './date.table.column.header.component';
|
|
2
|
+
export * from './daterange.table.cell.input.component';
|
|
3
|
+
export * from './table.date.module';
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3RhYmxlL3NyYy9saWIvZGF0ZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyxxQkFBcUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZGF0ZS50YWJsZS5jb2x1bW4uaGVhZGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2RhdGVyYW5nZS50YWJsZS5jZWxsLmlucHV0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3RhYmxlLmRhdGUubW9kdWxlJztcbiJdfQ==
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
2
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
3
|
+
import { DbxLoadingModule } from '@dereekb/dbx-web';
|
|
4
|
+
import { MatTableModule } from '@angular/material/table';
|
|
5
|
+
import { NgModule } from '@angular/core';
|
|
6
|
+
import { CommonModule } from '@angular/common';
|
|
7
|
+
import { DbxInjectionComponentModule } from '@dereekb/dbx-core';
|
|
8
|
+
import { DbxTableDateHeaderComponent } from './date.table.column.header.component';
|
|
9
|
+
import { DbxTableDateRangeDayDistanceInputCellInputComponent } from './daterange.table.cell.input.component';
|
|
10
|
+
import { MatDatepickerModule } from '@angular/material/datepicker';
|
|
11
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
const declarations = [
|
|
14
|
+
//
|
|
15
|
+
DbxTableDateHeaderComponent,
|
|
16
|
+
DbxTableDateRangeDayDistanceInputCellInputComponent
|
|
17
|
+
];
|
|
18
|
+
export class DbxTableDateModule {
|
|
19
|
+
}
|
|
20
|
+
DbxTableDateModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableDateModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
21
|
+
DbxTableDateModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: DbxTableDateModule, declarations: [
|
|
22
|
+
//
|
|
23
|
+
DbxTableDateHeaderComponent,
|
|
24
|
+
DbxTableDateRangeDayDistanceInputCellInputComponent], imports: [
|
|
25
|
+
//
|
|
26
|
+
CommonModule,
|
|
27
|
+
DbxLoadingModule,
|
|
28
|
+
DbxInjectionComponentModule,
|
|
29
|
+
FormsModule,
|
|
30
|
+
ReactiveFormsModule,
|
|
31
|
+
MatIconModule,
|
|
32
|
+
MatDatepickerModule,
|
|
33
|
+
MatButtonModule,
|
|
34
|
+
MatTableModule], exports: [
|
|
35
|
+
//
|
|
36
|
+
DbxTableDateHeaderComponent,
|
|
37
|
+
DbxTableDateRangeDayDistanceInputCellInputComponent] });
|
|
38
|
+
DbxTableDateModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableDateModule, imports: [
|
|
39
|
+
//
|
|
40
|
+
CommonModule,
|
|
41
|
+
DbxLoadingModule,
|
|
42
|
+
DbxInjectionComponentModule,
|
|
43
|
+
FormsModule,
|
|
44
|
+
ReactiveFormsModule,
|
|
45
|
+
MatIconModule,
|
|
46
|
+
MatDatepickerModule,
|
|
47
|
+
MatButtonModule,
|
|
48
|
+
MatTableModule] });
|
|
49
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableDateModule, decorators: [{
|
|
50
|
+
type: NgModule,
|
|
51
|
+
args: [{
|
|
52
|
+
imports: [
|
|
53
|
+
//
|
|
54
|
+
CommonModule,
|
|
55
|
+
DbxLoadingModule,
|
|
56
|
+
DbxInjectionComponentModule,
|
|
57
|
+
FormsModule,
|
|
58
|
+
ReactiveFormsModule,
|
|
59
|
+
MatIconModule,
|
|
60
|
+
MatDatepickerModule,
|
|
61
|
+
MatButtonModule,
|
|
62
|
+
MatTableModule
|
|
63
|
+
],
|
|
64
|
+
declarations,
|
|
65
|
+
exports: declarations
|
|
66
|
+
}]
|
|
67
|
+
}] });
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuZGF0ZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3RhYmxlL3NyYy9saWIvZGF0ZS90YWJsZS5kYXRlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUNuRixPQUFPLEVBQUUsbURBQW1ELEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUM3RyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNuRSxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7O0FBRWxFLE1BQU0sWUFBWSxHQUFHO0lBQ25CLEVBQUU7SUFDRiwyQkFBMkI7SUFDM0IsbURBQW1EO0NBQ3BELENBQUM7QUFrQkYsTUFBTSxPQUFPLGtCQUFrQjs7Z0hBQWxCLGtCQUFrQjtpSEFBbEIsa0JBQWtCO1FBckI3QixFQUFFO1FBQ0YsMkJBQTJCO1FBQzNCLG1EQUFtRDtRQUtqRCxFQUFFO1FBQ0YsWUFBWTtRQUNaLGdCQUFnQjtRQUNoQiwyQkFBMkI7UUFDM0IsV0FBVztRQUNYLG1CQUFtQjtRQUNuQixhQUFhO1FBQ2IsbUJBQW1CO1FBQ25CLGVBQWU7UUFDZixjQUFjO1FBaEJoQixFQUFFO1FBQ0YsMkJBQTJCO1FBQzNCLG1EQUFtRDtpSEFtQnhDLGtCQUFrQjtRQWQzQixFQUFFO1FBQ0YsWUFBWTtRQUNaLGdCQUFnQjtRQUNoQiwyQkFBMkI7UUFDM0IsV0FBVztRQUNYLG1CQUFtQjtRQUNuQixhQUFhO1FBQ2IsbUJBQW1CO1FBQ25CLGVBQWU7UUFDZixjQUFjOzRGQUtMLGtCQUFrQjtrQkFoQjlCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLEVBQUU7d0JBQ0YsWUFBWTt3QkFDWixnQkFBZ0I7d0JBQ2hCLDJCQUEyQjt3QkFDM0IsV0FBVzt3QkFDWCxtQkFBbUI7d0JBQ25CLGFBQWE7d0JBQ2IsbUJBQW1CO3dCQUNuQixlQUFlO3dCQUNmLGNBQWM7cUJBQ2Y7b0JBQ0QsWUFBWTtvQkFDWixPQUFPLEVBQUUsWUFBWTtpQkFDdEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgRGJ4TG9hZGluZ01vZHVsZSB9IGZyb20gJ0BkZXJlZWtiL2RieC13ZWInO1xuaW1wb3J0IHsgTWF0VGFibGVNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90YWJsZSc7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IERieEluamVjdGlvbkNvbXBvbmVudE1vZHVsZSB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcbmltcG9ydCB7IERieFRhYmxlRGF0ZUhlYWRlckNvbXBvbmVudCB9IGZyb20gJy4vZGF0ZS50YWJsZS5jb2x1bW4uaGVhZGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYnhUYWJsZURhdGVSYW5nZURheURpc3RhbmNlSW5wdXRDZWxsSW5wdXRDb21wb25lbnQgfSBmcm9tICcuL2RhdGVyYW5nZS50YWJsZS5jZWxsLmlucHV0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNYXREYXRlcGlja2VyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGF0ZXBpY2tlcic7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuY29uc3QgZGVjbGFyYXRpb25zID0gW1xuICAvL1xuICBEYnhUYWJsZURhdGVIZWFkZXJDb21wb25lbnQsXG4gIERieFRhYmxlRGF0ZVJhbmdlRGF5RGlzdGFuY2VJbnB1dENlbGxJbnB1dENvbXBvbmVudFxuXTtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIC8vXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIERieExvYWRpbmdNb2R1bGUsXG4gICAgRGJ4SW5qZWN0aW9uQ29tcG9uZW50TW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlLFxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgTWF0SWNvbk1vZHVsZSxcbiAgICBNYXREYXRlcGlja2VyTW9kdWxlLFxuICAgIE1hdEJ1dHRvbk1vZHVsZSxcbiAgICBNYXRUYWJsZU1vZHVsZVxuICBdLFxuICBkZWNsYXJhdGlvbnMsXG4gIGV4cG9ydHM6IGRlY2xhcmF0aW9uc1xufSlcbmV4cG9ydCBjbGFzcyBEYnhUYWJsZURhdGVNb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export * from './date';
|
|
2
|
+
export * from './table.cell.action.component';
|
|
3
|
+
export * from './table.cell.input.component';
|
|
4
|
+
export * from './table.cell.summaryend.component';
|
|
5
|
+
export * from './table.cell.summarystart.component';
|
|
6
|
+
export * from './table.column.directive';
|
|
7
|
+
export * from './table.column.header.component';
|
|
8
|
+
export * from './table.column.footer.component';
|
|
9
|
+
export * from './table.component';
|
|
10
|
+
export * from './table.directive';
|
|
11
|
+
export * from './table.item.action.component';
|
|
12
|
+
export * from './table.item.cell.component';
|
|
13
|
+
export * from './table.item.directive';
|
|
14
|
+
export * from './table.item.header.component';
|
|
15
|
+
export * from './table.module';
|
|
16
|
+
export * from './table.store';
|
|
17
|
+
export * from './table';
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3RhYmxlL3NyYy9saWIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9kYXRlJztcbmV4cG9ydCAqIGZyb20gJy4vdGFibGUuY2VsbC5hY3Rpb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vdGFibGUuY2VsbC5pbnB1dC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi90YWJsZS5jZWxsLnN1bW1hcnllbmQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vdGFibGUuY2VsbC5zdW1tYXJ5c3RhcnQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vdGFibGUuY29sdW1uLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3RhYmxlLmNvbHVtbi5oZWFkZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vdGFibGUuY29sdW1uLmZvb3Rlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi90YWJsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi90YWJsZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi90YWJsZS5pdGVtLmFjdGlvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi90YWJsZS5pdGVtLmNlbGwuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vdGFibGUuaXRlbS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi90YWJsZS5pdGVtLmhlYWRlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi90YWJsZS5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi90YWJsZS5zdG9yZSc7XG5leHBvcnQgKiBmcm9tICcuL3RhYmxlJztcbiJdfQ==
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import { map, distinctUntilChanged } from 'rxjs';
|
|
3
|
+
import { DbxTableStore } from './table.store';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "./table.store";
|
|
6
|
+
import * as i2 from "@dereekb/dbx-core";
|
|
7
|
+
import * as i3 from "@angular/common";
|
|
8
|
+
export class DbxTableActionCellComponent {
|
|
9
|
+
constructor(tableStore) {
|
|
10
|
+
this.tableStore = tableStore;
|
|
11
|
+
this.config$ = this.tableStore.viewDelegate$.pipe(map((x) => x.summaryRowEnd), distinctUntilChanged());
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
DbxTableActionCellComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableActionCellComponent, deps: [{ token: i1.DbxTableStore }], target: i0.ɵɵFactoryTarget.Component });
|
|
15
|
+
DbxTableActionCellComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxTableActionCellComponent, selector: "dbx-table-action-cell", ngImport: i0, template: `
|
|
16
|
+
<dbx-injection [config]="config$ | async"></dbx-injection>
|
|
17
|
+
`, isInline: true, dependencies: [{ kind: "component", type: i2.DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableActionCellComponent, decorators: [{
|
|
19
|
+
type: Component,
|
|
20
|
+
args: [{
|
|
21
|
+
selector: 'dbx-table-action-cell',
|
|
22
|
+
template: `
|
|
23
|
+
<dbx-injection [config]="config$ | async"></dbx-injection>
|
|
24
|
+
`,
|
|
25
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
26
|
+
}]
|
|
27
|
+
}], ctorParameters: function () { return [{ type: i1.DbxTableStore }]; } });
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY2VsbC5hY3Rpb24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi90YWJsZS9zcmMvbGliL3RhYmxlLmNlbGwuYWN0aW9uLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25FLE9BQU8sRUFBRSxHQUFHLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDakQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFTOUMsTUFBTSxPQUFPLDJCQUEyQjtJQU10QyxZQUFxQixVQUF5QjtRQUF6QixlQUFVLEdBQVYsVUFBVSxDQUFlO1FBTHJDLFlBQU8sR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQ25ELEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxFQUMzQixvQkFBb0IsRUFBRSxDQUN2QixDQUFDO0lBRStDLENBQUM7O3lIQU52QywyQkFBMkI7NkdBQTNCLDJCQUEyQiw2REFMNUI7O0dBRVQ7NEZBR1UsMkJBQTJCO2tCQVB2QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSx1QkFBdUI7b0JBQ2pDLFFBQVEsRUFBRTs7R0FFVDtvQkFDRCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBtYXAsIGRpc3RpbmN0VW50aWxDaGFuZ2VkIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBEYnhUYWJsZVN0b3JlIH0gZnJvbSAnLi90YWJsZS5zdG9yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2RieC10YWJsZS1hY3Rpb24tY2VsbCcsXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRieC1pbmplY3Rpb24gW2NvbmZpZ109XCJjb25maWckIHwgYXN5bmNcIj48L2RieC1pbmplY3Rpb24+XG4gIGAsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIERieFRhYmxlQWN0aW9uQ2VsbENvbXBvbmVudCB7XG4gIHJlYWRvbmx5IGNvbmZpZyQgPSB0aGlzLnRhYmxlU3RvcmUudmlld0RlbGVnYXRlJC5waXBlKFxuICAgIG1hcCgoeCkgPT4geC5zdW1tYXJ5Um93RW5kKSxcbiAgICBkaXN0aW5jdFVudGlsQ2hhbmdlZCgpXG4gICk7XG5cbiAgY29uc3RydWN0b3IocmVhZG9ubHkgdGFibGVTdG9yZTogRGJ4VGFibGVTdG9yZSkge31cbn1cbiJdfQ==
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import { map, distinctUntilChanged } from 'rxjs';
|
|
3
|
+
import { DbxTableStore } from './table.store';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "./table.store";
|
|
6
|
+
import * as i2 from "@dereekb/dbx-core";
|
|
7
|
+
import * as i3 from "@angular/common";
|
|
8
|
+
/**
|
|
9
|
+
* A table header component used for injecting the input picker view.
|
|
10
|
+
*/
|
|
11
|
+
export class DbxTableInputCellComponent {
|
|
12
|
+
constructor(tableStore) {
|
|
13
|
+
this.tableStore = tableStore;
|
|
14
|
+
this.config$ = this.tableStore.viewDelegate$.pipe(map((x) => x.inputHeader), distinctUntilChanged());
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
DbxTableInputCellComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableInputCellComponent, deps: [{ token: i1.DbxTableStore }], target: i0.ɵɵFactoryTarget.Component });
|
|
18
|
+
DbxTableInputCellComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxTableInputCellComponent, selector: "dbx-table-input-cell", ngImport: i0, template: `
|
|
19
|
+
<dbx-injection [config]="config$ | async"></dbx-injection>
|
|
20
|
+
`, isInline: true, dependencies: [{ kind: "component", type: i2.DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
21
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableInputCellComponent, decorators: [{
|
|
22
|
+
type: Component,
|
|
23
|
+
args: [{
|
|
24
|
+
selector: 'dbx-table-input-cell',
|
|
25
|
+
template: `
|
|
26
|
+
<dbx-injection [config]="config$ | async"></dbx-injection>
|
|
27
|
+
`,
|
|
28
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
29
|
+
}]
|
|
30
|
+
}], ctorParameters: function () { return [{ type: i1.DbxTableStore }]; } });
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY2VsbC5pbnB1dC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3RhYmxlL3NyYy9saWIvdGFibGUuY2VsbC5pbnB1dC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRSxPQUFPLEVBQUUsR0FBRyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7O0FBRTlDOztHQUVHO0FBUUgsTUFBTSxPQUFPLDBCQUEwQjtJQU1yQyxZQUFxQixVQUF5QjtRQUF6QixlQUFVLEdBQVYsVUFBVSxDQUFlO1FBTHJDLFlBQU8sR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQ25ELEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxFQUN6QixvQkFBb0IsRUFBRSxDQUN2QixDQUFDO0lBRStDLENBQUM7O3dIQU52QywwQkFBMEI7NEdBQTFCLDBCQUEwQiw0REFMM0I7O0dBRVQ7NEZBR1UsMEJBQTBCO2tCQVB0QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxzQkFBc0I7b0JBQ2hDLFFBQVEsRUFBRTs7R0FFVDtvQkFDRCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBtYXAsIGRpc3RpbmN0VW50aWxDaGFuZ2VkIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBEYnhUYWJsZVN0b3JlIH0gZnJvbSAnLi90YWJsZS5zdG9yZSc7XG5cbi8qKlxuICogQSB0YWJsZSBoZWFkZXIgY29tcG9uZW50IHVzZWQgZm9yIGluamVjdGluZyB0aGUgaW5wdXQgcGlja2VyIHZpZXcuXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2RieC10YWJsZS1pbnB1dC1jZWxsJyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8ZGJ4LWluamVjdGlvbiBbY29uZmlnXT1cImNvbmZpZyQgfCBhc3luY1wiPjwvZGJ4LWluamVjdGlvbj5cbiAgYCxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgRGJ4VGFibGVJbnB1dENlbGxDb21wb25lbnQge1xuICByZWFkb25seSBjb25maWckID0gdGhpcy50YWJsZVN0b3JlLnZpZXdEZWxlZ2F0ZSQucGlwZShcbiAgICBtYXAoKHgpID0+IHguaW5wdXRIZWFkZXIpLFxuICAgIGRpc3RpbmN0VW50aWxDaGFuZ2VkKClcbiAgKTtcblxuICBjb25zdHJ1Y3RvcihyZWFkb25seSB0YWJsZVN0b3JlOiBEYnhUYWJsZVN0b3JlKSB7fVxufVxuIl19
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import { map, distinctUntilChanged } from 'rxjs';
|
|
3
|
+
import { DbxTableStore } from './table.store';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "./table.store";
|
|
6
|
+
import * as i2 from "@dereekb/dbx-core";
|
|
7
|
+
import * as i3 from "@angular/common";
|
|
8
|
+
export class DbxTableSummaryEndCellComponent {
|
|
9
|
+
constructor(tableStore) {
|
|
10
|
+
this.tableStore = tableStore;
|
|
11
|
+
this.config$ = this.tableStore.viewDelegate$.pipe(map((x) => x.summaryRowEnd), distinctUntilChanged());
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
DbxTableSummaryEndCellComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableSummaryEndCellComponent, deps: [{ token: i1.DbxTableStore }], target: i0.ɵɵFactoryTarget.Component });
|
|
15
|
+
DbxTableSummaryEndCellComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxTableSummaryEndCellComponent, selector: "dbx-table-summary-end-cell", ngImport: i0, template: `
|
|
16
|
+
<dbx-injection [config]="config$ | async"></dbx-injection>
|
|
17
|
+
`, isInline: true, dependencies: [{ kind: "component", type: i2.DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableSummaryEndCellComponent, decorators: [{
|
|
19
|
+
type: Component,
|
|
20
|
+
args: [{
|
|
21
|
+
selector: 'dbx-table-summary-end-cell',
|
|
22
|
+
template: `
|
|
23
|
+
<dbx-injection [config]="config$ | async"></dbx-injection>
|
|
24
|
+
`,
|
|
25
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
26
|
+
}]
|
|
27
|
+
}], ctorParameters: function () { return [{ type: i1.DbxTableStore }]; } });
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY2VsbC5zdW1tYXJ5ZW5kLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvdGFibGUvc3JjL2xpYi90YWJsZS5jZWxsLnN1bW1hcnllbmQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkUsT0FBTyxFQUFFLEdBQUcsRUFBRSxvQkFBb0IsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUNqRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7OztBQVM5QyxNQUFNLE9BQU8sK0JBQStCO0lBTTFDLFlBQXFCLFVBQXlCO1FBQXpCLGVBQVUsR0FBVixVQUFVLENBQWU7UUFMckMsWUFBTyxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLElBQUksQ0FDbkQsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsYUFBYSxDQUFDLEVBQzNCLG9CQUFvQixFQUFFLENBQ3ZCLENBQUM7SUFFK0MsQ0FBQzs7NkhBTnZDLCtCQUErQjtpSEFBL0IsK0JBQStCLGtFQUxoQzs7R0FFVDs0RkFHVSwrQkFBK0I7a0JBUDNDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLDRCQUE0QjtvQkFDdEMsUUFBUSxFQUFFOztHQUVUO29CQUNELGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2lCQUNoRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IG1hcCwgZGlzdGluY3RVbnRpbENoYW5nZWQgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IERieFRhYmxlU3RvcmUgfSBmcm9tICcuL3RhYmxlLnN0b3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZGJ4LXRhYmxlLXN1bW1hcnktZW5kLWNlbGwnLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkYngtaW5qZWN0aW9uIFtjb25maWddPVwiY29uZmlnJCB8IGFzeW5jXCI+PC9kYngtaW5qZWN0aW9uPlxuICBgLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBEYnhUYWJsZVN1bW1hcnlFbmRDZWxsQ29tcG9uZW50IHtcbiAgcmVhZG9ubHkgY29uZmlnJCA9IHRoaXMudGFibGVTdG9yZS52aWV3RGVsZWdhdGUkLnBpcGUoXG4gICAgbWFwKCh4KSA9PiB4LnN1bW1hcnlSb3dFbmQpLFxuICAgIGRpc3RpbmN0VW50aWxDaGFuZ2VkKClcbiAgKTtcblxuICBjb25zdHJ1Y3RvcihyZWFkb25seSB0YWJsZVN0b3JlOiBEYnhUYWJsZVN0b3JlKSB7fVxufVxuIl19
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import { map, distinctUntilChanged } from 'rxjs';
|
|
3
|
+
import { DbxTableStore } from './table.store';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "./table.store";
|
|
6
|
+
import * as i2 from "@dereekb/dbx-core";
|
|
7
|
+
import * as i3 from "@angular/common";
|
|
8
|
+
/**
|
|
9
|
+
* A table header component used for injecting the input picker view.
|
|
10
|
+
*/
|
|
11
|
+
export class DbxTableSummaryStartCellComponent {
|
|
12
|
+
constructor(tableStore) {
|
|
13
|
+
this.tableStore = tableStore;
|
|
14
|
+
this.config$ = this.tableStore.viewDelegate$.pipe(map((x) => x.summaryRowHeader), distinctUntilChanged());
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
DbxTableSummaryStartCellComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableSummaryStartCellComponent, deps: [{ token: i1.DbxTableStore }], target: i0.ɵɵFactoryTarget.Component });
|
|
18
|
+
DbxTableSummaryStartCellComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxTableSummaryStartCellComponent, selector: "dbx-table-summary-start-cell", ngImport: i0, template: `
|
|
19
|
+
<dbx-injection [config]="config$ | async"></dbx-injection>
|
|
20
|
+
`, isInline: true, dependencies: [{ kind: "component", type: i2.DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
21
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableSummaryStartCellComponent, decorators: [{
|
|
22
|
+
type: Component,
|
|
23
|
+
args: [{
|
|
24
|
+
selector: 'dbx-table-summary-start-cell',
|
|
25
|
+
template: `
|
|
26
|
+
<dbx-injection [config]="config$ | async"></dbx-injection>
|
|
27
|
+
`,
|
|
28
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
29
|
+
}]
|
|
30
|
+
}], ctorParameters: function () { return [{ type: i1.DbxTableStore }]; } });
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY2VsbC5zdW1tYXJ5c3RhcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi90YWJsZS9zcmMvbGliL3RhYmxlLmNlbGwuc3VtbWFyeXN0YXJ0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25FLE9BQU8sRUFBRSxHQUFHLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDakQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFFOUM7O0dBRUc7QUFRSCxNQUFNLE9BQU8saUNBQWlDO0lBTTVDLFlBQXFCLFVBQXlCO1FBQXpCLGVBQVUsR0FBVixVQUFVLENBQWU7UUFMckMsWUFBTyxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLElBQUksQ0FDbkQsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsZ0JBQWdCLENBQUMsRUFDOUIsb0JBQW9CLEVBQUUsQ0FDdkIsQ0FBQztJQUUrQyxDQUFDOzsrSEFOdkMsaUNBQWlDO21IQUFqQyxpQ0FBaUMsb0VBTGxDOztHQUVUOzRGQUdVLGlDQUFpQztrQkFQN0MsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsOEJBQThCO29CQUN4QyxRQUFRLEVBQUU7O0dBRVQ7b0JBQ0QsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2hEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgbWFwLCBkaXN0aW5jdFVudGlsQ2hhbmdlZCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgRGJ4VGFibGVTdG9yZSB9IGZyb20gJy4vdGFibGUuc3RvcmUnO1xuXG4vKipcbiAqIEEgdGFibGUgaGVhZGVyIGNvbXBvbmVudCB1c2VkIGZvciBpbmplY3RpbmcgdGhlIGlucHV0IHBpY2tlciB2aWV3LlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkYngtdGFibGUtc3VtbWFyeS1zdGFydC1jZWxsJyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8ZGJ4LWluamVjdGlvbiBbY29uZmlnXT1cImNvbmZpZyQgfCBhc3luY1wiPjwvZGJ4LWluamVjdGlvbj5cbiAgYCxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgRGJ4VGFibGVTdW1tYXJ5U3RhcnRDZWxsQ29tcG9uZW50IHtcbiAgcmVhZG9ubHkgY29uZmlnJCA9IHRoaXMudGFibGVTdG9yZS52aWV3RGVsZWdhdGUkLnBpcGUoXG4gICAgbWFwKCh4KSA9PiB4LnN1bW1hcnlSb3dIZWFkZXIpLFxuICAgIGRpc3RpbmN0VW50aWxDaGFuZ2VkKClcbiAgKTtcblxuICBjb25zdHJ1Y3RvcihyZWFkb25seSB0YWJsZVN0b3JlOiBEYnhUYWJsZVN0b3JlKSB7fVxufVxuIl19
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { filterMaybe } from '@dereekb/rxjs';
|
|
2
|
+
import { Input, Directive } from '@angular/core';
|
|
3
|
+
import { distinctUntilChanged, BehaviorSubject } from 'rxjs';
|
|
4
|
+
import { DbxTableStore } from './table.store';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "./table.store";
|
|
7
|
+
/**
|
|
8
|
+
* Abstract directive that has a column input.
|
|
9
|
+
*/
|
|
10
|
+
export class AbstractDbxTableColumnDirective {
|
|
11
|
+
constructor(tableStore) {
|
|
12
|
+
this.tableStore = tableStore;
|
|
13
|
+
this._column = new BehaviorSubject(undefined);
|
|
14
|
+
this.column$ = this._column.pipe(filterMaybe(), distinctUntilChanged());
|
|
15
|
+
}
|
|
16
|
+
set column(column) {
|
|
17
|
+
this._column.next(column);
|
|
18
|
+
}
|
|
19
|
+
ngOnDestroy() {
|
|
20
|
+
this._column.complete();
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
AbstractDbxTableColumnDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AbstractDbxTableColumnDirective, deps: [{ token: i1.DbxTableStore }], target: i0.ɵɵFactoryTarget.Directive });
|
|
24
|
+
AbstractDbxTableColumnDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: AbstractDbxTableColumnDirective, inputs: { column: "column" }, ngImport: i0 });
|
|
25
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AbstractDbxTableColumnDirective, decorators: [{
|
|
26
|
+
type: Directive
|
|
27
|
+
}], ctorParameters: function () { return [{ type: i1.DbxTableStore }]; }, propDecorators: { column: [{
|
|
28
|
+
type: Input
|
|
29
|
+
}] } });
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY29sdW1uLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvdGFibGUvc3JjL2xpYi90YWJsZS5jb2x1bW4uZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDNUMsT0FBTyxFQUFhLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDNUQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLGVBQWUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUM3RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFJOUM7O0dBRUc7QUFFSCxNQUFNLE9BQU8sK0JBQStCO0lBSTFDLFlBQXFCLFVBQXFDO1FBQXJDLGVBQVUsR0FBVixVQUFVLENBQTJCO1FBSHpDLFlBQU8sR0FBRyxJQUFJLGVBQWUsQ0FBMkIsU0FBUyxDQUFDLENBQUM7UUFDM0UsWUFBTyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxFQUFFLG9CQUFvQixFQUFFLENBQUMsQ0FBQztJQUVmLENBQUM7SUFFOUQsSUFDSSxNQUFNLENBQUMsTUFBZ0M7UUFDekMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDNUIsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQzFCLENBQUM7OzZIQWJVLCtCQUErQjtpSEFBL0IsK0JBQStCOzRGQUEvQiwrQkFBK0I7a0JBRDNDLFNBQVM7b0dBUUosTUFBTTtzQkFEVCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZmlsdGVyTWF5YmUgfSBmcm9tICdAZGVyZWVrYi9yeGpzJztcbmltcG9ydCB7IE9uRGVzdHJveSwgSW5wdXQsIERpcmVjdGl2ZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgZGlzdGluY3RVbnRpbENoYW5nZWQsIEJlaGF2aW9yU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgRGJ4VGFibGVTdG9yZSB9IGZyb20gJy4vdGFibGUuc3RvcmUnO1xuaW1wb3J0IHsgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCB7IERieFRhYmxlQ29sdW1uIH0gZnJvbSAnLi90YWJsZSc7XG5cbi8qKlxuICogQWJzdHJhY3QgZGlyZWN0aXZlIHRoYXQgaGFzIGEgY29sdW1uIGlucHV0LlxuICovXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBjbGFzcyBBYnN0cmFjdERieFRhYmxlQ29sdW1uRGlyZWN0aXZlPEM+IGltcGxlbWVudHMgT25EZXN0cm95IHtcbiAgcHJpdmF0ZSByZWFkb25seSBfY29sdW1uID0gbmV3IEJlaGF2aW9yU3ViamVjdDxNYXliZTxEYnhUYWJsZUNvbHVtbjxDPj4+KHVuZGVmaW5lZCk7XG4gIHJlYWRvbmx5IGNvbHVtbiQgPSB0aGlzLl9jb2x1bW4ucGlwZShmaWx0ZXJNYXliZSgpLCBkaXN0aW5jdFVudGlsQ2hhbmdlZCgpKTtcblxuICBjb25zdHJ1Y3RvcihyZWFkb25seSB0YWJsZVN0b3JlOiBEYnhUYWJsZVN0b3JlPHVua25vd24sIEM+KSB7fVxuXG4gIEBJbnB1dCgpXG4gIHNldCBjb2x1bW4oY29sdW1uOiBNYXliZTxEYnhUYWJsZUNvbHVtbjxDPj4pIHtcbiAgICB0aGlzLl9jb2x1bW4ubmV4dChjb2x1bW4pO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy5fY29sdW1uLmNvbXBsZXRlKCk7XG4gIH1cbn1cbiJdfQ==
|