@cauca-911/material 18.0.8 → 19.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/fesm2022/cauca-911-material.mjs +48 -47
- package/fesm2022/cauca-911-material.mjs.map +1 -1
- package/package.json +7 -9
- package/esm2022/cauca-911-material.mjs +0 -5
- package/esm2022/lib/cauca-date-time-picker/cauca-date-time-picker.component.mjs +0 -208
- package/esm2022/lib/cauca-date-time-picker/components/desktop-time-picker/desktop-time-picker.component.mjs +0 -49
- package/esm2022/lib/cauca-date-time-picker/components/dialog-date-time-picker/dialog-date-time-picker.component.mjs +0 -363
- 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/esm2022/lib/cauca-material.component.mjs +0 -21
- package/esm2022/lib/cauca-material.module.mjs +0 -94
- package/esm2022/lib/cauca-material.service.mjs +0 -13
- package/esm2022/lib/cauca-menu-sidebar/cauca-menu-sidebar.component.mjs +0 -147
- package/esm2022/lib/cauca-menu-vertical/cauca-menu-vertical.component.mjs +0 -166
- package/esm2022/lib/cauca-simple-dialog/cauca-simple-dialog.component.mjs +0 -62
- package/esm2022/lib/cauca-slideshow/cauca-slideshow.component.mjs +0 -140
- package/esm2022/lib/shared/models/menu-item.mjs +0 -9
- package/esm2022/lib/shared/models/simple-dialog-data.mjs +0 -6
- package/esm2022/public-api.mjs +0 -15
|
@@ -1,208 +0,0 @@
|
|
|
1
|
-
import { Component, EventEmitter, forwardRef, inject, Injector, 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 { ControlContainer, FormControl, FormControlName, NG_VALUE_ACCESSOR, NgControl, Validators } 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.ɵɵtextInterpolate2("", ctx_r0.translateLabel ? i0.ɵɵpipeBind1(2, 2, ctx_r0.label) : ctx_r0.label, "", ctx_r0.isRequired ? "*" : "", "");
|
|
27
|
-
} }
|
|
28
|
-
export class CaucaDateTimePickerComponent {
|
|
29
|
-
constructor(elementRef, dialog, datePipe) {
|
|
30
|
-
this.elementRef = elementRef;
|
|
31
|
-
this.dialog = dialog;
|
|
32
|
-
this.datePipe = datePipe;
|
|
33
|
-
this.subscriptSizing = 'fixed';
|
|
34
|
-
this.showTime = true;
|
|
35
|
-
this.label = '';
|
|
36
|
-
this.translateLabel = 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.injector = inject(Injector);
|
|
49
|
-
this.onChange = (value) => value;
|
|
50
|
-
this.onTouched = () => { };
|
|
51
|
-
}
|
|
52
|
-
set value(value) {
|
|
53
|
-
if (value) {
|
|
54
|
-
this.stringDate = this.stringifyDate(value);
|
|
55
|
-
this.selectedDate = value;
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
get isRequired() {
|
|
59
|
-
return Boolean(this.control?.hasValidator(Validators.required));
|
|
60
|
-
}
|
|
61
|
-
ngOnInit() {
|
|
62
|
-
const ngControl = this.injector.get(NgControl, null, { self: true, optional: true });
|
|
63
|
-
if (ngControl instanceof FormControlName) {
|
|
64
|
-
const container = this.injector.get(ControlContainer).control;
|
|
65
|
-
this.control = container.controls[ngControl.name];
|
|
66
|
-
}
|
|
67
|
-
else {
|
|
68
|
-
this.control = new FormControl();
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
showDialog() {
|
|
72
|
-
const dialogRef = this.dialog.open(DialogDateTimePickerComponent, {
|
|
73
|
-
position: this.getDialogPosition(),
|
|
74
|
-
data: this.getDateTimePickerOptions(),
|
|
75
|
-
});
|
|
76
|
-
dialogRef.afterClosed().subscribe((data) => {
|
|
77
|
-
if (data) {
|
|
78
|
-
this.stringDate = this.stringifyDate(data.value);
|
|
79
|
-
this.selectedDate = data.value;
|
|
80
|
-
this.selectedChange.emit(data.value);
|
|
81
|
-
this.onChange(data.value);
|
|
82
|
-
}
|
|
83
|
-
});
|
|
84
|
-
}
|
|
85
|
-
writeValue(date) {
|
|
86
|
-
this.value = date;
|
|
87
|
-
}
|
|
88
|
-
registerOnChange(fn) {
|
|
89
|
-
this.onChange = fn;
|
|
90
|
-
}
|
|
91
|
-
registerOnTouched(fn) {
|
|
92
|
-
this.onTouched = fn;
|
|
93
|
-
}
|
|
94
|
-
getDateTimePickerOptions() {
|
|
95
|
-
return {
|
|
96
|
-
selectedDate: this.selectedDate,
|
|
97
|
-
minimumDate: this.minimumDate,
|
|
98
|
-
maximumDate: this.maximumDate,
|
|
99
|
-
showSeconds: this.showSeconds,
|
|
100
|
-
showClearButton: this.showClearButton,
|
|
101
|
-
showButtonIcons: this.showButtonIcons,
|
|
102
|
-
showTime: this.showTime,
|
|
103
|
-
step: {
|
|
104
|
-
hours: this.stepHours,
|
|
105
|
-
minutes: this.stepMinutes,
|
|
106
|
-
seconds: this.stepSecondes,
|
|
107
|
-
}
|
|
108
|
-
};
|
|
109
|
-
}
|
|
110
|
-
stringifyDate(date) {
|
|
111
|
-
return this.datePipe.transform(date, this.showFormat);
|
|
112
|
-
}
|
|
113
|
-
getDialogPosition() {
|
|
114
|
-
const rect = this.elementRef.nativeElement.getBoundingClientRect();
|
|
115
|
-
const top = rect.y + rect.height - 22;
|
|
116
|
-
const bottom = window.innerHeight - rect.y;
|
|
117
|
-
const minimumDialogHeight = 400;
|
|
118
|
-
const minimumScreenSize = 800;
|
|
119
|
-
if (window.innerHeight < minimumScreenSize || window.innerWidth < minimumScreenSize) {
|
|
120
|
-
return null;
|
|
121
|
-
}
|
|
122
|
-
else if (window.innerHeight > (top + minimumDialogHeight)) {
|
|
123
|
-
return {
|
|
124
|
-
left: `${rect.x}px`,
|
|
125
|
-
top: `${top}px`,
|
|
126
|
-
};
|
|
127
|
-
}
|
|
128
|
-
return {
|
|
129
|
-
left: `${rect.x}px`,
|
|
130
|
-
bottom: `${bottom}px`,
|
|
131
|
-
};
|
|
132
|
-
}
|
|
133
|
-
static { this.ɵfac = function CaucaDateTimePickerComponent_Factory(t) { return new (t || CaucaDateTimePickerComponent)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i1.MatDialog), i0.ɵɵdirectiveInject(i2.DatePipe)); }; }
|
|
134
|
-
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: CaucaDateTimePickerComponent, selectors: [["cauca-date-time-picker"]], inputs: { subscriptSizing: "subscriptSizing", showTime: "showTime", label: "label", translateLabel: "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([
|
|
135
|
-
DatePipe,
|
|
136
|
-
{
|
|
137
|
-
provide: NG_VALUE_ACCESSOR,
|
|
138
|
-
multi: true,
|
|
139
|
-
useExisting: forwardRef(() => CaucaDateTimePickerComponent),
|
|
140
|
-
}
|
|
141
|
-
]), i0.ɵɵStandaloneFeature], decls: 6, vars: 3, consts: [[3, "subscriptSizing"], ["matInput", "", "readonly", "readonly", 3, "focusout", "value"], ["matSuffix", "", "mat-icon-button", "", 3, "click"]], template: function CaucaDateTimePickerComponent_Template(rf, ctx) { if (rf & 1) {
|
|
142
|
-
i0.ɵɵelementStart(0, "mat-form-field", 0);
|
|
143
|
-
i0.ɵɵtemplate(1, CaucaDateTimePickerComponent_Conditional_1_Template, 3, 4, "mat-label");
|
|
144
|
-
i0.ɵɵelementStart(2, "input", 1);
|
|
145
|
-
i0.ɵɵlistener("focusout", function CaucaDateTimePickerComponent_Template_input_focusout_2_listener() { return ctx.onTouched(); });
|
|
146
|
-
i0.ɵɵelementEnd();
|
|
147
|
-
i0.ɵɵelementStart(3, "button", 2);
|
|
148
|
-
i0.ɵɵlistener("click", function CaucaDateTimePickerComponent_Template_button_click_3_listener() { return ctx.showDialog(); });
|
|
149
|
-
i0.ɵɵelementStart(4, "mat-icon");
|
|
150
|
-
i0.ɵɵtext(5, "calendar_month");
|
|
151
|
-
i0.ɵɵelementEnd()()();
|
|
152
|
-
} if (rf & 2) {
|
|
153
|
-
i0.ɵɵproperty("subscriptSizing", ctx.subscriptSizing);
|
|
154
|
-
i0.ɵɵadvance();
|
|
155
|
-
i0.ɵɵconditional(ctx.label ? 1 : -1);
|
|
156
|
-
i0.ɵɵadvance();
|
|
157
|
-
i0.ɵɵproperty("value", ctx.stringDate);
|
|
158
|
-
} }, 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%}"] }); }
|
|
159
|
-
}
|
|
160
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CaucaDateTimePickerComponent, [{
|
|
161
|
-
type: Component,
|
|
162
|
-
args: [{ selector: 'cauca-date-time-picker', standalone: true, imports: [
|
|
163
|
-
TranslateModule,
|
|
164
|
-
MatButtonModule,
|
|
165
|
-
MatIconModule,
|
|
166
|
-
MatInputModule,
|
|
167
|
-
MatFormFieldModule
|
|
168
|
-
], providers: [
|
|
169
|
-
DatePipe,
|
|
170
|
-
{
|
|
171
|
-
provide: NG_VALUE_ACCESSOR,
|
|
172
|
-
multi: true,
|
|
173
|
-
useExisting: forwardRef(() => CaucaDateTimePickerComponent),
|
|
174
|
-
}
|
|
175
|
-
], template: "<mat-form-field [subscriptSizing]=\"subscriptSizing\">\n @if (label) {\n <mat-label>{{ translateLabel ? (label | translate) : label }}{{isRequired ? '*' : ''}}</mat-label>\n }\n <input (focusout)=\"onTouched()\" 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"] }]
|
|
176
|
-
}], () => [{ type: i0.ElementRef }, { type: i1.MatDialog }, { type: i2.DatePipe }], { subscriptSizing: [{
|
|
177
|
-
type: Input
|
|
178
|
-
}], showTime: [{
|
|
179
|
-
type: Input
|
|
180
|
-
}], label: [{
|
|
181
|
-
type: Input
|
|
182
|
-
}], translateLabel: [{
|
|
183
|
-
type: Input
|
|
184
|
-
}], stepHours: [{
|
|
185
|
-
type: Input
|
|
186
|
-
}], stepMinutes: [{
|
|
187
|
-
type: Input
|
|
188
|
-
}], stepSecondes: [{
|
|
189
|
-
type: Input
|
|
190
|
-
}], minimumDate: [{
|
|
191
|
-
type: Input
|
|
192
|
-
}], maximumDate: [{
|
|
193
|
-
type: Input
|
|
194
|
-
}], showSeconds: [{
|
|
195
|
-
type: Input
|
|
196
|
-
}], showFormat: [{
|
|
197
|
-
type: Input
|
|
198
|
-
}], showClearButton: [{
|
|
199
|
-
type: Input
|
|
200
|
-
}], showButtonIcons: [{
|
|
201
|
-
type: Input
|
|
202
|
-
}], selectedChange: [{
|
|
203
|
-
type: Output
|
|
204
|
-
}], value: [{
|
|
205
|
-
type: Input
|
|
206
|
-
}] }); })();
|
|
207
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(CaucaDateTimePickerComponent, { className: "CaucaDateTimePickerComponent", filePath: "lib\\cauca-date-time-picker\\cauca-date-time-picker.component.ts", lineNumber: 34 }); })();
|
|
208
|
-
//# 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, inject, Injector, Input, OnInit, 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 { AbstractControl, ControlContainer, ControlValueAccessor, FormControl, FormControlName, FormGroup, NG_VALUE_ACCESSOR, NgControl, Validators } from '@angular/forms';\nimport { MatFormFieldModule, SubscriptSizing } 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, OnInit {\n  @Input() public subscriptSizing: SubscriptSizing = 'fixed';\n  @Input() public showTime: boolean = true;\n  @Input() public label: string = '';\n  @Input() public translateLabel: boolean = 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 control: AbstractControl;\n  public stringDate: string = '';\n  \n  private injector = inject(Injector);\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 get isRequired(): boolean {\n    return Boolean(this.control?.hasValidator(Validators.required))\n  }\n\n  public ngOnInit(): void {\n    const ngControl = this.injector.get(NgControl, null, { self: true, optional: true });\n    if (ngControl instanceof FormControlName) {\n      const container = this.injector.get(ControlContainer).control as FormGroup;\n      this.control = container.controls[ngControl.name] as FormControl;\n    } else {\n      this.control = new FormControl();\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 [subscriptSizing]=\"subscriptSizing\">\n    @if (label) {\n        <mat-label>{{ translateLabel ? (label | translate) : label }}{{isRequired ? '*' : ''}}</mat-label>\n    }\n    <input (focusout)=\"onTouched()\" 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>"]}
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
-
import { MatListModule } from '@angular/material/list';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@angular/material/list";
|
|
5
|
-
function DesktopTimePickerComponent_For_2_Template(rf, ctx) { if (rf & 1) {
|
|
6
|
-
const _r1 = i0.ɵɵgetCurrentView();
|
|
7
|
-
i0.ɵɵelementStart(0, "mat-list-item", 2);
|
|
8
|
-
i0.ɵɵlistener("click", function DesktopTimePickerComponent_For_2_Template_mat_list_item_click_0_listener() { const option_r2 = i0.ɵɵrestoreView(_r1).$implicit; const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.valueChange.emit(option_r2)); });
|
|
9
|
-
i0.ɵɵtext(1);
|
|
10
|
-
i0.ɵɵelementEnd();
|
|
11
|
-
} if (rf & 2) {
|
|
12
|
-
const option_r2 = ctx.$implicit;
|
|
13
|
-
const ctx_r2 = i0.ɵɵnextContext();
|
|
14
|
-
i0.ɵɵproperty("activated", ctx_r2.value === option_r2)("disabled", ctx_r2.disabled == null ? null : ctx_r2.disabled.someOptions.includes(option_r2));
|
|
15
|
-
i0.ɵɵadvance();
|
|
16
|
-
i0.ɵɵtextInterpolate((option_r2 < 10 ? "0" : "") + option_r2);
|
|
17
|
-
} }
|
|
18
|
-
export class DesktopTimePickerComponent {
|
|
19
|
-
constructor() {
|
|
20
|
-
this.options = [];
|
|
21
|
-
this.valueChange = new EventEmitter();
|
|
22
|
-
}
|
|
23
|
-
static { this.ɵfac = function DesktopTimePickerComponent_Factory(t) { return new (t || DesktopTimePickerComponent)(); }; }
|
|
24
|
-
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: DesktopTimePickerComponent, selectors: [["cauca-desktop-time-picker"]], inputs: { options: "options", value: "value", disabled: "disabled" }, outputs: { valueChange: "valueChange" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 3, vars: 1, consts: [[3, "disabled"], [3, "activated", "disabled"], [3, "click", "activated", "disabled"]], template: function DesktopTimePickerComponent_Template(rf, ctx) { if (rf & 1) {
|
|
25
|
-
i0.ɵɵelementStart(0, "mat-list", 0);
|
|
26
|
-
i0.ɵɵrepeaterCreate(1, DesktopTimePickerComponent_For_2_Template, 2, 3, "mat-list-item", 1, i0.ɵɵrepeaterTrackByIdentity);
|
|
27
|
-
i0.ɵɵelementEnd();
|
|
28
|
-
} if (rf & 2) {
|
|
29
|
-
i0.ɵɵproperty("disabled", ctx.disabled == null ? null : ctx.disabled.all);
|
|
30
|
-
i0.ɵɵadvance();
|
|
31
|
-
i0.ɵɵrepeater(ctx.options);
|
|
32
|
-
} }, dependencies: [MatListModule, i1.MatList, i1.MatListItem], styles: ["mat-list[_ngcontent-%COMP%]{width:50px;padding:0}mat-list[_ngcontent-%COMP%] .mat-mdc-list-item[_ngcontent-%COMP%]:not(.mat-mdc-list-item-interactive){cursor:pointer} > div[_ngcontent-%COMP%]::-webkit-scrollbar{display:none} .mdc-list-item__primary-text{font-family:var(--mat-datepicker-calendar-text-font);font-size:var(--mat-datepicker-calendar-text-size)} .mdc-list-item--activated{background-color:var(--mat-datepicker-calendar-date-selected-state-background-color)} .mdc-list-item--activated .mdc-list-item__primary-text{color:var(--mat-datepicker-calendar-date-selected-state-text-color)}"] }); }
|
|
33
|
-
}
|
|
34
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DesktopTimePickerComponent, [{
|
|
35
|
-
type: Component,
|
|
36
|
-
args: [{ selector: 'cauca-desktop-time-picker', standalone: true, imports: [
|
|
37
|
-
MatListModule
|
|
38
|
-
], template: "<mat-list [disabled]=\"disabled?.all\">\n @for (option of options; track option) {\n <mat-list-item [activated]=\"value === option\" [disabled]=\"disabled?.someOptions.includes(option)\"\n (click)=\"valueChange.emit(option)\">{{(option < 10 ? '0' : '' ) + option}}</mat-list-item>\n }\n</mat-list>", styles: ["mat-list{width:50px;padding:0}mat-list .mat-mdc-list-item:not(.mat-mdc-list-item-interactive){cursor:pointer}>div::-webkit-scrollbar{display:none}::ng-deep .mdc-list-item__primary-text{font-family:var(--mat-datepicker-calendar-text-font);font-size:var(--mat-datepicker-calendar-text-size)}::ng-deep .mdc-list-item--activated{background-color:var(--mat-datepicker-calendar-date-selected-state-background-color)}::ng-deep .mdc-list-item--activated .mdc-list-item__primary-text{color:var(--mat-datepicker-calendar-date-selected-state-text-color)}\n"] }]
|
|
39
|
-
}], null, { options: [{
|
|
40
|
-
type: Input
|
|
41
|
-
}], value: [{
|
|
42
|
-
type: Input
|
|
43
|
-
}], disabled: [{
|
|
44
|
-
type: Input
|
|
45
|
-
}], valueChange: [{
|
|
46
|
-
type: Output
|
|
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVza3RvcC10aW1lLXBpY2tlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYXVjYS1tYXRlcmlhbC9zcmMvbGliL2NhdWNhLWRhdGUtdGltZS1waWNrZXIvY29tcG9uZW50cy9kZXNrdG9wLXRpbWUtcGlja2VyL2Rlc2t0b3AtdGltZS1waWNrZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2F1Y2EtbWF0ZXJpYWwvc3JjL2xpYi9jYXVjYS1kYXRlLXRpbWUtcGlja2VyL2NvbXBvbmVudHMvZGVza3RvcC10aW1lLXBpY2tlci9kZXNrdG9wLXRpbWUtcGlja2VyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDOzs7OztJQ0NuRCx3Q0FDdUM7SUFBbkMseU5BQVMsa0NBQXdCLEtBQUM7SUFBQyxZQUFzQztJQUFBLGlCQUFnQjs7OztJQUQvQyxBQUEvQixzREFBOEIsOEZBQW9EO0lBQzFELGNBQXNDO0lBQXRDLDZEQUFzQzs7QURTakYsTUFBTSxPQUFPLDBCQUEwQjtJQVR2QztRQVVrQixZQUFPLEdBQWEsRUFBRSxDQUFDO1FBSXRCLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztLQUMzRDsyRkFOWSwwQkFBMEI7b0VBQTFCLDBCQUEwQjtZQ1p2QyxtQ0FBcUM7WUFDakMseUhBR1M7WUFDYixpQkFBVzs7WUFMRCx5RUFBMEI7WUFDaEMsY0FHUztZQUhULDBCQUdTOzRCREdULGFBQWE7O2lGQUtKLDBCQUEwQjtjQVR0QyxTQUFTOzJCQUNFLDJCQUEyQixjQUN6QixJQUFJLFdBQ1A7b0JBQ1AsYUFBYTtpQkFDZDtnQkFLZSxPQUFPO2tCQUF0QixLQUFLO1lBQ1UsS0FBSztrQkFBcEIsS0FBSztZQUNVLFFBQVE7a0JBQXZCLEtBQUs7WUFFVyxXQUFXO2tCQUEzQixNQUFNOztrRkFMSSwwQkFBMEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF0TGlzdE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2xpc3QnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdjYXVjYS1kZXNrdG9wLXRpbWUtcGlja2VyJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIE1hdExpc3RNb2R1bGVcbiAgXSxcbiAgdGVtcGxhdGVVcmw6ICcuL2Rlc2t0b3AtdGltZS1waWNrZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vZGVza3RvcC10aW1lLXBpY2tlci5jb21wb25lbnQuc2Nzcydcbn0pXG5leHBvcnQgY2xhc3MgRGVza3RvcFRpbWVQaWNrZXJDb21wb25lbnQge1xuICBASW5wdXQoKSBwdWJsaWMgb3B0aW9uczogbnVtYmVyW10gPSBbXTtcbiAgQElucHV0KCkgcHVibGljIHZhbHVlOiBudW1iZXI7XG4gIEBJbnB1dCgpIHB1YmxpYyBkaXNhYmxlZDogRGVza3RvcFRpbWVQaWNrZXJDb21wb25lbnREaXNhYmxlZDtcblxuICBAT3V0cHV0KCkgcHVibGljIHZhbHVlQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxudW1iZXI+KCk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGVza3RvcFRpbWVQaWNrZXJDb21wb25lbnREaXNhYmxlZCB7XG4gIGFsbDogYm9vbGVhbjtcbiAgc29tZU9wdGlvbnM6IG51bWJlcltdO1xufSIsIjxtYXQtbGlzdCBbZGlzYWJsZWRdPVwiZGlzYWJsZWQ/LmFsbFwiPlxuICAgIEBmb3IgKG9wdGlvbiBvZiBvcHRpb25zOyB0cmFjayBvcHRpb24pIHtcbiAgICA8bWF0LWxpc3QtaXRlbSBbYWN0aXZhdGVkXT1cInZhbHVlID09PSBvcHRpb25cIiBbZGlzYWJsZWRdPVwiZGlzYWJsZWQ/LnNvbWVPcHRpb25zLmluY2x1ZGVzKG9wdGlvbilcIlxuICAgICAgICAoY2xpY2spPVwidmFsdWVDaGFuZ2UuZW1pdChvcHRpb24pXCI+e3sob3B0aW9uIDwgMTAgPyAnMCcgOiAnJyApICsgb3B0aW9ufX08L21hdC1saXN0LWl0ZW0+XG4gICAgICAgICAgICB9XG48L21hdC1saXN0PiJdfQ==
|