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 20.1 kB
import { inject } from '@angular/core'; import { ADC_DATE_ADAPTER, ADC_DATE_FORMATTER, ADC_LABELS, ADC_OPTIONS, DateChangeService } from '@asadi/angular-date-components/core'; import { Subject, takeUntil } from 'rxjs'; import { ADCResourceSchedulerSource } from '../../directives/adc-resource-scheduler-source.directive'; import { ADCResourceSchedulerTools } from '../../utils/resource-scheduler.tools'; /** * The `AdcResourceSchedulerBase` class provides the base functionality for resource schedulers. * It manages date navigation, event changes, and resource updates. Derived classes are expected to * implement specific handling for buttons, event changes, resource changes, and date range changes. */ export class AdcResourceSchedulerBase { constructor() { this.destory$ = new Subject(); this.dateChangeService = inject(DateChangeService); this.resourceSchedulerSource = inject(ADCResourceSchedulerSource); this.isViewReady = false; /** * The date adapter used for formatting and managing date operations in the resouce scheduler. */ this.dateAdapter = inject(ADC_DATE_ADAPTER); /** * The date formatter used to format dates in the resource scheduler. */ this.dateFormatter = inject(ADC_DATE_FORMATTER); /** * Utility tools for working with resource scheduler data. */ this.tools = new ADCResourceSchedulerTools(); /** * Optional labels used for localizing or customizing the text displayed in the resource scheduler. */ this.labels = inject(ADC_LABELS); /** * start of date provided in the scheduler component use it to set initial date range. */ this.startOf = this.resourceSchedulerSource.startOf; this.options = inject(ADC_OPTIONS); } /** * Initializes the resource scheduler by subscribing to date and resource changes, and setting up event handlers. */ init() { this.initViewHanlder(); this.dateChangeService.onNext().pipe(takeUntil(this.destory$)).subscribe(() => { this.isViewReady = false; this.nextButtonHandler(); ///this.dateChangesHandler(); //this.eventChangesHandler(undefined); }); this.dateChangeService.onPrevious().pipe(takeUntil(this.destory$)).subscribe(() => { this.isViewReady = false; this.previousButtonHandler(); //this.dateChangesHandler(); //this.eventChangesHandler(undefined); }); this.dateChangeService.onToday().pipe(takeUntil(this.destory$)).subscribe(() => { this.isViewReady = false; this.todayButtonHandler(); //this.dateChangesHandler(); //this.eventChangesHandler(undefined); }); this.resourceSchedulerSource.resourceChanges().pipe(takeUntil(this.destory$)).subscribe((value) => { this.isViewReady = false; this.resourceChangesHandler(value); //this.dateChangesHandler(); //this.eventChangesHandler(undefined); }); this.resourceSchedulerSource.eventChanges().pipe(takeUntil(this.destory$)).subscribe((events) => { if (!this.isViewReady) return; this.eventChangesHandler(events); }); this.resourceSchedulerSource.holidayChanges().pipe(takeUntil(this.destory$)).subscribe((value) => { this.holidaysChangesHandler(value); //this.dateChangesHandler(); }); this.resourceSchedulerSource.weekendChanges().pipe(takeUntil(this.destory$)).subscribe((value) => { this.weekendChangesHandler(value); //this.dateChangesHandler(); }); } /** * Handles date range change events and forwards them to the resource scheduler source. * * @param e - The date range change event. */ dateRangeChange(e) { this.resourceSchedulerSource.onDateRangeChange(e); } /** * Handles date range select events and forwards them to the resource scheduler source. * * @param e - The date range select event. */ dateRangeSelect(e) { this.resourceSchedulerSource.onDateRangeSelect(e); } /** * Handles event select events and forwards them to the resource scheduler source. * * @param e - The event select event. */ eventClick(e) { this.resourceSchedulerSource.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.resourceSchedulerSource.events); } /** * Destroys the resource scheduler instance and cleans up any active subscriptions. */ destory() { this.destory$.next(); } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adc-resource-scheduler-base.js","sourceRoot":"","sources":["../../../../../../../../projects/asadi/angular-date-components/resource-scheduler/src/components/adc-resource-scheduler-base/adc-resource-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, DateChangeService } from '@asadi/angular-date-components/core';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { ADCResourceSchedulerSource } from '../../directives/adc-resource-scheduler-source.directive';\r\nimport { ADCIResourceSchedulerEvent, ADCIResourceSchedulerEventSelectEvent, ADCIResourceSchedulerResource, ADCIResourceSchedulerTableEvent } from '../../interface.global';\r\nimport { ADCResourceSchedulerTools } from '../../utils/resource-scheduler.tools';\r\n\r\n/**\r\n * The `AdcResourceSchedulerBase` class provides the base functionality for resource schedulers.\r\n * It manages date navigation, event changes, and resource updates. Derived classes are expected to\r\n * implement specific handling for buttons, event changes, resource changes, and date range changes.\r\n */\r\nexport abstract class AdcResourceSchedulerBase {\r\n\r\n  private readonly destory$ = new Subject<void>();\r\n  private readonly dateChangeService: DateChangeService = inject(DateChangeService);\r\n  private readonly resourceSchedulerSource: ADCResourceSchedulerSource = inject(ADCResourceSchedulerSource);\r\n  private isViewReady: boolean = false;\r\n\r\n    /**\r\n   * The date adapter used for formatting and managing date operations in the resouce scheduler.\r\n   */\r\n  readonly dateAdapter: ADCIDateAdapter = inject(ADC_DATE_ADAPTER);\r\n\r\n   /**\r\n   * The date formatter used to format dates in the resource scheduler.\r\n   */\r\n  readonly dateFormatter: ADCIDateFormatter = inject(ADC_DATE_FORMATTER);\r\n\r\n    /**\r\n   * Utility tools for working with resource scheduler data.\r\n   */\r\n  readonly tools: ADCResourceSchedulerTools = new ADCResourceSchedulerTools();\r\n\r\n    /**\r\n   * Optional labels used for localizing or customizing the text displayed in the resource scheduler.\r\n   */\r\n  readonly labels?: ADCILabels = inject(ADC_LABELS);\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.resourceSchedulerSource.startOf;\r\n\r\n  readonly options: ADCIOptions = inject(ADC_OPTIONS);\r\n\r\n\r\n    /**\r\n   * Initializes the resource scheduler by subscribing to date and resource changes, and setting up event handlers.\r\n   */\r\n  init(): void \r\n  {\r\n    this.initViewHanlder();\r\n\r\n    this.dateChangeService.onNext().pipe(takeUntil(this.destory$)).subscribe(() => {\r\n      this.isViewReady = false;\r\n      this.nextButtonHandler();\r\n      ///this.dateChangesHandler();\r\n      //this.eventChangesHandler(undefined);\r\n    });\r\n\r\n    this.dateChangeService.onPrevious().pipe(takeUntil(this.destory$)).subscribe(() => {\r\n      this.isViewReady = false;\r\n      this.previousButtonHandler();\r\n      //this.dateChangesHandler();\r\n      //this.eventChangesHandler(undefined);\r\n    });\r\n\r\n    this.dateChangeService.onToday().pipe(takeUntil(this.destory$)).subscribe(() => {\r\n      this.isViewReady = false;\r\n      this.todayButtonHandler();\r\n      //this.dateChangesHandler();\r\n      //this.eventChangesHandler(undefined);\r\n    });\r\n\r\n    this.resourceSchedulerSource.resourceChanges().pipe(takeUntil(this.destory$)).subscribe((value) => {\r\n      this.isViewReady = false;\r\n      this.resourceChangesHandler(value);\r\n      //this.dateChangesHandler();\r\n      //this.eventChangesHandler(undefined);\r\n    });\r\n\r\n    this.resourceSchedulerSource.eventChanges().pipe(takeUntil(this.destory$)).subscribe((events) => {\r\n      if(!this.isViewReady) return;\r\n\r\n      this.eventChangesHandler(events);\r\n    });\r\n\r\n    this.resourceSchedulerSource.holidayChanges().pipe(takeUntil(this.destory$)).subscribe((value: string[]) => {\r\n      this.holidaysChangesHandler(value);\r\n      //this.dateChangesHandler();\r\n    });\r\n\r\n    this.resourceSchedulerSource.weekendChanges().pipe(takeUntil(this.destory$)).subscribe((value: number[]) => {\r\n      this.weekendChangesHandler(value);\r\n      //this.dateChangesHandler();\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    /**\r\n   * Abstract method for handling the \"Today\" button click.\r\n   * Must be implemented by subclasses.\r\n   */\r\n  abstract todayButtonHandler(): void\r\n\r\n    /**\r\n   * Abstract method for handling the \"Previous\" button click.\r\n   * Must be implemented by subclasses.\r\n   */\r\n  abstract previousButtonHandler(): void\r\n\r\n    /**\r\n   * Abstract method for handling the \"Next\" button click.\r\n   * Must be implemented by subclasses.\r\n   */\r\n  abstract nextButtonHandler(): void\r\n\r\n    /**\r\n   * Abstract method for handling changes to events.\r\n   * Must be implemented by subclasses.\r\n   * \r\n   * @param events - The events that have changed, or undefined if there are no events.\r\n   */\r\n  abstract eventChangesHandler(events: ADCIResourceSchedulerEvent[]): void\r\n\r\n    /**\r\n   * Abstract method for handling changes to resources.\r\n   * Must be implemented by subclasses.\r\n   * \r\n   * @param resources - The resources that have changed.\r\n   */\r\n  abstract resourceChangesHandler(resources: ADCIResourceSchedulerResource[]): void\r\n\r\n  //   /**\r\n  //  * Abstract method for handling date changes.\r\n  //  * Must be implemented by subclasses.\r\n  //  */\r\n  // abstract dateChangesHandler(): void\r\n\r\n    /**\r\n   * Abstract method for handling changes to holidays.\r\n   * Must be implemented by subclasses.\r\n   * \r\n   * @param holidays - The updated list of holidays.\r\n   */\r\n  abstract holidaysChangesHandler(holidays: string[]): void\r\n\r\n\r\n    /**\r\n   * Abstract method for handling changes to weekends.\r\n   * Must be implemented by subclasses.\r\n   * \r\n   * @param weekends - The updated list of weekends.\r\n   */\r\n  abstract weekendChangesHandler(weekends: number[]): void\r\n\r\n    /**\r\n   * Handles date range change events and forwards them to the resource scheduler source.\r\n   * \r\n   * @param e - The date range change event.\r\n   */\r\n  dateRangeChange(e: ADCIDateRangeChangeEvent): void\r\n  {\r\n    this.resourceSchedulerSource.onDateRangeChange(e);\r\n  }\r\n\r\n    /**\r\n   * Handles date range select events and forwards them to the resource scheduler source.\r\n   * \r\n   * @param e - The date range select event.\r\n   */\r\n  dateRangeSelect(e: ADCIResourceSchedulerTableEvent): void\r\n  {\r\n    this.resourceSchedulerSource.onDateRangeSelect(e);\r\n  }\r\n\r\n    /**\r\n   * Handles event select events and forwards them to the resource scheduler source.\r\n   * \r\n   * @param e - The event select event.\r\n   */\r\n  eventClick(e: ADCIResourceSchedulerEventSelectEvent): void\r\n  {\r\n    this.resourceSchedulerSource.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.resourceSchedulerSource.events);\r\n    }\r\n\r\n   /**\r\n   * Destroys the resource scheduler instance and cleans up any active subscriptions.\r\n   */\r\n  destory(): void \r\n  {\r\n    this.destory$.next();\r\n  }\r\n}\r\n"]}