igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
662 lines • 51.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { ChangeDetectorRef, Component, Directive, HostBinding, Input, Optional, ViewChild, Inject, TemplateRef } from '@angular/core';
import { DisplayDensityToken, DisplayDensityBase } from '../core/displayDensity';
import { CsvFileTypes, IgxCsvExporterOptions, IgxCsvExporterService, IgxExcelExporterOptions, IgxExcelExporterService, AbsoluteScrollStrategy } from '../services/index';
import { GridBaseAPIService } from './api.service';
import { IgxDropDownComponent } from '../drop-down/drop-down.component';
import { IgxColumnHidingComponent } from './column-hiding.component';
import { IgxColumnPinningComponent } from './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`.
*/
var IgxGridToolbarComponent = /** @class */ (function (_super) {
tslib_1.__extends(IgxGridToolbarComponent, _super);
function IgxGridToolbarComponent(gridAPI, cdr, excelExporter, csvExporter, _displayDensityOptions) {
var _this = _super.call(this, _displayDensityOptions) || this;
_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
};
return _this;
}
Object.defineProperty(IgxGridToolbarComponent.prototype, "filterColumnsPrompt", {
/**
* Gets the default text shown in the filtering box.
* ```typescript
* const filterPrompt = this.grid.toolbar.filterColumnsPrompt;
* ```
*/
get: /**
* Gets the default text shown in the filtering box.
* ```typescript
* const filterPrompt = this.grid.toolbar.filterColumnsPrompt;
* ```
* @return {?}
*/
function () {
return this._filterColumnsPrompt;
},
/**
* Sets the default text shown in the filtering box.
* ```typescript
* this.grid.toolbar.filterColumnsPrompt('Filter columns ...');
* ```
*/
set: /**
* Sets the default text shown in the filtering box.
* ```typescript
* this.grid.toolbar.filterColumnsPrompt('Filter columns ...');
* ```
* @param {?} value
* @return {?}
*/
function (value) {
this._filterColumnsPrompt = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridToolbarComponent.prototype, "defaultDropDownsMaxHeight", {
/**
* Gets the height for the `IgxGridToolbarComponent`'s drop down panels.
* ```typescript
* const dropdownHeight = this.grid.toolbar.defaultDropDownsMaxHeight;
* ```
*/
get: /**
* Gets the height for the `IgxGridToolbarComponent`'s drop down panels.
* ```typescript
* const dropdownHeight = this.grid.toolbar.defaultDropDownsMaxHeight;
* ```
* @return {?}
*/
function () {
/** @type {?} */
var gridHeight = this.grid.calcHeight;
return (gridHeight) ? gridHeight * 0.7 + 'px' : '100%';
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridToolbarComponent.prototype, "grid", {
/**
* Returns a reference to the `IgxGridComponent` component, hosting the `IgxGridToolbarComponent`.
* ```typescript
* const grid = this.igxGrid1.toolbar.grid;
* ```
*/
get: /**
* Returns a reference to the `IgxGridComponent` component, hosting the `IgxGridToolbarComponent`.
* ```typescript
* const grid = this.igxGrid1.toolbar.grid;
* ```
* @return {?}
*/
function () {
return this.gridAPI.grid;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridToolbarComponent.prototype, "shouldShowExportButton", {
/**
* Returns whether the `IgxGridComponent` renders an export button.
* ```typescript
* const exportButton = this.igxGrid1.toolbar.shouldShowExportButton;
* ```
*/
get: /**
* Returns whether the `IgxGridComponent` renders an export button.
* ```typescript
* const exportButton = this.igxGrid1.toolbar.shouldShowExportButton;
* ```
* @return {?}
*/
function () {
return (this.grid != null && (this.grid.exportExcel || this.grid.exportCsv));
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridToolbarComponent.prototype, "shouldShowExportExcelButton", {
/**
* Returns whether the `IgxGridComponent` renders an Excel export button.
* ```typescript
* const exportExcelButton = this.igxGrid1.toolbar.shouldShowExportExcelButton;
* ```
*/
get: /**
* Returns whether the `IgxGridComponent` renders an Excel export button.
* ```typescript
* const exportExcelButton = this.igxGrid1.toolbar.shouldShowExportExcelButton;
* ```
* @return {?}
*/
function () {
return (this.grid != null && this.grid.exportExcel);
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridToolbarComponent.prototype, "shouldShowExportCsvButton", {
/**
* Returns whether the `IgxGridComponent` renders an CSV export button.
* ```typescript
* const exportCSVButton = this.igxGrid1.toolbar.shouldShowExportCsvButton;
* ```
*/
get: /**
* Returns whether the `IgxGridComponent` renders an CSV export button.
* ```typescript
* const exportCSVButton = this.igxGrid1.toolbar.shouldShowExportCsvButton;
* ```
* @return {?}
*/
function () {
return (this.grid != null && this.grid.exportCsv);
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridToolbarComponent.prototype, "pinnedColumnsCount", {
/**
* Returns how many columns are pinned.
* ```typescript
* const pinnedCount = this.igxGrid1.toolbar.pinnedColumnsCount;
* ```
*/
get: /**
* Returns how many columns are pinned.
* ```typescript
* const pinnedCount = this.igxGrid1.toolbar.pinnedColumnsCount;
* ```
* @return {?}
*/
function () {
return this.grid.pinnedColumns.length;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridToolbarComponent.prototype, "hostClass", {
/**
* Returns the theme of the `IgxGridToolbarComponent`.
* ```typescript
* const toolbarTheme = this.grid.toolbar.hostClass;
* ```
*/
get: /**
* Returns the theme of the `IgxGridToolbarComponent`.
* ```typescript
* const toolbarTheme = this.grid.toolbar.hostClass;
* ```
* @return {?}
*/
function () {
return this.getComponentDensityClass('igx-grid-toolbar');
},
enumerable: true,
configurable: true
});
/**
* Returns the title of `IgxGridToolbarComponent`.
* ```typescript
* const toolbarTitle = this.igxGrid1.toolbar.getTitle();
* ```
*/
/**
* Returns the title of `IgxGridToolbarComponent`.
* ```typescript
* const toolbarTitle = this.igxGrid1.toolbar.getTitle();
* ```
* @return {?}
*/
IgxGridToolbarComponent.prototype.getTitle = /**
* Returns the title of `IgxGridToolbarComponent`.
* ```typescript
* const toolbarTitle = this.igxGrid1.toolbar.getTitle();
* ```
* @return {?}
*/
function () {
return this.grid != null ? this.grid.toolbarTitle : '';
};
/**
* Returns the text of the export button of the `IgxGridToolbarComponent`.
* ```typescript
* const toolbarExportText = this.igxGrid1.toolbar.getTitle();
* ```
*/
/**
* Returns the text of the export button of the `IgxGridToolbarComponent`.
* ```typescript
* const toolbarExportText = this.igxGrid1.toolbar.getTitle();
* ```
* @return {?}
*/
IgxGridToolbarComponent.prototype.getExportText = /**
* Returns the text of the export button of the `IgxGridToolbarComponent`.
* ```typescript
* const toolbarExportText = this.igxGrid1.toolbar.getTitle();
* ```
* @return {?}
*/
function () {
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();
* ```
*/
/**
* Returns the text of the Excel export button of the `IgxGridToolbarComponent`.
* ```typescript
* const toolbarExcelText = this.igxGrid1.toolbar.getExportExcelText();
* ```
* @return {?}
*/
IgxGridToolbarComponent.prototype.getExportExcelText = /**
* Returns the text of the Excel export button of the `IgxGridToolbarComponent`.
* ```typescript
* const toolbarExcelText = this.igxGrid1.toolbar.getExportExcelText();
* ```
* @return {?}
*/
function () {
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();
* ```
*/
/**
* Returns the text of the CSV export button of the `IgxGridToolbarComponent`.
* ```typescript
* const toolbarCSVText = this.igxGrid1.toolbar.getExportCsvText();
* ```
* @return {?}
*/
IgxGridToolbarComponent.prototype.getExportCsvText = /**
* Returns the text of the CSV export button of the `IgxGridToolbarComponent`.
* ```typescript
* const toolbarCSVText = this.igxGrid1.toolbar.getExportCsvText();
* ```
* @return {?}
*/
function () {
return this.grid != null ? this.grid.exportCsvText : '';
};
/**
* Toggles the export button's dropdown menu.
* ```typescript
* this.igxGrid1.toolbar.exportClicked();
* ```
*/
/**
* Toggles the export button's dropdown menu.
* ```typescript
* this.igxGrid1.toolbar.exportClicked();
* ```
* @return {?}
*/
IgxGridToolbarComponent.prototype.exportClicked = /**
* Toggles the export button's dropdown menu.
* ```typescript
* this.igxGrid1.toolbar.exportClicked();
* ```
* @return {?}
*/
function () {
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();
* ```
*/
/**
* Exports the grid to excel.
* ```typescript
* this.igxGrid1.toolbar.exportToExcelClicked();
* ```
* @return {?}
*/
IgxGridToolbarComponent.prototype.exportToExcelClicked = /**
* Exports the grid to excel.
* ```typescript
* this.igxGrid1.toolbar.exportToExcelClicked();
* ```
* @return {?}
*/
function () {
this.performExport(this.excelExporter, 'excel');
};
/**
* Exports the grid to CSV.
* ```typescript
* this.igxGrid1.toolbar.exportToCsvClicked();
* ```
*/
/**
* Exports the grid to CSV.
* ```typescript
* this.igxGrid1.toolbar.exportToCsvClicked();
* ```
* @return {?}
*/
IgxGridToolbarComponent.prototype.exportToCsvClicked = /**
* Exports the grid to CSV.
* ```typescript
* this.igxGrid1.toolbar.exportToCsvClicked();
* ```
* @return {?}
*/
function () {
this.performExport(this.csvExporter, 'csv');
};
/**
* @private
* @param {?} exp
* @param {?} exportType
* @return {?}
*/
IgxGridToolbarComponent.prototype.performExport = /**
* @private
* @param {?} exp
* @param {?} exportType
* @return {?}
*/
function (exp, exportType) {
this.exportClicked();
/** @type {?} */
var fileName = 'ExportedData';
/** @type {?} */
var options = exportType === 'excel' ?
new IgxExcelExporterOptions(fileName) :
new IgxCsvExporterOptions(fileName, CsvFileTypes.CSV);
/** @type {?} */
var 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();
* ```
*/
/**
* Toggles the Column Hiding UI.
* ```typescript
* this.grid1.toolbar.toggleColumnHidingUI();
* ```
* @return {?}
*/
IgxGridToolbarComponent.prototype.toggleColumnHidingUI = /**
* Toggles the Column Hiding UI.
* ```typescript
* this.grid1.toolbar.toggleColumnHidingUI();
* ```
* @return {?}
*/
function () {
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();
* ```
*/
/**
* Toggles the Column Pinning UI.
* ```typescript
* this.grid1.toolbar.toggleColumnPinningUI();
* ```
* @return {?}
*/
IgxGridToolbarComponent.prototype.toggleColumnPinningUI = /**
* Toggles the Column Pinning UI.
* ```typescript
* this.grid1.toolbar.toggleColumnPinningUI();
* ```
* @return {?}
*/
function () {
this._overlaySettings.positionStrategy.settings.target = this.columnPinningButton.nativeElement;
this._overlaySettings.outlet = this.grid.outletDirective;
this.columnPinningDropdown.toggle(this._overlaySettings);
};
Object.defineProperty(IgxGridToolbarComponent.prototype, "context", {
/**
* 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: /**
* 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;
* ```
* @return {?}
*/
function () {
return {
// $implicit: this
grid: this.grid,
toolbar: this
};
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridToolbarComponent.prototype, "customContentTemplate", {
/** @hidden */
get: /**
* @hidden
* @return {?}
*/
function () {
if (this.grid != null && this.grid.toolbarCustomContentTemplate != null) {
return this.grid.toolbarCustomContentTemplate.template;
}
else {
return null;
}
},
enumerable: true,
configurable: true
});
IgxGridToolbarComponent.decorators = [
{ type: Component, args: [{
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.columnHiding\">\n <button igxButton=\"flat\" #columnHidingButton name=\"btnColumnHiding\" igxButton 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=\"flat\" #columnPinningButton name=\"btnColumnPinning\" igxButton 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\n <div class=\"igx-grid-toolbar__dropdown\" *ngIf=\"shouldShowExportButton\" id=\"btnExport\">\n <button igxButton=\"flat\" 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"
}] }
];
/** @nocollapse */
IgxGridToolbarComponent.ctorParameters = function () { return [
{ type: GridBaseAPIService },
{ type: ChangeDetectorRef },
{ type: IgxExcelExporterService, decorators: [{ type: Optional }] },
{ type: IgxCsvExporterService, decorators: [{ type: Optional }] },
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DisplayDensityToken,] }] }
]; };
IgxGridToolbarComponent.propDecorators = {
gridID: [{ type: HostBinding, args: ['class.igx-grid-toolbar',] }, { type: Input }],
filterColumnsPrompt: [{ type: Input }],
defaultDropDownsMaxHeight: [{ type: Input }],
columnHidingDropdown: [{ type: ViewChild, args: ['columnHidingDropdown', { read: IgxDropDownComponent },] }],
columnHidingUI: [{ type: ViewChild, args: [IgxColumnHidingComponent,] }],
columnHidingButton: [{ type: ViewChild, args: ['columnHidingButton',] }],
exportDropdown: [{ type: ViewChild, args: ['exportDropdown', { read: IgxDropDownComponent },] }],
exportButton: [{ type: ViewChild, args: ['btnExport',] }],
columnPinningDropdown: [{ type: ViewChild, args: ['columnPinningDropdown', { read: IgxDropDownComponent },] }],
columnPinningUI: [{ type: ViewChild, args: [IgxColumnPinningComponent,] }],
columnPinningButton: [{ type: ViewChild, args: ['columnPinningButton',] }],
hostClass: [{ type: HostBinding, args: ['attr.class',] }]
};
return IgxGridToolbarComponent;
}(DisplayDensityBase));
export { IgxGridToolbarComponent };
if (false) {
/**
* @hidden
* @type {?}
*/
IgxGridToolbarComponent.prototype.gridID;
/**
* @type {?}
* @private
*/
IgxGridToolbarComponent.prototype._filterColumnsPrompt;
/**
* Provides a reference to the `IgxDropDownComponent` of the Column Hiding UI.
* ```typescript
* const dropdownHiding = this.grid.toolbar.columnHidingDropdown;
* ```
* @type {?}
*/
IgxGridToolbarComponent.prototype.columnHidingDropdown;
/**
* Provides a reference to the `IgxColumnHidingComponent`.
* ```typescript
* const hidingUI = this.grid.toolbar.columnHidingUI;
* ```
* @type {?}
*/
IgxGridToolbarComponent.prototype.columnHidingUI;
/**
* Provides a reference to the Column Hiding button.
* ```typescript
* const hidingButton = this.grid.toolbar.columnHidingButton;
* ```
* @type {?}
*/
IgxGridToolbarComponent.prototype.columnHidingButton;
/**
* Provides a reference to the `IgxDropDownComponent` of the Export button.
* ```typescript
* const exportDropdown = this.grid.toolbar.exportDropdown;
* ```
* @type {?}
*/
IgxGridToolbarComponent.prototype.exportDropdown;
/**
* Provides a reference to the Export button.
* ```typescript
* const exportBtn = this.grid.toolbar.exportButton;
* ```
* @type {?}
*/
IgxGridToolbarComponent.prototype.exportButton;
/**
* Provides a reference to the `IgxDropDownComponent` of the Column Pinning UI.
* ```typescript
* const dropdownPinning = this.grid.toolbar.columnPinningDropdown;
* ```
* @type {?}
*/
IgxGridToolbarComponent.prototype.columnPinningDropdown;
/**
* Provides a reference to the `IgxColumnPinningComponent`.
* ```typescript
* const pinningUI = this.grid.toolbar.columnPinningDropdown;
* ```
* @type {?}
*/
IgxGridToolbarComponent.prototype.columnPinningUI;
/**
* Provides a reference to the Column Pinning button.
* ```typescript
* const pinningButton = this.grid.toolbar.columnPinningButton;
* ```
* @type {?}
*/
IgxGridToolbarComponent.prototype.columnPinningButton;
/**
* @type {?}
* @private
*/
IgxGridToolbarComponent.prototype._positionSettings;
/**
* @type {?}
* @private
*/
IgxGridToolbarComponent.prototype._overlaySettings;
/** @type {?} */
IgxGridToolbarComponent.prototype.gridAPI;
/** @type {?} */
IgxGridToolbarComponent.prototype.cdr;
/** @type {?} */
IgxGridToolbarComponent.prototype.excelExporter;
/** @type {?} */
IgxGridToolbarComponent.prototype.csvExporter;
/**
* @type {?}
* @protected
*/
IgxGridToolbarComponent.prototype._displayDensityOptions;
}
/**
* The IgxGridToolbarCustomContentDirective directive is used to mark an 'ng-template' (with
* the 'igxToolbarCustomContent' selector) defined in the IgxGrid which is used to provide
* custom content for cener part of the IgxGridToolbar.
*/
var IgxGridToolbarCustomContentDirective = /** @class */ (function () {
function IgxGridToolbarCustomContentDirective(template) {
this.template = template;
}
IgxGridToolbarCustomContentDirective.decorators = [
{ type: Directive, args: [{
selector: '[igxToolbarCustomContent]'
},] }
];
/** @nocollapse */
IgxGridToolbarCustomContentDirective.ctorParameters = function () { return [
{ type: TemplateRef }
]; };
return IgxGridToolbarCustomContentDirective;
}());
export { IgxGridToolbarCustomContentDirective };
if (false) {
/** @type {?} */
IgxGridToolbarCustomContentDirective.prototype.template;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-toolbar.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/grid-toolbar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectorRef,\n    Component,\n    Directive,\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 { IgxGridBaseComponent, IGridDataBindable } from './grid-base.component';\nimport { IgxDropDownComponent } from '../drop-down/drop-down.component';\nimport { IgxColumnHidingComponent } from './column-hiding.component';\nimport { IgxColumnPinningComponent } from './column-pinning.component';\nimport { OverlaySettings, PositionSettings, HorizontalAlignment, VerticalAlignment } from '../services/overlay/utilities';\nimport { ConnectedPositioningStrategy } from '../services/overlay/position';\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    /**\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')\n    public columnHidingButton;\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')\n    public exportButton;\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')\n    public columnPinningButton;\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(): IgxGridBaseComponent {\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.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<IgxGridBaseComponent & IGridDataBindable>,\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    /**\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     * Returns the `context` object which represents the `template context` binding into the\n     * `toolbar custom