@junte/ui
Version:
Quality Angular UI components kit
206 lines • 28.3 kB
JavaScript
import { __decorate, __metadata, __read, __spread } from "tslib";
import { Component, ContentChild, ContentChildren, EventEmitter, forwardRef, HostBinding, HostListener, Input, Output, QueryList, TemplateRef } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { addDays, addMonths, addWeeks, addYears, getMonth, getYear, isSameMonth, startOfWeek, subMonths, subYears } from 'date-fns';
import { NGXLogger } from 'ngx-logger';
import { JunteUIConfig } from '../../config';
import { PropertyApi } from '../../core/decorators/api';
import { Feature } from '../../core/enums/feature';
import { UI } from '../../core/enums/ui';
import { I18N_PROVIDERS } from '../../core/i18n/providers';
import { today } from './utils';
import { WeekMetricComponent } from './week/week-metric.component';
var WEEKS_DISPLAYED = 6;
var DAYS_IN_WEEK = 7;
var DATE_ROWS = 3;
var DATE_COLS = 4;
var ViewType;
(function (ViewType) {
ViewType["date"] = "date";
ViewType["year"] = "year";
ViewType["month"] = "month";
})(ViewType || (ViewType = {}));
var CalendarComponent = /** @class */ (function () {
function CalendarComponent(logger, config) {
var _this = this;
this.logger = logger;
this.config = config;
this.host = 'jnt-calendar-host';
this.ui = UI;
this._period = today();
this.weeks = [];
this.months = [];
this.years = [];
this.viewType = ViewType;
this.view = ViewType.date;
this.features = [];
this.updated = new EventEmitter();
this.selected = new EventEmitter();
this.disabled = false;
this.onChange = function () { return _this.logger.debug('value accessor is not registered'); };
this.onTouched = function () { return _this.logger.debug('value accessor is not registered'); };
this.registerOnChange = function (fn) { return _this.onChange = fn; };
this.registerOnTouched = function (fn) { return _this.onTouched = fn; };
this.onBlur = function () { return _this.onTouched(); };
}
CalendarComponent_1 = CalendarComponent;
Object.defineProperty(CalendarComponent.prototype, "period", {
get: function () {
return this._period;
},
set: function (period) {
if (!isSameMonth(this._period, period)) {
this._period = period;
this.update();
}
},
enumerable: true,
configurable: true
});
CalendarComponent.prototype.ngOnInit = function () {
this.update();
};
CalendarComponent.prototype.writeValue = function (date) {
this.current = date;
this.period = date || today();
};
CalendarComponent.prototype.setDisabledState = function (isDisabled) {
this.disabled = isDisabled;
};
CalendarComponent.prototype.select = function (date) {
this.current = date;
this.onChange(date);
this.selected.emit(date);
};
CalendarComponent.prototype.today = function () {
var now = new Date();
this.period = now;
this.select(now);
};
CalendarComponent.prototype.add = function () {
if (this.view === ViewType.date) {
this.period = addMonths(this.period, 1);
}
else if (this.view === ViewType.month) {
this.period = addYears(this.period, 1);
}
else {
this.period = addYears(this.period, 12);
}
};
CalendarComponent.prototype.sub = function () {
if (this.view === ViewType.date) {
this.period = subMonths(this.period, 1);
}
else if (this.view === ViewType.month) {
this.period = subYears(this.period, 1);
}
else {
this.period = subYears(this.period, 12);
}
};
CalendarComponent.prototype.update = function () {
var start = startOfWeek(new Date(getYear(this.period), getMonth(this.period), 1), { locale: this.config.locale.dfns });
var date = start;
this.weeks = [];
for (var i = 0; i < WEEKS_DISPLAYED; i++) {
this.weeks[i] = { days: [], date: date };
for (var j = 0; j < DAYS_IN_WEEK; j++) {
this.weeks[i].days[j] = addDays(date, j);
}
date = addWeeks(date, 1);
}
this.updated.emit({ start: start, end: date });
for (var i = 0; i < DATE_ROWS; i++) {
this.months[i] = [];
for (var j = 0; j < DATE_COLS; j++) {
this.months[i].push(new Date(getYear(this.period), i * DATE_COLS + j, 1));
}
}
for (var i = 0; i < DATE_ROWS; i++) {
this.years[i] = [];
for (var j = 0; j < DATE_COLS; j++) {
this.years[i].push(new Date(getYear(this.period) - 4 + i * DATE_COLS + j, i * DATE_COLS + j, 1));
}
}
};
var CalendarComponent_1;
CalendarComponent.ctorParameters = function () { return [
{ type: NGXLogger },
{ type: JunteUIConfig }
]; };
__decorate([
HostBinding('attr.host'),
__metadata("design:type", Object)
], CalendarComponent.prototype, "host", void 0);
__decorate([
PropertyApi({
description: 'Calendar features',
path: 'ui.feature',
options: [Feature.today]
}),
Input(),
__metadata("design:type", Array)
], CalendarComponent.prototype, "features", void 0);
__decorate([
ContentChildren(WeekMetricComponent),
__metadata("design:type", QueryList)
], CalendarComponent.prototype, "metrics", void 0);
__decorate([
ContentChild('calendarDayTemplate'),
__metadata("design:type", TemplateRef)
], CalendarComponent.prototype, "dayTemplate", void 0);
__decorate([
ContentChild('calendarMetricTemplate'),
__metadata("design:type", TemplateRef)
], CalendarComponent.prototype, "metricTemplate", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], CalendarComponent.prototype, "updated", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], CalendarComponent.prototype, "selected", void 0);
__decorate([
PropertyApi({
description: 'Set disabled state',
type: 'boolean',
default: 'false',
}),
HostBinding('attr.data-disabled'),
Input(),
__metadata("design:type", Object)
], CalendarComponent.prototype, "disabled", void 0);
__decorate([
PropertyApi({
description: 'Set current month for displaying',
type: 'Date'
}),
Input('month'),
__metadata("design:type", Date),
__metadata("design:paramtypes", [Date])
], CalendarComponent.prototype, "period", null);
__decorate([
HostListener('blur'),
__metadata("design:type", Object)
], CalendarComponent.prototype, "onBlur", void 0);
CalendarComponent = CalendarComponent_1 = __decorate([
Component({
selector: 'jnt-calendar',
template: "<jnt-stack child-of=\"jnt-calendar-host\" [align]=\"ui.align.stretch\">\n <table child-of=\"jnt-calendar-host\" >\n <thead child-of=\"jnt-calendar-host\" >\n <tr child-of=\"jnt-calendar-host\" >\n <td child-of=\"jnt-calendar-host\" >\n <jnt-button child-of=\"jnt-calendar-host\" data-arrow [icon]=\"ui.icons.chevronLeft\"\n [outline]=\"ui.outline.transparent\"\n [scheme]=\"ui.scheme.secondary\"\n [size]=\"ui.size.small\"\n (click)=\"sub()\">\n </jnt-button>\n </td>\n <td child-of=\"jnt-calendar-host\" *ngIf=\"view === viewType.date\" (click)=\"view = viewType.month\" colspan=\"5\">\n <jnt-button child-of=\"jnt-calendar-host\" data-date [outline]=\"ui.outline.transparent\"\n [scheme]=\"ui.scheme.secondary\"\n [size]=\"ui.size.small\"\n text=\"{{period | jntFormat: 'LLLL'}}, {{period | jntFormat: 'yyyy'}}\"></jnt-button>\n </td>\n <td child-of=\"jnt-calendar-host\" *ngIf=\"view === viewType.month\" (click)=\"view = viewType.year\" colspan=\"2\">\n <jnt-button child-of=\"jnt-calendar-host\" data-date [outline]=\"ui.outline.transparent\"\n [scheme]=\"ui.scheme.secondary\"\n [size]=\"ui.size.small\"\n [width]=\"ui.width.fluid\"\n text=\"{{period | jntFormat: 'yyyy'}}\">\n </jnt-button>\n </td>\n <td child-of=\"jnt-calendar-host\" *ngIf=\"view === viewType.year\" colspan=\"2\" data-year>\n {{(period | jntGetYear) - 4}} - {{(period | jntGetYear) + 7}}\n </td>\n <td child-of=\"jnt-calendar-host\" >\n <jnt-button child-of=\"jnt-calendar-host\" data-arrow [icon]=\"ui.icons.chevronRight\"\n [outline]=\"ui.outline.transparent\"\n [scheme]=\"ui.scheme.secondary\"\n [size]=\"ui.size.small\"\n (click)=\"add()\">\n </jnt-button>\n </td>\n <td child-of=\"jnt-calendar-host\" data-divider *ngIf=\"metrics.length\"></td>\n <td child-of=\"jnt-calendar-host\" data-metrics *ngIf=\"metrics.length\"\n [translate]=\"'label.metrics'\"\n [attr.colspan]=\"metrics.length\">\n Metrics\n </td>\n </tr>\n <tr child-of=\"jnt-calendar-host\" data-days *ngIf=\"view === viewType.date; else empty\">\n <th child-of=\"jnt-calendar-host\" *ngFor=\"let weekDay of [0,1,2,3,4,5,6]\">{{weekDay | jntWeekdayName:'x2'}}</th>\n\n <th child-of=\"jnt-calendar-host\" data-divider *ngIf=\"!!metrics.length\"></th>\n\n <th child-of=\"jnt-calendar-host\" data-metric *ngFor=\"let m of metrics\">\n {{m.title}}\n </th>\n </tr>\n\n <ng-template #empty>\n <tr child-of=\"jnt-calendar-host\" data-days>\n <th child-of=\"jnt-calendar-host\" *ngFor=\"let col of [1,2,3,4]\"></th>\n </tr>\n </ng-template>\n </thead>\n\n <tbody child-of=\"jnt-calendar-host\" >\n <ng-container *ngIf=\"view === viewType.date\">\n <tr child-of=\"jnt-calendar-host\" *ngFor=\"let w of weeks\"\n [attr.data-current-week]=\"(current | jntStartOfWeek) | jntIsEqual: (w.date | jntStartOfWeek)\">\n <td child-of=\"jnt-calendar-host\" data-day *ngFor=\"let d of w.days\"\n [attr.data-today]=\"d | jntIsToday\"\n [attr.data-current-month]=\"(d | jntStartOfMonth) | jntIsEqual: (period | jntStartOfMonth)\"\n [attr.data-selected-day]=\"(d | jntStartOfDay) | jntIsEqual: (current | jntStartOfDay)\"\n (click)=\"select(d)\" tabindex=\"0\">\n <ng-container *ngTemplateOutlet=\"!!dayTemplate ? dayTemplate: defaultDayTemplate;context:{date: d}\">\n </ng-container>\n </td>\n\n <td child-of=\"jnt-calendar-host\" data-divider *ngIf=\"!!metrics.length\"></td>\n\n <td child-of=\"jnt-calendar-host\" data-metric *ngFor=\"let m of metrics;let i = index;\">\n <ng-container *ngTemplateOutlet=\"metricTemplate;context:{metric: i, date: w.date}\">\n </ng-container>\n </td>\n </tr>\n </ng-container>\n\n <ng-container *ngIf=\"view === viewType.month\">\n <tr child-of=\"jnt-calendar-host\" *ngFor=\"let row of months\">\n <td child-of=\"jnt-calendar-host\" data-day data-day-extend *ngFor=\"let month of row\"\n [attr.data-current-month]=\"month | jntIsThisMonth\"\n [attr.data-selected-month]=\"(month | jntStartOfMonth) | jntIsEqual: (current | jntStartOfMonth)\"\n (click)=\"period = month; view = viewType.date\">\n {{month | jntFormat: 'LLL'}}\n </td>\n </tr>\n </ng-container>\n\n <ng-container *ngIf=\"view === viewType.year\">\n <tr child-of=\"jnt-calendar-host\" *ngFor=\"let row of years\">\n <td child-of=\"jnt-calendar-host\" data-day data-day-extend data-year *ngFor=\"let year of row\"\n [attr.data-current-year]=\"year | jntIsThisYear\"\n [attr.data-selected-year]=\"(year | jntStartOfYear) | jntIsEqual: (current | jntStartOfYear)\"\n (click)=\"period = year; view = viewType.month\">\n {{year | jntFormat: 'yyyy'}}\n </td>\n </tr>\n </ng-container>\n\n </tbody>\n </table>\n <jnt-stack child-of=\"jnt-calendar-host\" *ngIf=\"features | includes : ui.feature.today\" [align]=\"ui.align.center\">\n <jnt-button child-of=\"jnt-calendar-host\" [scheme]=\"ui.scheme.secondary\"\n [size]=\"ui.size.small\"\n [icon]=\"ui.icons.today\"\n text=\"Today\"\n (click)=\"today()\">\n </jnt-button>\n </jnt-stack>\n</jnt-stack>\n\n<ng-template #defaultDayTemplate let-date=\"date\">\n <div child-of=\"jnt-calendar-host\" data-default>{{date | jntGetDate}}</div>\n</ng-template>",
providers: __spread([
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(function () { return CalendarComponent_1; }),
multi: true
}
], I18N_PROVIDERS)
}),
__metadata("design:paramtypes", [NGXLogger,
JunteUIConfig])
], CalendarComponent);
return CalendarComponent;
}());
export { CalendarComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"ng://@junte/ui/","sources":["lib/forms/calendar/calendar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ContentChild,\n  ContentChildren,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  HostListener,\n  Input,\n  OnInit,\n  Output,\n  QueryList,\n  TemplateRef\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport {\n  addDays, addMonths,\n  addWeeks,\n  addYears,\n  getMonth,\n  getYear,\n  isSameMonth,\n  startOfWeek,\n  subMonths,\n  subYears\n} from 'date-fns';\nimport { NGXLogger } from 'ngx-logger';\nimport { JunteUIConfig } from '../../config';\nimport { PropertyApi } from '../../core/decorators/api';\nimport { Feature } from '../../core/enums/feature';\nimport { UI } from '../../core/enums/ui';\nimport { I18N_PROVIDERS } from '../../core/i18n/providers';\nimport { Period } from './types';\nimport { today } from './utils';\nimport { WeekMetricComponent } from './week/week-metric.component';\n\nconst WEEKS_DISPLAYED = 6;\nconst DAYS_IN_WEEK = 7;\nconst DATE_ROWS = 3;\nconst DATE_COLS = 4;\n\nenum ViewType {\n  date = 'date',\n  year = 'year',\n  month = 'month'\n}\n\n@Component({\n  selector: 'jnt-calendar',\n  templateUrl: './calendar.encapsulated.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => CalendarComponent),\n      multi: true\n    },\n    ...I18N_PROVIDERS\n  ]\n})\nexport class CalendarComponent implements ControlValueAccessor, OnInit {\n\n  @HostBinding('attr.host')\n  readonly host = 'jnt-calendar-host';\n\n  ui = UI;\n\n  private _period: Date = today();\n\n  current: Date;\n\n  weeks = [];\n  months = [];\n  years = [];\n  viewType = ViewType;\n  view: ViewType = ViewType.date;\n\n  @PropertyApi({\n    description: 'Calendar features',\n    path: 'ui.feature',\n    options: [Feature.today]\n  })\n  @Input()\n  features: Feature[] = [];\n\n  @ContentChildren(WeekMetricComponent)\n  metrics: QueryList<WeekMetricComponent>;\n\n  @ContentChild('calendarDayTemplate')\n  dayTemplate: TemplateRef<any>;\n\n  @ContentChild('calendarMetricTemplate')\n  metricTemplate: TemplateRef<any>;\n\n  @Output()\n  updated = new EventEmitter<Period>();\n\n  @Output()\n  selected = new EventEmitter<Date>();\n\n  @PropertyApi({\n    description: 'Set disabled state',\n    type: 'boolean',\n    default: 'false',\n  })\n  @HostBinding('attr.data-disabled')\n  @Input()\n  disabled = false;\n\n  @PropertyApi({\n    description: 'Set current month for displaying',\n    type: 'Date'\n  })\n  @Input('month')\n  set period(period: Date) {\n    if (!isSameMonth(this._period, period)) {\n      this._period = period;\n      this.update();\n    }\n  }\n\n  get period() {\n    return this._period;\n  }\n\n  onChange: (date: Date) => void = () => this.logger.debug('value accessor is not registered');\n  onTouched: () => void = () => this.logger.debug('value accessor is not registered');\n  registerOnChange = fn => this.onChange = fn;\n  registerOnTouched = fn => this.onTouched = fn;\n  @HostListener('blur') onBlur = () => this.onTouched();\n\n  constructor(private logger: NGXLogger,\n              public config: JunteUIConfig) {\n  }\n\n  ngOnInit() {\n    this.update();\n  }\n\n  writeValue(date: Date): void {\n    this.current = date;\n    this.period = date || today();\n  }\n\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  select(date: Date) {\n    this.current = date;\n    this.onChange(date);\n    this.selected.emit(date);\n  }\n\n  today() {\n    const now = new Date();\n    this.period = now;\n    this.select(now);\n  }\n\n  add() {\n    if(this.view === ViewType.date) {\n      this.period = addMonths(this.period, 1);\n    } else if (this.view === ViewType.month) {\n      this.period = addYears(this.period, 1)\n    } else {\n      this.period = addYears(this.period, 12)\n    }\n  }\n\n  sub() {\n    if(this.view === ViewType.date) {\n      this.period = subMonths(this.period, 1);\n    } else if (this.view === ViewType.month) {\n      this.period = subYears(this.period, 1)\n    } else {\n      this.period = subYears(this.period, 12)\n    }\n  }\n\n  private update() {\n    const start = startOfWeek(new Date(getYear(this.period), getMonth(this.period), 1),\n      {locale: this.config.locale.dfns});\n    let date = start;\n    this.weeks = [];\n    for (let i = 0; i < WEEKS_DISPLAYED; i++) {\n      this.weeks[i] = {days: [], date: date};\n      for (let j = 0; j < DAYS_IN_WEEK; j++) {\n        this.weeks[i].days[j] = addDays(date, j);\n      }\n      date = addWeeks(date, 1);\n    }\n    this.updated.emit({start: start, end: date});\n\n    for (let i = 0; i < DATE_ROWS; i++) {\n      this.months[i] = [];\n      for (let j = 0; j < DATE_COLS; j++) {\n        this.months[i].push(new Date(getYear(this.period), i * DATE_COLS + j, 1));\n      }\n    }\n\n    for (let i = 0; i < DATE_ROWS; i++) {\n      this.years[i] = [];\n      for (let j = 0; j < DATE_COLS; j++) {\n        this.years[i].push(new Date(getYear(this.period) - 4 + i * DATE_COLS + j, i * DATE_COLS + j, 1));\n      }\n    }\n  }\n}\n"]}