@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
81 lines • 11.8 kB
JavaScript
import { Subject } from "rxjs";
export class TableSelection {
init(tableViewController) {
tableViewController.cellChanges().subscribe(cells => {
this.tableCells = cells;
this.checkForInvalidCells();
this.applyHoverEvent();
this.applyClickEvent();
});
}
constructor(dateFilter = () => true) {
this.dateFilter = dateFilter;
this.selectedCell = null;
this.tableCells = [];
this.selectionSubject = new Subject();
this.cellSelectionStream = this.selectionSubject.asObservable();
}
checkForInvalidCells() {
if (this.selectedCell == null)
return;
const selected = this.tableCells.find(c => c.columnValue == this.selectedCell?.columnValue && c.rowValue == this.selectedCell?.rowValue);
if (selected != null) {
this.selectedCell = selected;
this.selectedCell.markAsSelected();
}
this.tableCells.forEach(c => {
if (!this.dateFilter(this.selectedCell?.asTableCell(), c.asTableCell())) {
c.markAsInvalid();
}
});
}
applyClickEvent() {
this.tableCells.forEach((c, i) => {
c.element.addEventListener('click', () => this.onSelect(i));
});
}
applyHoverEvent() {
this.tableCells.forEach((c, i) => {
c.element.addEventListener('pointerover', () => this.onHover(i));
});
}
onSelect(index) {
const cell = this.tableCells[index];
if (this.selectedCell == null) {
this.selectedCell = cell;
this.selectedCell.markAsSelected();
this.tableCells.forEach(c => {
if (!this.dateFilter(this.selectedCell, c))
c.markAsInvalid();
});
return;
}
if (!cell.invalid) {
this.selectionSubject.next({ start: this.selectedCell.asTableCell(), end: cell.asTableCell() });
}
this.clearSelectionState();
}
onHover(index) {
const cell = this.tableCells[index];
if (this.selectedCell == null || cell.invalid)
return;
this.tableCells.forEach(c => c.removeState('pointed'));
let startCellIndex = this.tableCells.findIndex(c => c.rowValue == this.selectedCell?.rowValue && c.columnValue == this.selectedCell?.columnValue);
if (startCellIndex == -1)
startCellIndex = 0;
this.tableCells.forEach((c, i) => {
if (c.invalid)
return;
if ((i > index || i < startCellIndex) && index >= startCellIndex)
return;
if ((i < index || i > startCellIndex) && index < startCellIndex)
return;
c.markAsPointed();
});
}
clearSelectionState() {
this.selectedCell = null;
this.tableCells.forEach(c => c.resetState());
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-selection.js","sourceRoot":"","sources":["../../../../../../projects/asadi/angular-date-components/core/src/table-selection.ts"],"names":[],"mappings":"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","sourcesContent":["import { Subject } from \"rxjs\";\r\nimport { ADCITableCell, ADCITableViewCTRL } from \"./interface\";\r\nimport { ADCTableCell } from \"./utils/table-cell.tools\";\r\n\r\nexport class TableSelection\r\n{\r\n  private selectedCell: ADCTableCell | null = null;\r\n  private tableCells: ADCTableCell[] = [];\r\n  private selectionSubject = new Subject<{start: ADCITableCell, end: ADCITableCell}>();\r\n\r\n  readonly cellSelectionStream = this.selectionSubject.asObservable();\r\n\r\n  init(tableViewController: ADCITableViewCTRL): void\r\n  {\r\n    tableViewController.cellChanges().subscribe(cells => {\r\n\r\n      this.tableCells = cells;\r\n\r\n      this.checkForInvalidCells();\r\n\r\n      this.applyHoverEvent();\r\n      this.applyClickEvent();\r\n    });\r\n  }\r\n\r\n  constructor(\r\n    private dateFilter: (selectedCell: ADCITableCell, tableCell: ADCITableCell) => boolean = () => true\r\n  ) { }\r\n\r\n  private checkForInvalidCells(): void\r\n  {\r\n    if(this.selectedCell == null) return;\r\n\r\n    const selected = this.tableCells.find(c => c.columnValue == this.selectedCell?.columnValue && c.rowValue == this.selectedCell?.rowValue)\r\n\r\n    if(selected != null)\r\n    {\r\n      this.selectedCell = selected;\r\n\r\n      this.selectedCell.markAsSelected();\r\n    }\r\n\r\n    this.tableCells.forEach(c => {\r\n\r\n      if(!this.dateFilter(this.selectedCell?.asTableCell()!, c.asTableCell()))\r\n      {\r\n        c.markAsInvalid();\r\n      }\r\n    })\r\n  }\r\n\r\n  private applyClickEvent(): void\r\n  {\r\n    this.tableCells.forEach((c, i) => {\r\n      c.element.addEventListener('click', () => this.onSelect(i));\r\n    });\r\n  }\r\n\r\n  private applyHoverEvent(): void\r\n  {\r\n    this.tableCells.forEach((c, i) => {\r\n      c.element.addEventListener('pointerover', () => this.onHover(i))\r\n    });\r\n  }\r\n\r\n  private onSelect(index: number): any\r\n  {\r\n    const cell = this.tableCells[index];\r\n\r\n    if(this.selectedCell == null)\r\n    {\r\n      this.selectedCell = cell;\r\n      this.selectedCell.markAsSelected();\r\n\r\n      this.tableCells.forEach(c => {\r\n        if(!this.dateFilter(this.selectedCell!, c))\r\n          c.markAsInvalid();\r\n      });\r\n\r\n      return;\r\n    }\r\n\r\n    if(!cell.invalid)\r\n    {\r\n      this.selectionSubject.next({start: this.selectedCell.asTableCell(), end: cell.asTableCell()})\r\n    }\r\n\r\n\r\n    this.clearSelectionState();\r\n  }\r\n\r\n  private onHover(index: number): void\r\n  {\r\n    const cell = this.tableCells[index];\r\n\r\n    if(this.selectedCell == null || cell.invalid) return;\r\n\r\n    this.tableCells.forEach(c => c.removeState('pointed'));\r\n\r\n    let startCellIndex = this.tableCells.findIndex(c => c.rowValue == this.selectedCell?.rowValue && c.columnValue == this.selectedCell?.columnValue);\r\n\r\n    if(startCellIndex == -1) startCellIndex = 0;\r\n\r\n    this.tableCells.forEach((c, i) => {\r\n\r\n      if(c.invalid) return;\r\n\r\n      if((i > index || i < startCellIndex) && index >= startCellIndex) return;\r\n\r\n      if((i < index || i > startCellIndex) && index < startCellIndex) return;\r\n\r\n      c.markAsPointed();\r\n    })\r\n  }\r\n\r\n  private clearSelectionState(): void\r\n  {\r\n    this.selectedCell = null;\r\n    this.tableCells.forEach(c => c.resetState());\r\n  }\r\n}"]}