@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
JavaScript
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"]}