ngx-histaff-alpha 0.5.3 → 0.5.4

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.
@@ -10,8 +10,9 @@ import * as i0 from "@angular/core";
10
10
  import * as i1 from "../../services/dom.service";
11
11
  import * as i2 from "../../services/core-datetime.service";
12
12
  import * as i3 from "../../../services/multi-language.service";
13
- import * as i4 from "@angular/common";
14
- import * as i5 from "@angular/forms";
13
+ import * as i4 from "../../alert/alert.service";
14
+ import * as i5 from "@angular/common";
15
+ import * as i6 from "@angular/forms";
15
16
  /*
16
17
  this component renders its main part and popup part
17
18
  the main part deals with user input from physical keyboard or touch keyboard
@@ -24,12 +25,13 @@ import * as i5 from "@angular/forms";
24
25
 
25
26
  */
26
27
  export class CoreDatePickerComponent extends CoreFormControlBaseComponent {
27
- constructor(renderer, domService, coreDatetimeService, mls) {
28
+ constructor(renderer, domService, coreDatetimeService, mls, alertService) {
28
29
  super();
29
30
  this.renderer = renderer;
30
31
  this.domService = domService;
31
32
  this.coreDatetimeService = coreDatetimeService;
32
33
  this.mls = mls;
34
+ this.alertService = alertService;
33
35
  this.showPlaceholder = false;
34
36
  this.popupWidth = 300;
35
37
  this.popupXPadding = 12;
@@ -162,6 +164,11 @@ export class CoreDatePickerComponent extends CoreFormControlBaseComponent {
162
164
  this.markAsTouched();
163
165
  this.onChange(date);
164
166
  }
167
+ else {
168
+ this.markAsTouched();
169
+ this.onChange(null);
170
+ return;
171
+ }
165
172
  });
166
173
  }
