igniteui-angular 16.1.2 → 16.1.3

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.
Files changed (66) hide show
  1. package/README.md +6 -5
  2. package/esm2022/lib/action-strip/action-strip.component.mjs +3 -3
  3. package/esm2022/lib/action-strip/grid-actions/grid-action-button.component.mjs +3 -3
  4. package/esm2022/lib/banner/banner.component.mjs +8 -8
  5. package/esm2022/lib/card/card.component.mjs +3 -3
  6. package/esm2022/lib/carousel/carousel.component.mjs +7 -7
  7. package/esm2022/lib/combo/combo-dropdown.component.mjs +3 -3
  8. package/esm2022/lib/combo/combo.common.mjs +5 -5
  9. package/esm2022/lib/combo/combo.component.mjs +3 -3
  10. package/esm2022/lib/combo/combo.directives.mjs +2 -2
  11. package/esm2022/lib/core/navigation/directives.mjs +3 -3
  12. package/esm2022/lib/date-common/calendar-container/calendar-container.component.mjs +3 -3
  13. package/esm2022/lib/date-picker/date-picker.component.mjs +7 -7
  14. package/esm2022/lib/date-range-picker/date-range-picker.component.mjs +6 -6
  15. package/esm2022/lib/dialog/dialog.component.mjs +5 -5
  16. package/esm2022/lib/directives/button/button.directive.mjs +8 -8
  17. package/esm2022/lib/directives/ripple/ripple.directive.mjs +6 -6
  18. package/esm2022/lib/directives/tooltip/tooltip-target.directive.mjs +7 -9
  19. package/esm2022/lib/directives/tooltip/tooltip.directive.mjs +2 -2
  20. package/esm2022/lib/drop-down/drop-down.component.mjs +3 -3
  21. package/esm2022/lib/expansion-panel/expansion-panel.component.mjs +4 -4
  22. package/esm2022/lib/grids/column-actions/column-actions.component.mjs +3 -3
  23. package/esm2022/lib/grids/common/crud.service.mjs +2 -2
  24. package/esm2022/lib/grids/filtering/base/grid-filtering-row.component.mjs +3 -3
  25. package/esm2022/lib/grids/filtering/excel-style/excel-style-custom-dialog.component.mjs +3 -3
  26. package/esm2022/lib/grids/filtering/excel-style/excel-style-date-expression.component.mjs +3 -3
  27. package/esm2022/lib/grids/filtering/excel-style/excel-style-default-expression.component.mjs +3 -3
  28. package/esm2022/lib/grids/filtering/excel-style/excel-style-header.component.mjs +3 -3
  29. package/esm2022/lib/grids/filtering/excel-style/excel-style-moving.component.mjs +3 -3
  30. package/esm2022/lib/grids/filtering/excel-style/excel-style-search.component.mjs +3 -3
  31. package/esm2022/lib/grids/filtering/excel-style/excel-style-sorting.component.mjs +3 -3
  32. package/esm2022/lib/grids/grid/grid.component.mjs +3 -3
  33. package/esm2022/lib/grids/grid-base.directive.mjs +4 -4
  34. package/esm2022/lib/grids/hierarchical-grid/hierarchical-grid.component.mjs +3 -3
  35. package/esm2022/lib/grids/tree-grid/tree-grid.component.mjs +3 -3
  36. package/esm2022/lib/query-builder/query-builder.component.mjs +3 -3
  37. package/esm2022/lib/simple-combo/simple-combo.component.mjs +3 -3
  38. package/esm2022/lib/snackbar/snackbar.component.mjs +4 -4
  39. package/esm2022/lib/tabs/tabs/tabs.component.mjs +3 -3
  40. package/esm2022/lib/time-picker/time-picker.component.mjs +6 -5
  41. package/esm2022/lib/toast/toast.component.mjs +2 -2
  42. package/esm2022/lib/tree/tree-node/tree-node.component.mjs +4 -4
  43. package/fesm2022/igniteui-angular.mjs +117 -118
  44. package/fesm2022/igniteui-angular.mjs.map +1 -1
  45. package/lib/banner/banner.component.d.ts +5 -5
  46. package/lib/card/card.component.d.ts +2 -2
  47. package/lib/carousel/carousel.component.d.ts +6 -6
  48. package/lib/combo/combo.common.d.ts +4 -4
  49. package/lib/combo/combo.directives.d.ts +1 -1
  50. package/lib/core/navigation/directives.d.ts +2 -2
  51. package/lib/date-picker/date-picker.component.d.ts +4 -4
  52. package/lib/date-range-picker/date-range-picker.component.d.ts +3 -3
  53. package/lib/dialog/dialog.component.d.ts +4 -4
  54. package/lib/directives/button/button.directive.d.ts +7 -7
  55. package/lib/directives/ripple/ripple.directive.d.ts +6 -6
  56. package/lib/directives/tooltip/tooltip-target.directive.d.ts +6 -8
  57. package/lib/directives/tooltip/tooltip.directive.d.ts +1 -1
  58. package/lib/expansion-panel/expansion-panel.component.d.ts +3 -3
  59. package/lib/grids/common/crud.service.d.ts +1 -1
  60. package/lib/grids/grid-base.directive.d.ts +3 -3
  61. package/lib/snackbar/snackbar.component.d.ts +1 -1
  62. package/lib/time-picker/time-picker.component.d.ts +1 -1
  63. package/lib/toast/toast.component.d.ts +1 -1
  64. package/lib/tree/tree-node/tree-node.component.d.ts +3 -3
  65. package/migrations/common/UpdateChanges.js +1 -1
  66. package/package.json +1 -1
