igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
395 lines • 27.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { CommonModule } from '@angular/common';
import { ChangeDetectorRef, Component, EventEmitter, Input, NgModule, Output } from '@angular/core';
import { FormsModule } from '@angular/forms';
import { IgxCheckboxModule } from '../checkbox/checkbox.component';
import { IgxButtonModule } from '../directives/button/button.directive';
import { IgxColumnHidingItemDirective } from './column-hiding-item.directive';
import { IgxInputGroupModule } from '../input-group/input-group.component';
import { ColumnChooserBase } from './column-chooser-base';
import { takeUntil } from 'rxjs/operators';
import { Subject } from 'rxjs';
var IgxColumnHidingComponent = /** @class */ (function (_super) {
tslib_1.__extends(IgxColumnHidingComponent, _super);
function IgxColumnHidingComponent(cdr) {
var _this = _super.call(this, cdr) || this;
_this.cdr = cdr;
/**
* Sets/gets the text of the button that shows all columns if they are hidden.
* ```typescript
* let showAllButtonText = this.columnHiding.showAllText;
* ```
*
* ```html
* <igx-column-hiding [showAllText] = "'Show Columns'"></igx-column-hiding>
* ```
* \@memberof IgxColumnHidingComponent
*/
_this.showAllText = 'Show All';
/**
* Sets/gets the text of the button that hides all columns if they are shown.
* ```typescript
* let hideAllButtonText = this.columnHiding.hideAllText;
* ```
*
* ```html
* <igx-column-hiding [hideAllText] = "'Hide Columns'"></igx-column-hiding>
* ```
* \@memberof IgxColumnHidingComponent
*/
_this.hideAllText = 'Hide All';
/**
* An event that is emitted after the columns visibility is changed.
* Provides references to the `column` and the `newValue` properties as event arguments.
* ```html
* <igx-column-hiding (onColumnVisibilityChanged) = "onColumnVisibilityChanged($event)"></igx-column-hiding>
* ```
* \@memberof IgxColumnHidingComponent
*/
_this.onColumnVisibilityChanged = new EventEmitter();
_this.destroy$ = new Subject();
return _this;
}
Object.defineProperty(IgxColumnHidingComponent.prototype, "disableHideAll", {
/**
* Returns a boolean indicating whether the `HIDE ALL` button is disabled.
* ```html
* <igx-column-hiding #columnHidingUI
* [columns]="grid.columns" [title]="'Column Hiding'">
* </igx-column-hiding>
* ```
* ```typescript
* @ViewChild("'columnHidingUI'")
* public columnHiding: IgxColumnHidingComponent;
* let isHideAlldisabled = this.columnHiding.disableHideAll;
* ```
*@memberof IgxColumnHidingComponent
*/
get: /**
* Returns a boolean indicating whether the `HIDE ALL` button is disabled.
* ```html
* <igx-column-hiding #columnHidingUI
* [columns]="grid.columns" [title]="'Column Hiding'">
* </igx-column-hiding>
* ```
* ```typescript
* \@ViewChild("'columnHidingUI'")
* public columnHiding: IgxColumnHidingComponent;
* let isHideAlldisabled = this.columnHiding.disableHideAll;
* ```
* \@memberof IgxColumnHidingComponent
* @return {?}
*/
function () {
if (!this.columnItems || this.columnItems.length < 1 ||
this.hiddenColumnsCount === this.columns.length) {
return true;
}
else if (this.hidableColumns.length < 1 ||
this.hidableColumns.length === this.hidableColumns.filter(function (col) { return col.value; }).length) {
return true;
}
else {
return false;
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxColumnHidingComponent.prototype, "disableShowAll", {
/**
* Returns a boolean indicating whether the `SHOW ALL` button is disabled.
* ```typescript
* let isShowAlldisabled = this.columnHiding.disableShowAll;
* ```
* @memberof IgxColumnHidingComponent
*/
get: /**
* Returns a boolean indicating whether the `SHOW ALL` button is disabled.
* ```typescript
* let isShowAlldisabled = this.columnHiding.disableShowAll;
* ```
* \@memberof IgxColumnHidingComponent
* @return {?}
*/
function () {
if (!this.columnItems || this.columnItems.length < 1 ||
this.hiddenColumnsCount < 1 || this.hidableColumns.length < 1) {
return true;
}
else if (this.hidableColumns.length === this.hidableColumns.filter(function (col) { return !col.value; }).length) {
return true;
}
else {
return false;
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxColumnHidingComponent.prototype, "hiddenColumnsCount", {
/**
* Gets the count of the hidden columns.
* ```typescript
* let hiddenColumnsCount = this.columnHiding.hiddenColumnsCount;
* ```
* @memberof IgxColumnHidingComponent
*/
get: /**
* Gets the count of the hidden columns.
* ```typescript
* let hiddenColumnsCount = this.columnHiding.hiddenColumnsCount;
* ```
* \@memberof IgxColumnHidingComponent
* @return {?}
*/
function () {
return (this.columns) ? this.columns.filter(function (col) { return col.hidden; }).length : 0;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxColumnHidingComponent.prototype, "hidableColumns", {
/**
*@hidden
*/
get: /**
* @hidden
* @return {?}
*/
function () {
return this.columnItems.filter(function (col) { return !col.disabled; });
},
enumerable: true,
configurable: true
});
/**
*@hidden
*/
/**
* @hidden
* @protected
* @param {?} container
* @param {?} column
* @return {?}
*/
IgxColumnHidingComponent.prototype.createColumnItem = /**
* @hidden
* @protected
* @param {?} container
* @param {?} column
* @return {?}
*/
function (container, column) {
var _this = this;
/** @type {?} */
var item = new IgxColumnHidingItemDirective();
item.container = container;
item.column = column;
item.valueChanged.pipe(takeUntil(this.destroy$)).subscribe(function (args) {
_this.onVisibilityChanged({ column: item.column, newValue: args.newValue });
});
return item;
};
/**
* Shows all columns in the grid.
* ```typescript
* this.columnHiding.showAllColumns();
* ```
* @memberof IgxColumnHidingComponent
*/
/**
* Shows all columns in the grid.
* ```typescript
* this.columnHiding.showAllColumns();
* ```
* \@memberof IgxColumnHidingComponent
* @return {?}
*/
IgxColumnHidingComponent.prototype.showAllColumns = /**
* Shows all columns in the grid.
* ```typescript
* this.columnHiding.showAllColumns();
* ```
* \@memberof IgxColumnHidingComponent
* @return {?}
*/
function () {
var e_1, _a;
try {
for (var _b = tslib_1.__values(this.hidableColumns), _c = _b.next(); !_c.done; _c = _b.next()) {
var col = _c.value;
col.value = false;
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
};
/**
* Hides all columns in the grid.
* ```typescript
* this.columnHiding.hideAllColumns();
* ```
* @memberof IgxColumnHidingComponent
*/
/**
* Hides all columns in the grid.
* ```typescript
* this.columnHiding.hideAllColumns();
* ```
* \@memberof IgxColumnHidingComponent
* @return {?}
*/
IgxColumnHidingComponent.prototype.hideAllColumns = /**
* Hides all columns in the grid.
* ```typescript
* this.columnHiding.hideAllColumns();
* ```
* \@memberof IgxColumnHidingComponent
* @return {?}
*/
function () {
var e_2, _a;
try {
for (var _b = tslib_1.__values(this.hidableColumns), _c = _b.next(); !_c.done; _c = _b.next()) {
var col = _c.value;
col.value = true;
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_2) throw e_2.error; }
}
};
/**
* @hidden
*/
/**
* @hidden
* @param {?} args
* @return {?}
*/
IgxColumnHidingComponent.prototype.onVisibilityChanged = /**
* @hidden
* @param {?} args
* @return {?}
*/
function (args) {
this.onColumnVisibilityChanged.emit(args);
};
/**
*@hidden
*/
/**
* @hidden
* @return {?}
*/
IgxColumnHidingComponent.prototype.ngOnDestroy = /**
* @hidden
* @return {?}
*/
function () {
this.destroy$.next(true);
this.destroy$.complete();
};
IgxColumnHidingComponent.decorators = [
{ type: Component, args: [{
preserveWhitespaces: false,
selector: 'igx-column-hiding',
template: "<div class=\"igx-column-hiding__header\">\n <h4 class=\"igx-column-hiding__header-title\" *ngIf=\"title\">{{ title }}</h4>\n\n <igx-input-group class=\"igx-column-hiding__header-input\" *ngIf=\"!disableFilter\">\n <input igxInput\n type=\"text\"\n [(ngModel)]=\"filterCriteria\"\n [placeholder]=\"filterColumnsPrompt\"\n autocomplete=\"off\" />\n </igx-input-group>\n</div>\n\n<div class=\"igx-column-hiding__columns\"\n [style.max-height]=\"columnsAreaMaxHeight\">\n <igx-checkbox\n *ngFor=\"let columnItem of hidableColumns\"\n class=\"igx-column-hiding__columns-item\"\n (onColumnVisibilityChanged)=\"onVisibilityChanged($event)\"\n (change)=\"columnItem.value = !columnItem.value\"\n [checked]=\"columnItem.value\"\n [disabled]=\"columnItem.disabled\"\n [style.margin-left.px]=\"columnItem.calcIndent\">\n {{ columnItem.name }}\n </igx-checkbox>\n</div>\n\n<div class=\"igx-column-hiding__buttons\">\n <button igxButton igxRipple (click)=\"showAllColumns()\" [disabled]=\"disableShowAll\">{{ showAllText }}</button>\n <button igxButton igxRipple (click)=\"hideAllColumns()\" [disabled]=\"disableHideAll\">{{ hideAllText }}</button>\n</div>\n"
}] }
];
/** @nocollapse */
IgxColumnHidingComponent.ctorParameters = function () { return [
{ type: ChangeDetectorRef }
]; };
IgxColumnHidingComponent.propDecorators = {
disableHideAll: [{ type: Input }],
disableShowAll: [{ type: Input }],
showAllText: [{ type: Input }],
hideAllText: [{ type: Input }],
onColumnVisibilityChanged: [{ type: Output }]
};
return IgxColumnHidingComponent;
}(ColumnChooserBase));
export { IgxColumnHidingComponent };
if (false) {
/**
* Sets/gets the text of the button that shows all columns if they are hidden.
* ```typescript
* let showAllButtonText = this.columnHiding.showAllText;
* ```
*
* ```html
* <igx-column-hiding [showAllText] = "'Show Columns'"></igx-column-hiding>
* ```
* \@memberof IgxColumnHidingComponent
* @type {?}
*/
IgxColumnHidingComponent.prototype.showAllText;
/**
* Sets/gets the text of the button that hides all columns if they are shown.
* ```typescript
* let hideAllButtonText = this.columnHiding.hideAllText;
* ```
*
* ```html
* <igx-column-hiding [hideAllText] = "'Hide Columns'"></igx-column-hiding>
* ```
* \@memberof IgxColumnHidingComponent
* @type {?}
*/
IgxColumnHidingComponent.prototype.hideAllText;
/**
* An event that is emitted after the columns visibility is changed.
* Provides references to the `column` and the `newValue` properties as event arguments.
* ```html
* <igx-column-hiding (onColumnVisibilityChanged) = "onColumnVisibilityChanged($event)"></igx-column-hiding>
* ```
* \@memberof IgxColumnHidingComponent
* @type {?}
*/
IgxColumnHidingComponent.prototype.onColumnVisibilityChanged;
/**
* @type {?}
* @private
*/
IgxColumnHidingComponent.prototype.destroy$;
/** @type {?} */
IgxColumnHidingComponent.prototype.cdr;
}
/**
* @hidden
*/
var IgxColumnHidingModule = /** @class */ (function () {
function IgxColumnHidingModule() {
}
IgxColumnHidingModule.decorators = [
{ type: NgModule, args: [{
declarations: [IgxColumnHidingComponent, IgxColumnHidingItemDirective],
exports: [IgxColumnHidingComponent],
imports: [
IgxButtonModule,
IgxCheckboxModule,
IgxInputGroupModule,
CommonModule,
FormsModule,
]
},] }
];
return IgxColumnHidingModule;
}());
export { IgxColumnHidingModule };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-hiding.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/column-hiding.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    Input,\n    NgModule,\n    Output,\n    OnDestroy\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { IgxCheckboxModule } from '../checkbox/checkbox.component';\nimport { IgxButtonModule } from '../directives/button/button.directive';\nimport { IColumnVisibilityChangedEventArgs, IgxColumnHidingItemDirective } from './column-hiding-item.directive';\nimport { IgxInputGroupModule } from '../input-group/input-group.component';\nimport { ColumnChooserBase } from './column-chooser-base';\nimport { takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\n\n@Component({\n    preserveWhitespaces: false,\n    selector: 'igx-column-hiding',\n    templateUrl: './column-hiding.component.html'\n})\nexport class IgxColumnHidingComponent extends ColumnChooserBase implements OnDestroy {\n    /**\n     * Returns a boolean indicating whether the `HIDE ALL` button is disabled.\n     * ```html\n     * <igx-column-hiding #columnHidingUI\n     *     [columns]=\"grid.columns\" [title]=\"'Column Hiding'\">\n     * </igx-column-hiding>\n     * ```\n     * ```typescript\n     * @ViewChild(\"'columnHidingUI'\")\n     * public columnHiding: IgxColumnHidingComponent;\n     * let isHideAlldisabled =  this.columnHiding.disableHideAll;\n     * ```\n     *@memberof IgxColumnHidingComponent\n     */\n    @Input()\n    get disableHideAll(): boolean {\n        if (!this.columnItems || this.columnItems.length < 1 ||\n            this.hiddenColumnsCount === this.columns.length) {\n            return true;\n        } else if (this.hidableColumns.length < 1 ||\n            this.hidableColumns.length === this.hidableColumns.filter((col) => col.value).length) {\n            return true;\n        } else {\n            return false;\n        }\n    }\n    /**\n     * Returns a boolean indicating whether the `SHOW ALL` button is disabled.\n     * ```typescript\n     * let isShowAlldisabled =  this.columnHiding.disableShowAll;\n     * ```\n     * @memberof IgxColumnHidingComponent\n     */\n    @Input()\n    get disableShowAll(): boolean {\n        if (!this.columnItems || this.columnItems.length < 1 ||\n            this.hiddenColumnsCount < 1 || this.hidableColumns.length < 1) {\n            return true;\n        } else if (this.hidableColumns.length === this.hidableColumns.filter((col) => !col.value).length) {\n            return true;\n        } else {\n            return false;\n        }\n    }\n    /**\n     * Sets/gets the text of the button that shows all columns if they are hidden.\n     * ```typescript\n     * let showAllButtonText =  this.columnHiding.showAllText;\n     * ```\n     *\n     * ```html\n     * <igx-column-hiding [showAllText] = \"'Show Columns'\"></igx-column-hiding>\n     * ```\n     * @memberof IgxColumnHidingComponent\n     */\n    @Input()\n    public showAllText = 'Show All';\n    /**\n     * Sets/gets the text of the button that hides all columns if they are shown.\n     * ```typescript\n     * let hideAllButtonText =  this.columnHiding.hideAllText;\n     * ```\n     *\n     * ```html\n     * <igx-column-hiding [hideAllText] = \"'Hide Columns'\"></igx-column-hiding>\n     * ```\n     * @memberof IgxColumnHidingComponent\n     */\n    @Input()\n    public hideAllText = 'Hide All';\n    /**\n     * An event that is emitted after the columns visibility is changed.\n     * Provides references to the `column` and the `newValue` properties as event arguments.\n     * ```html\n     *  <igx-column-hiding (onColumnVisibilityChanged) = \"onColumnVisibilityChanged($event)\"></igx-column-hiding>\n     * ```\n     * @memberof IgxColumnHidingComponent\n     */\n    @Output()\n    public onColumnVisibilityChanged = new EventEmitter<IColumnVisibilityChangedEventArgs>();\n    /**\n     * Gets the count of the hidden columns.\n     * ```typescript\n     * let hiddenColumnsCount =  this.columnHiding.hiddenColumnsCount;\n     * ```\n     * @memberof IgxColumnHidingComponent\n     */\n    public get hiddenColumnsCount() {\n        return (this.columns) ? this.columns.filter((col) => col.hidden).length : 0;\n    }\n\n    constructor(public cdr: ChangeDetectorRef) {\n        super(cdr);\n    }\n\n    /**\n     *@hidden\n     */\n    public get hidableColumns() {\n        return this.columnItems.filter((col) => !col.disabled);\n    }\n\n    private destroy$ = new Subject<boolean>();\n    /**\n     *@hidden\n     */\n    protected createColumnItem(container: any, column: any) {\n        const item = new IgxColumnHidingItemDirective();\n        item.container = container;\n        item.column = column;\n\n        item.valueChanged.pipe(takeUntil(this.destroy$)).subscribe((args) => {\n            this.onVisibilityChanged({ column: item.column, newValue: args.newValue });\n        });\n\n        return item;\n    }\n    /**\n     * Shows all columns in the grid.\n     * ```typescript\n     * this.columnHiding.showAllColumns();\n     * ```\n     * @memberof IgxColumnHidingComponent\n     */\n    public showAllColumns() {\n        for (const col of this.hidableColumns) {\n            col.value = false;\n        }\n    }\n    /**\n     * Hides all columns in the grid.\n     * ```typescript\n     * this.columnHiding.hideAllColumns();\n     * ```\n     * @memberof IgxColumnHidingComponent\n     */\n    public hideAllColumns() {\n        for (const col of this.hidableColumns) {\n            col.value = true;\n        }\n    }\n    /**\n     * @hidden\n     */\n    public onVisibilityChanged(args: IColumnVisibilityChangedEventArgs) {\n        this.onColumnVisibilityChanged.emit(args);\n    }\n\n    /**\n     *@hidden\n     */\n    public ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.complete();\n    }\n}\n\n/**\n * @hidden\n */\n@NgModule({\n    declarations: [IgxColumnHidingComponent, IgxColumnHidingItemDirective],\n    exports: [IgxColumnHidingComponent],\n    imports: [\n        IgxButtonModule,\n        IgxCheckboxModule,\n        IgxInputGroupModule,\n        CommonModule,\n        FormsModule,\n    ]\n})\nexport class IgxColumnHidingModule {\n}\n"]}