@eui/mobile-core 17.2.0-snapshot-1716965435198 → 17.2.0-snapshot-1717135823057
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/assets/i18n-mobile/en.json +7 -1
- package/assets/i18n-mobile/es.json +8 -2
- package/assets/i18n-mobile/fr.json +7 -1
- package/assets/i18n-mobile/tr.json +7 -1
- package/docs/components/EuimAboutComponent.html +7 -0
- package/docs/components/EuimPdfViewerComponent.html +8 -1
- package/docs/components/EuimSliderInfoScreenComponent.html +4 -4
- package/docs/components/EuimToolbarDatepickerComponent.html +24 -4
- package/docs/dependencies.html +5 -5
- package/docs/js/menu-wc.js +3 -3
- package/docs/js/menu-wc_es5.js +1 -1
- package/docs/js/search/search_index.js +2 -2
- package/esm2022/lib/components/euim-about/euim-about.component.mjs +5 -1
- package/esm2022/lib/components/euim-pdf-viewer/euim-pdf-viewer.component.mjs +7 -3
- package/esm2022/lib/components/euim-slider-info-screen/euim-slider-info-screen.component.mjs +7 -6
- package/esm2022/lib/components/euim-slider-info-screen/euim-slider-info-screen.module.mjs +7 -3
- package/esm2022/lib/components/euim-toolbar-datepicker/euim-toolbar-datepicker.component.mjs +46 -13
- package/fesm2022/eui-mobile-core.mjs +109 -66
- package/fesm2022/eui-mobile-core.mjs.map +1 -1
- package/lib/components/euim-about/euim-about.component.d.ts +4 -0
- package/lib/components/euim-about/euim-about.component.d.ts.map +1 -1
- package/lib/components/euim-pdf-viewer/euim-pdf-viewer.component.d.ts +4 -0
- package/lib/components/euim-pdf-viewer/euim-pdf-viewer.component.d.ts.map +1 -1
- package/lib/components/euim-slider-info-screen/euim-slider-info-screen.component.d.ts.map +1 -1
- package/lib/components/euim-slider-info-screen/euim-slider-info-screen.module.d.ts +2 -1
- package/lib/components/euim-slider-info-screen/euim-slider-info-screen.module.d.ts.map +1 -1
- package/lib/components/euim-toolbar-datepicker/euim-toolbar-datepicker.component.d.ts +17 -5
- package/lib/components/euim-toolbar-datepicker/euim-toolbar-datepicker.component.d.ts.map +1 -1
- package/package.json +1 -1
package/esm2022/lib/components/euim-toolbar-datepicker/euim-toolbar-datepicker.component.mjs
CHANGED
|
@@ -2,24 +2,32 @@ import { booleanAttribute, Component, EventEmitter, HostBinding, Input, Output,
|
|
|
2
2
|
import { BaseStatesDirective } from '../base-states.directive';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "../base-states.directive";
|
|
5
|
-
import * as i2 from "@
|
|
6
|
-
import * as i3 from "
|
|
7
|
-
import * as i4 from "../
|
|
5
|
+
import * as i2 from "@ngx-translate/core";
|
|
6
|
+
import * as i3 from "@ionic/angular";
|
|
7
|
+
import * as i4 from "../euim-avatar-icon/euim-avatar-icon.component";
|
|
8
|
+
import * as i5 from "../atoms/euim-label/euim-label.component";
|
|
9
|
+
import * as i6 from "@angular/forms";
|
|
10
|
+
/**
|
|
11
|
+
* This component is not ready yet for production
|
|
12
|
+
* @beta
|
|
13
|
+
*/
|
|
8
14
|
export class EuimToolbarDatepickerComponent {
|
|
9
15
|
get cssClasses() {
|
|
10
16
|
return this.getCssClasses();
|
|
11
17
|
}
|
|
12
|
-
constructor(baseStatesDirective) {
|
|
18
|
+
constructor(baseStatesDirective, translate) {
|
|
13
19
|
this.baseStatesDirective = baseStatesDirective;
|
|
20
|
+
this.translate = translate;
|
|
14
21
|
this.icon = 'calendar-clear-sharp';
|
|
15
22
|
this.prevBtnClick = new EventEmitter();
|
|
16
23
|
this.nextBtnClick = new EventEmitter();
|
|
17
24
|
this.dateChanged = new EventEmitter();
|
|
18
|
-
this.weekdays = [
|
|
25
|
+
this.weekdays = [];
|
|
19
26
|
this._dateTimeId = 'date';
|
|
20
27
|
this.dateTimeId = crypto.randomUUID();
|
|
21
28
|
this.modalId = crypto.randomUUID();
|
|
22
29
|
this.currentDate = new Date();
|
|
30
|
+
this.formattedDate = this.currentDate.toLocaleDateString();
|
|
23
31
|
}
|
|
24
32
|
get dateTimeId() {
|
|
25
33
|
return this._dateTimeId;
|
|
@@ -31,8 +39,19 @@ export class EuimToolbarDatepickerComponent {
|
|
|
31
39
|
if (!this.baseStatesDirective.color) {
|
|
32
40
|
this.baseStatesDirective.color = 'primary';
|
|
33
41
|
}
|
|
42
|
+
this.loadWeekdaysTranslation(this.translate.currentLang);
|
|
43
|
+
this.langChangeSubscription = this.translate.onLangChange.subscribe((event) => {
|
|
44
|
+
this.currentLang = event.lang;
|
|
45
|
+
this.loadWeekdaysTranslation(event.lang);
|
|
46
|
+
this.formatDateAndWeekDay();
|
|
47
|
+
});
|
|
34
48
|
this.formatDateAndWeekDay();
|
|
35
49
|
}
|
|
50
|
+
ngOnDestroy() {
|
|
51
|
+
if (this.langChangeSubscription) {
|
|
52
|
+
this.langChangeSubscription.unsubscribe();
|
|
53
|
+
}
|
|
54
|
+
}
|
|
36
55
|
getCssClasses() {
|
|
37
56
|
return [
|
|
38
57
|
this.baseStatesDirective.getCssClasses('euim-toolbar-datepicker'),
|
|
@@ -41,28 +60,42 @@ export class EuimToolbarDatepickerComponent {
|
|
|
41
60
|
updateCurrentDate(date) {
|
|
42
61
|
this.currentDate = (new Date(date));
|
|
43
62
|
this.dateChanged.emit(this.currentDate);
|
|
63
|
+
this.formattedDate = this.currentDate.toLocaleDateString();
|
|
44
64
|
this.formatDateAndWeekDay();
|
|
45
65
|
}
|
|
46
66
|
calendarDateChanged(event) {
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
67
|
+
const customEvent = event;
|
|
68
|
+
if (customEvent.detail.value) {
|
|
69
|
+
this.currentDate = (new Date(customEvent.detail.value));
|
|
70
|
+
this.formattedDate = this.currentDate.toLocaleDateString();
|
|
71
|
+
this.formatDateAndWeekDay();
|
|
72
|
+
this.dateChanged.emit(this.currentDate);
|
|
73
|
+
}
|
|
50
74
|
}
|
|
51
75
|
selectPrevDate() {
|
|
52
76
|
this.currentDate.setDate(this.currentDate.getDate() - 1);
|
|
77
|
+
this.formattedDate = this.currentDate.toLocaleDateString();
|
|
53
78
|
this.formatDateAndWeekDay();
|
|
79
|
+
this.selectedDate = this.currentDate.toISOString();
|
|
54
80
|
this.prevBtnClick.emit(this.currentDate);
|
|
55
81
|
}
|
|
56
82
|
selectNextDate() {
|
|
57
83
|
this.currentDate.setDate(this.currentDate.getDate() + 1);
|
|
84
|
+
this.formattedDate = this.currentDate.toLocaleDateString();
|
|
58
85
|
this.formatDateAndWeekDay();
|
|
86
|
+
this.selectedDate = this.currentDate.toISOString();
|
|
59
87
|
this.nextBtnClick.emit(this.currentDate);
|
|
60
88
|
}
|
|
89
|
+
loadWeekdaysTranslation(lang) {
|
|
90
|
+
this.translate.get('euim.toolbar-datepicker.WEEKDAYS').subscribe((weekdays) => {
|
|
91
|
+
this.weekdays = weekdays;
|
|
92
|
+
});
|
|
93
|
+
}
|
|
61
94
|
formatDateAndWeekDay() {
|
|
62
95
|
this.weekDayName = this.weekdays[this.currentDate.getDay()];
|
|
63
96
|
}
|
|
64
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimToolbarDatepickerComponent, deps: [{ token: i1.BaseStatesDirective }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
65
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.7", type: EuimToolbarDatepickerComponent, selector: "euim-toolbar-datepicker", inputs: { icon: "icon", title: "title", subTitle: "subTitle", euimPrevBtnDisabled: ["euimPrevBtnDisabled", "euimPrevBtnDisabled", booleanAttribute], euimNextBtnDisabled: ["euimNextBtnDisabled", "euimNextBtnDisabled", booleanAttribute], euimReadOnly: ["euimReadOnly", "euimReadOnly", booleanAttribute] }, outputs: { prevBtnClick: "prevBtnClick", nextBtnClick: "nextBtnClick", dateChanged: "dateChanged" }, host: { properties: { "class": "this.cssClasses" } }, hostDirectives: [{ directive: i1.BaseStatesDirective, inputs: ["color", "color"] }], ngImport: i0, template: "<ion-item class=\"euim-toolbar-datepicker__item\"\n color=\"primary\">\n <euim-avatar-icon fill=\"clear\" slot=\"start\" >\n <ion-icon [name]=\"icon\"\n class=\"euim-toolbar-datepicker__calendar\"></ion-icon>\n </euim-avatar-icon>\n\n <ion-
|
|
97
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimToolbarDatepickerComponent, deps: [{ token: i1.BaseStatesDirective }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
98
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.7", type: EuimToolbarDatepickerComponent, selector: "euim-toolbar-datepicker", inputs: { icon: "icon", title: "title", subTitle: "subTitle", euimPrevBtnDisabled: ["euimPrevBtnDisabled", "euimPrevBtnDisabled", booleanAttribute], euimNextBtnDisabled: ["euimNextBtnDisabled", "euimNextBtnDisabled", booleanAttribute], euimReadOnly: ["euimReadOnly", "euimReadOnly", booleanAttribute] }, outputs: { prevBtnClick: "prevBtnClick", nextBtnClick: "nextBtnClick", dateChanged: "dateChanged" }, host: { properties: { "class": "this.cssClasses" } }, hostDirectives: [{ directive: i1.BaseStatesDirective, inputs: ["color", "color"] }], ngImport: i0, template: "<ion-item class=\"euim-toolbar-datepicker__item\"\n color=\"primary\">\n <euim-avatar-icon fill=\"clear\" slot=\"start\" >\n <ion-icon [name]=\"icon\"\n class=\"euim-toolbar-datepicker__calendar\"></ion-icon>\n </euim-avatar-icon>\n\n <ion-datetime-button class=\"euim-toolbar-datepicker__datetime-button--hidden\"\n [datetime]=\"dateTimeId\">\n </ion-datetime-button>\n <div class=\"euim-toolbar-datepicker__datetime-button\" [id]=\"modalId\">\n <ion-label class=\"euim-toolbar-datepicker__date\"\n position=\"fixed\">\n <div class=\"euim-toolbar-datepicker__title\"\n euimLabel\n euimLabelTitle\n disabled=\"euimReadOnly\">{{!title ? weekDayName : title}}</div>\n\n <div euimLabel euimLabelSubTitle\n disabled=\"euimReadOnly\">{{!subTitle ? formattedDate : subTitle}}</div>\n </ion-label>\n @if (!euimReadOnly){\n <ion-icon class=\"euim-toolbar-datepicker__datetime-caret\"\n name=\"caret-down-sharp\"\n color=\"light\"></ion-icon>\n }\n </div>\n\n @if (!euimReadOnly) {\n <ion-buttons slot=\"end\">\n <ion-button (click)=\"selectPrevDate()\"\n [disabled] = \"euimPrevBtnDisabled\"\n shape=\"round\"\n class=\"euim-toolbar-datepicker__nav-button\">\n <ion-icon name=\"chevron-back-circle-sharp\"\n color=\"light\">\n </ion-icon>\n </ion-button>\n <ion-button\n (click)=\"selectNextDate()\"\n [disabled]=\"euimNextBtnDisabled\"\n shape=\"round\"\n class=\"euim-toolbar-datepicker__nav-button euim-toolbar-datepicker__nav-button--next\">\n <ion-icon name=\"chevron-forward-circle-sharp\"\n color=\"light\"></ion-icon>\n </ion-button>\n </ion-buttons>\n }\n</ion-item>\n\n<ion-modal [keepContentsMounted]=\"true\"\n [trigger]=\"modalId\">\n <ng-template>\n <ion-datetime\n [showDefaultButtons]=\"true\"\n (ionChange)=\"calendarDateChanged($event)\"\n size=\"cover\"\n [id]=\"dateTimeId\"\n [locale]=\"currentLang\"\n [(ngModel)]=\"selectedDate\"\n presentation=\"date\"></ion-datetime>\n </ng-template>\n</ion-modal>\n", styles: [".euim-toolbar-datepicker{--inner-padding-end: var(--eui-base-spacing-xs)}.euim-toolbar-datepicker ion-item:has(ion-buttons ion-button ion-icon){--inner-padding-end: var(--eui-base-spacing-2xs)}.euim-toolbar-datepicker__datetime_icon{margin-left:var(--eui-base-spacing-l);margin-right:var(--eui-base-spacing-l);width:var(--eui-base-spacing-l);height:var(--eui-base-spacing-l)}.euim-toolbar-datepicker__datetime-button{cursor:pointer;display:flex;align-items:center;height:100%;padding-top:var(--eui-base-spacing-s);padding-bottom:var(--eui-base-spacing-s)}.euim-toolbar-datepicker__datetime-button--hidden{display:none}.euim-toolbar-datepicker__datetime-caret{margin-left:var(--eui-base-spacing-xs)!important;margin-right:var(--eui-base-spacing-xs)!important;width:var(--eui-base-spacing-m);height:var(--eui-base-spacing-m)}.euim-toolbar-datepicker__nav-button{width:calc(var(--eui-base-spacing-2xl) + var(--eui-base-spacing-2xs))!important;height:calc(var(--eui-base-spacing-2xl) + var(--eui-base-spacing-2xs))!important}.euim-toolbar-datepicker__nav-button ion-icon{width:var(--eui-base-spacing-xl);height:var(--eui-base-spacing-xl)}.euim-toolbar-datepicker__date{display:inline-table!important;flex:0 0 0!important;min-width:0!important}.euim-toolbar-datepicker__title{width:fit-content}.euim-toolbar-datepicker--primary .euim-toolbar-datepicker__calendar,.euim-toolbar-datepicker--primary .euim-label{color:#fff}.euim-toolbar-datepicker--primary .euim-toolbar-datepicker__datetime-button::part(native){background:var(--eui-base-color-primary);color:#fff}\n"], dependencies: [{ kind: "component", type: i3.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: i3.IonButtons, selector: "ion-buttons", inputs: ["collapse"] }, { kind: "component", type: i3.IonDatetime, selector: "ion-datetime", inputs: ["cancelText", "clearText", "color", "dayValues", "disabled", "doneText", "firstDayOfWeek", "highlightedDates", "hourCycle", "hourValues", "isDateEnabled", "locale", "max", "min", "minuteValues", "mode", "monthValues", "multiple", "name", "preferWheel", "presentation", "readonly", "showClearButton", "showDefaultButtons", "showDefaultTimeLabel", "showDefaultTitle", "size", "titleSelectedDatesFormatter", "value", "yearValues"] }, { kind: "component", type: i3.IonDatetimeButton, selector: "ion-datetime-button", inputs: ["color", "datetime", "disabled", "mode"] }, { kind: "component", type: i3.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i3.IonItem, selector: "ion-item", inputs: ["button", "color", "counter", "counterFormatter", "detail", "detailIcon", "disabled", "download", "fill", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "shape", "target", "type"] }, { kind: "component", type: i3.IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "component", type: i3.IonModal, selector: "ion-modal", inputs: ["animated", "keepContentsMounted", "backdropBreakpoint", "backdropDismiss", "breakpoints", "canDismiss", "cssClass", "enterAnimation", "event", "handle", "handleBehavior", "initialBreakpoint", "isOpen", "keyboardClose", "leaveAnimation", "mode", "presentingElement", "showBackdrop", "swipeToClose", "translucent", "trigger"] }, { kind: "directive", type: i3.SelectValueAccessor, selector: "ion-range, ion-select, ion-radio-group, ion-segment, ion-datetime" }, { kind: "component", type: i4.EuimAvatarIconComponent, selector: "euim-avatar-icon", inputs: ["color", "size", "fill", "variant", "borderColor"] }, { kind: "component", type: i5.EuimLabelComponent, selector: "div[euimLabel], p[euimLabel], span[euimLabel], euim-label", inputs: ["euimLabelTruncateWithLines", "euimLabelTitle", "euimLabelSubTitle", "euimLabelMeta", "euimLabelTruncate"] }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
66
99
|
}
|
|
67
100
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimToolbarDatepickerComponent, decorators: [{
|
|
68
101
|
type: Component,
|
|
@@ -73,8 +106,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
73
106
|
'color',
|
|
74
107
|
],
|
|
75
108
|
},
|
|
76
|
-
], template: "<ion-item class=\"euim-toolbar-datepicker__item\"\n color=\"primary\">\n <euim-avatar-icon fill=\"clear\" slot=\"start\" >\n <ion-icon [name]=\"icon\"\n class=\"euim-toolbar-datepicker__calendar\"></ion-icon>\n </euim-avatar-icon>\n\n <ion-
|
|
77
|
-
}], ctorParameters: () => [{ type: i1.BaseStatesDirective }], propDecorators: { icon: [{
|
|
109
|
+
], template: "<ion-item class=\"euim-toolbar-datepicker__item\"\n color=\"primary\">\n <euim-avatar-icon fill=\"clear\" slot=\"start\" >\n <ion-icon [name]=\"icon\"\n class=\"euim-toolbar-datepicker__calendar\"></ion-icon>\n </euim-avatar-icon>\n\n <ion-datetime-button class=\"euim-toolbar-datepicker__datetime-button--hidden\"\n [datetime]=\"dateTimeId\">\n </ion-datetime-button>\n <div class=\"euim-toolbar-datepicker__datetime-button\" [id]=\"modalId\">\n <ion-label class=\"euim-toolbar-datepicker__date\"\n position=\"fixed\">\n <div class=\"euim-toolbar-datepicker__title\"\n euimLabel\n euimLabelTitle\n disabled=\"euimReadOnly\">{{!title ? weekDayName : title}}</div>\n\n <div euimLabel euimLabelSubTitle\n disabled=\"euimReadOnly\">{{!subTitle ? formattedDate : subTitle}}</div>\n </ion-label>\n @if (!euimReadOnly){\n <ion-icon class=\"euim-toolbar-datepicker__datetime-caret\"\n name=\"caret-down-sharp\"\n color=\"light\"></ion-icon>\n }\n </div>\n\n @if (!euimReadOnly) {\n <ion-buttons slot=\"end\">\n <ion-button (click)=\"selectPrevDate()\"\n [disabled] = \"euimPrevBtnDisabled\"\n shape=\"round\"\n class=\"euim-toolbar-datepicker__nav-button\">\n <ion-icon name=\"chevron-back-circle-sharp\"\n color=\"light\">\n </ion-icon>\n </ion-button>\n <ion-button\n (click)=\"selectNextDate()\"\n [disabled]=\"euimNextBtnDisabled\"\n shape=\"round\"\n class=\"euim-toolbar-datepicker__nav-button euim-toolbar-datepicker__nav-button--next\">\n <ion-icon name=\"chevron-forward-circle-sharp\"\n color=\"light\"></ion-icon>\n </ion-button>\n </ion-buttons>\n }\n</ion-item>\n\n<ion-modal [keepContentsMounted]=\"true\"\n [trigger]=\"modalId\">\n <ng-template>\n <ion-datetime\n [showDefaultButtons]=\"true\"\n (ionChange)=\"calendarDateChanged($event)\"\n size=\"cover\"\n [id]=\"dateTimeId\"\n [locale]=\"currentLang\"\n [(ngModel)]=\"selectedDate\"\n presentation=\"date\"></ion-datetime>\n </ng-template>\n</ion-modal>\n", styles: [".euim-toolbar-datepicker{--inner-padding-end: var(--eui-base-spacing-xs)}.euim-toolbar-datepicker ion-item:has(ion-buttons ion-button ion-icon){--inner-padding-end: var(--eui-base-spacing-2xs)}.euim-toolbar-datepicker__datetime_icon{margin-left:var(--eui-base-spacing-l);margin-right:var(--eui-base-spacing-l);width:var(--eui-base-spacing-l);height:var(--eui-base-spacing-l)}.euim-toolbar-datepicker__datetime-button{cursor:pointer;display:flex;align-items:center;height:100%;padding-top:var(--eui-base-spacing-s);padding-bottom:var(--eui-base-spacing-s)}.euim-toolbar-datepicker__datetime-button--hidden{display:none}.euim-toolbar-datepicker__datetime-caret{margin-left:var(--eui-base-spacing-xs)!important;margin-right:var(--eui-base-spacing-xs)!important;width:var(--eui-base-spacing-m);height:var(--eui-base-spacing-m)}.euim-toolbar-datepicker__nav-button{width:calc(var(--eui-base-spacing-2xl) + var(--eui-base-spacing-2xs))!important;height:calc(var(--eui-base-spacing-2xl) + var(--eui-base-spacing-2xs))!important}.euim-toolbar-datepicker__nav-button ion-icon{width:var(--eui-base-spacing-xl);height:var(--eui-base-spacing-xl)}.euim-toolbar-datepicker__date{display:inline-table!important;flex:0 0 0!important;min-width:0!important}.euim-toolbar-datepicker__title{width:fit-content}.euim-toolbar-datepicker--primary .euim-toolbar-datepicker__calendar,.euim-toolbar-datepicker--primary .euim-label{color:#fff}.euim-toolbar-datepicker--primary .euim-toolbar-datepicker__datetime-button::part(native){background:var(--eui-base-color-primary);color:#fff}\n"] }]
|
|
110
|
+
}], ctorParameters: () => [{ type: i1.BaseStatesDirective }, { type: i2.TranslateService }], propDecorators: { icon: [{
|
|
78
111
|
type: Input
|
|
79
112
|
}], title: [{
|
|
80
113
|
type: Input
|
|
@@ -99,4 +132,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
99
132
|
type: HostBinding,
|
|
100
133
|
args: ['class']
|
|
101
134
|
}] } });
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-toolbar-datepicker.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/euim-toolbar-datepicker/euim-toolbar-datepicker.component.ts","../../../../../src/lib/components/euim-toolbar-datepicker/euim-toolbar-datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    booleanAttribute, ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    HostBinding,\n    Input, OnInit,\n    Output,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { BaseStatesDirective } from '../base-states.directive';\n\n@Component({\n    selector: 'euim-toolbar-datepicker',\n    styleUrls: ['./styles/_index.scss'],\n    templateUrl: 'euim-toolbar-datepicker.component.html',\n    encapsulation: ViewEncapsulation.None,\n    hostDirectives: [\n        {\n            directive: BaseStatesDirective,\n            inputs: [\n                'color',\n            ],\n        },\n    ],\n})\nexport class EuimToolbarDatepickerComponent\n    implements OnInit {\n    @Input() icon = 'calendar-clear-sharp';\n    @Input() title : string;\n    @Input() subTitle : string;\n    @Input({ transform: booleanAttribute })\n    euimPrevBtnDisabled: boolean;\n    @Input({ transform: booleanAttribute })\n    euimNextBtnDisabled:boolean;\n    // should be fixed as now is it disabled colors\n    @Input({ transform: booleanAttribute })\n    euimReadOnly:boolean;\n\n    @Output() prevBtnClick: EventEmitter<Date> = new EventEmitter<Date>();\n    @Output() nextBtnClick: EventEmitter<Date> = new EventEmitter<Date>();\n    @Output() dateChanged: EventEmitter<Date> = new EventEmitter<Date>();\n\n    weekDayName: string;\n\n    private weekdays = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'];\n    private _dateTimeId = 'date';\n\n    protected modalId: string;\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return this.getCssClasses();\n    }\n    constructor(public baseStatesDirective: BaseStatesDirective) {\n        this.dateTimeId =  crypto.randomUUID();\n        this.modalId =  crypto.randomUUID();\n        this.currentDate = new Date();\n    }\n\n    get dateTimeId(): string {\n        return this._dateTimeId;\n    }\n\n    protected set dateTimeId(val:string) {\n        this._dateTimeId = val;\n    }\n\n    protected currentDate: Date;\n\n    ngOnInit (): void {\n        if (!this.baseStatesDirective.color) {\n            this.baseStatesDirective.color = 'primary';\n        }\n        this.formatDateAndWeekDay();\n    }\n\n    getCssClasses(): string {\n        return [\n            this.baseStatesDirective.getCssClasses('euim-toolbar-datepicker'),\n        ].join(' ');\n    }\n\n    updateCurrentDate(date:string): void {\n        this.currentDate = (new Date(date));\n        this.dateChanged.emit(this.currentDate);\n        this.formatDateAndWeekDay();\n    }\n\n    calendarDateChanged(event: CustomEvent): void {\n        this.currentDate = (new Date(event.detail.value));\n        this.dateChanged.emit(this.currentDate);\n        this.formatDateAndWeekDay();\n    }\n    protected selectPrevDate(): void {\n        this.currentDate.setDate(this.currentDate.getDate() - 1 );\n        this.formatDateAndWeekDay();\n        this.prevBtnClick.emit(this.currentDate);\n    }\n\n    protected selectNextDate(): void {\n        this.currentDate.setDate(this.currentDate.getDate() + 1 );\n        this.formatDateAndWeekDay();\n        this.nextBtnClick.emit(this.currentDate);\n    }\n\n    private formatDateAndWeekDay(): void {\n        this.weekDayName = this.weekdays[this.currentDate.getDay()];\n    }\n\n}\n","<ion-item class=\"euim-toolbar-datepicker__item\"\n           color=\"primary\">\n    <euim-avatar-icon  fill=\"clear\" slot=\"start\" >\n        <ion-icon [name]=\"icon\"\n                  class=\"euim-toolbar-datepicker__calendar\"></ion-icon>\n    </euim-avatar-icon>\n\n    <ion-label class=\"euim-toolbar-datepicker__date\"\n               position=\"fixed\">\n        <euim-label class=\"euim-toolbar-datepicker__title\"\n                    euimLabelTitle\n                    disabled=\"euimReadOnly\">{{!title ? this.weekDayName : title}}</euim-label>\n        @if (!subTitle) {\n                <ion-datetime-button class=\"euim-toolbar-datepicker__datetime-button\"\n                                     [datetime]=\"dateTimeId\"\n                                     [disabled]=\"euimReadOnly\">\n                </ion-datetime-button>\n        } @else {\n            <div euimLabel euimLabelSubTitle\n                 disabled=\"euimReadOnly\">{{subTitle}}</div>\n        }\n\n    </ion-label>\n    @if (!euimReadOnly){\n        <ion-icon class=\"euim-toolbar-datepicker__datetime-caret\"\n                  name=\"caret-down-sharp\"\n                  [id]=\"modalId\"></ion-icon>\n    }\n\n    @if (!euimReadOnly) {\n        <ion-buttons slot=\"end\">\n            <ion-button size=\"large\"\n                        (click)=\"selectPrevDate()\"\n                        [disabled] = \"euimPrevBtnDisabled\"\n                        shape=\"round\"\n                        class=\"euim-toolbar-datepicker__nav-button\">\n                <ion-icon name=\"chevron-back-circle-sharp\"\n                          color=\"light\"\n                          size=\"large\">\n                </ion-icon>\n            </ion-button>\n            <ion-button\n                        (click)=\"selectNextDate()\"\n                        [disabled]=\"euimNextBtnDisabled\"\n                        shape=\"round\"\n                        size=\"large\"\n                        class=\"euim-toolbar-datepicker__nav-button\">\n                <ion-icon name=\"chevron-forward-circle-sharp\"\n                          color=\"light\"\n                          size=\"large\"></ion-icon>\n            </ion-button>\n        </ion-buttons>\n    }\n</ion-item>\n\n<ion-modal [keepContentsMounted]=\"true\"\n           [trigger]=\"modalId\">\n    <ng-template>\n        <ng-content select=\"ion-datetime\"></ng-content>\n    </ng-template>\n</ion-modal>\n"]}
|
|
135
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-toolbar-datepicker.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/euim-toolbar-datepicker/euim-toolbar-datepicker.component.ts","../../../../../src/lib/components/euim-toolbar-datepicker/euim-toolbar-datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    booleanAttribute,\n    Component,\n    EventEmitter,\n    HostBinding,\n    Input, OnInit,\n    Output,\n    OnDestroy,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { BaseStatesDirective } from '../base-states.directive';\nimport { TranslateService, LangChangeEvent } from '@ngx-translate/core';\nimport { Subscription } from 'rxjs';\n\n/**\n * This component is not ready yet for production\n * @beta\n */\n@Component({\n    selector: 'euim-toolbar-datepicker',\n    styleUrls: ['./styles/_index.scss'],\n    templateUrl: 'euim-toolbar-datepicker.component.html',\n    encapsulation: ViewEncapsulation.None,\n    hostDirectives: [\n        {\n            directive: BaseStatesDirective,\n            inputs: [\n                'color',\n            ],\n        },\n    ],\n})\nexport class EuimToolbarDatepickerComponent\n    implements OnInit, OnDestroy {\n    @Input() icon = 'calendar-clear-sharp';\n    @Input() title : string;\n    @Input() subTitle : string;\n    @Input({ transform: booleanAttribute })\n    euimPrevBtnDisabled: boolean;\n    @Input({ transform: booleanAttribute })\n    euimNextBtnDisabled:boolean;\n    // should be fixed as now is it disabled colors\n    @Input({ transform: booleanAttribute })\n    euimReadOnly:boolean;\n\n    @Output() prevBtnClick: EventEmitter<Date> = new EventEmitter<Date>();\n    @Output() nextBtnClick: EventEmitter<Date> = new EventEmitter<Date>();\n    @Output() dateChanged: EventEmitter<Date> = new EventEmitter<Date>();\n\n    weekDayName: string;\n    protected formattedDate: string;\n    protected selectedDate: string;\n\n    private weekdays = [];\n    private _dateTimeId = 'date';\n    private langChangeSubscription: Subscription;\n    protected currentLang: string;\n\n    protected modalId: string;\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return this.getCssClasses();\n    }\n    constructor(public baseStatesDirective: BaseStatesDirective, private translate: TranslateService) {\n        this.dateTimeId =  crypto.randomUUID();\n        this.modalId =  crypto.randomUUID();\n        this.currentDate = new Date();\n        this.formattedDate = this.currentDate.toLocaleDateString();\n    }\n\n    get dateTimeId(): string {\n        return this._dateTimeId;\n    }\n\n    protected set dateTimeId(val:string) {\n        this._dateTimeId = val;\n    }\n\n    protected currentDate: Date;\n\n    ngOnInit (): void {\n        if (!this.baseStatesDirective.color) {\n            this.baseStatesDirective.color = 'primary';\n        }\n        this.loadWeekdaysTranslation(this.translate.currentLang);\n\n        this.langChangeSubscription = this.translate.onLangChange.subscribe((event: LangChangeEvent) => {\n            this.currentLang = event.lang;\n            this.loadWeekdaysTranslation(event.lang);\n            this.formatDateAndWeekDay();\n        });\n\n        this.formatDateAndWeekDay();\n    }\n\n    ngOnDestroy(): void {\n        if (this.langChangeSubscription) {\n            this.langChangeSubscription.unsubscribe();\n        }\n    }\n\n    getCssClasses(): string {\n        return [\n            this.baseStatesDirective.getCssClasses('euim-toolbar-datepicker'),\n        ].join(' ');\n    }\n\n    updateCurrentDate(date:string): void {\n        this.currentDate = (new Date(date));\n        this.dateChanged.emit(this.currentDate);\n        this.formattedDate = this.currentDate.toLocaleDateString();\n        this.formatDateAndWeekDay();\n    }\n\n    calendarDateChanged(event: Event): void {\n        const customEvent = event as CustomEvent;\n        if (customEvent.detail.value) {\n            this.currentDate = (new Date(customEvent.detail.value));\n            this.formattedDate = this.currentDate.toLocaleDateString();\n            this.formatDateAndWeekDay();\n            this.dateChanged.emit(this.currentDate);\n        }\n    }\n    protected selectPrevDate(): void {\n        this.currentDate.setDate(this.currentDate.getDate() - 1 );\n        this.formattedDate = this.currentDate.toLocaleDateString();\n        this.formatDateAndWeekDay();\n        this.selectedDate = this.currentDate.toISOString();\n        this.prevBtnClick.emit(this.currentDate);\n    }\n\n    protected selectNextDate(): void {\n        this.currentDate.setDate(this.currentDate.getDate() + 1 );\n        this.formattedDate = this.currentDate.toLocaleDateString();\n        this.formatDateAndWeekDay();\n        this.selectedDate = this.currentDate.toISOString();\n        this.nextBtnClick.emit(this.currentDate);\n    }\n\n    private loadWeekdaysTranslation(lang: string): void {\n        this.translate.get('euim.toolbar-datepicker.WEEKDAYS').subscribe((weekdays: string[]) => {\n            this.weekdays = weekdays;\n        });\n    }\n\n    private formatDateAndWeekDay(): void {\n        this.weekDayName = this.weekdays[this.currentDate.getDay()];\n    }\n\n}\n","<ion-item class=\"euim-toolbar-datepicker__item\"\n           color=\"primary\">\n    <euim-avatar-icon  fill=\"clear\" slot=\"start\" >\n        <ion-icon [name]=\"icon\"\n                  class=\"euim-toolbar-datepicker__calendar\"></ion-icon>\n    </euim-avatar-icon>\n\n    <ion-datetime-button class=\"euim-toolbar-datepicker__datetime-button--hidden\"\n                         [datetime]=\"dateTimeId\">\n    </ion-datetime-button>\n    <div class=\"euim-toolbar-datepicker__datetime-button\" [id]=\"modalId\">\n        <ion-label class=\"euim-toolbar-datepicker__date\"\n                   position=\"fixed\">\n            <div class=\"euim-toolbar-datepicker__title\"\n                 euimLabel\n                 euimLabelTitle\n                 disabled=\"euimReadOnly\">{{!title ? weekDayName : title}}</div>\n\n            <div euimLabel euimLabelSubTitle\n                 disabled=\"euimReadOnly\">{{!subTitle ? formattedDate : subTitle}}</div>\n        </ion-label>\n        @if (!euimReadOnly){\n            <ion-icon class=\"euim-toolbar-datepicker__datetime-caret\"\n                      name=\"caret-down-sharp\"\n                      color=\"light\"></ion-icon>\n        }\n    </div>\n\n    @if (!euimReadOnly) {\n        <ion-buttons slot=\"end\">\n            <ion-button (click)=\"selectPrevDate()\"\n                        [disabled] = \"euimPrevBtnDisabled\"\n                        shape=\"round\"\n                        class=\"euim-toolbar-datepicker__nav-button\">\n                <ion-icon name=\"chevron-back-circle-sharp\"\n                          color=\"light\">\n                </ion-icon>\n            </ion-button>\n            <ion-button\n                        (click)=\"selectNextDate()\"\n                        [disabled]=\"euimNextBtnDisabled\"\n                        shape=\"round\"\n                        class=\"euim-toolbar-datepicker__nav-button euim-toolbar-datepicker__nav-button--next\">\n                <ion-icon name=\"chevron-forward-circle-sharp\"\n                          color=\"light\"></ion-icon>\n            </ion-button>\n        </ion-buttons>\n    }\n</ion-item>\n\n<ion-modal [keepContentsMounted]=\"true\"\n           [trigger]=\"modalId\">\n    <ng-template>\n        <ion-datetime\n            [showDefaultButtons]=\"true\"\n            (ionChange)=\"calendarDateChanged($event)\"\n            size=\"cover\"\n            [id]=\"dateTimeId\"\n            [locale]=\"currentLang\"\n            [(ngModel)]=\"selectedDate\"\n            presentation=\"date\"></ion-datetime>\n    </ng-template>\n</ion-modal>\n"]}
|