@datarailsshared/datarailsshared 1.6.187 → 1.6.189

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 (36) hide show
  1. package/datarailsshared-datarailsshared-1.6.189.tgz +0 -0
  2. package/esm2022/lib/dr-avatar/dr-avatar.component.mjs +1 -1
  3. package/esm2022/lib/dr-dropdown/dr-dropdown.directive.mjs +1 -1
  4. package/esm2022/lib/dr-error/dr-error.component.mjs +1 -1
  5. package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.mjs +2 -3
  6. package/esm2022/lib/dr-inputs/dr-select/dr-select.component.mjs +2 -2
  7. package/esm2022/lib/dr-list-overflow/dr-list-overflow.component.mjs +130 -0
  8. package/esm2022/lib/dr-popover/dr-popover.directive.mjs +1 -1
  9. package/esm2022/lib/dr-tooltip/dr-tooltip.directive.mjs +1 -1
  10. package/esm2022/lib/filter-dropdown/filter-dropdown.component.mjs +198 -173
  11. package/esm2022/lib/models/constants.mjs +1 -1
  12. package/esm2022/lib/models/dropdown.mjs +1 -1
  13. package/esm2022/lib/models/popover.mjs +1 -1
  14. package/esm2022/lib/models/position.mjs +2 -0
  15. package/esm2022/lib/text-overflow/text-overflow.component.mjs +7 -4
  16. package/esm2022/public-api.mjs +2 -2
  17. package/fesm2022/datarailsshared-datarailsshared.mjs +456 -323
  18. package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
  19. package/lib/dr-avatar/dr-avatar.component.d.ts +2 -2
  20. package/lib/dr-dropdown/dr-dropdown.directive.d.ts +3 -2
  21. package/lib/dr-error/dr-error.component.d.ts +2 -1
  22. package/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.d.ts +2 -1
  23. package/lib/dr-list-overflow/dr-list-overflow.component.d.ts +26 -0
  24. package/lib/dr-popover/dr-popover.directive.d.ts +2 -2
  25. package/lib/dr-tooltip/dr-tooltip.directive.d.ts +3 -2
  26. package/lib/filter-dropdown/filter-dropdown.component.d.ts +4 -4
  27. package/lib/models/constants.d.ts +3 -86
  28. package/lib/models/dropdown.d.ts +2 -2
  29. package/lib/models/popover.d.ts +2 -2
  30. package/lib/models/position.d.ts +1 -0
  31. package/lib/text-overflow/text-overflow.component.d.ts +3 -1
  32. package/package.json +1 -1
  33. package/public-api.d.ts +3 -2
  34. package/datarailsshared-datarailsshared-1.6.187.tgz +0 -0
  35. package/esm2022/lib/dr-tooltip/enums/tooltip-position.enum.mjs +0 -16
  36. package/lib/dr-tooltip/enums/tooltip-position.enum.d.ts +0 -14
@@ -139,4 +139,4 @@ export class DrAvatarComponent {
139
139
  }], userClicked: [{
140
140
  type: Output
141
141
  }] }); })();
142
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItYXZhdGFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWF2YXRhci9kci1hdmF0YXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZHItYXZhdGFyL2RyLWF2YXRhci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM3RyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sOEJBQThCLENBQUM7Ozs7OztJQ0QvRCx5QkFJZ0Q7OztJQUQ1QyxvREFBb0MsdUNBQUE7Ozs7O0lBR3hDLDhCQWN3RDtJQUFwRCwySkFBUyw2Q0FBdUIseUJBQWtCLENBQUEsSUFBQzs7SUFDbkQsWUFDSjs7SUFBQSxpQkFBTTs7OztJQWJGLDZCQUFxQjtJQUNyQixvREFBb0MsdUNBQUEsb0RBQUE7SUFHcEMsMEhBR0UsNkNBQUEsK0NBQUEscURBQUE7SUFLRixlQUNKO0lBREksNEVBQ0o7OztJQUVBLDhCQUltQztJQUMvQixZQUNKO0lBQUEsaUJBQU07Ozs7SUFIRiwrQkFBMkIsK0JBQUE7SUFFM0IsZUFDSjtJQURJLCtEQUNKOzs7O0lBR0ksOEJBQW9FLGFBQUE7SUFJNUQsNEtBQVMsZUFBQSwwQkFBa0IsQ0FBQSxJQUFDO0lBRTVCLFlBQ0o7O0lBQUEsaUJBQU07SUFDTixnQ0FBdUI7SUFDbkIsWUFDSjs7SUFBQSxpQkFBTyxFQUFBOzs7O0lBTEgsZUFBb0I7SUFBcEIsNEJBQW9CO0lBRnBCLGtFQUErQztJQUcvQyxlQUNKO0lBREksMEVBQ0o7SUFFSSxlQUNKO0lBREksOERBQ0o7OztJQVZKLGlGQVdNOzs7SUFYZ0IsK0NBQWlCOztBRDVCM0MsTUFBTSxhQUFhLEdBQUcsQ0FBQyxDQUFDO0FBUXhCLE1BQU0sT0FBTyxpQkFBaUI7SUFOOUI7UUFtQmEsbUJBQWMsR0FBRyxLQUFLLENBQUM7UUFDdkIsNEJBQXVCLEdBQWUsUUFBUSxDQUFDO1FBRy9DLHdCQUFtQixHQUFHLElBQUksQ0FBQztRQUlwQyxZQUFPLEdBQUcsS0FBSyxDQUFDO1FBRU4sZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO1FBQ2pELGdCQUFXLEdBQVEsRUFBRSxDQUFDO1FBRWIsa0JBQWEsR0FBRyxhQUFhLENBQUM7S0FnQjFDO0lBekNHLElBQ0ksS0FBSyxDQUFDLEtBQWlDO1FBQ3ZDLElBQUksS0FBSyxFQUFFO1lBQ1AsSUFBSSxDQUFDLFdBQVcsR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDMUQsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLEVBQUU7Z0JBQ3JDLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFO29CQUNuQixJQUFJLENBQUMsV0FBVyxHQUFHLGVBQWUsQ0FBQyxvQkFBb0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztpQkFDbEU7WUFDTCxDQUFDLENBQUMsQ0FBQztTQUNOO0lBQ0wsQ0FBQztJQWlCRCxhQUFhO1FBQ1QsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsYUFBYSxDQUFDLENBQUM7SUFDcEQsQ0FBQztJQUVELFlBQVk7UUFDUixJQUFJLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxHQUFHLGFBQWEsRUFBRTtZQUN6QyxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1NBQ3pFO1FBQ0QsT0FBTyxFQUFFLENBQUM7SUFDZCxDQUFDO0lBRU0sY0FBYyxDQUFDLElBQU87UUFDekIsT0FBTyxlQUFlLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxlQUFlLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQzdGLENBQUM7cUdBekNRLGlCQUFpQjttR0FBakIsaUJBQWlCOzs7WUNiOUIsa0VBSWdEO1lBRWhELG1FQWdCTTtZQUVOLGtFQU1NO1lBRU4sbUhBYWM7O1lBNUNULDhDQUF5QjtZQU1ULGVBQWtCO1lBQWxCLDZDQUFrQjtZQWtCbEMsZUFBd0M7WUFBeEMsaUVBQXdDOzs7dUZEWmhDLGlCQUFpQjtjQU43QixTQUFTOzJCQUNJLFdBQVcsbUJBR0osdUJBQXVCLENBQUMsTUFBTTtnQkFJM0MsS0FBSztrQkFEUixLQUFLO1lBWUcsY0FBYztrQkFBdEIsS0FBSztZQUNHLHVCQUF1QjtrQkFBL0IsS0FBSztZQUNHLG9CQUFvQjtrQkFBNUIsS0FBSztZQUNHLFlBQVk7a0JBQXBCLEtBQUs7WUFDRyxtQkFBbUI7a0JBQTNCLEtBQUs7WUFJTixPQUFPO2tCQUZOLFdBQVc7bUJBQUMsZUFBZTs7a0JBQzNCLEtBQUs7WUFHSSxXQUFXO2tCQUFwQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBIb3N0QmluZGluZywgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRHJBdmF0YXJTZXJ2aWNlIH0gZnJvbSAnLi9zZXJ2aWNlcy9kci1hdmF0YXIuc2VydmljZSc7XG5pbXBvcnQgeyBBdmF0YXJVc2VyIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBFbFBvc2l0aW9uIH0gZnJvbSAnLi4vbW9kZWxzL2Ryb3Bkb3duJztcblxuY29uc3QgVVNFUlNfVE9fU0hPVyA9IDI7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZHItYXZhdGFyJyxcbiAgICB0ZW1wbGF0ZVVybDogJ2RyLWF2YXRhci5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJ2RyLWF2YXRhci5jb21wb25lbnQuc2NzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBEckF2YXRhckNvbXBvbmVudDxUIGV4dGVuZHMgQXZhdGFyVXNlciA9IEF2YXRhclVzZXI+IHtcbiAgICBASW5wdXQoKVxuICAgIHNldCB1c2Vycyh1c2VyczogVFtdIHwgVCB8IG51bGwgfCB1bmRlZmluZWQpIHtcbiAgICAgICAgaWYgKHVzZXJzKSB7XG4gICAgICAgICAgICB0aGlzLnBhcnNlZFVzZXJzID0gQXJyYXkuaXNBcnJheSh1c2VycykgPyB1c2VycyA6IFt1c2Vyc107XG4gICAgICAgICAgICB0aGlzLnBhcnNlZFVzZXJzLmZvckVhY2goKHVzZXIsIGluZGV4KSA9PiB7XG4gICAgICAgICAgICAgICAgaWYgKCF1c2VyLmNvbG9yTnVtYmVyKSB7XG4gICAgICAgICAgICAgICAgICAgIHVzZXIuY29sb3JOdW1iZXIgPSBEckF2YXRhclNlcnZpY2UuZ2V0QXZhdGFyQ29sb3JOdW1iZXIoaW5kZXgpO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH0pO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgQElucHV0KCkgc2hvd1VuYXNzaWduZWQgPSBmYWxzZTtcbiAgICBASW5wdXQoKSBkckF2YXRhclRvb2x0aXBQb3NpdGlvbjogRWxQb3NpdGlvbiA9ICdib3R0b20nO1xuICAgIEBJbnB1dCgpIGRyQXZhdGFyVG9vbHRpcENsYXNzOiBzdHJpbmc7XG4gICAgQElucHV0KCkgZHJBdmF0YXJTaXplOiBzdHJpbmc7XG4gICAgQElucHV0KCkgZHJBdmF0YXJJc0NsaWNrYWJsZSA9IHRydWU7XG5cbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzLmNvbXBhY3QnKVxuICAgIEBJbnB1dCgpXG4gICAgY29tcGFjdCA9IGZhbHNlO1xuXG4gICAgQE91dHB1dCgpIHVzZXJDbGlja2VkID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICAgIHBhcnNlZFVzZXJzOiBUW10gPSBbXTtcblxuICAgIHJlYWRvbmx5IFVTRVJTX1RPX1NIT1cgPSBVU0VSU19UT19TSE9XO1xuXG4gICAgZ2V0Rmlyc3RVc2VycygpOiBUW10ge1xuICAgICAgICByZXR1cm4gdGhpcy5wYXJzZWRVc2Vycy5zbGljZSgwLCBVU0VSU19UT19TSE9XKTtcbiAgICB9XG5cbiAgICBnZXRMYXN0VXNlcnMoKTogVFtdIHtcbiAgICAgICAgaWYgKHRoaXMucGFyc2VkVXNlcnMubGVuZ3RoID4gVVNFUlNfVE9fU0hPVykge1xuICAgICAgICAgICAgcmV0dXJuIHRoaXMucGFyc2VkVXNlcnMuc2xpY2UoVVNFUlNfVE9fU0hPVywgdGhpcy5wYXJzZWRVc2Vycy5sZW5ndGgpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiBbXTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0QXZhdGFyQ29sb3IodXNlcjogVCk6IHN0cmluZyB7XG4gICAgICAgIHJldHVybiBEckF2YXRhclNlcnZpY2UuYXZhdGFyQ29sb3JzW3VzZXIuY29sb3JOdW1iZXJdIHx8IERyQXZhdGFyU2VydmljZS5hdmF0YXJDb2xvcnNbMF07XG4gICAgfVxufVxuIiwiPGRpdlxuICAgICpuZ0lmPVwiIXBhcnNlZFVzZXJzLmxlbmd0aFwiXG4gICAgY2xhc3M9XCJ1c2Vycy1zZWN0aW9uX19kZWZhdWx0XCJcbiAgICBbc3R5bGUud2lkdGhdPVwiZHJBdmF0YXJTaXplIHx8IG51bGxcIlxuICAgIFtzdHlsZS5oZWlnaHRdPVwiZHJBdmF0YXJTaXplIHx8IG51bGxcIj48L2Rpdj5cblxuPGRpdlxuICAgICpuZ0Zvcj1cImxldCB1c2VyIG9mIGdldEZpcnN0VXNlcnMoKVwiXG4gICAgY2xhc3M9XCJ1c2Vycy1zZWN0aW9uX191c2VyXCJcbiAgICBbY2xhc3NdPVwidXNlci5zdGF0dXNcIlxuICAgIFtzdHlsZS53aWR0aF09XCJkckF2YXRhclNpemUgfHwgbnVsbFwiXG4gICAgW3N0eWxlLmhlaWdodF09XCJkckF2YXRhclNpemUgfHwgbnVsbFwiXG4gICAgW3N0eWxlLmJhY2tncm91bmQtY29sb3JdPVwiZ2V0QXZhdGFyQ29sb3IodXNlcilcIlxuICAgIFtuZ0NsYXNzXT1cIntcbiAgICAgICAgJ3VzZXJzLXNlY3Rpb25fX2RlZmF1bHQnOiBzaG93VW5hc3NpZ25lZCAmJiAhdXNlci5lbWFpbCxcbiAgICAgICAgJ3VzZXJzLXNlY3Rpb25fX3VzZXItLWNsaWNrYWJsZSc6IGRyQXZhdGFySXNDbGlja2FibGUsXG4gICAgfVwiXG4gICAgW2RyVG9vbHRpcF09XCJ1c2VyIHwgZHJBdmF0YXJcIlxuICAgIFtkclRvb2x0aXBDbGFzc109XCJkckF2YXRhclRvb2x0aXBDbGFzc1wiXG4gICAgW2RyVG9vbHRpcFBvc2l0aW9uXT1cImRyQXZhdGFyVG9vbHRpcFBvc2l0aW9uXCJcbiAgICAoY2xpY2spPVwiZHJBdmF0YXJJc0NsaWNrYWJsZSAmJiB1c2VyQ2xpY2tlZC5lbWl0KClcIj5cbiAgICB7eyB1c2VyIHwgZHJBdmF0YXI6ICdpbml0aWFscycgfX1cbjwvZGl2PlxuXG48ZGl2XG4gICAgKm5nSWY9XCJwYXJzZWRVc2Vycy5sZW5ndGggPiBVU0VSU19UT19TSE9XXCJcbiAgICBjbGFzcz1cInVzZXJzLXNlY3Rpb25fX3VzZXIgdXNlcnMtc2VjdGlvbl9fdXNlci1tb3JlIGljb24tMlwiXG4gICAgW2RyVG9vbHRpcF09XCJ1c2Vyc1RlbXBsYXRlXCJcbiAgICBbZHJUb29sdGlwUG9zaXRpb25dPVwiJ2JvdHRvbSdcIj5cbiAgICAre3sgZ2V0TGFzdFVzZXJzKCkubGVuZ3RoIH19XG48L2Rpdj5cblxuPG5nLXRlbXBsYXRlICN1c2Vyc1RlbXBsYXRlPlxuICAgIDxkaXYgKm5nRm9yPVwibGV0IHVzZXIgb2YgZ2V0TGFzdFVzZXJzKClcIiBjbGFzcz1cInVzZXJzLXBvcG92ZXItaXRlbVwiPlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgICBjbGFzcz1cInVzZXJzLXNlY3Rpb25fX3VzZXJcIlxuICAgICAgICAgICAgW3N0eWxlLmJhY2tncm91bmQtY29sb3JdPVwiZ2V0QXZhdGFyQ29sb3IodXNlcilcIlxuICAgICAgICAgICAgKGNsaWNrKT1cInVzZXJDbGlja2VkLmVtaXQoKVwiXG4gICAgICAgICAgICBbY2xhc3NdPVwidXNlci5jbGFzc1wiPlxuICAgICAgICAgICAge3sgdXNlciB8IGRyQXZhdGFyOiAnaW5pdGlhbHMnIH19XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8c3BhbiBjbGFzcz1cInVzZXJuYW1lXCI+XG4gICAgICAgICAgICB7eyB1c2VyIHwgZHJBdmF0YXIgfX1cbiAgICAgICAgPC9zcGFuPlxuICAgIDwvZGl2PlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
142
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItYXZhdGFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWF2YXRhci9kci1hdmF0YXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZHItYXZhdGFyL2RyLWF2YXRhci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM3RyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sOEJBQThCLENBQUM7Ozs7OztJQ0QvRCx5QkFJZ0Q7OztJQUQ1QyxvREFBb0MsdUNBQUE7Ozs7O0lBR3hDLDhCQWN3RDtJQUFwRCwySkFBUyw2Q0FBdUIseUJBQWtCLENBQUEsSUFBQzs7SUFDbkQsWUFDSjs7SUFBQSxpQkFBTTs7OztJQWJGLDZCQUFxQjtJQUNyQixvREFBb0MsdUNBQUEsb0RBQUE7SUFHcEMsMEhBR0UsNkNBQUEsK0NBQUEscURBQUE7SUFLRixlQUNKO0lBREksNEVBQ0o7OztJQUVBLDhCQUltQztJQUMvQixZQUNKO0lBQUEsaUJBQU07Ozs7SUFIRiwrQkFBMkIsK0JBQUE7SUFFM0IsZUFDSjtJQURJLCtEQUNKOzs7O0lBR0ksOEJBQW9FLGFBQUE7SUFJNUQsNEtBQVMsZUFBQSwwQkFBa0IsQ0FBQSxJQUFDO0lBRTVCLFlBQ0o7O0lBQUEsaUJBQU07SUFDTixnQ0FBdUI7SUFDbkIsWUFDSjs7SUFBQSxpQkFBTyxFQUFBOzs7O0lBTEgsZUFBb0I7SUFBcEIsNEJBQW9CO0lBRnBCLGtFQUErQztJQUcvQyxlQUNKO0lBREksMEVBQ0o7SUFFSSxlQUNKO0lBREksOERBQ0o7OztJQVZKLGlGQVdNOzs7SUFYZ0IsK0NBQWlCOztBRDVCM0MsTUFBTSxhQUFhLEdBQUcsQ0FBQyxDQUFDO0FBUXhCLE1BQU0sT0FBTyxpQkFBaUI7SUFOOUI7UUFtQmEsbUJBQWMsR0FBRyxLQUFLLENBQUM7UUFDdkIsNEJBQXVCLEdBQWEsUUFBUSxDQUFDO1FBRzdDLHdCQUFtQixHQUFHLElBQUksQ0FBQztRQUlwQyxZQUFPLEdBQUcsS0FBSyxDQUFDO1FBRU4sZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO1FBQ2pELGdCQUFXLEdBQVEsRUFBRSxDQUFDO1FBRWIsa0JBQWEsR0FBRyxhQUFhLENBQUM7S0FnQjFDO0lBekNHLElBQ0ksS0FBSyxDQUFDLEtBQWlDO1FBQ3ZDLElBQUksS0FBSyxFQUFFO1lBQ1AsSUFBSSxDQUFDLFdBQVcsR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDMUQsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLEVBQUU7Z0JBQ3JDLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFO29CQUNuQixJQUFJLENBQUMsV0FBVyxHQUFHLGVBQWUsQ0FBQyxvQkFBb0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztpQkFDbEU7WUFDTCxDQUFDLENBQUMsQ0FBQztTQUNOO0lBQ0wsQ0FBQztJQWlCRCxhQUFhO1FBQ1QsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsYUFBYSxDQUFDLENBQUM7SUFDcEQsQ0FBQztJQUVELFlBQVk7UUFDUixJQUFJLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxHQUFHLGFBQWEsRUFBRTtZQUN6QyxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1NBQ3pFO1FBQ0QsT0FBTyxFQUFFLENBQUM7SUFDZCxDQUFDO0lBRU0sY0FBYyxDQUFDLElBQU87UUFDekIsT0FBTyxlQUFlLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxlQUFlLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQzdGLENBQUM7cUdBekNRLGlCQUFpQjttR0FBakIsaUJBQWlCOzs7WUNiOUIsa0VBSWdEO1lBRWhELG1FQWdCTTtZQUVOLGtFQU1NO1lBRU4sbUhBYWM7O1lBNUNULDhDQUF5QjtZQU1ULGVBQWtCO1lBQWxCLDZDQUFrQjtZQWtCbEMsZUFBd0M7WUFBeEMsaUVBQXdDOzs7dUZEWmhDLGlCQUFpQjtjQU43QixTQUFTOzJCQUNJLFdBQVcsbUJBR0osdUJBQXVCLENBQUMsTUFBTTtnQkFJM0MsS0FBSztrQkFEUixLQUFLO1lBWUcsY0FBYztrQkFBdEIsS0FBSztZQUNHLHVCQUF1QjtrQkFBL0IsS0FBSztZQUNHLG9CQUFvQjtrQkFBNUIsS0FBSztZQUNHLFlBQVk7a0JBQXBCLEtBQUs7WUFDRyxtQkFBbUI7a0JBQTNCLEtBQUs7WUFJTixPQUFPO2tCQUZOLFdBQVc7bUJBQUMsZUFBZTs7a0JBQzNCLEtBQUs7WUFHSSxXQUFXO2tCQUFwQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBIb3N0QmluZGluZywgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRHJBdmF0YXJTZXJ2aWNlIH0gZnJvbSAnLi9zZXJ2aWNlcy9kci1hdmF0YXIuc2VydmljZSc7XG5pbXBvcnQgeyBBdmF0YXJVc2VyIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBQb3NpdGlvbiB9IGZyb20gJy4uL21vZGVscy9wb3NpdGlvbic7XG5cbmNvbnN0IFVTRVJTX1RPX1NIT1cgPSAyO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2RyLWF2YXRhcicsXG4gICAgdGVtcGxhdGVVcmw6ICdkci1hdmF0YXIuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWydkci1hdmF0YXIuY29tcG9uZW50LnNjc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgRHJBdmF0YXJDb21wb25lbnQ8VCBleHRlbmRzIEF2YXRhclVzZXIgPSBBdmF0YXJVc2VyPiB7XG4gICAgQElucHV0KClcbiAgICBzZXQgdXNlcnModXNlcnM6IFRbXSB8IFQgfCBudWxsIHwgdW5kZWZpbmVkKSB7XG4gICAgICAgIGlmICh1c2Vycykge1xuICAgICAgICAgICAgdGhpcy5wYXJzZWRVc2VycyA9IEFycmF5LmlzQXJyYXkodXNlcnMpID8gdXNlcnMgOiBbdXNlcnNdO1xuICAgICAgICAgICAgdGhpcy5wYXJzZWRVc2Vycy5mb3JFYWNoKCh1c2VyLCBpbmRleCkgPT4ge1xuICAgICAgICAgICAgICAgIGlmICghdXNlci5jb2xvck51bWJlcikge1xuICAgICAgICAgICAgICAgICAgICB1c2VyLmNvbG9yTnVtYmVyID0gRHJBdmF0YXJTZXJ2aWNlLmdldEF2YXRhckNvbG9yTnVtYmVyKGluZGV4KTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIEBJbnB1dCgpIHNob3dVbmFzc2lnbmVkID0gZmFsc2U7XG4gICAgQElucHV0KCkgZHJBdmF0YXJUb29sdGlwUG9zaXRpb246IFBvc2l0aW9uID0gJ2JvdHRvbSc7XG4gICAgQElucHV0KCkgZHJBdmF0YXJUb29sdGlwQ2xhc3M6IHN0cmluZztcbiAgICBASW5wdXQoKSBkckF2YXRhclNpemU6IHN0cmluZztcbiAgICBASW5wdXQoKSBkckF2YXRhcklzQ2xpY2thYmxlID0gdHJ1ZTtcblxuICAgIEBIb3N0QmluZGluZygnY2xhc3MuY29tcGFjdCcpXG4gICAgQElucHV0KClcbiAgICBjb21wYWN0ID0gZmFsc2U7XG5cbiAgICBAT3V0cHV0KCkgdXNlckNsaWNrZWQgPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG4gICAgcGFyc2VkVXNlcnM6IFRbXSA9IFtdO1xuXG4gICAgcmVhZG9ubHkgVVNFUlNfVE9fU0hPVyA9IFVTRVJTX1RPX1NIT1c7XG5cbiAgICBnZXRGaXJzdFVzZXJzKCk6IFRbXSB7XG4gICAgICAgIHJldHVybiB0aGlzLnBhcnNlZFVzZXJzLnNsaWNlKDAsIFVTRVJTX1RPX1NIT1cpO1xuICAgIH1cblxuICAgIGdldExhc3RVc2VycygpOiBUW10ge1xuICAgICAgICBpZiAodGhpcy5wYXJzZWRVc2Vycy5sZW5ndGggPiBVU0VSU19UT19TSE9XKSB7XG4gICAgICAgICAgICByZXR1cm4gdGhpcy5wYXJzZWRVc2Vycy5zbGljZShVU0VSU19UT19TSE9XLCB0aGlzLnBhcnNlZFVzZXJzLmxlbmd0aCk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIFtdO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXRBdmF0YXJDb2xvcih1c2VyOiBUKTogc3RyaW5nIHtcbiAgICAgICAgcmV0dXJuIERyQXZhdGFyU2VydmljZS5hdmF0YXJDb2xvcnNbdXNlci5jb2xvck51bWJlcl0gfHwgRHJBdmF0YXJTZXJ2aWNlLmF2YXRhckNvbG9yc1swXTtcbiAgICB9XG59XG4iLCI8ZGl2XG4gICAgKm5nSWY9XCIhcGFyc2VkVXNlcnMubGVuZ3RoXCJcbiAgICBjbGFzcz1cInVzZXJzLXNlY3Rpb25fX2RlZmF1bHRcIlxuICAgIFtzdHlsZS53aWR0aF09XCJkckF2YXRhclNpemUgfHwgbnVsbFwiXG4gICAgW3N0eWxlLmhlaWdodF09XCJkckF2YXRhclNpemUgfHwgbnVsbFwiPjwvZGl2PlxuXG48ZGl2XG4gICAgKm5nRm9yPVwibGV0IHVzZXIgb2YgZ2V0Rmlyc3RVc2VycygpXCJcbiAgICBjbGFzcz1cInVzZXJzLXNlY3Rpb25fX3VzZXJcIlxuICAgIFtjbGFzc109XCJ1c2VyLnN0YXR1c1wiXG4gICAgW3N0eWxlLndpZHRoXT1cImRyQXZhdGFyU2l6ZSB8fCBudWxsXCJcbiAgICBbc3R5bGUuaGVpZ2h0XT1cImRyQXZhdGFyU2l6ZSB8fCBudWxsXCJcbiAgICBbc3R5bGUuYmFja2dyb3VuZC1jb2xvcl09XCJnZXRBdmF0YXJDb2xvcih1c2VyKVwiXG4gICAgW25nQ2xhc3NdPVwie1xuICAgICAgICAndXNlcnMtc2VjdGlvbl9fZGVmYXVsdCc6IHNob3dVbmFzc2lnbmVkICYmICF1c2VyLmVtYWlsLFxuICAgICAgICAndXNlcnMtc2VjdGlvbl9fdXNlci0tY2xpY2thYmxlJzogZHJBdmF0YXJJc0NsaWNrYWJsZSxcbiAgICB9XCJcbiAgICBbZHJUb29sdGlwXT1cInVzZXIgfCBkckF2YXRhclwiXG4gICAgW2RyVG9vbHRpcENsYXNzXT1cImRyQXZhdGFyVG9vbHRpcENsYXNzXCJcbiAgICBbZHJUb29sdGlwUG9zaXRpb25dPVwiZHJBdmF0YXJUb29sdGlwUG9zaXRpb25cIlxuICAgIChjbGljayk9XCJkckF2YXRhcklzQ2xpY2thYmxlICYmIHVzZXJDbGlja2VkLmVtaXQoKVwiPlxuICAgIHt7IHVzZXIgfCBkckF2YXRhcjogJ2luaXRpYWxzJyB9fVxuPC9kaXY+XG5cbjxkaXZcbiAgICAqbmdJZj1cInBhcnNlZFVzZXJzLmxlbmd0aCA+IFVTRVJTX1RPX1NIT1dcIlxuICAgIGNsYXNzPVwidXNlcnMtc2VjdGlvbl9fdXNlciB1c2Vycy1zZWN0aW9uX191c2VyLW1vcmUgaWNvbi0yXCJcbiAgICBbZHJUb29sdGlwXT1cInVzZXJzVGVtcGxhdGVcIlxuICAgIFtkclRvb2x0aXBQb3NpdGlvbl09XCInYm90dG9tJ1wiPlxuICAgICt7eyBnZXRMYXN0VXNlcnMoKS5sZW5ndGggfX1cbjwvZGl2PlxuXG48bmctdGVtcGxhdGUgI3VzZXJzVGVtcGxhdGU+XG4gICAgPGRpdiAqbmdGb3I9XCJsZXQgdXNlciBvZiBnZXRMYXN0VXNlcnMoKVwiIGNsYXNzPVwidXNlcnMtcG9wb3Zlci1pdGVtXCI+XG4gICAgICAgIDxkaXZcbiAgICAgICAgICAgIGNsYXNzPVwidXNlcnMtc2VjdGlvbl9fdXNlclwiXG4gICAgICAgICAgICBbc3R5bGUuYmFja2dyb3VuZC1jb2xvcl09XCJnZXRBdmF0YXJDb2xvcih1c2VyKVwiXG4gICAgICAgICAgICAoY2xpY2spPVwidXNlckNsaWNrZWQuZW1pdCgpXCJcbiAgICAgICAgICAgIFtjbGFzc109XCJ1c2VyLmNsYXNzXCI+XG4gICAgICAgICAgICB7eyB1c2VyIHwgZHJBdmF0YXI6ICdpbml0aWFscycgfX1cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxzcGFuIGNsYXNzPVwidXNlcm5hbWVcIj5cbiAgICAgICAgICAgIHt7IHVzZXIgfCBkckF2YXRhciB9fVxuICAgICAgICA8L3NwYW4+XG4gICAgPC9kaXY+XG48L25nLXRlbXBsYXRlPlxuIl19
@@ -145,4 +145,4 @@ export class DrDropdownChildDirective {
145
145
  selector: '[drDropdownChild]',
146
146
  }]
