igniteui-angular 17.2.19 → 17.2.21
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/grids/filtering/excel-style/excel-style-filtering.component.mjs +21 -1
- package/esm2022/lib/grids/grouping/grid-group-by-area.component.mjs +3 -3
- package/esm2022/lib/grids/grouping/tree-grid-group-by-area.component.mjs +3 -3
- package/esm2022/lib/grids/selection/selection.service.mjs +10 -2
- package/esm2022/lib/query-builder/query-builder-header.component.mjs +3 -3
- package/esm2022/lib/query-builder/query-builder.component.mjs +3 -3
- package/fesm2022/igniteui-angular.mjs +37 -9
- package/fesm2022/igniteui-angular.mjs.map +1 -1
- package/lib/core/styles/components/tabs/_tabs-theme.scss +1 -1
- package/lib/grids/filtering/excel-style/excel-style-filtering.component.d.ts +20 -0
- package/migrations/common/ServerHost.d.ts +2 -0
- package/migrations/common/ServerHost.js +4 -1
- package/migrations/common/UpdateChanges.js +3 -3
- package/package.json +1 -1
- package/styles/igniteui-bootstrap-dark.css +1 -1
- package/styles/igniteui-bootstrap-light.css +1 -1
- package/styles/maps/igniteui-bootstrap-dark.css.map +1 -1
- package/styles/maps/igniteui-bootstrap-light.css.map +1 -1
|
@@ -89,6 +89,16 @@ export class IgxGridExcelStyleFilteringComponent extends BaseFilteringComponent
|
|
|
89
89
|
}
|
|
90
90
|
/**
|
|
91
91
|
* Gets the minimum height.
|
|
92
|
+
*
|
|
93
|
+
* Setting value in template:
|
|
94
|
+
* ```ts
|
|
95
|
+
* [minHeight]="'<number><unit (px|rem|etc..)>'"
|
|
96
|
+
* ```
|
|
97
|
+
*
|
|
98
|
+
* Example for setting a value:
|
|
99
|
+
* ```ts
|
|
100
|
+
* [minHeight]="'700px'"
|
|
101
|
+
* ```
|
|
92
102
|
*/
|
|
93
103
|
get minHeight() {
|
|
94
104
|
if (this._minHeight || this._minHeight === 0) {
|
|
@@ -116,6 +126,16 @@ export class IgxGridExcelStyleFilteringComponent extends BaseFilteringComponent
|
|
|
116
126
|
}
|
|
117
127
|
/**
|
|
118
128
|
* Gets the maximum height.
|
|
129
|
+
*
|
|
130
|
+
* Setting value in template:
|
|
131
|
+
* ```ts
|
|
132
|
+
* [maxHeight]="'<number><unit (px|rem|etc..)>'"
|
|
133
|
+
* ```
|
|
134
|
+
*
|
|
135
|
+
* Example for setting a value:
|
|
136
|
+
* ```ts
|
|
137
|
+
* [maxHeight]="'700px'"
|
|
138
|
+
* ```
|
|
119
139
|
*/
|
|
120
140
|
get maxHeight() {
|
|
121
141
|
if (this._maxHeight) {
|
|
@@ -676,4 +696,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
|
|
|
676
696
|
type: HostBinding,
|
|
677
697
|
args: ['style.max-height']
|
|
678
698
|
}] } });
|
|
679
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"excel-style-filtering.component.js","sourceRoot":"","sources":["../../../../../../../projects/igniteui-angular/src/lib/grids/filtering/excel-style/excel-style-filtering.component.ts","../../../../../../../projects/igniteui-angular/src/lib/grids/filtering/excel-style/excel-style-filtering.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewChecked,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Host,\n    HostBinding,\n    Inject,\n    Input,\n    OnDestroy,\n    Optional,\n    Output,\n    TemplateRef,\n    ViewChild,\n    ViewRef\n} from '@angular/core';\nimport { FilteringExpressionsTree, IFilteringExpressionsTree } from '../../../data-operations/filtering-expressions-tree';\nimport { PlatformUtil, formatDate, formatCurrency } from '../../../core/utils';\nimport { GridColumnDataType } from '../../../data-operations/data-util';\nimport { Subject, Subscription } from 'rxjs';\nimport { DisplayDensity } from '../../../core/density';\nimport { GridSelectionMode } from '../../common/enums';\nimport { IgxFilterItem } from '../../../data-operations/filtering-strategy';\nimport { formatNumber, formatPercent, getLocaleCurrencyCode, NgIf, NgClass, DOCUMENT } from '@angular/common';\nimport { BaseFilteringComponent } from './base-filtering.component';\nimport { ExpressionUI, FilterListItem, generateExpressionsList } from './common';\nimport { ColumnType, GridType, IGX_GRID_BASE } from '../../common/grid.interface';\nimport { IgxOverlayService } from '../../../services/overlay/overlay';\nimport { SortingDirection } from '../../../data-operations/sorting-strategy';\nimport { IgxExcelStyleSearchComponent } from './excel-style-search.component';\nimport { IgxExcelStyleConditionalFilterComponent } from './excel-style-conditional-filter.component';\nimport { IgxExcelStyleClearFiltersComponent } from './excel-style-clear-filters.component';\nimport { IgxExcelStyleSelectingComponent } from './excel-style-selecting.component';\nimport { IgxExcelStyleHidingComponent } from './excel-style-hiding.component';\nimport { IgxExcelStylePinningComponent } from './excel-style-pinning.component';\nimport { IgxExcelStyleMovingComponent } from './excel-style-moving.component';\nimport { IgxExcelStyleSortingComponent } from './excel-style-sorting.component';\nimport { IgxExcelStyleHeaderComponent } from './excel-style-header.component';\n\n@Directive({\n    selector: 'igx-excel-style-column-operations,[igxExcelStyleColumnOperations]',\n    standalone: true\n})\nexport class IgxExcelStyleColumnOperationsTemplateDirective { }\n\n@Directive({\n    selector: 'igx-excel-style-filter-operations,[igxExcelStyleFilterOperations]',\n    standalone: true\n})\nexport class IgxExcelStyleFilterOperationsTemplateDirective { }\n\n/**\n * A component used for presenting Excel style filtering UI for a specific column.\n * It is used internally in the Grid, but could also be hosted in a container outside of it.\n *\n * Example:\n * ```html\n * <igx-grid-excel-style-filtering\n *     [column]=\"grid1.columns[0]\">\n * </igx-grid-excel-style-filtering>\n * ```\n */\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [{ provide: BaseFilteringComponent, useExisting: forwardRef(() => IgxGridExcelStyleFilteringComponent) }],\n    selector: 'igx-grid-excel-style-filtering',\n    templateUrl: './excel-style-filtering.component.html',\n    standalone: true,\n    imports: [IgxExcelStyleHeaderComponent, NgIf, IgxExcelStyleSortingComponent, IgxExcelStyleMovingComponent, IgxExcelStylePinningComponent, IgxExcelStyleHidingComponent, IgxExcelStyleSelectingComponent, IgxExcelStyleClearFiltersComponent, IgxExcelStyleConditionalFilterComponent, IgxExcelStyleSearchComponent, NgClass]\n})\nexport class IgxGridExcelStyleFilteringComponent extends BaseFilteringComponent implements AfterViewChecked, OnDestroy {\n\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('class.igx-excel-filter')\n    public defaultClass = true;\n\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('class.igx-excel-filter--inline')\n    public inline = true;\n\n    /**\n     * @hidden @internal\n     */\n    @Output()\n    public loadingStart = new EventEmitter();\n\n    /**\n     * @hidden @internal\n     */\n    @Output()\n    public loadingEnd = new EventEmitter();\n\n    /**\n     * @hidden @internal\n     */\n    @Output()\n    public initialized = new EventEmitter();\n\n    /**\n     * @hidden @internal\n     */\n    @Output()\n    public sortingChanged = new EventEmitter();\n\n    /**\n     * @hidden @internal\n     */\n    @Output()\n    public columnChange = new EventEmitter<ColumnType>();\n\n    /**\n     * @hidden @internal\n     */\n    @Output()\n    public listDataLoaded = new EventEmitter();\n\n    @ViewChild('mainDropdown', { read: ElementRef })\n    public mainDropdown: ElementRef<HTMLElement>;\n\n    /**\n     * @hidden @internal\n     */\n    @ContentChild(IgxExcelStyleColumnOperationsTemplateDirective, { read: IgxExcelStyleColumnOperationsTemplateDirective })\n    public excelColumnOperationsDirective: IgxExcelStyleColumnOperationsTemplateDirective;\n\n    /**\n     * @hidden @internal\n     */\n    @ContentChild(IgxExcelStyleFilterOperationsTemplateDirective, { read: IgxExcelStyleFilterOperationsTemplateDirective })\n    public excelFilterOperationsDirective: IgxExcelStyleFilterOperationsTemplateDirective;\n\n    /**\n     * @hidden @internal\n     */\n    @ViewChild('defaultExcelColumnOperations', { read: TemplateRef, static: true })\n    protected defaultExcelColumnOperations: TemplateRef<any>;\n\n    /**\n     * @hidden @internal\n     */\n    @ViewChild('defaultExcelFilterOperations', { read: TemplateRef, static: true })\n    protected defaultExcelFilterOperations: TemplateRef<any>;\n\n    /**\n     * Sets the column.\n     */\n    @Input()\n    public set column(value: ColumnType) {\n        this._column = value;\n        this.listData = new Array<FilterListItem>();\n        this.columnChange.emit(this._column);\n\n        this.subscriptions?.unsubscribe();\n\n        if (this._column) {\n            this.grid.filteringService.registerSVGIcons();\n            this.init();\n            this.sortingChanged.emit();\n\n            this.subscriptions = this.grid.columnPin.subscribe(() => {\n                requestAnimationFrame(() => {\n                    if (!(this.cdr as ViewRef).destroyed) {\n                        this.cdr.detectChanges();\n                    }\n                });\n            });\n\n            this.subscriptions.add(this.grid.columnVisibilityChanged.subscribe(() => this.detectChanges()));\n            this.subscriptions.add(this.grid.sortingExpressionsChange.subscribe(() => this.sortingChanged.emit()));\n            this.subscriptions.add(this.grid.filteringExpressionsTreeChange.subscribe(() => this.init()));\n            this.subscriptions.add(this.grid.densityChanged.subscribe(() => this.detectChanges()));\n            this.subscriptions.add(this.grid.columnMovingEnd.subscribe(() => this.cdr.markForCheck()));\n        }\n    }\n\n    /**\n     * Returns the current column.\n     */\n    public get column(): ColumnType {\n        return this._column;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public expressionsList = new Array<ExpressionUI>();\n    /**\n     * @hidden @internal\n     */\n    public listData = new Array<FilterListItem>();\n    /**\n     * @hidden @internal\n     */\n    public uniqueValues: IgxFilterItem[] = [];\n    /**\n     * @hidden @internal\n     */\n    public overlayService: IgxOverlayService;\n    /**\n     * @hidden @internal\n     */\n    public overlayComponentId: string;\n    /**\n     * @hidden @internal\n     */\n    public isHierarchical = false;\n\n    private _minHeight;\n    private _sizeSubscription: Subscription;\n    private _size: string;\n    private _size$ = new Subject();\n\n    /**\n     * Gets the minimum height.\n     */\n    @Input()\n    public get minHeight(): string {\n        if (this._minHeight || this._minHeight === 0) {\n            return this._minHeight;\n        }\n\n        if (!this.inline) {\n            let minHeight = 645;\n            switch (this.displayDensity) {\n                case DisplayDensity.cosy: minHeight = 465; break;\n                case DisplayDensity.compact: minHeight = 330; break;\n                default: break;\n            }\n            return `${minHeight}px`;\n        }\n    }\n\n    /**\n     * Sets the minimum height.\n     */\n    public set minHeight(value: string) {\n        this._minHeight = value;\n    }\n\n\n    private _maxHeight: string;\n    private containsNullOrEmpty = false;\n    private selectAllSelected = true;\n    private selectAllIndeterminate = false;\n    private filterValues = new Set<any>();\n    private _column: ColumnType;\n    private subscriptions: Subscription;\n    private _originalDisplay: string;\n\n    /**\n     * Gets the maximum height.\n     */\n    @Input()\n    @HostBinding('style.max-height')\n    public get maxHeight(): string {\n        if (this._maxHeight) {\n            return this._maxHeight;\n        }\n\n        if (!this.inline) {\n            let maxHeight = 775;\n            switch (this.displayDensity) {\n                case DisplayDensity.cosy: maxHeight = 565; break;\n                case DisplayDensity.compact: maxHeight = 405; break;\n                default: break;\n            }\n            return `${maxHeight}px`;\n        }\n    }\n\n    /**\n     * Sets the maximum height.\n     */\n    public set maxHeight(value: string) {\n        this._maxHeight = value;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get grid(): GridType {\n        return this.column?.grid ?? this.gridAPI;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get displayDensity() {\n        switch (this._size) {\n            case '1':\n                return DisplayDensity.compact;\n            case '2':\n                return DisplayDensity.cosy;\n            case '3':\n            default:\n                return DisplayDensity.comfortable;\n        }\n    }\n\n    constructor(\n        cdr: ChangeDetectorRef,\n        element: ElementRef<HTMLElement>,\n        platform: PlatformUtil,\n        @Inject(DOCUMENT)\n        private document: any,\n        @Host() @Optional() @Inject(IGX_GRID_BASE) protected gridAPI?: GridType) {\n        super(cdr, element, platform);\n\n        this._sizeSubscription = this._size$.asObservable().subscribe(value => {\n            this._size = value as string;\n            this.cdr.detectChanges();\n        });\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public ngOnDestroy(): void {\n        this.subscriptions?.unsubscribe();\n        this._sizeSubscription?.unsubscribe();\n        delete this.overlayComponentId;\n    }\n\n    /** @hidden @internal */\n    public ngAfterViewChecked() {\n        // TODO: Should only check for the value of `--ig-size` in 17.0;\n        const sizeVar = this.grid ? '--grid-size' : '--ig-size';\n\n        if (!this._size) {\n            const cssProp = this.document.defaultView\n                .getComputedStyle(this.element.nativeElement)\n                .getPropertyValue(sizeVar)\n                .trim();\n\n            if (cssProp !== '') {\n                Promise.resolve().then(() => {\n                    this._size$.next(cssProp);\n                    this.cdr.markForCheck();\n                });\n            }\n        }\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public initialize(column: ColumnType, overlayService: IgxOverlayService) {\n        this.inline = false;\n        this.column = column;\n        this.overlayService = overlayService;\n        if (this._originalDisplay) {\n            this.element.nativeElement.style.display = this._originalDisplay;\n        }\n\n        this.initialized.emit();\n        this.subscriptions.add(this.grid.columnMoving.subscribe(() => this.closeDropdown()));\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onPin() {\n        this.closeDropdown();\n        this.column.pinned = !this.column.pinned;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onSelect() {\n        if (!this.column.selected) {\n            this.grid.selectionService.selectColumn(this.column.field, this.grid.columnSelection === GridSelectionMode.single);\n        } else {\n            this.grid.selectionService.deselectColumn(this.column.field);\n        }\n        this.grid.notifyChanges();\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public columnSelectable() {\n        return this.grid?.columnSelection !== GridSelectionMode.none && this.column?.selectable;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onHideToggle() {\n        this.column.toggleVisibility();\n        this.closeDropdown();\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public cancel() {\n        if (!this.overlayComponentId) {\n            this.init();\n        }\n        this.closeDropdown();\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public closeDropdown() {\n        if (this.overlayComponentId) {\n            this.overlayService.hide(this.overlayComponentId);\n            this.overlayComponentId = null;\n        }\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onKeyDown(eventArgs: KeyboardEvent) {\n        if (this.platform.isFilteringKeyCombo(eventArgs)) {\n            eventArgs.preventDefault();\n            this.closeDropdown();\n        }\n        eventArgs.stopPropagation();\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public hide() {\n        this._originalDisplay = document.defaultView.getComputedStyle(this.element.nativeElement).display;\n        this.element.nativeElement.style.display = 'none';\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public detectChanges() {\n        this.cdr.detectChanges();\n    }\n\n    private init() {\n        this.expressionsList = new Array<ExpressionUI>();\n        generateExpressionsList(this.column.filteringExpressionsTree, this.grid.filteringLogic, this.expressionsList);\n        this.populateColumnData();\n    }\n\n    private areExpressionsSelectable() {\n        if (this.expressionsList.length === 1 &&\n            (this.expressionsList[0].expression.condition.name === 'equals' ||\n                this.expressionsList[0].expression.condition.name === 'at' ||\n                this.expressionsList[0].expression.condition.name === 'true' ||\n                this.expressionsList[0].expression.condition.name === 'false' ||\n                this.expressionsList[0].expression.condition.name === 'empty' ||\n                this.expressionsList[0].expression.condition.name === 'in')) {\n            return true;\n        }\n\n        const selectableExpressionsCount = this.expressionsList.filter(exp =>\n            (exp.beforeOperator === 1 || exp.afterOperator === 1) &&\n            (exp.expression.condition.name === 'equals' ||\n                exp.expression.condition.name === 'at' ||\n                exp.expression.condition.name === 'true' ||\n                exp.expression.condition.name === 'false' ||\n                exp.expression.condition.name === 'empty' ||\n                exp.expression.condition.name === 'in')).length;\n\n        return selectableExpressionsCount === this.expressionsList.length;\n    }\n\n    private populateColumnData() {\n        this.cdr.detectChanges();\n\n        if (this.grid.uniqueColumnValuesStrategy) {\n            this.renderColumnValuesRemotely();\n        } else {\n            this.renderColumnValuesFromData();\n        }\n    }\n\n    private renderColumnValuesRemotely() {\n        this.loadingStart.emit();\n        const expressionsTree: FilteringExpressionsTree = this.getColumnFilterExpressionsTree();\n\n        const prevColumn = this.column;\n        this.grid.uniqueColumnValuesStrategy(this.column, expressionsTree, (values: any[]) => {\n            if (!this.column || this.column !== prevColumn) {\n                return;\n            }\n\n            const items = values.map(v => ({\n                value: v\n            }));\n\n            this.uniqueValues = this.column.sortStrategy.sort(items, 'value', SortingDirection.Asc, this.column.sortingIgnoreCase,\n                (obj, key) => {\n                    let resolvedValue = obj[key];\n                    if (this.column.dataType === GridColumnDataType.Time) {\n                        resolvedValue = new Date().setHours(\n                            resolvedValue.getHours(),\n                            resolvedValue.getMinutes(),\n                            resolvedValue.getSeconds(),\n                            resolvedValue.getMilliseconds());\n                    }\n\n                    return resolvedValue;\n                });\n\n            this.renderValues();\n            this.loadingEnd.emit();\n        });\n    }\n\n    private renderColumnValuesFromData() {\n        this.loadingStart.emit();\n\n        const expressionsTree = this.getColumnFilterExpressionsTree();\n        const promise = this.grid.filterStrategy.getFilterItems(this.column, expressionsTree);\n        promise.then((items) => {\n            this.isHierarchical = items.length > 0 && items.some(i => i.children && i.children.length > 0);\n            this.uniqueValues = items;\n            this.renderValues();\n            this.loadingEnd.emit();\n            this.sortingChanged.emit();\n        });\n    }\n\n    private renderValues() {\n        this.filterValues = this.generateFilterValues();\n        this.generateListData();\n    }\n\n    private generateFilterValues() {\n        const formatValue = (value: any): any => {\n            if (!value) return value;\n\n            switch (this.column.dataType) {\n                case GridColumnDataType.Date:\n                    return new Date(value).toDateString();\n                case GridColumnDataType.DateTime:\n                    return new Date(value).toISOString();\n                case GridColumnDataType.Time:\n                    return typeof value === 'string' ? value : new Date(value).toLocaleTimeString();\n                default:\n                    return value;\n            }\n        };\n\n        const processExpression = (arr: any[], e: any): any[] => {\n            if (e.expression.condition.name === 'in') {\n                return [...arr, ...Array.from((e.expression.searchVal as Set<any>).values()).map(v => formatValue(v))];\n            }\n            return [...arr, formatValue(e.expression.searchVal)];\n        };\n\n        const filterValues = new Set<any>(this.expressionsList.reduce(processExpression, []));\n\n        return filterValues;\n    }\n\n    private generateListData() {\n        this.listData = new Array<FilterListItem>();\n        const shouldUpdateSelection = this.areExpressionsSelectable();\n\n        if (this.column.dataType === GridColumnDataType.Boolean) {\n            this.addBooleanItems();\n        } else {\n            this.addItems(shouldUpdateSelection);\n        }\n\n        if (!this.isHierarchical && this.containsNullOrEmpty) {\n            const blanksItem = this.generateBlanksItem(shouldUpdateSelection);\n            this.listData.unshift(blanksItem);\n        }\n\n        if (this.listData.length > 0) {\n            this.addSelectAllItem();\n        }\n\n        if (!(this.cdr as any).destroyed) {\n            this.cdr.detectChanges();\n        }\n\n        this.listDataLoaded.emit();\n    }\n\n    private getColumnFilterExpressionsTree() {\n        const gridExpressionsTree: IFilteringExpressionsTree = this.grid.filteringExpressionsTree;\n        const expressionsTree = new FilteringExpressionsTree(gridExpressionsTree.operator, gridExpressionsTree.fieldName);\n\n        for (const operand of gridExpressionsTree.filteringOperands) {\n            if (operand instanceof FilteringExpressionsTree) {\n                const columnExprTree = operand as FilteringExpressionsTree;\n                if (columnExprTree.fieldName === this.column.field) {\n                    continue;\n                }\n            }\n            expressionsTree.filteringOperands.push(operand);\n        }\n\n        return expressionsTree;\n    }\n\n    private addBooleanItems() {\n        this.selectAllSelected = true;\n        this.selectAllIndeterminate = false;\n        this.uniqueValues.forEach(element => {\n            const value = element.value;\n            const filterListItem = new FilterListItem();\n            if (value !== undefined && value !== null && value !== '') {\n                if (this.column.filteringExpressionsTree) {\n                    if (value === true && this.expressionsList.find(exp => exp.expression.condition.name === 'true')) {\n                        filterListItem.isSelected = true;\n                        filterListItem.isFiltered = true;\n                        this.selectAllIndeterminate = true;\n                    } else if (value === false && this.expressionsList.find(exp => exp.expression.condition.name === 'false')) {\n                        filterListItem.isSelected = true;\n                        filterListItem.isFiltered = true;\n                        this.selectAllIndeterminate = true;\n                    } else {\n                        filterListItem.isSelected = false;\n                        filterListItem.isFiltered = false;\n                    }\n                } else {\n                    filterListItem.isSelected = true;\n                    filterListItem.isFiltered = true;\n                }\n                filterListItem.value = value;\n                filterListItem.label = value ?\n                    this.grid.resourceStrings.igx_grid_filter_true :\n                    this.grid.resourceStrings.igx_grid_filter_false;\n                filterListItem.indeterminate = false;\n                this.listData.push(filterListItem);\n            } else {\n                this.containsNullOrEmpty = true;\n            }\n        });\n    }\n\n    private addItems(shouldUpdateSelection: boolean) {\n        this.selectAllSelected = true;\n        this.selectAllIndeterminate = false;\n        this.containsNullOrEmpty = false;\n        this.listData = this.generateFilterListItems(this.uniqueValues, shouldUpdateSelection);\n        this.containsNullOrEmpty = this.uniqueValues.length > this.listData.length;\n    }\n\n    private generateFilterListItems(values: IgxFilterItem[], shouldUpdateSelection: boolean, parent?: FilterListItem) {\n        const filterListItems = [];\n        values?.forEach(element => {\n            const value = element.value;\n            const hasValue = value !== undefined && value !== null && value !== '';\n\n            if (hasValue) {\n                const filterListItem = new FilterListItem();\n                filterListItem.parent = parent;\n                filterListItem.value = value;\n                filterListItem.label = element.label !== undefined ?\n                    element.label :\n                    this.getFilterItemLabel(value);\n                filterListItem.indeterminate = false;\n                filterListItem.isSelected = true;\n                filterListItem.isFiltered = true;\n\n                if (this.column.filteringExpressionsTree) {\n                    filterListItem.isSelected = false;\n                    filterListItem.isFiltered = false;\n\n                    if (shouldUpdateSelection) {\n                        const exprValue = this.getExpressionValue(value);\n                        if (this.filterValues.has(exprValue)) {\n                            filterListItem.isSelected = true;\n                            filterListItem.isFiltered = true;\n                        }\n                        this.selectAllIndeterminate = true;\n                    } else {\n                        this.selectAllSelected = false;\n                    }\n                }\n\n                filterListItem.children = this.generateFilterListItems(element.children ?? element.value?.children, shouldUpdateSelection, filterListItem);\n                filterListItems.push(filterListItem);\n            }\n        });\n\n        return filterListItems;\n    }\n\n    private addSelectAllItem() {\n        const selectAll = new FilterListItem();\n        selectAll.isSelected = this.selectAllSelected;\n        selectAll.value = this.grid.resourceStrings.igx_grid_excel_select_all;\n        selectAll.label = this.grid.resourceStrings.igx_grid_excel_select_all;\n        selectAll.indeterminate = this.selectAllIndeterminate;\n        selectAll.isSpecial = true;\n        selectAll.isFiltered = this.selectAllSelected;\n        this.listData.unshift(selectAll);\n    }\n\n    private generateBlanksItem(shouldUpdateSelection) {\n        const blanks = new FilterListItem();\n        if (this.column.filteringExpressionsTree) {\n            if (shouldUpdateSelection) {\n                if (this.filterValues.has(null)) {\n                    blanks.isSelected = true;\n                    blanks.isFiltered = true;\n                } else {\n                    blanks.isSelected = false;\n                    blanks.isFiltered = false;\n                }\n            }\n        } else {\n            blanks.isSelected = true;\n            blanks.isFiltered = true;\n        }\n        blanks.value = null;\n        blanks.label = this.grid.resourceStrings.igx_grid_excel_blanks;\n        blanks.indeterminate = false;\n        blanks.isSpecial = true;\n        blanks.isBlanks = true;\n\n        return blanks;\n    }\n\n    private getFilterItemLabel(value: any, applyFormatter = true, data?: any) {\n        if (this.column.formatter) {\n            if (applyFormatter) {\n                return this.column.formatter(value, data);\n            }\n            return value;\n        }\n\n        const { display, format, digitsInfo, currencyCode, timezone } = this.column.pipeArgs;\n        const locale = this.grid.locale;\n\n        switch (this.column.dataType) {\n            case GridColumnDataType.Date:\n            case GridColumnDataType.DateTime:\n            case GridColumnDataType.Time:\n                return formatDate(value, format, locale, timezone);\n            case GridColumnDataType.Currency:\n                return formatCurrency(value, currencyCode || getLocaleCurrencyCode(locale), display, digitsInfo, locale);\n            case GridColumnDataType.Number:\n                return formatNumber(value, locale, digitsInfo);\n            case GridColumnDataType.Percent:\n                return formatPercent(value, locale, digitsInfo);\n            default:\n                return value;\n        }\n    }\n\n    private getExpressionValue(value: any): string {\n        if (this.column.dataType === GridColumnDataType.Date) {\n            value = value ? new Date(value).toDateString() : value;\n        } else if (this.column.dataType === GridColumnDataType.DateTime) {\n            value = value ? new Date(value).toISOString() : value;\n        } else if (this.column.dataType === GridColumnDataType.Time) {\n            value = value ? new Date(value).toLocaleTimeString() : value;\n        }\n\n        return value;\n    }\n}\n","<ng-template #defaultExcelColumnOperations>\n    <igx-excel-style-header\n        [showHiding]=\"displayDensity !== 'comfortable' && !column?.disableHiding\"\n        [showPinning]=\"displayDensity !== 'comfortable' && !column?.disablePinning\"\n        [showSelecting]=\"displayDensity !== 'comfortable' && columnSelectable()\"\n    >\n    </igx-excel-style-header>\n\n    <igx-excel-style-sorting *ngIf=\"column?.sortable\">\n    </igx-excel-style-sorting>\n\n    <igx-excel-style-moving *ngIf=\"grid?.moving\">\n    </igx-excel-style-moving>\n\n    <igx-excel-style-pinning *ngIf=\"!column?.disablePinning && displayDensity==='comfortable'\">\n    </igx-excel-style-pinning>\n\n    <igx-excel-style-hiding *ngIf=\"!column?.disableHiding && displayDensity==='comfortable'\">\n    </igx-excel-style-hiding>\n\n    <igx-excel-style-selecting *ngIf=\"columnSelectable() && displayDensity==='comfortable'\">\n    </igx-excel-style-selecting>\n</ng-template>\n\n<ng-template #defaultExcelFilterOperations>\n    <igx-excel-style-clear-filters>\n    </igx-excel-style-clear-filters>\n\n    <igx-excel-style-conditional-filter>\n    </igx-excel-style-conditional-filter>\n\n    <igx-excel-style-search>\n    </igx-excel-style-search>\n</ng-template>\n\n<article #mainDropdown\n    class=\"igx-excel-filter__menu\"\n    [ngClass]=\"{\n        'igx-excel-filter__menu--cosy': displayDensity === 'cosy',\n        'igx-excel-filter__menu--compact': displayDensity === 'compact'\n    }\"\n    [id]=\"overlayComponentId\"\n    (keydown)=\"onKeyDown($event)\"\n    [style.min-height]=\"minHeight\"\n    [style.max-height]=\"maxHeight\"\n    role=\"menu\">\n\n    <ng-container *ngIf=\"this.excelColumnOperationsDirective; else defaultExcelColumnOperations\">\n        <ng-content select=\"igx-excel-style-column-operations,[igxExcelStyleColumnOperations]\">\n        </ng-content>\n    </ng-container>\n\n    <ng-container *ngIf=\"this.excelFilterOperationsDirective; else defaultExcelFilterOperations\">\n        <ng-content select=\"igx-excel-style-filter-operations,[igxExcelStyleFilterOperations]\">\n        </ng-content>\n    </ng-container>\n</article>\n"]}
|
|
699
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"excel-style-filtering.component.js","sourceRoot":"","sources":["../../../../../../../projects/igniteui-angular/src/lib/grids/filtering/excel-style/excel-style-filtering.component.ts","../../../../../../../projects/igniteui-angular/src/lib/grids/filtering/excel-style/excel-style-filtering.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewChecked,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Host,\n    HostBinding,\n    Inject,\n    Input,\n    OnDestroy,\n    Optional,\n    Output,\n    TemplateRef,\n    ViewChild,\n    ViewRef\n} from '@angular/core';\nimport { FilteringExpressionsTree, IFilteringExpressionsTree } from '../../../data-operations/filtering-expressions-tree';\nimport { PlatformUtil, formatDate, formatCurrency } from '../../../core/utils';\nimport { GridColumnDataType } from '../../../data-operations/data-util';\nimport { Subject, Subscription } from 'rxjs';\nimport { DisplayDensity } from '../../../core/density';\nimport { GridSelectionMode } from '../../common/enums';\nimport { IgxFilterItem } from '../../../data-operations/filtering-strategy';\nimport { formatNumber, formatPercent, getLocaleCurrencyCode, NgIf, NgClass, DOCUMENT } from '@angular/common';\nimport { BaseFilteringComponent } from './base-filtering.component';\nimport { ExpressionUI, FilterListItem, generateExpressionsList } from './common';\nimport { ColumnType, GridType, IGX_GRID_BASE } from '../../common/grid.interface';\nimport { IgxOverlayService } from '../../../services/overlay/overlay';\nimport { SortingDirection } from '../../../data-operations/sorting-strategy';\nimport { IgxExcelStyleSearchComponent } from './excel-style-search.component';\nimport { IgxExcelStyleConditionalFilterComponent } from './excel-style-conditional-filter.component';\nimport { IgxExcelStyleClearFiltersComponent } from './excel-style-clear-filters.component';\nimport { IgxExcelStyleSelectingComponent } from './excel-style-selecting.component';\nimport { IgxExcelStyleHidingComponent } from './excel-style-hiding.component';\nimport { IgxExcelStylePinningComponent } from './excel-style-pinning.component';\nimport { IgxExcelStyleMovingComponent } from './excel-style-moving.component';\nimport { IgxExcelStyleSortingComponent } from './excel-style-sorting.component';\nimport { IgxExcelStyleHeaderComponent } from './excel-style-header.component';\n\n@Directive({\n    selector: 'igx-excel-style-column-operations,[igxExcelStyleColumnOperations]',\n    standalone: true\n})\nexport class IgxExcelStyleColumnOperationsTemplateDirective { }\n\n@Directive({\n    selector: 'igx-excel-style-filter-operations,[igxExcelStyleFilterOperations]',\n    standalone: true\n})\nexport class IgxExcelStyleFilterOperationsTemplateDirective { }\n\n/**\n * A component used for presenting Excel style filtering UI for a specific column.\n * It is used internally in the Grid, but could also be hosted in a container outside of it.\n *\n * Example:\n * ```html\n * <igx-grid-excel-style-filtering\n *     [column]=\"grid1.columns[0]\">\n * </igx-grid-excel-style-filtering>\n * ```\n */\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [{ provide: BaseFilteringComponent, useExisting: forwardRef(() => IgxGridExcelStyleFilteringComponent) }],\n    selector: 'igx-grid-excel-style-filtering',\n    templateUrl: './excel-style-filtering.component.html',\n    standalone: true,\n    imports: [IgxExcelStyleHeaderComponent, NgIf, IgxExcelStyleSortingComponent, IgxExcelStyleMovingComponent, IgxExcelStylePinningComponent, IgxExcelStyleHidingComponent, IgxExcelStyleSelectingComponent, IgxExcelStyleClearFiltersComponent, IgxExcelStyleConditionalFilterComponent, IgxExcelStyleSearchComponent, NgClass]\n})\nexport class IgxGridExcelStyleFilteringComponent extends BaseFilteringComponent implements AfterViewChecked, OnDestroy {\n\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('class.igx-excel-filter')\n    public defaultClass = true;\n\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('class.igx-excel-filter--inline')\n    public inline = true;\n\n    /**\n     * @hidden @internal\n     */\n    @Output()\n    public loadingStart = new EventEmitter();\n\n    /**\n     * @hidden @internal\n     */\n    @Output()\n    public loadingEnd = new EventEmitter();\n\n    /**\n     * @hidden @internal\n     */\n    @Output()\n    public initialized = new EventEmitter();\n\n    /**\n     * @hidden @internal\n     */\n    @Output()\n    public sortingChanged = new EventEmitter();\n\n    /**\n     * @hidden @internal\n     */\n    @Output()\n    public columnChange = new EventEmitter<ColumnType>();\n\n    /**\n     * @hidden @internal\n     */\n    @Output()\n    public listDataLoaded = new EventEmitter();\n\n    @ViewChild('mainDropdown', { read: ElementRef })\n    public mainDropdown: ElementRef<HTMLElement>;\n\n    /**\n     * @hidden @internal\n     */\n    @ContentChild(IgxExcelStyleColumnOperationsTemplateDirective, { read: IgxExcelStyleColumnOperationsTemplateDirective })\n    public excelColumnOperationsDirective: IgxExcelStyleColumnOperationsTemplateDirective;\n\n    /**\n     * @hidden @internal\n     */\n    @ContentChild(IgxExcelStyleFilterOperationsTemplateDirective, { read: IgxExcelStyleFilterOperationsTemplateDirective })\n    public excelFilterOperationsDirective: IgxExcelStyleFilterOperationsTemplateDirective;\n\n    /**\n     * @hidden @internal\n     */\n    @ViewChild('defaultExcelColumnOperations', { read: TemplateRef, static: true })\n    protected defaultExcelColumnOperations: TemplateRef<any>;\n\n    /**\n     * @hidden @internal\n     */\n    @ViewChild('defaultExcelFilterOperations', { read: TemplateRef, static: true })\n    protected defaultExcelFilterOperations: TemplateRef<any>;\n\n    /**\n     * Sets the column.\n     */\n    @Input()\n    public set column(value: ColumnType) {\n        this._column = value;\n        this.listData = new Array<FilterListItem>();\n        this.columnChange.emit(this._column);\n\n        this.subscriptions?.unsubscribe();\n\n        if (this._column) {\n            this.grid.filteringService.registerSVGIcons();\n            this.init();\n            this.sortingChanged.emit();\n\n            this.subscriptions = this.grid.columnPin.subscribe(() => {\n                requestAnimationFrame(() => {\n                    if (!(this.cdr as ViewRef).destroyed) {\n                        this.cdr.detectChanges();\n                    }\n                });\n            });\n\n            this.subscriptions.add(this.grid.columnVisibilityChanged.subscribe(() => this.detectChanges()));\n            this.subscriptions.add(this.grid.sortingExpressionsChange.subscribe(() => this.sortingChanged.emit()));\n            this.subscriptions.add(this.grid.filteringExpressionsTreeChange.subscribe(() => this.init()));\n            this.subscriptions.add(this.grid.densityChanged.subscribe(() => this.detectChanges()));\n            this.subscriptions.add(this.grid.columnMovingEnd.subscribe(() => this.cdr.markForCheck()));\n        }\n    }\n\n    /**\n     * Returns the current column.\n     */\n    public get column(): ColumnType {\n        return this._column;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public expressionsList = new Array<ExpressionUI>();\n    /**\n     * @hidden @internal\n     */\n    public listData = new Array<FilterListItem>();\n    /**\n     * @hidden @internal\n     */\n    public uniqueValues: IgxFilterItem[] = [];\n    /**\n     * @hidden @internal\n     */\n    public overlayService: IgxOverlayService;\n    /**\n     * @hidden @internal\n     */\n    public overlayComponentId: string;\n    /**\n     * @hidden @internal\n     */\n    public isHierarchical = false;\n\n    private _minHeight;\n    private _sizeSubscription: Subscription;\n    private _size: string;\n    private _size$ = new Subject();\n\n    /**\n     * Gets the minimum height.\n     * \n     * Setting value in template: \n     * ```ts\n     * [minHeight]=\"'<number><unit (px|rem|etc..)>'\" \n     * ```\n     * \n     * Example for setting a value: \n     * ```ts\n     * [minHeight]=\"'700px'\"\n     * ```\n     */\n    @Input()\n    public get minHeight(): string {\n        if (this._minHeight || this._minHeight === 0) {\n            return this._minHeight;\n        }\n\n        if (!this.inline) {\n            let minHeight = 645;\n            switch (this.displayDensity) {\n                case DisplayDensity.cosy: minHeight = 465; break;\n                case DisplayDensity.compact: minHeight = 330; break;\n                default: break;\n            }\n            return `${minHeight}px`;\n        }\n    }\n\n    /**\n     * Sets the minimum height.\n     */\n    public set minHeight(value: string) {\n        this._minHeight = value;\n    }\n\n\n    private _maxHeight: string;\n    private containsNullOrEmpty = false;\n    private selectAllSelected = true;\n    private selectAllIndeterminate = false;\n    private filterValues = new Set<any>();\n    private _column: ColumnType;\n    private subscriptions: Subscription;\n    private _originalDisplay: string;\n\n    /**\n     * Gets the maximum height.\n     * \n     * Setting value in template: \n     * ```ts\n     * [maxHeight]=\"'<number><unit (px|rem|etc..)>'\" \n     * ```\n     * \n     * Example for setting a value: \n     * ```ts\n     * [maxHeight]=\"'700px'\"\n     * ```\n     */\n    @Input()\n    @HostBinding('style.max-height')\n    public get maxHeight(): string {\n        if (this._maxHeight) {\n            return this._maxHeight;\n        }\n\n        if (!this.inline) {\n            let maxHeight = 775;\n            switch (this.displayDensity) {\n                case DisplayDensity.cosy: maxHeight = 565; break;\n                case DisplayDensity.compact: maxHeight = 405; break;\n                default: break;\n            }\n            return `${maxHeight}px`;\n        }\n    }\n\n    /**\n     * Sets the maximum height.\n     */\n    public set maxHeight(value: string) {\n        this._maxHeight = value;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get grid(): GridType {\n        return this.column?.grid ?? this.gridAPI;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get displayDensity() {\n        switch (this._size) {\n            case '1':\n                return DisplayDensity.compact;\n            case '2':\n                return DisplayDensity.cosy;\n            case '3':\n            default:\n                return DisplayDensity.comfortable;\n        }\n    }\n\n    constructor(\n        cdr: ChangeDetectorRef,\n        element: ElementRef<HTMLElement>,\n        platform: PlatformUtil,\n        @Inject(DOCUMENT)\n        private document: any,\n        @Host() @Optional() @Inject(IGX_GRID_BASE) protected gridAPI?: GridType) {\n        super(cdr, element, platform);\n\n        this._sizeSubscription = this._size$.asObservable().subscribe(value => {\n            this._size = value as string;\n            this.cdr.detectChanges();\n        });\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public ngOnDestroy(): void {\n        this.subscriptions?.unsubscribe();\n        this._sizeSubscription?.unsubscribe();\n        delete this.overlayComponentId;\n    }\n\n    /** @hidden @internal */\n    public ngAfterViewChecked() {\n        // TODO: Should only check for the value of `--ig-size` in 17.0;\n        const sizeVar = this.grid ? '--grid-size' : '--ig-size';\n\n        if (!this._size) {\n            const cssProp = this.document.defaultView\n                .getComputedStyle(this.element.nativeElement)\n                .getPropertyValue(sizeVar)\n                .trim();\n\n            if (cssProp !== '') {\n                Promise.resolve().then(() => {\n                    this._size$.next(cssProp);\n                    this.cdr.markForCheck();\n                });\n            }\n        }\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public initialize(column: ColumnType, overlayService: IgxOverlayService) {\n        this.inline = false;\n        this.column = column;\n        this.overlayService = overlayService;\n        if (this._originalDisplay) {\n            this.element.nativeElement.style.display = this._originalDisplay;\n        }\n\n        this.initialized.emit();\n        this.subscriptions.add(this.grid.columnMoving.subscribe(() => this.closeDropdown()));\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onPin() {\n        this.closeDropdown();\n        this.column.pinned = !this.column.pinned;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onSelect() {\n        if (!this.column.selected) {\n            this.grid.selectionService.selectColumn(this.column.field, this.grid.columnSelection === GridSelectionMode.single);\n        } else {\n            this.grid.selectionService.deselectColumn(this.column.field);\n        }\n        this.grid.notifyChanges();\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public columnSelectable() {\n        return this.grid?.columnSelection !== GridSelectionMode.none && this.column?.selectable;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onHideToggle() {\n        this.column.toggleVisibility();\n        this.closeDropdown();\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public cancel() {\n        if (!this.overlayComponentId) {\n            this.init();\n        }\n        this.closeDropdown();\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public closeDropdown() {\n        if (this.overlayComponentId) {\n            this.overlayService.hide(this.overlayComponentId);\n            this.overlayComponentId = null;\n        }\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onKeyDown(eventArgs: KeyboardEvent) {\n        if (this.platform.isFilteringKeyCombo(eventArgs)) {\n            eventArgs.preventDefault();\n            this.closeDropdown();\n        }\n        eventArgs.stopPropagation();\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public hide() {\n        this._originalDisplay = document.defaultView.getComputedStyle(this.element.nativeElement).display;\n        this.element.nativeElement.style.display = 'none';\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public detectChanges() {\n        this.cdr.detectChanges();\n    }\n\n    private init() {\n        this.expressionsList = new Array<ExpressionUI>();\n        generateExpressionsList(this.column.filteringExpressionsTree, this.grid.filteringLogic, this.expressionsList);\n        this.populateColumnData();\n    }\n\n    private areExpressionsSelectable() {\n        if (this.expressionsList.length === 1 &&\n            (this.expressionsList[0].expression.condition.name === 'equals' ||\n                this.expressionsList[0].expression.condition.name === 'at' ||\n                this.expressionsList[0].expression.condition.name === 'true' ||\n                this.expressionsList[0].expression.condition.name === 'false' ||\n                this.expressionsList[0].expression.condition.name === 'empty' ||\n                this.expressionsList[0].expression.condition.name === 'in')) {\n            return true;\n        }\n\n        const selectableExpressionsCount = this.expressionsList.filter(exp =>\n            (exp.beforeOperator === 1 || exp.afterOperator === 1) &&\n            (exp.expression.condition.name === 'equals' ||\n                exp.expression.condition.name === 'at' ||\n                exp.expression.condition.name === 'true' ||\n                exp.expression.condition.name === 'false' ||\n                exp.expression.condition.name === 'empty' ||\n                exp.expression.condition.name === 'in')).length;\n\n        return selectableExpressionsCount === this.expressionsList.length;\n    }\n\n    private populateColumnData() {\n        this.cdr.detectChanges();\n\n        if (this.grid.uniqueColumnValuesStrategy) {\n            this.renderColumnValuesRemotely();\n        } else {\n            this.renderColumnValuesFromData();\n        }\n    }\n\n    private renderColumnValuesRemotely() {\n        this.loadingStart.emit();\n        const expressionsTree: FilteringExpressionsTree = this.getColumnFilterExpressionsTree();\n\n        const prevColumn = this.column;\n        this.grid.uniqueColumnValuesStrategy(this.column, expressionsTree, (values: any[]) => {\n            if (!this.column || this.column !== prevColumn) {\n                return;\n            }\n\n            const items = values.map(v => ({\n                value: v\n            }));\n\n            this.uniqueValues = this.column.sortStrategy.sort(items, 'value', SortingDirection.Asc, this.column.sortingIgnoreCase,\n                (obj, key) => {\n                    let resolvedValue = obj[key];\n                    if (this.column.dataType === GridColumnDataType.Time) {\n                        resolvedValue = new Date().setHours(\n                            resolvedValue.getHours(),\n                            resolvedValue.getMinutes(),\n                            resolvedValue.getSeconds(),\n                            resolvedValue.getMilliseconds());\n                    }\n\n                    return resolvedValue;\n                });\n\n            this.renderValues();\n            this.loadingEnd.emit();\n        });\n    }\n\n    private renderColumnValuesFromData() {\n        this.loadingStart.emit();\n\n        const expressionsTree = this.getColumnFilterExpressionsTree();\n        const promise = this.grid.filterStrategy.getFilterItems(this.column, expressionsTree);\n        promise.then((items) => {\n            this.isHierarchical = items.length > 0 && items.some(i => i.children && i.children.length > 0);\n            this.uniqueValues = items;\n            this.renderValues();\n            this.loadingEnd.emit();\n            this.sortingChanged.emit();\n        });\n    }\n\n    private renderValues() {\n        this.filterValues = this.generateFilterValues();\n        this.generateListData();\n    }\n\n    private generateFilterValues() {\n        const formatValue = (value: any): any => {\n            if (!value) return value;\n\n            switch (this.column.dataType) {\n                case GridColumnDataType.Date:\n                    return new Date(value).toDateString();\n                case GridColumnDataType.DateTime:\n                    return new Date(value).toISOString();\n                case GridColumnDataType.Time:\n                    return typeof value === 'string' ? value : new Date(value).toLocaleTimeString();\n                default:\n                    return value;\n            }\n        };\n\n        const processExpression = (arr: any[], e: any): any[] => {\n            if (e.expression.condition.name === 'in') {\n                return [...arr, ...Array.from((e.expression.searchVal as Set<any>).values()).map(v => formatValue(v))];\n            }\n            return [...arr, formatValue(e.expression.searchVal)];\n        };\n\n        const filterValues = new Set<any>(this.expressionsList.reduce(processExpression, []));\n\n        return filterValues;\n    }\n\n    private generateListData() {\n        this.listData = new Array<FilterListItem>();\n        const shouldUpdateSelection = this.areExpressionsSelectable();\n\n        if (this.column.dataType === GridColumnDataType.Boolean) {\n            this.addBooleanItems();\n        } else {\n            this.addItems(shouldUpdateSelection);\n        }\n\n        if (!this.isHierarchical && this.containsNullOrEmpty) {\n            const blanksItem = this.generateBlanksItem(shouldUpdateSelection);\n            this.listData.unshift(blanksItem);\n        }\n\n        if (this.listData.length > 0) {\n            this.addSelectAllItem();\n        }\n\n        if (!(this.cdr as any).destroyed) {\n            this.cdr.detectChanges();\n        }\n\n        this.listDataLoaded.emit();\n    }\n\n    private getColumnFilterExpressionsTree() {\n        const gridExpressionsTree: IFilteringExpressionsTree = this.grid.filteringExpressionsTree;\n        const expressionsTree = new FilteringExpressionsTree(gridExpressionsTree.operator, gridExpressionsTree.fieldName);\n\n        for (const operand of gridExpressionsTree.filteringOperands) {\n            if (operand instanceof FilteringExpressionsTree) {\n                const columnExprTree = operand as FilteringExpressionsTree;\n                if (columnExprTree.fieldName === this.column.field) {\n                    continue;\n                }\n            }\n            expressionsTree.filteringOperands.push(operand);\n        }\n\n        return expressionsTree;\n    }\n\n    private addBooleanItems() {\n        this.selectAllSelected = true;\n        this.selectAllIndeterminate = false;\n        this.uniqueValues.forEach(element => {\n            const value = element.value;\n            const filterListItem = new FilterListItem();\n            if (value !== undefined && value !== null && value !== '') {\n                if (this.column.filteringExpressionsTree) {\n                    if (value === true && this.expressionsList.find(exp => exp.expression.condition.name === 'true')) {\n                        filterListItem.isSelected = true;\n                        filterListItem.isFiltered = true;\n                        this.selectAllIndeterminate = true;\n                    } else if (value === false && this.expressionsList.find(exp => exp.expression.condition.name === 'false')) {\n                        filterListItem.isSelected = true;\n                        filterListItem.isFiltered = true;\n                        this.selectAllIndeterminate = true;\n                    } else {\n                        filterListItem.isSelected = false;\n                        filterListItem.isFiltered = false;\n                    }\n                } else {\n                    filterListItem.isSelected = true;\n                    filterListItem.isFiltered = true;\n                }\n                filterListItem.value = value;\n                filterListItem.label = value ?\n                    this.grid.resourceStrings.igx_grid_filter_true :\n                    this.grid.resourceStrings.igx_grid_filter_false;\n                filterListItem.indeterminate = false;\n                this.listData.push(filterListItem);\n            } else {\n                this.containsNullOrEmpty = true;\n            }\n        });\n    }\n\n    private addItems(shouldUpdateSelection: boolean) {\n        this.selectAllSelected = true;\n        this.selectAllIndeterminate = false;\n        this.containsNullOrEmpty = false;\n        this.listData = this.generateFilterListItems(this.uniqueValues, shouldUpdateSelection);\n        this.containsNullOrEmpty = this.uniqueValues.length > this.listData.length;\n    }\n\n    private generateFilterListItems(values: IgxFilterItem[], shouldUpdateSelection: boolean, parent?: FilterListItem) {\n        const filterListItems = [];\n        values?.forEach(element => {\n            const value = element.value;\n            const hasValue = value !== undefined && value !== null && value !== '';\n\n            if (hasValue) {\n                const filterListItem = new FilterListItem();\n                filterListItem.parent = parent;\n                filterListItem.value = value;\n                filterListItem.label = element.label !== undefined ?\n                    element.label :\n                    this.getFilterItemLabel(value);\n                filterListItem.indeterminate = false;\n                filterListItem.isSelected = true;\n                filterListItem.isFiltered = true;\n\n                if (this.column.filteringExpressionsTree) {\n                    filterListItem.isSelected = false;\n                    filterListItem.isFiltered = false;\n\n                    if (shouldUpdateSelection) {\n                        const exprValue = this.getExpressionValue(value);\n                        if (this.filterValues.has(exprValue)) {\n                            filterListItem.isSelected = true;\n                            filterListItem.isFiltered = true;\n                        }\n                        this.selectAllIndeterminate = true;\n                    } else {\n                        this.selectAllSelected = false;\n                    }\n                }\n\n                filterListItem.children = this.generateFilterListItems(element.children ?? element.value?.children, shouldUpdateSelection, filterListItem);\n                filterListItems.push(filterListItem);\n            }\n        });\n\n        return filterListItems;\n    }\n\n    private addSelectAllItem() {\n        const selectAll = new FilterListItem();\n        selectAll.isSelected = this.selectAllSelected;\n        selectAll.value = this.grid.resourceStrings.igx_grid_excel_select_all;\n        selectAll.label = this.grid.resourceStrings.igx_grid_excel_select_all;\n        selectAll.indeterminate = this.selectAllIndeterminate;\n        selectAll.isSpecial = true;\n        selectAll.isFiltered = this.selectAllSelected;\n        this.listData.unshift(selectAll);\n    }\n\n    private generateBlanksItem(shouldUpdateSelection) {\n        const blanks = new FilterListItem();\n        if (this.column.filteringExpressionsTree) {\n            if (shouldUpdateSelection) {\n                if (this.filterValues.has(null)) {\n                    blanks.isSelected = true;\n                    blanks.isFiltered = true;\n                } else {\n                    blanks.isSelected = false;\n                    blanks.isFiltered = false;\n                }\n            }\n        } else {\n            blanks.isSelected = true;\n            blanks.isFiltered = true;\n        }\n        blanks.value = null;\n        blanks.label = this.grid.resourceStrings.igx_grid_excel_blanks;\n        blanks.indeterminate = false;\n        blanks.isSpecial = true;\n        blanks.isBlanks = true;\n\n        return blanks;\n    }\n\n    private getFilterItemLabel(value: any, applyFormatter = true, data?: any) {\n        if (this.column.formatter) {\n            if (applyFormatter) {\n                return this.column.formatter(value, data);\n            }\n            return value;\n        }\n\n        const { display, format, digitsInfo, currencyCode, timezone } = this.column.pipeArgs;\n        const locale = this.grid.locale;\n\n        switch (this.column.dataType) {\n            case GridColumnDataType.Date:\n            case GridColumnDataType.DateTime:\n            case GridColumnDataType.Time:\n                return formatDate(value, format, locale, timezone);\n            case GridColumnDataType.Currency:\n                return formatCurrency(value, currencyCode || getLocaleCurrencyCode(locale), display, digitsInfo, locale);\n            case GridColumnDataType.Number:\n                return formatNumber(value, locale, digitsInfo);\n            case GridColumnDataType.Percent:\n                return formatPercent(value, locale, digitsInfo);\n            default:\n                return value;\n        }\n    }\n\n    private getExpressionValue(value: any): string {\n        if (this.column.dataType === GridColumnDataType.Date) {\n            value = value ? new Date(value).toDateString() : value;\n        } else if (this.column.dataType === GridColumnDataType.DateTime) {\n            value = value ? new Date(value).toISOString() : value;\n        } else if (this.column.dataType === GridColumnDataType.Time) {\n            value = value ? new Date(value).toLocaleTimeString() : value;\n        }\n\n        return value;\n    }\n}\n","<ng-template #defaultExcelColumnOperations>\n    <igx-excel-style-header\n        [showHiding]=\"displayDensity !== 'comfortable' && !column?.disableHiding\"\n        [showPinning]=\"displayDensity !== 'comfortable' && !column?.disablePinning\"\n        [showSelecting]=\"displayDensity !== 'comfortable' && columnSelectable()\"\n    >\n    </igx-excel-style-header>\n\n    <igx-excel-style-sorting *ngIf=\"column?.sortable\">\n    </igx-excel-style-sorting>\n\n    <igx-excel-style-moving *ngIf=\"grid?.moving\">\n    </igx-excel-style-moving>\n\n    <igx-excel-style-pinning *ngIf=\"!column?.disablePinning && displayDensity==='comfortable'\">\n    </igx-excel-style-pinning>\n\n    <igx-excel-style-hiding *ngIf=\"!column?.disableHiding && displayDensity==='comfortable'\">\n    </igx-excel-style-hiding>\n\n    <igx-excel-style-selecting *ngIf=\"columnSelectable() && displayDensity==='comfortable'\">\n    </igx-excel-style-selecting>\n</ng-template>\n\n<ng-template #defaultExcelFilterOperations>\n    <igx-excel-style-clear-filters>\n    </igx-excel-style-clear-filters>\n\n    <igx-excel-style-conditional-filter>\n    </igx-excel-style-conditional-filter>\n\n    <igx-excel-style-search>\n    </igx-excel-style-search>\n</ng-template>\n\n<article #mainDropdown\n    class=\"igx-excel-filter__menu\"\n    [ngClass]=\"{\n        'igx-excel-filter__menu--cosy': displayDensity === 'cosy',\n        'igx-excel-filter__menu--compact': displayDensity === 'compact'\n    }\"\n    [id]=\"overlayComponentId\"\n    (keydown)=\"onKeyDown($event)\"\n    [style.min-height]=\"minHeight\"\n    [style.max-height]=\"maxHeight\"\n    role=\"menu\">\n\n    <ng-container *ngIf=\"this.excelColumnOperationsDirective; else defaultExcelColumnOperations\">\n        <ng-content select=\"igx-excel-style-column-operations,[igxExcelStyleColumnOperations]\">\n        </ng-content>\n    </ng-container>\n\n    <ng-container *ngIf=\"this.excelFilterOperationsDirective; else defaultExcelFilterOperations\">\n        <ng-content select=\"igx-excel-style-filter-operations,[igxExcelStyleFilterOperations]\">\n        </ng-content>\n    </ng-container>\n</article>\n"]}
|
|
@@ -39,14 +39,14 @@ export class IgxGridGroupByAreaComponent extends IgxGroupByAreaDirective {
|
|
|
39
39
|
this.grid.clearGrouping(name);
|
|
40
40
|
}
|
|
41
41
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: IgxGridGroupByAreaComponent, deps: [{ token: i0.ElementRef }, { token: i1.PlatformUtil }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
42
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: IgxGridGroupByAreaComponent, isStandalone: true, selector: "igx-grid-group-by-area", inputs: { sortingExpressions: "sortingExpressions", grid: "grid" }, providers: [{ provide: IgxGroupByAreaDirective, useExisting: IgxGridGroupByAreaComponent }], usesInheritance: true, ngImport: i0, template: "<igx-chips-area (reorder)=\"handleReorder($event)\" (moveEnd)=\"handleMoveEnd()\">\n <ng-container *ngFor=\"let expression of chipExpressions; let last = last;\">\n <igx-chip\n [id]=\"expression.fieldName\"\n [title]=\"(expression.fieldName | igxGroupByMeta:grid).title\"\n [displayDensity]=\"grid.displayDensity\"\n [removable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n [draggable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n [disabled]=\"!(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n (keyDown)=\"handleKeyDown($event.owner.id, $event.originalEvent)\"\n (remove)=\"clearGrouping($event.owner.id)\"\n (chipClick)=\"handleClick(expression.fieldName)\"\n >\n <span>{{ (expression.fieldName | igxGroupByMeta:grid).title }}</span>\n <igx-icon igxSuffix>{{ expression.dir === 1 ? 'arrow_upward' : 'arrow_downward' }}</igx-icon>\n </igx-chip>\n\n <span class=\"igx-grid-grouparea__connector\">\n <igx-icon [hidden]=\"(last && !dropAreaVisible)\">arrow_forward</igx-icon>\n </span>\n </ng-container>\n <div igxGroupAreaDrop\n class=\"igx-drop-area\"\n [attr.gridId]=\"grid.id\"\n [hidden]=\"!dropAreaVisible\"\n (igxDrop)=\"onDragDrop($event)\"\n >\n <ng-container *ngTemplateOutlet=\"dropAreaTemplate || default\"></ng-container>\n </div>\n</igx-chips-area>\n\n<ng-template #default>\n <igx-icon class=\"igx-drop-area__icon\">group_work</igx-icon>\n <span class=\"igx-drop-area__text\">{{ dropAreaMessage }}</span>\n</ng-template>\n", dependencies: [{ kind: "component", type: IgxChipsAreaComponent, selector: "igx-chips-area", inputs: ["width", "height"], outputs: ["reorder", "selectionChange", "moveStart", "moveEnd"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: IgxChipComponent, selector: "igx-chip", inputs: ["variant", "id", "tabIndex", "data", "draggable", "animateOnRelease", "hideBaseOnDrag", "removable", "removeIcon", "selectable", "selectIcon", "class", "disabled", "selected", "color", "resourceStrings"], outputs: ["selectedChange", "moveStart", "moveEnd", "remove", "chipClick", "selectedChanging", "selectedChanged", "keyDown", "dragEnter", "dragLeave", "dragOver", "dragDrop"] }, { kind: "component", type: IgxIconComponent, selector: "igx-icon", inputs: ["family", "active", "name"] }, { kind: "directive", type: IgxSuffixDirective, selector: "igx-suffix,[igxSuffix],[igxEnd]" }, { kind: "directive", type: IgxGroupAreaDropDirective, selector: "[igxGroupAreaDrop]" }, { kind: "directive", type: IgxDropDirective, selector: "[igxDrop]", inputs: ["igxDrop", "dropChannel", "dropStrategy"], outputs: ["enter", "over", "leave", "dropped"], exportAs: ["drop"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: IgxGroupByMetaPipe, name: "igxGroupByMeta" }] }); }
|
|
42
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: IgxGridGroupByAreaComponent, isStandalone: true, selector: "igx-grid-group-by-area", inputs: { sortingExpressions: "sortingExpressions", grid: "grid" }, providers: [{ provide: IgxGroupByAreaDirective, useExisting: IgxGridGroupByAreaComponent }], usesInheritance: true, ngImport: i0, template: "<igx-chips-area (reorder)=\"handleReorder($event)\" (moveEnd)=\"handleMoveEnd()\">\n <ng-container *ngFor=\"let expression of chipExpressions; let last = last;\">\n <igx-chip\n [id]=\"expression.fieldName\"\n [title]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).title\"\n [displayDensity]=\"grid.displayDensity\"\n [removable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n [draggable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n [disabled]=\"!(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n (keyDown)=\"handleKeyDown($event.owner.id, $event.originalEvent)\"\n (remove)=\"clearGrouping($event.owner.id)\"\n (chipClick)=\"handleClick(expression.fieldName)\"\n >\n <span>{{ (expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).title }}</span>\n <igx-icon igxSuffix>{{ expression.dir === 1 ? 'arrow_upward' : 'arrow_downward' }}</igx-icon>\n </igx-chip>\n\n <span class=\"igx-grid-grouparea__connector\">\n <igx-icon [hidden]=\"(last && !dropAreaVisible)\">arrow_forward</igx-icon>\n </span>\n </ng-container>\n <div igxGroupAreaDrop\n class=\"igx-drop-area\"\n [attr.gridId]=\"grid.id\"\n [hidden]=\"!dropAreaVisible\"\n (igxDrop)=\"onDragDrop($event)\"\n >\n <ng-container *ngTemplateOutlet=\"dropAreaTemplate || default\"></ng-container>\n </div>\n</igx-chips-area>\n\n<ng-template #default>\n <igx-icon class=\"igx-drop-area__icon\">group_work</igx-icon>\n <span class=\"igx-drop-area__text\">{{ dropAreaMessage }}</span>\n</ng-template>\n", dependencies: [{ kind: "component", type: IgxChipsAreaComponent, selector: "igx-chips-area", inputs: ["width", "height"], outputs: ["reorder", "selectionChange", "moveStart", "moveEnd"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: IgxChipComponent, selector: "igx-chip", inputs: ["variant", "id", "tabIndex", "data", "draggable", "animateOnRelease", "hideBaseOnDrag", "removable", "removeIcon", "selectable", "selectIcon", "class", "disabled", "selected", "color", "resourceStrings"], outputs: ["selectedChange", "moveStart", "moveEnd", "remove", "chipClick", "selectedChanging", "selectedChanged", "keyDown", "dragEnter", "dragLeave", "dragOver", "dragDrop"] }, { kind: "component", type: IgxIconComponent, selector: "igx-icon", inputs: ["family", "active", "name"] }, { kind: "directive", type: IgxSuffixDirective, selector: "igx-suffix,[igxSuffix],[igxEnd]" }, { kind: "directive", type: IgxGroupAreaDropDirective, selector: "[igxGroupAreaDrop]" }, { kind: "directive", type: IgxDropDirective, selector: "[igxDrop]", inputs: ["igxDrop", "dropChannel", "dropStrategy"], outputs: ["enter", "over", "leave", "dropped"], exportAs: ["drop"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: IgxGroupByMetaPipe, name: "igxGroupByMeta" }] }); }
|
|
43
43
|
}
|
|
44
44
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: IgxGridGroupByAreaComponent, decorators: [{
|
|
45
45
|
type: Component,
|
|
46
|
-
args: [{ selector: 'igx-grid-group-by-area', providers: [{ provide: IgxGroupByAreaDirective, useExisting: IgxGridGroupByAreaComponent }], standalone: true, imports: [IgxChipsAreaComponent, NgFor, IgxChipComponent, IgxIconComponent, IgxSuffixDirective, IgxGroupAreaDropDirective, IgxDropDirective, NgTemplateOutlet, IgxGroupByMetaPipe], template: "<igx-chips-area (reorder)=\"handleReorder($event)\" (moveEnd)=\"handleMoveEnd()\">\n <ng-container *ngFor=\"let expression of chipExpressions; let last = last;\">\n <igx-chip\n [id]=\"expression.fieldName\"\n [title]=\"(expression.fieldName | igxGroupByMeta:grid).title\"\n [displayDensity]=\"grid.displayDensity\"\n [removable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n [draggable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n [disabled]=\"!(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n (keyDown)=\"handleKeyDown($event.owner.id, $event.originalEvent)\"\n (remove)=\"clearGrouping($event.owner.id)\"\n (chipClick)=\"handleClick(expression.fieldName)\"\n >\n <span>{{ (expression.fieldName | igxGroupByMeta:grid).title }}</span>\n <igx-icon igxSuffix>{{ expression.dir === 1 ? 'arrow_upward' : 'arrow_downward' }}</igx-icon>\n </igx-chip>\n\n <span class=\"igx-grid-grouparea__connector\">\n <igx-icon [hidden]=\"(last && !dropAreaVisible)\">arrow_forward</igx-icon>\n </span>\n </ng-container>\n <div igxGroupAreaDrop\n class=\"igx-drop-area\"\n [attr.gridId]=\"grid.id\"\n [hidden]=\"!dropAreaVisible\"\n (igxDrop)=\"onDragDrop($event)\"\n >\n <ng-container *ngTemplateOutlet=\"dropAreaTemplate || default\"></ng-container>\n </div>\n</igx-chips-area>\n\n<ng-template #default>\n <igx-icon class=\"igx-drop-area__icon\">group_work</igx-icon>\n <span class=\"igx-drop-area__text\">{{ dropAreaMessage }}</span>\n</ng-template>\n" }]
|
|
46
|
+
args: [{ selector: 'igx-grid-group-by-area', providers: [{ provide: IgxGroupByAreaDirective, useExisting: IgxGridGroupByAreaComponent }], standalone: true, imports: [IgxChipsAreaComponent, NgFor, IgxChipComponent, IgxIconComponent, IgxSuffixDirective, IgxGroupAreaDropDirective, IgxDropDirective, NgTemplateOutlet, IgxGroupByMetaPipe], template: "<igx-chips-area (reorder)=\"handleReorder($event)\" (moveEnd)=\"handleMoveEnd()\">\n <ng-container *ngFor=\"let expression of chipExpressions; let last = last;\">\n <igx-chip\n [id]=\"expression.fieldName\"\n [title]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).title\"\n [displayDensity]=\"grid.displayDensity\"\n [removable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n [draggable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n [disabled]=\"!(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n (keyDown)=\"handleKeyDown($event.owner.id, $event.originalEvent)\"\n (remove)=\"clearGrouping($event.owner.id)\"\n (chipClick)=\"handleClick(expression.fieldName)\"\n >\n <span>{{ (expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).title }}</span>\n <igx-icon igxSuffix>{{ expression.dir === 1 ? 'arrow_upward' : 'arrow_downward' }}</igx-icon>\n </igx-chip>\n\n <span class=\"igx-grid-grouparea__connector\">\n <igx-icon [hidden]=\"(last && !dropAreaVisible)\">arrow_forward</igx-icon>\n </span>\n </ng-container>\n <div igxGroupAreaDrop\n class=\"igx-drop-area\"\n [attr.gridId]=\"grid.id\"\n [hidden]=\"!dropAreaVisible\"\n (igxDrop)=\"onDragDrop($event)\"\n >\n <ng-container *ngTemplateOutlet=\"dropAreaTemplate || default\"></ng-container>\n </div>\n</igx-chips-area>\n\n<ng-template #default>\n <igx-icon class=\"igx-drop-area__icon\">group_work</igx-icon>\n <span class=\"igx-drop-area__text\">{{ dropAreaMessage }}</span>\n</ng-template>\n" }]
|
|
47
47
|
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.PlatformUtil }], propDecorators: { sortingExpressions: [{
|
|
48
48
|
type: Input
|
|
49
49
|
}], grid: [{
|
|
50
50
|
type: Input
|
|
51
51
|
}] } });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-group-by-area.component.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/grouping/grid-group-by-area.component.ts","../../../../../../projects/igniteui-angular/src/lib/grids/grouping/group-by-area.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EAET,KAAK,GACR,MAAM,eAAe,CAAC;AAMvB,OAAO,EAAE,uBAAuB,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AACxF,OAAO,EAAE,gBAAgB,EAAE,MAAM,gDAAgD,CAAC;AAClF,OAAO,EAAE,yBAAyB,EAAE,MAAM,oBAAoB,CAAC;AAC/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,0CAA0C,CAAC;AAC9E,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAE,KAAK,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAC1D,OAAO,EAAE,qBAAqB,EAAE,MAAM,kCAAkC,CAAC;;;AAEzE;;;;GAIG;AAQH,MAAM,OAAO,2BAA4B,SAAQ,uBAAuB;IAQpE,YAAY,GAA4B,EAAE,QAAsB;QAC5D,KAAK,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAPlB,uBAAkB,GAAyB,EAAE,CAAC;IAQpD,CAAC;IAEK,aAAa,CAAC,KAAiC;QAClD,MAAM,EAAE,UAAU,EAAE,aAAa,EAAE,GAAG,KAAK,CAAC;QAC5C,MAAM,cAAc,GAAG,IAAI,CAAC,uBAAuB,CAAC,UAAU,CAAC,CAAC;QAEhE,IAAI,CAAC,IAAI,CAAC,sBAAsB,GAAG,EAAE,CAAC;QACtC,IAAI,CAAC,WAAW,GAAG,cAAc,CAAC;QAElC,6EAA6E;QAC7E,IAAI,aAAa,YAAY,aAAa,EAAE;YACxC,IAAI,CAAC,IAAI,CAAC,mBAAmB,GAAG,cAAc,CAAC;SAClD;IACL,CAAC;IAEM,aAAa;QAChB,IAAI,CAAC,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,WAAW,CAAC;IACrD,CAAC;IAEM,OAAO,CAAC,UAA+B;QAC1C,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IAClC,CAAC;IAEM,aAAa,CAAC,IAAY;QAC7B,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;IAClC,CAAC;8GAnCQ,2BAA2B;kGAA3B,2BAA2B,yIAJzB,CAAC,EAAE,OAAO,EAAE,uBAAuB,EAAE,WAAW,EAAE,2BAA2B,EAAE,CAAC,iDC3B/F,uyDAmCA,4CDNc,qBAAqB,yJAAE,KAAK,mHAAE,gBAAgB,2bAAE,gBAAgB,2FAAE,kBAAkB,4EAAE,yBAAyB,+DAAE,gBAAgB,8KAAE,gBAAgB,+IAAE,kBAAkB;;2FAExK,2BAA2B;kBAPvC,SAAS;+BACI,wBAAwB,aAEvB,CAAC,EAAE,OAAO,EAAE,uBAAuB,EAAE,WAAW,6BAA6B,EAAE,CAAC,cAC/E,IAAI,WACP,CAAC,qBAAqB,EAAE,KAAK,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,yBAAyB,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,kBAAkB,CAAC;0GAI3K,kBAAkB;sBADxB,KAAK;gBAKU,IAAI;sBADnB,KAAK","sourcesContent":["import {\n    Component,\n    ElementRef,\n    Input,\n} from '@angular/core';\nimport { IChipsAreaReorderEventArgs } from '../../chips/public_api';\nimport { PlatformUtil } from '../../core/utils';\nimport { IGroupingExpression } from '../../data-operations/grouping-expression.interface';\nimport { ISortingExpression } from '../../data-operations/sorting-strategy';\nimport { FlatGridType } from '../common/grid.interface';\nimport { IgxGroupByAreaDirective, IgxGroupByMetaPipe } from './group-by-area.directive';\nimport { IgxDropDirective } from '../../directives/drag-drop/drag-drop.directive';\nimport { IgxGroupAreaDropDirective } from '../grid.directives';\nimport { IgxSuffixDirective } from '../../directives/suffix/suffix.directive';\nimport { IgxIconComponent } from '../../icon/icon.component';\nimport { IgxChipComponent } from '../../chips/chip.component';\nimport { NgFor, NgTemplateOutlet } from '@angular/common';\nimport { IgxChipsAreaComponent } from '../../chips/chips-area.component';\n\n/**\n * An internal component representing the group-by drop area for the igx-grid component.\n *\n * @hidden @internal\n */\n@Component({\n    selector: 'igx-grid-group-by-area',\n    templateUrl: 'group-by-area.component.html',\n    providers: [{ provide: IgxGroupByAreaDirective, useExisting: IgxGridGroupByAreaComponent }],\n    standalone: true,\n    imports: [IgxChipsAreaComponent, NgFor, IgxChipComponent, IgxIconComponent, IgxSuffixDirective, IgxGroupAreaDropDirective, IgxDropDirective, NgTemplateOutlet, IgxGroupByMetaPipe]\n})\nexport class IgxGridGroupByAreaComponent extends IgxGroupByAreaDirective {\n    @Input()\n    public sortingExpressions: ISortingExpression[] = [];\n\n    /** The parent grid containing the component. */\n    @Input()\n    public override grid: FlatGridType;\n\n    constructor(ref: ElementRef<HTMLElement>, platform: PlatformUtil) {\n        super(ref, platform);\n     }\n\n    public handleReorder(event: IChipsAreaReorderEventArgs) {\n        const { chipsArray, originalEvent } = event;\n        const newExpressions = this.getReorderedExpressions(chipsArray);\n\n        this.grid.groupingExpansionState = [];\n        this.expressions = newExpressions;\n\n        // When reordered using keyboard navigation, we don't have `onMoveEnd` event.\n        if (originalEvent instanceof KeyboardEvent) {\n            this.grid.groupingExpressions = newExpressions;\n        }\n    }\n\n    public handleMoveEnd() {\n        this.grid.groupingExpressions = this.expressions;\n    }\n\n    public groupBy(expression: IGroupingExpression) {\n        this.grid.groupBy(expression);\n    }\n\n    public clearGrouping(name: string) {\n        this.grid.clearGrouping(name);\n    }\n}\n\n","<igx-chips-area (reorder)=\"handleReorder($event)\" (moveEnd)=\"handleMoveEnd()\">\n    <ng-container *ngFor=\"let expression of chipExpressions; let last = last;\">\n        <igx-chip\n            [id]=\"expression.fieldName\"\n            [title]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).title\"\n            [displayDensity]=\"grid.displayDensity\"\n            [removable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n            [draggable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n            [disabled]=\"!(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n            (keyDown)=\"handleKeyDown($event.owner.id, $event.originalEvent)\"\n            (remove)=\"clearGrouping($event.owner.id)\"\n            (chipClick)=\"handleClick(expression.fieldName)\"\n        >\n            <span>{{ (expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).title }}</span>\n            <igx-icon igxSuffix>{{ expression.dir === 1 ? 'arrow_upward' : 'arrow_downward' }}</igx-icon>\n        </igx-chip>\n\n        <span class=\"igx-grid-grouparea__connector\">\n            <igx-icon [hidden]=\"(last && !dropAreaVisible)\">arrow_forward</igx-icon>\n        </span>\n    </ng-container>\n    <div igxGroupAreaDrop\n        class=\"igx-drop-area\"\n        [attr.gridId]=\"grid.id\"\n        [hidden]=\"!dropAreaVisible\"\n        (igxDrop)=\"onDragDrop($event)\"\n    >\n        <ng-container *ngTemplateOutlet=\"dropAreaTemplate || default\"></ng-container>\n    </div>\n</igx-chips-area>\n\n<ng-template #default>\n    <igx-icon class=\"igx-drop-area__icon\">group_work</igx-icon>\n    <span class=\"igx-drop-area__text\">{{ dropAreaMessage }}</span>\n</ng-template>\n"]}
|
|
@@ -107,13 +107,13 @@ export class IgxTreeGridGroupByAreaComponent extends IgxGroupByAreaDirective {
|
|
|
107
107
|
}
|
|
108
108
|
}
|
|
109
109
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: IgxTreeGridGroupByAreaComponent, deps: [{ token: i0.IterableDiffers }, { token: i0.ElementRef }, { token: i1.PlatformUtil }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
110
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.2.4", type: IgxTreeGridGroupByAreaComponent, isStandalone: true, selector: "igx-tree-grid-group-by-area", inputs: { hideGroupedColumns: ["hideGroupedColumns", "hideGroupedColumns", booleanAttribute] }, providers: [{ provide: IgxGroupByAreaDirective, useExisting: IgxTreeGridGroupByAreaComponent }], usesInheritance: true, ngImport: i0, template: "<igx-chips-area (reorder)=\"handleReorder($event)\" (moveEnd)=\"handleMoveEnd()\">\n <ng-container *ngFor=\"let expression of chipExpressions; let last = last;\">\n <igx-chip\n [id]=\"expression.fieldName\"\n [title]=\"(expression.fieldName | igxGroupByMeta:grid).title\"\n [displayDensity]=\"grid.displayDensity\"\n [removable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n [draggable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n [disabled]=\"!(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n (keyDown)=\"handleKeyDown($event.owner.id, $event.originalEvent)\"\n (remove)=\"clearGrouping($event.owner.id)\"\n (chipClick)=\"handleClick(expression.fieldName)\"\n >\n <span>{{ (expression.fieldName | igxGroupByMeta:grid).title }}</span>\n <igx-icon igxSuffix>{{ expression.dir === 1 ? 'arrow_upward' : 'arrow_downward' }}</igx-icon>\n </igx-chip>\n\n <span class=\"igx-grid-grouparea__connector\">\n <igx-icon [hidden]=\"(last && !dropAreaVisible)\">arrow_forward</igx-icon>\n </span>\n </ng-container>\n <div igxGroupAreaDrop\n class=\"igx-drop-area\"\n [attr.gridId]=\"grid.id\"\n [hidden]=\"!dropAreaVisible\"\n (igxDrop)=\"onDragDrop($event)\"\n >\n <ng-container *ngTemplateOutlet=\"dropAreaTemplate || default\"></ng-container>\n </div>\n</igx-chips-area>\n\n<ng-template #default>\n <igx-icon class=\"igx-drop-area__icon\">group_work</igx-icon>\n <span class=\"igx-drop-area__text\">{{ dropAreaMessage }}</span>\n</ng-template>\n", dependencies: [{ kind: "component", type: IgxChipsAreaComponent, selector: "igx-chips-area", inputs: ["width", "height"], outputs: ["reorder", "selectionChange", "moveStart", "moveEnd"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: IgxChipComponent, selector: "igx-chip", inputs: ["variant", "id", "tabIndex", "data", "draggable", "animateOnRelease", "hideBaseOnDrag", "removable", "removeIcon", "selectable", "selectIcon", "class", "disabled", "selected", "color", "resourceStrings"], outputs: ["selectedChange", "moveStart", "moveEnd", "remove", "chipClick", "selectedChanging", "selectedChanged", "keyDown", "dragEnter", "dragLeave", "dragOver", "dragDrop"] }, { kind: "component", type: IgxIconComponent, selector: "igx-icon", inputs: ["family", "active", "name"] }, { kind: "directive", type: IgxSuffixDirective, selector: "igx-suffix,[igxSuffix],[igxEnd]" }, { kind: "directive", type: IgxGroupAreaDropDirective, selector: "[igxGroupAreaDrop]" }, { kind: "directive", type: IgxDropDirective, selector: "[igxDrop]", inputs: ["igxDrop", "dropChannel", "dropStrategy"], outputs: ["enter", "over", "leave", "dropped"], exportAs: ["drop"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: IgxGroupByMetaPipe, name: "igxGroupByMeta" }] }); }
|
|
110
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.2.4", type: IgxTreeGridGroupByAreaComponent, isStandalone: true, selector: "igx-tree-grid-group-by-area", inputs: { hideGroupedColumns: ["hideGroupedColumns", "hideGroupedColumns", booleanAttribute] }, providers: [{ provide: IgxGroupByAreaDirective, useExisting: IgxTreeGridGroupByAreaComponent }], usesInheritance: true, ngImport: i0, template: "<igx-chips-area (reorder)=\"handleReorder($event)\" (moveEnd)=\"handleMoveEnd()\">\n <ng-container *ngFor=\"let expression of chipExpressions; let last = last;\">\n <igx-chip\n [id]=\"expression.fieldName\"\n [title]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).title\"\n [displayDensity]=\"grid.displayDensity\"\n [removable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n [draggable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n [disabled]=\"!(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n (keyDown)=\"handleKeyDown($event.owner.id, $event.originalEvent)\"\n (remove)=\"clearGrouping($event.owner.id)\"\n (chipClick)=\"handleClick(expression.fieldName)\"\n >\n <span>{{ (expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).title }}</span>\n <igx-icon igxSuffix>{{ expression.dir === 1 ? 'arrow_upward' : 'arrow_downward' }}</igx-icon>\n </igx-chip>\n\n <span class=\"igx-grid-grouparea__connector\">\n <igx-icon [hidden]=\"(last && !dropAreaVisible)\">arrow_forward</igx-icon>\n </span>\n </ng-container>\n <div igxGroupAreaDrop\n class=\"igx-drop-area\"\n [attr.gridId]=\"grid.id\"\n [hidden]=\"!dropAreaVisible\"\n (igxDrop)=\"onDragDrop($event)\"\n >\n <ng-container *ngTemplateOutlet=\"dropAreaTemplate || default\"></ng-container>\n </div>\n</igx-chips-area>\n\n<ng-template #default>\n <igx-icon class=\"igx-drop-area__icon\">group_work</igx-icon>\n <span class=\"igx-drop-area__text\">{{ dropAreaMessage }}</span>\n</ng-template>\n", dependencies: [{ kind: "component", type: IgxChipsAreaComponent, selector: "igx-chips-area", inputs: ["width", "height"], outputs: ["reorder", "selectionChange", "moveStart", "moveEnd"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: IgxChipComponent, selector: "igx-chip", inputs: ["variant", "id", "tabIndex", "data", "draggable", "animateOnRelease", "hideBaseOnDrag", "removable", "removeIcon", "selectable", "selectIcon", "class", "disabled", "selected", "color", "resourceStrings"], outputs: ["selectedChange", "moveStart", "moveEnd", "remove", "chipClick", "selectedChanging", "selectedChanged", "keyDown", "dragEnter", "dragLeave", "dragOver", "dragDrop"] }, { kind: "component", type: IgxIconComponent, selector: "igx-icon", inputs: ["family", "active", "name"] }, { kind: "directive", type: IgxSuffixDirective, selector: "igx-suffix,[igxSuffix],[igxEnd]" }, { kind: "directive", type: IgxGroupAreaDropDirective, selector: "[igxGroupAreaDrop]" }, { kind: "directive", type: IgxDropDirective, selector: "[igxDrop]", inputs: ["igxDrop", "dropChannel", "dropStrategy"], outputs: ["enter", "over", "leave", "dropped"], exportAs: ["drop"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: IgxGroupByMetaPipe, name: "igxGroupByMeta" }] }); }
|
|
111
111
|
}
|
|
112
112
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: IgxTreeGridGroupByAreaComponent, decorators: [{
|
|
113
113
|
type: Component,
|
|
114
|
-
args: [{ selector: 'igx-tree-grid-group-by-area', providers: [{ provide: IgxGroupByAreaDirective, useExisting: IgxTreeGridGroupByAreaComponent }], standalone: true, imports: [IgxChipsAreaComponent, NgFor, IgxChipComponent, IgxIconComponent, IgxSuffixDirective, IgxGroupAreaDropDirective, IgxDropDirective, NgTemplateOutlet, IgxGroupByMetaPipe], template: "<igx-chips-area (reorder)=\"handleReorder($event)\" (moveEnd)=\"handleMoveEnd()\">\n <ng-container *ngFor=\"let expression of chipExpressions; let last = last;\">\n <igx-chip\n [id]=\"expression.fieldName\"\n [title]=\"(expression.fieldName | igxGroupByMeta:grid).title\"\n [displayDensity]=\"grid.displayDensity\"\n [removable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n [draggable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n [disabled]=\"!(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n (keyDown)=\"handleKeyDown($event.owner.id, $event.originalEvent)\"\n (remove)=\"clearGrouping($event.owner.id)\"\n (chipClick)=\"handleClick(expression.fieldName)\"\n >\n <span>{{ (expression.fieldName | igxGroupByMeta:grid).title }}</span>\n <igx-icon igxSuffix>{{ expression.dir === 1 ? 'arrow_upward' : 'arrow_downward' }}</igx-icon>\n </igx-chip>\n\n <span class=\"igx-grid-grouparea__connector\">\n <igx-icon [hidden]=\"(last && !dropAreaVisible)\">arrow_forward</igx-icon>\n </span>\n </ng-container>\n <div igxGroupAreaDrop\n class=\"igx-drop-area\"\n [attr.gridId]=\"grid.id\"\n [hidden]=\"!dropAreaVisible\"\n (igxDrop)=\"onDragDrop($event)\"\n >\n <ng-container *ngTemplateOutlet=\"dropAreaTemplate || default\"></ng-container>\n </div>\n</igx-chips-area>\n\n<ng-template #default>\n <igx-icon class=\"igx-drop-area__icon\">group_work</igx-icon>\n <span class=\"igx-drop-area__text\">{{ dropAreaMessage }}</span>\n</ng-template>\n" }]
|
|
114
|
+
args: [{ selector: 'igx-tree-grid-group-by-area', providers: [{ provide: IgxGroupByAreaDirective, useExisting: IgxTreeGridGroupByAreaComponent }], standalone: true, imports: [IgxChipsAreaComponent, NgFor, IgxChipComponent, IgxIconComponent, IgxSuffixDirective, IgxGroupAreaDropDirective, IgxDropDirective, NgTemplateOutlet, IgxGroupByMetaPipe], template: "<igx-chips-area (reorder)=\"handleReorder($event)\" (moveEnd)=\"handleMoveEnd()\">\n <ng-container *ngFor=\"let expression of chipExpressions; let last = last;\">\n <igx-chip\n [id]=\"expression.fieldName\"\n [title]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).title\"\n [displayDensity]=\"grid.displayDensity\"\n [removable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n [draggable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n [disabled]=\"!(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n (keyDown)=\"handleKeyDown($event.owner.id, $event.originalEvent)\"\n (remove)=\"clearGrouping($event.owner.id)\"\n (chipClick)=\"handleClick(expression.fieldName)\"\n >\n <span>{{ (expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).title }}</span>\n <igx-icon igxSuffix>{{ expression.dir === 1 ? 'arrow_upward' : 'arrow_downward' }}</igx-icon>\n </igx-chip>\n\n <span class=\"igx-grid-grouparea__connector\">\n <igx-icon [hidden]=\"(last && !dropAreaVisible)\">arrow_forward</igx-icon>\n </span>\n </ng-container>\n <div igxGroupAreaDrop\n class=\"igx-drop-area\"\n [attr.gridId]=\"grid.id\"\n [hidden]=\"!dropAreaVisible\"\n (igxDrop)=\"onDragDrop($event)\"\n >\n <ng-container *ngTemplateOutlet=\"dropAreaTemplate || default\"></ng-container>\n </div>\n</igx-chips-area>\n\n<ng-template #default>\n <igx-icon class=\"igx-drop-area__icon\">group_work</igx-icon>\n <span class=\"igx-drop-area__text\">{{ dropAreaMessage }}</span>\n</ng-template>\n" }]
|
|
115
115
|
}], ctorParameters: () => [{ type: i0.IterableDiffers }, { type: i0.ElementRef }, { type: i1.PlatformUtil }], propDecorators: { hideGroupedColumns: [{
|
|
116
116
|
type: Input,
|
|
117
117
|
args: [{ transform: booleanAttribute }]
|
|
118
118
|
}] } });
|
|
119
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-grid-group-by-area.component.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/grouping/tree-grid-group-by-area.component.ts","../../../../../../projects/igniteui-angular/src/lib/grids/grouping/group-by-area.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    Component,\n    ElementRef,\n    Input,\n    IterableDiffer,\n    IterableDiffers,\n    OnDestroy,\n    booleanAttribute,\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { IChipsAreaReorderEventArgs } from '../../chips/public_api';\nimport { PlatformUtil } from '../../core/utils';\nimport { IGroupingExpression } from '../../data-operations/grouping-expression.interface';\nimport { ISortingExpression } from '../../data-operations/sorting-strategy';\nimport { IgxGroupByAreaDirective, IgxGroupByMetaPipe } from './group-by-area.directive';\nimport { IgxDropDirective } from '../../directives/drag-drop/drag-drop.directive';\nimport { IgxGroupAreaDropDirective } from '../grid.directives';\nimport { IgxSuffixDirective } from '../../directives/suffix/suffix.directive';\nimport { IgxIconComponent } from '../../icon/icon.component';\nimport { IgxChipComponent } from '../../chips/chip.component';\nimport { NgFor, NgTemplateOutlet } from '@angular/common';\nimport { IgxChipsAreaComponent } from '../../chips/chips-area.component';\n\n/**\n * An internal component representing the group-by drop area for the igx-grid component.\n *\n * @hidden @internal\n */\n@Component({\n    selector: 'igx-tree-grid-group-by-area',\n    templateUrl: 'group-by-area.component.html',\n    providers: [{ provide: IgxGroupByAreaDirective, useExisting: IgxTreeGridGroupByAreaComponent }],\n    standalone: true,\n    imports: [IgxChipsAreaComponent, NgFor, IgxChipComponent, IgxIconComponent, IgxSuffixDirective, IgxGroupAreaDropDirective, IgxDropDirective, NgTemplateOutlet, IgxGroupByMetaPipe]\n})\nexport class IgxTreeGridGroupByAreaComponent extends IgxGroupByAreaDirective implements AfterContentInit, OnDestroy {\n    @Input({ transform: booleanAttribute })\n    public get hideGroupedColumns() {\n        return this._hideGroupedColumns;\n    }\n\n    public set hideGroupedColumns(value: boolean) {\n        if (this.grid?.columns && this.expressions) {\n            this.setColumnsVisibility(value);\n        }\n\n        this._hideGroupedColumns = value;\n    }\n\n    private _hideGroupedColumns = false;\n    private groupingDiffer: IterableDiffer<IGroupingExpression>;\n    private destroy$ = new Subject<any>();\n\n    constructor(private differs: IterableDiffers, ref: ElementRef<HTMLElement>, platform: PlatformUtil) {\n        super(ref, platform);\n    }\n\n    public ngAfterContentInit(): void {\n        if (this.grid.columns && this.expressions) {\n            this.groupingDiffer = this.differs.find(this.expressions).create();\n            this.updateColumnsVisibility();\n        }\n\n        this.grid.sortingExpressionsChange.pipe(takeUntil(this.destroy$)).subscribe((sortingExpressions: ISortingExpression[]) => {\n            if (!this.expressions || !this.expressions.length) {\n                return;\n            }\n\n            let changed = false;\n\n            sortingExpressions.forEach((sortExpr: ISortingExpression) => {\n                const fieldName = sortExpr.fieldName;\n                const groupingExpr = this.expressions.find(ex => ex.fieldName === fieldName);\n                if (groupingExpr && groupingExpr.dir !== sortExpr.dir) {\n                    groupingExpr.dir = sortExpr.dir;\n                    changed = true;\n                }\n            });\n\n            if (changed) {\n                this.expressions = [...this.expressions];\n            }\n        });\n    }\n\n    public ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.complete();\n    }\n\n    public handleReorder(event: IChipsAreaReorderEventArgs) {\n        const { chipsArray, originalEvent } = event;\n        const newExpressions = this.getReorderedExpressions(chipsArray);\n\n        this.chipExpressions = newExpressions;\n\n        // When reordered using keyboard navigation, we don't have `onMoveEnd` event.\n        if (originalEvent instanceof KeyboardEvent) {\n            this.expressions = newExpressions;\n        }\n    }\n\n    public handleMoveEnd() {\n        this.expressions = this.chipExpressions;\n    }\n\n    public groupBy(expression: IGroupingExpression) {\n        this.expressions.push(expression);\n        this.expressions = [...this.expressions];\n    }\n\n    public clearGrouping(name: string) {\n        this.expressions = this.expressions.filter(item => item.fieldName !== name);\n        this.grid.sortingExpressions = this.grid.sortingExpressions.filter(item => item.fieldName !== name);\n        this.grid.notifyChanges(true);\n    }\n\n    protected override expressionsChanged() {\n        this.updateColumnsVisibility();\n    }\n\n    private updateColumnsVisibility() {\n        if (this.groupingDiffer && this.grid.columns && !this.grid.hasColumnLayouts) {\n            const changes = this.groupingDiffer.diff(this.expressions);\n            if (changes && this.grid.columns.length > 0) {\n                changes.forEachAddedItem((rec) => {\n                    const col = this.grid.getColumnByName(rec.item.fieldName);\n                    col.hidden = this.hideGroupedColumns;\n                });\n                changes.forEachRemovedItem((rec) => {\n                    const col = this.grid.getColumnByName(rec.item.fieldName);\n                    col.hidden = false;\n                });\n            }\n        }\n    }\n\n    private setColumnsVisibility(value) {\n        if (this.grid.columns.length > 0 && !this.grid.hasColumnLayouts) {\n            this.expressions.forEach((expr) => {\n                const col = this.grid.getColumnByName(expr.fieldName);\n                col.hidden = value;\n            });\n        }\n    }\n}\n\n","<igx-chips-area (reorder)=\"handleReorder($event)\" (moveEnd)=\"handleMoveEnd()\">\n    <ng-container *ngFor=\"let expression of chipExpressions; let last = last;\">\n        <igx-chip\n            [id]=\"expression.fieldName\"\n            [title]=\"(expression.fieldName | igxGroupByMeta:grid).title\"\n            [displayDensity]=\"grid.displayDensity\"\n            [removable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n            [draggable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n            [disabled]=\"!(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n            (keyDown)=\"handleKeyDown($event.owner.id, $event.originalEvent)\"\n            (remove)=\"clearGrouping($event.owner.id)\"\n            (chipClick)=\"handleClick(expression.fieldName)\"\n        >\n            <span>{{ (expression.fieldName | igxGroupByMeta:grid).title }}</span>\n            <igx-icon igxSuffix>{{ expression.dir === 1 ? 'arrow_upward' : 'arrow_downward' }}</igx-icon>\n        </igx-chip>\n\n        <span class=\"igx-grid-grouparea__connector\">\n            <igx-icon [hidden]=\"(last && !dropAreaVisible)\">arrow_forward</igx-icon>\n        </span>\n    </ng-container>\n    <div igxGroupAreaDrop\n        class=\"igx-drop-area\"\n        [attr.gridId]=\"grid.id\"\n        [hidden]=\"!dropAreaVisible\"\n        (igxDrop)=\"onDragDrop($event)\"\n    >\n        <ng-container *ngTemplateOutlet=\"dropAreaTemplate || default\"></ng-container>\n    </div>\n</igx-chips-area>\n\n<ng-template #default>\n    <igx-icon class=\"igx-drop-area__icon\">group_work</igx-icon>\n    <span class=\"igx-drop-area__text\">{{ dropAreaMessage }}</span>\n</ng-template>\n"]}
|
|
119
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-grid-group-by-area.component.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/grouping/tree-grid-group-by-area.component.ts","../../../../../../projects/igniteui-angular/src/lib/grids/grouping/group-by-area.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    Component,\n    ElementRef,\n    Input,\n    IterableDiffer,\n    IterableDiffers,\n    OnDestroy,\n    booleanAttribute,\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { IChipsAreaReorderEventArgs } from '../../chips/public_api';\nimport { PlatformUtil } from '../../core/utils';\nimport { IGroupingExpression } from '../../data-operations/grouping-expression.interface';\nimport { ISortingExpression } from '../../data-operations/sorting-strategy';\nimport { IgxGroupByAreaDirective, IgxGroupByMetaPipe } from './group-by-area.directive';\nimport { IgxDropDirective } from '../../directives/drag-drop/drag-drop.directive';\nimport { IgxGroupAreaDropDirective } from '../grid.directives';\nimport { IgxSuffixDirective } from '../../directives/suffix/suffix.directive';\nimport { IgxIconComponent } from '../../icon/icon.component';\nimport { IgxChipComponent } from '../../chips/chip.component';\nimport { NgFor, NgTemplateOutlet } from '@angular/common';\nimport { IgxChipsAreaComponent } from '../../chips/chips-area.component';\n\n/**\n * An internal component representing the group-by drop area for the igx-grid component.\n *\n * @hidden @internal\n */\n@Component({\n    selector: 'igx-tree-grid-group-by-area',\n    templateUrl: 'group-by-area.component.html',\n    providers: [{ provide: IgxGroupByAreaDirective, useExisting: IgxTreeGridGroupByAreaComponent }],\n    standalone: true,\n    imports: [IgxChipsAreaComponent, NgFor, IgxChipComponent, IgxIconComponent, IgxSuffixDirective, IgxGroupAreaDropDirective, IgxDropDirective, NgTemplateOutlet, IgxGroupByMetaPipe]\n})\nexport class IgxTreeGridGroupByAreaComponent extends IgxGroupByAreaDirective implements AfterContentInit, OnDestroy {\n    @Input({ transform: booleanAttribute })\n    public get hideGroupedColumns() {\n        return this._hideGroupedColumns;\n    }\n\n    public set hideGroupedColumns(value: boolean) {\n        if (this.grid?.columns && this.expressions) {\n            this.setColumnsVisibility(value);\n        }\n\n        this._hideGroupedColumns = value;\n    }\n\n    private _hideGroupedColumns = false;\n    private groupingDiffer: IterableDiffer<IGroupingExpression>;\n    private destroy$ = new Subject<any>();\n\n    constructor(private differs: IterableDiffers, ref: ElementRef<HTMLElement>, platform: PlatformUtil) {\n        super(ref, platform);\n    }\n\n    public ngAfterContentInit(): void {\n        if (this.grid.columns && this.expressions) {\n            this.groupingDiffer = this.differs.find(this.expressions).create();\n            this.updateColumnsVisibility();\n        }\n\n        this.grid.sortingExpressionsChange.pipe(takeUntil(this.destroy$)).subscribe((sortingExpressions: ISortingExpression[]) => {\n            if (!this.expressions || !this.expressions.length) {\n                return;\n            }\n\n            let changed = false;\n\n            sortingExpressions.forEach((sortExpr: ISortingExpression) => {\n                const fieldName = sortExpr.fieldName;\n                const groupingExpr = this.expressions.find(ex => ex.fieldName === fieldName);\n                if (groupingExpr && groupingExpr.dir !== sortExpr.dir) {\n                    groupingExpr.dir = sortExpr.dir;\n                    changed = true;\n                }\n            });\n\n            if (changed) {\n                this.expressions = [...this.expressions];\n            }\n        });\n    }\n\n    public ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.complete();\n    }\n\n    public handleReorder(event: IChipsAreaReorderEventArgs) {\n        const { chipsArray, originalEvent } = event;\n        const newExpressions = this.getReorderedExpressions(chipsArray);\n\n        this.chipExpressions = newExpressions;\n\n        // When reordered using keyboard navigation, we don't have `onMoveEnd` event.\n        if (originalEvent instanceof KeyboardEvent) {\n            this.expressions = newExpressions;\n        }\n    }\n\n    public handleMoveEnd() {\n        this.expressions = this.chipExpressions;\n    }\n\n    public groupBy(expression: IGroupingExpression) {\n        this.expressions.push(expression);\n        this.expressions = [...this.expressions];\n    }\n\n    public clearGrouping(name: string) {\n        this.expressions = this.expressions.filter(item => item.fieldName !== name);\n        this.grid.sortingExpressions = this.grid.sortingExpressions.filter(item => item.fieldName !== name);\n        this.grid.notifyChanges(true);\n    }\n\n    protected override expressionsChanged() {\n        this.updateColumnsVisibility();\n    }\n\n    private updateColumnsVisibility() {\n        if (this.groupingDiffer && this.grid.columns && !this.grid.hasColumnLayouts) {\n            const changes = this.groupingDiffer.diff(this.expressions);\n            if (changes && this.grid.columns.length > 0) {\n                changes.forEachAddedItem((rec) => {\n                    const col = this.grid.getColumnByName(rec.item.fieldName);\n                    col.hidden = this.hideGroupedColumns;\n                });\n                changes.forEachRemovedItem((rec) => {\n                    const col = this.grid.getColumnByName(rec.item.fieldName);\n                    col.hidden = false;\n                });\n            }\n        }\n    }\n\n    private setColumnsVisibility(value) {\n        if (this.grid.columns.length > 0 && !this.grid.hasColumnLayouts) {\n            this.expressions.forEach((expr) => {\n                const col = this.grid.getColumnByName(expr.fieldName);\n                col.hidden = value;\n            });\n        }\n    }\n}\n\n","<igx-chips-area (reorder)=\"handleReorder($event)\" (moveEnd)=\"handleMoveEnd()\">\n    <ng-container *ngFor=\"let expression of chipExpressions; let last = last;\">\n        <igx-chip\n            [id]=\"expression.fieldName\"\n            [title]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).title\"\n            [displayDensity]=\"grid.displayDensity\"\n            [removable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n            [draggable]=\"(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n            [disabled]=\"!(expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).groupable\"\n            (keyDown)=\"handleKeyDown($event.owner.id, $event.originalEvent)\"\n            (remove)=\"clearGrouping($event.owner.id)\"\n            (chipClick)=\"handleClick(expression.fieldName)\"\n        >\n            <span>{{ (expression.fieldName | igxGroupByMeta:grid:grid.groupablePipeTrigger).title }}</span>\n            <igx-icon igxSuffix>{{ expression.dir === 1 ? 'arrow_upward' : 'arrow_downward' }}</igx-icon>\n        </igx-chip>\n\n        <span class=\"igx-grid-grouparea__connector\">\n            <igx-icon [hidden]=\"(last && !dropAreaVisible)\">arrow_forward</igx-icon>\n        </span>\n    </ng-container>\n    <div igxGroupAreaDrop\n        class=\"igx-drop-area\"\n        [attr.gridId]=\"grid.id\"\n        [hidden]=\"!dropAreaVisible\"\n        (igxDrop)=\"onDragDrop($event)\"\n    >\n        <ng-container *ngTemplateOutlet=\"dropAreaTemplate || default\"></ng-container>\n    </div>\n</igx-chips-area>\n\n<ng-template #default>\n    <igx-icon class=\"igx-drop-area__icon\">group_work</igx-icon>\n    <span class=\"igx-drop-area__text\">{{ dropAreaMessage }}</span>\n</ng-template>\n"]}
|