@leanix/components 0.4.3 → 0.4.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/forms-ui/components/date-input/date-input.component.mjs +5 -4
- package/esm2020/lib/forms-ui/components/date-picker-ui/date-formatter.mjs +8 -0
- package/esm2020/lib/forms-ui/components/date-picker-ui/datepicker-inner.component.mjs +310 -0
- package/esm2020/lib/forms-ui/components/date-picker-ui/datepicker-ui.module.mjs +28 -0
- package/esm2020/lib/forms-ui/components/date-picker-ui/datepicker.component.mjs +205 -0
- package/esm2020/lib/forms-ui/components/date-picker-ui/datepicker.config.mjs +29 -0
- package/esm2020/lib/forms-ui/components/date-picker-ui/daypicker.component.mjs +305 -0
- package/esm2020/lib/forms-ui/components/date-picker-ui/isBs3.mjs +2 -0
- package/esm2020/lib/forms-ui/components/date-picker-ui/monthpicker.component.mjs +149 -0
- package/esm2020/lib/forms-ui/components/date-picker-ui/yearpicker.component.mjs +153 -0
- package/esm2020/lib/forms-ui/forms-ui.module.mjs +6 -6
- package/fesm2015/leanix-components.mjs +1151 -8
- package/fesm2015/leanix-components.mjs.map +1 -1
- package/fesm2020/leanix-components.mjs +1150 -8
- package/fesm2020/leanix-components.mjs.map +1 -1
- package/lib/forms-ui/components/date-picker-ui/date-formatter.d.ts +3 -0
- package/lib/forms-ui/components/date-picker-ui/datepicker-inner.component.d.ts +78 -0
- package/lib/forms-ui/components/date-picker-ui/datepicker-ui.module.d.ts +15 -0
- package/lib/forms-ui/components/date-picker-ui/datepicker.component.d.ts +81 -0
- package/lib/forms-ui/components/date-picker-ui/datepicker.config.d.ts +22 -0
- package/lib/forms-ui/components/date-picker-ui/daypicker.component.d.ts +17 -0
- package/lib/forms-ui/components/date-picker-ui/isBs3.d.ts +1 -0
- package/lib/forms-ui/components/date-picker-ui/monthpicker.component.d.ts +14 -0
- package/lib/forms-ui/components/date-picker-ui/yearpicker.component.d.ts +14 -0
- package/lib/forms-ui/forms-ui.module.d.ts +2 -2
- package/package.json +1 -1
- package/src/lib/forms-ui/components/date-picker-ui/README.md +8 -0
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
import { Component, EventEmitter, forwardRef, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { DatePickerInnerComponent } from './datepicker-inner.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "./datepicker.config";
|
|
6
|
+
import * as i2 from "./datepicker-inner.component";
|
|
7
|
+
import * as i3 from "./daypicker.component";
|
|
8
|
+
import * as i4 from "./monthpicker.component";
|
|
9
|
+
import * as i5 from "./yearpicker.component";
|
|
10
|
+
export const DATEPICKER_CONTROL_VALUE_ACCESSOR = {
|
|
11
|
+
provide: NG_VALUE_ACCESSOR,
|
|
12
|
+
useExisting: forwardRef(() => DatePickerComponent),
|
|
13
|
+
multi: true
|
|
14
|
+
};
|
|
15
|
+
/* tslint:enable:component-selector-name component-selector-type */
|
|
16
|
+
export class DatePickerComponent {
|
|
17
|
+
constructor(config) {
|
|
18
|
+
/** sets datepicker mode, supports: `day`, `month`, `year` */
|
|
19
|
+
this.datepickerMode = 'day';
|
|
20
|
+
/** if false week numbers will be hidden */
|
|
21
|
+
this.showWeeks = true;
|
|
22
|
+
this.selectionDone = new EventEmitter(undefined);
|
|
23
|
+
/** callback to invoke when the activeDate is changed. */
|
|
24
|
+
this.activeDateChange = new EventEmitter(undefined);
|
|
25
|
+
/* tslint:disable-next-line: no-any*/
|
|
26
|
+
this.onChange = Function.prototype;
|
|
27
|
+
/* tslint:disable-next-line: no-any*/
|
|
28
|
+
this.onTouched = Function.prototype;
|
|
29
|
+
this._now = new Date();
|
|
30
|
+
this.config = config;
|
|
31
|
+
this.configureOptions();
|
|
32
|
+
}
|
|
33
|
+
/** currently active date */
|
|
34
|
+
get activeDate() {
|
|
35
|
+
return this._activeDate || this._now;
|
|
36
|
+
}
|
|
37
|
+
set activeDate(value) {
|
|
38
|
+
this._activeDate = value;
|
|
39
|
+
}
|
|
40
|
+
configureOptions() {
|
|
41
|
+
Object.assign(this, this.config);
|
|
42
|
+
}
|
|
43
|
+
onUpdate(event) {
|
|
44
|
+
this.activeDate = event;
|
|
45
|
+
this.onChange(event);
|
|
46
|
+
}
|
|
47
|
+
onSelectionDone(event) {
|
|
48
|
+
this.selectionDone.emit(event);
|
|
49
|
+
}
|
|
50
|
+
onActiveDateChange(event) {
|
|
51
|
+
this.activeDateChange.emit(event);
|
|
52
|
+
}
|
|
53
|
+
// todo: support null value
|
|
54
|
+
/* tslint:disable-next-line: no-any*/
|
|
55
|
+
writeValue(value) {
|
|
56
|
+
if (this._datePicker.compare(value, this._activeDate) === 0) {
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
if (value && value instanceof Date) {
|
|
60
|
+
this.activeDate = value;
|
|
61
|
+
this._datePicker.select(value, false);
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
this.activeDate = (value ? new Date(value) : void 0);
|
|
65
|
+
}
|
|
66
|
+
registerOnChange(fn) {
|
|
67
|
+
this.onChange = fn;
|
|
68
|
+
}
|
|
69
|
+
registerOnTouched(fn) {
|
|
70
|
+
this.onTouched = fn;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
DatePickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: DatePickerComponent, deps: [{ token: i1.DatepickerConfig }], target: i0.ɵɵFactoryTarget.Component });
|
|
74
|
+
DatePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.1", type: DatePickerComponent, selector: "datepicker", inputs: { datepickerMode: "datepickerMode", initDate: "initDate", minDate: "minDate", maxDate: "maxDate", minMode: "minMode", maxMode: "maxMode", showWeeks: "showWeeks", formatDay: "formatDay", formatMonth: "formatMonth", formatYear: "formatYear", formatDayHeader: "formatDayHeader", formatDayTitle: "formatDayTitle", formatMonthTitle: "formatMonthTitle", startingDay: "startingDay", yearRange: "yearRange", onlyCurrentMonth: "onlyCurrentMonth", shortcutPropagation: "shortcutPropagation", monthColLimit: "monthColLimit", yearColLimit: "yearColLimit", customClass: "customClass", dateDisabled: "dateDisabled", dayDisabled: "dayDisabled", activeDate: "activeDate" }, outputs: { selectionDone: "selectionDone", activeDateChange: "activeDateChange" }, providers: [DATEPICKER_CONTROL_VALUE_ACCESSOR], viewQueries: [{ propertyName: "_datePicker", first: true, predicate: DatePickerInnerComponent, descendants: true, static: true }], ngImport: i0, template: `
|
|
75
|
+
<datepicker-inner
|
|
76
|
+
[activeDate]="activeDate"
|
|
77
|
+
(update)="onUpdate($event)"
|
|
78
|
+
[locale]="config.locale"
|
|
79
|
+
[datepickerMode]="datepickerMode"
|
|
80
|
+
[initDate]="initDate"
|
|
81
|
+
[minDate]="minDate"
|
|
82
|
+
[maxDate]="maxDate"
|
|
83
|
+
[minMode]="minMode"
|
|
84
|
+
[maxMode]="maxMode"
|
|
85
|
+
[showWeeks]="showWeeks"
|
|
86
|
+
[formatDay]="formatDay"
|
|
87
|
+
[formatMonth]="formatMonth"
|
|
88
|
+
[formatYear]="formatYear"
|
|
89
|
+
[formatDayHeader]="formatDayHeader"
|
|
90
|
+
[formatDayTitle]="formatDayTitle"
|
|
91
|
+
[formatMonthTitle]="formatMonthTitle"
|
|
92
|
+
[startingDay]="startingDay"
|
|
93
|
+
[yearRange]="yearRange"
|
|
94
|
+
[customClass]="customClass"
|
|
95
|
+
[dateDisabled]="dateDisabled"
|
|
96
|
+
[dayDisabled]="dayDisabled"
|
|
97
|
+
[onlyCurrentMonth]="onlyCurrentMonth"
|
|
98
|
+
[shortcutPropagation]="shortcutPropagation"
|
|
99
|
+
[monthColLimit]="monthColLimit"
|
|
100
|
+
[yearColLimit]="yearColLimit"
|
|
101
|
+
(selectionDone)="onSelectionDone($event)"
|
|
102
|
+
(activeDateChange)="onActiveDateChange($event)"
|
|
103
|
+
>
|
|
104
|
+
<daypicker tabindex="0"></daypicker>
|
|
105
|
+
<monthpicker tabindex="0"></monthpicker>
|
|
106
|
+
<yearpicker tabindex="0"></yearpicker>
|
|
107
|
+
</datepicker-inner>
|
|
108
|
+
`, isInline: true, dependencies: [{ kind: "component", type: i2.DatePickerInnerComponent, selector: "datepicker-inner", inputs: ["locale", "datepickerMode", "startingDay", "yearRange", "minDate", "maxDate", "minMode", "maxMode", "showWeeks", "formatDay", "formatMonth", "formatYear", "formatDayHeader", "formatDayTitle", "formatMonthTitle", "onlyCurrentMonth", "shortcutPropagation", "customClass", "monthColLimit", "yearColLimit", "dateDisabled", "dayDisabled", "initDate", "activeDate"], outputs: ["selectionDone", "update", "activeDateChange"] }, { kind: "component", type: i3.DayPickerComponent, selector: "daypicker" }, { kind: "component", type: i4.MonthPickerComponent, selector: "monthpicker" }, { kind: "component", type: i5.YearPickerComponent, selector: "yearpicker" }] });
|
|
109
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: DatePickerComponent, decorators: [{
|
|
110
|
+
type: Component,
|
|
111
|
+
args: [{
|
|
112
|
+
// eslint-disable-next-line @angular-eslint/component-selector
|
|
113
|
+
selector: 'datepicker',
|
|
114
|
+
template: `
|
|
115
|
+
<datepicker-inner
|
|
116
|
+
[activeDate]="activeDate"
|
|
117
|
+
(update)="onUpdate($event)"
|
|
118
|
+
[locale]="config.locale"
|
|
119
|
+
[datepickerMode]="datepickerMode"
|
|
120
|
+
[initDate]="initDate"
|
|
121
|
+
[minDate]="minDate"
|
|
122
|
+
[maxDate]="maxDate"
|
|
123
|
+
[minMode]="minMode"
|
|
124
|
+
[maxMode]="maxMode"
|
|
125
|
+
[showWeeks]="showWeeks"
|
|
126
|
+
[formatDay]="formatDay"
|
|
127
|
+
[formatMonth]="formatMonth"
|
|
128
|
+
[formatYear]="formatYear"
|
|
129
|
+
[formatDayHeader]="formatDayHeader"
|
|
130
|
+
[formatDayTitle]="formatDayTitle"
|
|
131
|
+
[formatMonthTitle]="formatMonthTitle"
|
|
132
|
+
[startingDay]="startingDay"
|
|
133
|
+
[yearRange]="yearRange"
|
|
134
|
+
[customClass]="customClass"
|
|
135
|
+
[dateDisabled]="dateDisabled"
|
|
136
|
+
[dayDisabled]="dayDisabled"
|
|
137
|
+
[onlyCurrentMonth]="onlyCurrentMonth"
|
|
138
|
+
[shortcutPropagation]="shortcutPropagation"
|
|
139
|
+
[monthColLimit]="monthColLimit"
|
|
140
|
+
[yearColLimit]="yearColLimit"
|
|
141
|
+
(selectionDone)="onSelectionDone($event)"
|
|
142
|
+
(activeDateChange)="onActiveDateChange($event)"
|
|
143
|
+
>
|
|
144
|
+
<daypicker tabindex="0"></daypicker>
|
|
145
|
+
<monthpicker tabindex="0"></monthpicker>
|
|
146
|
+
<yearpicker tabindex="0"></yearpicker>
|
|
147
|
+
</datepicker-inner>
|
|
148
|
+
`,
|
|
149
|
+
providers: [DATEPICKER_CONTROL_VALUE_ACCESSOR]
|
|
150
|
+
}]
|
|
151
|
+
}], ctorParameters: function () { return [{ type: i1.DatepickerConfig }]; }, propDecorators: { datepickerMode: [{
|
|
152
|
+
type: Input
|
|
153
|
+
}], initDate: [{
|
|
154
|
+
type: Input
|
|
155
|
+
}], minDate: [{
|
|
156
|
+
type: Input
|
|
157
|
+
}], maxDate: [{
|
|
158
|
+
type: Input
|
|
159
|
+
}], minMode: [{
|
|
160
|
+
type: Input
|
|
161
|
+
}], maxMode: [{
|
|
162
|
+
type: Input
|
|
163
|
+
}], showWeeks: [{
|
|
164
|
+
type: Input
|
|
165
|
+
}], formatDay: [{
|
|
166
|
+
type: Input
|
|
167
|
+
}], formatMonth: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], formatYear: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], formatDayHeader: [{
|
|
172
|
+
type: Input
|
|
173
|
+
}], formatDayTitle: [{
|
|
174
|
+
type: Input
|
|
175
|
+
}], formatMonthTitle: [{
|
|
176
|
+
type: Input
|
|
177
|
+
}], startingDay: [{
|
|
178
|
+
type: Input
|
|
179
|
+
}], yearRange: [{
|
|
180
|
+
type: Input
|
|
181
|
+
}], onlyCurrentMonth: [{
|
|
182
|
+
type: Input
|
|
183
|
+
}], shortcutPropagation: [{
|
|
184
|
+
type: Input
|
|
185
|
+
}], monthColLimit: [{
|
|
186
|
+
type: Input
|
|
187
|
+
}], yearColLimit: [{
|
|
188
|
+
type: Input
|
|
189
|
+
}], customClass: [{
|
|
190
|
+
type: Input
|
|
191
|
+
}], dateDisabled: [{
|
|
192
|
+
type: Input
|
|
193
|
+
}], dayDisabled: [{
|
|
194
|
+
type: Input
|
|
195
|
+
}], activeDate: [{
|
|
196
|
+
type: Input
|
|
197
|
+
}], selectionDone: [{
|
|
198
|
+
type: Output
|
|
199
|
+
}], activeDateChange: [{
|
|
200
|
+
type: Output
|
|
201
|
+
}], _datePicker: [{
|
|
202
|
+
type: ViewChild,
|
|
203
|
+
args: [DatePickerInnerComponent, { static: true }]
|
|
204
|
+
}] } });
|
|
205
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/date-picker-ui/datepicker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, forwardRef, Input, Output, Provider, ViewChild } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DatePickerInnerComponent } from './datepicker-inner.component';\nimport { DatepickerConfig } from './datepicker.config';\n\nexport const DATEPICKER_CONTROL_VALUE_ACCESSOR: Provider = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => DatePickerComponent),\n  multi: true\n};\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'datepicker',\n  template: `\n    <datepicker-inner\n      [activeDate]=\"activeDate\"\n      (update)=\"onUpdate($event)\"\n      [locale]=\"config.locale\"\n      [datepickerMode]=\"datepickerMode\"\n      [initDate]=\"initDate\"\n      [minDate]=\"minDate\"\n      [maxDate]=\"maxDate\"\n      [minMode]=\"minMode\"\n      [maxMode]=\"maxMode\"\n      [showWeeks]=\"showWeeks\"\n      [formatDay]=\"formatDay\"\n      [formatMonth]=\"formatMonth\"\n      [formatYear]=\"formatYear\"\n      [formatDayHeader]=\"formatDayHeader\"\n      [formatDayTitle]=\"formatDayTitle\"\n      [formatMonthTitle]=\"formatMonthTitle\"\n      [startingDay]=\"startingDay\"\n      [yearRange]=\"yearRange\"\n      [customClass]=\"customClass\"\n      [dateDisabled]=\"dateDisabled\"\n      [dayDisabled]=\"dayDisabled\"\n      [onlyCurrentMonth]=\"onlyCurrentMonth\"\n      [shortcutPropagation]=\"shortcutPropagation\"\n      [monthColLimit]=\"monthColLimit\"\n      [yearColLimit]=\"yearColLimit\"\n      (selectionDone)=\"onSelectionDone($event)\"\n      (activeDateChange)=\"onActiveDateChange($event)\"\n    >\n      <daypicker tabindex=\"0\"></daypicker>\n      <monthpicker tabindex=\"0\"></monthpicker>\n      <yearpicker tabindex=\"0\"></yearpicker>\n    </datepicker-inner>\n  `,\n  providers: [DATEPICKER_CONTROL_VALUE_ACCESSOR]\n})\n/* tslint:enable:component-selector-name component-selector-type */\nexport class DatePickerComponent implements ControlValueAccessor {\n  /** sets datepicker mode, supports: `day`, `month`, `year` */\n  @Input() datepickerMode = 'day';\n  /** default date to show if `ng-model` value is not specified */\n  @Input()\n  initDate!: Date;\n  /**  oldest selectable date */\n  @Input()\n  minDate!: Date;\n  /** latest selectable date */\n  @Input()\n  maxDate!: Date;\n  /** set lower datepicker mode, supports: `day`, `month`, `year` */\n  @Input()\n  minMode!: string;\n  /** sets upper datepicker mode, supports: `day`, `month`, `year` */\n  @Input()\n  maxMode!: string;\n  /** if false week numbers will be hidden */\n  @Input() showWeeks = true;\n  /** format of day in month */\n  @Input()\n  formatDay!: string;\n  /** format of month in year */\n  @Input()\n  formatMonth!: string;\n  /** format of year in year range */\n  @Input()\n  formatYear!: string;\n  /** format of day in week header */\n  @Input()\n  formatDayHeader!: string;\n  /** format of title when selecting day */\n  @Input()\n  formatDayTitle!: string;\n  /** format of title when selecting month */\n  @Input()\n  formatMonthTitle!: string;\n  /** starting day of the week from 0-6 (0=Sunday, ..., 6=Saturday) */\n  @Input()\n  startingDay!: number;\n  /** number of years displayed in year selection */\n  @Input()\n  yearRange!: number;\n  /** if true only dates from the currently displayed month will be shown */\n  @Input()\n  onlyCurrentMonth!: boolean;\n  /** if true shortcut`s event propagation will be disabled */\n  @Input()\n  shortcutPropagation!: boolean;\n  /** number of months displayed in a single row of month picker */\n  @Input()\n  monthColLimit!: number;\n  /** number of years displayed in a single row of year picker */\n  @Input()\n  yearColLimit!: number;\n  /** array of custom css classes to be applied to targeted dates */\n  @Input()\n  customClass!: { date: Date; mode: string; clazz: string }[];\n  /** array of disabled dates */\n  @Input()\n  dateDisabled!: { date: Date; mode: string }[];\n  /** disabled days of the week from 0-6 (0=Sunday, ..., 6=Saturday) */\n  @Input()\n  dayDisabled!: number[];\n\n  /** currently active date */\n  @Input()\n  get activeDate(): Date {\n    return this._activeDate || this._now;\n  }\n\n  set activeDate(value: Date) {\n    this._activeDate = value;\n  }\n\n  @Output()\n  selectionDone: EventEmitter<Date> = new EventEmitter<Date>(undefined);\n\n  /** callback to invoke when the activeDate is changed. */\n  @Output()\n  activeDateChange: EventEmitter<Date> = new EventEmitter<Date>(undefined);\n\n  @ViewChild(DatePickerInnerComponent, { static: true })\n  _datePicker!: DatePickerInnerComponent;\n\n  /* tslint:disable-next-line: no-any*/\n  onChange: any = Function.prototype;\n  /* tslint:disable-next-line: no-any*/\n  onTouched: any = Function.prototype;\n\n  config: DatepickerConfig;\n\n  protected _now: Date = new Date();\n  protected _activeDate!: Date;\n\n  constructor(config: DatepickerConfig) {\n    this.config = config;\n    this.configureOptions();\n  }\n\n  configureOptions(): void {\n    Object.assign(this, this.config);\n  }\n\n  onUpdate(event: Date): void {\n    this.activeDate = event;\n    this.onChange(event);\n  }\n\n  onSelectionDone(event: Date): void {\n    this.selectionDone.emit(event);\n  }\n\n  onActiveDateChange(event: Date): void {\n    this.activeDateChange.emit(event);\n  }\n  // todo: support null value\n  /* tslint:disable-next-line: no-any*/\n  writeValue(value: any): void {\n    if (this._datePicker.compare(value, this._activeDate) === 0) {\n      return;\n    }\n    if (value && value instanceof Date) {\n      this.activeDate = value;\n      this._datePicker.select(value, false);\n\n      return;\n    }\n\n    this.activeDate = (value ? new Date(value) : void 0)!;\n  }\n\n  registerOnChange(fn: () => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n}\n"]}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class DatepickerConfig {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.locale = 'en';
|
|
6
|
+
this.datepickerMode = 'day';
|
|
7
|
+
this.startingDay = 0;
|
|
8
|
+
this.yearRange = 20;
|
|
9
|
+
this.minMode = 'day';
|
|
10
|
+
this.maxMode = 'year';
|
|
11
|
+
this.showWeeks = true;
|
|
12
|
+
this.formatDay = 'DD';
|
|
13
|
+
this.formatMonth = 'MMMM';
|
|
14
|
+
this.formatYear = 'YYYY';
|
|
15
|
+
this.formatDayHeader = 'dd';
|
|
16
|
+
this.formatDayTitle = 'MMMM YYYY';
|
|
17
|
+
this.formatMonthTitle = 'YYYY';
|
|
18
|
+
this.onlyCurrentMonth = false;
|
|
19
|
+
this.monthColLimit = 3;
|
|
20
|
+
this.yearColLimit = 5;
|
|
21
|
+
this.shortcutPropagation = false;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
DatepickerConfig.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: DatepickerConfig, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
25
|
+
DatepickerConfig.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: DatepickerConfig });
|
|
26
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: DatepickerConfig, decorators: [{
|
|
27
|
+
type: Injectable
|
|
28
|
+
}] });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXBpY2tlci5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9jb21wb25lbnRzL2RhdGUtcGlja2VyLXVpL2RhdGVwaWNrZXIuY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRzNDLE1BQU0sT0FBTyxnQkFBZ0I7SUFEN0I7UUFFRSxXQUFNLEdBQUcsSUFBSSxDQUFDO1FBQ2QsbUJBQWMsR0FBRyxLQUFLLENBQUM7UUFDdkIsZ0JBQVcsR0FBRyxDQUFDLENBQUM7UUFDaEIsY0FBUyxHQUFHLEVBQUUsQ0FBQztRQUNmLFlBQU8sR0FBRyxLQUFLLENBQUM7UUFDaEIsWUFBTyxHQUFHLE1BQU0sQ0FBQztRQUNqQixjQUFTLEdBQUcsSUFBSSxDQUFDO1FBQ2pCLGNBQVMsR0FBRyxJQUFJLENBQUM7UUFDakIsZ0JBQVcsR0FBRyxNQUFNLENBQUM7UUFDckIsZUFBVSxHQUFHLE1BQU0sQ0FBQztRQUNwQixvQkFBZSxHQUFHLElBQUksQ0FBQztRQUN2QixtQkFBYyxHQUFHLFdBQVcsQ0FBQztRQUM3QixxQkFBZ0IsR0FBRyxNQUFNLENBQUM7UUFDMUIscUJBQWdCLEdBQUcsS0FBSyxDQUFDO1FBQ3pCLGtCQUFhLEdBQUcsQ0FBQyxDQUFDO1FBQ2xCLGlCQUFZLEdBQUcsQ0FBQyxDQUFDO1FBQ2pCLHdCQUFtQixHQUFHLEtBQUssQ0FBQztLQUM3Qjs7NkdBbEJZLGdCQUFnQjtpSEFBaEIsZ0JBQWdCOzJGQUFoQixnQkFBZ0I7a0JBRDVCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBEYXRlcGlja2VyQ29uZmlnIHtcbiAgbG9jYWxlID0gJ2VuJztcbiAgZGF0ZXBpY2tlck1vZGUgPSAnZGF5JztcbiAgc3RhcnRpbmdEYXkgPSAwO1xuICB5ZWFyUmFuZ2UgPSAyMDtcbiAgbWluTW9kZSA9ICdkYXknO1xuICBtYXhNb2RlID0gJ3llYXInO1xuICBzaG93V2Vla3MgPSB0cnVlO1xuICBmb3JtYXREYXkgPSAnREQnO1xuICBmb3JtYXRNb250aCA9ICdNTU1NJztcbiAgZm9ybWF0WWVhciA9ICdZWVlZJztcbiAgZm9ybWF0RGF5SGVhZGVyID0gJ2RkJztcbiAgZm9ybWF0RGF5VGl0bGUgPSAnTU1NTSBZWVlZJztcbiAgZm9ybWF0TW9udGhUaXRsZSA9ICdZWVlZJztcbiAgb25seUN1cnJlbnRNb250aCA9IGZhbHNlO1xuICBtb250aENvbExpbWl0ID0gMztcbiAgeWVhckNvbExpbWl0ID0gNTtcbiAgc2hvcnRjdXRQcm9wYWdhdGlvbiA9IGZhbHNlO1xufVxuIl19
|
|
@@ -0,0 +1,305 @@
|
|
|
1
|
+
// @deprecated
|
|
2
|
+
// tslint:disable
|
|
3
|
+
import { Component } from '@angular/core';
|
|
4
|
+
import { isBs3 } from './isBs3';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "./datepicker-inner.component";
|
|
7
|
+
import * as i2 from "@angular/common";
|
|
8
|
+
export class DayPickerComponent {
|
|
9
|
+
constructor(datePicker) {
|
|
10
|
+
this.labels = [];
|
|
11
|
+
this.rows = [];
|
|
12
|
+
this.weekNumbers = [];
|
|
13
|
+
this.datePicker = datePicker;
|
|
14
|
+
}
|
|
15
|
+
get isBs4() {
|
|
16
|
+
return !isBs3();
|
|
17
|
+
}
|
|
18
|
+
/*protected getDaysInMonth(year:number, month:number) {
|
|
19
|
+
return ((month === 1) && (year % 4 === 0) &&
|
|
20
|
+
((year % 100 !== 0) || (year % 400 === 0))) ? 29 : DAYS_IN_MONTH[month];
|
|
21
|
+
}*/
|
|
22
|
+
ngOnInit() {
|
|
23
|
+
// eslint-disable-next-line @typescript-eslint/no-this-alias
|
|
24
|
+
const self = this;
|
|
25
|
+
this.datePicker.stepDay = { months: 1 };
|
|
26
|
+
this.datePicker.setRefreshViewHandler(function () {
|
|
27
|
+
const year = this.activeDate.getFullYear();
|
|
28
|
+
const month = this.activeDate.getMonth();
|
|
29
|
+
const firstDayOfMonth = new Date(year, month, 1);
|
|
30
|
+
const difference = this.startingDay - firstDayOfMonth.getDay();
|
|
31
|
+
const numDisplayedFromPreviousMonth = difference > 0 ? 7 - difference : -difference;
|
|
32
|
+
const firstDate = new Date(firstDayOfMonth.getTime());
|
|
33
|
+
if (numDisplayedFromPreviousMonth > 0) {
|
|
34
|
+
firstDate.setDate(-numDisplayedFromPreviousMonth + 1);
|
|
35
|
+
}
|
|
36
|
+
// 42 is the number of days on a six-week calendar
|
|
37
|
+
const _days = self.getDates(firstDate, 42);
|
|
38
|
+
const days = [];
|
|
39
|
+
for (let i = 0; i < 42; i++) {
|
|
40
|
+
const _dateObject = this.createDateObject(_days[i], this.formatDay);
|
|
41
|
+
_dateObject.secondary = _days[i]?.getMonth() !== month;
|
|
42
|
+
_dateObject.uid = this.uniqueId + '-' + i;
|
|
43
|
+
days[i] = _dateObject;
|
|
44
|
+
}
|
|
45
|
+
self.labels = [];
|
|
46
|
+
for (let j = 0; j < 7; j++) {
|
|
47
|
+
self.labels[j] = {};
|
|
48
|
+
self.labels[j].abbr = this.dateFilter(days[j].date, this.formatDayHeader);
|
|
49
|
+
self.labels[j].full = this.dateFilter(days[j].date, 'EEEE');
|
|
50
|
+
}
|
|
51
|
+
self.title = this.dateFilter(this.activeDate, this.formatDayTitle);
|
|
52
|
+
self.rows = this.split(days, 7);
|
|
53
|
+
if (this.showWeeks) {
|
|
54
|
+
self.weekNumbers = [];
|
|
55
|
+
const thursdayIndex = (4 + 7 - this.startingDay) % 7;
|
|
56
|
+
const numWeeks = self.rows.length;
|
|
57
|
+
for (let curWeek = 0; curWeek < numWeeks; curWeek++) {
|
|
58
|
+
self.weekNumbers.push(self.getISO8601WeekNumber(self.rows[curWeek][thursdayIndex].date));
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}, 'day');
|
|
62
|
+
this.datePicker.setCompareHandler(function (date1, date2) {
|
|
63
|
+
const d1 = new Date(date1.getFullYear(), date1.getMonth(), date1.getDate());
|
|
64
|
+
const d2 = new Date(date2.getFullYear(), date2.getMonth(), date2.getDate());
|
|
65
|
+
return d1.getTime() - d2.getTime();
|
|
66
|
+
}, 'day');
|
|
67
|
+
this.datePicker.refreshView();
|
|
68
|
+
}
|
|
69
|
+
getDates(startDate, n) {
|
|
70
|
+
const dates = new Array(n);
|
|
71
|
+
let current = new Date(startDate.getTime());
|
|
72
|
+
let i = 0;
|
|
73
|
+
let date;
|
|
74
|
+
while (i < n) {
|
|
75
|
+
date = new Date(current.getTime());
|
|
76
|
+
date = this.datePicker.fixTimeZone(date);
|
|
77
|
+
dates[i++] = date;
|
|
78
|
+
current = new Date(date.getFullYear(), date.getMonth(), date.getDate() + 1);
|
|
79
|
+
}
|
|
80
|
+
return dates;
|
|
81
|
+
}
|
|
82
|
+
getISO8601WeekNumber(date) {
|
|
83
|
+
const checkDate = new Date(date.getTime());
|
|
84
|
+
// Thursday
|
|
85
|
+
checkDate.setDate(checkDate.getDate() + 4 - (checkDate.getDay() || 7));
|
|
86
|
+
const time = checkDate.getTime();
|
|
87
|
+
// Compare with Jan 1
|
|
88
|
+
checkDate.setMonth(0);
|
|
89
|
+
checkDate.setDate(1);
|
|
90
|
+
return Math.floor(Math.round((time - checkDate.getTime()) / 86400000) / 7) + 1;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
DayPickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: DayPickerComponent, deps: [{ token: i1.DatePickerInnerComponent }], target: i0.ɵɵFactoryTarget.Component });
|
|
94
|
+
DayPickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.1", type: DayPickerComponent, selector: "daypicker", ngImport: i0, template: `
|
|
95
|
+
<table
|
|
96
|
+
*ngIf="datePicker.datepickerMode === 'day'"
|
|
97
|
+
role="grid"
|
|
98
|
+
[attr.aria-labelledby]="datePicker.uniqueId + '-title'"
|
|
99
|
+
aria-activedescendant="activeDateId"
|
|
100
|
+
>
|
|
101
|
+
<thead>
|
|
102
|
+
<tr>
|
|
103
|
+
<th>
|
|
104
|
+
<button
|
|
105
|
+
*ngIf="!isBs4"
|
|
106
|
+
type="button"
|
|
107
|
+
class="btn btn-default btn-secondary btn-sm pull-left float-left"
|
|
108
|
+
(click)="datePicker.move(-1)"
|
|
109
|
+
tabindex="-1"
|
|
110
|
+
>
|
|
111
|
+
‹
|
|
112
|
+
</button>
|
|
113
|
+
<button
|
|
114
|
+
*ngIf="isBs4"
|
|
115
|
+
type="button"
|
|
116
|
+
class="btn btn-default btn-secondary btn-sm pull-left float-left"
|
|
117
|
+
(click)="datePicker.move(-1)"
|
|
118
|
+
tabindex="-1"
|
|
119
|
+
>
|
|
120
|
+
<
|
|
121
|
+
</button>
|
|
122
|
+
</th>
|
|
123
|
+
<th [attr.colspan]="5 + (datePicker.showWeeks ? 1 : 0)">
|
|
124
|
+
<button
|
|
125
|
+
[id]="datePicker.uniqueId + '-title'"
|
|
126
|
+
type="button"
|
|
127
|
+
class="btn btn-default btn-secondary btn-sm"
|
|
128
|
+
(click)="datePicker.toggleMode(0)"
|
|
129
|
+
[disabled]="datePicker.datepickerMode === datePicker.maxMode"
|
|
130
|
+
[ngClass]="{ disabled: datePicker.datepickerMode === datePicker.maxMode }"
|
|
131
|
+
tabindex="-1"
|
|
132
|
+
style="width:100%;"
|
|
133
|
+
>
|
|
134
|
+
<strong>{{ title }}</strong>
|
|
135
|
+
</button>
|
|
136
|
+
</th>
|
|
137
|
+
<th>
|
|
138
|
+
<button
|
|
139
|
+
*ngIf="!isBs4"
|
|
140
|
+
type="button"
|
|
141
|
+
class="btn btn-default btn-secondary btn-sm pull-right float-right"
|
|
142
|
+
(click)="datePicker.move(1)"
|
|
143
|
+
tabindex="-1"
|
|
144
|
+
>
|
|
145
|
+
›
|
|
146
|
+
</button>
|
|
147
|
+
<button
|
|
148
|
+
*ngIf="isBs4"
|
|
149
|
+
type="button"
|
|
150
|
+
class="btn btn-default btn-secondary btn-sm pull-right float-right"
|
|
151
|
+
(click)="datePicker.move(1)"
|
|
152
|
+
tabindex="-1"
|
|
153
|
+
>
|
|
154
|
+
>
|
|
155
|
+
</button>
|
|
156
|
+
</th>
|
|
157
|
+
</tr>
|
|
158
|
+
<tr>
|
|
159
|
+
<th *ngIf="datePicker.showWeeks"></th>
|
|
160
|
+
<th *ngFor="let labelz of labels" class="text-center">
|
|
161
|
+
<small aria-label="labelz.full"
|
|
162
|
+
><b>{{ labelz.abbr }}</b></small
|
|
163
|
+
>
|
|
164
|
+
</th>
|
|
165
|
+
</tr>
|
|
166
|
+
</thead>
|
|
167
|
+
<tbody>
|
|
168
|
+
<ng-template ngFor [ngForOf]="rows" let-rowz="$implicit" let-index="index">
|
|
169
|
+
<tr *ngIf="!(datePicker.onlyCurrentMonth && rowz[0].secondary && rowz[6].secondary)">
|
|
170
|
+
<td *ngIf="datePicker.showWeeks" class="h6" class="text-center">
|
|
171
|
+
<em>{{ weekNumbers[index] }}</em>
|
|
172
|
+
</td>
|
|
173
|
+
<td *ngFor="let dtz of rowz" class="text-center" role="gridcell" [id]="dtz.uid">
|
|
174
|
+
<button
|
|
175
|
+
type="button"
|
|
176
|
+
style="min-width:100%;"
|
|
177
|
+
class="btn btn-sm {{ dtz.customClass }}"
|
|
178
|
+
*ngIf="!(datePicker.onlyCurrentMonth && dtz.secondary)"
|
|
179
|
+
[ngClass]="{
|
|
180
|
+
'btn-secondary': isBs4 && !dtz.selected && !datePicker.isActive(dtz),
|
|
181
|
+
'btn-info': dtz.selected,
|
|
182
|
+
disabled: dtz.disabled,
|
|
183
|
+
active: !isBs4 && datePicker.isActive(dtz),
|
|
184
|
+
'btn-default': !isBs4
|
|
185
|
+
}"
|
|
186
|
+
[disabled]="dtz.disabled"
|
|
187
|
+
(click)="datePicker.select(dtz.date)"
|
|
188
|
+
tabindex="-1"
|
|
189
|
+
>
|
|
190
|
+
<span [ngClass]="{ 'text-muted': dtz.secondary || dtz.current, 'text-info': !isBs4 && dtz.current }">{{ dtz.label }}</span>
|
|
191
|
+
</button>
|
|
192
|
+
</td>
|
|
193
|
+
</tr>
|
|
194
|
+
</ng-template>
|
|
195
|
+
</tbody>
|
|
196
|
+
</table>
|
|
197
|
+
`, isInline: true, styles: [":host .btn-secondary{color:#292b2c;background-color:#fff;border-color:#ccc}:host .btn-info .text-muted{color:#292b2c!important}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
198
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: DayPickerComponent, decorators: [{
|
|
199
|
+
type: Component,
|
|
200
|
+
args: [{ selector: 'daypicker', template: `
|
|
201
|
+
<table
|
|
202
|
+
*ngIf="datePicker.datepickerMode === 'day'"
|
|
203
|
+
role="grid"
|
|
204
|
+
[attr.aria-labelledby]="datePicker.uniqueId + '-title'"
|
|
205
|
+
aria-activedescendant="activeDateId"
|
|
206
|
+
>
|
|
207
|
+
<thead>
|
|
208
|
+
<tr>
|
|
209
|
+
<th>
|
|
210
|
+
<button
|
|
211
|
+
*ngIf="!isBs4"
|
|
212
|
+
type="button"
|
|
213
|
+
class="btn btn-default btn-secondary btn-sm pull-left float-left"
|
|
214
|
+
(click)="datePicker.move(-1)"
|
|
215
|
+
tabindex="-1"
|
|
216
|
+
>
|
|
217
|
+
‹
|
|
218
|
+
</button>
|
|
219
|
+
<button
|
|
220
|
+
*ngIf="isBs4"
|
|
221
|
+
type="button"
|
|
222
|
+
class="btn btn-default btn-secondary btn-sm pull-left float-left"
|
|
223
|
+
(click)="datePicker.move(-1)"
|
|
224
|
+
tabindex="-1"
|
|
225
|
+
>
|
|
226
|
+
<
|
|
227
|
+
</button>
|
|
228
|
+
</th>
|
|
229
|
+
<th [attr.colspan]="5 + (datePicker.showWeeks ? 1 : 0)">
|
|
230
|
+
<button
|
|
231
|
+
[id]="datePicker.uniqueId + '-title'"
|
|
232
|
+
type="button"
|
|
233
|
+
class="btn btn-default btn-secondary btn-sm"
|
|
234
|
+
(click)="datePicker.toggleMode(0)"
|
|
235
|
+
[disabled]="datePicker.datepickerMode === datePicker.maxMode"
|
|
236
|
+
[ngClass]="{ disabled: datePicker.datepickerMode === datePicker.maxMode }"
|
|
237
|
+
tabindex="-1"
|
|
238
|
+
style="width:100%;"
|
|
239
|
+
>
|
|
240
|
+
<strong>{{ title }}</strong>
|
|
241
|
+
</button>
|
|
242
|
+
</th>
|
|
243
|
+
<th>
|
|
244
|
+
<button
|
|
245
|
+
*ngIf="!isBs4"
|
|
246
|
+
type="button"
|
|
247
|
+
class="btn btn-default btn-secondary btn-sm pull-right float-right"
|
|
248
|
+
(click)="datePicker.move(1)"
|
|
249
|
+
tabindex="-1"
|
|
250
|
+
>
|
|
251
|
+
›
|
|
252
|
+
</button>
|
|
253
|
+
<button
|
|
254
|
+
*ngIf="isBs4"
|
|
255
|
+
type="button"
|
|
256
|
+
class="btn btn-default btn-secondary btn-sm pull-right float-right"
|
|
257
|
+
(click)="datePicker.move(1)"
|
|
258
|
+
tabindex="-1"
|
|
259
|
+
>
|
|
260
|
+
>
|
|
261
|
+
</button>
|
|
262
|
+
</th>
|
|
263
|
+
</tr>
|
|
264
|
+
<tr>
|
|
265
|
+
<th *ngIf="datePicker.showWeeks"></th>
|
|
266
|
+
<th *ngFor="let labelz of labels" class="text-center">
|
|
267
|
+
<small aria-label="labelz.full"
|
|
268
|
+
><b>{{ labelz.abbr }}</b></small
|
|
269
|
+
>
|
|
270
|
+
</th>
|
|
271
|
+
</tr>
|
|
272
|
+
</thead>
|
|
273
|
+
<tbody>
|
|
274
|
+
<ng-template ngFor [ngForOf]="rows" let-rowz="$implicit" let-index="index">
|
|
275
|
+
<tr *ngIf="!(datePicker.onlyCurrentMonth && rowz[0].secondary && rowz[6].secondary)">
|
|
276
|
+
<td *ngIf="datePicker.showWeeks" class="h6" class="text-center">
|
|
277
|
+
<em>{{ weekNumbers[index] }}</em>
|
|
278
|
+
</td>
|
|
279
|
+
<td *ngFor="let dtz of rowz" class="text-center" role="gridcell" [id]="dtz.uid">
|
|
280
|
+
<button
|
|
281
|
+
type="button"
|
|
282
|
+
style="min-width:100%;"
|
|
283
|
+
class="btn btn-sm {{ dtz.customClass }}"
|
|
284
|
+
*ngIf="!(datePicker.onlyCurrentMonth && dtz.secondary)"
|
|
285
|
+
[ngClass]="{
|
|
286
|
+
'btn-secondary': isBs4 && !dtz.selected && !datePicker.isActive(dtz),
|
|
287
|
+
'btn-info': dtz.selected,
|
|
288
|
+
disabled: dtz.disabled,
|
|
289
|
+
active: !isBs4 && datePicker.isActive(dtz),
|
|
290
|
+
'btn-default': !isBs4
|
|
291
|
+
}"
|
|
292
|
+
[disabled]="dtz.disabled"
|
|
293
|
+
(click)="datePicker.select(dtz.date)"
|
|
294
|
+
tabindex="-1"
|
|
295
|
+
>
|
|
296
|
+
<span [ngClass]="{ 'text-muted': dtz.secondary || dtz.current, 'text-info': !isBs4 && dtz.current }">{{ dtz.label }}</span>
|
|
297
|
+
</button>
|
|
298
|
+
</td>
|
|
299
|
+
</tr>
|
|
300
|
+
</ng-template>
|
|
301
|
+
</tbody>
|
|
302
|
+
</table>
|
|
303
|
+
`, styles: [":host .btn-secondary{color:#292b2c;background-color:#fff;border-color:#ccc}:host .btn-info .text-muted{color:#292b2c!important}\n"] }]
|
|
304
|
+
}], ctorParameters: function () { return [{ type: i1.DatePickerInnerComponent }]; } });
|
|
305
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daypicker.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/date-picker-ui/daypicker.component.ts"],"names":[],"mappings":"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","sourcesContent":["// @deprecated\n// tslint:disable\nimport { Component, OnInit } from '@angular/core';\nimport { DatePickerInnerComponent } from './datepicker-inner.component';\nimport { isBs3 } from './isBs3';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'daypicker',\n  template: `\n    <table\n      *ngIf=\"datePicker.datepickerMode === 'day'\"\n      role=\"grid\"\n      [attr.aria-labelledby]=\"datePicker.uniqueId + '-title'\"\n      aria-activedescendant=\"activeDateId\"\n    >\n      <thead>\n        <tr>\n          <th>\n            <button\n              *ngIf=\"!isBs4\"\n              type=\"button\"\n              class=\"btn btn-default btn-secondary btn-sm pull-left float-left\"\n              (click)=\"datePicker.move(-1)\"\n              tabindex=\"-1\"\n            >\n              ‹\n            </button>\n            <button\n              *ngIf=\"isBs4\"\n              type=\"button\"\n              class=\"btn btn-default btn-secondary btn-sm pull-left float-left\"\n              (click)=\"datePicker.move(-1)\"\n              tabindex=\"-1\"\n            >\n              &lt;\n            </button>\n          </th>\n          <th [attr.colspan]=\"5 + (datePicker.showWeeks ? 1 : 0)\">\n            <button\n              [id]=\"datePicker.uniqueId + '-title'\"\n              type=\"button\"\n              class=\"btn btn-default btn-secondary btn-sm\"\n              (click)=\"datePicker.toggleMode(0)\"\n              [disabled]=\"datePicker.datepickerMode === datePicker.maxMode\"\n              [ngClass]=\"{ disabled: datePicker.datepickerMode === datePicker.maxMode }\"\n              tabindex=\"-1\"\n              style=\"width:100%;\"\n            >\n              <strong>{{ title }}</strong>\n            </button>\n          </th>\n          <th>\n            <button\n              *ngIf=\"!isBs4\"\n              type=\"button\"\n              class=\"btn btn-default btn-secondary btn-sm pull-right float-right\"\n              (click)=\"datePicker.move(1)\"\n              tabindex=\"-1\"\n            >\n              ›\n            </button>\n            <button\n              *ngIf=\"isBs4\"\n              type=\"button\"\n              class=\"btn btn-default btn-secondary btn-sm pull-right float-right\"\n              (click)=\"datePicker.move(1)\"\n              tabindex=\"-1\"\n            >\n              &gt;\n            </button>\n          </th>\n        </tr>\n        <tr>\n          <th *ngIf=\"datePicker.showWeeks\"></th>\n          <th *ngFor=\"let labelz of labels\" class=\"text-center\">\n            <small aria-label=\"labelz.full\"\n              ><b>{{ labelz.abbr }}</b></small\n            >\n          </th>\n        </tr>\n      </thead>\n      <tbody>\n        <ng-template ngFor [ngForOf]=\"rows\" let-rowz=\"$implicit\" let-index=\"index\">\n          <tr *ngIf=\"!(datePicker.onlyCurrentMonth && rowz[0].secondary && rowz[6].secondary)\">\n            <td *ngIf=\"datePicker.showWeeks\" class=\"h6\" class=\"text-center\">\n              <em>{{ weekNumbers[index] }}</em>\n            </td>\n            <td *ngFor=\"let dtz of rowz\" class=\"text-center\" role=\"gridcell\" [id]=\"dtz.uid\">\n              <button\n                type=\"button\"\n                style=\"min-width:100%;\"\n                class=\"btn btn-sm {{ dtz.customClass }}\"\n                *ngIf=\"!(datePicker.onlyCurrentMonth && dtz.secondary)\"\n                [ngClass]=\"{\n                  'btn-secondary': isBs4 && !dtz.selected && !datePicker.isActive(dtz),\n                  'btn-info': dtz.selected,\n                  disabled: dtz.disabled,\n                  active: !isBs4 && datePicker.isActive(dtz),\n                  'btn-default': !isBs4\n                }\"\n                [disabled]=\"dtz.disabled\"\n                (click)=\"datePicker.select(dtz.date)\"\n                tabindex=\"-1\"\n              >\n                <span [ngClass]=\"{ 'text-muted': dtz.secondary || dtz.current, 'text-info': !isBs4 && dtz.current }\">{{ dtz.label }}</span>\n              </button>\n            </td>\n          </tr>\n        </ng-template>\n      </tbody>\n    </table>\n  `,\n  styles: [\n    `\n      :host .btn-secondary {\n        color: #292b2c;\n        background-color: #fff;\n        border-color: #ccc;\n      }\n      :host .btn-info .text-muted {\n        color: #292b2c !important;\n      }\n    `\n  ]\n})\nexport class DayPickerComponent implements OnInit {\n  labels: any[] = [];\n  title!: string;\n  rows: any[] = [];\n  weekNumbers: number[] = [];\n  datePicker: DatePickerInnerComponent;\n\n  constructor(datePicker: DatePickerInnerComponent) {\n    this.datePicker = datePicker;\n  }\n\n  get isBs4(): boolean {\n    return !isBs3();\n  }\n\n  /*protected getDaysInMonth(year:number, month:number) {\n   return ((month === 1) && (year % 4 === 0) &&\n   ((year % 100 !== 0) || (year % 400 === 0))) ? 29 : DAYS_IN_MONTH[month];\n   }*/\n  ngOnInit(): void {\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    const self = this;\n\n    this.datePicker.stepDay = { months: 1 };\n\n    this.datePicker.setRefreshViewHandler(function (this: any): void {\n      const year = this.activeDate.getFullYear();\n      const month = this.activeDate.getMonth();\n      const firstDayOfMonth = new Date(year, month, 1);\n      const difference = this.startingDay - firstDayOfMonth.getDay();\n      const numDisplayedFromPreviousMonth = difference > 0 ? 7 - difference : -difference;\n      const firstDate = new Date(firstDayOfMonth.getTime());\n\n      if (numDisplayedFromPreviousMonth > 0) {\n        firstDate.setDate(-numDisplayedFromPreviousMonth + 1);\n      }\n\n      // 42 is the number of days on a six-week calendar\n      const _days: Date[] = self.getDates(firstDate, 42);\n      const days: any[] = [];\n      for (let i = 0; i < 42; i++) {\n        const _dateObject = this.createDateObject(_days[i], this.formatDay);\n        _dateObject.secondary = _days[i]?.getMonth() !== month;\n        _dateObject.uid = this.uniqueId + '-' + i;\n        days[i] = _dateObject;\n      }\n\n      self.labels = [];\n      for (let j = 0; j < 7; j++) {\n        self.labels[j] = {};\n        self.labels[j].abbr = this.dateFilter(days[j].date, this.formatDayHeader);\n        self.labels[j].full = this.dateFilter(days[j].date, 'EEEE');\n      }\n\n      self.title = this.dateFilter(this.activeDate, this.formatDayTitle);\n      self.rows = this.split(days, 7);\n\n      if (this.showWeeks) {\n        self.weekNumbers = [];\n        const thursdayIndex = (4 + 7 - this.startingDay) % 7;\n        const numWeeks = self.rows.length;\n        for (let curWeek = 0; curWeek < numWeeks; curWeek++) {\n          self.weekNumbers.push(self.getISO8601WeekNumber(self.rows[curWeek][thursdayIndex].date));\n        }\n      }\n    }, 'day');\n\n    this.datePicker.setCompareHandler(function (date1: Date, date2: Date): number {\n      const d1 = new Date(date1.getFullYear(), date1.getMonth(), date1.getDate());\n      const d2 = new Date(date2.getFullYear(), date2.getMonth(), date2.getDate());\n      return d1.getTime() - d2.getTime();\n    }, 'day');\n\n    this.datePicker.refreshView();\n  }\n\n  protected getDates(startDate: Date, n: number): Date[] {\n    const dates: Date[] = new Array(n);\n    let current = new Date(startDate.getTime());\n    let i = 0;\n    let date: Date;\n    while (i < n) {\n      date = new Date(current.getTime());\n      date = this.datePicker.fixTimeZone(date);\n      dates[i++] = date;\n      current = new Date(date.getFullYear(), date.getMonth(), date.getDate() + 1);\n    }\n    return dates;\n  }\n\n  protected getISO8601WeekNumber(date: Date): number {\n    const checkDate = new Date(date.getTime());\n    // Thursday\n    checkDate.setDate(checkDate.getDate() + 4 - (checkDate.getDay() || 7));\n    const time = checkDate.getTime();\n    // Compare with Jan 1\n    checkDate.setMonth(0);\n    checkDate.setDate(1);\n    return Math.floor(Math.round((time - checkDate.getTime()) / 86400000) / 7) + 1;\n  }\n\n  // todo: key events implementation\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export const isBs3 = () => true;
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXNCczMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9jb21wb25lbnRzL2RhdGUtcGlja2VyLXVpL2lzQnMzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLEtBQUssR0FBRyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgaXNCczMgPSAoKSA9PiB0cnVlO1xuIl19
|