147
147
  }], null, null); })();
148
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown.directive.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, EventEmitter, HostListener, inject, Injector, Input, OnDestroy, Output } from '@angular/core';\nimport { ElPosition, IDropdownAction, IDropdownItem } from '../models/dropdown';\nimport { DrDropdownService, DropdownInstanceService } from './dr-dropdown.service';\nimport { DrDropdownComponent } from './dr-dropdown.component';\nimport { DrPopoverRef } from '../models/popover';\n\n@Directive({\n    selector: '[drDropdown]',\n    providers: [\n        {\n            provide: DropdownInstanceService,\n            useFactory: (injector: Injector) => {\n                const service = injector.get(DropdownInstanceService, null, { skipSelf: true });\n                return service ?? new DropdownInstanceService(injector);\n            },\n            deps: [Injector],\n        },\n    ],\n})\nexport class DrDropdownDirective<T> implements OnDestroy {\n    private readonly elementRef = inject(ElementRef<HTMLElement>);\n    private readonly service = inject(DrDropdownService);\n    private readonly child = inject(DrDropdownChildDirective, { optional: true, self: true });\n    private readonly dropdownInstanceService = inject(DropdownInstanceService);\n\n    @Input({ required: true })\n    drDropdown: IDropdownItem<T>[];\n    @Input()\n    drDropdownPosition: ElPosition = 'left-top';\n    @Input()\n    drDropdownClass: string;\n    @Input()\n    drDropdownInHover: boolean;\n    @Input({ alias: 'data-analytics' })\n    dataAnalytics: string;\n\n    @Input() drDropdownPositionOffsetX: number;\n\n    @Input() drDropdownPositionOffsetY: number;\n\n    @Output()\n    drDropdownAction = new EventEmitter<IDropdownAction<T>>();\n    @Output('drDropdownClose') dropdownClosed = new EventEmitter<void>();\n    @Output('drDropdownOpened') dropdownOpened = new EventEmitter<void>();\n\n    private ref: DrPopoverRef<DrDropdownComponent>;\n\n    private readonly mouseleaveTimeout = 200;\n\n    @HostListener('mouseenter')\n    elementHover() {\n        if (!this.drDropdownInHover) return;\n        this.openDropdown();\n    }\n\n    @HostListener('click')\n    elementClick() {\n        this.openDropdown();\n    }\n\n    @HostListener('mouseleave')\n    leaveDropdownTriggerElement() {\n        if (this.drDropdownInHover) {\n            setTimeout(() => {\n                if (this.ref && !this.ref.instance.wasHovered) {\n                    this.close();\n                }\n            }, this.mouseleaveTimeout);\n        }\n    }\n\n    @HostListener('document:mouseup')\n    documentClick() {\n        this.close();\n    }\n\n    private openDropdown(): void {\n        if (!this.drDropdown?.length) {\n            return;\n        }\n\n        if (this.ref) {\n            this.close();\n            return;\n        }\n\n        this.ref = this.service.open({\n            hostRef: this.elementRef,\n            position: this.drDropdownPosition,\n            asChild: !!this.child,\n            providers: [{ provide: DropdownInstanceService, useValue: this.dropdownInstanceService }],\n            action$: this.drDropdownAction,\n            positionOffsetX: this.drDropdownPositionOffsetX,\n            positionOffsetY: this.drDropdownPositionOffsetY,\n            options: {\n                drDropdownInHover: this.drDropdownInHover,\n                position: this.drDropdownPosition,\n                list: this.drDropdown,\n                class: this.drDropdownClass,\n                dataAnalytics: this.dataAnalytics,\n            },\n        });\n        this.dropdownOpened.emit();\n    }\n\n    private close(): void {\n        if (this.ref) {\n            this.ref.close();\n            this.ref = null;\n            this.dropdownClosed.emit();\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.close();\n    }\n}\n\n@Directive({\n    selector: '[drDropdownChild]',\n})\nexport class DrDropdownChildDirective {}\n"]}
148
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown.directive.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, EventEmitter, HostListener, inject, Injector, Input, OnDestroy, Output } from '@angular/core';\nimport { IDropdownAction, IDropdownItem } from '../models/dropdown';\nimport { DrDropdownService, DropdownInstanceService } from './dr-dropdown.service';\nimport { DrDropdownComponent } from './dr-dropdown.component';\nimport { DrPopoverRef } from '../models/popover';\nimport { Position } from '../models/position';\n\n@Directive({\n    selector: '[drDropdown]',\n    providers: [\n        {\n            provide: DropdownInstanceService,\n            useFactory: (injector: Injector) => {\n                const service = injector.get(DropdownInstanceService, null, { skipSelf: true });\n                return service ?? new DropdownInstanceService(injector);\n            },\n            deps: [Injector],\n        },\n    ],\n})\nexport class DrDropdownDirective<T> implements OnDestroy {\n    private readonly elementRef = inject(ElementRef<HTMLElement>);\n    private readonly service = inject(DrDropdownService);\n    private readonly child = inject(DrDropdownChildDirective, { optional: true, self: true });\n    private readonly dropdownInstanceService = inject(DropdownInstanceService);\n\n    @Input({ required: true })\n    drDropdown: IDropdownItem<T>[];\n    @Input()\n    drDropdownPosition: Position = 'left-top';\n    @Input()\n    drDropdownClass: string;\n    @Input()\n    drDropdownInHover: boolean;\n    @Input({ alias: 'data-analytics' })\n    dataAnalytics: string;\n\n    @Input() drDropdownPositionOffsetX: number;\n\n    @Input() drDropdownPositionOffsetY: number;\n\n    @Output()\n    drDropdownAction = new EventEmitter<IDropdownAction<T>>();\n    @Output('drDropdownClose') dropdownClosed = new EventEmitter<void>();\n    @Output('drDropdownOpened') dropdownOpened = new EventEmitter<void>();\n\n    private ref: DrPopoverRef<DrDropdownComponent>;\n\n    private readonly mouseleaveTimeout = 200;\n\n    @HostListener('mouseenter')\n    elementHover() {\n        if (!this.drDropdownInHover) return;\n        this.openDropdown();\n    }\n\n    @HostListener('click')\n    elementClick() {\n        this.openDropdown();\n    }\n\n    @HostListener('mouseleave')\n    leaveDropdownTriggerElement() {\n        if (this.drDropdownInHover) {\n            setTimeout(() => {\n                if (this.ref && !this.ref.instance.wasHovered) {\n                    this.close();\n                }\n            }, this.mouseleaveTimeout);\n        }\n    }\n\n    @HostListener('document:mouseup')\n    documentClick() {\n        this.close();\n    }\n\n    private openDropdown(): void {\n        if (!this.drDropdown?.length) {\n            return;\n        }\n\n        if (this.ref) {\n            this.close();\n            return;\n        }\n\n        this.ref = this.service.open({\n            hostRef: this.elementRef,\n            position: this.drDropdownPosition,\n            asChild: !!this.child,\n            providers: [{ provide: DropdownInstanceService, useValue: this.dropdownInstanceService }],\n            action$: this.drDropdownAction,\n            positionOffsetX: this.drDropdownPositionOffsetX,\n            positionOffsetY: this.drDropdownPositionOffsetY,\n            options: {\n                drDropdownInHover: this.drDropdownInHover,\n                position: this.drDropdownPosition,\n                list: this.drDropdown,\n                class: this.drDropdownClass,\n                dataAnalytics: this.dataAnalytics,\n            },\n        });\n        this.dropdownOpened.emit();\n    }\n\n    private close(): void {\n        if (this.ref) {\n            this.ref.close();\n            this.ref = null;\n            this.dropdownClosed.emit();\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.close();\n    }\n}\n\n@Directive({\n    selector: '[drDropdownChild]',\n})\nexport class DrDropdownChildDirective {}\n"]}
@@ -87,4 +87,4 @@ export class DrErrorComponent {
87
87
  type: HostBinding,
88
88
  args: ['class.no-icon']
89
89
  }] }); })();
