@syncfusion/ej2-angular-grids
Version:
Feature-rich JavaScript datagrid (datatable) control with built-in support for editing, filtering, grouping, paging, sorting, and exporting to Excel. for Angular
100 lines • 35.9 kB
JavaScript
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', 'allowGrouping', 'allowReordering', 'allowResizing', 'allowSearching', 'allowSorting', 'autoFit', 'clipMode', 'columns', 'commands', 'customAttributes', 'dataSource', 'defaultValue', 'disableHtmlEncode', 'displayAsCheckBox', 'edit', 'editTemplate', 'editType', 'enableColumnSpan', 'enableGroupByFormat', 'enableRowSpan', 'field', 'filter', 'filterBarTemplate', 'filterTemplate', 'foreignKeyField', 'foreignKeyValue', 'format', 'formatter', 'freeze', 'headerTemplate', 'headerText', 'headerTextAlign', 'headerValueAccessor', 'hideAtMedia', 'index', 'isFrozen', 'isIdentity', 'isPrimaryKey', 'lockColumn', 'maxWidth', 'minWidth', 'showColumnMenu', 'showInColumnChooser', 'sortComparer', 'template', 'templateOptions', 'textAlign', 'type', 'uid', 'validationRules', 'valueAccessor', 'visible', 'width'];
let outputs = [];
/**
* `e-column` directive represent a column of the Angular Grid.
* It must be contained in a Grid component(`ejs-grid`).
* ```html
* <ejs-grid [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-grid>
* ```
*/
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-grid>e-columns>e-column", inputs: { allowEditing: "allowEditing", allowFiltering: "allowFiltering", allowGrouping: "allowGrouping", allowReordering: "allowReordering", allowResizing: "allowResizing", allowSearching: "allowSearching", allowSorting: "allowSorting", autoFit: "autoFit", clipMode: "clipMode", columns: "columns", commands: "commands", customAttributes: "customAttributes", dataSource: "dataSource", defaultValue: "defaultValue", disableHtmlEncode: "disableHtmlEncode", displayAsCheckBox: "displayAsCheckBox", edit: "edit", editTemplate: "editTemplate", editType: "editType", enableColumnSpan: "enableColumnSpan", enableGroupByFormat: "enableGroupByFormat", enableRowSpan: "enableRowSpan", field: "field", filter: "filter", filterBarTemplate: "filterBarTemplate", filterTemplate: "filterTemplate", foreignKeyField: "foreignKeyField", foreignKeyValue: "foreignKeyValue", format: "format", formatter: "formatter", freeze: "freeze", headerTemplate: "headerTemplate", headerText: "headerText", headerTextAlign: "headerTextAlign", headerValueAccessor: "headerValueAccessor", hideAtMedia: "hideAtMedia", index: "index", isFrozen: "isFrozen", isIdentity: "isIdentity", isPrimaryKey: "isPrimaryKey", lockColumn: "lockColumn", maxWidth: "maxWidth", minWidth: "minWidth", showColumnMenu: "showColumnMenu", showInColumnChooser: "showInColumnChooser", sortComparer: "sortComparer", template: "template", templateOptions: "templateOptions", 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: "commandsTemplate", first: true, predicate: ["commandsTemplate"], descendants: true }, { propertyName: "filter_itemTemplate", first: true, predicate: ["filterItemTemplate"], descendants: true }, { propertyName: "editTemplate", first: true, predicate: ["editTemplate"], descendants: true }, { propertyName: "filterTemplate", first: true, predicate: ["filterTemplate"], 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, "commandsTemplate", void 0);
__decorate([
Template()
], ColumnDirective.prototype, "filter_itemTemplate", void 0);
__decorate([
Template()
], ColumnDirective.prototype, "editTemplate", void 0);
__decorate([
Template()
], ColumnDirective.prototype, "filterTemplate", void 0);
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: ColumnDirective, decorators: [{
type: Directive,
args: [{
selector: 'ejs-grid>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']
}], commandsTemplate: [{
type: ContentChild,
args: ['commandsTemplate']
}], filter_itemTemplate: [{
type: ContentChild,
args: ['filterItemTemplate']
}], editTemplate: [{
type: ContentChild,
args: ['editTemplate']
}], filterTemplate: [{
type: ContentChild,
args: ['filterTemplate']
}] } });
/**
* 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-grid>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-grid>e-columns',
queries: {
children: new ContentChildren(ColumnDirective)
},
}]
}], ctorParameters: function () { return []; } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"columns.directive.js","sourceRoot":"","sources":["../../../../src/grid/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,eAAe,EAAE,iBAAiB,EAAE,eAAe,EAAE,gBAAgB,EAAE,cAAc,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,kBAAkB,EAAE,YAAY,EAAE,cAAc,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,MAAM,EAAE,cAAc,EAAE,UAAU,EAAE,kBAAkB,EAAE,qBAAqB,EAAE,eAAe,EAAE,OAAO,EAAE,QAAQ,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,QAAQ,EAAE,WAAW,EAAE,QAAQ,EAAE,gBAAgB,EAAE,YAAY,EAAE,iBAAiB,EAAE,qBAAqB,EAAE,aAAa,EAAE,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,cAAc,EAAE,YAAY,EAAE,UAAU,EAAE,UAAU,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,cAAc,EAAE,UAAU,EAAE,iBAAiB,EAAE,WAAW,EAAE,MAAM,EAAE,KAAK,EAAE,iBAAiB,EAAE,eAAe,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;AACz1B,IAAI,OAAO,GAAa,EAAE,CAAC;AAC3B;;;;;;;;;;;GAWG;AASH,MAAM,OAAO,eAAgB,SAAQ,WAA4B;IAqd7D,YAAoB,gBAAiC;QACjD,KAAK,EAAE,CAAC;QADQ,qBAAgB,GAAhB,gBAAgB,CAAiB;QAjd9C,SAAI,GAAa,CAAC,SAAS,CAAC,CAAC;QAmdhC,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;;4GA1dQ,eAAe;gGAAf,eAAe,8tEAHW,uBAAuB;AAsb1D;IADC,QAAQ,EAAE;iDACU;AAQrB;IADC,QAAQ,EAAE;uDACgB;AAG3B;IADC,QAAQ,EAAE;yDACkB;AAG7B;IADC,QAAQ,EAAE;4DACqB;AAShC;IADC,QAAQ,EAAE;qDACc;AASzB;IADC,QAAQ,EAAE;uDACgB;2FAndlB,eAAe;kBAR3B,SAAS;mBAAC;oBACP,QAAQ,EAAE,6BAA6B;oBACvC,MAAM,EAAE,KAAK;oBACb,OAAO,EAAE,OAAO;oBAChB,OAAO,EAAE;wBACL,YAAY,EAAE,IAAI,YAAY,CAAC,uBAAuB,CAAC;qBAC1D;iBACJ;uGAobU,QAAQ;sBAFd,YAAY;uBAAC,UAAU;gBAUjB,cAAc;sBAFpB,YAAY;uBAAC,gBAAgB;gBAKvB,gBAAgB;sBAFtB,YAAY;uBAAC,kBAAkB;gBAKzB,mBAAmB;sBAFzB,YAAY;uBAAC,oBAAoB;gBAW3B,YAAY;sBAFlB,YAAY;uBAAC,cAAc;gBAWrB,cAAc;sBAFpB,YAAY;uBAAC,gBAAgB;;AAYlC;;;GAGG;AAOH,MAAM,OAAO,gBAAiB,SAAQ,SAA2B;IAC7D;QACI,KAAK,CAAC,SAAS,CAAC,CAAC;IACrB,CAAC;;6GAHQ,gBAAgB;iGAAhB,gBAAgB,mFAHS,eAAe;2FAGxC,gBAAgB;kBAN5B,SAAS;mBAAC;oBACP,QAAQ,EAAE,oBAAoB;oBAC9B,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', 'allowGrouping', 'allowReordering', 'allowResizing', 'allowSearching', 'allowSorting', 'autoFit', 'clipMode', 'columns', 'commands', 'customAttributes', 'dataSource', 'defaultValue', 'disableHtmlEncode', 'displayAsCheckBox', 'edit', 'editTemplate', 'editType', 'enableColumnSpan', 'enableGroupByFormat', 'enableRowSpan', 'field', 'filter', 'filterBarTemplate', 'filterTemplate', 'foreignKeyField', 'foreignKeyValue', 'format', 'formatter', 'freeze', 'headerTemplate', 'headerText', 'headerTextAlign', 'headerValueAccessor', 'hideAtMedia', 'index', 'isFrozen', 'isIdentity', 'isPrimaryKey', 'lockColumn', 'maxWidth', 'minWidth', 'showColumnMenu', 'showInColumnChooser', 'sortComparer', 'template', 'templateOptions', 'textAlign', 'type', 'uid', 'validationRules', 'valueAccessor', 'visible', 'width'];\nlet outputs: string[] = [];\n/**\n * `e-column` directive represent a column of the Angular Grid. \n * It must be contained in a Grid component(`ejs-grid`). \n * ```html\n * <ejs-grid [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-grid>\n * ```\n */\n@Directive({\n    selector: 'ejs-grid>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 data type of the column.\n     * @default null\n     */\n    public type: any;\n    /** \n     * If `allowEditing` set to false, then it disables editing of a particular column. \n     * By default all columns are editable.\n     * @default true\n     */\n    public allowEditing: any;\n    /** \n     * If `allowFiltering` set to false, then it disables filtering option and filter bar element of a particular column. \n     * By default all columns are filterable.\n     * @default true\n     */\n    public allowFiltering: any;\n    /** \n     * If `allowGrouping` set to false, then it disables grouping of a particular column. \n     * By default all columns are groupable.\n     * @default true\n     */\n    public allowGrouping: any;\n    /** \n     * If `allowReordering` set to false, then it disables reorder of a particular column. \n     * By default all columns can be reorder.\n     * @default true\n     */\n    public allowReordering: any;\n    /** \n     * If `allowResizing` set to false, it disables resize option of a particular column.\n     * @default true\n     */\n    public allowResizing: any;\n    /** \n     * If `allowSearching` set to false, then it disables Searching of a particular column. \n     * By default all columns allow Searching.\n     * @default true\n     */\n    public allowSearching: any;\n    /** \n     * If `allowSorting` set to false, then it disables sorting option of a particular column. \n     * By default all columns are sortable.\n     * @default true\n     */\n    public allowSorting: any;\n    /** \n     * If `autoFit` set to true, then the particular column content width will be \n     * adjusted based on its content in the initial rendering itself. \n     * Setting this property as true is equivalent to calling `autoFitColumns` method in the `dataBound` event.\n     * @default false\n     */\n    public autoFit: any;\n    /** \n     * Defines the cell content's overflow mode. The available modes are \n     * * `Clip` -  Truncates the cell content when it overflows its area. \n     * * `Ellipsis` -  Displays ellipsis when the cell content overflows its area. \n     * * `EllipsisWithTooltip` - Displays ellipsis when the cell content overflows its area \n     * also it will display tooltip while hover on ellipsis applied cell.\n     * @default Ellipsis\n     */\n    public clipMode: any;\n    /** \n     * Used to render multiple header rows(stacked headers) on the Grid header.\n     * @default null\n     */\n    public columns: any;\n    /** \n     * `commands` provides an option to display command buttons in every cell. \n     * The available built-in command buttons are \n     * * Edit - Edit the record. \n     * * Delete - Delete the record. \n     * * Save - Save the record. \n     * * Cancel - Cancel the edit state.\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=\"Grid\"></div>\n     *```\n     *```typescript\n     *var gridObj = new Grid({\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(\"#Grid\");\n     *```\n     *     \n     * @default null\n     */\n    public commands: any;\n    /** \n     * The CSS styles and attributes of the content cells of a particular column can be customized.\n     * \n     * ```html\n     *<div id=\"Grid\"></div>\n     *```\n     *```typescript\n     *let gridObj: Grid = new Grid({\n     *dataSource: filterData,\n     *columns: [\n     *   { field: 'OrderID', headerText: 'Order ID' },\n     *   {\n     *       field: 'EmployeeID', headerText: 'Employee ID', customAttributes: {\n     *          class: 'employeeid',\n     *          type: 'employee-id-cell'\n     *     }\n     *  }]\n     *});\n     *gridObj.appendTo('#Grid');\n     *```\n     *     \n     * @default null\n     */\n    public customAttributes: any;\n    /** \n     * Defines the column data source  which will act as foreign data source.\n     * @default null\n     */\n    public dataSource: any;\n    /** \n     * Defines default values for the component when adding a new record to the Grid.\n     * @default null\n     * @asptype object\n     */\n    public defaultValue: any;\n    /** \n     * If `disableHtmlEncode` is set to true, it encodes the HTML of the header and content cells.\n     * @default true\n     */\n    public disableHtmlEncode: any;\n    /** \n     * If `displayAsCheckBox` is set to true, it displays the column value as a check box instead of Boolean value.\n     * @default false\n     */\n    public displayAsCheckBox: any;\n    /** \n     * Defines the `IEditCell`(../../grid/edit/#cell-edit-template) object to customize default edit cell.\n     * @default {}\n     */\n    public edit: any;\n    /** \n     * Defines the type of component for editing.\n     * @default 'stringedit'\n     */\n    public editType: any;\n    /** \n     * Allows grid to perform column spanning on the specified column.\n     * @default true\n     */\n    public enableColumnSpan: any;\n    /** \n     * If `enableGroupByFormat` set to true, then it groups the particular column by formatted values. \n     * By default no columns are group by format.\n     * @default true\n     */\n    public enableGroupByFormat: any;\n    /** \n     * Allows grid to perform row spanning on the specified column.\n     * @default true\n     */\n    public enableRowSpan: any;\n    /** \n     * Defines the field name of column which is mapped with mapping name of DataSource. \n     * The bounded columns can be sort, filter and group etc., \n     * If the `field` name contains “dot”, then it is considered as complex binding. \n     * The `field` name must be a valid JavaScript identifier, \n     * the first character must be an alphabet and should not contain spaces and special characters.\n     * @default ''\n     */\n    public field: any;\n    /** \n     *  Defines the filter options to customize filtering for the particular column.\n     * @default {}\n     */\n    public filter: any;\n    /** \n     * The `filterBarTemplate` is used to add a custom component instead of default input component for filter bar. \n     * It have create and read functions. \n     * * create: It is used for creating custom components. \n     * * read: It is used to perform custom filter action.\n     * \n     * ```html\n     *<div id=\"Grid\"></div>\n     *```\n     *```typescript\n     *let gridObj: Grid = new Grid({\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('#Grid');\n     *```\n     *     \n     * @default null\n     */\n    public filterBarTemplate: any;\n    /** \n     * Defines the mapping column name of the foreign data source. \n     * If it is not defined then the `columns.field` will be considered as mapping column name\n     * @default null\n     */\n    public foreignKeyField: any;\n    /** \n     * Defines the display column name from the foreign data source which will be obtained from comparing local and foreign data\n     * @default null\n     */\n    public foreignKeyValue: any;\n    /** \n     * It is used to change display value with the given format and does not affect the original data. \n     * Gets the format from the user which can be standard or custom \n     * [`number`](../../common/internationalization/#manipulating-numbers) \n     * and [`date`](../../common/internationalization/#manipulating-datetime) formats.\n     * @default null\n     * @asptype string\n     */\n    public format: any;\n    /** \n     * Defines the method which is used to achieve custom formatting from an external function. \n     * This function triggers before rendering of each cell.\n     * \n     * ```html\n     *<div id=\"Grid\"></div>\n     *```\n     *```typescript\n     *class ExtendedFormatter implements ICellFormatter {\n     *public getValue(column: Column, data: Object): Object {\n     *  return '<span style=\"color:' + (data['Verified'] ? 'green' : 'red') + '\"><i>' + data['Verified'] + '</i><span>';\n     *}\n     *}\n     *let gridObj: Grid = new Grid({\n     *    dataSource: filterData,\n     *    columns: [\n     *        { field: 'ShipName', headerText: 'Ship Name' },\n     *        { field: 'Verified', headerText: 'Verified Status', formatter: ExtendedFormatter }]\n     *});\n     *gridObj.appendTo('#Grid');\n     *```\n     *     \n     * @default null\n     */\n    public formatter: any;\n    /** \n     * defines which side the column need to freeze \n     * The available built-in freeze directions are \n     * * Left - Freeze the column at left side. \n     * * Right - Freeze the column at right side. \n     * * Fixed - Freeze the column at Center. \n     * * None - Does not freeze the column.\n     * @default None\n     */\n    public freeze: any;\n    /** \n     * Defines the header text of column which is used to display in column header. \n     * If `headerText` is not defined, then field name value will be assigned to header text.\n     * @default null\n     */\n    public headerText: any;\n    /** \n     * Define the alignment of column header which is used to align the text of column header.\n     * @aspdefaultvalueignore \n     * @default null\n     */\n    public headerTextAlign: any;\n    /** \n     * Defines the method used to apply custom header cell values from external function and display this on each cell rendered.\n     * \n     * ```html\n     *<div id=\"Grid\"></div>\n     *```\n     *```typescript\n     *let gridObj: Grid = new Grid({\n     *dataSource: [{ EmployeeID: 1, EmployeeName: ['John', 'M'] }, { EmployeeID: 2, EmployeeName: ['Peter', 'A'] }],\n     *columns: [\n     *    { field: 'EmployeeID', headerText: 'Employee ID' },\n     *    { field: 'EmployeeName', headerText: 'Employee First Name',\n     *      headerValueAccessor: (field: string,column: Column) => {\n     *            return \"newheadername\";\n     *        },\n     *    }]\n     *});\n     *```\n     *     \n     * @default null\n     */\n    public headerValueAccessor: any;\n    /** \n     * column visibility can change based on its [`Media Queries`](http://cssmediaqueries.com/what-are-css-media-queries.html). \n     * `hideAtMedia` accepts only valid Media Queries.\n     * @default ''\n     */\n    public hideAtMedia: any;\n    /** \n     * Gets the unique identifier value of the column. It is used to get the object.\n     * @default null\n     */\n    public index: any;\n    /** \n     * You can use this property to freeze selected columns in grid.\n     * @default false\n     */\n    public isFrozen: any;\n    /** \n     * If `isIdentity` is set to true, then this column is considered as identity column.\n     * @default false\n     */\n    public isIdentity: any;\n    /** \n     * If `isPrimaryKey` is set to true, considers this column as the primary key constraint.\n     * @default false\n     */\n    public isPrimaryKey: any;\n    /** \n     * Defines the mapping column name of the foreign data source. \n     * If it is not defined then the `columns.field` will be considered as mapping column name\n     * @default false\n     */\n    public lockColumn: any;\n    /** \n     * Defines the maximum width of the column in pixel or percentage, which will restrict resizing beyond this pixel or percentage.\n     * @default ''\n     */\n    public maxWidth: any;\n    /** \n     * Defines the minimum width of the column in pixels or percentage.\n     * @default ''\n     */\n    public minWidth: any;\n    /** \n     * If `showColumnMenu` set to false, then it disable the column menu of a particular column. \n     * By default column menu will show for all columns\n     * @default true\n     */\n    public showColumnMenu: any;\n    /** \n     * If `showInColumnChooser` set to false, then hides the particular column in column chooser. \n     * By default all columns are displayed in column Chooser.\n     * @default true\n     */\n    public showInColumnChooser: any;\n    /** \n     * It defines the custom sort comparer function.\n     */\n    public sortComparer: any;\n    /** \n     * Determines the behavior of the `aria-label` attribute for cells in template columns. \n     * If enableAriaLabel is set to false, the aria-label attribute is not applied to template column cells, which affects screen reader accessibility.\n     * @default {}\n     */\n    public templateOptions: any;\n    /** \n     * Defines the alignment of the column in both header and content cells.\n     * @default Left\n     */\n    public textAlign: any;\n    /** \n     * Gets the unique identifier value of the column. It is used to get the object.\n     * @default ''\n     */\n    public uid: any;\n    /** \n     * `editType`(../../grid/edit/#cell-edit-type-and-its-params) Defines rules to validate data before creating and updating.\n     * @default null\n     */\n    public validationRules: any;\n    /** \n     * Defines the method used to apply custom cell values from external function and display this on each cell rendered.\n     * \n     * ```html\n     *<div id=\"Grid\"></div>\n     *```\n     *```typescript\n     *let gridObj: Grid = new Grid({\n     *dataSource: [{ EmployeeID: 1, EmployeeName: ['John', 'M'] }, { EmployeeID: 2, EmployeeName: ['Peter', 'A'] }],\n     *columns: [\n     *    { field: 'EmployeeID', headerText: 'Employee ID' },\n     *    { field: 'EmployeeName', headerText: 'Employee First Name',\n     *      valueAccessor: (field: string, data: Object, column: Column) => {\n     *            return data['EmployeeName'][0];\n     *        },\n     *    }]\n     *});\n     *```\n     *     \n     * @default null\n     */\n    public valueAccessor: any;\n    /** \n     * If `visible` is set to false, hides the particular column. By default, all columns are displayed.\n     * @default true\n     */\n    public visible: any;\n    /** \n     * Defines the width of the column in pixels or percentage.\n     * @default ''\n     */\n    public width: any;\n    /** \n     * Defines the column template that renders customized element in each cell of the column. \n     * It accepts either [template string](../../common/template/) or HTML element ID.\n     * @default null\n     * @asptype string\n     */\n    @ContentChild('template')\n    @Template()\n    public template: any;\n    /** \n     * Defines the column template as string or HTML element ID which is used to add customized element in the column header.\n     * @default null\n     * @asptype string\n     */\n    @ContentChild('headerTemplate')\n    @Template()\n    public headerTemplate: any;\n    @ContentChild('commandsTemplate')\n    @Template()\n    public commandsTemplate: any;\n    @ContentChild('filterItemTemplate')\n    @Template()\n    public filter_itemTemplate: any;\n    /** \n     * Defines the cell edit template that used as editor for a particular column. \n     * It accepts either template string or HTML element ID.\n     * @default null\n     * @asptype string\n     */\n    @ContentChild('editTemplate')\n    @Template()\n    public editTemplate: any;\n    /** \n     * Defines the filter template/UI that used as filter for a particular column. \n     * It accepts either template string or HTML element ID.\n     * @default null\n     * @asptype string\n     */\n    @ContentChild('filterTemplate')\n    @Template()\n    public filterTemplate: 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-grid>e-columns',\n    queries: {\n        children: new ContentChildren(ColumnDirective)\n    },\n})\nexport class ColumnsDirective extends ArrayBase<ColumnsDirective> {\n    constructor() {\n        super('columns');\n    }\n}"]}