igniteui-angular 16.0.17 → 16.0.18
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/calendar/calendar.mjs +33 -6
- package/esm2022/lib/calendar/days-view/days-view.component.mjs +2 -2
- package/esm2022/lib/services/exporter-common/base-export-service.mjs +9 -2
- package/esm2022/lib/splitter/splitter-pane/splitter-pane.component.mjs +2 -3
- package/esm2022/lib/splitter/splitter.component.mjs +22 -19
- package/fesm2022/igniteui-angular.mjs +63 -27
- package/fesm2022/igniteui-angular.mjs.map +1 -1
- package/lib/calendar/calendar.d.ts +1 -1
- package/lib/splitter/splitter.component.d.ts +5 -0
- package/package.json +1 -1
|
@@ -94,9 +94,8 @@ export class IgxSplitterPaneComponent {
|
|
|
94
94
|
* Gets the `flex` property of the current `IgxSplitterPaneComponent`.
|
|
95
95
|
*/
|
|
96
96
|
get flex() {
|
|
97
|
-
const isAuto = this.size === 'auto' && !this.dragSize;
|
|
98
|
-
const grow = !isAuto ? 0 : 1;
|
|
99
97
|
const size = this.dragSize || this.size;
|
|
98
|
+
const grow = this.isPercentageSize && !this.dragSize ? 1 : 0;
|
|
100
99
|
return `${grow} ${grow} ${size}`;
|
|
101
100
|
}
|
|
102
101
|
/**
|
|
@@ -248,4 +247,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.2", ngImpor
|
|
|
248
247
|
}], collapsed: [{
|
|
249
248
|
type: Input
|
|
250
249
|
}] } });
|
|
251
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"splitter-pane.component.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/splitter/splitter-pane/splitter-pane.component.ts","../../../../../../projects/igniteui-angular/src/lib/splitter/splitter-pane/splitter-pane.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostBinding, Input, ElementRef, Output, EventEmitter } from '@angular/core';\n\n/**\n * Represents individual resizable/collapsible panes.\n *\n * @igxModule IgxSplitterModule\n *\n * @igxParent IgxSplitterComponent\n *\n * @igxKeywords pane\n *\n * @igxGroup presentation\n *\n * @remarks\n *  Users can control the resize behavior via the min and max size properties.\n */\n@Component({\n    selector: 'igx-splitter-pane',\n    templateUrl: './splitter-pane.component.html',\n    standalone: true\n})\nexport class IgxSplitterPaneComponent {\n    private _minSize: string;\n    private _maxSize: string;\n\n    /**\n     * @hidden @internal\n     * Gets/Sets the 'display' property of the current pane.\n     */\n    @HostBinding('style.display')\n    public display = 'flex';\n\n    /**\n     * Gets/Sets the minimum allowed size of the current pane.\n     *\n     * @example\n     * ```html\n     * <igx-splitter>\n     *  <igx-splitter-pane [minSize]='minSize'>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Input()\n    public get minSize(): string {\n        return this._minSize;\n    }\n    public set minSize(value: string) {\n        this._minSize = value;\n        if (this.owner) {\n            this.owner.panes.notifyOnChanges();\n        }\n    }\n\n    /**\n     * Gets/Set the maximum allowed size of the current pane.\n     *\n     * @example\n     * ```html\n     * <igx-splitter>\n     *  <igx-splitter-pane [maxSize]='maxSize'>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Input()\n    public get maxSize(): string {\n        return this._maxSize;\n    }\n    public set maxSize(value: string) {\n        this._maxSize = value;\n        if (this.owner) {\n            this.owner.panes.notifyOnChanges();\n        }\n    }\n\n    /**\n     * Gets/Sets whether pane is resizable.\n     *\n     * @example\n     * ```html\n     * <igx-splitter>\n     *  <igx-splitter-pane [resizable]='false'>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     * @remarks\n     * If pane is not resizable its related splitter bar cannot be dragged.\n     */\n    @Input()\n    public resizable = true;\n\n    /**\n     * Event fired when collapsed state of pane is changed.\n     *\n     * @example\n     * ```html\n     * <igx-splitter>\n     *  <igx-splitter-pane (collapsedChange)='paneCollapsedChange($event)'>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Output()\n    public collapsedChange = new EventEmitter<boolean>();\n\n    /** @hidden @internal */\n    @HostBinding('style.order')\n    public order!: number;\n\n    /**\n     * @hidden @internal\n     * Gets/Sets the `overflow`.\n     */\n    @HostBinding('style.overflow')\n    public overflow = 'auto';\n\n    /**\n     * @hidden @internal\n     * Get/Sets the `minWidth` properties of the current pane.\n     */\n    @HostBinding('style.min-width')\n    public minWidth = '0';\n\n    /**\n     * @hidden @internal\n     * Get/Sets the `maxWidth` properties of the current pane.\n     */\n    @HostBinding('style.max-width')\n    public maxWidth = '100%';\n\n    /**\n     * @hidden @internal\n     * Gets/Sets the `minHeight` properties of the current pane.\n     */\n    @HostBinding('style.min-height')\n    public minHeight = '0';\n\n    /**\n     * @hidden @internal\n     * Gets/Sets the `maxHeight` properties of the current `IgxSplitterPaneComponent`.\n     */\n    @HostBinding('style.max-height')\n    public maxHeight = '100%';\n\n    /** @hidden @internal */\n    public owner;\n\n    /**\n     * Gets/Sets the size of the current pane.\n     *  * @example\n     * ```html\n     * <igx-splitter>\n     *  <igx-splitter-pane [size]='size'>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Input()\n    public get size() {\n        return this._size;\n    }\n\n    public set size(value) {\n        this._size = value;\n        this.el.nativeElement.style.flex = this.flex;\n    }\n\n    /** @hidden @internal */\n    public get isPercentageSize() {\n        return this.size === 'auto' || this.size.indexOf('%') !== -1;\n    }\n\n    /** @hidden @internal */\n    public get dragSize() {\n        return this._dragSize;\n    }\n    public set dragSize(val) {\n        this._dragSize = val;\n        this.el.nativeElement.style.flex = this.flex;\n    }\n\n    /**\n     *\n     * @hidden @internal\n     * Gets the host native element.\n     */\n    public get element(): any {\n        return this.el.nativeElement;\n    }\n\n    /**\n     * @hidden @internal\n     * Gets the `flex` property of the current `IgxSplitterPaneComponent`.\n     */\n    @HostBinding('style.flex')\n    public get flex() {\n        const isAuto = this.size === 'auto' && !this.dragSize;\n        const grow = !isAuto ? 0 : 1;\n        const size = this.dragSize || this.size;\n        return `${grow} ${grow} ${size}`;\n    }\n\n    /**\n     * Gets/Sets whether current pane is collapsed.\n     *\n     * @example\n     * ```typescript\n     * const isCollapsed = pane.collapsed;\n     * ```\n     */\n    @Input()\n    public set collapsed(value) {\n        if (this.owner) {\n            // reset sibling sizes when pane collapse state changes.\n            this._getSiblings().forEach(sibling => {\n                sibling.size = 'auto'\n                sibling.dragSize = null;\n            });\n        }\n        this._collapsed = value;\n        this.display = this._collapsed ? 'none' : 'flex';\n        this.collapsedChange.emit(this._collapsed);\n    }\n\n    public get collapsed() {\n        return this._collapsed;\n    }\n\n    private _size = 'auto';\n    private _dragSize;\n    private _collapsed = false;\n\n\n    constructor(private el: ElementRef) { }\n\n    /**\n     * Toggles the collapsed state of the pane.\n     *\n     * @example\n     * ```typescript\n     * pane.toggle();\n     * ```\n     */\n    public toggle() {\n        this.collapsed = !this.collapsed;\n    }\n\n    /** @hidden @internal */\n    private _getSiblings() {\n        const panes = this.owner.panes.toArray();\n        const index = panes.indexOf(this);\n        const siblings = [];\n        if (index !== 0) {\n            siblings.push(panes[index - 1]);\n        }\n        if (index !== panes.length - 1) {\n            siblings.push(panes[index + 1]);\n        }\n        return siblings;\n    }\n}\n","<ng-content></ng-content>"]}
|
|
250
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"splitter-pane.component.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/splitter/splitter-pane/splitter-pane.component.ts","../../../../../../projects/igniteui-angular/src/lib/splitter/splitter-pane/splitter-pane.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostBinding, Input, ElementRef, Output, EventEmitter } from '@angular/core';\n\n/**\n * Represents individual resizable/collapsible panes.\n *\n * @igxModule IgxSplitterModule\n *\n * @igxParent IgxSplitterComponent\n *\n * @igxKeywords pane\n *\n * @igxGroup presentation\n *\n * @remarks\n *  Users can control the resize behavior via the min and max size properties.\n */\n@Component({\n    selector: 'igx-splitter-pane',\n    templateUrl: './splitter-pane.component.html',\n    standalone: true\n})\nexport class IgxSplitterPaneComponent {\n    private _minSize: string;\n    private _maxSize: string;\n\n    /**\n     * @hidden @internal\n     * Gets/Sets the 'display' property of the current pane.\n     */\n    @HostBinding('style.display')\n    public display = 'flex';\n\n    /**\n     * Gets/Sets the minimum allowed size of the current pane.\n     *\n     * @example\n     * ```html\n     * <igx-splitter>\n     *  <igx-splitter-pane [minSize]='minSize'>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Input()\n    public get minSize(): string {\n        return this._minSize;\n    }\n    public set minSize(value: string) {\n        this._minSize = value;\n        if (this.owner) {\n            this.owner.panes.notifyOnChanges();\n        }\n    }\n\n    /**\n     * Gets/Set the maximum allowed size of the current pane.\n     *\n     * @example\n     * ```html\n     * <igx-splitter>\n     *  <igx-splitter-pane [maxSize]='maxSize'>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Input()\n    public get maxSize(): string {\n        return this._maxSize;\n    }\n    public set maxSize(value: string) {\n        this._maxSize = value;\n        if (this.owner) {\n            this.owner.panes.notifyOnChanges();\n        }\n    }\n\n    /**\n     * Gets/Sets whether pane is resizable.\n     *\n     * @example\n     * ```html\n     * <igx-splitter>\n     *  <igx-splitter-pane [resizable]='false'>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     * @remarks\n     * If pane is not resizable its related splitter bar cannot be dragged.\n     */\n    @Input()\n    public resizable = true;\n\n    /**\n     * Event fired when collapsed state of pane is changed.\n     *\n     * @example\n     * ```html\n     * <igx-splitter>\n     *  <igx-splitter-pane (collapsedChange)='paneCollapsedChange($event)'>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Output()\n    public collapsedChange = new EventEmitter<boolean>();\n\n    /** @hidden @internal */\n    @HostBinding('style.order')\n    public order!: number;\n\n    /**\n     * @hidden @internal\n     * Gets/Sets the `overflow`.\n     */\n    @HostBinding('style.overflow')\n    public overflow = 'auto';\n\n    /**\n     * @hidden @internal\n     * Get/Sets the `minWidth` properties of the current pane.\n     */\n    @HostBinding('style.min-width')\n    public minWidth = '0';\n\n    /**\n     * @hidden @internal\n     * Get/Sets the `maxWidth` properties of the current pane.\n     */\n    @HostBinding('style.max-width')\n    public maxWidth = '100%';\n\n    /**\n     * @hidden @internal\n     * Gets/Sets the `minHeight` properties of the current pane.\n     */\n    @HostBinding('style.min-height')\n    public minHeight = '0';\n\n    /**\n     * @hidden @internal\n     * Gets/Sets the `maxHeight` properties of the current `IgxSplitterPaneComponent`.\n     */\n    @HostBinding('style.max-height')\n    public maxHeight = '100%';\n\n    /** @hidden @internal */\n    public owner;\n\n    /**\n     * Gets/Sets the size of the current pane.\n     *  * @example\n     * ```html\n     * <igx-splitter>\n     *  <igx-splitter-pane [size]='size'>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Input()\n    public get size() {\n        return this._size;\n    }\n\n    public set size(value) {\n        this._size = value;\n        this.el.nativeElement.style.flex = this.flex;\n    }\n\n    /** @hidden @internal */\n    public get isPercentageSize() {\n        return this.size === 'auto' || this.size.indexOf('%') !== -1;\n    }\n\n    /** @hidden @internal */\n    public get dragSize() {\n        return this._dragSize;\n    }\n    public set dragSize(val) {\n        this._dragSize = val;\n        this.el.nativeElement.style.flex = this.flex;\n    }\n\n    /**\n     *\n     * @hidden @internal\n     * Gets the host native element.\n     */\n    public get element(): any {\n        return this.el.nativeElement;\n    }\n\n    /**\n     * @hidden @internal\n     * Gets the `flex` property of the current `IgxSplitterPaneComponent`.\n     */\n    @HostBinding('style.flex')\n    public get flex() {\n        const size = this.dragSize || this.size;\n        const grow = this.isPercentageSize && !this.dragSize ? 1 : 0;\n        return `${grow} ${grow} ${size}`;\n    }\n\n    /**\n     * Gets/Sets whether current pane is collapsed.\n     *\n     * @example\n     * ```typescript\n     * const isCollapsed = pane.collapsed;\n     * ```\n     */\n    @Input()\n    public set collapsed(value) {\n        if (this.owner) {\n            // reset sibling sizes when pane collapse state changes.\n            this._getSiblings().forEach(sibling => {\n                sibling.size = 'auto'\n                sibling.dragSize = null;\n            });\n        }\n        this._collapsed = value;\n        this.display = this._collapsed ? 'none' : 'flex';\n        this.collapsedChange.emit(this._collapsed);\n    }\n\n    public get collapsed() {\n        return this._collapsed;\n    }\n\n    private _size = 'auto';\n    private _dragSize;\n    private _collapsed = false;\n\n\n    constructor(private el: ElementRef) { }\n\n    /**\n     * Toggles the collapsed state of the pane.\n     *\n     * @example\n     * ```typescript\n     * pane.toggle();\n     * ```\n     */\n    public toggle() {\n        this.collapsed = !this.collapsed;\n    }\n\n    /** @hidden @internal */\n    private _getSiblings() {\n        const panes = this.owner.panes.toArray();\n        const index = panes.indexOf(this);\n        const siblings = [];\n        if (index !== 0) {\n            siblings.push(panes[index - 1]);\n        }\n        if (index !== panes.length - 1) {\n            siblings.push(panes[index + 1]);\n        }\n        return siblings;\n    }\n}\n","<ng-content></ng-content>"]}
|
|
@@ -150,30 +150,14 @@ export class IgxSplitterComponent {
|
|
|
150
150
|
* @param delta - The difference along the X (or Y) axis between the initial and the current point when dragging the bar.
|
|
151
151
|
*/
|
|
152
152
|
onMoving(delta) {
|
|
153
|
-
const
|
|
154
|
-
const max = parseInt(this.pane.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;
|
|
155
|
-
const minSibling = parseInt(this.sibling.minSize, 10) || 0;
|
|
156
|
-
const maxSibling = parseInt(this.sibling.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;
|
|
157
|
-
const paneSize = this.initialPaneSize - delta;
|
|
158
|
-
const siblingSize = this.initialSiblingSize + delta;
|
|
159
|
-
if (paneSize < min || paneSize > max || siblingSize < minSibling || siblingSize > maxSibling) {
|
|
160
|
-
return;
|
|
161
|
-
}
|
|
153
|
+
const [paneSize, siblingSize] = this.calcNewSizes(delta);
|
|
162
154
|
this.pane.dragSize = paneSize + 'px';
|
|
163
155
|
this.sibling.dragSize = siblingSize + 'px';
|
|
164
156
|
const args = { pane: this.pane, sibling: this.sibling };
|
|
165
157
|
this.resizing.emit(args);
|
|
166
158
|
}
|
|
167
159
|
onMoveEnd(delta) {
|
|
168
|
-
const
|
|
169
|
-
const max = parseInt(this.pane.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;
|
|
170
|
-
const minSibling = parseInt(this.sibling.minSize, 10) || 0;
|
|
171
|
-
const maxSibling = parseInt(this.sibling.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;
|
|
172
|
-
const paneSize = this.initialPaneSize - delta;
|
|
173
|
-
const siblingSize = this.initialSiblingSize + delta;
|
|
174
|
-
if (paneSize < min || paneSize > max || siblingSize < minSibling || siblingSize > maxSibling) {
|
|
175
|
-
return;
|
|
176
|
-
}
|
|
160
|
+
const [paneSize, siblingSize] = this.calcNewSizes(delta);
|
|
177
161
|
if (this.pane.isPercentageSize) {
|
|
178
162
|
// handle % resizes
|
|
179
163
|
const totalSize = this.getTotalSize();
|
|
@@ -261,6 +245,25 @@ export class IgxSplitterComponent {
|
|
|
261
245
|
k += 2;
|
|
262
246
|
});
|
|
263
247
|
}
|
|
248
|
+
/**
|
|
249
|
+
* @hidden @internal
|
|
250
|
+
* Calculates new sizes for the panes based on move delta and initial sizes
|
|
251
|
+
*/
|
|
252
|
+
calcNewSizes(delta) {
|
|
253
|
+
const min = parseInt(this.pane.minSize, 10) || 0;
|
|
254
|
+
const minSibling = parseInt(this.sibling.minSize, 10) || 0;
|
|
255
|
+
const max = parseInt(this.pane.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize - minSibling;
|
|
256
|
+
const maxSibling = parseInt(this.sibling.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize - min;
|
|
257
|
+
if (delta < 0) {
|
|
258
|
+
const maxPossibleDelta = Math.min(max - this.initialPaneSize, this.initialSiblingSize - minSibling);
|
|
259
|
+
delta = Math.min(maxPossibleDelta, Math.abs(delta)) * -1;
|
|
260
|
+
}
|
|
261
|
+
else {
|
|
262
|
+
const maxPossibleDelta = Math.min(this.initialPaneSize - min, maxSibling - this.initialSiblingSize);
|
|
263
|
+
delta = Math.min(maxPossibleDelta, Math.abs(delta));
|
|
264
|
+
}
|
|
265
|
+
return [this.initialPaneSize - delta, this.initialSiblingSize + delta];
|
|
266
|
+
}
|
|
264
267
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: IgxSplitterComponent, deps: [{ token: DOCUMENT }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
265
268
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.2", type: IgxSplitterComponent, isStandalone: true, selector: "igx-splitter", inputs: { type: "type" }, outputs: { resizeStart: "resizeStart", resizing: "resizing", resizeEnd: "resizeEnd" }, host: { properties: { "class.igx-splitter": "this.cssClass", "style.overflow": "this.overflow", "style.display": "this.display", "attr.aria-orientation": "this.orientation", "style.flex-direction": "this.direction" } }, queries: [{ propertyName: "panes", predicate: IgxSplitterPaneComponent, read: IgxSplitterPaneComponent }], ngImport: i0, template: "<ng-content select=\"igx-splitter-pane\"></ng-content>\n<ng-container *ngFor=\"let pane of panes; let last = last; let index= index;\">\n <igx-splitter-bar *ngIf=\"!last\" [order]='pane.order + 1' role='separator'\n [type]=\"type\"\n [pane]=\"pane\"\n [siblings]='getPaneSiblingsByOrder(pane.order + 1, index)'\n (moveStart)=\"onMoveStart($event)\"\n (moving)=\"onMoving($event)\"\n (movingEnd)='onMoveEnd($event)'>\n </igx-splitter-bar>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return NgFor; }), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i0.forwardRef(function () { return NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i0.forwardRef(function () { return IgxSplitBarComponent; }), selector: "igx-splitter-bar", inputs: ["type", "order", "pane", "siblings"], outputs: ["moveStart", "moving", "movingEnd"] }] }); }
|
|
266
269
|
}
|
|
@@ -524,4 +527,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.2", ngImpor
|
|
|
524
527
|
type: HostListener,
|
|
525
528
|
args: ['keydown', ['$event']]
|
|
526
529
|
}] } });
|
|
527
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"splitter.component.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/splitter/splitter.component.ts","../../../../../projects/igniteui-angular/src/lib/splitter/splitter.component.html","../../../../../projects/igniteui-angular/src/lib/splitter/splitter-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT, NgFor, NgIf } from '@angular/common';\nimport { AfterContentInit, Component, ContentChildren, ElementRef, EventEmitter, HostBinding, HostListener, Inject, Input, Output, QueryList, forwardRef } from '@angular/core';\nimport { DragDirection, IDragMoveEventArgs, IDragStartEventArgs, IgxDragDirective, IgxDragIgnoreDirective } from '../directives/drag-drop/drag-drop.directive';\nimport { IgxSplitterPaneComponent } from './splitter-pane/splitter-pane.component';\n\n/**\n * An enumeration that defines the `SplitterComponent` panes orientation.\n */\nexport enum SplitterType {\n    Horizontal,\n    Vertical\n}\n\nexport declare interface ISplitterBarResizeEventArgs {\n    pane: IgxSplitterPaneComponent;\n    sibling: IgxSplitterPaneComponent;\n}\n\n/**\n * Provides a framework for a simple layout, splitting the view horizontally or vertically\n * into multiple smaller resizable and collapsible areas.\n *\n * @igxModule IgxSplitterModule\n *\n * @igxParent Layouts\n *\n * @igxTheme igx-splitter-theme\n *\n * @igxKeywords splitter panes layout\n *\n * @igxGroup presentation\n *\n * @example\n * ```html\n * <igx-splitter>\n *  <igx-splitter-pane>\n *      ...\n *  </igx-splitter-pane>\n *  <igx-splitter-pane>\n *      ...\n *  </igx-splitter-pane>\n * </igx-splitter>\n * ```\n */\n@Component({\n    selector: 'igx-splitter',\n    templateUrl: './splitter.component.html',\n    standalone: true,\n    imports: [NgFor, NgIf, forwardRef(() => IgxSplitBarComponent)]\n})\nexport class IgxSplitterComponent implements AfterContentInit {\n    /**\n     * Gets the list of splitter panes.\n     *\n     * @example\n     * ```typescript\n     * const panes = this.splitter.panes;\n     * ```\n     */\n    @ContentChildren(IgxSplitterPaneComponent, { read: IgxSplitterPaneComponent })\n    public panes!: QueryList<IgxSplitterPaneComponent>;\n\n    /**\n    * @hidden\n    * @internal\n    */\n    @HostBinding('class.igx-splitter')\n    public cssClass = 'igx-splitter';\n\n    /**\n     * @hidden @internal\n     * Gets/Sets the `overflow` property of the current splitter.\n     */\n    @HostBinding('style.overflow')\n    public overflow = 'hidden';\n\n    /**\n     * @hidden @internal\n     * Sets/Gets the `display` property of the current splitter.\n     */\n    @HostBinding('style.display')\n    public display = 'flex';\n\n    /**\n     * @hidden\n     * @internal\n     */\n    @HostBinding('attr.aria-orientation')\n    public get orientation() {\n        return this.type === SplitterType.Horizontal ? 'horizontal' : 'vertical';\n    }\n\n    /**\n     * Event fired when resizing of panes starts.\n     *\n     * @example\n     * ```html\n     * <igx-splitter (resizeStart)='resizeStart($event)'>\n     *  <igx-splitter-pane>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Output()\n    public resizeStart = new EventEmitter<ISplitterBarResizeEventArgs>();\n\n    /**\n     * Event fired when resizing of panes is in progress.\n     *\n     * @example\n     * ```html\n     * <igx-splitter (resizing)='resizing($event)'>\n     *  <igx-splitter-pane>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Output()\n    public resizing = new EventEmitter<ISplitterBarResizeEventArgs>();\n\n\n    /**\n     * Event fired when resizing of panes ends.\n     *\n     * @example\n     * ```html\n     * <igx-splitter (resizeEnd)='resizeEnd($event)'>\n     *  <igx-splitter-pane>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Output()\n    public resizeEnd = new EventEmitter<ISplitterBarResizeEventArgs>();\n\n    private _type: SplitterType = SplitterType.Horizontal;\n\n    /**\n     * @hidden @internal\n     * A field that holds the initial size of the main `IgxSplitterPaneComponent` in each pair of panes divided by a splitter bar.\n     */\n    private initialPaneSize!: number;\n\n    /**\n     * @hidden @internal\n     * A field that holds the initial size of the sibling pane in each pair of panes divided by a gripper.\n     * @memberof SplitterComponent\n     */\n    private initialSiblingSize!: number;\n\n    /**\n     * @hidden @internal\n     * The main pane in each pair of panes divided by a gripper.\n     */\n    private pane!: IgxSplitterPaneComponent;\n\n    /**\n     * The sibling pane in each pair of panes divided by a splitter bar.\n     */\n    private sibling!: IgxSplitterPaneComponent;\n\n    constructor(@Inject(DOCUMENT) public document, private elementRef: ElementRef) { }\n    /**\n     * Gets/Sets the splitter orientation.\n     *\n     * @example\n     * ```html\n     * <igx-splitter [type]=\"type\">...</igx-splitter>\n     * ```\n     */\n    @Input()\n    public get type() {\n        return this._type;\n    }\n    public set type(value) {\n        this._type = value;\n        this.resetPaneSizes();\n        this.panes?.notifyOnChanges();\n    }\n\n    /**\n     * @hidden @internal\n     * Gets the `flex-direction` property of the current `SplitterComponent`.\n     */\n    @HostBinding('style.flex-direction')\n    public get direction(): string {\n        return this.type === SplitterType.Horizontal ? 'row' : 'column';\n    }\n\n    /** @hidden @internal */\n    public ngAfterContentInit(): void {\n        this.initPanes();\n        this.panes.changes.subscribe(() => {\n            this.initPanes();\n        });\n    }\n\n    /**\n     * @hidden @internal\n     * This method performs  initialization logic when the user starts dragging the splitter bar between each pair of panes.\n     * @param pane - the main pane associated with the currently dragged bar.\n     */\n    public onMoveStart(pane: IgxSplitterPaneComponent) {\n        const panes = this.panes.toArray();\n        this.pane = pane;\n        this.sibling = panes[panes.indexOf(this.pane) + 1];\n\n        const paneRect = this.pane.element.getBoundingClientRect();\n        this.initialPaneSize = this.type === SplitterType.Horizontal ? paneRect.width : paneRect.height;\n\n        const siblingRect = this.sibling.element.getBoundingClientRect();\n        this.initialSiblingSize = this.type === SplitterType.Horizontal ? siblingRect.width : siblingRect.height;\n        const args: ISplitterBarResizeEventArgs = { pane: this.pane, sibling: this.sibling };\n        this.resizeStart.emit(args);\n    }\n\n    /**\n     * @hidden @internal\n     * This method performs calculations concerning the sizes of each pair of panes when the bar between them is dragged.\n     * @param delta - The difference along the X (or Y) axis between the initial and the current point when dragging the bar.\n     */\n    public onMoving(delta: number) {\n        const min = parseInt(this.pane.minSize, 10) || 0;\n        const max = parseInt(this.pane.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;\n        const minSibling = parseInt(this.sibling.minSize, 10) || 0;\n        const maxSibling = parseInt(this.sibling.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;\n\n        const paneSize = this.initialPaneSize - delta;\n        const siblingSize = this.initialSiblingSize + delta;\n        if (paneSize < min || paneSize > max || siblingSize < minSibling || siblingSize > maxSibling) {\n            return;\n        }\n        this.pane.dragSize = paneSize + 'px';\n        this.sibling.dragSize = siblingSize + 'px';\n\n        const args: ISplitterBarResizeEventArgs = { pane: this.pane, sibling: this.sibling };\n        this.resizing.emit(args);\n    }\n\n    public onMoveEnd(delta: number) {\n        const min = parseInt(this.pane.minSize, 10) || 0;\n        const max = parseInt(this.pane.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;\n        const minSibling = parseInt(this.sibling.minSize, 10) || 0;\n        const maxSibling = parseInt(this.sibling.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;\n\n        const paneSize = this.initialPaneSize - delta;\n        const siblingSize = this.initialSiblingSize + delta;\n\n        if (paneSize < min || paneSize > max || siblingSize < minSibling || siblingSize > maxSibling) {\n            return;\n        }\n        if (this.pane.isPercentageSize) {\n            // handle % resizes\n            const totalSize = this.getTotalSize();\n            const percentPaneSize = (paneSize / totalSize) * 100;\n            this.pane.size = percentPaneSize + '%';\n        } else {\n            // px resize\n            this.pane.size = paneSize + 'px';\n        }\n\n        if (this.sibling.isPercentageSize) {\n            // handle % resizes\n            const totalSize = this.getTotalSize();\n            const percentSiblingPaneSize = (siblingSize / totalSize) * 100;\n            this.sibling.size = percentSiblingPaneSize + '%';\n        } else {\n            // px resize\n            this.sibling.size = siblingSize + 'px';\n        }\n        this.pane.dragSize = null;\n        this.sibling.dragSize = null;\n\n        const args: ISplitterBarResizeEventArgs = { pane: this.pane, sibling: this.sibling };\n        this.resizeEnd.emit(args);\n    }\n\n    /** @hidden @internal */\n    public getPaneSiblingsByOrder(order: number, barIndex: number): Array<IgxSplitterPaneComponent> {\n        const panes = this.panes.toArray();\n        const prevPane = panes[order - barIndex - 1];\n        const nextPane = panes[order - barIndex];\n        const siblings = [prevPane, nextPane];\n        return siblings;\n    }\n\n    private getTotalSize() {\n        const computed = this.document.defaultView.getComputedStyle(this.elementRef.nativeElement);\n        const totalSize = this.type === SplitterType.Horizontal ? computed.getPropertyValue('width') : computed.getPropertyValue('height');\n        return parseFloat(totalSize);\n    }\n\n\n    /**\n     * @hidden @internal\n     * This method inits panes with properties.\n     */\n    private initPanes() {\n        this.panes.forEach(pane => {\n            pane.owner = this;\n            if (this.type === SplitterType.Horizontal) {\n                pane.minWidth = pane.minSize ?? '0';\n                pane.maxWidth = pane.maxSize ?? '100%';\n            } else {\n                pane.minHeight = pane.minSize ?? '0';\n                pane.maxHeight = pane.maxSize ?? '100%';\n            }\n        });\n        this.assignFlexOrder();\n        if (this.panes.filter(x => x.collapsed).length > 0) {\n            // if any panes are collapsed, reset sizes.\n            this.resetPaneSizes();\n        }\n    }\n\n    /**\n     * @hidden @internal\n     * This method reset pane sizes.\n     */\n    private resetPaneSizes() {\n        if (this.panes) {\n            // if type is changed runtime, should reset sizes.\n            this.panes.forEach(x => {\n                x.size = 'auto'\n                x.minWidth = '0';\n                x.maxWidth = '100%';\n                x.minHeight = '0';\n                x.maxHeight = '100%';\n            });\n        }\n    }\n\n    /**\n     * @hidden @internal\n     * This method assigns the order of each pane.\n     */\n    private assignFlexOrder() {\n        let k = 0;\n        this.panes.forEach((pane: IgxSplitterPaneComponent) => {\n            pane.order = k;\n            k += 2;\n        });\n    }\n}\n\nexport const SPLITTER_INTERACTION_KEYS = new Set('right down left up arrowright arrowdown arrowleft arrowup'.split(' '));\n\n/**\n * @hidden @internal\n * Represents the draggable bar that visually separates panes and allows for changing their sizes.\n */\n@Component({\n    selector: 'igx-splitter-bar',\n    templateUrl: './splitter-bar.component.html',\n    standalone: true,\n    imports: [IgxDragDirective, IgxDragIgnoreDirective]\n})\nexport class IgxSplitBarComponent {\n    /**\n     * Set css class to the host element.\n     */\n    @HostBinding('class.igx-splitter-bar-host')\n    public cssClass = 'igx-splitter-bar-host';\n\n    /**\n     * Gets/Sets the orientation.\n     */\n    @Input()\n    public type: SplitterType = SplitterType.Horizontal;\n\n    /**\n     * Sets/gets the element order.\n     */\n    @HostBinding('style.order')\n    @Input()\n    public order!: number;\n\n    /**\n     * @hidden\n     * @internal\n     */\n    @HostBinding('attr.tabindex')\n    public get tabindex() {\n        return this.resizeDisallowed ? null : 0;\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    @HostBinding('attr.aria-orientation')\n    public get orientation() {\n        return this.type === SplitterType.Horizontal ? 'horizontal' : 'vertical';\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public get cursor() {\n        if (this.resizeDisallowed) {\n            return '';\n        }\n        return this.type === SplitterType.Horizontal ? 'col-resize' : 'row-resize';\n    }\n\n    /**\n     * Sets/gets the `SplitPaneComponent` associated with the current `SplitBarComponent`.\n     *\n     * @memberof SplitBarComponent\n     */\n    @Input()\n    public pane!: IgxSplitterPaneComponent;\n\n    /**\n     * Sets/Gets the `SplitPaneComponent` sibling components associated with the current `SplitBarComponent`.\n     */\n    @Input()\n    public siblings!: Array<IgxSplitterPaneComponent>;\n\n    /**\n     * An event that is emitted whenever we start dragging the current `SplitBarComponent`.\n     */\n    @Output()\n    public moveStart = new EventEmitter<IgxSplitterPaneComponent>();\n\n    /**\n     * An event that is emitted while we are dragging the current `SplitBarComponent`.\n     */\n    @Output()\n    public moving = new EventEmitter<number>();\n\n    @Output()\n    public movingEnd = new EventEmitter<number>();\n\n    /**\n     * A temporary holder for the pointer coordinates.\n     */\n    private startPoint!: number;\n\n    /**\n     * @hidden @internal\n     */\n    public get prevButtonHidden() {\n        return this.siblings[0].collapsed && !this.siblings[1].collapsed;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    @HostListener('keydown', ['$event'])\n    public keyEvent(event: KeyboardEvent) {\n        const key = event.key.toLowerCase();\n        const ctrl = event.ctrlKey;\n        event.stopPropagation();\n        if (SPLITTER_INTERACTION_KEYS.has(key)) {\n            event.preventDefault();\n        }\n        switch (key) {\n            case 'arrowup':\n            case 'up':\n                if (this.type === SplitterType.Vertical) {\n                    if (ctrl) {\n                        this.onCollapsing(false);\n                        break;\n                    }\n                    if (!this.resizeDisallowed) {\n                        event.preventDefault();\n                        this.moveStart.emit(this.pane);\n                        this.moving.emit(10);\n                    }\n                }\n                break;\n            case 'arrowdown':\n            case 'down':\n                if (this.type === SplitterType.Vertical) {\n                    if (ctrl) {\n                        this.onCollapsing(true);\n                        break;\n                    }\n                    if (!this.resizeDisallowed) {\n                        event.preventDefault();\n                        this.moveStart.emit(this.pane);\n                        this.moving.emit(-10);\n                    }\n                }\n                break;\n            case 'arrowleft':\n            case 'left':\n                if (this.type === SplitterType.Horizontal) {\n                    if (ctrl) {\n                        this.onCollapsing(false);\n                        break;\n                    }\n                    if (!this.resizeDisallowed) {\n                        event.preventDefault();\n                        this.moveStart.emit(this.pane);\n                        this.moving.emit(10);\n                    }\n                }\n                break;\n            case 'arrowright':\n            case 'right':\n                if (this.type === SplitterType.Horizontal) {\n                    if (ctrl) {\n                        this.onCollapsing(true);\n                        break;\n                    }\n                    if (!this.resizeDisallowed) {\n                        event.preventDefault();\n                        this.moveStart.emit(this.pane);\n                        this.moving.emit(-10);\n                    }\n                }\n                break;\n            default:\n                break;\n        }\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get dragDir() {\n        return this.type === SplitterType.Horizontal ? DragDirection.VERTICAL : DragDirection.HORIZONTAL;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get nextButtonHidden() {\n        return this.siblings[1].collapsed && !this.siblings[0].collapsed;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onDragStart(event: IDragStartEventArgs) {\n        if (this.resizeDisallowed) {\n            event.cancel = true;\n            return;\n        }\n        this.startPoint = this.type === SplitterType.Horizontal ? event.startX : event.startY;\n        this.moveStart.emit(this.pane);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onDragMove(event: IDragMoveEventArgs) {\n        const isHorizontal = this.type === SplitterType.Horizontal;\n        const curr = isHorizontal ? event.pageX : event.pageY;\n        const delta = this.startPoint - curr;\n        if (delta !== 0) {\n            this.moving.emit(delta);\n            event.cancel = true;\n            event.owner.element.nativeElement.style.transform = '';\n        }\n    }\n\n    public onDragEnd(event: any) {\n        const isHorizontal = this.type === SplitterType.Horizontal;\n        const curr = isHorizontal ? event.pageX : event.pageY;\n        const delta = this.startPoint - curr;\n        if (delta !== 0) {\n            this.movingEnd.emit(delta);\n        }\n    }\n\n    protected get resizeDisallowed() {\n        const relatedTabs = this.siblings;\n        return !!relatedTabs.find(x => x.resizable === false || x.collapsed === true);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onCollapsing(next: boolean) {\n        const prevSibling = this.siblings[0];\n        const nextSibling = this.siblings[1];\n        let target;\n        if (next) {\n            // if next is clicked when prev pane is hidden, show prev pane, else hide next pane.\n            target = prevSibling.collapsed ? prevSibling : nextSibling;\n        } else {\n            // if prev is clicked when next pane is hidden, show next pane, else hide prev pane.\n            target = nextSibling.collapsed ? nextSibling : prevSibling;\n        }\n        target.toggle();\n    }\n}\n","<ng-content select=\"igx-splitter-pane\"></ng-content>\n<ng-container *ngFor=\"let pane of panes; let last = last; let index= index;\">\n    <igx-splitter-bar *ngIf=\"!last\" [order]='pane.order + 1' role='separator'\n                    [type]=\"type\"\n                    [pane]=\"pane\"\n                    [siblings]='getPaneSiblingsByOrder(pane.order + 1, index)'\n                    (moveStart)=\"onMoveStart($event)\"\n                    (moving)=\"onMoving($event)\"\n                    (movingEnd)='onMoveEnd($event)'>\n    </igx-splitter-bar>\n</ng-container>\n","<div class=\"igx-splitter-bar\"\n    [class.igx-splitter-bar--vertical]='type === 0'\n    [style.cursor]='cursor'\n    igxDrag\n    [ghost]=\"false\"\n    [dragDirection]='dragDir'\n    (dragStart)='onDragStart($event)'\n    (dragMove)=\"onDragMove($event)\"\n    (dragEnd)=\"onDragEnd($event)\"\n>\n    <div class=\"igx-splitter-bar__expander--start\" igxDragIgnore (click)='onCollapsing(false)' [hidden]='prevButtonHidden'></div>\n    <div class=\"igx-splitter-bar__handle\" ></div>\n    <div class=\"igx-splitter-bar__expander--end\" igxDragIgnore (click)='onCollapsing(true)' [hidden]='nextButtonHidden'></div>\n</div>\n"]}
|
|
530
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"splitter.component.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/splitter/splitter.component.ts","../../../../../projects/igniteui-angular/src/lib/splitter/splitter.component.html","../../../../../projects/igniteui-angular/src/lib/splitter/splitter-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT, NgFor, NgIf } from '@angular/common';\nimport { AfterContentInit, Component, ContentChildren, ElementRef, EventEmitter, HostBinding, HostListener, Inject, Input, Output, QueryList, forwardRef } from '@angular/core';\nimport { DragDirection, IDragMoveEventArgs, IDragStartEventArgs, IgxDragDirective, IgxDragIgnoreDirective } from '../directives/drag-drop/drag-drop.directive';\nimport { IgxSplitterPaneComponent } from './splitter-pane/splitter-pane.component';\n\n/**\n * An enumeration that defines the `SplitterComponent` panes orientation.\n */\nexport enum SplitterType {\n    Horizontal,\n    Vertical\n}\n\nexport declare interface ISplitterBarResizeEventArgs {\n    pane: IgxSplitterPaneComponent;\n    sibling: IgxSplitterPaneComponent;\n}\n\n/**\n * Provides a framework for a simple layout, splitting the view horizontally or vertically\n * into multiple smaller resizable and collapsible areas.\n *\n * @igxModule IgxSplitterModule\n *\n * @igxParent Layouts\n *\n * @igxTheme igx-splitter-theme\n *\n * @igxKeywords splitter panes layout\n *\n * @igxGroup presentation\n *\n * @example\n * ```html\n * <igx-splitter>\n *  <igx-splitter-pane>\n *      ...\n *  </igx-splitter-pane>\n *  <igx-splitter-pane>\n *      ...\n *  </igx-splitter-pane>\n * </igx-splitter>\n * ```\n */\n@Component({\n    selector: 'igx-splitter',\n    templateUrl: './splitter.component.html',\n    standalone: true,\n    imports: [NgFor, NgIf, forwardRef(() => IgxSplitBarComponent)]\n})\nexport class IgxSplitterComponent implements AfterContentInit {\n    /**\n     * Gets the list of splitter panes.\n     *\n     * @example\n     * ```typescript\n     * const panes = this.splitter.panes;\n     * ```\n     */\n    @ContentChildren(IgxSplitterPaneComponent, { read: IgxSplitterPaneComponent })\n    public panes!: QueryList<IgxSplitterPaneComponent>;\n\n    /**\n    * @hidden\n    * @internal\n    */\n    @HostBinding('class.igx-splitter')\n    public cssClass = 'igx-splitter';\n\n    /**\n     * @hidden @internal\n     * Gets/Sets the `overflow` property of the current splitter.\n     */\n    @HostBinding('style.overflow')\n    public overflow = 'hidden';\n\n    /**\n     * @hidden @internal\n     * Sets/Gets the `display` property of the current splitter.\n     */\n    @HostBinding('style.display')\n    public display = 'flex';\n\n    /**\n     * @hidden\n     * @internal\n     */\n    @HostBinding('attr.aria-orientation')\n    public get orientation() {\n        return this.type === SplitterType.Horizontal ? 'horizontal' : 'vertical';\n    }\n\n    /**\n     * Event fired when resizing of panes starts.\n     *\n     * @example\n     * ```html\n     * <igx-splitter (resizeStart)='resizeStart($event)'>\n     *  <igx-splitter-pane>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Output()\n    public resizeStart = new EventEmitter<ISplitterBarResizeEventArgs>();\n\n    /**\n     * Event fired when resizing of panes is in progress.\n     *\n     * @example\n     * ```html\n     * <igx-splitter (resizing)='resizing($event)'>\n     *  <igx-splitter-pane>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Output()\n    public resizing = new EventEmitter<ISplitterBarResizeEventArgs>();\n\n\n    /**\n     * Event fired when resizing of panes ends.\n     *\n     * @example\n     * ```html\n     * <igx-splitter (resizeEnd)='resizeEnd($event)'>\n     *  <igx-splitter-pane>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Output()\n    public resizeEnd = new EventEmitter<ISplitterBarResizeEventArgs>();\n\n    private _type: SplitterType = SplitterType.Horizontal;\n\n    /**\n     * @hidden @internal\n     * A field that holds the initial size of the main `IgxSplitterPaneComponent` in each pair of panes divided by a splitter bar.\n     */\n    private initialPaneSize!: number;\n\n    /**\n     * @hidden @internal\n     * A field that holds the initial size of the sibling pane in each pair of panes divided by a gripper.\n     * @memberof SplitterComponent\n     */\n    private initialSiblingSize!: number;\n\n    /**\n     * @hidden @internal\n     * The main pane in each pair of panes divided by a gripper.\n     */\n    private pane!: IgxSplitterPaneComponent;\n\n    /**\n     * The sibling pane in each pair of panes divided by a splitter bar.\n     */\n    private sibling!: IgxSplitterPaneComponent;\n\n    constructor(@Inject(DOCUMENT) public document, private elementRef: ElementRef) { }\n    /**\n     * Gets/Sets the splitter orientation.\n     *\n     * @example\n     * ```html\n     * <igx-splitter [type]=\"type\">...</igx-splitter>\n     * ```\n     */\n    @Input()\n    public get type() {\n        return this._type;\n    }\n    public set type(value) {\n        this._type = value;\n        this.resetPaneSizes();\n        this.panes?.notifyOnChanges();\n    }\n\n    /**\n     * @hidden @internal\n     * Gets the `flex-direction` property of the current `SplitterComponent`.\n     */\n    @HostBinding('style.flex-direction')\n    public get direction(): string {\n        return this.type === SplitterType.Horizontal ? 'row' : 'column';\n    }\n\n    /** @hidden @internal */\n    public ngAfterContentInit(): void {\n        this.initPanes();\n        this.panes.changes.subscribe(() => {\n            this.initPanes();\n        });\n    }\n\n    /**\n     * @hidden @internal\n     * This method performs  initialization logic when the user starts dragging the splitter bar between each pair of panes.\n     * @param pane - the main pane associated with the currently dragged bar.\n     */\n    public onMoveStart(pane: IgxSplitterPaneComponent) {\n        const panes = this.panes.toArray();\n        this.pane = pane;\n        this.sibling = panes[panes.indexOf(this.pane) + 1];\n\n        const paneRect = this.pane.element.getBoundingClientRect();\n        this.initialPaneSize = this.type === SplitterType.Horizontal ? paneRect.width : paneRect.height;\n\n        const siblingRect = this.sibling.element.getBoundingClientRect();\n        this.initialSiblingSize = this.type === SplitterType.Horizontal ? siblingRect.width : siblingRect.height;\n        const args: ISplitterBarResizeEventArgs = { pane: this.pane, sibling: this.sibling };\n        this.resizeStart.emit(args);\n    }\n\n    /**\n     * @hidden @internal\n     * This method performs calculations concerning the sizes of each pair of panes when the bar between them is dragged.\n     * @param delta - The difference along the X (or Y) axis between the initial and the current point when dragging the bar.\n     */\n    public onMoving(delta: number) {\n        const [ paneSize, siblingSize ] = this.calcNewSizes(delta);\n\n        this.pane.dragSize = paneSize + 'px';\n        this.sibling.dragSize = siblingSize + 'px';\n\n        const args: ISplitterBarResizeEventArgs = { pane: this.pane, sibling: this.sibling };\n        this.resizing.emit(args);\n    }\n\n    public onMoveEnd(delta: number) {\n        const [ paneSize, siblingSize ] = this.calcNewSizes(delta);\n\n        if (this.pane.isPercentageSize) {\n            // handle % resizes\n            const totalSize = this.getTotalSize();\n            const percentPaneSize = (paneSize / totalSize) * 100;\n            this.pane.size = percentPaneSize + '%';\n        } else {\n            // px resize\n            this.pane.size = paneSize + 'px';\n        }\n\n        if (this.sibling.isPercentageSize) {\n            // handle % resizes\n            const totalSize = this.getTotalSize();\n            const percentSiblingPaneSize = (siblingSize / totalSize) * 100;\n            this.sibling.size = percentSiblingPaneSize + '%';\n        } else {\n            // px resize\n            this.sibling.size = siblingSize + 'px';\n        }\n        this.pane.dragSize = null;\n        this.sibling.dragSize = null;\n\n        const args: ISplitterBarResizeEventArgs = { pane: this.pane, sibling: this.sibling };\n        this.resizeEnd.emit(args);\n    }\n\n    /** @hidden @internal */\n    public getPaneSiblingsByOrder(order: number, barIndex: number): Array<IgxSplitterPaneComponent> {\n        const panes = this.panes.toArray();\n        const prevPane = panes[order - barIndex - 1];\n        const nextPane = panes[order - barIndex];\n        const siblings = [prevPane, nextPane];\n        return siblings;\n    }\n\n    private getTotalSize() {\n        const computed = this.document.defaultView.getComputedStyle(this.elementRef.nativeElement);\n        const totalSize = this.type === SplitterType.Horizontal ? computed.getPropertyValue('width') : computed.getPropertyValue('height');\n        return parseFloat(totalSize);\n    }\n\n\n    /**\n     * @hidden @internal\n     * This method inits panes with properties.\n     */\n    private initPanes() {\n        this.panes.forEach(pane => {\n            pane.owner = this;\n            if (this.type === SplitterType.Horizontal) {\n                pane.minWidth = pane.minSize ?? '0';\n                pane.maxWidth = pane.maxSize ?? '100%';\n            } else {\n                pane.minHeight = pane.minSize ?? '0';\n                pane.maxHeight = pane.maxSize ?? '100%';\n            }\n        });\n        this.assignFlexOrder();\n        if (this.panes.filter(x => x.collapsed).length > 0) {\n            // if any panes are collapsed, reset sizes.\n            this.resetPaneSizes();\n        }\n    }\n\n    /**\n     * @hidden @internal\n     * This method reset pane sizes.\n     */\n    private resetPaneSizes() {\n        if (this.panes) {\n            // if type is changed runtime, should reset sizes.\n            this.panes.forEach(x => {\n                x.size = 'auto'\n                x.minWidth = '0';\n                x.maxWidth = '100%';\n                x.minHeight = '0';\n                x.maxHeight = '100%';\n            });\n        }\n    }\n\n    /**\n     * @hidden @internal\n     * This method assigns the order of each pane.\n     */\n    private assignFlexOrder() {\n        let k = 0;\n        this.panes.forEach((pane: IgxSplitterPaneComponent) => {\n            pane.order = k;\n            k += 2;\n        });\n    }\n\n    /**\n     * @hidden @internal\n     * Calculates new sizes for the panes based on move delta and initial sizes\n     */\n    private calcNewSizes(delta: number): [number, number] {\n        const min = parseInt(this.pane.minSize, 10) || 0;\n        const minSibling = parseInt(this.sibling.minSize, 10) || 0;\n        const max = parseInt(this.pane.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize - minSibling;\n        const maxSibling = parseInt(this.sibling.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize - min;\n\n        if (delta < 0) {\n            const maxPossibleDelta = Math.min(\n                max - this.initialPaneSize,\n                this.initialSiblingSize - minSibling,\n            )\n            delta = Math.min(maxPossibleDelta, Math.abs(delta)) * -1;\n        } else {\n            const maxPossibleDelta = Math.min(\n                this.initialPaneSize - min,\n                maxSibling - this.initialSiblingSize\n            )\n            delta = Math.min(maxPossibleDelta, Math.abs(delta));\n        }\n        return [this.initialPaneSize - delta, this.initialSiblingSize + delta];\n    }\n}\n\nexport const SPLITTER_INTERACTION_KEYS = new Set('right down left up arrowright arrowdown arrowleft arrowup'.split(' '));\n\n/**\n * @hidden @internal\n * Represents the draggable bar that visually separates panes and allows for changing their sizes.\n */\n@Component({\n    selector: 'igx-splitter-bar',\n    templateUrl: './splitter-bar.component.html',\n    standalone: true,\n    imports: [IgxDragDirective, IgxDragIgnoreDirective]\n})\nexport class IgxSplitBarComponent {\n    /**\n     * Set css class to the host element.\n     */\n    @HostBinding('class.igx-splitter-bar-host')\n    public cssClass = 'igx-splitter-bar-host';\n\n    /**\n     * Gets/Sets the orientation.\n     */\n    @Input()\n    public type: SplitterType = SplitterType.Horizontal;\n\n    /**\n     * Sets/gets the element order.\n     */\n    @HostBinding('style.order')\n    @Input()\n    public order!: number;\n\n    /**\n     * @hidden\n     * @internal\n     */\n    @HostBinding('attr.tabindex')\n    public get tabindex() {\n        return this.resizeDisallowed ? null : 0;\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    @HostBinding('attr.aria-orientation')\n    public get orientation() {\n        return this.type === SplitterType.Horizontal ? 'horizontal' : 'vertical';\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public get cursor() {\n        if (this.resizeDisallowed) {\n            return '';\n        }\n        return this.type === SplitterType.Horizontal ? 'col-resize' : 'row-resize';\n    }\n\n    /**\n     * Sets/gets the `SplitPaneComponent` associated with the current `SplitBarComponent`.\n     *\n     * @memberof SplitBarComponent\n     */\n    @Input()\n    public pane!: IgxSplitterPaneComponent;\n\n    /**\n     * Sets/Gets the `SplitPaneComponent` sibling components associated with the current `SplitBarComponent`.\n     */\n    @Input()\n    public siblings!: Array<IgxSplitterPaneComponent>;\n\n    /**\n     * An event that is emitted whenever we start dragging the current `SplitBarComponent`.\n     */\n    @Output()\n    public moveStart = new EventEmitter<IgxSplitterPaneComponent>();\n\n    /**\n     * An event that is emitted while we are dragging the current `SplitBarComponent`.\n     */\n    @Output()\n    public moving = new EventEmitter<number>();\n\n    @Output()\n    public movingEnd = new EventEmitter<number>();\n\n    /**\n     * A temporary holder for the pointer coordinates.\n     */\n    private startPoint!: number;\n\n    /**\n     * @hidden @internal\n     */\n    public get prevButtonHidden() {\n        return this.siblings[0].collapsed && !this.siblings[1].collapsed;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    @HostListener('keydown', ['$event'])\n    public keyEvent(event: KeyboardEvent) {\n        const key = event.key.toLowerCase();\n        const ctrl = event.ctrlKey;\n        event.stopPropagation();\n        if (SPLITTER_INTERACTION_KEYS.has(key)) {\n            event.preventDefault();\n        }\n        switch (key) {\n            case 'arrowup':\n            case 'up':\n                if (this.type === SplitterType.Vertical) {\n                    if (ctrl) {\n                        this.onCollapsing(false);\n                        break;\n                    }\n                    if (!this.resizeDisallowed) {\n                        event.preventDefault();\n                        this.moveStart.emit(this.pane);\n                        this.moving.emit(10);\n                    }\n                }\n                break;\n            case 'arrowdown':\n            case 'down':\n                if (this.type === SplitterType.Vertical) {\n                    if (ctrl) {\n                        this.onCollapsing(true);\n                        break;\n                    }\n                    if (!this.resizeDisallowed) {\n                        event.preventDefault();\n                        this.moveStart.emit(this.pane);\n                        this.moving.emit(-10);\n                    }\n                }\n                break;\n            case 'arrowleft':\n            case 'left':\n                if (this.type === SplitterType.Horizontal) {\n                    if (ctrl) {\n                        this.onCollapsing(false);\n                        break;\n                    }\n                    if (!this.resizeDisallowed) {\n                        event.preventDefault();\n                        this.moveStart.emit(this.pane);\n                        this.moving.emit(10);\n                    }\n                }\n                break;\n            case 'arrowright':\n            case 'right':\n                if (this.type === SplitterType.Horizontal) {\n                    if (ctrl) {\n                        this.onCollapsing(true);\n                        break;\n                    }\n                    if (!this.resizeDisallowed) {\n                        event.preventDefault();\n                        this.moveStart.emit(this.pane);\n                        this.moving.emit(-10);\n                    }\n                }\n                break;\n            default:\n                break;\n        }\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get dragDir() {\n        return this.type === SplitterType.Horizontal ? DragDirection.VERTICAL : DragDirection.HORIZONTAL;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get nextButtonHidden() {\n        return this.siblings[1].collapsed && !this.siblings[0].collapsed;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onDragStart(event: IDragStartEventArgs) {\n        if (this.resizeDisallowed) {\n            event.cancel = true;\n            return;\n        }\n        this.startPoint = this.type === SplitterType.Horizontal ? event.startX : event.startY;\n        this.moveStart.emit(this.pane);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onDragMove(event: IDragMoveEventArgs) {\n        const isHorizontal = this.type === SplitterType.Horizontal;\n        const curr = isHorizontal ? event.pageX : event.pageY;\n        const delta = this.startPoint - curr;\n        if (delta !== 0) {\n            this.moving.emit(delta);\n            event.cancel = true;\n            event.owner.element.nativeElement.style.transform = '';\n        }\n    }\n\n    public onDragEnd(event: any) {\n        const isHorizontal = this.type === SplitterType.Horizontal;\n        const curr = isHorizontal ? event.pageX : event.pageY;\n        const delta = this.startPoint - curr;\n        if (delta !== 0) {\n            this.movingEnd.emit(delta);\n        }\n    }\n\n    protected get resizeDisallowed() {\n        const relatedTabs = this.siblings;\n        return !!relatedTabs.find(x => x.resizable === false || x.collapsed === true);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onCollapsing(next: boolean) {\n        const prevSibling = this.siblings[0];\n        const nextSibling = this.siblings[1];\n        let target;\n        if (next) {\n            // if next is clicked when prev pane is hidden, show prev pane, else hide next pane.\n            target = prevSibling.collapsed ? prevSibling : nextSibling;\n        } else {\n            // if prev is clicked when next pane is hidden, show next pane, else hide prev pane.\n            target = nextSibling.collapsed ? nextSibling : prevSibling;\n        }\n        target.toggle();\n    }\n}\n","<ng-content select=\"igx-splitter-pane\"></ng-content>\n<ng-container *ngFor=\"let pane of panes; let last = last; let index= index;\">\n    <igx-splitter-bar *ngIf=\"!last\" [order]='pane.order + 1' role='separator'\n                    [type]=\"type\"\n                    [pane]=\"pane\"\n                    [siblings]='getPaneSiblingsByOrder(pane.order + 1, index)'\n                    (moveStart)=\"onMoveStart($event)\"\n                    (moving)=\"onMoving($event)\"\n                    (movingEnd)='onMoveEnd($event)'>\n    </igx-splitter-bar>\n</ng-container>\n","<div class=\"igx-splitter-bar\"\n    [class.igx-splitter-bar--vertical]='type === 0'\n    [style.cursor]='cursor'\n    igxDrag\n    [ghost]=\"false\"\n    [dragDirection]='dragDir'\n    (dragStart)='onDragStart($event)'\n    (dragMove)=\"onDragMove($event)\"\n    (dragEnd)=\"onDragEnd($event)\"\n>\n    <div class=\"igx-splitter-bar__expander--start\" igxDragIgnore (click)='onCollapsing(false)' [hidden]='prevButtonHidden'></div>\n    <div class=\"igx-splitter-bar__handle\" ></div>\n    <div class=\"igx-splitter-bar__expander--end\" igxDragIgnore (click)='onCollapsing(true)' [hidden]='nextButtonHidden'></div>\n</div>\n"]}
|
|
@@ -4146,7 +4146,14 @@ class IgxBaseExporter {
|
|
|
4146
4146
|
let startIndex = 0;
|
|
4147
4147
|
const key = keys[0];
|
|
4148
4148
|
const records = this.flatRecords.map(r => r.data);
|
|
4149
|
-
const groupedRecords =
|
|
4149
|
+
const groupedRecords = {};
|
|
4150
|
+
records.forEach(obj => {
|
|
4151
|
+
const keyValue = obj[key.name];
|
|
4152
|
+
if (!groupedRecords[keyValue]) {
|
|
4153
|
+
groupedRecords[keyValue] = [];
|
|
4154
|
+
}
|
|
4155
|
+
groupedRecords[keyValue].push(obj);
|
|
4156
|
+
});
|
|
4150
4157
|
if (columnGroupParent) {
|
|
4151
4158
|
const mapKeys = [...this.pivotGridKeyValueMap.keys()];
|
|
4152
4159
|
const mapValues = [...this.pivotGridKeyValueMap.values()];
|
|
@@ -30222,12 +30229,39 @@ class Calendar {
|
|
|
30222
30229
|
getPrevYear(date) {
|
|
30223
30230
|
return this.timedelta(date, TimeDeltaInterval.Year, -1);
|
|
30224
30231
|
}
|
|
30225
|
-
getWeekNumber(date) {
|
|
30226
|
-
|
|
30227
|
-
const
|
|
30232
|
+
getWeekNumber(date, weekStart) {
|
|
30233
|
+
// current year
|
|
30234
|
+
const yearStart = new Date(date.getFullYear(), 0, 1);
|
|
30235
|
+
// first day number of the current year
|
|
30236
|
+
let firstDayOfTheYear = yearStart.getDay() - weekStart;
|
|
30237
|
+
firstDayOfTheYear = firstDayOfTheYear >= 0 ? firstDayOfTheYear : firstDayOfTheYear + 7;
|
|
30228
30238
|
const dayInMilSeconds = 86400000;
|
|
30229
|
-
|
|
30230
|
-
|
|
30239
|
+
// day number in the year
|
|
30240
|
+
const dayNumber = Math.floor((date.getTime() - yearStart.getTime() -
|
|
30241
|
+
(date.getTimezoneOffset() - yearStart.getTimezoneOffset()) * 60000) / dayInMilSeconds) + 1;
|
|
30242
|
+
let weekNumber;
|
|
30243
|
+
// if 01 Jan is Monday to Thursday, is considered 1st week of the year
|
|
30244
|
+
// if 01 Jan starts Friday to Sunday, is considered last week of previous year
|
|
30245
|
+
if (firstDayOfTheYear < 4) {
|
|
30246
|
+
// when calculating the week number we add 1 for the 1st week
|
|
30247
|
+
weekNumber = Math.floor((dayNumber + firstDayOfTheYear - 1) / 7) + 1;
|
|
30248
|
+
}
|
|
30249
|
+
else {
|
|
30250
|
+
// calculating the week number
|
|
30251
|
+
weekNumber = Math.floor((dayNumber + firstDayOfTheYear - 1) / 7);
|
|
30252
|
+
}
|
|
30253
|
+
// if the week number is greater than week 52
|
|
30254
|
+
if (weekNumber > 52) {
|
|
30255
|
+
// next year
|
|
30256
|
+
let nextYear = new Date(date.getFullYear() + 1, 0, 1);
|
|
30257
|
+
// first day of the next year
|
|
30258
|
+
let nextYearFirstDay = nextYear.getDay() - weekStart;
|
|
30259
|
+
nextYearFirstDay = nextYearFirstDay >= 0 ? nextYearFirstDay : nextYearFirstDay + 7;
|
|
30260
|
+
// if 01 Jan of the next year is Monday to Thursday, is considered 1st week of the next year
|
|
30261
|
+
// if 01 Jan is Friday to Sunday, is considered 53rd week of the current year
|
|
30262
|
+
weekNumber = nextYearFirstDay < 4 ? 1 : 53;
|
|
30263
|
+
}
|
|
30264
|
+
return weekNumber;
|
|
30231
30265
|
}
|
|
30232
30266
|
generateICalendarDate(date, year, month) {
|
|
30233
30267
|
return {
|
|
@@ -32199,7 +32233,7 @@ class IgxDaysViewComponent extends IgxCalendarBaseDirective {
|
|
|
32199
32233
|
* @hidden
|
|
32200
32234
|
*/
|
|
32201
32235
|
getWeekNumber(date) {
|
|
32202
|
-
return this.calendarModel.getWeekNumber(date);
|
|
32236
|
+
return this.calendarModel.getWeekNumber(date, this.weekStart);
|
|
32203
32237
|
}
|
|
32204
32238
|
/**
|
|
32205
32239
|
* Returns the locale representation of the date in the days view.
|
|
@@ -86784,9 +86818,8 @@ class IgxSplitterPaneComponent {
|
|
|
86784
86818
|
* Gets the `flex` property of the current `IgxSplitterPaneComponent`.
|
|
86785
86819
|
*/
|
|
86786
86820
|
get flex() {
|
|
86787
|
-
const isAuto = this.size === 'auto' && !this.dragSize;
|
|
86788
|
-
const grow = !isAuto ? 0 : 1;
|
|
86789
86821
|
const size = this.dragSize || this.size;
|
|
86822
|
+
const grow = this.isPercentageSize && !this.dragSize ? 1 : 0;
|
|
86790
86823
|
return `${grow} ${grow} ${size}`;
|
|
86791
86824
|
}
|
|
86792
86825
|
/**
|
|
@@ -87086,30 +87119,14 @@ class IgxSplitterComponent {
|
|
|
87086
87119
|
* @param delta - The difference along the X (or Y) axis between the initial and the current point when dragging the bar.
|
|
87087
87120
|
*/
|
|
87088
87121
|
onMoving(delta) {
|
|
87089
|
-
const
|
|
87090
|
-
const max = parseInt(this.pane.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;
|
|
87091
|
-
const minSibling = parseInt(this.sibling.minSize, 10) || 0;
|
|
87092
|
-
const maxSibling = parseInt(this.sibling.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;
|
|
87093
|
-
const paneSize = this.initialPaneSize - delta;
|
|
87094
|
-
const siblingSize = this.initialSiblingSize + delta;
|
|
87095
|
-
if (paneSize < min || paneSize > max || siblingSize < minSibling || siblingSize > maxSibling) {
|
|
87096
|
-
return;
|
|
87097
|
-
}
|
|
87122
|
+
const [paneSize, siblingSize] = this.calcNewSizes(delta);
|
|
87098
87123
|
this.pane.dragSize = paneSize + 'px';
|
|
87099
87124
|
this.sibling.dragSize = siblingSize + 'px';
|
|
87100
87125
|
const args = { pane: this.pane, sibling: this.sibling };
|
|
87101
87126
|
this.resizing.emit(args);
|
|
87102
87127
|
}
|
|
87103
87128
|
onMoveEnd(delta) {
|
|
87104
|
-
const
|
|
87105
|
-
const max = parseInt(this.pane.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;
|
|
87106
|
-
const minSibling = parseInt(this.sibling.minSize, 10) || 0;
|
|
87107
|
-
const maxSibling = parseInt(this.sibling.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;
|
|
87108
|
-
const paneSize = this.initialPaneSize - delta;
|
|
87109
|
-
const siblingSize = this.initialSiblingSize + delta;
|
|
87110
|
-
if (paneSize < min || paneSize > max || siblingSize < minSibling || siblingSize > maxSibling) {
|
|
87111
|
-
return;
|
|
87112
|
-
}
|
|
87129
|
+
const [paneSize, siblingSize] = this.calcNewSizes(delta);
|
|
87113
87130
|
if (this.pane.isPercentageSize) {
|
|
87114
87131
|
// handle % resizes
|
|
87115
87132
|
const totalSize = this.getTotalSize();
|
|
@@ -87197,6 +87214,25 @@ class IgxSplitterComponent {
|
|
|
87197
87214
|
k += 2;
|
|
87198
87215
|
});
|
|
87199
87216
|
}
|
|
87217
|
+
/**
|
|
87218
|
+
* @hidden @internal
|
|
87219
|
+
* Calculates new sizes for the panes based on move delta and initial sizes
|
|
87220
|
+
*/
|
|
87221
|
+
calcNewSizes(delta) {
|
|
87222
|
+
const min = parseInt(this.pane.minSize, 10) || 0;
|
|
87223
|
+
const minSibling = parseInt(this.sibling.minSize, 10) || 0;
|
|
87224
|
+
const max = parseInt(this.pane.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize - minSibling;
|
|
87225
|
+
const maxSibling = parseInt(this.sibling.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize - min;
|
|
87226
|
+
if (delta < 0) {
|
|
87227
|
+
const maxPossibleDelta = Math.min(max - this.initialPaneSize, this.initialSiblingSize - minSibling);
|
|
87228
|
+
delta = Math.min(maxPossibleDelta, Math.abs(delta)) * -1;
|
|
87229
|
+
}
|
|
87230
|
+
else {
|
|
87231
|
+
const maxPossibleDelta = Math.min(this.initialPaneSize - min, maxSibling - this.initialSiblingSize);
|
|
87232
|
+
delta = Math.min(maxPossibleDelta, Math.abs(delta));
|
|
87233
|
+
}
|
|
87234
|
+
return [this.initialPaneSize - delta, this.initialSiblingSize + delta];
|
|
87235
|
+
}
|
|
87200
87236
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: IgxSplitterComponent, deps: [{ token: DOCUMENT }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
87201
87237
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.2", type: IgxSplitterComponent, isStandalone: true, selector: "igx-splitter", inputs: { type: "type" }, outputs: { resizeStart: "resizeStart", resizing: "resizing", resizeEnd: "resizeEnd" }, host: { properties: { "class.igx-splitter": "this.cssClass", "style.overflow": "this.overflow", "style.display": "this.display", "attr.aria-orientation": "this.orientation", "style.flex-direction": "this.direction" } }, queries: [{ propertyName: "panes", predicate: IgxSplitterPaneComponent, read: IgxSplitterPaneComponent }], ngImport: i0, template: "<ng-content select=\"igx-splitter-pane\"></ng-content>\n<ng-container *ngFor=\"let pane of panes; let last = last; let index= index;\">\n <igx-splitter-bar *ngIf=\"!last\" [order]='pane.order + 1' role='separator'\n [type]=\"type\"\n [pane]=\"pane\"\n [siblings]='getPaneSiblingsByOrder(pane.order + 1, index)'\n (moveStart)=\"onMoveStart($event)\"\n (moving)=\"onMoving($event)\"\n (movingEnd)='onMoveEnd($event)'>\n </igx-splitter-bar>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return NgFor; }), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i0.forwardRef(function () { return NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i0.forwardRef(function () { return IgxSplitBarComponent; }), selector: "igx-splitter-bar", inputs: ["type", "order", "pane", "siblings"], outputs: ["moveStart", "moving", "movingEnd"] }] }); }
|
|
87202
87238
|
}
|