@@ -55,11 +55,11 @@ export class IgxExcelStyleSortingComponent {
55
55
  }
56
56
  }
57
57
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.8", ngImport: i0, type: IgxExcelStyleSortingComponent, deps: [{ token: i1.BaseFilteringComponent }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
58
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.8", type: IgxExcelStyleSortingComponent, isStandalone: true, selector: "igx-excel-style-sorting", host: { properties: { "class.igx-excel-filter__sort": "this.defaultClass" } }, viewQueries: [{ propertyName: "sortButtonGroup", first: true, predicate: ["sortButtonGroup"], descendants: true, read: IgxButtonGroupComponent }], ngImport: i0, template: "<ng-container *ngIf=\"esf.column\">\n<header>\n {{ esf.grid.resourceStrings.igx_grid_excel_filter_sorting_header }}\n</header>\n<igx-buttongroup #sortButtonGroup>\n <button igxButton\n [displayDensity]=\"esf.displayDensity\"\n [attr.data-togglable]=\"true\"\n (click)=\"onSortButtonClicked(1)\"\n >\n <igx-icon>arrow_upwards</igx-icon>\n <span>\n {{ esf.displayDensity==='compact'?\n esf.grid.resourceStrings.igx_grid_excel_filter_sorting_asc_short:\n esf.grid.resourceStrings.igx_grid_excel_filter_sorting_asc }}\n </span>\n </button>\n\n <button igxButton\n [displayDensity]=\"esf.displayDensity\"\n [attr.data-togglable]=\"true\"\n (click)=\"onSortButtonClicked(2)\"\n >\n <igx-icon>arrow_downwards</igx-icon>\n <span>\n {{ esf.displayDensity==='compact'?\n esf.grid.resourceStrings.igx_grid_excel_filter_sorting_desc_short:\n esf.grid.resourceStrings.igx_grid_excel_filter_sorting_desc\n }}\n </span>\n </button>\n</igx-buttongroup>\n</ng-container>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: IgxButtonGroupComponent, selector: "igx-buttongroup", inputs: ["id", "itemContentCssClass", "multiSelection", "selectionMode", "values", "disabled", "alignment"], outputs: ["selected", "deselected"] }, { kind: "directive", type: IgxButtonDirective, selector: "[igxButton]", inputs: ["selected", "igxButton", "igxButtonColor", "igxButtonBackground", "igxLabel", "disabled"], outputs: ["buttonClick", "buttonSelected"] }, { kind: "component", type: IgxIconComponent, selector: "igx-icon", inputs: ["family", "active", "name"] }] }); }
58
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.8", type: IgxExcelStyleSortingComponent, isStandalone: true, selector: "igx-excel-style-sorting", host: { properties: { "class.igx-excel-filter__sort": "this.defaultClass" } }, viewQueries: [{ propertyName: "sortButtonGroup", first: true, predicate: ["sortButtonGroup"], descendants: true, read: IgxButtonGroupComponent }], ngImport: i0, template: "<ng-container *ngIf=\"esf.column\">\n<header>\n {{ esf.grid.resourceStrings.igx_grid_excel_filter_sorting_header }}\n</header>\n<igx-buttongroup #sortButtonGroup>\n <button type=\"button\"\n igxButton\n [displayDensity]=\"esf.displayDensity\"\n [attr.data-togglable]=\"true\"\n (click)=\"onSortButtonClicked(1)\"\n >\n <igx-icon>arrow_upwards</igx-icon>\n <span>\n {{ esf.displayDensity==='compact'?\n esf.grid.resourceStrings.igx_grid_excel_filter_sorting_asc_short:\n esf.grid.resourceStrings.igx_grid_excel_filter_sorting_asc }}\n </span>\n </button>\n\n <button type=\"button\"\n igxButton\n [displayDensity]=\"esf.displayDensity\"\n [attr.data-togglable]=\"true\"\n (click)=\"onSortButtonClicked(2)\"\n >\n <igx-icon>arrow_downwards</igx-icon>\n <span>\n {{ esf.displayDensity==='compact'?\n esf.grid.resourceStrings.igx_grid_excel_filter_sorting_desc_short:\n esf.grid.resourceStrings.igx_grid_excel_filter_sorting_desc\n }}\n </span>\n </button>\n</igx-buttongroup>\n</ng-container>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: IgxButtonGroupComponent, selector: "igx-buttongroup", inputs: ["id", "itemContentCssClass", "multiSelection", "selectionMode", "values", "disabled", "alignment"], outputs: ["selected", "deselected"] }, { kind: "directive", type: IgxButtonDirective, selector: "[igxButton]", inputs: ["selected", "igxButton", "igxButtonColor", "igxButtonBackground", "igxLabel", "disabled"], outputs: ["buttonClick", "buttonSelected"] }, { kind: "component", type: IgxIconComponent, selector: "igx-icon", inputs: ["family", "active", "name"] }] }); }
59
59
  }