90
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItZXJyb3IuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZHItZXJyb3IvZHItZXJyb3IuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZHItZXJyb3IvZHItZXJyb3IuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN4RSxPQUFPLEVBQW1CLGtCQUFrQixFQUFXLE1BQU0sZ0JBQWdCLENBQUM7QUFDOUUsT0FBTyxFQUFFLGNBQWMsRUFBRSxlQUFlLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLGNBQWMsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7Ozs7O0lDS3RHLHVCQUFvRDs7O0lBUHhELDhCQU11Qzs7SUFDbkMsbUVBQW9EO0lBQ3BELDRCQUFNO0lBQUEsWUFBVztJQUFBLGlCQUFPLEVBQUE7Ozs7SUFIeEIseUVBQXlELGtEQUFBO0lBSHpELG1FQUEyQyxrREFBQTtJQUt2QyxlQUFhO0lBQWIscUNBQWE7SUFDWCxlQUFXO0lBQVgsOEJBQVc7O0FEQ3JCLE1BQU0sT0FBTyxnQkFBZ0I7SUFDekIsWUFBZ0Msa0JBQXNDO1FBQXRDLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBb0I7UUFrQjdELFVBQUssR0FBRyxhQUFhLENBQUM7UUFDdEIseUJBQW9CLEdBQUcsS0FBSyxDQUFDO1FBQzdCLG1CQUFjLEdBQUcsS0FBSyxDQUFDO1FBRU8sV0FBTSxHQUFHLEtBQUssQ0FBQztRQVU3QyxtQkFBYyxHQUFHLElBQUksZUFBZSxDQUE0QixJQUFJLENBQUMsQ0FBQztRQUN0RSx3QkFBbUIsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FDbkQsTUFBTSxDQUFDLE9BQU8sQ0FBQyxFQUNmLFNBQVMsQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFDN0UsR0FBRyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxPQUFPLENBQUMsTUFBTSxLQUFLLFNBQVMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FDdEUsQ0FBQztRQUNPLFdBQU0sR0FBRyxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUMzQyxTQUFTLENBQUMsY0FBYyxDQUFDLEVBQ3pCLGNBQWMsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLEVBQ25DLEdBQUcsQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFLE9BQU8sQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsRUFDOUYsR0FBRyxDQUFDLENBQUMsQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQ2hELENBQUM7UUFDTyxhQUFRLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxTQUFTLENBQUMsQ0FBQyxDQUFDO0lBNUNuQixDQUFDO0lBRTFFLElBQWEsT0FBTyxDQUFDLEtBQWdDO1FBQ2pELElBQUksS0FBSyxFQUFFO1lBQ1AsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDbkM7SUFDTCxDQUFDO0lBRUQsSUFBYSxXQUFXLENBQUMsS0FBYTtRQUNsQyxJQUFJLENBQUMsS0FBSyxJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVE7WUFBRSxPQUFPO1FBRWhELElBQUksQ0FBQyxJQUFJLENBQUMsa0JBQWtCLEVBQUU7WUFDMUIsTUFBTSxJQUFJLEtBQUssQ0FBQyx5REFBeUQsQ0FBQyxDQUFDO1NBQzlFO1FBRUQsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsa0JBQWtCLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQW9CLENBQUM7SUFDakYsQ0FBQztJQVFELFdBQVcsQ0FBQyxPQUFrQztRQUMxQyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsVUFBVSxDQUFDLEVBQUU7WUFDOUIsT0FBTyxvQkFBb0IsQ0FBQztTQUMvQjtRQUVELE9BQU8sT0FBTyxDQUFDLE1BQU0sRUFBRSxXQUFXLElBQUksSUFBSSxDQUFDO0lBQy9DLENBQUM7b0dBL0JRLGdCQUFnQjttR0FBaEIsZ0JBQWdCOzs7WUNUN0Isa0VBU007OztZQVJELHVEQUFxQjs7O3VGRFFiLGdCQUFnQjtjQUw1QixTQUFTOzJCQUVJLFVBQVU7O3NCQUlQLFFBQVE7d0JBRVIsT0FBTztrQkFBbkIsS0FBSztZQU1PLFdBQVc7a0JBQXZCLEtBQUs7WUFVRyxLQUFLO2tCQUFiLEtBQUs7WUFDRyxvQkFBb0I7a0JBQTVCLEtBQUs7WUFDRyxjQUFjO2tCQUF0QixLQUFLO1lBRWlDLE1BQU07a0JBQTVDLEtBQUs7O2tCQUFJLFdBQVc7bUJBQUMsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0LCBPcHRpb25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQWJzdHJhY3RDb250cm9sLCBGb3JtR3JvdXBEaXJlY3RpdmUsIE5nTW9kZWwgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBhc3luY1NjaGVkdWxlciwgQmVoYXZpb3JTdWJqZWN0LCBmaWx0ZXIsIG1hcCwgb2JzZXJ2ZU9uLCBzd2l0Y2hNYXAsIHdpdGhMYXRlc3RGcm9tIH0gZnJvbSAncnhqcyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHRlbXBsYXRlVXJsOiAnZHItZXJyb3IuY29tcG9uZW50Lmh0bWwnLFxuICAgIHNlbGVjdG9yOiAnZHItZXJyb3InLFxuICAgIHN0eWxlVXJsczogWydkci1lcnJvci5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBEckVycm9yQ29tcG9uZW50IHtcbiAgICBjb25zdHJ1Y3RvcihAT3B0aW9uYWwoKSBwcml2YXRlIGZvcm1Hcm91cERpcmVjdGl2ZTogRm9ybUdyb3VwRGlyZWN0aXZlKSB7fVxuXG4gICAgQElucHV0KCkgc2V0IGNvbnRyb2wodmFsdWU6IEFic3RyYWN0Q29udHJvbCB8IE5nTW9kZWwpIHtcbiAgICAgICAgaWYgKHZhbHVlKSB7XG4gICAgICAgICAgICB0aGlzLmNvbnRyb2xDaGFuZ2UkLm5leHQodmFsdWUpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgQElucHV0KCkgc2V0IGNvbnRyb2xOYW1lKHZhbHVlOiBzdHJpbmcpIHtcbiAgICAgICAgaWYgKCF2YWx1ZSB8fCB0eXBlb2YgdmFsdWUgIT09ICdzdHJpbmcnKSByZXR1cm47XG5cbiAgICAgICAgaWYgKCF0aGlzLmZvcm1Hcm91cERpcmVjdGl2ZSkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdZb3UgbXVzdCBwcm92aWRlIGEgZm9ybUdyb3VwRGlyZWN0aXZlIHRvIHVzZSB0aGlzIGlucHV0Jyk7XG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLmNvbnRyb2wgPSB0aGlzLmZvcm1Hcm91cERpcmVjdGl2ZS5jb250cm9sLmdldCh2YWx1ZSkgYXMgQWJzdHJhY3RDb250cm9sO1xuICAgIH1cblxuICAgIEBJbnB1dCgpIGxhYmVsID0gJ0ZpZWxkIGVycm9yJztcbiAgICBASW5wdXQoKSBlcnJvclRvb2x0aXBQb3NpdGlvbiA9ICd0b3AnO1xuICAgIEBJbnB1dCgpIGRpc3BsYXlBc0xhYmVsID0gZmFsc2U7XG5cbiAgICBASW5wdXQoKSBASG9zdEJpbmRpbmcoJ2NsYXNzLm5vLWljb24nKSBub0ljb24gPSBmYWxzZTtcblxuICAgIGVycm9yU3RyaW5nKGNvbnRyb2w6IEFic3RyYWN0Q29udHJvbCB8IE5nTW9kZWwpIHtcbiAgICAgICAgaWYgKGNvbnRyb2wuaGFzRXJyb3IoJ3JlcXVpcmVkJykpIHtcbiAgICAgICAgICAgIHJldHVybiAnRmllbGQgaXMgcmVxdWlyZWQhJztcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBjb250cm9sLmVycm9ycz8uZXJyb3JTdHJpbmcgfHwgbnVsbDtcbiAgICB9XG5cbiAgICByZWFkb25seSBjb250cm9sQ2hhbmdlJCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8QWJzdHJhY3RDb250cm9sIHwgTmdNb2RlbD4obnVsbCk7XG4gICAgcmVhZG9ubHkgY29udHJvbEVycm9yU3RhdHVzJCA9IHRoaXMuY29udHJvbENoYW5nZSQucGlwZShcbiAgICAgICAgZmlsdGVyKEJvb2xlYW4pLFxuICAgICAgICBzd2l0Y2hNYXAoKGNvbnRyb2wpID0+IGNvbnRyb2wuc3RhdHVzQ2hhbmdlcy5waXBlKCkucGlwZShtYXAoKCkgPT4gY29udHJvbCkpKSxcbiAgICAgICAgbWFwKChjb250cm9sKSA9PiBjb250cm9sLnN0YXR1cyA9PT0gJ0lOVkFMSUQnICYmICFjb250cm9sLnByaXN0aW5lKSxcbiAgICApO1xuICAgIHJlYWRvbmx5IGVycm9yJCA9IHRoaXMuY29udHJvbEVycm9yU3RhdHVzJC5waXBlKFxuICAgICAgICBvYnNlcnZlT24oYXN5bmNTY2hlZHVsZXIpLFxuICAgICAgICB3aXRoTGF0ZXN0RnJvbSh0aGlzLmNvbnRyb2xDaGFuZ2UkKSxcbiAgICAgICAgbWFwKChbc2hvdywgY29udHJvbF0pID0+IFtzaG93LCB0aGlzLmRpc3BsYXlBc0xhYmVsID8gdGhpcy5lcnJvclN0cmluZyhjb250cm9sKSA6IHRoaXMubGFiZWxdKSxcbiAgICAgICAgbWFwKChbc2hvdywgbGFiZWxdKSA9PiAoc2hvdyA/IGxhYmVsIDogbnVsbCkpLFxuICAgICk7XG4gICAgcmVhZG9ubHkgd2FybmluZyQgPSB0aGlzLmNvbnRyb2xDaGFuZ2UkLnBpcGUobWFwKChjb250cm9sKSA9PiAhIWNvbnRyb2wuZXJyb3JzPy5pc1dhcm5pbmcpKTtcbn1cbiIsIjxkaXZcbiAgICAqbmdJZj1cImVycm9yJCB8IGFzeW5jIGFzIGVycm9yXCJcbiAgICBbZHJUb29sdGlwXT1cImRpc3BsYXlBc0xhYmVsID8gbnVsbCA6IGVycm9yXCJcbiAgICBbZHJUb29sdGlwUG9zaXRpb25dPVwiZXJyb3JUb29sdGlwUG9zaXRpb25cIlxuICAgIGNsYXNzPVwiZXJyb3ItY29udGFpbmVyXCJcbiAgICBbY2xhc3MuZXJyb3ItY29udGFpbmVyLS1jdXJzb3ItcG9pbnRlcl09XCIhZGlzcGxheUFzTGFiZWxcIlxuICAgIFtjbGFzcy53YXJuaW5nXT1cIndhcm5pbmckIHwgYXN5bmNcIj5cbiAgICA8aSAqbmdJZj1cIiFub0ljb25cIiBjbGFzcz1cImRyLWljb24tc3RhdHVzLWVycm9yXCI+PC9pPlxuICAgIDxzcGFuPnt7IGVycm9yIH19PC9zcGFuPlxuPC9kaXY+XG4iXX0=
90
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItZXJyb3IuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZHItZXJyb3IvZHItZXJyb3IuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZHItZXJyb3IvZHItZXJyb3IuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN4RSxPQUFPLEVBQW1CLGtCQUFrQixFQUFXLE1BQU0sZ0JBQWdCLENBQUM7QUFDOUUsT0FBTyxFQUFFLGNBQWMsRUFBRSxlQUFlLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLGNBQWMsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7Ozs7O0lDS3RHLHVCQUFvRDs7O0lBUHhELDhCQU11Qzs7SUFDbkMsbUVBQW9EO0lBQ3BELDRCQUFNO0lBQUEsWUFBVztJQUFBLGlCQUFPLEVBQUE7Ozs7SUFIeEIseUVBQXlELGtEQUFBO0lBSHpELG1FQUEyQyxrREFBQTtJQUt2QyxlQUFhO0lBQWIscUNBQWE7SUFDWCxlQUFXO0lBQVgsOEJBQVc7O0FERXJCLE1BQU0sT0FBTyxnQkFBZ0I7SUFDekIsWUFBZ0Msa0JBQXNDO1FBQXRDLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBb0I7UUFrQjdELFVBQUssR0FBRyxhQUFhLENBQUM7UUFDdEIseUJBQW9CLEdBQWEsS0FBSyxDQUFDO1FBQ3ZDLG1CQUFjLEdBQUcsS0FBSyxDQUFDO1FBRU8sV0FBTSxHQUFHLEtBQUssQ0FBQztRQVU3QyxtQkFBYyxHQUFHLElBQUksZUFBZSxDQUE0QixJQUFJLENBQUMsQ0FBQztRQUN0RSx3QkFBbUIsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FDbkQsTUFBTSxDQUFDLE9BQU8sQ0FBQyxFQUNmLFNBQVMsQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFDN0UsR0FBRyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxPQUFPLENBQUMsTUFBTSxLQUFLLFNBQVMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FDdEUsQ0FBQztRQUNPLFdBQU0sR0FBRyxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUMzQyxTQUFTLENBQUMsY0FBYyxDQUFDLEVBQ3pCLGNBQWMsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLEVBQ25DLEdBQUcsQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFLE9BQU8sQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsRUFDOUYsR0FBRyxDQUFDLENBQUMsQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQ2hELENBQUM7UUFDTyxhQUFRLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxTQUFTLENBQUMsQ0FBQyxDQUFDO0lBNUNuQixDQUFDO0lBRTFFLElBQWEsT0FBTyxDQUFDLEtBQWdDO1FBQ2pELElBQUksS0FBSyxFQUFFO1lBQ1AsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDbkM7SUFDTCxDQUFDO0lBRUQsSUFBYSxXQUFXLENBQUMsS0FBYTtRQUNsQyxJQUFJLENBQUMsS0FBSyxJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVE7WUFBRSxPQUFPO1FBRWhELElBQUksQ0FBQyxJQUFJLENBQUMsa0JBQWtCLEVBQUU7WUFDMUIsTUFBTSxJQUFJLEtBQUssQ0FBQyx5REFBeUQsQ0FBQyxDQUFDO1NBQzlFO1FBRUQsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsa0JBQWtCLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQW9CLENBQUM7SUFDakYsQ0FBQztJQVFELFdBQVcsQ0FBQyxPQUFrQztRQUMxQyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsVUFBVSxDQUFDLEVBQUU7WUFDOUIsT0FBTyxvQkFBb0IsQ0FBQztTQUMvQjtRQUVELE9BQU8sT0FBTyxDQUFDLE1BQU0sRUFBRSxXQUFXLElBQUksSUFBSSxDQUFDO0lBQy9DLENBQUM7b0dBL0JRLGdCQUFnQjttR0FBaEIsZ0JBQWdCOzs7WUNWN0Isa0VBU007OztZQVJELHVEQUFxQjs7O3VGRFNiLGdCQUFnQjtjQUw1QixTQUFTOzJCQUVJLFVBQVU7O3NCQUlQLFFBQVE7d0JBRVIsT0FBTztrQkFBbkIsS0FBSztZQU1PLFdBQVc7a0JBQXZCLEtBQUs7WUFVRyxLQUFLO2tCQUFiLEtBQUs7WUFDRyxvQkFBb0I7a0JBQTVCLEtBQUs7WUFDRyxjQUFjO2tCQUF0QixLQUFLO1lBRWlDLE1BQU07a0JBQTVDLEtBQUs7O2tCQUFJLFdBQVc7bUJBQUMsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0LCBPcHRpb25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQWJzdHJhY3RDb250cm9sLCBGb3JtR3JvdXBEaXJlY3RpdmUsIE5nTW9kZWwgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBhc3luY1NjaGVkdWxlciwgQmVoYXZpb3JTdWJqZWN0LCBmaWx0ZXIsIG1hcCwgb2JzZXJ2ZU9uLCBzd2l0Y2hNYXAsIHdpdGhMYXRlc3RGcm9tIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBQb3NpdGlvbiB9IGZyb20gJy4uL21vZGVscy9wb3NpdGlvbic7XG5cbkBDb21wb25lbnQoe1xuICAgIHRlbXBsYXRlVXJsOiAnZHItZXJyb3IuY29tcG9uZW50Lmh0bWwnLFxuICAgIHNlbGVjdG9yOiAnZHItZXJyb3InLFxuICAgIHN0eWxlVXJsczogWydkci1lcnJvci5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBEckVycm9yQ29tcG9uZW50IHtcbiAgICBjb25zdHJ1Y3RvcihAT3B0aW9uYWwoKSBwcml2YXRlIGZvcm1Hcm91cERpcmVjdGl2ZTogRm9ybUdyb3VwRGlyZWN0aXZlKSB7fVxuXG4gICAgQElucHV0KCkgc2V0IGNvbnRyb2wodmFsdWU6IEFic3RyYWN0Q29udHJvbCB8IE5nTW9kZWwpIHtcbiAgICAgICAgaWYgKHZhbHVlKSB7XG4gICAgICAgICAgICB0aGlzLmNvbnRyb2xDaGFuZ2UkLm5leHQodmFsdWUpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgQElucHV0KCkgc2V0IGNvbnRyb2xOYW1lKHZhbHVlOiBzdHJpbmcpIHtcbiAgICAgICAgaWYgKCF2YWx1ZSB8fCB0eXBlb2YgdmFsdWUgIT09ICdzdHJpbmcnKSByZXR1cm47XG5cbiAgICAgICAgaWYgKCF0aGlzLmZvcm1Hcm91cERpcmVjdGl2ZSkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdZb3UgbXVzdCBwcm92aWRlIGEgZm9ybUdyb3VwRGlyZWN0aXZlIHRvIHVzZSB0aGlzIGlucHV0Jyk7XG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLmNvbnRyb2wgPSB0aGlzLmZvcm1Hcm91cERpcmVjdGl2ZS5jb250cm9sLmdldCh2YWx1ZSkgYXMgQWJzdHJhY3RDb250cm9sO1xuICAgIH1cblxuICAgIEBJbnB1dCgpIGxhYmVsID0gJ0ZpZWxkIGVycm9yJztcbiAgICBASW5wdXQoKSBlcnJvclRvb2x0aXBQb3NpdGlvbjogUG9zaXRpb24gPSAndG9wJztcbiAgICBASW5wdXQoKSBkaXNwbGF5QXNMYWJlbCA9IGZhbHNlO1xuXG4gICAgQElucHV0KCkgQEhvc3RCaW5kaW5nKCdjbGFzcy5uby1pY29uJykgbm9JY29uID0gZmFsc2U7XG5cbiAgICBlcnJvclN0cmluZyhjb250cm9sOiBBYnN0cmFjdENvbnRyb2wgfCBOZ01vZGVsKSB7XG4gICAgICAgIGlmIChjb250cm9sLmhhc0Vycm9yKCdyZXF1aXJlZCcpKSB7XG4gICAgICAgICAgICByZXR1cm4gJ0ZpZWxkIGlzIHJlcXVpcmVkISc7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gY29udHJvbC5lcnJvcnM/LmVycm9yU3RyaW5nIHx8IG51bGw7XG4gICAgfVxuXG4gICAgcmVhZG9ubHkgY29udHJvbENoYW5nZSQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PEFic3RyYWN0Q29udHJvbCB8IE5nTW9kZWw+KG51bGwpO1xuICAgIHJlYWRvbmx5IGNvbnRyb2xFcnJvclN0YXR1cyQgPSB0aGlzLmNvbnRyb2xDaGFuZ2UkLnBpcGUoXG4gICAgICAgIGZpbHRlcihCb29sZWFuKSxcbiAgICAgICAgc3dpdGNoTWFwKChjb250cm9sKSA9PiBjb250cm9sLnN0YXR1c0NoYW5nZXMucGlwZSgpLnBpcGUobWFwKCgpID0+IGNvbnRyb2wpKSksXG4gICAgICAgIG1hcCgoY29udHJvbCkgPT4gY29udHJvbC5zdGF0dXMgPT09ICdJTlZBTElEJyAmJiAhY29udHJvbC5wcmlzdGluZSksXG4gICAgKTtcbiAgICByZWFkb25seSBlcnJvciQgPSB0aGlzLmNvbnRyb2xFcnJvclN0YXR1cyQucGlwZShcbiAgICAgICAgb2JzZXJ2ZU9uKGFzeW5jU2NoZWR1bGVyKSxcbiAgICAgICAgd2l0aExhdGVzdEZyb20odGhpcy5jb250cm9sQ2hhbmdlJCksXG4gICAgICAgIG1hcCgoW3Nob3csIGNvbnRyb2xdKSA9PiBbc2hvdywgdGhpcy5kaXNwbGF5QXNMYWJlbCA/IHRoaXMuZXJyb3JTdHJpbmcoY29udHJvbCkgOiB0aGlzLmxhYmVsXSksXG4gICAgICAgIG1hcCgoW3Nob3csIGxhYmVsXSkgPT4gKHNob3cgPyBsYWJlbCA6IG51bGwpKSxcbiAgICApO1xuICAgIHJlYWRvbmx5IHdhcm5pbmckID0gdGhpcy5jb250cm9sQ2hhbmdlJC5waXBlKG1hcCgoY29udHJvbCkgPT4gISFjb250cm9sLmVycm9ycz8uaXNXYXJuaW5nKSk7XG59XG4iLCI8ZGl2XG4gICAgKm5nSWY9XCJlcnJvciQgfCBhc3luYyBhcyBlcnJvclwiXG4gICAgW2RyVG9vbHRpcF09XCJkaXNwbGF5QXNMYWJlbCA/IG51bGwgOiBlcnJvclwiXG4gICAgW2RyVG9vbHRpcFBvc2l0aW9uXT1cImVycm9yVG9vbHRpcFBvc2l0aW9uXCJcbiAgICBjbGFzcz1cImVycm9yLWNvbnRhaW5lclwiXG4gICAgW2NsYXNzLmVycm9yLWNvbnRhaW5lci0tY3Vyc29yLXBvaW50ZXJdPVwiIWRpc3BsYXlBc0xhYmVsXCJcbiAgICBbY2xhc3Mud2FybmluZ109XCJ3YXJuaW5nJCB8IGFzeW5jXCI+XG4gICAgPGkgKm5nSWY9XCIhbm9JY29uXCIgY2xhc3M9XCJkci1pY29uLXN0YXR1cy1lcnJvclwiPjwvaT5cbiAgICA8c3Bhbj57eyBlcnJvciB9fTwvc3Bhbj5cbjwvZGl2PlxuIl19
@@ -7,7 +7,6 @@ import { TimeframeOption } from '../../../models/datePicker';
7
7
  import { debounceTime, map, takeUntil } from 'rxjs/operators';
