@nova-ui/bits
Version:
SolarWinds Nova Framework
131 lines • 35.4 kB
JavaScript
// © 2022 SolarWinds Worldwide, LLC. All rights reserved.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to
// deal in the Software without restriction, including without limitation the
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
// sell copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
import { Component, ViewEncapsulation } from "@angular/core";
import moment from "moment/moment";
import { DatePickerInnerComponent } from "./date-picker-inner.component";
import * as i0 from "@angular/core";
import * as i1 from "./date-picker-inner.component";
import * as i2 from "@angular/common";
import * as i3 from "../button/button.component";
/** @ignore */
export class DayPickerComponent {
constructor(datePicker) {
this.datePicker = datePicker;
this.labels = [];
this.rows = [];
this.weekNumbers = [];
/*
* TODO: Check the default value, Added variable
* to avoid build prod crash
*/
this.todayDate = moment().toString();
this.datePicker = datePicker;
}
ngOnInit() {
this.datePicker.stepDay = { months: 1 };
this.datePicker.setRefreshViewHandler(() => {
const picker = this.datePicker;
const value = picker.value && picker.value.isValid()
? picker.value.clone()
: moment();
const month = value.month();
const firstDateOfMonthDayOfWeek = value
.clone()
.set("date", 1)
.day();
const difference = picker.startingDay - firstDateOfMonthDayOfWeek;
const numDisplayedFromPreviousMonth = difference > 0 ? 7 - difference : -difference;
const firstDateOfMonth = numDisplayedFromPreviousMonth > 0
? value
.clone()
.set("date", -numDisplayedFromPreviousMonth + 1)
: value.clone().set("date", 1);
// 42 is the number of days on a six-week calendar
const _days = this.getDates(firstDateOfMonth, 42);
const days = [];
for (let i = 0; i < 42; i++) {
const handler = this.datePicker.handleTimezone
? moment.parseZone
: moment;
const _dateObject = picker.createDateObject(handler(_days[i].date), picker.formatDay);
_dateObject.secondary = _days[i].month !== month;
_dateObject.uid = picker.uniqueId + "-" + i;
_dateObject.isCellVisible = !(picker.onlyCurrentMonth && _dateObject.secondary);
days[i] = _dateObject;
}
this.labels = [];
for (let j = 0; j < 7; j++) {
this.labels[j] = {
abbr: picker.formatDate(days[j].date, picker.formatDayHeader),
full: picker.formatDate(days[j].date, "EEEE"),
};
}
this.title = picker.formatDate(value, picker.formatDayTitle);
this.rows = picker.split(days, 7).map((row) => ({
days: row,
isRowVisible: !(picker.onlyCurrentMonth &&
row[0].secondary &&
row[6].secondary),
}));
if (picker.showWeeks) {
const thursdayIndex = (4 + 7 - picker.startingDay) % 7;
const numWeeks = this.rows.length;
this.weekNumbers = [];
for (let curWeek = 0; curWeek < numWeeks; curWeek++) {
this.weekNumbers.push(moment(this.rows[curWeek].days[thursdayIndex].date).isoWeek());
}
}
}, "day");
this.datePicker.setCompareHandler((date1, date2) => {
const d1 = moment({
year: date1.year(),
month: date1.month(),
date: date1.date(),
});
const d2 = moment({
year: date2.year(),
month: date2.month(),
date: date2.date(),
});
return d1.valueOf() - d2.valueOf();
}, "day");
}
getDates(startDate, n) {
const dates = new Array(n);
let current = startDate.clone();
let i = 0;
while (i < n) {
dates[i++] = {
date: current.toISOString(this.datePicker.handleTimezone),
day: current.day(),
month: current.month(),
};
current = current.clone().date(current.date() + 1);
}
return dates;
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DayPickerComponent, deps: [{ token: i1.DatePickerInnerComponent }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DayPickerComponent, selector: "nui-day-picker", ngImport: i0, template: "<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 nui-button\n type=\"button\"\n displayStyle=\"action\"\n icon=\"caret-left\"\n (click)=\"datePicker.move(-1, $event)\"\n tabindex=\"-1\"\n ></button>\n </th>\n <th [attr.colspan]=\"5 + (datePicker.showWeeks ? 1 : 0)\">\n <button\n nui-button\n type=\"button\"\n [id]=\"datePicker.uniqueId + '-title'\"\n displayStyle=\"action\"\n [disabled]=\"\n datePicker.datepickerMode === datePicker.maxMode\n \"\n class=\"change-mode-button\"\n [ngClass]=\"{\n disabled:\n datePicker.datepickerMode === datePicker.maxMode\n }\"\n (click)=\"datePicker.toggleMode($event)\"\n tabindex=\"-1\"\n >\n <span>{{ title }}</span>\n </button>\n </th>\n <th>\n <button\n nui-button\n type=\"button\"\n displayStyle=\"action\"\n icon=\"caret-right\"\n (click)=\"datePicker.move(1, $event)\"\n tabindex=\"-1\"\n ></button>\n </th>\n </tr>\n <tr>\n <th *ngIf=\"datePicker.showWeeks\"></th>\n <th *ngFor=\"let label of labels\" class=\"text-center\">\n <div class=\"day-label\">\n <span aria-label=\"label.full\">{{ label.abbr }}</span>\n </div>\n </th>\n </tr>\n </thead>\n <tbody>\n <ng-template\n ngFor\n [ngForOf]=\"rows\"\n let-row=\"$implicit\"\n let-index=\"index\"\n >\n <tr *ngIf=\"row.isRowVisible\">\n <td *ngIf=\"datePicker.showWeeks\" class=\"h6 text-center\">\n <em>{{ weekNumbers[index] }}</em>\n </td>\n <td\n *ngFor=\"let cell of row.days\"\n class=\"text-center day\"\n [id]=\"cell.uid\"\n >\n <button\n *ngIf=\"cell.isCellVisible\"\n nui-button\n type=\"button\"\n displayStyle=\"action\"\n [ngClass]=\"{\n selected: cell.selected,\n disabled: cell.disabled\n }\"\n [disabled]=\"cell.disabled\"\n (click)=\"datePicker.select(cell.date, $event)\"\n tabindex=\"-1\"\n >\n <span\n [ngClass]=\"{\n 'text-muted': cell.secondary,\n 'text-info': cell.current,\n today: cell.today\n }\"\n >{{ cell.label }}</span\n >\n </button>\n </td>\n </tr>\n </ng-template>\n <tr>\n <td [attr.colspan]=\"7 + (datePicker.showWeeks ? 1 : 0)\">\n <button\n nui-button\n type=\"button\"\n class=\"today-button\"\n displayStyle=\"action\"\n [disabled]=\"datePicker.isTodayButtonDisabled\"\n (click)=\"datePicker.select(todayDate, $event)\"\n i18n\n >\n Today\n </button>\n </td>\n </tr>\n </tbody>\n</table>\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"] }, { kind: "component", type: i3.ButtonComponent, selector: "[nui-button]", inputs: ["displayStyle", "icon", "iconColor", "iconRight", "isBusy", "isEmpty", "ariaLabel", "isRepeat", "size"] }], encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DayPickerComponent, decorators: [{
type: Component,
args: [{ selector: "nui-day-picker", encapsulation: ViewEncapsulation.None, template: "<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 nui-button\n type=\"button\"\n displayStyle=\"action\"\n icon=\"caret-left\"\n (click)=\"datePicker.move(-1, $event)\"\n tabindex=\"-1\"\n ></button>\n </th>\n <th [attr.colspan]=\"5 + (datePicker.showWeeks ? 1 : 0)\">\n <button\n nui-button\n type=\"button\"\n [id]=\"datePicker.uniqueId + '-title'\"\n displayStyle=\"action\"\n [disabled]=\"\n datePicker.datepickerMode === datePicker.maxMode\n \"\n class=\"change-mode-button\"\n [ngClass]=\"{\n disabled:\n datePicker.datepickerMode === datePicker.maxMode\n }\"\n (click)=\"datePicker.toggleMode($event)\"\n tabindex=\"-1\"\n >\n <span>{{ title }}</span>\n </button>\n </th>\n <th>\n <button\n nui-button\n type=\"button\"\n displayStyle=\"action\"\n icon=\"caret-right\"\n (click)=\"datePicker.move(1, $event)\"\n tabindex=\"-1\"\n ></button>\n </th>\n </tr>\n <tr>\n <th *ngIf=\"datePicker.showWeeks\"></th>\n <th *ngFor=\"let label of labels\" class=\"text-center\">\n <div class=\"day-label\">\n <span aria-label=\"label.full\">{{ label.abbr }}</span>\n </div>\n </th>\n </tr>\n </thead>\n <tbody>\n <ng-template\n ngFor\n [ngForOf]=\"rows\"\n let-row=\"$implicit\"\n let-index=\"index\"\n >\n <tr *ngIf=\"row.isRowVisible\">\n <td *ngIf=\"datePicker.showWeeks\" class=\"h6 text-center\">\n <em>{{ weekNumbers[index] }}</em>\n </td>\n <td\n *ngFor=\"let cell of row.days\"\n class=\"text-center day\"\n [id]=\"cell.uid\"\n >\n <button\n *ngIf=\"cell.isCellVisible\"\n nui-button\n type=\"button\"\n displayStyle=\"action\"\n [ngClass]=\"{\n selected: cell.selected,\n disabled: cell.disabled\n }\"\n [disabled]=\"cell.disabled\"\n (click)=\"datePicker.select(cell.date, $event)\"\n tabindex=\"-1\"\n >\n <span\n [ngClass]=\"{\n 'text-muted': cell.secondary,\n 'text-info': cell.current,\n today: cell.today\n }\"\n >{{ cell.label }}</span\n >\n </button>\n </td>\n </tr>\n </ng-template>\n <tr>\n <td [attr.colspan]=\"7 + (datePicker.showWeeks ? 1 : 0)\">\n <button\n nui-button\n type=\"button\"\n class=\"today-button\"\n displayStyle=\"action\"\n [disabled]=\"datePicker.isTodayButtonDisabled\"\n (click)=\"datePicker.select(todayDate, $event)\"\n i18n\n >\n Today\n </button>\n </td>\n </tr>\n </tbody>\n</table>\n" }]
}], ctorParameters: () => [{ type: i1.DatePickerInnerComponent }] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker-day-picker.component.js","sourceRoot":"","sources":["../../../../src/lib/date-picker/date-picker-day-picker.component.ts","../../../../src/lib/date-picker/date-picker-day-picker.component.html"],"names":[],"mappings":"AAAA,yDAAyD;AACzD,EAAE;AACF,+EAA+E;AAC/E,4EAA4E;AAC5E,8EAA8E;AAC9E,+EAA+E;AAC/E,8EAA8E;AAC9E,4DAA4D;AAC5D,EAAE;AACF,6EAA6E;AAC7E,uDAAuD;AACvD,EAAE;AACF,6EAA6E;AAC7E,4EAA4E;AAC5E,+EAA+E;AAC/E,0EAA0E;AAC1E,iFAAiF;AACjF,6EAA6E;AAC7E,iBAAiB;AAEjB,OAAO,EAAE,SAAS,EAAU,iBAAiB,EAAE,MAAM,eAAe,CAAC;AACrE,OAAO,MAAkB,MAAM,eAAe,CAAC;AAE/C,OAAO,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;;;;;AAEzE,cAAc;AAMd,MAAM,OAAO,kBAAkB;IAY3B,YAAmB,UAAoC;QAApC,eAAU,GAAV,UAAU,CAA0B;QAXhD,WAAM,GAAU,EAAE,CAAC;QAEnB,SAAI,GAAU,EAAE,CAAC;QACjB,gBAAW,GAAa,EAAE,CAAC;QAElC;;;WAGG;QACI,cAAS,GAAW,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC;QAG3C,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IACjC,CAAC;IAEM,QAAQ;QACX,IAAI,CAAC,UAAU,CAAC,OAAO,GAAG,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;QAExC,IAAI,CAAC,UAAU,CAAC,qBAAqB,CAAC,GAAS,EAAE;YAC7C,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC;YAC/B,MAAM,KAAK,GACP,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE;gBAClC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,EAAE;gBACtB,CAAC,CAAC,MAAM,EAAE,CAAC;YAEnB,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,EAAE,CAAC;YAC5B,MAAM,yBAAyB,GAAG,KAAK;iBAClC,KAAK,EAAE;iBACP,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC;iBACd,GAAG,EAAE,CAAC;YACX,MAAM,UAAU,GAAG,MAAM,CAAC,WAAW,GAAG,yBAAyB,CAAC;YAClE,MAAM,6BAA6B,GAC/B,UAAU,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC;YAClD,MAAM,gBAAgB,GAClB,6BAA6B,GAAG,CAAC;gBAC7B,CAAC,CAAC,KAAK;qBACA,KAAK,EAAE;qBACP,GAAG,CAAC,MAAM,EAAE,CAAC,6BAA6B,GAAG,CAAC,CAAC;gBACtD,CAAC,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YAEvC,kDAAkD;YAClD,MAAM,KAAK,GAAU,IAAI,CAAC,QAAQ,CAAC,gBAAgB,EAAE,EAAE,CAAC,CAAC;YACzD,MAAM,IAAI,GAAU,EAAE,CAAC;YAEvB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE;gBACzB,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,cAAc;oBAC1C,CAAC,CAAC,MAAM,CAAC,SAAS;oBAClB,CAAC,CAAC,MAAM,CAAC;gBACb,MAAM,WAAW,GAAG,MAAM,CAAC,gBAAgB,CACvC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EACtB,MAAM,CAAC,SAAS,CACnB,CAAC;gBAEF,WAAW,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,KAAK,KAAK,CAAC;gBACjD,WAAW,CAAC,GAAG,GAAG,MAAM,CAAC,QAAQ,GAAG,GAAG,GAAG,CAAC,CAAC;gBAC5C,WAAW,CAAC,aAAa,GAAG,CAAC,CACzB,MAAM,CAAC,gBAAgB,IAAI,WAAW,CAAC,SAAS,CACnD,CAAC;gBACF,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;aACzB;YAED,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;YAEjB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;gBACxB,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG;oBACb,IAAI,EAAE,MAAM,CAAC,UAAU,CACnB,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,EACZ,MAAM,CAAC,eAAe,CACzB;oBACD,IAAI,EAAE,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,MAAM,CAAC;iBAChD,CAAC;aACL;YAED,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,CAAC,cAAc,CAAC,CAAC;YAC7D,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;gBAC5C,IAAI,EAAE,GAAG;gBACT,YAAY,EAAE,CAAC,CACX,MAAM,CAAC,gBAAgB;oBACvB,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS;oBAChB,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CACnB;aACJ,CAAC,CAAC,CAAC;YAEJ,IAAI,MAAM,CAAC,SAAS,EAAE;gBAClB,MAAM,aAAa,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;gBACvD,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;gBAElC,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;gBAEtB,KAAK,IAAI,OAAO,GAAG,CAAC,EAAE,OAAO,GAAG,QAAQ,EAAE,OAAO,EAAE,EAAE;oBACjD,IAAI,CAAC,WAAW,CAAC,IAAI,CACjB,MAAM,CACF,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,IAAI,CAC9C,CAAC,OAAO,EAAE,CACd,CAAC;iBACL;aACJ;QACL,CAAC,EAAE,KAAK,CAAC,CAAC;QAEV,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAC7B,CAAC,KAAa,EAAE,KAAa,EAAU,EAAE;YACrC,MAAM,EAAE,GAAG,MAAM,CAAC;gBACd,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE;gBAClB,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE;gBACpB,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE;aACrB,CAAC,CAAC;YACH,MAAM,EAAE,GAAG,MAAM,CAAC;gBACd,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE;gBAClB,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE;gBACpB,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE;aACrB,CAAC,CAAC;YACH,OAAO,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE,CAAC,OAAO,EAAE,CAAC;QACvC,CAAC,EACD,KAAK,CACR,CAAC;IACN,CAAC;IAES,QAAQ,CAAC,SAAiB,EAAE,CAAS;QAC3C,MAAM,KAAK,GAAU,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC;QAElC,IAAI,OAAO,GAAG,SAAS,CAAC,KAAK,EAAE,CAAC;QAChC,IAAI,CAAC,GAAG,CAAC,CAAC;QAEV,OAAO,CAAC,GAAG,CAAC,EAAE;YACV,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG;gBACT,IAAI,EAAE,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC;gBACzD,GAAG,EAAE,OAAO,CAAC,GAAG,EAAE;gBAClB,KAAK,EAAE,OAAO,CAAC,KAAK,EAAE;aACzB,CAAC;YAEF,OAAO,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC;SACtD;QAED,OAAO,KAAK,CAAC;IACjB,CAAC;+GAvIQ,kBAAkB;mGAAlB,kBAAkB,sDC/B/B,woIAoHA;;4FDrFa,kBAAkB;kBAL9B,SAAS;+BACI,gBAAgB,iBAEX,iBAAiB,CAAC,IAAI","sourcesContent":["// © 2022 SolarWinds Worldwide, LLC. All rights reserved.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n//  of this software and associated documentation files (the \"Software\"), to\n//  deal in the Software without restriction, including without limitation the\n//  rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n//  sell copies of the Software, and to permit persons to whom the Software is\n//  furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n//  all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n//  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n//  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n//  AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n//  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n//  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n//  THE SOFTWARE.\n\nimport { Component, OnInit, ViewEncapsulation } from \"@angular/core\";\nimport moment, { Moment } from \"moment/moment\";\n\nimport { DatePickerInnerComponent } from \"./date-picker-inner.component\";\n\n/** @ignore */\n@Component({\n    selector: \"nui-day-picker\",\n    templateUrl: \"./date-picker-day-picker.component.html\",\n    encapsulation: ViewEncapsulation.None,\n})\nexport class DayPickerComponent implements OnInit {\n    public labels: any[] = [];\n    public title: string;\n    public rows: any[] = [];\n    public weekNumbers: number[] = [];\n\n    /*\n     *  TODO: Check the default value, Added variable\n     *  to avoid build prod crash\n     */\n    public todayDate: string = moment().toString();\n\n    constructor(public datePicker: DatePickerInnerComponent) {\n        this.datePicker = datePicker;\n    }\n\n    public ngOnInit(): void {\n        this.datePicker.stepDay = { months: 1 };\n\n        this.datePicker.setRefreshViewHandler((): void => {\n            const picker = this.datePicker;\n            const value =\n                picker.value && picker.value.isValid()\n                    ? picker.value.clone()\n                    : moment();\n\n            const month = value.month();\n            const firstDateOfMonthDayOfWeek = value\n                .clone()\n                .set(\"date\", 1)\n                .day();\n            const difference = picker.startingDay - firstDateOfMonthDayOfWeek;\n            const numDisplayedFromPreviousMonth =\n                difference > 0 ? 7 - difference : -difference;\n            const firstDateOfMonth =\n                numDisplayedFromPreviousMonth > 0\n                    ? value\n                          .clone()\n                          .set(\"date\", -numDisplayedFromPreviousMonth + 1)\n                    : value.clone().set(\"date\", 1);\n\n            // 42 is the number of days on a six-week calendar\n            const _days: any[] = this.getDates(firstDateOfMonth, 42);\n            const days: any[] = [];\n\n            for (let i = 0; i < 42; i++) {\n                const handler = this.datePicker.handleTimezone\n                    ? moment.parseZone\n                    : moment;\n                const _dateObject = picker.createDateObject(\n                    handler(_days[i].date),\n                    picker.formatDay\n                );\n\n                _dateObject.secondary = _days[i].month !== month;\n                _dateObject.uid = picker.uniqueId + \"-\" + i;\n                _dateObject.isCellVisible = !(\n                    picker.onlyCurrentMonth && _dateObject.secondary\n                );\n                days[i] = _dateObject;\n            }\n\n            this.labels = [];\n\n            for (let j = 0; j < 7; j++) {\n                this.labels[j] = {\n                    abbr: picker.formatDate(\n                        days[j].date,\n                        picker.formatDayHeader\n                    ),\n                    full: picker.formatDate(days[j].date, \"EEEE\"),\n                };\n            }\n\n            this.title = picker.formatDate(value, picker.formatDayTitle);\n            this.rows = picker.split(days, 7).map((row) => ({\n                days: row,\n                isRowVisible: !(\n                    picker.onlyCurrentMonth &&\n                    row[0].secondary &&\n                    row[6].secondary\n                ),\n            }));\n\n            if (picker.showWeeks) {\n                const thursdayIndex = (4 + 7 - picker.startingDay) % 7;\n                const numWeeks = this.rows.length;\n\n                this.weekNumbers = [];\n\n                for (let curWeek = 0; curWeek < numWeeks; curWeek++) {\n                    this.weekNumbers.push(\n                        moment(\n                            this.rows[curWeek].days[thursdayIndex].date\n                        ).isoWeek()\n                    );\n                }\n            }\n        }, \"day\");\n\n        this.datePicker.setCompareHandler(\n            (date1: Moment, date2: Moment): number => {\n                const d1 = moment({\n                    year: date1.year(),\n                    month: date1.month(),\n                    date: date1.date(),\n                });\n                const d2 = moment({\n                    year: date2.year(),\n                    month: date2.month(),\n                    date: date2.date(),\n                });\n                return d1.valueOf() - d2.valueOf();\n            },\n            \"day\"\n        );\n    }\n\n    protected getDates(startDate: Moment, n: number): Moment[] {\n        const dates: any[] = new Array(n);\n\n        let current = startDate.clone();\n        let i = 0;\n\n        while (i < n) {\n            dates[i++] = {\n                date: current.toISOString(this.datePicker.handleTimezone),\n                day: current.day(),\n                month: current.month(),\n            };\n\n            current = current.clone().date(current.date() + 1);\n        }\n\n        return dates;\n    }\n}\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                    nui-button\n                    type=\"button\"\n                    displayStyle=\"action\"\n                    icon=\"caret-left\"\n                    (click)=\"datePicker.move(-1, $event)\"\n                    tabindex=\"-1\"\n                ></button>\n            </th>\n            <th [attr.colspan]=\"5 + (datePicker.showWeeks ? 1 : 0)\">\n                <button\n                    nui-button\n                    type=\"button\"\n                    [id]=\"datePicker.uniqueId + '-title'\"\n                    displayStyle=\"action\"\n                    [disabled]=\"\n                        datePicker.datepickerMode === datePicker.maxMode\n                    \"\n                    class=\"change-mode-button\"\n                    [ngClass]=\"{\n                        disabled:\n                            datePicker.datepickerMode === datePicker.maxMode\n                    }\"\n                    (click)=\"datePicker.toggleMode($event)\"\n                    tabindex=\"-1\"\n                >\n                    <span>{{ title }}</span>\n                </button>\n            </th>\n            <th>\n                <button\n                    nui-button\n                    type=\"button\"\n                    displayStyle=\"action\"\n                    icon=\"caret-right\"\n                    (click)=\"datePicker.move(1, $event)\"\n                    tabindex=\"-1\"\n                ></button>\n            </th>\n        </tr>\n        <tr>\n            <th *ngIf=\"datePicker.showWeeks\"></th>\n            <th *ngFor=\"let label of labels\" class=\"text-center\">\n                <div class=\"day-label\">\n                    <span aria-label=\"label.full\">{{ label.abbr }}</span>\n                </div>\n            </th>\n        </tr>\n    </thead>\n    <tbody>\n        <ng-template\n            ngFor\n            [ngForOf]=\"rows\"\n            let-row=\"$implicit\"\n            let-index=\"index\"\n        >\n            <tr *ngIf=\"row.isRowVisible\">\n                <td *ngIf=\"datePicker.showWeeks\" class=\"h6 text-center\">\n                    <em>{{ weekNumbers[index] }}</em>\n                </td>\n                <td\n                    *ngFor=\"let cell of row.days\"\n                    class=\"text-center day\"\n                    [id]=\"cell.uid\"\n                >\n                    <button\n                        *ngIf=\"cell.isCellVisible\"\n                        nui-button\n                        type=\"button\"\n                        displayStyle=\"action\"\n                        [ngClass]=\"{\n                            selected: cell.selected,\n                            disabled: cell.disabled\n                        }\"\n                        [disabled]=\"cell.disabled\"\n                        (click)=\"datePicker.select(cell.date, $event)\"\n                        tabindex=\"-1\"\n                    >\n                        <span\n                            [ngClass]=\"{\n                                'text-muted': cell.secondary,\n                                'text-info': cell.current,\n                                today: cell.today\n                            }\"\n                            >{{ cell.label }}</span\n                        >\n                    </button>\n                </td>\n            </tr>\n        </ng-template>\n        <tr>\n            <td [attr.colspan]=\"7 + (datePicker.showWeeks ? 1 : 0)\">\n                <button\n                    nui-button\n                    type=\"button\"\n                    class=\"today-button\"\n                    displayStyle=\"action\"\n                    [disabled]=\"datePicker.isTodayButtonDisabled\"\n                    (click)=\"datePicker.select(todayDate, $event)\"\n                    i18n\n                >\n                    Today\n                </button>\n            </td>\n        </tr>\n    </tbody>\n</table>\n"]}