60
60
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.8", ngImport: i0, type: IgxExcelStyleSortingComponent, decorators: [{
61
61
  type: Component,
62
- args: [{ selector: 'igx-excel-style-sorting', standalone: true, imports: [NgIf, IgxButtonGroupComponent, IgxButtonDirective, IgxIconComponent], template: "<ng-container *ngIf=\"esf.column\">\n<header>\n {{ esf.grid.resourceStrings.igx_grid_excel_filter_sorting_header }}\n</header>\n<igx-buttongroup #sortButtonGroup>\n <button igxButton\n [displayDensity]=\"esf.displayDensity\"\n [attr.data-togglable]=\"true\"\n (click)=\"onSortButtonClicked(1)\"\n >\n <igx-icon>arrow_upwards</igx-icon>\n <span>\n {{ esf.displayDensity==='compact'?\n esf.grid.resourceStrings.igx_grid_excel_filter_sorting_asc_short:\n esf.grid.resourceStrings.igx_grid_excel_filter_sorting_asc }}\n </span>\n </button>\n\n <button igxButton\n [displayDensity]=\"esf.displayDensity\"\n [attr.data-togglable]=\"true\"\n (click)=\"onSortButtonClicked(2)\"\n >\n <igx-icon>arrow_downwards</igx-icon>\n <span>\n {{ esf.displayDensity==='compact'?\n esf.grid.resourceStrings.igx_grid_excel_filter_sorting_desc_short:\n esf.grid.resourceStrings.igx_grid_excel_filter_sorting_desc\n }}\n </span>\n </button>\n</igx-buttongroup>\n</ng-container>\n" }]
62
+ args: [{ selector: 'igx-excel-style-sorting', standalone: true, imports: [NgIf, IgxButtonGroupComponent, IgxButtonDirective, IgxIconComponent], template: "<ng-container *ngIf=\"esf.column\">\n<header>\n {{ esf.grid.resourceStrings.igx_grid_excel_filter_sorting_header }}\n</header>\n<igx-buttongroup #sortButtonGroup>\n <button type=\"button\"\n igxButton\n [displayDensity]=\"esf.displayDensity\"\n [attr.data-togglable]=\"true\"\n (click)=\"onSortButtonClicked(1)\"\n >\n <igx-icon>arrow_upwards</igx-icon>\n <span>\n {{ esf.displayDensity==='compact'?\n esf.grid.resourceStrings.igx_grid_excel_filter_sorting_asc_short:\n esf.grid.resourceStrings.igx_grid_excel_filter_sorting_asc }}\n </span>\n </button>\n\n <button type=\"button\"\n igxButton\n [displayDensity]=\"esf.displayDensity\"\n [attr.data-togglable]=\"true\"\n (click)=\"onSortButtonClicked(2)\"\n >\n <igx-icon>arrow_downwards</igx-icon>\n <span>\n {{ esf.displayDensity==='compact'?\n esf.grid.resourceStrings.igx_grid_excel_filter_sorting_desc_short:\n esf.grid.resourceStrings.igx_grid_excel_filter_sorting_desc\n }}\n </span>\n </button>\n</igx-buttongroup>\n</ng-container>\n" }]
63
63
  }], ctorParameters: function () { return [{ type: i1.BaseFilteringComponent }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { defaultClass: [{
64
64
  type: HostBinding,
65
65
  args: ['class.igx-excel-filter__sort']
@@ -67,4 +67,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.8", ngImpor
67
67
  type: ViewChild,
68
68
  args: ['sortButtonGroup', { read: IgxButtonGroupComponent }]
69
69
  }] } });
