@one-paragon/angular-utilities 1.2.17 → 1.3.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 (20) hide show
  1. package/esm2022/http-request-state/HttpRequestStateFactory.mjs +2 -2
  2. package/esm2022/http-request-state/HttpRequestStateStore.mjs +19 -5
  3. package/esm2022/ngrx/actionable-selector.mjs +70 -34
  4. package/esm2022/table-builder/components/column-builder/column-builder.component.mjs +12 -1
  5. package/esm2022/table-builder/components/date-filter/date-filter.component.mjs +3 -3
  6. package/esm2022/table-builder/components/date-time-filter/date-time-filter.component.mjs +3 -3
  7. package/esm2022/table-builder/components/filter/filter.component.mjs +7 -7
  8. package/esm2022/table-builder/components/generic-table/generic-table.component.mjs +37 -41
  9. package/esm2022/table-builder/components/table-container/table-container.mjs +6 -8
  10. package/esm2022/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.mjs +4 -5
  11. package/fesm2022/one-paragon-angular-utilities.mjs +151 -95
  12. package/fesm2022/one-paragon-angular-utilities.mjs.map +1 -1
  13. package/http-request-state/HttpRequestStateStore.d.ts +4 -0
  14. package/ngrx/actionable-selector.d.ts +19 -5
  15. package/package.json +1 -1
  16. package/table-builder/components/column-builder/column-builder.component.d.ts +3 -0
  17. package/table-builder/components/generic-table/generic-table.component.d.ts +5 -10
  18. package/table-builder/components/table-container/table-container-imports.d.ts +2 -2
  19. package/table-builder/components/table-container/table-container.d.ts +5 -4
  20. package/table-builder/directives/table-wrapper.directive.d.ts +1 -1
@@ -8,7 +8,7 @@ export class HttpRequestStateFactory {
8
8
  }
9
9
  requestors = [];
10
10
  create(req, optionsOrProject, options) {
11
- const requestor = (typeof (optionsOrProject) === 'function' ? new HttpRequestStateStore(req, options, optionsOrProject) : new HttpRequestStateStore(req, options));
11
+ const requestor = (typeof (optionsOrProject) === 'function' ? new HttpRequestStateStore(req, options, optionsOrProject) : new HttpRequestStateStore(req, optionsOrProject));
12
12
  this.requestors.push(requestor);
13
13
  return requestor;
14
14
  }
@@ -48,4 +48,4 @@ function getDestroyRef(options) {
48
48
  const destroyRef = providedInjector?.get(DestroyRef) || inject(DestroyRef);
49
49
  return destroyRef;
50
50
  }
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSHR0cFJlcXVlc3RTdGF0ZUZhY3RvcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXV0aWxpdGllcy9zcmMvaHR0cC1yZXF1ZXN0LXN0YXRlL0h0dHBSZXF1ZXN0U3RhdGVGYWN0b3J5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFhLHdCQUF3QixFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVwRyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7QUFJaEUsTUFBTSxPQUFPLHVCQUF1QjtJQUVsQyxnQkFBZSxDQUFDO0lBQ2hCLFdBQVc7UUFDVCxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBRSxPQUFPLENBQUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO0lBQzdELENBQUM7SUFDTyxVQUFVLEdBQWdCLEVBQUUsQ0FBQztJQUlyQyxNQUFNLENBQWlFLEdBQWtDLEVBQUUsZ0JBQThELEVBQUUsT0FBcUM7UUFDOU0sTUFBTSxTQUFTLEdBQUcsQ0FBQyxPQUFNLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxVQUFVLENBQUMsQ0FBQyxDQUFFLElBQUkscUJBQXFCLENBQWtCLEdBQUcsRUFBRSxPQUFPLEVBQUUsZ0JBQWdCLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxxQkFBcUIsQ0FBa0IsR0FBRyxFQUFFLE9BQU8sQ0FBQyxDQUFDLENBQUM7UUFDck0sSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDaEMsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztJQUVELGdCQUFnQixDQUFLLENBQXVDLEVBQUcsT0FBa0M7UUFDL0YsTUFBTSxTQUFTLEdBQUcsSUFBSSxxQkFBcUIsQ0FBQyxDQUFDLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDeEQsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDaEMsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQzt1R0FwQlUsdUJBQXVCOzJHQUF2Qix1QkFBdUI7OzJGQUF2Qix1QkFBdUI7a0JBRG5DLFVBQVU7O0FBMkJYLE1BQU0sVUFBVSxlQUFlLENBQWlFLEdBQWtDLEVBQUUsZ0JBQWdFLEVBQUUsT0FBdUM7SUFFM08sTUFBTSxHQUFHLEdBQUksVUFBVSxDQUFDLGdCQUFnQixDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsZ0JBQWdCLENBQUM7SUFFdkUsTUFBTSxVQUFVLEdBQUcsYUFBYSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRXRDLE1BQU0sWUFBWSxHQUFHLE9BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLFVBQVUsQ0FBQyxDQUFDO1FBQzVELElBQUkscUJBQXFCLENBQWtCLEdBQUcsRUFBRSxPQUFPLEVBQUUsZ0JBQWdCLENBQUM7UUFDMUUsQ0FBQyxDQUFDLElBQUkscUJBQXFCLENBQWtCLEdBQUcsRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDO0lBRXRFLFVBQVUsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLENBQUMsWUFBWSxFQUFFLFdBQVcsRUFBRSxDQUFDLENBQUM7SUFFeEQsT0FBTyxZQUFZLENBQUM7QUFDdEIsQ0FBQztBQUVELFNBQVMsVUFBVSxDQUFDLEtBQVU7SUFDNUIsT0FBTyxPQUFPLEtBQUssS0FBSyxVQUFVLENBQUM7QUFDckMsQ0FBQztBQUVELFNBQVMsYUFBYSxDQUFDLE9BQW9DO0lBQ3pELE1BQU0sZ0JBQWdCLEdBQUcsT0FBTyxFQUFFLFFBQVEsQ0FBQztJQUUzQyxJQUFHLENBQUMsZ0JBQWdCLEVBQUMsQ0FBQztRQUNwQixJQUFJLENBQUM7WUFDSCx3QkFBd0IsQ0FBQyxlQUFlLENBQUMsQ0FBQztRQUM1QyxDQUFDO1FBQUMsT0FBTyxLQUFLLEVBQUUsQ0FBQztZQUNmLE1BQU0sSUFBSSxLQUFLLENBQUMsNkdBQTZHLENBQUMsQ0FBQztRQUNqSSxDQUFDO0lBQ0gsQ0FBQztJQUVELE1BQU0sVUFBVSxHQUFHLGdCQUFnQixFQUFFLEdBQUcsQ0FBQyxVQUFVLENBQUMsSUFBSSxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7SUFFM0UsT0FBTyxVQUFVLENBQUM7QUFDcEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERlc3Ryb3lSZWYsIEluamVjdGFibGUsIE9uRGVzdHJveSwgYXNzZXJ0SW5JbmplY3Rpb25Db250ZXh0LCBpbmplY3QgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBIdHRwUmVxdWVzdEZhY3RvcnksIFJlcXVlc3RTdGF0ZU9wdGlvbnMsIFJlcXVlc3RDcmVhdG9yT3B0aW9ucyB9IGZyb20gXCIuL3R5cGVzXCI7XHJcbmltcG9ydCB7IEh0dHBSZXF1ZXN0U3RhdGVTdG9yZSB9IGZyb20gJy4vSHR0cFJlcXVlc3RTdGF0ZVN0b3JlJztcclxuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gXCJyeGpzXCI7XHJcblxyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBIdHRwUmVxdWVzdFN0YXRlRmFjdG9yeSAgaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHt9XHJcbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XHJcbiAgICB0aGlzLnJlcXVlc3RvcnMuZm9yRWFjaCggcmVxdWVzdCA9PiByZXF1ZXN0Lm5nT25EZXN0cm95KCkpO1xyXG4gIH1cclxuICBwcml2YXRlIHJlcXVlc3RvcnM6IE9uRGVzdHJveVtdID0gW107XHJcblxyXG4gIGNyZWF0ZTxUUGFyYW0gZXh0ZW5kcyBhbnlbXSwgVj4oIHJlcTogSHR0cFJlcXVlc3RGYWN0b3J5PFRQYXJhbSwgVj4sIG9wdGlvbnM/OiBSZXF1ZXN0U3RhdGVPcHRpb25zPFRQYXJhbT4pIDogSHR0cFJlcXVlc3RTdGF0ZVN0b3JlPFRQYXJhbSwgVj5cclxuICBjcmVhdGU8VFBhcmFtIGV4dGVuZHMgYW55W10sIFYsIFIsIFQgPSBSPiggcmVxOiBIdHRwUmVxdWVzdEZhY3Rvcnk8VFBhcmFtLCBWPiwgcHJvamVjdDogKHY6IFYpID0+IFIgLCBvcHRpb25zPzogUmVxdWVzdFN0YXRlT3B0aW9uczxUUGFyYW0+KSA6IEh0dHBSZXF1ZXN0U3RhdGVTdG9yZTxUUGFyYW0sIFYsIFQ+XHJcbiAgY3JlYXRlPFRQYXJhbSBleHRlbmRzIGFueVtdLCBWLCBSID0gbnVsbCwgVCA9IFIgZXh0ZW5kcyBudWxsID8gViA6IFI+KCByZXE6IEh0dHBSZXF1ZXN0RmFjdG9yeTxUUGFyYW0sIFY+LCBvcHRpb25zT3JQcm9qZWN0PzogUmVxdWVzdFN0YXRlT3B0aW9uczxUUGFyYW0+IHwgKCh2OiBWKSA9PiBSKSwgb3B0aW9ucz86IFJlcXVlc3RTdGF0ZU9wdGlvbnM8VFBhcmFtPiApIDogSHR0cFJlcXVlc3RTdGF0ZVN0b3JlPFRQYXJhbSwgViwgUiwgVD4ge1xyXG4gICAgY29uc3QgcmVxdWVzdG9yID0gKHR5cGVvZihvcHRpb25zT3JQcm9qZWN0KSA9PT0gJ2Z1bmN0aW9uJyA/ICBuZXcgSHR0cFJlcXVlc3RTdGF0ZVN0b3JlPFRQYXJhbSwgViwgUiwgVD4ocmVxLCBvcHRpb25zLCBvcHRpb25zT3JQcm9qZWN0KSA6IG5ldyBIdHRwUmVxdWVzdFN0YXRlU3RvcmU8VFBhcmFtLCBWLCBSLCBUPihyZXEsIG9wdGlvbnMpKTtcclxuICAgIHRoaXMucmVxdWVzdG9ycy5wdXNoKHJlcXVlc3Rvcik7XHJcbiAgICByZXR1cm4gcmVxdWVzdG9yO1xyXG4gIH1cclxuXHJcbiAgY3JlYXRlSHR0cENsaWVudDxUPiggcjogKG86IE9ic2VydmFibGU8VD4gKSA9PiBPYnNlcnZhYmxlPFQ+ICwgb3B0aW9ucz86IFJlcXVlc3RTdGF0ZU9wdGlvbnM8YW55PiApICB7XHJcbiAgICBjb25zdCByZXF1ZXN0b3IgPSBuZXcgSHR0cFJlcXVlc3RTdGF0ZVN0b3JlKHIsIG9wdGlvbnMpO1xyXG4gICAgdGhpcy5yZXF1ZXN0b3JzLnB1c2gocmVxdWVzdG9yKTtcclxuICAgIHJldHVybiByZXF1ZXN0b3I7XHJcbiAgfVxyXG5cclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVJlcXVlc3RvcjxUUGFyYW0gZXh0ZW5kcyBhbnlbXSwgVj4oIHJlcTogSHR0cFJlcXVlc3RGYWN0b3J5PFRQYXJhbSwgVj4sIG9wdGlvbnM/OiBSZXF1ZXN0Q3JlYXRvck9wdGlvbnM8VFBhcmFtPikgOiBIdHRwUmVxdWVzdFN0YXRlU3RvcmU8VFBhcmFtLCBWPlxyXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlUmVxdWVzdG9yPFRQYXJhbSBleHRlbmRzIGFueVtdLCBWLCBSLCBUID0gUj4oIHJlcTogSHR0cFJlcXVlc3RGYWN0b3J5PFRQYXJhbSwgVj4sIHByb2plY3Q6ICh2OiBWKSA9PiBSICwgb3B0aW9ucz86IFJlcXVlc3RDcmVhdG9yT3B0aW9uczxUUGFyYW0+KSA6IEh0dHBSZXF1ZXN0U3RhdGVTdG9yZTxUUGFyYW0sIFYsIFQ+XHJcbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVSZXF1ZXN0b3I8VFBhcmFtIGV4dGVuZHMgYW55W10sIFYsIFIgPSBudWxsLCBUID0gUiBleHRlbmRzIG51bGwgPyBWIDogUj4oIHJlcTogSHR0cFJlcXVlc3RGYWN0b3J5PFRQYXJhbSwgVj4sIG9wdGlvbnNPclByb2plY3Q/OiBSZXF1ZXN0Q3JlYXRvck9wdGlvbnM8VFBhcmFtPiB8ICgodjogVikgPT4gUiksIG9wdGlvbnM/OiBSZXF1ZXN0Q3JlYXRvck9wdGlvbnM8VFBhcmFtPiApIDogSHR0cFJlcXVlc3RTdGF0ZVN0b3JlPFRQYXJhbSwgViwgUiwgVD57XHJcblxyXG4gIGNvbnN0IG9wcyAgPSBpc0Z1bmN0aW9uKG9wdGlvbnNPclByb2plY3QpID8gb3B0aW9ucyA6IG9wdGlvbnNPclByb2plY3Q7XHJcblxyXG4gIGNvbnN0IGRlc3Ryb3lSZWYgPSBnZXREZXN0cm95UmVmKG9wcyk7XHJcblxyXG4gIGNvbnN0IHJlcXVlc3RTdG9yZSA9IHR5cGVvZihvcHRpb25zT3JQcm9qZWN0KSA9PT0gJ2Z1bmN0aW9uJyA/ICBcclxuICAgIG5ldyBIdHRwUmVxdWVzdFN0YXRlU3RvcmU8VFBhcmFtLCBWLCBSLCBUPihyZXEsIG9wdGlvbnMsIG9wdGlvbnNPclByb2plY3QpXHJcbiAgICA6IG5ldyBIdHRwUmVxdWVzdFN0YXRlU3RvcmU8VFBhcmFtLCBWLCBSLCBUPihyZXEsIG9wdGlvbnNPclByb2plY3QpO1xyXG5cclxuICBkZXN0cm95UmVmLm9uRGVzdHJveSgoKSA9PiByZXF1ZXN0U3RvcmU/Lm5nT25EZXN0cm95KCkpO1xyXG5cclxuICByZXR1cm4gcmVxdWVzdFN0b3JlO1xyXG59XHJcblxyXG5mdW5jdGlvbiBpc0Z1bmN0aW9uKHZhbHVlOiBhbnkpOiB2YWx1ZSBpcyBGdW5jdGlvbiB7XHJcbiAgcmV0dXJuIHR5cGVvZiB2YWx1ZSA9PT0gJ2Z1bmN0aW9uJztcclxufVxyXG5cclxuZnVuY3Rpb24gZ2V0RGVzdHJveVJlZihvcHRpb25zPzogUmVxdWVzdENyZWF0b3JPcHRpb25zPGFueT4pe1xyXG4gIGNvbnN0IHByb3ZpZGVkSW5qZWN0b3IgPSBvcHRpb25zPy5pbmplY3RvcjtcclxuXHJcbiAgaWYoIXByb3ZpZGVkSW5qZWN0b3Ipe1xyXG4gICAgdHJ5IHtcclxuICAgICAgYXNzZXJ0SW5JbmplY3Rpb25Db250ZXh0KGNyZWF0ZVJlcXVlc3Rvcik7XHJcbiAgICB9IGNhdGNoIChlcnJvcikge1xyXG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ2NyZWF0ZVJlcXVlc3RvcigpIG11c3QgYmUgdXNlZCBpbiBhbiBJbmplY3Rpb24gQ29udGV4dCBvciB5b3UgbXVzdCBwcm92aWRlIGFuIGluamVjdG9yIHRvIGNyZWF0ZVJlcXVlc3RvcigpJyk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBjb25zdCBkZXN0cm95UmVmID0gcHJvdmlkZWRJbmplY3Rvcj8uZ2V0KERlc3Ryb3lSZWYpIHx8IGluamVjdChEZXN0cm95UmVmKTtcclxuXHJcbiAgcmV0dXJuIGRlc3Ryb3lSZWY7XHJcbn0iXX0=
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSHR0cFJlcXVlc3RTdGF0ZUZhY3RvcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXV0aWxpdGllcy9zcmMvaHR0cC1yZXF1ZXN0LXN0YXRlL0h0dHBSZXF1ZXN0U3RhdGVGYWN0b3J5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUF1Qix3QkFBd0IsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFOUcsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUJBQXlCLENBQUM7O0FBSWhFLE1BQU0sT0FBTyx1QkFBdUI7SUFFbEMsZ0JBQWUsQ0FBQztJQUNoQixXQUFXO1FBQ1QsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUUsT0FBTyxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztJQUM3RCxDQUFDO0lBQ08sVUFBVSxHQUFnQixFQUFFLENBQUM7SUFJckMsTUFBTSxDQUFnRSxHQUFrQyxFQUFFLGdCQUE4RCxFQUFFLE9BQXFDO1FBQzdNLE1BQU0sU0FBUyxHQUFHLENBQUMsT0FBTSxDQUFDLGdCQUFnQixDQUFDLEtBQUssVUFBVSxDQUFDLENBQUMsQ0FBRSxJQUFJLHFCQUFxQixDQUFrQixHQUFHLEVBQUUsT0FBTyxFQUFFLGdCQUFnQixDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUkscUJBQXFCLENBQWtCLEdBQUcsRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDLENBQUM7UUFDOU0sSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDaEMsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztJQUVELGdCQUFnQixDQUFLLENBQXVDLEVBQUcsT0FBa0M7UUFDL0YsTUFBTSxTQUFTLEdBQUcsSUFBSSxxQkFBcUIsQ0FBQyxDQUFDLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDeEQsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDaEMsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQzt1R0FwQlUsdUJBQXVCOzJHQUF2Qix1QkFBdUI7OzJGQUF2Qix1QkFBdUI7a0JBRG5DLFVBQVU7O0FBMkJYLE1BQU0sVUFBVSxlQUFlLENBQWlFLEdBQWtDLEVBQUUsZ0JBQWdFLEVBQUUsT0FBdUM7SUFFM08sTUFBTSxHQUFHLEdBQUksVUFBVSxDQUFDLGdCQUFnQixDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsZ0JBQWdCLENBQUM7SUFFdkUsTUFBTSxVQUFVLEdBQUcsYUFBYSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRXRDLE1BQU0sWUFBWSxHQUFHLE9BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLFVBQVUsQ0FBQyxDQUFDO1FBQzVELElBQUkscUJBQXFCLENBQWtCLEdBQUcsRUFBRSxPQUFPLEVBQUUsZ0JBQWdCLENBQUM7UUFDMUUsQ0FBQyxDQUFDLElBQUkscUJBQXFCLENBQWtCLEdBQUcsRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDO0lBRXRFLFVBQVUsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLENBQUMsWUFBWSxFQUFFLFdBQVcsRUFBRSxDQUFDLENBQUM7SUFFeEQsT0FBTyxZQUFZLENBQUM7QUFDdEIsQ0FBQztBQUVELFNBQVMsVUFBVSxDQUFDLEtBQVU7SUFDNUIsT0FBTyxPQUFPLEtBQUssS0FBSyxVQUFVLENBQUM7QUFDckMsQ0FBQztBQUVELFNBQVMsYUFBYSxDQUFDLE9BQW9DO0lBQ3pELE1BQU0sZ0JBQWdCLEdBQUcsT0FBTyxFQUFFLFFBQVEsQ0FBQztJQUUzQyxJQUFHLENBQUMsZ0JBQWdCLEVBQUMsQ0FBQztRQUNwQixJQUFJLENBQUM7WUFDSCx3QkFBd0IsQ0FBQyxlQUFlLENBQUMsQ0FBQztRQUM1QyxDQUFDO1FBQUMsT0FBTyxLQUFLLEVBQUUsQ0FBQztZQUNmLE1BQU0sSUFBSSxLQUFLLENBQUMsNkdBQTZHLENBQUMsQ0FBQztRQUNqSSxDQUFDO0lBQ0gsQ0FBQztJQUVELE1BQU0sVUFBVSxHQUFHLGdCQUFnQixFQUFFLEdBQUcsQ0FBQyxVQUFVLENBQUMsSUFBSSxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7SUFFM0UsT0FBTyxVQUFVLENBQUM7QUFDcEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERlc3Ryb3lSZWYsIEluamVjdGFibGUsIEluamVjdG9yLCBPbkRlc3Ryb3ksIGFzc2VydEluSW5qZWN0aW9uQ29udGV4dCwgaW5qZWN0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgSHR0cFJlcXVlc3RGYWN0b3J5LCBSZXF1ZXN0U3RhdGVPcHRpb25zLCBSZXF1ZXN0Q3JlYXRvck9wdGlvbnMgfSBmcm9tIFwiLi90eXBlc1wiO1xyXG5pbXBvcnQgeyBIdHRwUmVxdWVzdFN0YXRlU3RvcmUgfSBmcm9tICcuL0h0dHBSZXF1ZXN0U3RhdGVTdG9yZSc7XHJcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tIFwicnhqc1wiO1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgSHR0cFJlcXVlc3RTdGF0ZUZhY3RvcnkgIGltcGxlbWVudHMgT25EZXN0cm95IHtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7fVxyXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xyXG4gICAgdGhpcy5yZXF1ZXN0b3JzLmZvckVhY2goIHJlcXVlc3QgPT4gcmVxdWVzdC5uZ09uRGVzdHJveSgpKTtcclxuICB9XHJcbiAgcHJpdmF0ZSByZXF1ZXN0b3JzOiBPbkRlc3Ryb3lbXSA9IFtdO1xyXG5cclxuICBjcmVhdGU8VFBhcmFtIGV4dGVuZHMgYW55W10sIFY+KCByZXE6IEh0dHBSZXF1ZXN0RmFjdG9yeTxUUGFyYW0sIFY+LCBvcHRpb25zPzogUmVxdWVzdFN0YXRlT3B0aW9uczxUUGFyYW0+KSA6IEh0dHBSZXF1ZXN0U3RhdGVTdG9yZTxUUGFyYW0sIFY+XHJcbiAgY3JlYXRlPFRQYXJhbSBleHRlbmRzIGFueVtdLCBWLCBSLCBUID0gUj4oIHJlcTogSHR0cFJlcXVlc3RGYWN0b3J5PFRQYXJhbSwgVj4sIHByb2plY3Q6ICh2OiBWKSA9PiBSICwgb3B0aW9ucz86IFJlcXVlc3RTdGF0ZU9wdGlvbnM8VFBhcmFtPikgOiBIdHRwUmVxdWVzdFN0YXRlU3RvcmU8VFBhcmFtLCBWLCBUPlxyXG4gIGNyZWF0ZTxUUGFyYW0gZXh0ZW5kcyBhbnlbXSwgViwgUiA9IG51bGwsIFQgPSBSIGV4dGVuZHMgbnVsbCA/IFYgOiBSPihyZXE6IEh0dHBSZXF1ZXN0RmFjdG9yeTxUUGFyYW0sIFY+LCBvcHRpb25zT3JQcm9qZWN0PzogUmVxdWVzdFN0YXRlT3B0aW9uczxUUGFyYW0+IHwgKCh2OiBWKSA9PiBSKSwgb3B0aW9ucz86IFJlcXVlc3RTdGF0ZU9wdGlvbnM8VFBhcmFtPiApIDogSHR0cFJlcXVlc3RTdGF0ZVN0b3JlPFRQYXJhbSwgViwgUiwgVD4ge1xyXG4gICAgY29uc3QgcmVxdWVzdG9yID0gKHR5cGVvZihvcHRpb25zT3JQcm9qZWN0KSA9PT0gJ2Z1bmN0aW9uJyA/ICBuZXcgSHR0cFJlcXVlc3RTdGF0ZVN0b3JlPFRQYXJhbSwgViwgUiwgVD4ocmVxLCBvcHRpb25zLCBvcHRpb25zT3JQcm9qZWN0KSA6IG5ldyBIdHRwUmVxdWVzdFN0YXRlU3RvcmU8VFBhcmFtLCBWLCBSLCBUPihyZXEsIG9wdGlvbnNPclByb2plY3QpKTtcclxuICAgIHRoaXMucmVxdWVzdG9ycy5wdXNoKHJlcXVlc3Rvcik7XHJcbiAgICByZXR1cm4gcmVxdWVzdG9yO1xyXG4gIH1cclxuXHJcbiAgY3JlYXRlSHR0cENsaWVudDxUPiggcjogKG86IE9ic2VydmFibGU8VD4gKSA9PiBPYnNlcnZhYmxlPFQ+ICwgb3B0aW9ucz86IFJlcXVlc3RTdGF0ZU9wdGlvbnM8YW55PiApICB7XHJcbiAgICBjb25zdCByZXF1ZXN0b3IgPSBuZXcgSHR0cFJlcXVlc3RTdGF0ZVN0b3JlKHIsIG9wdGlvbnMpO1xyXG4gICAgdGhpcy5yZXF1ZXN0b3JzLnB1c2gocmVxdWVzdG9yKTtcclxuICAgIHJldHVybiByZXF1ZXN0b3I7XHJcbiAgfVxyXG5cclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVJlcXVlc3RvcjxUUGFyYW0gZXh0ZW5kcyBhbnlbXSwgVj4oIHJlcTogSHR0cFJlcXVlc3RGYWN0b3J5PFRQYXJhbSwgVj4sIG9wdGlvbnM/OiBSZXF1ZXN0Q3JlYXRvck9wdGlvbnM8VFBhcmFtPikgOiBIdHRwUmVxdWVzdFN0YXRlU3RvcmU8VFBhcmFtLCBWPlxyXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlUmVxdWVzdG9yPFRQYXJhbSBleHRlbmRzIGFueVtdLCBWLCBSLCBUID0gUj4oIHJlcTogSHR0cFJlcXVlc3RGYWN0b3J5PFRQYXJhbSwgVj4sIHByb2plY3Q6ICh2OiBWKSA9PiBSICwgb3B0aW9ucz86IFJlcXVlc3RDcmVhdG9yT3B0aW9uczxUUGFyYW0+KSA6IEh0dHBSZXF1ZXN0U3RhdGVTdG9yZTxUUGFyYW0sIFYsIFQ+XHJcbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVSZXF1ZXN0b3I8VFBhcmFtIGV4dGVuZHMgYW55W10sIFYsIFIgPSBudWxsLCBUID0gUiBleHRlbmRzIG51bGwgPyBWIDogUj4oIHJlcTogSHR0cFJlcXVlc3RGYWN0b3J5PFRQYXJhbSwgVj4sIG9wdGlvbnNPclByb2plY3Q/OiBSZXF1ZXN0Q3JlYXRvck9wdGlvbnM8VFBhcmFtPiB8ICgodjogVikgPT4gUiksIG9wdGlvbnM/OiBSZXF1ZXN0Q3JlYXRvck9wdGlvbnM8VFBhcmFtPiApIDogSHR0cFJlcXVlc3RTdGF0ZVN0b3JlPFRQYXJhbSwgViwgUiwgVD57XHJcblxyXG4gIGNvbnN0IG9wcyAgPSBpc0Z1bmN0aW9uKG9wdGlvbnNPclByb2plY3QpID8gb3B0aW9ucyA6IG9wdGlvbnNPclByb2plY3Q7XHJcblxyXG4gIGNvbnN0IGRlc3Ryb3lSZWYgPSBnZXREZXN0cm95UmVmKG9wcyk7XHJcblxyXG4gIGNvbnN0IHJlcXVlc3RTdG9yZSA9IHR5cGVvZihvcHRpb25zT3JQcm9qZWN0KSA9PT0gJ2Z1bmN0aW9uJyA/ICBcclxuICAgIG5ldyBIdHRwUmVxdWVzdFN0YXRlU3RvcmU8VFBhcmFtLCBWLCBSLCBUPihyZXEsIG9wdGlvbnMsIG9wdGlvbnNPclByb2plY3QpXHJcbiAgICA6IG5ldyBIdHRwUmVxdWVzdFN0YXRlU3RvcmU8VFBhcmFtLCBWLCBSLCBUPihyZXEsIG9wdGlvbnNPclByb2plY3QpO1xyXG5cclxuICBkZXN0cm95UmVmLm9uRGVzdHJveSgoKSA9PiByZXF1ZXN0U3RvcmU/Lm5nT25EZXN0cm95KCkpO1xyXG5cclxuICByZXR1cm4gcmVxdWVzdFN0b3JlO1xyXG59XHJcblxyXG5mdW5jdGlvbiBpc0Z1bmN0aW9uKHZhbHVlOiBhbnkpOiB2YWx1ZSBpcyBGdW5jdGlvbiB7XHJcbiAgcmV0dXJuIHR5cGVvZiB2YWx1ZSA9PT0gJ2Z1bmN0aW9uJztcclxufVxyXG5cclxuZnVuY3Rpb24gZ2V0RGVzdHJveVJlZihvcHRpb25zPzogUmVxdWVzdENyZWF0b3JPcHRpb25zPGFueT4pe1xyXG4gIGNvbnN0IHByb3ZpZGVkSW5qZWN0b3IgPSBvcHRpb25zPy5pbmplY3RvcjtcclxuXHJcbiAgaWYoIXByb3ZpZGVkSW5qZWN0b3Ipe1xyXG4gICAgdHJ5IHtcclxuICAgICAgYXNzZXJ0SW5JbmplY3Rpb25Db250ZXh0KGNyZWF0ZVJlcXVlc3Rvcik7XHJcbiAgICB9IGNhdGNoIChlcnJvcikge1xyXG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ2NyZWF0ZVJlcXVlc3RvcigpIG11c3QgYmUgdXNlZCBpbiBhbiBJbmplY3Rpb24gQ29udGV4dCBvciB5b3UgbXVzdCBwcm92aWRlIGFuIGluamVjdG9yIHRvIGNyZWF0ZVJlcXVlc3RvcigpJyk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBjb25zdCBkZXN0cm95UmVmID0gcHJvdmlkZWRJbmplY3Rvcj8uZ2V0KERlc3Ryb3lSZWYpIHx8IGluamVjdChEZXN0cm95UmVmKTtcclxuXHJcbiAgcmV0dXJuIGRlc3Ryb3lSZWY7XHJcbn0iXX0=
@@ -48,10 +48,24 @@ export class HttpRequestStateStore extends ComponentStore {
48
48
  }
