@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
231 lines • 39.4 kB
JavaScript
import { Component } from '@angular/core';
import { ADCCommonService, ADCStaticValues, FlatEventBuilder, TableSelection } from '@asadi/angular-date-components/core';
import { AdcResourceSchedulerBase } from '../adc-resource-scheduler-base/adc-resource-scheduler-base';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "@asadi/angular-date-components/core";
export class ADCDayViewComponent extends AdcResourceSchedulerBase {
constructor() {
super();
this.year = 0;
this.week = 0;
this.day = 0;
this.currentDate = '';
this.title = '';
this.hoursOfDay = ADCStaticValues.getHoursOfDay();
this.daysOfweek = ADCStaticValues.getDaysOfWeek();
this.monthsOfYear = this.dateAdapter.getMonthsOfYear();
this.dateSplitter = this.dateFormatter.DateSplitter;
this.resources = [];
this.events = [];
this.rows = [];
this.weekends = [];
this.holidays = [];
this.commonService = new ADCCommonService(this.dateAdapter, this.labels);
this.today = this.dateAdapter.today();
this.selectionManager = new TableSelection(this.dateFilter);
this.eventBuilder = new FlatEventBuilder();
}
ngOnInit() {
super.init();
this.selectionManager.cellSelectionStream.subscribe(event => this.onDateRangeSelect(event.start, event.end));
this.eventBuilder.eventSelectionStream.subscribe(e => {
this.onEventClick(e.event, e.dom, e.jsEvent);
});
}
dateFilter(cell1, cell2) {
return cell1.rowValue == cell2.rowValue && cell2.columnValue >= cell1.columnValue;
}
initViewHanlder() {
if (this.startOf == null) {
this.todayButtonHandler();
}
else {
this.day = this.dateAdapter.getDayIndexOf(this.startOf);
this.week = this.dateAdapter.getWeekOf(this.startOf);
this.year = this.dateAdapter.getYearOf(this.startOf);
this.calculateCurrentDate();
}
}
todayButtonHandler() {
this.day = this.dateAdapter.getCurrentDay();
this.week = this.dateAdapter.getCurrentWeek();
this.year = this.dateAdapter.getCurrentYear();
this.calculateCurrentDate();
}
previousButtonHandler() {
this.day--;
if (this.day < 0) {
this.day = 6;
this.week--;
if (this.week < 1) {
this.year--;
this.week = this.dateAdapter.getWeeksOfYear(this.year);
}
}
this.calculateCurrentDate();
}
nextButtonHandler() {
this.day++;
if (this.day > 6) {
this.day = 0;
this.week++;
const weeksOfYear = this.dateAdapter.getWeeksOfYear(this.year);
if (this.week > weeksOfYear) {
this.week = 1;
this.year++;
}
}
this.calculateCurrentDate();
}
calculateCurrentDate() {
const date = this.dateAdapter.getDateOfDay(this.year, this.week, this.day);
this.currentDate = this.dateAdapter.transformDate(+date.split(this.dateSplitter)[0], +date.split(this.dateSplitter)[1], +date.split(this.dateSplitter)[2]);
const dayIndex = this.commonService.getDayIndex(this.day);
const month = this.monthsOfYear[+date.split(this.dateSplitter)[1] - 1];
this.title = `${this.labels?.daysOfWeek[dayIndex] || this.daysOfweek[dayIndex]}
${+date.split(this.dateSplitter)[2]}
${this.commonService.getMonthName(month) || month} ${this.labels?.year || "Year"}
${this.year}`;
this.dateChangesHandler();
super.dateRangeChange({ startDate: this.currentDate, endDate: this.currentDate });
}
eventChangesHandler(events) {
const tableEvents = [];
this.events = events;
const viewEvents = this.tools.resourceScheduler.getEventsBetweenDateRange(this.currentDate, this.currentDate, this.events);
viewEvents.forEach((e) => {
const rowIndex = this.rows.findIndex((r) => r.value == e.resourceId);
if (rowIndex == -1)
return;
const row = this.rows[rowIndex];
const startColumnIndex = row.columns.findIndex((c) => {
const time = this.tools.dateTime.timeOnly(c.value);
const date = this.tools.dateTime.dateOnly(c.value);
return date == this.tools.dateTime.dateOnly(e.startDate) &&
this.tools.dateTime.hour(time) == this.tools.dateTime.hourOrDefault(e.startTime, '00');
});
const endColumnIndex = row.columns.findIndex((c) => {
const time = this.tools.dateTime.timeOnly(c.value);
const date = this.tools.dateTime.dateOnly(c.value);
return date == this.tools.dateTime.dateOnly(e.endDate) &&
this.tools.dateTime.hour(time) == this.tools.dateTime.hourOrDefault(e.endTime, '23');
});
const startTime = +this.tools.dateTime.minutesOrDefault(e.startTime, '00');
const endTime = +this.tools.dateTime.minutesOrDefault(e.endTime, '60');
const currentDateOnly = this.tools.dateTime.dateOnly(this.currentDate);
const cellEvent = {
columnStart: startColumnIndex != -1 ? startColumnIndex : null,
columnEnd: endColumnIndex != -1 ? endColumnIndex : null,
data: e,
rowStart: rowIndex,
rowEnd: rowIndex,
offsetX: this.tools.dateTime.dateOnly(e.startDate) == currentDateOnly ? startTime / 60 : 0,
fractionX: endTime / 60,
overlapTolerance: this.options.eventOverlapTolerance / 60
};
if (e.allDay == true) {
const eventHourEnd = +this.tools.dateTime.hourOrDefault(e.endTime, '23');
const eventMinuteEnd = +this.tools.dateTime.minutesOrDefault(e.endTime, '00');
cellEvent.fractionX = 24 - eventHourEnd + (eventMinuteEnd / 60);
}
tableEvents.push(cellEvent);
});
this.eventBuilder.data = tableEvents;
}
resourceChangesHandler(resources) {
this.resources = resources;
this.dateChangesHandler();
}
dateChangesHandler() {
this.rows = this.getRowInitialValue();
if (this.resources.length == 0)
return;
const date = this.dateAdapter.getDateOfDay(this.year, this.week, this.day).split(this.dateSplitter);
const transformedDate = this.dateAdapter.transformDate(+date[0], +date[1], +date[2]).split('T')[0];
this.resources.forEach((resource, rowIndex) => {
const row = {
classList: '',
label: resource.title,
prefix: '',
suffix: '',
value: resource.id.toString(),
verticalAlign: 'center',
horizontalAlign: 'center',
columns: [],
};
this.hoursOfDay.forEach((hour) => {
const column = {
classList: '',
label: '',
prefix: '',
suffix: '',
value: `${transformedDate}T${hour}`,
verticalAlign: 'center',
horizontalAlign: 'center',
selectable: true,
};
row.columns.push(column);
});
this.rows.push(row);
});
}
holidaysChangesHandler(holidays) {
this.holidays = holidays;
this.dateChangesHandler();
}
weekendChangesHandler(weekends) {
this.weekends = weekends;
this.dateChangesHandler();
}
onDateRangeSelect(start, end) {
const e = {
endDate: end.columnValue.split('T')[0],
endTime: end.columnValue.split('T')[1],
startDate: start.columnValue.split('T')[0],
startTime: start.columnValue.split('T')[1],
resourceId: start.rowValue
};
super.dateRangeSelect(e);
}
onEventClick(event, dom, jsEvent) {
const resourceSchedulerEvent = this.events.filter(item => item.id == event.data.id)[0];
super.eventClick({ dom: dom, jsEvent: jsEvent, event: resourceSchedulerEvent });
}
ngOnDestroy() {
super.destory();
}
getRowInitialValue() {
const row = {
verticalAlign: 'center',
horizontalAlign: 'center',
classList: '',
columns: [],
label: '',
prefix: '',
suffix: '',
value: '',
};
this.hoursOfDay.forEach((hour) => {
const column = {
classList: '',
label: hour,
prefix: '',
suffix: '',
value: hour,
verticalAlign: 'center',
horizontalAlign: 'center',
selectable: false,
};
row.columns.push(column);
});
return [row];
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: ADCDayViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.7", type: ADCDayViewComponent, selector: "adc-day-view", usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"resources.length != 0\">\r\n <adc-table\r\n [rows]=\"rows\"\r\n [title]=\"title\"\r\n [titleClass]=\"''.concat(\r\n today == currentDate.split('T')[0] ? ' today ' : ' ',\r\n weekends.includes(day) || holidays.includes(currentDate.split('T')[0]) ? ' holiday ' : ' '\r\n )\"\r\n [selectionManager]=\"selectionManager\"\r\n [eventBuilder]=\"eventBuilder\"\r\n (viewReady)=\"markViewAsReady()\"\r\n ></adc-table>\r\n</ng-container>", styles: [".w-full{width:100%}.table-layout-fixed{table-layout:fixed}.border-collapse{border-collapse:collapse}.h-12{height:3rem}.text-center{text-align:center}.events{height:100%;width:100%;overflow:visible;padding:0;margin:0}.h-1152{height:1152px}.over-flow-hidden{overflow:hidden}table{border-spacing:0}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.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: ADCDayViewComponent, decorators: [{
type: Component,
args: [{ selector: 'adc-day-view', template: "<ng-container *ngIf=\"resources.length != 0\">\r\n <adc-table\r\n [rows]=\"rows\"\r\n [title]=\"title\"\r\n [titleClass]=\"''.concat(\r\n today == currentDate.split('T')[0] ? ' today ' : ' ',\r\n weekends.includes(day) || holidays.includes(currentDate.split('T')[0]) ? ' holiday ' : ' '\r\n )\"\r\n [selectionManager]=\"selectionManager\"\r\n [eventBuilder]=\"eventBuilder\"\r\n (viewReady)=\"markViewAsReady()\"\r\n ></adc-table>\r\n</ng-container>", styles: [".w-full{width:100%}.table-layout-fixed{table-layout:fixed}.border-collapse{border-collapse:collapse}.h-12{height:3rem}.text-center{text-align:center}.events{height:100%;width:100%;overflow:visible;padding:0;margin:0}.h-1152{height:1152px}.over-flow-hidden{overflow:hidden}table{border-spacing:0}\n"] }]
}], ctorParameters: () => [] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adc-day-view.component.js","sourceRoot":"","sources":["../../../../../../../../projects/asadi/angular-date-components/resource-scheduler/src/components/adc-day-view/adc-day-view.component.ts","../../../../../../../../projects/asadi/angular-date-components/resource-scheduler/src/components/adc-day-view/adc-day-view.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAgC,MAAM,eAAe,CAAC;AACxE,OAAO,EAAE,gBAAgB,EAA8F,eAAe,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,qCAAqC,CAAC;AAEtN,OAAO,EAAE,wBAAwB,EAAE,MAAM,4DAA4D,CAAC;;;;AAOtG,MAAM,OAAO,mBAAoB,SAAQ,wBAAwB;IA6B/D;QAGE,KAAK,EAAE,CAAC;QA7BV,SAAI,GAAW,CAAC,CAAC;QACjB,SAAI,GAAW,CAAC,CAAC;QACjB,QAAG,GAAW,CAAC,CAAC;QAEhB,gBAAW,GAAW,EAAE,CAAC;QACzB,UAAK,GAAW,EAAE,CAAC;QAEnB,eAAU,GAAa,eAAe,CAAC,aAAa,EAAE,CAAC;QACvD,eAAU,GAAa,eAAe,CAAC,aAAa,EAAE,CAAC;QACvD,iBAAY,GAAa,IAAI,CAAC,WAAW,CAAC,eAAe,EAAE,CAAC;QAE5D,iBAAY,GAAoB,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC;QAEhE,cAAS,GAAoC,EAAE,CAAC;QAChD,WAAM,GAAiC,EAAE,CAAC;QAE1C,SAAI,GAAmB,EAAE,CAAC;QAE1B,aAAQ,GAAa,EAAE,CAAC;QACxB,aAAQ,GAAa,EAAE,CAAC;QAEf,kBAAa,GAAG,IAAI,gBAAgB,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QACpE,UAAK,GAAW,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;QACzC,qBAAgB,GAAG,IAAI,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACvD,iBAAY,GAAG,IAAI,gBAAgB,EAAE,CAAC;IAM/C,CAAC;IAED,QAAQ;QAEN,KAAK,CAAC,IAAI,EAAE,CAAC;QAEb,IAAI,CAAC,gBAAgB,CAAC,mBAAmB,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;QAE7G,IAAI,CAAC,YAAY,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YACnD,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;IACL,CAAC;IAED,UAAU,CAAC,KAAoB,EAAE,KAAoB;QAEnD,OAAO,KAAK,CAAC,QAAQ,IAAI,KAAK,CAAC,QAAQ,IAAI,KAAK,CAAC,WAAW,IAAI,KAAK,CAAC,WAAW,CAAC;IACpF,CAAC;IAEQ,eAAe;QAEtB,IAAG,IAAI,CAAC,OAAO,IAAI,IAAI,EACvB;YACE,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC3B;aAED;YACE,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACxD,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACrD,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACrD,IAAI,CAAC,oBAAoB,EAAE,CAAC;SAC7B;IACH,CAAC;IAEQ,kBAAkB;QAEzB,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,CAAC;QAC5C,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,EAAE,CAAC;QAC9C,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,EAAE,CAAC;QAC9C,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAEQ,qBAAqB;QAE5B,IAAI,CAAC,GAAG,EAAE,CAAC;QACX,IAAG,IAAI,CAAC,GAAG,GAAG,CAAC,EACf;YACE,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC;YACb,IAAI,CAAC,IAAI,EAAE,CAAC;YAEZ,IAAG,IAAI,CAAC,IAAI,GAAG,CAAC,EAChB;gBACE,IAAI,CAAC,IAAI,EAAE,CAAC;gBACZ,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aACxD;SACF;QACD,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAEQ,iBAAiB;QAExB,IAAI,CAAC,GAAG,EAAE,CAAC;QACX,IAAG,IAAI,CAAC,GAAG,GAAG,CAAC,EACf;YACE,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC;YACb,IAAI,CAAC,IAAI,EAAE,CAAC;YAEZ,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAE/D,IAAG,IAAI,CAAC,IAAI,GAAG,WAAW,EAC1B;gBACE,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;gBACd,IAAI,CAAC,IAAI,EAAE,CAAC;aACb;SACF;QACD,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAED,oBAAoB;QAElB,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;QAC3E,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAE3J,MAAM,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC1D,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAEvE,IAAI,CAAC,KAAK,GAAG,GAAG,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC;MAC5E,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;MACjC,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,KAAK,IAAI,IAAI,CAAC,MAAM,EAAE,IAAI,IAAI,MAAM;MAC9E,IAAI,CAAC,IAAI,EAAE,CAAC;QAEd,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,KAAK,CAAC,eAAe,CAAC,EAAC,SAAS,EAAE,IAAI,CAAC,WAAW,EAAE,OAAO,EAAE,IAAI,CAAC,WAAW,EAAC,CAAC,CAAC;IAClF,CAAC;IAEQ,mBAAmB,CAAC,MAAoC;QAE/D,MAAM,WAAW,GAAqB,EAAE,CAAC;QAEzC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QAErB,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,yBAAyB,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAE3H,UAAU,CAAC,OAAO,CAAC,CAAC,CAA6B,EAAE,EAAE;YAEnD,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAe,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,UAAU,CAAC,CAAC;YAEnF,IAAG,QAAQ,IAAI,CAAC,CAAC;gBAAE,OAAO;YAE1B,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAEhC,MAAM,gBAAgB,GAAG,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAkB,EAAE,EAAE;gBAEpE,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;gBACnD,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;gBAEnD,OAAO,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC;oBACxD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;YACzF,CAAC,CAAC,CAAC;YAEH,MAAM,cAAc,GAAG,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAkB,EAAE,EAAE;gBAElE,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;gBACnD,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;gBAEnD,OAAO,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC;oBACtD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;YACvF,CAAC,CAAC,CAAC;YAEH,MAAM,SAAS,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,gBAAgB,CAAC,CAAC,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;YAC3E,MAAM,OAAO,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,gBAAgB,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;YAEvE,MAAM,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YAEvE,MAAM,SAAS,GAAmB;gBAChC,WAAW,EAAE,gBAAgB,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI;gBAC7D,SAAS,EAAE,cAAc,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI;gBACvD,IAAI,EAAE,CAAC;gBACP,QAAQ,EAAE,QAAQ;gBAClB,MAAM,EAAE,QAAQ;gBAChB,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,eAAe,CAAC,CAAC,CAAC,SAAS,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;gBAC1F,SAAS,EAAE,OAAO,GAAG,EAAE;gBACvB,gBAAgB,EAAE,IAAI,CAAC,OAAO,CAAC,qBAAqB,GAAG,EAAE;aAC1D,CAAC;YAEF,IAAG,CAAC,CAAC,MAAM,IAAI,IAAI,EACnB;gBACE,MAAM,YAAY,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;gBACzE,MAAM,cAAc,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,gBAAgB,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;gBAE9E,SAAS,CAAC,SAAS,GAAG,EAAE,GAAG,YAAY,GAAG,CAAC,cAAc,GAAG,EAAE,CAAC,CAAC;aACjE;YAED,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC9B,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,CAAC,IAAI,GAAG,WAAW,CAAC;IACvC,CAAC;IAEQ,sBAAsB,CAAC,SAA0C;QAExE,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED,kBAAkB;QAEhB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAEtC,IAAG,IAAI,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC;YAAE,OAAO;QAEtC,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACpG,MAAM,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAEnG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,QAAuC,EAAE,QAAgB,EAAE,EAAE;YAEjF,MAAM,GAAG,GACT;gBACE,SAAS,EAAE,EAAE;gBACb,KAAK,EAAE,QAAQ,CAAC,KAAK;gBACrB,MAAM,EAAE,EAAE;gBACV,MAAM,EAAE,EAAE;gBACV,KAAK,EAAE,QAAQ,CAAC,EAAE,CAAC,QAAQ,EAAE;gBAC7B,aAAa,EAAE,QAAQ;gBACvB,eAAe,EAAE,QAAQ;gBACzB,OAAO,EAAE,EAAE;aACZ,CAAA;YAED,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,IAAY,EAAE,EAAE;gBAEvC,MAAM,MAAM,GACZ;oBACE,SAAS,EAAE,EAAE;oBACb,KAAK,EAAE,EAAE;oBACT,MAAM,EAAE,EAAE;oBACV,MAAM,EAAE,EAAE;oBACV,KAAK,EAAE,GAAG,eAAe,IAAI,IAAI,EAAE;oBACnC,aAAa,EAAE,QAAQ;oBACvB,eAAe,EAAE,QAAQ;oBACzB,UAAU,EAAE,IAAI;iBACjB,CAAA;gBAED,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC3B,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAExB,CAAC,CAAC,CAAC;IACL,CAAC;IAEQ,sBAAsB,CAAC,QAAkB;QAChD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAEQ,qBAAqB,CAAC,QAAkB;QAC/C,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED,iBAAiB,CAAC,KAAoB,EAAE,GAAkB;QAExD,MAAM,CAAC,GACP;YACE,OAAO,EAAE,GAAG,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACtC,OAAO,EAAE,GAAG,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACtC,SAAS,EAAE,KAAK,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAC1C,SAAS,EAAE,KAAK,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAC1C,UAAU,EAAE,KAAK,CAAC,QAAQ;SAC3B,CAAA;QAED,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;IAC3B,CAAC;IAEQ,YAAY,CAAC,KAAqB,EAAE,GAAgB,EAAE,OAAmB;QAEhF,MAAM,sBAAsB,GAA+B,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,IAAI,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAEnH,KAAK,CAAC,UAAU,CAAC,EAAC,GAAG,EAAE,GAAG,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,sBAAsB,EAAC,CAAC,CAAC;IAChF,CAAC;IAED,WAAW;QAET,KAAK,CAAC,OAAO,EAAE,CAAC;IAClB,CAAC;IAEO,kBAAkB;QAExB,MAAM,GAAG,GAAiB;YACxB,aAAa,EAAE,QAAQ;YACvB,eAAe,EAAE,QAAQ;YACzB,SAAS,EAAE,EAAE;YACb,OAAO,EAAE,EAAE;YACX,KAAK,EAAE,EAAE;YACT,MAAM,EAAE,EAAE;YACV,MAAM,EAAE,EAAE;YACV,KAAK,EAAE,EAAE;SACV,CAAC;QAEF,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,IAAY,EAAE,EAAE;YAEvC,MAAM,MAAM,GACZ;gBACE,SAAS,EAAE,EAAE;gBACb,KAAK,EAAE,IAAI;gBACX,MAAM,EAAE,EAAE;gBACV,MAAM,EAAE,EAAE;gBACV,KAAK,EAAE,IAAI;gBACX,aAAa,EAAE,QAAQ;gBACvB,eAAe,EAAE,QAAQ;gBACzB,UAAU,EAAE,KAAK;aAClB,CAAA;YAED,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC3B,CAAC,CAAC,CAAC;QAIH,OAAO,CAAC,GAAG,CAAC,CAAC;IACf,CAAC;8GAvTU,mBAAmB;kGAAnB,mBAAmB,2ECVhC,4eAYe;;2FDFF,mBAAmB;kBAL/B,SAAS;+BACE,cAAc","sourcesContent":["import { Component, forwardRef,OnDestroy, OnInit } from '@angular/core';\r\nimport { ADCCommonService, ADCDateSplitter, ADCIOptions, ADCITableCell, ADCITableColumn, ADCITableEvent, ADCITableRow, ADCStaticValues, FlatEventBuilder, TableSelection } from '@asadi/angular-date-components/core';\r\nimport { ADCIResourceSchedulerEvent, ADCIResourceSchedulerResource, ADCIResourceSchedulerTableEvent } from \"../../interface.global\";\r\nimport { AdcResourceSchedulerBase } from '../adc-resource-scheduler-base/adc-resource-scheduler-base';\r\n\r\n@Component({\r\n  selector: 'adc-day-view',\r\n  templateUrl: './adc-day-view.component.html',\r\n  styleUrls: ['./adc-day-view.component.css']\r\n})\r\nexport class ADCDayViewComponent extends AdcResourceSchedulerBase implements OnInit, OnDestroy \r\n{\r\n\r\n  year: number = 0;\r\n  week: number = 0;\r\n  day: number = 0;\r\n\r\n  currentDate: string = '';\r\n  title: string = '';\r\n\r\n  hoursOfDay: string[] = ADCStaticValues.getHoursOfDay();\r\n  daysOfweek: string[] = ADCStaticValues.getDaysOfWeek();\r\n  monthsOfYear: string[] = this.dateAdapter.getMonthsOfYear();\r\n\r\n  dateSplitter: ADCDateSplitter = this.dateFormatter.DateSplitter;\r\n\r\n  resources: ADCIResourceSchedulerResource[] = [];\r\n  events: ADCIResourceSchedulerEvent[] = [];\r\n\r\n  rows: ADCITableRow[] = [];\r\n\r\n  weekends: number[] = [];\r\n  holidays: string[] = [];\r\n\r\n  readonly commonService = new ADCCommonService(this.dateAdapter, this.labels);\r\n  readonly today: string = this.dateAdapter.today();\r\n  readonly selectionManager = new TableSelection(this.dateFilter);\r\n  readonly eventBuilder = new FlatEventBuilder();\r\n\r\n  constructor(\r\n  )\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(event => this.onDateRangeSelect(event.start, event.end));\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 cell1.rowValue == cell2.rowValue && cell2.columnValue >= cell1.columnValue;\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.day = this.dateAdapter.getDayIndexOf(this.startOf);\r\n      this.week = this.dateAdapter.getWeekOf(this.startOf);\r\n      this.year = this.dateAdapter.getYearOf(this.startOf);\r\n      this.calculateCurrentDate();\r\n    }\r\n  }\r\n\r\n  override todayButtonHandler(): void\r\n  {\r\n    this.day = this.dateAdapter.getCurrentDay();\r\n    this.week = this.dateAdapter.getCurrentWeek();\r\n    this.year = this.dateAdapter.getCurrentYear();\r\n    this.calculateCurrentDate();\r\n  }\r\n\r\n  override previousButtonHandler(): void\r\n  {\r\n    this.day--;\r\n    if(this.day < 0)\r\n    {\r\n      this.day = 6;\r\n      this.week--;\r\n\r\n      if(this.week < 1)\r\n      {\r\n        this.year--;\r\n        this.week = this.dateAdapter.getWeeksOfYear(this.year);\r\n      }\r\n    }\r\n    this.calculateCurrentDate();\r\n  }\r\n\r\n  override nextButtonHandler(): void\r\n  {\r\n    this.day++;\r\n    if(this.day > 6)\r\n    {\r\n      this.day = 0;\r\n      this.week++;\r\n\r\n      const weeksOfYear = this.dateAdapter.getWeeksOfYear(this.year);\r\n\r\n      if(this.week > weeksOfYear)\r\n      {\r\n        this.week = 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    const date = this.dateAdapter.getDateOfDay(this.year, this.week, this.day);\r\n    this.currentDate = this.dateAdapter.transformDate(+date.split(this.dateSplitter)[0], +date.split(this.dateSplitter)[1], +date.split(this.dateSplitter)[2]);\r\n\r\n    const dayIndex = this.commonService.getDayIndex(this.day);\r\n    const month = this.monthsOfYear[+date.split(this.dateSplitter)[1] - 1];\r\n\r\n    this.title = `${this.labels?.daysOfWeek[dayIndex] || this.daysOfweek[dayIndex]} \r\n    ${+date.split(this.dateSplitter)[2]} \r\n    ${this.commonService.getMonthName(month) || month} ${this.labels?.year || \"Year\"} \r\n    ${this.year}`;\r\n\r\n    this.dateChangesHandler();\r\n    super.dateRangeChange({startDate: this.currentDate, endDate: this.currentDate});\r\n  }\r\n\r\n  override eventChangesHandler(events: ADCIResourceSchedulerEvent[]): void\r\n  {\r\n    const tableEvents: ADCITableEvent[] = [];\r\n\r\n    this.events = events;\r\n\r\n    const viewEvents = this.tools.resourceScheduler.getEventsBetweenDateRange(this.currentDate, this.currentDate, this.events);\r\n    \r\n    viewEvents.forEach((e: ADCIResourceSchedulerEvent) => {\r\n\r\n      const rowIndex = this.rows.findIndex((r: ADCITableRow) => r.value == e.resourceId);\r\n\r\n      if(rowIndex == -1) return;\r\n\r\n      const row = this.rows[rowIndex];\r\n\r\n      const startColumnIndex = row.columns.findIndex((c: ADCITableColumn) => {\r\n\r\n        const time = this.tools.dateTime.timeOnly(c.value);\r\n        const date = this.tools.dateTime.dateOnly(c.value);\r\n\r\n        return date == this.tools.dateTime.dateOnly(e.startDate) &&\r\n        this.tools.dateTime.hour(time) == this.tools.dateTime.hourOrDefault(e.startTime, '00');\r\n      });\r\n\r\n      const endColumnIndex = row.columns.findIndex((c: ADCITableColumn) => {\r\n        \r\n        const time = this.tools.dateTime.timeOnly(c.value);\r\n        const date = this.tools.dateTime.dateOnly(c.value);\r\n\r\n        return date == this.tools.dateTime.dateOnly(e.endDate) && \r\n        this.tools.dateTime.hour(time) == this.tools.dateTime.hourOrDefault(e.endTime, '23');\r\n      });\r\n\r\n      const startTime = +this.tools.dateTime.minutesOrDefault(e.startTime, '00');\r\n      const endTime = +this.tools.dateTime.minutesOrDefault(e.endTime, '60');\r\n\r\n      const currentDateOnly = this.tools.dateTime.dateOnly(this.currentDate);\r\n\r\n      const cellEvent: ADCITableEvent = {\r\n        columnStart: startColumnIndex != -1 ? startColumnIndex : null,\r\n        columnEnd: endColumnIndex != -1 ? endColumnIndex : null,\r\n        data: e,\r\n        rowStart: rowIndex,\r\n        rowEnd: rowIndex,\r\n        offsetX: this.tools.dateTime.dateOnly(e.startDate) == currentDateOnly ? startTime / 60 : 0,\r\n        fractionX: endTime / 60,\r\n        overlapTolerance: this.options.eventOverlapTolerance / 60\r\n      };\r\n\r\n      if(e.allDay == true)\r\n      {\r\n        const eventHourEnd = +this.tools.dateTime.hourOrDefault(e.endTime, '23');\r\n        const eventMinuteEnd = +this.tools.dateTime.minutesOrDefault(e.endTime, '00');\r\n\r\n        cellEvent.fractionX = 24 - eventHourEnd + (eventMinuteEnd / 60);\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  override resourceChangesHandler(resources: ADCIResourceSchedulerResource[]): void \r\n  {\r\n    this.resources = resources;\r\n    this.dateChangesHandler();\r\n  }\r\n\r\n  dateChangesHandler(): void\r\n  {\r\n    this.rows = this.getRowInitialValue();\r\n\r\n    if(this.resources.length == 0) return;\r\n\r\n    const date = this.dateAdapter.getDateOfDay(this.year, this.week, this.day).split(this.dateSplitter);\r\n    const transformedDate = this.dateAdapter.transformDate(+date[0], +date[1], +date[2]).split('T')[0];\r\n\r\n    this.resources.forEach((resource: ADCIResourceSchedulerResource, rowIndex: number) => {\r\n\r\n        const row: ADCITableRow =\r\n        {\r\n          classList: '',\r\n          label: resource.title,\r\n          prefix: '',\r\n          suffix: '',\r\n          value: resource.id.toString(),\r\n          verticalAlign: 'center',\r\n          horizontalAlign: 'center',\r\n          columns: [],\r\n        }\r\n\r\n        this.hoursOfDay.forEach((hour: string) => {\r\n\r\n          const column: ADCITableColumn =\r\n          {\r\n            classList: '',\r\n            label: '',\r\n            prefix: '',\r\n            suffix: '',\r\n            value: `${transformedDate}T${hour}`,\r\n            verticalAlign: 'center',\r\n            horizontalAlign: 'center',\r\n            selectable: true,\r\n          }\r\n    \r\n          row.columns.push(column);\r\n        });\r\n\r\n        this.rows.push(row);\r\n\r\n    });\r\n  }\r\n\r\n  override holidaysChangesHandler(holidays: string[]): void {\r\n    this.holidays = holidays;\r\n    this.dateChangesHandler();\r\n  }\r\n\r\n  override weekendChangesHandler(weekends: number[]): void {\r\n    this.weekends = weekends;\r\n    this.dateChangesHandler();\r\n  }\r\n\r\n  onDateRangeSelect(start: ADCITableCell, end: ADCITableCell): void\r\n  {\r\n    const e: ADCIResourceSchedulerTableEvent = \r\n    {\r\n      endDate: end.columnValue.split('T')[0],\r\n      endTime: end.columnValue.split('T')[1],\r\n      startDate: start.columnValue.split('T')[0],\r\n      startTime: start.columnValue.split('T')[1],\r\n      resourceId: start.rowValue\r\n    }\r\n\r\n    super.dateRangeSelect(e);\r\n  }\r\n\r\n  override onEventClick(event: ADCITableEvent, dom: HTMLElement, jsEvent: MouseEvent): void \r\n  {\r\n    const resourceSchedulerEvent: ADCIResourceSchedulerEvent = this.events.filter(item => item.id == event.data.id)[0];\r\n\r\n    super.eventClick({dom: dom, jsEvent: jsEvent, event: resourceSchedulerEvent});\r\n  }\r\n\r\n  ngOnDestroy(): void \r\n  {\r\n    super.destory();\r\n  }\r\n\r\n  private getRowInitialValue(): ADCITableRow[]\r\n  {\r\n    const row: ADCITableRow = {\r\n      verticalAlign: 'center',\r\n      horizontalAlign: 'center',\r\n      classList: '',\r\n      columns: [],\r\n      label: '',\r\n      prefix: '',\r\n      suffix: '',\r\n      value: '',\r\n    };\r\n\r\n    this.hoursOfDay.forEach((hour: string) => {\r\n\r\n      const column: ADCITableColumn =\r\n      {\r\n        classList: '',\r\n        label: hour,\r\n        prefix: '',\r\n        suffix: '',\r\n        value: hour,\r\n        verticalAlign: 'center',\r\n        horizontalAlign: 'center',\r\n        selectable: false,\r\n      }\r\n\r\n      row.columns.push(column);\r\n    });\r\n\r\n\r\n\r\n    return [row];\r\n  }\r\n}\r\n","<ng-container *ngIf=\"resources.length != 0\">\r\n    <adc-table\r\n    [rows]=\"rows\"\r\n    [title]=\"title\"\r\n    [titleClass]=\"''.concat(\r\n        today == currentDate.split('T')[0] ? ' today ' : ' ',\r\n        weekends.includes(day) || holidays.includes(currentDate.split('T')[0]) ? ' holiday ' : ' '\r\n    )\"\r\n    [selectionManager]=\"selectionManager\"\r\n    [eventBuilder]=\"eventBuilder\"\r\n    (viewReady)=\"markViewAsReady()\"\r\n    ></adc-table>\r\n</ng-container>"]}