@syncfusion/ej2-angular-schedule
Version:
Flexible scheduling library with more built-in features and enhanced customization options similar to outlook and google calendar, allowing the users to plan and manage their appointments with efficient data-binding support. for Angular
58 lines • 11.7 kB
JavaScript
import { Directive, ContentChildren } from '@angular/core';
import { ComplexBase, ArrayBase, setValue } from '@syncfusion/ej2-angular-base';
import * as i0 from "@angular/core";
let input = ['allowMultiple', 'colorField', 'cssClassField', 'dataSource', 'endHourField', 'expandedField', 'field', 'groupIDField', 'idField', 'name', 'query', 'startHourField', 'textField', 'title', 'workDaysField'];
let outputs = [];
/**
* `e-resources` directive represent a resources of the Angular Schedule.
* It must be contained in a Schedule component(`ejs-schedule`).
* ```html
* <ejs-schedule>
* <e-resources>
* <e-resource field='RoomId' name='Rooms'></e-resource>
* <e-resource field='OwnerId' name='Owners'></e-resource>
* </e-resources>
* </ejs-schedule>
* ```
*/
export class ResourceDirective extends ComplexBase {
constructor(viewContainerRef) {
super();
this.viewContainerRef = viewContainerRef;
setValue('currentInstance', this, this.viewContainerRef);
this.registerEvents(outputs);
this.directivePropList = input;
}
}
ResourceDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: ResourceDirective, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
ResourceDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.0.3", type: ResourceDirective, selector: "e-resources>e-resource", inputs: { allowMultiple: "allowMultiple", colorField: "colorField", cssClassField: "cssClassField", dataSource: "dataSource", endHourField: "endHourField", expandedField: "expandedField", field: "field", groupIDField: "groupIDField", idField: "idField", name: "name", query: "query", startHourField: "startHourField", textField: "textField", title: "title", workDaysField: "workDaysField" }, usesInheritance: true, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: ResourceDirective, decorators: [{
type: Directive,
args: [{
selector: 'e-resources>e-resource',
inputs: input,
outputs: outputs,
queries: {}
}]
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }]; } });
/**
* Resource Array Directive
* @private
*/
export class ResourcesDirective extends ArrayBase {
constructor() {
super('resources');
}
}
ResourcesDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: ResourcesDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
ResourcesDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.0.3", type: ResourcesDirective, selector: "ejs-schedule>e-resources", queries: [{ propertyName: "children", predicate: ResourceDirective }], usesInheritance: true, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: ResourcesDirective, decorators: [{
type: Directive,
args: [{
selector: 'ejs-schedule>e-resources',
queries: {
children: new ContentChildren(ResourceDirective)
},
}]
}], ctorParameters: function () { return []; } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resources.directive.js","sourceRoot":"","sources":["../../../../src/schedule/resources.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAoB,eAAe,EAAE,MAAM,eAAe,CAAC;AAC7E,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,8BAA8B,CAAC;;AAIhF,IAAI,KAAK,GAAa,CAAC,eAAe,EAAE,YAAY,EAAE,eAAe,EAAE,YAAY,EAAE,cAAc,EAAE,eAAe,EAAE,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAE,OAAO,EAAE,eAAe,CAAC,CAAC;AACpO,IAAI,OAAO,GAAa,EAAE,CAAC;AAC3B;;;;;;;;;;;GAWG;AASH,MAAM,OAAO,iBAAkB,SAAQ,WAA8B;IA0FjE,YAAoB,gBAAiC;QACjD,KAAK,EAAE,CAAC;QADQ,qBAAgB,GAAhB,gBAAgB,CAAiB;QAEjD,QAAQ,CAAC,iBAAiB,EAAE,IAAI,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;QACzD,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;QAC7B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;IACnC,CAAC;;8GA/FQ,iBAAiB;kGAAjB,iBAAiB;2FAAjB,iBAAiB;kBAR7B,SAAS;mBAAC;oBACP,QAAQ,EAAE,wBAAwB;oBAClC,MAAM,EAAE,KAAK;oBACb,OAAO,EAAE,OAAO;oBAChB,OAAO,EAAE,EAER;iBACJ;;AAmGD;;;GAGG;AAOH,MAAM,OAAO,kBAAmB,SAAQ,SAA6B;IACjE;QACI,KAAK,CAAC,WAAW,CAAC,CAAC;IACvB,CAAC;;+GAHQ,kBAAkB;mGAAlB,kBAAkB,yFAHO,iBAAiB;2FAG1C,kBAAkB;kBAN9B,SAAS;mBAAC;oBACP,QAAQ,EAAE,0BAA0B;oBACpC,OAAO,EAAE;wBACL,QAAQ,EAAE,IAAI,eAAe,CAAC,iBAAiB,CAAC;qBACnD;iBACJ","sourcesContent":["import { Directive, ViewContainerRef, ContentChildren } from '@angular/core';\nimport { ComplexBase, ArrayBase, setValue } from '@syncfusion/ej2-angular-base';\n\n\n\nlet input: string[] = ['allowMultiple', 'colorField', 'cssClassField', 'dataSource', 'endHourField', 'expandedField', 'field', 'groupIDField', 'idField', 'name', 'query', 'startHourField', 'textField', 'title', 'workDaysField'];\nlet outputs: string[] = [];\n/**\n * `e-resources` directive represent a resources of the Angular Schedule. \n * It must be contained in a Schedule component(`ejs-schedule`). \n * ```html\n * <ejs-schedule>\n *   <e-resources>\n *    <e-resource field='RoomId' name='Rooms'></e-resource>\n *    <e-resource field='OwnerId' name='Owners'></e-resource>\n *   </e-resources>\n * </ejs-schedule>\n * ```\n */\n@Directive({\n    selector: 'e-resources>e-resource',\n    inputs: input,\n    outputs: outputs,    \n    queries: {\n\n    }\n})\nexport class ResourceDirective extends ComplexBase<ResourceDirective> {\n    public directivePropList: any;\n\t\n\n\n    /** \n     * When set to true, allows multiple selection of resource names, thus creating multiple instances of same appointment for the \n     *  selected resources.\n     * @default false\n     */\n    public allowMultiple: any;\n    /** \n     * It maps the `color` field from the dataSource, which is used to specify colors for the resources.\n     * @default 'Color'\n     */\n    public colorField: any;\n    /** \n     * It maps the `cssClass` field from the dataSource, which is used to specify different styles to each resource appointments.\n     * @default 'CssClass'\n     */\n    public cssClassField: any;\n    /** \n     * Assigns the resource dataSource \n     * The data can be passed either as an array of JavaScript objects, \n     * or else can create an instance of [`DataManager`](http://ej2.syncfusion.com/documentation/data/api-dataManager.html) \n     * in case of processing remote data and can be assigned to the `dataSource` property. \n     * With the remote data assigned to dataSource, check the available \n     *  [adaptors](http://ej2.syncfusion.com/documentation/data/adaptors.html) to customize the data processing.\n     * @default []\n     */\n    public dataSource: any;\n    /** \n     * It maps the `endHour` field from the dataSource, which is used to specify different work end hour for each resources.\n     * @default 'EndHour'\n     */\n    public endHourField: any;\n    /** \n     * It maps the `expanded` field from the dataSource, which is used to specify whether each resource levels \n     * in timeline view needs to be maintained in an expanded or collapsed state by default.\n     * @default 'Expanded'\n     */\n    public expandedField: any;\n    /** \n     * A value that binds to the resource field of event object.\n     * @default null\n     */\n    public field: any;\n    /** \n     * It maps the `groupID` field from the dataSource, which is used to specify under which parent resource, \n     *  the child should be grouped.\n     * @default 'GroupID'\n     */\n    public groupIDField: any;\n    /** \n     * It maps the `id` field from the dataSource and is used to uniquely identify the resources.\n     * @default 'Id'\n     */\n    public idField: any;\n    /** \n     * It represents a unique resource name for differentiating various resource objects while grouping.\n     * @default null\n     */\n    public name: any;\n    /** \n     * Defines the external [`query`](http://ej2.syncfusion.com/documentation/data/api-query.html) \n     * that will be executed along with the data processing.\n     * @default null\n     */\n    public query: any;\n    /** \n     * It maps the `startHour` field from the dataSource, which is used to specify different work start hour for each resources.\n     * @default 'StartHour'\n     */\n    public startHourField: any;\n    /** \n     * It maps the `text` field from the dataSource, which is used to specify the resource names.\n     * @default 'Text'\n     */\n    public textField: any;\n    /** \n     * It holds the title of the resource field to be displayed on the schedule event editor window.\n     * @default null\n     */\n    public title: any;\n    /** \n     * It maps the working days field from the dataSource, which is used to specify different working days for each resources.\n     * @default 'WorkDays'\n     */\n    public workDaysField: any;\n\n    constructor(private viewContainerRef:ViewContainerRef) {\n        super();\n        setValue('currentInstance', this, this.viewContainerRef);\n        this.registerEvents(outputs);\n        this.directivePropList = input;\n    }\n}\n\n/**\n * Resource Array Directive\n * @private\n */\n@Directive({\n    selector: 'ejs-schedule>e-resources',\n    queries: {\n        children: new ContentChildren(ResourceDirective)\n    },\n})\nexport class ResourcesDirective extends ArrayBase<ResourcesDirective> {\n    constructor() {\n        super('resources');\n    }\n}"]}