167
174
  writeValue(obj) {
@@ -344,14 +351,14 @@ export class CoreDatePickerComponent extends CoreFormControlBaseComponent {
344
351
  this.yearPickerActive = false;
345
352
  this.monthPickerActive = true;
346
353
  }
347
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreDatePickerComponent, deps: [{ token: i0.Renderer2 }, { token: i1.DomService }, { token: i2.CoreDatetimeService }, { token: i3.MultiLanguageService }], target: i0.ɵɵFactoryTarget.Component }); }
354
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreDatePickerComponent, deps: [{ token: i0.Renderer2 }, { token: i1.DomService }, { token: i2.CoreDatetimeService }, { token: i3.MultiLanguageService }, { token: i4.AlertService }], target: i0.ɵɵFactoryTarget.Component }); }
348
355
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: CoreDatePickerComponent, isStandalone: true, selector: "core-date-picker", inputs: { enableTimeZoneConverter: "enableTimeZoneConverter", showPlaceholder: "showPlaceholder", popupWidth: "popupWidth", popupXPadding: "popupXPadding", rangeLimit: "rangeLimit", readonly: "readonly", disabled: "disabled" }, providers: [
349
356
  {
350
357
  provide: NG_VALUE_ACCESSOR,
351
358
  multi: true,
352
359
  useExisting: CoreDatePickerComponent
353
360
  }
354
- ], viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }, { propertyName: "input", first: true, predicate: ["input"], descendants: true }, { propertyName: "backward", first: true, predicate: ["backward"], descendants: true }, { propertyName: "calendarBody", first: true, predicate: ["calendarBody"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div #container class=\"core-date-picker-container\">\r\n <input type=\"checkbox\" [(ngModel)]=\"openState\">\r\n <input type=\"checkbox\" [(ngModel)]=\"monthPickerActive\">\r\n <input type=\"checkbox\" [(ngModel)]=\"yearPickerActive\">\r\n <input #backward type=\"checkbox\" class=\"tl-datepicker-direction\">\r\n <input #input type=\"text\" class=\"form-control\" [placeholder]=\"showPlaceholder ? 'dd/mm/yyyy' : ''\"\r\n maxlength=\"10\" [(ngModel)]=\"textValue\" [class.form-control-disabled]=\"disabled\" [disabled]=\"disabled\"><label class=\"icon\" (click)=\"toggleOpen()\"></label>\r\n <div class=\"tl-date-picker-popup\" [class.open]=\"openState\">\r\n <div class=\"date-picker-session\" [class.d-none]=\"monthPickerActive || yearPickerActive\">\r\n <div class=\"navigator\">\r\n <label class=\"month-dropdown\" (click)=\"toggleMonthPickerActive()\">{{ currentMonthText }} {{\r\n currentMonthObject$.value.year }}</label>\r\n <div class=\"arrows\">\r\n <div class=\"go-up\" (click)=\"goBackward()\"></div>\r\n <div class=\"go-down\" (click)=\"goForeward()\"></div>\r\n </div>\r\n </div>\r\n <div class=\"weekday-header\">\r\n <ul>\r\n <li *ngFor=\"let day of headerWeekdays; let i = index\" [class.t7]=\"i===5\" [class.cn]=\"i===6\">\r\n <div>{{ day }}</div>\r\n </li>\r\n </ul>\r\n </div>\r\n <div class=\"calendar-body-container\">\r\n <div #calendarBody class=\"calendar-body\" [class.slide-up]=\"direction===1\"\r\n [class.slide-down]=\"direction===-1\">\r\n <ul *ngFor=\"let week of data\">\r\n <li *ngFor=\"let item of week.items; let i = index\">\r\n <div [class.out-of-month]=\"!!!item.currentMonth\" [class.t7]=\"i===5\" [class.cn]=\"i===6\"\r\n [class.out-of-range]=\"!!rangeLimit && !!!((item.dateValue>=rangeLimit.minDate) && (rangeLimit.maxDate>=item.dateValue))\"\r\n [class.active]=\"item.dateValue.getFullYear()===pendingYear && item.dateValue.getMonth()===pendingMonthIndex && item.dateValue.getDate()===pendingDay\"\r\n (click)=\"onItemClick(item.dateValue)\">\r\n {{ item.date }}</div>\r\n </li>\r\n </ul>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"month-picker-session\" [class.active]=\"monthPickerActive\">\r\n <core-month-picker [lang]=\"lang\" [monthObject$]=\"currentMonthObject$\" (onChange)=\"onMonthObjectChange($event)\" (onYearClick)=\"onMonthPickerYearClick($event)\"></core-month-picker>\r\n </div>\r\n <div class=\"year-picker-session\" [class.active]=\"yearPickerActive\">\r\n <core-year-picker [lang]=\"lang\" (onChange)=\"onYearPicked($event)\"></core-year-picker>\r\n </div>\r\n <div class=\"footer-wrapper\">\r\n <div class=\"cdp-footer\">\r\n <div class=\"clear\" [class.opacity-0]=\"!!!textValue\" (click)=\"clear()\">{{ 'UI.CORE_DATE_PICKER_CLEAR' | translate: lang }}</div>\r\n <div class=\"digi-watch\"></div>\r\n <div class=\"today\" (click)=\"goToday()\">{{ 'UI.CORE_DATE_PICKER_TODAY' | translate: lang }}</div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".core-date-picker-container{--indicator-height: 39px;--popup-z-index: 99999999;--popup-width: 300px;--popup-height: 400px;--popup-bg-color: white;--popup-x-padding: 12px;--cell-size: 0px;--arrow-font-size: 28px;--font-size: 13px;--font-bold: 700;--font-light: 400;--hover-bg-color: #358ccb;--active-bg-color: cadetblue;--scroll-distance: calc(var(--cell-size) * 6);position:relative;font-weight:var(--font-light);font-size:var(--font-size)}.core-date-picker-container input[type=checkbox]{display:none}.core-date-picker-container label.icon{position:absolute;top:3px;right:3px}.core-date-picker-container label.icon:before{content:\"\";display:inline-block;aspect-ratio:1/1;width:var(--indicator-height);height:var(--indicator-height);border-radius:3px;background:url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzkiIGhlaWdodD0iMzkiIHZpZXdCb3g9IjAgMCAzOSAzOSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHJlY3Qgd2lkdGg9IjM5IiBoZWlnaHQ9IjM5IiBmaWxsPSIjRjVGNUY1Ii8+CjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMF8wXzEpIj4KPHJlY3Qgd2lkdGg9IjE5MjAiIGhlaWdodD0iMTM5NyIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTEyNjggLTg0MikiIGZpbGw9IiNGMUYxRjEiLz4KPHJlY3QgeD0iLTEyNjgiIHk9Ii04NDIiIHdpZHRoPSIxOTIwIiBoZWlnaHQ9IjEzOTciIGZpbGw9ImJsYWNrIiBmaWxsLW9wYWNpdHk9IjAuMyIvPgo8cmVjdCB4PSItNjgyIiB5PSItNjU4IiB3aWR0aD0iNzUwIiBoZWlnaHQ9Ijk5OSIgcng9IjEwIiBmaWxsPSJ3aGl0ZSIvPgo8cmVjdCB4PSItMjkwLjUiIHk9Ii0yLjUiIHdpZHRoPSIzMzIiIGhlaWdodD0iNDQiIHJ4PSI0LjUiIGZpbGw9IndoaXRlIiBzdHJva2U9IiNEMUQxRDEiLz4KPHJlY3Qgd2lkdGg9IjM5IiBoZWlnaHQ9IjM5IiByeD0iMyIgZmlsbD0iI0U5RTlFOSIvPgo8cGF0aCBkPSJNMjYuOTAwMSAxMS4wOTkxSDEyLjE5OTdDMTEuMDM5OCAxMS4wOTkxIDEwLjA5OTYgMTIuMDM5MyAxMC4wOTk2IDEzLjE5OTJWMjcuODk5NkMxMC4wOTk2IDI5LjA1OTQgMTEuMDM5OCAyOS45OTk2IDEyLjE5OTcgMjkuOTk5NkgyNi45MDAxQzI4LjA1OTkgMjkuOTk5NiAyOS4wMDAxIDI5LjA1OTQgMjkuMDAwMSAyNy44OTk2VjEzLjE5OTJDMjkuMDAwMSAxMi4wMzkzIDI4LjA1OTkgMTEuMDk5MSAyNi45MDAxIDExLjA5OTFaIiBzdHJva2U9IiM4NDg0ODQiIHN0cm9rZS13aWR0aD0iMiIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+CjxwYXRoIGQ9Ik0yMy43NTA1IDguOTk5NTFWMTMuMTk5NiIgc3Ryb2tlPSIjODQ4NDg0IiBzdHJva2Utd2lkdGg9IjIiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPgo8cGF0aCBkPSJNMTUuMzQ5NiA4Ljk5OTUxVjEzLjE5OTYiIHN0cm9rZT0iIzg0ODQ4NCIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiLz4KPHBhdGggZD0iTTEwLjA5OTYgMTcuMzk5NEgyOS4wMDAxIiBzdHJva2U9IiM4NDg0ODQiIHN0cm9rZS13aWR0aD0iMiIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+CjwvZz4KPGRlZnM+CjxjbGlwUGF0aCBpZD0iY2xpcDBfMF8xIj4KPHJlY3Qgd2lkdGg9IjE5MjAiIGhlaWdodD0iMTM5NyIgZmlsbD0id2hpdGUiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0xMjY4IC04NDIpIi8+CjwvY2xpcFBhdGg+CjwvZGVmcz4KPC9zdmc+Cg==) 0px 50% no-repeat;background-size:cover;cursor:pointer}.core-date-picker-container .tl-date-picker-popup{position:absolute;right:0;overflow:hidden;z-index:var(--popup-z-index);width:var(--popup-width);height:var(--popup-height);background-color:var(--popup-bg-color);box-shadow:var(--decoration-box-shadow);border-radius:3px;padding:0 12px;display:none}.core-date-picker-container .tl-date-picker-popup.open{display:block}.core-date-picker-container .month-picker-session,.core-date-picker-container .year-picker-session{display:none}.core-date-picker-container .month-picker-session.active,.core-date-picker-container .year-picker-session.active{display:block}.core-date-picker-container .date-picker-session.d-none{display:none}.core-date-picker-container .navigator{width:100%;display:flex;align-items:center;justify-content:space-between}.core-date-picker-container .month-dropdown{font-weight:var(--font-bold);cursor:pointer}.core-date-picker-container .arrows{display:flex;align-items:center;justify-content:flex-end}.core-date-picker-container .arrows>div{margin:0 2px}.core-date-picker-container .arrows>div:before{font-family:feather;font-size:var(--arrow-font-size);cursor:pointer}.core-date-picker-container .arrows>div:hover:before{background-color:var(--hover-bg-color)}.core-date-picker-container .go-up:before{content:\"\\e914\"}.core-date-picker-container .go-down:before{content:\"\\e90c\"}.core-date-picker-container ul{padding:0;margin:0}.core-date-picker-container ul{height:calc((var(--popup-width) - var(--popup-x-padding) * 2) / 7)}.core-date-picker-container ul>li{user-select:none;-webkit-user-select:none;position:relative;display:inline-block;width:var(--cell-size);height:var(--cell-size);cursor:pointer}.core-date-picker-container .calendar-body-container{width:100%;height:calc((var(--popup-width) - var(--popup-x-padding) * 2) / 7 * 6);position:absolute;z-index:1;background-color:var(--popup-bg-color);overflow:hidden}.core-date-picker-container .calendar-body>ul>li>div:hover{background-color:var(--hover-bg-color)}.core-date-picker-container .calendar-body>ul>li>div.active{background-color:var(--active-bg-color)}.core-date-picker-container .calendar-body>ul>li>div.out-of-month{color:#d3d3d3}.core-date-picker-container .calendar-body>ul>li>div.out-of-range{-webkit-user-select:none;user-select:none;cursor:default;opacity:.2!important}.core-date-picker-container .calendar-body>ul>li>div.out-of-range:hover{background-color:var(--popup-bg-color)}.core-date-picker-container ul>li>div{width:100%;height:calc((var(--popup-width) - var(--popup-x-padding) * 2) / 7);display:flex;align-items:center;justify-content:center;border-radius:5px}.core-date-picker-container .t7{color:#07b7ee}.core-date-picker-container .cn{color:#ef2b58}.core-date-picker-container .weekday-header{font-weight:var(--font-bold)}.core-date-picker-container .calendar-body{position:absolute;bottom:0}.core-date-picker-container .tl-datepicker-direction:checked~.tl-date-picker-popup>.calendar-body-container>.calendar-body{top:0}.core-date-picker-container .slide-up{animation:slide-up .25s linear}.core-date-picker-container .slide-down{animation:slide-down .25s linear}.core-date-picker-container .footer-wrapper{width:calc(var(--popup-width) - var(--popup-x-padding) * 2);position:absolute;bottom:var(--popup-x-padding);left:var(--popup-x-padding);background-color:var(--popup-bg-color)!important}.core-date-picker-container .cdp-footer{width:100%;display:flex;align-items:center;justify-content:space-between}.core-date-picker-container .today,.core-date-picker-container .clear{width:30%;height:var(--cell-size);border-radius:calc(var(--cell-size) / 2);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.core-date-picker-container .today{background-color:#f37540}.core-date-picker-container .clear{background-color:brown}@keyframes slide-down{0%{top:calc(var(--scroll-distance) * -1)}to{top:0}}@keyframes slide-up{0%{top:0}to{top:calc(var(--scroll-distance) * -1)}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: CoreYearPickerComponent, selector: "core-year-picker", inputs: ["id", "default"], outputs: ["onChange"] }, { kind: "component", type: CoreMonthPickerComponent, selector: "core-month-picker", inputs: ["id", "lang", "monthObject$"], outputs: ["onChange", "onYearClick"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }] }); }
361
+ ], viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }, { propertyName: "input", first: true, predicate: ["input"], descendants: true }, { propertyName: "backward", first: true, predicate: ["backward"], descendants: true }, { propertyName: "calendarBody", first: true, predicate: ["calendarBody"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div #container class=\"core-date-picker-container\">\r\n <input type=\"checkbox\" [(ngModel)]=\"openState\">\r\n <input type=\"checkbox\" [(ngModel)]=\"monthPickerActive\">\r\n <input type=\"checkbox\" [(ngModel)]=\"yearPickerActive\">\r\n <input #backward type=\"checkbox\" class=\"tl-datepicker-direction\">\r\n <input #input type=\"text\" class=\"form-control\" [placeholder]=\"showPlaceholder ? 'dd/mm/yyyy' : ''\"\r\n maxlength=\"10\" [(ngModel)]=\"textValue\" [class.form-control-disabled]=\"disabled\" [disabled]=\"disabled\"><label class=\"icon\" (click)=\"toggleOpen()\"></label>\r\n <div class=\"tl-date-picker-popup\" [class.open]=\"openState\">\r\n <div class=\"date-picker-session\" [class.d-none]=\"monthPickerActive || yearPickerActive\">\r\n <div class=\"navigator\">\r\n <label class=\"month-dropdown\" (click)=\"toggleMonthPickerActive()\">{{ currentMonthText }} {{\r\n currentMonthObject$.value.year }}</label>\r\n <div class=\"arrows\">\r\n <div class=\"go-up\" (click)=\"goBackward()\"></div>\r\n <div class=\"go-down\" (click)=\"goForeward()\"></div>\r\n </div>\r\n </div>\r\n <div class=\"weekday-header\">\r\n <ul>\r\n <li *ngFor=\"let day of headerWeekdays; let i = index\" [class.t7]=\"i===5\" [class.cn]=\"i===6\">\r\n <div>{{ day }}</div>\r\n </li>\r\n </ul>\r\n </div>\r\n <div class=\"calendar-body-container\">\r\n <div #calendarBody class=\"calendar-body\" [class.slide-up]=\"direction===1\"\r\n [class.slide-down]=\"direction===-1\">\r\n <ul *ngFor=\"let week of data\">\r\n <li *ngFor=\"let item of week.items; let i = index\">\r\n <div [class.out-of-month]=\"!!!item.currentMonth\" [class.t7]=\"i===5\" [class.cn]=\"i===6\"\r\n [class.out-of-range]=\"!!rangeLimit && !!!((item.dateValue>=rangeLimit.minDate) && (rangeLimit.maxDate>=item.dateValue))\"\r\n [class.active]=\"item.dateValue.getFullYear()===pendingYear && item.dateValue.getMonth()===pendingMonthIndex && item.dateValue.getDate()===pendingDay\"\r\n (click)=\"onItemClick(item.dateValue)\">\r\n {{ item.date }}</div>\r\n </li>\r\n </ul>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"month-picker-session\" [class.active]=\"monthPickerActive\">\r\n <core-month-picker [lang]=\"lang\" [monthObject$]=\"currentMonthObject$\" (onChange)=\"onMonthObjectChange($event)\" (onYearClick)=\"onMonthPickerYearClick($event)\"></core-month-picker>\r\n </div>\r\n <div class=\"year-picker-session\" [class.active]=\"yearPickerActive\">\r\n <core-year-picker [lang]=\"lang\" (onChange)=\"onYearPicked($event)\"></core-year-picker>\r\n </div>\r\n <div class=\"footer-wrapper\">\r\n <div class=\"cdp-footer\">\r\n <div class=\"clear\" [class.opacity-0]=\"!!!textValue\" (click)=\"clear()\">{{ 'UI.CORE_DATE_PICKER_CLEAR' | translate: lang }}</div>\r\n <div class=\"digi-watch\"></div>\r\n <div class=\"today\" (click)=\"goToday()\">{{ 'UI.CORE_DATE_PICKER_TODAY' | translate: lang }}</div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".core-date-picker-container{--indicator-height: 39px;--popup-z-index: 99999999;--popup-width: 300px;--popup-height: 400px;--popup-bg-color: white;--popup-x-padding: 12px;--cell-size: 0px;--arrow-font-size: 28px;--font-size: 13px;--font-bold: 700;--font-light: 400;--hover-bg-color: #358ccb;--active-bg-color: cadetblue;--scroll-distance: calc(var(--cell-size) * 6);position:relative;font-weight:var(--font-light);font-size:var(--font-size)}.core-date-picker-container input[type=checkbox]{display:none}.core-date-picker-container label.icon{position:absolute;top:3px;right:3px}.core-date-picker-container label.icon:before{content:\"\";display:inline-block;aspect-ratio:1/1;width:var(--indicator-height);height:var(--indicator-height);border-radius:3px;background:url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzkiIGhlaWdodD0iMzkiIHZpZXdCb3g9IjAgMCAzOSAzOSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHJlY3Qgd2lkdGg9IjM5IiBoZWlnaHQ9IjM5IiBmaWxsPSIjRjVGNUY1Ii8+CjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMF8wXzEpIj4KPHJlY3Qgd2lkdGg9IjE5MjAiIGhlaWdodD0iMTM5NyIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTEyNjggLTg0MikiIGZpbGw9IiNGMUYxRjEiLz4KPHJlY3QgeD0iLTEyNjgiIHk9Ii04NDIiIHdpZHRoPSIxOTIwIiBoZWlnaHQ9IjEzOTciIGZpbGw9ImJsYWNrIiBmaWxsLW9wYWNpdHk9IjAuMyIvPgo8cmVjdCB4PSItNjgyIiB5PSItNjU4IiB3aWR0aD0iNzUwIiBoZWlnaHQ9Ijk5OSIgcng9IjEwIiBmaWxsPSJ3aGl0ZSIvPgo8cmVjdCB4PSItMjkwLjUiIHk9Ii0yLjUiIHdpZHRoPSIzMzIiIGhlaWdodD0iNDQiIHJ4PSI0LjUiIGZpbGw9IndoaXRlIiBzdHJva2U9IiNEMUQxRDEiLz4KPHJlY3Qgd2lkdGg9IjM5IiBoZWlnaHQ9IjM5IiByeD0iMyIgZmlsbD0iI0U5RTlFOSIvPgo8cGF0aCBkPSJNMjYuOTAwMSAxMS4wOTkxSDEyLjE5OTdDMTEuMDM5OCAxMS4wOTkxIDEwLjA5OTYgMTIuMDM5MyAxMC4wOTk2IDEzLjE5OTJWMjcuODk5NkMxMC4wOTk2IDI5LjA1OTQgMTEuMDM5OCAyOS45OTk2IDEyLjE5OTcgMjkuOTk5NkgyNi45MDAxQzI4LjA1OTkgMjkuOTk5NiAyOS4wMDAxIDI5LjA1OTQgMjkuMDAwMSAyNy44OTk2VjEzLjE5OTJDMjkuMDAwMSAxMi4wMzkzIDI4LjA1OTkgMTEuMDk5MSAyNi45MDAxIDExLjA5OTFaIiBzdHJva2U9IiM4NDg0ODQiIHN0cm9rZS13aWR0aD0iMiIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+CjxwYXRoIGQ9Ik0yMy43NTA1IDguOTk5NTFWMTMuMTk5NiIgc3Ryb2tlPSIjODQ4NDg0IiBzdHJva2Utd2lkdGg9IjIiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPgo8cGF0aCBkPSJNMTUuMzQ5NiA4Ljk5OTUxVjEzLjE5OTYiIHN0cm9rZT0iIzg0ODQ4NCIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiLz4KPHBhdGggZD0iTTEwLjA5OTYgMTcuMzk5NEgyOS4wMDAxIiBzdHJva2U9IiM4NDg0ODQiIHN0cm9rZS13aWR0aD0iMiIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+CjwvZz4KPGRlZnM+CjxjbGlwUGF0aCBpZD0iY2xpcDBfMF8xIj4KPHJlY3Qgd2lkdGg9IjE5MjAiIGhlaWdodD0iMTM5NyIgZmlsbD0id2hpdGUiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0xMjY4IC04NDIpIi8+CjwvY2xpcFBhdGg+CjwvZGVmcz4KPC9zdmc+Cg==) 0px 50% no-repeat;background-size:cover;cursor:pointer}.core-date-picker-container .tl-date-picker-popup{position:absolute;right:0;overflow:hidden;z-index:var(--popup-z-index);width:var(--popup-width);height:var(--popup-height);background-color:var(--popup-bg-color);box-shadow:var(--decoration-box-shadow);border-radius:3px;padding:0 12px;display:none}.core-date-picker-container .tl-date-picker-popup.open{display:block}.core-date-picker-container .month-picker-session,.core-date-picker-container .year-picker-session{display:none}.core-date-picker-container .month-picker-session.active,.core-date-picker-container .year-picker-session.active{display:block}.core-date-picker-container .date-picker-session.d-none{display:none}.core-date-picker-container .navigator{width:100%;display:flex;align-items:center;justify-content:space-between}.core-date-picker-container .month-dropdown{font-weight:var(--font-bold);cursor:pointer}.core-date-picker-container .arrows{display:flex;align-items:center;justify-content:flex-end}.core-date-picker-container .arrows>div{margin:0 2px}.core-date-picker-container .arrows>div:before{font-family:feather;font-size:var(--arrow-font-size);cursor:pointer}.core-date-picker-container .arrows>div:hover:before{background-color:var(--hover-bg-color)}.core-date-picker-container .go-up:before{content:\"\\e914\"}.core-date-picker-container .go-down:before{content:\"\\e90c\"}.core-date-picker-container ul{padding:0;margin:0}.core-date-picker-container ul{height:calc((var(--popup-width) - var(--popup-x-padding) * 2) / 7)}.core-date-picker-container ul>li{user-select:none;-webkit-user-select:none;position:relative;display:inline-block;width:var(--cell-size);height:var(--cell-size);cursor:pointer}.core-date-picker-container .calendar-body-container{width:100%;height:calc((var(--popup-width) - var(--popup-x-padding) * 2) / 7 * 6);position:absolute;z-index:1;background-color:var(--popup-bg-color);overflow:hidden}.core-date-picker-container .calendar-body>ul>li>div:hover{background-color:var(--hover-bg-color)}.core-date-picker-container .calendar-body>ul>li>div.active{background-color:var(--active-bg-color)}.core-date-picker-container .calendar-body>ul>li>div.out-of-month{color:#d3d3d3}.core-date-picker-container .calendar-body>ul>li>div.out-of-range{-webkit-user-select:none;user-select:none;cursor:default;opacity:.2!important}.core-date-picker-container .calendar-body>ul>li>div.out-of-range:hover{background-color:var(--popup-bg-color)}.core-date-picker-container ul>li>div{width:100%;height:calc((var(--popup-width) - var(--popup-x-padding) * 2) / 7);display:flex;align-items:center;justify-content:center;border-radius:5px}.core-date-picker-container .t7{color:#07b7ee}.core-date-picker-container .cn{color:#ef2b58}.core-date-picker-container .weekday-header{font-weight:var(--font-bold)}.core-date-picker-container .calendar-body{position:absolute;bottom:0}.core-date-picker-container .tl-datepicker-direction:checked~.tl-date-picker-popup>.calendar-body-container>.calendar-body{top:0}.core-date-picker-container .slide-up{animation:slide-up .25s linear}.core-date-picker-container .slide-down{animation:slide-down .25s linear}.core-date-picker-container .footer-wrapper{width:calc(var(--popup-width) - var(--popup-x-padding) * 2);position:absolute;bottom:var(--popup-x-padding);left:var(--popup-x-padding);background-color:var(--popup-bg-color)!important}.core-date-picker-container .cdp-footer{width:100%;display:flex;align-items:center;justify-content:space-between}.core-date-picker-container .today,.core-date-picker-container .clear{width:30%;height:var(--cell-size);border-radius:calc(var(--cell-size) / 2);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.core-date-picker-container .today{background-color:#f37540}.core-date-picker-container .clear{background-color:brown}@keyframes slide-down{0%{top:calc(var(--scroll-distance) * -1)}to{top:0}}@keyframes slide-up{0%{top:0}to{top:calc(var(--scroll-distance) * -1)}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: CoreYearPickerComponent, selector: "core-year-picker", inputs: ["id", "default"], outputs: ["onChange"] }, { kind: "component", type: CoreMonthPickerComponent, selector: "core-month-picker", inputs: ["id", "lang", "monthObject$"], outputs: ["onChange", "onYearClick"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }] }); }
355
362
  }
356
363
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreDatePickerComponent, decorators: [{
357
364
  type: Component,
@@ -368,7 +375,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
368
375
  useExisting: CoreDatePickerComponent
369
376
  }
370
377
  ], template: "<div #container class=\"core-date-picker-container\">\r\n <input type=\"checkbox\" [(ngModel)]=\"openState\">\r\n <input type=\"checkbox\" [(ngModel)]=\"monthPickerActive\">\r\n <input type=\"checkbox\" [(ngModel)]=\"yearPickerActive\">\r\n <input #backward type=\"checkbox\" class=\"tl-datepicker-direction\">\r\n <input #input type=\"text\" class=\"form-control\" [placeholder]=\"showPlaceholder ? 'dd/mm/yyyy' : ''\"\r\n maxlength=\"10\" [(ngModel)]=\"textValue\" [class.form-control-disabled]=\"disabled\" [disabled]=\"disabled\"><label class=\"icon\" (click)=\"toggleOpen()\"></label>\r\n <div class=\"tl-date-picker-popup\" [class.open]=\"openState\">\r\n <div class=\"date-picker-session\" [class.d-none]=\"monthPickerActive || yearPickerActive\">\r\n <div class=\"navigator\">\r\n <label class=\"month-dropdown\" (click)=\"toggleMonthPickerActive()\">{{ currentMonthText }} {{\r\n currentMonthObject$.value.year }}</label>\r\n <div class=\"arrows\">\r\n <div class=\"go-up\" (click)=\"goBackward()\"></div>\r\n <div class=\"go-down\" (click)=\"goForeward()\"></div>\r\n </div>\r\n </div>\r\n <div class=\"weekday-header\">\r\n <ul>\r\n <li *ngFor=\"let day of headerWeekdays; let i = index\" [class.t7]=\"i===5\" [class.cn]=\"i===6\">\r\n <div>{{ day }}</div>\r\n </li>\r\n </ul>\r\n </div>\r\n <div class=\"calendar-body-container\">\r\n <div #calendarBody class=\"calendar-body\" [class.slide-up]=\"direction===1\"\r\n [class.slide-down]=\"direction===-1\">\r\n <ul *ngFor=\"let week of data\">\r\n <li *ngFor=\"let item of week.items; let i = index\">\r\n <div [class.out-of-month]=\"!!!item.currentMonth\" [class.t7]=\"i===5\" [class.cn]=\"i===6\"\r\n [class.out-of-range]=\"!!rangeLimit && !!!((item.dateValue>=rangeLimit.minDate) && (rangeLimit.maxDate>=item.dateValue))\"\r\n [class.active]=\"item.dateValue.getFullYear()===pendingYear && item.dateValue.getMonth()===pendingMonthIndex && item.dateValue.getDate()===pendingDay\"\r\n (click)=\"onItemClick(item.dateValue)\">\r\n {{ item.date }}</div>\r\n </li>\r\n </ul>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"month-picker-session\" [class.active]=\"monthPickerActive\">\r\n <core-month-picker [lang]=\"lang\" [monthObject$]=\"currentMonthObject$\" (onChange)=\"onMonthObjectChange($event)\" (onYearClick)=\"onMonthPickerYearClick($event)\"></core-month-picker>\r\n </div>\r\n <div class=\"year-picker-session\" [class.active]=\"yearPickerActive\">\r\n <core-year-picker [lang]=\"lang\" (onChange)=\"onYearPicked($event)\"></core-year-picker>\r\n </div>\r\n <div class=\"footer-wrapper\">\r\n <div class=\"cdp-footer\">\r\n <div class=\"clear\" [class.opacity-0]=\"!!!textValue\" (click)=\"clear()\">{{ 'UI.CORE_DATE_PICKER_CLEAR' | translate: lang }}</div>\r\n <div class=\"digi-watch\"></div>\r\n <div class=\"today\" (click)=\"goToday()\">{{ 'UI.CORE_DATE_PICKER_TODAY' | translate: lang }}</div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".core-date-picker-container{--indicator-height: 39px;--popup-z-index: 99999999;--popup-width: 300px;--popup-height: 400px;--popup-bg-color: white;--popup-x-padding: 12px;--cell-size: 0px;--arrow-font-size: 28px;--font-size: 13px;--font-bold: 700;--font-light: 400;--hover-bg-color: #358ccb;--active-bg-color: cadetblue;--scroll-distance: calc(var(--cell-size) * 6);position:relative;font-weight:var(--font-light);font-size:var(--font-size)}.core-date-picker-container input[type=checkbox]{display:none}.core-date-picker-container label.icon{position:absolute;top:3px;right:3px}.core-date-picker-container label.icon:before{content:\"\";display:inline-block;aspect-ratio:1/1;width:var(--indicator-height);height:var(--indicator-height);border-radius:3px;background:url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzkiIGhlaWdodD0iMzkiIHZpZXdCb3g9IjAgMCAzOSAzOSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHJlY3Qgd2lkdGg9IjM5IiBoZWlnaHQ9IjM5IiBmaWxsPSIjRjVGNUY1Ii8+CjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMF8wXzEpIj4KPHJlY3Qgd2lkdGg9IjE5MjAiIGhlaWdodD0iMTM5NyIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTEyNjggLTg0MikiIGZpbGw9IiNGMUYxRjEiLz4KPHJlY3QgeD0iLTEyNjgiIHk9Ii04NDIiIHdpZHRoPSIxOTIwIiBoZWlnaHQ9IjEzOTciIGZpbGw9ImJsYWNrIiBmaWxsLW9wYWNpdHk9IjAuMyIvPgo8cmVjdCB4PSItNjgyIiB5PSItNjU4IiB3aWR0aD0iNzUwIiBoZWlnaHQ9Ijk5OSIgcng9IjEwIiBmaWxsPSJ3aGl0ZSIvPgo8cmVjdCB4PSItMjkwLjUiIHk9Ii0yLjUiIHdpZHRoPSIzMzIiIGhlaWdodD0iNDQiIHJ4PSI0LjUiIGZpbGw9IndoaXRlIiBzdHJva2U9IiNEMUQxRDEiLz4KPHJlY3Qgd2lkdGg9IjM5IiBoZWlnaHQ9IjM5IiByeD0iMyIgZmlsbD0iI0U5RTlFOSIvPgo8cGF0aCBkPSJNMjYuOTAwMSAxMS4wOTkxSDEyLjE5OTdDMTEuMDM5OCAxMS4wOTkxIDEwLjA5OTYgMTIuMDM5MyAxMC4wOTk2IDEzLjE5OTJWMjcuODk5NkMxMC4wOTk2IDI5LjA1OTQgMTEuMDM5OCAyOS45OTk2IDEyLjE5OTcgMjkuOTk5NkgyNi45MDAxQzI4LjA1OTkgMjkuOTk5NiAyOS4wMDAxIDI5LjA1OTQgMjkuMDAwMSAyNy44OTk2VjEzLjE5OTJDMjkuMDAwMSAxMi4wMzkzIDI4LjA1OTkgMTEuMDk5MSAyNi45MDAxIDExLjA5OTFaIiBzdHJva2U9IiM4NDg0ODQiIHN0cm9rZS13aWR0aD0iMiIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+CjxwYXRoIGQ9Ik0yMy43NTA1IDguOTk5NTFWMTMuMTk5NiIgc3Ryb2tlPSIjODQ4NDg0IiBzdHJva2Utd2lkdGg9IjIiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPgo8cGF0aCBkPSJNMTUuMzQ5NiA4Ljk5OTUxVjEzLjE5OTYiIHN0cm9rZT0iIzg0ODQ4NCIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiLz4KPHBhdGggZD0iTTEwLjA5OTYgMTcuMzk5NEgyOS4wMDAxIiBzdHJva2U9IiM4NDg0ODQiIHN0cm9rZS13aWR0aD0iMiIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+CjwvZz4KPGRlZnM+CjxjbGlwUGF0aCBpZD0iY2xpcDBfMF8xIj4KPHJlY3Qgd2lkdGg9IjE5MjAiIGhlaWdodD0iMTM5NyIgZmlsbD0id2hpdGUiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0xMjY4IC04NDIpIi8+CjwvY2xpcFBhdGg+CjwvZGVmcz4KPC9zdmc+Cg==) 0px 50% no-repeat;background-size:cover;cursor:pointer}.core-date-picker-container .tl-date-picker-popup{position:absolute;right:0;overflow:hidden;z-index:var(--popup-z-index);width:var(--popup-width);height:var(--popup-height);background-color:var(--popup-bg-color);box-shadow:var(--decoration-box-shadow);border-radius:3px;padding:0 12px;display:none}.core-date-picker-container .tl-date-picker-popup.open{display:block}.core-date-picker-container .month-picker-session,.core-date-picker-container .year-picker-session{display:none}.core-date-picker-container .month-picker-session.active,.core-date-picker-container .year-picker-session.active{display:block}.core-date-picker-container .date-picker-session.d-none{display:none}.core-date-picker-container .navigator{width:100%;display:flex;align-items:center;justify-content:space-between}.core-date-picker-container .month-dropdown{font-weight:var(--font-bold);cursor:pointer}.core-date-picker-container .arrows{display:flex;align-items:center;justify-content:flex-end}.core-date-picker-container .arrows>div{margin:0 2px}.core-date-picker-container .arrows>div:before{font-family:feather;font-size:var(--arrow-font-size);cursor:pointer}.core-date-picker-container .arrows>div:hover:before{background-color:var(--hover-bg-color)}.core-date-picker-container .go-up:before{content:\"\\e914\"}.core-date-picker-container .go-down:before{content:\"\\e90c\"}.core-date-picker-container ul{padding:0;margin:0}.core-date-picker-container ul{height:calc((var(--popup-width) - var(--popup-x-padding) * 2) / 7)}.core-date-picker-container ul>li{user-select:none;-webkit-user-select:none;position:relative;display:inline-block;width:var(--cell-size);height:var(--cell-size);cursor:pointer}.core-date-picker-container .calendar-body-container{width:100%;height:calc((var(--popup-width) - var(--popup-x-padding) * 2) / 7 * 6);position:absolute;z-index:1;background-color:var(--popup-bg-color);overflow:hidden}.core-date-picker-container .calendar-body>ul>li>div:hover{background-color:var(--hover-bg-color)}.core-date-picker-container .calendar-body>ul>li>div.active{background-color:var(--active-bg-color)}.core-date-picker-container .calendar-body>ul>li>div.out-of-month{color:#d3d3d3}.core-date-picker-container .calendar-body>ul>li>div.out-of-range{-webkit-user-select:none;user-select:none;cursor:default;opacity:.2!important}.core-date-picker-container .calendar-body>ul>li>div.out-of-range:hover{background-color:var(--popup-bg-color)}.core-date-picker-container ul>li>div{width:100%;height:calc((var(--popup-width) - var(--popup-x-padding) * 2) / 7);display:flex;align-items:center;justify-content:center;border-radius:5px}.core-date-picker-container .t7{color:#07b7ee}.core-date-picker-container .cn{color:#ef2b58}.core-date-picker-container .weekday-header{font-weight:var(--font-bold)}.core-date-picker-container .calendar-body{position:absolute;bottom:0}.core-date-picker-container .tl-datepicker-direction:checked~.tl-date-picker-popup>.calendar-body-container>.calendar-body{top:0}.core-date-picker-container .slide-up{animation:slide-up .25s linear}.core-date-picker-container .slide-down{animation:slide-down .25s linear}.core-date-picker-container .footer-wrapper{width:calc(var(--popup-width) - var(--popup-x-padding) * 2);position:absolute;bottom:var(--popup-x-padding);left:var(--popup-x-padding);background-color:var(--popup-bg-color)!important}.core-date-picker-container .cdp-footer{width:100%;display:flex;align-items:center;justify-content:space-between}.core-date-picker-container .today,.core-date-picker-container .clear{width:30%;height:var(--cell-size);border-radius:calc(var(--cell-size) / 2);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.core-date-picker-container .today{background-color:#f37540}.core-date-picker-container .clear{background-color:brown}@keyframes slide-down{0%{top:calc(var(--scroll-distance) * -1)}to{top:0}}@keyframes slide-up{0%{top:0}to{top:calc(var(--scroll-distance) * -1)}}\n"] }]
371
- }], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i1.DomService }, { type: i2.CoreDatetimeService }, { type: i3.MultiLanguageService }], propDecorators: { enableTimeZoneConverter: [{
378
+ }], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i1.DomService }, { type: i2.CoreDatetimeService }, { type: i3.MultiLanguageService }, { type: i4.AlertService }], propDecorators: { enableTimeZoneConverter: [{
372
379
  type: Input
373
380
  }], showPlaceholder: [{
374
381
  type: Input
@@ -395,4 +402,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
395
402
  type: ViewChild,
396
403
  args: ['calendarBody']
397
404
  }] } });
