UNPKG

@asadi/angular-date-components

Version:

`Angular Date Components` is a comprehensive angular library of date-related components designed to meet the needs of applications that require localization based on various calendar systems. While the package currently includes two powerful components (S

204 lines 37.9 kB
import { Component } from '@angular/core'; import { ADCCommonService, ADCStaticValues, TableSelection, FlatEventBuilder } from '@asadi/angular-date-components/core'; import { AdcSchedulerBase } from '../adc-scheduler-base/adc-scheduler-base'; import * as i0 from "@angular/core"; import * as i1 from "@asadi/angular-date-components/core"; export class ADCMonthViewComponent extends AdcSchedulerBase { constructor() { super(); this.month = 0; this.year = 0; this.daysOfWeek = ADCStaticValues.getDaysOfWeek(); this.monthsOfYear = this.dateAdapter.getMonthsOfYear(); this.weeksOfMonth = []; this.title = ''; this.dateSplitter = this.dateFormatter.DateSplitter; this.events = []; this.rows = []; this.startOfMonth = ''; this.endOfMonth = ''; this.weekends = []; this.holidays = []; this.today = this.dateAdapter.today(); this.commonService = new ADCCommonService(this.dateAdapter, this.labels); this.selectionManager = new TableSelection(this.dateFilter); this.eventBuilder = new FlatEventBuilder(); } ngOnInit() { super.init(); this.selectionManager.cellSelectionStream.subscribe(e => { this.onDateRangeSelect(e.start, e.end); }); this.eventBuilder.eventSelectionStream.subscribe(e => { this.onEventClick(e.event, e.dom, e.jsEvent); }); } dateFilter(cell1, cell2) { return +cell2.rowValue > +cell1.rowValue || (cell2.rowValue == cell1.rowValue && cell2.columnIndex >= cell1.columnIndex); } todayButtonHandler() { this.month = this.dateAdapter.getCurrentMonth(); this.year = this.dateAdapter.getCurrentYear(); this.calculateCurrentDate(); } previousButtonHandler() { this.month--; if (this.month < 1) { this.month = 12; this.year--; } this.calculateCurrentDate(); } nextButtonHandler() { this.month++; if (this.month > 12) { this.month = 1; this.year++; } this.calculateCurrentDate(); } calculateCurrentDate() { this.weeksOfMonth = this.dateAdapter.getWeeksOfMonth(this.year, this.month); this.startOfMonth = this.dateAdapter.transformDate(this.year, this.month, 1); const daysOfMonth = this.dateAdapter.getDaysOfMonth(this.year, this.month); this.endOfMonth = this.dateAdapter.transformDate(this.year, this.month, daysOfMonth); const month = this.monthsOfYear[this.month - 1]; this.title = this.commonService.getMonthName(month) || month + ' ' + this.year; this.dateChangesHandler(); super.dateRangeChange({ startDate: this.startOfMonth, endDate: this.endOfMonth }); } initViewHanlder() { if (this.startOf == null) { this.todayButtonHandler(); } else { this.month = this.dateAdapter.getMonthOf(this.startOf); this.year = this.dateAdapter.getYearOf(this.startOf); this.calculateCurrentDate(); } } eventChangesHandler(schedulerEvents) { const tableEvents = []; this.events = schedulerEvents; const viewEvents = this.tools.scheduler.getEventsBetweenDateRange(this.startOfMonth, this.endOfMonth, this.events); viewEvents.forEach((e) => { const startRowIndex = this.rows.findIndex((r, i) => { if (i == 0) return; return r.columns.map(c => (this.tools.dateTime.dateOnly(c.value))).includes(this.tools.dateTime.dateOnly(e.startDate)); }); const startColumnIndex = startRowIndex == -1 ? 0 : this.rows[startRowIndex].columns.findIndex(c => this.tools.dateTime.dateOnly(c.value) == this.tools.dateTime.dateOnly(e.startDate)); const endRowIndex = this.rows.findIndex((r, i) => { if (i == 0) return; return r.columns.map(c => (this.tools.dateTime.dateOnly(c.value))).includes(this.tools.dateTime.dateOnly(e.endDate)); }); const endColumnIndex = endRowIndex == -1 ? this.rows[this.rows.length - 1].columns.length - 1 : this.rows[endRowIndex].columns.findIndex(c => this.tools.dateTime.dateOnly(c.value) == this.tools.dateTime.dateOnly(e.endDate)); const startTime = +this.tools.dateTime.hourOrDefault(e.startTime, '00'); const endTime = +this.tools.dateTime.hourOrDefault(e.endTime, '24'); const cellEvent = { columnStart: startRowIndex != -1 ? startColumnIndex : null, columnEnd: endRowIndex != -1 ? endColumnIndex : null, data: e, rowStart: startRowIndex != -1 ? startRowIndex : 0, rowEnd: endRowIndex != -1 ? endRowIndex : this.rows.length - 1, offsetX: startTime / 24, fractionX: e.allDay == true ? 1 : (endTime / 24), overlapTolerance: this.options.eventOverlapTolerance / 24 }; tableEvents.push(cellEvent); }); this.eventBuilder.data = tableEvents; } dateChangesHandler() { this.rows = this.getRowsInitialValue(); this.weeksOfMonth.forEach((week, weekIndex) => { const row = { verticalAlign: 'start', horizontalAlign: 'start', label: '', classList: '', prefix: '', suffix: '', value: week, columns: [] }; this.daysOfWeek.forEach((day, dayIndex) => { const date = this.dateAdapter.getDateOfDay(this.year, +week, dayIndex); const splittedDate = date.split(this.dateSplitter); const transformedDate = this.dateAdapter.transformDate(+splittedDate[0], +splittedDate[1], +splittedDate[2]); row.columns.push({ classList: ''.concat(transformedDate.split('T')[0] == this.today && this.month == +splittedDate[1] ? ' today ' : ' ', this.weekends.includes(dayIndex) || this.holidays.includes(transformedDate.split('T')[0]) ? ' holiday ' : ' ', this.month != +splittedDate[1] ? ' unavailable ' : ' '), label: splittedDate[2], prefix: '', suffix: '', value: transformedDate.split('T')[0], verticalAlign: 'start', horizontalAlign: 'start', selectable: true }); }); this.rows.push(row); }); } weekendsChangesHandler(weekends) { this.weekends = weekends; this.dateChangesHandler(); } holidaysChangesHandler(holidays) { this.holidays = holidays; this.dateChangesHandler(); } onDateRangeSelect(startCell, endCell) { const startDate = this.dateAdapter.getDateOfDay(this.year, +startCell.rowValue, +startCell.columnIndex).split(this.dateSplitter); const transformedStart = this.dateAdapter.transformDate(+startDate[0], +startDate[1], +startDate[2]); const endDate = this.dateAdapter.getDateOfDay(this.year, +endCell.rowValue, +endCell.columnIndex).split(this.dateSplitter); const transformedEnd = this.dateAdapter.transformDate(+endDate[0], +endDate[1], +endDate[2]); const e = { endDate: transformedEnd, endTime: '00:00', startDate: transformedStart, startTime: '00:00', }; super.dateRangeSelect(e); } onEventClick(event, dom, jsEvent) { const schedulerEvent = this.events.filter(item => item.id == event.data.id)[0]; super.eventClick({ dom: dom, event: schedulerEvent, jsEvent: jsEvent }); } ngOnDestroy() { super.destroy(); } getRowsInitialValue() { return [{ label: '', prefix: '', suffix: '', verticalAlign: 'center', horizontalAlign: 'center', classList: '', value: '', columns: this.daysOfWeek.map((dayName, index) => { const dIndex = this.commonService.getDayIndex(index); return { label: this.labels?.daysOfWeek[dIndex] || dayName, prefix: '', suffix: '', verticalAlign: 'center', horizontalAlign: 'center', classList: this.weekends.includes(index) ? 'holiday' : '', display: true, value: index.toString(), selectable: false, }; }), }]; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: ADCMonthViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.7", type: ADCMonthViewComponent, selector: "adc-month-view", usesInheritance: true, ngImport: i0, template: " \r\n<adc-table\r\n[rows]=\"rows\"\r\n[title]=\"title\"\r\n[showRowDetails]=\"false\"\r\n[selectionManager]=\"selectionManager\"\r\n[eventBuilder]=\"eventBuilder\"\r\n(viewReady)=\"markViewAsReady()\"\r\n></adc-table>\r\n\r\n<!-- [eventBuilder]=\"builder\" -->\r\n\r\n<!-- [tableEvents]=\"tableEvents\" -->\r\n\r\n<!-- <div flatEventBuilder [columns]=\"columns.length\" [rows]=\"rows.length\" #builder=\"eventBuilder\"></div> -->\r\n\r\n\r\n\r\n", styles: ["table{border-collapse:collapse;table-layout:fixed}.w-full{width:100%}.h-full{height:100%}.table-border{border:1px solid #000}.relative{position:relative}.disabled{pointer-events:none;opacity:.5}.date{font-weight:500}.text-left{text-align:left}.vertical-text-top{vertical-align:text-top}.min-h-24{height:6rem}\n"], dependencies: [{ kind: "component", type: i1.ADCTableComponent, selector: "adc-table", inputs: ["rows", "showRowDetails", "title", "titleClass", "eventBuilder", "selectionManager"], outputs: ["viewReady"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: ADCMonthViewComponent, decorators: [{ type: Component, args: [{ selector: 'adc-month-view', template: " \r\n<adc-table\r\n[rows]=\"rows\"\r\n[title]=\"title\"\r\n[showRowDetails]=\"false\"\r\n[selectionManager]=\"selectionManager\"\r\n[eventBuilder]=\"eventBuilder\"\r\n(viewReady)=\"markViewAsReady()\"\r\n></adc-table>\r\n\r\n<!-- [eventBuilder]=\"builder\" -->\r\n\r\n<!-- [tableEvents]=\"tableEvents\" -->\r\n\r\n<!-- <div flatEventBuilder [columns]=\"columns.length\" [rows]=\"rows.length\" #builder=\"eventBuilder\"></div> -->\r\n\r\n\r\n\r\n", styles: ["table{border-collapse:collapse;table-layout:fixed}.w-full{width:100%}.h-full{height:100%}.table-border{border:1px solid #000}.relative{position:relative}.disabled{pointer-events:none;opacity:.5}.date{font-weight:500}.text-left{text-align:left}.vertical-text-top{vertical-align:text-top}.min-h-24{height:6rem}\n"] }] }], ctorParameters: () => [] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adcmonth-view.component.js","sourceRoot":"","sources":["../../../../../../../../projects/asadi/angular-date-components/scheduler/src/components/adcmonth-view/adcmonth-view.component.ts","../../../../../../../../projects/asadi/angular-date-components/scheduler/src/components/adcmonth-view/adcmonth-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, OnInit } from '@angular/core';\r\nimport { ADCDateSplitter, ADCITableEvent, ADCITableRow, ADCCommonService, ADCStaticValues, ADCITableCell, TableSelection, FlatEventBuilder} from '@asadi/angular-date-components/core';\r\nimport { ADCISchedulerDateRangeSelectEvent, ADCISchedulerEvent } from '../../interface.global';\r\nimport { AdcSchedulerBase } from '../adc-scheduler-base/adc-scheduler-base';\r\n\r\n@Component({\r\n  selector: 'adc-month-view',\r\n  templateUrl: './adcmonth-view.component.html',\r\n  styleUrls: ['./adcmonth-view.component.css']\r\n})\r\nexport class ADCMonthViewComponent extends AdcSchedulerBase implements OnInit, OnDestroy{\r\n\r\n  month: number = 0;\r\n  year: number = 0;\r\n\r\n  daysOfWeek: string[] = ADCStaticValues.getDaysOfWeek();\r\n  monthsOfYear: string[] = this.dateAdapter.getMonthsOfYear();\r\n  weeksOfMonth: string[] = [];\r\n\r\n  title: string = '';\r\n  \r\n  dateSplitter: ADCDateSplitter = this.dateFormatter.DateSplitter;\r\n\r\n  events: ADCISchedulerEvent[] = [];\r\n\r\n  rows: ADCITableRow[] = [];\r\n\r\n  private startOfMonth: string = '';\r\n  private endOfMonth: string = '';\r\n\r\n  weekends: number[] = [];\r\n  holidays: string[] = [];\r\n\r\n  readonly today: string = this.dateAdapter.today();\r\n  readonly commonService = new ADCCommonService(this.dateAdapter, this.labels);\r\n  readonly selectionManager = new TableSelection(this.dateFilter);\r\n  readonly eventBuilder = new FlatEventBuilder();\r\n\r\n  constructor()\r\n  {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void \r\n  {\r\n    super.init();\r\n\r\n    this.selectionManager.cellSelectionStream.subscribe(e => {\r\n      this.onDateRangeSelect(e.start, e.end);\r\n    });\r\n\r\n    this.eventBuilder.eventSelectionStream.subscribe(e => {\r\n      this.onEventClick(e.event, e.dom, e.jsEvent);\r\n    });\r\n  }\r\n\r\n  dateFilter(cell1: ADCITableCell, cell2: ADCITableCell): boolean\r\n  {\r\n    return +cell2.rowValue > +cell1.rowValue || (cell2.rowValue == cell1.rowValue && cell2.columnIndex >= cell1.columnIndex);\r\n  }\r\n\r\n  override todayButtonHandler(): void\r\n  {\r\n    this.month = this.dateAdapter.getCurrentMonth();\r\n    this.year = this.dateAdapter.getCurrentYear();\r\n\r\n    this.calculateCurrentDate();\r\n  }\r\n\r\n  override previousButtonHandler(): void\r\n  {\r\n    this.month--;\r\n    if(this.month < 1)\r\n    {\r\n      this.month = 12;\r\n      this.year--;\r\n    }\r\n\r\n    this.calculateCurrentDate();\r\n  }\r\n\r\n  override nextButtonHandler(): void\r\n  {\r\n    this.month++;\r\n    if(this.month > 12)\r\n    {\r\n      this.month = 1;\r\n      this.year++;\r\n    }\r\n\r\n    this.calculateCurrentDate();\r\n  }\r\n\r\n  calculateCurrentDate(): void\r\n  {\r\n    this.weeksOfMonth = this.dateAdapter.getWeeksOfMonth(this.year, this.month);\r\n    this.startOfMonth = this.dateAdapter.transformDate(this.year, this.month, 1);\r\n    const daysOfMonth = this.dateAdapter.getDaysOfMonth(this.year, this.month);\r\n    this.endOfMonth = this.dateAdapter.transformDate(this.year, this.month, daysOfMonth);\r\n\r\n    const month =  this.monthsOfYear[this.month - 1];\r\n\r\n    this.title = this.commonService.getMonthName(month) || month + ' ' + this.year;\r\n\r\n    this.dateChangesHandler();\r\n    super.dateRangeChange({startDate: this.startOfMonth, endDate: this.endOfMonth});\r\n  }\r\n\r\n  override initViewHanlder(): void \r\n  {\r\n    if(this.startOf == null)\r\n    {\r\n      this.todayButtonHandler();\r\n    }\r\n    else\r\n    {\r\n      this.month = this.dateAdapter.getMonthOf(this.startOf);\r\n      this.year = this.dateAdapter.getYearOf(this.startOf);\r\n      this.calculateCurrentDate();\r\n    }\r\n  }\r\n\r\n  override eventChangesHandler(schedulerEvents: ADCISchedulerEvent[]): void\r\n  {\r\n    const tableEvents: ADCITableEvent[] = [];\r\n\r\n    this.events = schedulerEvents;\r\n\r\n    const viewEvents = this.tools.scheduler.getEventsBetweenDateRange(this.startOfMonth, this.endOfMonth, this.events);\r\n\r\n    viewEvents.forEach((e: ADCISchedulerEvent) => {\r\n\r\n      const startRowIndex = this.rows.findIndex((r, i) => {\r\n        if(i == 0) return;\r\n\r\n        return r.columns.map(c => (this.tools.dateTime.dateOnly(c.value))).includes(this.tools.dateTime.dateOnly(e.startDate))\r\n      });\r\n\r\n      const startColumnIndex = startRowIndex == -1 ? 0 : this.rows[startRowIndex].columns.findIndex(c => \r\n        this.tools.dateTime.dateOnly(c.value) == this.tools.dateTime.dateOnly(e.startDate)\r\n      );\r\n\r\n      const endRowIndex = this.rows.findIndex((r, i) => {\r\n\r\n        if(i == 0) return;\r\n\r\n        return r.columns.map(c => (this.tools.dateTime.dateOnly(c.value))).includes(this.tools.dateTime.dateOnly(e.endDate));\r\n      });\r\n\r\n      const endColumnIndex = endRowIndex == -1 ? this.rows[this.rows.length - 1].columns.length - 1 : this.rows[endRowIndex].columns.findIndex(c => \r\n        this.tools.dateTime.dateOnly(c.value) == this.tools.dateTime.dateOnly(e.endDate)\r\n      );\r\n\r\n      const startTime = +this.tools.dateTime.hourOrDefault(e.startTime, '00');\r\n      const endTime = +this.tools.dateTime.hourOrDefault(e.endTime, '24');\r\n\r\n      const cellEvent: ADCITableEvent = {\r\n        columnStart: startRowIndex != -1 ? startColumnIndex : null,\r\n        columnEnd: endRowIndex != -1 ? endColumnIndex : null,\r\n        data: e,\r\n        rowStart: startRowIndex != -1 ? startRowIndex : 0,\r\n        rowEnd:  endRowIndex != -1 ? endRowIndex : this.rows.length - 1,\r\n        offsetX: startTime / 24,\r\n        fractionX: e.allDay == true ? 1 : (endTime / 24),\r\n        overlapTolerance: this.options.eventOverlapTolerance / 24\r\n      };\r\n\r\n      tableEvents.push(cellEvent);\r\n    });\r\n\r\n    this.eventBuilder.data = tableEvents;\r\n  }\r\n\r\n  dateChangesHandler(): void\r\n  {\r\n    this.rows = this.getRowsInitialValue();\r\n\r\n    this.weeksOfMonth.forEach((week: string, weekIndex: number) => {\r\n\r\n        const row: ADCITableRow = {\r\n          verticalAlign: 'start',\r\n          horizontalAlign: 'start',\r\n          label: '',\r\n          classList: '',\r\n          prefix: '',\r\n          suffix: '',\r\n          value: week,\r\n          columns: []\r\n        };\r\n\r\n        this.daysOfWeek.forEach((day: string, dayIndex: number) => {\r\n\r\n          const date = this.dateAdapter.getDateOfDay(this.year, +week, dayIndex);\r\n          const splittedDate = date.split(this.dateSplitter);\r\n          const transformedDate = this.dateAdapter.transformDate(+splittedDate[0], +splittedDate[1], +splittedDate[2]);\r\n\r\n          row.columns.push({\r\n            classList: ''.concat(\r\n              transformedDate.split('T')[0] == this.today && this.month == +splittedDate[1] ? ' today ' : ' ',\r\n              this.weekends.includes(dayIndex) || this.holidays.includes(transformedDate.split('T')[0]) ? ' holiday ' : ' ',\r\n              this.month != +splittedDate[1] ? ' unavailable ' : ' '\r\n            ),\r\n            label: splittedDate[2],\r\n            prefix: '',\r\n            suffix: '',\r\n            value: transformedDate.split('T')[0],\r\n            verticalAlign: 'start',\r\n            horizontalAlign: 'start',\r\n            selectable: true\r\n          })\r\n\r\n        });\r\n\r\n        this.rows.push(row);\r\n\r\n\r\n    });   \r\n  }\r\n\r\n  override weekendsChangesHandler(weekends: number[]): void \r\n  {\r\n    this.weekends = weekends;\r\n    this.dateChangesHandler();\r\n  }\r\n\r\n  override holidaysChangesHandler(holidays: string[]): void \r\n  {\r\n    this.holidays = holidays;\r\n    this.dateChangesHandler();\r\n  }\r\n\r\n  onDateRangeSelect(startCell: ADCITableCell, endCell: ADCITableCell): void\r\n  {\r\n    const startDate = this.dateAdapter.getDateOfDay(this.year, +startCell.rowValue, +startCell.columnIndex).split(this.dateSplitter);\r\n    const transformedStart = this.dateAdapter.transformDate(+startDate[0], +startDate[1], +startDate[2]);\r\n\r\n    const endDate = this.dateAdapter.getDateOfDay(this.year, +endCell.rowValue, +endCell.columnIndex).split(this.dateSplitter);\r\n    const transformedEnd = this.dateAdapter.transformDate(+endDate[0], +endDate[1], +endDate[2]);\r\n\r\n\r\n    const e: ADCISchedulerDateRangeSelectEvent = \r\n    {\r\n      endDate: transformedEnd,\r\n      endTime: '00:00',\r\n      startDate: transformedStart,\r\n      startTime: '00:00',\r\n    }\r\n\r\n    super.dateRangeSelect(e);\r\n  }\r\n\r\n\r\n  override onEventClick(event: ADCITableEvent, dom: HTMLElement, jsEvent: MouseEvent): void \r\n  {\r\n    const schedulerEvent: ADCISchedulerEvent = this.events.filter(item => item.id == event.data.id)[0];\r\n\r\n    super.eventClick({dom: dom, event: schedulerEvent, jsEvent: jsEvent});\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    super.destroy();\r\n  }\r\n\r\n  private getRowsInitialValue(): ADCITableRow[]\r\n  {\r\n    return [{\r\n      label: '',\r\n      prefix: '',\r\n      suffix: '',\r\n      verticalAlign: 'center',\r\n      horizontalAlign: 'center',\r\n      classList: '',\r\n      value: '',\r\n      columns: this.daysOfWeek.map((dayName, index) => {\r\n\r\n        const dIndex = this.commonService.getDayIndex(index);\r\n\r\n        return {\r\n          label: this.labels?.daysOfWeek[dIndex] || dayName,\r\n          prefix: '',\r\n          suffix: '',\r\n          verticalAlign: 'center',\r\n          horizontalAlign: 'center',\r\n          classList: this.weekends.includes(index) ? 'holiday' : '',\r\n          display: true,\r\n          value: index.toString(),\r\n          selectable: false,\r\n        }\r\n      }),\r\n    }]\r\n  }\r\n}\r\n"," \r\n<adc-table\r\n[rows]=\"rows\"\r\n[title]=\"title\"\r\n[showRowDetails]=\"false\"\r\n[selectionManager]=\"selectionManager\"\r\n[eventBuilder]=\"eventBuilder\"\r\n(viewReady)=\"markViewAsReady()\"\r\n></adc-table>\r\n\r\n<!-- [eventBuilder]=\"builder\" -->\r\n\r\n<!-- [tableEvents]=\"tableEvents\"  -->\r\n\r\n<!-- <div flatEventBuilder [columns]=\"columns.length\" [rows]=\"rows.length\" #builder=\"eventBuilder\"></div> -->\r\n\r\n\r\n\r\n"]}