ngx-moderndatepicker 2.0.1 → 3.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/esm2020/ngx-moderndatepicker.mjs +5 -0
- package/esm2020/public_api.mjs +3 -0
- package/esm2020/src/ngx-moderndatepicker/component/ngx-moderndatepicker.component.mjs +367 -0
- package/esm2020/src/ngx-moderndatepicker/module/ngx-moderndatepicker.module.mjs +19 -0
- package/fesm2015/ngx-moderndatepicker.mjs +389 -0
- package/fesm2015/ngx-moderndatepicker.mjs.map +1 -0
- package/fesm2020/ngx-moderndatepicker.mjs +389 -0
- package/fesm2020/ngx-moderndatepicker.mjs.map +1 -0
- package/ngx-moderndatepicker.d.ts +5 -0
- package/package.json +23 -43
- package/src/ngx-moderndatepicker/component/ngx-moderndatepicker.component.d.ts +127 -0
- package/src/ngx-moderndatepicker/module/ngx-moderndatepicker.module.d.ts +9 -0
- package/.browserslistrc +0 -12
- package/angular.json +0 -148
- package/dist/LICENSE +0 -21
- package/dist/README.md +0 -75
- package/dist/bundles/ngx-moderndatepicker.umd.js +0 -428
- package/dist/bundles/ngx-moderndatepicker.umd.js.map +0 -1
- package/dist/package.json +0 -33
- package/e2e/app.e2e-spec.ts +0 -14
- package/e2e/app.po.ts +0 -11
- package/e2e/tsconfig.e2e.json +0 -14
- package/karma.conf.js +0 -33
- package/ng-package.json +0 -9
- package/protractor.conf.js +0 -28
- package/src/app/app.component.css +0 -0
- package/src/app/app.component.html +0 -14
- package/src/app/app.component.ts +0 -21
- package/src/app/app.module.ts +0 -21
- package/src/assets/.gitkeep +0 -0
- package/src/assets/Screenshot 2021-06-11 at 11.00.41 AM.png +0 -0
- package/src/assets/Screenshot.png +0 -0
- package/src/environments/environment.prod.ts +0 -3
- package/src/environments/environment.ts +0 -8
- package/src/favicon.ico +0 -0
- package/src/index.html +0 -14
- package/src/main.ts +0 -12
- package/src/ngx-moderndatepicker/component/ngx-moderndatepicker.component.html +0 -66
- package/src/ngx-moderndatepicker/component/ngx-moderndatepicker.component.scss +0 -232
- package/src/ngx-moderndatepicker/component/ngx-moderndatepicker.component.ts +0 -488
- package/src/ngx-moderndatepicker/module/ngx-moderndatepicker.module.ts +0 -14
- package/src/polyfills.ts +0 -34
- package/src/styles.scss +0 -10
- package/src/test.ts +0 -20
- package/src/tsconfig.app.json +0 -15
- package/src/tsconfig.spec.json +0 -19
- package/tsconfig.json +0 -21
- package/tslint.json +0 -135
- /package/{public_api.ts → public_api.d.ts} +0 -0
package/README.md
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
# ngx-moderndatepicker
|
|
2
2
|
|
|
3
|
-
Angular
|
|
3
|
+
Angular 13+ simple and interactive calendar datepicker component
|
|
4
4
|
|
|
5
5
|