49
49
  return this.requestEffect(value);
50
50
  };
51
- selectHttpState$ = this.state$.pipe(map(a => a.response));
52
- selectStatus$ = this.selectHttpState$.pipe(map(a => a.status));
53
- selectError$ = this.state$.pipe(map(r => r.response), filter(isErrorState), map(state => state.error));
54
- selectResponse$ = this.state$.pipe(map(r => r.response), filter(isSuccessState), map(state => state.body));
51
+ $selectHttpState = this.selectSignal(a => a.response);
52
+ selectHttpState$ = this.select(a => a.response);
53
+ $selectStatus = computed(() => this.$selectHttpState()?.status);
54
+ selectStatus$ = this.selectHttpState$.pipe(map(s => s.status));
55
+ selectError$ = this.selectHttpState$.pipe(filter(isErrorState), map(state => state.error));
56
+ $selectError = computed(() => {
57
+ const state = this.$selectHttpState();
58
+ if (isErrorState(state))
59
+ return state.error;
60
+ });
61
+ selectResponse$ = this.selectHttpState$.pipe(filter(isSuccessState), map(state => state.body));
62
+ $selectResponse = computed(() => {
63
+ const state = this.$selectHttpState();
64
+ if (isSuccessState(state)) {
65
+ return state.body;
66
+ }
67
+ return undefined;
68
+ });
55
69
  selectSuccessOrError$ = this.state$.pipe(map(r => r.response), filter(isSuccessOrErrorState), map(() => null));
56
70
  errorHandled = false;
