UNPKG

@nova-ui/bits

Version:

SolarWinds Nova Framework

69 lines 19.6 kB
// © 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 } 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 YearPickerComponent { constructor(datePicker) { this.datePicker = datePicker; this.rows = []; this.datePicker = datePicker; } ngOnInit() { this.datePicker.stepYear = { years: this.datePicker.yearRange }; this.datePicker.setRefreshViewHandler(() => { const picker = this.datePicker; const years = new Array(picker.yearRange); let date = picker.value && picker.value.isValid() ? picker.value.clone() : moment(); date = date.set("date", 1); const start = this.getStartingYear(date.year()); for (let i = 0; i < picker.yearRange; i++) { date = date.set({ year: start + i }); years[i] = picker.createDateObject(date, picker.formatYear); years[i].uid = picker.uniqueId + "-" + i; } this.title = [ years[0].label, years[picker.yearRange - 1].label, ].join(" - "); this.rows = picker.split(years, 5); }, "year"); this.datePicker.setCompareHandler((date1, date2) => date1.year() - date2.year(), "year"); } getStartingYear(year) { return (((year - 1) / this.datePicker.yearRange) * this.datePicker.yearRange + 1); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: YearPickerComponent, deps: [{ token: i1.DatePickerInnerComponent }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: YearPickerComponent, selector: "nui-year-picker", ngImport: i0, template: "<table *ngIf=\"datePicker.datepickerMode === 'year'\" role=\"grid\">\n <thead>\n <tr>\n <th>\n <button\n nui-button\n type=\"button\"\n icon=\"caret-left\"\n displayStyle=\"action\"\n (click)=\"datePicker.move(-1, $event)\"\n tabindex=\"-1\"\n ></button>\n </th>\n <th [attr.colspan]=\"3\">\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 icon=\"caret-right\"\n displayStyle=\"action\"\n (click)=\"datePicker.move(1, $event)\"\n tabindex=\"-1\"\n ></button>\n </th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let row of rows\">\n <td *ngFor=\"let cell of row\" class=\"text-center year\">\n <button\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 [ngClass]=\"{ 'text-info': cell.current }\">{{\n cell.label\n }}</span>\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"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: YearPickerComponent, decorators: [{ type: Component, args: [{ selector: "nui-year-picker", template: "<table *ngIf=\"datePicker.datepickerMode === 'year'\" role=\"grid\">\n <thead>\n <tr>\n <th>\n <button\n nui-button\n type=\"button\"\n icon=\"caret-left\"\n displayStyle=\"action\"\n (click)=\"datePicker.move(-1, $event)\"\n tabindex=\"-1\"\n ></button>\n </th>\n <th [attr.colspan]=\"3\">\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 icon=\"caret-right\"\n displayStyle=\"action\"\n (click)=\"datePicker.move(1, $event)\"\n tabindex=\"-1\"\n ></button>\n </th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let row of rows\">\n <td *ngFor=\"let cell of row\" class=\"text-center year\">\n <button\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 [ngClass]=\"{ 'text-info': cell.current }\">{{\n cell.label\n }}</span>\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-year-picker.component.js","sourceRoot":"","sources":["../../../../src/lib/date-picker/date-picker-year-picker.component.ts","../../../../src/lib/date-picker/date-picker-year-picker.component.html"],"names":[],"mappings":"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","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 } from \"@angular/core\";\nimport moment from \"moment/moment\";\nimport { Moment } from \"moment/moment\";\n\nimport { DatePickerInnerComponent } from \"./date-picker-inner.component\";\n/** @ignore */\n@Component({\n    selector: \"nui-year-picker\",\n    templateUrl: \"./date-picker-year-picker.component.html\",\n})\nexport class YearPickerComponent implements OnInit {\n    title: string;\n    rows: any[] = [];\n\n    constructor(public datePicker: DatePickerInnerComponent) {\n        this.datePicker = datePicker;\n    }\n\n    public ngOnInit(): void {\n        this.datePicker.stepYear = { years: this.datePicker.yearRange };\n\n        this.datePicker.setRefreshViewHandler((): void => {\n            const picker = this.datePicker;\n            const years: any[] = new Array(picker.yearRange);\n\n            let date: Moment =\n                picker.value && picker.value.isValid()\n                    ? picker.value.clone()\n                    : moment();\n            date = date.set(\"date\", 1);\n\n            const start = this.getStartingYear(date.year());\n\n            for (let i = 0; i < picker.yearRange; i++) {\n                date = date.set({ year: start + i });\n                years[i] = picker.createDateObject(date, picker.formatYear);\n                years[i].uid = picker.uniqueId + \"-\" + i;\n            }\n\n            this.title = [\n                years[0].label,\n                years[picker.yearRange - 1].label,\n            ].join(\" - \");\n            this.rows = picker.split(years, 5);\n        }, \"year\");\n\n        this.datePicker.setCompareHandler(\n            (date1: Moment, date2: Moment): number =>\n                date1.year() - date2.year(),\n            \"year\"\n        );\n    }\n\n    protected getStartingYear(year: number): number {\n        return (\n            ((year - 1) / this.datePicker.yearRange) *\n                this.datePicker.yearRange +\n            1\n        );\n    }\n}\n","<table *ngIf=\"datePicker.datepickerMode === 'year'\" role=\"grid\">\n    <thead>\n        <tr>\n            <th>\n                <button\n                    nui-button\n                    type=\"button\"\n                    icon=\"caret-left\"\n                    displayStyle=\"action\"\n                    (click)=\"datePicker.move(-1, $event)\"\n                    tabindex=\"-1\"\n                ></button>\n            </th>\n            <th [attr.colspan]=\"3\">\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                    icon=\"caret-right\"\n                    displayStyle=\"action\"\n                    (click)=\"datePicker.move(1, $event)\"\n                    tabindex=\"-1\"\n                ></button>\n            </th>\n        </tr>\n    </thead>\n    <tbody>\n        <tr *ngFor=\"let row of rows\">\n            <td *ngFor=\"let cell of row\" class=\"text-center year\">\n                <button\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 [ngClass]=\"{ 'text-info': cell.current }\">{{\n                        cell.label\n                    }}</span>\n                </button>\n            </td>\n        </tr>\n    </tbody>\n</table>\n"]}