@libs-ui/components-datetime-picker 0.2.10-6.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +3 -0
- package/custom-ranges/calendar/calendar.component.d.ts +140 -0
- package/custom-ranges/custom-ranges.component.d.ts +58 -0
- package/defines/calendar.define.d.ts +13 -0
- package/defines/common-date.define.d.ts +2 -0
- package/defines/date-options.define.d.ts +18 -0
- package/esm2022/custom-ranges/calendar/calendar.component.mjs +1259 -0
- package/esm2022/custom-ranges/custom-ranges.component.mjs +303 -0
- package/esm2022/defines/calendar.define.mjs +135 -0
- package/esm2022/defines/common-date.define.mjs +3 -0
- package/esm2022/defines/date-options.define.mjs +53 -0
- package/esm2022/index.mjs +4 -0
- package/esm2022/interfaces/calendar-emit.interface.mjs +2 -0
- package/esm2022/interfaces/calendar-variables.interface.mjs +6 -0
- package/esm2022/interfaces/function-control.interface.mjs +2 -0
- package/esm2022/interfaces/index.mjs +7 -0
- package/esm2022/interfaces/picker.interface.mjs +2 -0
- package/esm2022/interfaces/time-variables.interface.mjs +4 -0
- package/esm2022/interfaces/valid.interface.mjs +2 -0
- package/esm2022/libs-ui-components-datetime-picker.mjs +5 -0
- package/esm2022/picker.component.mjs +190 -0
- package/fesm2022/libs-ui-components-datetime-picker.mjs +1936 -0
- package/fesm2022/libs-ui-components-datetime-picker.mjs.map +1 -0
- package/index.d.ts +3 -0
- package/interfaces/calendar-emit.interface.d.ts +25 -0
- package/interfaces/calendar-variables.interface.d.ts +80 -0
- package/interfaces/function-control.interface.d.ts +8 -0
- package/interfaces/index.d.ts +6 -0
- package/interfaces/picker.interface.d.ts +26 -0
- package/interfaces/time-variables.interface.d.ts +36 -0
- package/interfaces/valid.interface.d.ts +5 -0
- package/package.json +25 -0
- package/picker.component.d.ts +77 -0
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItZW1pdC5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvZGF0ZXRpbWUvcGlja2VyL3NyYy9pbnRlcmZhY2VzL2NhbGVuZGFyLWVtaXQuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBkYXlqcyBmcm9tIFwiZGF5anNcIjtcbmltcG9ydCB7IElTcGxpdFBpY2tlckRhdGUgfSBmcm9tIFwiLi9jYWxlbmRhci12YXJpYWJsZXMuaW50ZXJmYWNlXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUVtaXREYXRlQ2FsZW5kYXIge1xuICBkaXNwbGF5TGFiZWw/OiBzdHJpbmc7XG4gIHN0YXJ0RGF0ZTogZGF5anMuRGF5anMgfCB1bmRlZmluZWQ7XG4gIGVuZERhdGU6IGRheWpzLkRheWpzIHwgdW5kZWZpbmVkO1xuICBkZXRhaWxEYXRlUGlja2VyOiBJU3BsaXRQaWNrZXJEYXRlO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElFbWl0U2luZ2xlRGF0ZSB7XG4gIGRpc3BsYXlMYWJlbD86IHN0cmluZzsgLy8gbGFiZWwgaGnhu4NuIHRo4buLIG5nb8OgaSBkYXRlIHBpY2tlciBmb3JtXG4gIGRhdGU6IHN0cmluZyB8IGRheWpzLkRheWpzIHwgdW5kZWZpbmVkO1xuICB2YWx1ZXM6IHtcbiAgICBtb250aDogc3RyaW5nIHwgbnVtYmVyO1xuICAgIHllYXI6IHN0cmluZyB8IG51bWJlcjtcbiAgICBkYXk6IHN0cmluZyB8IG51bWJlcjtcbiAgICBob3VyPzogc3RyaW5nIHwgbnVtYmVyO1xuICAgIG1pbnV0ZT86IHN0cmluZyB8IG51bWJlcjtcbiAgfTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJRW1pdERhdGVSYW5nZSB7XG4gIHF1aWNrUmFuZ2VJZD86IHN0cmluZzsgLy8gaWQgcXVpY2sgcmFuZ2VcbiAgZGlzcGxheUxhYmVsPzogc3RyaW5nOyAvLyBsYWJlbCBoaeG7g24gdGjhu4sgbmdvw6BpIGRhdGUgcGlja2VyIGZvcm1cbiAgc3RhcnREYXRlOiBzdHJpbmcgfCBkYXlqcy5EYXlqcyB8IHVuZGVmaW5lZDtcbiAgZW5kRGF0ZTogc3RyaW5nIHwgZGF5anMuRGF5anMgfCB1bmRlZmluZWQ7XG59XG4iXX0=
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export var SideEnum;
|
|
2
|
+
(function (SideEnum) {
|
|
3
|
+
SideEnum["left"] = "left";
|
|
4
|
+
SideEnum["right"] = "right";
|
|
5
|
+
})(SideEnum || (SideEnum = {}));
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItdmFyaWFibGVzLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMtdWkvY29tcG9uZW50cy9kYXRldGltZS9waWNrZXIvc3JjL2ludGVyZmFjZXMvY2FsZW5kYXItdmFyaWFibGVzLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3REEsTUFBTSxDQUFOLElBQVksUUFHWDtBQUhELFdBQVksUUFBUTtJQUNsQix5QkFBYSxDQUFBO0lBQ2IsMkJBQWUsQ0FBQTtBQUNqQixDQUFDLEVBSFcsUUFBUSxLQUFSLFFBQVEsUUFHbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBXcml0YWJsZVNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0ICogYXMgZGF5anMgZnJvbSAnZGF5anMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIElDYWxlbmRhclZhcmlhYmxlcyB7XG4gIGxlZnQ6IFdyaXRhYmxlU2lnbmFsPElDYWxlbmRhclZhcmlhYmxlc1NpZGU+O1xuICByaWdodDogV3JpdGFibGVTaWduYWw8SUNhbGVuZGFyVmFyaWFibGVzU2lkZT47XG59XG5pbnRlcmZhY2UgSUNhbGVuZGFyVmFyaWFibGVzU2lkZSB7XG4gIGNhbENvbHM/OiBXcml0YWJsZVNpZ25hbDxBcnJheTxudW1iZXI+PjtcbiAgY2FsUm93cz86IFdyaXRhYmxlU2lnbmFsPEFycmF5PG51bWJlcj4+O1xuICBjYWxlbmRhcj86IElDYWxlbmRhcjtcbiAgY2xhc3Nlcz86IElDYWxlbmRhclZhcmlhYmxlc0NsYXNzZXM7XG4gIGRheU9mV2Vlaz86IG51bWJlcjtcbiAgZGF5c0luTGFzdE1vbnRoPzogbnVtYmVyO1xuICBkYXlzSW5Nb250aD86IG51bWJlcjtcbiAgZHJvcGRvd25zPzogV3JpdGFibGVTaWduYWw8SUNhbGVuZGFyVmFyaWFibGVzRHJvcGRvd25zPjtcbiAgZmlyc3REYXk/OiBkYXlqcy5EYXlqcztcbiAgaG91cj86IG51bWJlcjtcbiAgbGFzdERheT86IGRheWpzLkRheWpzO1xuICBsYXN0TW9udGg/OiBudW1iZXI7XG4gIGxhc3RZZWFyPzogbnVtYmVyO1xuICBtYXhEYXRlPzogZGF5anMuRGF5anM7XG4gIG1pbkRhdGU/OiBkYXlqcy5EYXlqcztcbiAgbWludXRlPzogbnVtYmVyO1xuICBtb250aD86IG51bWJlcjtcbiAgc2Vjb25kPzogbnVtYmVyO1xuICB5ZWFyPzogbnVtYmVyO1xufVxuaW50ZXJmYWNlIElDYWxlbmRhclZhcmlhYmxlc0NsYXNzZXMge1xuICBbaW5kZXg6IG51bWJlcl06IHsgW2luZGV4OiBudW1iZXJdOiBzdHJpbmcsIGNsYXNzTGlzdD86IHN0cmluZyB9O1xufVxuaW50ZXJmYWNlIElDYWxlbmRhclZhcmlhYmxlc0Ryb3Bkb3ducyB7XG4gIGN1cnJlbnRNb250aD86IG51bWJlcjtcbiAgY3VycmVudFllYXI/OiBudW1iZXI7XG4gIGluTWF4WWVhcj86IGJvb2xlYW47XG4gIGluTWluWWVhcj86IGJvb2xlYW47XG4gIG1heFllYXI/OiBudW1iZXI7XG4gIG1pblllYXI/OiBudW1iZXI7XG4gIG1vbnRoQXJyYXlzPzogV3JpdGFibGVTaWduYWw8QXJyYXk8bnVtYmVyPj47XG4gIHllYXJBcnJheXM/OiBXcml0YWJsZVNpZ25hbDxBcnJheTxudW1iZXI+Pjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJQ2FsZW5kYXIge1xuICBbaW5kZXg6IG51bWJlcl06IEFycmF5PGRheWpzLkRheWpzPjtcbiAgZmlyc3REYXk/OiBkYXlqcy5EYXlqcztcbiAgbGFzdERheT86IGRheWpzLkRheWpzO1xufVxuXG50eXBlIFRZUEVfRFJPUERPV05fTU9OVEhfSUQgPSAxIHwgMiB8IDMgfCA0IHwgNSB8IDYgfCA3IHwgOCB8IDkgfCAxMCB8IDExIHwgMTI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUNhbGVuZGFyTW9udGhJdGVtIHtcbiAgaWQ6IFRZUEVfRFJPUERPV05fTU9OVEhfSUQ7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIG1heERheXM6IG51bWJlcjtcbn1cblxuZXhwb3J0IGVudW0gU2lkZUVudW0ge1xuICBsZWZ0ID0gJ2xlZnQnLFxuICByaWdodCA9ICdyaWdodCdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJRGF0ZVJhbmdlIHtcbiAgaWQ6IHN0cmluZztcbiAgbGFiZWw6IHN0cmluZztcbiAgdmFsdWVzPzogQXJyYXk8ZGF5anMuRGF5anM+XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSVNwbGl0UGlja2VyRGF0ZSB7XG4gIHN0YXJ0OiBXcml0YWJsZVNpZ25hbDx7XG4gICAgbW9udGg6IHN0cmluZyB8IG51bWJlcjtcbiAgICB5ZWFyOiBzdHJpbmcgfCBudW1iZXI7XG4gICAgZGF5OiBzdHJpbmcgfCBudW1iZXI7XG4gICAgaG91cjogc3RyaW5nIHwgbnVtYmVyO1xuICAgIG1pbnV0ZTogc3RyaW5nIHwgbnVtYmVyO1xuICB9PjtcbiAgZW5kOiBXcml0YWJsZVNpZ25hbDx7XG4gICAgbW9udGg6IHN0cmluZyB8IG51bWJlcjtcbiAgICB5ZWFyOiBzdHJpbmcgfCBudW1iZXI7XG4gICAgZGF5OiBzdHJpbmcgfCBudW1iZXI7XG4gICAgaG91cjogc3RyaW5nIHwgbnVtYmVyO1xuICAgIG1pbnV0ZTogc3RyaW5nIHwgbnVtYmVyO1xuICB9Pjtcbn0iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnVuY3Rpb24tY29udHJvbC5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvZGF0ZXRpbWUvcGlja2VyL3NyYy9pbnRlcmZhY2VzL2Z1bmN0aW9uLWNvbnRyb2wuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgZGF5anMgZnJvbSAnZGF5anMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIElEYXRlVGltZVBpY2tlckZ1bmN0aW9uQ29udHJvbEV2ZW50IHtcbiAgY2hlY2tJc1ZhbGlkOiAoKSA9PiBQcm9taXNlPGJvb2xlYW4+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElDYWxlbmRhckZ1bmN0aW9uQ29udHJvbEV2ZW50IHtcbiAgYnVpbGREZWZhdWx0UmFuZ2U6IChzdGFydERhdGU6IGRheWpzLkRheWpzLCBlbmREYXRlOiBkYXlqcy5EYXlqcykgPT4gUHJvbWlzZTx2b2lkPjtcbiAgYXBwbHlUb1NlbGVjdDogKCkgPT4gUHJvbWlzZTx2b2lkPjtcbn0iXX0=
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export * from "./calendar-emit.interface";
|
|
2
|
+
export * from "./calendar-variables.interface";
|
|
3
|
+
export * from "./function-control.interface";
|
|
4
|
+
export * from "./picker.interface";
|
|
5
|
+
export * from "./time-variables.interface";
|
|
6
|
+
export * from "./valid.interface";
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvZGF0ZXRpbWUvcGlja2VyL3NyYy9pbnRlcmZhY2VzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLDhCQUE4QixDQUFBO0FBQzVDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vY2FsZW5kYXItZW1pdC5pbnRlcmZhY2VcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2NhbGVuZGFyLXZhcmlhYmxlcy5pbnRlcmZhY2VcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2Z1bmN0aW9uLWNvbnRyb2wuaW50ZXJmYWNlXCJcbmV4cG9ydCAqIGZyb20gXCIuL3BpY2tlci5pbnRlcmZhY2VcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3RpbWUtdmFyaWFibGVzLmludGVyZmFjZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdmFsaWQuaW50ZXJmYWNlXCI7XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGlja2VyLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMtdWkvY29tcG9uZW50cy9kYXRldGltZS9waWNrZXIvc3JjL2ludGVyZmFjZXMvcGlja2VyLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgZGF5anMgZnJvbSBcImRheWpzXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUNob3NlbkRhdGUge1xuICBzZWxlY3RlZExhYmVsPzogc3RyaW5nO1xuICBzdGFydERhdGU/OiBkYXlqcy5EYXlqcztcbiAgZW5kRGF0ZT86IGRheWpzLkRheWpzO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExvY2FsaXphdGlvbkNvbmZpZyB7XG4gIG1vbnRoTmFtZXM6IHN0cmluZ1tdO1xuICByYW5nZXM6IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH07XG4gIGRheXNPZldlZWs6IHN0cmluZ1tdO1xuICBhcHBseUxhYmVsOiBzdHJpbmc7XG4gIGNhbmNlbExhYmVsOiBzdHJpbmc7XG4gIGZyb21MYWJlbDogc3RyaW5nO1xuICB0b0xhYmVsOiBzdHJpbmc7XG4gIGN1c3RvbVJhbmdlTGFiZWw6IHN0cmluZztcbiAgZm9ybWF0Pzogc3RyaW5nO1xuICBkaXJlY3Rpb24/OiBzdHJpbmc7XG4gIHNlcGFyYXRvcj86IHN0cmluZztcbiAgd2Vla0xhYmVsPzogc3RyaW5nO1xuICBjbGVhckxhYmVsPzogc3RyaW5nO1xuICBmaXJzdERheT86IG51bWJlcjtcbiAgZGlzcGxheUZvcm1hdD86IHN0cmluZztcbn1cblxuZXhwb3J0IHR5cGUgVFlQRV9SQU5HRV9LRVkgPSAndG9kYXknIHwgJ3llc3RlcmRheScgfCAnXzdkYXlzX2FnbycgfCAnXzMwZGF5c19hZ28nIHwgJ3RoaXNfbW9udGgnIHwgJ2xhc3RfbW9udGgnIHwgJ18zbW9udGhzX2Fnbyc7XG4iXX0=
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
;
|
|
2
|
+
;
|
|
3
|
+
export {};
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZS12YXJpYWJsZXMuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL2RhdGV0aW1lL3BpY2tlci9zcmMvaW50ZXJmYWNlcy90aW1lLXZhcmlhYmxlcy5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJDLENBQUM7QUFNRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgV3JpdGFibGVTaWduYWwgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0ICogYXMgZGF5anMgZnJvbSBcImRheWpzXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSVRpbWVwaWNrZXJWYXJpYWJsZXMge1xuICBsZWZ0OiBXcml0YWJsZVNpZ25hbDxJVGltZXBpY2tlclZhcmlhYmxlc1NpZGU+O1xuICByaWdodDogV3JpdGFibGVTaWduYWw8SVRpbWVwaWNrZXJWYXJpYWJsZXNTaWRlPjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJVGltZXBpY2tlclZhcmlhYmxlc1NpZGUge1xuICBzZWxlY3RlZEhvdXI6IG51bWJlcjtcbiAgc2VsZWN0ZWRNaW51dGU6IG51bWJlcjtcbiAgaG91cnM/OiBBcnJheTxudW1iZXI+O1xuICBtaW51dGVzPzogQXJyYXk8bnVtYmVyPjtcbiAgbWludXRlc0xhYmVsPzogQXJyYXk8c3RyaW5nPjtcbiAgc2Vjb25kcz86IEFycmF5PG51bWJlcj47XG4gIHNlY29uZHNMYWJlbD86IEFycmF5PG51bWJlcj47XG4gIGRpc2FibGVkSG91cnM/OiBBcnJheTxudW1iZXI+O1xuICBkaXNhYmxlZE1pbnV0ZXM/OiBBcnJheTxudW1iZXI+O1xuICBkaXNhYmxlZFNlY29uZHM/OiBBcnJheTxudW1iZXI+O1xuICBzZWxlY3RlZFNlY29uZD86IG51bWJlcjtcbiAgc2VsZWN0ZWQ/OiBkYXlqcy5EYXlqcztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJVGltZXBpY2tlckl0ZW1WYWx1ZSB7XG4gIGxlZnRob3VyOiBXcml0YWJsZVNpZ25hbDxudW1iZXI+O1xuICBsZWZ0bWludXRlOiBXcml0YWJsZVNpZ25hbDxudW1iZXI+O1xuICByaWdodGhvdXI6IFdyaXRhYmxlU2lnbmFsPG51bWJlcj47XG4gIHJpZ2h0bWludXRlOiBXcml0YWJsZVNpZ25hbDxudW1iZXI+O1xufTtcbmV4cG9ydCBpbnRlcmZhY2UgSUNoZWNrVGltZXBpY2tlclNlbGVjdGVkIHtcbiAgbGVmdG1vbnRoOiBib29sZWFuO1xuICBsZWZ0eWVhcjogYm9vbGVhbjtcbiAgcmlnaHRtb250aDogYm9vbGVhbjtcbiAgcmlnaHR5ZWFyOiBib29sZWFuXG59O1xuZXhwb3J0IGludGVyZmFjZSBJU2VsZWN0ZWRPbGQge1xuICBzdGFydD86IGRheWpzLkRheWpzIHwgdW5kZWZpbmVkLFxuICBlbmQ/OiBkYXlqcy5EYXlqcyB8IHVuZGVmaW5lZFxufSJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWQuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL2RhdGV0aW1lL3BpY2tlci9zcmMvaW50ZXJmYWNlcy92YWxpZC5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgSURhdGVUaW1lVmFsaWQge1xuICBtZXNzYWdlPzogc3RyaW5nO1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxuICBpbnRlcnBvbGF0ZVBhcmFtcz86IFJlY29yZDxzdHJpbmcsIGFueT47XG4gIGlnbm9yZU1lc3NhZ2U/OiBib29sZWFuO1xufSJdfQ==
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlicy11aS1jb21wb25lbnRzLWRhdGV0aW1lLXBpY2tlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMtdWkvY29tcG9uZW50cy9kYXRldGltZS9waWNrZXIvc3JjL2xpYnMtdWktY29tcG9uZW50cy1kYXRldGltZS1waWNrZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
|
|
@@ -0,0 +1,190 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, input, model, output, signal } from "@angular/core";
|
|
2
|
+
import { LibsUiComponentsLabelComponent } from "@libs-ui/components-label";
|
|
3
|
+
import { LibsUiComponentsPopoverComponent } from "@libs-ui/components-popover";
|
|
4
|
+
import { ERROR_MESSAGE_EMPTY_VALID } from "@libs-ui/utils";
|
|
5
|
+
import { TranslateModule } from "@ngx-translate/core";
|
|
6
|
+
import { defaultLocaleConfig, getDateOptions } from "./defines/date-options.define";
|
|
7
|
+
import { LibsUiComponentsDatetimePickerCustomRangesComponent } from "./custom-ranges/custom-ranges.component";
|
|
8
|
+
import dayjs from "dayjs";
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "@ngx-translate/core";
|
|
11
|
+
export class LibsUiComponentsDatetimePickerComponent {
|
|
12
|
+
/** PROPERTY */
|
|
13
|
+
ERROR_MESSAGE_EMPTY_VALID = ERROR_MESSAGE_EMPTY_VALID;
|
|
14
|
+
showRangesPopup = signal(false);
|
|
15
|
+
width = computed(this.computedWidth.bind(this));
|
|
16
|
+
singleError = signal({ message: undefined });
|
|
17
|
+
chosenDateFromRanges = signal({});
|
|
18
|
+
selectedDateFromCalendar;
|
|
19
|
+
displayRangeTitle = computed(() => {
|
|
20
|
+
const selectedLabel = this.chosenDateFromRanges().selectedLabel;
|
|
21
|
+
if (this.isSingle() || !selectedLabel) {
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
return selectedLabel;
|
|
25
|
+
});
|
|
26
|
+
dateOptions = signal({ ...defaultLocaleConfig(), ...getDateOptions() });
|
|
27
|
+
popoverFunctionControlEvent = signal(undefined);
|
|
28
|
+
/** INPUT */
|
|
29
|
+
showCustomRangeLabel = input(true, { transform: (value) => value ?? true });
|
|
30
|
+
labelConfig = input();
|
|
31
|
+
disable = input(false);
|
|
32
|
+
readonly = input(false);
|
|
33
|
+
classInclude = input('');
|
|
34
|
+
classPickerInclude = input('');
|
|
35
|
+
classPickerContentInclude = input('');
|
|
36
|
+
ignoreBorderQuickRange = input(false);
|
|
37
|
+
useColorModeExist = input(false);
|
|
38
|
+
hasTimePicker = input(true);
|
|
39
|
+
allowReset = input(true);
|
|
40
|
+
widthByLabel = input(true, { transform: (value) => value ?? true });
|
|
41
|
+
defaultWidth = input(undefined);
|
|
42
|
+
isSingle = input(false);
|
|
43
|
+
extendRanges = input([]);
|
|
44
|
+
validRequired = input(undefined);
|
|
45
|
+
ignoreStopPropagationEvent = input(false);
|
|
46
|
+
flagMouse = model({ isMouseEnter: false, isMouseEnterContent: false });
|
|
47
|
+
widthByParent = input(false);
|
|
48
|
+
zIndex = input(1200, { transform: (value) => value ?? 1200 });
|
|
49
|
+
rangesPopoverPosition = input('start', { transform: (value) => value ?? 'start' });
|
|
50
|
+
isNgContent = input(false);
|
|
51
|
+
classIncludeCustomRanges = input('');
|
|
52
|
+
autoApply = input(false);
|
|
53
|
+
positionQuickRanges = input('left'); // vị trí list chọn nhanh khoảng thời gian
|
|
54
|
+
singleDateSelected = model();
|
|
55
|
+
dateRangeSelected = model();
|
|
56
|
+
/** OUTPUT */
|
|
57
|
+
outChangStageFlagMouse = output();
|
|
58
|
+
outReset = output();
|
|
59
|
+
outSelectSingleDate = output();
|
|
60
|
+
outSelectDateRange = output();
|
|
61
|
+
outFunctionsControl = output();
|
|
62
|
+
constructor() {
|
|
63
|
+
// this.dateOptions.set(getDateOptions());
|
|
64
|
+
}
|
|
65
|
+
ngOnInit() {
|
|
66
|
+
this.outFunctionsControl.emit({ checkIsValid: this.checkIsValid.bind(this) });
|
|
67
|
+
}
|
|
68
|
+
handlerSelectRanges(event) {
|
|
69
|
+
event.stopPropagation();
|
|
70
|
+
}
|
|
71
|
+
handlerChangStageFlagMouse(flagMouse) {
|
|
72
|
+
this.flagMouse.set(flagMouse);
|
|
73
|
+
}
|
|
74
|
+
handlerChangStagePopoverFlagMouse(flagMouse) {
|
|
75
|
+
if (this.flagMouse()?.isMouseEnterContent) {
|
|
76
|
+
flagMouse.isMouseEnterContent = true;
|
|
77
|
+
}
|
|
78
|
+
this.outChangStageFlagMouse.emit(flagMouse);
|
|
79
|
+
}
|
|
80
|
+
handlerFunctionControl(event) {
|
|
81
|
+
this.popoverFunctionControlEvent.set(event);
|
|
82
|
+
}
|
|
83
|
+
handlerPopoverEvent(event) {
|
|
84
|
+
if (event === 'remove') {
|
|
85
|
+
this.showRangesPopup.set(false);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
handlerPickerSingleDate(data) {
|
|
89
|
+
this.outSelectSingleDate.emit(data);
|
|
90
|
+
this.chosenDateFromRanges.set({ selectedLabel: data.displayLabel });
|
|
91
|
+
if (this.hasTimePicker()) {
|
|
92
|
+
const startTime = dayjs(data.date).format('DD/MM/YYYY HH:mm');
|
|
93
|
+
this.chosenDateFromRanges.update(current => {
|
|
94
|
+
current.selectedLabel = `${startTime}`;
|
|
95
|
+
return current;
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
this.singleDateSelected.set(data);
|
|
99
|
+
this.popoverFunctionControlEvent()?.removePopoverOverlay();
|
|
100
|
+
}
|
|
101
|
+
handlerPickerDateRange(data) {
|
|
102
|
+
console.log(data);
|
|
103
|
+
if ((data.displayLabel?.indexOf('Invalid Date') ?? -1) > -1) {
|
|
104
|
+
return;
|
|
105
|
+
}
|
|
106
|
+
// this.selectedKey = data.selectedLabel;
|
|
107
|
+
this.chosenDateFromRanges.set({ selectedLabel: data.displayLabel });
|
|
108
|
+
// this.selected.start = dayjs(data.startDate);
|
|
109
|
+
// this.selected.end = dayjs(data.endDate);
|
|
110
|
+
if (this.hasTimePicker()) {
|
|
111
|
+
const startTime = dayjs(data.startDate).format('DD/MM/YYYY HH:mm');
|
|
112
|
+
const endTime = dayjs(data.endDate).format('DD/MM/YYYY HH:mm');
|
|
113
|
+
this.chosenDateFromRanges.update(current => {
|
|
114
|
+
current.selectedLabel = `${startTime} - ${endTime}`;
|
|
115
|
+
return current;
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
// this.moDatePicker.emit(this.singleDatePicker ? { chosenLabel: this.dateValue.chosenLabel, singleDate: this.dateValue.startDate?.utc(), startDate: this.dateValue.startDate?.utc(), endDate: this.dateValue.endDate?.utc() } : { chosenLabel: this.dateValue.chosenLabel, startDate: this.dateValue.startDate?.utc(), endDate: this.dateValue.endDate?.utc() });
|
|
119
|
+
const showViewExternalRangeLabel = this.extendRanges()?.find(item => item.id === this.chosenDateFromRanges().selectedLabel);
|
|
120
|
+
if (this.extendRanges() && showViewExternalRangeLabel) {
|
|
121
|
+
this.chosenDateFromRanges.update(current => {
|
|
122
|
+
current.selectedLabel = showViewExternalRangeLabel && showViewExternalRangeLabel.label;
|
|
123
|
+
return current;
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
this.dateRangeSelected.set({ quickRangeId: data.quickRangeId, startDate: data.startDate, endDate: data.endDate });
|
|
127
|
+
this.outSelectDateRange.emit({ quickRangeId: data.quickRangeId, startDate: data.startDate, endDate: data.endDate });
|
|
128
|
+
this.popoverFunctionControlEvent()?.removePopoverOverlay();
|
|
129
|
+
this.checkIsValid();
|
|
130
|
+
}
|
|
131
|
+
handlerReset(event) {
|
|
132
|
+
event?.stopPropagation();
|
|
133
|
+
this.chosenDateFromRanges.set({});
|
|
134
|
+
// this.selected = { start: dayjs().hour(0).minute(0).second(0), end: dayjs().hour(23).minute(59).second(59) };
|
|
135
|
+
this.outReset.emit(undefined);
|
|
136
|
+
}
|
|
137
|
+
handlerUpdateWidth() {
|
|
138
|
+
this.popoverFunctionControlEvent()?.updatePopoverOverlayPosition();
|
|
139
|
+
}
|
|
140
|
+
handlerCancel() {
|
|
141
|
+
this.popoverFunctionControlEvent()?.removePopoverOverlay();
|
|
142
|
+
}
|
|
143
|
+
async checkIsValid() {
|
|
144
|
+
if (this.readonly() || this.disable()) {
|
|
145
|
+
return true;
|
|
146
|
+
}
|
|
147
|
+
await this.validate();
|
|
148
|
+
return this.singleError().message ? false : true;
|
|
149
|
+
}
|
|
150
|
+
async validate() {
|
|
151
|
+
this.singleError.set({ message: undefined });
|
|
152
|
+
if (!this.validRequired()) {
|
|
153
|
+
return;
|
|
154
|
+
}
|
|
155
|
+
if (this.validRequired() && !this.chosenDateFromRanges().selectedLabel) {
|
|
156
|
+
this.singleError.set({
|
|
157
|
+
message: this.validRequired()?.message || ERROR_MESSAGE_EMPTY_VALID,
|
|
158
|
+
interpolateParams: this.validRequired()?.interpolateParams || {}
|
|
159
|
+
});
|
|
160
|
+
return;
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
computedWidth() {
|
|
164
|
+
if (this.widthByLabel()) {
|
|
165
|
+
return;
|
|
166
|
+
}
|
|
167
|
+
if (this.defaultWidth()) {
|
|
168
|
+
return this.defaultWidth();
|
|
169
|
+
}
|
|
170
|
+
if (this.hasTimePicker()) {
|
|
171
|
+
return !this.isSingle() ? 322 : 190;
|
|
172
|
+
}
|
|
173
|
+
return !this.isSingle() ? 232 : 152;
|
|
174
|
+
}
|
|
175
|
+
ngOnDestroy() {
|
|
176
|
+
console.log('ngOnDestroy');
|
|
177
|
+
}
|
|
178
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsDatetimePickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
179
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsDatetimePickerComponent, isStandalone: true, selector: "libs_ui-components-datetime-picker", inputs: { showCustomRangeLabel: { classPropertyName: "showCustomRangeLabel", publicName: "showCustomRangeLabel", isSignal: true, isRequired: false, transformFunction: null }, labelConfig: { classPropertyName: "labelConfig", publicName: "labelConfig", isSignal: true, isRequired: false, transformFunction: null }, disable: { classPropertyName: "disable", publicName: "disable", isSignal: true, isRequired: false, transformFunction: null }, readonly: { classPropertyName: "readonly", publicName: "readonly", isSignal: true, isRequired: false, transformFunction: null }, classInclude: { classPropertyName: "classInclude", publicName: "classInclude", isSignal: true, isRequired: false, transformFunction: null }, classPickerInclude: { classPropertyName: "classPickerInclude", publicName: "classPickerInclude", isSignal: true, isRequired: false, transformFunction: null }, classPickerContentInclude: { classPropertyName: "classPickerContentInclude", publicName: "classPickerContentInclude", isSignal: true, isRequired: false, transformFunction: null }, ignoreBorderQuickRange: { classPropertyName: "ignoreBorderQuickRange", publicName: "ignoreBorderQuickRange", isSignal: true, isRequired: false, transformFunction: null }, useColorModeExist: { classPropertyName: "useColorModeExist", publicName: "useColorModeExist", isSignal: true, isRequired: false, transformFunction: null }, hasTimePicker: { classPropertyName: "hasTimePicker", publicName: "hasTimePicker", isSignal: true, isRequired: false, transformFunction: null }, allowReset: { classPropertyName: "allowReset", publicName: "allowReset", isSignal: true, isRequired: false, transformFunction: null }, widthByLabel: { classPropertyName: "widthByLabel", publicName: "widthByLabel", isSignal: true, isRequired: false, transformFunction: null }, defaultWidth: { classPropertyName: "defaultWidth", publicName: "defaultWidth", isSignal: true, isRequired: false, transformFunction: null }, isSingle: { classPropertyName: "isSingle", publicName: "isSingle", isSignal: true, isRequired: false, transformFunction: null }, extendRanges: { classPropertyName: "extendRanges", publicName: "extendRanges", isSignal: true, isRequired: false, transformFunction: null }, validRequired: { classPropertyName: "validRequired", publicName: "validRequired", isSignal: true, isRequired: false, transformFunction: null }, ignoreStopPropagationEvent: { classPropertyName: "ignoreStopPropagationEvent", publicName: "ignoreStopPropagationEvent", isSignal: true, isRequired: false, transformFunction: null }, flagMouse: { classPropertyName: "flagMouse", publicName: "flagMouse", isSignal: true, isRequired: false, transformFunction: null }, widthByParent: { classPropertyName: "widthByParent", publicName: "widthByParent", isSignal: true, isRequired: false, transformFunction: null }, zIndex: { classPropertyName: "zIndex", publicName: "zIndex", isSignal: true, isRequired: false, transformFunction: null }, rangesPopoverPosition: { classPropertyName: "rangesPopoverPosition", publicName: "rangesPopoverPosition", isSignal: true, isRequired: false, transformFunction: null }, isNgContent: { classPropertyName: "isNgContent", publicName: "isNgContent", isSignal: true, isRequired: false, transformFunction: null }, classIncludeCustomRanges: { classPropertyName: "classIncludeCustomRanges", publicName: "classIncludeCustomRanges", isSignal: true, isRequired: false, transformFunction: null }, autoApply: { classPropertyName: "autoApply", publicName: "autoApply", isSignal: true, isRequired: false, transformFunction: null }, positionQuickRanges: { classPropertyName: "positionQuickRanges", publicName: "positionQuickRanges", isSignal: true, isRequired: false, transformFunction: null }, singleDateSelected: { classPropertyName: "singleDateSelected", publicName: "singleDateSelected", isSignal: true, isRequired: false, transformFunction: null }, dateRangeSelected: { classPropertyName: "dateRangeSelected", publicName: "dateRangeSelected", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { flagMouse: "flagMouseChange", singleDateSelected: "singleDateSelectedChange", dateRangeSelected: "dateRangeSelectedChange", outChangStageFlagMouse: "outChangStageFlagMouse", outReset: "outReset", outSelectSingleDate: "outSelectSingleDate", outSelectDateRange: "outSelectDateRange", outFunctionsControl: "outFunctionsControl" }, ngImport: i0, template: "<div class=\"{{ classInclude() }}\">\n @if (labelConfig(); as labelConfig) {\n <libs_ui-components-label [classInclude]=\"labelConfig.classInclude\"\n [labelLeft]=\"labelConfig.labelLeft\"\n [labelLeftClass]=\"labelConfig.labelLeftClass\"\n [required]=\"labelConfig.required \"\n [description]=\"labelConfig.description\"\n [descriptionClass]=\"labelConfig.descriptionClass\"\n [labelRight]=\"labelConfig.labelRight\"\n [labelRightClass]=\"labelConfig.labelRightClass\"\n [onlyShowCount]=\"labelConfig.onlyShowCount\"\n [buttonsLeft]=\"labelConfig.buttonsLeft\"\n [buttonsRight]=\"labelConfig.buttonsRight\"\n [disableButtonsLeft]=\"labelConfig.disableButtonsLeft || disable()\"\n [disableButtonsRight]=\"labelConfig.disableButtonsRight || disable()\"\n [hasToggle]=\"labelConfig.hasToggle\"\n [toggleActive]=\"labelConfig.toggleActive\"\n [toggleDisable]=\"labelConfig.toggleDisable || disable()\"\n [popover]=\"labelConfig.popover\"\n [iconPopoverClass]=\"labelConfig.iconPopoverClass\"\n [onlyShowCount]=\"labelConfig.onlyShowCount\"\n [limitLength]=\"labelConfig.limitLength\"\n [buttonsDescription]=\"labelConfig.buttonsDescription\"\n [disableButtonsDescription]=\"labelConfig.disableButtonsDescription || disable()\"\n [buttonsDescriptionContainerClass]=\"labelConfig.buttonsDescriptionContainerClass\"\n [count]=\"labelConfig.count\" />\n }\n <div class=\"flex w-full\">\n <libs_ui-components-popover [classInclude]=\"classPickerInclude()\"\n [ignoreShowPopover]=\"disable() || readonly()\"\n [mode]=\"'click'\"\n [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n [ignoreStopPropagationEvent]=\"ignoreStopPropagationEvent()\"\n [flagMouse]=\"flagMouse()\"\n [config]=\"{\n animationConfig:{},\n maxWidth: 770,\n maxHeight: 420,\n directionDistance:2,\n template: customRangesRef,\n widthByParent: widthByParent(),\n whiteTheme: true,\n ignoreArrow: true,\n zIndex: zIndex(),\n classInclude: 'rounded-[4px] ',\n position: {mode: rangesPopoverPosition(),distance: 0}}\"\n (outChangStageFlagMouse)=\"handlerChangStagePopoverFlagMouse($event)\"\n (outFunctionsControl)=\"handlerFunctionControl($event)\"\n (outEvent)=\"handlerPopoverEvent($event)\">\n @if (!isNgContent()) {\n <div #containerRef\n class=\"flex items-center px-[12px] h-[32px] rounded-[4px] bg-[#ffffff] cursor-pointer libs-ui-font-h5r {{ classPickerContentInclude() }}\"\n [class.libs-ui-disable]=\"disable()\"\n [class.!border-none]=\"ignoreBorderQuickRange()\"\n [class.libs-ui-border-general]=\"!singleError().message && !ignoreBorderQuickRange()\"\n [class.libs-ui-border-error-general]=\"singleError().message && !ignoreBorderQuickRange()\"\n [class.min-w-[284px]]=\"!chosenDateFromRanges().selectedLabel && !isSingle() && hasTimePicker()\"\n [class.!border]=\"showRangesPopup() && !ignoreBorderQuickRange() && !readonly()\"\n [class.!border-[#4e8cf7]]=\"showRangesPopup() && !ignoreBorderQuickRange() && !readonly()\"\n [class.libs-ui-readonly]=\"readonly() || false\"\n [style.width.px]=\"width()\"\n (click)=\"handlerSelectRanges($event)\">\n <div class=\"libs-ui-icon-calendar text-[#9ca2ad] text-[16px]\"></div>\n <div class=\"ml-[8px]\"\n [class.!text-[#071631]]=\"!disable()\"\n [class.!text-[#9ca2ad]]=\"disable()\">\n @if (!chosenDateFromRanges().selectedLabel) {\n @if (!isSingle()) {\n <span class=\"text-[#9ca2ad]\">dd/mm/yyyy@if (hasTimePicker()) {<span> hh:mm</span>} - dd/mm/yyyy@if (hasTimePicker()) {<span> hh:mm</span>}</span>\n }\n @if (isSingle()) {\n <span class=\"text-[#9ca2ad]\">dd/mm/yyyy@if (hasTimePicker()) {<span> hh:mm</span>}</span>\n }\n }\n @if (chosenDateFromRanges().selectedLabel && !isSingle()) {\n {{ displayRangeTitle() }}\n }\n @if (chosenDateFromRanges().selectedLabel && isSingle()) {\n <span [class.text-[#29c7cc]]=\"useColorModeExist() || false\">\n {{ chosenDateFromRanges().selectedLabel }}\n </span>\n }\n </div>\n @if (chosenDateFromRanges().selectedLabel && allowReset() && !disable() && !readonly()) {\n <div class=\"pl-[12px] ml-auto h-full flex items-center\">\n <i class=\"libs-ui-icon-close-circle-solid text-[16px] text-[#cdd0d6]\"\n (click)=\"handlerReset($event)\"></i>\n </div>\n }\n </div>\n }\n @if (isNgContent()) {\n <div (click)=\"handlerSelectRanges($event)\">\n <ng-content></ng-content>\n </div>\n }\n </libs_ui-components-popover>\n </div>\n @if (singleError().message && !validRequired()?.ignoreMessage) {\n <div class=\"mt-[8px] text-[#ee2d41] libs-ui-font-h7r libs-ui-text-error\"\n [innerHTML]=\"(singleError().message || ERROR_MESSAGE_EMPTY_VALID)| translate:validRequired()?.interpolateParams\"></div>\n }\n</div>\n\n<ng-template #customRangesRef>\n <libs_ui-components-datetime-picker-custom_ranges [zIndex]=\"zIndex()\"\n [classInclude]=\"classIncludeCustomRanges()\"\n [widthByParent]=\"widthByParent()\"\n [dateOptions]=\"dateOptions()\"\n [positionQuickRanges]=\"positionQuickRanges()\"\n [showCustomRangeLabel]=\"showCustomRangeLabel()\"\n [autoApply]=\"autoApply()\"\n [isSingle]=\"isSingle()\"\n [singleDateSelected]=\"singleDateSelected()\"\n [dateRangeSelected]=\"dateRangeSelected()\"\n [extendRanges]=\"extendRanges()\"\n [hasTimePicker]=\"hasTimePicker()\"\n (outUpdateWidth)=\"handlerUpdateWidth()\"\n (outCancel)=\"handlerCancel()\"\n (outSelectSingleDate)=\"handlerPickerSingleDate($event)\"\n (outSelectDateRange)=\"handlerPickerDateRange($event)\"\n (outChangStageFlagMouse)=\"handlerChangStageFlagMouse($event)\" />\n</ng-template>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "component", type: LibsUiComponentsLabelComponent, selector: "libs_ui-components-label", inputs: ["iconPopoverClass", "classInclude", "labelLeft", "labelLeftClass", "labelLeftBehindToggleButton", "popover", "required", "buttonsLeft", "disableButtonsLeft", "buttonsRight", "disableButtonsRight", "labelRight", "labelRightClass", "labelRightRequired", "hasToggle", "toggleSize", "toggleActive", "toggleDisable", "description", "descriptionClass", "buttonsDescription", "disableButtonsDescription", "buttonsDescriptionContainerClass", "onlyShowCount", "zIndexPopover", "timerDestroyPopover", "count", "limitLength"], outputs: ["outClickButton", "outSwitchEvent", "outLabelRightClick", "outLabelLeftClick"] }, { kind: "component", type: LibsUiComponentsPopoverComponent, selector: "libs_ui-components-popover,[LibsUiComponentsPopoverDirective]", inputs: ["debugId", "flagMouse", "type", "mode", "config", "ignoreShowPopover", "elementRefCustom", "classInclude", "ignoreHiddenPopoverContentWhenMouseLeave", "ignoreStopPropagationEvent", "ignoreCursorPointerModeLikeClick", "isAddContentToParentDocument", "ignoreClickOutside"], outputs: ["outEvent", "outChangStageFlagMouse", "outEventPopoverContent", "outFunctionsControl"] }, { kind: "component", type: LibsUiComponentsDatetimePickerCustomRangesComponent, selector: "libs_ui-components-datetime-picker-custom_ranges", inputs: ["zIndex", "classInclude", "extendRanges", "widthByParent", "autoApply", "positionQuickRanges", "isSingle", "hasTimePicker", "flagMouse", "dateOptions", "alwaysShowCalendars", "startDate", "endDate", "showCustomRangeLabel", "keepCalendarOpeningWithRange", "singleDateSelected", "dateRangeSelected"], outputs: ["startDateChange", "endDateChange", "outChangStageFlagMouse", "outUpdateWidth", "outCancel", "outSelectSingleDate", "outSelectDateRange", "outClickRange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
180
|
+
}
|
|
181
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsDatetimePickerComponent, decorators: [{
|
|
182
|
+
type: Component,
|
|
183
|
+
args: [{ selector: 'libs_ui-components-datetime-picker', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
|
|
184
|
+
TranslateModule,
|
|
185
|
+
LibsUiComponentsLabelComponent,
|
|
186
|
+
LibsUiComponentsPopoverComponent,
|
|
187
|
+
LibsUiComponentsDatetimePickerCustomRangesComponent
|
|
188
|
+
], template: "<div class=\"{{ classInclude() }}\">\n @if (labelConfig(); as labelConfig) {\n <libs_ui-components-label [classInclude]=\"labelConfig.classInclude\"\n [labelLeft]=\"labelConfig.labelLeft\"\n [labelLeftClass]=\"labelConfig.labelLeftClass\"\n [required]=\"labelConfig.required \"\n [description]=\"labelConfig.description\"\n [descriptionClass]=\"labelConfig.descriptionClass\"\n [labelRight]=\"labelConfig.labelRight\"\n [labelRightClass]=\"labelConfig.labelRightClass\"\n [onlyShowCount]=\"labelConfig.onlyShowCount\"\n [buttonsLeft]=\"labelConfig.buttonsLeft\"\n [buttonsRight]=\"labelConfig.buttonsRight\"\n [disableButtonsLeft]=\"labelConfig.disableButtonsLeft || disable()\"\n [disableButtonsRight]=\"labelConfig.disableButtonsRight || disable()\"\n [hasToggle]=\"labelConfig.hasToggle\"\n [toggleActive]=\"labelConfig.toggleActive\"\n [toggleDisable]=\"labelConfig.toggleDisable || disable()\"\n [popover]=\"labelConfig.popover\"\n [iconPopoverClass]=\"labelConfig.iconPopoverClass\"\n [onlyShowCount]=\"labelConfig.onlyShowCount\"\n [limitLength]=\"labelConfig.limitLength\"\n [buttonsDescription]=\"labelConfig.buttonsDescription\"\n [disableButtonsDescription]=\"labelConfig.disableButtonsDescription || disable()\"\n [buttonsDescriptionContainerClass]=\"labelConfig.buttonsDescriptionContainerClass\"\n [count]=\"labelConfig.count\" />\n }\n <div class=\"flex w-full\">\n <libs_ui-components-popover [classInclude]=\"classPickerInclude()\"\n [ignoreShowPopover]=\"disable() || readonly()\"\n [mode]=\"'click'\"\n [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n [ignoreStopPropagationEvent]=\"ignoreStopPropagationEvent()\"\n [flagMouse]=\"flagMouse()\"\n [config]=\"{\n animationConfig:{},\n maxWidth: 770,\n maxHeight: 420,\n directionDistance:2,\n template: customRangesRef,\n widthByParent: widthByParent(),\n whiteTheme: true,\n ignoreArrow: true,\n zIndex: zIndex(),\n classInclude: 'rounded-[4px] ',\n position: {mode: rangesPopoverPosition(),distance: 0}}\"\n (outChangStageFlagMouse)=\"handlerChangStagePopoverFlagMouse($event)\"\n (outFunctionsControl)=\"handlerFunctionControl($event)\"\n (outEvent)=\"handlerPopoverEvent($event)\">\n @if (!isNgContent()) {\n <div #containerRef\n class=\"flex items-center px-[12px] h-[32px] rounded-[4px] bg-[#ffffff] cursor-pointer libs-ui-font-h5r {{ classPickerContentInclude() }}\"\n [class.libs-ui-disable]=\"disable()\"\n [class.!border-none]=\"ignoreBorderQuickRange()\"\n [class.libs-ui-border-general]=\"!singleError().message && !ignoreBorderQuickRange()\"\n [class.libs-ui-border-error-general]=\"singleError().message && !ignoreBorderQuickRange()\"\n [class.min-w-[284px]]=\"!chosenDateFromRanges().selectedLabel && !isSingle() && hasTimePicker()\"\n [class.!border]=\"showRangesPopup() && !ignoreBorderQuickRange() && !readonly()\"\n [class.!border-[#4e8cf7]]=\"showRangesPopup() && !ignoreBorderQuickRange() && !readonly()\"\n [class.libs-ui-readonly]=\"readonly() || false\"\n [style.width.px]=\"width()\"\n (click)=\"handlerSelectRanges($event)\">\n <div class=\"libs-ui-icon-calendar text-[#9ca2ad] text-[16px]\"></div>\n <div class=\"ml-[8px]\"\n [class.!text-[#071631]]=\"!disable()\"\n [class.!text-[#9ca2ad]]=\"disable()\">\n @if (!chosenDateFromRanges().selectedLabel) {\n @if (!isSingle()) {\n <span class=\"text-[#9ca2ad]\">dd/mm/yyyy@if (hasTimePicker()) {<span> hh:mm</span>} - dd/mm/yyyy@if (hasTimePicker()) {<span> hh:mm</span>}</span>\n }\n @if (isSingle()) {\n <span class=\"text-[#9ca2ad]\">dd/mm/yyyy@if (hasTimePicker()) {<span> hh:mm</span>}</span>\n }\n }\n @if (chosenDateFromRanges().selectedLabel && !isSingle()) {\n {{ displayRangeTitle() }}\n }\n @if (chosenDateFromRanges().selectedLabel && isSingle()) {\n <span [class.text-[#29c7cc]]=\"useColorModeExist() || false\">\n {{ chosenDateFromRanges().selectedLabel }}\n </span>\n }\n </div>\n @if (chosenDateFromRanges().selectedLabel && allowReset() && !disable() && !readonly()) {\n <div class=\"pl-[12px] ml-auto h-full flex items-center\">\n <i class=\"libs-ui-icon-close-circle-solid text-[16px] text-[#cdd0d6]\"\n (click)=\"handlerReset($event)\"></i>\n </div>\n }\n </div>\n }\n @if (isNgContent()) {\n <div (click)=\"handlerSelectRanges($event)\">\n <ng-content></ng-content>\n </div>\n }\n </libs_ui-components-popover>\n </div>\n @if (singleError().message && !validRequired()?.ignoreMessage) {\n <div class=\"mt-[8px] text-[#ee2d41] libs-ui-font-h7r libs-ui-text-error\"\n [innerHTML]=\"(singleError().message || ERROR_MESSAGE_EMPTY_VALID)| translate:validRequired()?.interpolateParams\"></div>\n }\n</div>\n\n<ng-template #customRangesRef>\n <libs_ui-components-datetime-picker-custom_ranges [zIndex]=\"zIndex()\"\n [classInclude]=\"classIncludeCustomRanges()\"\n [widthByParent]=\"widthByParent()\"\n [dateOptions]=\"dateOptions()\"\n [positionQuickRanges]=\"positionQuickRanges()\"\n [showCustomRangeLabel]=\"showCustomRangeLabel()\"\n [autoApply]=\"autoApply()\"\n [isSingle]=\"isSingle()\"\n [singleDateSelected]=\"singleDateSelected()\"\n [dateRangeSelected]=\"dateRangeSelected()\"\n [extendRanges]=\"extendRanges()\"\n [hasTimePicker]=\"hasTimePicker()\"\n (outUpdateWidth)=\"handlerUpdateWidth()\"\n (outCancel)=\"handlerCancel()\"\n (outSelectSingleDate)=\"handlerPickerSingleDate($event)\"\n (outSelectDateRange)=\"handlerPickerDateRange($event)\"\n (outChangStageFlagMouse)=\"handlerChangStageFlagMouse($event)\" />\n</ng-template>\n" }]
|
|
189
|
+
}], ctorParameters: () => [] });
|
|
190
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"picker.component.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/datetime/picker/src/picker.component.ts","../../../../../../libs-ui/components/datetime/picker/src/picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input, model, OnDestroy, OnInit, output, signal } from \"@angular/core\";\nimport { ILabel, LibsUiComponentsLabelComponent } from \"@libs-ui/components-label\";\nimport { IFlagMouse, IPopoverFunctionControlEvent, LibsUiComponentsPopoverComponent, TYPE_POPOVER_EVENT } from \"@libs-ui/components-popover\";\nimport { ERROR_MESSAGE_EMPTY_VALID } from \"@libs-ui/utils\";\nimport { TranslateModule } from \"@ngx-translate/core\";\nimport { IDateTimeValid } from \"./interfaces/valid.interface\";\nimport { IChosenDate, LocalizationConfig, TYPE_RANGE_KEY } from \"./interfaces/picker.interface\";\nimport { IDateTimePickerFunctionControlEvent } from \"./interfaces/function-control.interface\";\nimport { defaultLocaleConfig, getDateOptions } from \"./defines/date-options.define\";\nimport { LibsUiComponentsDatetimePickerCustomRangesComponent } from \"./custom-ranges/custom-ranges.component\";\nimport { IEmitDateRange, IEmitSingleDate } from \"./interfaces/calendar-emit.interface\";\nimport dayjs from \"dayjs\";\nimport { IDateRange } from \"./interfaces/calendar-variables.interface\";\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-datetime-picker',\n  templateUrl: './picker.component.html',\n  styleUrls: ['./picker.component.scss'],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    TranslateModule,\n    LibsUiComponentsLabelComponent,\n    LibsUiComponentsPopoverComponent,\n    LibsUiComponentsDatetimePickerCustomRangesComponent\n  ]\n})\nexport class LibsUiComponentsDatetimePickerComponent implements OnInit, OnDestroy {\n  /** PROPERTY */\n  protected readonly ERROR_MESSAGE_EMPTY_VALID = ERROR_MESSAGE_EMPTY_VALID;\n  protected showRangesPopup = signal<boolean>(false);\n  protected width = computed(this.computedWidth.bind(this));\n  protected singleError = signal<IDateTimeValid>({ message: undefined });\n  protected chosenDateFromRanges = signal<IChosenDate>({});\n  protected selectedDateFromCalendar!: { start?: dayjs.Dayjs, end?: dayjs.Dayjs };\n  protected displayRangeTitle = computed(() => {\n    const selectedLabel = this.chosenDateFromRanges().selectedLabel as TYPE_RANGE_KEY;\n\n    if (this.isSingle() || !selectedLabel) {\n      return;\n    }\n\n    return selectedLabel;\n  });\n  protected dateOptions = signal<LocalizationConfig>({ ...defaultLocaleConfig(), ...getDateOptions() });\n\n  private popoverFunctionControlEvent = signal<IPopoverFunctionControlEvent | undefined>(undefined);\n\n  /** INPUT */\n  readonly showCustomRangeLabel = input<boolean, boolean>(true, { transform: (value) => value ?? true });\n  readonly labelConfig = input<ILabel>();\n  readonly disable = input<boolean>(false);\n  readonly readonly = input<boolean>(false);\n  readonly classInclude = input<string>('');\n  readonly classPickerInclude = input<string>('');\n  readonly classPickerContentInclude = input<string>('');\n  readonly ignoreBorderQuickRange = input<boolean>(false);\n  readonly useColorModeExist = input<boolean>(false);\n  readonly hasTimePicker = input<boolean>(true);\n  readonly allowReset = input<boolean>(true);\n  readonly widthByLabel = input<boolean, boolean>(true, { transform: (value) => value ?? true });\n  readonly defaultWidth = input<number | undefined>(undefined);\n  readonly isSingle = input<boolean>(false);\n  readonly extendRanges = input<Array<IDateRange>>([]);\n\n  readonly validRequired = input<IDateTimeValid | undefined>(undefined);\n  readonly ignoreStopPropagationEvent = input<boolean>(false);\n  readonly flagMouse = model<IFlagMouse>({ isMouseEnter: false, isMouseEnterContent: false });\n  readonly widthByParent = input<boolean>(false);\n  readonly zIndex = input<number, number>(1200, { transform: (value) => value ?? 1200 });\n  readonly rangesPopoverPosition = input<'start' | 'center' | 'end', 'start' | 'center' | 'end'>('start', { transform: (value) => value ?? 'start' });\n  readonly isNgContent = input<boolean>(false);\n  readonly classIncludeCustomRanges = input<string>('');\n  readonly autoApply = input<boolean>(false);\n  readonly positionQuickRanges = input<'left' | 'right'>('left'); // vị trí list chọn nhanh khoảng thời gian\n\n  readonly singleDateSelected = model<IEmitSingleDate>();\n  readonly dateRangeSelected = model<IEmitDateRange>();\n\n  /** OUTPUT */\n  readonly outChangStageFlagMouse = output<IFlagMouse>();\n  readonly outReset = output<undefined>();\n  readonly outSelectSingleDate = output<IEmitSingleDate>();\n  readonly outSelectDateRange = output<IEmitDateRange>();\n  readonly outFunctionsControl = output<IDateTimePickerFunctionControlEvent>();\n\n  constructor() {\n    // this.dateOptions.set(getDateOptions());\n  }\n\n  ngOnInit() {\n    this.outFunctionsControl.emit({ checkIsValid: this.checkIsValid.bind(this) })\n  }\n\n  protected handlerSelectRanges(event: Event) {\n    event.stopPropagation();\n  }\n\n  protected handlerChangStageFlagMouse(flagMouse: IFlagMouse) {\n    this.flagMouse.set(flagMouse)\n  }\n\n  protected handlerChangStagePopoverFlagMouse(flagMouse: IFlagMouse) {\n    if (this.flagMouse()?.isMouseEnterContent) {\n      flagMouse.isMouseEnterContent = true;\n    }\n    this.outChangStageFlagMouse.emit(flagMouse);\n  }\n\n\n  protected handlerFunctionControl(event: IPopoverFunctionControlEvent) {\n    this.popoverFunctionControlEvent.set(event);\n  }\n\n  protected handlerPopoverEvent(event: TYPE_POPOVER_EVENT) {\n    if (event === 'remove') {\n      this.showRangesPopup.set(false);\n    }\n  }\n\n  protected handlerPickerSingleDate(data: IEmitSingleDate) {\n    this.outSelectSingleDate.emit(data);\n    this.chosenDateFromRanges.set({ selectedLabel: data.displayLabel });\n    if (this.hasTimePicker()) {\n      const startTime = dayjs(data.date).format('DD/MM/YYYY HH:mm');\n\n      this.chosenDateFromRanges.update(current => {\n        current.selectedLabel = `${startTime}`;\n        return current;\n      });\n    }\n    this.singleDateSelected.set(data);\n    this.popoverFunctionControlEvent()?.removePopoverOverlay();\n  }\n\n  protected handlerPickerDateRange(data: IEmitDateRange) {\n    console.log(data);\n\n    if ((data.displayLabel?.indexOf('Invalid Date') ?? -1) > -1) {\n      return;\n    }\n    // this.selectedKey = data.selectedLabel;\n    this.chosenDateFromRanges.set({ selectedLabel: data.displayLabel });\n\n    // this.selected.start = dayjs(data.startDate);\n    // this.selected.end = dayjs(data.endDate);\n    if (this.hasTimePicker()) {\n      const startTime = dayjs(data.startDate).format('DD/MM/YYYY HH:mm');\n      const endTime = dayjs(data.endDate).format('DD/MM/YYYY HH:mm');\n\n      this.chosenDateFromRanges.update(current => {\n        current.selectedLabel = `${startTime} - ${endTime}`;\n        return current;\n      });\n    }\n    // this.moDatePicker.emit(this.singleDatePicker ? { chosenLabel: this.dateValue.chosenLabel, singleDate: this.dateValue.startDate?.utc(), startDate: this.dateValue.startDate?.utc(), endDate: this.dateValue.endDate?.utc() } : { chosenLabel: this.dateValue.chosenLabel, startDate: this.dateValue.startDate?.utc(), endDate: this.dateValue.endDate?.utc() });\n    const showViewExternalRangeLabel = this.extendRanges()?.find(item => item.id === this.chosenDateFromRanges().selectedLabel);\n\n    if (this.extendRanges() && showViewExternalRangeLabel) {\n      this.chosenDateFromRanges.update(current => {\n        current.selectedLabel = showViewExternalRangeLabel && showViewExternalRangeLabel.label;\n        return current;\n      });\n    }\n\n    this.dateRangeSelected.set({ quickRangeId: data.quickRangeId, startDate: data.startDate, endDate: data.endDate });\n    this.outSelectDateRange.emit({ quickRangeId: data.quickRangeId, startDate: data.startDate, endDate: data.endDate });\n    this.popoverFunctionControlEvent()?.removePopoverOverlay();\n    this.checkIsValid();\n  }\n\n  protected handlerReset(event?: Event) {\n    event?.stopPropagation();\n    this.chosenDateFromRanges.set({});\n    // this.selected = { start: dayjs().hour(0).minute(0).second(0), end: dayjs().hour(23).minute(59).second(59) };\n    this.outReset.emit(undefined);\n  }\n\n  protected handlerUpdateWidth() {\n    this.popoverFunctionControlEvent()?.updatePopoverOverlayPosition();\n  }\n\n  protected handlerCancel() {\n    this.popoverFunctionControlEvent()?.removePopoverOverlay();\n  }\n\n  private async checkIsValid() {\n    if (this.readonly() || this.disable()) {\n      return true;\n    }\n    await this.validate();\n\n    return this.singleError().message ? false : true;\n  }\n\n  private async validate() {\n    this.singleError.set({ message: undefined });\n\n    if (!this.validRequired()) {\n      return;\n    }\n\n    if (this.validRequired() && !this.chosenDateFromRanges().selectedLabel) {\n      this.singleError.set({\n        message: this.validRequired()?.message || ERROR_MESSAGE_EMPTY_VALID,\n        interpolateParams: this.validRequired()?.interpolateParams || {}\n      });\n\n      return;\n    }\n  }\n\n  private computedWidth() {\n    if (this.widthByLabel()) {\n      return;\n    }\n\n    if (this.defaultWidth()) {\n      return this.defaultWidth();\n    }\n\n    if (this.hasTimePicker()) {\n      return !this.isSingle() ? 322 : 190;\n    }\n    return !this.isSingle() ? 232 : 152;\n  }\n\n  ngOnDestroy() {\n    console.log('ngOnDestroy');\n  }\n}\n","<div class=\"{{ classInclude() }}\">\n  @if (labelConfig(); as labelConfig) {\n    <libs_ui-components-label [classInclude]=\"labelConfig.classInclude\"\n      [labelLeft]=\"labelConfig.labelLeft\"\n      [labelLeftClass]=\"labelConfig.labelLeftClass\"\n      [required]=\"labelConfig.required \"\n      [description]=\"labelConfig.description\"\n      [descriptionClass]=\"labelConfig.descriptionClass\"\n      [labelRight]=\"labelConfig.labelRight\"\n      [labelRightClass]=\"labelConfig.labelRightClass\"\n      [onlyShowCount]=\"labelConfig.onlyShowCount\"\n      [buttonsLeft]=\"labelConfig.buttonsLeft\"\n      [buttonsRight]=\"labelConfig.buttonsRight\"\n      [disableButtonsLeft]=\"labelConfig.disableButtonsLeft || disable()\"\n      [disableButtonsRight]=\"labelConfig.disableButtonsRight || disable()\"\n      [hasToggle]=\"labelConfig.hasToggle\"\n      [toggleActive]=\"labelConfig.toggleActive\"\n      [toggleDisable]=\"labelConfig.toggleDisable || disable()\"\n      [popover]=\"labelConfig.popover\"\n      [iconPopoverClass]=\"labelConfig.iconPopoverClass\"\n      [onlyShowCount]=\"labelConfig.onlyShowCount\"\n      [limitLength]=\"labelConfig.limitLength\"\n      [buttonsDescription]=\"labelConfig.buttonsDescription\"\n      [disableButtonsDescription]=\"labelConfig.disableButtonsDescription || disable()\"\n      [buttonsDescriptionContainerClass]=\"labelConfig.buttonsDescriptionContainerClass\"\n      [count]=\"labelConfig.count\" />\n  }\n  <div class=\"flex w-full\">\n    <libs_ui-components-popover [classInclude]=\"classPickerInclude()\"\n      [ignoreShowPopover]=\"disable() || readonly()\"\n      [mode]=\"'click'\"\n      [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n      [ignoreStopPropagationEvent]=\"ignoreStopPropagationEvent()\"\n      [flagMouse]=\"flagMouse()\"\n      [config]=\"{\n        animationConfig:{},\n        maxWidth: 770,\n        maxHeight: 420,\n        directionDistance:2,\n        template: customRangesRef,\n        widthByParent: widthByParent(),\n        whiteTheme: true,\n        ignoreArrow: true,\n        zIndex: zIndex(),\n        classInclude: 'rounded-[4px] ',\n        position: {mode: rangesPopoverPosition(),distance: 0}}\"\n      (outChangStageFlagMouse)=\"handlerChangStagePopoverFlagMouse($event)\"\n      (outFunctionsControl)=\"handlerFunctionControl($event)\"\n      (outEvent)=\"handlerPopoverEvent($event)\">\n      @if (!isNgContent()) {\n        <div #containerRef\n          class=\"flex items-center px-[12px] h-[32px] rounded-[4px] bg-[#ffffff] cursor-pointer libs-ui-font-h5r {{ classPickerContentInclude() }}\"\n          [class.libs-ui-disable]=\"disable()\"\n          [class.!border-none]=\"ignoreBorderQuickRange()\"\n          [class.libs-ui-border-general]=\"!singleError().message && !ignoreBorderQuickRange()\"\n          [class.libs-ui-border-error-general]=\"singleError().message && !ignoreBorderQuickRange()\"\n          [class.min-w-[284px]]=\"!chosenDateFromRanges().selectedLabel && !isSingle() && hasTimePicker()\"\n          [class.!border]=\"showRangesPopup() && !ignoreBorderQuickRange() && !readonly()\"\n          [class.!border-[#4e8cf7]]=\"showRangesPopup() && !ignoreBorderQuickRange() && !readonly()\"\n          [class.libs-ui-readonly]=\"readonly() || false\"\n          [style.width.px]=\"width()\"\n          (click)=\"handlerSelectRanges($event)\">\n          <div class=\"libs-ui-icon-calendar text-[#9ca2ad] text-[16px]\"></div>\n          <div class=\"ml-[8px]\"\n            [class.!text-[#071631]]=\"!disable()\"\n            [class.!text-[#9ca2ad]]=\"disable()\">\n            @if (!chosenDateFromRanges().selectedLabel) {\n              @if (!isSingle()) {\n                <span class=\"text-[#9ca2ad]\">dd/mm/yyyy@if (hasTimePicker()) {<span>&nbsp;hh:mm</span>} - dd/mm/yyyy@if (hasTimePicker()) {<span>&nbsp;hh:mm</span>}</span>\n              }\n              @if (isSingle()) {\n                <span class=\"text-[#9ca2ad]\">dd/mm/yyyy@if (hasTimePicker()) {<span>&nbsp;hh:mm</span>}</span>\n                }\n                }\n                @if (chosenDateFromRanges().selectedLabel && !isSingle()) {\n                  {{ displayRangeTitle() }}\n                }\n                @if (chosenDateFromRanges().selectedLabel && isSingle()) {\n                  <span [class.text-[#29c7cc]]=\"useColorModeExist() || false\">\n                    {{ chosenDateFromRanges().selectedLabel }}\n                  </span>\n                }\n          </div>\n          @if (chosenDateFromRanges().selectedLabel && allowReset() && !disable() && !readonly()) {\n            <div class=\"pl-[12px] ml-auto h-full flex items-center\">\n              <i class=\"libs-ui-icon-close-circle-solid text-[16px] text-[#cdd0d6]\"\n                (click)=\"handlerReset($event)\"></i>\n            </div>\n          }\n        </div>\n        }\n        @if (isNgContent()) {\n          <div (click)=\"handlerSelectRanges($event)\">\n            <ng-content></ng-content>\n          </div>\n        }\n    </libs_ui-components-popover>\n  </div>\n  @if (singleError().message && !validRequired()?.ignoreMessage) {\n    <div class=\"mt-[8px] text-[#ee2d41] libs-ui-font-h7r libs-ui-text-error\"\n      [innerHTML]=\"(singleError().message || ERROR_MESSAGE_EMPTY_VALID)| translate:validRequired()?.interpolateParams\"></div>\n  }\n</div>\n\n<ng-template #customRangesRef>\n  <libs_ui-components-datetime-picker-custom_ranges [zIndex]=\"zIndex()\"\n    [classInclude]=\"classIncludeCustomRanges()\"\n    [widthByParent]=\"widthByParent()\"\n    [dateOptions]=\"dateOptions()\"\n    [positionQuickRanges]=\"positionQuickRanges()\"\n    [showCustomRangeLabel]=\"showCustomRangeLabel()\"\n    [autoApply]=\"autoApply()\"\n    [isSingle]=\"isSingle()\"\n    [singleDateSelected]=\"singleDateSelected()\"\n    [dateRangeSelected]=\"dateRangeSelected()\"\n    [extendRanges]=\"extendRanges()\"\n    [hasTimePicker]=\"hasTimePicker()\"\n    (outUpdateWidth)=\"handlerUpdateWidth()\"\n    (outCancel)=\"handlerCancel()\"\n    (outSelectSingleDate)=\"handlerPickerSingleDate($event)\"\n    (outSelectDateRange)=\"handlerPickerDateRange($event)\"\n    (outChangStageFlagMouse)=\"handlerChangStageFlagMouse($event)\" />\n</ng-template>\n"]}
|