@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
220 lines • 27.3 kB
JavaScript
import { booleanAttribute, Component, EventEmitter, Inject, Input, Optional, Output } from '@angular/core';
import { AdcResourceSchedulerModule } from '../../adc-resource-scheduler.module';
import { ADCBaseContainerComponent, ADC_LABELS, ADC_OPTIONS, DateChangeService } from '@asadi/angular-date-components/core';
import { CommonModule } from '@angular/common';
import { ADCResourceSchedulerSource } from '../../directives/adc-resource-scheduler-source.directive';
import { ADCMonthViewComponent } from '../adc-month-view/adc-month-view.component';
import { ADCWeekViewComponent } from '../adc-week-view/adc-week-view.component';
import { ADCDayViewComponent } from '../adc-day-view/adc-day-view.component';
import * as i0 from "@angular/core";
import * as i1 from "@asadi/angular-date-components/core";
import * as i2 from "../../directives/adc-resource-scheduler-source.directive";
import * as i3 from "@angular/common";
const defaultViews = ['month', 'week', 'day'];
/**
* The ADCResourceSchedulerComponent is responsible for rendering a resource scheduler view.
* It supports different views (e.g., month, week, day) and handles navigation through date ranges.
* This component integrates with other services like date changes and event handling.
*
* ### Usage Example:
* ```html
* <adc-resource-scheduler
* [DefaultViews]="['month', 'week']"
* [CustomViews]="customViewsArray"
* (ViewChange)="handleViewChange($event)"
* (Next)="handleNext()"
* (Previous)="handlePrevious()">
* </adc-resource-scheduler>
* ```
*/
export class ADCResourceSchedulerComponent {
/**
* The default views for the scheduler.
* This input accepts an array of view identifiers (e.g., 'month', 'week', 'day') to set the default views.
*
* @example
* ```html
* <adc-resource-scheduler [DefaultViews]="['month', 'week']"></adc-resource-scheduler>
* ```
*/
set defaultViews(value) {
this._defaultViews = value;
this.onViewSet();
}
get defaultViews() {
return this._defaultViews;
}
/**
* Custom views for the scheduler.
* This input allows you to provide custom views to display in the scheduler.
*
* @example
* ```html
* <adc-resource-scheduler [CustomViews]="customViewsArray"></adc-resource-scheduler>
* ```
*/
set customViews(value) {
this._customViews = value;
this.onViewSet();
}
get customViews() {
return this._customViews;
}
constructor(options, labels, dateChangeService) {
this.options = options;
this.labels = labels;
this.dateChangeService = dateChangeService;
this.currentView = this.options.initialView;
this.defaultViewComponents = [
{
id: 'month',
name: this.labels?.month || 'month',
component: ADCMonthViewComponent
},
{
id: 'week',
name: this.labels?.week || 'week',
component: ADCWeekViewComponent
},
{
id: 'day',
name: this.labels?.day || 'day',
component: ADCDayViewComponent
}
];
this.viewButtons = [];
this.resourceSchedulerViews = this.defaultViewComponents;
this._defaultViews = [];
this._customViews = [];
/**
* disables next button for resource scheduler component
*
* @example
* <adc-resource-scheduler disableNext></adc-resource-scheduler>
*/
this.disableNext = false;
/**
* disables previous button for resource scheduler component
*
* @example
* adc-resource-scheduler disablePrevious></adc-resource-scheduler>
*/
this.disablePrevious = false;
/**
* disables today button for resource scheduler component
*
* @example
* <adc-resource-scheduler disableToday></adc-resource-scheduler>
*/
this.disableToday = false;
/**
* Emitted when the view changes (e.g., month, week, or day).
* Use this output to capture the current view selection in the parent component.
*
* @event
* @example
* ```html
* <adc-resource-scheduler (viewChange)="onViewChange($event)"></adc-resource-scheduler>
* ```
*/
this.onViewChangeEvent = new EventEmitter();
/**
* Emitted when the "Next" button is clicked to navigate to the next date range.
*
* @event
* @example
* ```html
* <adc-resource-scheduler (next)="onNext()"></adc-resource-scheduler>
* ```
*/
this.onNextEvent = new EventEmitter();
/**
* Emitted when the "Previous" button is clicked to navigate to the previous date range.
*
* @event
* @example
* ```html
* <adc-resource-scheduler (previous)="onPrevious()"></adc-resource-scheduler>
* ```
*/
this.onPreviousEvent = new EventEmitter();
this.defaultViews = defaultViews;
}
onViewChange(view) {
this.currentView = view;
this.onViewChangeEvent.emit(view);
}
onPrevious() {
this.dateChangeService.previous();
this.onPreviousEvent.emit();
}
onNext() {
this.dateChangeService.next();
this.onNextEvent.emit();
}
onToday() {
this.dateChangeService.today();
}
onViewSet() {
this.resourceSchedulerViews = this.defaultViewComponents.filter(v => this.defaultViews.includes(v.id)).concat(this.customViews);
this.viewButtons = this.resourceSchedulerViews.map(v => {
return {
id: v.id,
name: v.name,
};
});
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: ADCResourceSchedulerComponent, deps: [{ token: ADC_OPTIONS }, { token: ADC_LABELS, optional: true }, { token: i1.DateChangeService }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.0.7", type: ADCResourceSchedulerComponent, isStandalone: true, selector: "adc-resource-scheduler", inputs: { defaultViews: "defaultViews", customViews: "customViews", disableNext: ["disableNext", "disableNext", booleanAttribute], disablePrevious: ["disablePrevious", "disablePrevious", booleanAttribute], disableToday: ["disableToday", "disableToday", booleanAttribute] }, outputs: { onViewChangeEvent: "viewChange", onNextEvent: "next", onPreviousEvent: "previous" }, providers: [
DateChangeService
], hostDirectives: [{ directive: i2.ADCResourceSchedulerSource, inputs: ["startOf", "startOf", "holidays", "holidays", "weekends", "weekends", "events", "events", "resources", "resources"], outputs: ["dateRangeSelect", "dateRangeSelect", "eventSelect", "eventSelect", "dateRangeChange", "dateRangeChange"] }], ngImport: i0, template: "\r\n\r\n<adc-base-container [disableNext]=\"disableNext\" [disablePrevious]=\"disablePrevious\" [disableToday]=\"disableToday\" [views]=\"viewButtons\" (viewChange)=\"onViewChange($event)\" (previous)=\"onPrevious()\" (today)=\"onToday()\" (next)=\"onNext()\">\r\n\r\n <ng-container [ngSwitch]=\"currentView\">\r\n <ng-container *ngFor=\"let item of resourceSchedulerViews\">\r\n <ng-container *ngSwitchCase=\"item.id\">\r\n <ng-container *ngComponentOutlet=\"item.component;\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n</adc-base-container>", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "ngmodule", type: AdcResourceSchedulerModule }, { kind: "component", type: ADCBaseContainerComponent, selector: "adc-base-container", inputs: ["views", "disableNext", "disableToday", "disablePrevious"], outputs: ["viewChange", "next", "today", "previous"] }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: ADCResourceSchedulerComponent, decorators: [{
type: Component,
args: [{ selector: 'adc-resource-scheduler', standalone: true, imports: [
CommonModule,
AdcResourceSchedulerModule,
ADCBaseContainerComponent
], providers: [
DateChangeService
], hostDirectives: [
{
directive: ADCResourceSchedulerSource,
outputs: ['dateRangeSelect', 'eventSelect', 'dateRangeChange'],
inputs: ['startOf', 'holidays', 'weekends', 'events', 'resources']
}
], template: "\r\n\r\n<adc-base-container [disableNext]=\"disableNext\" [disablePrevious]=\"disablePrevious\" [disableToday]=\"disableToday\" [views]=\"viewButtons\" (viewChange)=\"onViewChange($event)\" (previous)=\"onPrevious()\" (today)=\"onToday()\" (next)=\"onNext()\">\r\n\r\n <ng-container [ngSwitch]=\"currentView\">\r\n <ng-container *ngFor=\"let item of resourceSchedulerViews\">\r\n <ng-container *ngSwitchCase=\"item.id\">\r\n <ng-container *ngComponentOutlet=\"item.component;\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n</adc-base-container>" }]
}], ctorParameters: () => [{ type: undefined, decorators: [{
type: Inject,
args: [ADC_OPTIONS]
}] }, { type: undefined, decorators: [{
type: Optional
}, {
type: Inject,
args: [ADC_LABELS]
}] }, { type: i1.DateChangeService }], propDecorators: { defaultViews: [{
type: Input,
args: ['defaultViews']
}], customViews: [{
type: Input,
args: ['customViews']
}], disableNext: [{
type: Input,
args: [{ alias: 'disableNext', transform: booleanAttribute }]
}], disablePrevious: [{
type: Input,
args: [{ alias: 'disablePrevious', transform: booleanAttribute }]
}], disableToday: [{
type: Input,
args: [{ alias: 'disableToday', transform: booleanAttribute }]
}], onViewChangeEvent: [{
type: Output,
args: ['viewChange']
}], onNextEvent: [{
type: Output,
args: ['next']
}], onPreviousEvent: [{
type: Output,
args: ['previous']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adc-resource-scheduler.component.js","sourceRoot":"","sources":["../../../../../../../../projects/asadi/angular-date-components/resource-scheduler/src/components/adc-resource-scheduler/adc-resource-scheduler.component.ts","../../../../../../../../projects/asadi/angular-date-components/resource-scheduler/src/components/adc-resource-scheduler/adc-resource-scheduler.component.html"],"names":[],"mappings":"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","sourcesContent":["import { booleanAttribute, Component, EventEmitter, Inject, Input, Optional, Output } from '@angular/core';\r\nimport { AdcResourceSchedulerModule } from '../../adc-resource-scheduler.module';\r\nimport { ADCBaseContainerComponent, ADCILabels, ADCIOptions, ADCIViewButton, ADC_LABELS, ADC_OPTIONS, DateChangeService } from '@asadi/angular-date-components/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ADCResourceSchedulerSource } from '../../directives/adc-resource-scheduler-source.directive';\r\nimport { ADCIResourceSchedulerView } from '../../interface.global';\r\nimport { ADCMonthViewComponent } from '../adc-month-view/adc-month-view.component';\r\nimport { ADCWeekViewComponent } from '../adc-week-view/adc-week-view.component';\r\nimport { ADCDayViewComponent } from '../adc-day-view/adc-day-view.component';\r\n\r\n\r\nconst defaultViews: string[] = ['month', 'week', 'day'];\r\n\r\n\r\n/**\r\n * The ADCResourceSchedulerComponent is responsible for rendering a resource scheduler view. \r\n * It supports different views (e.g., month, week, day) and handles navigation through date ranges.\r\n * This component integrates with other services like date changes and event handling.\r\n * \r\n * ### Usage Example:\r\n * ```html\r\n * <adc-resource-scheduler\r\n *   [DefaultViews]=\"['month', 'week']\"\r\n *   [CustomViews]=\"customViewsArray\"\r\n *   (ViewChange)=\"handleViewChange($event)\"\r\n *   (Next)=\"handleNext()\"\r\n *   (Previous)=\"handlePrevious()\">\r\n * </adc-resource-scheduler>\r\n * ```\r\n */\r\n@Component({\r\n  selector: 'adc-resource-scheduler',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    AdcResourceSchedulerModule,\r\n    ADCBaseContainerComponent\r\n  ],\r\n  templateUrl: './adc-resource-scheduler.component.html',\r\n  styleUrls: ['./adc-resource-scheduler.component.css'],\r\n  providers: [\r\n    DateChangeService\r\n  ],\r\n  hostDirectives: [\r\n    {\r\n      directive: ADCResourceSchedulerSource,\r\n      outputs: ['dateRangeSelect', 'eventSelect', 'dateRangeChange'],\r\n      inputs: ['startOf', 'holidays', 'weekends', 'events', 'resources']\r\n    }\r\n  ]\r\n})\r\nexport class ADCResourceSchedulerComponent {\r\n\r\n  currentView: 'month' | 'week' | 'day' = this.options.initialView;\r\n\r\n  private defaultViewComponents: ADCIResourceSchedulerView[] = [\r\n    {\r\n      id: 'month',\r\n      name: this.labels?.month || 'month',\r\n      component: ADCMonthViewComponent\r\n    },\r\n    {\r\n      id: 'week',\r\n      name: this.labels?.week || 'week',\r\n      component: ADCWeekViewComponent\r\n    },\r\n    {\r\n      id: 'day',\r\n      name: this.labels?.day || 'day',\r\n      component: ADCDayViewComponent\r\n    }\r\n  ]\r\n\r\n  viewButtons: ADCIViewButton[] = [];\r\n  resourceSchedulerViews: ADCIResourceSchedulerView[] = this.defaultViewComponents;\r\n\r\n  private _defaultViews: string[] = [];\r\n  private _customViews: ADCIResourceSchedulerView[] = [];\r\n\r\n    /**\r\n   * The default views for the scheduler.\r\n   * This input accepts an array of view identifiers (e.g., 'month', 'week', 'day') to set the default views.\r\n   * \r\n   * @example\r\n   * ```html\r\n   * <adc-resource-scheduler [DefaultViews]=\"['month', 'week']\"></adc-resource-scheduler>\r\n   * ```\r\n   */\r\n  @Input('defaultViews')\r\n  set defaultViews(value: string[])\r\n  {\r\n    this._defaultViews = value;\r\n    this.onViewSet();\r\n  }\r\n  get defaultViews(): string[]\r\n  {\r\n    return this._defaultViews;\r\n  }\r\n\r\n    /**\r\n   * Custom views for the scheduler.\r\n   * This input allows you to provide custom views to display in the scheduler.\r\n   * \r\n   * @example\r\n   * ```html\r\n   * <adc-resource-scheduler [CustomViews]=\"customViewsArray\"></adc-resource-scheduler>\r\n   * ```\r\n   */\r\n  @Input('customViews')\r\n  set customViews(value: ADCIResourceSchedulerView[])\r\n  {\r\n    this._customViews = value;\r\n    this.onViewSet();\r\n  }\r\n  get customViews(): ADCIResourceSchedulerView[]\r\n  {\r\n    return this._customViews;\r\n  }\r\n\r\n\r\n      /**\r\n   * disables next button for resource scheduler component\r\n   * \r\n   * @example\r\n   * <adc-resource-scheduler disableNext></adc-resource-scheduler>\r\n   */\r\n    @Input({alias: 'disableNext', transform: booleanAttribute})\r\n    disableNext: boolean = false;\r\n  \r\n      /**\r\n     * disables previous button for resource scheduler component\r\n     * \r\n     * @example\r\n     * adc-resource-scheduler disablePrevious></adc-resource-scheduler>\r\n     */\r\n    @Input({alias: 'disablePrevious', transform: booleanAttribute})\r\n    disablePrevious: boolean = false;\r\n  \r\n      /**\r\n     * disables today button for resource scheduler component\r\n     * \r\n     * @example\r\n     * <adc-resource-scheduler disableToday></adc-resource-scheduler>\r\n     */\r\n    @Input({alias: 'disableToday', transform: booleanAttribute})\r\n    disableToday: boolean = false;\r\n\r\n    /**\r\n   * Emitted when the view changes (e.g., month, week, or day).\r\n   * Use this output to capture the current view selection in the parent component.\r\n   * \r\n   * @event\r\n   * @example\r\n   * ```html\r\n   * <adc-resource-scheduler (viewChange)=\"onViewChange($event)\"></adc-resource-scheduler>\r\n   * ```\r\n   */\r\n  @Output('viewChange')\r\n  onViewChangeEvent: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n    /**\r\n   * Emitted when the \"Next\" button is clicked to navigate to the next date range.\r\n   * \r\n   * @event\r\n   * @example\r\n   * ```html\r\n   * <adc-resource-scheduler (next)=\"onNext()\"></adc-resource-scheduler>\r\n   * ```\r\n   */\r\n  @Output('next')\r\n  onNextEvent: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n    /**\r\n   * Emitted when the \"Previous\" button is clicked to navigate to the previous date range.\r\n   * \r\n   * @event\r\n   * @example\r\n   * ```html\r\n   * <adc-resource-scheduler (previous)=\"onPrevious()\"></adc-resource-scheduler>\r\n   * ```\r\n   */\r\n  @Output('previous')\r\n  onPreviousEvent: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  constructor(\r\n    @Inject(ADC_OPTIONS) private options: ADCIOptions,\r\n    @Optional() @Inject(ADC_LABELS) public labels: ADCILabels | null,\r\n    private dateChangeService: DateChangeService,\r\n  )\r\n  {\r\n    this.defaultViews = defaultViews;\r\n  }\r\n\r\n\r\n  onViewChange(view: any)\r\n  {\r\n    this.currentView = view;\r\n    this.onViewChangeEvent.emit(view);\r\n  }\r\n\r\n  onPrevious(): void\r\n  {\r\n    this.dateChangeService.previous();\r\n    this.onPreviousEvent.emit();\r\n  }\r\n\r\n  onNext(): void\r\n  {\r\n    this.dateChangeService.next();\r\n    this.onNextEvent.emit();\r\n  }\r\n\r\n  onToday(): void\r\n  {\r\n    this.dateChangeService.today();\r\n  }\r\n\r\n  onViewSet(): void\r\n  {\r\n    this.resourceSchedulerViews = this.defaultViewComponents.filter(v => this.defaultViews.includes(v.id)).concat(this.customViews);\r\n\r\n    this.viewButtons = this.resourceSchedulerViews.map(v => {\r\n      return {\r\n        id: v.id,\r\n        name: v.name,\r\n      }\r\n    });\r\n  }\r\n}\r\n","\r\n\r\n<adc-base-container [disableNext]=\"disableNext\" [disablePrevious]=\"disablePrevious\" [disableToday]=\"disableToday\" [views]=\"viewButtons\" (viewChange)=\"onViewChange($event)\" (previous)=\"onPrevious()\" (today)=\"onToday()\" (next)=\"onNext()\">\r\n\r\n    <ng-container [ngSwitch]=\"currentView\">\r\n        <ng-container *ngFor=\"let item of resourceSchedulerViews\">\r\n            <ng-container *ngSwitchCase=\"item.id\">\r\n                <ng-container *ngComponentOutlet=\"item.component;\"></ng-container>\r\n            </ng-container>\r\n        </ng-container>\r\n    </ng-container>\r\n\r\n</adc-base-container>"]}