398
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-date-picker.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-date-picker/core-date-picker/core-date-picker.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-date-picker/core-date-picker/core-date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, OnInit, OnDestroy, AfterViewInit, ViewChild, Input, Renderer2 } from '@angular/core';\r\nimport { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { BehaviorSubject, Observable, Subscription, distinctUntilChanged, fromEvent } from 'rxjs';\r\nimport { DomService } from '../../services/dom.service';\r\nimport { CoreFormControlBaseComponent } from '../../core-form-control-base/core-form-control-base.component';\r\nimport { CoreDatetimeService, IDataRow, IMonthIdentity } from '../../services/core-datetime.service';\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CoreYearPickerComponent } from '../../core-year-picker/core-year-picker/core-year-picker.component';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { CoreMonthPickerComponent } from '../../core-month-picker/core-month-picker/core-month-picker.component';\r\n\r\n\r\nexport interface ICoreDatePickerRange {\r\n  minDate: Date;\r\n  maxDate: Date;\r\n}\r\n\r\n@Component({\r\n  selector: 'core-date-picker',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    CoreYearPickerComponent,\r\n    CoreMonthPickerComponent,\r\n    TranslatePipe,\r\n  ],\r\n  templateUrl: './core-date-picker.component.html',\r\n  styleUrls: ['./core-date-picker.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreDatePickerComponent\r\n    }\r\n  ]\r\n})\r\n/*\r\n  this component renders its main part and popup part\r\n  the main part deals with user input from physical keyboard or touch keyboard\r\n  the popup part consists of 1) navigator 2) header 3) calendar body container 4) calendar body\r\n  the most important part of them is:\r\n    4) calendar body:\r\n      due variations the calendar body may reach to 6 rows of week day sub-array\r\n    - for visual, logic and coding simplicity I will always render all the 6 rows\r\n    so calendar body dimension stays unchanged\r\n  \r\n*/\r\nexport class CoreDatePickerComponent extends CoreFormControlBaseComponent implements OnInit, AfterViewInit, OnDestroy {\r\n\r\n  @Input() enableTimeZoneConverter!: boolean;\r\n  @Input() showPlaceholder: boolean = false;\r\n  @Input() popupWidth: number = 300;\r\n  @Input() popupXPadding: number = 12;\r\n  @Input() rangeLimit!: ICoreDatePickerRange;\r\n  @Input() override readonly!: boolean;\r\n  @Input() override disabled!: boolean;\r\n\r\n\r\n  listenerFn!: () => void;\r\n\r\n  lang!: string;\r\n  subscriptions: Subscription[] = [];\r\n  openState: boolean = false;\r\n  monthPickerActive: boolean = false;\r\n  yearPickerActive: boolean = false;\r\n\r\n  cellSize: number = (this.popupWidth - this.popupXPadding * 2) / 7;\r\n\r\n  override value!: Date | null;\r\n  pendingYear!: number;\r\n  pendingMonthIndex!: number;\r\n  pendingDay: number = this.value?.getDate()!;\r\n\r\n  currentMonthObject$!: BehaviorSubject<IMonthIdentity>;\r\n  newDate!: Date;\r\n\r\n  currentMonthText!: string;\r\n  currentHours!: number;\r\n  currentMinutes!: number;\r\n  currentSeconds!: number;\r\n  currentMilliseconds!: number;\r\n\r\n  data!: IDataRow[];\r\n  headerWeekdays!: string[];\r\n  direction: number = 1; // startup direction 1 | -1\r\n\r\n  textValue: string = '';\r\n\r\n  @ViewChild('container') container!: ElementRef;\r\n  @ViewChild('input') input!: ElementRef;\r\n  @ViewChild('backward') backward!: ElementRef;\r\n  @ViewChild('calendarBody') calendarBody!: ElementRef;\r\n\r\n  inputStream$!: Observable<any>;\r\n  lastText!: string;\r\n\r\n  constructor(\r\n    private readonly renderer: Renderer2,\r\n    private readonly domService: DomService,\r\n    private readonly coreDatetimeService: CoreDatetimeService,\r\n    private mls: MultiLanguageService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n    this.newDate = !!this.rangeLimit ? this.rangeLimit.minDate : new Date();\r\n    this.currentMonthObject$ = new BehaviorSubject<IMonthIdentity>({\r\n      year: this.value?.getFullYear() || this.newDate.getFullYear(),\r\n      monthIndex: this.value?.getMonth() || this.newDate.getMonth()\r\n    });\r\n\r\n    if (!!this.disabled) this.readonly = true;\r\n\r\n    if (!!!this.value) {\r\n      this.value = this.newDate;\r\n      this.lastText = this.coreDatetimeService.dateToVnString(this.value)\r\n    }\r\n      \r\n    this.pendingYear = this.value.getFullYear();\r\n    this.pendingMonthIndex = this.value.getMonth();\r\n    this.pendingDay = this.value.getDate();\r\n    this.currentHours = this.value.getHours();\r\n    this.currentMinutes = this.value.getMinutes();\r\n    this.currentSeconds = this.value.getSeconds();\r\n    this.currentMilliseconds = this.value.getMilliseconds();\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(x => this.lang = x)\r\n    )\r\n\r\n    /*\r\n    if (!!!this.id) {\r\n      console.error(`\r\n      within a page, tanleica-date-picker needs an unique property id value to work correctly\r\n      for example: <tanleica-date-picker id=\"startDate\" formControlName=\"startDate\"></tanleica-date-picker>\r\n      `)\r\n    }\r\n    */\r\n    this.headerWeekdays = this.coreDatetimeService.getShortWeekdays(this.lang);\r\n  }\r\n\r\n  /*\r\n    trigger animation by reflow the DOM\r\n  */\r\n  triggerReflow() {\r\n    const el = this.calendarBody.nativeElement;\r\n    //DOM manipulation\r\n    if (this.direction === 1) {\r\n      el.classList.remove(\"slide-up\");\r\n    } else {\r\n      el.classList.remove(\"slide-down\");\r\n    }\r\n    el.offsetHeight;  /* trigger reflow (alternative: el.offsetWidth) */\r\n    if (this.direction === 1) {\r\n      setTimeout(() => el.classList.add(\"slide-up\"), 0); // pass the callback to Callback queue through WebAPIs, so it will be executed after DOM manipulation ends\r\n    } else {\r\n      setTimeout(() => el.classList.add(\"slide-down\"), 0); // pass the callback to Callback queue through WebAPIs, so it will be executed after DOM manipulation ends\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n\r\n    /*\r\n      This events get called by all clicks on the page\r\n    */\r\n    this.listenerFn = this.renderer.listen('window', 'click', (e: Event) => {\r\n      /*\r\n        handle click outside\r\n      */\r\n      if (this.container && !!!this.container.nativeElement.contains(e.target)) {\r\n        this.openState = false;\r\n      }\r\n    })\r\n\r\n    const maxZIndex = this.domService.getMaxZIndex();\r\n\r\n    this.container.nativeElement.style.setProperty('--indicator-height', (this.input.nativeElement.getBoundingClientRect().height - 6) + 'px')\r\n    this.container.nativeElement.style.setProperty('--popup-z-index', maxZIndex);\r\n    this.container.nativeElement.style.setProperty('--cell-size', this.cellSize + 'px')\r\n\r\n    this.currentMonthObject$.pipe(\r\n      distinctUntilChanged()\r\n    ).subscribe(value => {\r\n      setTimeout(() => {\r\n        this.currentMonthText = this.coreDatetimeService.getMonthText(this.lang, value.monthIndex);\r\n        console.log(\"Rebuilding....\")\r\n        this.buildBody(value.year, value.monthIndex);\r\n        this.triggerReflow();\r\n      }, 0)\r\n    })\r\n\r\n    this.inputStream$ = fromEvent(this.input.nativeElement, 'input');\r\n    this.inputStream$.subscribe(event => {\r\n\r\n      if ( event.inputType !== 'deleteContentBackward' \r\n        && '#0#1#2#3#4#5#6#7#8#9#Backspace#Delete'.indexOf('#' + event.data) < 0) \r\n      {\r\n        event.target.value = this.lastText;\r\n        this.markAsTouched();\r\n        this.onChange(null);\r\n        return;\r\n      } else {\r\n        this.lastText = event.target.value\r\n      }\r\n\r\n      var v = event.target.value;\r\n      if (v.match(/^\\d{2}$/) !== null) {\r\n        event.target.value = v + '/';\r\n        this.textValue = v + '/';\r\n      } else if (v.match(/^\\d{2}\\/\\d{2}$/) !== null) {\r\n        event.target.value = v + '/';\r\n        this.textValue = v + '/';\r\n      } else {\r\n        this.textValue = v;\r\n      }\r\n\r\n      if (this.textValue.length === 10) {\r\n        const digits = this.textValue.split('/');\r\n        const y = Number(digits[2]);\r\n        const m = Number(digits[1]) - 1;\r\n        const d = Number(digits[0]);\r\n\r\n        if (y <= 0 || m < 0 || m > 11 || d < 1 || d > 31) {\r\n          event.target.value = '';\r\n          this.textValue = '';\r\n          this.markAsTouched();\r\n          this.onChange(null);\r\n          return;\r\n        }\r\n\r\n        const now = new Date();\r\n        const hr = now.getHours();\r\n        const mn = now.getMinutes();\r\n        const sd = now.getSeconds();\r\n        const ms = now.getMilliseconds();\r\n\r\n        const date = new Date(Number(digits[2]), Number(digits[1]) - 1, Number(digits[0]), hr, mn, sd, ms);\r\n        event.target.value = this.coreDatetimeService.dateToVnString(date);\r\n        this.markAsTouched();\r\n        this.onChange(date);\r\n\r\n      }\r\n    })\r\n\r\n  }\r\n\r\n  override writeValue(obj: Date | null): void {\r\n    console.log(\"UTC Date \", obj);\r\n\r\n    const updateProperties = (value: Date) => {\r\n      console.log(\"After convert to Local Date \", value);\r\n      this.value = value;\r\n      this.lastText = this.coreDatetimeService.dateToVnString(value)\r\n      this.textValue = this.coreDatetimeService.dateToVnString(value);\r\n      this.currentMonthObject$.next({\r\n        year: value.getFullYear(),\r\n        monthIndex: value.getMonth()\r\n      })\r\n      this.currentHours = value.getHours();\r\n      this.currentMinutes = value.getMinutes();\r\n      this.currentSeconds = value.getSeconds();\r\n      this.currentMilliseconds = value.getMilliseconds();\r\n\r\n      this.currentMonthText = this.coreDatetimeService.getMonthText(this.lang, this.currentMonthObject$.value.monthIndex);\r\n      this.pendingYear = value.getFullYear();\r\n      this.pendingMonthIndex = value.getMonth();\r\n      this.pendingDay = value.getDate();\r\n    }\r\n\r\n    if (obj === null || obj === undefined) {\r\n      let now = new Date();\r\n      if (!!this.rangeLimit) {\r\n        now = this.rangeLimit.minDate;\r\n      }\r\n      this.textValue = '';\r\n      this.currentMonthObject$.next({\r\n        year: now.getFullYear(),\r\n        monthIndex: now.getMonth()\r\n      })\r\n      this.currentHours = now.getHours();\r\n      this.currentMinutes = now.getMinutes();\r\n      this.currentSeconds = now.getSeconds();\r\n      this.currentMilliseconds = now.getMilliseconds();\r\n      this.currentMonthText = this.coreDatetimeService.getMonthText(this.lang, this.currentMonthObject$.value.monthIndex);\r\n    } else {\r\n      /* Convert UTC date to local date */\r\n      const originalDate: Date = new Date(obj);\r\n      const offset = (new Date()).getTimezoneOffset();\r\n      const dateValue = new Date(originalDate.getTime() - offset * 60000);\r\n      /*--------------------------------------*/\r\n      if (typeof obj!.getFullYear === 'function') {\r\n        updateProperties(dateValue);\r\n      } else if (typeof obj === 'string') {\r\n        const isDate = this.coreDatetimeService.isDateString(obj);\r\n        if (isDate) {\r\n          //const _obj = new Date(obj); // convert string to date \r\n          updateProperties(dateValue);\r\n        } else {\r\n          console.error(\"Invalid date input: \", obj);\r\n        }\r\n\r\n      } else {\r\n        console.error(\"Invalid date input: \", obj);\r\n      }\r\n    }\r\n  }\r\n\r\n  onItemClick(date: Date) {\r\n\r\n    if (this.readonly) return;\r\n\r\n    if (!!this.rangeLimit) {\r\n      if (date < this.rangeLimit.minDate || date > this.rangeLimit.maxDate) return;\r\n    }\r\n\r\n    const now = new Date();\r\n    const h = now.getHours();\r\n    const m = now.getMinutes();\r\n    const s = now.getSeconds();\r\n    const ms = now.getMilliseconds();\r\n    date.setHours(h);\r\n    date.setMinutes(m);\r\n    date.setSeconds(s);\r\n    date.setMilliseconds(ms);\r\n    this.textValue = this.coreDatetimeService.dateToVnString(date);\r\n\r\n    this.pendingYear = date.getFullYear();\r\n    this.pendingMonthIndex = date.getMonth();\r\n    this.pendingDay = date.getDate();\r\n\r\n    this.markAsTouched();\r\n    \r\n    this.onChange(date);\r\n    this.openState = false;\r\n  }\r\n\r\n  goToday() {\r\n    const today = new Date();\r\n    if (!!this.rangeLimit) {\r\n      if (today < this.rangeLimit.minDate || today > this.rangeLimit.maxDate) return;\r\n    }\r\n    this.textValue = this.coreDatetimeService.dateToVnString(today);\r\n    this.markAsTouched();\r\n    this.onChange(today);\r\n    this.openState = false;\r\n  }\r\n\r\n  clear() {\r\n    this.textValue = '';\r\n    this.value = null;\r\n    this.lastText = '';\r\n    this.markAsTouched();\r\n    this.onChange(null);\r\n    this.openState = false;\r\n  }\r\n\r\n  goBackward() {\r\n    this.direction = -1;\r\n    this.backward.nativeElement.checked = true;\r\n    if (this.currentMonthObject$.value.monthIndex === 0) {\r\n      this.currentMonthObject$.next({\r\n        year: this.currentMonthObject$.value.year - 1,\r\n        monthIndex: 11\r\n      });\r\n      this.currentMonthText = this.coreDatetimeService.getMonthText(this.lang, 11);\r\n    } else {\r\n      this.currentMonthObject$.next({\r\n        year: this.currentMonthObject$.value.year,\r\n        monthIndex: this.currentMonthObject$.value.monthIndex - 1\r\n      });\r\n\r\n      this.currentMonthText = this.coreDatetimeService.getMonthText(this.lang, this.currentMonthObject$.value.monthIndex);\r\n    }\r\n  }\r\n\r\n  goForeward() {\r\n    this.direction = 1;\r\n    this.backward.nativeElement.checked = false;\r\n    this\r\n    if (this.currentMonthObject$.value.monthIndex === 11) {\r\n      this.currentMonthObject$.next({\r\n        year: this.currentMonthObject$.value.year + 1,\r\n        monthIndex: 0\r\n      });\r\n      this.currentMonthText = this.coreDatetimeService.getMonthText(this.lang, 0);\r\n    } else {\r\n      this.currentMonthObject$.next({\r\n        year: this.currentMonthObject$.value.year,\r\n        monthIndex: this.currentMonthObject$.value.monthIndex + 1\r\n      });\r\n      this.currentMonthText = this.coreDatetimeService.getMonthText(this.lang, this.currentMonthObject$.value.monthIndex);\r\n    }\r\n  }\r\n\r\n  /* Probably the most important function */\r\n  buildBody(year: number, monthIndex: number) {\r\n    const body = this.coreDatetimeService.getCalendarBody(year, monthIndex, this.direction);\r\n    this.data = body.rows;\r\n    this.container.nativeElement.style.setProperty('--scroll-distance', (body.rows.length - 6) * this.cellSize + 'px');\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.listenerFn) this.listenerFn();\r\n    this.subscriptions.map(x => x?.unsubscribe())\r\n  }\r\n\r\n  toggleOpen() {\r\n    if (!!this.readonly) return\r\n    if (!!this.disabled) return\r\n    this.openState = !this.openState;\r\n  }\r\n\r\n  toggleMonthPickerActive() {\r\n    this.monthPickerActive = !this.monthPickerActive;\r\n  }\r\n\r\n  onMonthObjectChange(args: IMonthIdentity) {\r\n    this.currentMonthObject$.next({\r\n      year: args.year,\r\n      monthIndex: args.monthIndex\r\n    })\r\n    this.monthPickerActive = false;\r\n  }\r\n\r\n  onMonthPickerYearClick(e: number) {\r\n    this.monthPickerActive = false;\r\n    this.yearPickerActive = true;\r\n  }\r\n\r\n  onYearPicked(e: number) {\r\n    this.currentMonthObject$.next({\r\n      year: e,\r\n      monthIndex: this.currentMonthObject$.value.monthIndex\r\n    });\r\n    this.yearPickerActive = false;\r\n    this.monthPickerActive = true;\r\n  }\r\n\r\n}\r\n","<div #container class=\"core-date-picker-container\">\r\n    <input type=\"checkbox\" [(ngModel)]=\"openState\">\r\n    <input type=\"checkbox\" [(ngModel)]=\"monthPickerActive\">\r\n    <input type=\"checkbox\" [(ngModel)]=\"yearPickerActive\">\r\n    <input #backward type=\"checkbox\" class=\"tl-datepicker-direction\">\r\n    <input #input type=\"text\" class=\"form-control\" [placeholder]=\"showPlaceholder ? 'dd/mm/yyyy' : ''\"\r\n        maxlength=\"10\" [(ngModel)]=\"textValue\" [class.form-control-disabled]=\"disabled\" [disabled]=\"disabled\"><label class=\"icon\" (click)=\"toggleOpen()\"></label>\r\n    <div class=\"tl-date-picker-popup\" [class.open]=\"openState\">\r\n        <div class=\"date-picker-session\" [class.d-none]=\"monthPickerActive || yearPickerActive\">\r\n            <div class=\"navigator\">\r\n                <label class=\"month-dropdown\" (click)=\"toggleMonthPickerActive()\">{{ currentMonthText }} {{\r\n                    currentMonthObject$.value.year }}</label>\r\n                <div class=\"arrows\">\r\n                    <div class=\"go-up\" (click)=\"goBackward()\"></div>\r\n                    <div class=\"go-down\" (click)=\"goForeward()\"></div>\r\n                </div>\r\n            </div>\r\n            <div class=\"weekday-header\">\r\n                <ul>\r\n                    <li *ngFor=\"let day of headerWeekdays; let i = index\" [class.t7]=\"i===5\" [class.cn]=\"i===6\">\r\n                        <div>{{ day }}</div>\r\n                    </li>\r\n                </ul>\r\n            </div>\r\n            <div class=\"calendar-body-container\">\r\n                <div #calendarBody class=\"calendar-body\" [class.slide-up]=\"direction===1\"\r\n                    [class.slide-down]=\"direction===-1\">\r\n                    <ul *ngFor=\"let week of data\">\r\n                        <li *ngFor=\"let item of week.items; let i = index\">\r\n                            <div [class.out-of-month]=\"!!!item.currentMonth\" [class.t7]=\"i===5\" [class.cn]=\"i===6\"\r\n                                [class.out-of-range]=\"!!rangeLimit && !!!((item.dateValue>=rangeLimit.minDate) && (rangeLimit.maxDate>=item.dateValue))\"\r\n                                [class.active]=\"item.dateValue.getFullYear()===pendingYear && item.dateValue.getMonth()===pendingMonthIndex && item.dateValue.getDate()===pendingDay\"\r\n                                (click)=\"onItemClick(item.dateValue)\">\r\n                                {{ item.date }}</div>\r\n                        </li>\r\n                    </ul>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div class=\"month-picker-session\" [class.active]=\"monthPickerActive\">\r\n            <core-month-picker [lang]=\"lang\" [monthObject$]=\"currentMonthObject$\" (onChange)=\"onMonthObjectChange($event)\" (onYearClick)=\"onMonthPickerYearClick($event)\"></core-month-picker>\r\n        </div>\r\n        <div class=\"year-picker-session\" [class.active]=\"yearPickerActive\">\r\n            <core-year-picker [lang]=\"lang\" (onChange)=\"onYearPicked($event)\"></core-year-picker>\r\n        </div>\r\n        <div class=\"footer-wrapper\">\r\n            <div class=\"cdp-footer\">\r\n                <div class=\"clear\" [class.opacity-0]=\"!!!textValue\" (click)=\"clear()\">{{ 'UI.CORE_DATE_PICKER_CLEAR' | translate: lang }}</div>\r\n                <div class=\"digi-watch\"></div>\r\n                <div class=\"today\" (click)=\"goToday()\">{{ 'UI.CORE_DATE_PICKER_TODAY' | translate: lang }}</div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
405
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-date-picker.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-date-picker/core-date-picker/core-date-picker.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-date-picker/core-date-picker/core-date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, OnInit, OnDestroy, AfterViewInit, ViewChild, Input, Renderer2, isDevMode } from '@angular/core';\r\nimport { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { BehaviorSubject, Observable, Subscription, distinctUntilChanged, fromEvent } from 'rxjs';\r\nimport { DomService } from '../../services/dom.service';\r\nimport { CoreFormControlBaseComponent } from '../../core-form-control-base/core-form-control-base.component';\r\nimport { CoreDatetimeService, IDataRow, IMonthIdentity } from '../../services/core-datetime.service';\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CoreYearPickerComponent } from '../../core-year-picker/core-year-picker/core-year-picker.component';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { CoreMonthPickerComponent } from '../../core-month-picker/core-month-picker/core-month-picker.component';\r\nimport { AlertService } from '../../alert/alert.service';\r\n\r\n\r\nexport interface ICoreDatePickerRange {\r\n  minDate: Date;\r\n  maxDate: Date;\r\n}\r\n\r\n@Component({\r\n  selector: 'core-date-picker',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    CoreYearPickerComponent,\r\n    CoreMonthPickerComponent,\r\n    TranslatePipe,\r\n  ],\r\n  templateUrl: './core-date-picker.component.html',\r\n  styleUrls: ['./core-date-picker.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreDatePickerComponent\r\n    }\r\n  ]\r\n})\r\n/*\r\n  this component renders its main part and popup part\r\n  the main part deals with user input from physical keyboard or touch keyboard\r\n  the popup part consists of 1) navigator 2) header 3) calendar body container 4) calendar body\r\n  the most important part of them is:\r\n    4) calendar body:\r\n      due variations the calendar body may reach to 6 rows of week day sub-array\r\n    - for visual, logic and coding simplicity I will always render all the 6 rows\r\n    so calendar body dimension stays unchanged\r\n  \r\n*/\r\nexport class CoreDatePickerComponent extends CoreFormControlBaseComponent implements OnInit, AfterViewInit, OnDestroy {\r\n\r\n  @Input() enableTimeZoneConverter!: boolean;\r\n  @Input() showPlaceholder: boolean = false;\r\n  @Input() popupWidth: number = 300;\r\n  @Input() popupXPadding: number = 12;\r\n  @Input() rangeLimit!: ICoreDatePickerRange;\r\n  @Input() override readonly!: boolean;\r\n  @Input() override disabled!: boolean;\r\n\r\n\r\n  listenerFn!: () => void;\r\n\r\n  lang!: string;\r\n  subscriptions: Subscription[] = [];\r\n  openState: boolean = false;\r\n  monthPickerActive: boolean = false;\r\n  yearPickerActive: boolean = false;\r\n\r\n  cellSize: number = (this.popupWidth - this.popupXPadding * 2) / 7;\r\n\r\n  override value!: Date | null;\r\n  pendingYear!: number;\r\n  pendingMonthIndex!: number;\r\n  pendingDay: number = this.value?.getDate()!;\r\n\r\n  currentMonthObject$!: BehaviorSubject<IMonthIdentity>;\r\n  newDate!: Date;\r\n\r\n  currentMonthText!: string;\r\n  currentHours!: number;\r\n  currentMinutes!: number;\r\n  currentSeconds!: number;\r\n  currentMilliseconds!: number;\r\n\r\n  data!: IDataRow[];\r\n  headerWeekdays!: string[];\r\n  direction: number = 1; // startup direction 1 | -1\r\n\r\n  textValue: string = '';\r\n\r\n  @ViewChild('container') container!: ElementRef;\r\n  @ViewChild('input') input!: ElementRef;\r\n  @ViewChild('backward') backward!: ElementRef;\r\n  @ViewChild('calendarBody') calendarBody!: ElementRef;\r\n\r\n  inputStream$!: Observable<any>;\r\n  lastText!: string;\r\n\r\n  constructor(\r\n    private readonly renderer: Renderer2,\r\n    private readonly domService: DomService,\r\n    private readonly coreDatetimeService: CoreDatetimeService,\r\n    private mls: MultiLanguageService,\r\n    private alertService: AlertService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n    this.newDate = !!this.rangeLimit ? this.rangeLimit.minDate : new Date();\r\n    this.currentMonthObject$ = new BehaviorSubject<IMonthIdentity>({\r\n      year: this.value?.getFullYear() || this.newDate.getFullYear(),\r\n      monthIndex: this.value?.getMonth() || this.newDate.getMonth()\r\n    });\r\n\r\n    if (!!this.disabled) this.readonly = true;\r\n\r\n    if (!!!this.value) {\r\n      this.value = this.newDate;\r\n      this.lastText = this.coreDatetimeService.dateToVnString(this.value)\r\n    }\r\n      \r\n    this.pendingYear = this.value.getFullYear();\r\n    this.pendingMonthIndex = this.value.getMonth();\r\n    this.pendingDay = this.value.getDate();\r\n    this.currentHours = this.value.getHours();\r\n    this.currentMinutes = this.value.getMinutes();\r\n    this.currentSeconds = this.value.getSeconds();\r\n    this.currentMilliseconds = this.value.getMilliseconds();\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(x => this.lang = x)\r\n    )\r\n\r\n    /*\r\n    if (!!!this.id) {\r\n      console.error(`\r\n      within a page, tanleica-date-picker needs an unique property id value to work correctly\r\n      for example: <tanleica-date-picker id=\"startDate\" formControlName=\"startDate\"></tanleica-date-picker>\r\n      `)\r\n    }\r\n    */\r\n    this.headerWeekdays = this.coreDatetimeService.getShortWeekdays(this.lang);\r\n  }\r\n\r\n  /*\r\n    trigger animation by reflow the DOM\r\n  */\r\n  triggerReflow() {\r\n    const el = this.calendarBody.nativeElement;\r\n    //DOM manipulation\r\n    if (this.direction === 1) {\r\n      el.classList.remove(\"slide-up\");\r\n    } else {\r\n      el.classList.remove(\"slide-down\");\r\n    }\r\n    el.offsetHeight;  /* trigger reflow (alternative: el.offsetWidth) */\r\n    if (this.direction === 1) {\r\n      setTimeout(() => el.classList.add(\"slide-up\"), 0); // pass the callback to Callback queue through WebAPIs, so it will be executed after DOM manipulation ends\r\n    } else {\r\n      setTimeout(() => el.classList.add(\"slide-down\"), 0); // pass the callback to Callback queue through WebAPIs, so it will be executed after DOM manipulation ends\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n\r\n    /*\r\n      This events get called by all clicks on the page\r\n    */\r\n    this.listenerFn = this.renderer.listen('window', 'click', (e: Event) => {\r\n      /*\r\n        handle click outside\r\n      */\r\n      if (this.container && !!!this.container.nativeElement.contains(e.target)) {\r\n        this.openState = false;\r\n      }\r\n    })\r\n\r\n    const maxZIndex = this.domService.getMaxZIndex();\r\n\r\n    this.container.nativeElement.style.setProperty('--indicator-height', (this.input.nativeElement.getBoundingClientRect().height - 6) + 'px')\r\n    this.container.nativeElement.style.setProperty('--popup-z-index', maxZIndex);\r\n    this.container.nativeElement.style.setProperty('--cell-size', this.cellSize + 'px')\r\n\r\n    this.currentMonthObject$.pipe(\r\n      distinctUntilChanged()\r\n    ).subscribe(value => {\r\n      setTimeout(() => {\r\n        this.currentMonthText = this.coreDatetimeService.getMonthText(this.lang, value.monthIndex);\r\n        console.log(\"Rebuilding....\")\r\n        this.buildBody(value.year, value.monthIndex);\r\n        this.triggerReflow();\r\n      }, 0)\r\n    })\r\n\r\n    this.inputStream$ = fromEvent(this.input.nativeElement, 'input');\r\n    this.inputStream$.subscribe(event => {\r\n\r\n      if ( event.inputType !== 'deleteContentBackward' \r\n        && '#0#1#2#3#4#5#6#7#8#9#Backspace#Delete'.indexOf('#' + event.data) < 0) \r\n      {\r\n        event.target.value = this.lastText;\r\n        this.markAsTouched();\r\n        this.onChange(null);\r\n        return;\r\n      } else {\r\n        this.lastText = event.target.value\r\n      }\r\n\r\n      var v = event.target.value;\r\n      if (v.match(/^\\d{2}$/) !== null) {\r\n        event.target.value = v + '/';\r\n        this.textValue = v + '/';\r\n      } else if (v.match(/^\\d{2}\\/\\d{2}$/) !== null) {\r\n        event.target.value = v + '/';\r\n        this.textValue = v + '/';\r\n      } else {\r\n        this.textValue = v;\r\n      }\r\n\r\n      if (this.textValue.length === 10) {\r\n        const digits = this.textValue.split('/');\r\n        const y = Number(digits[2]);\r\n        const m = Number(digits[1]) - 1;\r\n        const d = Number(digits[0]);\r\n\r\n        if (y <= 0 || m < 0 || m > 11 || d < 1 || d > 31) {\r\n          event.target.value = '';\r\n          this.textValue = '';\r\n          this.markAsTouched();\r\n          this.onChange(null);\r\n          return;\r\n        }\r\n\r\n        const now = new Date();\r\n        const hr = now.getHours();\r\n        const mn = now.getMinutes();\r\n        const sd = now.getSeconds();\r\n        const ms = now.getMilliseconds();\r\n\r\n        const date = new Date(Number(digits[2]), Number(digits[1]) - 1, Number(digits[0]), hr, mn, sd, ms);\r\n        event.target.value = this.coreDatetimeService.dateToVnString(date);\r\n        this.markAsTouched();\r\n        this.onChange(date);\r\n\r\n      } else {\r\n        this.markAsTouched();\r\n        this.onChange(null);\r\n        return;\r\n      }\r\n    })\r\n\r\n  }\r\n\r\n  override writeValue(obj: Date | null): void {\r\n    console.log(\"UTC Date \", obj);\r\n\r\n    const updateProperties = (value: Date) => {\r\n      console.log(\"After convert to Local Date \", value);\r\n      this.value = value;\r\n      this.lastText = this.coreDatetimeService.dateToVnString(value)\r\n      this.textValue = this.coreDatetimeService.dateToVnString(value);\r\n      this.currentMonthObject$.next({\r\n        year: value.getFullYear(),\r\n        monthIndex: value.getMonth()\r\n      })\r\n      this.currentHours = value.getHours();\r\n      this.currentMinutes = value.getMinutes();\r\n      this.currentSeconds = value.getSeconds();\r\n      this.currentMilliseconds = value.getMilliseconds();\r\n\r\n      this.currentMonthText = this.coreDatetimeService.getMonthText(this.lang, this.currentMonthObject$.value.monthIndex);\r\n      this.pendingYear = value.getFullYear();\r\n      this.pendingMonthIndex = value.getMonth();\r\n      this.pendingDay = value.getDate();\r\n    }\r\n\r\n    if (obj === null || obj === undefined) {\r\n      let now = new Date();\r\n      if (!!this.rangeLimit) {\r\n        now = this.rangeLimit.minDate;\r\n      }\r\n      this.textValue = '';\r\n      this.currentMonthObject$.next({\r\n        year: now.getFullYear(),\r\n        monthIndex: now.getMonth()\r\n      })\r\n      this.currentHours = now.getHours();\r\n      this.currentMinutes = now.getMinutes();\r\n      this.currentSeconds = now.getSeconds();\r\n      this.currentMilliseconds = now.getMilliseconds();\r\n      this.currentMonthText = this.coreDatetimeService.getMonthText(this.lang, this.currentMonthObject$.value.monthIndex);\r\n    } else {\r\n      /* Convert UTC date to local date */\r\n      const originalDate: Date = new Date(obj);\r\n      const offset = (new Date()).getTimezoneOffset();\r\n      const dateValue = new Date(originalDate.getTime() - offset * 60000);\r\n      /*--------------------------------------*/\r\n      if (typeof obj!.getFullYear === 'function') {\r\n        updateProperties(dateValue);\r\n      } else if (typeof obj === 'string') {\r\n        const isDate = this.coreDatetimeService.isDateString(obj);\r\n        if (isDate) {\r\n          //const _obj = new Date(obj); // convert string to date \r\n          updateProperties(dateValue);\r\n        } else {\r\n          console.error(\"Invalid date input: \", obj);\r\n        }\r\n\r\n      } else {\r\n        console.error(\"Invalid date input: \", obj);\r\n      }\r\n    }\r\n  }\r\n\r\n  onItemClick(date: Date) {\r\n\r\n    if (this.readonly) return;\r\n\r\n    if (!!this.rangeLimit) {\r\n      if (date < this.rangeLimit.minDate || date > this.rangeLimit.maxDate) return;\r\n    }\r\n\r\n    const now = new Date();\r\n    const h = now.getHours();\r\n    const m = now.getMinutes();\r\n    const s = now.getSeconds();\r\n    const ms = now.getMilliseconds();\r\n    date.setHours(h);\r\n    date.setMinutes(m);\r\n    date.setSeconds(s);\r\n    date.setMilliseconds(ms);\r\n    this.textValue = this.coreDatetimeService.dateToVnString(date);\r\n\r\n    this.pendingYear = date.getFullYear();\r\n    this.pendingMonthIndex = date.getMonth();\r\n    this.pendingDay = date.getDate();\r\n\r\n    this.markAsTouched();\r\n    \r\n    this.onChange(date);\r\n    this.openState = false;\r\n  }\r\n\r\n  goToday() {\r\n    const today = new Date();\r\n    if (!!this.rangeLimit) {\r\n      if (today < this.rangeLimit.minDate || today > this.rangeLimit.maxDate) return;\r\n    }\r\n    this.textValue = this.coreDatetimeService.dateToVnString(today);\r\n    this.markAsTouched();\r\n    this.onChange(today);\r\n    this.openState = false;\r\n  }\r\n\r\n  clear() {\r\n    this.textValue = '';\r\n    this.value = null;\r\n    this.lastText = '';\r\n    this.markAsTouched();\r\n    this.onChange(null);\r\n    this.openState = false;\r\n  }\r\n\r\n  goBackward() {\r\n    this.direction = -1;\r\n    this.backward.nativeElement.checked = true;\r\n    if (this.currentMonthObject$.value.monthIndex === 0) {\r\n      this.currentMonthObject$.next({\r\n        year: this.currentMonthObject$.value.year - 1,\r\n        monthIndex: 11\r\n      });\r\n      this.currentMonthText = this.coreDatetimeService.getMonthText(this.lang, 11);\r\n    } else {\r\n      this.currentMonthObject$.next({\r\n        year: this.currentMonthObject$.value.year,\r\n        monthIndex: this.currentMonthObject$.value.monthIndex - 1\r\n      });\r\n\r\n      this.currentMonthText = this.coreDatetimeService.getMonthText(this.lang, this.currentMonthObject$.value.monthIndex);\r\n    }\r\n  }\r\n\r\n  goForeward() {\r\n    this.direction = 1;\r\n    this.backward.nativeElement.checked = false;\r\n    this\r\n    if (this.currentMonthObject$.value.monthIndex === 11) {\r\n      this.currentMonthObject$.next({\r\n        year: this.currentMonthObject$.value.year + 1,\r\n        monthIndex: 0\r\n      });\r\n      this.currentMonthText = this.coreDatetimeService.getMonthText(this.lang, 0);\r\n    } else {\r\n      this.currentMonthObject$.next({\r\n        year: this.currentMonthObject$.value.year,\r\n        monthIndex: this.currentMonthObject$.value.monthIndex + 1\r\n      });\r\n      this.currentMonthText = this.coreDatetimeService.getMonthText(this.lang, this.currentMonthObject$.value.monthIndex);\r\n    }\r\n  }\r\n\r\n  /* Probably the most important function */\r\n  buildBody(year: number, monthIndex: number) {\r\n    const body = this.coreDatetimeService.getCalendarBody(year, monthIndex, this.direction);\r\n    this.data = body.rows;\r\n    this.container.nativeElement.style.setProperty('--scroll-distance', (body.rows.length - 6) * this.cellSize + 'px');\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.listenerFn) this.listenerFn();\r\n    this.subscriptions.map(x => x?.unsubscribe())\r\n  }\r\n\r\n  toggleOpen() {\r\n    if (!!this.readonly) return\r\n    if (!!this.disabled) return\r\n    this.openState = !this.openState;\r\n  }\r\n\r\n  toggleMonthPickerActive() {\r\n    this.monthPickerActive = !this.monthPickerActive;\r\n  }\r\n\r\n  onMonthObjectChange(args: IMonthIdentity) {\r\n    this.currentMonthObject$.next({\r\n      year: args.year,\r\n      monthIndex: args.monthIndex\r\n    })\r\n    this.monthPickerActive = false;\r\n  }\r\n\r\n  onMonthPickerYearClick(e: number) {\r\n    this.monthPickerActive = false;\r\n    this.yearPickerActive = true;\r\n  }\r\n\r\n  onYearPicked(e: number) {\r\n    this.currentMonthObject$.next({\r\n      year: e,\r\n      monthIndex: this.currentMonthObject$.value.monthIndex\r\n    });\r\n    this.yearPickerActive = false;\r\n    this.monthPickerActive = true;\r\n  }\r\n}\r\n","<div #container class=\"core-date-picker-container\">\r\n    <input type=\"checkbox\" [(ngModel)]=\"openState\">\r\n    <input type=\"checkbox\" [(ngModel)]=\"monthPickerActive\">\r\n    <input type=\"checkbox\" [(ngModel)]=\"yearPickerActive\">\r\n    <input #backward type=\"checkbox\" class=\"tl-datepicker-direction\">\r\n    <input #input type=\"text\" class=\"form-control\" [placeholder]=\"showPlaceholder ? 'dd/mm/yyyy' : ''\"\r\n        maxlength=\"10\" [(ngModel)]=\"textValue\" [class.form-control-disabled]=\"disabled\" [disabled]=\"disabled\"><label class=\"icon\" (click)=\"toggleOpen()\"></label>\r\n    <div class=\"tl-date-picker-popup\" [class.open]=\"openState\">\r\n        <div class=\"date-picker-session\" [class.d-none]=\"monthPickerActive || yearPickerActive\">\r\n            <div class=\"navigator\">\r\n                <label class=\"month-dropdown\" (click)=\"toggleMonthPickerActive()\">{{ currentMonthText }} {{\r\n                    currentMonthObject$.value.year }}</label>\r\n                <div class=\"arrows\">\r\n                    <div class=\"go-up\" (click)=\"goBackward()\"></div>\r\n                    <div class=\"go-down\" (click)=\"goForeward()\"></div>\r\n                </div>\r\n            </div>\r\n            <div class=\"weekday-header\">\r\n                <ul>\r\n                    <li *ngFor=\"let day of headerWeekdays; let i = index\" [class.t7]=\"i===5\" [class.cn]=\"i===6\">\r\n                        <div>{{ day }}</div>\r\n                    </li>\r\n                </ul>\r\n            </div>\r\n            <div class=\"calendar-body-container\">\r\n                <div #calendarBody class=\"calendar-body\" [class.slide-up]=\"direction===1\"\r\n                    [class.slide-down]=\"direction===-1\">\r\n                    <ul *ngFor=\"let week of data\">\r\n                        <li *ngFor=\"let item of week.items; let i = index\">\r\n                            <div [class.out-of-month]=\"!!!item.currentMonth\" [class.t7]=\"i===5\" [class.cn]=\"i===6\"\r\n                                [class.out-of-range]=\"!!rangeLimit && !!!((item.dateValue>=rangeLimit.minDate) && (rangeLimit.maxDate>=item.dateValue))\"\r\n                                [class.active]=\"item.dateValue.getFullYear()===pendingYear && item.dateValue.getMonth()===pendingMonthIndex && item.dateValue.getDate()===pendingDay\"\r\n                                (click)=\"onItemClick(item.dateValue)\">\r\n                                {{ item.date }}</div>\r\n                        </li>\r\n                    </ul>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div class=\"month-picker-session\" [class.active]=\"monthPickerActive\">\r\n            <core-month-picker [lang]=\"lang\" [monthObject$]=\"currentMonthObject$\" (onChange)=\"onMonthObjectChange($event)\" (onYearClick)=\"onMonthPickerYearClick($event)\"></core-month-picker>\r\n        </div>\r\n        <div class=\"year-picker-session\" [class.active]=\"yearPickerActive\">\r\n            <core-year-picker [lang]=\"lang\" (onChange)=\"onYearPicked($event)\"></core-year-picker>\r\n        </div>\r\n        <div class=\"footer-wrapper\">\r\n            <div class=\"cdp-footer\">\r\n                <div class=\"clear\" [class.opacity-0]=\"!!!textValue\" (click)=\"clear()\">{{ 'UI.CORE_DATE_PICKER_CLEAR' | translate: lang }}</div>\r\n                <div class=\"digi-watch\"></div>\r\n                <div class=\"today\" (click)=\"goToday()\">{{ 'UI.CORE_DATE_PICKER_TODAY' | translate: lang }}</div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
@@ -7,13 +7,34 @@ import { CommonModule } from '@angular/common';
7
7
  import { ThreedotsComponent } from '../../threedots/threedots.component';
8
8
  import { TranslatePipe } from '../../../app-pipes/translate.pipe';
9
9
  import { MapAvatarToServerPipe } from '../../../app-pipes/map-avatar-to-server.pipe';
10
- //declare let coreFileUtils: any;
11
- import { coreFileUtils } from '../../../../assets/js/coreFileUtils';
12
10
  import * as i0 from "@angular/core";
13
11
  import * as i1 from "../../alert/alert.service";
14
12
  import * as i2 from "../../../services/multi-language.service";
15
13
  import * as i3 from "@angular/common";
16
- const { compressImage, blobToBase64 } = coreFileUtils.prototype;
14
+ //declare let coreFileUtils: any;
15
+ //import { coreFileUtils } from '../../../../assets/js/coreFileUtils';
16
+ //const { compressImage, blobToBase64 } = coreFileUtils.prototype;
17
+ const blobToBase64 = async (blob) => {
18
+ return new Promise((resolve, _) => {
19
+ const reader = new FileReader();
20
+ reader.onloadend = () => resolve(reader.result);
21
+ reader.readAsDataURL(blob);
22
+ });
23
+ };
24
+ const compressImage = async (blob) => {
25
+ const response = await createImageBitmap(blob);
26
+ const { width, height } = response;
27
+ const dWidth = width > height ? 1024 : 1024 * width / height;
28
+ const dHeight = width < height ? 1024 : 1024 / width * height;
29
+ const offscreen = new OffscreenCanvas(dWidth, dHeight);
30
+ const ctx = offscreen.getContext('2d');
31
+ ctx.drawImage(response, 0, 0, dWidth, dHeight);
32
+ const result = offscreen.convertToBlob({
33
+ type: 'image/jpeg',
34
+ quality: 0.9,
35
+ });
36
+ return result;
37
+ };
17
38
  export var EnumCoreFileUploaderType;
18
39
  (function (EnumCoreFileUploaderType) {
19
40
  EnumCoreFileUploaderType["IMAGE_AVATAR"] = "IMAGE_AVATAR";
@@ -182,4 +203,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
182
203
  type: ViewChild,
183
204
  args: ['customFileInput']
184
205
  }] } });
