slick-components 4.4.18 → 4.4.19
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/slick-calendar/slick-calendar.component.mjs +2 -3
- package/esm2020/slick-date-picker/slick-date-picker.component.mjs +2 -3
- package/esm2020/slick-file-list/slick-file-list-item.component.mjs +2 -3
- package/esm2020/utils/slick-init.service.mjs +2 -2
- package/fesm2015/slick-components.mjs +33 -36
- package/fesm2015/slick-components.mjs.map +1 -1
- package/fesm2020/slick-components.mjs +33 -36
- package/fesm2020/slick-components.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -1,10 +1,9 @@
|
|
|
1
1
|
import { Component, forwardRef, Input, Output, EventEmitter, HostListener } from "@angular/core";
|
|
2
2
|
import { SlickUtilsService } from "../utils/slick-utils.service";
|
|
3
3
|
import { NG_VALUE_ACCESSOR } from "@angular/forms";
|
|
4
|
-
import
|
|
4
|
+
import moment from "moment";
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@angular/common";
|
|
7
|
-
const moment = _moment;
|
|
8
7
|
class DayModel {
|
|
9
8
|
}
|
|
10
9
|
class WeekModel {
|
|
@@ -244,4 +243,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.3", ngImpor
|
|
|
244
243
|
type: HostListener,
|
|
245
244
|
args: ['click', ['$event', '$event.target']]
|
|
246
245
|
}] } });
|
|
247
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slick-calendar.component.js","sourceRoot":"","sources":["../../../../projects/components/src/slick-calendar/slick-calendar.component.ts","../../../../projects/components/src/slick-calendar/slick-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, OnInit, OnChanges, SimpleChanges, Input, Output, EventEmitter, HostListener } from \"@angular/core\";\r\nimport { SlickUtilsService } from \"../utils/slick-utils.service\";\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\r\nimport * as _moment from \"moment\"; const moment = _moment;\r\n\r\n\r\nclass DayModel {\r\n\tdate: Date;\r\n\tisSelected: boolean;\r\n\tisToday: boolean;\r\n\tisInCurrentMonth: boolean;\r\n\tisActive: boolean;\r\n}\r\n\r\nclass WeekModel {\r\n\tdays: DayModel[];\r\n}\r\n\r\nclass MonthModel {\r\n\tmonthDisplay: string;\r\n\tweeks: WeekModel[]\r\n}\r\n\r\n@Component({\r\n\tselector: 'slick-calendar',\r\n\ttemplateUrl: 'slick-calendar.component.html',\r\n\tproviders: [\r\n\t\t{\r\n\t\t\tprovide: NG_VALUE_ACCESSOR,\r\n\t\t\tuseExisting: forwardRef(() => SlickCalendarComponent),\r\n\t\t\tmulti: true,\r\n\t\t}]\r\n})\r\nexport class SlickCalendarComponent implements ControlValueAccessor, OnInit, OnChanges {\r\n\t@Input() condensed: boolean = false;\r\n\t@Input() monthsToShow: number = 1;\r\n\t@Input() inactiveDates: Date[] = [];\r\n\t@Input() inactiveWeekends: boolean = false;\r\n\t@Input() showDaysNotInMonth: boolean = false;\r\n\t@Input() multiSelect: boolean = false;\r\n\t@Input() multiSelectDates: Date[];\r\n\t@Output() multiSelectDatesChange: EventEmitter<Date[]> = new EventEmitter<Date[]>();\r\n\t@Output() onDateSelect: EventEmitter<Date> = new EventEmitter<Date>();\r\n\t@Output() onDateChange: EventEmitter<Date> = new EventEmitter<Date>();\r\n\t@Output() onMonthChange: EventEmitter<Date> = new EventEmitter<Date>();\r\n\t@Output() onMultiDateChange: EventEmitter<Date[]> = new EventEmitter<Date[]>();\r\n\r\n\t@HostListener('click', ['$event', '$event.target'])\r\n\tonClick(event: MouseEvent, targetElement: HTMLElement): void {\r\n\t\tif (!targetElement || SlickUtilsService.checkParentClassExists(targetElement, \"slickCalendar_month\"))\r\n\t\t\treturn;\r\n\t}\r\n\r\n\tuuid: string;\r\n\tselectedDate: Date = new Date();\r\n\tvisibleDate: Date = new Date();\r\n\tmonths: MonthModel[];\r\n\tminWidth: number;\r\n\r\n\tconstructor() {\r\n\t\tthis.uuid = SlickUtilsService.newGuid();\r\n\t}\r\n\r\n\tngOnInit() {\r\n\t\tthis.recalc();\r\n\t}\r\n\r\n\tasync ngOnChanges(changes: SimpleChanges) {\r\n\t\tif (changes.condensed)\r\n\t\t\tthis.condensed = (this.condensed || 'false').toString().toLowerCase() === 'true' ? true : false;\r\n\r\n\t\tif (changes.inactiveWeekends)\r\n\t\t\tthis.inactiveWeekends = (this.inactiveWeekends || 'true').toString().toLowerCase() === 'false' ? false : true;\r\n\r\n\t\tif (changes.showDaysNotInMonth)\r\n\t\t\tthis.showDaysNotInMonth = (this.showDaysNotInMonth || 'false').toString().toLowerCase() === 'true' ? true : false;\r\n\r\n\t\tif (changes.multiSelect)\r\n\t\t\tthis.multiSelect = (this.multiSelect || 'false').toString().toLowerCase() === 'true' ? true : false;\r\n\r\n\t\tconst widthPerCalendar = (this.condensed) ? 180 : 250;\r\n\t\tthis.minWidth = this.monthsToShow * widthPerCalendar;\r\n\r\n\t\tthis.recalc();\r\n\r\n\t}\r\n\r\n\tpropagateChange = (_: any) => { };\r\n\r\n\t// this is the initial value set to the component\r\n\twriteValue(obj: any) {\r\n\t\tif (obj) {\r\n\t\t\tif (moment(obj).isValid()) {\r\n\t\t\t\tthis.selectedDate = obj;\r\n\t\t\t\tthis.visibleDate = obj;\r\n\t\t\t\tthis.recalc();\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\tthis.selectedDate = null;\r\n\t\t\t}\r\n\t\t}\r\n\t\telse {\r\n\t\t\tif (!this.selectedDate && this.onDateChange)\r\n\t\t\t\tthis.onDateChange.emit(null);\r\n\t\t\tthis.selectedDate = null;\r\n\t\t}\r\n\t}\r\n\r\n\t// registers 'fn' that will be fired when changes are made\r\n\t// this is how we emit the changes back to the form\r\n\tregisterOnChange(fn: any) {\r\n\t\tthis.propagateChange = fn;\r\n\t}\r\n\r\n\t// not used, used for touch input\r\n\tregisterOnTouched() { }\r\n\r\n\tprevMonth() {\r\n\t\tthis.visibleDate = moment(this.visibleDate).subtract(this.monthsToShow, \"months\").toDate();\r\n\t\tthis.recalc();\r\n\r\n\t\tif (this.onMonthChange) {\r\n\t\t\tlet monthStart = moment(this.visibleDate).startOf(\"month\");\r\n\t\t\tif (this.showDaysNotInMonth === true)\r\n\t\t\t\tmonthStart = monthStart.startOf(\"week\");\r\n\r\n\t\t\tthis.onMonthChange.emit(monthStart.toDate());\r\n\t\t}\r\n\t}\r\n\r\n\tnextMonth() {\r\n\t\tthis.visibleDate = moment(this.visibleDate).add(this.monthsToShow, \"months\").toDate();\r\n\t\tthis.recalc();\r\n\r\n\t\tif (this.onMonthChange) {\r\n\t\t\tlet monthStart = moment(this.visibleDate).startOf(\"month\");\r\n\t\t\tif (this.showDaysNotInMonth === true)\r\n\t\t\t\tmonthStart = monthStart.startOf(\"week\");\r\n\r\n\t\t\tthis.onMonthChange.emit(monthStart.toDate());\r\n\t\t}\r\n\t}\r\n\r\n\tselectMonth(monthIdx) {\r\n\t\tconst month = this.months[monthIdx];\r\n\t\tlet visibleDate = moment(this.visibleDate);\r\n\t\tlet dateString = month + visibleDate.format(\" 1, YYYY\");\r\n\r\n\t\tthis.visibleDate = moment(dateString, \"MMMM DD, YYYY\").toDate();\r\n\t\tthis.recalc();\r\n\t}\r\n\r\n\tsetDate(dayModel: DayModel) {\r\n\t\tif (this.showDaysNotInMonth === false && dayModel.isInCurrentMonth === false)\r\n\t\t\treturn;\r\n\r\n\t\tif (dayModel.isActive === false)\r\n\t\t\treturn;\r\n\r\n\t\tif (this.multiSelect === false) {\r\n\t\t\tthis.selectedDate = dayModel.date;\r\n\t\t\tthis.visibleDate = dayModel.date;\r\n\r\n\t\t\tthis.propagateChange(this.selectedDate);\r\n\r\n\t\t\tif (this.onDateChange)\r\n\t\t\t\tthis.onDateChange.emit(this.selectedDate);\r\n\r\n\t\t\tif (this.onDateSelect)\r\n\t\t\t\tthis.onDateSelect.emit(this.selectedDate);\r\n\r\n\t\t\t// Say we have 3 months showing and they select a date on the 3rd month\r\n\t\t\t// Recalc will re-draw the 3rd month as the first month instead of just \r\n\t\t\t// higlighting the date on the 3rd month.  Highlight instead.\r\n\t\t\tlet dateFound = false;\r\n\t\t\tfor (let month of this.months) {\r\n\t\t\t\tfor (let week of month.weeks) {\r\n\t\t\t\t\tfor (let day of week.days) {\r\n\t\t\t\t\t\tday.isSelected = false;\r\n\t\t\t\t\t\tif (day.isInCurrentMonth === true && moment(day.date).isSame(this.selectedDate, \"date\")) {\r\n\t\t\t\t\t\t\tday.isSelected = true;\r\n\t\t\t\t\t\t\tdateFound = true;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t\t// But if they've \r\n\t\t\tif (dateFound === false)\r\n\t\t\t\tthis.recalc();\r\n\t\t}\r\n\t\telse {\r\n\t\t\t// This will be reversed since we haven't re-calced the dates yet.\r\n\t\t\tif (!dayModel.isSelected)\r\n\t\t\t\tthis.multiSelectDates.push(dayModel.date);\r\n\t\t\telse {\r\n\t\t\t\tlet dateIdx = this.multiSelectDates.findIndex(d => moment(d).startOf(\"date\").isSame(moment(dayModel.date).startOf(\"date\")));\r\n\t\t\t\tthis.multiSelectDates.splice(dateIdx, 1);\r\n\t\t\t}\r\n\r\n\t\t\tif (this.onMultiDateChange)\r\n\t\t\t\tthis.onMultiDateChange.emit(this.multiSelectDates)\r\n\r\n\t\t\tfor (let month of this.months) {\r\n\t\t\t\tfor (let week of month.weeks) {\r\n\t\t\t\t\tfor (let day of week.days) {\r\n\t\t\t\t\t\tday.isSelected = false;\r\n\t\t\t\t\t\tif (day.isInCurrentMonth === true && (this.multiSelectDates.findIndex(x => moment(x).isSame(moment(day.date), \"date\")) >= 0)) {\r\n\t\t\t\t\t\t\tday.isSelected = true;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t}\r\n\t}\r\n\r\n\tprivate recalc() {\r\n\t\tthis.months = [];\r\n\r\n\t\tfor (let monthCount = 0; monthCount < this.monthsToShow; monthCount++) {\r\n\t\t\tlet currentDate = moment(this.visibleDate).startOf(\"month\");\r\n\t\t\tcurrentDate = moment(currentDate).add(monthCount, \"months\")\r\n\t\t\tcurrentDate = moment(currentDate).startOf(\"week\").startOf(\"date\");\r\n\r\n\t\t\tconst month = new MonthModel();\r\n\t\t\tmonth.weeks = [];\r\n\r\n\t\t\t// CurrentDate is most likely going to be the month before, so add 15 days to get to the middle of the current month\r\n\t\t\tconst monthToDisplay = moment(currentDate).add(15, \"days\");\r\n\t\t\tmonth.monthDisplay = (this.condensed === true) ? monthToDisplay.format(\"MMM YYYY\") : monthToDisplay.format(\"MMM YYYY\");\r\n\r\n\t\t\tfor (let weekCount = 0; weekCount < 6; weekCount++) {\r\n\t\t\t\tconst week = new WeekModel();\r\n\t\t\t\tweek.days = [];\r\n\r\n\t\t\t\tfor (let dayCount = 0; dayCount < 7; dayCount++) {\r\n\t\t\t\t\tconst day = new DayModel();\r\n\t\t\t\t\tday.date = currentDate.toDate();\r\n\t\t\t\t\tday.isToday = moment().isSame(currentDate, \"date\");\r\n\t\t\t\t\tif (this.multiSelect && this.multiSelectDates)\r\n\t\t\t\t\t\tday.isSelected = (this.multiSelectDates.findIndex(x => moment(x).isSame(moment(day.date), \"date\")) >= 0);\r\n\t\t\t\t\telse\r\n\t\t\t\t\t\tday.isSelected = moment(this.selectedDate).isSame(currentDate, \"date\");\r\n\r\n\t\t\t\t\tday.isInCurrentMonth = (currentDate.month() === monthToDisplay.month());\r\n\r\n\t\t\t\t\tday.isActive = true;\r\n\r\n\t\t\t\t\tif (this.inactiveWeekends && currentDate.day() === 6 || currentDate.day() === 7)\r\n\t\t\t\t\t\tday.isActive = false;\r\n\r\n\t\t\t\t\tif (this.inactiveDates && this.inactiveDates.findIndex(x => moment(x).isSame(currentDate, \"date\")) >= 0)\r\n\t\t\t\t\t\tday.isActive = false;\r\n\r\n\t\t\t\t\tif (this.showDaysNotInMonth === false && day.isInCurrentMonth === false)\r\n\t\t\t\t\t\tday.isActive = false;\r\n\r\n\t\t\t\t\t// It's possible for the day to be in the month display, but hidden, but active\r\n\t\t\t\t\tif (day.isActive === false)\r\n\t\t\t\t\t\tday.isSelected = false;\r\n\r\n\t\t\t\t\tif (day.isInCurrentMonth === false)\r\n\t\t\t\t\t\tday.isSelected = false;\r\n\r\n\t\t\t\t\tweek.days.push(day);\r\n\r\n\t\t\t\t\tcurrentDate = moment(currentDate).add(1, \"days\");\r\n\t\t\t\t}\r\n\r\n\t\t\t\tmonth.weeks.push(week);\r\n\t\t\t}\r\n\r\n\t\t\tthis.months.push(month);\r\n\t\t}\r\n\t}\r\n\r\n}","<div class=\"slick-calendar default-width card\" id=\"slick-calendar_{{uuid}}\" [style.minWidth.px]=\"minWidth\" [ngClass]=\"{'slick-calendar_condensed': condensed === true, 'slick-calendar_single': monthsToShow === 1 }\">\r\n\t<div class=\"slick-calendar_prev-month\" (click)=\"prevMonth()\"><i class=\"far fa-chevron-left\"></i></div>\r\n\t<div class=\"slick-calendar_next-month\" (click)=\"nextMonth()\"><i class=\"far fa-chevron-right\"></i></div>\r\n\r\n\t<div class=\"d-flex justify-content-around pt-2\" [ngClass]=\"{ 'mx-3': monthsToShow > 1, 'mx-1': monthsToShow === 1 }\">\r\n\t\t<div *ngFor=\"let month of months\" class=\"flex-fill mx-2\" style=\"text-align: center;max-width: 220px;\">\r\n\r\n\t\t\t<table class=\"table table-sm table-borderless\" style=\"table-layout: fixed; \">\r\n\t\t\t\t<thead>\r\n\t\t\t\t\t<tr class=\"slick-calendar_month-display\">\r\n\t\t\t\t\t\t<td colspan=\"7\"><b>{{month.monthDisplay}}</b></td>\r\n\t\t\t\t\t</tr>\r\n\t\t\t\t\t<tr class=\"slick-calendar_days-of-week\">\r\n\t\t\t\t\t\t<td><span *ngIf='condensed === false'>Sun</span><span *ngIf='condensed === true'>S</span></td>\r\n\t\t\t\t\t\t<td><span *ngIf='condensed === false'>Mon</span><span *ngIf='condensed === true'>M</span></td>\r\n\t\t\t\t\t\t<td><span *ngIf='condensed === false'>Tue</span><span *ngIf='condensed === true'>T</span></td>\r\n\t\t\t\t\t\t<td><span *ngIf='condensed === false'>Wed</span><span *ngIf='condensed === true'>W</span></td>\r\n\t\t\t\t\t\t<td><span *ngIf='condensed === false'>Thu</span><span *ngIf='condensed === true'>Th</span></td>\r\n\t\t\t\t\t\t<td><span *ngIf='condensed === false'>Fri</span><span *ngIf='condensed === true'>F</span></td>\r\n\t\t\t\t\t\t<td><span *ngIf='condensed === false'>Sat</span><span *ngIf='condensed === true'>S</span></td>\r\n\t\t\t\t\t</tr>\r\n\t\t\t\t</thead>\r\n\r\n\t\t\t\t<tbody>\r\n\t\t\t\t\t<tr *ngFor=\"let week of month.weeks\">\r\n\t\t\t\t\t\t<td *ngFor=\"let day of week.days\" (click)=\"setDate(day)\" class=\"slick-calendar_date\" [ngClass]=\"{ 'slick-calendar_is-today': day.isToday, 'bg-success text-white': day.isSelected, 'slick-calendar_not_in_month': day.isInCurrentMonth === false, 'slick-calendar_inactive': day.isActive === false }\">\r\n\t\t\t\t\t\t\t<span *ngIf=\"showDaysNotInMonth === true || (showDaysNotInMonth === false && day.isInCurrentMonth === true)\">{{day.date | date:'d'}}</span>\r\n\t\t\t\t\t\t\t<span *ngIf=\"monthsToShow > 1 && (showDaysNotInMonth === false && day.isInCurrentMonth === false)\">&nbsp;</span>\r\n\t\t\t\t\t\t</td>\r\n\t\t\t\t\t</tr>\r\n\t\t\t\t</tbody>\r\n\t\t\t</table>\r\n\r\n\r\n\t\t</div>\r\n\r\n\t</div>\r\n</div>"]}
|
|
246
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slick-calendar.component.js","sourceRoot":"","sources":["../../../../projects/components/src/slick-calendar/slick-calendar.component.ts","../../../../projects/components/src/slick-calendar/slick-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, OnInit, OnChanges, SimpleChanges, Input, Output, EventEmitter, HostListener } from \"@angular/core\";\r\nimport { SlickUtilsService } from \"../utils/slick-utils.service\";\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\r\nimport moment from \"moment\";\r\n\r\n\r\nclass DayModel {\r\n\tdate: Date;\r\n\tisSelected: boolean;\r\n\tisToday: boolean;\r\n\tisInCurrentMonth: boolean;\r\n\tisActive: boolean;\r\n}\r\n\r\nclass WeekModel {\r\n\tdays: DayModel[];\r\n}\r\n\r\nclass MonthModel {\r\n\tmonthDisplay: string;\r\n\tweeks: WeekModel[]\r\n}\r\n\r\n@Component({\r\n\tselector: 'slick-calendar',\r\n\ttemplateUrl: 'slick-calendar.component.html',\r\n\tproviders: [\r\n\t\t{\r\n\t\t\tprovide: NG_VALUE_ACCESSOR,\r\n\t\t\tuseExisting: forwardRef(() => SlickCalendarComponent),\r\n\t\t\tmulti: true,\r\n\t\t}]\r\n})\r\nexport class SlickCalendarComponent implements ControlValueAccessor, OnInit, OnChanges {\r\n\t@Input() condensed: boolean = false;\r\n\t@Input() monthsToShow: number = 1;\r\n\t@Input() inactiveDates: Date[] = [];\r\n\t@Input() inactiveWeekends: boolean = false;\r\n\t@Input() showDaysNotInMonth: boolean = false;\r\n\t@Input() multiSelect: boolean = false;\r\n\t@Input() multiSelectDates: Date[];\r\n\t@Output() multiSelectDatesChange: EventEmitter<Date[]> = new EventEmitter<Date[]>();\r\n\t@Output() onDateSelect: EventEmitter<Date> = new EventEmitter<Date>();\r\n\t@Output() onDateChange: EventEmitter<Date> = new EventEmitter<Date>();\r\n\t@Output() onMonthChange: EventEmitter<Date> = new EventEmitter<Date>();\r\n\t@Output() onMultiDateChange: EventEmitter<Date[]> = new EventEmitter<Date[]>();\r\n\r\n\t@HostListener('click', ['$event', '$event.target'])\r\n\tonClick(event: MouseEvent, targetElement: HTMLElement): void {\r\n\t\tif (!targetElement || SlickUtilsService.checkParentClassExists(targetElement, \"slickCalendar_month\"))\r\n\t\t\treturn;\r\n\t}\r\n\r\n\tuuid: string;\r\n\tselectedDate: Date = new Date();\r\n\tvisibleDate: Date = new Date();\r\n\tmonths: MonthModel[];\r\n\tminWidth: number;\r\n\r\n\tconstructor() {\r\n\t\tthis.uuid = SlickUtilsService.newGuid();\r\n\t}\r\n\r\n\tngOnInit() {\r\n\t\tthis.recalc();\r\n\t}\r\n\r\n\tasync ngOnChanges(changes: SimpleChanges) {\r\n\t\tif (changes.condensed)\r\n\t\t\tthis.condensed = (this.condensed || 'false').toString().toLowerCase() === 'true' ? true : false;\r\n\r\n\t\tif (changes.inactiveWeekends)\r\n\t\t\tthis.inactiveWeekends = (this.inactiveWeekends || 'true').toString().toLowerCase() === 'false' ? false : true;\r\n\r\n\t\tif (changes.showDaysNotInMonth)\r\n\t\t\tthis.showDaysNotInMonth = (this.showDaysNotInMonth || 'false').toString().toLowerCase() === 'true' ? true : false;\r\n\r\n\t\tif (changes.multiSelect)\r\n\t\t\tthis.multiSelect = (this.multiSelect || 'false').toString().toLowerCase() === 'true' ? true : false;\r\n\r\n\t\tconst widthPerCalendar = (this.condensed) ? 180 : 250;\r\n\t\tthis.minWidth = this.monthsToShow * widthPerCalendar;\r\n\r\n\t\tthis.recalc();\r\n\r\n\t}\r\n\r\n\tpropagateChange = (_: any) => { };\r\n\r\n\t// this is the initial value set to the component\r\n\twriteValue(obj: any) {\r\n\t\tif (obj) {\r\n\t\t\tif (moment(obj).isValid()) {\r\n\t\t\t\tthis.selectedDate = obj;\r\n\t\t\t\tthis.visibleDate = obj;\r\n\t\t\t\tthis.recalc();\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\tthis.selectedDate = null;\r\n\t\t\t}\r\n\t\t}\r\n\t\telse {\r\n\t\t\tif (!this.selectedDate && this.onDateChange)\r\n\t\t\t\tthis.onDateChange.emit(null);\r\n\t\t\tthis.selectedDate = null;\r\n\t\t}\r\n\t}\r\n\r\n\t// registers 'fn' that will be fired when changes are made\r\n\t// this is how we emit the changes back to the form\r\n\tregisterOnChange(fn: any) {\r\n\t\tthis.propagateChange = fn;\r\n\t}\r\n\r\n\t// not used, used for touch input\r\n\tregisterOnTouched() { }\r\n\r\n\tprevMonth() {\r\n\t\tthis.visibleDate = moment(this.visibleDate).subtract(this.monthsToShow, \"months\").toDate();\r\n\t\tthis.recalc();\r\n\r\n\t\tif (this.onMonthChange) {\r\n\t\t\tlet monthStart = moment(this.visibleDate).startOf(\"month\");\r\n\t\t\tif (this.showDaysNotInMonth === true)\r\n\t\t\t\tmonthStart = monthStart.startOf(\"week\");\r\n\r\n\t\t\tthis.onMonthChange.emit(monthStart.toDate());\r\n\t\t}\r\n\t}\r\n\r\n\tnextMonth() {\r\n\t\tthis.visibleDate = moment(this.visibleDate).add(this.monthsToShow, \"months\").toDate();\r\n\t\tthis.recalc();\r\n\r\n\t\tif (this.onMonthChange) {\r\n\t\t\tlet monthStart = moment(this.visibleDate).startOf(\"month\");\r\n\t\t\tif (this.showDaysNotInMonth === true)\r\n\t\t\t\tmonthStart = monthStart.startOf(\"week\");\r\n\r\n\t\t\tthis.onMonthChange.emit(monthStart.toDate());\r\n\t\t}\r\n\t}\r\n\r\n\tselectMonth(monthIdx) {\r\n\t\tconst month = this.months[monthIdx];\r\n\t\tlet visibleDate = moment(this.visibleDate);\r\n\t\tlet dateString = month + visibleDate.format(\" 1, YYYY\");\r\n\r\n\t\tthis.visibleDate = moment(dateString, \"MMMM DD, YYYY\").toDate();\r\n\t\tthis.recalc();\r\n\t}\r\n\r\n\tsetDate(dayModel: DayModel) {\r\n\t\tif (this.showDaysNotInMonth === false && dayModel.isInCurrentMonth === false)\r\n\t\t\treturn;\r\n\r\n\t\tif (dayModel.isActive === false)\r\n\t\t\treturn;\r\n\r\n\t\tif (this.multiSelect === false) {\r\n\t\t\tthis.selectedDate = dayModel.date;\r\n\t\t\tthis.visibleDate = dayModel.date;\r\n\r\n\t\t\tthis.propagateChange(this.selectedDate);\r\n\r\n\t\t\tif (this.onDateChange)\r\n\t\t\t\tthis.onDateChange.emit(this.selectedDate);\r\n\r\n\t\t\tif (this.onDateSelect)\r\n\t\t\t\tthis.onDateSelect.emit(this.selectedDate);\r\n\r\n\t\t\t// Say we have 3 months showing and they select a date on the 3rd month\r\n\t\t\t// Recalc will re-draw the 3rd month as the first month instead of just \r\n\t\t\t// higlighting the date on the 3rd month.  Highlight instead.\r\n\t\t\tlet dateFound = false;\r\n\t\t\tfor (let month of this.months) {\r\n\t\t\t\tfor (let week of month.weeks) {\r\n\t\t\t\t\tfor (let day of week.days) {\r\n\t\t\t\t\t\tday.isSelected = false;\r\n\t\t\t\t\t\tif (day.isInCurrentMonth === true && moment(day.date).isSame(this.selectedDate, \"date\")) {\r\n\t\t\t\t\t\t\tday.isSelected = true;\r\n\t\t\t\t\t\t\tdateFound = true;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t\t// But if they've \r\n\t\t\tif (dateFound === false)\r\n\t\t\t\tthis.recalc();\r\n\t\t}\r\n\t\telse {\r\n\t\t\t// This will be reversed since we haven't re-calced the dates yet.\r\n\t\t\tif (!dayModel.isSelected)\r\n\t\t\t\tthis.multiSelectDates.push(dayModel.date);\r\n\t\t\telse {\r\n\t\t\t\tlet dateIdx = this.multiSelectDates.findIndex(d => moment(d).startOf(\"date\").isSame(moment(dayModel.date).startOf(\"date\")));\r\n\t\t\t\tthis.multiSelectDates.splice(dateIdx, 1);\r\n\t\t\t}\r\n\r\n\t\t\tif (this.onMultiDateChange)\r\n\t\t\t\tthis.onMultiDateChange.emit(this.multiSelectDates)\r\n\r\n\t\t\tfor (let month of this.months) {\r\n\t\t\t\tfor (let week of month.weeks) {\r\n\t\t\t\t\tfor (let day of week.days) {\r\n\t\t\t\t\t\tday.isSelected = false;\r\n\t\t\t\t\t\tif (day.isInCurrentMonth === true && (this.multiSelectDates.findIndex(x => moment(x).isSame(moment(day.date), \"date\")) >= 0)) {\r\n\t\t\t\t\t\t\tday.isSelected = true;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t}\r\n\t}\r\n\r\n\tprivate recalc() {\r\n\t\tthis.months = [];\r\n\r\n\t\tfor (let monthCount = 0; monthCount < this.monthsToShow; monthCount++) {\r\n\t\t\tlet currentDate = moment(this.visibleDate).startOf(\"month\");\r\n\t\t\tcurrentDate = moment(currentDate).add(monthCount, \"months\")\r\n\t\t\tcurrentDate = moment(currentDate).startOf(\"week\").startOf(\"date\");\r\n\r\n\t\t\tconst month = new MonthModel();\r\n\t\t\tmonth.weeks = [];\r\n\r\n\t\t\t// CurrentDate is most likely going to be the month before, so add 15 days to get to the middle of the current month\r\n\t\t\tconst monthToDisplay = moment(currentDate).add(15, \"days\");\r\n\t\t\tmonth.monthDisplay = (this.condensed === true) ? monthToDisplay.format(\"MMM YYYY\") : monthToDisplay.format(\"MMM YYYY\");\r\n\r\n\t\t\tfor (let weekCount = 0; weekCount < 6; weekCount++) {\r\n\t\t\t\tconst week = new WeekModel();\r\n\t\t\t\tweek.days = [];\r\n\r\n\t\t\t\tfor (let dayCount = 0; dayCount < 7; dayCount++) {\r\n\t\t\t\t\tconst day = new DayModel();\r\n\t\t\t\t\tday.date = currentDate.toDate();\r\n\t\t\t\t\tday.isToday = moment().isSame(currentDate, \"date\");\r\n\t\t\t\t\tif (this.multiSelect && this.multiSelectDates)\r\n\t\t\t\t\t\tday.isSelected = (this.multiSelectDates.findIndex(x => moment(x).isSame(moment(day.date), \"date\")) >= 0);\r\n\t\t\t\t\telse\r\n\t\t\t\t\t\tday.isSelected = moment(this.selectedDate).isSame(currentDate, \"date\");\r\n\r\n\t\t\t\t\tday.isInCurrentMonth = (currentDate.month() === monthToDisplay.month());\r\n\r\n\t\t\t\t\tday.isActive = true;\r\n\r\n\t\t\t\t\tif (this.inactiveWeekends && currentDate.day() === 6 || currentDate.day() === 7)\r\n\t\t\t\t\t\tday.isActive = false;\r\n\r\n\t\t\t\t\tif (this.inactiveDates && this.inactiveDates.findIndex(x => moment(x).isSame(currentDate, \"date\")) >= 0)\r\n\t\t\t\t\t\tday.isActive = false;\r\n\r\n\t\t\t\t\tif (this.showDaysNotInMonth === false && day.isInCurrentMonth === false)\r\n\t\t\t\t\t\tday.isActive = false;\r\n\r\n\t\t\t\t\t// It's possible for the day to be in the month display, but hidden, but active\r\n\t\t\t\t\tif (day.isActive === false)\r\n\t\t\t\t\t\tday.isSelected = false;\r\n\r\n\t\t\t\t\tif (day.isInCurrentMonth === false)\r\n\t\t\t\t\t\tday.isSelected = false;\r\n\r\n\t\t\t\t\tweek.days.push(day);\r\n\r\n\t\t\t\t\tcurrentDate = moment(currentDate).add(1, \"days\");\r\n\t\t\t\t}\r\n\r\n\t\t\t\tmonth.weeks.push(week);\r\n\t\t\t}\r\n\r\n\t\t\tthis.months.push(month);\r\n\t\t}\r\n\t}\r\n\r\n}","<div class=\"slick-calendar default-width card\" id=\"slick-calendar_{{uuid}}\" [style.minWidth.px]=\"minWidth\" [ngClass]=\"{'slick-calendar_condensed': condensed === true, 'slick-calendar_single': monthsToShow === 1 }\">\r\n\t<div class=\"slick-calendar_prev-month\" (click)=\"prevMonth()\"><i class=\"far fa-chevron-left\"></i></div>\r\n\t<div class=\"slick-calendar_next-month\" (click)=\"nextMonth()\"><i class=\"far fa-chevron-right\"></i></div>\r\n\r\n\t<div class=\"d-flex justify-content-around pt-2\" [ngClass]=\"{ 'mx-3': monthsToShow > 1, 'mx-1': monthsToShow === 1 }\">\r\n\t\t<div *ngFor=\"let month of months\" class=\"flex-fill mx-2\" style=\"text-align: center;max-width: 220px;\">\r\n\r\n\t\t\t<table class=\"table table-sm table-borderless\" style=\"table-layout: fixed; \">\r\n\t\t\t\t<thead>\r\n\t\t\t\t\t<tr class=\"slick-calendar_month-display\">\r\n\t\t\t\t\t\t<td colspan=\"7\"><b>{{month.monthDisplay}}</b></td>\r\n\t\t\t\t\t</tr>\r\n\t\t\t\t\t<tr class=\"slick-calendar_days-of-week\">\r\n\t\t\t\t\t\t<td><span *ngIf='condensed === false'>Sun</span><span *ngIf='condensed === true'>S</span></td>\r\n\t\t\t\t\t\t<td><span *ngIf='condensed === false'>Mon</span><span *ngIf='condensed === true'>M</span></td>\r\n\t\t\t\t\t\t<td><span *ngIf='condensed === false'>Tue</span><span *ngIf='condensed === true'>T</span></td>\r\n\t\t\t\t\t\t<td><span *ngIf='condensed === false'>Wed</span><span *ngIf='condensed === true'>W</span></td>\r\n\t\t\t\t\t\t<td><span *ngIf='condensed === false'>Thu</span><span *ngIf='condensed === true'>Th</span></td>\r\n\t\t\t\t\t\t<td><span *ngIf='condensed === false'>Fri</span><span *ngIf='condensed === true'>F</span></td>\r\n\t\t\t\t\t\t<td><span *ngIf='condensed === false'>Sat</span><span *ngIf='condensed === true'>S</span></td>\r\n\t\t\t\t\t</tr>\r\n\t\t\t\t</thead>\r\n\r\n\t\t\t\t<tbody>\r\n\t\t\t\t\t<tr *ngFor=\"let week of month.weeks\">\r\n\t\t\t\t\t\t<td *ngFor=\"let day of week.days\" (click)=\"setDate(day)\" class=\"slick-calendar_date\" [ngClass]=\"{ 'slick-calendar_is-today': day.isToday, 'bg-success text-white': day.isSelected, 'slick-calendar_not_in_month': day.isInCurrentMonth === false, 'slick-calendar_inactive': day.isActive === false }\">\r\n\t\t\t\t\t\t\t<span *ngIf=\"showDaysNotInMonth === true || (showDaysNotInMonth === false && day.isInCurrentMonth === true)\">{{day.date | date:'d'}}</span>\r\n\t\t\t\t\t\t\t<span *ngIf=\"monthsToShow > 1 && (showDaysNotInMonth === false && day.isInCurrentMonth === false)\">&nbsp;</span>\r\n\t\t\t\t\t\t</td>\r\n\t\t\t\t\t</tr>\r\n\t\t\t\t</tbody>\r\n\t\t\t</table>\r\n\r\n\r\n\t\t</div>\r\n\r\n\t</div>\r\n</div>"]}
|
|
@@ -2,12 +2,11 @@ import { Component, ViewChild, Input, HostListener, forwardRef, EventEmitter, Ou
|
|
|
2
2
|
import { NG_VALUE_ACCESSOR } from "@angular/forms";
|
|
3
3
|
import { SlickSleepService } from "../utils/slick-sleep.service";
|
|
4
4
|
import { SlickUtilsService } from "../utils/slick-utils.service";
|
|
5
|
-
import
|
|
5
|
+
import moment from "moment";
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
import * as i1 from "../slick-calendar/slick-calendar.component";
|
|
8
8
|
import * as i2 from "@angular/common";
|
|
9
9
|
import * as i3 from "@angular/forms";
|
|
10
|
-
const moment = _moment;
|
|
11
10
|
export class SlickDatePickerComponent {
|
|
12
11
|
constructor(el) {
|
|
13
12
|
this.el = el;
|
|
@@ -276,4 +275,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.3", ngImpor
|
|
|
276
275
|
type: HostListener,
|
|
277
276
|
args: ['blur', ['$event', '$event.target']]
|
|
278
277
|
}] } });
|
|
279
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slick-date-picker.component.js","sourceRoot":"","sources":["../../../../projects/components/src/slick-date-picker/slick-date-picker.component.ts","../../../../projects/components/src/slick-date-picker/slick-date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, ViewChild, Input, HostListener, forwardRef, OnInit, OnDestroy, EventEmitter, Output } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\r\nimport { SlickSleepService } from \"../utils/slick-sleep.service\";\r\nimport { SlickUtilsService } from \"../utils/slick-utils.service\";\r\nimport * as _moment from \"moment\"; const moment = _moment;\r\n\r\n@Component({\r\n\tselector: '[slick-date-picker]',\r\n\tproviders: [\r\n\t\t{\r\n\t\t\tprovide: NG_VALUE_ACCESSOR,\r\n\t\t\tuseExisting: forwardRef(() => SlickDatePickerComponent),\r\n\t\t\tmulti: true\r\n\t\t}],\r\n\ttemplateUrl: 'slick-date-picker.component.html'\r\n})\r\nexport class SlickDatePickerComponent implements OnInit, OnDestroy, ControlValueAccessor {\r\n\t@Input(\"slick-date-picker\") slickDatePicker: SlickDatePickerComponent;\r\n\t@Input(\"slick-date-picker-format\") format: string = \"M/D/YYYY\";\r\n\t@Input(\"slick-date-picker-condensed\") condensed: boolean = false;\r\n\t@Input(\"slick-date-picker-mobile\") mobile: boolean = false;\r\n\t@Output(\"onDateChange\") onDateChange = new EventEmitter<Date>();\r\n\t@ViewChild(\"containerRef\") containerRef: ElementRef;\r\n\r\n\tfnDocumentClick = (e) => this.documentClick(e);\r\n\tfnDocumentMouseDown = (e) => this.documentMouseDown(e);\r\n\r\n\t// Make sure they only press valid keys\r\n\t@HostListener('keydown', ['$event'])\r\n\tasync onKeydown(event: KeyboardEvent) {\t\t\r\n\t\tif (event.altKey || event.ctrlKey || event.metaKey === true)\r\n\t\t\treturn;\r\n\r\n\t\tthis.hideCalendar();\r\n\r\n\t\t// Allow: backspace, delete, tab, escape, enter\r\n\t\tif ((event.keyCode === 46 || event.keyCode === 8) ||\r\n\t\t\t(event.keyCode === 9 || event.keyCode === 27 || event.keyCode === 13) ||\r\n\t\t\t// Allow F1-F12 keys\r\n\t\t\t((event.keyCode >= 112 && event.keyCode <= 123)) ||\r\n\t\t\t// Allow: home, end, left, right, down, up\r\n\t\t\t(event.keyCode >= 35 && event.keyCode <= 40)) {\r\n\t\t\t// let it happen, don't do anything\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\t// Ensure that it is a number and stop the keypress\r\n\t\tif ((event.shiftKey || event.altKey || event.key < '0' || event.key > '9') &&\r\n\t\t\tevent.key !== '/' &&  // Allow /\r\n\t\t\tevent.key !== '-') {  // Allow -\t\t\r\n\t\t\tevent.preventDefault();\r\n\t\t\treturn;\r\n\t\t}\r\n\t}\r\n\r\n\t// When we first focus, show the date picker\r\n\t@HostListener('focus', ['$event'])\r\n\tonFocus(event: FocusEvent): void {\r\n\t\tthis.showCalendar();\r\n\t}\r\n\r\n\t// When we blur, update the model\r\n\t@HostListener('blur', ['$event', '$event.target'])\r\n\tasync onBlur(event: FocusEvent, targetElement: HTMLElement) {\r\n\t\t// If the user clicked on the calendar, it will trigger a mouse down event before the blur event.  Don't blur\r\n\t\t// if they clicked on the calendar.\r\n\t\tif (this.ignoreBlur === true) {\r\n\t\t\tthis.ignoreBlur = false;\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst textVal = this.el.nativeElement.value;\r\n\r\n\t\tif (!textVal) {\r\n\t\t\tthis.doPropagate(null);\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif (moment(textVal, this.format).isValid()) {\r\n\t\t\tvar newDate = moment(textVal, this.format);\r\n\t\t\tthis.doPropagate(newDate.toDate())\r\n\t\t\tthis.el.nativeElement.value = newDate.format(this.format);\r\n\t\t}\r\n\t}\r\n\r\n\tuuid: string = SlickUtilsService.newGuid();\r\n\tignoreBlur: boolean = false;\r\n\tshowDatePicker: boolean = false;\r\n\tdatePickerVisiblity: string = \"hidden\";\r\n\tdatePickerOpacity: string = '0';\r\n\tleft: string;\r\n\ttop: string;\r\n\tselectedDate: Date = null;\r\n\tisInitial = true;\r\n\r\n\tprivate inputGroupPrepend: HTMLElement;\r\n\r\n\tconstructor(private el: ElementRef) {\r\n\t}\r\n\r\n\tasync ngOnInit() {\r\n\r\n\t\tthis.mobile = (this.mobile || 'false').toString().toLowerCase() === 'true' ? true : false;\r\n\t\tthis.condensed = (this.condensed || 'false').toString().toLowerCase() === 'true' ? true : false;\r\n\r\n\t\t// Since this.mobile isn't necessarily defined yet, we need to sleep to allow the ngIf's to do their thing\r\n\t\tawait SlickSleepService.sleep();\r\n\t\t// Remove this from the inline version and put it on the body so that it doesn't hide behind the bottom\r\n\t\t// of a div when it expands beyond the bottom.\r\n\t\tthis.containerRef.nativeElement.remove(this.containerRef);\r\n\t\tdocument.body.appendChild(this.containerRef.nativeElement);\r\n\r\n\t\tawait SlickSleepService.sleep();\r\n\t\tthis.inputGroupPrepend = SlickUtilsService.getClosestSibling(this.el.nativeElement, \"input-group-prepend\");\r\n\t}\r\n\r\n\tngOnDestroy() {\r\n\t\tdocument.removeEventListener(\"mousedown\", this.fnDocumentMouseDown, true);\r\n\t\tdocument.removeEventListener(\"click\", this.fnDocumentClick, true);\r\n\t\t// Is okay if this fails.  It just means it was already removed.\r\n\t\ttry {\r\n\t\t\tdocument.body.removeChild(this.containerRef.nativeElement);\r\n\t\t}\r\n\t\tcatch { }\r\n\t}\r\n\r\n\tpropagateChange = (_: any) => { };\r\n\r\n    private doPropagate(date: Date) {\r\n        // We don't always go through the emit on the first call, so make sure this isn't the first change\r\n        this.isInitial = false;\r\n\r\n\t\tif (!date) {\r\n\t\t\tif (this.selectedDate) {\r\n\t\t\t\tthis.propagateChange(null);\r\n\t\t\t\tthis.emitDateChange(null);\r\n\t\t\t}\r\n\r\n\t\t\tthis.selectedDate = null;\r\n\t\t\treturn;\r\n\t\t}\r\n\t\telse {\r\n\t\t\tconst newDate = moment(date);\r\n\t\t\t// If the date is not valid, return\r\n\t\t\tif (newDate.isValid() === false)\r\n\t\t\t\treturn;\r\n\r\n\t\t\t// Don't propogate if the dates are the same\r\n\t\t\tif (moment(this.selectedDate).isSame(newDate))\r\n\t\t\t\treturn;\r\n\r\n\r\n\t\t\t// Setting this selectedDate will trigger the ngModelChange of the calendar.  Ignore this.\r\n\t\t\tthis.selectedDate = moment(date).startOf(\"date\").toDate();\r\n\t\t\tthis.propagateChange(this.selectedDate);\r\n\t\t\tthis.emitDateChange(this.selectedDate);\r\n\t\t}\r\n\t}\r\n\r\n\tprivate emitDateChange(date: Date) {\r\n\t\tif (this.onDateChange && !this.isInitial)\r\n\t\t\tthis.onDateChange.emit(date);\r\n\r\n\t\tthis.isInitial = false;\r\n\t}\r\n\r\n\t// this is the initial value set to the component\r\n\tpublic writeValue(obj: any) {\r\n\t\tif (obj) {\r\n\t\t\tif (moment(obj).isValid() === false) {\r\n\t\t\t\tthis.selectedDate = null;\r\n                this.el.nativeElement.value = \"Invalid Date\";\r\n                this.isInitial = false;\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\r\n\t\t\tlet updatedDate: moment.Moment;\r\n\t\t\tif (obj instanceof Date || obj.indexOf(\"Z\") >= 0)\r\n\t\t\t\tupdatedDate = moment(obj).startOf(\"date\");\r\n\t\t\telse\r\n\t\t\t\tupdatedDate = moment(obj, this.format).startOf(\"date\");\r\n\r\n            if (moment(this.selectedDate || new Date()).isSame(updatedDate)) {\r\n                this.isInitial = false;\r\n                return;\r\n            }\r\n\r\n\t\t\tthis.selectedDate = updatedDate.toDate();\r\n\t\t\tthis.el.nativeElement.value = moment(this.selectedDate).format(this.format);\r\n\t\t}\r\n\t\telse {\r\n            if (!this.selectedDate && !obj) {\r\n                this.isInitial = false;\r\n                return;\r\n            }\r\n\r\n\t\t\tthis.el.nativeElement.value = '';\r\n\t\t\tthis.selectedDate = null;\r\n\t\t}\r\n\t}\r\n\r\n\t// registers 'fn' that will be fired when changes are made\r\n\t// this is how we emit the changes back to the form\r\n\tpublic registerOnChange(fn: any) {\r\n\t\tthis.propagateChange = fn;\r\n\t}\r\n\r\n\t// not used, used for touch input\r\n\tpublic registerOnTouched() { }\r\n\r\n\tprivate documentMouseDown(e: MouseEvent) {\r\n\t\t// This is the only way to capture that they clicked on the calendar before the blur event\r\n\t\t// fires.  \r\n\t\tif (SlickUtilsService.checkParentClassExists(<HTMLElement>e.target, \"slick-calendar\") === true)\r\n\t\t\tthis.ignoreBlur = true;\r\n\t}\r\n\r\n\tprivate documentClick(e: MouseEvent) {\r\n\t\tif (!e.target)\r\n\t\t\treturn;\r\n\r\n\t\tlet targetElement: HTMLElement = (<HTMLElement>e.target);\r\n\r\n\t\tif (SlickUtilsService.checkParentClassExists(targetElement, \"slick-calendar\") === true)\r\n\t\t\treturn;\r\n\r\n\t\tif (this.inputGroupPrepend && ((targetElement === this.inputGroupPrepend)\r\n\t\t\t|| (targetElement.parentElement && targetElement.parentElement === this.inputGroupPrepend))\r\n\t\t\t|| (targetElement.parentElement && targetElement.parentElement.parentElement && targetElement.parentElement.parentElement === this.inputGroupPrepend)) {\r\n\t\t\tthis.toggleCalendar();\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst clickedInside = this.el.nativeElement.contains(targetElement);\r\n\t\tif (!clickedInside) {\r\n\t\t\tthis.hideCalendar();\r\n\t\t}\r\n\t}\r\n\r\n\tonDateSelect(date) {\r\n\t\tthis.el.nativeElement.value = moment(date).format(this.format);\r\n\t\tthis.hideCalendar();\r\n\r\n\t\tconst newDate = moment(this.el.nativeElement.value, this.format).toDate();\r\n\r\n\t\tthis.doPropagate(newDate);\t\t\r\n\t}\r\n\r\n\tasync showCalendar() {\r\n\t\tdocument.removeEventListener(\"mousedown\", this.fnDocumentMouseDown, true);\r\n\t\tdocument.removeEventListener(\"click\", this.fnDocumentClick, true);\r\n\r\n\t\tthis.showDatePicker = true;\r\n\r\n\t\tif (!this.mobile) {\r\n\t\t\tthis.reposition();\r\n\t\t}\r\n\r\n\t\tthis.datePickerOpacity = '1';\r\n\t\tthis.datePickerVisiblity = 'visible';\r\n\r\n\t\t// Not sure why, but the click event is called immediately, which hides the calendar\r\n\t\tsetTimeout(() => {\r\n\t\t\tdocument.addEventListener(\"mousedown\", this.fnDocumentMouseDown, true);\r\n\t\t\tdocument.addEventListener(\"click\", this.fnDocumentClick, true);\r\n\t\t}, 350)\r\n\t}\r\n\r\n\thideCalendar() {\r\n\t\tdocument.removeEventListener(\"mousedown\", this.fnDocumentMouseDown, true);\r\n\t\tdocument.removeEventListener(\"click\", this.fnDocumentClick, true);\r\n\r\n\t\tthis.datePickerVisiblity = 'hidden';\r\n\t\tthis.datePickerOpacity = '0';\r\n\t\tthis.showDatePicker = false;\r\n\t}\r\n\r\n\tprivate reposition() {\r\n\t\tif (this.mobile === true)\r\n\t\t\treturn;\r\n\r\n\t\t// Reposition the element to be where the textbox is, either below or above if there isn't enough room\r\n\t\tconst inputEl: HTMLInputElement = this.el.nativeElement;\r\n\r\n\t\tconst rect = inputEl.getBoundingClientRect();\r\n\t\tconst textboxLeft = rect.left;\r\n\t\tconst textboxTop = rect.top;\r\n\t\tconst textboxHeight = inputEl.offsetHeight;\r\n\t\tconst containerHeight = (<HTMLDivElement>this.containerRef.nativeElement).offsetHeight;\r\n\r\n\t\tthis.left = textboxLeft + \"px\";\r\n\t\tthis.top = (textboxTop + textboxHeight) + \"px\";\r\n\r\n\t\tif (textboxTop + textboxHeight + containerHeight > window.innerHeight) {\r\n\t\t\tthis.top = (textboxTop - containerHeight - 2) + \"px\";\r\n\t\t}\r\n\r\n\t}\r\n\r\n\ttoggleCalendar() {\r\n\t\t(this.showDatePicker === true) ? this.hideCalendar() : this.showCalendar();\r\n\t}\r\n}","<ng-content></ng-content>\r\n<div *ngIf=\"mobile === false\" #containerRef class=\"slick-date-picker-container\" [style.left]=\"left\" [style.top]=\"top\" [style.visibility]=\"datePickerVisiblity\" [style.opacity]=\"datePickerOpacity\">\r\n\t<slick-calendar [ngModel]=\"selectedDate\" [condensed]=\"condensed\" (onDateSelect)=\"onDateSelect($event)\"></slick-calendar>\r\n</div>\r\n<div *ngIf=\"mobile === true\" #containerRef class=\"slick-date-picker-mobile-container\" [style.visibility]=\"datePickerVisiblity\" [style.opacity]=\"datePickerOpacity\">\r\n\t<div class=\"slick-date-picker-mobile-calendar\">\r\n\t\t<slick-calendar [ngModel]=\"selectedDate\" [condensed]=\"condensed\" (onDateSelect)=\"onDateSelect($event)\"></slick-calendar>\r\n\t</div>\r\n</div>\r\n"]}
|
|
278
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slick-date-picker.component.js","sourceRoot":"","sources":["../../../../projects/components/src/slick-date-picker/slick-date-picker.component.ts","../../../../projects/components/src/slick-date-picker/slick-date-picker.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,SAAS,EAAE,KAAK,EAAE,YAAY,EAAE,UAAU,EAAqB,YAAY,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC3I,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,MAAM,MAAM,QAAQ,CAAC;;;;;AAY5B,MAAM,OAAO,wBAAwB;IAiFpC,YAAoB,EAAc;QAAd,OAAE,GAAF,EAAE,CAAY;QA/EC,WAAM,GAAW,UAAU,CAAC;QACzB,cAAS,GAAY,KAAK,CAAC;QAC9B,WAAM,GAAY,KAAK,CAAC;QACnC,iBAAY,GAAG,IAAI,YAAY,EAAQ,CAAC;QAGhE,oBAAe,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;QAC/C,wBAAmB,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;QA4DvD,SAAI,GAAW,iBAAiB,CAAC,OAAO,EAAE,CAAC;QAC3C,eAAU,GAAY,KAAK,CAAC;QAC5B,mBAAc,GAAY,KAAK,CAAC;QAChC,wBAAmB,GAAW,QAAQ,CAAC;QACvC,sBAAiB,GAAW,GAAG,CAAC;QAGhC,iBAAY,GAAS,IAAI,CAAC;QAC1B,cAAS,GAAG,IAAI,CAAC;QAiCjB,oBAAe,GAAG,CAAC,CAAM,EAAE,EAAE,GAAG,CAAC,CAAC;IA5BlC,CAAC;IAvED,uCAAuC;IAEvC,KAAK,CAAC,SAAS,CAAC,KAAoB;QACnC,IAAI,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,KAAK,IAAI;YAC1D,OAAO;QAER,IAAI,CAAC,YAAY,EAAE,CAAC;QAEpB,+CAA+C;QAC/C,IAAI,CAAC,KAAK,CAAC,OAAO,KAAK,EAAE,IAAI,KAAK,CAAC,OAAO,KAAK,CAAC,CAAC;YAChD,CAAC,KAAK,CAAC,OAAO,KAAK,CAAC,IAAI,KAAK,CAAC,OAAO,KAAK,EAAE,IAAI,KAAK,CAAC,OAAO,KAAK,EAAE,CAAC;YACrE,oBAAoB;YACpB,CAAC,CAAC,KAAK,CAAC,OAAO,IAAI,GAAG,IAAI,KAAK,CAAC,OAAO,IAAI,GAAG,CAAC,CAAC;YAChD,0CAA0C;YAC1C,CAAC,KAAK,CAAC,OAAO,IAAI,EAAE,IAAI,KAAK,CAAC,OAAO,IAAI,EAAE,CAAC,EAAE;YAC9C,mCAAmC;YACnC,OAAO;SACP;QAED,mDAAmD;QACnD,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,GAAG,GAAG,GAAG,IAAI,KAAK,CAAC,GAAG,GAAG,GAAG,CAAC;YACzE,KAAK,CAAC,GAAG,KAAK,GAAG,IAAK,UAAU;YAChC,KAAK,CAAC,GAAG,KAAK,GAAG,EAAE,EAAG,YAAY;YAClC,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,OAAO;SACP;IACF,CAAC;IAED,4CAA4C;IAE5C,OAAO,CAAC,KAAiB;QACxB,IAAI,CAAC,YAAY,EAAE,CAAC;IACrB,CAAC;IAED,iCAAiC;IAEjC,KAAK,CAAC,MAAM,CAAC,KAAiB,EAAE,aAA0B;QACzD,6GAA6G;QAC7G,mCAAmC;QACnC,IAAI,IAAI,CAAC,UAAU,KAAK,IAAI,EAAE;YAC7B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,OAAO;SACP;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC;QAE5C,IAAI,CAAC,OAAO,EAAE;YACb,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;YACvB,OAAO;SACP;QAED,IAAI,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,OAAO,EAAE,EAAE;YAC3C,IAAI,OAAO,GAAG,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;YAC3C,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,CAAA;YAClC,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SAC1D;IACF,CAAC;IAiBD,KAAK,CAAC,QAAQ;QAEb,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,MAAM,IAAI,OAAO,CAAC,CAAC,QAAQ,EAAE,CAAC,WAAW,EAAE,KAAK,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;QAC1F,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,SAAS,IAAI,OAAO,CAAC,CAAC,QAAQ,EAAE,CAAC,WAAW,EAAE,KAAK,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;QAEhG,0GAA0G;QAC1G,MAAM,iBAAiB,CAAC,KAAK,EAAE,CAAC;QAChC,uGAAuG;QACvG,8CAA8C;QAC9C,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAC1D,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;QAE3D,MAAM,iBAAiB,CAAC,KAAK,EAAE,CAAC;QAChC,IAAI,CAAC,iBAAiB,GAAG,iBAAiB,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,qBAAqB,CAAC,CAAC;IAC5G,CAAC;IAED,WAAW;QACV,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,mBAAmB,EAAE,IAAI,CAAC,CAAC;QAC1E,QAAQ,CAAC,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;QAClE,gEAAgE;QAChE,IAAI;YACH,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;SAC3D;QACD,MAAM,GAAG;IACV,CAAC;IAIU,WAAW,CAAC,IAAU;QAC1B,kGAAkG;QAClG,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QAE7B,IAAI,CAAC,IAAI,EAAE;YACV,IAAI,IAAI,CAAC,YAAY,EAAE;gBACtB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;gBAC3B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;aAC1B;YAED,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YACzB,OAAO;SACP;aACI;YACJ,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;YAC7B,mCAAmC;YACnC,IAAI,OAAO,CAAC,OAAO,EAAE,KAAK,KAAK;gBAC9B,OAAO;YAER,4CAA4C;YAC5C,IAAI,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC;gBAC5C,OAAO;YAGR,0FAA0F;YAC1F,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,CAAC;YAC1D,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACxC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SACvC;IACF,CAAC;IAEO,cAAc,CAAC,IAAU;QAChC,IAAI,IAAI,CAAC,YAAY,IAAI,CAAC,IAAI,CAAC,SAAS;YACvC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE9B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACxB,CAAC;IAED,iDAAiD;IAC1C,UAAU,CAAC,GAAQ;QACzB,IAAI,GAAG,EAAE;YACR,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,KAAK,KAAK,EAAE;gBACpC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;gBACb,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,GAAG,cAAc,CAAC;gBAC7C,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;gBACnC,OAAO;aACP;YAED,IAAI,WAA0B,CAAC;YAC/B,IAAI,GAAG,YAAY,IAAI,IAAI,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC;gBAC/C,WAAW,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;;gBAE1C,WAAW,GAAG,MAAM,CAAC,GAAG,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;YAE/C,IAAI,MAAM,CAAC,IAAI,CAAC,YAAY,IAAI,IAAI,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE;gBAC7D,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;gBACvB,OAAO;aACV;YAEV,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC;YACzC,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SAC5E;aACI;YACK,IAAI,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,GAAG,EAAE;gBAC5B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;gBACvB,OAAO;aACV;YAEV,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAC;YACjC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;SACzB;IACF,CAAC;IAED,0DAA0D;IAC1D,mDAAmD;IAC5C,gBAAgB,CAAC,EAAO;QAC9B,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;IAC3B,CAAC;IAED,iCAAiC;IAC1B,iBAAiB,KAAK,CAAC;IAEtB,iBAAiB,CAAC,CAAa;QACtC,0FAA0F;QAC1F,WAAW;QACX,IAAI,iBAAiB,CAAC,sBAAsB,CAAc,CAAC,CAAC,MAAM,EAAE,gBAAgB,CAAC,KAAK,IAAI;YAC7F,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IACzB,CAAC;IAEO,aAAa,CAAC,CAAa;QAClC,IAAI,CAAC,CAAC,CAAC,MAAM;YACZ,OAAO;QAER,IAAI,aAAa,GAA8B,CAAC,CAAC,MAAO,CAAC;QAEzD,IAAI,iBAAiB,CAAC,sBAAsB,CAAC,aAAa,EAAE,gBAAgB,CAAC,KAAK,IAAI;YACrF,OAAO;QAER,IAAI,IAAI,CAAC,iBAAiB,IAAI,CAAC,CAAC,aAAa,KAAK,IAAI,CAAC,iBAAiB,CAAC;eACrE,CAAC,aAAa,CAAC,aAAa,IAAI,aAAa,CAAC,aAAa,KAAK,IAAI,CAAC,iBAAiB,CAAC,CAAC;eACxF,CAAC,aAAa,CAAC,aAAa,IAAI,aAAa,CAAC,aAAa,CAAC,aAAa,IAAI,aAAa,CAAC,aAAa,CAAC,aAAa,KAAK,IAAI,CAAC,iBAAiB,CAAC,EAAE;YACvJ,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,OAAO;SACP;QAED,MAAM,aAAa,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;QACpE,IAAI,CAAC,aAAa,EAAE;YACnB,IAAI,CAAC,YAAY,EAAE,CAAC;SACpB;IACF,CAAC;IAED,YAAY,CAAC,IAAI;QAChB,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC/D,IAAI,CAAC,YAAY,EAAE,CAAC;QAEpB,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,CAAC;QAE1E,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;IAC3B,CAAC;IAED,KAAK,CAAC,YAAY;QACjB,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,mBAAmB,EAAE,IAAI,CAAC,CAAC;QAC1E,QAAQ,CAAC,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;QAElE,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAE3B,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACjB,IAAI,CAAC,UAAU,EAAE,CAAC;SAClB;QAED,IAAI,CAAC,iBAAiB,GAAG,GAAG,CAAC;QAC7B,IAAI,CAAC,mBAAmB,GAAG,SAAS,CAAC;QAErC,oFAAoF;QACpF,UAAU,CAAC,GAAG,EAAE;YACf,QAAQ,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,mBAAmB,EAAE,IAAI,CAAC,CAAC;YACvE,QAAQ,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;QAChE,CAAC,EAAE,GAAG,CAAC,CAAA;IACR,CAAC;IAED,YAAY;QACX,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,mBAAmB,EAAE,IAAI,CAAC,CAAC;QAC1E,QAAQ,CAAC,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;QAElE,IAAI,CAAC,mBAAmB,GAAG,QAAQ,CAAC;QACpC,IAAI,CAAC,iBAAiB,GAAG,GAAG,CAAC;QAC7B,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;IAC7B,CAAC;IAEO,UAAU;QACjB,IAAI,IAAI,CAAC,MAAM,KAAK,IAAI;YACvB,OAAO;QAER,sGAAsG;QACtG,MAAM,OAAO,GAAqB,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC;QAExD,MAAM,IAAI,GAAG,OAAO,CAAC,qBAAqB,EAAE,CAAC;QAC7C,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC;QAC9B,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC;QAC5B,MAAM,aAAa,GAAG,OAAO,CAAC,YAAY,CAAC;QAC3C,MAAM,eAAe,GAAoB,IAAI,CAAC,YAAY,CAAC,aAAc,CAAC,YAAY,CAAC;QAEvF,IAAI,CAAC,IAAI,GAAG,WAAW,GAAG,IAAI,CAAC;QAC/B,IAAI,CAAC,GAAG,GAAG,CAAC,UAAU,GAAG,aAAa,CAAC,GAAG,IAAI,CAAC;QAE/C,IAAI,UAAU,GAAG,aAAa,GAAG,eAAe,GAAG,MAAM,CAAC,WAAW,EAAE;YACtE,IAAI,CAAC,GAAG,GAAG,CAAC,UAAU,GAAG,eAAe,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC;SACrD;IAEF,CAAC;IAED,cAAc;QACb,CAAC,IAAI,CAAC,cAAc,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;IAC5E,CAAC;;wIA7RW,wBAAwB;4HAAxB,wBAAwB,sbARzB;QACV;YACC,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,EAAC,GAAG,EAAE,CAAC,wBAAwB,EAAC;YACvD,KAAK,EAAE,IAAI;SACX;KAAC,wICbJ,kwBASA;2FDOa,wBAAwB;kBAVpC,SAAS;+BACC,qBAAqB,aACpB;wBACV;4BACC,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,EAAC,GAAG,EAAE,yBAAyB,EAAC;4BACvD,KAAK,EAAE,IAAI;yBACX;qBAAC;iGAIyB,eAAe;sBAA1C,KAAK;uBAAC,mBAAmB;gBACS,MAAM;sBAAxC,KAAK;uBAAC,0BAA0B;gBACK,SAAS;sBAA9C,KAAK;uBAAC,6BAA6B;gBACD,MAAM;sBAAxC,KAAK;uBAAC,0BAA0B;gBACT,YAAY;sBAAnC,MAAM;uBAAC,cAAc;gBACK,YAAY;sBAAtC,SAAS;uBAAC,cAAc;gBAOnB,SAAS;sBADd,YAAY;uBAAC,SAAS,EAAE,CAAC,QAAQ,CAAC;gBA6BnC,OAAO;sBADN,YAAY;uBAAC,OAAO,EAAE,CAAC,QAAQ,CAAC;gBAO3B,MAAM;sBADX,YAAY;uBAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,eAAe,CAAC","sourcesContent":["import { Component, ElementRef, ViewChild, Input, HostListener, forwardRef, OnInit, OnDestroy, EventEmitter, Output } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\r\nimport { SlickSleepService } from \"../utils/slick-sleep.service\";\r\nimport { SlickUtilsService } from \"../utils/slick-utils.service\";\r\nimport moment from \"moment\";\r\n\r\n@Component({\r\n\tselector: '[slick-date-picker]',\r\n\tproviders: [\r\n\t\t{\r\n\t\t\tprovide: NG_VALUE_ACCESSOR,\r\n\t\t\tuseExisting: forwardRef(() => SlickDatePickerComponent),\r\n\t\t\tmulti: true\r\n\t\t}],\r\n\ttemplateUrl: 'slick-date-picker.component.html'\r\n})\r\nexport class SlickDatePickerComponent implements OnInit, OnDestroy, ControlValueAccessor {\r\n\t@Input(\"slick-date-picker\") slickDatePicker: SlickDatePickerComponent;\r\n\t@Input(\"slick-date-picker-format\") format: string = \"M/D/YYYY\";\r\n\t@Input(\"slick-date-picker-condensed\") condensed: boolean = false;\r\n\t@Input(\"slick-date-picker-mobile\") mobile: boolean = false;\r\n\t@Output(\"onDateChange\") onDateChange = new EventEmitter<Date>();\r\n\t@ViewChild(\"containerRef\") containerRef: ElementRef;\r\n\r\n\tfnDocumentClick = (e) => this.documentClick(e);\r\n\tfnDocumentMouseDown = (e) => this.documentMouseDown(e);\r\n\r\n\t// Make sure they only press valid keys\r\n\t@HostListener('keydown', ['$event'])\r\n\tasync onKeydown(event: KeyboardEvent) {\t\t\r\n\t\tif (event.altKey || event.ctrlKey || event.metaKey === true)\r\n\t\t\treturn;\r\n\r\n\t\tthis.hideCalendar();\r\n\r\n\t\t// Allow: backspace, delete, tab, escape, enter\r\n\t\tif ((event.keyCode === 46 || event.keyCode === 8) ||\r\n\t\t\t(event.keyCode === 9 || event.keyCode === 27 || event.keyCode === 13) ||\r\n\t\t\t// Allow F1-F12 keys\r\n\t\t\t((event.keyCode >= 112 && event.keyCode <= 123)) ||\r\n\t\t\t// Allow: home, end, left, right, down, up\r\n\t\t\t(event.keyCode >= 35 && event.keyCode <= 40)) {\r\n\t\t\t// let it happen, don't do anything\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\t// Ensure that it is a number and stop the keypress\r\n\t\tif ((event.shiftKey || event.altKey || event.key < '0' || event.key > '9') &&\r\n\t\t\tevent.key !== '/' &&  // Allow /\r\n\t\t\tevent.key !== '-') {  // Allow -\t\t\r\n\t\t\tevent.preventDefault();\r\n\t\t\treturn;\r\n\t\t}\r\n\t}\r\n\r\n\t// When we first focus, show the date picker\r\n\t@HostListener('focus', ['$event'])\r\n\tonFocus(event: FocusEvent): void {\r\n\t\tthis.showCalendar();\r\n\t}\r\n\r\n\t// When we blur, update the model\r\n\t@HostListener('blur', ['$event', '$event.target'])\r\n\tasync onBlur(event: FocusEvent, targetElement: HTMLElement) {\r\n\t\t// If the user clicked on the calendar, it will trigger a mouse down event before the blur event.  Don't blur\r\n\t\t// if they clicked on the calendar.\r\n\t\tif (this.ignoreBlur === true) {\r\n\t\t\tthis.ignoreBlur = false;\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst textVal = this.el.nativeElement.value;\r\n\r\n\t\tif (!textVal) {\r\n\t\t\tthis.doPropagate(null);\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif (moment(textVal, this.format).isValid()) {\r\n\t\t\tvar newDate = moment(textVal, this.format);\r\n\t\t\tthis.doPropagate(newDate.toDate())\r\n\t\t\tthis.el.nativeElement.value = newDate.format(this.format);\r\n\t\t}\r\n\t}\r\n\r\n\tuuid: string = SlickUtilsService.newGuid();\r\n\tignoreBlur: boolean = false;\r\n\tshowDatePicker: boolean = false;\r\n\tdatePickerVisiblity: string = \"hidden\";\r\n\tdatePickerOpacity: string = '0';\r\n\tleft: string;\r\n\ttop: string;\r\n\tselectedDate: Date = null;\r\n\tisInitial = true;\r\n\r\n\tprivate inputGroupPrepend: HTMLElement;\r\n\r\n\tconstructor(private el: ElementRef) {\r\n\t}\r\n\r\n\tasync ngOnInit() {\r\n\r\n\t\tthis.mobile = (this.mobile || 'false').toString().toLowerCase() === 'true' ? true : false;\r\n\t\tthis.condensed = (this.condensed || 'false').toString().toLowerCase() === 'true' ? true : false;\r\n\r\n\t\t// Since this.mobile isn't necessarily defined yet, we need to sleep to allow the ngIf's to do their thing\r\n\t\tawait SlickSleepService.sleep();\r\n\t\t// Remove this from the inline version and put it on the body so that it doesn't hide behind the bottom\r\n\t\t// of a div when it expands beyond the bottom.\r\n\t\tthis.containerRef.nativeElement.remove(this.containerRef);\r\n\t\tdocument.body.appendChild(this.containerRef.nativeElement);\r\n\r\n\t\tawait SlickSleepService.sleep();\r\n\t\tthis.inputGroupPrepend = SlickUtilsService.getClosestSibling(this.el.nativeElement, \"input-group-prepend\");\r\n\t}\r\n\r\n\tngOnDestroy() {\r\n\t\tdocument.removeEventListener(\"mousedown\", this.fnDocumentMouseDown, true);\r\n\t\tdocument.removeEventListener(\"click\", this.fnDocumentClick, true);\r\n\t\t// Is okay if this fails.  It just means it was already removed.\r\n\t\ttry {\r\n\t\t\tdocument.body.removeChild(this.containerRef.nativeElement);\r\n\t\t}\r\n\t\tcatch { }\r\n\t}\r\n\r\n\tpropagateChange = (_: any) => { };\r\n\r\n    private doPropagate(date: Date) {\r\n        // We don't always go through the emit on the first call, so make sure this isn't the first change\r\n        this.isInitial = false;\r\n\r\n\t\tif (!date) {\r\n\t\t\tif (this.selectedDate) {\r\n\t\t\t\tthis.propagateChange(null);\r\n\t\t\t\tthis.emitDateChange(null);\r\n\t\t\t}\r\n\r\n\t\t\tthis.selectedDate = null;\r\n\t\t\treturn;\r\n\t\t}\r\n\t\telse {\r\n\t\t\tconst newDate = moment(date);\r\n\t\t\t// If the date is not valid, return\r\n\t\t\tif (newDate.isValid() === false)\r\n\t\t\t\treturn;\r\n\r\n\t\t\t// Don't propogate if the dates are the same\r\n\t\t\tif (moment(this.selectedDate).isSame(newDate))\r\n\t\t\t\treturn;\r\n\r\n\r\n\t\t\t// Setting this selectedDate will trigger the ngModelChange of the calendar.  Ignore this.\r\n\t\t\tthis.selectedDate = moment(date).startOf(\"date\").toDate();\r\n\t\t\tthis.propagateChange(this.selectedDate);\r\n\t\t\tthis.emitDateChange(this.selectedDate);\r\n\t\t}\r\n\t}\r\n\r\n\tprivate emitDateChange(date: Date) {\r\n\t\tif (this.onDateChange && !this.isInitial)\r\n\t\t\tthis.onDateChange.emit(date);\r\n\r\n\t\tthis.isInitial = false;\r\n\t}\r\n\r\n\t// this is the initial value set to the component\r\n\tpublic writeValue(obj: any) {\r\n\t\tif (obj) {\r\n\t\t\tif (moment(obj).isValid() === false) {\r\n\t\t\t\tthis.selectedDate = null;\r\n                this.el.nativeElement.value = \"Invalid Date\";\r\n                this.isInitial = false;\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\r\n\t\t\tlet updatedDate: moment.Moment;\r\n\t\t\tif (obj instanceof Date || obj.indexOf(\"Z\") >= 0)\r\n\t\t\t\tupdatedDate = moment(obj).startOf(\"date\");\r\n\t\t\telse\r\n\t\t\t\tupdatedDate = moment(obj, this.format).startOf(\"date\");\r\n\r\n            if (moment(this.selectedDate || new Date()).isSame(updatedDate)) {\r\n                this.isInitial = false;\r\n                return;\r\n            }\r\n\r\n\t\t\tthis.selectedDate = updatedDate.toDate();\r\n\t\t\tthis.el.nativeElement.value = moment(this.selectedDate).format(this.format);\r\n\t\t}\r\n\t\telse {\r\n            if (!this.selectedDate && !obj) {\r\n                this.isInitial = false;\r\n                return;\r\n            }\r\n\r\n\t\t\tthis.el.nativeElement.value = '';\r\n\t\t\tthis.selectedDate = null;\r\n\t\t}\r\n\t}\r\n\r\n\t// registers 'fn' that will be fired when changes are made\r\n\t// this is how we emit the changes back to the form\r\n\tpublic registerOnChange(fn: any) {\r\n\t\tthis.propagateChange = fn;\r\n\t}\r\n\r\n\t// not used, used for touch input\r\n\tpublic registerOnTouched() { }\r\n\r\n\tprivate documentMouseDown(e: MouseEvent) {\r\n\t\t// This is the only way to capture that they clicked on the calendar before the blur event\r\n\t\t// fires.  \r\n\t\tif (SlickUtilsService.checkParentClassExists(<HTMLElement>e.target, \"slick-calendar\") === true)\r\n\t\t\tthis.ignoreBlur = true;\r\n\t}\r\n\r\n\tprivate documentClick(e: MouseEvent) {\r\n\t\tif (!e.target)\r\n\t\t\treturn;\r\n\r\n\t\tlet targetElement: HTMLElement = (<HTMLElement>e.target);\r\n\r\n\t\tif (SlickUtilsService.checkParentClassExists(targetElement, \"slick-calendar\") === true)\r\n\t\t\treturn;\r\n\r\n\t\tif (this.inputGroupPrepend && ((targetElement === this.inputGroupPrepend)\r\n\t\t\t|| (targetElement.parentElement && targetElement.parentElement === this.inputGroupPrepend))\r\n\t\t\t|| (targetElement.parentElement && targetElement.parentElement.parentElement && targetElement.parentElement.parentElement === this.inputGroupPrepend)) {\r\n\t\t\tthis.toggleCalendar();\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst clickedInside = this.el.nativeElement.contains(targetElement);\r\n\t\tif (!clickedInside) {\r\n\t\t\tthis.hideCalendar();\r\n\t\t}\r\n\t}\r\n\r\n\tonDateSelect(date) {\r\n\t\tthis.el.nativeElement.value = moment(date).format(this.format);\r\n\t\tthis.hideCalendar();\r\n\r\n\t\tconst newDate = moment(this.el.nativeElement.value, this.format).toDate();\r\n\r\n\t\tthis.doPropagate(newDate);\t\t\r\n\t}\r\n\r\n\tasync showCalendar() {\r\n\t\tdocument.removeEventListener(\"mousedown\", this.fnDocumentMouseDown, true);\r\n\t\tdocument.removeEventListener(\"click\", this.fnDocumentClick, true);\r\n\r\n\t\tthis.showDatePicker = true;\r\n\r\n\t\tif (!this.mobile) {\r\n\t\t\tthis.reposition();\r\n\t\t}\r\n\r\n\t\tthis.datePickerOpacity = '1';\r\n\t\tthis.datePickerVisiblity = 'visible';\r\n\r\n\t\t// Not sure why, but the click event is called immediately, which hides the calendar\r\n\t\tsetTimeout(() => {\r\n\t\t\tdocument.addEventListener(\"mousedown\", this.fnDocumentMouseDown, true);\r\n\t\t\tdocument.addEventListener(\"click\", this.fnDocumentClick, true);\r\n\t\t}, 350)\r\n\t}\r\n\r\n\thideCalendar() {\r\n\t\tdocument.removeEventListener(\"mousedown\", this.fnDocumentMouseDown, true);\r\n\t\tdocument.removeEventListener(\"click\", this.fnDocumentClick, true);\r\n\r\n\t\tthis.datePickerVisiblity = 'hidden';\r\n\t\tthis.datePickerOpacity = '0';\r\n\t\tthis.showDatePicker = false;\r\n\t}\r\n\r\n\tprivate reposition() {\r\n\t\tif (this.mobile === true)\r\n\t\t\treturn;\r\n\r\n\t\t// Reposition the element to be where the textbox is, either below or above if there isn't enough room\r\n\t\tconst inputEl: HTMLInputElement = this.el.nativeElement;\r\n\r\n\t\tconst rect = inputEl.getBoundingClientRect();\r\n\t\tconst textboxLeft = rect.left;\r\n\t\tconst textboxTop = rect.top;\r\n\t\tconst textboxHeight = inputEl.offsetHeight;\r\n\t\tconst containerHeight = (<HTMLDivElement>this.containerRef.nativeElement).offsetHeight;\r\n\r\n\t\tthis.left = textboxLeft + \"px\";\r\n\t\tthis.top = (textboxTop + textboxHeight) + \"px\";\r\n\r\n\t\tif (textboxTop + textboxHeight + containerHeight > window.innerHeight) {\r\n\t\t\tthis.top = (textboxTop - containerHeight - 2) + \"px\";\r\n\t\t}\r\n\r\n\t}\r\n\r\n\ttoggleCalendar() {\r\n\t\t(this.showDatePicker === true) ? this.hideCalendar() : this.showCalendar();\r\n\t}\r\n}","<ng-content></ng-content>\r\n<div *ngIf=\"mobile === false\" #containerRef class=\"slick-date-picker-container\" [style.left]=\"left\" [style.top]=\"top\" [style.visibility]=\"datePickerVisiblity\" [style.opacity]=\"datePickerOpacity\">\r\n\t<slick-calendar [ngModel]=\"selectedDate\" [condensed]=\"condensed\" (onDateSelect)=\"onDateSelect($event)\"></slick-calendar>\r\n</div>\r\n<div *ngIf=\"mobile === true\" #containerRef class=\"slick-date-picker-mobile-container\" [style.visibility]=\"datePickerVisiblity\" [style.opacity]=\"datePickerOpacity\">\r\n\t<div class=\"slick-date-picker-mobile-calendar\">\r\n\t\t<slick-calendar [ngModel]=\"selectedDate\" [condensed]=\"condensed\" (onDateSelect)=\"onDateSelect($event)\"></slick-calendar>\r\n\t</div>\r\n</div>\r\n"]}
|