@cauca-911/material 18.0.1-beta7 → 18.0.1
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/cauca-date-time-picker/cauca-date-time-picker.component.mjs +184 -0
- package/esm2022/lib/{inputs/cauca-date-time-picker → cauca-date-time-picker}/components/desktop-time-picker/desktop-time-picker.component.mjs +2 -2
- package/esm2022/lib/cauca-date-time-picker/components/dialog-date-time-picker/dialog-date-time-picker.component.mjs +365 -0
- package/esm2022/lib/cauca-date-time-picker/components/mobile-time-picker/mobile-time-picker.component.mjs +74 -0
- package/esm2022/lib/cauca-date-time-picker/models/dialog-date-time-picker-data.mjs +2 -0
- package/esm2022/lib/cauca-input-file/cauca-input-file.component.mjs +148 -0
- package/esm2022/lib/cauca-input-multiple-langue/cauca-input-multiple-langue.component.mjs +87 -0
- package/esm2022/lib/cauca-material.component.mjs +5 -6
- package/esm2022/lib/cauca-material.module.mjs +52 -14
- package/esm2022/lib/cauca-menu-sidebar/cauca-menu-sidebar.component.mjs +10 -14
- package/esm2022/lib/cauca-menu-vertical/cauca-menu-vertical.component.mjs +8 -16
- package/esm2022/lib/cauca-simple-dialog/cauca-simple-dialog.component.mjs +10 -14
- package/esm2022/lib/cauca-slideshow/cauca-slideshow.component.mjs +6 -6
- package/esm2022/public-api.mjs +4 -21
- package/fesm2022/cauca-911-material.mjs +822 -2110
- package/fesm2022/cauca-911-material.mjs.map +1 -1
- package/lib/cauca-date-time-picker/cauca-date-time-picker.component.d.ts +40 -0
- package/lib/{inputs/cauca-date-time-picker → cauca-date-time-picker}/components/dialog-date-time-picker/dialog-date-time-picker.component.d.ts +2 -1
- package/lib/{inputs/cauca-date-time-picker → cauca-date-time-picker}/models/dialog-date-time-picker-data.d.ts +3 -2
- package/lib/{inputs/cauca-input-file → cauca-input-file}/cauca-input-file.component.d.ts +1 -1
- package/lib/{inputs/cauca-input-multiple-langue → cauca-input-multiple-langue}/cauca-input-multiple-langue.component.d.ts +1 -1
- package/lib/cauca-material.component.d.ts +1 -1
- package/lib/cauca-material.module.d.ts +14 -4
- 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/package.json +2 -3
- package/public-api.d.ts +3 -20
- package/esm2022/lib/buttons/base-button.mjs +0 -33
- package/esm2022/lib/buttons/basic-button/basic-button.component.mjs +0 -64
- package/esm2022/lib/buttons/flat-button/flat-button.component.mjs +0 -64
- package/esm2022/lib/buttons/icon-button/icon-button.component.mjs +0 -28
- package/esm2022/lib/buttons/menu-item/menu-item.component.mjs +0 -68
- package/esm2022/lib/buttons/raised-button/raised-button.component.mjs +0 -64
- package/esm2022/lib/buttons/stroked-button/stroked-button.component.mjs +0 -71
- package/esm2022/lib/dialogs/alert-dialog/alert-dialog.component.mjs +0 -57
- package/esm2022/lib/dialogs/confirm-dialog/confirm-dialog.component.mjs +0 -69
- package/esm2022/lib/dialogs/services/dialog.service.mjs +0 -52
- package/esm2022/lib/inputs/cauca-date-time-picker/cauca-date-time-picker.component.mjs +0 -137
- package/esm2022/lib/inputs/cauca-date-time-picker/components/dialog-date-time-picker/dialog-date-time-picker.component.mjs +0 -358
- package/esm2022/lib/inputs/cauca-date-time-picker/components/mobile-time-picker/mobile-time-picker.component.mjs +0 -74
- package/esm2022/lib/inputs/cauca-date-time-picker/models/dialog-date-time-picker-data.mjs +0 -2
- package/esm2022/lib/inputs/cauca-input-file/cauca-input-file.component.mjs +0 -147
- package/esm2022/lib/inputs/cauca-input-multiple-langue/cauca-input-multiple-langue.component.mjs +0 -99
- package/esm2022/lib/inputs/password/models/password-validation.mjs +0 -13
- package/esm2022/lib/inputs/password/password-criteria/password-criteria.component.mjs +0 -49
- package/esm2022/lib/inputs/password/password-criteria-viewer/password-criteria-viewer.component.mjs +0 -29
- package/esm2022/lib/inputs/password/password-input/password-input.component.mjs +0 -112
- package/esm2022/lib/inputs/password/password-selection/password-selection.component.mjs +0 -112
- package/esm2022/lib/inputs/password/validators/password-validator.mjs +0 -19
- package/esm2022/lib/inputs/select-with-search/select-with-search.component.mjs +0 -157
- package/esm2022/lib/layout/expandable-panel/expandable-panel.component.mjs +0 -75
- package/esm2022/lib/layout/menu-expandable-panel/menu-expandable-panel.component.mjs +0 -148
- package/esm2022/lib/layout/menu-expandable-panel-item/menu-expandable-panel-item.component.mjs +0 -50
- package/esm2022/lib/layout/page-title/page-title.component.mjs +0 -86
- package/esm2022/lib/notifications/snack-bar/snack-bar.component.mjs +0 -75
- package/lib/buttons/base-button.d.ts +0 -21
- package/lib/buttons/basic-button/basic-button.component.d.ts +0 -6
- package/lib/buttons/flat-button/flat-button.component.d.ts +0 -6
- package/lib/buttons/icon-button/icon-button.component.d.ts +0 -6
- package/lib/buttons/menu-item/menu-item.component.d.ts +0 -9
- package/lib/buttons/raised-button/raised-button.component.d.ts +0 -6
- package/lib/buttons/stroked-button/stroked-button.component.d.ts +0 -6
- package/lib/dialogs/alert-dialog/alert-dialog.component.d.ts +0 -18
- package/lib/dialogs/confirm-dialog/confirm-dialog.component.d.ts +0 -17
- package/lib/dialogs/services/dialog.service.d.ts +0 -26
- package/lib/inputs/cauca-date-time-picker/cauca-date-time-picker.component.d.ts +0 -29
- package/lib/inputs/password/models/password-validation.d.ts +0 -9
- package/lib/inputs/password/password-criteria/password-criteria.component.d.ts +0 -9
- package/lib/inputs/password/password-criteria-viewer/password-criteria-viewer.component.d.ts +0 -9
- package/lib/inputs/password/password-input/password-input.component.d.ts +0 -25
- package/lib/inputs/password/password-selection/password-selection.component.d.ts +0 -20
- package/lib/inputs/password/validators/password-validator.d.ts +0 -9
- package/lib/inputs/select-with-search/select-with-search.component.d.ts +0 -32
- package/lib/layout/expandable-panel/expandable-panel.component.d.ts +0 -10
- package/lib/layout/menu-expandable-panel/menu-expandable-panel.component.d.ts +0 -29
- package/lib/layout/menu-expandable-panel-item/menu-expandable-panel-item.component.d.ts +0 -13
- package/lib/layout/page-title/page-title.component.d.ts +0 -11
- package/lib/notifications/snack-bar/snack-bar.component.d.ts +0 -17
- /package/lib/{inputs/cauca-date-time-picker → cauca-date-time-picker}/components/desktop-time-picker/desktop-time-picker.component.d.ts +0 -0
- /package/lib/{inputs/cauca-date-time-picker → cauca-date-time-picker}/components/mobile-time-picker/mobile-time-picker.component.d.ts +0 -0
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
import { Component, EventEmitter, forwardRef, input, 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 { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
8
|
+
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
9
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@angular/material/dialog";
|
|
12
|
+
import * as i2 from "@angular/common";
|
|
13
|
+
import * as i3 from "@ngx-translate/core";
|
|
14
|
+
import * as i4 from "@angular/material/button";
|
|
15
|
+
import * as i5 from "@angular/material/icon";
|
|
16
|
+
import * as i6 from "@angular/material/input";
|
|
17
|
+
import * as i7 from "@angular/material/form-field";
|
|
18
|
+
function CaucaDateTimePickerComponent_Conditional_1_Template(rf, ctx) { if (rf & 1) {
|
|
19
|
+
i0.ɵɵelementStart(0, "mat-label");
|
|
20
|
+
i0.ɵɵtext(1);
|
|
21
|
+
i0.ɵɵpipe(2, "translate");
|
|
22
|
+
i0.ɵɵelementEnd();
|
|
23
|
+
} if (rf & 2) {
|
|
24
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
25
|
+
i0.ɵɵadvance();
|
|
26
|
+
i0.ɵɵtextInterpolate(ctx_r0.translateLabel() ? i0.ɵɵpipeBind1(2, 1, ctx_r0.label()) : ctx_r0.label());
|
|
27
|
+
} }
|
|
28
|
+
export class CaucaDateTimePickerComponent {
|
|
29
|
+
constructor(elementRef, dialog, datePipe) {
|
|
30
|
+
this.elementRef = elementRef;
|
|
31
|
+
this.dialog = dialog;
|
|
32
|
+
this.datePipe = datePipe;
|
|
33
|
+
this.appearance = input('fill');
|
|
34
|
+
this.showTime = input(true);
|
|
35
|
+
this.label = input('');
|
|
36
|
+
this.translateLabel = input(true);
|
|
37
|
+
this.stepHours = 1;
|
|
38
|
+
this.stepMinutes = 1;
|
|
39
|
+
this.stepSecondes = 1;
|
|
40
|
+
this.minimumDate = null;
|
|
41
|
+
this.maximumDate = null;
|
|
42
|
+
this.showSeconds = false;
|
|
43
|
+
this.showFormat = 'yyyy/MM/dd, HH:mm';
|
|
44
|
+
this.showClearButton = true;
|
|
45
|
+
this.showButtonIcons = true;
|
|
46
|
+
this.selectedChange = new EventEmitter();
|
|
47
|
+
this.stringDate = '';
|
|
48
|
+
this.onChange = (value) => value;
|
|
49
|
+
this.onTouched = () => { };
|
|
50
|
+
}
|
|
51
|
+
set value(value) {
|
|
52
|
+
if (value) {
|
|
53
|
+
this.stringDate = this.stringifyDate(value);
|
|
54
|
+
this.selectedDate = value;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
showDialog() {
|
|
58
|
+
const dialogRef = this.dialog.open(DialogDateTimePickerComponent, {
|
|
59
|
+
position: this.getDialogPosition(),
|
|
60
|
+
data: this.getDateTimePickerOptions(),
|
|
61
|
+
});
|
|
62
|
+
dialogRef.afterClosed().subscribe((data) => {
|
|
63
|
+
if (data) {
|
|
64
|
+
this.stringDate = this.stringifyDate(data.value);
|
|
65
|
+
this.selectedDate = data.value;
|
|
66
|
+
this.selectedChange.emit(data.value);
|
|
67
|
+
this.onChange(data.value);
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
writeValue(date) {
|
|
72
|
+
this.value = date;
|
|
73
|
+
}
|
|
74
|
+
registerOnChange(fn) {
|
|
75
|
+
this.onChange = fn;
|
|
76
|
+
}
|
|
77
|
+
registerOnTouched(fn) {
|
|
78
|
+
this.onTouched = fn;
|
|
79
|
+
}
|
|
80
|
+
getDateTimePickerOptions() {
|
|
81
|
+
return {
|
|
82
|
+
selectedDate: this.selectedDate,
|
|
83
|
+
minimumDate: this.minimumDate,
|
|
84
|
+
maximumDate: this.maximumDate,
|
|
85
|
+
showSeconds: this.showSeconds,
|
|
86
|
+
showClearButton: this.showClearButton,
|
|
87
|
+
showButtonIcons: this.showButtonIcons,
|
|
88
|
+
showTime: this.showTime(),
|
|
89
|
+
step: {
|
|
90
|
+
hours: this.stepHours,
|
|
91
|
+
minutes: this.stepMinutes,
|
|
92
|
+
seconds: this.stepSecondes,
|
|
93
|
+
}
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
stringifyDate(date) {
|
|
97
|
+
return this.datePipe.transform(date, this.showFormat);
|
|
98
|
+
}
|
|
99
|
+
getDialogPosition() {
|
|
100
|
+
const rect = this.elementRef.nativeElement.getBoundingClientRect();
|
|
101
|
+
const top = rect.y + rect.height - 22;
|
|
102
|
+
const bottom = window.innerHeight - rect.y;
|
|
103
|
+
const minimumDialogHeight = 400;
|
|
104
|
+
const minimumScreenSize = 800;
|
|
105
|
+
if (window.innerHeight < minimumScreenSize || window.innerWidth < minimumScreenSize) {
|
|
106
|
+
return null;
|
|
107
|
+
}
|
|
108
|
+
else if (window.innerHeight > (top + minimumDialogHeight)) {
|
|
109
|
+
return {
|
|
110
|
+
left: `${rect.x}px`,
|
|
111
|
+
top: `${top}px`,
|
|
112
|
+
};
|
|
113
|
+
}
|
|
114
|
+
return {
|
|
115
|
+
left: `${rect.x}px`,
|
|
116
|
+
bottom: `${bottom}px`,
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
static { this.ɵfac = function CaucaDateTimePickerComponent_Factory(t) { return new (t || CaucaDateTimePickerComponent)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i1.MatDialog), i0.ɵɵdirectiveInject(i2.DatePipe)); }; }
|
|
120
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: CaucaDateTimePickerComponent, selectors: [["cauca-date-time-picker"]], inputs: { appearance: [1, "appearance"], showTime: [1, "showTime"], label: [1, "label"], translateLabel: [1, "translateLabel"], 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([
|
|
121
|
+
DatePipe,
|
|
122
|
+
{
|
|
123
|
+
provide: NG_VALUE_ACCESSOR,
|
|
124
|
+
multi: true,
|
|
125
|
+
useExisting: forwardRef(() => CaucaDateTimePickerComponent),
|
|
126
|
+
}
|
|
127
|
+
]), i0.ɵɵStandaloneFeature], decls: 6, vars: 3, consts: [[3, "appearance"], ["matInput", "", "readonly", "readonly", 3, "value"], ["matSuffix", "", "mat-icon-button", "", 3, "click"]], template: function CaucaDateTimePickerComponent_Template(rf, ctx) { if (rf & 1) {
|
|
128
|
+
i0.ɵɵelementStart(0, "mat-form-field", 0);
|
|
129
|
+
i0.ɵɵtemplate(1, CaucaDateTimePickerComponent_Conditional_1_Template, 3, 3, "mat-label");
|
|
130
|
+
i0.ɵɵelement(2, "input", 1);
|
|
131
|
+
i0.ɵɵelementStart(3, "button", 2);
|
|
132
|
+
i0.ɵɵlistener("click", function CaucaDateTimePickerComponent_Template_button_click_3_listener() { return ctx.showDialog(); });
|
|
133
|
+
i0.ɵɵelementStart(4, "mat-icon");
|
|
134
|
+
i0.ɵɵtext(5, "calendar_month");
|
|
135
|
+
i0.ɵɵelementEnd()()();
|
|
136
|
+
} if (rf & 2) {
|
|
137
|
+
i0.ɵɵproperty("appearance", ctx.appearance());
|
|
138
|
+
i0.ɵɵadvance();
|
|
139
|
+
i0.ɵɵconditional(ctx.label() ? 1 : -1);
|
|
140
|
+
i0.ɵɵadvance();
|
|
141
|
+
i0.ɵɵproperty("value", ctx.stringDate);
|
|
142
|
+
} }, dependencies: [TranslateModule, i3.TranslatePipe, MatButtonModule, i4.MatIconButton, MatIconModule, i5.MatIcon, MatInputModule, i6.MatInput, i7.MatFormField, i7.MatLabel, i7.MatSuffix, MatFormFieldModule], styles: ["[_nghost-%COMP%]{display:block}mat-form-field[_ngcontent-%COMP%]{width:100%}"] }); }
|
|
143
|
+
}
|
|
144
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CaucaDateTimePickerComponent, [{
|
|
145
|
+
type: Component,
|
|
146
|
+
args: [{ selector: 'cauca-date-time-picker', standalone: true, imports: [
|
|
147
|
+
TranslateModule,
|
|
148
|
+
MatButtonModule,
|
|
149
|
+
MatIconModule,
|
|
150
|
+
MatInputModule,
|
|
151
|
+
MatFormFieldModule
|
|
152
|
+
], providers: [
|
|
153
|
+
DatePipe,
|
|
154
|
+
{
|
|
155
|
+
provide: NG_VALUE_ACCESSOR,
|
|
156
|
+
multi: true,
|
|
157
|
+
useExisting: forwardRef(() => CaucaDateTimePickerComponent),
|
|
158
|
+
}
|
|
159
|
+
], template: "<mat-form-field [appearance]=\"appearance()\">\n @if (label()) {\n <mat-label>{{ translateLabel() ? (label() | translate) : label() }}</mat-label>\n }\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"] }]
|
|
160
|
+
}], () => [{ type: i0.ElementRef }, { type: i1.MatDialog }, { type: i2.DatePipe }], { stepHours: [{
|
|
161
|
+
type: Input
|
|
162
|
+
}], stepMinutes: [{
|
|
163
|
+
type: Input
|
|
164
|
+
}], stepSecondes: [{
|
|
165
|
+
type: Input
|
|
166
|
+
}], minimumDate: [{
|
|
167
|
+
type: Input
|
|
168
|
+
}], maximumDate: [{
|
|
169
|
+
type: Input
|
|
170
|
+
}], showSeconds: [{
|
|
171
|
+
type: Input
|
|
172
|
+
}], showFormat: [{
|
|
173
|
+
type: Input
|
|
174
|
+
}], showClearButton: [{
|
|
175
|
+
type: Input
|
|
176
|
+
}], showButtonIcons: [{
|
|
177
|
+
type: Input
|
|
178
|
+
}], selectedChange: [{
|
|
179
|
+
type: Output
|
|
180
|
+
}], value: [{
|
|
181
|
+
type: Input
|
|
182
|
+
}] }); })();
|
|
183
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(CaucaDateTimePickerComponent, { className: "CaucaDateTimePickerComponent", filePath: "lib\\cauca-date-time-picker\\cauca-date-time-picker.component.ts", lineNumber: 34 }); })();
|
|
184
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cauca-date-time-picker.component.js","sourceRoot":"","sources":["../../../../../projects/cauca-material/src/lib/cauca-date-time-picker/cauca-date-time-picker.component.ts","../../../../../projects/cauca-material/src/lib/cauca-date-time-picker/cauca-date-time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, forwardRef, input, Input, InputSignal, 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';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { MatFormFieldAppearance, MatFormFieldModule } from '@angular/material/form-field';\nimport { TranslateModule } from '@ngx-translate/core';\n\n@Component({\n  selector: 'cauca-date-time-picker',\n  standalone: true,\n  imports: [\n    TranslateModule,\n    MatButtonModule,\n    MatIconModule,\n    MatInputModule,\n    MatFormFieldModule\n  ],\n  providers: [\n    DatePipe,\n    {\n      provide: NG_VALUE_ACCESSOR,\n      multi: true,\n      useExisting: forwardRef(() => CaucaDateTimePickerComponent),\n    }\n  ],\n  templateUrl: './cauca-date-time-picker.component.html',\n  styleUrl: './cauca-date-time-picker.component.scss'\n})\nexport class CaucaDateTimePickerComponent implements ControlValueAccessor {\n  public appearance: InputSignal<MatFormFieldAppearance> = input('fill');\n  public showTime: InputSignal<boolean> = input(true);\n  public label: InputSignal<string> = input('');\n  public translateLabel: InputSignal<boolean> = input(true);\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        this.onChange(data.value);\n      }\n    });\n  }\n\n  public writeValue(date: Date): void {\n    this.value = date;\n  }\n\n  public registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  public registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  public onChange = (value: Date): Date => value;\n\n  public onTouched = (): void => {/* This method needs to be empty */ };\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      showTime: this.showTime(),\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 [appearance]=\"appearance()\">\n    @if (label()) {\n        <mat-label>{{ translateLabel() ? (label() | translate) : label() }}</mat-label>\n    }\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\\
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVza3RvcC10aW1lLXBpY2tlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYXVjYS1tYXRlcmlhbC9zcmMvbGliL2NhdWNhLWRhdGUtdGltZS1waWNrZXIvY29tcG9uZW50cy9kZXNrdG9wLXRpbWUtcGlja2VyL2Rlc2t0b3AtdGltZS1waWNrZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2F1Y2EtbWF0ZXJpYWwvc3JjL2xpYi9jYXVjYS1kYXRlLXRpbWUtcGlja2VyL2NvbXBvbmVudHMvZGVza3RvcC10aW1lLXBpY2tlci9kZXNrdG9wLXRpbWUtcGlja2VyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDOzs7OztJQ0NuRCx3Q0FDdUM7SUFBbkMseU5BQVMsa0NBQXdCLEtBQUM7SUFBQyxZQUFzQztJQUFBLGlCQUFnQjs7OztJQUQvQyxBQUEvQixzREFBOEIsOEZBQW9EO0lBQzFELGNBQXNDO0lBQXRDLDZEQUFzQzs7QURTakYsTUFBTSxPQUFPLDBCQUEwQjtJQVR2QztRQVVrQixZQUFPLEdBQWEsRUFBRSxDQUFDO1FBSXRCLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztLQUMzRDsyRkFOWSwwQkFBMEI7b0VBQTFCLDBCQUEwQjtZQ1p2QyxtQ0FBcUM7WUFDakMseUhBR1M7WUFDYixpQkFBVzs7WUFMRCx5RUFBMEI7WUFDaEMsY0FHUztZQUhULDBCQUdTOzRCREdULGFBQWE7O2lGQUtKLDBCQUEwQjtjQVR0QyxTQUFTOzJCQUNFLDJCQUEyQixjQUN6QixJQUFJLFdBQ1A7b0JBQ1AsYUFBYTtpQkFDZDtnQkFLZSxPQUFPO2tCQUF0QixLQUFLO1lBQ1UsS0FBSztrQkFBcEIsS0FBSztZQUNVLFFBQVE7a0JBQXZCLEtBQUs7WUFFVyxXQUFXO2tCQUEzQixNQUFNOztrRkFMSSwwQkFBMEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF0TGlzdE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2xpc3QnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdjYXVjYS1kZXNrdG9wLXRpbWUtcGlja2VyJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIE1hdExpc3RNb2R1bGVcbiAgXSxcbiAgdGVtcGxhdGVVcmw6ICcuL2Rlc2t0b3AtdGltZS1waWNrZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vZGVza3RvcC10aW1lLXBpY2tlci5jb21wb25lbnQuc2Nzcydcbn0pXG5leHBvcnQgY2xhc3MgRGVza3RvcFRpbWVQaWNrZXJDb21wb25lbnQge1xuICBASW5wdXQoKSBwdWJsaWMgb3B0aW9uczogbnVtYmVyW10gPSBbXTtcbiAgQElucHV0KCkgcHVibGljIHZhbHVlOiBudW1iZXI7XG4gIEBJbnB1dCgpIHB1YmxpYyBkaXNhYmxlZDogRGVza3RvcFRpbWVQaWNrZXJDb21wb25lbnREaXNhYmxlZDtcblxuICBAT3V0cHV0KCkgcHVibGljIHZhbHVlQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxudW1iZXI+KCk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGVza3RvcFRpbWVQaWNrZXJDb21wb25lbnREaXNhYmxlZCB7XG4gIGFsbDogYm9vbGVhbjtcbiAgc29tZU9wdGlvbnM6IG51bWJlcltdO1xufSIsIjxtYXQtbGlzdCBbZGlzYWJsZWRdPVwiZGlzYWJsZWQ/LmFsbFwiPlxuICAgIEBmb3IgKG9wdGlvbiBvZiBvcHRpb25zOyB0cmFjayBvcHRpb24pIHtcbiAgICA8bWF0LWxpc3QtaXRlbSBbYWN0aXZhdGVkXT1cInZhbHVlID09PSBvcHRpb25cIiBbZGlzYWJsZWRdPVwiZGlzYWJsZWQ/LnNvbWVPcHRpb25zLmluY2x1ZGVzKG9wdGlvbilcIlxuICAgICAgICAoY2xpY2spPVwidmFsdWVDaGFuZ2UuZW1pdChvcHRpb24pXCI+e3sob3B0aW9uIDwgMTAgPyAnMCcgOiAnJyApICsgb3B0aW9ufX08L21hdC1saXN0LWl0ZW0+XG4gICAgICAgICAgICB9XG48L21hdC1saXN0PiJdfQ==
|