57
71
  onError(cb) {
@@ -118,4 +132,4 @@ export function wrapInArr(sigOrObs) {
118
132
  computed(() => [sigOrObs()])
119
133
  : sigOrObs.pipe(map(a => [a]));
120
134
  }
121
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"HttpRequestStateStore.js","sourceRoot":"","sources":["../../../../projects/angular-utilities/src/http-request-state/HttpRequestStateStore.ts"],"names":[],"mappings":"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","sourcesContent":["import { Observable, of, Subscription } from 'rxjs';\r\nimport { ComponentStore } from '@ngrx/component-store';\r\nimport { HttpRequestFactory, HttpRequestStrategy, HttpRequestStatus, HttpRequestState, RequestStateOptions, HttpRequestStateCancelled } from './types';\r\nimport { createFailure, createSuccess, inProgress, isErrorState, isSuccessOrErrorState, isSuccessState, notStarted } from './helpers';\r\nimport { concatMap, filter, map, mergeMap, startWith, switchMap, takeUntil, tap } from 'rxjs/operators';\r\nimport { HttpErrorResponse } from '@angular/common/http';\r\nimport { mapError } from '../rxjs/mapError';\r\nimport { defaultShareReplay } from '../rxjs/defaultShareReplay';\r\nimport { computed, Directive, Injector, isSignal, Signal } from '@angular/core';\r\nimport { toObservable } from '@angular/core/rxjs-interop';\r\nimport { notNull } from '../rxjs';\r\n\r\nexport interface RequestResponse<TParam extends any[], T> {\r\n  requestParams: [...TParam];\r\n  response: HttpRequestState<T>;\r\n}\r\n\r\n@Directive()\r\nexport class HttpRequestStateStore<TParam extends any[], V, R = null, T = R extends null ? V : R> extends ComponentStore<RequestResponse<TParam, T>> {\r\n    private options?: RequestStateOptions;\r\n    private project?: (v: V) => R;\r\n    private req: HttpRequestFactory<TParam, V>;\r\n    private injector?: Injector;\r\n    constructor(req: HttpRequestFactory<TParam, V> ,options?: RequestStateOptions<TParam>, project?: (v: V) => R) {\r\n      super({ requestParams: null as any, response: notStarted });\r\n      this.project = project;\r\n      this.options = options;\r\n      this.injector = options?.injector;\r\n      this.req = req;\r\n      this.request = (this.options?.strategy === HttpRequestStrategy.singleUse) ? this.singleUseRequest :  this.flattenedRequest;\r\n\r\n      if(options?.autoRequestWith){\r\n        this.request(...options.autoRequestWith);\r\n      }\r\n    }\r\n\r\n    reset() {\r\n      this.setState({ requestParams:null as any, response: notStarted });\r\n    }\r\n\r\n    private flatteningStrategy = () => {\r\n      if(this.options?.strategy === HttpRequestStrategy.concurrent)\r\n        return mergeMap( (params: [...TParam]) => this.createRequest(...params));\r\n      if(this.options?.strategy === HttpRequestStrategy.sequential)\r\n        return concatMap( (params: [...TParam]) => this.createRequest(...params));\r\n      return switchMap( (params: [...TParam]) => ((params[0] as any) instanceof CancellationToken) ?\r\n        of({ requestParams: params[0], response: { status: HttpRequestStatus.cancelled } as HttpRequestStateCancelled } ) : this.createRequest(...params) );\r\n    }\r\n\r\n    private requestEffect: (value: [...TParam] ) => Subscription = this.effect((obs: Observable<[...TParam]>) => {\r\n      return (obs).pipe(\r\n        this.flatteningStrategy(),\r\n        tap<RequestResponse<TParam, T>>(state => this.setState(state)),\r\n      );\r\n    });\r\n\r\n    private flattenedRequest = (...value: [...TParam]) => {\r\n      return this.requestEffect(value) as Subscription;\r\n    }\r\n    private singleUseRequest = (...value: [...TParam]) => {\r\n      if (this.get().response.status !== HttpRequestStatus.notStarted) {\r\n        throw new Error(\"state can not be reused. either reset the state by calling reset() or use a state requester that allows concurrent requests.\");\r\n      }\r\n      return this.requestEffect(value) as Subscription;\r\n    }\r\n\r\n    selectHttpState$ = this.state$.pipe(map(a => a.response));\r\n\r\n    selectStatus$ = this.selectHttpState$.pipe(map(a => a.status));\r\n\r\n    selectError$ = this.state$.pipe(\r\n      map(r => r.response),\r\n      filter(isErrorState),\r\n      map( state => state.error)\r\n    );\r\n\r\n    selectResponse$: Observable<T> = this.state$.pipe(\r\n      map(r => r.response),\r\n      filter(isSuccessState),\r\n      map( state => state.body)\r\n    );\r\n    selectSuccessOrError$ = this.state$.pipe(\r\n      map(r => r.response),\r\n      filter(isSuccessOrErrorState),\r\n      map( () => null)\r\n    );\r\n\r\n    errorHandled = false;\r\n    onError( cb: (error: HttpErrorResponse) => void) {\r\n      this.errorHandled = true;\r\n      this.on(this.selectError$, cb);\r\n      return this;\r\n    }\r\n\r\n    onSuccess( cb: (body?: T) => void) {\r\n      this.on(this.selectResponse$, cb);\r\n      return this;\r\n    }\r\n\r\n    onSuccessOrError(cb: () => void){\r\n      this.on(this.selectSuccessOrError$, cb);\r\n      return this;\r\n    }\r\n\r\n    onSuccessWithRequest(func: (state: {\r\n      requestParams: [...TParam];\r\n      body: T;\r\n    }) => void) {\r\n      this.onUpdate(({ requestParams, response }) => {\r\n        if(isSuccessState(response)){\r\n          func({requestParams,body: response.body});\r\n        }\r\n      });\r\n      return this;\r\n    }\r\n\r\n    onErrorWithRequest(func: (state: {\r\n      error: HttpErrorResponse;\r\n      requestParams: [...TParam];\r\n    }) => void) {\r\n      this.onUpdate( ({ requestParams, response }) => {\r\n        if(isErrorState(response)){\r\n          func({ requestParams, error: response.error });\r\n        }\r\n      });\r\n      return this;\r\n    }\r\n\r\n    private createRequest(...params: [...TParam]): Observable<RequestResponse<TParam, T>> {\r\n      return this.req(...params).pipe(\r\n        map(re => createSuccess((this.project ? this.project(re) : re) as T)),\r\n        mapError(createFailure),\r\n        startWith(inProgress),\r\n        map( state => ({ requestParams: params, response: state })),\r\n        defaultShareReplay()\r\n      );\r\n    }\r\n\r\n    onUpdate(func: (state: {\r\n      requestParams: [...TParam];\r\n      response: HttpRequestState<T>;\r\n    }) => void) {\r\n      this.on(this.state$, func);\r\n    }\r\n\r\n    on = <V>(srcObservable: Observable<V>, func: (obj: V) => void): Subscription => {\r\n      return this.effect((src: Observable<V>) => {\r\n        return src.pipe(tap(func));\r\n      })(srcObservable) as Subscription;\r\n    }\r\n\r\n    request: (...value:  [...TParam] ) => Subscription;\r\n\r\n    ngOnDestroy() {\r\n      super.ngOnDestroy();\r\n    }\r\n\r\n    requestWith = (params: Observable<[...TParam]> | Signal<[...TParam]>) => {\r\n      if(isSignal(params)){\r\n        params = toObservable(params, { injector: this.injector }).pipe(notNull());\r\n      }\r\n      params.pipe(takeUntil(this.destroy$)).subscribe((p) => this.request(...p));\r\n      return this;\r\n    }\r\n  }\r\n  export class CancellationToken {}\r\n  export function wrapInArr<T>(sig: Signal<T>) : Signal<[T]>;\r\n  export function wrapInArr<T>(obs: Observable<T>): Observable<[T]>;\r\n  export function wrapInArr<T>(sigOrObs: Signal<T> | Observable<T>){\r\n    return isSignal(sigOrObs) ?\r\n    computed(() => [sigOrObs()])\r\n    : sigOrObs.pipe(map(a => [a]));\r\n  }\r\n"]}
135
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"HttpRequestStateStore.js","sourceRoot":"","sources":["../../../../projects/angular-utilities/src/http-request-state/HttpRequestStateStore.ts"],"names":[],"mappings":"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","sourcesContent":["import { Observable, of, Subscription } from 'rxjs';\r\nimport { ComponentStore } from '@ngrx/component-store';\r\nimport { HttpRequestFactory, HttpRequestStrategy, HttpRequestStatus, HttpRequestState, RequestStateOptions, HttpRequestStateCancelled } from './types';\r\nimport { createFailure, createSuccess, inProgress, isErrorState, isSuccessOrErrorState, isSuccessState, notStarted } from './helpers';\r\nimport { concatMap, filter, map, mergeMap, startWith, switchMap, takeUntil, tap } from 'rxjs/operators';\r\nimport { HttpErrorResponse } from '@angular/common/http';\r\nimport { mapError } from '../rxjs/mapError';\r\nimport { defaultShareReplay } from '../rxjs/defaultShareReplay';\r\nimport { computed, Directive, Injector, isSignal, Signal } from '@angular/core';\r\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\r\nimport { notNull } from '../rxjs';\r\n\r\nexport interface RequestResponse<TParam extends any[], T> {\r\n  requestParams: [...TParam];\r\n  response: HttpRequestState<T>;\r\n}\r\n\r\n@Directive()\r\nexport class HttpRequestStateStore<TParam extends any[], V, R = null, T = R extends null ? V : R> extends ComponentStore<RequestResponse<TParam, T>> {\r\n    private options?: RequestStateOptions;\r\n    private project?: (v: V) => R;\r\n    private req: HttpRequestFactory<TParam, V>;\r\n    private injector?: Injector;\r\n    constructor(req: HttpRequestFactory<TParam, V> ,options?: RequestStateOptions<TParam>, project?: (v: V) => R) {\r\n      super({ requestParams: null as any, response: notStarted });\r\n      this.project = project;\r\n      this.options = options;\r\n      this.injector = options?.injector;\r\n      this.req = req;\r\n      this.request = (this.options?.strategy === HttpRequestStrategy.singleUse) ? this.singleUseRequest :  this.flattenedRequest;\r\n\r\n      if(options?.autoRequestWith){\r\n        this.request(...options.autoRequestWith);\r\n      }\r\n    }\r\n\r\n    reset() {\r\n      this.setState({ requestParams:null as any, response: notStarted });\r\n    }\r\n\r\n    private flatteningStrategy = () => {\r\n      if(this.options?.strategy === HttpRequestStrategy.concurrent)\r\n        return mergeMap( (params: [...TParam]) => this.createRequest(...params));\r\n      if(this.options?.strategy === HttpRequestStrategy.sequential)\r\n        return concatMap( (params: [...TParam]) => this.createRequest(...params));\r\n      return switchMap( (params: [...TParam]) => ((params[0] as any) instanceof CancellationToken) ?\r\n        of({ requestParams: params[0], response: { status: HttpRequestStatus.cancelled } as HttpRequestStateCancelled } ) : this.createRequest(...params) );\r\n    }\r\n\r\n    private requestEffect: (value: [...TParam] ) => Subscription = this.effect((obs: Observable<[...TParam]>) => {\r\n      return (obs).pipe(\r\n        this.flatteningStrategy(),\r\n        tap<RequestResponse<TParam, T>>(state => this.setState(state)),\r\n      );\r\n    });\r\n\r\n    private flattenedRequest = (...value: [...TParam]) => {\r\n      return this.requestEffect(value) as Subscription;\r\n    }\r\n    private singleUseRequest = (...value: [...TParam]) => {\r\n      if (this.get().response.status !== HttpRequestStatus.notStarted) {\r\n        throw new Error(\"state can not be reused. either reset the state by calling reset() or use a state requester that allows concurrent requests.\");\r\n      }\r\n      return this.requestEffect(value) as Subscription;\r\n    }\r\n\r\n    $selectHttpState = this.selectSignal(a => a.response);\r\n\r\n    selectHttpState$ = this.select(a => a.response);\r\n\r\n    $selectStatus = computed(() => this.$selectHttpState()?.status);\r\n\r\n    selectStatus$ = this.selectHttpState$.pipe(map(s => s.status));\r\n\r\n\r\n\r\n    selectError$ = this.selectHttpState$.pipe(\r\n      filter(isErrorState),\r\n      map(state => state.error)\r\n    );\r\n\r\n    $selectError = computed(() => {\r\n      const state = this.$selectHttpState();\r\n      if(isErrorState(state)) return state.error\r\n    })\r\n\r\n    selectResponse$: Observable<T> = this.selectHttpState$.pipe(\r\n      filter(isSuccessState),\r\n      map( state => state.body)\r\n    );\r\n\r\n    $selectResponse = computed(() => {\r\n      const state = this.$selectHttpState();\r\n      if(isSuccessState(state)){\r\n        return state.body\r\n      }\r\n      return undefined;\r\n    })\r\n\r\n    selectSuccessOrError$ = this.state$.pipe(\r\n      map(r => r.response),\r\n      filter(isSuccessOrErrorState),\r\n      map( () => null)\r\n    );\r\n\r\n    errorHandled = false;\r\n    onError( cb: (error: HttpErrorResponse) => void) {\r\n      this.errorHandled = true;\r\n      this.on(this.selectError$, cb);\r\n      return this;\r\n    }\r\n\r\n    onSuccess( cb: (body?: T) => void) {\r\n      this.on(this.selectResponse$, cb);\r\n      return this;\r\n    }\r\n\r\n    onSuccessOrError(cb: () => void){\r\n      this.on(this.selectSuccessOrError$, cb);\r\n      return this;\r\n    }\r\n\r\n    onSuccessWithRequest(func: (state: {\r\n      requestParams: [...TParam];\r\n      body: T;\r\n    }) => void) {\r\n      this.onUpdate(({ requestParams, response }) => {\r\n        if(isSuccessState(response)){\r\n          func({requestParams,body: response.body});\r\n        }\r\n      });\r\n      return this;\r\n    }\r\n\r\n    onErrorWithRequest(func: (state: {\r\n      error: HttpErrorResponse;\r\n      requestParams: [...TParam];\r\n    }) => void) {\r\n      this.onUpdate( ({ requestParams, response }) => {\r\n        if(isErrorState(response)){\r\n          func({ requestParams, error: response.error });\r\n        }\r\n      });\r\n      return this;\r\n    }\r\n\r\n    private createRequest(...params: [...TParam]): Observable<RequestResponse<TParam, T>> {\r\n      return this.req(...params).pipe(\r\n        map(re => createSuccess((this.project ? this.project(re) : re) as T)),\r\n        mapError(createFailure),\r\n        startWith(inProgress),\r\n        map( state => ({ requestParams: params, response: state })),\r\n        defaultShareReplay()\r\n      );\r\n    }\r\n\r\n    onUpdate(func: (state: {\r\n      requestParams: [...TParam];\r\n      response: HttpRequestState<T>;\r\n    }) => void) {\r\n      this.on(this.state$, func);\r\n    }\r\n\r\n    on = <V>(srcObservable: Observable<V>, func: (obj: V) => void): Subscription => {\r\n      return this.effect((src: Observable<V>) => {\r\n        return src.pipe(tap(func));\r\n      })(srcObservable) as Subscription;\r\n    }\r\n\r\n    request: (...value:  [...TParam] ) => Subscription;\r\n\r\n    ngOnDestroy() {\r\n      super.ngOnDestroy();\r\n    }\r\n\r\n    requestWith = (params: Observable<[...TParam]> | Signal<[...TParam]>) => {\r\n      if(isSignal(params)){\r\n        params = toObservable(params, { injector: this.injector }).pipe(notNull());\r\n      }\r\n      params.pipe(takeUntil(this.destroy$)).subscribe((p) => this.request(...p));\r\n      return this;\r\n    }\r\n  }\r\n  export class CancellationToken {}\r\n  export function wrapInArr<T>(sig: Signal<T>) : Signal<[T]>;\r\n  export function wrapInArr<T>(obs: Observable<T>): Observable<[T]>;\r\n  export function wrapInArr<T>(sigOrObs: Signal<T> | Observable<T>){\r\n    return isSignal(sigOrObs) ?\r\n    computed(() => [sigOrObs()])\r\n    : sigOrObs.pipe(map(a => [a]));\r\n  }\r\n"]}
@@ -1,33 +1,9 @@
1
- import { APP_INITIALIZER, makeEnvironmentProviders } from "@angular/core";
1
+ import { APP_INITIALIZER, EnvironmentInjector, makeEnvironmentProviders, runInInjectionContext } from "@angular/core";
2
2
  import { createSelector, Store } from "@ngrx/store";
3
3
  import { v4 as uuid } from 'uuid';
4
- class AppStoreCache {
5
- cache = {};
6
- isInCache = (props, actionableSelectorId) => {
7
- if (typeof props != 'object')
8
- props = { props };
9
- let itemsInCache = this.cache[actionableSelectorId] = this.cache[actionableSelectorId] || [];
10
- if (itemsInCache.some(itemInCache => shallowEquals(itemInCache, props))) {
11
- return true;
12
- }
13
- itemsInCache.push(props);
14
- return false;
15
- };
16
- }
17
4
  let _store;
18
5
  let _cache;
19
- export const clearActionableSelectorRequestCache = () => _cache.cache = {};
20
- const setStore = (store) => {
21
- if (store instanceof Store)
22
- _store = store;
23
- };
24
- export function setUpStoreFactory(store) {
25
- _cache = new AppStoreCache();
26
- return () => new Promise((resolve, reject) => {
27
- setStore(store);
28
- resolve(null);
29
- });
30
- }
6
+ let _ei;
31
7
  /**
32
8
  * Creates a selector that can dispatch an action if conditions are met.
33
9
  * Note: The props of the selector factory must include the props of the action.
@@ -37,18 +13,59 @@ export function setUpStoreFactory(store) {
37
13
  * if true is returned. If no method is passed in than the action will be dispatched if the selector returns undefined or null.
38
14
  */
