UNPKG

@syncfusion/ej2-angular-treegrid

Version:
100 lines 28.1 kB
import { __decorate } from "tslib"; import { Directive, ContentChildren, ContentChild } from '@angular/core'; import { ComplexBase, ArrayBase, setValue } from '@syncfusion/ej2-angular-base'; import { Template } from '@syncfusion/ej2-angular-base'; import { StackedColumnsDirective } from './stacked-column.directive'; import * as i0 from "@angular/core"; let input = ['allowEditing', 'allowFiltering', 'allowReordering', 'allowResizing', 'allowSorting', 'clipMode', 'columns', 'commands', 'customAttributes', 'defaultValue', 'disableHtmlEncode', 'displayAsCheckBox', 'edit', 'editTemplate', 'editType', 'field', 'filter', 'filterBarTemplate', 'filterTemplate', 'format', 'formatter', 'freeze', 'headerTemplate', 'headerText', 'headerTextAlign', 'hideAtMedia', 'isFrozen', 'isIdentity', 'isPrimaryKey', 'lockColumn', 'maxWidth', 'minWidth', 'showCheckbox', 'showColumnMenu', 'showInColumnChooser', 'sortComparer', 'template', 'textAlign', 'type', 'uid', 'validationRules', 'valueAccessor', 'visible', 'width']; let outputs = []; /** * `e-column` directive represent a column of the Angular TreeGrid. * It must be contained in a TreeGrid component(`ejs-treegrid`). * ```html * <ejs-treegrid [dataSource]='data' allowPaging='true' allowSorting='true'> * <e-columns> * <e-column field='ID' width='100'></e-column> * <e-column field='name' headerText='Name' width='100'></e-column> * </e-columns> * </ejs-treegrid> * ``` */ export class ColumnDirective extends ComplexBase { constructor(viewContainerRef) { super(); this.viewContainerRef = viewContainerRef; this.tags = ['columns']; setValue('currentInstance', this, this.viewContainerRef); this.registerEvents(outputs); this.directivePropList = input; } } ColumnDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: ColumnDirective, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive }); ColumnDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.0.3", type: ColumnDirective, selector: "ejs-treegrid>e-columns>e-column", inputs: { allowEditing: "allowEditing", allowFiltering: "allowFiltering", allowReordering: "allowReordering", allowResizing: "allowResizing", allowSorting: "allowSorting", clipMode: "clipMode", columns: "columns", commands: "commands", customAttributes: "customAttributes", defaultValue: "defaultValue", disableHtmlEncode: "disableHtmlEncode", displayAsCheckBox: "displayAsCheckBox", edit: "edit", editTemplate: "editTemplate", editType: "editType", field: "field", filter: "filter", filterBarTemplate: "filterBarTemplate", filterTemplate: "filterTemplate", format: "format", formatter: "formatter", freeze: "freeze", headerTemplate: "headerTemplate", headerText: "headerText", headerTextAlign: "headerTextAlign", hideAtMedia: "hideAtMedia", isFrozen: "isFrozen", isIdentity: "isIdentity", isPrimaryKey: "isPrimaryKey", lockColumn: "lockColumn", maxWidth: "maxWidth", minWidth: "minWidth", showCheckbox: "showCheckbox", showColumnMenu: "showColumnMenu", showInColumnChooser: "showInColumnChooser", sortComparer: "sortComparer", template: "template", textAlign: "textAlign", type: "type", uid: "uid", validationRules: "validationRules", valueAccessor: "valueAccessor", visible: "visible", width: "width" }, queries: [{ propertyName: "template", first: true, predicate: ["template"], descendants: true }, { propertyName: "headerTemplate", first: true, predicate: ["headerTemplate"], descendants: true }, { propertyName: "filter_itemTemplate", first: true, predicate: ["filterItemTemplate"], descendants: true }, { propertyName: "filterTemplate", first: true, predicate: ["filterTemplate"], descendants: true }, { propertyName: "commandsTemplate", first: true, predicate: ["commandsTemplate"], descendants: true }, { propertyName: "editTemplate", first: true, predicate: ["editTemplate"], descendants: true }, { propertyName: "childColumns", first: true, predicate: StackedColumnsDirective, descendants: true }], usesInheritance: true, ngImport: i0 }); __decorate([ Template() ], ColumnDirective.prototype, "template", void 0); __decorate([ Template() ], ColumnDirective.prototype, "headerTemplate", void 0); __decorate([ Template() ], ColumnDirective.prototype, "filter_itemTemplate", void 0); __decorate([ Template() ], ColumnDirective.prototype, "filterTemplate", void 0); __decorate([ Template() ], ColumnDirective.prototype, "commandsTemplate", void 0); __decorate([ Template() ], ColumnDirective.prototype, "editTemplate", void 0); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: ColumnDirective, decorators: [{ type: Directive, args: [{ selector: 'ejs-treegrid>e-columns>e-column', inputs: input, outputs: outputs, queries: { childColumns: new ContentChild(StackedColumnsDirective) } }] }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }]; }, propDecorators: { template: [{ type: ContentChild, args: ['template'] }], headerTemplate: [{ type: ContentChild, args: ['headerTemplate'] }], filter_itemTemplate: [{ type: ContentChild, args: ['filterItemTemplate'] }], filterTemplate: [{ type: ContentChild, args: ['filterTemplate'] }], commandsTemplate: [{ type: ContentChild, args: ['commandsTemplate'] }], editTemplate: [{ type: ContentChild, args: ['editTemplate'] }] } }); /** * Column Array Directive * @private */ export class ColumnsDirective extends ArrayBase { constructor() { super('columns'); } } ColumnsDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: ColumnsDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); ColumnsDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.0.3", type: ColumnsDirective, selector: "ejs-treegrid>e-columns", queries: [{ propertyName: "children", predicate: ColumnDirective }], usesInheritance: true, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: ColumnsDirective, decorators: [{ type: Directive, args: [{ selector: 'ejs-treegrid>e-columns', queries: { children: new ContentChildren(ColumnDirective) }, }] }], ctorParameters: function () { return []; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"columns.directive.js","sourceRoot":"","sources":["../../../../src/treegrid/columns.directive.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAoB,eAAe,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC3F,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,8BAA8B,CAAC;AAChF,OAAO,EAAE,QAAQ,EAAE,MAAM,8BAA8B,CAAC;AACxD,OAAO,EAAE,uBAAuB,EAAE,MAAM,4BAA4B,CAAC;;AAErE,IAAI,KAAK,GAAa,CAAC,cAAc,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,eAAe,EAAE,cAAc,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,kBAAkB,EAAE,cAAc,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,MAAM,EAAE,cAAc,EAAE,UAAU,EAAE,OAAO,EAAE,QAAQ,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,QAAQ,EAAE,WAAW,EAAE,QAAQ,EAAE,gBAAgB,EAAE,YAAY,EAAE,iBAAiB,EAAE,aAAa,EAAE,UAAU,EAAE,YAAY,EAAE,cAAc,EAAE,YAAY,EAAE,UAAU,EAAE,UAAU,EAAE,cAAc,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,cAAc,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,EAAE,KAAK,EAAE,iBAAiB,EAAE,eAAe,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;AACxpB,IAAI,OAAO,GAAa,EAAE,CAAC;AAC3B;;;;;;;;;;;GAWG;AASH,MAAM,OAAO,eAAgB,SAAQ,WAA4B;IAyT7D,YAAoB,gBAAiC;QACjD,KAAK,EAAE,CAAC;QADQ,qBAAgB,GAAhB,gBAAgB,CAAiB;QArT9C,SAAI,GAAa,CAAC,SAAS,CAAC,CAAC;QAuThC,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;;4GA9TQ,eAAe;gGAAf,eAAe,s3DAHW,uBAAuB;AA8R1D;IADC,QAAQ,EAAE;iDACU;AAQrB;IADC,QAAQ,EAAE;uDACgB;AAG3B;IADC,QAAQ,EAAE;4DACqB;AAOhC;IADC,QAAQ,EAAE;uDACgB;AAG3B;IADC,QAAQ,EAAE;yDACkB;AAO7B;IADC,QAAQ,EAAE;qDACc;2FAvThB,eAAe;kBAR3B,SAAS;mBAAC;oBACP,QAAQ,EAAE,iCAAiC;oBAC3C,MAAM,EAAE,KAAK;oBACb,OAAO,EAAE,OAAO;oBAChB,OAAO,EAAE;wBACL,YAAY,EAAE,IAAI,YAAY,CAAC,uBAAuB,CAAC;qBAC1D;iBACJ;uGA4RU,QAAQ;sBAFd,YAAY;uBAAC,UAAU;gBAUjB,cAAc;sBAFpB,YAAY;uBAAC,gBAAgB;gBAKvB,mBAAmB;sBAFzB,YAAY;uBAAC,oBAAoB;gBAS3B,cAAc;sBAFpB,YAAY;uBAAC,gBAAgB;gBAKvB,gBAAgB;sBAFtB,YAAY;uBAAC,kBAAkB;gBASzB,YAAY;sBAFlB,YAAY;uBAAC,cAAc;;AAYhC;;;GAGG;AAOH,MAAM,OAAO,gBAAiB,SAAQ,SAA2B;IAC7D;QACI,KAAK,CAAC,SAAS,CAAC,CAAC;IACrB,CAAC;;6GAHQ,gBAAgB;iGAAhB,gBAAgB,uFAHS,eAAe;2FAGxC,gBAAgB;kBAN5B,SAAS;mBAAC;oBACP,QAAQ,EAAE,wBAAwB;oBAClC,OAAO,EAAE;wBACL,QAAQ,EAAE,IAAI,eAAe,CAAC,eAAe,CAAC;qBACjD;iBACJ","sourcesContent":["import { Directive, ViewContainerRef, ContentChildren, ContentChild } from '@angular/core';\nimport { ComplexBase, ArrayBase, setValue } from '@syncfusion/ej2-angular-base';\nimport { Template } from '@syncfusion/ej2-angular-base';\nimport { StackedColumnsDirective } from './stacked-column.directive';\n\nlet input: string[] = ['allowEditing', 'allowFiltering', 'allowReordering', 'allowResizing', 'allowSorting', 'clipMode', 'columns', 'commands', 'customAttributes', 'defaultValue', 'disableHtmlEncode', 'displayAsCheckBox', 'edit', 'editTemplate', 'editType', 'field', 'filter', 'filterBarTemplate', 'filterTemplate', 'format', 'formatter', 'freeze', 'headerTemplate', 'headerText', 'headerTextAlign', 'hideAtMedia', 'isFrozen', 'isIdentity', 'isPrimaryKey', 'lockColumn', 'maxWidth', 'minWidth', 'showCheckbox', 'showColumnMenu', 'showInColumnChooser', 'sortComparer', 'template', 'textAlign', 'type', 'uid', 'validationRules', 'valueAccessor', 'visible', 'width'];\nlet outputs: string[] = [];\n/**\n * `e-column` directive represent a column of the Angular TreeGrid. \n * It must be contained in a TreeGrid component(`ejs-treegrid`). \n * ```html\n * <ejs-treegrid [dataSource]='data' allowPaging='true' allowSorting='true'> \n *   <e-columns>\n *    <e-column field='ID' width='100'></e-column>\n *    <e-column field='name' headerText='Name' width='100'></e-column>\n *   </e-columns>\n * </ejs-treegrid>\n * ```\n */\n@Directive({\n    selector: 'ejs-treegrid>e-columns>e-column',\n    inputs: input,\n    outputs: outputs,    \n    queries: {\n        childColumns: new ContentChild(StackedColumnsDirective)\n    }\n})\nexport class ColumnDirective extends ComplexBase<ColumnDirective> {\n    public directivePropList: any;\n\t\n    public childColumns: any;\n    public tags: string[] = ['columns'];\n    /** \n     * Defines the type of data stored in the column, which may be string, number, date, or other types.\n     * @default null\n     */\n    public type: any;\n    /** \n     * Controls whether editing is permitted for the column. By default, all columns are editable.\n     * @default true\n     */\n    public allowEditing: any;\n    /** \n     * Controls whether the column supports filtering. If set to false, users cannot filter data by this column.\n     * @default true\n     */\n    public allowFiltering: any;\n    /** \n     * Enables or disables the reordering of this column via drag-and-drop. Allows for dynamic column adjustments.\n     * @default true\n     */\n    public allowReordering: any;\n    /** \n     * Determines if this column can be resized. If false, the column size is fixed.\n     * @default true\n     */\n    public allowResizing: any;\n    /** \n     * Specifies whether sorting is enabled for this column. Set to false to prevent sort actions.\n     * @default true\n     */\n    public allowSorting: any;\n    /** \n     * Determines how overflow content is handled within a cell. Options include: \n     * * `Clip`: Truncates the content. \n     * * `Ellipsis`: Shows ellipsis for overflow. \n     * * `EllipsisWithTooltip`: Shows ellipsis and tooltip on hover.\n     * @default Syncfusion.EJ2.Grids.ClipMode.Ellipsis\n     * @isenumeration true\n     * @asptype Syncfusion.EJ2.Grids.ClipMode\n     */\n    public clipMode: any;\n    /** \n     * Allows for the creation of stacked headers by using multiple rows in the grid's header.\n     * @default null\n     */\n    public columns: any;\n    /** \n     * Provides built-in command button options for cells. Options include Edit, Delete, Save, and Cancel. \n     * Custom command button implementations are possible.\n     * \n     * The following code example implements the custom command column.\n     *```html\n     *<style type=\"text/css\" class=\"cssStyles\">\n     *.details-icon:before\n     *{\n     *   content:\"\\e74d\";\n     *}\n     *</style>\n     *<div id=\"TreeGrid\"></div>\n     *```\n     *```typescript\n     *var gridObj = new TreeGrid({\n     *datasource: window.gridData,\n     *columns : [\n     * { field: 'CustomerID', headerText: 'Customer ID' },\n     * { field: 'CustomerName', headerText: 'Customer Name' },\n     * {commands: [{buttonOption:{content: 'Details', click: onClick, cssClass: details-icon}}], headerText: 'Customer Details'}\n     *]\n     *gridObj.appendTo(\"#TreeGrid\");\n     *```\n     *     \n     * @default null\n     */\n    public commands: any;\n    /** \n     * Enables the addition of CSS styles and attributes for the content cells in a particular column.\n     * @default null\n     */\n    public customAttributes: any;\n    /** \n     * Sets default values when new records are added to the TreeGrid involving this column.\n     * @default null\n     */\n    public defaultValue: any;\n    /** \n     * If set to `true`, the HTML content within header and content cells is encoded to prevent injection attacks.\n     * @default true\n     */\n    public disableHtmlEncode: any;\n    /** \n     * Displays the column value as a checkbox instead of a Boolean value when set to `true`.\n     * @default false\n     */\n    public displayAsCheckBox: any;\n    /** \n     * Allows customizing the default edit cell through the `IEditCell` object for more control over editing.\n     * @default {}\n     */\n    public edit: any;\n    /** \n     * Specifies the component type used for editing cells within this column.\n     * @default 'stringedit'\n     */\n    public editType: any;\n    /** \n     * Specifies the field name in the data source to which the column is bound. This field is used for operations like sorting and filtering. \n     * The field name must be a valid JavaScript identifier, beginning with a letter and avoiding spaces and special characters.\n     * @default 'undefined'\n     */\n    public field: any;\n    /** \n     * Customizes filter options for the column, enabling specialized filtering functionality.\n     * @default null\n     */\n    public filter: any;\n    /** \n     * Allows for a custom component within the filter bar, facilitating advanced filter interfaces. \n     * Includes create and read functions for custom component management.\n     * \n     * ```html\n     *<div id=\"TreeGrid\"></div>\n     *```\n     *```typescript\n     *let gridObj: TreeGrid = new TreeGrid({\n     *dataSource: filterData,\n     *columns: [\n     *  { field: 'OrderID', headerText: 'Order ID' },\n     *  {\n     *     field: 'EmployeeID', filterBarTemplate: {\n     *        create: (args: { element: Element, column: Column }) => {\n     *             let input: HTMLInputElement = document.createElement('input');\n     *             input.id = 'EmployeeID';\n     *             input.type = 'text';\n     *             return input;\n     *        },\n     *        write: (args: { element: Element, column: Column }) => {\n     *            args.element.addEventListener('input', args.column.filterBarTemplate.read as EventListener);\n     *        },\n     *        read: (args: { element: HTMLInputElement, columnIndex: number, column: Column }) => {\n     *            gridObj.filterByColumn(args.element.id, 'equal', args.element.value);\n     *       }\n     *    }\n     *}],\n     *  allowFiltering: true\n     *});\n     *gridObj.appendTo('#TreeGrid');\n     *```\n     *     \n     * @default null\n     */\n    public filterBarTemplate: any;\n    /** \n     * Formats the displayed value of the column without affecting the underlying data. Supports standard and custom formats for numbers and dates.\n     * \n     * References for [number](https://ej2.syncfusion.com/documentation/common/internationalization/#supported-format-string)\n     *and [date](https://ej2.syncfusion.com/documentation/common/internationalization#date-formatting) formats.     \n     * @default null\n     * @asptype string\n     */\n    public format: any;\n    /** \n     * Allows for custom cell content formatting using an external method, executed prior to rendering.\n     * @default null\n     */\n    public formatter: any;\n    /** \n     * Determines which side (left, right, or center) the column should be frozen on.\n     * @default Syncfusion.EJ2.Grids.FreezeDirection.None\n     * @isenumeration true\n     * @asptype Syncfusion.EJ2.Grids.FreezeDirection\n     */\n    public freeze: any;\n    /** \n     * Specifies the text displayed in the column header. If omitted, the `field` value is used as the header text.\n     * @default 'undefined'\n     */\n    public headerText: any;\n    /** \n     * Aligns the text in the column header. By default, the alignment corresponds to other content alignments.\n     * @default null\n     * @aspdefaultvalueignore \n     * @isenumeration true\n     * @asptype Syncfusion.EJ2.Grids.TextAlign\n     */\n    public headerTextAlign: any;\n    /** \n     * Adjusts column visibility based on [Media Queries](http://cssmediaqueries.com/what-are-css-media-queries.html). Accepts valid CSS media query strings for responsive adjustments.\n     * @default 'undefined'\n     */\n    public hideAtMedia: any;\n    /** \n     * Allows the column to be frozen, keeping it stationary while scrolling horizontally through the grid.\n     * @default false\n     */\n    public isFrozen: any;\n    /** \n     * Identifies the column as an identity column in database terms, if set to `true`.\n     * @default false\n     */\n    public isIdentity: any;\n    /** \n     * Identifies the column as a primary key if set to `true`, enforcing uniqueness.\n     * @default false\n     */\n    public isPrimaryKey: any;\n    /** \n     * Prevents column reordering when set to true, locking the column into a set position.\n     * @default false\n     */\n    public lockColumn: any;\n    /** \n     * Defines the maximum allowable width of the column in pixels or as a percentage, preventing resizing beyond this limit.\n     * @default 'undefined'\n     */\n    public maxWidth: any;\n    /** \n     * Determines the minimum width of the column in pixels or percentage. This ensures the column does not shrink below this size.\n     * @default 'undefined'\n     */\n    public minWidth: any;\n    /** \n     * Displays checkboxes in the column when enabled, allowing for selections and certain operations.\n     * @default false\n     */\n    public showCheckbox: any;\n    /** \n     * Decides if the column menu should be available, providing options for column customization.\n     * @default true\n     */\n    public showColumnMenu: any;\n    /** \n     * Determines whether the column should appear in the Column Chooser. Set to false to exclude it.\n     * @default true\n     */\n    public showInColumnChooser: any;\n    /** \n     * Provides a custom sort comparer property to control how sorting is handled for this column's data.\n     * @default 'undefined'\n     */\n    public sortComparer: any;\n    /** \n     * Specifies the horizontal alignment for the column content and header. Options include alignment to the left, center, or right.\n     * @default Syncfusion.EJ2.Grids.TextAlign.Left\n     * @isenumeration true\n     * @asptype Syncfusion.EJ2.Grids.TextAlign\n     */\n    public textAlign: any;\n    /** \n     * Retrieves the unique identifier for the column. This UID is used internally to reference and manipulate the column.\n     * @default 'undefined'\n     */\n    public uid: any;\n    /** \n     * Establishes validation rules to ensure data integrity during creation and updates.\n     * @default null\n     */\n    public validationRules: any;\n    /** \n     * Applies custom cell values using an external function, allowing for dynamic display adjustments.\n     * @default null\n     */\n    public valueAccessor: any;\n    /** \n     * Toggles the visibility of the column. Set to false to hide the column from view. Columns are visible by default.\n     * @default true\n     */\n    public visible: any;\n    /** \n     * Sets the column's width in pixels or as a percentage. This defines how the column will occupy space in the grid.\n     * @default 'undefined'\n     */\n    public width: any;\n    /** \n     * Customizes the rendering of cell content using either a template string or HTML element ID.\n     * @default null\n     * @asptype string\n     */\n    @ContentChild('template')\n    @Template()\n    public template: any;\n    /** \n     * Customizes the header content with a template, defined as a string or an HTML element ID.\n     * @default null\n     * @asptype string\n     */\n    @ContentChild('headerTemplate')\n    @Template()\n    public headerTemplate: any;\n    @ContentChild('filterItemTemplate')\n    @Template()\n    public filter_itemTemplate: any;\n    /** \n     * Specifies a custom template or UI for filtering within this column, utilizing either string templates or HTML element IDs.\n     * @aspignore \n     */\n    @ContentChild('filterTemplate')\n    @Template()\n    public filterTemplate: any;\n    @ContentChild('commandsTemplate')\n    @Template()\n    public commandsTemplate: any;\n    /** \n     * Provides a template for editing cells in this column, supporting either a template string or an HTML element ID.\n     * @aspignore \n     */\n    @ContentChild('editTemplate')\n    @Template()\n    public editTemplate: 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 * Column Array Directive\n * @private\n */\n@Directive({\n    selector: 'ejs-treegrid>e-columns',\n    queries: {\n        children: new ContentChildren(ColumnDirective)\n    },\n})\nexport class ColumnsDirective extends ArrayBase<ColumnsDirective> {\n    constructor() {\n        super('columns');\n    }\n}"]}