8
8
  import { Subject } from 'rxjs';
9
9
  import { PRESET_TAGS_LIST } from '../../../models/constants';
10
- import { TooltipPosition } from '../../../dr-tooltip/enums/tooltip-position.enum';
11
10
  import * as i0 from "@angular/core";
12
11
  import * as i1 from "@angular/material/core";
13
12
  import * as i2 from "../services/dr-date-picker.service";
@@ -81,7 +80,7 @@ export class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
81
80
  this.dateAdapter = dateAdapter;
82
81
  this.datePickerService = datePickerService;
83
82
  this.canSelectTimeframe = true;
84
- this.datepickerTooltipPosition = TooltipPosition.TOP;
83
+ this.datepickerTooltipPosition = 'top';
85
84
  this.datepickerTooltipTimeout = 0;
86
85
  this.isOpen = false;
87
86
  this.onChangeFormat = new EventEmitter();
@@ -280,4 +279,4 @@ export class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
280
279
  }], onChangePresetTag: [{
281
280
  type: Output
282
281
  }] }); })();
283
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker-with-timeframe.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.ts","../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    SimpleChanges,\n    TemplateRef,\n} from '@angular/core';\nimport { CustomDateAdapter, DrDatePickerComponent } from '../dr-date-picker/dr-date-picker.component';\nimport { DateAdapter } from '@angular/material/core';\nimport { DrDatePickerService } from '../services/dr-date-picker.service';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DateTags, IDatePickerFormatConfig, TimeframeOption } from '../../../models/datePicker';\nimport { debounceTime, map, takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\nimport { Moment } from 'moment';\nimport { PRESET_TAGS_LIST } from '../../../models/constants';\nimport { TooltipPosition } from '../../../dr-tooltip/enums/tooltip-position.enum';\n\n@Component({\n    selector: 'dr-date-picker-with-timeframe',\n    templateUrl: './dr-date-picker-with-timeframe.component.html',\n    styleUrls: ['./dr-date-picker-with-timeframe.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        { provide: NG_VALUE_ACCESSOR, useExisting: DrDatePickerWithTimeframeComponent, multi: true },\n        { provide: DateAdapter, useClass: CustomDateAdapter },\n        { provide: DrDatePickerService },\n    ],\n})\nexport class DrDatePickerWithTimeframeComponent\n    extends DrDatePickerComponent\n    implements ControlValueAccessor, AfterViewInit, OnDestroy, OnInit, OnChanges\n{\n    presetTagSelected: string;\n\n    @Input() set dateFormatConfig(value: IDatePickerFormatConfig) {\n        if (value) {\n            this.datePickerService.formatConfig = { ...this.datePickerService.formatConfig, ...value };\n            this.cdr.markForCheck();\n        }\n    }\n\n    @Input() canSelectTimeframe = true;\n    @Input() customPanelClass: string;\n\n    @Input() set availableTimeframes(value: TimeframeOption[]) {\n        if (value && value.length) {\n            this.datePickerService.availableTimeframes = value;\n        }\n    }\n    @Input() set availableDateTagPresets(value: Array<{ key: string; label: string }>) {\n        if (value && value.length) {\n            this.datePickerService.availableDateTagPresets = value;\n        }\n    }\n    @Input() paginationDebounce;\n\n    @Input() set isUsingDateTagPresets(flag: boolean) {\n        this.datePickerService.isUsingDateTagPresets = flag;\n    }\n\n    @Input() set isUsingTimeFrameSelect(flag: boolean) {\n        this.datePickerService.isUsingTimeFrameSelect = flag;\n    }\n\n    @Input() set presetTag(tag: string) {\n        this.datePickerService.presetTag$.next(tag as DateTags);\n    }\n\n    @Input() datepickerTooltip: TemplateRef<any> | null;\n    @Input() datepickerTooltipPosition: string = TooltipPosition.TOP;\n    @Input() datepickerTooltipTimeout: number = 0;\n\n    @Input() isOpen: boolean = false;\n\n    @Output() onChangeFormat = new EventEmitter<string>();\n    @Output() onChangePresetTag = new EventEmitter<DateTags>();\n\n    private readonly pagingSetup = {\n        [TimeframeOption.YEAR]: (forward) => this.getNextDate('addCalendarYears', 1, forward),\n        [TimeframeOption.QUARTER]: (forward) => this.getNextDate('addCalendarMonths', 3, forward),\n        [TimeframeOption.MONTH]: (forward) => this.getNextDate('addCalendarMonths', 1, forward),\n        [TimeframeOption.DAY]: (forward) => this.getNextDate('addCalendarDays', 1, forward),\n        [TimeframeOption.WEEK]: (forward) => this.getNextDate('addCalendarDays', 7, forward),\n    };\n\n    public isNextDateDisabled = false;\n    public isPrevDateDisabled = false;\n\n    private onChangeDebounced$: Subject<number> = new Subject<number>();\n\n    public displayedFormattedValue$ = this.displayValue$.pipe(\n        takeUntil(this.destroyed$),\n        map((value: Moment) => {\n            if (!value) return this.placeholder;\n            return (\n                this.datePickerService.getDisplayPrefix() +\n                this.dateAdapter.format(value, this.datePickerService.getConfiguredFormat(this.datePickerService.timeframe))\n            );\n        }),\n    );\n\n    public get combinedPanelClass(): string {\n        const baseClass = this.datePickerService.isUsingDateTagPresets ? 'date-picker-preset-tag' : 'dr-timeframe-datepicker';\n        return this.customPanelClass ? `${baseClass} ${this.customPanelClass}` : baseClass;\n    }\n\n    constructor(\n        protected cdr: ChangeDetectorRef,\n        protected dateAdapter: DateAdapter<any>,\n        public datePickerService: DrDatePickerService,\n    ) {\n        super(cdr, dateAdapter, datePickerService);\n        datePickerService.isTimeframeSelectionEnabled = true;\n\n        datePickerService.format$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            this.onChangeFormat.emit(datePickerService.normalizeValue(value));\n        });\n\n        datePickerService.presetTag$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            let tagObj = PRESET_TAGS_LIST.find((val) => val?.key === value);\n            this.presetTagSelected = tagObj?.label;\n            this.onChangePresetTag.emit(value);\n        });\n\n        this.datePickerService.onSameDaySelectedInCalendar$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            this.setValueFromMoment(value);\n        });\n\n        datePickerService.updatedDateAndClose$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            if (value) {\n                this.setValueFromMoment(value);\n            } else {\n                this.onChangeCallback(this.innerValue.unix());\n            }\n            this.datePicker.close();\n        });\n    }\n\n    ngOnInit() {\n        this.datePickerService.isTimeframeSelectionEnabled = this.canSelectTimeframe;\n        this.cdr.markForCheck();\n\n        if (this.paginationDebounce) {\n            this.onChangeDebounced$.pipe(takeUntil(this.destroyed$), debounceTime(this.paginationDebounce)).subscribe((value) => {\n                this.onChangeCallback(value);\n            });\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.format?.currentValue && changes.format.currentValue !== changes.format.previousValue) {\n            this.datePickerService.updateTimeframeAndFormat(changes.format.currentValue);\n        }\n    }\n\n    ngAfterViewInit() {\n        super.ngAfterViewInit();\n        if (this.isOpen) {\n            this.datePicker.open();\n        }\n    }\n\n    pagingClicked(forward: boolean): void {\n        if (this.pagingSetup[this.datePickerService.timeframe]) {\n            const nextValue = this.pagingSetup[this.datePickerService.timeframe](forward);\n            this.pagingDateChange(nextValue);\n        }\n        this.datePicker.close();\n    }\n\n    pagingDateChange(newValue: Moment): void {\n        if (this.paginationDebounce) {\n            // this is required for not sending extra requests when user quickly clicking on pagination\n            // here we do the same as in setValueFromMoment(newValue) with difference\n            // that updating of ngModel/formControl is debounced\n            this.datePickerService.resetPresetTag();\n            this.writeValue(newValue.unix());\n            this.onChangeDebounced$.next(this.innerValue.unix());\n        } else {\n            this.setValueFromMoment(newValue);\n        }\n    }\n\n    /**\n     * Set inner value from timestamp and propagate\n     *\n     * @param timestamp\n     */\n    protected setValue(timestamp: number): void {\n        this.datePickerService.resetPresetTag();\n        super.setValue(timestamp);\n    }\n    public writeValue(value: number): void {\n        super.writeValue(value);\n        if (!value) return;\n        this.restrictPagination();\n    }\n\n    private getNextDate(actionCall: string, amount: number, forward: boolean): Moment {\n        return this.dateAdapter[actionCall]?.(this.innerValue, forward ? amount : -amount);\n    }\n\n    private restrictPagination(): void {\n        if (!this._min && !this._max) return;\n        const timeFrame = this.datePickerService.timeframe;\n        const nextValue = this.pagingSetup[timeFrame](true);\n        const prevValue = this.pagingSetup[timeFrame](false);\n        const granularity = timeFrame;\n        /* TODO: Take into account fiscal year start and back for cases where fiscal year and quarter is true - https://datarailsteam.atlassian.net/browse/DR-35528 and\n          https://datarailsteam.atlassian.net/browse/DR-35568\n        */\n        if (this.fiscalYearBack || this.fiscalYearMonthsModifier !== 0) {\n            this.isNextDateDisabled = this._max && nextValue && nextValue.unix() > this._max.unix();\n            this.isPrevDateDisabled = this._min && prevValue && prevValue.unix() < this._min.unix();\n        } else {\n            this.isNextDateDisabled = !!(this._max && nextValue && !nextValue.isSameOrBefore(this._max, granularity));\n            this.isPrevDateDisabled = !!(this._min && prevValue && !prevValue.isSameOrAfter(this._min, granularity));\n        }\n    }\n}\n","<dr-button\n    [disabled]=\"isPrevDateDisabled\"\n    *ngIf=\"!disabled\"\n    theme=\"icon\"\n    icon=\"dr-icon-arrow-left\"\n    (click)=\"pagingClicked(false)\"></dr-button>\n<div\n    [drTooltip]=\"datepickerTooltip\"\n    [drTooltipPosition]=\"datepickerTooltipPosition\"\n    [drTooltipMousleaveTimeout]=\"datepickerTooltipTimeout\"\n    class=\"dr-datepicker-input-container\">\n    <i class=\"dr-icon-date\" (click)=\"datepickerInput.click()\"></i>\n\n    <div class=\"dr-datepicker-input-container__formatted-value-display\" (click)=\"datepickerInput.click()\">\n        <ng-container\n            [ngTemplateOutlet]=\"formattedValueTmpl\"\n            [ngTemplateOutletContext]=\"{\n                formattedValue: displayedFormattedValue$ | async,\n            }\">\n        </ng-container>\n        <ng-template #formattedValueTmpl let-value=\"formattedValue\">\n            <span>\n                {{\n                    datePickerService.isUsingDateTagPresets && !!presetTagSelected\n                        ? presetTagSelected + ' (' + value + ')'\n                        : value\n                }}\n            </span>\n        </ng-template>\n    </div>\n    <input\n        #datepickerInput\n        [ngModel]=\"displayValue$ | async\"\n        (ngModelChange)=\"valueChangedInCalendar($event)\"\n        (click)=\"datePicker.open()\"\n        [matDatepicker]=\"datePicker\"\n        [readonly]=\"readonly\"\n        [min]=\"_min\"\n        [max]=\"_max\" />\n</div>\n<dr-button\n    [disabled]=\"isNextDateDisabled\"\n    *ngIf=\"!disabled\"\n    theme=\"icon\"\n    icon=\"dr-icon-arrow-right\"\n    (click)=\"pagingClicked(true)\"></dr-button>\n\n<mat-datepicker\n    #datePicker\n    class=\"dr-timeframe-datepicker\"\n    [calendarHeaderComponent]=\"customHeader\"\n    (yearSelected)=\"chosenPeriodHandler($event, timeframeOption.YEAR, datePicker)\"\n    (monthSelected)=\"chosenPeriodHandler($event, timeframeOption.MONTH, datePicker)\"\n    (opened)=\"onOpen()\"\n    (closed)=\"onCLose()\"\n    [panelClass]=\"combinedPanelClass\">\n</mat-datepicker>\n"]}
282
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker-with-timeframe.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.ts","../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    SimpleChanges,\n    TemplateRef,\n} from '@angular/core';\nimport { CustomDateAdapter, DrDatePickerComponent } from '../dr-date-picker/dr-date-picker.component';\nimport { DateAdapter } from '@angular/material/core';\nimport { DrDatePickerService } from '../services/dr-date-picker.service';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DateTags, IDatePickerFormatConfig, TimeframeOption } from '../../../models/datePicker';\nimport { debounceTime, map, takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\nimport { Moment } from 'moment';\nimport { PRESET_TAGS_LIST } from '../../../models/constants';\nimport { Position } from '../../../models/position';\n\n@Component({\n    selector: 'dr-date-picker-with-timeframe',\n    templateUrl: './dr-date-picker-with-timeframe.component.html',\n    styleUrls: ['./dr-date-picker-with-timeframe.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        { provide: NG_VALUE_ACCESSOR, useExisting: DrDatePickerWithTimeframeComponent, multi: true },\n        { provide: DateAdapter, useClass: CustomDateAdapter },\n        { provide: DrDatePickerService },\n    ],\n})\nexport class DrDatePickerWithTimeframeComponent\n    extends DrDatePickerComponent\n    implements ControlValueAccessor, AfterViewInit, OnDestroy, OnInit, OnChanges\n{\n    presetTagSelected: string;\n\n    @Input() set dateFormatConfig(value: IDatePickerFormatConfig) {\n        if (value) {\n            this.datePickerService.formatConfig = { ...this.datePickerService.formatConfig, ...value };\n            this.cdr.markForCheck();\n        }\n    }\n\n    @Input() canSelectTimeframe = true;\n    @Input() customPanelClass: string;\n\n    @Input() set availableTimeframes(value: TimeframeOption[]) {\n        if (value && value.length) {\n            this.datePickerService.availableTimeframes = value;\n        }\n    }\n    @Input() set availableDateTagPresets(value: Array<{ key: string; label: string }>) {\n        if (value && value.length) {\n            this.datePickerService.availableDateTagPresets = value;\n        }\n    }\n    @Input() paginationDebounce;\n\n    @Input() set isUsingDateTagPresets(flag: boolean) {\n        this.datePickerService.isUsingDateTagPresets = flag;\n    }\n\n    @Input() set isUsingTimeFrameSelect(flag: boolean) {\n        this.datePickerService.isUsingTimeFrameSelect = flag;\n    }\n\n    @Input() set presetTag(tag: string) {\n        this.datePickerService.presetTag$.next(tag as DateTags);\n    }\n\n    @Input() datepickerTooltip: TemplateRef<any> | null;\n    @Input() datepickerTooltipPosition: Position = 'top';\n    @Input() datepickerTooltipTimeout: number = 0;\n\n    @Input() isOpen: boolean = false;\n\n    @Output() onChangeFormat = new EventEmitter<string>();\n    @Output() onChangePresetTag = new EventEmitter<DateTags>();\n\n    private readonly pagingSetup = {\n        [TimeframeOption.YEAR]: (forward) => this.getNextDate('addCalendarYears', 1, forward),\n        [TimeframeOption.QUARTER]: (forward) => this.getNextDate('addCalendarMonths', 3, forward),\n        [TimeframeOption.MONTH]: (forward) => this.getNextDate('addCalendarMonths', 1, forward),\n        [TimeframeOption.DAY]: (forward) => this.getNextDate('addCalendarDays', 1, forward),\n        [TimeframeOption.WEEK]: (forward) => this.getNextDate('addCalendarDays', 7, forward),\n    };\n\n    public isNextDateDisabled = false;\n    public isPrevDateDisabled = false;\n\n    private onChangeDebounced$: Subject<number> = new Subject<number>();\n\n    public displayedFormattedValue$ = this.displayValue$.pipe(\n        takeUntil(this.destroyed$),\n        map((value: Moment) => {\n            if (!value) return this.placeholder;\n            return (\n                this.datePickerService.getDisplayPrefix() +\n                this.dateAdapter.format(value, this.datePickerService.getConfiguredFormat(this.datePickerService.timeframe))\n            );\n        }),\n    );\n\n    public get combinedPanelClass(): string {\n        const baseClass = this.datePickerService.isUsingDateTagPresets ? 'date-picker-preset-tag' : 'dr-timeframe-datepicker';\n        return this.customPanelClass ? `${baseClass} ${this.customPanelClass}` : baseClass;\n    }\n\n    constructor(\n        protected cdr: ChangeDetectorRef,\n        protected dateAdapter: DateAdapter<any>,\n        public datePickerService: DrDatePickerService,\n    ) {\n        super(cdr, dateAdapter, datePickerService);\n        datePickerService.isTimeframeSelectionEnabled = true;\n\n        datePickerService.format$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            this.onChangeFormat.emit(datePickerService.normalizeValue(value));\n        });\n\n        datePickerService.presetTag$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            let tagObj = PRESET_TAGS_LIST.find((val) => val?.key === value);\n            this.presetTagSelected = tagObj?.label;\n            this.onChangePresetTag.emit(value);\n        });\n\n        this.datePickerService.onSameDaySelectedInCalendar$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            this.setValueFromMoment(value);\n        });\n\n        datePickerService.updatedDateAndClose$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            if (value) {\n                this.setValueFromMoment(value);\n            } else {\n                this.onChangeCallback(this.innerValue.unix());\n            }\n            this.datePicker.close();\n        });\n    }\n\n    ngOnInit() {\n        this.datePickerService.isTimeframeSelectionEnabled = this.canSelectTimeframe;\n        this.cdr.markForCheck();\n\n        if (this.paginationDebounce) {\n            this.onChangeDebounced$.pipe(takeUntil(this.destroyed$), debounceTime(this.paginationDebounce)).subscribe((value) => {\n                this.onChangeCallback(value);\n            });\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.format?.currentValue && changes.format.currentValue !== changes.format.previousValue) {\n            this.datePickerService.updateTimeframeAndFormat(changes.format.currentValue);\n        }\n    }\n\n    ngAfterViewInit() {\n        super.ngAfterViewInit();\n        if (this.isOpen) {\n            this.datePicker.open();\n        }\n    }\n\n    pagingClicked(forward: boolean): void {\n        if (this.pagingSetup[this.datePickerService.timeframe]) {\n            const nextValue = this.pagingSetup[this.datePickerService.timeframe](forward);\n            this.pagingDateChange(nextValue);\n        }\n        this.datePicker.close();\n    }\n\n    pagingDateChange(newValue: Moment): void {\n        if (this.paginationDebounce) {\n            // this is required for not sending extra requests when user quickly clicking on pagination\n            // here we do the same as in setValueFromMoment(newValue) with difference\n            // that updating of ngModel/formControl is debounced\n            this.datePickerService.resetPresetTag();\n            this.writeValue(newValue.unix());\n            this.onChangeDebounced$.next(this.innerValue.unix());\n        } else {\n            this.setValueFromMoment(newValue);\n        }\n    }\n\n    /**\n     * Set inner value from timestamp and propagate\n     *\n     * @param timestamp\n     */\n    protected setValue(timestamp: number): void {\n        this.datePickerService.resetPresetTag();\n        super.setValue(timestamp);\n    }\n    public writeValue(value: number): void {\n        super.writeValue(value);\n        if (!value) return;\n        this.restrictPagination();\n    }\n\n    private getNextDate(actionCall: string, amount: number, forward: boolean): Moment {\n        return this.dateAdapter[actionCall]?.(this.innerValue, forward ? amount : -amount);\n    }\n\n    private restrictPagination(): void {\n        if (!this._min && !this._max) return;\n        const timeFrame = this.datePickerService.timeframe;\n        const nextValue = this.pagingSetup[timeFrame](true);\n        const prevValue = this.pagingSetup[timeFrame](false);\n        const granularity = timeFrame;\n        /* TODO: Take into account fiscal year start and back for cases where fiscal year and quarter is true - https://datarailsteam.atlassian.net/browse/DR-35528 and\n          https://datarailsteam.atlassian.net/browse/DR-35568\n        */\n        if (this.fiscalYearBack || this.fiscalYearMonthsModifier !== 0) {\n            this.isNextDateDisabled = this._max && nextValue && nextValue.unix() > this._max.unix();\n            this.isPrevDateDisabled = this._min && prevValue && prevValue.unix() < this._min.unix();\n        } else {\n            this.isNextDateDisabled = !!(this._max && nextValue && !nextValue.isSameOrBefore(this._max, granularity));\n            this.isPrevDateDisabled = !!(this._min && prevValue && !prevValue.isSameOrAfter(this._min, granularity));\n        }\n    }\n}\n","<dr-button\n    [disabled]=\"isPrevDateDisabled\"\n    *ngIf=\"!disabled\"\n    theme=\"icon\"\n    icon=\"dr-icon-arrow-left\"\n    (click)=\"pagingClicked(false)\"></dr-button>\n<div\n    [drTooltip]=\"datepickerTooltip\"\n    [drTooltipPosition]=\"datepickerTooltipPosition\"\n    [drTooltipMousleaveTimeout]=\"datepickerTooltipTimeout\"\n    class=\"dr-datepicker-input-container\">\n    <i class=\"dr-icon-date\" (click)=\"datepickerInput.click()\"></i>\n\n    <div class=\"dr-datepicker-input-container__formatted-value-display\" (click)=\"datepickerInput.click()\">\n        <ng-container\n            [ngTemplateOutlet]=\"formattedValueTmpl\"\n            [ngTemplateOutletContext]=\"{\n                formattedValue: displayedFormattedValue$ | async,\n            }\">\n        </ng-container>\n        <ng-template #formattedValueTmpl let-value=\"formattedValue\">\n            <span>\n                {{\n                    datePickerService.isUsingDateTagPresets && !!presetTagSelected\n                        ? presetTagSelected + ' (' + value + ')'\n                        : value\n                }}\n            </span>\n        </ng-template>\n    </div>\n    <input\n        #datepickerInput\n        [ngModel]=\"displayValue$ | async\"\n        (ngModelChange)=\"valueChangedInCalendar($event)\"\n        (click)=\"datePicker.open()\"\n        [matDatepicker]=\"datePicker\"\n        [readonly]=\"readonly\"\n        [min]=\"_min\"\n        [max]=\"_max\" />\n</div>\n<dr-button\n    [disabled]=\"isNextDateDisabled\"\n    *ngIf=\"!disabled\"\n    theme=\"icon\"\n    icon=\"dr-icon-arrow-right\"\n    (click)=\"pagingClicked(true)\"></dr-button>\n\n<mat-datepicker\n    #datePicker\n    class=\"dr-timeframe-datepicker\"\n    [calendarHeaderComponent]=\"customHeader\"\n    (yearSelected)=\"chosenPeriodHandler($event, timeframeOption.YEAR, datePicker)\"\n    (monthSelected)=\"chosenPeriodHandler($event, timeframeOption.MONTH, datePicker)\"\n    (opened)=\"onOpen()\"\n    (closed)=\"onCLose()\"\n    [panelClass]=\"combinedPanelClass\">\n</mat-datepicker>\n"]}
@@ -320,7 +320,7 @@ export class DrSelectComponent {
320
320
  i0.ɵɵproperty("ngIf", ctx.groupBy);
321
321
  i0.ɵɵadvance(2);
322
322
  i0.ɵɵproperty("ngIf", ctx.type === "search-input");
323
- } }, dependencies: [i1.NgControlStatus, i1.NgModel, i2.NgIf, i2.NgTemplateOutlet, i3.NgSelectComponent, i3.NgOptgroupTemplateDirective, i3.NgOptionTemplateDirective, i3.NgLabelTemplateDirective, i3.NgMultiLabelTemplateDirective, i3.NgHeaderTemplateDirective, i3.NgFooterTemplateDirective, i3.NgLoadingSpinnerTemplateDirective, i4.DrSpinnerDirective, i5.DrInputComponent], styles: ["[_nghost-%COMP%]{width:100%;height:32px;font-family:Poppins,sans-serif}.textView[_nghost-%COMP%] {width:auto}.textView[_nghost-%COMP%] ng-select.ng-select .ng-select-container{border:none!important;cursor:pointer}.textView[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-value-container{padding:0;color:#4646ce}.textView[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-value-container:hover{text-decoration-line:underline}.textView[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-arrow-wrapper{display:none}.textView[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container, .textView[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container:hover, .textView[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container:focus-within{background:#fff!important;border:none!important;cursor:default}.textView[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container .ng-value, .textView[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container:hover .ng-value, .textView[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container:focus-within .ng-value{color:#aeabac!important}.textView[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container .ng-input input::placeholder{color:#aeabac}.textView[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-value-container:hover{text-decoration-line:none}.no-left-border-radius[_nghost-%COMP%] ng-select.ng-select .ng-select-container{border-bottom-left-radius:0!important;border-top-left-radius:0!important}.no-right-border-radius[_nghost-%COMP%] ng-select.ng-select .ng-select-container{border-bottom-right-radius:0!important;border-top-right-radius:0!important}.no-right-border[_nghost-%COMP%] ng-select.ng-select .ng-select-container{border-right:none!important}.no-left-border[_nghost-%COMP%] ng-select.ng-select .ng-select-container{border-left:none!important}[_nghost-%COMP%] ng-select.ng-select .ng-select-container{min-height:32px;height:32px;width:100%;border-radius:6px;border:1px solid #9ea1aa;box-shadow:none!important}[_nghost-%COMP%] ng-select.ng-select .ng-select-container:hover{border-color:#4646ce}[_nghost-%COMP%] ng-select.ng-select .ng-select-container:focus-within{border-color:#4646ce}[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-input{font-size:14px;line-height:24px;font-weight:400;top:0!important;padding:0 50px 0 8px!important;color:#333}[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-input input::placeholder{font-size:14px;line-height:24px;font-weight:400;color:#6d6e6f}[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-value-container{font-size:14px;line-height:24px;font-weight:400;padding:0 0 0 8px;height:100%;overflow:auto}[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-value-container .ng-input{padding:0 0 0 3px!important}[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-arrow-wrapper{margin-right:7px}[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-arrow-wrapper .ng-arrow{border:none;width:auto;height:auto;display:flex;text-decoration-line:none;top:0}[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-arrow-wrapper .ng-arrow:before{font-family:DataRails!important;content:\"\\ea17\";font-size:24px;color:#6d6e6f}[_nghost-%COMP%] ng-select.ng-select.ng-select-opened .ng-select-container{border-radius:6px}[_nghost-%COMP%] ng-select.ng-select.ng-select-multiple .ng-select-container{max-height:58px;height:100%}[_nghost-%COMP%] ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container{font-size:14px;line-height:24px;font-weight:400;max-height:58px}[_nghost-%COMP%] ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value{font-size:12px;line-height:16px;font-weight:400;color:#333;height:24px;padding:2px 16px;margin:2px 4px 2px 0;background:#f0f1f4;display:flex;flex-direction:row-reverse;align-items:center;border-radius:12px}[_nghost-%COMP%] ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-label{padding:0!important}[_nghost-%COMP%] ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-icon{border:none!important;padding:0!important;width:20px;display:flex;align-items:center;color:transparent;margin-left:4px}[_nghost-%COMP%] ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-icon:before{font-family:DataRails!important;content:\"\\ea75\";font-size:20px;color:#333}[_nghost-%COMP%] ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-icon, [_nghost-%COMP%] ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-icon:hover{background:transparent!important}[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container, [_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container:hover, [_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container:focus-within{background:#f0f1f4!important;border:1px solid #aeabac!important}[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container .ng-value, [_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container:hover .ng-value, [_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container:focus-within .ng-value{color:#aeabac!important}[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container .ng-arrow{color:#aeabac}[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container .ng-arrow:before{color:#aeabac}[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container .ng-input input::placeholder{color:#aeabac}[_nghost-%COMP%] ng-select.ng-select.ng-select-single.ng-invalid.ng-touched .ng-select-container, [_nghost-%COMP%] ng-select.ng-select.ng-select-multiple.ng-invalid.ng-touched .ng-select-container{border-color:#bf1d30}[_nghost-%COMP%] ng-select.ng-select--multiple-height-increased.ng-select-multiple .ng-select-container{max-height:88px}[_nghost-%COMP%] ng-select.ng-select--multiple-height-increased.ng-select-multiple .ng-select-container .ng-value-container{max-height:88px}[_nghost-%COMP%] ng-select.ng-select--no-value-padding .ng-select-container .ng-value-container .ng-value, [_nghost-%COMP%] ng-select.ng-select--no-value-padding.ng-select-multiple .ng-select-container .ng-value-container .ng-value{padding:0}[_nghost-%COMP%] ng-select.ng-select--no-value-padding .ng-select-container .ng-value-container .ng-value .ng-select-user-label, [_nghost-%COMP%] ng-select.ng-select--no-value-padding.ng-select-multiple .ng-select-container .ng-value-container .ng-value .ng-select-user-label{height:100%}.ng-invalid.ng-touched[_nghost-%COMP%] ng-select.ng-select .ng-select-container{border-color:#bf1d30}[_nghost-%COMP%] .dr-select__loading[_ngcontent-%COMP%]{position:relative;height:32px;width:24px}.search-input[_nghost-%COMP%]{position:relative}.search-input[_nghost-%COMP%] .search-icon[_ngcontent-%COMP%]{position:absolute;top:4px;right:16px;color:#6d6e6f;z-index:1001}.search-input[_nghost-%COMP%] ng-select.ng-select .ng-select-container{border-radius:16px}.search-input[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-arrow-wrapper{display:none!important}.search-input[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-clear-wrapper{display:flex;justify-content:center;align-items:center;right:40px;top:1px;width:24px;height:24px}.search-input[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-clear-wrapper .ng-clear{font-size:24px;font-weight:300;color:#6d6e6f}.search-input[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-input, .search-input[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-value-container{padding:0 0 0 16px!important;width:calc(100% - 63px)}.search-input[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-input input, .search-input[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-value-container input{height:100%} ng-dropdown-panel.ng-dropdown-panel.dr-select{font-family:Poppins,sans-serif;border:1px solid #dfe0e3;border-radius:4px!important;margin:8px 0;box-shadow:0 4px 8px 1px #00000040;background-color:#fff;overflow:hidden;padding:8px 0} ng-dropdown-panel.ng-dropdown-panel.dr-select.textView{width:auto!important} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option:empty{display:none} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option{display:flex;align-items:center;min-height:36px;padding:8px 12px;font-size:14px;line-height:22px;background:#fff} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option>.ng-option-label{text-overflow:ellipsis;overflow:hidden} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-marked{background:#f5f5f5} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-selected, ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-selected.ng-option-marked{background:#eaeaff;color:#333} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-selected span, ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-selected.ng-option-marked span{font-weight:400!important} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled{cursor:default} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled>div{color:#aeabac} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled>div.dr-select__option-with-desc__wrapper .dr-select__option-with-desc__description{color:#aeabac} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled[role=group]{font-size:14px;line-height:22px;color:#aeabac;cursor:default} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled[role=group]:not(:first-of-type){border-top:1px solid #dfe0e3} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled[role=group]:hover{background:#fff} ng-dropdown-panel.ng-dropdown-panel.dr-select .dr-select__option-with-desc__wrapper{color:#333} ng-dropdown-panel.ng-dropdown-panel.dr-select .dr-select__option-with-desc__wrapper .dr-select__option-with-desc__description{max-width:-moz-fit-content;max-width:fit-content;word-break:break-word;white-space:normal;color:#6d6e6f;font-weight:400;font-size:12px;line-height:20px} ng-dropdown-panel.ng-dropdown-panel.dr-select.ng-option-selected .dr-select__option-with-desc__wrapper .dr-select__option-with-desc__description, ng-dropdown-panel.ng-dropdown-panel.dr-select.ng-option-selected.ng-option-marked .dr-select__option-with-desc__wrapper .dr-select__option-with-desc__description{color:#6d6e6f} .ng-dropdown-panel--with-search .ng-dropdown-header{border-bottom:none}.custom-backdrop[_ngcontent-%COMP%]{position:fixed;inset:0;overflow:hidden;pointer-events:none}"] }); }
323
+ } }, dependencies: [i1.NgControlStatus, i1.NgModel, i2.NgIf, i2.NgTemplateOutlet, i3.NgSelectComponent, i3.NgOptgroupTemplateDirective, i3.NgOptionTemplateDirective, i3.NgLabelTemplateDirective, i3.NgMultiLabelTemplateDirective, i3.NgHeaderTemplateDirective, i3.NgFooterTemplateDirective, i3.NgLoadingSpinnerTemplateDirective, i4.DrSpinnerDirective, i5.DrInputComponent], styles: ["[_nghost-%COMP%]{width:100%;height:32px;font-family:Poppins,sans-serif}.textView[_nghost-%COMP%] {width:auto}.textView[_nghost-%COMP%] ng-select.ng-select .ng-select-container{border:none!important;cursor:pointer}.textView[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-value-container{padding:0;color:#4646ce}.textView[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-value-container:hover{text-decoration-line:underline}.textView[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-arrow-wrapper{display:none}.textView[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container, .textView[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container:hover, .textView[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container:focus-within{background:#fff!important;border:none!important;cursor:default}.textView[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container .ng-value, .textView[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container:hover .ng-value, .textView[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container:focus-within .ng-value{color:#aeabac!important}.textView[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container .ng-input input::placeholder{color:#aeabac}.textView[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-value-container:hover{text-decoration-line:none}.no-left-border-radius[_nghost-%COMP%] ng-select.ng-select .ng-select-container{border-bottom-left-radius:0!important;border-top-left-radius:0!important}.no-right-border-radius[_nghost-%COMP%] ng-select.ng-select .ng-select-container{border-bottom-right-radius:0!important;border-top-right-radius:0!important}.no-right-border[_nghost-%COMP%] ng-select.ng-select .ng-select-container{border-right:none!important}.no-left-border[_nghost-%COMP%] ng-select.ng-select .ng-select-container{border-left:none!important}[_nghost-%COMP%] ng-select.ng-select .ng-select-container{min-height:32px;height:32px;width:100%;border-radius:6px;border:1px solid #9ea1aa;box-shadow:none!important}[_nghost-%COMP%] ng-select.ng-select .ng-select-container:hover{border-color:#4646ce}[_nghost-%COMP%] ng-select.ng-select .ng-select-container:focus-within{border-color:#4646ce}[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-input{font-size:14px;line-height:24px;font-weight:400;top:0!important;padding:0 50px 0 8px!important;color:#333}[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-input input::placeholder{font-size:14px;line-height:24px;font-weight:400;color:#6d6e6f}[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-value-container{font-size:14px;line-height:24px;font-weight:400;padding:0 0 0 8px;height:100%;overflow:auto}[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-value-container .ng-input{padding:0 0 0 3px!important}[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-arrow-wrapper{margin-right:7px}[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-arrow-wrapper .ng-arrow{border:none;width:auto;height:auto;display:flex;text-decoration-line:none;top:0}[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-arrow-wrapper .ng-arrow:before{font-family:DataRails!important;content:\"\\ea17\";font-size:24px;color:#6d6e6f}[_nghost-%COMP%] ng-select.ng-select.ng-select-opened .ng-select-container{border-radius:6px}[_nghost-%COMP%] ng-select.ng-select.ng-select-multiple .ng-select-container{max-height:58px;height:100%}[_nghost-%COMP%] ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container{font-size:14px;line-height:24px;font-weight:400;max-height:58px}[_nghost-%COMP%] ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value{font-size:12px;line-height:16px;font-weight:400;color:#333;height:24px;padding:2px 16px;margin:2px 4px 2px 0;background:#f0f1f4;display:flex;flex-direction:row-reverse;align-items:center;border-radius:12px}[_nghost-%COMP%] ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-label{padding:0!important}[_nghost-%COMP%] ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-icon{border:none!important;padding:0!important;width:20px;display:flex;align-items:center;color:transparent;margin-left:4px}[_nghost-%COMP%] ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-icon:before{font-family:DataRails!important;content:\"\\ea74\";font-size:20px;color:#333}[_nghost-%COMP%] ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-icon, [_nghost-%COMP%] ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-icon:hover{background:transparent!important}[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container, [_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container:hover, [_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container:focus-within{background:#f0f1f4!important;border:1px solid #aeabac!important}[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container .ng-value, [_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container:hover .ng-value, [_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container:focus-within .ng-value{color:#aeabac!important}[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container .ng-arrow{color:#aeabac}[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container .ng-arrow:before{color:#aeabac}[_nghost-%COMP%] ng-select.ng-select.ng-select-disabled .ng-select-container .ng-input input::placeholder{color:#aeabac}[_nghost-%COMP%] ng-select.ng-select.ng-select-single.ng-invalid.ng-touched .ng-select-container, [_nghost-%COMP%] ng-select.ng-select.ng-select-multiple.ng-invalid.ng-touched .ng-select-container{border-color:#bf1d30}[_nghost-%COMP%] ng-select.ng-select--multiple-height-increased.ng-select-multiple .ng-select-container{max-height:88px}[_nghost-%COMP%] ng-select.ng-select--multiple-height-increased.ng-select-multiple .ng-select-container .ng-value-container{max-height:88px}[_nghost-%COMP%] ng-select.ng-select--no-value-padding .ng-select-container .ng-value-container .ng-value, [_nghost-%COMP%] ng-select.ng-select--no-value-padding.ng-select-multiple .ng-select-container .ng-value-container .ng-value{padding:0}[_nghost-%COMP%] ng-select.ng-select--no-value-padding .ng-select-container .ng-value-container .ng-value .ng-select-user-label, [_nghost-%COMP%] ng-select.ng-select--no-value-padding.ng-select-multiple .ng-select-container .ng-value-container .ng-value .ng-select-user-label{height:100%}.ng-invalid.ng-touched[_nghost-%COMP%] ng-select.ng-select .ng-select-container{border-color:#bf1d30}[_nghost-%COMP%] .dr-select__loading[_ngcontent-%COMP%]{position:relative;height:32px;width:24px}.search-input[_nghost-%COMP%]{position:relative}.search-input[_nghost-%COMP%] .search-icon[_ngcontent-%COMP%]{position:absolute;top:4px;right:16px;color:#6d6e6f;z-index:1001}.search-input[_nghost-%COMP%] ng-select.ng-select .ng-select-container{border-radius:16px}.search-input[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-arrow-wrapper{display:none!important}.search-input[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-clear-wrapper{display:flex;justify-content:center;align-items:center;right:40px;top:1px;width:24px;height:24px}.search-input[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-clear-wrapper .ng-clear{font-size:24px;font-weight:300;color:#6d6e6f}.search-input[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-input, .search-input[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-value-container{padding:0 0 0 16px!important;width:calc(100% - 63px)}.search-input[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-input input, .search-input[_nghost-%COMP%] ng-select.ng-select .ng-select-container .ng-value-container input{height:100%} ng-dropdown-panel.ng-dropdown-panel.dr-select{font-family:Poppins,sans-serif;border:1px solid #dfe0e3;border-radius:4px!important;margin:8px 0;box-shadow:0 4px 8px 1px #00000040;background-color:#fff;overflow:hidden;padding:8px 0} ng-dropdown-panel.ng-dropdown-panel.dr-select.textView{width:auto!important} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option:empty{display:none} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option{display:flex;align-items:center;min-height:36px;padding:8px 12px;font-size:14px;line-height:22px;background:#fff} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option>.ng-option-label{text-overflow:ellipsis;overflow:hidden} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-marked{background:#f5f5f5} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-selected, ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-selected.ng-option-marked{background:#eaeaff;color:#333} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-selected span, ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-selected.ng-option-marked span{font-weight:400!important} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled{cursor:default} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled>div{color:#aeabac} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled>div.dr-select__option-with-desc__wrapper .dr-select__option-with-desc__description{color:#aeabac} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled[role=group]{font-size:14px;line-height:22px;color:#aeabac;cursor:default} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled[role=group]:not(:first-of-type){border-top:1px solid #dfe0e3} ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled[role=group]:hover{background:#fff} ng-dropdown-panel.ng-dropdown-panel.dr-select .dr-select__option-with-desc__wrapper{color:#333} ng-dropdown-panel.ng-dropdown-panel.dr-select .dr-select__option-with-desc__wrapper .dr-select__option-with-desc__description{max-width:-moz-fit-content;max-width:fit-content;word-break:break-word;white-space:normal;color:#6d6e6f;font-weight:400;font-size:12px;line-height:20px} ng-dropdown-panel.ng-dropdown-panel.dr-select.ng-option-selected .dr-select__option-with-desc__wrapper .dr-select__option-with-desc__description, ng-dropdown-panel.ng-dropdown-panel.dr-select.ng-option-selected.ng-option-marked .dr-select__option-with-desc__wrapper .dr-select__option-with-desc__description{color:#6d6e6f} .ng-dropdown-panel--with-search .ng-dropdown-header{border-bottom:none}.custom-backdrop[_ngcontent-%COMP%]{position:fixed;inset:0;overflow:hidden;pointer-events:none}"] }); }
324
324
  }
