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

126 lines 18.6 kB
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":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAyG,gBAAgB,EAAE,kBAAkB,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,qCAAqC,CAAC;AAC3N,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAC1C,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,kBAAkB,EAAE,MAAM,iDAAiD,CAAC;AAErF,OAAO,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAGhE;;;;GAIG;AACH,MAAM,OAAgB,gBAAgB;IAAtC;QAEE,kBAAkB;QACD,aAAQ,GAAkB,IAAI,OAAO,EAAE,CAAC;QACxC,sBAAiB,GAAsB,MAAM,CAAC,iBAAiB,CAAC,CAAC;QACjE,oBAAe,GAAuB,MAAM,CAAC,kBAAkB,CAAC,CAAC;QAC1E,gBAAW,GAAY,KAAK,CAAC;QAErC;;WAEG;QACM,gBAAW,GAAoB,MAAM,CAAC,gBAAgB,CAAC,CAAC;QAEjE;;WAEG;QACM,kBAAa,GAAsB,MAAM,CAAC,kBAAkB,CAAC,CAAC;QAEvE;;WAEG;QACM,UAAK,GAAsB,IAAI,iBAAiB,EAAE,CAAC;QAE5D;;WAEG;QACM,WAAM,GAAgB,MAAM,CAAC,UAAU,CAAC,CAAC;QAEzC,YAAO,GAAG,MAAM,CAAc,WAAW,CAAC,CAAC;QAGlD;;SAEC;QACM,YAAO,GAAkB,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC;IAgKjE,CAAC;IA9JC;;;;;OAKG;IACH,IAAI;QACF,IAAI,CAAC,eAAe,EAAE,CAAC;QAEvB,kCAAkC;QAClC,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC5E,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;YACzB,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,iBAAiB,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAChF,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;YACzB,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC/B,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,iBAAiB,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC7E,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;YACzB,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;QAEH,uDAAuD;QACvD,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACjF,IAAG,CAAC,IAAI,CAAC,WAAW;gBAAE,OAAO;YAE7B,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC;QAC9B,CAAC,CAAC,CAAC;QAEH,+BAA+B;QAC/B,IAAI,CAAC,eAAe,CAAC,cAAc,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,KAAe,EAAE,EAAE;YACjG,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;QAEH,+BAA+B;QAC/B,IAAI,CAAC,eAAe,CAAC,cAAc,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,KAAe,EAAE,EAAE;YACjG,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;IACL,CAAC;IA8DD;;;;;OAKG;IACH,eAAe,CAAC,CAA2B;QACzC,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;IAC5C,CAAC;IAED;;;;;OAKG;IACH,eAAe,CAAC,CAAoC;QAClD,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;IAC5C,CAAC;IAED;;;;;OAKG;IACH,UAAU,CAAC,CAAgC;QACzC,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;IACxC,CAAC;IAID;;;;;;;;OAQG;IACH,eAAe;QAEb,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;IACxD,CAAC;IAED;;;;OAIG;IACH,OAAO;QACL,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;IACvB,CAAC;CACF","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"]}