70
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"excel-style-sorting.component.js","sourceRoot":"","sources":["../../../../../../../projects/igniteui-angular/src/lib/grids/filtering/excel-style/excel-style-sorting.component.ts","../../../../../../../projects/igniteui-angular/src/lib/grids/filtering/excel-style/excel-style-sorting.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ViewChild,\n    OnDestroy,\n    HostBinding,\n    ChangeDetectorRef\n} from '@angular/core';\nimport { IgxButtonGroupComponent } from '../../../buttonGroup/buttonGroup.component';\nimport { takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\nimport { BaseFilteringComponent } from './base-filtering.component';\nimport { IgxIconComponent } from '../../../icon/icon.component';\nimport { IgxButtonDirective } from '../../../directives/button/button.directive';\nimport { NgIf } from '@angular/common';\n\n/**\n * A component used for presenting Excel style column sorting UI.\n */\n@Component({\n    selector: 'igx-excel-style-sorting',\n    templateUrl: './excel-style-sorting.component.html',\n    standalone: true,\n    imports: [NgIf, IgxButtonGroupComponent, IgxButtonDirective, IgxIconComponent]\n})\nexport class IgxExcelStyleSortingComponent implements OnDestroy {\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('class.igx-excel-filter__sort')\n    public defaultClass = true;\n\n    /**\n     * @hidden @internal\n     */\n    @ViewChild('sortButtonGroup', { read: IgxButtonGroupComponent })\n    public sortButtonGroup: IgxButtonGroupComponent;\n\n    private destroy$ = new Subject<boolean>();\n\n    constructor(public esf: BaseFilteringComponent, private cdr: ChangeDetectorRef) {\n        this.esf.sortingChanged.pipe(takeUntil(this.destroy$)).subscribe(() => {\n            this.updateSelectedButtons(this.esf.column.field);\n        });\n     }\n\n     public ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.complete();\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onSortButtonClicked(sortDirection) {\n        if (this.sortButtonGroup.selectedIndexes.length === 0) {\n            if (this.esf.grid.isColumnGrouped(this.esf.column.field)) {\n                this.sortButtonGroup.selectButton(sortDirection - 1);\n            } else {\n                this.esf.grid.clearSort(this.esf.column.field);\n            }\n        } else {\n            this.esf.grid.sort({ fieldName: this.esf.column.field, dir: sortDirection, ignoreCase: true });\n        }\n    }\n\n    private updateSelectedButtons(fieldName: string) {\n        const sortIndex = this.esf.grid.sortingExpressions.findIndex(s => s.fieldName === fieldName);\n\n        this.cdr.detectChanges();\n        this.sortButtonGroup.buttons.forEach((b, i) => {\n            this.sortButtonGroup.deselectButton(i);\n        });\n\n        if (sortIndex !== -1 ) {\n            const sortDirection = this.esf.grid.sortingExpressions[sortIndex].dir;\n            this.sortButtonGroup.selectButton(sortDirection - 1);\n        }\n    }\n}\n","<ng-container *ngIf=\"esf.column\">\n<header>\n    {{ esf.grid.resourceStrings.igx_grid_excel_filter_sorting_header }}\n</header>\n<igx-buttongroup #sortButtonGroup>\n    <button igxButton\n        [displayDensity]=\"esf.displayDensity\"\n        [attr.data-togglable]=\"true\"\n        (click)=\"onSortButtonClicked(1)\"\n        >\n        <igx-icon>arrow_upwards</igx-icon>\n        <span>\n            {{ esf.displayDensity==='compact'?\n            esf.grid.resourceStrings.igx_grid_excel_filter_sorting_asc_short:\n            esf.grid.resourceStrings.igx_grid_excel_filter_sorting_asc  }}\n        </span>\n    </button>\n\n    <button igxButton\n        [displayDensity]=\"esf.displayDensity\"\n        [attr.data-togglable]=\"true\"\n        (click)=\"onSortButtonClicked(2)\"\n        >\n        <igx-icon>arrow_downwards</igx-icon>\n        <span>\n            {{ esf.displayDensity==='compact'?\n            esf.grid.resourceStrings.igx_grid_excel_filter_sorting_desc_short:\n            esf.grid.resourceStrings.igx_grid_excel_filter_sorting_desc\n        }}\n        </span>\n    </button>\n</igx-buttongroup>\n</ng-container>\n"]}
70
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"excel-style-sorting.component.js","sourceRoot":"","sources":["../../../../../../../projects/igniteui-angular/src/lib/grids/filtering/excel-style/excel-style-sorting.component.ts","../../../../../../../projects/igniteui-angular/src/lib/grids/filtering/excel-style/excel-style-sorting.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ViewChild,\n    OnDestroy,\n    HostBinding,\n    ChangeDetectorRef\n} from '@angular/core';\nimport { IgxButtonGroupComponent } from '../../../buttonGroup/buttonGroup.component';\nimport { takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\nimport { BaseFilteringComponent } from './base-filtering.component';\nimport { IgxIconComponent } from '../../../icon/icon.component';\nimport { IgxButtonDirective } from '../../../directives/button/button.directive';\nimport { NgIf } from '@angular/common';\n\n/**\n * A component used for presenting Excel style column sorting UI.\n */\n@Component({\n    selector: 'igx-excel-style-sorting',\n    templateUrl: './excel-style-sorting.component.html',\n    standalone: true,\n    imports: [NgIf, IgxButtonGroupComponent, IgxButtonDirective, IgxIconComponent]\n})\nexport class IgxExcelStyleSortingComponent implements OnDestroy {\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('class.igx-excel-filter__sort')\n    public defaultClass = true;\n\n    /**\n     * @hidden @internal\n     */\n    @ViewChild('sortButtonGroup', { read: IgxButtonGroupComponent })\n    public sortButtonGroup: IgxButtonGroupComponent;\n\n    private destroy$ = new Subject<boolean>();\n\n    constructor(public esf: BaseFilteringComponent, private cdr: ChangeDetectorRef) {\n        this.esf.sortingChanged.pipe(takeUntil(this.destroy$)).subscribe(() => {\n            this.updateSelectedButtons(this.esf.column.field);\n        });\n     }\n\n     public ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.complete();\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onSortButtonClicked(sortDirection) {\n        if (this.sortButtonGroup.selectedIndexes.length === 0) {\n            if (this.esf.grid.isColumnGrouped(this.esf.column.field)) {\n                this.sortButtonGroup.selectButton(sortDirection - 1);\n            } else {\n                this.esf.grid.clearSort(this.esf.column.field);\n            }\n        } else {\n            this.esf.grid.sort({ fieldName: this.esf.column.field, dir: sortDirection, ignoreCase: true });\n        }\n    }\n\n    private updateSelectedButtons(fieldName: string) {\n        const sortIndex = this.esf.grid.sortingExpressions.findIndex(s => s.fieldName === fieldName);\n\n        this.cdr.detectChanges();\n        this.sortButtonGroup.buttons.forEach((b, i) => {\n            this.sortButtonGroup.deselectButton(i);\n        });\n\n        if (sortIndex !== -1 ) {\n            const sortDirection = this.esf.grid.sortingExpressions[sortIndex].dir;\n            this.sortButtonGroup.selectButton(sortDirection - 1);\n        }\n    }\n}\n","<ng-container *ngIf=\"esf.column\">\n<header>\n    {{ esf.grid.resourceStrings.igx_grid_excel_filter_sorting_header }}\n</header>\n<igx-buttongroup #sortButtonGroup>\n    <button type=\"button\"\n        igxButton\n        [displayDensity]=\"esf.displayDensity\"\n        [attr.data-togglable]=\"true\"\n        (click)=\"onSortButtonClicked(1)\"\n        >\n        <igx-icon>arrow_upwards</igx-icon>\n        <span>\n            {{ esf.displayDensity==='compact'?\n            esf.grid.resourceStrings.igx_grid_excel_filter_sorting_asc_short:\n            esf.grid.resourceStrings.igx_grid_excel_filter_sorting_asc  }}\n        </span>\n    </button>\n\n    <button type=\"button\"\n        igxButton\n        [displayDensity]=\"esf.displayDensity\"\n        [attr.data-togglable]=\"true\"\n        (click)=\"onSortButtonClicked(2)\"\n        >\n        <igx-icon>arrow_downwards</igx-icon>\n        <span>\n            {{ esf.displayDensity==='compact'?\n            esf.grid.resourceStrings.igx_grid_excel_filter_sorting_desc_short:\n            esf.grid.resourceStrings.igx_grid_excel_filter_sorting_desc\n        }}\n        </span>\n    </button>\n</igx-buttongroup>\n</ng-container>\n"]}