39
15
  export const createActionableSelector = (selectorFactory, action, dispatchIf = defaultFilter) => {
16
+ const options = {
17
+ selectorFactory,
18
+ action: (...props) => () => _store.dispatch(action(...props)),
19
+ dispatchIf
20
+ };
21
+ const actionable = createActionResultSelector(options);
22
+ return (...props) => createSelector(actionable(...props), b => b.result);
23
+ };
24
+ export const createActionSelector = (options) => {
25
+ const actionable = createActionResultSelector(options);
26
+ return ((...props) => createSelector(actionable(...props), b => b.result));
27
+ };
28
+ export const createActionableResultSelector = (selectorFactory, action, dispatchIf = defaultFilter) => {
29
+ const options = {
30
+ selectorFactory,
31
+ action: (...props) => () => _store.dispatch(action(...props)),
32
+ dispatchIf
33
+ };
34
+ return createActionResultSelector(options);
35
+ };
36
+ export const createActionResultSelector = (options) => {
40
37
  const id = uuid();
41
- const slctr = (props) => createSelector(selectorFactory(props), (selected) => {
42
- if (dispatchIf(selected) && !_cache.isInCache(props, id)) {
43
- queueMicrotask(() => _store.dispatch(action(props)));
38
+ const slctr = (...props) => createSelector(options.selectorFactory(...props), (selected) => {
39
+ const needsDispatch = (options.dispatchIf || defaultFilter)(selected);
40
+ if (needsDispatch && !_cache.isInCache(id, ...props)) {
41
+ queueMicrotask(() => runInInjectionContext(options.injector || _ei, () => {
42
+ options.action(...props)();
43
+ }));
44
44
  }
45
- return selected;
45
+ return ({
46
+ loading: needsDispatch,
47
+ result: selected
48
+ });
46
49
  });
47
50
  return slctr;
48
51
  };
49
- export function defaultFilter(data) {
50
- return data == null || data == undefined;
52
+ class AppStoreCache {
53
+ cache = {};
54
+ isInCache = (actionableSelectorId, ...p) => {
55
+ const props = p.reduce((a, b) => {
56
+ if (typeof b != 'object')
57
+ b = { b };
58
+ return ({ ...a, ...b });
59
+ }, {});
60
+ let itemsInCache = this.cache[actionableSelectorId] = (this.cache[actionableSelectorId] || []);
61
+ if (itemsInCache.some(itemInCache => shallowEquals(itemInCache, props))) {
62
+ return true;
63
+ }
64
+ itemsInCache.push(props);
65
+ return false;
66
+ };
51
67
  }
68
+ export const clearActionableSelectorRequestCache = () => _cache.cache = {};
52
69
  const shallowEquals = (cachedItem, newItem) => {
53
70
  const cachedItemKeys = Object.keys(cachedItem);
54
71
  const secondKeys = Object.keys(newItem);
@@ -63,9 +80,28 @@ const shallowEquals = (cachedItem, newItem) => {
63
80
  }
64
81
  return true;
65
82
  };
83
+ export function defaultFilter(data) {
84
+ return data == null || data == undefined;
85
+ }
86
+ const setStore = (store) => {
87
+ if (store instanceof Store)
88
+ _store ??= store;
89
+ };
90
+ const setEnvironmentInjector = (ei) => {
91
+ if (ei instanceof EnvironmentInjector)
92
+ _ei ??= ei;
93
+ };
66
94
  export function provideActionableSelector() {
67
95
  return makeEnvironmentProviders([
68
- { provide: APP_INITIALIZER, useFactory: setUpStoreFactory, multi: true, deps: [Store] },
96
+ { provide: APP_INITIALIZER, useFactory: setUpStoreFactory, multi: true, deps: [Store, EnvironmentInjector] },
69
97
  ]);
70
98
  }
71
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"actionable-selector.js","sourceRoot":"","sources":["../../../../projects/angular-utilities/src/ngrx/actionable-selector.ts"],"names":[],"mappings":"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","sourcesContent":["import { APP_INITIALIZER, makeEnvironmentProviders } from \"@angular/core\";\r\nimport { Action, createSelector, MemoizedSelector, Store } from \"@ngrx/store\";\r\nimport { v4 as uuid } from 'uuid';\r\n\r\ntype Cache = {\r\n  [key: string]: { [key: string]: any }[];\r\n}\r\n\r\nclass AppStoreCache {\r\n  cache: Cache = {};\r\n  isInCache = (props: any, actionableSelectorId: string): boolean => {\r\n    if(typeof props != 'object') props = { props };\r\n\r\n    let itemsInCache = this.cache[actionableSelectorId] = this.cache[actionableSelectorId] || [];\r\n\r\n    if(itemsInCache.some(itemInCache => shallowEquals(itemInCache, props))){\r\n      return true;\r\n    }\r\n\r\n    itemsInCache.push(props);\r\n    return false;\r\n  }\r\n}\r\n\r\nlet _store: Store<any>;\r\nlet _cache: AppStoreCache;\r\n\r\nexport const clearActionableSelectorRequestCache = () => _cache.cache = {};\r\n\r\nconst setStore = (store: Store) => {\r\n  if(store instanceof Store) _store = store;\r\n};\r\n\r\nexport function setUpStoreFactory(store: Store){\r\n  _cache = new AppStoreCache();\r\n  return () => new Promise((resolve, reject) => {\r\n    setStore(store);\r\n    resolve(null);\r\n  })\r\n}\r\n\r\n/**\r\n * Creates a selector that can dispatch an action if conditions are met.\r\n * Note: The props of the selector factory must include the props of the action.\r\n * @param selectorFactory A method that returns selector.\r\n * @param action The action that will be dispatched when conditions are met.\r\n * @param [dispatchIf = defaultFilter] Optional. A method that takes the result of the selector and returns a boolean. The actions gets dispatched\r\n * if true is returned. If no method is passed in than the action will be dispatched if the selector returns undefined or null.\r\n */\r\nexport const createActionableSelector = <State, Result, Props = any>(\r\n  selectorFactory: (props?: Props) => MemoizedSelector<State, Result>,\r\n  action: ActionReturner<Props | undefined>,\r\n  dispatchIf: (data: Result) => boolean = defaultFilter,\r\n): (props?: Props) => ActionableMemoizedSelector<State, Result> => {\r\n  const id = uuid();\r\n  const slctr = (props?: Props) => createSelector(\r\n    selectorFactory(props),\r\n    (selected: Result) => {\r\n      if(dispatchIf(selected) && !_cache.isInCache(props, id)){\r\n        queueMicrotask(() => _store.dispatch(action(props)));\r\n      }\r\n      return selected;\r\n    }\r\n  ) as ActionableMemoizedSelector<State, Result>;\r\n  return slctr;\r\n}\r\n\r\ntype ActionableMemoizedSelector<State, Result> = MemoizedSelector<State, Result>;\r\n\r\nexport type ActionReturner<Props> = (props: Props) => Action;\r\n\r\nexport function defaultFilter(data: any) {\r\n  return data == null || data == undefined;\r\n}\r\n\r\nconst shallowEquals = (cachedItem: object, newItem: object): boolean => {\r\n  const cachedItemKeys = Object.keys(cachedItem);\r\n  const secondKeys = Object.keys(newItem);\r\n  if(cachedItemKeys.length !== secondKeys.length) {\r\n    return false;\r\n  }\r\n  for(let index = 0; index < cachedItemKeys.length; index++) {\r\n    const currentKey = cachedItemKeys[index];\r\n    if(cachedItem[currentKey] !== newItem[currentKey]){\r\n      return false;\r\n    }\r\n  }\r\n  return true;\r\n}\r\n\r\nexport function provideActionableSelector(){\r\n  return makeEnvironmentProviders([\r\n    { provide: APP_INITIALIZER, useFactory: setUpStoreFactory, multi: true, deps: [Store] },\r\n  ])\r\n}\r\n"]}
99
+ export function setUpStoreFactory(store, env) {
100
+ _cache ??= new AppStoreCache();
101
+ return () => new Promise((resolve, reject) => {
102
+ setStore(store);
103
+ setEnvironmentInjector(env);
104
+ resolve(null);
105
+ });
106
+ }
107
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"actionable-selector.js","sourceRoot":"","sources":["../../../../projects/angular-utilities/src/ngrx/actionable-selector.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,mBAAmB,EAAY,wBAAwB,EAAE,qBAAqB,EAAa,MAAM,eAAe,CAAC;AAC3I,OAAO,EAAU,cAAc,EAAoB,KAAK,EAAE,MAAM,aAAa,CAAC;AAC9E,OAAO,EAAE,EAAE,IAAI,IAAI,EAAE,MAAM,MAAM,CAAC;AAElC,IAAI,MAAkB,CAAC;AACvB,IAAI,MAAqB,CAAC;AAC1B,IAAI,GAAyB,CAAC;AAE9B;;;;;;;GAOG;AACH,MAAM,CAAC,MAAM,wBAAwB,GAAG,CACtC,eAAuE,EACvE,MAA6B,EAC7B,aAAwC,aAAa,EACrD,EAAE;IACF,MAAM,OAAO,GAAG;QACd,eAAe;QACf,MAAM,EAAE,CAAC,GAAG,KAAY,EAAE,EAAE,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,GAAG,KAAK,CAAC,CAAC;QACpE,UAAU;KACX,CAAA;IACD,MAAM,UAAU,GAAG,0BAA0B,CAAC,OAAO,CAAC,CAAC;IACvD,OAAO,CAAC,GAAG,KAAY,EAAE,EAAE,CAAC,cAAc,CAAC,UAAU,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;AAClF,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAA6C,OAAyD,EAAE,EAAE;IAC5I,MAAM,UAAU,GAAG,0BAA0B,CAAC,OAAO,CAAC,CAAC;IACvD,OAAO,CAAC,CAAC,GAAG,KAAY,EAAE,EAAE,CAAC,cAAc,CAAC,UAAU,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;AACpF,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,8BAA8B,GAAG,CAC5C,eAAuE,EACvE,MAA6B,EAC7B,aAAwC,aAAa,EACrD,EAAE;IACF,MAAM,OAAO,GAAqD;QAChE,eAAe;QACf,MAAM,EAAE,CAAC,GAAG,KAAY,EAAE,EAAE,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,GAAG,KAAK,CAAC,CAAC;QACpE,UAAU;KACX,CAAC;IAEF,OAAO,0BAA0B,CAAC,OAAO,CAAC,CAAC;AAC7C,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,0BAA0B,GAAG,CAA6C,OAAyD,EAAE,EAAE;IAClJ,MAAM,EAAE,GAAG,IAAI,EAAE,CAAC;IAClB,MAAM,KAAK,GAAG,CAAC,GAAG,KAAY,EAAE,EAAE,CAAC,cAAc,CAC/C,OAAO,CAAC,eAAe,CAAC,GAAG,KAAK,CAAC,EACjC,CAAC,QAAgB,EAAE,EAAE;QACnB,MAAM,aAAa,GAAG,CAAC,OAAO,CAAC,UAAU,IAAI,aAAa,CAAC,CAAC,QAAQ,CAAC,CAAC;QACtE,IAAG,aAAa,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,EAAE,GAAG,KAAK,CAAC,EAAC,CAAC;YACnD,cAAc,CAAC,GAAG,EAAE,CAClB,qBAAqB,CAAC,OAAO,CAAC,QAAQ,IAAI,GAAG,EAAE,GAAG,EAAE;gBAClD,OAAO,CAAC,MAAM,CAAC,GAAG,KAAK,CAAC,EAAE,CAAA;YAC5B,CAAC,CAAC,CAAC,CAAC;QACR,CAAC;QACD,OAAO,CAAC;YACN,OAAO,EAAE,aAAa;YACtB,MAAM,EAAE,QAAQ;SACjB,CAAC,CAAC;IACL,CAAC,CACyD,CAAC;IAC7D,OAAO,KAAK,CAAC;AACf,CAAC,CAAA;AAED,MAAM,aAAa;IACjB,KAAK,GAAU,EAAE,CAAC;IAClB,SAAS,GAAG,CAAC,oBAA4B,EAAE,GAAG,CAAQ,EAAW,EAAE;QACjE,MAAM,KAAK,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YAC9B,IAAG,OAAO,CAAC,IAAI,QAAQ;gBAAE,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC;YACnC,OAAM,CAAC,EAAE,GAAG,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAA;QACxB,CAAC,EAAE,EAAE,CAAC,CAAC;QAEP,IAAI,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,oBAAoB,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,oBAAoB,CAAC,IAAI,EAAE,CAAC,CAAC;QAE/F,IAAG,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,aAAa,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC,EAAC,CAAC;YACtE,OAAO,IAAI,CAAC;QACd,CAAC;QAED,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACzB,OAAO,KAAK,CAAC;IACf,CAAC,CAAA;CACF;AAED,MAAM,CAAC,MAAM,mCAAmC,GAAG,GAAG,EAAE,CAAC,MAAM,CAAC,KAAK,GAAG,EAAE,CAAC;AAE3E,MAAM,aAAa,GAAG,CAAC,UAAkB,EAAE,OAAe,EAAW,EAAE;IACrE,MAAM,cAAc,GAAG,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC/C,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACxC,IAAG,cAAc,CAAC,MAAM,KAAK,UAAU,CAAC,MAAM,EAAE,CAAC;QAC/C,OAAO,KAAK,CAAC;IACf,CAAC;IACD,KAAI,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,cAAc,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC;QAC1D,MAAM,UAAU,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC;QACzC,IAAG,UAAU,CAAC,UAAU,CAAC,KAAK,OAAO,CAAC,UAAU,CAAC,EAAC,CAAC;YACjD,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC,CAAA;AAED,MAAM,UAAU,aAAa,CAAC,IAAS;IACrC,OAAO,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,SAAS,CAAC;AAC3C,CAAC;AAED,MAAM,QAAQ,GAAG,CAAC,KAAY,EAAE,EAAE;IAChC,IAAG,KAAK,YAAY,KAAK;QAAE,MAAM,KAAK,KAAK,CAAC;AAC9C,CAAC,CAAC;AAEF,MAAM,sBAAsB,GAAG,CAAC,EAAuB,EAAE,EAAE;IACzD,IAAG,EAAE,YAAY,mBAAmB;QAAE,GAAG,KAAK,EAAE,CAAC;AACnD,CAAC,CAAC;AAEF,MAAM,UAAU,yBAAyB;IACvC,OAAO,wBAAwB,CAAC;QAC9B,EAAE,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,iBAAiB,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,KAAK,EAAE,mBAAmB,CAAC,EAAE;KAC7G,CAAC,CAAA;AACJ,CAAC;AAED,MAAM,UAAU,iBAAiB,CAAC,KAAY,EAAE,GAAwB;IACtE,MAAM,KAAK,IAAI,aAAa,EAAE,CAAC;IAC/B,OAAO,GAAG,EAAE,CAAC,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QAC3C,QAAQ,CAAC,KAAK,CAAC,CAAC;QAChB,sBAAsB,CAAC,GAAG,CAAC,CAAA;QAC3B,OAAO,CAAC,IAAI,CAAC,CAAC;IAChB,CAAC,CAAC,CAAA;AACJ,CAAC","sourcesContent":["import { APP_INITIALIZER, EnvironmentInjector, Injector, makeEnvironmentProviders, runInInjectionContext, untracked } from \"@angular/core\";\r\nimport { Action, createSelector, MemoizedSelector, Store } from \"@ngrx/store\";\r\nimport { v4 as uuid } from 'uuid';\r\n\r\nlet _store: Store<any>;\r\nlet _cache: AppStoreCache;\r\nlet _ei : EnvironmentInjector;\r\n\r\n/**\r\n * Creates a selector that can dispatch an action if conditions are met.\r\n * Note: The props of the selector factory must include the props of the action.\r\n * @param selectorFactory A method that returns selector.\r\n * @param action The action that will be dispatched when conditions are met.\r\n * @param [dispatchIf = defaultFilter] Optional. A method that takes the result of the selector and returns a boolean. The actions gets dispatched\r\n * if true is returned. If no method is passed in than the action will be dispatched if the selector returns undefined or null.\r\n */\r\nexport const createActionableSelector = <State, Result, Props extends any[]>(\r\n  selectorFactory: ((...props: Props) => MemoizedSelector<State, Result>),\r\n  action: ActionReturner<Props>,\r\n  dispatchIf: (data: Result) => boolean = defaultFilter,\r\n) => {\r\n  const options = {\r\n    selectorFactory,\r\n    action: (...props: Props) => () => _store.dispatch(action(...props)),\r\n    dispatchIf\r\n  }\r\n  const actionable = createActionResultSelector(options);\r\n  return (...props: Props) => createSelector(actionable(...props), b => b.result);\r\n}\r\n\r\nexport const createActionSelector = <State, Result, Props extends any[] = any[]>(options: CreateActionResultsOptions<State, Result, Props>) => {\r\n  const actionable = createActionResultSelector(options);\r\n  return ((...props: Props) => createSelector(actionable(...props), b => b.result));\r\n}\r\n\r\nexport const createActionableResultSelector = <State, Result, Props extends any[]>(\r\n  selectorFactory: ((...props: Props) => MemoizedSelector<State, Result>),\r\n  action: ActionReturner<Props>,\r\n  dispatchIf: (data: Result) => boolean = defaultFilter,\r\n) => {\r\n  const options: CreateActionResultsOptions<State, Result, Props> = { \r\n    selectorFactory,\r\n    action: (...props: Props) => () => _store.dispatch(action(...props)),\r\n    dispatchIf\r\n  };\r\n\r\n  return createActionResultSelector(options);\r\n}\r\n\r\nexport const createActionResultSelector = <State, Result, Props extends any[] = any[]>(options: CreateActionResultsOptions<State, Result, Props>) => {\r\n  const id = uuid();\r\n  const slctr = (...props: Props) => createSelector(\r\n    options.selectorFactory(...props),\r\n    (selected: Result) => {\r\n      const needsDispatch = (options.dispatchIf || defaultFilter)(selected);\r\n      if(needsDispatch && !_cache.isInCache(id, ...props)){\r\n        queueMicrotask(() =>  \r\n          runInInjectionContext(options.injector || _ei, () => {\r\n            options.action(...props)()\r\n          }));\r\n      }\r\n      return ({\r\n        loading: needsDispatch,\r\n        result: selected\r\n      });\r\n    }\r\n  ) as ActionableMemoizedSelector<State, LoadingState<Result>>;\r\n  return slctr;\r\n}\r\n\r\nclass AppStoreCache {\r\n  cache: Cache = {};\r\n  isInCache = (actionableSelectorId: string, ...p: any[]): boolean => {\r\n    const props = p.reduce((a, b) => {\r\n      if(typeof b != 'object') b = { b };\r\n      return({ ...a, ...b })\r\n    }, {});\r\n\r\n    let itemsInCache = this.cache[actionableSelectorId] = (this.cache[actionableSelectorId] || []);\r\n\r\n    if(itemsInCache.some(itemInCache => shallowEquals(itemInCache, props))){\r\n      return true;\r\n    }\r\n\r\n    itemsInCache.push(props);\r\n    return false;\r\n  }\r\n}\r\n\r\nexport const clearActionableSelectorRequestCache = () => _cache.cache = {};\r\n\r\nconst shallowEquals = (cachedItem: object, newItem: object): boolean => {\r\n  const cachedItemKeys = Object.keys(cachedItem);\r\n  const secondKeys = Object.keys(newItem);\r\n  if(cachedItemKeys.length !== secondKeys.length) {\r\n    return false;\r\n  }\r\n  for(let index = 0; index < cachedItemKeys.length; index++) {\r\n    const currentKey = cachedItemKeys[index];\r\n    if(cachedItem[currentKey] !== newItem[currentKey]){\r\n      return false;\r\n    }\r\n  }\r\n  return true;\r\n}\r\n\r\nexport function defaultFilter(data: any) {\r\n  return data == null || data == undefined;\r\n}\r\n\r\nconst setStore = (store: Store) => {\r\n  if(store instanceof Store) _store ??= store;\r\n};\r\n\r\nconst setEnvironmentInjector = (ei: EnvironmentInjector) => {\r\n  if(ei instanceof EnvironmentInjector) _ei ??= ei;\r\n};\r\n\r\nexport function provideActionableSelector(){\r\n  return makeEnvironmentProviders([\r\n    { provide: APP_INITIALIZER, useFactory: setUpStoreFactory, multi: true, deps: [Store, EnvironmentInjector] },\r\n  ])\r\n}\r\n\r\nexport function setUpStoreFactory(store: Store, env: EnvironmentInjector){\r\n  _cache ??= new AppStoreCache();\r\n  return () => new Promise((resolve, reject) => {\r\n    setStore(store);\r\n    setEnvironmentInjector(env)\r\n    resolve(null);\r\n  })\r\n}\r\n\r\nexport interface CreateActionResultsOptions<State, Result, Props extends any[]>{\r\n  selectorFactory: (...props: Props) => MemoizedSelector<State, Result>,\r\n  action: (...props: Props) => () => void,\r\n  dispatchIf?: (data: Result) => boolean,\r\n  injector?: Injector\r\n}\r\n\r\ninterface LoadingState<T> {\r\n  loading: boolean;\r\n  result?: T;\r\n}\r\n\r\ntype ActionableMemoizedSelector<State, Result> = MemoizedSelector<State, Result>;\r\n\r\nexport type ActionReturner<Props extends any[]> = (...props: Props) => Action;\r\n\r\ntype Cache = {\r\n  [key: string]: { [key: string]: any }[];\r\n}"]}
@@ -70,10 +70,21 @@ export class ColumnBuilderComponent {
70
70
  ngOnInit() {
71
71
  this.initialSetUp();
72
72
  }
73
+ viewInited = false;
73
74
  ngAfterViewInit() {
74
75
  this.furtherSetUp();
75
76
  this.table.addColumnDef(this.columnDef);
77
+ this.onViewInit();
78
+ this.viewInited = true;
76
79
  }
80
+ onViewInit = () => { };
81
+ whenViewInited = (callback) => {
82
+ if (this.viewInited) {
83
+ callback();
84
+ return;
85
+ }
86
+ this.onViewInit = callback;
87
+ };
77
88
  initialSetUp() {
78
89
  if (this.metaData.fieldType === FieldType.Currency) {
79
90
  this.classes = {
@@ -131,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
131
142
  type: ViewChild,
132
143
  args: ['body']
133
144
  }] } });
134
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-builder.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/column-builder/column-builder.component.ts","../../../../../../projects/angular-utilities/src/table-builder/components/column-builder/column-builder.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ChangeDetectionStrategy, TemplateRef, ViewChild, OnInit, Predicate, Injector, computed, inject } from '@angular/core';\r\nimport { ArrayAdditional, FieldType, MetaData } from '../../interfaces/report-def';\r\nimport { MatColumnDef, MatTable, MatTableModule } from '@angular/material/table';\r\nimport { Observable } from 'rxjs';\r\nimport { CustomCellDirective, ResizeColumnDirective } from '../../directives';\r\nimport { FilterInfo } from '../../classes/filter-info';\r\nimport { TransformCreator } from '../../services/transform-creator';\r\nimport { TableStore } from '../../classes/table-store';\r\nimport { map } from 'rxjs/operators';\r\nimport { TableTemplateService } from '../../services/table-template-service';\r\nimport { CdkDropList, CDK_DROP_LIST, DragDropModule } from '@angular/cdk/drag-drop';\r\nimport { Dictionary } from '@ngrx/entity';\r\nimport { AsyncPipe, CurrencyPipe, DecimalPipe, NgTemplateOutlet } from '@angular/common';\r\nimport { ConditionalClassesDirective, FunctionPipe, SpaceCasePipe } from '../../../utilities';\r\nimport { MatSortModule } from '@angular/material/sort';\r\nimport { HeaderMenuComponent } from '../header-menu/header-menu.component';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { LetDirective } from '@ngrx/component';\r\nimport { ColumnTotalPipe } from '../../pipes/column-total.pipe';\r\nimport { StylerDirective } from '../../../utilities/directives/styler';\r\nimport { columnStyles } from './column-helpers';\r\nimport { TableBuilderConfigToken } from '../../classes/TableBuilderConfig';\r\nimport { LinkInfo } from '../../services/link-creator.service';\r\n\r\n\r\n@Component({\r\n  templateUrl: './column-builder.component.html',\r\n  styleUrls: ['./column-builder.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  viewProviders: [\r\n    { provide: CDK_DROP_LIST, useExisting: CdkDropList },\r\n  ],\r\n  standalone: true,\r\n  imports: [\r\n    MatTableModule, NgTemplateOutlet, ResizeColumnDirective, FunctionPipe, StylerDirective,\r\n    ConditionalClassesDirective, DragDropModule, MatSortModule, SpaceCasePipe, HeaderMenuComponent,\r\n    AsyncPipe, MatTooltipModule, LetDirective, ColumnTotalPipe, CurrencyPipe, DecimalPipe\r\n  ]\r\n})\r\nexport class ColumnBuilderComponent implements OnInit {\r\n  private transformCreator = inject(TransformCreator);\r\n  private table = inject<MatTable<any>>(MatTable);\r\n  private state = inject(TableStore);\r\n  private templateService = inject(TableTemplateService);\r\n  protected injector = inject(Injector);\r\n\r\n  @ViewChild(MatColumnDef) columnDef!: MatColumnDef;\r\n  @ViewChild('body') bodyTemplate!: TemplateRef<any>;\r\n  tableConfig = inject(TableBuilderConfigToken);\r\n  FieldType = FieldType;\r\n  filter!: Partial<FilterInfo>;\r\n  _metaData!: MetaData;\r\n  get metaData(){\r\n    return this._metaData;\r\n  }\r\n  set metaData(md: MetaData){\r\n    if(this.metaData && this.metaData.fieldType !== md.fieldType){\r\n      this._metaData = md;\r\n      this.initialSetUp();\r\n      this.furtherSetUp();\r\n    } else {\r\n      this._metaData = md;\r\n    }\r\n  }\r\n  customCell?: CustomCellDirective = undefined;\r\n  data$!: Observable<any[]>;\r\n\r\n  outerTemplate!: TemplateRef<any>;\r\n  innerTemplate!: TemplateRef<any>;\r\n  transform!: (o: any, ...args: any[])=> any ;\r\n\r\n  getInnerTemplate() :TemplateRef<any> {\r\n    if(this.metaData.template) return this.metaData.template;\r\n    if (this.customCell?.TemplateRef)  return this.customCell.TemplateRef;\r\n    return this.templateService.getTemplate(this.metaData);\r\n  }\r\n  showFilters$!: Observable<boolean>;\r\n  getOuterTemplate() {\r\n    return this.customCell?.columnDef?.cell?.template ?? this.bodyTemplate;\r\n  }\r\n  classes?: Dictionary<Predicate<any>>;\r\n  styles = computed(() => {\r\n    return columnStyles(this.metaData, this.state.$getUserDefinedWidth(this.metaData.key)(), this.state.tableSettingsMinWidth());\r\n  })\r\n  ngOnInit() {\r\n    this.initialSetUp();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.furtherSetUp();\r\n    this.table.addColumnDef(this.columnDef);\r\n  }\r\n\r\n  initialSetUp(){\r\n    if(this.metaData.fieldType === FieldType.Currency) {\r\n      this.classes = {\r\n        ['negative-currency']: (element) => element[this.metaData.key] < 0,\r\n        ...this.metaData.classes\r\n      }\r\n    }\r\n    else {\r\n      this.classes = this.metaData.classes;\r\n    }\r\n    this.filter = {key: this.metaData.key, fieldType: this.metaData.fieldType};\r\n\r\n    this.showFilters$ = this.state.tableSettings$.pipe(map(settings => !(settings.hideColumnHeaderFilters || this.metaData.noFilter)));\r\n    this.additional = this.metaData.fieldType === FieldType.Link\r\n      ? this.state.getLinkInfo(this.metaData)()\r\n      :\r\n      this.metaData.fieldType === FieldType.Array\r\n      ? (this.metaData.additional as ArrayAdditional)?.limit || this.tableConfig?.arrayDefaults?.arrayStyle\r\n      : undefined;\r\n  }\r\n\r\n  furtherSetUp(){\r\n    this.outerTemplate = this.getOuterTemplate();\r\n    this.innerTemplate = this.getInnerTemplate();\r\n    this.transform = this.transformCreator.createTransformer(this.metaData);\r\n  }\r\n\r\n  cellClicked(element: any, key: string) {\r\n    if(this.metaData.click) {\r\n      this.metaData.click(element,key);\r\n    }\r\n  }\r\n\r\n  getTooltip = (element: any) => {\r\n    if(typeof this.metaData.toolTip === 'string') {\r\n      return this.metaData.toolTip;\r\n    }\r\n    return this.metaData.toolTip!(element);\r\n  }\r\n\r\n  additional: LinkInfo | number | undefined;\r\n}\r\n","<ng-container [matColumnDef]=\"metaData.key\" *ngrxLet=\"styles() as styles\" >\r\n\r\n  <!-- header -->\r\n  <ng-template matHeaderCellDef #myHeader>\r\n    <mat-header-cell cdkDrag [style]='styles.header' resizeColumn [key]=\"metaData.key\" class=\"column-head\"\r\n      [class]='metaData.additional?.columnPartClasses?.header'>\r\n      <div class=\"header-container\" cdkDragHandle>\r\n        @if(!customCell?.columnDef?.headerCell)\r\n        {\r\n            @if(metaData.fieldType !== FieldType.NotMapped){\r\n              <div mat-sort-header [disabled]=\"metaData.noSort\" style=\"width: 100%\">\r\n                {{ metaData.displayName ?  metaData.displayName : ( metaData.key | spaceCase ) }}\r\n              </div>\r\n            } @else if(metaData.fieldType === FieldType.NotMapped){\r\n              <div style=\"width: 100%\">\r\n                {{ metaData.displayName ?  metaData.displayName : ( metaData.key | spaceCase ) }}\r\n              </div>\r\n            }\r\n            @if((showFilters$ | async)){\r\n              <tb-header-menu #menu [metaData]='metaData' />\r\n            }\r\n        }\r\n        @else\r\n        {\r\n          <ng-container *ngTemplateOutlet=\"customCell!.columnDef!.headerCell.template; context: {metaData: metaData, styles:  styles.header} \">\r\n          </ng-container>\r\n        }\r\n      </div>\r\n    </mat-header-cell>\r\n  </ng-template>\r\n\r\n  <!-- body -->\r\n  <ng-container *matCellDef=\"let element;\">\r\n    <ng-container *ngTemplateOutlet=\"outerTemplate; context: { metaData: metaData, element: element , styles: styles.body, $implicit: element }\"/>\r\n  </ng-container>\r\n  <ng-template #body let-element='element' >\r\n    <mat-cell  [matTooltip]=\"metaData.toolTip ? (getTooltip | func : element) : ''\"  [conditionalClasses]='metaData.classes' [element]='element' [styler]='styles.body' (click)='cellClicked(element, metaData.key)' >\r\n      <ng-container *ngTemplateOutlet=\"innerTemplate; context: { value: (transform | func : element), element: element, additional: additional, $implicit: element }; Injector: injector\" />\r\n    </mat-cell>\r\n  </ng-template>\r\n\r\n  <!-- footer -->\r\n  <ng-template matFooterCellDef>\r\n    @if(customCell?.columnDef?.footerCell){\r\n      <ng-container\r\n      *ngTemplateOutlet=\"customCell!.columnDef!.footerCell.template; context: {metaData: metaData, data: data$, styles : styles.footer }\"/>\r\n    } @else {\r\n      <mat-footer-cell  [style]='styles.footer' *ngrxLet=\"data$ as data\" [class]='metaData.additional?.columnPartClasses?.footer'>\r\n        @if(!!data?.length && metaData.additional?.footer){\r\n          <span class=\"bold\">\r\n            @switch (metaData.fieldType) {\r\n              @case (FieldType.Currency) { {{ data | columnTotal: metaData | currency }} }\r\n              @case (FieldType.Number) { {{ data | columnTotal: metaData | number }} }\r\n            }\r\n          </span>\r\n        }\r\n\r\n      </mat-footer-cell>\r\n    }\r\n  </ng-template>\r\n</ng-container>\r\n"]}
145
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-builder.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/column-builder/column-builder.component.ts","../../../../../../projects/angular-utilities/src/table-builder/components/column-builder/column-builder.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ChangeDetectionStrategy, TemplateRef, ViewChild, OnInit, Predicate, Injector, computed, inject } from '@angular/core';\r\nimport { ArrayAdditional, FieldType, MetaData } from '../../interfaces/report-def';\r\nimport { MatColumnDef, MatTable, MatTableModule } from '@angular/material/table';\r\nimport { Observable } from 'rxjs';\r\nimport { CustomCellDirective, ResizeColumnDirective } from '../../directives';\r\nimport { FilterInfo } from '../../classes/filter-info';\r\nimport { TransformCreator } from '../../services/transform-creator';\r\nimport { TableStore } from '../../classes/table-store';\r\nimport { map } from 'rxjs/operators';\r\nimport { TableTemplateService } from '../../services/table-template-service';\r\nimport { CdkDropList, CDK_DROP_LIST, DragDropModule } from '@angular/cdk/drag-drop';\r\nimport { Dictionary } from '@ngrx/entity';\r\nimport { AsyncPipe, CurrencyPipe, DecimalPipe, NgTemplateOutlet } from '@angular/common';\r\nimport { ConditionalClassesDirective, FunctionPipe, SpaceCasePipe } from '../../../utilities';\r\nimport { MatSortModule } from '@angular/material/sort';\r\nimport { HeaderMenuComponent } from '../header-menu/header-menu.component';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { LetDirective } from '@ngrx/component';\r\nimport { ColumnTotalPipe } from '../../pipes/column-total.pipe';\r\nimport { StylerDirective } from '../../../utilities/directives/styler';\r\nimport { columnStyles } from './column-helpers';\r\nimport { TableBuilderConfigToken } from '../../classes/TableBuilderConfig';\r\nimport { LinkInfo } from '../../services/link-creator.service';\r\n\r\n\r\n@Component({\r\n  templateUrl: './column-builder.component.html',\r\n  styleUrls: ['./column-builder.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  viewProviders: [\r\n    { provide: CDK_DROP_LIST, useExisting: CdkDropList },\r\n  ],\r\n  standalone: true,\r\n  imports: [\r\n    MatTableModule, NgTemplateOutlet, ResizeColumnDirective, FunctionPipe, StylerDirective,\r\n    ConditionalClassesDirective, DragDropModule, MatSortModule, SpaceCasePipe, HeaderMenuComponent,\r\n    AsyncPipe, MatTooltipModule, LetDirective, ColumnTotalPipe, CurrencyPipe, DecimalPipe\r\n  ]\r\n})\r\nexport class ColumnBuilderComponent implements OnInit {\r\n  private transformCreator = inject(TransformCreator);\r\n  private table = inject<MatTable<any>>(MatTable);\r\n  private state = inject(TableStore);\r\n  private templateService = inject(TableTemplateService);\r\n  protected injector = inject(Injector);\r\n\r\n  @ViewChild(MatColumnDef) columnDef!: MatColumnDef;\r\n  @ViewChild('body') bodyTemplate!: TemplateRef<any>;\r\n  tableConfig = inject(TableBuilderConfigToken);\r\n  FieldType = FieldType;\r\n  filter!: Partial<FilterInfo>;\r\n  _metaData!: MetaData;\r\n  get metaData(){\r\n    return this._metaData;\r\n  }\r\n  set metaData(md: MetaData){\r\n    if(this.metaData && this.metaData.fieldType !== md.fieldType){\r\n      this._metaData = md;\r\n      this.initialSetUp();\r\n      this.furtherSetUp();\r\n    } else {\r\n      this._metaData = md;\r\n    }\r\n  }\r\n  customCell?: CustomCellDirective = undefined;\r\n  data$!: Observable<any[]>;\r\n\r\n  outerTemplate!: TemplateRef<any>;\r\n  innerTemplate!: TemplateRef<any>;\r\n  transform!: (o: any, ...args: any[])=> any ;\r\n\r\n  getInnerTemplate() :TemplateRef<any> {\r\n    if(this.metaData.template) return this.metaData.template;\r\n    if (this.customCell?.TemplateRef)  return this.customCell.TemplateRef;\r\n    return this.templateService.getTemplate(this.metaData);\r\n  }\r\n  showFilters$!: Observable<boolean>;\r\n  getOuterTemplate() {\r\n    return this.customCell?.columnDef?.cell?.template ?? this.bodyTemplate;\r\n  }\r\n  classes?: Dictionary<Predicate<any>>;\r\n  styles = computed(() => {\r\n    return columnStyles(this.metaData, this.state.$getUserDefinedWidth(this.metaData.key)(), this.state.tableSettingsMinWidth());\r\n  })\r\n  ngOnInit() {\r\n    this.initialSetUp();\r\n  }\r\n\r\n  private viewInited = false;\r\n  ngAfterViewInit() {\r\n    this.furtherSetUp();\r\n    this.table.addColumnDef(this.columnDef);\r\n    this.onViewInit();\r\n    this.viewInited = true;\r\n  }\r\n  private onViewInit: () => void = () => {};\r\n  whenViewInited = (callback: () => void) => {\r\n    if(this.viewInited) {\r\n      callback();\r\n      return;\r\n    }\r\n    this.onViewInit = callback;\r\n  }\r\n\r\n  initialSetUp(){\r\n    if(this.metaData.fieldType === FieldType.Currency) {\r\n      this.classes = {\r\n        ['negative-currency']: (element) => element[this.metaData.key] < 0,\r\n        ...this.metaData.classes\r\n      }\r\n    }\r\n    else {\r\n      this.classes = this.metaData.classes;\r\n    }\r\n    this.filter = {key: this.metaData.key, fieldType: this.metaData.fieldType};\r\n\r\n    this.showFilters$ = this.state.tableSettings$.pipe(map(settings => !(settings.hideColumnHeaderFilters || this.metaData.noFilter)));\r\n    this.additional = this.metaData.fieldType === FieldType.Link\r\n      ? this.state.getLinkInfo(this.metaData)()\r\n      :\r\n      this.metaData.fieldType === FieldType.Array\r\n      ? (this.metaData.additional as ArrayAdditional)?.limit || this.tableConfig?.arrayDefaults?.arrayStyle\r\n      : undefined;\r\n  }\r\n\r\n  furtherSetUp(){\r\n    this.outerTemplate = this.getOuterTemplate();\r\n    this.innerTemplate = this.getInnerTemplate();\r\n    this.transform = this.transformCreator.createTransformer(this.metaData);\r\n  }\r\n\r\n  cellClicked(element: any, key: string) {\r\n    if(this.metaData.click) {\r\n      this.metaData.click(element,key);\r\n    }\r\n  }\r\n\r\n  getTooltip = (element: any) => {\r\n    if(typeof this.metaData.toolTip === 'string') {\r\n      return this.metaData.toolTip;\r\n    }\r\n    return this.metaData.toolTip!(element);\r\n  }\r\n\r\n  additional: LinkInfo | number | undefined;\r\n}\r\n","<ng-container [matColumnDef]=\"metaData.key\" *ngrxLet=\"styles() as styles\" >\r\n\r\n  <!-- header -->\r\n  <ng-template matHeaderCellDef #myHeader>\r\n    <mat-header-cell cdkDrag [style]='styles.header' resizeColumn [key]=\"metaData.key\" class=\"column-head\"\r\n      [class]='metaData.additional?.columnPartClasses?.header'>\r\n      <div class=\"header-container\" cdkDragHandle>\r\n        @if(!customCell?.columnDef?.headerCell)\r\n        {\r\n            @if(metaData.fieldType !== FieldType.NotMapped){\r\n              <div mat-sort-header [disabled]=\"metaData.noSort\" style=\"width: 100%\">\r\n                {{ metaData.displayName ?  metaData.displayName : ( metaData.key | spaceCase ) }}\r\n              </div>\r\n            } @else if(metaData.fieldType === FieldType.NotMapped){\r\n              <div style=\"width: 100%\">\r\n                {{ metaData.displayName ?  metaData.displayName : ( metaData.key | spaceCase ) }}\r\n              </div>\r\n            }\r\n            @if((showFilters$ | async)){\r\n              <tb-header-menu #menu [metaData]='metaData' />\r\n            }\r\n        }\r\n        @else\r\n        {\r\n          <ng-container *ngTemplateOutlet=\"customCell!.columnDef!.headerCell.template; context: {metaData: metaData, styles:  styles.header} \">\r\n          </ng-container>\r\n        }\r\n      </div>\r\n    </mat-header-cell>\r\n  </ng-template>\r\n\r\n  <!-- body -->\r\n  <ng-container *matCellDef=\"let element;\">\r\n    <ng-container *ngTemplateOutlet=\"outerTemplate; context: { metaData: metaData, element: element , styles: styles.body, $implicit: element }\"/>\r\n  </ng-container>\r\n  <ng-template #body let-element='element' >\r\n    <mat-cell  [matTooltip]=\"metaData.toolTip ? (getTooltip | func : element) : ''\"  [conditionalClasses]='metaData.classes' [element]='element' [styler]='styles.body' (click)='cellClicked(element, metaData.key)' >\r\n      <ng-container *ngTemplateOutlet=\"innerTemplate; context: { value: (transform | func : element), element: element, additional: additional, $implicit: element }; Injector: injector\" />\r\n    </mat-cell>\r\n  </ng-template>\r\n\r\n  <!-- footer -->\r\n  <ng-template matFooterCellDef>\r\n    @if(customCell?.columnDef?.footerCell){\r\n      <ng-container\r\n      *ngTemplateOutlet=\"customCell!.columnDef!.footerCell.template; context: {metaData: metaData, data: data$, styles : styles.footer }\"/>\r\n    } @else {\r\n      <mat-footer-cell  [style]='styles.footer' *ngrxLet=\"data$ as data\" [class]='metaData.additional?.columnPartClasses?.footer'>\r\n        @if(!!data?.length && metaData.additional?.footer){\r\n          <span class=\"bold\">\r\n            @switch (metaData.fieldType) {\r\n              @case (FieldType.Currency) { {{ data | columnTotal: metaData | currency }} }\r\n              @case (FieldType.Number) { {{ data | columnTotal: metaData | number }} }\r\n            }\r\n          </span>\r\n        }\r\n\r\n      </mat-footer-cell>\r\n    }\r\n  </ng-template>\r\n</ng-container>\r\n"]}
@@ -14,16 +14,16 @@ export class DateFilterComponent {
14
14
  info;
15
15
  CurrentFilterType;
16
16
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: DateFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
17
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: DateFilterComponent, isStandalone: true, selector: "tb-date-filter", inputs: { info: "info", CurrentFilterType: "CurrentFilterType" }, ngImport: i0, template: "@if (CurrentFilterType !== FilterType.DateBetween && CurrentFilterType !== FilterType.IsNull) {\r\n <mat-form-field>\r\n <input matInput name=\"filterValue\" [ngModel]=\"info.filterValue\" [matDatepicker]=\"cal\"/>\r\n <mat-datepicker-toggle class=\"small-button date-toggle\" matSuffix [for]=\"cal\" preventEnter />\r\n <mat-datepicker #cal />\r\n </mat-form-field>\r\n}\r\n@if(CurrentFilterType === FilterType.DateBetween){\r\n <ng-container ngModelGroup=\"filterValue\">\r\n <mat-form-field class=\"my-filter\" >\r\n <input matInput name=\"Start\" [ngModel]=\"info.filterValue?.Start\" placeholder=\"From\" [matDatepicker]=\"fromVal\"\r\n (click)=\"fromVal.open()\"/>\r\n <mat-datepicker-toggle matSuffix class=\"small-button date-toggle\" [for]=\"fromVal\" preventEnter />\r\n <mat-datepicker #fromVal></mat-datepicker>\r\n </mat-form-field>\r\n <mat-form-field>\r\n <input matInput name=\"End\" [ngModel]=\"info.filterValue?.End\" placeholder=\"To\" [matDatepicker]=\"toVal\" (click)=\"toVal.open()\"/>\r\n <mat-datepicker-toggle matSuffix class=\"small-button date-toggle\" [for]=\"toVal\" preventEnter />\r\n <mat-datepicker #toVal />\r\n </mat-form-field>\r\n </ng-container>\r\n}\r\n\r\n", styles: [".filter-name{color:#6495ed;margin:10px 0;font-weight:600;display:inline-block}.switch{display:inline-block}.my-filter{margin-right:15px}.cancel-button{float:right}.head-row{width:100%}.filter-row{width:fit-content}mat-card.filter-card::ng-deep mat-form-field{width:150px}mat-card.filter-card::ng-deep .mat-mdc-form-field-subscript-wrapper{line-height:0}mat-card.filter-card::ng-deep .mat-mdc-form-field-subscript-wrapper:before{height:0}.inline{display:inline-block}.small-button{height:18px;width:18px;font-size:18px;padding:0;margin:0}.small-button ::ng-deep *{line-height:initial;font-size:initial;height:18px;width:18px;font-size:18px;bottom:initial}.cancel-button{float:right;font-weight:700}.date-toggle ::ng-deep svg{position:absolute;left:0;top:0}\n"], dependencies: [{ kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i1.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: FormsModule }, { 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.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.NgModelGroup, selector: "[ngModelGroup]", inputs: ["ngModelGroup"], exportAs: ["ngModelGroup"] }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i4.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i4.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i4.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }], viewProviders: [{ provide: ControlContainer, useExisting: NgForm }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
17
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: DateFilterComponent, isStandalone: true, selector: "tb-date-filter", inputs: { info: "info", CurrentFilterType: "CurrentFilterType" }, ngImport: i0, template: "@if (CurrentFilterType !== FilterType.DateBetween && CurrentFilterType !== FilterType.IsNull) {\r\n <mat-form-field>\r\n <input matInput name=\"filterValue\" [ngModel]=\"info.filterValue\" [matDatepicker]=\"cal\"/>\r\n <mat-datepicker-toggle class=\"small-button date-toggle\" matSuffix [for]=\"cal\" preventEnter />\r\n <mat-datepicker #cal />\r\n </mat-form-field>\r\n}\r\n@if(CurrentFilterType === FilterType.DateBetween){\r\n <ng-container ngModelGroup=\"filterValue\">\r\n <mat-form-field class=\"my-filter\" >\r\n <input matInput name=\"Start\" [ngModel]=\"info.filterValue?.Start\" placeholder=\"From\" [matDatepicker]=\"fromVal\"\r\n (click)=\"fromVal.open()\"/>\r\n <mat-datepicker-toggle matSuffix class=\"small-button date-toggle\" [for]=\"fromVal\" preventEnter />\r\n <mat-datepicker #fromVal></mat-datepicker>\r\n </mat-form-field>\r\n <mat-form-field>\r\n <input matInput name=\"End\" [ngModel]=\"info.filterValue?.End\" placeholder=\"To\" [matDatepicker]=\"toVal\" (click)=\"toVal.open()\"/>\r\n <mat-datepicker-toggle matSuffix class=\"small-button date-toggle\" [for]=\"toVal\" preventEnter />\r\n <mat-datepicker #toVal />\r\n </mat-form-field>\r\n </ng-container>\r\n}\r\n\r\n", styles: [".filter-name{color:#6495ed;margin:10px 0;font-weight:600;display:inline-block}.switch{display:inline-block}.head-row{display:flex;width:100%;align-items:center;justify-content:space-between}.filter-row{display:flex;align-items:center;gap:1rem}mat-card.filter-card::ng-deep mat-form-field{width:150px}mat-card.filter-card::ng-deep .mat-mdc-form-field-subscript-wrapper{line-height:0}mat-card.filter-card::ng-deep .mat-mdc-form-field-subscript-wrapper:before{height:0}.inline{display:inline-block}.small-button{height:18px;width:18px;font-size:18px;padding:0;margin:0}.small-button ::ng-deep *{line-height:initial;font-size:initial;height:18px;width:18px;font-size:18px;bottom:initial}.cancel-button{font-weight:700}.date-toggle ::ng-deep svg{position:absolute;left:0;top:0}\n"], dependencies: [{ kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i1.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: FormsModule }, { 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.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.NgModelGroup, selector: "[ngModelGroup]", inputs: ["ngModelGroup"], exportAs: ["ngModelGroup"] }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i4.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i4.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i4.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }], viewProviders: [{ provide: ControlContainer, useExisting: NgForm }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
18
18
  }
19
19
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: DateFilterComponent, decorators: [{
20
20
  type: Component,
21
21
  args: [{ selector: 'tb-date-filter', changeDetection: ChangeDetectionStrategy.OnPush, viewProviders: [{ provide: ControlContainer, useExisting: NgForm }], standalone: true, imports: [
22
22
  MatInputModule, FormsModule, MatDatepickerModule, PreventEnterDirective
23
- ], template: "@if (CurrentFilterType !== FilterType.DateBetween && CurrentFilterType !== FilterType.IsNull) {\r\n <mat-form-field>\r\n <input matInput name=\"filterValue\" [ngModel]=\"info.filterValue\" [matDatepicker]=\"cal\"/>\r\n <mat-datepicker-toggle class=\"small-button date-toggle\" matSuffix [for]=\"cal\" preventEnter />\r\n <mat-datepicker #cal />\r\n </mat-form-field>\r\n}\r\n@if(CurrentFilterType === FilterType.DateBetween){\r\n <ng-container ngModelGroup=\"filterValue\">\r\n <mat-form-field class=\"my-filter\" >\r\n <input matInput name=\"Start\" [ngModel]=\"info.filterValue?.Start\" placeholder=\"From\" [matDatepicker]=\"fromVal\"\r\n (click)=\"fromVal.open()\"/>\r\n <mat-datepicker-toggle matSuffix class=\"small-button date-toggle\" [for]=\"fromVal\" preventEnter />\r\n <mat-datepicker #fromVal></mat-datepicker>\r\n </mat-form-field>\r\n <mat-form-field>\r\n <input matInput name=\"End\" [ngModel]=\"info.filterValue?.End\" placeholder=\"To\" [matDatepicker]=\"toVal\" (click)=\"toVal.open()\"/>\r\n <mat-datepicker-toggle matSuffix class=\"small-button date-toggle\" [for]=\"toVal\" preventEnter />\r\n <mat-datepicker #toVal />\r\n </mat-form-field>\r\n </ng-container>\r\n}\r\n\r\n", styles: [".filter-name{color:#6495ed;margin:10px 0;font-weight:600;display:inline-block}.switch{display:inline-block}.my-filter{margin-right:15px}.cancel-button{float:right}.head-row{width:100%}.filter-row{width:fit-content}mat-card.filter-card::ng-deep mat-form-field{width:150px}mat-card.filter-card::ng-deep .mat-mdc-form-field-subscript-wrapper{line-height:0}mat-card.filter-card::ng-deep .mat-mdc-form-field-subscript-wrapper:before{height:0}.inline{display:inline-block}.small-button{height:18px;width:18px;font-size:18px;padding:0;margin:0}.small-button ::ng-deep *{line-height:initial;font-size:initial;height:18px;width:18px;font-size:18px;bottom:initial}.cancel-button{float:right;font-weight:700}.date-toggle ::ng-deep svg{position:absolute;left:0;top:0}\n"] }]
23
+ ], template: "@if (CurrentFilterType !== FilterType.DateBetween && CurrentFilterType !== FilterType.IsNull) {\r\n <mat-form-field>\r\n <input matInput name=\"filterValue\" [ngModel]=\"info.filterValue\" [matDatepicker]=\"cal\"/>\r\n <mat-datepicker-toggle class=\"small-button date-toggle\" matSuffix [for]=\"cal\" preventEnter />\r\n <mat-datepicker #cal />\r\n </mat-form-field>\r\n}\r\n@if(CurrentFilterType === FilterType.DateBetween){\r\n <ng-container ngModelGroup=\"filterValue\">\r\n <mat-form-field class=\"my-filter\" >\r\n <input matInput name=\"Start\" [ngModel]=\"info.filterValue?.Start\" placeholder=\"From\" [matDatepicker]=\"fromVal\"\r\n (click)=\"fromVal.open()\"/>\r\n <mat-datepicker-toggle matSuffix class=\"small-button date-toggle\" [for]=\"fromVal\" preventEnter />\r\n <mat-datepicker #fromVal></mat-datepicker>\r\n </mat-form-field>\r\n <mat-form-field>\r\n <input matInput name=\"End\" [ngModel]=\"info.filterValue?.End\" placeholder=\"To\" [matDatepicker]=\"toVal\" (click)=\"toVal.open()\"/>\r\n <mat-datepicker-toggle matSuffix class=\"small-button date-toggle\" [for]=\"toVal\" preventEnter />\r\n <mat-datepicker #toVal />\r\n </mat-form-field>\r\n </ng-container>\r\n}\r\n\r\n", styles: [".filter-name{color:#6495ed;margin:10px 0;font-weight:600;display:inline-block}.switch{display:inline-block}.head-row{display:flex;width:100%;align-items:center;justify-content:space-between}.filter-row{display:flex;align-items:center;gap:1rem}mat-card.filter-card::ng-deep mat-form-field{width:150px}mat-card.filter-card::ng-deep .mat-mdc-form-field-subscript-wrapper{line-height:0}mat-card.filter-card::ng-deep .mat-mdc-form-field-subscript-wrapper:before{height:0}.inline{display:inline-block}.small-button{height:18px;width:18px;font-size:18px;padding:0;margin:0}.small-button ::ng-deep *{line-height:initial;font-size:initial;height:18px;width:18px;font-size:18px;bottom:initial}.cancel-button{font-weight:700}.date-toggle ::ng-deep svg{position:absolute;left:0;top:0}\n"] }]
24
24
  }], propDecorators: { info: [{
25
25
  type: Input
26
26
  }], CurrentFilterType: [{
27
27
  type: Input
28
28
  }] } });
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1maWx0ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11dGlsaXRpZXMvc3JjL3RhYmxlLWJ1aWxkZXIvY29tcG9uZW50cy9kYXRlLWZpbHRlci9kYXRlLWZpbHRlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXV0aWxpdGllcy9zcmMvdGFibGUtYnVpbGRlci9jb21wb25lbnRzL2RhdGUtZmlsdGVyL2RhdGUtZmlsdGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsdUJBQXVCLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTFFLE9BQU8sRUFBYyxXQUFXLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsV0FBVyxFQUFFLE1BQU0sRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNuRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQzs7Ozs7O0FBYTNELE1BQU0sT0FBTyxtQkFBbUI7SUFDNUIsVUFBVSxHQUFHLFdBQVcsQ0FBQztJQUNoQixJQUFJLENBQWlCO0lBQ3JCLGlCQUFpQixDQUFjO3VHQUgvQixtQkFBbUI7MkZBQW5CLG1CQUFtQiw0SUNuQmhDLGd2Q0F1QkEsOHlCRFBRLGNBQWMsc3JCQUFFLFdBQVcsMDRCQUFFLG1CQUFtQix1ZkFIckMsQ0FBQyxFQUFDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxXQUFXLEVBQUUsTUFBTSxFQUFDLENBQUM7OzJGQU14RCxtQkFBbUI7a0JBWC9CLFNBQVM7K0JBQ0ksZ0JBQWdCLG1CQUVULHVCQUF1QixDQUFDLE1BQU0saUJBRWhDLENBQUMsRUFBQyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsV0FBVyxFQUFFLE1BQU0sRUFBQyxDQUFDLGNBQ3JELElBQUksV0FDUDt3QkFDTCxjQUFjLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLHFCQUFxQjtxQkFDMUU7OEJBSVEsSUFBSTtzQkFBWixLQUFLO2dCQUNHLGlCQUFpQjtzQkFBekIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFBhcnRpYWxGaWx0ZXIgfSBmcm9tICcuLi8uLi9jbGFzc2VzL2ZpbHRlci1pbmZvJztcclxuaW1wb3J0IHsgRmlsdGVyVHlwZSwgRmlsdGVyVHlwZXMgfSBmcm9tICcuLi8uLi9lbnVtcy9maWx0ZXJUeXBlcyc7XHJcbmltcG9ydCB7IENvbnRyb2xDb250YWluZXIsIEZvcm1zTW9kdWxlLCBOZ0Zvcm0gfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IE1hdElucHV0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXQnO1xyXG5pbXBvcnQgeyBNYXREYXRlcGlja2VyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGF0ZXBpY2tlcic7XHJcbmltcG9ydCB7IFByZXZlbnRFbnRlckRpcmVjdGl2ZSB9IGZyb20gJy4uLy4uLy4uL3V0aWxpdGllcyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAndGItZGF0ZS1maWx0ZXInLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL2RhdGUtZmlsdGVyLmNvbXBvbmVudC5odG1sJyxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4uL2ZpbHRlci9maWx0ZXIuY29tcG9uZW50LnNjc3MnXSxcclxuICAgIHZpZXdQcm92aWRlcnM6IFt7cHJvdmlkZTogQ29udHJvbENvbnRhaW5lciwgdXNlRXhpc3Rpbmc6IE5nRm9ybX1dLFxyXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICAgIGltcG9ydHM6IFtcclxuICAgICAgICBNYXRJbnB1dE1vZHVsZSwgRm9ybXNNb2R1bGUsIE1hdERhdGVwaWNrZXJNb2R1bGUsIFByZXZlbnRFbnRlckRpcmVjdGl2ZVxyXG4gICAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgRGF0ZUZpbHRlckNvbXBvbmVudCB7XHJcbiAgICBGaWx0ZXJUeXBlID0gRmlsdGVyVHlwZXM7XHJcbiAgICBASW5wdXQoKSBpbmZvITogUGFydGlhbEZpbHRlcjtcclxuICAgIEBJbnB1dCgpIEN1cnJlbnRGaWx0ZXJUeXBlITogRmlsdGVyVHlwZTtcclxufVxyXG4iLCJAaWYgKEN1cnJlbnRGaWx0ZXJUeXBlICE9PSBGaWx0ZXJUeXBlLkRhdGVCZXR3ZWVuICYmIEN1cnJlbnRGaWx0ZXJUeXBlICE9PSBGaWx0ZXJUeXBlLklzTnVsbCkge1xyXG4gIDxtYXQtZm9ybS1maWVsZD5cclxuICAgIDxpbnB1dCBtYXRJbnB1dCBuYW1lPVwiZmlsdGVyVmFsdWVcIiBbbmdNb2RlbF09XCJpbmZvLmZpbHRlclZhbHVlXCIgW21hdERhdGVwaWNrZXJdPVwiY2FsXCIvPlxyXG4gICAgPG1hdC1kYXRlcGlja2VyLXRvZ2dsZSBjbGFzcz1cInNtYWxsLWJ1dHRvbiBkYXRlLXRvZ2dsZVwiIG1hdFN1ZmZpeCBbZm9yXT1cImNhbFwiIHByZXZlbnRFbnRlciAvPlxyXG4gICAgPG1hdC1kYXRlcGlja2VyICNjYWwgLz5cclxuICA8L21hdC1mb3JtLWZpZWxkPlxyXG59XHJcbkBpZihDdXJyZW50RmlsdGVyVHlwZSA9PT0gRmlsdGVyVHlwZS5EYXRlQmV0d2Vlbil7XHJcbiAgPG5nLWNvbnRhaW5lciBuZ01vZGVsR3JvdXA9XCJmaWx0ZXJWYWx1ZVwiPlxyXG4gICAgPG1hdC1mb3JtLWZpZWxkIGNsYXNzPVwibXktZmlsdGVyXCIgPlxyXG4gICAgICA8aW5wdXQgbWF0SW5wdXQgbmFtZT1cIlN0YXJ0XCIgW25nTW9kZWxdPVwiaW5mby5maWx0ZXJWYWx1ZT8uU3RhcnRcIiAgcGxhY2Vob2xkZXI9XCJGcm9tXCIgW21hdERhdGVwaWNrZXJdPVwiZnJvbVZhbFwiXHJcbiAgICAgICAgICAoY2xpY2spPVwiZnJvbVZhbC5vcGVuKClcIi8+XHJcbiAgICAgIDxtYXQtZGF0ZXBpY2tlci10b2dnbGUgbWF0U3VmZml4IGNsYXNzPVwic21hbGwtYnV0dG9uIGRhdGUtdG9nZ2xlXCIgW2Zvcl09XCJmcm9tVmFsXCIgcHJldmVudEVudGVyIC8+XHJcbiAgICAgIDxtYXQtZGF0ZXBpY2tlciAjZnJvbVZhbD48L21hdC1kYXRlcGlja2VyPlxyXG4gICAgPC9tYXQtZm9ybS1maWVsZD5cclxuICAgIDxtYXQtZm9ybS1maWVsZD5cclxuICAgICAgPGlucHV0IG1hdElucHV0IG5hbWU9XCJFbmRcIiBbbmdNb2RlbF09XCJpbmZvLmZpbHRlclZhbHVlPy5FbmRcIiAgcGxhY2Vob2xkZXI9XCJUb1wiIFttYXREYXRlcGlja2VyXT1cInRvVmFsXCIgKGNsaWNrKT1cInRvVmFsLm9wZW4oKVwiLz5cclxuICAgICAgPG1hdC1kYXRlcGlja2VyLXRvZ2dsZSBtYXRTdWZmaXggY2xhc3M9XCJzbWFsbC1idXR0b24gZGF0ZS10b2dnbGVcIiBbZm9yXT1cInRvVmFsXCIgcHJldmVudEVudGVyIC8+XHJcbiAgICAgIDxtYXQtZGF0ZXBpY2tlciAjdG9WYWwgLz5cclxuICAgIDwvbWF0LWZvcm0tZmllbGQ+XHJcbiAgPC9uZy1jb250YWluZXI+XHJcbn1cclxuXHJcbiJdfQ==
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1maWx0ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11dGlsaXRpZXMvc3JjL3RhYmxlLWJ1aWxkZXIvY29tcG9uZW50cy9kYXRlLWZpbHRlci9kYXRlLWZpbHRlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXV0aWxpdGllcy9zcmMvdGFibGUtYnVpbGRlci9jb21wb25lbnRzL2RhdGUtZmlsdGVyL2RhdGUtZmlsdGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsdUJBQXVCLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTFFLE9BQU8sRUFBYyxXQUFXLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsV0FBVyxFQUFFLE1BQU0sRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNuRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQzs7Ozs7O0FBYTNELE1BQU0sT0FBTyxtQkFBbUI7SUFDNUIsVUFBVSxHQUFHLFdBQVcsQ0FBQztJQUNoQixJQUFJLENBQWlCO0lBQ3JCLGlCQUFpQixDQUFjO3VHQUgvQixtQkFBbUI7MkZBQW5CLG1CQUFtQiw0SUNuQmhDLGd2Q0F1QkEsK3pCRFBRLGNBQWMsc3JCQUFFLFdBQVcsMDRCQUFFLG1CQUFtQix1ZkFIckMsQ0FBQyxFQUFDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxXQUFXLEVBQUUsTUFBTSxFQUFDLENBQUM7OzJGQU14RCxtQkFBbUI7a0JBWC9CLFNBQVM7K0JBQ0ksZ0JBQWdCLG1CQUVULHVCQUF1QixDQUFDLE1BQU0saUJBRWhDLENBQUMsRUFBQyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsV0FBVyxFQUFFLE1BQU0sRUFBQyxDQUFDLGNBQ3JELElBQUksV0FDUDt3QkFDTCxjQUFjLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLHFCQUFxQjtxQkFDMUU7OEJBSVEsSUFBSTtzQkFBWixLQUFLO2dCQUNHLGlCQUFpQjtzQkFBekIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFBhcnRpYWxGaWx0ZXIgfSBmcm9tICcuLi8uLi9jbGFzc2VzL2ZpbHRlci1pbmZvJztcclxuaW1wb3J0IHsgRmlsdGVyVHlwZSwgRmlsdGVyVHlwZXMgfSBmcm9tICcuLi8uLi9lbnVtcy9maWx0ZXJUeXBlcyc7XHJcbmltcG9ydCB7IENvbnRyb2xDb250YWluZXIsIEZvcm1zTW9kdWxlLCBOZ0Zvcm0gfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IE1hdElucHV0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXQnO1xyXG5pbXBvcnQgeyBNYXREYXRlcGlja2VyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGF0ZXBpY2tlcic7XHJcbmltcG9ydCB7IFByZXZlbnRFbnRlckRpcmVjdGl2ZSB9IGZyb20gJy4uLy4uLy4uL3V0aWxpdGllcyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAndGItZGF0ZS1maWx0ZXInLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL2RhdGUtZmlsdGVyLmNvbXBvbmVudC5odG1sJyxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4uL2ZpbHRlci9maWx0ZXIuY29tcG9uZW50LnNjc3MnXSxcclxuICAgIHZpZXdQcm92aWRlcnM6IFt7cHJvdmlkZTogQ29udHJvbENvbnRhaW5lciwgdXNlRXhpc3Rpbmc6IE5nRm9ybX1dLFxyXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICAgIGltcG9ydHM6IFtcclxuICAgICAgICBNYXRJbnB1dE1vZHVsZSwgRm9ybXNNb2R1bGUsIE1hdERhdGVwaWNrZXJNb2R1bGUsIFByZXZlbnRFbnRlckRpcmVjdGl2ZVxyXG4gICAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgRGF0ZUZpbHRlckNvbXBvbmVudCB7XHJcbiAgICBGaWx0ZXJUeXBlID0gRmlsdGVyVHlwZXM7XHJcbiAgICBASW5wdXQoKSBpbmZvITogUGFydGlhbEZpbHRlcjtcclxuICAgIEBJbnB1dCgpIEN1cnJlbnRGaWx0ZXJUeXBlITogRmlsdGVyVHlwZTtcclxufVxyXG4iLCJAaWYgKEN1cnJlbnRGaWx0ZXJUeXBlICE9PSBGaWx0ZXJUeXBlLkRhdGVCZXR3ZWVuICYmIEN1cnJlbnRGaWx0ZXJUeXBlICE9PSBGaWx0ZXJUeXBlLklzTnVsbCkge1xyXG4gIDxtYXQtZm9ybS1maWVsZD5cclxuICAgIDxpbnB1dCBtYXRJbnB1dCBuYW1lPVwiZmlsdGVyVmFsdWVcIiBbbmdNb2RlbF09XCJpbmZvLmZpbHRlclZhbHVlXCIgW21hdERhdGVwaWNrZXJdPVwiY2FsXCIvPlxyXG4gICAgPG1hdC1kYXRlcGlja2VyLXRvZ2dsZSBjbGFzcz1cInNtYWxsLWJ1dHRvbiBkYXRlLXRvZ2dsZVwiIG1hdFN1ZmZpeCBbZm9yXT1cImNhbFwiIHByZXZlbnRFbnRlciAvPlxyXG4gICAgPG1hdC1kYXRlcGlja2VyICNjYWwgLz5cclxuICA8L21hdC1mb3JtLWZpZWxkPlxyXG59XHJcbkBpZihDdXJyZW50RmlsdGVyVHlwZSA9PT0gRmlsdGVyVHlwZS5EYXRlQmV0d2Vlbil7XHJcbiAgPG5nLWNvbnRhaW5lciBuZ01vZGVsR3JvdXA9XCJmaWx0ZXJWYWx1ZVwiPlxyXG4gICAgPG1hdC1mb3JtLWZpZWxkIGNsYXNzPVwibXktZmlsdGVyXCIgPlxyXG4gICAgICA8aW5wdXQgbWF0SW5wdXQgbmFtZT1cIlN0YXJ0XCIgW25nTW9kZWxdPVwiaW5mby5maWx0ZXJWYWx1ZT8uU3RhcnRcIiAgcGxhY2Vob2xkZXI9XCJGcm9tXCIgW21hdERhdGVwaWNrZXJdPVwiZnJvbVZhbFwiXHJcbiAgICAgICAgICAoY2xpY2spPVwiZnJvbVZhbC5vcGVuKClcIi8+XHJcbiAgICAgIDxtYXQtZGF0ZXBpY2tlci10b2dnbGUgbWF0U3VmZml4IGNsYXNzPVwic21hbGwtYnV0dG9uIGRhdGUtdG9nZ2xlXCIgW2Zvcl09XCJmcm9tVmFsXCIgcHJldmVudEVudGVyIC8+XHJcbiAgICAgIDxtYXQtZGF0ZXBpY2tlciAjZnJvbVZhbD48L21hdC1kYXRlcGlja2VyPlxyXG4gICAgPC9tYXQtZm9ybS1maWVsZD5cclxuICAgIDxtYXQtZm9ybS1maWVsZD5cclxuICAgICAgPGlucHV0IG1hdElucHV0IG5hbWU9XCJFbmRcIiBbbmdNb2RlbF09XCJpbmZvLmZpbHRlclZhbHVlPy5FbmRcIiAgcGxhY2Vob2xkZXI9XCJUb1wiIFttYXREYXRlcGlja2VyXT1cInRvVmFsXCIgKGNsaWNrKT1cInRvVmFsLm9wZW4oKVwiLz5cclxuICAgICAgPG1hdC1kYXRlcGlja2VyLXRvZ2dsZSBtYXRTdWZmaXggY2xhc3M9XCJzbWFsbC1idXR0b24gZGF0ZS10b2dnbGVcIiBbZm9yXT1cInRvVmFsXCIgcHJldmVudEVudGVyIC8+XHJcbiAgICAgIDxtYXQtZGF0ZXBpY2tlciAjdG9WYWwgLz5cclxuICAgIDwvbWF0LWZvcm0tZmllbGQ+XHJcbiAgPC9uZy1jb250YWluZXI+XHJcbn1cclxuXHJcbiJdfQ==
@@ -9,16 +9,16 @@ export class DateTimeFilterComponent {
9
9
  info;
10
10
  CurrentFilterType;
11
11
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: DateTimeFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
12
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: DateTimeFilterComponent, isStandalone: true, selector: "tb-date-time-filter", inputs: { info: "info", CurrentFilterType: "CurrentFilterType" }, ngImport: i0, template: "@if(CurrentFilterType !== FilterType.DateTimeBetween && CurrentFilterType !== FilterType.IsNull){\r\n <input type=\"datetime-local\" [ngModel]=\"info.filterValue\" preventEnter name=\"filterValue\" class=\"op-date-time-input\"/>\r\n}\r\n@if(CurrentFilterType === FilterType.DateTimeBetween){\r\n <ng-container ngModelGroup=\"filterValue\">\r\n <input type=\"datetime-local\" [ngModel]=\"info.filterValue?.Start\" preventEnter name=\"Start\" class=\"op-date-time-input\"/>\r\n <input type=\"datetime-local\" [ngModel]=\"info.filterValue?.End\" preventEnter name=\"End\" class=\"op-date-time-input\"/>\r\n </ng-container>\r\n}", styles: [".filter-name{color:#6495ed;margin:10px 0;font-weight:600;display:inline-block}.switch{display:inline-block}.my-filter{margin-right:15px}.cancel-button{float:right}.head-row{width:100%}.filter-row{width:fit-content}mat-card.filter-card::ng-deep mat-form-field{width:150px}mat-card.filter-card::ng-deep .mat-mdc-form-field-subscript-wrapper{line-height:0}mat-card.filter-card::ng-deep .mat-mdc-form-field-subscript-wrapper:before{height:0}.inline{display:inline-block}.small-button{height:18px;width:18px;font-size:18px;padding:0;margin:0}.small-button ::ng-deep *{line-height:initial;font-size:initial;height:18px;width:18px;font-size:18px;bottom:initial}.cancel-button{float:right;font-weight:700}.date-toggle ::ng-deep svg{position:absolute;left:0;top:0}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.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: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i1.NgModelGroup, selector: "[ngModelGroup]", inputs: ["ngModelGroup"], exportAs: ["ngModelGroup"] }], viewProviders: [{ provide: ControlContainer, useExisting: NgForm }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
12
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: DateTimeFilterComponent, isStandalone: true, selector: "tb-date-time-filter", inputs: { info: "info", CurrentFilterType: "CurrentFilterType" }, ngImport: i0, template: "@if(CurrentFilterType !== FilterType.DateTimeBetween && CurrentFilterType !== FilterType.IsNull){\r\n <input type=\"datetime-local\" [ngModel]=\"info.filterValue\" preventEnter name=\"filterValue\" class=\"op-date-time-input\"/>\r\n}\r\n@if(CurrentFilterType === FilterType.DateTimeBetween){\r\n <ng-container ngModelGroup=\"filterValue\">\r\n <input type=\"datetime-local\" [ngModel]=\"info.filterValue?.Start\" preventEnter name=\"Start\" class=\"op-date-time-input\"/>\r\n <input type=\"datetime-local\" [ngModel]=\"info.filterValue?.End\" preventEnter name=\"End\" class=\"op-date-time-input\"/>\r\n </ng-container>\r\n}", styles: [".filter-name{color:#6495ed;margin:10px 0;font-weight:600;display:inline-block}.switch{display:inline-block}.head-row{display:flex;width:100%;align-items:center;justify-content:space-between}.filter-row{display:flex;align-items:center;gap:1rem}mat-card.filter-card::ng-deep mat-form-field{width:150px}mat-card.filter-card::ng-deep .mat-mdc-form-field-subscript-wrapper{line-height:0}mat-card.filter-card::ng-deep .mat-mdc-form-field-subscript-wrapper:before{height:0}.inline{display:inline-block}.small-button{height:18px;width:18px;font-size:18px;padding:0;margin:0}.small-button ::ng-deep *{line-height:initial;font-size:initial;height:18px;width:18px;font-size:18px;bottom:initial}.cancel-button{font-weight:700}.date-toggle ::ng-deep svg{position:absolute;left:0;top:0}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.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: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i1.NgModelGroup, selector: "[ngModelGroup]", inputs: ["ngModelGroup"], exportAs: ["ngModelGroup"] }], viewProviders: [{ provide: ControlContainer, useExisting: NgForm }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
13
13
  }
14
14
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: DateTimeFilterComponent, decorators: [{
15
15
  type: Component,
16
16
  args: [{ selector: 'tb-date-time-filter', changeDetection: ChangeDetectionStrategy.OnPush, viewProviders: [{ provide: ControlContainer, useExisting: NgForm }], standalone: true, imports: [
17
17
  FormsModule, PreventEnterDirective
18
- ], template: "@if(CurrentFilterType !== FilterType.DateTimeBetween && CurrentFilterType !== FilterType.IsNull){\r\n <input type=\"datetime-local\" [ngModel]=\"info.filterValue\" preventEnter name=\"filterValue\" class=\"op-date-time-input\"/>\r\n}\r\n@if(CurrentFilterType === FilterType.DateTimeBetween){\r\n <ng-container ngModelGroup=\"filterValue\">\r\n <input type=\"datetime-local\" [ngModel]=\"info.filterValue?.Start\" preventEnter name=\"Start\" class=\"op-date-time-input\"/>\r\n <input type=\"datetime-local\" [ngModel]=\"info.filterValue?.End\" preventEnter name=\"End\" class=\"op-date-time-input\"/>\r\n </ng-container>\r\n}", styles: [".filter-name{color:#6495ed;margin:10px 0;font-weight:600;display:inline-block}.switch{display:inline-block}.my-filter{margin-right:15px}.cancel-button{float:right}.head-row{width:100%}.filter-row{width:fit-content}mat-card.filter-card::ng-deep mat-form-field{width:150px}mat-card.filter-card::ng-deep .mat-mdc-form-field-subscript-wrapper{line-height:0}mat-card.filter-card::ng-deep .mat-mdc-form-field-subscript-wrapper:before{height:0}.inline{display:inline-block}.small-button{height:18px;width:18px;font-size:18px;padding:0;margin:0}.small-button ::ng-deep *{line-height:initial;font-size:initial;height:18px;width:18px;font-size:18px;bottom:initial}.cancel-button{float:right;font-weight:700}.date-toggle ::ng-deep svg{position:absolute;left:0;top:0}\n"] }]
18
+ ], template: "@if(CurrentFilterType !== FilterType.DateTimeBetween && CurrentFilterType !== FilterType.IsNull){\r\n <input type=\"datetime-local\" [ngModel]=\"info.filterValue\" preventEnter name=\"filterValue\" class=\"op-date-time-input\"/>\r\n}\r\n@if(CurrentFilterType === FilterType.DateTimeBetween){\r\n <ng-container ngModelGroup=\"filterValue\">\r\n <input type=\"datetime-local\" [ngModel]=\"info.filterValue?.Start\" preventEnter name=\"Start\" class=\"op-date-time-input\"/>\r\n <input type=\"datetime-local\" [ngModel]=\"info.filterValue?.End\" preventEnter name=\"End\" class=\"op-date-time-input\"/>\r\n </ng-container>\r\n}", styles: [".filter-name{color:#6495ed;margin:10px 0;font-weight:600;display:inline-block}.switch{display:inline-block}.head-row{display:flex;width:100%;align-items:center;justify-content:space-between}.filter-row{display:flex;align-items:center;gap:1rem}mat-card.filter-card::ng-deep mat-form-field{width:150px}mat-card.filter-card::ng-deep .mat-mdc-form-field-subscript-wrapper{line-height:0}mat-card.filter-card::ng-deep .mat-mdc-form-field-subscript-wrapper:before{height:0}.inline{display:inline-block}.small-button{height:18px;width:18px;font-size:18px;padding:0;margin:0}.small-button ::ng-deep *{line-height:initial;font-size:initial;height:18px;width:18px;font-size:18px;bottom:initial}.cancel-button{font-weight:700}.date-toggle ::ng-deep svg{position:absolute;left:0;top:0}\n"] }]
19
19
  }], propDecorators: { info: [{
20
20
  type: Input
21
21
  }], CurrentFilterType: [{
22
22
  type: Input
23
23
  }] } });
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS10aW1lLWZpbHRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXV0aWxpdGllcy9zcmMvdGFibGUtYnVpbGRlci9jb21wb25lbnRzL2RhdGUtdGltZS1maWx0ZXIvZGF0ZS10aW1lLWZpbHRlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXV0aWxpdGllcy9zcmMvdGFibGUtYnVpbGRlci9jb21wb25lbnRzL2RhdGUtdGltZS1maWx0ZXIvZGF0ZS10aW1lLWZpbHRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLHVCQUF1QixFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUxRSxPQUFPLEVBQWMsV0FBVyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLFdBQVcsRUFBRSxNQUFNLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUN2RSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQzs7O0FBYTNELE1BQU0sT0FBTyx1QkFBdUI7SUFDbEMsVUFBVSxHQUFHLFdBQVcsQ0FBQztJQUNoQixJQUFJLENBQWlCO0lBQ3JCLGlCQUFpQixDQUFjO3VHQUg3Qix1QkFBdUI7MkZBQXZCLHVCQUF1QixpSkNqQnBDLDJuQkFRQyw4eUJETUcsV0FBVyxnNEJBSEUsQ0FBQyxFQUFDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxXQUFXLEVBQUUsTUFBTSxFQUFDLENBQUM7OzJGQU10RCx1QkFBdUI7a0JBWG5DLFNBQVM7K0JBQ0UscUJBQXFCLG1CQUVkLHVCQUF1QixDQUFDLE1BQU0saUJBRWhDLENBQUMsRUFBQyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsV0FBVyxFQUFFLE1BQU0sRUFBQyxDQUFDLGNBQ3JELElBQUksV0FDUDt3QkFDUCxXQUFXLEVBQUUscUJBQXFCO3FCQUNuQzs4QkFJUSxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csaUJBQWlCO3NCQUF6QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgUGFydGlhbEZpbHRlciB9IGZyb20gJy4uLy4uL2NsYXNzZXMvZmlsdGVyLWluZm8nO1xyXG5pbXBvcnQgeyBGaWx0ZXJUeXBlLCBGaWx0ZXJUeXBlcyB9IGZyb20gJy4uLy4uL2VudW1zL2ZpbHRlclR5cGVzJztcclxuaW1wb3J0IHsgQ29udHJvbENvbnRhaW5lciwgRm9ybXNNb2R1bGUsIE5nRm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgUHJldmVudEVudGVyRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vLi4vdXRpbGl0aWVzJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAndGItZGF0ZS10aW1lLWZpbHRlcicsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2RhdGUtdGltZS1maWx0ZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gIHN0eWxlVXJsczogWycuLi9maWx0ZXIvZmlsdGVyLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgdmlld1Byb3ZpZGVyczogW3twcm92aWRlOiBDb250cm9sQ29udGFpbmVyLCB1c2VFeGlzdGluZzogTmdGb3JtfV0sXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBGb3Jtc01vZHVsZSwgUHJldmVudEVudGVyRGlyZWN0aXZlXHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgRGF0ZVRpbWVGaWx0ZXJDb21wb25lbnQge1xyXG4gIEZpbHRlclR5cGUgPSBGaWx0ZXJUeXBlcztcclxuICBASW5wdXQoKSBpbmZvITogUGFydGlhbEZpbHRlcjtcclxuICBASW5wdXQoKSBDdXJyZW50RmlsdGVyVHlwZSE6IEZpbHRlclR5cGU7XHJcbn1cclxuIiwiQGlmKEN1cnJlbnRGaWx0ZXJUeXBlICE9PSBGaWx0ZXJUeXBlLkRhdGVUaW1lQmV0d2VlbiAmJiBDdXJyZW50RmlsdGVyVHlwZSAhPT0gRmlsdGVyVHlwZS5Jc051bGwpe1xyXG4gIDxpbnB1dCB0eXBlPVwiZGF0ZXRpbWUtbG9jYWxcIiBbbmdNb2RlbF09XCJpbmZvLmZpbHRlclZhbHVlXCIgcHJldmVudEVudGVyIG5hbWU9XCJmaWx0ZXJWYWx1ZVwiIGNsYXNzPVwib3AtZGF0ZS10aW1lLWlucHV0XCIvPlxyXG59XHJcbkBpZihDdXJyZW50RmlsdGVyVHlwZSA9PT0gRmlsdGVyVHlwZS5EYXRlVGltZUJldHdlZW4pe1xyXG4gIDxuZy1jb250YWluZXIgbmdNb2RlbEdyb3VwPVwiZmlsdGVyVmFsdWVcIj5cclxuICAgIDxpbnB1dCB0eXBlPVwiZGF0ZXRpbWUtbG9jYWxcIiBbbmdNb2RlbF09XCJpbmZvLmZpbHRlclZhbHVlPy5TdGFydFwiIHByZXZlbnRFbnRlciBuYW1lPVwiU3RhcnRcIiBjbGFzcz1cIm9wLWRhdGUtdGltZS1pbnB1dFwiLz5cclxuICAgIDxpbnB1dCB0eXBlPVwiZGF0ZXRpbWUtbG9jYWxcIiBbbmdNb2RlbF09XCJpbmZvLmZpbHRlclZhbHVlPy5FbmRcIiBwcmV2ZW50RW50ZXIgbmFtZT1cIkVuZFwiIGNsYXNzPVwib3AtZGF0ZS10aW1lLWlucHV0XCIvPlxyXG4gIDwvbmctY29udGFpbmVyPlxyXG59Il19
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS10aW1lLWZpbHRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXV0aWxpdGllcy9zcmMvdGFibGUtYnVpbGRlci9jb21wb25lbnRzL2RhdGUtdGltZS1maWx0ZXIvZGF0ZS10aW1lLWZpbHRlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXV0aWxpdGllcy9zcmMvdGFibGUtYnVpbGRlci9jb21wb25lbnRzL2RhdGUtdGltZS1maWx0ZXIvZGF0ZS10aW1lLWZpbHRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLHVCQUF1QixFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUxRSxPQUFPLEVBQWMsV0FBVyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLFdBQVcsRUFBRSxNQUFNLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUN2RSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQzs7O0FBYTNELE1BQU0sT0FBTyx1QkFBdUI7SUFDbEMsVUFBVSxHQUFHLFdBQVcsQ0FBQztJQUNoQixJQUFJLENBQWlCO0lBQ3JCLGlCQUFpQixDQUFjO3VHQUg3Qix1QkFBdUI7MkZBQXZCLHVCQUF1QixpSkNqQnBDLDJuQkFRQywrekJETUcsV0FBVyxnNEJBSEUsQ0FBQyxFQUFDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxXQUFXLEVBQUUsTUFBTSxFQUFDLENBQUM7OzJGQU10RCx1QkFBdUI7a0JBWG5DLFNBQVM7K0JBQ0UscUJBQXFCLG1CQUVkLHVCQUF1QixDQUFDLE1BQU0saUJBRWhDLENBQUMsRUFBQyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsV0FBVyxFQUFFLE1BQU0sRUFBQyxDQUFDLGNBQ3JELElBQUksV0FDUDt3QkFDUCxXQUFXLEVBQUUscUJBQXFCO3FCQUNuQzs4QkFJUSxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csaUJBQWlCO3NCQUF6QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgUGFydGlhbEZpbHRlciB9IGZyb20gJy4uLy4uL2NsYXNzZXMvZmlsdGVyLWluZm8nO1xyXG5pbXBvcnQgeyBGaWx0ZXJUeXBlLCBGaWx0ZXJUeXBlcyB9IGZyb20gJy4uLy4uL2VudW1zL2ZpbHRlclR5cGVzJztcclxuaW1wb3J0IHsgQ29udHJvbENvbnRhaW5lciwgRm9ybXNNb2R1bGUsIE5nRm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgUHJldmVudEVudGVyRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vLi4vdXRpbGl0aWVzJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAndGItZGF0ZS10aW1lLWZpbHRlcicsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2RhdGUtdGltZS1maWx0ZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gIHN0eWxlVXJsczogWycuLi9maWx0ZXIvZmlsdGVyLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgdmlld1Byb3ZpZGVyczogW3twcm92aWRlOiBDb250cm9sQ29udGFpbmVyLCB1c2VFeGlzdGluZzogTmdGb3JtfV0sXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBGb3Jtc01vZHVsZSwgUHJldmVudEVudGVyRGlyZWN0aXZlXHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgRGF0ZVRpbWVGaWx0ZXJDb21wb25lbnQge1xyXG4gIEZpbHRlclR5cGUgPSBGaWx0ZXJUeXBlcztcclxuICBASW5wdXQoKSBpbmZvITogUGFydGlhbEZpbHRlcjtcclxuICBASW5wdXQoKSBDdXJyZW50RmlsdGVyVHlwZSE6IEZpbHRlclR5cGU7XHJcbn1cclxuIiwiQGlmKEN1cnJlbnRGaWx0ZXJUeXBlICE9PSBGaWx0ZXJUeXBlLkRhdGVUaW1lQmV0d2VlbiAmJiBDdXJyZW50RmlsdGVyVHlwZSAhPT0gRmlsdGVyVHlwZS5Jc051bGwpe1xyXG4gIDxpbnB1dCB0eXBlPVwiZGF0ZXRpbWUtbG9jYWxcIiBbbmdNb2RlbF09XCJpbmZvLmZpbHRlclZhbHVlXCIgcHJldmVudEVudGVyIG5hbWU9XCJmaWx0ZXJWYWx1ZVwiIGNsYXNzPVwib3AtZGF0ZS10aW1lLWlucHV0XCIvPlxyXG59XHJcbkBpZihDdXJyZW50RmlsdGVyVHlwZSA9PT0gRmlsdGVyVHlwZS5EYXRlVGltZUJldHdlZW4pe1xyXG4gIDxuZy1jb250YWluZXIgbmdNb2RlbEdyb3VwPVwiZmlsdGVyVmFsdWVcIj5cclxuICAgIDxpbnB1dCB0eXBlPVwiZGF0ZXRpbWUtbG9jYWxcIiBbbmdNb2RlbF09XCJpbmZvLmZpbHRlclZhbHVlPy5TdGFydFwiIHByZXZlbnRFbnRlciBuYW1lPVwiU3RhcnRcIiBjbGFzcz1cIm9wLWRhdGUtdGltZS1pbnB1dFwiLz5cclxuICAgIDxpbnB1dCB0eXBlPVwiZGF0ZXRpbWUtbG9jYWxcIiBbbmdNb2RlbF09XCJpbmZvLmZpbHRlclZhbHVlPy5FbmRcIiBwcmV2ZW50RW50ZXIgbmFtZT1cIkVuZFwiIGNsYXNzPVwib3AtZGF0ZS10aW1lLWlucHV0XCIvPlxyXG4gIDwvbmctY29udGFpbmVyPlxyXG59Il19