@cauca-911/material 18.0.9 → 19.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.
Files changed (25) hide show
  1. package/fesm2022/cauca-911-material.mjs +124 -49
  2. package/fesm2022/cauca-911-material.mjs.map +1 -1
  3. package/lib/test-component-with-classic-input/test-component-with-classic-input.component.d.ts +9 -0
  4. package/lib/test-component-with-model-signal/test-component-with-model-signal.component.d.ts +7 -0
  5. package/lib/test-component-with-signal-input/test-component-with-signal-input.component.d.ts +8 -0
  6. package/package.json +7 -9
  7. package/public-api.d.ts +3 -0
  8. package/esm2022/cauca-911-material.mjs +0 -5
  9. package/esm2022/lib/cauca-date-time-picker/cauca-date-time-picker.component.mjs +0 -209
  10. package/esm2022/lib/cauca-date-time-picker/components/desktop-time-picker/desktop-time-picker.component.mjs +0 -49
  11. package/esm2022/lib/cauca-date-time-picker/components/dialog-date-time-picker/dialog-date-time-picker.component.mjs +0 -363
  12. package/esm2022/lib/cauca-date-time-picker/components/mobile-time-picker/mobile-time-picker.component.mjs +0 -74
  13. package/esm2022/lib/cauca-date-time-picker/models/dialog-date-time-picker-data.mjs +0 -2
  14. package/esm2022/lib/cauca-input-file/cauca-input-file.component.mjs +0 -148
  15. package/esm2022/lib/cauca-input-multiple-langue/cauca-input-multiple-langue.component.mjs +0 -87
  16. package/esm2022/lib/cauca-material.component.mjs +0 -21
  17. package/esm2022/lib/cauca-material.module.mjs +0 -94
  18. package/esm2022/lib/cauca-material.service.mjs +0 -13
  19. package/esm2022/lib/cauca-menu-sidebar/cauca-menu-sidebar.component.mjs +0 -147
  20. package/esm2022/lib/cauca-menu-vertical/cauca-menu-vertical.component.mjs +0 -166
  21. package/esm2022/lib/cauca-simple-dialog/cauca-simple-dialog.component.mjs +0 -62
  22. package/esm2022/lib/cauca-slideshow/cauca-slideshow.component.mjs +0 -140
  23. package/esm2022/lib/shared/models/menu-item.mjs +0 -9
  24. package/esm2022/lib/shared/models/simple-dialog-data.mjs +0 -6
  25. package/esm2022/public-api.mjs +0 -15