185
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-file-uploader.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-file-uploader/core-file-uploader/core-file-uploader.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-file-uploader/core-file-uploader/core-file-uploader.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  ViewChild,\r\n  isDevMode,\r\n  Injector,\r\n} from '@angular/core';\r\nimport { CoreFormControlBaseComponent } from '../../core-form-control-base/core-form-control-base.component';\r\nimport { FormsModule, NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';\r\n\r\nimport { AlertService } from '../../alert/alert.service';\r\n\r\nimport { Subscription } from 'rxjs';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { alertOptions } from '../../../constants/alertOptions';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ThreedotsComponent } from '../../threedots/threedots.component';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { MapAvatarToServerPipe } from '../../../app-pipes/map-avatar-to-server.pipe';\r\n\r\n//declare let coreFileUtils: any;\r\nimport { coreFileUtils } from '../../../../assets/js/coreFileUtils';\r\nconst { compressImage, blobToBase64 } = coreFileUtils.prototype;\r\n\r\nexport enum EnumCoreFileUploaderType {\r\n  IMAGE_AVATAR = 'IMAGE_AVATAR',\r\n  IMAGE_OTHER = 'IMAGE_OTHER',\r\n  PDF = 'PDF',\r\n  DOC = 'DOC',\r\n  EXCEL = 'EXCEL',\r\n  AUDIO = 'AUDIO',\r\n  OTHER = 'OTHER',\r\n}\r\n\r\n@Component({\r\n  selector: 'core-file-uploader',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ThreedotsComponent,\r\n    TranslatePipe,\r\n    MapAvatarToServerPipe\r\n  ],\r\n  templateUrl: './core-file-uploader.component.html',\r\n  styleUrls: ['./core-file-uploader.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreFileUploaderComponent,\r\n    },\r\n  ],\r\n})\r\nexport class CoreFileUploaderComponent extends CoreFormControlBaseComponent implements OnInit, OnDestroy {\r\n  @Input() uploadFileType!: EnumCoreFileUploaderType;\r\n  @Input() fileDataControlName!: string;\r\n  @Input() fileNameControlName!: string;\r\n  @Input() fileTypeControlName!: string;\r\n  @Input() avatarSize!: number;\r\n  @Input() defaultAvatar!: string;\r\n  @Input() hidePreview!: boolean;\r\n  @Input() verticalMode!: boolean;\r\n  @ViewChild('customFileInput') customFileInput!: ElementRef;\r\n\r\n  override value!: string;\r\n\r\n  ngControl!: NgControl;\r\n\r\n  hoverText =\r\n    EnumTranslateKey.UI_CORE_CONTROL_FILE_UPLOADER_CLICK_TO_BROWSE_FILE;\r\n  lang!: string;\r\n  subscriptions: Subscription[] = [];\r\n  chosenFile: any;\r\n  compressedSize: any;\r\n  preview: any;\r\n  loading: boolean = false;\r\n  loadingCaption!: string;\r\n\r\n  accept!: string;\r\n\r\n  constructor(\r\n    private alertService: AlertService,\r\n    private mls: MultiLanguageService,\r\n    private injector: Injector\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    setTimeout(() => this.ngControl = this.injector.get(NgControl));\r\n\r\n    if (isDevMode() && !!!this.uploadFileType) {\r\n      this.alertService.error(\r\n        `Using CoreFileUploaderComponent required property uploadFileType!: EnumCoreFileUploaderType`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n    if (isDevMode() && !!!this.fileDataControlName) {\r\n      this.alertService.error(\r\n        `Using CoreFileUploaderComponent required property fileDataControlName!: string (base64)`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n    if (isDevMode() && !!!this.fileNameControlName) {\r\n      this.alertService.error(\r\n        `Using CoreFileUploaderComponent required property fileNameControlName!: string`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n    if (isDevMode() && !!!this.fileTypeControlName) {\r\n      this.alertService.error(\r\n        `Using CoreFileUploaderComponent required property fileTypeControlName!: string`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n\r\n    this.subscriptions.push(this.mls.lang$.subscribe((x) => (this.lang = x)));\r\n\r\n    if (\r\n      this.uploadFileType === EnumCoreFileUploaderType.IMAGE_AVATAR ||\r\n      this.uploadFileType === EnumCoreFileUploaderType.IMAGE_OTHER\r\n    ) {\r\n      this.accept = 'image/png, image/gif, image/jpeg';\r\n    } else if (\r\n      this.uploadFileType === EnumCoreFileUploaderType.PDF\r\n    ) {\r\n      this.accept = \"application/pdf\";\r\n    } else {\r\n      this.alertService.warn(\r\n        `When uploadFileType===${this.uploadFileType} => TO DO...`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n  }\r\n\r\n  onHover() {\r\n    console.log('onHover');\r\n    this.customFileInput.nativeElement.style.setProperty(\r\n      '--hover-text',\r\n      this.hoverText\r\n    );\r\n  }\r\n\r\n  handleInputChange(e: any) {\r\n    console.log('handleInputChange e', e);\r\n    if (!this.hasFileSize(e.target.files[0].size)) {\r\n      this.alertService.error(\r\n        `File size exceeds 3MB.`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n      return;\r\n    }\r\n    if (!!e.target.files.length) {\r\n      const file = e.target.files[0];\r\n      console.log('handleInputChange file', file);\r\n      this.chosenFile = file;\r\n\r\n      if (\r\n        file.type.split('/')[0] === 'image' ||\r\n        file.type.split('/')[0] === 'application'\r\n      ) {\r\n        const blob = new Blob([file]);\r\n        if (file.type !== 'image/gif') {\r\n          compressImage(blob).then((blob: any) => {\r\n            this.compressedSize = blob.size;\r\n            blobToBase64(blob).then((base64: any) => {\r\n              this.preview = base64;\r\n\r\n              const index = (base64 as string).indexOf('base64,');\r\n              if (index >= 0) {\r\n                base64 = (base64 as string).substring(index + 7);\r\n              }\r\n\r\n              this.onChange(base64);\r\n\r\n              const form = this.ngControl.control?.parent;\r\n              const objectToPatch: any = {};\r\n              objectToPatch[this.fileDataControlName] = base64;\r\n              objectToPatch[this.fileNameControlName] = file.name;\r\n              objectToPatch[this.fileTypeControlName] = file.type;\r\n              form?.patchValue(objectToPatch);\r\n\r\n              this.markAsTouched();\r\n            });\r\n          });\r\n        } else {\r\n          blobToBase64(blob).then((base64: any) => {\r\n            this.compressedSize = blob.size;\r\n            this.preview = base64;\r\n\r\n            const index = (base64 as string).indexOf('base64,');\r\n            if (index >= 0) {\r\n              base64 = (base64 as string).substring(index + 7);\r\n            }\r\n\r\n            this.onChange(base64);\r\n\r\n            const form = this.ngControl.control?.parent;\r\n            const objectToPatch: any = {};\r\n            objectToPatch[this.fileDataControlName] = base64;\r\n            objectToPatch[this.fileNameControlName] = file.name;\r\n            objectToPatch[this.fileTypeControlName] = file.type;\r\n            form?.patchValue(objectToPatch);\r\n\r\n            this.markAsTouched();\r\n          });\r\n        }\r\n      } else if (file.type.split('/')[0] === 'audio') {\r\n        console.log('To do');\r\n      } else {\r\n\r\n      }\r\n    } else {\r\n      this.preview = '';\r\n      this.onChange('');\r\n      this.markAsTouched();\r\n      this.chosenFile = '';\r\n    }\r\n  }\r\n\r\n  hasFileSize(fileSize : any) {\r\n    if (fileSize < 3 * 1024 * 1024) { return true; }\r\n    return false;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.map((x) => x?.unsubscribe());\r\n  }\r\n}\r\n","<div class=\"core-file-uploader-container\">\r\n\r\n    <div *ngIf=\"!!!verticalMode\">\r\n\r\n        <div class=\"row\">\r\n            <div [class]=\"!!hidePreview ? 'col-md-12' : 'col-md-6'\">\r\n                <input id=\"custom-file-input\" #customFileInput class=\"custom-file-input\" type=\"file\" [accept]=\"accept\"\r\n                    (change)=\"handleInputChange($event)\" (hover)=\"onHover()\">\r\n                <label id=\"file-input-label\" for=\"custom-file-input\">\r\n                    <img *ngIf=\"uploadFileType==='IMAGE_AVATAR'\"\r\n                        [src]=\"!!!hidePreview ? (value ? (value | mapAvatarToServer) : defaultAvatar) : (preview ? preview : defaultAvatar)\"\r\n                        class=\"avatar-preview\">\r\n                    <div *ngIf=\"uploadFileType!=='IMAGE_AVATAR'\">{{'EXISTING FILE...'}}</div>\r\n                </label>\r\n                <label id=\"file-input-label\" for=\"custom-file-input\">\r\n                    <input type=\"file\" *ngIf=\"uploadFileType!=='IMAGE_AVATAR'\" [src]=\"value\"\r\n                        (change)=\"handleInputChange($event)\" class=\"\">\r\n                </label>\r\n            </div>\r\n            <div class=\"col-md-2\" *ngIf=\"!!!hidePreview\">\r\n                <div *ngIf=\"!!!loading\">\r\n                    <div class=\"selected-preview\" *ngIf=\"preview\">\r\n                        <img [src]=\"preview\" alt=\"selected-file\">\r\n                    </div>\r\n                </div>\r\n                <app-threedots *ngIf=\"!!loading\"></app-threedots>\r\n            </div>\r\n            <div class=\"col-md-4 d-none\" *ngIf=\"!!!hidePreview\">\r\n                <ng-container *ngIf=\"!!chosenFile\">\r\n\r\n                    <div>\r\n                        <div>\r\n                            {{ 'UI_CORE_FILE_UPLOADER_FILE_NAME' | translate: lang }}:\r\n                        </div>\r\n                        <div>\r\n                            {{ chosenFile?.name }}\r\n                        </div>\r\n                    </div>\r\n\r\n                    <div>\r\n                        <div>\r\n                            {{ 'UI_CORE_FILE_UPLOADER_FILE_TYPE' | translate: lang }}:\r\n                        </div>\r\n                        <div>\r\n                            {{ chosenFile?.type }}\r\n                        </div>\r\n                    </div>\r\n\r\n                    <div>\r\n                        <div>\r\n                            {{ 'UI_CORE_FILE_UPLOADER_FILE_SIZE' | translate: lang }}:\r\n                        </div>\r\n                        <div>\r\n                            {{ chosenFile?.size }}\r\n                        </div>\r\n                    </div>\r\n                </ng-container>\r\n            </div>\r\n        </div>\r\n\r\n        <!-- <ng-container *ngIf=\"!!compressedSize\">\r\n            <div>\r\n                <div>\r\n                    {{ 'UI_CORE_FILE_UPLOADER_FILE_SIZE_COMPRESSED' | translate: lang }}:\r\n                </div>\r\n                <div>\r\n                    {{ compressedSize }}\r\n                </div>\r\n            </div>\r\n        </ng-container> -->\r\n    </div>\r\n\r\n    <div *ngIf=\"!!verticalMode\" class=\"mt20\">\r\n\r\n        <div class=\"container container-fluid\">\r\n\r\n            <div class=\"row\">\r\n                <div class='col-md-12'>\r\n                    <input id=\"custom-file-input\" #customFileInput class=\"custom-file-input\" type=\"file\"\r\n                        [accept]=\"accept\" (change)=\"handleInputChange($event)\" (hover)=\"onHover()\">\r\n                    <label id=\"file-input-label\" for=\"custom-file-input\">\r\n                        <img *ngIf=\"uploadFileType==='IMAGE_AVATAR'\"\r\n                            [src]=\"!!!hidePreview ? (value ? (value | mapAvatarToServer) : defaultAvatar) : ((value && !!!preview) ? (value | mapAvatarToServer) : (preview ? preview : defaultAvatar))\"\r\n                            class=\"avatar-preview\">\r\n                        <div *ngIf=\"uploadFileType!=='IMAGE_AVATAR'\">{{'EXISTING FILE...'}}</div>\r\n                    </label>\r\n                    <label id=\"file-input-label\" for=\"custom-file-input\">\r\n                        <input type=\"file\" *ngIf=\"uploadFileType!=='IMAGE_AVATAR'\" [src]=\"value\"\r\n                            (change)=\"handleInputChange($event)\" class=\"\">\r\n                    </label>\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"row\">\r\n                <div class=\"col-md-12\" *ngIf=\"!!!hidePreview\">\r\n                    <div *ngIf=\"!!!loading\">\r\n                        <div class=\"selected-preview\" *ngIf=\"preview\">\r\n                            <img [src]=\"preview\" alt=\"selected-file\">\r\n                        </div>\r\n                    </div>\r\n                    <app-threedots *ngIf=\"!!loading\"></app-threedots>\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"row d-none\">\r\n                <div class=\"col-md-12\" *ngIf=\"!!!hidePreview\">\r\n\r\n                    <ng-container *ngIf=\"!!chosenFile\">\r\n\r\n                        <div class=\"row\">\r\n                            <div class='col-md-6'>\r\n                                {{ 'UI_CORE_FILE_UPLOADER_FILE_NAME' | translate: lang }}:\r\n                            </div>\r\n                            <div class='col-md-6'>\r\n                                {{ chosenFile?.name }}\r\n                            </div>\r\n                        </div>\r\n\r\n                        <div class=\"row\">\r\n                            <div class='col-md-6'>\r\n                                {{ 'UI_CORE_FILE_UPLOADER_FILE_TYPE' | translate: lang }}:\r\n                            </div>\r\n                            <div class='col-md-6'>\r\n                                {{ chosenFile?.type }}\r\n                            </div>\r\n                        </div>\r\n\r\n                        <div class=\"row\">\r\n                            <div class='col-md-6'>\r\n                                {{ 'UI_CORE_FILE_UPLOADER_FILE_SIZE' | translate: lang }}:\r\n                            </div>\r\n                            <div class='col-md-6'>\r\n                                {{ chosenFile?.size }}\r\n                            </div>\r\n                        </div>\r\n\r\n                    </ng-container>\r\n\r\n                    <ng-container *ngIf=\"!!compressedSize\">\r\n                        <div class=\"row\">\r\n                            <div class='col-md-6'>\r\n                                {{ 'UI_CORE_FILE_UPLOADER_FILE_SIZE_COMPRESSED' | translate: lang }}:\r\n                            </div>\r\n                            <div class='col-md-6'>\r\n                                {{ compressedSize }}\r\n                            </div>\r\n                        </div>\r\n                    </ng-container>\r\n\r\n                </div>\r\n            </div>\r\n\r\n        </div>\r\n\r\n    </div>\r\n\r\n</div>"]}
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-file-uploader.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-file-uploader/core-file-uploader/core-file-uploader.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-file-uploader/core-file-uploader/core-file-uploader.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  ViewChild,\r\n  isDevMode,\r\n  Injector,\r\n} from '@angular/core';\r\nimport { CoreFormControlBaseComponent } from '../../core-form-control-base/core-form-control-base.component';\r\nimport { FormsModule, NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';\r\n\r\nimport { AlertService } from '../../alert/alert.service';\r\n\r\nimport { Subscription } from 'rxjs';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { alertOptions } from '../../../constants/alertOptions';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ThreedotsComponent } from '../../threedots/threedots.component';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { MapAvatarToServerPipe } from '../../../app-pipes/map-avatar-to-server.pipe';\r\n\r\n//declare let coreFileUtils: any;\r\n//import { coreFileUtils } from '../../../../assets/js/coreFileUtils';\r\n//const { compressImage, blobToBase64 } = coreFileUtils.prototype;\r\n\r\nconst blobToBase64 = async (blob) => {\r\n  return new Promise((resolve, _) => {\r\n      const reader = new FileReader()\r\n      reader.onloadend = () => resolve(reader.result)\r\n      reader.readAsDataURL(blob)\r\n  })\r\n}\r\n\r\nconst compressImage = async blob => {\r\n  const response = await createImageBitmap(blob)\r\n  const { width, height } = response\r\n  const dWidth = width > height ? 1024 : 1024 * width / height\r\n  const dHeight = width < height ? 1024 : 1024 / width * height\r\n  const offscreen = new OffscreenCanvas(dWidth, dHeight)\r\n  const ctx = offscreen.getContext('2d')\r\n  ctx!.drawImage(response, 0, 0, dWidth, dHeight)\r\n  const result = offscreen.convertToBlob({\r\n      type: 'image/jpeg',\r\n      quality: 0.9,\r\n  })\r\n  return result;\r\n}\r\n\r\nexport enum EnumCoreFileUploaderType {\r\n  IMAGE_AVATAR = 'IMAGE_AVATAR',\r\n  IMAGE_OTHER = 'IMAGE_OTHER',\r\n  PDF = 'PDF',\r\n  DOC = 'DOC',\r\n  EXCEL = 'EXCEL',\r\n  AUDIO = 'AUDIO',\r\n  OTHER = 'OTHER',\r\n}\r\n\r\n@Component({\r\n  selector: 'core-file-uploader',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ThreedotsComponent,\r\n    TranslatePipe,\r\n    MapAvatarToServerPipe\r\n  ],\r\n  templateUrl: './core-file-uploader.component.html',\r\n  styleUrls: ['./core-file-uploader.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreFileUploaderComponent,\r\n    },\r\n  ],\r\n})\r\nexport class CoreFileUploaderComponent extends CoreFormControlBaseComponent implements OnInit, OnDestroy {\r\n  @Input() uploadFileType!: EnumCoreFileUploaderType;\r\n  @Input() fileDataControlName!: string;\r\n  @Input() fileNameControlName!: string;\r\n  @Input() fileTypeControlName!: string;\r\n  @Input() avatarSize!: number;\r\n  @Input() defaultAvatar!: string;\r\n  @Input() hidePreview!: boolean;\r\n  @Input() verticalMode!: boolean;\r\n  @ViewChild('customFileInput') customFileInput!: ElementRef;\r\n\r\n  override value!: string;\r\n\r\n  ngControl!: NgControl;\r\n\r\n  hoverText =\r\n    EnumTranslateKey.UI_CORE_CONTROL_FILE_UPLOADER_CLICK_TO_BROWSE_FILE;\r\n  lang!: string;\r\n  subscriptions: Subscription[] = [];\r\n  chosenFile: any;\r\n  compressedSize: any;\r\n  preview: any;\r\n  loading: boolean = false;\r\n  loadingCaption!: string;\r\n\r\n  accept!: string;\r\n\r\n  constructor(\r\n    private alertService: AlertService,\r\n    private mls: MultiLanguageService,\r\n    private injector: Injector\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    setTimeout(() => this.ngControl = this.injector.get(NgControl));\r\n\r\n    if (isDevMode() && !!!this.uploadFileType) {\r\n      this.alertService.error(\r\n        `Using CoreFileUploaderComponent required property uploadFileType!: EnumCoreFileUploaderType`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n    if (isDevMode() && !!!this.fileDataControlName) {\r\n      this.alertService.error(\r\n        `Using CoreFileUploaderComponent required property fileDataControlName!: string (base64)`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n    if (isDevMode() && !!!this.fileNameControlName) {\r\n      this.alertService.error(\r\n        `Using CoreFileUploaderComponent required property fileNameControlName!: string`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n    if (isDevMode() && !!!this.fileTypeControlName) {\r\n      this.alertService.error(\r\n        `Using CoreFileUploaderComponent required property fileTypeControlName!: string`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n\r\n    this.subscriptions.push(this.mls.lang$.subscribe((x) => (this.lang = x)));\r\n\r\n    if (\r\n      this.uploadFileType === EnumCoreFileUploaderType.IMAGE_AVATAR ||\r\n      this.uploadFileType === EnumCoreFileUploaderType.IMAGE_OTHER\r\n    ) {\r\n      this.accept = 'image/png, image/gif, image/jpeg';\r\n    } else if (\r\n      this.uploadFileType === EnumCoreFileUploaderType.PDF\r\n    ) {\r\n      this.accept = \"application/pdf\";\r\n    } else {\r\n      this.alertService.warn(\r\n        `When uploadFileType===${this.uploadFileType} => TO DO...`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n  }\r\n\r\n  onHover() {\r\n    console.log('onHover');\r\n    this.customFileInput.nativeElement.style.setProperty(\r\n      '--hover-text',\r\n      this.hoverText\r\n    );\r\n  }\r\n\r\n  handleInputChange(e: any) {\r\n    console.log('handleInputChange e', e);\r\n    if (!this.hasFileSize(e.target.files[0].size)) {\r\n      this.alertService.error(\r\n        `File size exceeds 3MB.`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n      return;\r\n    }\r\n    if (!!e.target.files.length) {\r\n      const file = e.target.files[0];\r\n      console.log('handleInputChange file', file);\r\n      this.chosenFile = file;\r\n\r\n      if (\r\n        file.type.split('/')[0] === 'image' ||\r\n        file.type.split('/')[0] === 'application'\r\n      ) {\r\n        const blob = new Blob([file]);\r\n        if (file.type !== 'image/gif') {\r\n          compressImage(blob).then((blob: any) => {\r\n            this.compressedSize = blob.size;\r\n            blobToBase64(blob).then((base64: any) => {\r\n              this.preview = base64;\r\n\r\n              const index = (base64 as string).indexOf('base64,');\r\n              if (index >= 0) {\r\n                base64 = (base64 as string).substring(index + 7);\r\n              }\r\n\r\n              this.onChange(base64);\r\n\r\n              const form = this.ngControl.control?.parent;\r\n              const objectToPatch: any = {};\r\n              objectToPatch[this.fileDataControlName] = base64;\r\n              objectToPatch[this.fileNameControlName] = file.name;\r\n              objectToPatch[this.fileTypeControlName] = file.type;\r\n              form?.patchValue(objectToPatch);\r\n\r\n              this.markAsTouched();\r\n            });\r\n          });\r\n        } else {\r\n          blobToBase64(blob).then((base64: any) => {\r\n            this.compressedSize = blob.size;\r\n            this.preview = base64;\r\n\r\n            const index = (base64 as string).indexOf('base64,');\r\n            if (index >= 0) {\r\n              base64 = (base64 as string).substring(index + 7);\r\n            }\r\n\r\n            this.onChange(base64);\r\n\r\n            const form = this.ngControl.control?.parent;\r\n            const objectToPatch: any = {};\r\n            objectToPatch[this.fileDataControlName] = base64;\r\n            objectToPatch[this.fileNameControlName] = file.name;\r\n            objectToPatch[this.fileTypeControlName] = file.type;\r\n            form?.patchValue(objectToPatch);\r\n\r\n            this.markAsTouched();\r\n          });\r\n        }\r\n      } else if (file.type.split('/')[0] === 'audio') {\r\n        console.log('To do');\r\n      } else {\r\n\r\n      }\r\n    } else {\r\n      this.preview = '';\r\n      this.onChange('');\r\n      this.markAsTouched();\r\n      this.chosenFile = '';\r\n    }\r\n  }\r\n\r\n  hasFileSize(fileSize : any) {\r\n    if (fileSize < 3 * 1024 * 1024) { return true; }\r\n    return false;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.map((x) => x?.unsubscribe());\r\n  }\r\n}\r\n","<div class=\"core-file-uploader-container\">\r\n\r\n    <div *ngIf=\"!!!verticalMode\">\r\n\r\n        <div class=\"row\">\r\n            <div [class]=\"!!hidePreview ? 'col-md-12' : 'col-md-6'\">\r\n                <input id=\"custom-file-input\" #customFileInput class=\"custom-file-input\" type=\"file\" [accept]=\"accept\"\r\n                    (change)=\"handleInputChange($event)\" (hover)=\"onHover()\">\r\n                <label id=\"file-input-label\" for=\"custom-file-input\">\r\n                    <img *ngIf=\"uploadFileType==='IMAGE_AVATAR'\"\r\n                        [src]=\"!!!hidePreview ? (value ? (value | mapAvatarToServer) : defaultAvatar) : (preview ? preview : defaultAvatar)\"\r\n                        class=\"avatar-preview\">\r\n                    <div *ngIf=\"uploadFileType!=='IMAGE_AVATAR'\">{{'EXISTING FILE...'}}</div>\r\n                </label>\r\n                <label id=\"file-input-label\" for=\"custom-file-input\">\r\n                    <input type=\"file\" *ngIf=\"uploadFileType!=='IMAGE_AVATAR'\" [src]=\"value\"\r\n                        (change)=\"handleInputChange($event)\" class=\"\">\r\n                </label>\r\n            </div>\r\n            <div class=\"col-md-2\" *ngIf=\"!!!hidePreview\">\r\n                <div *ngIf=\"!!!loading\">\r\n                    <div class=\"selected-preview\" *ngIf=\"preview\">\r\n                        <img [src]=\"preview\" alt=\"selected-file\">\r\n                    </div>\r\n                </div>\r\n                <app-threedots *ngIf=\"!!loading\"></app-threedots>\r\n            </div>\r\n            <div class=\"col-md-4 d-none\" *ngIf=\"!!!hidePreview\">\r\n                <ng-container *ngIf=\"!!chosenFile\">\r\n\r\n                    <div>\r\n                        <div>\r\n                            {{ 'UI_CORE_FILE_UPLOADER_FILE_NAME' | translate: lang }}:\r\n                        </div>\r\n                        <div>\r\n                            {{ chosenFile?.name }}\r\n                        </div>\r\n                    </div>\r\n\r\n                    <div>\r\n                        <div>\r\n                            {{ 'UI_CORE_FILE_UPLOADER_FILE_TYPE' | translate: lang }}:\r\n                        </div>\r\n                        <div>\r\n                            {{ chosenFile?.type }}\r\n                        </div>\r\n                    </div>\r\n\r\n                    <div>\r\n                        <div>\r\n                            {{ 'UI_CORE_FILE_UPLOADER_FILE_SIZE' | translate: lang }}:\r\n                        </div>\r\n                        <div>\r\n                            {{ chosenFile?.size }}\r\n                        </div>\r\n                    </div>\r\n                </ng-container>\r\n            </div>\r\n        </div>\r\n\r\n        <!-- <ng-container *ngIf=\"!!compressedSize\">\r\n            <div>\r\n                <div>\r\n                    {{ 'UI_CORE_FILE_UPLOADER_FILE_SIZE_COMPRESSED' | translate: lang }}:\r\n                </div>\r\n                <div>\r\n                    {{ compressedSize }}\r\n                </div>\r\n            </div>\r\n        </ng-container> -->\r\n    </div>\r\n\r\n    <div *ngIf=\"!!verticalMode\" class=\"mt20\">\r\n\r\n        <div class=\"container container-fluid\">\r\n\r\n            <div class=\"row\">\r\n                <div class='col-md-12'>\r\n                    <input id=\"custom-file-input\" #customFileInput class=\"custom-file-input\" type=\"file\"\r\n                        [accept]=\"accept\" (change)=\"handleInputChange($event)\" (hover)=\"onHover()\">\r\n                    <label id=\"file-input-label\" for=\"custom-file-input\">\r\n                        <img *ngIf=\"uploadFileType==='IMAGE_AVATAR'\"\r\n                            [src]=\"!!!hidePreview ? (value ? (value | mapAvatarToServer) : defaultAvatar) : ((value && !!!preview) ? (value | mapAvatarToServer) : (preview ? preview : defaultAvatar))\"\r\n                            class=\"avatar-preview\">\r\n                        <div *ngIf=\"uploadFileType!=='IMAGE_AVATAR'\">{{'EXISTING FILE...'}}</div>\r\n                    </label>\r\n                    <label id=\"file-input-label\" for=\"custom-file-input\">\r\n                        <input type=\"file\" *ngIf=\"uploadFileType!=='IMAGE_AVATAR'\" [src]=\"value\"\r\n                            (change)=\"handleInputChange($event)\" class=\"\">\r\n                    </label>\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"row\">\r\n                <div class=\"col-md-12\" *ngIf=\"!!!hidePreview\">\r\n                    <div *ngIf=\"!!!loading\">\r\n                        <div class=\"selected-preview\" *ngIf=\"preview\">\r\n                            <img [src]=\"preview\" alt=\"selected-file\">\r\n                        </div>\r\n                    </div>\r\n                    <app-threedots *ngIf=\"!!loading\"></app-threedots>\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"row d-none\">\r\n                <div class=\"col-md-12\" *ngIf=\"!!!hidePreview\">\r\n\r\n                    <ng-container *ngIf=\"!!chosenFile\">\r\n\r\n                        <div class=\"row\">\r\n                            <div class='col-md-6'>\r\n                                {{ 'UI_CORE_FILE_UPLOADER_FILE_NAME' | translate: lang }}:\r\n                            </div>\r\n                            <div class='col-md-6'>\r\n                                {{ chosenFile?.name }}\r\n                            </div>\r\n                        </div>\r\n\r\n                        <div class=\"row\">\r\n                            <div class='col-md-6'>\r\n                                {{ 'UI_CORE_FILE_UPLOADER_FILE_TYPE' | translate: lang }}:\r\n                            </div>\r\n                            <div class='col-md-6'>\r\n                                {{ chosenFile?.type }}\r\n                            </div>\r\n                        </div>\r\n\r\n                        <div class=\"row\">\r\n                            <div class='col-md-6'>\r\n                                {{ 'UI_CORE_FILE_UPLOADER_FILE_SIZE' | translate: lang }}:\r\n                            </div>\r\n                            <div class='col-md-6'>\r\n                                {{ chosenFile?.size }}\r\n                            </div>\r\n                        </div>\r\n\r\n                    </ng-container>\r\n\r\n                    <ng-container *ngIf=\"!!compressedSize\">\r\n                        <div class=\"row\">\r\n                            <div class='col-md-6'>\r\n                                {{ 'UI_CORE_FILE_UPLOADER_FILE_SIZE_COMPRESSED' | translate: lang }}:\r\n                            </div>\r\n                            <div class='col-md-6'>\r\n                                {{ compressedSize }}\r\n                            </div>\r\n                        </div>\r\n                    </ng-container>\r\n\r\n                </div>\r\n            </div>\r\n\r\n        </div>\r\n\r\n    </div>\r\n\r\n</div>"]}