@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
126 lines • 18.6 kB
JavaScript
import { inject } from '@angular/core';
import { ADC_DATE_ADAPTER, ADC_DATE_FORMATTER, ADC_LABELS, ADC_OPTIONS } from '@asadi/angular-date-components/core';
import { Subject, takeUntil } from 'rxjs';
import { DateChangeService } from '@asadi/angular-date-components/core';
import { ADCSchedulerSource } from '../../directives/adc-scheduler-source.directive';
import { ADCSchedulerTools } from '../../utils/scheduler.tools';
/**
* Base class for the ADC scheduler. This class provides fundamental functionality for managing date changes,
* event handling, and interacting with the scheduler source. It handles the event subscription and delegates
* specific logic to abstract methods for customization.
*/
export class AdcSchedulerBase {
constructor() {
// Private members
this.destroy$ = new Subject();
this.dateChangeService = inject(DateChangeService);
this.schedulerSource = inject(ADCSchedulerSource);
this.isViewReady = false;
/**
* The date adapter used for managing date-related operations.
*/
this.dateAdapter = inject(ADC_DATE_ADAPTER);
/**
* The date formatter used for formatting dates.
*/
this.dateFormatter = inject(ADC_DATE_FORMATTER);
/**
* A utility toolset for the scheduler, offering additional methods for scheduling operations.
*/
this.tools = new ADCSchedulerTools();
/**
* The optional set of labels used for UI display.
*/
this.labels = inject(ADC_LABELS);
this.options = inject(ADC_OPTIONS);
/**
* start of date provided in the scheduler component use it to set initial date range.
*/
this.startOf = this.schedulerSource.startOf;
}
/**
* Initializes the scheduler by setting up event subscriptions and handlers.
* Subscribes to date change and event change notifications from the date change service and scheduler source.
*
* @returns void
*/
init() {
this.initViewHanlder();
// Subscribe to date change events
this.dateChangeService.onNext().pipe(takeUntil(this.destroy$)).subscribe(() => {
this.isViewReady = false;
this.nextButtonHandler();
});
this.dateChangeService.onPrevious().pipe(takeUntil(this.destroy$)).subscribe(() => {
this.isViewReady = false;
this.previousButtonHandler();
});
this.dateChangeService.onToday().pipe(takeUntil(this.destroy$)).subscribe(() => {
this.isViewReady = false;
this.todayButtonHandler();
});
// Subscribe to event changes from the scheduler source
this.schedulerSource.eventChanges().pipe(takeUntil(this.destroy$)).subscribe((e) => {
if (!this.isViewReady)
return;
this.eventChangesHandler(e);
});
// Subscribe to holiday changes
this.schedulerSource.holidayChanges().pipe(takeUntil(this.destroy$)).subscribe((value) => {
this.holidaysChangesHandler(value);
});
// Subscribe to weekend changes
this.schedulerSource.weekendChanges().pipe(takeUntil(this.destroy$)).subscribe((value) => {
this.weekendsChangesHandler(value);
});
}
/**
* Sends a date range change event to the scheduler source.
*
* @param e - The date range change event to be emitted.
* @returns void
*/
dateRangeChange(e) {
this.schedulerSource.onDateRangeChange(e);
}
/**
* Sends a date range selection event to the scheduler source.
*
* @param e - The date range selection event to be emitted.
* @returns void
*/
dateRangeSelect(e) {
this.schedulerSource.onDateRangeSelect(e);
}
/**
* Sends an event selection event to the scheduler source.
*
* @param e - The event selection event to be emitted.
* @returns void
*/
eventClick(e) {
this.schedulerSource.onEventSelect(e);
}
/**
* Marks the view as ready to process events.
*
* Once this method is called:
* - The `eventChangesHandler` will be triggered immediately with the current list of events.
* - Subsequent updates to events will also be handled automatically until the view is marked as unready.
*
* @returns void
*/
markViewAsReady() {
this.isViewReady = true;
this.eventChangesHandler(this.schedulerSource.events);
}
/**
* Cleans up subscriptions when the component or service is destroyed.
*
* @returns void
*/
destroy() {
this.destroy$.next();
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adc-scheduler-base.js","sourceRoot":"","sources":["../../../../../../../../projects/asadi/angular-date-components/scheduler/src/components/adc-scheduler-base/adc-scheduler-base.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject } from '@angular/core';\r\nimport { ADCIDateAdapter, ADCIDateFormatter, ADCIDateRangeChangeEvent, ADCILabels, ADCIOptions, ADCITableEvent, ADC_DATE_ADAPTER, ADC_DATE_FORMATTER, ADC_LABELS, ADC_OPTIONS } from '@asadi/angular-date-components/core';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { DateChangeService } from '@asadi/angular-date-components/core';\r\nimport { ADCSchedulerSource } from '../../directives/adc-scheduler-source.directive';\r\nimport { ADCISchedulerDateRangeSelectEvent, ADCISchedulerEvent, ADCISchedulerEventSelectEvent } from '../../interface.global';\r\nimport { ADCSchedulerTools } from '../../utils/scheduler.tools';\r\n\r\n\r\n/**\r\n * Base class for the ADC scheduler. This class provides fundamental functionality for managing date changes,\r\n * event handling, and interacting with the scheduler source. It handles the event subscription and delegates \r\n * specific logic to abstract methods for customization.\r\n */\r\nexport abstract class AdcSchedulerBase {\r\n\r\n  // Private members\r\n  private readonly destroy$: Subject<void> = new Subject();\r\n  private readonly dateChangeService: DateChangeService = inject(DateChangeService);\r\n  private readonly schedulerSource: ADCSchedulerSource = inject(ADCSchedulerSource);\r\n  private isViewReady: boolean = false;\r\n\r\n  /**\r\n   * The date adapter used for managing date-related operations.\r\n   */\r\n  readonly dateAdapter: ADCIDateAdapter = inject(ADC_DATE_ADAPTER);\r\n\r\n  /**\r\n   * The date formatter used for formatting dates.\r\n   */\r\n  readonly dateFormatter: ADCIDateFormatter = inject(ADC_DATE_FORMATTER);\r\n\r\n  /**\r\n   * A utility toolset for the scheduler, offering additional methods for scheduling operations.\r\n   */\r\n  readonly tools: ADCSchedulerTools = new ADCSchedulerTools();\r\n\r\n  /**\r\n   * The optional set of labels used for UI display.\r\n   */\r\n  readonly labels?: ADCILabels = inject(ADC_LABELS);\r\n\r\n  readonly options = inject<ADCIOptions>(ADC_OPTIONS);\r\n\r\n\r\n    /**\r\n   * start of date provided in the scheduler component use it to set initial date range.\r\n   */\r\n  readonly startOf: string | null = this.schedulerSource.startOf;\r\n\r\n  /**\r\n   * Initializes the scheduler by setting up event subscriptions and handlers.\r\n   * Subscribes to date change and event change notifications from the date change service and scheduler source.\r\n   * \r\n   * @returns void\r\n   */\r\n  init(): void {\r\n    this.initViewHanlder();\r\n\r\n    // Subscribe to date change events\r\n    this.dateChangeService.onNext().pipe(takeUntil(this.destroy$)).subscribe(() => {\r\n      this.isViewReady = false;\r\n      this.nextButtonHandler();\r\n    });\r\n\r\n    this.dateChangeService.onPrevious().pipe(takeUntil(this.destroy$)).subscribe(() => {\r\n      this.isViewReady = false;\r\n      this.previousButtonHandler();\r\n    });\r\n\r\n    this.dateChangeService.onToday().pipe(takeUntil(this.destroy$)).subscribe(() => {\r\n      this.isViewReady = false;\r\n      this.todayButtonHandler();\r\n    });\r\n\r\n    // Subscribe to event changes from the scheduler source\r\n    this.schedulerSource.eventChanges().pipe(takeUntil(this.destroy$)).subscribe((e) => {\r\n      if(!this.isViewReady) return;\r\n\r\n      this.eventChangesHandler(e);\r\n    });\r\n\r\n    // Subscribe to holiday changes\r\n    this.schedulerSource.holidayChanges().pipe(takeUntil(this.destroy$)).subscribe((value: string[]) => {\r\n      this.holidaysChangesHandler(value);\r\n    });\r\n\r\n    // Subscribe to weekend changes\r\n    this.schedulerSource.weekendChanges().pipe(takeUntil(this.destroy$)).subscribe((value: number[]) => {\r\n      this.weekendsChangesHandler(value);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Handler for the init view. This method should implement logic for setting the initial view date.\r\n   * \r\n   * @returns void\r\n   */\r\n  abstract initViewHanlder(): void;\r\n\r\n  // Abstract methods that must be implemented by subclasses\r\n  /**\r\n   * Handler for the 'Today' button. This method should implement logic for resetting to today's date.\r\n   * \r\n   * @returns void\r\n   */\r\n  abstract todayButtonHandler(): void;\r\n\r\n  /**\r\n   * Handler for the 'Previous' button. This method should implement logic for navigating to the previous date range.\r\n   * \r\n   * @returns void\r\n   */\r\n  abstract previousButtonHandler(): void;\r\n\r\n  /**\r\n   * Handler for the 'Next' button. This method should implement logic for navigating to the next date range.\r\n   * \r\n   * @returns void\r\n   */\r\n  abstract nextButtonHandler(): void;\r\n\r\n  /**\r\n   * Handler for event changes. This method should implement logic for processing updated scheduler events.\r\n   * \r\n   * @param schedulerEvents - The updated list of scheduler events.\r\n   * @returns void\r\n   */\r\n  abstract eventChangesHandler(schedulerEvents: ADCISchedulerEvent[] | undefined): void;\r\n\r\n  // /**\r\n  //  * Handler for date changes. This method should implement logic for processing updated date ranges.\r\n  //  * \r\n  //  * @returns void\r\n  //  */\r\n  // abstract dateChangesHandler(): void;\r\n\r\n  /**\r\n   * Handler for changes to weekends. This method should implement logic for processing updated weekend information.\r\n   * \r\n   * @param weekends - The updated list of weekend days.\r\n   * @returns void\r\n   */\r\n  abstract weekendsChangesHandler(weekends: number[]): void;\r\n\r\n  /**\r\n   * Handler for changes to holidays. This method should implement logic for processing updated holiday information.\r\n   * \r\n   * @param holidays - The updated list of holiday dates.\r\n   * @returns void\r\n   */\r\n  abstract holidaysChangesHandler(holidays: string[]): void;\r\n\r\n  /**\r\n   * Sends a date range change event to the scheduler source.\r\n   * \r\n   * @param e - The date range change event to be emitted.\r\n   * @returns void\r\n   */\r\n  dateRangeChange(e: ADCIDateRangeChangeEvent) {\r\n    this.schedulerSource.onDateRangeChange(e);\r\n  }\r\n\r\n  /**\r\n   * Sends a date range selection event to the scheduler source.\r\n   * \r\n   * @param e - The date range selection event to be emitted.\r\n   * @returns void\r\n   */\r\n  dateRangeSelect(e: ADCISchedulerDateRangeSelectEvent) {\r\n    this.schedulerSource.onDateRangeSelect(e);\r\n  }\r\n\r\n  /**\r\n   * Sends an event selection event to the scheduler source.\r\n   * \r\n   * @param e - The event selection event to be emitted.\r\n   * @returns void\r\n   */\r\n  eventClick(e: ADCISchedulerEventSelectEvent) {\r\n    this.schedulerSource.onEventSelect(e);\r\n  }\r\n\r\n  abstract onEventClick(event: ADCITableEvent, dom: HTMLElement, jsEvent: MouseEvent): void;\r\n\r\n  /**\r\n   * Marks the view as ready to process events.\r\n   * \r\n   * Once this method is called:\r\n   * - The `eventChangesHandler` will be triggered immediately with the current list of events.\r\n   * - Subsequent updates to events will also be handled automatically until the view is marked as unready.\r\n   * \r\n   * @returns void\r\n   */\r\n  markViewAsReady(): void\r\n  {\r\n    this.isViewReady = true;\r\n    this.eventChangesHandler(this.schedulerSource.events);\r\n  }\r\n\r\n  /**\r\n   * Cleans up subscriptions when the component or service is destroyed.\r\n   * \r\n   * @returns void\r\n   */\r\n  destroy(): void {\r\n    this.destroy$.next();\r\n  }\r\n}\r\n"]}