@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
192 lines • 36.9 kB
JavaScript
import { Subject } from "rxjs";
import { Interactions } from "./Interactions";
export class FlatEventBuilder {
constructor() {
this._data = [];
this._tvc = null;
this._options = null;
this._renderer = null;
this.eventHeight = 40;
this.eventSelectSubject = new Subject();
this.eventClearSubject = new Subject();
this.eventSelectionStream = this.eventSelectSubject.asObservable();
this.heightUpdateStrategy = (eventsCount) => {
return `${Math.max(eventsCount * (this.eventHeight + 5) + 50, 70)}px`;
};
}
set data(data) {
data = Array.isArray(data) ? data : [];
this._data = data;
this.buildEvents();
}
get data() {
return this._data;
}
init(renderer, tvc, options) {
this._tvc = tvc;
this._options = options;
this._renderer = renderer;
this.buildEvents();
}
clearEvents() {
if (this._tvc == null)
return;
const rowsCount = this._tvc.rowsCount();
this.eventClearSubject.next();
for (let i = 0; i < rowsCount; i++) {
this._tvc.row(i).clearEvents();
}
}
buildEvents() {
if (this._tvc == null)
return;
this.clearEvents();
const events = this.data;
const rowsCount = this._tvc.rowsCount();
for (let i = 0; i < rowsCount; i++) {
const row = this._tvc.row(i);
if (row.isSticky)
continue;
const rowEvents = events.filter(e => e.rowStart <= i && e.rowEnd >= i);
if (rowEvents.length == 0) {
const height = this.heightUpdateStrategy(0);
row.setHeight(height);
continue;
}
let rowMaxStack = 0;
for (const e of rowEvents) {
const attributes = this.calculateAttributes(e, row, rowMaxStack);
if (attributes.width == '0%')
continue;
if (attributes.level + 1 > rowMaxStack) {
rowMaxStack = attributes.level + 1;
const height = this.heightUpdateStrategy(rowMaxStack);
row.setHeight(height);
}
this.buildEvent(e, attributes, row);
}
}
}
calculateAttributes(event, row, maxStackSize) {
if (this._options == null || this._tvc == null) {
throw new Error("required options are not provided");
}
const direction = this._options.direction;
const horizontalOffset = this.horizontalOffset(event, row);
const width = this.width(event, row);
const level = this.level(event, row, maxStackSize);
const attributes = {
backgroundColor: event.data.bgColor,
left: direction === 'rtl' ? 'unset' : `${horizontalOffset}`,
right: direction === 'rtl' ? `${horizontalOffset}` : 'unset',
textAlign: direction === 'rtl' ? 'right' : 'left',
level: level,
width: width,
classList: ['table-event']
};
if (event.rowStart == row.index && event.columnStart != null) {
attributes.classList.push('event-start-day');
}
if (event.rowEnd == row.index && event.columnEnd != null) {
attributes.classList.push('event-end-day');
}
return attributes;
}
horizontalOffset(event, row) {
const offsetX = event.rowStart != row.index || event.columnStart == null ? 0 : event.offsetX;
const columnStart = event.columnStart == null || row.index != event.rowStart ? 0 : event.columnStart;
const cellWidth = row.width / row.cells.length;
return `${cellWidth * (offsetX + columnStart) + row.horizontalOffset}px`;
}
width(event, row) {
const offsetX = row.index == event.rowStart && event.columnStart != null ? event.offsetX : 0;
const columnStart = event.columnStart == null || row.index != event.rowStart ? 0 : event.columnStart;
const fractionX = row.index == event.rowEnd && event.columnEnd != null ? event.fractionX : 1;
const columnEnd = event.columnEnd == null || row.index != event.rowEnd ? (row.cells.length - 1) : event.columnEnd;
const cellWidth = columnEnd - columnStart - offsetX + fractionX;
return (row.width / row.cells.length) * cellWidth + 'px';
}
level(event, row, maxStackSize) {
const previousViewEvents = row.attachedEvents;
const previousEventIds = previousViewEvents.map((viewEvent) => {
return viewEvent.getAttribute('id');
});
const previousEvents = this.data.filter(item => previousEventIds.includes(item.data.id.toString()));
let selfStart = event.columnStart == null ? event.offsetX + event.overlapTolerance : event.columnStart + event.offsetX + event.overlapTolerance;
if (row.index != event.rowStart) {
selfStart = 0;
}
let selfEnd = event.columnEnd == null ? (row.cells.length + event.fractionX - event.overlapTolerance - 1) : event.columnEnd + event.fractionX - event.overlapTolerance;
if (row.index != event.rowEnd) {
selfEnd = row.cells.length;
}
const collisionneurEvents = previousEvents.filter(e => {
if (e.columnStart == null && e.columnEnd == null) {
return true;
}
let eventStart = e.columnStart == null ? e.offsetX : (e.columnStart + e.offsetX);
if (e.rowStart != row.index) {
eventStart = 0;
}
let eventEnd = e.columnEnd == null ? row.cells.length + e.fractionX - 1 : e.columnEnd + e.fractionX;
if (e.rowEnd != row.index) {
eventEnd = row.cells.length;
}
return (selfStart >= eventStart && selfStart <= eventEnd) ||
(selfEnd >= eventStart && selfEnd <= eventEnd) ||
(selfStart < eventStart && selfEnd > eventEnd);
});
const collisionneurViewEvents = previousViewEvents.filter((viewEvent) => collisionneurEvents.map((e) => e.data.id.toString()).includes(viewEvent.getAttribute('id')));
var level = 0;
for (let i = 0; i <= maxStackSize; i++) {
const isLevelFilled = collisionneurViewEvents.map((viewEvent) => viewEvent.getAttribute('level')).includes(i.toString());
if (!isLevelFilled) {
level = i;
break;
}
}
return level;
}
buildEvent(event, attributes, row) {
if (this._renderer == null) {
throw new Error("options are not provided");
}
const eventElRef = this._renderer.createElement('div');
this._renderer.appendChild(eventElRef, this._renderer.createText(event.data.title));
this._renderer.setStyle(eventElRef, 'background-color', attributes.backgroundColor);
this._renderer.setStyle(eventElRef, 'left', attributes.left);
this._renderer.setStyle(eventElRef, 'right', attributes.right);
this._renderer.setStyle(eventElRef, 'top', `${attributes.level * (this.eventHeight + 5) + 25}px`);
this._renderer.setStyle(eventElRef, 'width', `${attributes.width}`);
this._renderer.setStyle(eventElRef, 'height', `${this.eventHeight}px`);
this._renderer.setStyle(eventElRef, 'text-align', attributes.textAlign);
this._renderer.setAttribute(eventElRef, 'id', event.data.id.toString());
this._renderer.setAttribute(eventElRef, 'level', attributes.level.toString());
this._renderer.setAttribute(eventElRef, 'row-index', row.index.toString());
attributes.classList.forEach((className) => {
this._renderer.addClass(eventElRef, className);
});
if (event.data.isClickable) {
Interactions.click(eventElRef, this.eventClearSubject.asObservable()).subscribe((e) => {
this.eventSelectSubject.next({ dom: eventElRef, event: event, jsEvent: e });
});
this._renderer.setStyle(eventElRef, 'cursor', 'pointer');
}
if (event.data.tooltip) {
const tooltipRef = this._renderer.createElement('div');
this._renderer.addClass(tooltipRef, 'tooltip');
this._renderer.setAttribute(tooltipRef, 'id', event.data.id.toString());
this._renderer.appendChild(tooltipRef, this._renderer.createText(event.data.tooltip));
Interactions.tooltip(eventElRef, 300, this.eventClearSubject.asObservable(), this._tvc?.scrollableContainer).subscribe(e => {
if (e.state === 'hide') {
row.clearTooltips();
}
else {
row.attachTooltip(tooltipRef, e.coordinates);
}
});
}
row.attachEvent(eventElRef);
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flat-event-builder.js","sourceRoot":"","sources":["../../../../../../projects/asadi/angular-date-components/core/src/flat-event-builder.ts"],"names":[],"mappings":"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","sourcesContent":["import { Renderer2 } from \"@angular/core\";\r\nimport { ADCIOptions, ADCITableEvent, ADCITableEventAttributes, ADCITableEventSelectEvent, ADCITableViewCTRL } from \"./interface\";\r\nimport { ADCTableRowTools } from \"./utils/table-view-row.tools\";\r\nimport { Subject } from \"rxjs\";\r\nimport { Interactions } from \"./Interactions\";\r\n\r\nexport class FlatEventBuilder \r\n{\r\n    private _data: ADCITableEvent[] = [];\r\n    private _tvc: ADCITableViewCTRL | null = null;\r\n    private _options: ADCIOptions | null = null;\r\n    private _renderer: Renderer2 | null = null;\r\n\r\n    private eventHeight = 40;\r\n    private eventSelectSubject = new Subject<ADCITableEventSelectEvent>();\r\n    private eventClearSubject = new Subject<void>();\r\n\r\n\r\n    readonly eventSelectionStream = this.eventSelectSubject.asObservable();\r\n\r\n    set data(data: ADCITableEvent[])\r\n    {\r\n        data = Array.isArray(data) ? data : [];\r\n        this._data = data;\r\n\r\n        this.buildEvents();\r\n    }\r\n    get data(): ADCITableEvent[]\r\n    {\r\n        return this._data;\r\n    }\r\n\r\n    init(\r\n        renderer: Renderer2,\r\n        tvc: ADCITableViewCTRL,\r\n        options: ADCIOptions\r\n    )\r\n    {\r\n        this._tvc = tvc;\r\n        this._options = options;\r\n        this._renderer = renderer;\r\n\r\n        this.buildEvents();\r\n    }\r\n\r\n  clearEvents(): void \r\n  {\r\n    if(this._tvc == null) return;\r\n    \r\n    const rowsCount = this._tvc.rowsCount();\r\n\r\n    this.eventClearSubject.next();\r\n\r\n    for(let i = 0; i < rowsCount; i++)\r\n    {\r\n        this._tvc.row(i).clearEvents();\r\n    }\r\n  }\r\n\r\n    buildEvents(): void\r\n    {\r\n       if(this._tvc == null) return;\r\n       \r\n       this.clearEvents();   \r\n       const events = this.data;\r\n       const rowsCount = this._tvc.rowsCount();\r\n\r\n       for(let i = 0; i < rowsCount; i++)\r\n       {\r\n           const row = this._tvc.row(i);\r\n\r\n           if(row.isSticky) continue;\r\n\r\n           const rowEvents = events.filter(e => e.rowStart <= i && e.rowEnd >= i);\r\n             \r\n           if(rowEvents.length == 0)\r\n           {\r\n               const height = this.heightUpdateStrategy(0);\r\n               row.setHeight(height);   \r\n               continue;\r\n           }   \r\n\r\n           let rowMaxStack = 0;     \r\n\r\n           for(const e of rowEvents)\r\n           {\r\n               const attributes = this.calculateAttributes(e, row, rowMaxStack);\r\n               \r\n               if(attributes.width == '0%') continue;\r\n\r\n               if(attributes.level + 1 > rowMaxStack)\r\n               {\r\n                   rowMaxStack = attributes.level + 1;\r\n                   const height = this.heightUpdateStrategy(rowMaxStack);\r\n                   row.setHeight(height);\r\n               }\r\n               \r\n               this.buildEvent(e, attributes, row);\r\n           }\r\n       }\r\n    }\r\n\r\n    private heightUpdateStrategy = (eventsCount: number) => {\r\n        return `${Math.max(eventsCount * (this.eventHeight + 5) + 50, 70)}px`;\r\n    }\r\n\r\n    private calculateAttributes(event: ADCITableEvent, row: ADCTableRowTools, maxStackSize: number): ADCITableEventAttributes\r\n    {\r\n        if(this._options == null || this._tvc == null)\r\n        {\r\n            throw new Error(\"required options are not provided\");\r\n        }\r\n\r\n        const direction = this._options.direction;\r\n        const horizontalOffset = this.horizontalOffset(event, row);\r\n        const width = this.width(event, row);\r\n        const level = this.level(event, row, maxStackSize);\r\n    \r\n        const attributes: ADCITableEventAttributes = \r\n        {\r\n          backgroundColor: event.data.bgColor,\r\n          left: direction === 'rtl' ? 'unset' : `${horizontalOffset}`,\r\n          right: direction === 'rtl' ? `${horizontalOffset}` : 'unset',\r\n          textAlign: direction === 'rtl' ? 'right' : 'left',\r\n          level: level,\r\n          width: width,\r\n          classList: ['table-event']\r\n        }\r\n    \r\n        if(event.rowStart == row.index && event.columnStart != null)\r\n        {\r\n          attributes.classList.push('event-start-day');\r\n        }\r\n    \r\n        if(event.rowEnd == row.index && event.columnEnd != null)\r\n        {\r\n          attributes.classList.push('event-end-day')\r\n        }\r\n    \r\n        return attributes;\r\n    }\r\n\r\n    private horizontalOffset(event: ADCITableEvent, row: ADCTableRowTools): string\r\n    {\r\n        const offsetX = event.rowStart != row.index || event.columnStart == null ? 0 : event.offsetX;\r\n        const columnStart = event.columnStart == null || row.index != event.rowStart ? 0 : event.columnStart;\r\n\r\n        const cellWidth = row.width / row.cells.length;\r\n\r\n        return `${cellWidth * (offsetX + columnStart) + row.horizontalOffset}px`;\r\n    }\r\n\r\n    private width(event: ADCITableEvent, row: ADCTableRowTools): string\r\n    {\r\n        const offsetX = row.index == event.rowStart && event.columnStart != null ? event.offsetX : 0;\r\n        const columnStart = event.columnStart == null || row.index != event.rowStart ? 0 : event.columnStart;\r\n        const fractionX = row.index == event.rowEnd && event.columnEnd != null ? event.fractionX : 1;\r\n        const columnEnd = event.columnEnd == null || row.index != event.rowEnd  ? (row.cells.length - 1) : event.columnEnd;\r\n\r\n        const cellWidth = columnEnd - columnStart - offsetX + fractionX;\r\n\r\n        return (row.width / row.cells.length) * cellWidth + 'px';\r\n    }\r\n\r\n    private level(event: ADCITableEvent, row: ADCTableRowTools, maxStackSize: number): number\r\n    {\r\n        const previousViewEvents = row.attachedEvents;\r\n\r\n        const previousEventIds = previousViewEvents.map((viewEvent: HTMLElement) => {\r\n        return viewEvent.getAttribute('id');\r\n        });\r\n\r\n        const previousEvents = this.data.filter(item => previousEventIds.includes(item.data.id.toString()));\r\n        \r\n        let selfStart = event.columnStart == null ? event.offsetX + event.overlapTolerance : event.columnStart + event.offsetX + event.overlapTolerance;\r\n\r\n        if(row.index != event.rowStart)\r\n        {\r\n            selfStart = 0;\r\n        }\r\n\r\n        let selfEnd = event.columnEnd == null ? (row.cells.length + event.fractionX - event.overlapTolerance - 1) : event.columnEnd + event.fractionX - event.overlapTolerance;\r\n\r\n        if(row.index != event.rowEnd)\r\n        {\r\n            selfEnd = row.cells.length;\r\n        }\r\n\r\n        const collisionneurEvents = previousEvents.filter(e => {\r\n\r\n            if(e.columnStart == null && e.columnEnd == null)\r\n            {\r\n                return true;\r\n            }\r\n\r\n            let eventStart = e.columnStart == null ? e.offsetX : (e.columnStart + e.offsetX);\r\n\r\n            if(e.rowStart != row.index)\r\n            {\r\n                eventStart = 0;\r\n            }\r\n\r\n            let eventEnd = e.columnEnd == null ? row.cells.length + e.fractionX - 1 : e.columnEnd + e.fractionX;\r\n\r\n            if(e.rowEnd != row.index)\r\n            {\r\n                eventEnd = row.cells.length;\r\n            }\r\n\r\n            return (selfStart >= eventStart && selfStart <= eventEnd) ||\r\n            (selfEnd >= eventStart && selfEnd <= eventEnd) ||\r\n            (selfStart < eventStart && selfEnd > eventEnd);\r\n        });\r\n        \r\n        const collisionneurViewEvents = previousViewEvents.filter((viewEvent: HTMLElement) => \r\n            collisionneurEvents.map((e) => e.data.id.toString()).includes(viewEvent.getAttribute('id')!)\r\n        );\r\n\r\n        var level = 0;\r\n\r\n        for(let i = 0; i <= maxStackSize; i++)\r\n        {\r\n            const isLevelFilled = collisionneurViewEvents.map((viewEvent: HTMLElement) => viewEvent.getAttribute('level')).includes(i.toString());\r\n\r\n            if(!isLevelFilled)\r\n            {\r\n                level = i;\r\n                break;\r\n            }\r\n        }\r\n\r\n        return level;\r\n    }\r\n\r\n    private buildEvent(event: ADCITableEvent, attributes: ADCITableEventAttributes, row: ADCTableRowTools): void\r\n    {\r\n        if(this._renderer == null)\r\n        {\r\n            throw new Error(\"options are not provided\");\r\n        }\r\n\r\n        const eventElRef: HTMLElement = this._renderer.createElement('div');\r\n\r\n        this._renderer.appendChild(eventElRef, this._renderer.createText(event.data.title));\r\n\r\n        this._renderer.setStyle(eventElRef, 'background-color', attributes.backgroundColor);\r\n        this._renderer.setStyle(eventElRef, 'left', attributes.left);\r\n        this._renderer.setStyle(eventElRef, 'right', attributes.right);\r\n        this._renderer.setStyle(eventElRef, 'top', `${attributes.level * (this.eventHeight + 5) + 25}px`);\r\n        this._renderer.setStyle(eventElRef, 'width', `${attributes.width}`);\r\n        this._renderer.setStyle(eventElRef, 'height', `${this.eventHeight}px`);\r\n        this._renderer.setStyle(eventElRef, 'text-align', attributes.textAlign);\r\n\r\n        this._renderer.setAttribute(eventElRef, 'id', event.data.id.toString());\r\n        this._renderer.setAttribute(eventElRef, 'level', attributes.level.toString());\r\n        this._renderer.setAttribute(eventElRef, 'row-index', row.index.toString());\r\n\r\n        attributes.classList.forEach((className: string) => {\r\n            this._renderer!.addClass(eventElRef, className);\r\n        });\r\n\r\n        if(event.data.isClickable)\r\n        {\r\n            Interactions.click(eventElRef, this.eventClearSubject.asObservable()).subscribe((e) => {\r\n                this.eventSelectSubject.next({dom: eventElRef, event: event, jsEvent: e});\r\n            });\r\n\r\n            this._renderer.setStyle(eventElRef, 'cursor', 'pointer');\r\n        }\r\n\r\n\r\n        if(event.data.tooltip)\r\n        {\r\n            const tooltipRef = this._renderer.createElement('div');\r\n\r\n            this._renderer.addClass(tooltipRef, 'tooltip');\r\n\r\n            this._renderer.setAttribute(tooltipRef, 'id', event.data.id.toString());\r\n            this._renderer.appendChild(tooltipRef, this._renderer.createText(event.data.tooltip));\r\n\r\n            Interactions.tooltip(eventElRef, 300, this.eventClearSubject.asObservable(), this._tvc?.scrollableContainer).subscribe(e => {\r\n\r\n                if(e.state === 'hide')\r\n                {\r\n                    row.clearTooltips();\r\n                }\r\n                else\r\n                {\r\n                    row.attachTooltip(tooltipRef, e.coordinates);\r\n                }\r\n\r\n            });\r\n        }\r\n            \r\n\r\n        row.attachEvent(eventElRef);\r\n    }\r\n}"]}