@leanix/components 0.4.2 → 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.
Files changed (27) hide show
  1. package/esm2020/lib/forms-ui/components/date-input/date-input.component.mjs +5 -4
  2. package/esm2020/lib/forms-ui/components/date-picker-ui/date-formatter.mjs +8 -0
  3. package/esm2020/lib/forms-ui/components/date-picker-ui/datepicker-inner.component.mjs +310 -0
  4. package/esm2020/lib/forms-ui/components/date-picker-ui/datepicker-ui.module.mjs +28 -0
  5. package/esm2020/lib/forms-ui/components/date-picker-ui/datepicker.component.mjs +205 -0
  6. package/esm2020/lib/forms-ui/components/date-picker-ui/datepicker.config.mjs +29 -0
  7. package/esm2020/lib/forms-ui/components/date-picker-ui/daypicker.component.mjs +305 -0
  8. package/esm2020/lib/forms-ui/components/date-picker-ui/isBs3.mjs +2 -0
  9. package/esm2020/lib/forms-ui/components/date-picker-ui/monthpicker.component.mjs +149 -0
  10. package/esm2020/lib/forms-ui/components/date-picker-ui/yearpicker.component.mjs +153 -0
  11. package/esm2020/lib/forms-ui/forms-ui.module.mjs +6 -6
  12. package/fesm2015/leanix-components.mjs +1151 -8
  13. package/fesm2015/leanix-components.mjs.map +1 -1
  14. package/fesm2020/leanix-components.mjs +1150 -8
  15. package/fesm2020/leanix-components.mjs.map +1 -1
  16. package/lib/forms-ui/components/date-picker-ui/date-formatter.d.ts +3 -0
  17. package/lib/forms-ui/components/date-picker-ui/datepicker-inner.component.d.ts +78 -0
  18. package/lib/forms-ui/components/date-picker-ui/datepicker-ui.module.d.ts +15 -0
  19. package/lib/forms-ui/components/date-picker-ui/datepicker.component.d.ts +81 -0
  20. package/lib/forms-ui/components/date-picker-ui/datepicker.config.d.ts +22 -0
  21. package/lib/forms-ui/components/date-picker-ui/daypicker.component.d.ts +17 -0
  22. package/lib/forms-ui/components/date-picker-ui/isBs3.d.ts +1 -0
  23. package/lib/forms-ui/components/date-picker-ui/monthpicker.component.d.ts +14 -0
  24. package/lib/forms-ui/components/date-picker-ui/yearpicker.component.d.ts +14 -0
  25. package/lib/forms-ui/forms-ui.module.d.ts +2 -2
  26. package/package.json +1 -1
  27. 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
+ &lt;
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
+ &gt;
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
+ &lt;
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
+ &gt;
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