@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.
Files changed (126) hide show
  1. package/calendar/package.json +2 -2
  2. package/esm2020/lib/action/snackbar/action.snackbar.component.mjs +1 -1
  3. package/esm2020/lib/action/transition/transition.safety.dialog.component.mjs +1 -1
  4. package/esm2020/lib/button/button.component.mjs +14 -2
  5. package/esm2020/lib/button/progress/base.progress.button.directive.mjs +3 -1
  6. package/esm2020/lib/button/progress/button.progress.config.mjs +1 -1
  7. package/esm2020/lib/button/progress/spinner.button.component.mjs +7 -4
  8. package/esm2020/lib/extension/model/model.tracker.view.storage.mjs +2 -3
  9. package/esm2020/lib/extension/model/model.types.service.mjs +2 -3
  10. package/esm2020/lib/extension/model/state/effects/tracker.effects.mjs +2 -2
  11. package/esm2020/lib/interaction/filter/filter.preset.menu.component.mjs +2 -3
  12. package/esm2020/lib/interaction/filter/filter.preset.mjs +2 -3
  13. package/esm2020/lib/interaction/filter/filter.wrapper.component.mjs +1 -1
  14. package/esm2020/lib/interaction/popup/popup.controls.buttons.component.mjs +1 -1
  15. package/esm2020/lib/layout/column/two/two.column.sref.showright.directive.mjs +2 -3
  16. package/esm2020/lib/layout/content/content.layout.module.mjs +31 -4
  17. package/esm2020/lib/layout/content/content.pit.directive.mjs +19 -0
  18. package/esm2020/lib/layout/content/index.mjs +2 -1
  19. package/esm2020/lib/layout/list/list.wrapper.mjs +1 -1
  20. package/esm2020/mapbox/lib/mapbox.change.service.mjs +2 -3
  21. package/esm2020/table/dereekb-dbx-web-table.mjs +5 -0
  22. package/esm2020/table/index.mjs +2 -0
  23. package/esm2020/table/lib/date/date.table.column.header.component.mjs +49 -0
  24. package/esm2020/table/lib/date/daterange.table.cell.input.component.mjs +166 -0
  25. package/esm2020/table/lib/date/index.mjs +4 -0
  26. package/esm2020/table/lib/date/table.date.module.mjs +68 -0
  27. package/esm2020/table/lib/index.mjs +18 -0
  28. package/esm2020/table/lib/table.cell.action.component.mjs +28 -0
  29. package/esm2020/table/lib/table.cell.input.component.mjs +31 -0
  30. package/esm2020/table/lib/table.cell.summaryend.component.mjs +28 -0
  31. package/esm2020/table/lib/table.cell.summarystart.component.mjs +31 -0
  32. package/esm2020/table/lib/table.column.directive.mjs +30 -0
  33. package/esm2020/table/lib/table.column.footer.component.mjs +35 -0
  34. package/esm2020/table/lib/table.column.header.component.mjs +35 -0
  35. package/esm2020/table/lib/table.component.mjs +58 -0
  36. package/esm2020/table/lib/table.directive.mjs +37 -0
  37. package/esm2020/table/lib/table.item.action.component.mjs +35 -0
  38. package/esm2020/table/lib/table.item.cell.component.mjs +39 -0
  39. package/esm2020/table/lib/table.item.directive.mjs +30 -0
  40. package/esm2020/table/lib/table.item.header.component.mjs +27 -0
  41. package/esm2020/table/lib/table.mjs +2 -0
  42. package/esm2020/table/lib/table.module.mjs +74 -0
  43. package/esm2020/table/lib/table.store.mjs +53 -0
  44. package/fesm2015/dereekb-dbx-web-mapbox.mjs +1 -2
  45. package/fesm2015/dereekb-dbx-web-mapbox.mjs.map +1 -1
  46. package/fesm2015/dereekb-dbx-web-table.mjs +745 -0
  47. package/fesm2015/dereekb-dbx-web-table.mjs.map +1 -0
  48. package/fesm2015/dereekb-dbx-web.mjs +99 -38
  49. package/fesm2015/dereekb-dbx-web.mjs.map +1 -1
  50. package/fesm2020/dereekb-dbx-web-mapbox.mjs +1 -2
  51. package/fesm2020/dereekb-dbx-web-mapbox.mjs.map +1 -1
  52. package/fesm2020/dereekb-dbx-web-table.mjs +738 -0
  53. package/fesm2020/dereekb-dbx-web-table.mjs.map +1 -0
  54. package/fesm2020/dereekb-dbx-web.mjs +97 -38
  55. package/fesm2020/dereekb-dbx-web.mjs.map +1 -1
  56. package/lib/button/_button.scss +4 -0
  57. package/lib/button/button.component.d.ts +5 -2
  58. package/lib/button/progress/button.progress.config.d.ts +7 -0
  59. package/lib/button/progress/spinner.button.component.d.ts +1 -0
  60. package/lib/extension/_extension.scss +19 -0
  61. package/lib/extension/table/_table.scss +60 -0
  62. package/lib/layout/content/_content.scss +14 -0
  63. package/lib/layout/content/content.layout.module.d.ts +3 -2
  64. package/lib/layout/content/content.pit.directive.d.ts +8 -0
  65. package/lib/layout/content/index.d.ts +1 -0
  66. package/lib/layout/list/list.wrapper.d.ts +2 -1
  67. package/lib/layout/style/_style.scss +4 -0
  68. package/lib/style/_config.scss +8 -2
  69. package/mapbox/esm2020/lib/mapbox.change.service.mjs +2 -3
  70. package/mapbox/fesm2015/dereekb-dbx-web-mapbox.mjs +1 -2
  71. package/mapbox/fesm2015/dereekb-dbx-web-mapbox.mjs.map +1 -1
  72. package/mapbox/fesm2020/dereekb-dbx-web-mapbox.mjs +1 -2
  73. package/mapbox/fesm2020/dereekb-dbx-web-mapbox.mjs.map +1 -1
  74. package/mapbox/package.json +3 -3
  75. package/package.json +14 -6
  76. package/table/README.md +6 -0
  77. package/table/esm2020/dereekb-dbx-web-table.mjs +5 -0
  78. package/table/esm2020/index.mjs +2 -0
  79. package/table/esm2020/lib/date/date.table.column.header.component.mjs +49 -0
  80. package/table/esm2020/lib/date/daterange.table.cell.input.component.mjs +166 -0
  81. package/table/esm2020/lib/date/index.mjs +4 -0
  82. package/table/esm2020/lib/date/table.date.module.mjs +68 -0
  83. package/table/esm2020/lib/index.mjs +18 -0
  84. package/table/esm2020/lib/table.cell.action.component.mjs +28 -0
  85. package/table/esm2020/lib/table.cell.input.component.mjs +31 -0
  86. package/table/esm2020/lib/table.cell.summaryend.component.mjs +28 -0
  87. package/table/esm2020/lib/table.cell.summarystart.component.mjs +31 -0
  88. package/table/esm2020/lib/table.column.directive.mjs +30 -0
  89. package/table/esm2020/lib/table.column.footer.component.mjs +35 -0
  90. package/table/esm2020/lib/table.column.header.component.mjs +35 -0
  91. package/table/esm2020/lib/table.component.mjs +58 -0
  92. package/table/esm2020/lib/table.directive.mjs +37 -0
  93. package/table/esm2020/lib/table.item.action.component.mjs +35 -0
  94. package/table/esm2020/lib/table.item.cell.component.mjs +39 -0
  95. package/table/esm2020/lib/table.item.directive.mjs +30 -0
  96. package/table/esm2020/lib/table.item.header.component.mjs +27 -0
  97. package/table/esm2020/lib/table.mjs +2 -0
  98. package/table/esm2020/lib/table.module.mjs +74 -0
  99. package/table/esm2020/lib/table.store.mjs +53 -0
  100. package/table/fesm2015/dereekb-dbx-web-table.mjs +745 -0
  101. package/table/fesm2015/dereekb-dbx-web-table.mjs.map +1 -0
  102. package/table/fesm2020/dereekb-dbx-web-table.mjs +738 -0
  103. package/table/fesm2020/dereekb-dbx-web-table.mjs.map +1 -0
  104. package/table/index.d.ts +1 -0
  105. package/table/lib/date/date.table.column.header.component.d.ts +18 -0
  106. package/table/lib/date/daterange.table.cell.input.component.d.ts +66 -0
  107. package/table/lib/date/index.d.ts +3 -0
  108. package/table/lib/date/table.date.module.d.ts +16 -0
  109. package/table/lib/index.d.ts +17 -0
  110. package/table/lib/table.cell.action.component.d.ts +9 -0
  111. package/table/lib/table.cell.input.component.d.ts +12 -0
  112. package/table/lib/table.cell.summaryend.component.d.ts +9 -0
  113. package/table/lib/table.cell.summarystart.component.d.ts +12 -0
  114. package/table/lib/table.column.directive.d.ts +18 -0
  115. package/table/lib/table.column.footer.component.d.ts +8 -0
  116. package/table/lib/table.column.header.component.d.ts +8 -0
  117. package/table/lib/table.component.d.ts +29 -0
  118. package/table/lib/table.d.ts +99 -0
  119. package/table/lib/table.directive.d.ts +16 -0
  120. package/table/lib/table.item.action.component.d.ts +7 -0
  121. package/table/lib/table.item.cell.component.d.ts +13 -0
  122. package/table/lib/table.item.directive.d.ts +17 -0
  123. package/table/lib/table.item.header.component.d.ts +7 -0
  124. package/table/lib/table.module.d.ts +22 -0
  125. package/table/lib/table.store.d.ts +38 -0
  126. 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.20.20",
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.20.20",
11
- "@dereekb/dbx-core": "9.20.20",
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",
@@ -0,0 +1,6 @@
1
+ @dereekb/dbx-web/table
2
+ =======
3
+
4
+ The sources for this package are in the main [@dereekb/dbx-components](https://github.com/dereekb/dbx-components) repo. Please file issues and pull requests against that repo.
5
+
6
+ License: MIT
@@ -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":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,UAAU,EAAqB,MAAM,eAAe,CAAC;AAClG,OAAO,EAA6B,aAAa,EAAE,MAAM,eAAe,CAAC;AACzE,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAiC,SAAS,EAAE,iCAAiC,EAAE,MAAM,8BAA8B,CAAC;AAC3H,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AACxD,OAAO,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,IAAI,UAAU,EAAE,MAAM,UAAU,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,EAAE,GAAG,EAAc,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,MAAM,CAAC;;;;;;;;AAI7I,MAAM,OAAO,gEAAgE;IAC3E,YAAoB,YAA4B,EAAU,mDAAwG;QAA9I,iBAAY,GAAZ,YAAY,CAAgB;QAAU,wDAAmD,GAAnD,mDAAmD,CAAqD;IAAG,CAAC;IAEtK,iBAAiB,CAAC,IAAc;QAC9B,OAAO,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;IACxC,CAAC;IAED,aAAa,CAAC,UAAoB;QAChC,OAAO,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC,CAAC;IAC9C,CAAC;IAEO,mBAAmB,CAAC,IAAc;QACxC,IAAI,IAAI,EAAE;YACR,MAAM,KAAK,GAAG,IAAI,CAAC;YACnB,MAAM,GAAG,GAAG,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,IAAI,EAAE,IAAI,CAAC,mDAAmD,CAAC,YAAY,CAAC,CAAC;YAC3H,OAAO,IAAI,SAAS,CAAI,KAAK,EAAE,GAAG,CAAC,CAAC;SACrC;QAED,OAAO,IAAI,SAAS,CAAI,IAAI,EAAE,IAAI,CAAC,CAAC;IACtC,CAAC;;8JAnBU,gEAAgE;kKAAhE,gEAAgE;4FAAhE,gEAAgE;kBAD5E,UAAU;;AAoCX,MAAM,CAAC,MAAM,sEAAsE,GAAG,EAAE,YAAY,EAAE,CAAC,EAAE,CAAC;AAE1G,MAAM,CAAC,MAAM,8CAA8C,GAAG,QAAQ,CAAC;AAEvE;;GAEG;AAoBH,MAAM,OAAO,mDAAmD;IA6B9D,YAAqB,UAAoD;QAApD,eAAU,GAAV,UAAU,CAA0C;QA5BjE,aAAQ,GAAG,IAAI,kBAAkB,EAAE,CAAC;QACpC,cAAS,GAAG,IAAI,kBAAkB,EAAE,CAAC;QAErC,kBAAa,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QACpD,YAAO,GAAG,IAAI,eAAe,CAA4D,sEAAsE,CAAC,CAAC;QAEhK,UAAK,GAAG,IAAI,SAAS,CAAC;YAC7B,KAAK,EAAE,IAAI,WAAW,CAAc,IAAI,CAAC;YACzC,GAAG,EAAE,IAAI,WAAW,CAAc,IAAI,CAAC;SACxC,CAAC,CAAC;QAEM,kBAAa,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC;QAElD,aAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;QACpD,aAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;QAEpD,kBAAa,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,YAAY,IAAI,8CAA8C,CAAC,CAAC,CAAC;QAEhH,qBAAgB,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAC3F,GAAG,CAAC,CAAC,CAAC,YAAY,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE;YACrC,IAAI,KAAK,IAAI,GAAG,EAAE;gBAChB,OAAO,GAAG,UAAU,CAAC,KAAK,EAAE,YAAY,CAAC,MAAM,UAAU,CAAC,GAAG,EAAE,YAAY,CAAC,EAAE,CAAC;aAChF;iBAAM;gBACL,OAAO,aAAa,CAAC;aACtB;QACH,CAAC,CAAC,CACH,CAAC;IAE0E,CAAC;IAE7E,QAAQ;QACN,IAAI,CAAC,QAAQ,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YAClE,MAAM,KAAK,GAAG,CAAC,EAAE,IAAI,IAAI,IAAI,CAAC;YAC9B,MAAM,GAAG,GAAG,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;YAElE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;gBAClB,KAAK;gBACL,GAAG;aACJ,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,SAAS,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa;aAC7C,IAAI,CACH,oBAAoB,EAAE,EACtB,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YACnB,IAAI,GAAwC,CAAC;YAE7C,IAAI,MAAM,EAAE;gBACV,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;aACd;iBAAM;gBACL,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;aACjE;YAED,OAAO,GAAG,CAAC;QACb,CAAC,CAAC,EACF,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,EAC/B,oBAAoB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,aAAa,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAC/D,YAAY,CAAC,GAAG,EAAE,SAAS,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CACjD;aACA,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACf,IAAI,CAAC,CAAC,KAAK,EAAE;gBACX,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;aAC1E;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;QAC9B,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;QACxB,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;QACxB,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;IAC3B,CAAC;IAED,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,YAAY,CAAC;IACzC,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;IAC5B,CAAC;IAED,IAAI,MAAM,CAAC,MAAwE;QACjF,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,IAAI,sEAAsE,CAAC,CAAC;IACtG,CAAC;IAED,YAAY;QACV,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;IAED,YAAY;QACV,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;;iJA5FU,mDAAmD;qIAAnD,mDAAmD,uCARnD;QACT;YACE,OAAO,EAAE,iCAAiC;YAC1C,QAAQ,EAAE,gEAAgE;SAC3E;KACF,0BAfS;;;;;;;;;GAST;4FASU,mDAAmD;kBAnB/D,SAAS;mBAAC;oBACT,QAAQ,EAAE;;;;;;;;;GAST;oBACD,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,iCAAiC;4BAC1C,QAAQ,EAAE,gEAAgE;yBAC3E;qBACF;oBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD;;AAgGD,MAAM,UAAU,0CAA0C,CAAC,eAA2E;IACpI,MAAM,MAAM,GAAqF;QAC/F,cAAc,EAAE,mDAAmD;QACnE,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE;YACV,CAAC,CAAC,MAAM,GAAG,eAAe,CAAC;QAC7B,CAAC;KACF,CAAC;IAEF,OAAO,MAAM,CAAC;AAChB,CAAC","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==