@mintplayer/ng-bootstrap 15.25.0 → 15.25.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.
- package/dock/src/dock/dock.component.d.ts +4 -1
- package/dock/src/dock-panel-header/dock-panel-header.component.d.ts +5 -4
- package/dock/src/index.d.ts +1 -0
- package/dock/src/panes/content-pane.d.ts +1 -0
- package/dock/src/panes/dock-pane.d.ts +1 -0
- package/dock/src/panes/document-host-pane.d.ts +1 -0
- package/dock/src/panes/floating-pane.d.ts +2 -1
- package/dock/src/panes/split-pane.d.ts +1 -0
- package/dock/src/panes/tab-group-pane.d.ts +1 -0
- package/dock/src/services/dock/dock.service.d.ts +14 -0
- package/dock/src/services/index.d.ts +1 -0
- package/esm2020/dock/src/dock/dock.component.mjs +14 -2
- package/esm2020/dock/src/dock-panel-header/dock-panel-header.component.mjs +202 -96
- package/esm2020/dock/src/index.mjs +2 -1
- package/esm2020/dock/src/panes/content-pane.mjs +4 -1
- package/esm2020/dock/src/panes/dock-pane.mjs +1 -1
- package/esm2020/dock/src/panes/document-host-pane.mjs +4 -1
- package/esm2020/dock/src/panes/floating-pane.mjs +7 -2
- package/esm2020/dock/src/panes/split-pane.mjs +4 -1
- package/esm2020/dock/src/panes/tab-group-pane.mjs +4 -1
- package/esm2020/dock/src/services/dock/dock.service.mjs +56 -0
- package/esm2020/dock/src/services/index.mjs +2 -0
- package/esm2020/resizable/src/resize-glyph/resize-glyph.directive.mjs +1 -1
- package/fesm2015/mintplayer-ng-bootstrap-dock.mjs +291 -111
- package/fesm2015/mintplayer-ng-bootstrap-dock.mjs.map +1 -1
- package/fesm2015/mintplayer-ng-bootstrap-resizable.mjs.map +1 -1
- package/fesm2020/mintplayer-ng-bootstrap-dock.mjs +289 -111
- package/fesm2020/mintplayer-ng-bootstrap-dock.mjs.map +1 -1
- package/fesm2020/mintplayer-ng-bootstrap-resizable.mjs.map +1 -1
- package/package.json +2 -2
- package/resizable/src/resize-glyph/resize-glyph.directive.d.ts +1 -1
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
import { OnDestroy, QueryList } from '@angular/core';
|
|
2
|
-
import { BehaviorSubject, Subject } from 'rxjs';
|
|
2
|
+
import { BehaviorSubject, Observable, Subject } from 'rxjs';
|
|
3
|
+
import { Parentified } from '@mintplayer/parentify';
|
|
3
4
|
import { BsDockPanelComponent } from '../dock-panel/dock-panel.component';
|
|
4
5
|
import { BsDockLayout } from '../interfaces/dock-layout';
|
|
5
6
|
import { BsDockPaneRendererComponent } from '../dock-pane-renderer/dock-pane-renderer.component';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
export declare class BsDockComponent implements OnDestroy {
|
|
8
9
|
constructor();
|
|
10
|
+
private paneCache?;
|
|
9
11
|
panels$: BehaviorSubject<BsDockPanelComponent[]>;
|
|
10
12
|
set panels(value: QueryList<BsDockPanelComponent>);
|
|
11
13
|
layout$: BehaviorSubject<BsDockLayout>;
|
|
@@ -15,6 +17,7 @@ export declare class BsDockComponent implements OnDestroy {
|
|
|
15
17
|
set floatingPanes(value: QueryList<BsDockPaneRendererComponent>);
|
|
16
18
|
positionAbsolute: boolean;
|
|
17
19
|
positionPx: number;
|
|
20
|
+
parentifiedLayout$: Observable<Parentified<BsDockLayout>>;
|
|
18
21
|
destroyed$: Subject<unknown>;
|
|
19
22
|
ngOnDestroy(): void;
|
|
20
23
|
static ɵfac: i0.ɵɵFactoryDeclaration<BsDockComponent, never>;
|
|
@@ -2,20 +2,21 @@ import { ElementRef } from '@angular/core';
|
|
|
2
2
|
import { BsDockPanelComponent } from '../dock-panel/dock-panel.component';
|
|
3
3
|
import { BsDockComponent } from '../dock/dock.component';
|
|
4
4
|
import { BsDockPane } from '../panes/dock-pane';
|
|
5
|
-
import { RemoveFromPaneResult } from '../interfaces/remove-from-pane-result';
|
|
6
5
|
import { DragOperation } from '../interfaces/drag-operation';
|
|
6
|
+
import { BsDockService } from '../services/dock/dock.service';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
export declare class BsDockPanelHeaderComponent {
|
|
9
9
|
private dockPanel;
|
|
10
10
|
private dock;
|
|
11
|
+
private dockService;
|
|
11
12
|
private element;
|
|
12
|
-
constructor(dockPanel: BsDockPanelComponent, dock: BsDockComponent, element: ElementRef<HTMLElement>);
|
|
13
|
+
constructor(dockPanel: BsDockPanelComponent, dock: BsDockComponent, dockService: BsDockService, element: ElementRef<HTMLElement>);
|
|
13
14
|
isMouseDown: boolean;
|
|
14
15
|
dragOperation?: DragOperation;
|
|
15
|
-
|
|
16
|
+
isDragging: boolean;
|
|
16
17
|
onMouseDown(ev: MouseEvent): void;
|
|
17
18
|
onMouseMove(ev: MouseEvent): void;
|
|
18
|
-
|
|
19
|
+
removeFromPaneBis(host: BsDockPane, pane: BsDockPane): void;
|
|
19
20
|
onMouseUp(ev: Event): void;
|
|
20
21
|
dBlock: boolean;
|
|
21
22
|
static ɵfac: i0.ɵɵFactoryDeclaration<BsDockPanelHeaderComponent, never>;
|
package/dock/src/index.d.ts
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import { BsDockPane } from "./dock-pane";
|
|
2
2
|
import { Point } from "../interfaces/point";
|
|
3
3
|
import { Size } from "../interfaces/size";
|
|
4
|
-
export declare class BsFloatingPane {
|
|
4
|
+
export declare class BsFloatingPane extends BsDockPane {
|
|
5
5
|
constructor(data?: Partial<BsFloatingPane>);
|
|
6
6
|
pane?: BsDockPane;
|
|
7
7
|
size?: Size;
|
|
8
8
|
location?: Point;
|
|
9
|
+
get isEmpty(): boolean;
|
|
9
10
|
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { BsDockPane } from '../../panes/dock-pane';
|
|
2
|
+
import { BsDockLayout } from '../../interfaces/dock-layout';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class BsDockService {
|
|
5
|
+
buildTraces(layout: BsDockLayout): PaneTraceResult[];
|
|
6
|
+
private buildTracesPrivate;
|
|
7
|
+
private getChildPanes;
|
|
8
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<BsDockService, never>;
|
|
9
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<BsDockService>;
|
|
10
|
+
}
|
|
11
|
+
export interface PaneTraceResult {
|
|
12
|
+
trace: BsDockPane[];
|
|
13
|
+
finished: boolean;
|
|
14
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './dock/dock.service';
|
|
@@ -1,8 +1,12 @@
|
|
|
1
1
|
import { Component, ContentChildren, ViewChildren, Input, QueryList, HostBinding } from '@angular/core';
|
|
2
|
-
import { BehaviorSubject, Subject, takeUntil } from 'rxjs';
|
|
2
|
+
import { BehaviorSubject, map, Subject, takeUntil } from 'rxjs';
|
|
3
|
+
import { deepClone } from '@mintplayer/parentify';
|
|
3
4
|
import { BsDockPanelComponent } from '../dock-panel/dock-panel.component';
|
|
4
5
|
import { BsTabGroupPane } from '../panes/tab-group-pane';
|
|
5
6
|
import { BsDocumentHost } from '../panes/document-host-pane';
|
|
7
|
+
import { BsContentPane } from '../panes/content-pane';
|
|
8
|
+
import { BsFloatingPane } from '../panes/floating-pane';
|
|
9
|
+
import { BsSplitPane } from '../panes/split-pane';
|
|
6
10
|
import * as i0 from "@angular/core";
|
|
7
11
|
import * as i1 from "@angular/common";
|
|
8
12
|
import * as i2 from "../dock-pane-renderer/dock-pane-renderer.component";
|
|
@@ -30,6 +34,14 @@ export class BsDockComponent {
|
|
|
30
34
|
.subscribe((floating) => {
|
|
31
35
|
floating.forEach((panel) => panel.moveToOverlay());
|
|
32
36
|
});
|
|
37
|
+
this.parentifiedLayout$ = this.layout$.pipe(map(layout => {
|
|
38
|
+
const clone = deepClone(layout, true,
|
|
39
|
+
// []
|
|
40
|
+
[BsContentPane, BsDocumentHost, BsFloatingPane, BsSplitPane, BsTabGroupPane], true, this.paneCache);
|
|
41
|
+
this.paneCache = clone.cache;
|
|
42
|
+
return clone.result;
|
|
43
|
+
}));
|
|
44
|
+
this.parentifiedLayout$.pipe(takeUntil(this.destroyed$)).subscribe(console.log);
|
|
33
45
|
}
|
|
34
46
|
set panels(value) {
|
|
35
47
|
this.panels$.next(value.toArray());
|
|
@@ -77,4 +89,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
77
89
|
type: HostBinding,
|
|
78
90
|
args: ['style.right']
|
|
79
91
|
}] } });
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dock.component.js","sourceRoot":"","sources":["../../../../../../../libs/mintplayer-ng-bootstrap/dock/src/dock/dock.component.ts","../../../../../../../libs/mintplayer-ng-bootstrap/dock/src/dock/dock.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChildren, ViewChildren, Input, OnDestroy, QueryList, HostBinding } from '@angular/core';\nimport { BehaviorSubject, combineLatest, combineLatestAll, map, Observable, Subject, takeUntil } from 'rxjs';\nimport { Overlay } from '@angular/cdk/overlay';\nimport { Parentified, deepClone } from '@mintplayer/parentify';\nimport { BsDockPanelComponent } from '../dock-panel/dock-panel.component';\nimport { EPaneType } from '../enums/pane-type.enum';\nimport { BsDockLayout } from '../interfaces/dock-layout';\nimport { BsTabGroupPane } from '../panes/tab-group-pane';\nimport { BsDocumentHost } from '../panes/document-host-pane';\nimport { BsContentPane } from '../panes/content-pane';\nimport { BsFloatingPane } from '../panes/floating-pane';\nimport { BsSplitPane } from '../panes/split-pane';\nimport { BsDockPaneRendererComponent } from '../dock-pane-renderer/dock-pane-renderer.component';\n\n@Component({\n  selector: 'bs-dock',\n  templateUrl: './dock.component.html',\n  styleUrls: ['./dock.component.scss']\n})\nexport class BsDockComponent implements OnDestroy {\n  constructor() {\n    const tabs = new BsTabGroupPane();\n    const docHost = new BsDocumentHost();\n    docHost.rootPane = tabs;\n\n    this.layout$ = new BehaviorSubject<BsDockLayout>({\n      rootPane: docHost,\n      floatingPanes: []\n    });\n\n    // combineLatest([this.layout$, this.panels$])\n    //   .pipe(takeUntil(this.destroyed$))\n    //   .subscribe(([layout, panels]) => {\n        \n    //   })\n\n    this.floating$.pipe(takeUntil(this.destroyed$))\n      .subscribe((floating) => {\n        floating.forEach((panel) => panel.moveToOverlay());\n      });\n      \n    this.parentifiedLayout$ = this.layout$.pipe(map(layout => {\n      const clone = deepClone(\n        layout, true,\n        // []\n        [BsContentPane, BsDocumentHost, BsFloatingPane, BsSplitPane, BsTabGroupPane],\n        true,\n        this.paneCache);\n\n      this.paneCache = clone.cache;\n\n      return clone.result;\n    }));\n\n    this.parentifiedLayout$.pipe(takeUntil(this.destroyed$)).subscribe(console.log);\n  }\n\n  private paneCache?: Map<any, any>;\n\n  //#region Panels\n  panels$ = new BehaviorSubject<BsDockPanelComponent[]>([]);\n  @ContentChildren(BsDockPanelComponent) set panels(value: QueryList<BsDockPanelComponent>) {\n    this.panels$.next(value.toArray());\n  }\n  //#endregion\n  //#region Layout\n  layout$: BehaviorSubject<BsDockLayout>;\n  public get layout() {\n    return this.layout$.value;\n  }\n  @Input() public set layout(value: BsDockLayout) {\n    this.layout$.next(value);\n  }\n  //#endregion\n\n  floating$ = new BehaviorSubject<BsDockPaneRendererComponent[]>([]);\n  @ViewChildren('floating') set floatingPanes(value: QueryList<BsDockPaneRendererComponent>) {\n    this.floating$.next(value.toArray());\n  }\n\n  @HostBinding('class.position-absolute')\n  positionAbsolute = true;\n\n  @HostBinding('style.top')\n  @HostBinding('style.left')\n  @HostBinding('style.bottom')\n  @HostBinding('style.right')\n  positionPx = 0;\n\n  parentifiedLayout$: Observable<Parentified<BsDockLayout>>;\n\n  destroyed$ = new Subject();\n  ngOnDestroy() {\n    this.destroyed$.next(true);\n    this.floating$.value.forEach(panel => panel.disposeOverlay());\n  }\n}\n","<ng-content></ng-content>\n<ng-container *ngIf=\"(layout$ | async) as layout\">\n    <bs-dock-pane-renderer [layout]=\"layout.rootPane\"></bs-dock-pane-renderer>\n\n    <ng-container *ngFor=\"let pane of layout.floatingPanes\">\n        <bs-dock-pane-renderer #floating *ngIf=\"pane.pane\" [layout]=\"pane\"></bs-dock-pane-renderer>\n    </ng-container>\n</ng-container>\n<!-- <bs-splitter>\n    <ng-content></ng-content>\n    <ng-container *ngFor=\"let panel of (panels$ | async)\">\n        <bs-split-panel>\n            <ng-template [cdkPortalOutlet]=\"panel.portal\"></ng-template>\n        </bs-split-panel>\n    </ng-container>\n</bs-splitter> -->\n"]}
|