@cauca-911/material 18.0.0 → 18.0.1-beta2
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/esm2022/lib/buttons/base-button.mjs +33 -0
- package/esm2022/lib/buttons/basic-button/basic-button.component.mjs +64 -0
- package/esm2022/lib/buttons/flat-button/flat-button.component.mjs +64 -0
- package/esm2022/lib/buttons/icon-button/icon-button.component.mjs +28 -0
- package/esm2022/lib/buttons/menu-item/menu-item.component.mjs +68 -0
- package/esm2022/lib/buttons/raised-button/raised-button.component.mjs +64 -0
- package/esm2022/lib/buttons/stroked-button/stroked-button.component.mjs +71 -0
- package/esm2022/lib/cauca-material.component.mjs +6 -5
- package/esm2022/lib/cauca-material.module.mjs +14 -52
- package/esm2022/lib/cauca-menu-sidebar/cauca-menu-sidebar.component.mjs +14 -10
- package/esm2022/lib/cauca-menu-vertical/cauca-menu-vertical.component.mjs +16 -8
- package/esm2022/lib/cauca-simple-dialog/cauca-simple-dialog.component.mjs +14 -10
- package/esm2022/lib/cauca-slideshow/cauca-slideshow.component.mjs +6 -6
- package/esm2022/lib/dialogs/alert-dialog/alert-dialog.component.mjs +57 -0
- package/esm2022/lib/dialogs/confirm-dialog/confirm-dialog.component.mjs +69 -0
- package/esm2022/lib/dialogs/services/dialog.service.mjs +52 -0
- package/esm2022/lib/inputs/cauca-date-time-picker/cauca-date-time-picker.component.mjs +137 -0
- package/esm2022/lib/{cauca-date-time-picker → inputs/cauca-date-time-picker}/components/desktop-time-picker/desktop-time-picker.component.mjs +2 -2
- package/esm2022/lib/inputs/cauca-date-time-picker/components/dialog-date-time-picker/dialog-date-time-picker.component.mjs +358 -0
- package/esm2022/lib/inputs/cauca-date-time-picker/components/mobile-time-picker/mobile-time-picker.component.mjs +74 -0
- package/esm2022/lib/inputs/cauca-date-time-picker/models/dialog-date-time-picker-data.mjs +2 -0
- package/esm2022/lib/inputs/cauca-input-file/cauca-input-file.component.mjs +147 -0
- package/esm2022/lib/inputs/cauca-input-multiple-langue/cauca-input-multiple-langue.component.mjs +99 -0
- package/esm2022/lib/inputs/password/models/password-validation.mjs +13 -0
- package/esm2022/lib/inputs/password/password-criteria/password-criteria.component.mjs +49 -0
- package/esm2022/lib/inputs/password/password-criteria-viewer/password-criteria-viewer.component.mjs +29 -0
- package/esm2022/lib/inputs/password/password-input/password-input.component.mjs +112 -0
- package/esm2022/lib/inputs/password/password-selection/password-selection.component.mjs +112 -0
- package/esm2022/lib/inputs/password/validators/password-validator.mjs +19 -0
- package/esm2022/lib/inputs/select-with-search/select-with-search.component.mjs +157 -0
- package/esm2022/lib/layout/expandable-panel/expandable-panel.component.mjs +75 -0
- package/esm2022/lib/layout/menu-expandable-panel/menu-expandable-panel.component.mjs +148 -0
- package/esm2022/lib/layout/menu-expandable-panel-item/menu-expandable-panel-item.component.mjs +50 -0
- package/esm2022/lib/layout/page-title/page-title.component.mjs +86 -0
- package/esm2022/lib/notifications/snack-bar/snack-bar.component.mjs +75 -0
- package/esm2022/public-api.mjs +21 -4
- package/fesm2022/cauca-911-material.mjs +1988 -648
- package/fesm2022/cauca-911-material.mjs.map +1 -1
- package/lib/buttons/base-button.d.ts +21 -0
- package/lib/buttons/basic-button/basic-button.component.d.ts +6 -0
- package/lib/buttons/flat-button/flat-button.component.d.ts +6 -0
- package/lib/buttons/icon-button/icon-button.component.d.ts +6 -0
- package/lib/buttons/menu-item/menu-item.component.d.ts +9 -0
- package/lib/buttons/raised-button/raised-button.component.d.ts +6 -0
- package/lib/buttons/stroked-button/stroked-button.component.d.ts +6 -0
- package/lib/cauca-material.component.d.ts +1 -1
- package/lib/cauca-material.module.d.ts +4 -14
- package/lib/cauca-menu-sidebar/cauca-menu-sidebar.component.d.ts +1 -1
- package/lib/cauca-menu-vertical/cauca-menu-vertical.component.d.ts +1 -1
- package/lib/cauca-simple-dialog/cauca-simple-dialog.component.d.ts +1 -1
- package/lib/cauca-slideshow/cauca-slideshow.component.d.ts +1 -1
- package/lib/dialogs/alert-dialog/alert-dialog.component.d.ts +18 -0
- package/lib/dialogs/confirm-dialog/confirm-dialog.component.d.ts +17 -0
- package/lib/dialogs/services/dialog.service.d.ts +26 -0
- package/lib/{cauca-input-file → inputs/cauca-input-file}/cauca-input-file.component.d.ts +1 -1
- package/lib/{cauca-input-multiple-langue → inputs/cauca-input-multiple-langue}/cauca-input-multiple-langue.component.d.ts +1 -1
- package/lib/inputs/password/models/password-validation.d.ts +9 -0
- package/lib/inputs/password/password-criteria/password-criteria.component.d.ts +9 -0
- package/lib/inputs/password/password-criteria-viewer/password-criteria-viewer.component.d.ts +9 -0
- package/lib/inputs/password/password-input/password-input.component.d.ts +25 -0
- package/lib/inputs/password/password-selection/password-selection.component.d.ts +20 -0
- package/lib/inputs/password/validators/password-validator.d.ts +9 -0
- package/lib/inputs/select-with-search/select-with-search.component.d.ts +32 -0
- package/lib/layout/expandable-panel/expandable-panel.component.d.ts +10 -0
- package/lib/layout/menu-expandable-panel/menu-expandable-panel.component.d.ts +29 -0
- package/lib/layout/menu-expandable-panel-item/menu-expandable-panel-item.component.d.ts +13 -0
- package/lib/layout/page-title/page-title.component.d.ts +11 -0
- package/lib/notifications/snack-bar/snack-bar.component.d.ts +17 -0
- package/package.json +3 -2
- package/public-api.d.ts +20 -3
- package/esm2022/lib/cauca-date-time-picker/cauca-date-time-picker.component.mjs +0 -137
- package/esm2022/lib/cauca-date-time-picker/components/dialog-date-time-picker/dialog-date-time-picker.component.mjs +0 -357
- package/esm2022/lib/cauca-date-time-picker/components/mobile-time-picker/mobile-time-picker.component.mjs +0 -74
- package/esm2022/lib/cauca-date-time-picker/models/dialog-date-time-picker-data.mjs +0 -2
- package/esm2022/lib/cauca-input-file/cauca-input-file.component.mjs +0 -148
- package/esm2022/lib/cauca-input-multiple-langue/cauca-input-multiple-langue.component.mjs +0 -87
- /package/lib/{cauca-date-time-picker → inputs/cauca-date-time-picker}/cauca-date-time-picker.component.d.ts +0 -0
- /package/lib/{cauca-date-time-picker → inputs/cauca-date-time-picker}/components/desktop-time-picker/desktop-time-picker.component.d.ts +0 -0
- /package/lib/{cauca-date-time-picker → inputs/cauca-date-time-picker}/components/dialog-date-time-picker/dialog-date-time-picker.component.d.ts +0 -0
- /package/lib/{cauca-date-time-picker → inputs/cauca-date-time-picker}/components/mobile-time-picker/mobile-time-picker.component.d.ts +0 -0
- /package/lib/{cauca-date-time-picker → inputs/cauca-date-time-picker}/models/dialog-date-time-picker-data.d.ts +0 -0
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
3
|
+
import { MatInputModule } from '@angular/material/input';
|
|
4
|
+
import { DialogDateTimePickerComponent } from './components/dialog-date-time-picker/dialog-date-time-picker.component';
|
|
5
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
6
|
+
import { DatePipe } from '@angular/common';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@angular/material/dialog";
|
|
9
|
+
import * as i2 from "@angular/common";
|
|
10
|
+
import * as i3 from "@angular/material/button";
|
|
11
|
+
import * as i4 from "@angular/material/icon";
|
|
12
|
+
import * as i5 from "@angular/material/input";
|
|
13
|
+
import * as i6 from "@angular/material/form-field";
|
|
14
|
+
export class CaucaDateTimePickerComponent {
|
|
15
|
+
constructor(elementRef, dialog, datePipe) {
|
|
16
|
+
this.elementRef = elementRef;
|
|
17
|
+
this.dialog = dialog;
|
|
18
|
+
this.datePipe = datePipe;
|
|
19
|
+
this.stepHours = 1;
|
|
20
|
+
this.stepMinutes = 1;
|
|
21
|
+
this.stepSecondes = 1;
|
|
22
|
+
this.minimumDate = null;
|
|
23
|
+
this.maximumDate = null;
|
|
24
|
+
this.showSeconds = false;
|
|
25
|
+
this.showFormat = 'yyyy/MM/dd, HH:mm';
|
|
26
|
+
this.showClearButton = true;
|
|
27
|
+
this.showButtonIcons = true;
|
|
28
|
+
this.selectedChange = new EventEmitter();
|
|
29
|
+
this.stringDate = '';
|
|
30
|
+
}
|
|
31
|
+
set value(value) {
|
|
32
|
+
if (value) {
|
|
33
|
+
this.stringDate = this.stringifyDate(value);
|
|
34
|
+
this.selectedDate = value;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
showDialog() {
|
|
38
|
+
const dialogRef = this.dialog.open(DialogDateTimePickerComponent, {
|
|
39
|
+
position: this.getDialogPosition(),
|
|
40
|
+
data: this.getDateTimePickerOptions(),
|
|
41
|
+
});
|
|
42
|
+
dialogRef.afterClosed().subscribe((data) => {
|
|
43
|
+
if (data) {
|
|
44
|
+
this.stringDate = this.stringifyDate(data.value);
|
|
45
|
+
this.selectedDate = data.value;
|
|
46
|
+
this.selectedChange.emit(data.value);
|
|
47
|
+
}
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
getDateTimePickerOptions() {
|
|
51
|
+
return {
|
|
52
|
+
selectedDate: this.selectedDate,
|
|
53
|
+
minimumDate: this.minimumDate,
|
|
54
|
+
maximumDate: this.maximumDate,
|
|
55
|
+
showSeconds: this.showSeconds,
|
|
56
|
+
showClearButton: this.showClearButton,
|
|
57
|
+
showButtonIcons: this.showButtonIcons,
|
|
58
|
+
step: {
|
|
59
|
+
hours: this.stepHours,
|
|
60
|
+
minutes: this.stepMinutes,
|
|
61
|
+
seconds: this.stepSecondes,
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
stringifyDate(date) {
|
|
66
|
+
return this.datePipe.transform(date, this.showFormat);
|
|
67
|
+
}
|
|
68
|
+
getDialogPosition() {
|
|
69
|
+
const rect = this.elementRef.nativeElement.getBoundingClientRect();
|
|
70
|
+
const top = rect.y + rect.height - 22;
|
|
71
|
+
const bottom = window.innerHeight - rect.y;
|
|
72
|
+
const minimumDialogHeight = 400;
|
|
73
|
+
const minimumScreenSize = 800;
|
|
74
|
+
if (window.innerHeight < minimumScreenSize || window.innerWidth < minimumScreenSize) {
|
|
75
|
+
return null;
|
|
76
|
+
}
|
|
77
|
+
else if (window.innerHeight > (top + minimumDialogHeight)) {
|
|
78
|
+
return {
|
|
79
|
+
left: `${rect.x}px`,
|
|
80
|
+
top: `${top}px`,
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
return {
|
|
84
|
+
left: `${rect.x}px`,
|
|
85
|
+
bottom: `${bottom}px`,
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
static { this.ɵfac = function CaucaDateTimePickerComponent_Factory(t) { return new (t || CaucaDateTimePickerComponent)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i1.MatDialog), i0.ɵɵdirectiveInject(i2.DatePipe)); }; }
|
|
89
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: CaucaDateTimePickerComponent, selectors: [["cauca-date-time-picker"]], inputs: { stepHours: "stepHours", stepMinutes: "stepMinutes", stepSecondes: "stepSecondes", minimumDate: "minimumDate", maximumDate: "maximumDate", showSeconds: "showSeconds", showFormat: "showFormat", showClearButton: "showClearButton", showButtonIcons: "showButtonIcons", value: "value" }, outputs: { selectedChange: "selectedChange" }, standalone: true, features: [i0.ɵɵProvidersFeature([
|
|
90
|
+
DatePipe,
|
|
91
|
+
]), i0.ɵɵStandaloneFeature], decls: 5, vars: 1, consts: [["matInput", "", "readonly", "readonly", 3, "value"], ["matSuffix", "", "mat-icon-button", "", 3, "click"]], template: function CaucaDateTimePickerComponent_Template(rf, ctx) { if (rf & 1) {
|
|
92
|
+
i0.ɵɵelementStart(0, "mat-form-field");
|
|
93
|
+
i0.ɵɵelement(1, "input", 0);
|
|
94
|
+
i0.ɵɵelementStart(2, "button", 1);
|
|
95
|
+
i0.ɵɵlistener("click", function CaucaDateTimePickerComponent_Template_button_click_2_listener() { return ctx.showDialog(); });
|
|
96
|
+
i0.ɵɵelementStart(3, "mat-icon");
|
|
97
|
+
i0.ɵɵtext(4, "calendar_month");
|
|
98
|
+
i0.ɵɵelementEnd()()();
|
|
99
|
+
} if (rf & 2) {
|
|
100
|
+
i0.ɵɵadvance();
|
|
101
|
+
i0.ɵɵproperty("value", ctx.stringDate);
|
|
102
|
+
} }, dependencies: [MatButtonModule, i3.MatIconButton, MatIconModule, i4.MatIcon, MatInputModule, i5.MatInput, i6.MatFormField, i6.MatSuffix], styles: ["[_nghost-%COMP%]{display:block}mat-form-field[_ngcontent-%COMP%]{width:100%}"] }); }
|
|
103
|
+
}
|
|
104
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CaucaDateTimePickerComponent, [{
|
|
105
|
+
type: Component,
|
|
106
|
+
args: [{ selector: 'cauca-date-time-picker', standalone: true, imports: [
|
|
107
|
+
MatButtonModule,
|
|
108
|
+
MatIconModule,
|
|
109
|
+
MatInputModule,
|
|
110
|
+
], providers: [
|
|
111
|
+
DatePipe,
|
|
112
|
+
], template: "<mat-form-field>\n <input matInput [value]=\"stringDate\" readonly=\"readonly\">\n <button matSuffix mat-icon-button (click)=\"showDialog()\">\n <mat-icon>calendar_month</mat-icon>\n </button>\n</mat-form-field>", styles: [":host{display:block}mat-form-field{width:100%}\n"] }]
|
|
113
|
+
}], () => [{ type: i0.ElementRef }, { type: i1.MatDialog }, { type: i2.DatePipe }], { stepHours: [{
|
|
114
|
+
type: Input
|
|
115
|
+
}], stepMinutes: [{
|
|
116
|
+
type: Input
|
|
117
|
+
}], stepSecondes: [{
|
|
118
|
+
type: Input
|
|
119
|
+
}], minimumDate: [{
|
|
120
|
+
type: Input
|
|
121
|
+
}], maximumDate: [{
|
|
122
|
+
type: Input
|
|
123
|
+
}], showSeconds: [{
|
|
124
|
+
type: Input
|
|
125
|
+
}], showFormat: [{
|
|
126
|
+
type: Input
|
|
127
|
+
}], showClearButton: [{
|
|
128
|
+
type: Input
|
|
129
|
+
}], showButtonIcons: [{
|
|
130
|
+
type: Input
|
|
131
|
+
}], selectedChange: [{
|
|
132
|
+
type: Output
|
|
133
|
+
}], value: [{
|
|
134
|
+
type: Input
|
|
135
|
+
}] }); })();
|
|
136
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(CaucaDateTimePickerComponent, { className: "CaucaDateTimePickerComponent", filePath: "lib\\inputs\\cauca-date-time-picker\\cauca-date-time-picker.component.ts", lineNumber: 24 }); })();
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cauca-date-time-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/cauca-material/src/lib/inputs/cauca-date-time-picker/cauca-date-time-picker.component.ts","../../../../../../projects/cauca-material/src/lib/inputs/cauca-date-time-picker/cauca-date-time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, Output } from '@angular/core';\nimport { DialogPosition, MatDialog } from '@angular/material/dialog';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatInputModule } from '@angular/material/input';\nimport { DialogDateTimePickerComponent } from './components/dialog-date-time-picker/dialog-date-time-picker.component';\nimport { DialogDateTimePickerOptions, DialogDateTimePickerValue } from './models/dialog-date-time-picker-data';\nimport { MatButtonModule } from '@angular/material/button';\nimport { DatePipe } from '@angular/common';\n\n@Component({\n  selector: 'cauca-date-time-picker',\n  standalone: true,\n  imports: [\n    MatButtonModule,\n    MatIconModule,\n    MatInputModule,\n  ],\n  providers: [\n    DatePipe,\n  ],\n  templateUrl: './cauca-date-time-picker.component.html',\n  styleUrl: './cauca-date-time-picker.component.scss'\n})\nexport class CaucaDateTimePickerComponent {\n  @Input() public stepHours = 1;\n  @Input() public stepMinutes = 1;\n  @Input() public stepSecondes = 1;\n  @Input() public minimumDate: Date = null;\n  @Input() public maximumDate: Date = null;\n  @Input() public showSeconds: boolean = false;\n  @Input() public showFormat: string = 'yyyy/MM/dd, HH:mm';\n  @Input() public showClearButton: boolean = true;\n  @Input() public showButtonIcons: boolean = true;\n  @Output() public selectedChange = new EventEmitter<Date>();\n\n  public stringDate: string = '';\n\n  private selectedDate: Date;\n\n  public constructor(\n    private elementRef: ElementRef,\n    private dialog: MatDialog,\n    private datePipe: DatePipe,\n  ) {\n  }\n\n  @Input()\n  public set value(value: Date) {\n    if (value) {\n      this.stringDate = this.stringifyDate(value);\n      this.selectedDate = value;\n    }\n  }\n\n  public showDialog(): void {\n    const dialogRef = this.dialog.open(DialogDateTimePickerComponent, {\n      position: this.getDialogPosition(),\n      data: this.getDateTimePickerOptions(),\n    });\n\n    dialogRef.afterClosed().subscribe((data: DialogDateTimePickerValue) => {\n      if (data) {\n        this.stringDate = this.stringifyDate(data.value);\n        this.selectedDate = data.value;\n        this.selectedChange.emit(data.value);\n      }\n    });\n  }\n\n  private getDateTimePickerOptions(): DialogDateTimePickerOptions {\n    return {\n      selectedDate: this.selectedDate,\n      minimumDate: this.minimumDate,\n      maximumDate: this.maximumDate,\n      showSeconds: this.showSeconds,\n      showClearButton: this.showClearButton,\n      showButtonIcons: this.showButtonIcons,\n      step: {\n        hours: this.stepHours,\n        minutes: this.stepMinutes,\n        seconds: this.stepSecondes,\n      }\n    };\n  }\n  private stringifyDate(date: Date): string {\n    return this.datePipe.transform(date, this.showFormat);\n  }\n\n  private getDialogPosition(): DialogPosition {\n    const rect = this.elementRef.nativeElement.getBoundingClientRect();\n    const top = rect.y + rect.height - 22;\n    const bottom = window.innerHeight - rect.y;\n    const minimumDialogHeight = 400;\n    const minimumScreenSize = 800;\n\n    if (window.innerHeight < minimumScreenSize || window.innerWidth < minimumScreenSize) {\n      return null;\n    } else if (window.innerHeight > (top + minimumDialogHeight)) {\n      return {\n        left: `${rect.x}px`,\n        top: `${top}px`,\n      };\n    }\n\n    return {\n      left: `${rect.x}px`,\n      bottom: `${bottom}px`,\n    };\n  }\n}\n","<mat-form-field>\n    <input matInput [value]=\"stringDate\" readonly=\"readonly\">\n    <button matSuffix mat-icon-button (click)=\"showDialog()\">\n        <mat-icon>calendar_month</mat-icon>\n    </button>\n</mat-form-field>"]}
|
|
@@ -45,5 +45,5 @@ export class DesktopTimePickerComponent {
|
|
|
45
45
|
}], valueChange: [{
|
|
46
46
|
type: Output
|
|
47
47
|
}] }); })();
|
|
48
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(DesktopTimePickerComponent, { className: "DesktopTimePickerComponent", filePath: "lib\\cauca-date-time-picker\\components\\desktop-time-picker\\desktop-time-picker.component.ts", lineNumber: 13 }); })();
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
48
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(DesktopTimePickerComponent, { className: "DesktopTimePickerComponent", filePath: "lib\\inputs\\cauca-date-time-picker\\components\\desktop-time-picker\\desktop-time-picker.component.ts", lineNumber: 13 }); })();
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVza3RvcC10aW1lLXBpY2tlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYXVjYS1tYXRlcmlhbC9zcmMvbGliL2lucHV0cy9jYXVjYS1kYXRlLXRpbWUtcGlja2VyL2NvbXBvbmVudHMvZGVza3RvcC10aW1lLXBpY2tlci9kZXNrdG9wLXRpbWUtcGlja2VyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NhdWNhLW1hdGVyaWFsL3NyYy9saWIvaW5wdXRzL2NhdWNhLWRhdGUtdGltZS1waWNrZXIvY29tcG9uZW50cy9kZXNrdG9wLXRpbWUtcGlja2VyL2Rlc2t0b3AtdGltZS1waWNrZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2RSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7Ozs7O0lDQ25ELHdDQUN1QztJQUFuQyx5TkFBUyxrQ0FBd0IsS0FBQztJQUFDLFlBQXNDO0lBQUEsaUJBQWdCOzs7O0lBRC9DLEFBQS9CLHNEQUE4Qiw4RkFBb0Q7SUFDMUQsY0FBc0M7SUFBdEMsNkRBQXNDOztBRFNqRixNQUFNLE9BQU8sMEJBQTBCO0lBVHZDO1FBVWtCLFlBQU8sR0FBYSxFQUFFLENBQUM7UUFJdEIsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO0tBQzNEOzJGQU5ZLDBCQUEwQjtvRUFBMUIsMEJBQTBCO1lDWnZDLG1DQUFxQztZQUNqQyx5SEFHUztZQUNiLGlCQUFXOztZQUxELHlFQUEwQjtZQUNoQyxjQUdTO1lBSFQsMEJBR1M7NEJER1QsYUFBYTs7aUZBS0osMEJBQTBCO2NBVHRDLFNBQVM7MkJBQ0UsMkJBQTJCLGNBQ3pCLElBQUksV0FDUDtvQkFDUCxhQUFhO2lCQUNkO2dCQUtlLE9BQU87a0JBQXRCLEtBQUs7WUFDVSxLQUFLO2tCQUFwQixLQUFLO1lBQ1UsUUFBUTtrQkFBdkIsS0FBSztZQUVXLFdBQVc7a0JBQTNCLE1BQU07O2tGQUxJLDBCQUEwQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNYXRMaXN0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvbGlzdCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2NhdWNhLWRlc2t0b3AtdGltZS1waWNrZXInLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbXG4gICAgTWF0TGlzdE1vZHVsZVxuICBdLFxuICB0ZW1wbGF0ZVVybDogJy4vZGVza3RvcC10aW1lLXBpY2tlci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsOiAnLi9kZXNrdG9wLXRpbWUtcGlja2VyLmNvbXBvbmVudC5zY3NzJ1xufSlcbmV4cG9ydCBjbGFzcyBEZXNrdG9wVGltZVBpY2tlckNvbXBvbmVudCB7XG4gIEBJbnB1dCgpIHB1YmxpYyBvcHRpb25zOiBudW1iZXJbXSA9IFtdO1xuICBASW5wdXQoKSBwdWJsaWMgdmFsdWU6IG51bWJlcjtcbiAgQElucHV0KCkgcHVibGljIGRpc2FibGVkOiBEZXNrdG9wVGltZVBpY2tlckNvbXBvbmVudERpc2FibGVkO1xuXG4gIEBPdXRwdXQoKSBwdWJsaWMgdmFsdWVDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPG51bWJlcj4oKTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEZXNrdG9wVGltZVBpY2tlckNvbXBvbmVudERpc2FibGVkIHtcbiAgYWxsOiBib29sZWFuO1xuICBzb21lT3B0aW9uczogbnVtYmVyW107XG59IiwiPG1hdC1saXN0IFtkaXNhYmxlZF09XCJkaXNhYmxlZD8uYWxsXCI+XG4gICAgQGZvciAob3B0aW9uIG9mIG9wdGlvbnM7IHRyYWNrIG9wdGlvbikge1xuICAgIDxtYXQtbGlzdC1pdGVtIFthY3RpdmF0ZWRdPVwidmFsdWUgPT09IG9wdGlvblwiIFtkaXNhYmxlZF09XCJkaXNhYmxlZD8uc29tZU9wdGlvbnMuaW5jbHVkZXMob3B0aW9uKVwiXG4gICAgICAgIChjbGljayk9XCJ2YWx1ZUNoYW5nZS5lbWl0KG9wdGlvbilcIj57eyhvcHRpb24gPCAxMCA/ICcwJyA6ICcnICkgKyBvcHRpb259fTwvbWF0LWxpc3QtaXRlbT5cbiAgICAgICAgICAgIH1cbjwvbWF0LWxpc3Q+Il19
|
|
@@ -0,0 +1,358 @@
|
|
|
1
|
+
import { Component, HostListener, Inject } from '@angular/core';
|
|
2
|
+
import { MatNativeDateModule } from '@angular/material/core';
|
|
3
|
+
import { MatDatepickerModule } from '@angular/material/datepicker';
|
|
4
|
+
import { MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
5
|
+
import { MatListModule } from '@angular/material/list';
|
|
6
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
7
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
8
|
+
import { MobileTimePickerComponent } from '../mobile-time-picker/mobile-time-picker.component';
|
|
9
|
+
import { DesktopTimePickerComponent } from '../desktop-time-picker/desktop-time-picker.component';
|
|
10
|
+
import { NgClass } from '@angular/common';
|
|
11
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
import * as i1 from "@angular/material/dialog";
|
|
14
|
+
import * as i2 from "@angular/material/button";
|
|
15
|
+
import * as i3 from "@angular/material/datepicker";
|
|
16
|
+
import * as i4 from "@angular/material/icon";
|
|
17
|
+
import * as i5 from "@ngx-translate/core";
|
|
18
|
+
const _c0 = (a0, a1) => ({ all: a0, someOptions: a1 });
|
|
19
|
+
function DialogDateTimePickerComponent_div_4_Template(rf, ctx) { if (rf & 1) {
|
|
20
|
+
const _r1 = i0.ɵɵgetCurrentView();
|
|
21
|
+
i0.ɵɵelementStart(0, "div", 14)(1, "cauca-desktop-time-picker", 15);
|
|
22
|
+
i0.ɵɵlistener("valueChange", function DialogDateTimePickerComponent_div_4_Template_cauca_desktop_time_picker_valueChange_1_listener($event) { i0.ɵɵrestoreView(_r1); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.hourChanged($event)); });
|
|
23
|
+
i0.ɵɵelementEnd()();
|
|
24
|
+
} if (rf & 2) {
|
|
25
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
26
|
+
i0.ɵɵadvance();
|
|
27
|
+
i0.ɵɵproperty("disabled", i0.ɵɵpureFunction2(3, _c0, ctx_r1.disabled.hours, ctx_r1.disabled.someHours))("options", ctx_r1.hours)("value", ctx_r1.selectedHour);
|
|
28
|
+
} }
|
|
29
|
+
function DialogDateTimePickerComponent_div_5_Template(rf, ctx) { if (rf & 1) {
|
|
30
|
+
const _r3 = i0.ɵɵgetCurrentView();
|
|
31
|
+
i0.ɵɵelementStart(0, "div", 14)(1, "cauca-mobile-time-picker", 16);
|
|
32
|
+
i0.ɵɵlistener("valueChange", function DialogDateTimePickerComponent_div_5_Template_cauca_mobile_time_picker_valueChange_1_listener($event) { i0.ɵɵrestoreView(_r3); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.hourChanged($event)); });
|
|
33
|
+
i0.ɵɵelementEnd()();
|
|
34
|
+
} if (rf & 2) {
|
|
35
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
36
|
+
i0.ɵɵadvance();
|
|
37
|
+
i0.ɵɵproperty("options", ctx_r1.hours)("value", ctx_r1.selectedHour);
|
|
38
|
+
} }
|
|
39
|
+
function DialogDateTimePickerComponent_div_6_Template(rf, ctx) { if (rf & 1) {
|
|
40
|
+
i0.ɵɵelementStart(0, "div", 17);
|
|
41
|
+
i0.ɵɵtext(1, ":");
|
|
42
|
+
i0.ɵɵelementEnd();
|
|
43
|
+
} }
|
|
44
|
+
function DialogDateTimePickerComponent_div_7_Template(rf, ctx) { if (rf & 1) {
|
|
45
|
+
const _r4 = i0.ɵɵgetCurrentView();
|
|
46
|
+
i0.ɵɵelementStart(0, "div", 18)(1, "cauca-desktop-time-picker", 15);
|
|
47
|
+
i0.ɵɵlistener("valueChange", function DialogDateTimePickerComponent_div_7_Template_cauca_desktop_time_picker_valueChange_1_listener($event) { i0.ɵɵrestoreView(_r4); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.minuteChanged($event)); });
|
|
48
|
+
i0.ɵɵelementEnd()();
|
|
49
|
+
} if (rf & 2) {
|
|
50
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
51
|
+
i0.ɵɵadvance();
|
|
52
|
+
i0.ɵɵproperty("disabled", i0.ɵɵpureFunction2(3, _c0, ctx_r1.disabled.minutes, ctx_r1.disabled.someMinutes))("options", ctx_r1.minutes)("value", ctx_r1.selectedMinute);
|
|
53
|
+
} }
|
|
54
|
+
function DialogDateTimePickerComponent_div_8_Template(rf, ctx) { if (rf & 1) {
|
|
55
|
+
const _r5 = i0.ɵɵgetCurrentView();
|
|
56
|
+
i0.ɵɵelementStart(0, "div", 18)(1, "cauca-mobile-time-picker", 16);
|
|
57
|
+
i0.ɵɵlistener("valueChange", function DialogDateTimePickerComponent_div_8_Template_cauca_mobile_time_picker_valueChange_1_listener($event) { i0.ɵɵrestoreView(_r5); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.minuteChanged($event)); });
|
|
58
|
+
i0.ɵɵelementEnd()();
|
|
59
|
+
} if (rf & 2) {
|
|
60
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
61
|
+
i0.ɵɵadvance();
|
|
62
|
+
i0.ɵɵproperty("options", ctx_r1.minutes)("value", ctx_r1.selectedMinute);
|
|
63
|
+
} }
|
|
64
|
+
function DialogDateTimePickerComponent_div_9_Template(rf, ctx) { if (rf & 1) {
|
|
65
|
+
i0.ɵɵelementStart(0, "div", 19);
|
|
66
|
+
i0.ɵɵtext(1, ":");
|
|
67
|
+
i0.ɵɵelementEnd();
|
|
68
|
+
} }
|
|
69
|
+
function DialogDateTimePickerComponent_div_10_Template(rf, ctx) { if (rf & 1) {
|
|
70
|
+
const _r6 = i0.ɵɵgetCurrentView();
|
|
71
|
+
i0.ɵɵelementStart(0, "div", 20)(1, "cauca-desktop-time-picker", 15);
|
|
72
|
+
i0.ɵɵlistener("valueChange", function DialogDateTimePickerComponent_div_10_Template_cauca_desktop_time_picker_valueChange_1_listener($event) { i0.ɵɵrestoreView(_r6); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.secondChanged($event)); });
|
|
73
|
+
i0.ɵɵelementEnd()();
|
|
74
|
+
} if (rf & 2) {
|
|
75
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
76
|
+
i0.ɵɵadvance();
|
|
77
|
+
i0.ɵɵproperty("disabled", i0.ɵɵpureFunction2(3, _c0, ctx_r1.disabled.seconds, ctx_r1.disabled.someSeconds))("options", ctx_r1.seconds)("value", ctx_r1.selectedSecond);
|
|
78
|
+
} }
|
|
79
|
+
function DialogDateTimePickerComponent_div_11_Template(rf, ctx) { if (rf & 1) {
|
|
80
|
+
const _r7 = i0.ɵɵgetCurrentView();
|
|
81
|
+
i0.ɵɵelementStart(0, "div", 20)(1, "cauca-mobile-time-picker", 16);
|
|
82
|
+
i0.ɵɵlistener("valueChange", function DialogDateTimePickerComponent_div_11_Template_cauca_mobile_time_picker_valueChange_1_listener($event) { i0.ɵɵrestoreView(_r7); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.secondChanged($event)); });
|
|
83
|
+
i0.ɵɵelementEnd()();
|
|
84
|
+
} if (rf & 2) {
|
|
85
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
86
|
+
i0.ɵɵadvance();
|
|
87
|
+
i0.ɵɵproperty("options", ctx_r1.seconds)("value", ctx_r1.selectedSecond);
|
|
88
|
+
} }
|
|
89
|
+
function DialogDateTimePickerComponent_button_13_mat_icon_1_Template(rf, ctx) { if (rf & 1) {
|
|
90
|
+
i0.ɵɵelementStart(0, "mat-icon");
|
|
91
|
+
i0.ɵɵtext(1, "clear");
|
|
92
|
+
i0.ɵɵelementEnd();
|
|
93
|
+
} }
|
|
94
|
+
function DialogDateTimePickerComponent_button_13_Template(rf, ctx) { if (rf & 1) {
|
|
95
|
+
const _r8 = i0.ɵɵgetCurrentView();
|
|
96
|
+
i0.ɵɵelementStart(0, "button", 11);
|
|
97
|
+
i0.ɵɵlistener("click", function DialogDateTimePickerComponent_button_13_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r8); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.clear()); });
|
|
98
|
+
i0.ɵɵtemplate(1, DialogDateTimePickerComponent_button_13_mat_icon_1_Template, 2, 0, "mat-icon", 12);
|
|
99
|
+
i0.ɵɵtext(2);
|
|
100
|
+
i0.ɵɵpipe(3, "translate");
|
|
101
|
+
i0.ɵɵelementEnd();
|
|
102
|
+
} if (rf & 2) {
|
|
103
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
104
|
+
i0.ɵɵadvance();
|
|
105
|
+
i0.ɵɵproperty("ngIf", ctx_r1.showButtonIcons);
|
|
106
|
+
i0.ɵɵadvance();
|
|
107
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(3, 2, "material.clear"), " ");
|
|
108
|
+
} }
|
|
109
|
+
function DialogDateTimePickerComponent_mat_icon_15_Template(rf, ctx) { if (rf & 1) {
|
|
110
|
+
i0.ɵɵelementStart(0, "mat-icon");
|
|
111
|
+
i0.ɵɵtext(1, "cancel");
|
|
112
|
+
i0.ɵɵelementEnd();
|
|
113
|
+
} }
|
|
114
|
+
function DialogDateTimePickerComponent_mat_icon_19_Template(rf, ctx) { if (rf & 1) {
|
|
115
|
+
i0.ɵɵelementStart(0, "mat-icon");
|
|
116
|
+
i0.ɵɵtext(1, "check");
|
|
117
|
+
i0.ɵɵelementEnd();
|
|
118
|
+
} }
|
|
119
|
+
export class DialogDateTimePickerComponent {
|
|
120
|
+
constructor(dialogRef, options) {
|
|
121
|
+
this.dialogRef = dialogRef;
|
|
122
|
+
this.options = options;
|
|
123
|
+
this.selectedHour = 0;
|
|
124
|
+
this.selectedMinute = 0;
|
|
125
|
+
this.selectedSecond = 0;
|
|
126
|
+
this.initialDate = null;
|
|
127
|
+
this.selectedDate = null;
|
|
128
|
+
this.minimumDate = new Date();
|
|
129
|
+
this.maximumDate = new Date();
|
|
130
|
+
this.showSeconds = false;
|
|
131
|
+
this.showClearButton = true;
|
|
132
|
+
this.showButtonIcons = true;
|
|
133
|
+
this.hours = [...Array(24).keys()];
|
|
134
|
+
this.minutes = [...Array(60).keys()];
|
|
135
|
+
this.seconds = [...Array(60).keys()];
|
|
136
|
+
this.showMobileUi = false;
|
|
137
|
+
this.disabled = {
|
|
138
|
+
hours: true,
|
|
139
|
+
someHours: [],
|
|
140
|
+
minutes: true,
|
|
141
|
+
someMinutes: [],
|
|
142
|
+
seconds: true,
|
|
143
|
+
someSeconds: [],
|
|
144
|
+
};
|
|
145
|
+
this.step = {
|
|
146
|
+
hours: 1,
|
|
147
|
+
minutes: 1,
|
|
148
|
+
seconds: 1,
|
|
149
|
+
};
|
|
150
|
+
this.step = options.step || this.step;
|
|
151
|
+
this.showSeconds = options.showSeconds;
|
|
152
|
+
this.showButtonIcons = options.showButtonIcons ?? this.showButtonIcons;
|
|
153
|
+
this.showClearButton = options.showClearButton ?? this.showClearButton;
|
|
154
|
+
this.setListHoursMinutes();
|
|
155
|
+
this.initialEachComponentValue(options);
|
|
156
|
+
}
|
|
157
|
+
ngOnInit() {
|
|
158
|
+
this.onWindowWithChange(window.innerWidth);
|
|
159
|
+
}
|
|
160
|
+
onResize(event) {
|
|
161
|
+
this.onWindowWithChange(event.target.innerWidth);
|
|
162
|
+
}
|
|
163
|
+
dateChanged(date) {
|
|
164
|
+
if (date) {
|
|
165
|
+
this.selectedDate = date;
|
|
166
|
+
this.selectedDate.setHours(this.selectedHour);
|
|
167
|
+
this.selectedDate.setMinutes(this.selectedMinute);
|
|
168
|
+
this.selectedDate.setSeconds(this.selectedSecond);
|
|
169
|
+
this.disabled.hours = false;
|
|
170
|
+
this.disabled.someHours = this.hours.filter(hour => this.hourOfSelectedDateIsDisabled(hour));
|
|
171
|
+
}
|
|
172
|
+
else {
|
|
173
|
+
this.selectedDate = null;
|
|
174
|
+
this.disabled.hours = true;
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
hourChanged(hour) {
|
|
178
|
+
if (this.disabled.hours || this.disabled.someHours.includes(hour))
|
|
179
|
+
return;
|
|
180
|
+
this.selectedHour = hour;
|
|
181
|
+
this.selectedDate.setHours(hour);
|
|
182
|
+
this.disabled.minutes = false;
|
|
183
|
+
this.disabled.someMinutes = this.minutes.filter(minute => this.minuteOfSelectedDateIsDisabled(minute));
|
|
184
|
+
}
|
|
185
|
+
minuteChanged(minute) {
|
|
186
|
+
if (this.disabled.minutes || this.disabled.someMinutes.includes(minute))
|
|
187
|
+
return;
|
|
188
|
+
this.selectedMinute = minute;
|
|
189
|
+
this.selectedDate.setMinutes(minute);
|
|
190
|
+
this.disabled.seconds = false;
|
|
191
|
+
this.disabled.someSeconds = this.seconds.filter(second => this.secondOfSelectedDateIsDisabled(second));
|
|
192
|
+
}
|
|
193
|
+
secondChanged(second) {
|
|
194
|
+
if (this.disabled.seconds || this.disabled.someSeconds.includes(second))
|
|
195
|
+
return;
|
|
196
|
+
this.selectedSecond = second;
|
|
197
|
+
this.selectedDate.setSeconds(second);
|
|
198
|
+
}
|
|
199
|
+
clear() {
|
|
200
|
+
this.dialogRef.close({
|
|
201
|
+
value: null
|
|
202
|
+
});
|
|
203
|
+
}
|
|
204
|
+
cancel() {
|
|
205
|
+
this.dialogRef.close({
|
|
206
|
+
value: this.initialDate
|
|
207
|
+
});
|
|
208
|
+
}
|
|
209
|
+
confirm() {
|
|
210
|
+
this.dialogRef.close({
|
|
211
|
+
value: this.selectedDate
|
|
212
|
+
});
|
|
213
|
+
}
|
|
214
|
+
onWindowWithChange(width) {
|
|
215
|
+
this.showMobileUi = width && width <= 555;
|
|
216
|
+
}
|
|
217
|
+
hourOfSelectedDateIsDisabled(hour) {
|
|
218
|
+
if (this.selectedDateIsTheMinimumDate()) {
|
|
219
|
+
return hour < this.minimumDate.getHours();
|
|
220
|
+
}
|
|
221
|
+
else if (this.selectedDateIsTheMaximumDate()) {
|
|
222
|
+
return hour > this.maximumDate.getHours();
|
|
223
|
+
}
|
|
224
|
+
return false;
|
|
225
|
+
}
|
|
226
|
+
minuteOfSelectedDateIsDisabled(minute) {
|
|
227
|
+
if (this.selectedDateIsTheMinimumDate() &&
|
|
228
|
+
this.selectedDate.getHours() === this.minimumDate.getHours()) {
|
|
229
|
+
return minute < this.minimumDate.getMinutes();
|
|
230
|
+
}
|
|
231
|
+
else if (this.selectedDateIsTheMaximumDate() &&
|
|
232
|
+
this.selectedDate.getHours() === this.maximumDate.getHours()) {
|
|
233
|
+
return minute > this.maximumDate.getMinutes();
|
|
234
|
+
}
|
|
235
|
+
return false;
|
|
236
|
+
}
|
|
237
|
+
secondOfSelectedDateIsDisabled(second) {
|
|
238
|
+
if (this.selectedDateIsTheMinimumDate() &&
|
|
239
|
+
this.selectedDate.getHours() === this.minimumDate.getHours() &&
|
|
240
|
+
this.selectedDate.getMinutes() === this.minimumDate.getMinutes()) {
|
|
241
|
+
return second < this.minimumDate.getSeconds();
|
|
242
|
+
}
|
|
243
|
+
else if (this.selectedDateIsTheMaximumDate() &&
|
|
244
|
+
this.selectedDate.getMinutes() === this.maximumDate.getMinutes()) {
|
|
245
|
+
return second > this.maximumDate.getSeconds();
|
|
246
|
+
}
|
|
247
|
+
return false;
|
|
248
|
+
}
|
|
249
|
+
initialEachComponentValue(options) {
|
|
250
|
+
this.initialDate = options.selectedDate ? new Date(options.selectedDate) : null;
|
|
251
|
+
this.minimumDate = options.minimumDate ? new Date(options.minimumDate) : null;
|
|
252
|
+
this.maximumDate = options.maximumDate ? new Date(options.maximumDate) : null;
|
|
253
|
+
this.selectedDate = options.selectedDate ? new Date(options.selectedDate) : new Date();
|
|
254
|
+
this.dateChanged(options.selectedDate ? new Date(options.selectedDate) : null);
|
|
255
|
+
this.hourChanged(options.selectedDate ? new Date(options.selectedDate).getHours() : 0);
|
|
256
|
+
this.minuteChanged(options.selectedDate ? new Date(options.selectedDate).getMinutes() : 0);
|
|
257
|
+
this.secondChanged(options.selectedDate ? new Date(options.selectedDate).getSeconds() : 0);
|
|
258
|
+
}
|
|
259
|
+
selectedDateIsTheMinimumDate() {
|
|
260
|
+
return (this.minimumDate &&
|
|
261
|
+
this.selectedDate.getFullYear() === this.minimumDate.getFullYear() &&
|
|
262
|
+
this.selectedDate.getMonth() === this.minimumDate.getMonth() &&
|
|
263
|
+
this.selectedDate.getDate() === this.minimumDate.getDate());
|
|
264
|
+
}
|
|
265
|
+
selectedDateIsTheMaximumDate() {
|
|
266
|
+
return (this.maximumDate &&
|
|
267
|
+
this.selectedDate.getFullYear() === this.maximumDate.getFullYear() &&
|
|
268
|
+
this.selectedDate.getMonth() === this.maximumDate.getMonth() &&
|
|
269
|
+
this.selectedDate.getDate() === this.maximumDate.getDate());
|
|
270
|
+
}
|
|
271
|
+
setListHoursMinutes() {
|
|
272
|
+
this.hours = this.hours.filter(hour => hour % this.step.hours === 0);
|
|
273
|
+
this.minutes = this.minutes.filter(minute => minute % this.step.minutes === 0);
|
|
274
|
+
this.seconds = this.seconds.filter(seconde => seconde % this.step.seconds === 0);
|
|
275
|
+
}
|
|
276
|
+
static { this.ɵfac = function DialogDateTimePickerComponent_Factory(t) { return new (t || DialogDateTimePickerComponent)(i0.ɵɵdirectiveInject(i1.MatDialogRef), i0.ɵɵdirectiveInject(MAT_DIALOG_DATA)); }; }
|
|
277
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: DialogDateTimePickerComponent, selectors: [["cauca-dialog-date-time-picker"]], hostBindings: function DialogDateTimePickerComponent_HostBindings(rf, ctx) { if (rf & 1) {
|
|
278
|
+
i0.ɵɵlistener("resize", function DialogDateTimePickerComponent_resize_HostBindingHandler($event) { return ctx.onResize($event); }, false, i0.ɵɵresolveWindow);
|
|
279
|
+
} }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 22, vars: 21, consts: [["mat-dialog-content", ""], [1, "date-time-picker", 3, "ngClass"], [1, "calendar"], [3, "selectedChange", "minDate", "maxDate", "selected"], ["class", "hours", 4, "ngIf"], ["class", "hour-and-minute-separator", 4, "ngIf"], ["class", "minutes", 4, "ngIf"], ["class", "minute-and-second-separator", 4, "ngIf"], ["class", "seconds", 4, "ngIf"], ["mat-dialog-actions", "", "align", "end"], ["mat-stroked-button", "", 3, "click", 4, "ngIf"], ["mat-stroked-button", "", 3, "click"], [4, "ngIf"], ["color", "primary", "mat-raised-button", "", "cdkFocusInitial", "", 3, "click"], [1, "hours"], [3, "valueChange", "disabled", "options", "value"], [3, "valueChange", "options", "value"], [1, "hour-and-minute-separator"], [1, "minutes"], [1, "minute-and-second-separator"], [1, "seconds"]], template: function DialogDateTimePickerComponent_Template(rf, ctx) { if (rf & 1) {
|
|
280
|
+
i0.ɵɵelementStart(0, "div", 0)(1, "div", 1)(2, "div", 2)(3, "mat-calendar", 3);
|
|
281
|
+
i0.ɵɵlistener("selectedChange", function DialogDateTimePickerComponent_Template_mat_calendar_selectedChange_3_listener($event) { return ctx.dateChanged($event); });
|
|
282
|
+
i0.ɵɵelementEnd()();
|
|
283
|
+
i0.ɵɵtemplate(4, DialogDateTimePickerComponent_div_4_Template, 2, 6, "div", 4)(5, DialogDateTimePickerComponent_div_5_Template, 2, 2, "div", 4)(6, DialogDateTimePickerComponent_div_6_Template, 2, 0, "div", 5)(7, DialogDateTimePickerComponent_div_7_Template, 2, 6, "div", 6)(8, DialogDateTimePickerComponent_div_8_Template, 2, 2, "div", 6)(9, DialogDateTimePickerComponent_div_9_Template, 2, 0, "div", 7)(10, DialogDateTimePickerComponent_div_10_Template, 2, 6, "div", 8)(11, DialogDateTimePickerComponent_div_11_Template, 2, 2, "div", 8);
|
|
284
|
+
i0.ɵɵelementEnd()();
|
|
285
|
+
i0.ɵɵelementStart(12, "div", 9);
|
|
286
|
+
i0.ɵɵtemplate(13, DialogDateTimePickerComponent_button_13_Template, 4, 4, "button", 10);
|
|
287
|
+
i0.ɵɵelementStart(14, "button", 11);
|
|
288
|
+
i0.ɵɵlistener("click", function DialogDateTimePickerComponent_Template_button_click_14_listener() { return ctx.cancel(); });
|
|
289
|
+
i0.ɵɵtemplate(15, DialogDateTimePickerComponent_mat_icon_15_Template, 2, 0, "mat-icon", 12);
|
|
290
|
+
i0.ɵɵtext(16);
|
|
291
|
+
i0.ɵɵpipe(17, "translate");
|
|
292
|
+
i0.ɵɵelementEnd();
|
|
293
|
+
i0.ɵɵelementStart(18, "button", 13);
|
|
294
|
+
i0.ɵɵlistener("click", function DialogDateTimePickerComponent_Template_button_click_18_listener() { return ctx.confirm(); });
|
|
295
|
+
i0.ɵɵtemplate(19, DialogDateTimePickerComponent_mat_icon_19_Template, 2, 0, "mat-icon", 12);
|
|
296
|
+
i0.ɵɵtext(20);
|
|
297
|
+
i0.ɵɵpipe(21, "translate");
|
|
298
|
+
i0.ɵɵelementEnd()();
|
|
299
|
+
} if (rf & 2) {
|
|
300
|
+
i0.ɵɵadvance();
|
|
301
|
+
i0.ɵɵproperty("ngClass", ctx.showSeconds ? "show-seconds" : "hide-seconds");
|
|
302
|
+
i0.ɵɵadvance(2);
|
|
303
|
+
i0.ɵɵproperty("minDate", ctx.minimumDate)("maxDate", ctx.maximumDate)("selected", ctx.selectedDate);
|
|
304
|
+
i0.ɵɵadvance();
|
|
305
|
+
i0.ɵɵproperty("ngIf", !ctx.showMobileUi);
|
|
306
|
+
i0.ɵɵadvance();
|
|
307
|
+
i0.ɵɵproperty("ngIf", ctx.showMobileUi);
|
|
308
|
+
i0.ɵɵadvance();
|
|
309
|
+
i0.ɵɵproperty("ngIf", ctx.showMobileUi);
|
|
310
|
+
i0.ɵɵadvance();
|
|
311
|
+
i0.ɵɵproperty("ngIf", !ctx.showMobileUi);
|
|
312
|
+
i0.ɵɵadvance();
|
|
313
|
+
i0.ɵɵproperty("ngIf", ctx.showMobileUi);
|
|
314
|
+
i0.ɵɵadvance();
|
|
315
|
+
i0.ɵɵproperty("ngIf", ctx.showSeconds && ctx.showMobileUi);
|
|
316
|
+
i0.ɵɵadvance();
|
|
317
|
+
i0.ɵɵproperty("ngIf", ctx.showSeconds && !ctx.showMobileUi);
|
|
318
|
+
i0.ɵɵadvance();
|
|
319
|
+
i0.ɵɵproperty("ngIf", ctx.showSeconds && ctx.showMobileUi);
|
|
320
|
+
i0.ɵɵadvance(2);
|
|
321
|
+
i0.ɵɵproperty("ngIf", ctx.showClearButton);
|
|
322
|
+
i0.ɵɵadvance(2);
|
|
323
|
+
i0.ɵɵproperty("ngIf", ctx.showButtonIcons);
|
|
324
|
+
i0.ɵɵadvance();
|
|
325
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(17, 17, "material.cancel"), " ");
|
|
326
|
+
i0.ɵɵadvance(3);
|
|
327
|
+
i0.ɵɵproperty("ngIf", ctx.showButtonIcons);
|
|
328
|
+
i0.ɵɵadvance();
|
|
329
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(21, 19, "material.ok"), " ");
|
|
330
|
+
} }, dependencies: [MatButtonModule, i2.MatButton, MatDatepickerModule, i3.MatCalendar, MatIconModule, i4.MatIcon, MatListModule,
|
|
331
|
+
MatNativeDateModule,
|
|
332
|
+
MobileTimePickerComponent,
|
|
333
|
+
DesktopTimePickerComponent,
|
|
334
|
+
NgClass,
|
|
335
|
+
TranslateModule, i5.TranslatePipe], styles: ["div[mat-dialog-actions][_ngcontent-%COMP%]{padding:8px;border-top:1px solid #ccc}div[mat-dialog-actions][_ngcontent-%COMP%] button[_ngcontent-%COMP%]{margin:2px}.date-time-picker[_ngcontent-%COMP%]{display:grid;grid-template-areas:\"calendar hours minutes seconds\";height:350px;overflow:hidden;justify-content:center}.date-time-picker[_ngcontent-%COMP%] > div[_ngcontent-%COMP%]{overflow:auto;flex:1;max-width:50px;scrollbar-width:none;border-left:1px solid #ccc}.date-time-picker[_ngcontent-%COMP%] > div[_ngcontent-%COMP%]:first-child{flex:4;max-width:290px;border-left:none}.date-time-picker[_ngcontent-%COMP%] > div[_ngcontent-%COMP%]:first-child mat-calendar[_ngcontent-%COMP%]{width:290px;height:350px}.date-time-picker[_ngcontent-%COMP%] > div[_ngcontent-%COMP%]::-webkit-scrollbar{display:none}.date-time-picker[_ngcontent-%COMP%] .mdc-list-item__primary-text{font-family:var(--mat-datepicker-calendar-text-font);font-size:var(--mat-datepicker-calendar-text-size)}.date-time-picker[_ngcontent-%COMP%] .mdc-list-item--activated{background-color:var(--mat-datepicker-calendar-date-selected-state-background-color)}.date-time-picker[_ngcontent-%COMP%] .mdc-list-item--activated .mdc-list-item__primary-text{color:var(--mat-datepicker-calendar-date-selected-state-text-color)}.calendar[_ngcontent-%COMP%]{grid-area:calendar}.hours[_ngcontent-%COMP%]{grid-area:hours}.minutes[_ngcontent-%COMP%]{grid-area:minutes}.seconds[_ngcontent-%COMP%]{grid-area:seconds}.hour-and-minute-separator[_ngcontent-%COMP%]{grid-area:hour-and-minute-separator;display:flex;align-items:center;justify-content:center;font-weight:700}.minute-and-second-separator[_ngcontent-%COMP%]{grid-area:minute-and-second-separator;display:flex;align-items:center;justify-content:center;font-weight:700}@media only screen and (max-width: 555px){.show-seconds[_ngcontent-%COMP%]{grid-template-areas:\"calendar calendar calendar calendar calendar calendar calendar\" \". hours hour-and-minute-separator minutes minute-and-second-separator seconds .\";grid-template-columns:auto 40px 2px 40px 2px 40px auto}.hide-seconds[_ngcontent-%COMP%]{grid-template-areas:\"calendar calendar calendar calendar calendar\" \". hours hour-and-minute-separator minutes .\";grid-template-columns:auto 40px 2px 40px auto}.date-time-picker[_ngcontent-%COMP%]{grid-template-rows:auto auto;height:450px}.date-time-picker[_ngcontent-%COMP%] > div[_ngcontent-%COMP%]{border-left:none}.date-time-picker[_ngcontent-%COMP%] > div[_ngcontent-%COMP%]:not(:first-child){height:70px}.date-time-picker[_ngcontent-%COMP%] > div[_ngcontent-%COMP%]:first-child{overflow:initial;flex:4;max-width:290px;border-left:none}}"] }); }
|
|
336
|
+
}
|
|
337
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DialogDateTimePickerComponent, [{
|
|
338
|
+
type: Component,
|
|
339
|
+
args: [{ selector: 'cauca-dialog-date-time-picker', standalone: true, imports: [
|
|
340
|
+
MatButtonModule,
|
|
341
|
+
MatDatepickerModule,
|
|
342
|
+
MatIconModule,
|
|
343
|
+
MatListModule,
|
|
344
|
+
MatNativeDateModule,
|
|
345
|
+
MobileTimePickerComponent,
|
|
346
|
+
DesktopTimePickerComponent,
|
|
347
|
+
NgClass,
|
|
348
|
+
TranslateModule
|
|
349
|
+
], template: "<div mat-dialog-content>\n <div [ngClass]=\"showSeconds ? 'show-seconds' : 'hide-seconds'\" class=\"date-time-picker\">\n <div class=\"calendar\">\n <mat-calendar\n [minDate]=\"minimumDate\"\n [maxDate]=\"maximumDate\"\n [selected]=\"selectedDate\"\n (selectedChange)=\"dateChanged($event)\"\n ></mat-calendar>\n </div>\n\n <div class=\"hours\" *ngIf=\"!showMobileUi\">\n <cauca-desktop-time-picker [disabled]=\"{all: disabled.hours, someOptions: disabled.someHours}\" (valueChange)=\"hourChanged($event)\" [options]=\"hours\" [value]=\"selectedHour\"/>\n </div>\n <div class=\"hours\" *ngIf=\"showMobileUi\">\n <cauca-mobile-time-picker (valueChange)=\"hourChanged($event)\" [options]=\"hours\" [value]=\"selectedHour\" />\n </div>\n\n <div class=\"hour-and-minute-separator\" *ngIf=\"showMobileUi\">:</div>\n\n <div class=\"minutes\" *ngIf=\"!showMobileUi\">\n <cauca-desktop-time-picker [disabled]=\"{all: disabled.minutes, someOptions: disabled.someMinutes}\" (valueChange)=\"minuteChanged($event)\" [options]=\"minutes\" [value]=\"selectedMinute\"/>\n </div>\n <div class=\"minutes\" *ngIf=\"showMobileUi\">\n <cauca-mobile-time-picker (valueChange)=\"minuteChanged($event)\" [options]=\"minutes\" [value]=\"selectedMinute\" />\n </div>\n\n <div class=\"minute-and-second-separator\" *ngIf=\"showSeconds && showMobileUi\">:</div>\n <div class=\"seconds\" *ngIf=\"showSeconds && !showMobileUi\">\n <cauca-desktop-time-picker [disabled]=\"{all: disabled.seconds, someOptions: disabled.someSeconds}\" (valueChange)=\"secondChanged($event)\" [options]=\"seconds\" [value]=\"selectedSecond\"/>\n </div>\n <div class=\"seconds\" *ngIf=\"showSeconds && showMobileUi\">\n <cauca-mobile-time-picker (valueChange)=\"secondChanged($event)\" [options]=\"seconds\" [value]=\"selectedSecond\" />\n </div>\n </div>\n</div>\n\n<div mat-dialog-actions align=\"end\">\n <button mat-stroked-button (click)=\"clear()\" *ngIf=\"showClearButton\">\n <mat-icon *ngIf=\"showButtonIcons\">clear</mat-icon>\n {{'material.clear' | translate}}\n </button>\n <button mat-stroked-button (click)=\"cancel()\">\n <mat-icon *ngIf=\"showButtonIcons\">cancel</mat-icon>\n {{'material.cancel' | translate}}\n </button>\n <button color=\"primary\" mat-raised-button cdkFocusInitial (click)=\"confirm()\">\n <mat-icon *ngIf=\"showButtonIcons\">check</mat-icon>\n {{'material.ok' | translate}}\n </button>\n</div>", styles: ["div[mat-dialog-actions]{padding:8px;border-top:1px solid #ccc}div[mat-dialog-actions] button{margin:2px}.date-time-picker{display:grid;grid-template-areas:\"calendar hours minutes seconds\";height:350px;overflow:hidden;justify-content:center}.date-time-picker>div{overflow:auto;flex:1;max-width:50px;scrollbar-width:none;border-left:1px solid #ccc}.date-time-picker>div:first-child{flex:4;max-width:290px;border-left:none}.date-time-picker>div:first-child mat-calendar{width:290px;height:350px}.date-time-picker>div::-webkit-scrollbar{display:none}.date-time-picker ::ng-deep .mdc-list-item__primary-text{font-family:var(--mat-datepicker-calendar-text-font);font-size:var(--mat-datepicker-calendar-text-size)}.date-time-picker ::ng-deep .mdc-list-item--activated{background-color:var(--mat-datepicker-calendar-date-selected-state-background-color)}.date-time-picker ::ng-deep .mdc-list-item--activated .mdc-list-item__primary-text{color:var(--mat-datepicker-calendar-date-selected-state-text-color)}.calendar{grid-area:calendar}.hours{grid-area:hours}.minutes{grid-area:minutes}.seconds{grid-area:seconds}.hour-and-minute-separator{grid-area:hour-and-minute-separator;display:flex;align-items:center;justify-content:center;font-weight:700}.minute-and-second-separator{grid-area:minute-and-second-separator;display:flex;align-items:center;justify-content:center;font-weight:700}@media only screen and (max-width: 555px){.show-seconds{grid-template-areas:\"calendar calendar calendar calendar calendar calendar calendar\" \". hours hour-and-minute-separator minutes minute-and-second-separator seconds .\";grid-template-columns:auto 40px 2px 40px 2px 40px auto}.hide-seconds{grid-template-areas:\"calendar calendar calendar calendar calendar\" \". hours hour-and-minute-separator minutes .\";grid-template-columns:auto 40px 2px 40px auto}.date-time-picker{grid-template-rows:auto auto;height:450px}.date-time-picker>div{border-left:none}.date-time-picker>div:not(:first-child){height:70px}.date-time-picker>div:first-child{overflow:initial;flex:4;max-width:290px;border-left:none}}\n"] }]
|
|
350
|
+
}], () => [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
|
|
351
|
+
type: Inject,
|
|
352
|
+
args: [MAT_DIALOG_DATA]
|
|
353
|
+
}] }], { onResize: [{
|
|
354
|
+
type: HostListener,
|
|
355
|
+
args: ['window:resize', ['$event']]
|
|
356
|
+
}] }); })();
|
|
357
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(DialogDateTimePickerComponent, { className: "DialogDateTimePickerComponent", filePath: "lib\\inputs\\cauca-date-time-picker\\components\\dialog-date-time-picker\\dialog-date-time-picker.component.ts", lineNumber: 31 }); })();
|
|
358
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-date-time-picker.component.js","sourceRoot":"","sources":["../../../../../../../../projects/cauca-material/src/lib/inputs/cauca-date-time-picker/components/dialog-date-time-picker/dialog-date-time-picker.component.ts","../../../../../../../../projects/cauca-material/src/lib/inputs/cauca-date-time-picker/components/dialog-date-time-picker/dialog-date-time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostListener, Inject, OnInit } from '@angular/core';\nimport { MatNativeDateModule } from '@angular/material/core';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\nimport { MatListModule } from '@angular/material/list';\nimport { DialogDateTimePickerOptions, DialogDateTimePickerDataDisabled, DialogDateTimePickerDataStep } from '../../models/dialog-date-time-picker-data';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MobileTimePickerComponent } from '../mobile-time-picker/mobile-time-picker.component';\nimport { DesktopTimePickerComponent } from '../desktop-time-picker/desktop-time-picker.component';\nimport { NgClass } from '@angular/common';\nimport { TranslateModule } from '@ngx-translate/core';\n\n@Component({\n  selector: 'cauca-dialog-date-time-picker',\n  standalone: true,\n  imports: [\n    MatButtonModule,\n    MatDatepickerModule,\n    MatIconModule,\n    MatListModule,\n    MatNativeDateModule,\n    MobileTimePickerComponent,\n    DesktopTimePickerComponent,\n    NgClass,\n    TranslateModule\n  ],\n  templateUrl: './dialog-date-time-picker.component.html',\n  styleUrl: './dialog-date-time-picker.component.scss'\n})\nexport class DialogDateTimePickerComponent implements OnInit {\n  public selectedHour = 0;\n  public selectedMinute = 0;\n  public selectedSecond = 0;\n  public initialDate: Date = null;\n  public selectedDate: Date = null;\n  public minimumDate = new Date();\n  public maximumDate = new Date();\n  public showSeconds: boolean = false;\n  public showClearButton: boolean = true;\n  public showButtonIcons: boolean = true;\n\n  public hours = [...Array(24).keys()];\n  public minutes = [...Array(60).keys()];\n  public seconds = [...Array(60).keys()];\n  public showMobileUi: boolean = false;\n\n  public disabled: DialogDateTimePickerDataDisabled = {\n    hours: true,\n    someHours: [],\n    minutes: true,\n    someMinutes: [],\n    seconds: true,\n    someSeconds: [],\n  };\n\n  private step: DialogDateTimePickerDataStep = {\n    hours: 1,\n    minutes: 1,\n    seconds: 1,\n  };\n\n  public constructor(\n    public dialogRef: MatDialogRef<DialogDateTimePickerComponent>,\n    @Inject(MAT_DIALOG_DATA) public options: DialogDateTimePickerOptions\n  ) {\n    this.step = options.step || this.step;\n    this.showSeconds = options.showSeconds;\n    this.showButtonIcons = options.showButtonIcons ?? this.showButtonIcons;\n    this.showClearButton = options.showClearButton ?? this.showClearButton;\n    this.setListHoursMinutes();\n    this.initialEachComponentValue(options);\n  }\n\n  public ngOnInit(): void {\n    this.onWindowWithChange(window.innerWidth);\n  }\n\n  @HostListener('window:resize', ['$event'])\n  public onResize(event) {\n    this.onWindowWithChange(event.target.innerWidth);\n  }\n\n  public dateChanged(date: Date): void {\n    if (date) {\n      this.selectedDate = date;\n      this.selectedDate.setHours(this.selectedHour);\n      this.selectedDate.setMinutes(this.selectedMinute);\n      this.selectedDate.setSeconds(this.selectedSecond);\n      this.disabled.hours = false;\n      this.disabled.someHours = this.hours.filter(hour => this.hourOfSelectedDateIsDisabled(hour));\n    } else {\n      this.selectedDate = null;\n      this.disabled.hours = true;\n    }\n  }\n\n  public hourChanged(hour: number): void {\n    if (this.disabled.hours || this.disabled.someHours.includes(hour)) return;\n\n    this.selectedHour = hour;\n    this.selectedDate.setHours(hour);\n    this.disabled.minutes = false;\n    this.disabled.someMinutes = this.minutes.filter(minute => this.minuteOfSelectedDateIsDisabled(minute));\n  }\n\n  public minuteChanged(minute: number): void {\n    if (this.disabled.minutes || this.disabled.someMinutes.includes(minute)) return;\n\n    this.selectedMinute = minute;\n    this.selectedDate.setMinutes(minute);\n    this.disabled.seconds = false;\n    this.disabled.someSeconds = this.seconds.filter(second => this.secondOfSelectedDateIsDisabled(second));\n  }\n\n  public secondChanged(second: number): void {\n    if (this.disabled.seconds || this.disabled.someSeconds.includes(second)) return;\n\n    this.selectedSecond = second;\n    this.selectedDate.setSeconds(second);\n  }\n\n  public clear(): void {\n    this.dialogRef.close({\n      value: null\n    });\n  }\n\n  public cancel(): void {\n    this.dialogRef.close({\n      value: this.initialDate\n    });\n  }\n\n  public confirm(): void {\n    this.dialogRef.close({\n      value: this.selectedDate\n    });\n  }\n\n  private onWindowWithChange(width: number): void {\n    this.showMobileUi = width && width <= 555;\n  }\n\n  private hourOfSelectedDateIsDisabled(hour: number): boolean {\n    if (this.selectedDateIsTheMinimumDate()) {\n      return hour < this.minimumDate.getHours();\n    } else if (this.selectedDateIsTheMaximumDate()) {\n      return hour > this.maximumDate.getHours();\n    }\n\n    return false;\n  }\n\n  private minuteOfSelectedDateIsDisabled(minute: number): boolean {\n    if (\n      this.selectedDateIsTheMinimumDate() &&\n      this.selectedDate.getHours() === this.minimumDate.getHours()\n    ) {\n      return minute < this.minimumDate.getMinutes();\n    } else if (\n      this.selectedDateIsTheMaximumDate() &&\n      this.selectedDate.getHours() === this.maximumDate.getHours()\n    ) {\n      return minute > this.maximumDate.getMinutes();\n    }\n\n    return false;\n  }\n\n  private secondOfSelectedDateIsDisabled(second: number): boolean {\n    if (\n      this.selectedDateIsTheMinimumDate() &&\n      this.selectedDate.getHours() === this.minimumDate.getHours() &&\n      this.selectedDate.getMinutes() === this.minimumDate.getMinutes()\n    ) {\n      return second < this.minimumDate.getSeconds();\n    } else if (\n      this.selectedDateIsTheMaximumDate() &&\n      this.selectedDate.getMinutes() === this.maximumDate.getMinutes()\n    ) {\n      return second > this.maximumDate.getSeconds();\n    }\n\n    return false;\n  }\n\n  private initialEachComponentValue(options: DialogDateTimePickerOptions): void {\n    this.initialDate = options.selectedDate ? new Date(options.selectedDate) : null;\n    this.minimumDate = options.minimumDate ? new Date(options.minimumDate) : null;\n    this.maximumDate = options.maximumDate ? new Date(options.maximumDate) : null;\n    this.selectedDate = options.selectedDate ? new Date(options.selectedDate) : new Date();\n    this.dateChanged(options.selectedDate ? new Date(options.selectedDate) : null);\n    this.hourChanged(options.selectedDate ? new Date(options.selectedDate).getHours() : 0);\n    this.minuteChanged(options.selectedDate ? new Date(options.selectedDate).getMinutes() : 0);\n    this.secondChanged(options.selectedDate ? new Date(options.selectedDate).getSeconds() : 0);\n  }\n\n  private selectedDateIsTheMinimumDate(): boolean {\n    return (\n      this.minimumDate &&\n      this.selectedDate.getFullYear() === this.minimumDate.getFullYear() &&\n      this.selectedDate.getMonth() === this.minimumDate.getMonth() &&\n      this.selectedDate.getDate() === this.minimumDate.getDate()\n    );\n  }\n\n  private selectedDateIsTheMaximumDate(): boolean {\n    return (\n      this.maximumDate &&\n      this.selectedDate.getFullYear() === this.maximumDate.getFullYear() &&\n      this.selectedDate.getMonth() === this.maximumDate.getMonth() &&\n      this.selectedDate.getDate() === this.maximumDate.getDate()\n    );\n  }\n\n  private setListHoursMinutes(): void {\n    this.hours = this.hours.filter(hour => hour % this.step.hours === 0);\n    this.minutes = this.minutes.filter(minute => minute % this.step.minutes === 0);\n    this.seconds = this.seconds.filter(seconde => seconde % this.step.seconds === 0);\n  }\n}\n","<div mat-dialog-content>\n    <div [ngClass]=\"showSeconds ? 'show-seconds' : 'hide-seconds'\" class=\"date-time-picker\">\n        <div class=\"calendar\">\n            <mat-calendar\n                [minDate]=\"minimumDate\"\n                [maxDate]=\"maximumDate\"\n                [selected]=\"selectedDate\"\n                (selectedChange)=\"dateChanged($event)\"\n            ></mat-calendar>\n        </div>\n\n        <div class=\"hours\" *ngIf=\"!showMobileUi\">\n            <cauca-desktop-time-picker [disabled]=\"{all: disabled.hours, someOptions: disabled.someHours}\" (valueChange)=\"hourChanged($event)\" [options]=\"hours\" [value]=\"selectedHour\"/>\n        </div>\n        <div class=\"hours\" *ngIf=\"showMobileUi\">\n            <cauca-mobile-time-picker (valueChange)=\"hourChanged($event)\" [options]=\"hours\" [value]=\"selectedHour\" />\n        </div>\n\n        <div class=\"hour-and-minute-separator\" *ngIf=\"showMobileUi\">:</div>\n\n        <div class=\"minutes\" *ngIf=\"!showMobileUi\">\n            <cauca-desktop-time-picker [disabled]=\"{all: disabled.minutes, someOptions: disabled.someMinutes}\" (valueChange)=\"minuteChanged($event)\" [options]=\"minutes\" [value]=\"selectedMinute\"/>\n        </div>\n        <div class=\"minutes\" *ngIf=\"showMobileUi\">\n            <cauca-mobile-time-picker (valueChange)=\"minuteChanged($event)\" [options]=\"minutes\" [value]=\"selectedMinute\" />\n        </div>\n\n        <div class=\"minute-and-second-separator\" *ngIf=\"showSeconds && showMobileUi\">:</div>\n        <div class=\"seconds\" *ngIf=\"showSeconds && !showMobileUi\">\n            <cauca-desktop-time-picker [disabled]=\"{all: disabled.seconds, someOptions: disabled.someSeconds}\" (valueChange)=\"secondChanged($event)\" [options]=\"seconds\" [value]=\"selectedSecond\"/>\n        </div>\n        <div class=\"seconds\" *ngIf=\"showSeconds && showMobileUi\">\n            <cauca-mobile-time-picker (valueChange)=\"secondChanged($event)\" [options]=\"seconds\" [value]=\"selectedSecond\" />\n        </div>\n    </div>\n</div>\n\n<div mat-dialog-actions align=\"end\">\n    <button mat-stroked-button (click)=\"clear()\" *ngIf=\"showClearButton\">\n        <mat-icon *ngIf=\"showButtonIcons\">clear</mat-icon>\n        {{'material.clear' | translate}}\n    </button>\n    <button mat-stroked-button (click)=\"cancel()\">\n        <mat-icon *ngIf=\"showButtonIcons\">cancel</mat-icon>\n        {{'material.cancel' | translate}}\n    </button>\n    <button color=\"primary\" mat-raised-button cdkFocusInitial (click)=\"confirm()\">\n        <mat-icon *ngIf=\"showButtonIcons\">check</mat-icon>\n        {{'material.ok' | translate}}\n    </button>\n</div>"]}
|