|
|
6
6
|
|
|
@@ -18,7 +18,7 @@ npm install ngx-moderndatepicker --save
|
|
|
18
18
|
import { NgModule } from '@angular/core';
|
|
19
19
|
import { BrowserModule } from '@angular/platform-browser';
|
|
20
20
|
import { FormsModule } from '@angular/forms';
|
|
21
|
-
import {
|
|
21
|
+
import { NgxModerndatepickerModule } from 'ngx-moderndatepicker';
|
|
22
22
|
|
|
23
23
|
@NgModule({
|
|
24
24
|
imports: [
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public_api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LW1vZGVybmRhdGVwaWNrZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9uZ3gtbW9kZXJuZGF0ZXBpY2tlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpY19hcGknO1xuIl19
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './src/ngx-moderndatepicker/module/ngx-moderndatepicker.module';
|
|
2
|
+
export * from './src/ngx-moderndatepicker/component/ngx-moderndatepicker.component';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3B1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywrREFBK0QsQ0FBQztBQUM5RSxjQUFjLHFFQUFxRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9zcmMvbmd4LW1vZGVybmRhdGVwaWNrZXIvbW9kdWxlL25neC1tb2Rlcm5kYXRlcGlja2VyLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3NyYy9uZ3gtbW9kZXJuZGF0ZXBpY2tlci9jb21wb25lbnQvbmd4LW1vZGVybmRhdGVwaWNrZXIuY29tcG9uZW50JztcbiJdfQ==
|
|
@@ -0,0 +1,367 @@
|
|
|
1
|
+
import { Component, Input, HostListener, forwardRef, ChangeDetectionStrategy } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { startOfMonth, endOfMonth, addMonths, setYear, eachDay, getDate, getMonth, getYear, isToday, isSameDay, isSameMonth, isSameYear, format, getDay, subDays, setDay, addYears, subYears, setMonth, } from 'date-fns';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "@angular/forms";
|
|
7
|
+
// Counter for calculating the auto-incrementing field ID
|
|
8
|
+
let counter = 0;
|
|
9
|
+
/**
|
|
10
|
+
* Internal library helper that helps to check if value is empty
|
|
11
|
+
* @param value
|
|
12
|
+
*/
|
|
13
|
+
const isNil = (value) => {
|
|
14
|
+
return (typeof value === 'undefined') || (value === null);
|
|
15
|
+
};
|
|
16
|
+
export class NgxModerndatepickerComponent {
|
|
17
|
+
constructor() {
|
|
18
|
+
/**
|
|
19
|
+
* Disable datepicker's input
|
|
20
|
+
*/
|
|
21
|
+
this.headless = false;
|
|
22
|
+
/**
|
|
23
|
+
* Set datepicker's visibility state
|
|
24
|
+
*/
|
|
25
|
+
this.isOpened = false;
|
|
26
|
+
/**
|
|
27
|
+
* Datepicker dropdown position
|
|
28
|
+
*/
|
|
29
|
+
this.position = 'bottom-right';
|
|
30
|
+
this.positions = ['bottom-left', 'bottom-right', 'top-left', 'top-right'];
|
|
31
|
+
this.onTouchedCallback = () => { };
|
|
32
|
+
this.onChangeCallback = () => { };
|
|
33
|
+
}
|
|
34
|
+
setDisabledState(isDisabled) {
|
|
35
|
+
this.disabled = isDisabled;
|
|
36
|
+
}
|
|
37
|
+
get value() {
|
|
38
|
+
return this.innerValue;
|
|
39
|
+
}
|
|
40
|
+
set value(val) {
|
|
41
|
+
this.innerValue = val;
|
|
42
|
+
this.onChangeCallback(this.innerValue);
|
|
43
|
+
}
|
|
44
|
+
ngOnInit() {
|
|
45
|
+
this.view = 'year';
|
|
46
|
+
if (!this.date) {
|
|
47
|
+
this.date = new Date();
|
|
48
|
+
}
|
|
49
|
+
this.setOptions();
|
|
50
|
+
this.initDayNames();
|
|
51
|
+
this.initYears();
|
|
52
|
+
this.initMonthName();
|
|
53
|
+
this.init();
|
|
54
|
+
// Check if 'position' property is correct
|
|
55
|
+
if (this.positions.indexOf(this.position) === -1) {
|
|
56
|
+
const expectedValues = this.positions.join(', ');
|
|
57
|
+
const message = `ng-moderndatepicker: invalid position property value '${this.position}' (expected: ${expectedValues})`;
|
|
58
|
+
throw new TypeError(message);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
ngOnChanges(changes) {
|
|
62
|
+
this.setOptions();
|
|
63
|
+
this.initDayNames();
|
|
64
|
+
this.init();
|
|
65
|
+
this.initYears();
|
|
66
|
+
this.initMonthName();
|
|
67
|
+
}
|
|
68
|
+
get defaultFieldId() {
|
|
69
|
+
// Only evaluate and increment if required
|
|
70
|
+
const value = `datepicker-${counter++}`;
|
|
71
|
+
Object.defineProperty(this, 'defaultFieldId', { value });
|
|
72
|
+
return value;
|
|
73
|
+
}
|
|
74
|
+
setOptions() {
|
|
75
|
+
const today = new Date(); // this const was added because during my tests, I noticed that at this level this.date is undefined
|
|
76
|
+
this.minYear = this.options && this.options.minYear || getYear(today) - 30;
|
|
77
|
+
this.maxYear = this.options && this.options.maxYear || getYear(today) + 30;
|
|
78
|
+
this.displayFormat = this.options && this.options.displayFormat || 'MMM D[,] YYYY';
|
|
79
|
+
this.barTitleFormat = 'YYYY';
|
|
80
|
+
this.dayNamesFormat = this.options && this.options.dayNamesFormat || 'ddd';
|
|
81
|
+
this.monthNamesFormat = this.options && this.options.monthNamesFormat || 'MMM';
|
|
82
|
+
this.barTitleIfEmpty = (new Date().getFullYear()).toString();
|
|
83
|
+
this.firstCalendarDay = this.options && this.options.firstCalendarDay || 0;
|
|
84
|
+
this.locale = this.options && { locale: this.options.locale } || {};
|
|
85
|
+
this.placeholder = this.options && this.options.placeholder || '';
|
|
86
|
+
this.addClass = this.options && this.options.addClass || {};
|
|
87
|
+
this.addStyle = this.options && this.options.addStyle || {};
|
|
88
|
+
this.fieldId = this.options && this.options.fieldId || this.defaultFieldId;
|
|
89
|
+
}
|
|
90
|
+
nextYear() {
|
|
91
|
+
this.date = addYears(this.date, 1);
|
|
92
|
+
this.barTitle = format(this.date, this.barTitleFormat, this.locale);
|
|
93
|
+
this.init();
|
|
94
|
+
this.initMonthName();
|
|
95
|
+
}
|
|
96
|
+
prevYear() {
|
|
97
|
+
this.date = subYears(this.date, 1);
|
|
98
|
+
this.barTitle = format(this.date, this.barTitleFormat, this.locale);
|
|
99
|
+
this.init();
|
|
100
|
+
this.initMonthName();
|
|
101
|
+
}
|
|
102
|
+
setDate(i) {
|
|
103
|
+
this.date = this.days[i].date;
|
|
104
|
+
this.value = this.date;
|
|
105
|
+
this.init();
|
|
106
|
+
this.close();
|
|
107
|
+
}
|
|
108
|
+
setYear(i) {
|
|
109
|
+
this.date = setYear(this.date, this.years[i].year);
|
|
110
|
+
this.init();
|
|
111
|
+
this.initMonthName();
|
|
112
|
+
this.view = 'year';
|
|
113
|
+
}
|
|
114
|
+
selectMonth(i) {
|
|
115
|
+
this.date = setMonth(this.date, i);
|
|
116
|
+
this.init();
|
|
117
|
+
this.initMonthName();
|
|
118
|
+
this.view = 'year';
|
|
119
|
+
}
|
|
120
|
+
/**
|
|
121
|
+
* Checks if specified date is in range of min and max dates
|
|
122
|
+
* @param date
|
|
123
|
+
*/
|
|
124
|
+
isDateSelectable(date) {
|
|
125
|
+
if (isNil(this.options)) {
|
|
126
|
+
return true;
|
|
127
|
+
}
|
|
128
|
+
const minDateSet = !isNil(this.options.minDate);
|
|
129
|
+
const maxDateSet = !isNil(this.options.maxDate);
|
|
130
|
+
const timestamp = date.valueOf();
|
|
131
|
+
if (minDateSet && (timestamp < this.options.minDate.valueOf())) {
|
|
132
|
+
return false;
|
|
133
|
+
}
|
|
134
|
+
if (maxDateSet && (timestamp > this.options.maxDate.valueOf())) {
|
|
135
|
+
return false;
|
|
136
|
+
}
|
|
137
|
+
return true;
|
|
138
|
+
}
|
|
139
|
+
isWeekendDay(date) {
|
|
140
|
+
const weekendsDay = Array.isArray(this.options.weekendsDay);
|
|
141
|
+
if (weekendsDay) {
|
|
142
|
+
return this.options.weekendsDay.indexOf(getDay(date)) !== -1;
|
|
143
|
+
}
|
|
144
|
+
return false;
|
|
145
|
+
}
|
|
146
|
+
isHoliday(date) {
|
|
147
|
+
const areHolidays = Array.isArray(this.options.holidayList);
|
|
148
|
+
if (areHolidays) {
|
|
149
|
+
return this.options.holidayList.some((day) => isSameDay(day, date));
|
|
150
|
+
}
|
|
151
|
+
return false;
|
|
152
|
+
}
|
|
153
|
+
init() {
|
|
154
|
+
// this.date may be null after .reset(); fall back to current date.
|
|
155
|
+
const actualDate = this.date || new Date();
|
|
156
|
+
const start = startOfMonth(actualDate);
|
|
157
|
+
const end = endOfMonth(actualDate);
|
|
158
|
+
this.days = eachDay(start, end).map(date => {
|
|
159
|
+
return {
|
|
160
|
+
date: date,
|
|
161
|
+
day: getDate(date),
|
|
162
|
+
month: getMonth(date),
|
|
163
|
+
year: getYear(date),
|
|
164
|
+
inThisMonth: true,
|
|
165
|
+
isToday: isToday(date),
|
|
166
|
+
isSelected: isSameDay(date, this.innerValue) && isSameMonth(date, this.innerValue) && isSameYear(date, this.innerValue),
|
|
167
|
+
isSelectable: this.isDateSelectable(date),
|
|
168
|
+
isWeekend: this.isWeekendDay(date),
|
|
169
|
+
isHoliday: this.isHoliday(date)
|
|
170
|
+
};
|
|
171
|
+
});
|
|
172
|
+
const tmp = getDay(start) - this.firstCalendarDay;
|
|
173
|
+
const prevDays = tmp < 0 ? 7 - this.firstCalendarDay : tmp;
|
|
174
|
+
for (let i = 1; i <= prevDays; i++) {
|
|
175
|
+
const date = subDays(start, i);
|
|
176
|
+
this.days.unshift({
|
|
177
|
+
date: date,
|
|
178
|
+
day: getDate(date),
|
|
179
|
+
month: getMonth(date),
|
|
180
|
+
year: getYear(date),
|
|
181
|
+
inThisMonth: false,
|
|
182
|
+
isToday: isToday(date),
|
|
183
|
+
isSelected: isSameDay(date, this.innerValue) && isSameMonth(date, this.innerValue) && isSameYear(date, this.innerValue),
|
|
184
|
+
isSelectable: this.isDateSelectable(date),
|
|
185
|
+
isWeekend: this.isWeekendDay(date),
|
|
186
|
+
isHoliday: this.isHoliday(date)
|
|
187
|
+
});
|
|
188
|
+
}
|
|
189
|
+
if (this.innerValue) {
|
|
190
|
+
this.displayValue = format(this.innerValue, this.displayFormat, this.locale);
|
|
191
|
+
this.barTitle = format(start, this.barTitleFormat, this.locale);
|
|
192
|
+
}
|
|
193
|
+
else {
|
|
194
|
+
this.displayValue = '';
|
|
195
|
+
this.barTitle = this.useEmptyBarTitle ? this.barTitleIfEmpty : format(this.date, this.barTitleFormat, this.locale);
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
initYears() {
|
|
199
|
+
const range = this.maxYear - this.minYear;
|
|
200
|
+
this.years = Array.from(new Array(range), (x, i) => i + this.minYear).map(year => {
|
|
201
|
+
return {
|
|
202
|
+
year,
|
|
203
|
+
isThisYear: year === getYear(this.date),
|
|
204
|
+
isToday: year === getYear(new Date()),
|
|
205
|
+
isSelectable: this.isYearSelectable(year)
|
|
206
|
+
};
|
|
207
|
+
});
|
|
208
|
+
}
|
|
209
|
+
isYearSelectable(date) {
|
|
210
|
+
const minDate = !isNil(this.options.minDate) ? this.options.minDate : null;
|
|
211
|
+
const maxDate = !isNil(this.options.maxDate) ? this.options.maxDate : null;
|
|
212
|
+
if (minDate && maxDate) {
|
|
213
|
+
return minDate.getFullYear() <= date && date <= maxDate.getFullYear();
|
|
214
|
+
}
|
|
215
|
+
if (minDate) {
|
|
216
|
+
return minDate.getFullYear() <= date;
|
|
217
|
+
}
|
|
218
|
+
if (maxDate) {
|
|
219
|
+
return date <= maxDate.getFullYear();
|
|
220
|
+
}
|
|
221
|
+
return true;
|
|
222
|
+
}
|
|
223
|
+
initDayNames() {
|
|
224
|
+
this.dayNames = [];
|
|
225
|
+
const start = this.firstCalendarDay;
|
|
226
|
+
for (let i = start; i <= 6 + start; i++) {
|
|
227
|
+
const date = setDay(new Date(), i);
|
|
228
|
+
this.dayNames.push(format(date, this.dayNamesFormat, this.locale));
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
initMonthName() {
|
|
232
|
+
const monthNames = [];
|
|
233
|
+
const actualDate = this.date || new Date();
|
|
234
|
+
const currentDate = new Date(actualDate);
|
|
235
|
+
const start = subYears(new Date(currentDate.setMonth(11)), 1);
|
|
236
|
+
for (let i = 1; i <= 12; i++) {
|
|
237
|
+
const date = addMonths(start, i);
|
|
238
|
+
monthNames.push({
|
|
239
|
+
name: format(date, this.monthNamesFormat, this.locale),
|
|
240
|
+
isSelected: date.getMonth() === actualDate.getMonth(),
|
|
241
|
+
isThisMonth: isSameMonth(date, new Date()) && isSameYear(actualDate, new Date()),
|
|
242
|
+
isSelectable: this.isMonthSelectable(date)
|
|
243
|
+
});
|
|
244
|
+
}
|
|
245
|
+
this.monthNames = monthNames;
|
|
246
|
+
}
|
|
247
|
+
isMonthSelectable(date) {
|
|
248
|
+
const minDate = !isNil(this.options.minDate) ? this.options.minDate : null;
|
|
249
|
+
const maxDate = !isNil(this.options.maxDate) ? this.options.maxDate : null;
|
|
250
|
+
const year = date.getFullYear();
|
|
251
|
+
const month = date.getMonth();
|
|
252
|
+
if (minDate && maxDate) {
|
|
253
|
+
const minYear = minDate.getFullYear();
|
|
254
|
+
const maxYear = maxDate.getFullYear();
|
|
255
|
+
if (year < minYear || year > maxYear) {
|
|
256
|
+
return false;
|
|
257
|
+
}
|
|
258
|
+
if (year === minYear && month < minDate.getMonth()) {
|
|
259
|
+
return false;
|
|
260
|
+
}
|
|
261
|
+
if (year === maxYear && month > maxDate.getMonth()) {
|
|
262
|
+
return false;
|
|
263
|
+
}
|
|
264
|
+
return true;
|
|
265
|
+
}
|
|
266
|
+
if (minDate) {
|
|
267
|
+
if (year < minDate.getFullYear()) {
|
|
268
|
+
return false;
|
|
269
|
+
}
|
|
270
|
+
if (year === minDate.getFullYear() && month < minDate.getMonth()) {
|
|
271
|
+
return false;
|
|
272
|
+
}
|
|
273
|
+
return true;
|
|
274
|
+
}
|
|
275
|
+
if (maxDate) {
|
|
276
|
+
if (year > maxDate.getFullYear()) {
|
|
277
|
+
return false;
|
|
278
|
+
}
|
|
279
|
+
if (year === maxDate.getFullYear() && month > maxDate.getMonth()) {
|
|
280
|
+
return false;
|
|
281
|
+
}
|
|
282
|
+
return true;
|
|
283
|
+
}
|
|
284
|
+
return true;
|
|
285
|
+
}
|
|
286
|
+
toggleView() {
|
|
287
|
+
this.view = this.view === 'year' ? 'years' : 'year';
|
|
288
|
+
}
|
|
289
|
+
toggle() {
|
|
290
|
+
this.isOpened = !this.isOpened;
|
|
291
|
+
if (!this.isOpened && this.view === 'years') {
|
|
292
|
+
this.toggleView();
|
|
293
|
+
}
|
|
294
|
+
}
|
|
295
|
+
close() {
|
|
296
|
+
this.isOpened = false;
|
|
297
|
+
if (this.view === 'years') {
|
|
298
|
+
this.toggleView();
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
reset(fireValueChangeEvent = false) {
|
|
302
|
+
this.date = null;
|
|
303
|
+
this.innerValue = null;
|
|
304
|
+
this.init();
|
|
305
|
+
this.initMonthName();
|
|
306
|
+
if (fireValueChangeEvent && this.onChangeCallback) {
|
|
307
|
+
this.onChangeCallback(this.innerValue);
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
writeValue(val) {
|
|
311
|
+
if (val) {
|
|
312
|
+
this.date = val;
|
|
313
|
+
this.innerValue = val;
|
|
314
|
+
this.init();
|
|
315
|
+
this.initMonthName();
|
|
316
|
+
this.displayValue = format(this.innerValue, this.displayFormat, this.locale);
|
|
317
|
+
this.barTitle = format(startOfMonth(val), this.barTitleFormat, this.locale);
|
|
318
|
+
}
|
|
319
|
+
}
|
|
320
|
+
registerOnChange(fn) {
|
|
321
|
+
this.onChangeCallback = fn;
|
|
322
|
+
}
|
|
323
|
+
registerOnTouched(fn) {
|
|
324
|
+
this.onTouchedCallback = fn;
|
|
325
|
+
}
|
|
326
|
+
onBlur(e) {
|
|
327
|
+
if (!this.isOpened) {
|
|
328
|
+
return;
|
|
329
|
+
}
|
|
330
|
+
const input = document.querySelector('.ngx-moderndatepicker-input');
|
|
331
|
+
if (input === null) {
|
|
332
|
+
return;
|
|
333
|
+
}
|
|
334
|
+
if (e.target === input || input.contains(e.target)) {
|
|
335
|
+
return;
|
|
336
|
+
}
|
|
337
|
+
const container = document.querySelector('.ngx-moderndatepicker-calendar-container');
|
|
338
|
+
const target = e.target;
|
|
339
|
+
const isYearUnit = target.classList.contains('year-unit');
|
|
340
|
+
const isMonthUnit = target.classList.contains('month-unit');
|
|
341
|
+
if (container && container !== target && !container.contains(target) && !isYearUnit && !isMonthUnit) {
|
|
342
|
+
this.close();
|
|
343
|
+
}
|
|
344
|
+
}
|
|
345
|
+
}
|
|
346
|
+
NgxModerndatepickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: NgxModerndatepickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
347
|
+
NgxModerndatepickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.0", type: NgxModerndatepickerComponent, selector: "ngx-moderndatepicker", inputs: { options: "options", headless: "headless", isOpened: "isOpened", position: "position" }, host: { listeners: { "document:click": "onBlur($event)" } }, providers: [
|
|
348
|
+
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => NgxModerndatepickerComponent), multi: true }
|
|
349
|
+
], usesOnChanges: true, ngImport: i0, template: "<div class=\"ngx-moderndatepicker-container\">\n <input type=\"text\" *ngIf=\"!headless\" class=\"ngx-moderndatepicker-input\" [(ngModel)]=\"displayValue\" readonly [placeholder]=\"placeholder\"\n [ngClass]=\"addClass\" [ngStyle]=\"addStyle\" [id]=\"fieldId\" [disabled]=\"disabled\" (click)=\"toggle()\" />\n <ng-content></ng-content>\n <div class=\"ngx-moderndatepicker-calendar-container ngx-moderndatepicker-position-{{position}}\" *ngIf=\"isOpened\">\n <div class=\"topbar-container\">\n <div class=\"main-calendar-selection-year\">\n <svg width=\"15px\" height=\"15px\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" x=\"0px\" y=\"0px\"\n \t viewBox=\"0 0 489.6 489.6\" style=\"enable-background:new 0 0 489.6 489.6;\" xml:space=\"preserve\"\n (click)=\"view === 'year' && prevYear()\">\n <g>\n \t<g>\n \t\t<path style=\"fill:#2C2F33;\" d=\"M244.8,489.6c135,0,244.8-109.8,244.8-244.8S379.8,0,244.8,0S0,109.8,0,244.8\n \t\t\tS109.8,489.6,244.8,489.6z M244.8,19.8c124.1,0,225,100.9,225,225s-100.9,225-225,225s-225-100.9-225-225S120.7,19.8,244.8,19.8z\"\n \t\t\t/>\n \t\t<path style=\"fill:#3C92CA;\" d=\"M265.5,326.1c1.9,1.9,4.5,2.9,7,2.9s5.1-1,7-2.9c3.9-3.9,3.9-10.1,0-14l-67.3-67.3l67.3-67.3\n \t\t\tc3.9-3.9,3.9-10.1,0-14s-10.1-3.9-14,0l-74.3,74.3c-3.9,3.9-3.9,10.1,0,14L265.5,326.1z\"/>\n \t</g>\n </g>\n </svg>\n <span class=\"topbar-title\" (click)=\"toggleView(); initYears();\">{{ barTitle }}</span>\n <svg width=\"15px\" height=\"15px\" viewBox=\"0 0 6 10\" version=\"1.1\" id=\"Layer_1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" x=\"0px\" y=\"0px\"\n \t viewBox=\"0 0 489.6 489.6\" style=\"enable-background:new 0 0 489.6 489.6;\" xml:space=\"preserve\"\n (click)=\"view === 'year' && nextYear()\">\n <g>\n \t<g>\n \t\t<path style=\"fill:#2C2F33;\" d=\"M244.8,489.6c135,0,244.8-109.8,244.8-244.8S379.8,0,244.8,0S0,109.8,0,244.8\n \t\t\tS109.8,489.6,244.8,489.6z M244.8,19.8c124.1,0,225,100.9,225,225s-100.9,225-225,225s-225-100.9-225-225S120.7,19.8,244.8,19.8z\"\n \t\t\t/>\n \t\t<path style=\"fill:#3C92CA;\" d=\"M210,326.1c1.9,1.9,4.5,2.9,7,2.9s5.1-1,7-2.9l74.3-74.3c1.9-1.9,2.9-4.4,2.9-7s-1-5.1-2.9-7\n \t\t\tL224,163.5c-3.9-3.9-10.1-3.9-14,0s-3.9,10.1,0,14l67.3,67.3L210,312.1C206.2,316,206.2,322.3,210,326.1z\"/>\n \t</g>\n </g>\n </svg>\n </div>\n <div class=\"main-calendar-day-names\" *ngIf=\"view === 'year'\">\n <span class=\"day-name-unit\" *ngFor=\"let name of dayNames\">{{ name }}</span>\n </div>\n </div>\n <div class=\"main-calendar-container\" *ngIf=\"view === 'year'\">\n <div class=\"main-calendar-month-names\">\n <div class=\"month-name-unit\" *ngFor=\"let month of monthNames; let index = index\" (click)=\"month.isSelectable && selectMonth(index)\">\n <span class=\"month-unit\"\n [ngClass]=\"{ 'is-this-month': month.isThisMonth, 'is-disabled': !month.isSelectable ,'is-selected': month.isSelected}\">\n {{ month.name }}\n </span>\n </div>\n </div>\n <div class=\"main-calender-days-container\">\n <div class=\"main-calendar-days\">\n <div class=\"day-unit\" *ngFor=\"let day of days; let i = index;\" >\n <span [ngClass]=\"{ 'is-prev-month': !day.inThisMonth, 'is-today': day.isToday, 'is-disabled': !day.isSelectable, 'is-weekend': day.isWeekend , 'is-holiday' : day.isHoliday, 'is-selected': day.isSelected}\"\n (click)=\"day.isSelectable && setDate(i)\">\n {{ day.day }}\n </span>\n </div>\n </div>\n </div>\n </div>\n <div class=\"main-calendar-container\" *ngIf=\"view === 'years'\">\n <div class=\"main-calendar-years\">\n <span class=\"year-unit\" *ngFor=\"let year of years; let i = index;\" [ngClass]=\"{ 'is-selected': year.isThisYear , 'is-today': year.isToday , 'is-disabled' : !year.isSelectable}\" (click)=\"year.isSelectable && setYear(i)\">{{ year.year }}</span>\n </div>\n </div>\n </div>\n</div>\n", styles: [".ngx-moderndatepicker-position-bottom-left{top:40px;right:0}.ngx-moderndatepicker-position-bottom-right{top:40px;left:0}.ngx-moderndatepicker-position-top-left{bottom:40px;right:0}.ngx-moderndatepicker-position-top-right{bottom:40px;left:0}.ngx-moderndatepicker-container{position:relative}.ngx-moderndatepicker-container .ngx-moderndatepicker-input{padding:5px 10px;font-size:14px;width:200px;outline:none;border:1px solid #DFE3E9}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container{position:absolute;width:356px;height:230px;background:#ffffff;padding:10px;box-shadow:0 1px 4px #00000014;border:1px solid #DFE3E9;border-radius:4px}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .topbar-container{height:10px;padding:5px 0;display:flex;align-items:center;-webkit-user-select:none;-moz-user-select:none;user-select:none}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .topbar-container .main-calendar-selection-year{display:flex;align-items:center;width:108px;min-width:108px}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .topbar-container .main-calendar-day-names{color:#a4a9b1;width:100%;display:flex;align-items:center;font-size:12px;padding:0 0 0 5px}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .topbar-container .main-calendar-day-names .day-name-unit{width:14.2857142857%;height:30px;text-transform:uppercase;text-align:center;line-height:30px}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container svg{cursor:pointer}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container svg g{fill:#ced0da}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .topbar-title{color:#3d495c;font-size:15px;font-weight:400;margin:0 10px;cursor:pointer}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container{width:100%;height:100%;font-size:14px;font-weight:500;display:flex;flex-direction:row}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-month-names{display:flex;flex-flow:row wrap;width:108px;min-width:108px;padding:15px 0}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-month-names .month-name-unit{width:45px;height:30px;color:#000;text-align:center;border-radius:5px;line-height:30px;cursor:pointer}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-month-names .month-name-unit span{width:35px;padding:2.5px 7px;border-radius:15%;height:25px;line-height:25px;text-align:center}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-month-names .month-name-unit span:hover,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-month-names .month-name-unit span.is-this-month{border:2px solid #1A91EB;margin:-2px}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-month-names .month-name-unit span.is-disabled{cursor:not-allowed;color:#a4a9b1}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-month-names .month-name-unit span.is-disabled :hover{background:transparent}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-month-names .month-name-unit span.is-selected{background:#1A91EB;color:#fff;border:2px solid #1A91EB}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years{padding:15px 5px;width:100%;display:inline-block;max-height:275px;overflow:auto}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit{height:30px;display:inline-flex;float:left;width:14.2857142857%;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;color:#3d495c}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit span,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit span,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit span,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit span{width:28px;border-radius:15%;height:20px;line-height:20px;text-align:center}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit span.is-prev-month,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit span.is-prev-month,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit span.is-prev-month,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit span.is-prev-month{color:#a4a9b1}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit span:hover,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit span.is-today,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit span:hover,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit span.is-today,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit span:hover,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit span.is-today,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit span:hover,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit span.is-today{border:2px solid #1A91EB;margin:-2px}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit span.is-weekend,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit span.is-holiday,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit span.is-weekend,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit span.is-holiday,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit span.is-weekend,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit span.is-holiday,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit span.is-weekend,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit span.is-holiday{background:#e0e0e0}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit span.is-selected,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit span.is-selected,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit span.is-selected,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit span.is-selected{background:#1A91EB;color:#fff;border:2px solid #1A91EB}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit span.is-disabled,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit span.is-disabled,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit span.is-disabled,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit span.is-disabled{cursor:not-allowed;color:#a4a9b1}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit span.is-disabled :hover,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit span.is-disabled :hover,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit span.is-disabled :hover,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit span.is-disabled :hover{background:transparent}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years{height:200px;display:block;margin:auto;padding:5px 10px}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit{width:33.3333333333%;border-radius:10px}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit.is-disabled{cursor:not-allowed;color:#a4a9b1}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit.is-disabled :hover{background:transparent}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit.is-selected{background:#1A91EB;color:#fff;border:2px solid #1A91EB}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit:hover,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit.is-today{border:2px solid #1A91EB;margin:-2px}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
350
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: NgxModerndatepickerComponent, decorators: [{
|
|
351
|
+
type: Component,
|
|
352
|
+
args: [{ selector: 'ngx-moderndatepicker', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
353
|
+
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => NgxModerndatepickerComponent), multi: true }
|
|
354
|
+
], template: "<div class=\"ngx-moderndatepicker-container\">\n <input type=\"text\" *ngIf=\"!headless\" class=\"ngx-moderndatepicker-input\" [(ngModel)]=\"displayValue\" readonly [placeholder]=\"placeholder\"\n [ngClass]=\"addClass\" [ngStyle]=\"addStyle\" [id]=\"fieldId\" [disabled]=\"disabled\" (click)=\"toggle()\" />\n <ng-content></ng-content>\n <div class=\"ngx-moderndatepicker-calendar-container ngx-moderndatepicker-position-{{position}}\" *ngIf=\"isOpened\">\n <div class=\"topbar-container\">\n <div class=\"main-calendar-selection-year\">\n <svg width=\"15px\" height=\"15px\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" x=\"0px\" y=\"0px\"\n \t viewBox=\"0 0 489.6 489.6\" style=\"enable-background:new 0 0 489.6 489.6;\" xml:space=\"preserve\"\n (click)=\"view === 'year' && prevYear()\">\n <g>\n \t<g>\n \t\t<path style=\"fill:#2C2F33;\" d=\"M244.8,489.6c135,0,244.8-109.8,244.8-244.8S379.8,0,244.8,0S0,109.8,0,244.8\n \t\t\tS109.8,489.6,244.8,489.6z M244.8,19.8c124.1,0,225,100.9,225,225s-100.9,225-225,225s-225-100.9-225-225S120.7,19.8,244.8,19.8z\"\n \t\t\t/>\n \t\t<path style=\"fill:#3C92CA;\" d=\"M265.5,326.1c1.9,1.9,4.5,2.9,7,2.9s5.1-1,7-2.9c3.9-3.9,3.9-10.1,0-14l-67.3-67.3l67.3-67.3\n \t\t\tc3.9-3.9,3.9-10.1,0-14s-10.1-3.9-14,0l-74.3,74.3c-3.9,3.9-3.9,10.1,0,14L265.5,326.1z\"/>\n \t</g>\n </g>\n </svg>\n <span class=\"topbar-title\" (click)=\"toggleView(); initYears();\">{{ barTitle }}</span>\n <svg width=\"15px\" height=\"15px\" viewBox=\"0 0 6 10\" version=\"1.1\" id=\"Layer_1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" x=\"0px\" y=\"0px\"\n \t viewBox=\"0 0 489.6 489.6\" style=\"enable-background:new 0 0 489.6 489.6;\" xml:space=\"preserve\"\n (click)=\"view === 'year' && nextYear()\">\n <g>\n \t<g>\n \t\t<path style=\"fill:#2C2F33;\" d=\"M244.8,489.6c135,0,244.8-109.8,244.8-244.8S379.8,0,244.8,0S0,109.8,0,244.8\n \t\t\tS109.8,489.6,244.8,489.6z M244.8,19.8c124.1,0,225,100.9,225,225s-100.9,225-225,225s-225-100.9-225-225S120.7,19.8,244.8,19.8z\"\n \t\t\t/>\n \t\t<path style=\"fill:#3C92CA;\" d=\"M210,326.1c1.9,1.9,4.5,2.9,7,2.9s5.1-1,7-2.9l74.3-74.3c1.9-1.9,2.9-4.4,2.9-7s-1-5.1-2.9-7\n \t\t\tL224,163.5c-3.9-3.9-10.1-3.9-14,0s-3.9,10.1,0,14l67.3,67.3L210,312.1C206.2,316,206.2,322.3,210,326.1z\"/>\n \t</g>\n </g>\n </svg>\n </div>\n <div class=\"main-calendar-day-names\" *ngIf=\"view === 'year'\">\n <span class=\"day-name-unit\" *ngFor=\"let name of dayNames\">{{ name }}</span>\n </div>\n </div>\n <div class=\"main-calendar-container\" *ngIf=\"view === 'year'\">\n <div class=\"main-calendar-month-names\">\n <div class=\"month-name-unit\" *ngFor=\"let month of monthNames; let index = index\" (click)=\"month.isSelectable && selectMonth(index)\">\n <span class=\"month-unit\"\n [ngClass]=\"{ 'is-this-month': month.isThisMonth, 'is-disabled': !month.isSelectable ,'is-selected': month.isSelected}\">\n {{ month.name }}\n </span>\n </div>\n </div>\n <div class=\"main-calender-days-container\">\n <div class=\"main-calendar-days\">\n <div class=\"day-unit\" *ngFor=\"let day of days; let i = index;\" >\n <span [ngClass]=\"{ 'is-prev-month': !day.inThisMonth, 'is-today': day.isToday, 'is-disabled': !day.isSelectable, 'is-weekend': day.isWeekend , 'is-holiday' : day.isHoliday, 'is-selected': day.isSelected}\"\n (click)=\"day.isSelectable && setDate(i)\">\n {{ day.day }}\n </span>\n </div>\n </div>\n </div>\n </div>\n <div class=\"main-calendar-container\" *ngIf=\"view === 'years'\">\n <div class=\"main-calendar-years\">\n <span class=\"year-unit\" *ngFor=\"let year of years; let i = index;\" [ngClass]=\"{ 'is-selected': year.isThisYear , 'is-today': year.isToday , 'is-disabled' : !year.isSelectable}\" (click)=\"year.isSelectable && setYear(i)\">{{ year.year }}</span>\n </div>\n </div>\n </div>\n</div>\n", styles: [".ngx-moderndatepicker-position-bottom-left{top:40px;right:0}.ngx-moderndatepicker-position-bottom-right{top:40px;left:0}.ngx-moderndatepicker-position-top-left{bottom:40px;right:0}.ngx-moderndatepicker-position-top-right{bottom:40px;left:0}.ngx-moderndatepicker-container{position:relative}.ngx-moderndatepicker-container .ngx-moderndatepicker-input{padding:5px 10px;font-size:14px;width:200px;outline:none;border:1px solid #DFE3E9}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container{position:absolute;width:356px;height:230px;background:#ffffff;padding:10px;box-shadow:0 1px 4px #00000014;border:1px solid #DFE3E9;border-radius:4px}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .topbar-container{height:10px;padding:5px 0;display:flex;align-items:center;-webkit-user-select:none;-moz-user-select:none;user-select:none}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .topbar-container .main-calendar-selection-year{display:flex;align-items:center;width:108px;min-width:108px}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .topbar-container .main-calendar-day-names{color:#a4a9b1;width:100%;display:flex;align-items:center;font-size:12px;padding:0 0 0 5px}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .topbar-container .main-calendar-day-names .day-name-unit{width:14.2857142857%;height:30px;text-transform:uppercase;text-align:center;line-height:30px}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container svg{cursor:pointer}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container svg g{fill:#ced0da}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .topbar-title{color:#3d495c;font-size:15px;font-weight:400;margin:0 10px;cursor:pointer}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container{width:100%;height:100%;font-size:14px;font-weight:500;display:flex;flex-direction:row}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-month-names{display:flex;flex-flow:row wrap;width:108px;min-width:108px;padding:15px 0}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-month-names .month-name-unit{width:45px;height:30px;color:#000;text-align:center;border-radius:5px;line-height:30px;cursor:pointer}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-month-names .month-name-unit span{width:35px;padding:2.5px 7px;border-radius:15%;height:25px;line-height:25px;text-align:center}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-month-names .month-name-unit span:hover,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-month-names .month-name-unit span.is-this-month{border:2px solid #1A91EB;margin:-2px}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-month-names .month-name-unit span.is-disabled{cursor:not-allowed;color:#a4a9b1}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-month-names .month-name-unit span.is-disabled :hover{background:transparent}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-month-names .month-name-unit span.is-selected{background:#1A91EB;color:#fff;border:2px solid #1A91EB}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years{padding:15px 5px;width:100%;display:inline-block;max-height:275px;overflow:auto}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit{height:30px;display:inline-flex;float:left;width:14.2857142857%;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;color:#3d495c}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit span,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit span,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit span,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit span{width:28px;border-radius:15%;height:20px;line-height:20px;text-align:center}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit span.is-prev-month,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit span.is-prev-month,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit span.is-prev-month,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit span.is-prev-month{color:#a4a9b1}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit span:hover,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit span.is-today,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit span:hover,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit span.is-today,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit span:hover,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit span.is-today,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit span:hover,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit span.is-today{border:2px solid #1A91EB;margin:-2px}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit span.is-weekend,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit span.is-holiday,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit span.is-weekend,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit span.is-holiday,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit span.is-weekend,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit span.is-holiday,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit span.is-weekend,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit span.is-holiday{background:#e0e0e0}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit span.is-selected,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit span.is-selected,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit span.is-selected,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit span.is-selected{background:#1A91EB;color:#fff;border:2px solid #1A91EB}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit span.is-disabled,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit span.is-disabled,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit span.is-disabled,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit span.is-disabled{cursor:not-allowed;color:#a4a9b1}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .day-unit span.is-disabled :hover,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-days .year-unit span.is-disabled :hover,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .day-unit span.is-disabled :hover,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit span.is-disabled :hover{background:transparent}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years{height:200px;display:block;margin:auto;padding:5px 10px}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit{width:33.3333333333%;border-radius:10px}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit.is-disabled{cursor:not-allowed;color:#a4a9b1}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit.is-disabled :hover{background:transparent}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit.is-selected{background:#1A91EB;color:#fff;border:2px solid #1A91EB}.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit:hover,.ngx-moderndatepicker-container .ngx-moderndatepicker-calendar-container .main-calendar-container .main-calendar-years .year-unit.is-today{border:2px solid #1A91EB;margin:-2px}\n"] }]
|
|
355
|
+
}], ctorParameters: function () { return []; }, propDecorators: { options: [{
|
|
356
|
+
type: Input
|
|
357
|
+
}], headless: [{
|
|
358
|
+
type: Input
|
|
359
|
+
}], isOpened: [{
|
|
360
|
+
type: Input
|
|
361
|
+
}], position: [{
|
|
362
|
+
type: Input
|
|
363
|
+
}], onBlur: [{
|
|
364
|
+
type: HostListener,
|
|
365
|
+
args: ['document:click', ['$event']]
|
|
366
|
+
}] } });
|
|
367
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-moderndatepicker.component.js","sourceRoot":"","sources":["../../../../../src/ngx-moderndatepicker/component/ngx-moderndatepicker.component.ts","../../../../../src/ngx-moderndatepicker/component/ngx-moderndatepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, OnChanges, SimpleChanges, HostListener, forwardRef, ElementRef, ChangeDetectionStrategy } from '@angular/core';\nimport { NG_VALUE_ACCESSOR , ControlValueAccessor} from '@angular/forms';\nimport {\n  startOfMonth,\n  endOfMonth,\n  addMonths,\n  setYear,\n  eachDay,\n  getDate,\n  getMonth,\n  getYear,\n  isToday,\n  isSameDay,\n  isSameMonth,\n  isSameYear,\n  format,\n  getDay,\n  subDays,\n  setDay,\n  addYears,\n  subYears,\n  setMonth,\n} from 'date-fns';\n\nexport type AddClass = string | string[] | { [k: string]: boolean } | null;\n\nexport interface ModernDatePickerOptions {\n  minYear?: number; // default: current year - 30\n  maxYear?: number; // default: current year + 30\n  displayFormat?: string; // default: 'MMM D[,] YYYY'\n  dayNamesFormat?: string; // default 'ddd'\n  monthNamesFormat?: string; // default 'MMM'\n  firstCalendarDay?: number; // 0 = Sunday (default), 1 = Monday, ..\n  locale?: object;\n  minDate?: Date;\n  maxDate?: Date;\n  /** Placeholder for the input field */\n  placeholder?: string;\n  /** [ngClass] to add to the input field */\n  addClass?: AddClass;\n  /** [ngStyle] to add to the input field */\n  addStyle?: { [k: string]: any } | null;\n  /** ID to assign to the input field */\n  fieldId?: string;\n  /** If false, barTitleIfEmpty will be disregarded and a date will always be shown. Default: true */\n  weekendsDay?: number[];\n   /** Sunday is 0 , Highlights the weekends with gray background**/\n  holidayList?: Array<Date>;\n  /** List of Holidays **/\n}\n\n// Counter for calculating the auto-incrementing field ID\nlet counter = 0;\n\n/**\n * Internal library helper that helps to check if value is empty\n * @param value\n */\nconst isNil = (value: Date | ModernDatePickerOptions) => {\n  return (typeof value === 'undefined') || (value === null);\n};\n\n@Component({\n  selector: 'ngx-moderndatepicker',\n  templateUrl: 'ngx-moderndatepicker.component.html',\n  styleUrls: ['ngx-moderndatepicker.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => NgxModerndatepickerComponent), multi: true }\n  ]\n})\nexport class NgxModerndatepickerComponent implements OnInit, OnChanges, ControlValueAccessor {\n  @Input() options: ModernDatePickerOptions;\n\n  /**\n   * Disable datepicker's input\n   */\n  @Input() headless = false;\n\n  /**\n   * Set datepicker's visibility state\n   */\n  @Input() isOpened = false;\n\n  /**\n   * Datepicker dropdown position\n   */\n  @Input() position = 'bottom-right';\n\n  private positions = ['bottom-left', 'bottom-right', 'top-left', 'top-right'];\n\n  innerValue: Date;\n  displayValue: string;\n  displayFormat: string;\n  date: Date;\n  barTitle: string;\n  barTitleFormat: string;\n  barTitleIfEmpty: string;\n  minYear: number;\n  maxYear: number;\n  firstCalendarDay: number;\n  view: string;\n  years: { year: number; isThisYear: boolean; isToday: boolean; isSelectable: boolean }[];\n  dayNames: string[];\n  monthNames: Array<any>;\n  dayNamesFormat: string;\n  monthNamesFormat: string;\n  days: {\n    date: Date;\n    day: number;\n    month: number;\n    year: number;\n    inThisMonth: boolean;\n    isToday: boolean;\n    isSelected: boolean;\n    isSelectable: boolean;\n    isWeekend: boolean;\n    isHoliday: boolean;\n  }[];\n  locale: object;\n  placeholder: string;\n  addClass: AddClass;\n  addStyle: { [k: string]: any } | null;\n  fieldId: string;\n  disabled: boolean;\n  useEmptyBarTitle: boolean;\n  private onTouchedCallback: () => void = () => { };\n  private onChangeCallback: (_: any) => void = () => { };\n\n  public setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  get value(): Date {\n    return this.innerValue;\n  }\n\n  set value(val: Date) {\n    this.innerValue = val;\n    this.onChangeCallback(this.innerValue);\n  }\n\n  constructor() {\n  }\n\n  ngOnInit() {\n    this.view = 'year';\n    if (!this.date) {\n      this.date = new Date();\n    }\n    this.setOptions();\n    this.initDayNames();\n    this.initYears();\n    this.initMonthName();\n    this.init();\n    // Check if 'position' property is correct\n    if (this.positions.indexOf(this.position) === -1) {\n      const expectedValues = this.positions.join(', ');\n      const message = `ng-moderndatepicker: invalid position property value '${this.position}' (expected: ${expectedValues})`;\n\n      throw new TypeError(message);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n      this.setOptions();\n      this.initDayNames();\n      this.init();\n      this.initYears();\n      this.initMonthName();\n  }\n\n  get defaultFieldId(): string {\n    // Only evaluate and increment if required\n    const value = `datepicker-${counter++}`;\n    Object.defineProperty(this, 'defaultFieldId', {value});\n\n    return value;\n  }\n\n  setOptions(): void {\n    const today = new Date(); // this const was added because during my tests, I noticed that at this level this.date is undefined\n    this.minYear = this.options && this.options.minYear || getYear(today) - 30;\n    this.maxYear = this.options && this.options.maxYear || getYear(today) + 30;\n    this.displayFormat = this.options && this.options.displayFormat || 'MMM D[,] YYYY';\n    this.barTitleFormat = 'YYYY';\n    this.dayNamesFormat = this.options && this.options.dayNamesFormat || 'ddd';\n    this.monthNamesFormat = this.options && this.options.monthNamesFormat || 'MMM';\n    this.barTitleIfEmpty = (new Date().getFullYear()).toString();\n    this.firstCalendarDay = this.options && this.options.firstCalendarDay || 0;\n    this.locale = this.options && { locale: this.options.locale } || {};\n    this.placeholder = this.options && this.options.placeholder || '';\n    this.addClass = this.options && this.options.addClass || {};\n    this.addStyle = this.options && this.options.addStyle || {};\n    this.fieldId = this.options && this.options.fieldId || this.defaultFieldId;\n  }\n\n  nextYear(): void {\n      this.date = addYears(this.date, 1);\n      this.barTitle = format(this.date, this.barTitleFormat, this.locale);\n      this.init();\n      this.initMonthName();\n  }\n\n  prevYear(): void {\n      this.date = subYears(this.date, 1);\n      this.barTitle = format(this.date, this.barTitleFormat, this.locale);\n      this.init();\n      this.initMonthName();\n  }\n\n  setDate(i: number): void {\n    this.date = this.days[i].date;\n    this.value = this.date;\n    this.init();\n    this.close();\n  }\n\n  setYear(i: number): void {\n    this.date = setYear(this.date, this.years[i].year);\n    this.init();\n    this.initMonthName();\n    this.view = 'year';\n  }\n\n  selectMonth(i: number): void {\n    this.date = setMonth(this.date, i);\n    this.init();\n    this.initMonthName();\n    this.view = 'year';\n  }\n  /**\n   * Checks if specified date is in range of min and max dates\n   * @param date\n   */\n  private isDateSelectable(date: Date): boolean {\n    if (isNil(this.options)) {\n      return true;\n    }\n\n    const minDateSet = !isNil(this.options.minDate);\n    const maxDateSet = !isNil(this.options.maxDate);\n\n    const timestamp = date.valueOf();\n\n    if (minDateSet && (timestamp < this.options.minDate.valueOf())) {\n      return false;\n    }\n\n    if (maxDateSet && (timestamp > this.options.maxDate.valueOf())) {\n      return false;\n    }\n\n    return true;\n  }\n\n  private isWeekendDay(date: Date): boolean {\n    const weekendsDay = Array.isArray(this.options.weekendsDay);\n    if (weekendsDay) {\n      return this.options.weekendsDay.indexOf(getDay(date)) !== -1;\n    }\n\n    return false;\n  }\n\n  private isHoliday(date: Date): boolean {\n    const areHolidays = Array.isArray(this.options.holidayList);\n    if (areHolidays) {\n      return this.options.holidayList.some((day) => isSameDay(day, date));\n    }\n\n    return false;\n  }\n\n  init(): void {\n    // this.date may be null after .reset(); fall back to current date.\n    const actualDate = this.date || new Date();\n    const start = startOfMonth(actualDate);\n    const end = endOfMonth(actualDate);\n\n    this.days = eachDay(start, end).map(date => {\n      return {\n        date: date,\n        day: getDate(date),\n        month: getMonth(date),\n        year: getYear(date),\n        inThisMonth: true,\n        isToday: isToday(date),\n        isSelected: isSameDay(date, this.innerValue) && isSameMonth(date, this.innerValue) && isSameYear(date, this.innerValue),\n        isSelectable: this.isDateSelectable(date),\n        isWeekend: this.isWeekendDay(date),\n        isHoliday: this.isHoliday(date)\n      };\n    });\n\n    const tmp = getDay(start) - this.firstCalendarDay;\n    const prevDays = tmp < 0 ? 7 - this.firstCalendarDay : tmp;\n\n    for (let i = 1; i <= prevDays; i++) {\n      const date = subDays(start, i);\n      this.days.unshift({\n        date: date,\n        day: getDate(date),\n        month: getMonth(date),\n        year: getYear(date),\n        inThisMonth: false,\n        isToday: isToday(date),\n        isSelected: isSameDay(date, this.innerValue) && isSameMonth(date, this.innerValue) && isSameYear(date, this.innerValue),\n        isSelectable: this.isDateSelectable(date),\n        isWeekend : this.isWeekendDay(date),\n        isHoliday: this.isHoliday(date)\n      });\n    }\n\n    if (this.innerValue) {\n      this.displayValue = format(this.innerValue, this.displayFormat, this.locale);\n      this.barTitle = format(start, this.barTitleFormat, this.locale);\n    } else {\n      this.displayValue = '';\n      this.barTitle = this.useEmptyBarTitle ? this.barTitleIfEmpty : format(this.date, this.barTitleFormat, this.locale);\n    }\n  }\n\n  initYears(): void {\n    const range = this.maxYear - this.minYear;\n    this.years = Array.from(new Array(range), (x, i) => i + this.minYear).map(year => {\n      return {\n        year,\n        isThisYear: year === getYear(this.date),\n        isToday: year === getYear(new Date()),\n        isSelectable: this.isYearSelectable(year)\n      };\n    });\n  }\n\n  private isYearSelectable(date: any): boolean {\n    const minDate = !isNil(this.options.minDate) ? this.options.minDate : null;\n    const maxDate = !isNil(this.options.maxDate) ? this.options.maxDate : null;\n\n    if (minDate && maxDate) {\n      return minDate.getFullYear() <= date && date <= maxDate.getFullYear();\n    }\n\n    if (minDate) {\n      return minDate.getFullYear() <= date;\n    }\n\n    if (maxDate) {\n      return date <= maxDate.getFullYear();\n    }\n\n    return true;\n  }\n\n  initDayNames(): void {\n    this.dayNames = [];\n    const start = this.firstCalendarDay;\n    for (let i = start; i <= 6 + start; i++) {\n      const date = setDay(new Date(), i);\n      this.dayNames.push(format(date, this.dayNamesFormat, this.locale));\n    }\n  }\n\n  initMonthName(): void {\n    const monthNames = [];\n    const actualDate = this.date || new Date();\n    const currentDate = new Date(actualDate);\n    const start = subYears(new Date(currentDate.setMonth(11)), 1);\n\n    for (let i = 1; i <= 12; i++) {\n      const date = addMonths(start, i);\n      monthNames.push({\n        name: format(date, this.monthNamesFormat, this.locale),\n        isSelected: date.getMonth() === actualDate.getMonth(),\n        isThisMonth: isSameMonth(date, new Date()) && isSameYear(actualDate, new Date()),\n        isSelectable: this.isMonthSelectable(date)\n      });\n    }\n\n    this.monthNames = monthNames;\n  }\n\n  private isMonthSelectable(date: Date): boolean {\n    const minDate = !isNil(this.options.minDate) ? this.options.minDate : null;\n    const maxDate = !isNil(this.options.maxDate) ? this.options.maxDate : null;\n    const year = date.getFullYear();\n    const month = date.getMonth();\n\n    if (minDate && maxDate) {\n      const minYear = minDate.getFullYear();\n      const maxYear = maxDate.getFullYear();\n\n      if (year < minYear || year > maxYear) {\n        return false;\n      }\n\n      if (year === minYear && month < minDate.getMonth()) {\n        return false;\n      }\n\n      if (year === maxYear && month > maxDate.getMonth()) {\n        return false;\n      }\n\n      return true;\n    }\n\n    if (minDate) {\n      if (year < minDate.getFullYear()) {\n        return false;\n      }\n\n      if (year === minDate.getFullYear() && month < minDate.getMonth()) {\n        return false;\n      }\n\n      return true;\n    }\n\n    if (maxDate) {\n      if (year > maxDate.getFullYear()) {\n        return false;\n      }\n\n      if (year === maxDate.getFullYear() && month > maxDate.getMonth()) {\n        return false;\n      }\n\n      return true;\n    }\n\n    return true;\n  }\n\n  toggleView(): void {\n    this.view = this.view === 'year' ? 'years' : 'year';\n  }\n\n  toggle(): void {\n    this.isOpened = !this.isOpened;\n\n    if (!this.isOpened && this.view === 'years') {\n      this.toggleView();\n    }\n  }\n\n  close(): void {\n    this.isOpened = false;\n\n    if (this.view === 'years') {\n      this.toggleView();\n    }\n  }\n\n  reset(fireValueChangeEvent = false): void {\n    this.date = null;\n    this.innerValue = null;\n    this.init();\n    this.initMonthName();\n    if (fireValueChangeEvent && this.onChangeCallback) {\n      this.onChangeCallback(this.innerValue);\n    }\n  }\n\n  writeValue(val: Date) {\n    if (val) {\n      this.date = val;\n      this.innerValue = val;\n      this.init();\n      this.initMonthName();\n      this.displayValue = format(this.innerValue, this.displayFormat, this.locale);\n      this.barTitle = format(startOfMonth(val), this.barTitleFormat, this.locale);\n    }\n  }\n\n  registerOnChange(fn: any) {\n    this.onChangeCallback = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouchedCallback = fn;\n  }\n\n  @HostListener('document:click', ['$event']) onBlur(e: MouseEvent) {\n    if (!this.isOpened) {\n      return;\n    }\n\n    const input = document.querySelector('.ngx-moderndatepicker-input');\n\n    if (input === null) {\n      return;\n    }\n\n    if (e.target === input || input.contains(<any>e.target)) {\n      return;\n    }\n\n    const container = document.querySelector('.ngx-moderndatepicker-calendar-container');\n    const target = e.target as HTMLElement;\n    const isYearUnit = target.classList.contains('year-unit');\n    const isMonthUnit = target.classList.contains('month-unit');\n\n    if (container && container !== target && !container.contains(target) && !isYearUnit && !isMonthUnit) {\n      this.close();\n    }\n  }\n}\n","<div class=\"ngx-moderndatepicker-container\">\n  <input type=\"text\" *ngIf=\"!headless\" class=\"ngx-moderndatepicker-input\" [(ngModel)]=\"displayValue\" readonly [placeholder]=\"placeholder\"\n    [ngClass]=\"addClass\" [ngStyle]=\"addStyle\" [id]=\"fieldId\" [disabled]=\"disabled\" (click)=\"toggle()\" />\n  <ng-content></ng-content>\n  <div class=\"ngx-moderndatepicker-calendar-container ngx-moderndatepicker-position-{{position}}\" *ngIf=\"isOpened\">\n    <div class=\"topbar-container\">\n      <div class=\"main-calendar-selection-year\">\n        <svg width=\"15px\" height=\"15px\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" x=\"0px\" y=\"0px\"\n  \t       viewBox=\"0 0 489.6 489.6\" style=\"enable-background:new 0 0 489.6 489.6;\" xml:space=\"preserve\"\n          (click)=\"view === 'year' && prevYear()\">\n          <g>\n          \t<g>\n          \t\t<path style=\"fill:#2C2F33;\" d=\"M244.8,489.6c135,0,244.8-109.8,244.8-244.8S379.8,0,244.8,0S0,109.8,0,244.8\n          \t\t\tS109.8,489.6,244.8,489.6z M244.8,19.8c124.1,0,225,100.9,225,225s-100.9,225-225,225s-225-100.9-225-225S120.7,19.8,244.8,19.8z\"\n          \t\t\t/>\n          \t\t<path style=\"fill:#3C92CA;\" d=\"M265.5,326.1c1.9,1.9,4.5,2.9,7,2.9s5.1-1,7-2.9c3.9-3.9,3.9-10.1,0-14l-67.3-67.3l67.3-67.3\n          \t\t\tc3.9-3.9,3.9-10.1,0-14s-10.1-3.9-14,0l-74.3,74.3c-3.9,3.9-3.9,10.1,0,14L265.5,326.1z\"/>\n          \t</g>\n          </g>\n        </svg>\n        <span class=\"topbar-title\" (click)=\"toggleView(); initYears();\">{{ barTitle }}</span>\n        <svg width=\"15px\" height=\"15px\" viewBox=\"0 0 6 10\" version=\"1.1\" id=\"Layer_1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" x=\"0px\" y=\"0px\"\n  \t       viewBox=\"0 0 489.6 489.6\" style=\"enable-background:new 0 0 489.6 489.6;\" xml:space=\"preserve\"\n          (click)=\"view === 'year' && nextYear()\">\n          <g>\n          \t<g>\n          \t\t<path style=\"fill:#2C2F33;\" d=\"M244.8,489.6c135,0,244.8-109.8,244.8-244.8S379.8,0,244.8,0S0,109.8,0,244.8\n          \t\t\tS109.8,489.6,244.8,489.6z M244.8,19.8c124.1,0,225,100.9,225,225s-100.9,225-225,225s-225-100.9-225-225S120.7,19.8,244.8,19.8z\"\n          \t\t\t/>\n          \t\t<path style=\"fill:#3C92CA;\" d=\"M210,326.1c1.9,1.9,4.5,2.9,7,2.9s5.1-1,7-2.9l74.3-74.3c1.9-1.9,2.9-4.4,2.9-7s-1-5.1-2.9-7\n          \t\t\tL224,163.5c-3.9-3.9-10.1-3.9-14,0s-3.9,10.1,0,14l67.3,67.3L210,312.1C206.2,316,206.2,322.3,210,326.1z\"/>\n          \t</g>\n          </g>\n        </svg>\n      </div>\n      <div class=\"main-calendar-day-names\" *ngIf=\"view === 'year'\">\n        <span class=\"day-name-unit\" *ngFor=\"let name of dayNames\">{{ name }}</span>\n      </div>\n    </div>\n    <div class=\"main-calendar-container\" *ngIf=\"view === 'year'\">\n      <div class=\"main-calendar-month-names\">\n        <div class=\"month-name-unit\" *ngFor=\"let month of monthNames; let index = index\" (click)=\"month.isSelectable && selectMonth(index)\">\n          <span class=\"month-unit\"\n            [ngClass]=\"{ 'is-this-month': month.isThisMonth,  'is-disabled': !month.isSelectable ,'is-selected': month.isSelected}\">\n            {{ month.name }}\n          </span>\n        </div>\n      </div>\n      <div class=\"main-calender-days-container\">\n        <div class=\"main-calendar-days\">\n          <div class=\"day-unit\" *ngFor=\"let day of days; let i = index;\" >\n            <span [ngClass]=\"{ 'is-prev-month': !day.inThisMonth, 'is-today': day.isToday,  'is-disabled': !day.isSelectable, 'is-weekend': day.isWeekend , 'is-holiday' : day.isHoliday, 'is-selected': day.isSelected}\"\n              (click)=\"day.isSelectable && setDate(i)\">\n              {{ day.day }}\n            </span>\n          </div>\n        </div>\n       </div>\n      </div>\n    <div class=\"main-calendar-container\" *ngIf=\"view === 'years'\">\n      <div class=\"main-calendar-years\">\n        <span class=\"year-unit\" *ngFor=\"let year of years; let i = index;\" [ngClass]=\"{ 'is-selected': year.isThisYear , 'is-today': year.isToday , 'is-disabled' : !year.isSelectable}\" (click)=\"year.isSelectable && setYear(i)\">{{ year.year }}</span>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { FormsModule } from '@angular/forms';
|
|
4
|
+
import { NgxModerndatepickerComponent } from '../component/ngx-moderndatepicker.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class NgxModerndatepickerModule {
|
|
7
|
+
}
|
|
8
|
+
NgxModerndatepickerModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: NgxModerndatepickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
9
|
+
NgxModerndatepickerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: NgxModerndatepickerModule, declarations: [NgxModerndatepickerComponent], imports: [CommonModule, FormsModule], exports: [NgxModerndatepickerComponent] });
|
|
10
|
+
NgxModerndatepickerModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: NgxModerndatepickerModule, imports: [[CommonModule, FormsModule]] });
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: NgxModerndatepickerModule, decorators: [{
|
|
12
|
+
type: NgModule,
|
|
13
|
+
args: [{
|
|
14
|
+
declarations: [NgxModerndatepickerComponent],
|
|
15
|
+
imports: [CommonModule, FormsModule],
|
|
16
|
+
exports: [NgxModerndatepickerComponent]
|
|
17
|
+
}]
|
|
18
|
+
}] });
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LW1vZGVybmRhdGVwaWNrZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL25neC1tb2Rlcm5kYXRlcGlja2VyL21vZHVsZS9uZ3gtbW9kZXJuZGF0ZXBpY2tlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRTdDLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLDZDQUE2QyxDQUFDOztBQU8zRixNQUFNLE9BQU8seUJBQXlCOztzSEFBekIseUJBQXlCO3VIQUF6Qix5QkFBeUIsaUJBSnJCLDRCQUE0QixhQUNqQyxZQUFZLEVBQUUsV0FBVyxhQUN6Qiw0QkFBNEI7dUhBRTNCLHlCQUF5QixZQUgzQixDQUFDLFlBQVksRUFBRSxXQUFXLENBQUM7MkZBR3pCLHlCQUF5QjtrQkFMckMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyw0QkFBNEIsQ0FBQztvQkFDNUMsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFdBQVcsQ0FBQztvQkFDcEMsT0FBTyxFQUFFLENBQUMsNEJBQTRCLENBQUM7aUJBQ3hDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuaW1wb3J0IHsgTmd4TW9kZXJuZGF0ZXBpY2tlckNvbXBvbmVudCB9IGZyb20gJy4uL2NvbXBvbmVudC9uZ3gtbW9kZXJuZGF0ZXBpY2tlci5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtOZ3hNb2Rlcm5kYXRlcGlja2VyQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGVdLFxuICBleHBvcnRzOiBbTmd4TW9kZXJuZGF0ZXBpY2tlckNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgTmd4TW9kZXJuZGF0ZXBpY2tlck1vZHVsZSB7IH1cbiJdfQ==
|