@daypilot/daypilot-lite-angular
Version:
DayPilot Lite for Angular
145 lines • 16.4 kB
JavaScript
import { Component, EventEmitter, Input, Output } from "@angular/core";
import { effect } from '@angular/core';
import { DayPilot } from "./core/daypilot-core";
import { optHash, rand } from "./util";
import * as i0 from "@angular/core";
class DayPilotSchedulerComponent {
control;
viewChange = new EventEmitter();
config;
_requestUpdateFull = false;
_requestUpdateEvents = false;
_requestViewChange = false;
_hashOptions = "";
_hashEvents = "";
_eventsSet = false;
_events = [];
get events() {
if (typeof this._events === 'function') {
return this._events();
}
return this._events;
}
set events(value) {
this._eventsSet = true;
this._events = value;
}
_id = "dp_" + new Date().getTime() + rand();
get configResolved() {
return typeof this.config === 'function' ? this.config() : this.config;
}
get id() {
return this._id;
}
constructor() {
effect(() => {
if (typeof this._events !== 'function') {
return;
}
const control = this.control;
const events = this._events();
if (control) {
control.internal.upd({ events });
}
});
effect(() => {
if (typeof this.config !== 'function') {
return;
}
const control = this.control;
const config = this.config();
if (control) {
control.internal.upd(config);
}
});
}
async ngOnInit() { }
ngOnDestroy() {
this.dispose();
}
ngAfterViewInit() {
this.control = new DayPilot.Scheduler(this.id);
this.updateOptions();
this.updateEvents();
this._requestUpdateFull = false; // config just loaded and calling init(), no need to call update again
this._requestUpdateEvents = false; // config just loaded and calling init(), no need to call update again
this.control.init();
}
ngDoCheck() {
const eventsAsSignal = typeof this._events === 'function' || !this._eventsSet;
const configAsSignal = typeof this.config === 'function' || !this.config;
if (eventsAsSignal && configAsSignal) {
return;
}
if (!this.control) {
return;
}
if (!configAsSignal) {
this.updateOptions();
}
if (!eventsAsSignal) {
this.updateEvents();
}
const control = this.control;
if (this._requestUpdateFull) {
control.internal.upd();
this._requestUpdateFull = false;
this._requestUpdateEvents = false;
}
else if (this._requestUpdateEvents) {
control.internal.upd({ "events": this.events });
this._requestUpdateEvents = false;
}
if (this._requestViewChange) {
this._requestViewChange = false;
const args = {};
this.viewChange.emit(args);
}
}
dispose() {
if (this.control) {
this.control.dispose();
//@ts-ignore
this.control = null;
}
}
updateOptions() {
const config = this.configResolved;
const hash = optHash(config);
if (hash !== this._hashOptions) {
const control = this.control;
control.internal.loadOptions(config);
this._requestUpdateFull = true;
this._requestViewChange = true;
}
this._hashOptions = hash;
}
updateEvents() {
if (!this._eventsSet) {
return;
}
const hash = optHash(this.events);
if (hash !== this._hashEvents) {
const control = this.control;
control.events.list = this.events;
this._requestUpdateEvents = true;
}
this._hashEvents = hash;
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DayPilotSchedulerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DayPilotSchedulerComponent, selector: "daypilot-scheduler", inputs: { config: "config", events: "events" }, outputs: { viewChange: "viewChange" }, ngImport: i0, template: `
<div id='{{id}}'></div>`, isInline: true, styles: [""] });
}
export { DayPilotSchedulerComponent };
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DayPilotSchedulerComponent, decorators: [{
type: Component,
args: [{ selector: 'daypilot-scheduler', template: `
<div id='{{id}}'></div>` }]
}], ctorParameters: function () { return []; }, propDecorators: { viewChange: [{
type: Output
}], config: [{
type: Input
}], events: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daypilot-scheduler.component.js","sourceRoot":"","sources":["../../../../../projects/daypilot/daypilot-lite-angular/src/lib/daypilot-scheduler.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, DoCheck, EventEmitter, Input, OnDestroy, OnInit, Output} from \"@angular/core\";\nimport { effect  } from '@angular/core';\nimport {DayPilot} from \"./core/daypilot-core\";\nimport {optHash, rand, EventDiff, OptionalSignal} from \"./util\";\n\n@Component({\n  selector: 'daypilot-scheduler',\n  template: `\n    <div id='{{id}}'></div>`,\n  styles: [``]\n})\nexport class DayPilotSchedulerComponent implements OnInit, OnDestroy, AfterViewInit, DoCheck {\n\n  public control!: DayPilot.Scheduler;\n  @Output() viewChange: EventEmitter<DayPilot.Date> = new EventEmitter<DayPilot.Date>();\n  @Input() config: OptionalSignal<any>;\n  private _requestUpdateFull: boolean = false;\n  private _requestUpdateEvents: boolean = false;\n  private _requestViewChange: boolean = false;\n  private _hashOptions: string = \"\";\n  private _hashEvents: string = \"\";\n  private _eventsSet: boolean = false;\n\n  private _events: OptionalSignal<DayPilot.EventData[]> = [];\n\n  public get events(): DayPilot.EventData[] {\n    if (typeof this._events === 'function') {\n      return this._events();\n    }\n    return this._events;\n  }\n\n  @Input()\n  public set events(value: OptionalSignal<DayPilot.EventData[]>) {\n    this._eventsSet = true;\n    this._events = value;\n  }\n\n  private _id: string = \"dp_\" + new Date().getTime() + rand();\n\n  private get configResolved() {\n    return typeof this.config === 'function' ? this.config() : this.config;\n  }\n\n  get id() {\n    return this._id;\n  }\n\n  constructor() {\n    effect(() => {\n      if (typeof this._events !== 'function') {\n        return;\n      }\n      const control: any = this.control;\n      const events = (<any>this._events)();\n      if (control) {\n          control.internal.upd({events});\n      }\n    });\n\n    effect(() => {\n      if (typeof this.config !== 'function') {\n        return;\n      }\n      const control: any = this.control;\n      const config = (<any>this.config)();\n      if (control) {\n          control.internal.upd(config);\n      }\n    });\n  }\n\n  async ngOnInit() { }\n\n  ngOnDestroy(): void {\n    this.dispose();\n  }\n\n  ngAfterViewInit(): void {\n    this.control = new DayPilot.Scheduler(this.id);\n    this.updateOptions();\n    this.updateEvents();\n    this._requestUpdateFull = false; // config just loaded and calling init(), no need to call update again\n    this._requestUpdateEvents = false; // config just loaded and calling init(), no need to call update again\n    this.control.init();\n  }\n\n  ngDoCheck(): void {\n\n    const eventsAsSignal = typeof this._events === 'function' || !this._eventsSet;\n    const configAsSignal = typeof this.config === 'function' || !this.config;\n\n    if (eventsAsSignal && configAsSignal) {\n      return;\n    }\n\n    if (!this.control) {\n      return;\n    }\n\n    if (!configAsSignal) {\n      this.updateOptions();\n    }\n    if (!eventsAsSignal) {\n      this.updateEvents();\n    }\n\n    const control: any = this.control;\n\n    if (this._requestUpdateFull) {\n      control.internal.upd();\n      this._requestUpdateFull = false;\n      this._requestUpdateEvents = false;\n    } else if (this._requestUpdateEvents) {\n      control.internal.upd({\"events\": this.events});\n      this._requestUpdateEvents = false;\n    }\n    if (this._requestViewChange) {\n      this._requestViewChange = false;\n      const args: any = {};\n      this.viewChange.emit(args);\n    }\n  }\n\n  private dispose() {\n    if (this.control) {\n      this.control.dispose();\n      //@ts-ignore\n      this.control = null;\n    }\n  }\n\n  private updateOptions(): void {\n\n    const config = this.configResolved;\n\n    const hash = optHash(config);\n    if (hash !== this._hashOptions) {\n      const control: any = this.control;\n      control.internal.loadOptions(config);\n      this._requestUpdateFull = true;\n      this._requestViewChange = true;\n    }\n    this._hashOptions = hash;\n\n  }\n\n  private updateEvents(): void {\n    if (!this._eventsSet) {\n      return;\n    }\n\n    const hash = optHash(this.events);\n    if (hash !== this._hashEvents) {\n      const control: any = this.control;\n      control.events.list = this.events;\n      this._requestUpdateEvents = true;\n    }\n    this._hashEvents = hash;\n  }\n}\n"]}