325
325
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrSelectComponent, [{
326
326
  type: Component,
@@ -330,7 +330,7 @@ export class DrSelectComponent {
330
330
  useExisting: DrSelectComponent,
331
331
  multi: true,
332
332
  },
333
- ], template: "<ng-select\n [(ngModel)]=\"selectedItem\"\n [items]=\"items\"\n [bindLabel]=\"bindLabel\"\n [bindValue]=\"bindValue\"\n [multiple]=\"multiple\"\n [addTag]=\"addTag\"\n [appendTo]=\"appendTo\"\n [clearable]=\"clearable\"\n [searchable]=\"searchable\"\n [hideSelected]=\"hideSelected\"\n [placeholder]=\"placeholder\"\n [loading]=\"loading\"\n [loadingText]=\"loadingText\"\n [readonly]=\"readonly\"\n [closeOnSelect]=\"closeOnSelect\"\n [disabled]=\"disabled\"\n [labelForId]=\"id\"\n [maxSelectedItems]=\"maxSelectedItems\"\n [keyDownFn]=\"keyDownFn\"\n [searchFn]=\"searchFn\"\n [isOpen]=\"(type !== 'search-input' || !!selectComponent.searchTerm?.length) && isOpen\"\n [groupBy]=\"groupBy\"\n [attr.autofocus]=\"autofocus\"\n [selectOnTab]=\"selectOnTabKeyPress\"\n [virtualScroll]=\"virtualScroll\"\n [typeahead]=\"typeahead\"\n (search)=\"search.emit($event)\"\n (scrollToEnd)=\"scrollToEnd.emit($event)\"\n (keydown.tab)=\"onTabKeypress($event)\"\n [compareWith]=\"compareWith\"\n (change)=\"onValueSelected(selectedItem)\"\n (open)=\"open.emit($event); onDropdownOpen()\"\n (close)=\"onClose($event)\"\n class=\"dr-select\"\n [class.ng-select--no-value-padding]=\"noValuePadding\"\n [class.ng-select--multiple-height-increased]=\"multipleHeightIncreased\"\n #selectComponent>\n <ng-template *ngIf=\"optionHeaderTemplate\" ng-header-tmp let-item=\"item\">\n <ng-container [ngTemplateOutlet]=\"optionHeaderTemplate\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-container>\n </ng-template>\n <ng-template\n ng-header-tmp\n *ngIf=\"!optionHeaderTemplate && isDisplayingSearchInHeader && items?.length >= minItemsToDisplaySearchInHeader\"\n let-item=\"item\">\n <dr-input\n class=\"dr-select__search\"\n [ngModel]=\"selectComponent.searchTerm\"\n (ngModelChange)=\"selectComponent.itemsList.filter($event + '')\"\n type=\"search\">\n </dr-input>\n </ng-template>\n <ng-template *ngIf=\"labelTemplate\" ng-label-tmp let-item=\"item\">\n <ng-container [ngTemplateOutlet]=\"labelTemplate\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-container>\n </ng-template>\n <ng-template *ngIf=\"multiLabelTemplate\" ng-multi-label-tmp let-items=\"items\" let-clear=\"clear\">\n <ng-container [ngTemplateOutlet]=\"multiLabelTemplate\" [ngTemplateOutletContext]=\"{ items: items, clear: clear }\">\n </ng-container>\n </ng-template>\n <ng-template *ngIf=\"optionTemplate\" ng-option-tmp let-item=\"item\" let-item$=\"item$\">\n <ng-container [ngTemplateOutlet]=\"optionTemplate\" [ngTemplateOutletContext]=\"{ item: item, item$: item$ }\"></ng-container>\n </ng-template>\n <ng-template *ngIf=\"optionWithDescription\" ng-option-tmp let-item=\"item\">\n <div class=\"dr-select__option-with-desc__wrapper\">\n <div>{{ item.name }}</div>\n <div class=\"dr-select__option-with-desc__description\">{{ item?.description }}</div>\n </div>\n </ng-template>\n <ng-template *ngIf=\"optionFooterTemplate\" ng-footer-tmp let-item=\"item\">\n <ng-container\n [ngTemplateOutlet]=\"optionFooterTemplate\"\n [ngTemplateOutletContext]=\"{ item: item, close: selectComponent.close.bind(selectComponent) }\"></ng-container>\n </ng-template>\n <ng-template *ngIf=\"groupBy\" ng-optgroup-tmp let-item=\"item\">\n {{ item[groupBy] }}\n </ng-template>\n <ng-template ng-loadingspinner-tmp>\n <div\n *ngIf=\"loading\"\n class=\"dr-select__loading\"\n [drSpinner]=\"loading\"\n [drSpinnerType]=\"'circle'\"\n [drSpinnerSize]=\"'small'\"\n [drSpinnerNoOverlay]=\"true\"></div>\n </ng-template>\n</ng-select>\n<i *ngIf=\"type === 'search-input'\" class=\"search-icon dr-icon-search\"></i>\n", styles: [":host{width:100%;height:32px;font-family:Poppins,sans-serif}:host.textView::ng-deep{width:auto}:host.textView::ng-deep ng-select.ng-select .ng-select-container{border:none!important;cursor:pointer}:host.textView::ng-deep ng-select.ng-select .ng-select-container .ng-value-container{padding:0;color:#4646ce}:host.textView::ng-deep ng-select.ng-select .ng-select-container .ng-value-container:hover{text-decoration-line:underline}:host.textView::ng-deep ng-select.ng-select .ng-select-container .ng-arrow-wrapper{display:none}:host.textView::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container,:host.textView::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container:hover,:host.textView::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container:focus-within{background:#fff!important;border:none!important;cursor:default}:host.textView::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container .ng-value,:host.textView::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container:hover .ng-value,:host.textView::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container:focus-within .ng-value{color:#aeabac!important}:host.textView::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container .ng-input input::placeholder{color:#aeabac}:host.textView::ng-deep ng-select.ng-select.ng-select-disabled .ng-value-container:hover{text-decoration-line:none}:host.no-left-border-radius ::ng-deep ng-select.ng-select .ng-select-container{border-bottom-left-radius:0!important;border-top-left-radius:0!important}:host.no-right-border-radius ::ng-deep ng-select.ng-select .ng-select-container{border-bottom-right-radius:0!important;border-top-right-radius:0!important}:host.no-right-border ::ng-deep ng-select.ng-select .ng-select-container{border-right:none!important}:host.no-left-border ::ng-deep ng-select.ng-select .ng-select-container{border-left:none!important}:host ::ng-deep ng-select.ng-select .ng-select-container{min-height:32px;height:32px;width:100%;border-radius:6px;border:1px solid #9ea1aa;box-shadow:none!important}:host ::ng-deep ng-select.ng-select .ng-select-container:hover{border-color:#4646ce}:host ::ng-deep ng-select.ng-select .ng-select-container:focus-within{border-color:#4646ce}:host ::ng-deep ng-select.ng-select .ng-select-container .ng-input{font-size:14px;line-height:24px;font-weight:400;top:0!important;padding:0 50px 0 8px!important;color:#333}:host ::ng-deep ng-select.ng-select .ng-select-container .ng-input input::placeholder{font-size:14px;line-height:24px;font-weight:400;color:#6d6e6f}:host ::ng-deep ng-select.ng-select .ng-select-container .ng-value-container{font-size:14px;line-height:24px;font-weight:400;padding:0 0 0 8px;height:100%;overflow:auto}:host ::ng-deep ng-select.ng-select .ng-select-container .ng-value-container .ng-input{padding:0 0 0 3px!important}:host ::ng-deep ng-select.ng-select .ng-select-container .ng-arrow-wrapper{margin-right:7px}:host ::ng-deep ng-select.ng-select .ng-select-container .ng-arrow-wrapper .ng-arrow{border:none;width:auto;height:auto;display:flex;text-decoration-line:none;top:0}:host ::ng-deep ng-select.ng-select .ng-select-container .ng-arrow-wrapper .ng-arrow:before{font-family:DataRails!important;content:\"\\ea17\";font-size:24px;color:#6d6e6f}:host ::ng-deep ng-select.ng-select.ng-select-opened .ng-select-container{border-radius:6px}:host ::ng-deep ng-select.ng-select.ng-select-multiple .ng-select-container{max-height:58px;height:100%}:host ::ng-deep ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container{font-size:14px;line-height:24px;font-weight:400;max-height:58px}:host ::ng-deep ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value{font-size:12px;line-height:16px;font-weight:400;color:#333;height:24px;padding:2px 16px;margin:2px 4px 2px 0;background:#f0f1f4;display:flex;flex-direction:row-reverse;align-items:center;border-radius:12px}:host ::ng-deep ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-label{padding:0!important}:host ::ng-deep ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-icon{border:none!important;padding:0!important;width:20px;display:flex;align-items:center;color:transparent;margin-left:4px}:host ::ng-deep ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-icon:before{font-family:DataRails!important;content:\"\\ea75\";font-size:20px;color:#333}:host ::ng-deep ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-icon,:host ::ng-deep ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-icon:hover{background:transparent!important}:host ::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container,:host ::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container:hover,:host ::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container:focus-within{background:#f0f1f4!important;border:1px solid #aeabac!important}:host ::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container .ng-value,:host ::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container:hover .ng-value,:host ::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container:focus-within .ng-value{color:#aeabac!important}:host ::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container .ng-arrow{color:#aeabac}:host ::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container .ng-arrow:before{color:#aeabac}:host ::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container .ng-input input::placeholder{color:#aeabac}:host ::ng-deep ng-select.ng-select.ng-select-single.ng-invalid.ng-touched .ng-select-container,:host ::ng-deep ng-select.ng-select.ng-select-multiple.ng-invalid.ng-touched .ng-select-container{border-color:#bf1d30}:host ::ng-deep ng-select.ng-select--multiple-height-increased.ng-select-multiple .ng-select-container{max-height:88px}:host ::ng-deep ng-select.ng-select--multiple-height-increased.ng-select-multiple .ng-select-container .ng-value-container{max-height:88px}:host ::ng-deep ng-select.ng-select--no-value-padding .ng-select-container .ng-value-container .ng-value,:host ::ng-deep ng-select.ng-select--no-value-padding.ng-select-multiple .ng-select-container .ng-value-container .ng-value{padding:0}:host ::ng-deep ng-select.ng-select--no-value-padding .ng-select-container .ng-value-container .ng-value .ng-select-user-label,:host ::ng-deep ng-select.ng-select--no-value-padding.ng-select-multiple .ng-select-container .ng-value-container .ng-value .ng-select-user-label{height:100%}:host.ng-invalid.ng-touched::ng-deep ng-select.ng-select .ng-select-container{border-color:#bf1d30}:host .dr-select__loading{position:relative;height:32px;width:24px}:host.search-input{position:relative}:host.search-input .search-icon{position:absolute;top:4px;right:16px;color:#6d6e6f;z-index:1001}:host.search-input::ng-deep ng-select.ng-select .ng-select-container{border-radius:16px}:host.search-input::ng-deep ng-select.ng-select .ng-select-container .ng-arrow-wrapper{display:none!important}:host.search-input::ng-deep ng-select.ng-select .ng-select-container .ng-clear-wrapper{display:flex;justify-content:center;align-items:center;right:40px;top:1px;width:24px;height:24px}:host.search-input::ng-deep ng-select.ng-select .ng-select-container .ng-clear-wrapper .ng-clear{font-size:24px;font-weight:300;color:#6d6e6f}:host.search-input::ng-deep ng-select.ng-select .ng-select-container .ng-input,:host.search-input::ng-deep ng-select.ng-select .ng-select-container .ng-value-container{padding:0 0 0 16px!important;width:calc(100% - 63px)}:host.search-input::ng-deep ng-select.ng-select .ng-select-container .ng-input input,:host.search-input::ng-deep ng-select.ng-select .ng-select-container .ng-value-container input{height:100%}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select{font-family:Poppins,sans-serif;border:1px solid #dfe0e3;border-radius:4px!important;margin:8px 0;box-shadow:0 4px 8px 1px #00000040;background-color:#fff;overflow:hidden;padding:8px 0}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select.textView{width:auto!important}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option:empty{display:none}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option{display:flex;align-items:center;min-height:36px;padding:8px 12px;font-size:14px;line-height:22px;background:#fff}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option>.ng-option-label{text-overflow:ellipsis;overflow:hidden}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-marked{background:#f5f5f5}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-selected,::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-selected.ng-option-marked{background:#eaeaff;color:#333}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-selected span,::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-selected.ng-option-marked span{font-weight:400!important}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled{cursor:default}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled>div{color:#aeabac}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled>div.dr-select__option-with-desc__wrapper .dr-select__option-with-desc__description{color:#aeabac}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled[role=group]{font-size:14px;line-height:22px;color:#aeabac;cursor:default}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled[role=group]:not(:first-of-type){border-top:1px solid #dfe0e3}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled[role=group]:hover{background:#fff}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .dr-select__option-with-desc__wrapper{color:#333}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .dr-select__option-with-desc__wrapper .dr-select__option-with-desc__description{max-width:-moz-fit-content;max-width:fit-content;word-break:break-word;white-space:normal;color:#6d6e6f;font-weight:400;font-size:12px;line-height:20px}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select.ng-option-selected .dr-select__option-with-desc__wrapper .dr-select__option-with-desc__description,::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select.ng-option-selected.ng-option-marked .dr-select__option-with-desc__wrapper .dr-select__option-with-desc__description{color:#6d6e6f}::ng-deep .ng-dropdown-panel--with-search .ng-dropdown-header{border-bottom:none}.custom-backdrop{position:fixed;inset:0;overflow:hidden;pointer-events:none}\n"] }]
333
+ ], template: "<ng-select\n [(ngModel)]=\"selectedItem\"\n [items]=\"items\"\n [bindLabel]=\"bindLabel\"\n [bindValue]=\"bindValue\"\n [multiple]=\"multiple\"\n [addTag]=\"addTag\"\n [appendTo]=\"appendTo\"\n [clearable]=\"clearable\"\n [searchable]=\"searchable\"\n [hideSelected]=\"hideSelected\"\n [placeholder]=\"placeholder\"\n [loading]=\"loading\"\n [loadingText]=\"loadingText\"\n [readonly]=\"readonly\"\n [closeOnSelect]=\"closeOnSelect\"\n [disabled]=\"disabled\"\n [labelForId]=\"id\"\n [maxSelectedItems]=\"maxSelectedItems\"\n [keyDownFn]=\"keyDownFn\"\n [searchFn]=\"searchFn\"\n [isOpen]=\"(type !== 'search-input' || !!selectComponent.searchTerm?.length) && isOpen\"\n [groupBy]=\"groupBy\"\n [attr.autofocus]=\"autofocus\"\n [selectOnTab]=\"selectOnTabKeyPress\"\n [virtualScroll]=\"virtualScroll\"\n [typeahead]=\"typeahead\"\n (search)=\"search.emit($event)\"\n (scrollToEnd)=\"scrollToEnd.emit($event)\"\n (keydown.tab)=\"onTabKeypress($event)\"\n [compareWith]=\"compareWith\"\n (change)=\"onValueSelected(selectedItem)\"\n (open)=\"open.emit($event); onDropdownOpen()\"\n (close)=\"onClose($event)\"\n class=\"dr-select\"\n [class.ng-select--no-value-padding]=\"noValuePadding\"\n [class.ng-select--multiple-height-increased]=\"multipleHeightIncreased\"\n #selectComponent>\n <ng-template *ngIf=\"optionHeaderTemplate\" ng-header-tmp let-item=\"item\">\n <ng-container [ngTemplateOutlet]=\"optionHeaderTemplate\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-container>\n </ng-template>\n <ng-template\n ng-header-tmp\n *ngIf=\"!optionHeaderTemplate && isDisplayingSearchInHeader && items?.length >= minItemsToDisplaySearchInHeader\"\n let-item=\"item\">\n <dr-input\n class=\"dr-select__search\"\n [ngModel]=\"selectComponent.searchTerm\"\n (ngModelChange)=\"selectComponent.itemsList.filter($event + '')\"\n type=\"search\">\n </dr-input>\n </ng-template>\n <ng-template *ngIf=\"labelTemplate\" ng-label-tmp let-item=\"item\">\n <ng-container [ngTemplateOutlet]=\"labelTemplate\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-container>\n </ng-template>\n <ng-template *ngIf=\"multiLabelTemplate\" ng-multi-label-tmp let-items=\"items\" let-clear=\"clear\">\n <ng-container [ngTemplateOutlet]=\"multiLabelTemplate\" [ngTemplateOutletContext]=\"{ items: items, clear: clear }\">\n </ng-container>\n </ng-template>\n <ng-template *ngIf=\"optionTemplate\" ng-option-tmp let-item=\"item\" let-item$=\"item$\">\n <ng-container [ngTemplateOutlet]=\"optionTemplate\" [ngTemplateOutletContext]=\"{ item: item, item$: item$ }\"></ng-container>\n </ng-template>\n <ng-template *ngIf=\"optionWithDescription\" ng-option-tmp let-item=\"item\">\n <div class=\"dr-select__option-with-desc__wrapper\">\n <div>{{ item.name }}</div>\n <div class=\"dr-select__option-with-desc__description\">{{ item?.description }}</div>\n </div>\n </ng-template>\n <ng-template *ngIf=\"optionFooterTemplate\" ng-footer-tmp let-item=\"item\">\n <ng-container\n [ngTemplateOutlet]=\"optionFooterTemplate\"\n [ngTemplateOutletContext]=\"{ item: item, close: selectComponent.close.bind(selectComponent) }\"></ng-container>\n </ng-template>\n <ng-template *ngIf=\"groupBy\" ng-optgroup-tmp let-item=\"item\">\n {{ item[groupBy] }}\n </ng-template>\n <ng-template ng-loadingspinner-tmp>\n <div\n *ngIf=\"loading\"\n class=\"dr-select__loading\"\n [drSpinner]=\"loading\"\n [drSpinnerType]=\"'circle'\"\n [drSpinnerSize]=\"'small'\"\n [drSpinnerNoOverlay]=\"true\"></div>\n </ng-template>\n</ng-select>\n<i *ngIf=\"type === 'search-input'\" class=\"search-icon dr-icon-search\"></i>\n", styles: [":host{width:100%;height:32px;font-family:Poppins,sans-serif}:host.textView::ng-deep{width:auto}:host.textView::ng-deep ng-select.ng-select .ng-select-container{border:none!important;cursor:pointer}:host.textView::ng-deep ng-select.ng-select .ng-select-container .ng-value-container{padding:0;color:#4646ce}:host.textView::ng-deep ng-select.ng-select .ng-select-container .ng-value-container:hover{text-decoration-line:underline}:host.textView::ng-deep ng-select.ng-select .ng-select-container .ng-arrow-wrapper{display:none}:host.textView::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container,:host.textView::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container:hover,:host.textView::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container:focus-within{background:#fff!important;border:none!important;cursor:default}:host.textView::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container .ng-value,:host.textView::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container:hover .ng-value,:host.textView::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container:focus-within .ng-value{color:#aeabac!important}:host.textView::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container .ng-input input::placeholder{color:#aeabac}:host.textView::ng-deep ng-select.ng-select.ng-select-disabled .ng-value-container:hover{text-decoration-line:none}:host.no-left-border-radius ::ng-deep ng-select.ng-select .ng-select-container{border-bottom-left-radius:0!important;border-top-left-radius:0!important}:host.no-right-border-radius ::ng-deep ng-select.ng-select .ng-select-container{border-bottom-right-radius:0!important;border-top-right-radius:0!important}:host.no-right-border ::ng-deep ng-select.ng-select .ng-select-container{border-right:none!important}:host.no-left-border ::ng-deep ng-select.ng-select .ng-select-container{border-left:none!important}:host ::ng-deep ng-select.ng-select .ng-select-container{min-height:32px;height:32px;width:100%;border-radius:6px;border:1px solid #9ea1aa;box-shadow:none!important}:host ::ng-deep ng-select.ng-select .ng-select-container:hover{border-color:#4646ce}:host ::ng-deep ng-select.ng-select .ng-select-container:focus-within{border-color:#4646ce}:host ::ng-deep ng-select.ng-select .ng-select-container .ng-input{font-size:14px;line-height:24px;font-weight:400;top:0!important;padding:0 50px 0 8px!important;color:#333}:host ::ng-deep ng-select.ng-select .ng-select-container .ng-input input::placeholder{font-size:14px;line-height:24px;font-weight:400;color:#6d6e6f}:host ::ng-deep ng-select.ng-select .ng-select-container .ng-value-container{font-size:14px;line-height:24px;font-weight:400;padding:0 0 0 8px;height:100%;overflow:auto}:host ::ng-deep ng-select.ng-select .ng-select-container .ng-value-container .ng-input{padding:0 0 0 3px!important}:host ::ng-deep ng-select.ng-select .ng-select-container .ng-arrow-wrapper{margin-right:7px}:host ::ng-deep ng-select.ng-select .ng-select-container .ng-arrow-wrapper .ng-arrow{border:none;width:auto;height:auto;display:flex;text-decoration-line:none;top:0}:host ::ng-deep ng-select.ng-select .ng-select-container .ng-arrow-wrapper .ng-arrow:before{font-family:DataRails!important;content:\"\\ea17\";font-size:24px;color:#6d6e6f}:host ::ng-deep ng-select.ng-select.ng-select-opened .ng-select-container{border-radius:6px}:host ::ng-deep ng-select.ng-select.ng-select-multiple .ng-select-container{max-height:58px;height:100%}:host ::ng-deep ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container{font-size:14px;line-height:24px;font-weight:400;max-height:58px}:host ::ng-deep ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value{font-size:12px;line-height:16px;font-weight:400;color:#333;height:24px;padding:2px 16px;margin:2px 4px 2px 0;background:#f0f1f4;display:flex;flex-direction:row-reverse;align-items:center;border-radius:12px}:host ::ng-deep ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-label{padding:0!important}:host ::ng-deep ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-icon{border:none!important;padding:0!important;width:20px;display:flex;align-items:center;color:transparent;margin-left:4px}:host ::ng-deep ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-icon:before{font-family:DataRails!important;content:\"\\ea74\";font-size:20px;color:#333}:host ::ng-deep ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-icon,:host ::ng-deep ng-select.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value-icon:hover{background:transparent!important}:host ::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container,:host ::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container:hover,:host ::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container:focus-within{background:#f0f1f4!important;border:1px solid #aeabac!important}:host ::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container .ng-value,:host ::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container:hover .ng-value,:host ::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container:focus-within .ng-value{color:#aeabac!important}:host ::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container .ng-arrow{color:#aeabac}:host ::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container .ng-arrow:before{color:#aeabac}:host ::ng-deep ng-select.ng-select.ng-select-disabled .ng-select-container .ng-input input::placeholder{color:#aeabac}:host ::ng-deep ng-select.ng-select.ng-select-single.ng-invalid.ng-touched .ng-select-container,:host ::ng-deep ng-select.ng-select.ng-select-multiple.ng-invalid.ng-touched .ng-select-container{border-color:#bf1d30}:host ::ng-deep ng-select.ng-select--multiple-height-increased.ng-select-multiple .ng-select-container{max-height:88px}:host ::ng-deep ng-select.ng-select--multiple-height-increased.ng-select-multiple .ng-select-container .ng-value-container{max-height:88px}:host ::ng-deep ng-select.ng-select--no-value-padding .ng-select-container .ng-value-container .ng-value,:host ::ng-deep ng-select.ng-select--no-value-padding.ng-select-multiple .ng-select-container .ng-value-container .ng-value{padding:0}:host ::ng-deep ng-select.ng-select--no-value-padding .ng-select-container .ng-value-container .ng-value .ng-select-user-label,:host ::ng-deep ng-select.ng-select--no-value-padding.ng-select-multiple .ng-select-container .ng-value-container .ng-value .ng-select-user-label{height:100%}:host.ng-invalid.ng-touched::ng-deep ng-select.ng-select .ng-select-container{border-color:#bf1d30}:host .dr-select__loading{position:relative;height:32px;width:24px}:host.search-input{position:relative}:host.search-input .search-icon{position:absolute;top:4px;right:16px;color:#6d6e6f;z-index:1001}:host.search-input::ng-deep ng-select.ng-select .ng-select-container{border-radius:16px}:host.search-input::ng-deep ng-select.ng-select .ng-select-container .ng-arrow-wrapper{display:none!important}:host.search-input::ng-deep ng-select.ng-select .ng-select-container .ng-clear-wrapper{display:flex;justify-content:center;align-items:center;right:40px;top:1px;width:24px;height:24px}:host.search-input::ng-deep ng-select.ng-select .ng-select-container .ng-clear-wrapper .ng-clear{font-size:24px;font-weight:300;color:#6d6e6f}:host.search-input::ng-deep ng-select.ng-select .ng-select-container .ng-input,:host.search-input::ng-deep ng-select.ng-select .ng-select-container .ng-value-container{padding:0 0 0 16px!important;width:calc(100% - 63px)}:host.search-input::ng-deep ng-select.ng-select .ng-select-container .ng-input input,:host.search-input::ng-deep ng-select.ng-select .ng-select-container .ng-value-container input{height:100%}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select{font-family:Poppins,sans-serif;border:1px solid #dfe0e3;border-radius:4px!important;margin:8px 0;box-shadow:0 4px 8px 1px #00000040;background-color:#fff;overflow:hidden;padding:8px 0}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select.textView{width:auto!important}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option:empty{display:none}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option{display:flex;align-items:center;min-height:36px;padding:8px 12px;font-size:14px;line-height:22px;background:#fff}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option>.ng-option-label{text-overflow:ellipsis;overflow:hidden}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-marked{background:#f5f5f5}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-selected,::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-selected.ng-option-marked{background:#eaeaff;color:#333}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-selected span,::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-selected.ng-option-marked span{font-weight:400!important}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled{cursor:default}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled>div{color:#aeabac}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled>div.dr-select__option-with-desc__wrapper .dr-select__option-with-desc__description{color:#aeabac}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled[role=group]{font-size:14px;line-height:22px;color:#aeabac;cursor:default}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled[role=group]:not(:first-of-type){border-top:1px solid #dfe0e3}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .ng-dropdown-panel-items .ng-option.ng-option-disabled[role=group]:hover{background:#fff}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .dr-select__option-with-desc__wrapper{color:#333}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select .dr-select__option-with-desc__wrapper .dr-select__option-with-desc__description{max-width:-moz-fit-content;max-width:fit-content;word-break:break-word;white-space:normal;color:#6d6e6f;font-weight:400;font-size:12px;line-height:20px}::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select.ng-option-selected .dr-select__option-with-desc__wrapper .dr-select__option-with-desc__description,::ng-deep ng-dropdown-panel.ng-dropdown-panel.dr-select.ng-option-selected.ng-option-marked .dr-select__option-with-desc__wrapper .dr-select__option-with-desc__description{color:#6d6e6f}::ng-deep .ng-dropdown-panel--with-search .ng-dropdown-header{border-bottom:none}.custom-backdrop{position:fixed;inset:0;overflow:hidden;pointer-events:none}\n"] }]
334
334
  }], function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, { type: [{
335
335
  type: Input
336
336
  }, {
@@ -0,0 +1,130 @@
1
+ import { ChangeDetectorRef, Component, ElementRef, EventEmitter, inject, Input, numberAttribute, Output, Renderer2, ViewChild, } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ const _c0 = ["container"];
6
+ function DrListOverflowComponent_div_3_Template(rf, ctx) { if (rf & 1) {
7
+ i0.ɵɵelementStart(0, "div", 4);
8
+ i0.ɵɵtext(1, "...");
9
+ i0.ɵɵelementEnd();
10
+ } }
11
+ function DrListOverflowComponent_div_4_Template(rf, ctx) { if (rf & 1) {
12
+ i0.ɵɵelementStart(0, "div", 5);
13
+ i0.ɵɵtext(1);
14
+ i0.ɵɵelementEnd();
15
+ } if (rf & 2) {
16
+ const ctx_r2 = i0.ɵɵnextContext();
17
+ i0.ɵɵstyleProp("width", ctx_r2.drListCounterWidth, "px");
18
+ i0.ɵɵadvance(1);
19
+ i0.ɵɵtextInterpolate1(", +", ctx_r2.overflowed, "");
20
+ } }
21
+ const _c1 = ["*"];
22
+ /**
23
+ * Calculate number in HORIZONTAL list that has been overflowed
24
+ */
25
+ export class DrListOverflowComponent {
26
+ constructor() {
27
+ this.drListCounterWidth = 25;
28
+ /** Number of items that have been overflowed */
29
+ this.drListOverflowedChange = new EventEmitter();
30
+ this.cdr = inject(ChangeDetectorRef);
31
+ this.renderer = inject(Renderer2);
32
+ this.mutationObserver = new MutationObserver(() => this.calculate());
33
+ this.overflowed = 0;
34
+ this.hasEllipsis = false;
35
+ this.usedWidth = 0;
36
+ }
37
+ get hasOverflowed() {
38
+ return !!this.overflowed || this.hasEllipsis;
39
+ }
40
+ ngOnInit() {
41
+ this.mutationObserver.observe(this.container.nativeElement, { childList: true, subtree: false });
42
+ }
43
+ ngOnDestroy() {
44
+ this.mutationObserver.disconnect();
45
+ }
46
+ calculate() {
47
+ const container = this.container.nativeElement;
48
+ const items = Array.from(container.children);
49
+ let usedWidth = 0;
50
+ let rendered = 0;
51
+ this.usedWidth = 0;
52
+ this.overflowed = 0; // to get container without the counter
53
+ this.hasEllipsis = false;
54
+ this.cdr.detectChanges();
55
+ if (items.length === 0) {
56
+ console.error('No items found in dr-list-overflow. Please make sure all children are a HTMLElements and not just plain text node.');
57
+ }
58
+ for (const [index, child] of items.entries()) {
59
+ const prev = items[index - 1];
60
+ const prevUsedWidth = usedWidth;
61
+ usedWidth += child.getBoundingClientRect().width; // we need clientRect width, as offsetWidth is an integer
62
+ // we need this as the container is flexible and can be wider (we don't know the exact width at the start)
63
+ this.updateWidth(usedWidth);
64
+ const containerWidth = container.getBoundingClientRect().width; // we need clientRect width, as clientWidth is an integer
65
+ const isOverflowed = this.usedWidth > containerWidth;
66
+ const isOverflowedPrevWithCounter = prev && prevUsedWidth > containerWidth - this.drListCounterWidth;
67
+ // if the first item is larger than the container - we need to render it anyway, but with ellipsis
68
+ if (isOverflowed && rendered === 0) {
69
+ rendered++;
70
+ this.hasEllipsis = true;
71
+ break;
72
+ }
73
+ // if an item is overflowed and counter makes prev item overflow as well - we need to hide this and prev items
74
+ if (isOverflowed && isOverflowedPrevWithCounter) {
75
+ rendered--;
76
+ this.updateWidth(prevUsedWidth - prev.getBoundingClientRect().width);
77
+ break;
78
+ }
79
+ // if an item is overflowed - hide it
80
+ if (isOverflowed) {
81
+ this.updateWidth(prevUsedWidth);
82
+ break;
83
+ }
84
+ rendered++;
85
+ }
86
+ // "hide" all overflowed items so they don't appear in innerText (textContent still includes all text, even hidden items)
87
+ // this prevents tests from picking up overflowed text
88
+ items.forEach((item, index) => this.renderer.setStyle(item, 'visibility', index < rendered ? 'visible' : 'hidden'));
89
+ this.overflowed = items.length - rendered;
90
+ this.drListOverflowedChange.emit(this.overflowed);
91
+ this.cdr.markForCheck();
92
+ }
93
+ /** Immediately update the container width to check whether items are overflowing or the container just became wider */
94
+ updateWidth(width) {
95
+ this.usedWidth = width;
96
+ this.renderer.setStyle(this.container.nativeElement, 'width', `${width}px`);
97
+ }
98
+ /** @nocollapse */ static { this.ɵfac = function DrListOverflowComponent_Factory(t) { return new (t || DrListOverflowComponent)(); }; }
99
+ /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrListOverflowComponent, selectors: [["dr-list-overflow"], ["", "drListOverflow", ""]], viewQuery: function DrListOverflowComponent_Query(rf, ctx) { if (rf & 1) {
100
+ i0.ɵɵviewQuery(_c0, 7);
101
+ } if (rf & 2) {
102
+ let _t;
103
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.container = _t.first);
104
+ } }, inputs: { drListCounterWidth: ["drListCounterWidth", "drListCounterWidth", numberAttribute] }, outputs: { drListOverflowedChange: "drListOverflowedChange" }, exportAs: ["listOverflow"], standalone: true, features: [i0.ɵɵInputTransformsFeature, i0.ɵɵStandaloneFeature], ngContentSelectors: _c1, decls: 5, vars: 2, consts: [[1, "overflow-container"], ["container", ""], ["class", "overflow-ellipsis", 4, "ngIf"], ["class", "overflow-counter", 3, "width", 4, "ngIf"], [1, "overflow-ellipsis"], [1, "overflow-counter"]], template: function DrListOverflowComponent_Template(rf, ctx) { if (rf & 1) {
105
+ i0.ɵɵprojectionDef();
106
+ i0.ɵɵelementStart(0, "div", 0, 1);
107
+ i0.ɵɵprojection(2);
108
+ i0.ɵɵelementEnd();
109
+ i0.ɵɵtemplate(3, DrListOverflowComponent_div_3_Template, 2, 0, "div", 2);
110
+ i0.ɵɵtemplate(4, DrListOverflowComponent_div_4_Template, 2, 3, "div", 3);
111
+ } if (rf & 2) {
112
+ i0.ɵɵadvance(3);
113
+ i0.ɵɵproperty("ngIf", ctx.hasEllipsis);
114
+ i0.ɵɵadvance(1);
115
+ i0.ɵɵproperty("ngIf", ctx.overflowed);
116
+ } }, dependencies: [CommonModule, i1.NgIf], styles: ["[_nghost-%COMP%]{display:flex;align-items:center;max-width:100%;min-width:0}.overflow-container[_ngcontent-%COMP%]{position:relative;display:flex;max-width:100%;overflow:hidden;white-space:nowrap}.overflow-container[_ngcontent-%COMP%] >*{flex-shrink:0;white-space:nowrap}.overflow-ellipsis[_ngcontent-%COMP%], .overflow-counter[_ngcontent-%COMP%]{text-align:left;white-space:nowrap}"] }); }
117
+ }
118
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrListOverflowComponent, [{
119
+ type: Component,
120
+ args: [{ standalone: true, exportAs: 'listOverflow', selector: 'dr-list-overflow, [drListOverflow]', imports: [CommonModule], template: "<div #container class=\"overflow-container\">\n <ng-content></ng-content>\n</div>\n\n<div *ngIf=\"hasEllipsis\" class=\"overflow-ellipsis\">...</div>\n<div *ngIf=\"overflowed\" class=\"overflow-counter\" [style.width.px]=\"drListCounterWidth\">, +{{ overflowed }}</div>\n", styles: [":host{display:flex;align-items:center;max-width:100%;min-width:0}.overflow-container{position:relative;display:flex;max-width:100%;overflow:hidden;white-space:nowrap}.overflow-container ::ng-deep>*{flex-shrink:0;white-space:nowrap}.overflow-ellipsis,.overflow-counter{text-align:left;white-space:nowrap}\n"] }]
121
+ }], null, { drListCounterWidth: [{
122
+ type: Input,
123
+ args: [{ transform: numberAttribute }]
124
+ }], drListOverflowedChange: [{
125
+ type: Output
126
+ }], container: [{
127
+ type: ViewChild,
128
+ args: ['container', { static: true }]
129
+ }] }); })();
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-list-overflow.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-list-overflow/dr-list-overflow.component.ts","../../../../../projects/datarailsshared/src/lib/dr-list-overflow/dr-list-overflow.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,MAAM,EACN,KAAK,EACL,eAAe,EAGf,MAAM,EACN,SAAS,EACT,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;;;;;ICV/C,8BAAmD;IAAA,mBAAG;IAAA,iBAAM;;;IAC5D,8BAAuF;IAAA,YAAmB;IAAA,iBAAM;;;IAA/D,wDAAqC;IAAC,eAAmB;IAAnB,mDAAmB;;;ADW1G;;GAEG;AASH,MAAM,OAAO,uBAAuB;IARpC;QAS2C,uBAAkB,GAAG,EAAE,CAAC;QAE/D,gDAAgD;QACtC,2BAAsB,GAAG,IAAI,YAAY,EAAU,CAAC;QAI7C,QAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAChC,aAAQ,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;QAE7B,qBAAgB,GAAG,IAAI,gBAAgB,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QAE1E,eAAU,GAAG,CAAC,CAAC;QAEf,gBAAW,GAAG,KAAK,CAAC;QAEpB,cAAS,GAAG,CAAC,CAAC;KAmFxB;IAjFG,IAAW,aAAa;QACpB,OAAO,CAAC,CAAC,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,WAAW,CAAC;IACjD,CAAC;IAEM,QAAQ;QACX,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;IACrG,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC;IACvC,CAAC;IAEO,SAAS;QACb,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC;QAC/C,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAkB,CAAC;QAE9D,IAAI,SAAS,GAAG,CAAC,CAAC;QAClB,IAAI,QAAQ,GAAG,CAAC,CAAC;QAEjB,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;QACnB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC,uCAAuC;QAC5D,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QAEzB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAEzB,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;YACpB,OAAO,CAAC,KAAK,CACT,oHAAoH,CACvH,CAAC;SACL;QAED,KAAK,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,KAAK,CAAC,OAAO,EAAE,EAAE;YAC1C,MAAM,IAAI,GAAG,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;YAC9B,MAAM,aAAa,GAAG,SAAS,CAAC;YAEhC,SAAS,IAAI,KAAK,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC,CAAC,yDAAyD;YAE3G,0GAA0G;YAC1G,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;YAE5B,MAAM,cAAc,GAAG,SAAS,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC,CAAC,yDAAyD;YACzH,MAAM,YAAY,GAAG,IAAI,CAAC,SAAS,GAAG,cAAc,CAAC;YACrD,MAAM,2BAA2B,GAAG,IAAI,IAAI,aAAa,GAAG,cAAc,GAAG,IAAI,CAAC,kBAAkB,CAAC;YAErG,kGAAkG;YAClG,IAAI,YAAY,IAAI,QAAQ,KAAK,CAAC,EAAE;gBAChC,QAAQ,EAAE,CAAC;gBACX,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;gBACxB,MAAM;aACT;YAED,8GAA8G;YAC9G,IAAI,YAAY,IAAI,2BAA2B,EAAE;gBAC7C,QAAQ,EAAE,CAAC;gBACX,IAAI,CAAC,WAAW,CAAC,aAAa,GAAG,IAAI,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC,CAAC;gBACrE,MAAM;aACT;YAED,qCAAqC;YACrC,IAAI,YAAY,EAAE;gBACd,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;gBAChC,MAAM;aACT;YAED,QAAQ,EAAE,CAAC;SACd;QAED,yHAAyH;QACzH,sDAAsD;QACtD,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,YAAY,EAAE,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;QAEpH,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,MAAM,GAAG,QAAQ,CAAC;QAC1C,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAClD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC5B,CAAC;IAED,uHAAuH;IAC/G,WAAW,CAAC,KAAa;QAC7B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,OAAO,EAAE,GAAG,KAAK,IAAI,CAAC,CAAC;IAChF,CAAC;2GAnGQ,uBAAuB;mGAAvB,uBAAuB;;;;;wFACZ,eAAe;;YC5BvC,iCAA2C;YACvC,kBAAyB;YAC7B,iBAAM;YAEN,wEAA4D;YAC5D,wEAAgH;;YAD1G,eAAiB;YAAjB,sCAAiB;YACjB,eAAgB;YAAhB,qCAAgB;4BDoBR,YAAY;;uFAEb,uBAAuB;cARnC,SAAS;6BACM,IAAI,YACN,cAAc,YACd,oCAAoC,WAGrC,CAAC,YAAY,CAAC;gBAGgB,kBAAkB;kBAAxD,KAAK;mBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;YAG3B,sBAAsB;kBAA/B,MAAM;YAEmC,SAAS;kBAAlD,SAAS;mBAAC,WAAW,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import {\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Input,\n    numberAttribute,\n    OnDestroy,\n    OnInit,\n    Output,\n    Renderer2,\n    ViewChild,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\n/**\n * Calculate number in HORIZONTAL list that has been overflowed\n */\n@Component({\n    standalone: true,\n    exportAs: 'listOverflow',\n    selector: 'dr-list-overflow, [drListOverflow]',\n    templateUrl: './dr-list-overflow.component.html',\n    styleUrls: ['./dr-list-overflow.component.scss'],\n    imports: [CommonModule],\n})\nexport class DrListOverflowComponent implements OnInit, OnDestroy {\n    @Input({ transform: numberAttribute }) drListCounterWidth = 25;\n\n    /** Number of items that have been overflowed */\n    @Output() drListOverflowedChange = new EventEmitter<number>();\n\n    @ViewChild('container', { static: true }) container!: ElementRef<HTMLElement>;\n\n    private readonly cdr = inject(ChangeDetectorRef);\n    private readonly renderer = inject(Renderer2);\n\n    private readonly mutationObserver = new MutationObserver(() => this.calculate());\n\n    public overflowed = 0;\n\n    public hasEllipsis = false;\n\n    public usedWidth = 0;\n\n    public get hasOverflowed() {\n        return !!this.overflowed || this.hasEllipsis;\n    }\n\n    public ngOnInit() {\n        this.mutationObserver.observe(this.container.nativeElement, { childList: true, subtree: false });\n    }\n\n    public ngOnDestroy() {\n        this.mutationObserver.disconnect();\n    }\n\n    private calculate() {\n        const container = this.container.nativeElement;\n        const items = Array.from(container.children) as HTMLElement[];\n\n        let usedWidth = 0;\n        let rendered = 0;\n\n        this.usedWidth = 0;\n        this.overflowed = 0; // to get container without the counter\n        this.hasEllipsis = false;\n\n        this.cdr.detectChanges();\n\n        if (items.length === 0) {\n            console.error(\n                'No items found in dr-list-overflow. Please make sure all children are a HTMLElements and not just plain text node.',\n            );\n        }\n\n        for (const [index, child] of items.entries()) {\n            const prev = items[index - 1];\n            const prevUsedWidth = usedWidth;\n\n            usedWidth += child.getBoundingClientRect().width; // we need clientRect width, as offsetWidth is an integer\n\n            // we need this as the container is flexible and can be wider (we don't know the exact width at the start)\n            this.updateWidth(usedWidth);\n\n            const containerWidth = container.getBoundingClientRect().width; // we need clientRect width, as clientWidth is an integer\n            const isOverflowed = this.usedWidth > containerWidth;\n            const isOverflowedPrevWithCounter = prev && prevUsedWidth > containerWidth - this.drListCounterWidth;\n\n            // if the first item is larger than the container - we need to render it anyway, but with ellipsis\n            if (isOverflowed && rendered === 0) {\n                rendered++;\n                this.hasEllipsis = true;\n                break;\n            }\n\n            // if an item is overflowed and counter makes prev item overflow as well - we need to hide this and prev items\n            if (isOverflowed && isOverflowedPrevWithCounter) {\n                rendered--;\n                this.updateWidth(prevUsedWidth - prev.getBoundingClientRect().width);\n                break;\n            }\n\n            // if an item is overflowed - hide it\n            if (isOverflowed) {\n                this.updateWidth(prevUsedWidth);\n                break;\n            }\n\n            rendered++;\n        }\n\n        // \"hide\" all overflowed items so they don't appear in innerText (textContent still includes all text, even hidden items)\n        // this prevents tests from picking up overflowed text\n        items.forEach((item, index) => this.renderer.setStyle(item, 'visibility', index < rendered ? 'visible' : 'hidden'));\n\n        this.overflowed = items.length - rendered;\n        this.drListOverflowedChange.emit(this.overflowed);\n        this.cdr.markForCheck();\n    }\n\n    /** Immediately update the container width to check whether items are overflowing or the container just became wider */\n    private updateWidth(width: number) {\n        this.usedWidth = width;\n        this.renderer.setStyle(this.container.nativeElement, 'width', `${width}px`);\n    }\n}\n","<div #container class=\"overflow-container\">\n    <ng-content></ng-content>\n</div>\n\n<div *ngIf=\"hasEllipsis\" class=\"overflow-ellipsis\">...</div>\n<div *ngIf=\"overflowed\" class=\"overflow-counter\" [style.width.px]=\"drListCounterWidth\">, +{{ overflowed }}</div>\n"]}