@@ -1,209 +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
- maxWidth: '100vw',
76
- });
77
- dialogRef.afterClosed().subscribe((data) => {
78
- if (data) {
79
- this.stringDate = this.stringifyDate(data.value);
80
- this.selectedDate = data.value;
81
- this.selectedChange.emit(data.value);
82
- this.onChange(data.value);
83
- }
84
- });
85
- }
86
- writeValue(date) {
87
- this.value = date;
88
- }
89
- registerOnChange(fn) {
90
- this.onChange = fn;
91
- }
92
- registerOnTouched(fn) {
93
- this.onTouched = fn;
94
- }
95
- getDateTimePickerOptions() {
96
- return {
97
- selectedDate: this.selectedDate,
98
- minimumDate: this.minimumDate,
99
- maximumDate: this.maximumDate,
100
- showSeconds: this.showSeconds,
101
- showClearButton: this.showClearButton,
102
- showButtonIcons: this.showButtonIcons,
103
- showTime: this.showTime,
104
- step: {
105
- hours: this.stepHours,
106
- minutes: this.stepMinutes,
107
- seconds: this.stepSecondes,
108
- }
109
- };
110
- }
111
- stringifyDate(date) {
112
- return this.datePipe.transform(date, this.showFormat);
113
- }
114
- getDialogPosition() {
115
- const rect = this.elementRef.nativeElement.getBoundingClientRect();
116
- const top = rect.y + rect.height - 22;
117
- const bottom = window.innerHeight - rect.y;
118
- const minimumDialogHeight = 400;
119
- const minimumScreenSize = 800;
120
- if (window.innerHeight < minimumScreenSize || window.innerWidth < minimumScreenSize) {
121
- return null;
122
- }
123
- else if (window.innerHeight > (top + minimumDialogHeight)) {
124
- return {
125
- left: `${rect.x}px`,
126
- top: `${top}px`,
127
- };
128
- }
129
- return {
130
- left: `${rect.x}px`,
131
- bottom: `${bottom}px`,
132
- };
133
- }
134
- static { this.ɵfac = function CaucaDateTimePickerComponent_Factory(t) { return new (t || CaucaDateTimePickerComponent)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i1.MatDialog), i0.ɵɵdirectiveInject(i2.DatePipe)); }; }
135
- 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([
136
- DatePipe,
137
- {
138
- provide: NG_VALUE_ACCESSOR,
139
- multi: true,
140
- useExisting: forwardRef(() => CaucaDateTimePickerComponent),
141
- }
142
- ]), 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) {
143
- i0.ɵɵelementStart(0, "mat-form-field", 0);
144
- i0.ɵɵtemplate(1, CaucaDateTimePickerComponent_Conditional_1_Template, 3, 4, "mat-label");
145
- i0.ɵɵelementStart(2, "input", 1);
146
- i0.ɵɵlistener("focusout", function CaucaDateTimePickerComponent_Template_input_focusout_2_listener() { return ctx.onTouched(); });
147
- i0.ɵɵelementEnd();
148
- i0.ɵɵelementStart(3, "button", 2);
149
- i0.ɵɵlistener("click", function CaucaDateTimePickerComponent_Template_button_click_3_listener() { return ctx.showDialog(); });
150
- i0.ɵɵelementStart(4, "mat-icon");
151
- i0.ɵɵtext(5, "calendar_month");
152
- i0.ɵɵelementEnd()()();
153
- } if (rf & 2) {
154
- i0.ɵɵproperty("subscriptSizing", ctx.subscriptSizing);
155
- i0.ɵɵadvance();
156
- i0.ɵɵconditional(ctx.label ? 1 : -1);
157
- i0.ɵɵadvance();
158
- i0.ɵɵproperty("value", ctx.stringDate);
159
- } }, 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%}"] }); }
160
- }
161
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CaucaDateTimePickerComponent, [{
162
- type: Component,
163
- args: [{ selector: 'cauca-date-time-picker', standalone: true, imports: [
164
- TranslateModule,
165
- MatButtonModule,
166
- MatIconModule,
167
- MatInputModule,
168
- MatFormFieldModule
169
- ], providers: [
170
- DatePipe,
171
- {
172
- provide: NG_VALUE_ACCESSOR,
173
- multi: true,
174
- useExisting: forwardRef(() => CaucaDateTimePickerComponent),
175
- }
176
- ], 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"] }]
177
- }], () => [{ type: i0.ElementRef }, { type: i1.MatDialog }, { type: i2.DatePipe }], { subscriptSizing: [{
178
- type: Input
179
- }], showTime: [{
180
- type: Input
181
- }], label: [{
182
- type: Input
183
- }], translateLabel: [{
184
- type: Input
185
- }], stepHours: [{
186
- type: Input
187
- }], stepMinutes: [{
188
- type: Input
189
- }], stepSecondes: [{
190
- type: Input
191
- }], minimumDate: [{
192
- type: Input
193
- }], maximumDate: [{
194
- type: Input
195
- }], showSeconds: [{
196
- type: Input
197
- }], showFormat: [{
198
- type: Input
199
- }], showClearButton: [{
200
- type: Input
201
- }], showButtonIcons: [{
202
- type: Input
203
- }], selectedChange: [{
204
- type: Output
205
- }], value: [{
206
- type: Input
207
- }] }); })();
208
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(CaucaDateTimePickerComponent, { className: "CaucaDateTimePickerComponent", filePath: "lib\\cauca-date-time-picker\\cauca-date-time-picker.component.ts", lineNumber: 34 }); })();
209
- //# 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      maxWidth: '100vw',\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==