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

145 lines 15.1 kB
import { Directive, EventEmitter, Input, Output } from '@angular/core'; import { BehaviorSubject } from 'rxjs'; import * as i0 from "@angular/core"; /** * The `ADCResourceSchedulerSource` directive is used to manage and interact with the data source * for the resource scheduler. It provides input properties for resources, events, holidays, and weekends, * and emits output events for date range changes, event selection, and date range selection. */ export class ADCResourceSchedulerSource { constructor() { this._events = new BehaviorSubject([]); this._resources = new BehaviorSubject([]); this._holidays = new BehaviorSubject([]); this._weekends = new BehaviorSubject([]); /** * Event emitted when a date range is selected. */ this.dateRangeSelect = new EventEmitter(); /** * Event emitted when an event is selected. */ this.eventSelect = new EventEmitter(); /** * Event emitted when the date range changes. */ this.dateRangeChange = new EventEmitter(); this.startOf = null; } /** * Input property for setting the list of events in the resource scheduler. * @param value The events to be set in the scheduler. */ set events(value) { if (value == null) { this._events.next([]); } else { this._events.next(value); } } get events() { return this._events.value; } /** * Input property for setting the list of resources in the resource scheduler. * @param value The resources to be set in the scheduler. */ set resources(value) { if (value == null) { this._resources.next([]); } else { this._resources.next(value); } } get resources() { return this._resources.value; } /** * Input property for setting the list of holidays in the resource scheduler. * @param value The holidays to be set in the scheduler. */ set holidays(value) { if (value == null) { this._holidays.next([]); } else { this._holidays.next(value); } } get holidays() { return this._holidays.value; } /** * Input property for setting the list of weekends in the resource scheduler. * @param value The weekends to be set in the scheduler. */ set weekends(value) { if (value == null) { this._weekends.next([]); } else { this._weekends.next(value); } } get weekends() { return this._weekends.value; } resourceChanges() { return this._resources.asObservable(); } eventChanges() { return this._events.asObservable(); } holidayChanges() { return this._holidays.asObservable(); } weekendChanges() { return this._weekends.asObservable(); } onEventSelect(e) { this.eventSelect.emit(e); } onDateRangeSelect(e) { this.dateRangeSelect.next(e); } ; onDateRangeChange(e) { this.dateRangeChange.emit(e); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: ADCResourceSchedulerSource, deps: [], target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.7", type: ADCResourceSchedulerSource, isStandalone: true, selector: "[ResourceSchedulerSource]", inputs: { events: "events", resources: "resources", holidays: "holidays", weekends: "weekends", startOf: "startOf" }, outputs: { dateRangeSelect: "dateRangeSelect", eventSelect: "eventSelect", dateRangeChange: "dateRangeChange" }, ngImport: i0 }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: ADCResourceSchedulerSource, decorators: [{ type: Directive, args: [{ selector: '[ResourceSchedulerSource]', standalone: true }] }], propDecorators: { dateRangeSelect: [{ type: Output, args: ['dateRangeSelect'] }], eventSelect: [{ type: Output, args: ['eventSelect'] }], dateRangeChange: [{ type: Output, args: ['dateRangeChange'] }], events: [{ type: Input, args: ['events'] }], resources: [{ type: Input, args: ['resources'] }], holidays: [{ type: Input, args: ["holidays"] }], weekends: [{ type: Input, args: ["weekends"] }], startOf: [{ type: Input, args: ['startOf'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adc-resource-scheduler-source.directive.js","sourceRoot":"","sources":["../../../../../../../projects/asadi/angular-date-components/resource-scheduler/src/directives/adc-resource-scheduler-source.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, EventEmitter, Input, Output } from '@angular/core';\r\nimport { ADCIResourceSchedulerEvent, ADCIResourceSchedulerEventSelectEvent, ADCIResourceSchedulerResource, ADCIResourceSchedulerTableEvent } from '../interface.global';\r\nimport { BehaviorSubject, Observable } from 'rxjs';\r\nimport { ADCIDateRangeChangeEvent } from '@asadi/angular-date-components/core';\r\n\r\n/**\r\n * The `ADCResourceSchedulerSource` directive is used to manage and interact with the data source \r\n * for the resource scheduler. It provides input properties for resources, events, holidays, and weekends,\r\n * and emits output events for date range changes, event selection, and date range selection.\r\n */\r\n@Directive({\r\n  selector: '[ResourceSchedulerSource]',\r\n  standalone: true\r\n})\r\nexport class ADCResourceSchedulerSource {\r\n\r\n  private _events: BehaviorSubject<ADCIResourceSchedulerEvent[]>  = new BehaviorSubject(([] as ADCIResourceSchedulerEvent[]));\r\n  private _resources: BehaviorSubject<ADCIResourceSchedulerResource[]>  = new BehaviorSubject(([] as ADCIResourceSchedulerResource[]));\r\n  private _holidays: BehaviorSubject<string[]> = new BehaviorSubject(([] as string[]));\r\n  private _weekends: BehaviorSubject<number[]> = new BehaviorSubject(([] as number[]));\r\n\r\n    /**\r\n   * Event emitted when a date range is selected.\r\n   */\r\n  @Output('dateRangeSelect')\r\n  private dateRangeSelect: EventEmitter<ADCIResourceSchedulerTableEvent> = new EventEmitter<ADCIResourceSchedulerTableEvent>();\r\n\r\n    /**\r\n   * Event emitted when an event is selected.\r\n   */\r\n  @Output('eventSelect')\r\n  private eventSelect: EventEmitter<ADCIResourceSchedulerEventSelectEvent> = new EventEmitter<ADCIResourceSchedulerEventSelectEvent>();\r\n\r\n   /**\r\n   * Event emitted when the date range changes.\r\n   */\r\n  @Output('dateRangeChange')\r\n  private dateRangeChange: EventEmitter<ADCIDateRangeChangeEvent> = new EventEmitter<ADCIDateRangeChangeEvent>();\r\n\r\n    /**\r\n   * Input property for setting the list of events in the resource scheduler.\r\n   * @param value The events to be set in the scheduler.\r\n   */\r\n  @Input('events')\r\n  set events(value: ADCIResourceSchedulerEvent[])\r\n  {\r\n    if(value == null)\r\n    {\r\n      this._events.next([]);\r\n    }\r\n    else\r\n    {\r\n      this._events.next(value);\r\n    }\r\n  }\r\n  get events(): ADCIResourceSchedulerEvent[]\r\n  {\r\n    return this._events.value;\r\n  }\r\n\r\n    /**\r\n   * Input property for setting the list of resources in the resource scheduler.\r\n   * @param value The resources to be set in the scheduler.\r\n   */\r\n  @Input('resources')\r\n  set resources(value: ADCIResourceSchedulerResource[])\r\n  {\r\n    if(value == null)\r\n    {\r\n      this._resources.next([]);\r\n    }\r\n    else\r\n    {\r\n      this._resources.next(value);\r\n    }\r\n    \r\n  }\r\n  get resources(): ADCIResourceSchedulerResource[]\r\n  {\r\n    return this._resources.value;\r\n  }\r\n\r\n    /**\r\n   * Input property for setting the list of holidays in the resource scheduler.\r\n   * @param value The holidays to be set in the scheduler.\r\n   */\r\n  @Input(\"holidays\")\r\n  set holidays(value: string[])\r\n  {\r\n    if(value == null)\r\n    {\r\n      this._holidays.next([]);\r\n    }\r\n    else\r\n    {\r\n      this._holidays.next(value);\r\n    }\r\n  }\r\n  get holidays(): string[]\r\n  {\r\n    return this._holidays.value;\r\n  }\r\n\r\n    /**\r\n   * Input property for setting the list of weekends in the resource scheduler.\r\n   * @param value The weekends to be set in the scheduler.\r\n   */\r\n  @Input(\"weekends\")\r\n  set weekends(value: number[])\r\n  {\r\n    if(value == null)\r\n    {\r\n      this._weekends.next([]);\r\n    }\r\n    else\r\n    {\r\n      this._weekends.next(value);\r\n    }\r\n  }\r\n  get weekends(): number[]\r\n  {\r\n    return this._weekends.value;\r\n  }\r\n\r\n  @Input('startOf')\r\n  startOf: string | null = null;\r\n\r\n  resourceChanges(): Observable<ADCIResourceSchedulerResource[]>\r\n  {\r\n    return this._resources.asObservable();\r\n  }\r\n\r\n  eventChanges(): Observable<ADCIResourceSchedulerEvent[]>\r\n  {\r\n    return this._events.asObservable();\r\n  }\r\n\r\n  holidayChanges(): Observable<string[]>\r\n  {\r\n    return this._holidays.asObservable();\r\n  }\r\n\r\n  weekendChanges(): Observable<number[]>\r\n  {\r\n    return this._weekends.asObservable();\r\n  }\r\n\r\n  onEventSelect(e: ADCIResourceSchedulerEventSelectEvent): void\r\n  {\r\n    this.eventSelect.emit(e);\r\n  }\r\n\r\n  onDateRangeSelect(e: ADCIResourceSchedulerTableEvent)\r\n  {\r\n    this.dateRangeSelect.next(e);\r\n  };\r\n\r\n  onDateRangeChange(e: ADCIDateRangeChangeEvent): void\r\n  {\r\n    this.dateRangeChange.emit(e);\r\n  }\r\n}\r\n"]}