UNPKG

@catull/igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

324 lines 41.4 kB
import { __decorate, __metadata, __param } from "tslib"; import { ChangeDetectorRef, Component, HostBinding, Input, Optional, ViewChild, Inject, TemplateRef } from '@angular/core'; import { DisplayDensityToken, DisplayDensityBase } from '../../core/displayDensity'; import { CsvFileTypes, IgxBaseExporter, IgxCsvExporterOptions, IgxCsvExporterService, IgxExcelExporterOptions, IgxExcelExporterService, AbsoluteScrollStrategy } from '../../services/index'; import { GridBaseAPIService } from '../api.service'; import { IgxButtonDirective } from '../../directives/button/button.directive'; import { IgxDropDownComponent } from '../../drop-down/drop-down.component'; import { IgxColumnHidingComponent } from '../hiding/column-hiding.component'; import { IgxColumnPinningComponent } from '../pinning/column-pinning.component'; import { HorizontalAlignment, VerticalAlignment } from '../../services/overlay/utilities'; import { ConnectedPositioningStrategy } from '../../services/overlay/position'; /** * This class encapsulates the Toolbar's logic and is internally used by * the `IgxGridComponent`, `IgxTreeGridComponent` and `IgxHierarchicalGridComponent`. */ let IgxGridToolbarComponent = class IgxGridToolbarComponent extends DisplayDensityBase { constructor(gridAPI, cdr, excelExporter, csvExporter, _displayDensityOptions) { super(_displayDensityOptions); this.gridAPI = gridAPI; this.cdr = cdr; this.excelExporter = excelExporter; this.csvExporter = csvExporter; this._displayDensityOptions = _displayDensityOptions; this._filterColumnsPrompt = 'Filter columns list ...'; this._positionSettings = { horizontalDirection: HorizontalAlignment.Left, horizontalStartPoint: HorizontalAlignment.Right, verticalDirection: VerticalAlignment.Bottom, verticalStartPoint: VerticalAlignment.Bottom }; this._overlaySettings = { positionStrategy: new ConnectedPositioningStrategy(this._positionSettings), scrollStrategy: new AbsoluteScrollStrategy(), modal: false, closeOnOutsideClick: true, excludePositionTarget: true }; } /** * Gets the default text shown in the filtering box. * ```typescript * const filterPrompt = this.grid.toolbar.filterColumnsPrompt; * ``` */ get filterColumnsPrompt() { return this._filterColumnsPrompt; } /** * Sets the default text shown in the filtering box. * ```typescript * this.grid.toolbar.filterColumnsPrompt('Filter columns ...'); * ``` */ set filterColumnsPrompt(value) { this._filterColumnsPrompt = value; } /** * Gets the height for the `IgxGridToolbarComponent`'s drop down panels. * ```typescript * const dropdownHeight = this.grid.toolbar.defaultDropDownsMaxHeight; * ``` */ get defaultDropDownsMaxHeight() { const gridHeight = this.grid.calcHeight; return (gridHeight) ? gridHeight * 0.7 + 'px' : '100%'; } /** * Returns a reference to the `IgxGridComponent` component, hosting the `IgxGridToolbarComponent`. * ```typescript * const grid = this.igxGrid1.toolbar.grid; * ``` */ get grid() { return this.gridAPI.grid; } /** * Returns whether the `IgxGridComponent` renders an export button. * ```typescript * const exportButton = this.igxGrid1.toolbar.shouldShowExportButton; * ``` */ get shouldShowExportButton() { return (this.grid != null && (this.grid.exportExcel || this.grid.exportCsv)); } /** * Returns whether the `IgxGridComponent` renders an Excel export button. * ```typescript * const exportExcelButton = this.igxGrid1.toolbar.shouldShowExportExcelButton; * ``` */ get shouldShowExportExcelButton() { return (this.grid != null && this.grid.exportExcel); } /** * Returns whether the `IgxGridComponent` renders an CSV export button. * ```typescript * const exportCSVButton = this.igxGrid1.toolbar.shouldShowExportCsvButton; * ``` */ get shouldShowExportCsvButton() { return (this.grid != null && this.grid.exportCsv); } /** * Returns how many columns are pinned. * ```typescript * const pinnedCount = this.igxGrid1.toolbar.pinnedColumnsCount; * ``` */ get pinnedColumnsCount() { return this.grid.pinnedColumns.filter(col => !col.columnLayout).length; } /** * Returns the theme of the `IgxGridToolbarComponent`. * ```typescript * const toolbarTheme = this.grid.toolbar.hostClass; * ``` */ get hostClass() { return this.getComponentDensityClass('igx-grid-toolbar'); } /** * Returns the title of `IgxGridToolbarComponent`. * ```typescript * const toolbarTitle = this.igxGrid1.toolbar.getTitle(); * ``` */ getTitle() { return this.grid != null ? this.grid.toolbarTitle : ''; } /** * Returns the text of the export button of the `IgxGridToolbarComponent`. * ```typescript * const toolbarExportText = this.igxGrid1.toolbar.getTitle(); * ``` */ getExportText() { return this.grid != null ? this.grid.exportText : ''; } /** * Returns the text of the Excel export button of the `IgxGridToolbarComponent`. * ```typescript * const toolbarExcelText = this.igxGrid1.toolbar.getExportExcelText(); * ``` */ getExportExcelText() { return this.grid != null ? this.grid.exportExcelText : ''; } /** * Returns the text of the CSV export button of the `IgxGridToolbarComponent`. * ```typescript * const toolbarCSVText = this.igxGrid1.toolbar.getExportCsvText(); * ``` */ getExportCsvText() { return this.grid != null ? this.grid.exportCsvText : ''; } /** * Toggles the export button's dropdown menu. * ```typescript * this.igxGrid1.toolbar.exportClicked(); * ``` */ exportClicked() { this._overlaySettings.positionStrategy.settings.target = this.exportButton.nativeElement; this._overlaySettings.outlet = this.grid.outletDirective; this.exportDropdown.toggle(this._overlaySettings); } /** * Exports the grid to excel. * ```typescript * this.igxGrid1.toolbar.exportToExcelClicked(); * ``` */ exportToExcelClicked() { this.performExport(this.excelExporter, 'excel'); } /** * Exports the grid to CSV. * ```typescript * this.igxGrid1.toolbar.exportToCsvClicked(); * ``` */ exportToCsvClicked() { this.performExport(this.csvExporter, 'csv'); } performExport(exp, exportType) { this.exportClicked(); const fileName = 'ExportedData'; const options = exportType === 'excel' ? new IgxExcelExporterOptions(fileName) : new IgxCsvExporterOptions(fileName, CsvFileTypes.CSV); const args = { grid: this.grid, exporter: exp, options: options, cancel: false }; this.grid.onToolbarExporting.emit(args); if (args.cancel) { return; } exp.export(this.grid, options); } /** * Toggles the Column Hiding UI. * ```typescript * this.grid1.toolbar.toggleColumnHidingUI(); * ``` */ toggleColumnHidingUI() { this._overlaySettings.positionStrategy.settings.target = this.columnHidingButton.nativeElement; this._overlaySettings.outlet = this.grid.outletDirective; this.columnHidingDropdown.toggle(this._overlaySettings); } /** * Toggles the Column Pinning UI. * ```typescript * this.grid1.toolbar.toggleColumnPinningUI(); * ``` */ toggleColumnPinningUI() { this._overlaySettings.positionStrategy.settings.target = this.columnPinningButton.nativeElement; this._overlaySettings.outlet = this.grid.outletDirective; this.columnPinningDropdown.toggle(this._overlaySettings); } /** * @hidden @internal */ showAdvancedFilteringUI() { this.grid.openAdvancedFilteringDialog(); } /** * Returns the `context` object which represents the `template context` binding into the * `toolbar custom container` by providing references to the parent IgxGird and the toolbar itself. * ```typescript * const context = this.igxGrid.toolbar.context; * ``` */ get context() { return { // $implicit: this grid: this.grid, toolbar: this }; } /** @hidden */ get customContentTemplate() { if (this.grid != null && this.grid.toolbarCustomContentTemplate != null) { return this.grid.toolbarCustomContentTemplate.template; } else { return null; } } }; IgxGridToolbarComponent.ctorParameters = () => [ { type: GridBaseAPIService }, { type: ChangeDetectorRef }, { type: IgxExcelExporterService, decorators: [{ type: Optional }] }, { type: IgxCsvExporterService, decorators: [{ type: Optional }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DisplayDensityToken,] }] } ]; __decorate([ HostBinding('class.igx-grid-toolbar'), Input(), __metadata("design:type", String) ], IgxGridToolbarComponent.prototype, "gridID", void 0); __decorate([ Input(), __metadata("design:type", String), __metadata("design:paramtypes", [String]) ], IgxGridToolbarComponent.prototype, "filterColumnsPrompt", null); __decorate([ Input(), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxGridToolbarComponent.prototype, "defaultDropDownsMaxHeight", null); __decorate([ ViewChild('columnHidingDropdown', { read: IgxDropDownComponent }), __metadata("design:type", IgxDropDownComponent) ], IgxGridToolbarComponent.prototype, "columnHidingDropdown", void 0); __decorate([ ViewChild(IgxColumnHidingComponent), __metadata("design:type", IgxColumnHidingComponent) ], IgxGridToolbarComponent.prototype, "columnHidingUI", void 0); __decorate([ ViewChild('columnHidingButton', { read: IgxButtonDirective }), __metadata("design:type", IgxButtonDirective) ], IgxGridToolbarComponent.prototype, "columnHidingButton", void 0); __decorate([ ViewChild('exportDropdown', { read: IgxDropDownComponent }), __metadata("design:type", IgxDropDownComponent) ], IgxGridToolbarComponent.prototype, "exportDropdown", void 0); __decorate([ ViewChild('btnExport', { read: IgxButtonDirective }), __metadata("design:type", IgxButtonDirective) ], IgxGridToolbarComponent.prototype, "exportButton", void 0); __decorate([ ViewChild('columnPinningDropdown', { read: IgxDropDownComponent }), __metadata("design:type", IgxDropDownComponent) ], IgxGridToolbarComponent.prototype, "columnPinningDropdown", void 0); __decorate([ ViewChild(IgxColumnPinningComponent), __metadata("design:type", IgxColumnPinningComponent) ], IgxGridToolbarComponent.prototype, "columnPinningUI", void 0); __decorate([ ViewChild('columnPinningButton', { read: IgxButtonDirective }), __metadata("design:type", IgxButtonDirective) ], IgxGridToolbarComponent.prototype, "columnPinningButton", void 0); __decorate([ HostBinding('attr.class'), __metadata("design:type", String), __metadata("design:paramtypes", []) ], IgxGridToolbarComponent.prototype, "hostClass", null); IgxGridToolbarComponent = __decorate([ Component({ selector: 'igx-grid-toolbar', template: "<span class=\"igx-grid-toolbar__title\" *ngIf=\"getTitle()\">\n {{ getTitle() }}\n</span>\n\n<div class=\"igx-grid-toolbar__custom-content\" *ngIf=\"customContentTemplate != null\">\n <ng-container *ngTemplateOutlet=\"customContentTemplate; context: context\">\n </ng-container>\n</div>\n\n<div class=\"igx-grid-toolbar__actions\">\n <div *ngIf=\"grid.allowAdvancedFiltering\">\n <button igxButton=\"outlined\" [displayDensity]=\"grid.displayDensity\" #advancedFilteringButton name=\"btnAdvancedFiltering\" igxRipple\n (click)=\"showAdvancedFilteringUI()\"\n [ngClass]=\"grid.advancedFilteringExpressionsTree ? 'igx-grid-toolbar__adv-filter--filtered' : 'igx-grid-toolbar__adv-filter'\">\n <div class=\"igx-grid-toolbar__button-space\">\n <igx-icon>\n filter_list\n </igx-icon>\n <span>{{grid.resourceStrings.igx_grid_advanced_filter_title}}</span>\n </div>\n </button>\n </div>\n\n <div *ngIf=\"grid.columnHiding\">\n <button igxButton=\"outlined\" [displayDensity]=\"grid.displayDensity\" #columnHidingButton name=\"btnColumnHiding\" igxRipple\n (click)=\"toggleColumnHidingUI()\">\n <div class=\"igx-grid-toolbar__button-space\">\n <igx-icon *ngIf=\"grid.hiddenColumnsCount > 0\">visibility_off</igx-icon>\n <igx-icon *ngIf=\"grid.hiddenColumnsCount === 0\">visibility</igx-icon>\n <span>{{ grid.hiddenColumnsCount }}</span>\n <span>{{ grid.hiddenColumnsText }}</span>\n </div>\n </button>\n <igx-drop-down #columnHidingDropdown>\n <igx-column-hiding\n [columns]=\"grid.columns\"\n [title]=\"grid.columnHidingTitle\"\n [filterColumnsPrompt]=\"filterColumnsPrompt\"\n [columnsAreaMaxHeight]=\"defaultDropDownsMaxHeight\"\n (onColumnVisibilityChanged)=\"grid.toggleColumnVisibility($event)\">\n </igx-column-hiding>\n </igx-drop-down>\n </div>\n <div *ngIf=\"grid.columnPinning\">\n <button igxButton=\"outlined\" [displayDensity]=\"grid.displayDensity\" #columnPinningButton name=\"btnColumnPinning\" igxRipple\n (click)=\"toggleColumnPinningUI()\">\n <div class=\"igx-grid-toolbar__button-space\">\n <igx-icon *ngIf=\"pinnedColumnsCount > 0\">lock</igx-icon>\n <igx-icon *ngIf=\"pinnedColumnsCount === 0\">lock_open</igx-icon>\n <span>{{ pinnedColumnsCount }}</span>\n <span>{{ grid.pinnedColumnsText }}</span>\n <span></span>\n </div>\n </button>\n <igx-drop-down #columnPinningDropdown>\n <igx-column-pinning\n [columns]=\"grid.columns\"\n [title]=\"grid.columnPinningTitle\"\n [filterColumnsPrompt]=\"filterColumnsPrompt\"\n [columnsAreaMaxHeight]=\"defaultDropDownsMaxHeight\"></igx-column-pinning>\n </igx-drop-down>\n </div>\n\n <div class=\"igx-grid-toolbar__dropdown\" *ngIf=\"shouldShowExportButton\" id=\"btnExport\">\n <button igxButton=\"outlined\" [displayDensity]=\"grid.displayDensity\" igxRipple #btnExport\n (click)=\"exportClicked()\">\n <span class=\"igx-grid-toolbar__button-space\">\n <igx-icon fontSet=\"material\">import_export</igx-icon>\n <span>{{ getExportText() }}</span>\n <igx-icon fontSet=\"material\">arrow_drop_down</igx-icon>\n </span>\n </button>\n\n <igx-drop-down #exportDropdown>\n <ul class=\"igx-grid-toolbar__dd-list\">\n <li class=\"igx-grid-toolbar__dd-list-items\" igxRipple *ngIf=\"shouldShowExportExcelButton\" id=\"btnExportExcel\"\n (click)=\"exportToExcelClicked()\">{{ getExportExcelText() }}</li>\n <li class=\"igx-grid-toolbar__dd-list-items\" igxRipple *ngIf=\"shouldShowExportCsvButton\" id=\"btnExportCsv\"\n (click)=\"exportToCsvClicked()\">{{ getExportCsvText() }}</li>\n </ul>\n </igx-drop-down>\n </div>\n</div>\n" }), __param(2, Optional()), __param(3, Optional()), __param(4, Optional()), __param(4, Inject(DisplayDensityToken)), __metadata("design:paramtypes", [GridBaseAPIService, ChangeDetectorRef, IgxExcelExporterService, IgxCsvExporterService, Object]) ], IgxGridToolbarComponent); export { IgxGridToolbarComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-toolbar.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/toolbar/grid-toolbar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectorRef,\n    Component,\n    HostBinding,\n    Input,\n    Optional,\n    ViewChild,\n    Inject,\n    TemplateRef\n} from '@angular/core';\n\nimport { IDisplayDensityOptions, DisplayDensityToken, DisplayDensityBase } from '../../core/displayDensity';\nimport {\n    CsvFileTypes,\n    IgxBaseExporter,\n    IgxCsvExporterOptions,\n    IgxCsvExporterService,\n    IgxExcelExporterOptions,\n    IgxExcelExporterService,\n    AbsoluteScrollStrategy\n} from '../../services/index';\nimport { GridBaseAPIService } from '../api.service';\nimport { IgxButtonDirective } from '../../directives/button/button.directive';\nimport { IgxGridBaseDirective } from '../grid-base.directive';\nimport { IgxDropDownComponent } from '../../drop-down/drop-down.component';\nimport { IgxColumnHidingComponent } from '../hiding/column-hiding.component';\nimport { IgxColumnPinningComponent } from '../pinning/column-pinning.component';\nimport { OverlaySettings, PositionSettings, HorizontalAlignment, VerticalAlignment } from '../../services/overlay/utilities';\nimport { ConnectedPositioningStrategy } from '../../services/overlay/position';\nimport { GridType } from '../common/grid.interface';\n\n/**\n * This class encapsulates the Toolbar's logic and is internally used by\n * the `IgxGridComponent`, `IgxTreeGridComponent` and `IgxHierarchicalGridComponent`.\n */\n@Component({\n    selector: 'igx-grid-toolbar',\n    templateUrl: './grid-toolbar.component.html'\n})\nexport class IgxGridToolbarComponent extends DisplayDensityBase {\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-grid-toolbar')\n    @Input()\n    public gridID: string;\n\n    /**\n     * Gets the default text shown in the filtering box.\n     * ```typescript\n     * const filterPrompt = this.grid.toolbar.filterColumnsPrompt;\n     * ```\n     */\n    @Input()\n    public get filterColumnsPrompt() {\n        return this._filterColumnsPrompt;\n    }\n\n    /**\n     * Sets the default text shown in the filtering box.\n     * ```typescript\n     * this.grid.toolbar.filterColumnsPrompt('Filter columns ...');\n     * ```\n     */\n    public set filterColumnsPrompt(value: string) {\n        this._filterColumnsPrompt = value;\n    }\n\n    private _filterColumnsPrompt = 'Filter columns list ...';\n\n    /**\n     * Gets the height for the `IgxGridToolbarComponent`'s drop down panels.\n     * ```typescript\n     * const dropdownHeight = this.grid.toolbar.defaultDropDownsMaxHeight;\n     * ```\n     */\n    @Input()\n    get defaultDropDownsMaxHeight() {\n        const gridHeight = this.grid.calcHeight;\n        return (gridHeight) ? gridHeight * 0.7 + 'px' : '100%';\n    }\n\n    /**\n     * Provides a reference to the `IgxDropDownComponent` of the Column Hiding UI.\n     * ```typescript\n     * const dropdownHiding = this.grid.toolbar.columnHidingDropdown;\n     * ```\n     */\n    @ViewChild('columnHidingDropdown', { read: IgxDropDownComponent })\n    public columnHidingDropdown: IgxDropDownComponent;\n\n    /**\n     * Provides a reference to the `IgxColumnHidingComponent`.\n     * ```typescript\n     * const hidingUI = this.grid.toolbar.columnHidingUI;\n     * ```\n     */\n    @ViewChild(IgxColumnHidingComponent)\n    public columnHidingUI: IgxColumnHidingComponent;\n\n    /**\n     * Provides a reference to the Column Hiding button.\n     * ```typescript\n     * const hidingButton = this.grid.toolbar.columnHidingButton;\n     * ```\n     */\n    @ViewChild('columnHidingButton', { read: IgxButtonDirective })\n    public columnHidingButton: IgxButtonDirective;\n\n    /**\n     * Provides a reference to the `IgxDropDownComponent` of the Export button.\n     * ```typescript\n     * const exportDropdown = this.grid.toolbar.exportDropdown;\n     * ```\n     */\n    @ViewChild('exportDropdown', { read: IgxDropDownComponent })\n    public exportDropdown: IgxDropDownComponent;\n\n    /**\n     * Provides a reference to the Export button.\n     * ```typescript\n     * const exportBtn = this.grid.toolbar.exportButton;\n     * ```\n     */\n    @ViewChild('btnExport', { read: IgxButtonDirective })\n    public exportButton: IgxButtonDirective;\n\n    /**\n     * Provides a reference to the `IgxDropDownComponent` of the Column Pinning UI.\n     * ```typescript\n     * const dropdownPinning = this.grid.toolbar.columnPinningDropdown;\n     * ```\n     */\n    @ViewChild('columnPinningDropdown', { read: IgxDropDownComponent })\n    public columnPinningDropdown: IgxDropDownComponent;\n\n    /**\n     * Provides a reference to the `IgxColumnPinningComponent`.\n     * ```typescript\n     * const pinningUI = this.grid.toolbar.columnPinningDropdown;\n     * ```\n     */\n    @ViewChild(IgxColumnPinningComponent)\n    public columnPinningUI: IgxColumnPinningComponent;\n\n    /**\n     * Provides a reference to the Column Pinning button.\n     * ```typescript\n     * const pinningButton = this.grid.toolbar.columnPinningButton;\n     * ```\n     */\n    @ViewChild('columnPinningButton', { read: IgxButtonDirective })\n    public columnPinningButton: IgxButtonDirective;\n\n    /**\n     * Returns a reference to the `IgxGridComponent` component, hosting the `IgxGridToolbarComponent`.\n     * ```typescript\n     * const grid = this.igxGrid1.toolbar.grid;\n     * ```\n     */\n    public get grid(): IgxGridBaseDirective {\n        return this.gridAPI.grid;\n    }\n\n    /**\n     * Returns whether the `IgxGridComponent` renders an export button.\n     * ```typescript\n     * const exportButton = this.igxGrid1.toolbar.shouldShowExportButton;\n     * ```\n     */\n    public get shouldShowExportButton(): boolean {\n        return (this.grid != null && (this.grid.exportExcel || this.grid.exportCsv));\n    }\n\n    /**\n     * Returns whether the `IgxGridComponent` renders an Excel export button.\n     * ```typescript\n     * const exportExcelButton = this.igxGrid1.toolbar.shouldShowExportExcelButton;\n     * ```\n     */\n    public get shouldShowExportExcelButton(): boolean {\n        return (this.grid != null && this.grid.exportExcel);\n    }\n\n    /**\n     * Returns whether the `IgxGridComponent` renders an CSV export button.\n     * ```typescript\n     * const exportCSVButton = this.igxGrid1.toolbar.shouldShowExportCsvButton;\n     * ```\n     */\n    public get shouldShowExportCsvButton(): boolean {\n        return (this.grid != null && this.grid.exportCsv);\n    }\n\n    /**\n     * Returns how many columns are pinned.\n     * ```typescript\n     * const pinnedCount = this.igxGrid1.toolbar.pinnedColumnsCount;\n     * ```\n     */\n    public get pinnedColumnsCount() {\n        return this.grid.pinnedColumns.filter(col => !col.columnLayout).length;\n    }\n\n    /**\n     * Returns the theme of the `IgxGridToolbarComponent`.\n     * ```typescript\n     * const toolbarTheme = this.grid.toolbar.hostClass;\n     * ```\n     */\n\n    @HostBinding('attr.class')\n    get hostClass(): string {\n        return this.getComponentDensityClass('igx-grid-toolbar');\n    }\n\n    constructor(public gridAPI: GridBaseAPIService<IgxGridBaseDirective & GridType>,\n        public cdr: ChangeDetectorRef,\n        @Optional() public excelExporter: IgxExcelExporterService,\n        @Optional() public csvExporter: IgxCsvExporterService,\n        @Optional() @Inject(DisplayDensityToken) protected _displayDensityOptions: IDisplayDensityOptions) {\n            super(_displayDensityOptions);\n    }\n\n    private _positionSettings: PositionSettings = {\n        horizontalDirection: HorizontalAlignment.Left,\n        horizontalStartPoint: HorizontalAlignment.Right,\n        verticalDirection: VerticalAlignment.Bottom,\n        verticalStartPoint: VerticalAlignment.Bottom\n    };\n\n    private _overlaySettings: OverlaySettings = {\n        positionStrategy: new ConnectedPositioningStrategy(this._positionSettings),\n        scrollStrategy: new AbsoluteScrollStrategy(),\n        modal: false,\n        closeOnOutsideClick: true,\n        excludePositionTarget: true\n    };\n\n    /**\n     * Returns the title of `IgxGridToolbarComponent`.\n     * ```typescript\n     * const toolbarTitle = this.igxGrid1.toolbar.getTitle();\n     * ```\n     */\n    public getTitle(): string {\n        return this.grid != null ? this.grid.toolbarTitle : '';\n    }\n\n    /**\n     * Returns the text of the export button of the `IgxGridToolbarComponent`.\n     * ```typescript\n     * const toolbarExportText = this.igxGrid1.toolbar.getTitle();\n     * ```\n     */\n    public getExportText(): string {\n        return this.grid != null ? this.grid.exportText : '';\n    }\n\n    /**\n     * Returns the text of the Excel export button of the `IgxGridToolbarComponent`.\n     * ```typescript\n     * const toolbarExcelText = this.igxGrid1.toolbar.getExportExcelText();\n     * ```\n     */\n    public getExportExcelText(): string {\n        return this.grid != null ? this.grid.exportExcelText : '';\n    }\n\n    /**\n     * Returns the text of the CSV export button of the `IgxGridToolbarComponent`.\n     * ```typescript\n     * const toolbarCSVText = this.igxGrid1.toolbar.getExportCsvText();\n     * ```\n     */\n    public getExportCsvText(): string {\n        return this.grid != null ? this.grid.exportCsvText : '';\n    }\n\n    /**\n     * Toggles the export button's dropdown menu.\n     * ```typescript\n     * this.igxGrid1.toolbar.exportClicked();\n     * ```\n     */\n    public exportClicked() {\n        this._overlaySettings.positionStrategy.settings.target = this.exportButton.nativeElement;\n        this._overlaySettings.outlet = this.grid.outletDirective;\n        this.exportDropdown.toggle(this._overlaySettings);\n    }\n\n    /**\n     * Exports the grid to excel.\n     * ```typescript\n     * this.igxGrid1.toolbar.exportToExcelClicked();\n     * ```\n     */\n    public exportToExcelClicked() {\n        this.performExport(this.excelExporter, 'excel');\n    }\n\n    /**\n     * Exports the grid to CSV.\n     * ```typescript\n     * this.igxGrid1.toolbar.exportToCsvClicked();\n     * ```\n     */\n    public exportToCsvClicked() {\n        this.performExport(this.csvExporter, 'csv');\n    }\n\n    private performExport(exp: IgxBaseExporter, exportType: string) {\n        this.exportClicked();\n\n        const fileName = 'ExportedData';\n        const options = exportType === 'excel' ?\n            new IgxExcelExporterOptions(fileName) :\n            new IgxCsvExporterOptions(fileName, CsvFileTypes.CSV);\n\n        const args = { grid: this.grid, exporter: exp, options: options, cancel: false };\n\n        this.grid.onToolbarExporting.emit(args);\n        if (args.cancel) {\n            return;\n        }\n        exp.export(this.grid, options);\n    }\n\n    /**\n     * Toggles the Column Hiding UI.\n     * ```typescript\n     * this.grid1.toolbar.toggleColumnHidingUI();\n     * ```\n     */\n    public toggleColumnHidingUI() {\n        this._overlaySettings.positionStrategy.settings.target = this.columnHidingButton.nativeElement;\n        this._overlaySettings.outlet = this.grid.outletDirective;\n        this.columnHidingDropdown.toggle(this._overlaySettings);\n    }\n\n    /**\n     * Toggles the Column Pinning UI.\n     * ```typescript\n     * this.grid1.toolbar.toggleColumnPinningUI();\n     * ```\n     */\n    public toggleColumnPinningUI() {\n        this._overlaySettings.positionStrategy.settings.target = this.columnPinningButton.nativeElement;\n        this._overlaySettings.outlet = this.grid.outletDirective;\n        this.columnPinningDropdown.toggle(this._overlaySettings);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public showAdvancedFilteringUI() {\n        this.grid.openAdvancedFilteringDialog();\n    }\n\n    /**\n     * Returns the `context` object which represents the `template context` binding into the\n     * `toolbar custom container` by providing references to the parent IgxGird and the toolbar itself.\n     * ```typescript\n     * const context =  this.igxGrid.toolbar.context;\n     * ```\n     */\n    public get context(): any {\n        return {\n            // $implicit: this\n            grid: this.grid,\n            toolbar: this\n        };\n    }\n\n    /** @hidden */\n    public get customContentTemplate(): TemplateRef<any> {\n        if (this.grid != null && this.grid.toolbarCustomContentTemplate != null) {\n            return this.grid.toolbarCustomContentTemplate.template;\n        } else {\n            return null;\n        }\n    }\n}\n"]}