UNPKG

@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
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`](https://ej2.syncfusion.com/documentation/api/data/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`](https://ej2.syncfusion.com/documentation/api/data/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}"]}