dockview-angular 4.13.0 → 5.0.0
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/README.md +49 -17
- package/dist/README.md +88 -0
- package/dist/dockview-angular.d.ts.map +1 -0
- package/dist/dockview.css +63 -7
- package/dist/esm2022/dockview-angular.mjs +5 -0
- package/dist/esm2022/lib/dockview/dockview-angular.component.mjs +185 -0
- package/dist/esm2022/lib/dockview/types.mjs +3 -0
- package/dist/esm2022/lib/dockview-angular.module.mjs +38 -0
- package/dist/esm2022/lib/gridview/angular-gridview-panel.mjs +24 -0
- package/dist/esm2022/lib/gridview/gridview-angular.component.mjs +98 -0
- package/dist/esm2022/lib/gridview/types.mjs +3 -0
- package/dist/esm2022/lib/paneview/angular-pane-part.mjs +26 -0
- package/dist/esm2022/lib/paneview/paneview-angular.component.mjs +122 -0
- package/dist/esm2022/lib/paneview/types.mjs +3 -0
- package/dist/esm2022/lib/splitview/angular-splitview-panel.mjs +24 -0
- package/dist/esm2022/lib/splitview/splitview-angular.component.mjs +98 -0
- package/dist/esm2022/lib/splitview/types.mjs +3 -0
- package/dist/esm2022/lib/utils/angular-renderer.mjs +83 -0
- package/dist/esm2022/lib/utils/component-factory.mjs +100 -0
- package/dist/esm2022/lib/utils/lifecycle-utils.mjs +69 -0
- package/dist/esm2022/public-api.mjs +17 -0
- package/dist/fesm2022/dockview-angular.mjs +846 -0
- package/dist/fesm2022/dockview-angular.mjs.map +1 -0
- package/dist/index.d.ts +6 -0
- package/dist/{cjs/lib → lib}/dockview/dockview-angular.component.d.ts +4 -0
- package/dist/lib/dockview/dockview-angular.component.d.ts.map +1 -0
- package/dist/{cjs/lib → lib}/dockview/types.d.ts +2 -1
- package/dist/lib/dockview/types.d.ts.map +1 -0
- package/dist/lib/dockview-angular.module.d.ts +12 -0
- package/dist/lib/dockview-angular.module.d.ts.map +1 -0
- package/dist/{cjs/lib → lib}/gridview/angular-gridview-panel.d.ts +1 -0
- package/dist/lib/gridview/angular-gridview-panel.d.ts.map +1 -0
- package/dist/{esm/lib → lib}/gridview/gridview-angular.component.d.ts +4 -0
- package/dist/lib/gridview/gridview-angular.component.d.ts.map +1 -0
- package/dist/{esm/lib → lib}/gridview/types.d.ts +1 -0
- package/dist/lib/gridview/types.d.ts.map +1 -0
- package/dist/{esm/lib → lib}/paneview/angular-pane-part.d.ts +1 -0
- package/dist/lib/paneview/angular-pane-part.d.ts.map +1 -0
- package/dist/{esm/lib → lib}/paneview/paneview-angular.component.d.ts +4 -0
- package/dist/lib/paneview/paneview-angular.component.d.ts.map +1 -0
- package/dist/{esm/lib → lib}/paneview/types.d.ts +1 -0
- package/dist/lib/paneview/types.d.ts.map +1 -0
- package/dist/{cjs/lib → lib}/splitview/angular-splitview-panel.d.ts +1 -0
- package/dist/lib/splitview/angular-splitview-panel.d.ts.map +1 -0
- package/dist/{cjs/lib → lib}/splitview/splitview-angular.component.d.ts +4 -0
- package/dist/lib/splitview/splitview-angular.component.d.ts.map +1 -0
- package/dist/{cjs/lib → lib}/splitview/types.d.ts +1 -0
- package/dist/lib/splitview/types.d.ts.map +1 -0
- package/dist/lib/utils/angular-renderer.d.ts +21 -0
- package/dist/lib/utils/angular-renderer.d.ts.map +1 -0
- package/dist/{cjs/lib → lib}/utils/component-factory.d.ts +1 -0
- package/dist/lib/utils/component-factory.d.ts.map +1 -0
- package/dist/{cjs/lib → lib}/utils/lifecycle-utils.d.ts +1 -0
- package/dist/lib/utils/lifecycle-utils.d.ts.map +1 -0
- package/dist/{cjs/public-api.d.ts → public-api.d.ts} +5 -4
- package/dist/public-api.d.ts.map +1 -0
- package/package.json +72 -66
- package/dist/cjs/index.d.ts +0 -1
- package/dist/cjs/index.js +0 -17
- package/dist/cjs/lib/dockview/dockview-angular.component.js +0 -256
- package/dist/cjs/lib/dockview/types.js +0 -8
- package/dist/cjs/lib/dockview-angular.module.d.ts +0 -2
- package/dist/cjs/lib/dockview-angular.module.js +0 -35
- package/dist/cjs/lib/gridview/angular-gridview-panel.js +0 -21
- package/dist/cjs/lib/gridview/gridview-angular.component.d.ts +0 -28
- package/dist/cjs/lib/gridview/gridview-angular.component.js +0 -140
- package/dist/cjs/lib/gridview/types.d.ts +0 -12
- package/dist/cjs/lib/gridview/types.js +0 -6
- package/dist/cjs/lib/paneview/angular-pane-part.d.ts +0 -13
- package/dist/cjs/lib/paneview/angular-pane-part.js +0 -29
- package/dist/cjs/lib/paneview/paneview-angular.component.d.ts +0 -31
- package/dist/cjs/lib/paneview/paneview-angular.component.js +0 -166
- package/dist/cjs/lib/paneview/types.d.ts +0 -14
- package/dist/cjs/lib/paneview/types.js +0 -6
- package/dist/cjs/lib/splitview/angular-splitview-panel.js +0 -21
- package/dist/cjs/lib/splitview/splitview-angular.component.js +0 -140
- package/dist/cjs/lib/splitview/types.js +0 -6
- package/dist/cjs/lib/utils/angular-renderer.d.ts +0 -18
- package/dist/cjs/lib/utils/angular-renderer.js +0 -70
- package/dist/cjs/lib/utils/component-factory.js +0 -103
- package/dist/cjs/lib/utils/lifecycle-utils.js +0 -74
- package/dist/cjs/public-api.js +0 -32
- package/dist/dockview-angular.amd.js +0 -13201
- package/dist/dockview-angular.amd.js.map +0 -1
- package/dist/dockview-angular.amd.min.js +0 -8
- package/dist/dockview-angular.amd.min.js.map +0 -1
- package/dist/dockview-angular.amd.min.noStyle.js +0 -8
- package/dist/dockview-angular.amd.min.noStyle.js.map +0 -1
- package/dist/dockview-angular.amd.noStyle.js +0 -13171
- package/dist/dockview-angular.amd.noStyle.js.map +0 -1
- package/dist/dockview-angular.cjs.js +0 -13203
- package/dist/dockview-angular.cjs.js.map +0 -1
- package/dist/dockview-angular.esm.js +0 -13131
- package/dist/dockview-angular.esm.js.map +0 -1
- package/dist/dockview-angular.esm.min.js +0 -8
- package/dist/dockview-angular.esm.min.js.map +0 -1
- package/dist/dockview-angular.js +0 -13205
- package/dist/dockview-angular.js.map +0 -1
- package/dist/dockview-angular.min.js +0 -8
- package/dist/dockview-angular.min.js.map +0 -1
- package/dist/dockview-angular.min.noStyle.js +0 -8
- package/dist/dockview-angular.min.noStyle.js.map +0 -1
- package/dist/dockview-angular.noStyle.js +0 -13175
- package/dist/dockview-angular.noStyle.js.map +0 -1
- package/dist/esm/index.d.ts +0 -1
- package/dist/esm/index.js +0 -1
- package/dist/esm/lib/dockview/dockview-angular.component.d.ts +0 -49
- package/dist/esm/lib/dockview/dockview-angular.component.js +0 -253
- package/dist/esm/lib/dockview/types.d.ts +0 -27
- package/dist/esm/lib/dockview/types.js +0 -2
- package/dist/esm/lib/dockview-angular.module.d.ts +0 -2
- package/dist/esm/lib/dockview-angular.module.js +0 -32
- package/dist/esm/lib/gridview/angular-gridview-panel.d.ts +0 -9
- package/dist/esm/lib/gridview/angular-gridview-panel.js +0 -17
- package/dist/esm/lib/gridview/gridview-angular.component.js +0 -137
- package/dist/esm/lib/gridview/types.js +0 -2
- package/dist/esm/lib/paneview/angular-pane-part.js +0 -25
- package/dist/esm/lib/paneview/paneview-angular.component.js +0 -163
- package/dist/esm/lib/paneview/types.js +0 -2
- package/dist/esm/lib/splitview/angular-splitview-panel.d.ts +0 -9
- package/dist/esm/lib/splitview/angular-splitview-panel.js +0 -17
- package/dist/esm/lib/splitview/splitview-angular.component.d.ts +0 -28
- package/dist/esm/lib/splitview/splitview-angular.component.js +0 -137
- package/dist/esm/lib/splitview/types.d.ts +0 -12
- package/dist/esm/lib/splitview/types.js +0 -2
- package/dist/esm/lib/utils/angular-renderer.d.ts +0 -18
- package/dist/esm/lib/utils/angular-renderer.js +0 -66
- package/dist/esm/lib/utils/component-factory.d.ts +0 -20
- package/dist/esm/lib/utils/component-factory.js +0 -99
- package/dist/esm/lib/utils/lifecycle-utils.d.ts +0 -18
- package/dist/esm/lib/utils/lifecycle-utils.js +0 -68
- package/dist/esm/public-api.d.ts +0 -13
- package/dist/esm/public-api.js +0 -16
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import { Component, ElementRef, EventEmitter, Injector, Input, Output, ViewChild, ChangeDetectionStrategy, EnvironmentInjector, inject, } from '@angular/core';
|
|
2
|
+
import { createGridview, PROPERTY_KEYS_GRIDVIEW, } from 'dockview-core';
|
|
3
|
+
import { AngularFrameworkComponentFactory } from '../utils/component-factory';
|
|
4
|
+
import { AngularLifecycleManager } from '../utils/lifecycle-utils';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class GridviewAngularComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.ready = new EventEmitter();
|
|
9
|
+
this.lifecycleManager = new AngularLifecycleManager();
|
|
10
|
+
this.injector = inject(Injector);
|
|
11
|
+
this.environmentInjector = inject(EnvironmentInjector);
|
|
12
|
+
}
|
|
13
|
+
ngOnInit() {
|
|
14
|
+
this.initializeGridview();
|
|
15
|
+
}
|
|
16
|
+
ngOnDestroy() {
|
|
17
|
+
this.lifecycleManager.destroy();
|
|
18
|
+
if (this.gridviewApi) {
|
|
19
|
+
this.gridviewApi.dispose();
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
ngOnChanges(changes) {
|
|
23
|
+
if (this.gridviewApi) {
|
|
24
|
+
const coreChanges = {};
|
|
25
|
+
let hasChanges = false;
|
|
26
|
+
// Check for changes in core gridview properties
|
|
27
|
+
PROPERTY_KEYS_GRIDVIEW.forEach((key) => {
|
|
28
|
+
if (changes[key] && !changes[key].isFirstChange()) {
|
|
29
|
+
coreChanges[key] = changes[key].currentValue;
|
|
30
|
+
hasChanges = true;
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
if (hasChanges) {
|
|
34
|
+
this.gridviewApi.updateOptions(coreChanges);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
getGridviewApi() {
|
|
39
|
+
return this.gridviewApi;
|
|
40
|
+
}
|
|
41
|
+
initializeGridview() {
|
|
42
|
+
if (!this.components) {
|
|
43
|
+
throw new Error('GridviewAngularComponent: components input is required');
|
|
44
|
+
}
|
|
45
|
+
const coreOptions = this.extractCoreOptions();
|
|
46
|
+
const frameworkOptions = this.createFrameworkOptions();
|
|
47
|
+
this.gridviewApi = createGridview(this.containerRef.nativeElement, {
|
|
48
|
+
...coreOptions,
|
|
49
|
+
...frameworkOptions,
|
|
50
|
+
});
|
|
51
|
+
// Emit ready event
|
|
52
|
+
this.ready.emit({ api: this.gridviewApi });
|
|
53
|
+
}
|
|
54
|
+
extractCoreOptions() {
|
|
55
|
+
const coreOptions = {};
|
|
56
|
+
PROPERTY_KEYS_GRIDVIEW.forEach((key) => {
|
|
57
|
+
const value = this[key];
|
|
58
|
+
if (value !== undefined) {
|
|
59
|
+
coreOptions[key] = value;
|
|
60
|
+
}
|
|
61
|
+
});
|
|
62
|
+
return coreOptions;
|
|
63
|
+
}
|
|
64
|
+
createFrameworkOptions() {
|
|
65
|
+
const componentFactory = new AngularFrameworkComponentFactory(this.components, this.injector, this.environmentInjector);
|
|
66
|
+
return {
|
|
67
|
+
createComponent: (options) => {
|
|
68
|
+
return componentFactory.createGridviewComponent(options);
|
|
69
|
+
},
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: GridviewAngularComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
73
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: GridviewAngularComponent, isStandalone: true, selector: "dv-gridview", inputs: { components: "components", className: "className", orientation: "orientation", proportionalLayout: "proportionalLayout", hideBorders: "hideBorders", debug: "debug", disableAutoResizing: "disableAutoResizing" }, outputs: { ready: "ready" }, viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["gridviewContainer"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: '<div #gridviewContainer class="gridview-container"></div>', isInline: true, styles: [":host{display:block;width:100%;height:100%}.gridview-container{width:100%;height:100%}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
74
|
+
}
|
|
75
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: GridviewAngularComponent, decorators: [{
|
|
76
|
+
type: Component,
|
|
77
|
+
args: [{ selector: 'dv-gridview', standalone: true, template: '<div #gridviewContainer class="gridview-container"></div>', changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:block;width:100%;height:100%}.gridview-container{width:100%;height:100%}\n"] }]
|
|
78
|
+
}], propDecorators: { containerRef: [{
|
|
79
|
+
type: ViewChild,
|
|
80
|
+
args: ['gridviewContainer', { static: true }]
|
|
81
|
+
}], components: [{
|
|
82
|
+
type: Input
|
|
83
|
+
}], className: [{
|
|
84
|
+
type: Input
|
|
85
|
+
}], orientation: [{
|
|
86
|
+
type: Input
|
|
87
|
+
}], proportionalLayout: [{
|
|
88
|
+
type: Input
|
|
89
|
+
}], hideBorders: [{
|
|
90
|
+
type: Input
|
|
91
|
+
}], debug: [{
|
|
92
|
+
type: Input
|
|
93
|
+
}], disableAutoResizing: [{
|
|
94
|
+
type: Input
|
|
95
|
+
}], ready: [{
|
|
96
|
+
type: Output
|
|
97
|
+
}] } });
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gridview-angular.component.js","sourceRoot":"","sources":["../../../../src/lib/gridview/gridview-angular.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ElementRef,\n    EventEmitter,\n    Injector,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    Type,\n    ViewChild,\n    ChangeDetectionStrategy,\n    OnChanges,\n    SimpleChanges,\n    EnvironmentInjector,\n    inject,\n} from '@angular/core';\nimport {\n    GridviewApi,\n    GridviewOptions,\n    createGridview,\n    PROPERTY_KEYS_GRIDVIEW,\n    GridviewFrameworkOptions,\n    GridviewComponentOptions,\n} from 'dockview-core';\nimport { AngularFrameworkComponentFactory } from '../utils/component-factory';\nimport { AngularLifecycleManager } from '../utils/lifecycle-utils';\nimport { GridviewAngularReadyEvent } from './types';\n\nexport interface GridviewAngularOptions extends GridviewOptions {\n    components: Record<string, Type<any>>;\n}\n\n@Component({\n    selector: 'dv-gridview',\n    standalone: true,\n    template: '<div #gridviewContainer class=\"gridview-container\"></div>',\n    styles: [\n        `\n            :host {\n                display: block;\n                width: 100%;\n                height: 100%;\n            }\n\n            .gridview-container {\n                width: 100%;\n                height: 100%;\n            }\n        `,\n    ],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class GridviewAngularComponent implements OnInit, OnDestroy, OnChanges {\n    @ViewChild('gridviewContainer', { static: true })\n    private containerRef!: ElementRef<HTMLDivElement>;\n\n    @Input() components!: Record<string, Type<any>>;\n\n    // Core gridview options as inputs\n    @Input() className?: string;\n    @Input() orientation?: 'horizontal' | 'vertical';\n    @Input() proportionalLayout?: boolean;\n    @Input() hideBorders?: boolean;\n    @Input() debug?: boolean;\n    @Input() disableAutoResizing?: boolean;\n\n    @Output() ready = new EventEmitter<GridviewAngularReadyEvent>();\n\n    private gridviewApi?: GridviewApi;\n    private lifecycleManager = new AngularLifecycleManager();\n    private injector = inject(Injector);\n    private environmentInjector = inject(EnvironmentInjector);\n\n    ngOnInit(): void {\n        this.initializeGridview();\n    }\n\n    ngOnDestroy(): void {\n        this.lifecycleManager.destroy();\n        if (this.gridviewApi) {\n            this.gridviewApi.dispose();\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (this.gridviewApi) {\n            const coreChanges: Partial<GridviewOptions> = {};\n            let hasChanges = false;\n\n            // Check for changes in core gridview properties\n            PROPERTY_KEYS_GRIDVIEW.forEach((key) => {\n                if (changes[key] && !changes[key].isFirstChange()) {\n                    (coreChanges as any)[key] = changes[key].currentValue;\n                    hasChanges = true;\n                }\n            });\n\n            if (hasChanges) {\n                this.gridviewApi.updateOptions(coreChanges);\n            }\n        }\n    }\n\n    getGridviewApi(): GridviewApi | undefined {\n        return this.gridviewApi;\n    }\n\n    private initializeGridview(): void {\n        if (!this.components) {\n            throw new Error(\n                'GridviewAngularComponent: components input is required'\n            );\n        }\n\n        const coreOptions = this.extractCoreOptions();\n        const frameworkOptions = this.createFrameworkOptions();\n\n        this.gridviewApi = createGridview(this.containerRef.nativeElement, {\n            ...coreOptions,\n            ...frameworkOptions,\n        });\n\n        // Emit ready event\n        this.ready.emit({ api: this.gridviewApi });\n    }\n\n    private extractCoreOptions(): GridviewOptions {\n        const coreOptions: Partial<GridviewComponentOptions> = {};\n\n        PROPERTY_KEYS_GRIDVIEW.forEach((key) => {\n            const value = (this as any)[key];\n            if (value !== undefined) {\n                (coreOptions as any)[key] = value;\n            }\n        });\n\n        return coreOptions as GridviewOptions;\n    }\n\n    private createFrameworkOptions(): GridviewFrameworkOptions {\n        const componentFactory = new AngularFrameworkComponentFactory(\n            this.components,\n            this.injector,\n            this.environmentInjector\n        );\n\n        return {\n            createComponent: (options) => {\n                return componentFactory.createGridviewComponent(options);\n            },\n        };\n    }\n}\n"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
// Re-export commonly used types from dockview-core
|
|
2
|
+
export { GridviewApi } from 'dockview-core';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL2dyaWR2aWV3L3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWVBLG1EQUFtRDtBQUNuRCxPQUFPLEVBQUUsV0FBVyxFQUFtQixNQUFNLGVBQWUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFR5cGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEdyaWR2aWV3T3B0aW9ucywgR3JpZHZpZXdBcGkgfSBmcm9tICdkb2Nrdmlldy1jb3JlJztcblxuZXhwb3J0IGludGVyZmFjZSBHcmlkdmlld0FuZ3VsYXJSZWFkeUV2ZW50IHtcbiAgICBhcGk6IEdyaWR2aWV3QXBpO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEdyaWR2aWV3QW5ndWxhck9wdGlvbnMgZXh0ZW5kcyBHcmlkdmlld09wdGlvbnMge1xuICAgIGNvbXBvbmVudHM6IFJlY29yZDxzdHJpbmcsIFR5cGU8YW55Pj47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgR3JpZHZpZXdBbmd1bGFyRXZlbnRzIHtcbiAgICByZWFkeTogR3JpZHZpZXdBbmd1bGFyUmVhZHlFdmVudDtcbn1cblxuLy8gUmUtZXhwb3J0IGNvbW1vbmx5IHVzZWQgdHlwZXMgZnJvbSBkb2Nrdmlldy1jb3JlXG5leHBvcnQgeyBHcmlkdmlld0FwaSwgR3JpZHZpZXdPcHRpb25zIH0gZnJvbSAnZG9ja3ZpZXctY29yZSc7XG4iXX0=
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { AngularRenderer } from '../utils/angular-renderer';
|
|
2
|
+
export class AngularPanePart {
|
|
3
|
+
constructor(angularComponent, injector, environmentInjector) {
|
|
4
|
+
this.angularComponent = angularComponent;
|
|
5
|
+
this.injector = injector;
|
|
6
|
+
this.environmentInjector = environmentInjector;
|
|
7
|
+
this.renderer = new AngularRenderer({
|
|
8
|
+
component: this.angularComponent,
|
|
9
|
+
injector: this.injector,
|
|
10
|
+
environmentInjector: this.environmentInjector,
|
|
11
|
+
});
|
|
12
|
+
}
|
|
13
|
+
get element() {
|
|
14
|
+
return this.renderer.element;
|
|
15
|
+
}
|
|
16
|
+
init(parameters) {
|
|
17
|
+
this.renderer.init(parameters);
|
|
18
|
+
}
|
|
19
|
+
update(params) {
|
|
20
|
+
this.renderer.update(params);
|
|
21
|
+
}
|
|
22
|
+
dispose() {
|
|
23
|
+
this.renderer.dispose();
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1wYW5lLXBhcnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL3BhbmV2aWV3L2FuZ3VsYXItcGFuZS1wYXJ0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU1BLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUU1RCxNQUFNLE9BQU8sZUFBZTtJQUd4QixZQUNxQixnQkFBMkIsRUFDM0IsUUFBa0IsRUFDbEIsbUJBQXlDO1FBRnpDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBVztRQUMzQixhQUFRLEdBQVIsUUFBUSxDQUFVO1FBQ2xCLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBc0I7UUFFMUQsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLGVBQWUsQ0FBQztZQUNoQyxTQUFTLEVBQUUsSUFBSSxDQUFDLGdCQUFnQjtZQUNoQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVE7WUFDdkIsbUJBQW1CLEVBQUUsSUFBSSxDQUFDLG1CQUFtQjtTQUNoRCxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsSUFBSSxPQUFPO1FBQ1AsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQztJQUNqQyxDQUFDO0lBRUQsSUFBSSxDQUFDLFVBQTJDO1FBQzVDLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ25DLENBQUM7SUFFRCxNQUFNLENBQUMsTUFBd0I7UUFDM0IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUVELE9BQU87UUFDSCxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQzVCLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFR5cGUsIEluamVjdG9yLCBFbnZpcm9ubWVudEluamVjdG9yIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1xuICAgIElQYW5lUGFydCxcbiAgICBQYW5lbFVwZGF0ZUV2ZW50LFxuICAgIFBhbmVQYW5lbENvbXBvbmVudEluaXRQYXJhbWV0ZXIsXG59IGZyb20gJ2RvY2t2aWV3LWNvcmUnO1xuaW1wb3J0IHsgQW5ndWxhclJlbmRlcmVyIH0gZnJvbSAnLi4vdXRpbHMvYW5ndWxhci1yZW5kZXJlcic7XG5cbmV4cG9ydCBjbGFzcyBBbmd1bGFyUGFuZVBhcnQgaW1wbGVtZW50cyBJUGFuZVBhcnQge1xuICAgIHByaXZhdGUgcmVuZGVyZXI6IEFuZ3VsYXJSZW5kZXJlcjtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIHJlYWRvbmx5IGFuZ3VsYXJDb21wb25lbnQ6IFR5cGU8YW55PixcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSBpbmplY3RvcjogSW5qZWN0b3IsXG4gICAgICAgIHByaXZhdGUgcmVhZG9ubHkgZW52aXJvbm1lbnRJbmplY3Rvcj86IEVudmlyb25tZW50SW5qZWN0b3JcbiAgICApIHtcbiAgICAgICAgdGhpcy5yZW5kZXJlciA9IG5ldyBBbmd1bGFyUmVuZGVyZXIoe1xuICAgICAgICAgICAgY29tcG9uZW50OiB0aGlzLmFuZ3VsYXJDb21wb25lbnQsXG4gICAgICAgICAgICBpbmplY3RvcjogdGhpcy5pbmplY3RvcixcbiAgICAgICAgICAgIGVudmlyb25tZW50SW5qZWN0b3I6IHRoaXMuZW52aXJvbm1lbnRJbmplY3RvcixcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgZ2V0IGVsZW1lbnQoKTogSFRNTEVsZW1lbnQge1xuICAgICAgICByZXR1cm4gdGhpcy5yZW5kZXJlci5lbGVtZW50O1xuICAgIH1cblxuICAgIGluaXQocGFyYW1ldGVyczogUGFuZVBhbmVsQ29tcG9uZW50SW5pdFBhcmFtZXRlcik6IHZvaWQge1xuICAgICAgICB0aGlzLnJlbmRlcmVyLmluaXQocGFyYW1ldGVycyk7XG4gICAgfVxuXG4gICAgdXBkYXRlKHBhcmFtczogUGFuZWxVcGRhdGVFdmVudCk6IHZvaWQge1xuICAgICAgICB0aGlzLnJlbmRlcmVyLnVwZGF0ZShwYXJhbXMpO1xuICAgIH1cblxuICAgIGRpc3Bvc2UoKTogdm9pZCB7XG4gICAgICAgIHRoaXMucmVuZGVyZXIuZGlzcG9zZSgpO1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
import { Component, ElementRef, EventEmitter, Injector, Input, Output, ViewChild, ChangeDetectionStrategy, EnvironmentInjector, inject, } from '@angular/core';
|
|
2
|
+
import { createPaneview, PROPERTY_KEYS_PANEVIEW, } from 'dockview-core';
|
|
3
|
+
import { AngularFrameworkComponentFactory } from '../utils/component-factory';
|
|
4
|
+
import { AngularLifecycleManager } from '../utils/lifecycle-utils';
|
|
5
|
+
import { AngularPanePart } from './angular-pane-part';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class PaneviewAngularComponent {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.ready = new EventEmitter();
|
|
10
|
+
this.drop = new EventEmitter();
|
|
11
|
+
this.lifecycleManager = new AngularLifecycleManager();
|
|
12
|
+
this.injector = inject(Injector);
|
|
13
|
+
this.environmentInjector = inject(EnvironmentInjector);
|
|
14
|
+
}
|
|
15
|
+
ngOnInit() {
|
|
16
|
+
this.initializePaneview();
|
|
17
|
+
}
|
|
18
|
+
ngOnDestroy() {
|
|
19
|
+
this.lifecycleManager.destroy();
|
|
20
|
+
if (this.paneviewApi) {
|
|
21
|
+
this.paneviewApi.dispose();
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
ngOnChanges(changes) {
|
|
25
|
+
if (this.paneviewApi) {
|
|
26
|
+
const coreChanges = {};
|
|
27
|
+
let hasChanges = false;
|
|
28
|
+
// Check for changes in core paneview properties
|
|
29
|
+
PROPERTY_KEYS_PANEVIEW.forEach((key) => {
|
|
30
|
+
if (changes[key] && !changes[key].isFirstChange()) {
|
|
31
|
+
coreChanges[key] = changes[key].currentValue;
|
|
32
|
+
hasChanges = true;
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
if (hasChanges) {
|
|
36
|
+
this.paneviewApi.updateOptions(coreChanges);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
getPaneviewApi() {
|
|
41
|
+
return this.paneviewApi;
|
|
42
|
+
}
|
|
43
|
+
initializePaneview() {
|
|
44
|
+
if (!this.components) {
|
|
45
|
+
throw new Error('PaneviewAngularComponent: components input is required');
|
|
46
|
+
}
|
|
47
|
+
const coreOptions = this.extractCoreOptions();
|
|
48
|
+
const frameworkOptions = this.createFrameworkOptions();
|
|
49
|
+
this.paneviewApi = createPaneview(this.containerRef.nativeElement, {
|
|
50
|
+
...coreOptions,
|
|
51
|
+
...frameworkOptions,
|
|
52
|
+
});
|
|
53
|
+
// Set up event listeners
|
|
54
|
+
this.setupEventListeners();
|
|
55
|
+
// Emit ready event
|
|
56
|
+
this.ready.emit({ api: this.paneviewApi });
|
|
57
|
+
}
|
|
58
|
+
extractCoreOptions() {
|
|
59
|
+
const coreOptions = {};
|
|
60
|
+
PROPERTY_KEYS_PANEVIEW.forEach((key) => {
|
|
61
|
+
const value = this[key];
|
|
62
|
+
if (value !== undefined) {
|
|
63
|
+
coreOptions[key] = value;
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
return coreOptions;
|
|
67
|
+
}
|
|
68
|
+
createFrameworkOptions() {
|
|
69
|
+
const componentFactory = new AngularFrameworkComponentFactory(this.components, this.injector, this.environmentInjector, this.headerComponents);
|
|
70
|
+
return {
|
|
71
|
+
createComponent: (options) => {
|
|
72
|
+
return componentFactory.createPaneviewComponent(options);
|
|
73
|
+
},
|
|
74
|
+
createHeaderComponent: this.headerComponents
|
|
75
|
+
? (options) => {
|
|
76
|
+
return new AngularPanePart(this.headerComponents[options.name], this.injector, this.environmentInjector);
|
|
77
|
+
}
|
|
78
|
+
: undefined,
|
|
79
|
+
};
|
|
80
|
+
}
|
|
81
|
+
setupEventListeners() {
|
|
82
|
+
if (!this.paneviewApi) {
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
// Set up event subscriptions using lifecycle manager
|
|
86
|
+
const api = this.paneviewApi;
|
|
87
|
+
if (this.drop.observers.length > 0) {
|
|
88
|
+
const disposable = api.onDidDrop((event) => {
|
|
89
|
+
this.drop.emit(event);
|
|
90
|
+
});
|
|
91
|
+
this.lifecycleManager.addDisposable(disposable);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PaneviewAngularComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
95
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: PaneviewAngularComponent, isStandalone: true, selector: "dv-paneview", inputs: { components: "components", headerComponents: "headerComponents", className: "className", orientation: "orientation", hideBorders: "hideBorders", debug: "debug", disableAutoResizing: "disableAutoResizing" }, outputs: { ready: "ready", drop: "drop" }, viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["paneviewContainer"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: '<div #paneviewContainer class="paneview-container"></div>', isInline: true, styles: [":host{display:block;width:100%;height:100%}.paneview-container{width:100%;height:100%}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
96
|
+
}
|
|
97
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PaneviewAngularComponent, decorators: [{
|
|
98
|
+
type: Component,
|
|
99
|
+
args: [{ selector: 'dv-paneview', standalone: true, template: '<div #paneviewContainer class="paneview-container"></div>', changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:block;width:100%;height:100%}.paneview-container{width:100%;height:100%}\n"] }]
|
|
100
|
+
}], propDecorators: { containerRef: [{
|
|
101
|
+
type: ViewChild,
|
|
102
|
+
args: ['paneviewContainer', { static: true }]
|
|
103
|
+
}], components: [{
|
|
104
|
+
type: Input
|
|
105
|
+
}], headerComponents: [{
|
|
106
|
+
type: Input
|
|
107
|
+
}], className: [{
|
|
108
|
+
type: Input
|
|
109
|
+
}], orientation: [{
|
|
110
|
+
type: Input
|
|
111
|
+
}], hideBorders: [{
|
|
112
|
+
type: Input
|
|
113
|
+
}], debug: [{
|
|
114
|
+
type: Input
|
|
115
|
+
}], disableAutoResizing: [{
|
|
116
|
+
type: Input
|
|
117
|
+
}], ready: [{
|
|
118
|
+
type: Output
|
|
119
|
+
}], drop: [{
|
|
120
|
+
type: Output
|
|
121
|
+
}] } });
|
|
122
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paneview-angular.component.js","sourceRoot":"","sources":["../../../../src/lib/paneview/paneview-angular.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ElementRef,\n    EventEmitter,\n    Injector,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    Type,\n    ViewChild,\n    ChangeDetectionStrategy,\n    OnChanges,\n    SimpleChanges,\n    EnvironmentInjector,\n    inject,\n} from '@angular/core';\nimport {\n    PaneviewApi,\n    PaneviewOptions,\n    PaneviewDropEvent,\n    createPaneview,\n    PROPERTY_KEYS_PANEVIEW,\n    PaneviewFrameworkOptions,\n    PaneviewComponentOptions,\n} from 'dockview-core';\nimport { AngularFrameworkComponentFactory } from '../utils/component-factory';\nimport { AngularLifecycleManager } from '../utils/lifecycle-utils';\nimport { PaneviewAngularReadyEvent } from './types';\nimport { AngularPanePart } from './angular-pane-part';\n\nexport interface PaneviewAngularOptions extends PaneviewOptions {\n    components: Record<string, Type<any>>;\n    headerComponents?: Record<string, Type<any>>;\n}\n\n@Component({\n    selector: 'dv-paneview',\n    standalone: true,\n    template: '<div #paneviewContainer class=\"paneview-container\"></div>',\n    styles: [\n        `\n            :host {\n                display: block;\n                width: 100%;\n                height: 100%;\n            }\n\n            .paneview-container {\n                width: 100%;\n                height: 100%;\n            }\n        `,\n    ],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class PaneviewAngularComponent implements OnInit, OnDestroy, OnChanges {\n    @ViewChild('paneviewContainer', { static: true })\n    private containerRef!: ElementRef<HTMLDivElement>;\n\n    @Input() components!: Record<string, Type<any>>;\n    @Input() headerComponents?: Record<string, Type<any>>;\n\n    // Core paneview options as inputs\n    @Input() className?: string;\n    @Input() orientation?: 'horizontal' | 'vertical';\n    @Input() hideBorders?: boolean;\n    @Input() debug?: boolean;\n    @Input() disableAutoResizing?: boolean;\n\n    @Output() ready = new EventEmitter<PaneviewAngularReadyEvent>();\n    @Output() drop = new EventEmitter<PaneviewDropEvent>();\n\n    private paneviewApi?: PaneviewApi;\n    private lifecycleManager = new AngularLifecycleManager();\n    private injector = inject(Injector);\n    private environmentInjector = inject(EnvironmentInjector);\n\n    ngOnInit(): void {\n        this.initializePaneview();\n    }\n\n    ngOnDestroy(): void {\n        this.lifecycleManager.destroy();\n        if (this.paneviewApi) {\n            this.paneviewApi.dispose();\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (this.paneviewApi) {\n            const coreChanges: Partial<PaneviewOptions> = {};\n            let hasChanges = false;\n\n            // Check for changes in core paneview properties\n            PROPERTY_KEYS_PANEVIEW.forEach((key) => {\n                if (changes[key] && !changes[key].isFirstChange()) {\n                    (coreChanges as any)[key] = changes[key].currentValue;\n                    hasChanges = true;\n                }\n            });\n\n            if (hasChanges) {\n                this.paneviewApi.updateOptions(coreChanges);\n            }\n        }\n    }\n\n    getPaneviewApi(): PaneviewApi | undefined {\n        return this.paneviewApi;\n    }\n\n    private initializePaneview(): void {\n        if (!this.components) {\n            throw new Error(\n                'PaneviewAngularComponent: components input is required'\n            );\n        }\n\n        const coreOptions = this.extractCoreOptions();\n        const frameworkOptions = this.createFrameworkOptions();\n\n        this.paneviewApi = createPaneview(this.containerRef.nativeElement, {\n            ...coreOptions,\n            ...frameworkOptions,\n        });\n\n        // Set up event listeners\n        this.setupEventListeners();\n\n        // Emit ready event\n        this.ready.emit({ api: this.paneviewApi });\n    }\n\n    private extractCoreOptions(): PaneviewOptions {\n        const coreOptions: Partial<PaneviewComponentOptions> = {};\n\n        PROPERTY_KEYS_PANEVIEW.forEach((key) => {\n            const value = (this as any)[key];\n            if (value !== undefined) {\n                (coreOptions as any)[key] = value;\n            }\n        });\n\n        return coreOptions as PaneviewOptions;\n    }\n\n    private createFrameworkOptions(): PaneviewFrameworkOptions {\n        const componentFactory = new AngularFrameworkComponentFactory(\n            this.components,\n            this.injector,\n            this.environmentInjector,\n            this.headerComponents\n        );\n\n        return {\n            createComponent: (options) => {\n                return componentFactory.createPaneviewComponent(options);\n            },\n            createHeaderComponent: this.headerComponents\n                ? (options) => {\n                      return new AngularPanePart(\n                          this.headerComponents![options.name],\n                          this.injector,\n                          this.environmentInjector\n                      );\n                  }\n                : undefined,\n        };\n    }\n\n    private setupEventListeners(): void {\n        if (!this.paneviewApi) {\n            return;\n        }\n\n        // Set up event subscriptions using lifecycle manager\n        const api = this.paneviewApi;\n\n        if (this.drop.observers.length > 0) {\n            const disposable = api.onDidDrop((event) => {\n                this.drop.emit(event);\n            });\n            this.lifecycleManager.addDisposable(disposable);\n        }\n    }\n}\n"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
// Re-export commonly used types from dockview-core
|
|
2
|
+
export { PaneviewApi } from 'dockview-core';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL3BhbmV2aWV3L3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCQSxtREFBbUQ7QUFDbkQsT0FBTyxFQUFFLFdBQVcsRUFBc0MsTUFBTSxlQUFlLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUeXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQYW5ldmlld09wdGlvbnMsIFBhbmV2aWV3QXBpLCBQYW5ldmlld0Ryb3BFdmVudCB9IGZyb20gJ2RvY2t2aWV3LWNvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFBhbmV2aWV3QW5ndWxhclJlYWR5RXZlbnQge1xuICAgIGFwaTogUGFuZXZpZXdBcGk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGFuZXZpZXdBbmd1bGFyT3B0aW9ucyBleHRlbmRzIFBhbmV2aWV3T3B0aW9ucyB7XG4gICAgY29tcG9uZW50czogUmVjb3JkPHN0cmluZywgVHlwZTxhbnk+PjtcbiAgICBoZWFkZXJDb21wb25lbnRzPzogUmVjb3JkPHN0cmluZywgVHlwZTxhbnk+Pjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQYW5ldmlld0FuZ3VsYXJFdmVudHMge1xuICAgIHJlYWR5OiBQYW5ldmlld0FuZ3VsYXJSZWFkeUV2ZW50O1xuICAgIGRyb3A6IFBhbmV2aWV3RHJvcEV2ZW50O1xufVxuXG4vLyBSZS1leHBvcnQgY29tbW9ubHkgdXNlZCB0eXBlcyBmcm9tIGRvY2t2aWV3LWNvcmVcbmV4cG9ydCB7IFBhbmV2aWV3QXBpLCBQYW5ldmlld0Ryb3BFdmVudCwgUGFuZXZpZXdPcHRpb25zIH0gZnJvbSAnZG9ja3ZpZXctY29yZSc7XG4iXX0=
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { SplitviewPanel } from 'dockview-core';
|
|
2
|
+
import { AngularRenderer } from '../utils/angular-renderer';
|
|
3
|
+
export class AngularSplitviewPanel extends SplitviewPanel {
|
|
4
|
+
constructor(id, component, angularComponent, injector, environmentInjector) {
|
|
5
|
+
super(id, component);
|
|
6
|
+
this.angularComponent = angularComponent;
|
|
7
|
+
this.injector = injector;
|
|
8
|
+
this.environmentInjector = environmentInjector;
|
|
9
|
+
}
|
|
10
|
+
getComponent() {
|
|
11
|
+
const renderer = new AngularRenderer({
|
|
12
|
+
component: this.angularComponent,
|
|
13
|
+
injector: this.injector,
|
|
14
|
+
environmentInjector: this.environmentInjector,
|
|
15
|
+
});
|
|
16
|
+
renderer.init({
|
|
17
|
+
params: this._params?.params ?? {},
|
|
18
|
+
api: this.api,
|
|
19
|
+
});
|
|
20
|
+
this.element.appendChild(renderer.element);
|
|
21
|
+
return renderer;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1zcGxpdHZpZXctcGFuZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL3NwbGl0dmlldy9hbmd1bGFyLXNwbGl0dmlldy1wYW5lbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsY0FBYyxFQUFrQixNQUFNLGVBQWUsQ0FBQztBQUMvRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFNUQsTUFBTSxPQUFPLHFCQUFzQixTQUFRLGNBQWM7SUFDckQsWUFDSSxFQUFVLEVBQ1YsU0FBaUIsRUFDQSxnQkFBMkIsRUFDM0IsUUFBa0IsRUFDbEIsbUJBQXlDO1FBRTFELEtBQUssQ0FBQyxFQUFFLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFKSixxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQVc7UUFDM0IsYUFBUSxHQUFSLFFBQVEsQ0FBVTtRQUNsQix3QkFBbUIsR0FBbkIsbUJBQW1CLENBQXNCO0lBRzlELENBQUM7SUFFRCxZQUFZO1FBQ1IsTUFBTSxRQUFRLEdBQUcsSUFBSSxlQUFlLENBQUM7WUFDakMsU0FBUyxFQUFFLElBQUksQ0FBQyxnQkFBZ0I7WUFDaEMsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRO1lBQ3ZCLG1CQUFtQixFQUFFLElBQUksQ0FBQyxtQkFBbUI7U0FDaEQsQ0FBQyxDQUFDO1FBQ0gsUUFBUSxDQUFDLElBQUksQ0FBQztZQUNWLE1BQU0sRUFBRSxJQUFJLENBQUMsT0FBTyxFQUFFLE1BQU0sSUFBSSxFQUFFO1lBQ2xDLEdBQUcsRUFBRSxJQUFJLENBQUMsR0FBRztTQUNoQixDQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDM0MsT0FBTyxRQUFRLENBQUM7SUFDcEIsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHlwZSwgSW5qZWN0b3IsIEVudmlyb25tZW50SW5qZWN0b3IgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNwbGl0dmlld1BhbmVsLCBJRnJhbWV3b3JrUGFydCB9IGZyb20gJ2RvY2t2aWV3LWNvcmUnO1xuaW1wb3J0IHsgQW5ndWxhclJlbmRlcmVyIH0gZnJvbSAnLi4vdXRpbHMvYW5ndWxhci1yZW5kZXJlcic7XG5cbmV4cG9ydCBjbGFzcyBBbmd1bGFyU3BsaXR2aWV3UGFuZWwgZXh0ZW5kcyBTcGxpdHZpZXdQYW5lbCB7XG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIGlkOiBzdHJpbmcsXG4gICAgICAgIGNvbXBvbmVudDogc3RyaW5nLFxuICAgICAgICBwcml2YXRlIHJlYWRvbmx5IGFuZ3VsYXJDb21wb25lbnQ6IFR5cGU8YW55PixcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSBpbmplY3RvcjogSW5qZWN0b3IsXG4gICAgICAgIHByaXZhdGUgcmVhZG9ubHkgZW52aXJvbm1lbnRJbmplY3Rvcj86IEVudmlyb25tZW50SW5qZWN0b3JcbiAgICApIHtcbiAgICAgICAgc3VwZXIoaWQsIGNvbXBvbmVudCk7XG4gICAgfVxuXG4gICAgZ2V0Q29tcG9uZW50KCk6IElGcmFtZXdvcmtQYXJ0IHtcbiAgICAgICAgY29uc3QgcmVuZGVyZXIgPSBuZXcgQW5ndWxhclJlbmRlcmVyKHtcbiAgICAgICAgICAgIGNvbXBvbmVudDogdGhpcy5hbmd1bGFyQ29tcG9uZW50LFxuICAgICAgICAgICAgaW5qZWN0b3I6IHRoaXMuaW5qZWN0b3IsXG4gICAgICAgICAgICBlbnZpcm9ubWVudEluamVjdG9yOiB0aGlzLmVudmlyb25tZW50SW5qZWN0b3IsXG4gICAgICAgIH0pO1xuICAgICAgICByZW5kZXJlci5pbml0KHtcbiAgICAgICAgICAgIHBhcmFtczogdGhpcy5fcGFyYW1zPy5wYXJhbXMgPz8ge30sXG4gICAgICAgICAgICBhcGk6IHRoaXMuYXBpLFxuICAgICAgICB9KTtcbiAgICAgICAgdGhpcy5lbGVtZW50LmFwcGVuZENoaWxkKHJlbmRlcmVyLmVsZW1lbnQpO1xuICAgICAgICByZXR1cm4gcmVuZGVyZXI7XG4gICAgfVxufVxuIl19
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import { Component, ElementRef, EventEmitter, Injector, Input, Output, ViewChild, ChangeDetectionStrategy, EnvironmentInjector, inject, } from '@angular/core';
|
|
2
|
+
import { createSplitview, PROPERTY_KEYS_SPLITVIEW, } from 'dockview-core';
|
|
3
|
+
import { AngularFrameworkComponentFactory } from '../utils/component-factory';
|
|
4
|
+
import { AngularLifecycleManager } from '../utils/lifecycle-utils';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class SplitviewAngularComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.ready = new EventEmitter();
|
|
9
|
+
this.lifecycleManager = new AngularLifecycleManager();
|
|
10
|
+
this.injector = inject(Injector);
|
|
11
|
+
this.environmentInjector = inject(EnvironmentInjector);
|
|
12
|
+
}
|
|
13
|
+
ngOnInit() {
|
|
14
|
+
this.initializeSplitview();
|
|
15
|
+
}
|
|
16
|
+
ngOnDestroy() {
|
|
17
|
+
this.lifecycleManager.destroy();
|
|
18
|
+
if (this.splitviewApi) {
|
|
19
|
+
this.splitviewApi.dispose();
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
ngOnChanges(changes) {
|
|
23
|
+
if (this.splitviewApi) {
|
|
24
|
+
const coreChanges = {};
|
|
25
|
+
let hasChanges = false;
|
|
26
|
+
// Check for changes in core splitview properties
|
|
27
|
+
PROPERTY_KEYS_SPLITVIEW.forEach((key) => {
|
|
28
|
+
if (changes[key] && !changes[key].isFirstChange()) {
|
|
29
|
+
coreChanges[key] = changes[key].currentValue;
|
|
30
|
+
hasChanges = true;
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
if (hasChanges) {
|
|
34
|
+
this.splitviewApi.updateOptions(coreChanges);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
getSplitviewApi() {
|
|
39
|
+
return this.splitviewApi;
|
|
40
|
+
}
|
|
41
|
+
initializeSplitview() {
|
|
42
|
+
if (!this.components) {
|
|
43
|
+
throw new Error('SplitviewAngularComponent: components input is required');
|
|
44
|
+
}
|
|
45
|
+
const coreOptions = this.extractCoreOptions();
|
|
46
|
+
const frameworkOptions = this.createFrameworkOptions();
|
|
47
|
+
this.splitviewApi = createSplitview(this.containerRef.nativeElement, {
|
|
48
|
+
...coreOptions,
|
|
49
|
+
...frameworkOptions,
|
|
50
|
+
});
|
|
51
|
+
// Emit ready event
|
|
52
|
+
this.ready.emit({ api: this.splitviewApi });
|
|
53
|
+
}
|
|
54
|
+
extractCoreOptions() {
|
|
55
|
+
const coreOptions = {};
|
|
56
|
+
PROPERTY_KEYS_SPLITVIEW.forEach((key) => {
|
|
57
|
+
const value = this[key];
|
|
58
|
+
if (value !== undefined) {
|
|
59
|
+
coreOptions[key] = value;
|
|
60
|
+
}
|
|
61
|
+
});
|
|
62
|
+
return coreOptions;
|
|
63
|
+
}
|
|
64
|
+
createFrameworkOptions() {
|
|
65
|
+
const componentFactory = new AngularFrameworkComponentFactory(this.components, this.injector, this.environmentInjector);
|
|
66
|
+
return {
|
|
67
|
+
createComponent: (options) => {
|
|
68
|
+
return componentFactory.createSplitviewComponent(options);
|
|
69
|
+
},
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SplitviewAngularComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
73
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SplitviewAngularComponent, isStandalone: true, selector: "dv-splitview", inputs: { components: "components", className: "className", orientation: "orientation", proportionalLayout: "proportionalLayout", hideBorders: "hideBorders", debug: "debug", disableAutoResizing: "disableAutoResizing" }, outputs: { ready: "ready" }, viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["splitviewContainer"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: '<div #splitviewContainer class="splitview-container"></div>', isInline: true, styles: [":host{display:block;width:100%;height:100%}.splitview-container{width:100%;height:100%}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
74
|
+
}
|
|
75
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SplitviewAngularComponent, decorators: [{
|
|
76
|
+
type: Component,
|
|
77
|
+
args: [{ selector: 'dv-splitview', standalone: true, template: '<div #splitviewContainer class="splitview-container"></div>', changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:block;width:100%;height:100%}.splitview-container{width:100%;height:100%}\n"] }]
|
|
78
|
+
}], propDecorators: { containerRef: [{
|
|
79
|
+
type: ViewChild,
|
|
80
|
+
args: ['splitviewContainer', { static: true }]
|
|
81
|
+
}], components: [{
|
|
82
|
+
type: Input
|
|
83
|
+
}], className: [{
|
|
84
|
+
type: Input
|
|
85
|
+
}], orientation: [{
|
|
86
|
+
type: Input
|
|
87
|
+
}], proportionalLayout: [{
|
|
88
|
+
type: Input
|
|
89
|
+
}], hideBorders: [{
|
|
90
|
+
type: Input
|
|
91
|
+
}], debug: [{
|
|
92
|
+
type: Input
|
|
93
|
+
}], disableAutoResizing: [{
|
|
94
|
+
type: Input
|
|
95
|
+
}], ready: [{
|
|
96
|
+
type: Output
|
|
97
|
+
}] } });
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"splitview-angular.component.js","sourceRoot":"","sources":["../../../../src/lib/splitview/splitview-angular.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ElementRef,\n    EventEmitter,\n    Injector,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    Type,\n    ViewChild,\n    ChangeDetectionStrategy,\n    OnChanges,\n    SimpleChanges,\n    EnvironmentInjector,\n    inject,\n} from '@angular/core';\nimport {\n    SplitviewApi,\n    SplitviewOptions,\n    createSplitview,\n    PROPERTY_KEYS_SPLITVIEW,\n    SplitviewFrameworkOptions,\n    SplitviewComponentOptions,\n} from 'dockview-core';\nimport { AngularFrameworkComponentFactory } from '../utils/component-factory';\nimport { AngularLifecycleManager } from '../utils/lifecycle-utils';\nimport { SplitviewAngularReadyEvent } from './types';\n\nexport interface SplitviewAngularOptions extends SplitviewOptions {\n    components: Record<string, Type<any>>;\n}\n\n@Component({\n    selector: 'dv-splitview',\n    standalone: true,\n    template: '<div #splitviewContainer class=\"splitview-container\"></div>',\n    styles: [\n        `\n            :host {\n                display: block;\n                width: 100%;\n                height: 100%;\n            }\n\n            .splitview-container {\n                width: 100%;\n                height: 100%;\n            }\n        `,\n    ],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SplitviewAngularComponent implements OnInit, OnDestroy, OnChanges {\n    @ViewChild('splitviewContainer', { static: true })\n    private containerRef!: ElementRef<HTMLDivElement>;\n\n    @Input() components!: Record<string, Type<any>>;\n\n    // Core splitview options as inputs\n    @Input() className?: string;\n    @Input() orientation?: 'horizontal' | 'vertical';\n    @Input() proportionalLayout?: boolean;\n    @Input() hideBorders?: boolean;\n    @Input() debug?: boolean;\n    @Input() disableAutoResizing?: boolean;\n\n    @Output() ready = new EventEmitter<SplitviewAngularReadyEvent>();\n\n    private splitviewApi?: SplitviewApi;\n    private lifecycleManager = new AngularLifecycleManager();\n    private injector = inject(Injector);\n    private environmentInjector = inject(EnvironmentInjector);\n\n    ngOnInit(): void {\n        this.initializeSplitview();\n    }\n\n    ngOnDestroy(): void {\n        this.lifecycleManager.destroy();\n        if (this.splitviewApi) {\n            this.splitviewApi.dispose();\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (this.splitviewApi) {\n            const coreChanges: Partial<SplitviewOptions> = {};\n            let hasChanges = false;\n\n            // Check for changes in core splitview properties\n            PROPERTY_KEYS_SPLITVIEW.forEach((key) => {\n                if (changes[key] && !changes[key].isFirstChange()) {\n                    (coreChanges as any)[key] = changes[key].currentValue;\n                    hasChanges = true;\n                }\n            });\n\n            if (hasChanges) {\n                this.splitviewApi.updateOptions(coreChanges);\n            }\n        }\n    }\n\n    getSplitviewApi(): SplitviewApi | undefined {\n        return this.splitviewApi;\n    }\n\n    private initializeSplitview(): void {\n        if (!this.components) {\n            throw new Error(\n                'SplitviewAngularComponent: components input is required'\n            );\n        }\n\n        const coreOptions = this.extractCoreOptions();\n        const frameworkOptions = this.createFrameworkOptions();\n\n        this.splitviewApi = createSplitview(this.containerRef.nativeElement, {\n            ...coreOptions,\n            ...frameworkOptions,\n        });\n\n        // Emit ready event\n        this.ready.emit({ api: this.splitviewApi });\n    }\n\n    private extractCoreOptions(): SplitviewOptions {\n        const coreOptions: Partial<SplitviewComponentOptions> = {};\n\n        PROPERTY_KEYS_SPLITVIEW.forEach((key) => {\n            const value = (this as any)[key];\n            if (value !== undefined) {\n                (coreOptions as any)[key] = value;\n            }\n        });\n\n        return coreOptions as SplitviewOptions;\n    }\n\n    private createFrameworkOptions(): SplitviewFrameworkOptions {\n        const componentFactory = new AngularFrameworkComponentFactory(\n            this.components,\n            this.injector,\n            this.environmentInjector\n        );\n\n        return {\n            createComponent: (options) => {\n                return componentFactory.createSplitviewComponent(options);\n            },\n        };\n    }\n}\n"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
// Re-export commonly used types from dockview-core
|
|
2
|
+
export { SplitviewApi } from 'dockview-core';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL3NwbGl0dmlldy90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlQSxtREFBbUQ7QUFDbkQsT0FBTyxFQUFFLFlBQVksRUFBb0IsTUFBTSxlQUFlLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUeXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTcGxpdHZpZXdPcHRpb25zLCBTcGxpdHZpZXdBcGkgfSBmcm9tICdkb2Nrdmlldy1jb3JlJztcblxuZXhwb3J0IGludGVyZmFjZSBTcGxpdHZpZXdBbmd1bGFyUmVhZHlFdmVudCB7XG4gICAgYXBpOiBTcGxpdHZpZXdBcGk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU3BsaXR2aWV3QW5ndWxhck9wdGlvbnMgZXh0ZW5kcyBTcGxpdHZpZXdPcHRpb25zIHtcbiAgICBjb21wb25lbnRzOiBSZWNvcmQ8c3RyaW5nLCBUeXBlPGFueT4+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNwbGl0dmlld0FuZ3VsYXJFdmVudHMge1xuICAgIHJlYWR5OiBTcGxpdHZpZXdBbmd1bGFyUmVhZHlFdmVudDtcbn1cblxuLy8gUmUtZXhwb3J0IGNvbW1vbmx5IHVzZWQgdHlwZXMgZnJvbSBkb2Nrdmlldy1jb3JlXG5leHBvcnQgeyBTcGxpdHZpZXdBcGksIFNwbGl0dmlld09wdGlvbnMgfSBmcm9tICdkb2Nrdmlldy1jb3JlJztcbiJdfQ==
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { createComponent, ApplicationRef, } from '@angular/core';
|
|
2
|
+
export class AngularRenderer {
|
|
3
|
+
constructor(options) {
|
|
4
|
+
this.options = options;
|
|
5
|
+
this.componentRef = null;
|
|
6
|
+
this._element = null;
|
|
7
|
+
this.appRef = options.injector.get(ApplicationRef);
|
|
8
|
+
}
|
|
9
|
+
get element() {
|
|
10
|
+
if (!this._element) {
|
|
11
|
+
throw new Error('Angular renderer not initialized');
|
|
12
|
+
}
|
|
13
|
+
return this._element;
|
|
14
|
+
}
|
|
15
|
+
get component() {
|
|
16
|
+
return this.componentRef;
|
|
17
|
+
}
|
|
18
|
+
init(parameters) {
|
|
19
|
+
// Only forward params, api, and containerApi to the component
|
|
20
|
+
// (matching the React renderer). Other init parameters like
|
|
21
|
+
// 'title' are internal to the framework.
|
|
22
|
+
const filtered = {};
|
|
23
|
+
if ('params' in parameters) {
|
|
24
|
+
filtered['params'] = parameters['params'];
|
|
25
|
+
}
|
|
26
|
+
if ('api' in parameters) {
|
|
27
|
+
filtered['api'] = parameters['api'];
|
|
28
|
+
}
|
|
29
|
+
if ('containerApi' in parameters) {
|
|
30
|
+
filtered['containerApi'] = parameters['containerApi'];
|
|
31
|
+
}
|
|
32
|
+
if (this.componentRef) {
|
|
33
|
+
this.update(filtered);
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
this.render(filtered);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
update(params) {
|
|
40
|
+
if (!this.componentRef) {
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
const instance = this.componentRef.instance;
|
|
44
|
+
for (const key of Object.keys(params)) {
|
|
45
|
+
if (key in instance) {
|
|
46
|
+
instance[key] = params[key];
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
// trigger change detection
|
|
50
|
+
this.componentRef.changeDetectorRef.markForCheck();
|
|
51
|
+
}
|
|
52
|
+
render(parameters) {
|
|
53
|
+
try {
|
|
54
|
+
// Create the component using modern Angular API
|
|
55
|
+
this.componentRef = createComponent(this.options.component, {
|
|
56
|
+
environmentInjector: this.options.environmentInjector ||
|
|
57
|
+
this.options.injector,
|
|
58
|
+
elementInjector: this.options.injector,
|
|
59
|
+
});
|
|
60
|
+
// Set initial parameters
|
|
61
|
+
this.update(parameters);
|
|
62
|
+
// Get the DOM element
|
|
63
|
+
const hostView = this.componentRef.hostView;
|
|
64
|
+
this._element = hostView.rootNodes[0];
|
|
65
|
+
// attach to change detection
|
|
66
|
+
this.appRef.attachView(hostView);
|
|
67
|
+
// trigger change detection
|
|
68
|
+
this.componentRef.changeDetectorRef.markForCheck();
|
|
69
|
+
}
|
|
70
|
+
catch (error) {
|
|
71
|
+
console.error('Error creating Angular component:', error);
|
|
72
|
+
throw error;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
dispose() {
|
|
76
|
+
if (this.componentRef) {
|
|
77
|
+
this.componentRef.destroy();
|
|
78
|
+
this.componentRef = null;
|
|
79
|
+
}
|
|
80
|
+
this._element = null;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1yZW5kZXJlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvdXRpbHMvYW5ndWxhci1yZW5kZXJlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBS0gsZUFBZSxFQUVmLGNBQWMsR0FDakIsTUFBTSxlQUFlLENBQUM7QUFTdkIsTUFBTSxPQUFPLGVBQWU7SUFPeEIsWUFBb0IsT0FBa0M7UUFBbEMsWUFBTyxHQUFQLE9BQU8sQ0FBMkI7UUFKOUMsaUJBQVksR0FBMkIsSUFBSSxDQUFDO1FBQzVDLGFBQVEsR0FBdUIsSUFBSSxDQUFDO1FBSXhDLElBQUksQ0FBQyxNQUFNLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDdkQsQ0FBQztJQUVELElBQUksT0FBTztRQUNQLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDakIsTUFBTSxJQUFJLEtBQUssQ0FBQyxrQ0FBa0MsQ0FBQyxDQUFDO1FBQ3hELENBQUM7UUFDRCxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUM7SUFDekIsQ0FBQztJQUVELElBQUksU0FBUztRQUNULE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQztJQUM3QixDQUFDO0lBRUQsSUFBSSxDQUFDLFVBQXNCO1FBQ3ZCLDhEQUE4RDtRQUM5RCw0REFBNEQ7UUFDNUQseUNBQXlDO1FBQ3pDLE1BQU0sUUFBUSxHQUE0QixFQUFFLENBQUM7UUFDN0MsSUFBSSxRQUFRLElBQUksVUFBVSxFQUFFLENBQUM7WUFDekIsUUFBUSxDQUFDLFFBQVEsQ0FBQyxHQUFHLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUM5QyxDQUFDO1FBQ0QsSUFBSSxLQUFLLElBQUksVUFBVSxFQUFFLENBQUM7WUFDdEIsUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUFHLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN4QyxDQUFDO1FBQ0QsSUFBSSxjQUFjLElBQUksVUFBVSxFQUFFLENBQUM7WUFDL0IsUUFBUSxDQUFDLGNBQWMsQ0FBQyxHQUFHLFVBQVUsQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUMxRCxDQUFDO1FBRUQsSUFBSSxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7WUFDcEIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUMxQixDQUFDO2FBQU0sQ0FBQztZQUNKLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDMUIsQ0FBQztJQUNMLENBQUM7SUFFRCxNQUFNLENBQUMsTUFBa0I7UUFDckIsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztZQUNyQixPQUFPO1FBQ1gsQ0FBQztRQUVELE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBbUMsQ0FBQztRQUV2RSxLQUFLLE1BQU0sR0FBRyxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztZQUNwQyxJQUFJLEdBQUcsSUFBSSxRQUFRLEVBQUUsQ0FBQztnQkFDbEIsUUFBUSxDQUFDLEdBQUcsQ0FBQyxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUNoQyxDQUFDO1FBQ0wsQ0FBQztRQUVELDJCQUEyQjtRQUMzQixJQUFJLENBQUMsWUFBWSxDQUFDLGlCQUFpQixDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ3ZELENBQUM7SUFFTyxNQUFNLENBQUMsVUFBc0I7UUFDakMsSUFBSSxDQUFDO1lBQ0QsZ0RBQWdEO1lBQ2hELElBQUksQ0FBQyxZQUFZLEdBQUcsZUFBZSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxFQUFFO2dCQUN4RCxtQkFBbUIsRUFDZixJQUFJLENBQUMsT0FBTyxDQUFDLG1CQUFtQjtvQkFDL0IsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFnQztnQkFDbEQsZUFBZSxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUTthQUN6QyxDQUFDLENBQUM7WUFFSCx5QkFBeUI7WUFDekIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztZQUV4QixzQkFBc0I7WUFDdEIsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFnQyxDQUFDO1lBQ3BFLElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQWdCLENBQUM7WUFFckQsNkJBQTZCO1lBQzdCLElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBRWpDLDJCQUEyQjtZQUMzQixJQUFJLENBQUMsWUFBWSxDQUFDLGlCQUFpQixDQUFDLFlBQVksRUFBRSxDQUFDO1FBQ3ZELENBQUM7UUFBQyxPQUFPLEtBQUssRUFBRSxDQUFDO1lBQ2IsT0FBTyxDQUFDLEtBQUssQ0FBQyxtQ0FBbUMsRUFBRSxLQUFLLENBQUMsQ0FBQztZQUMxRCxNQUFNLEtBQUssQ0FBQztRQUNoQixDQUFDO0lBQ0wsQ0FBQztJQUVELE9BQU87UUFDSCxJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztZQUNwQixJQUFJLENBQUMsWUFBWSxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQzVCLElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDO1FBQzdCLENBQUM7UUFDRCxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztJQUN6QixDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIENvbXBvbmVudFJlZixcbiAgICBJbmplY3RvcixcbiAgICBUeXBlLFxuICAgIEVtYmVkZGVkVmlld1JlZixcbiAgICBjcmVhdGVDb21wb25lbnQsXG4gICAgRW52aXJvbm1lbnRJbmplY3RvcixcbiAgICBBcHBsaWNhdGlvblJlZixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJQ29udGVudFJlbmRlcmVyLCBJRnJhbWV3b3JrUGFydCwgUGFyYW1ldGVycyB9IGZyb20gJ2RvY2t2aWV3LWNvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEFuZ3VsYXJSZW5kZXJlck9wdGlvbnM8VCA9IGFueT4ge1xuICAgIGNvbXBvbmVudDogVHlwZTxUPjtcbiAgICBpbmplY3RvcjogSW5qZWN0b3I7XG4gICAgZW52aXJvbm1lbnRJbmplY3Rvcj86IEVudmlyb25tZW50SW5qZWN0b3I7XG59XG5cbmV4cG9ydCBjbGFzcyBBbmd1bGFyUmVuZGVyZXI8VCA9IGFueT5cbiAgICBpbXBsZW1lbnRzIElDb250ZW50UmVuZGVyZXIsIElGcmFtZXdvcmtQYXJ0XG57XG4gICAgcHJpdmF0ZSBjb21wb25lbnRSZWY6IENvbXBvbmVudFJlZjxUPiB8IG51bGwgPSBudWxsO1xuICAgIHByaXZhdGUgX2VsZW1lbnQ6IEhUTUxFbGVtZW50IHwgbnVsbCA9IG51bGw7XG4gICAgcHJpdmF0ZSBhcHBSZWY6IEFwcGxpY2F0aW9uUmVmO1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBvcHRpb25zOiBBbmd1bGFyUmVuZGVyZXJPcHRpb25zPFQ+KSB7XG4gICAgICAgIHRoaXMuYXBwUmVmID0gb3B0aW9ucy5pbmplY3Rvci5nZXQoQXBwbGljYXRpb25SZWYpO1xuICAgIH1cblxuICAgIGdldCBlbGVtZW50KCk6IEhUTUxFbGVtZW50IHtcbiAgICAgICAgaWYgKCF0aGlzLl9lbGVtZW50KSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ0FuZ3VsYXIgcmVuZGVyZXIgbm90IGluaXRpYWxpemVkJyk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHRoaXMuX2VsZW1lbnQ7XG4gICAgfVxuXG4gICAgZ2V0IGNvbXBvbmVudCgpOiBDb21wb25lbnRSZWY8VD4gfCBudWxsIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuY29tcG9uZW50UmVmO1xuICAgIH1cblxuICAgIGluaXQocGFyYW1ldGVyczogUGFyYW1ldGVycyk6IHZvaWQge1xuICAgICAgICAvLyBPbmx5IGZvcndhcmQgcGFyYW1zLCBhcGksIGFuZCBjb250YWluZXJBcGkgdG8gdGhlIGNvbXBvbmVudFxuICAgICAgICAvLyAobWF0Y2hpbmcgdGhlIFJlYWN0IHJlbmRlcmVyKS4gT3RoZXIgaW5pdCBwYXJhbWV0ZXJzIGxpa2VcbiAgICAgICAgLy8gJ3RpdGxlJyBhcmUgaW50ZXJuYWwgdG8gdGhlIGZyYW1ld29yay5cbiAgICAgICAgY29uc3QgZmlsdGVyZWQ6IFJlY29yZDxzdHJpbmcsIHVua25vd24+ID0ge307XG4gICAgICAgIGlmICgncGFyYW1zJyBpbiBwYXJhbWV0ZXJzKSB7XG4gICAgICAgICAgICBmaWx0ZXJlZFsncGFyYW1zJ10gPSBwYXJhbWV0ZXJzWydwYXJhbXMnXTtcbiAgICAgICAgfVxuICAgICAgICBpZiAoJ2FwaScgaW4gcGFyYW1ldGVycykge1xuICAgICAgICAgICAgZmlsdGVyZWRbJ2FwaSddID0gcGFyYW1ldGVyc1snYXBpJ107XG4gICAgICAgIH1cbiAgICAgICAgaWYgKCdjb250YWluZXJBcGknIGluIHBhcmFtZXRlcnMpIHtcbiAgICAgICAgICAgIGZpbHRlcmVkWydjb250YWluZXJBcGknXSA9IHBhcmFtZXRlcnNbJ2NvbnRhaW5lckFwaSddO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKHRoaXMuY29tcG9uZW50UmVmKSB7XG4gICAgICAgICAgICB0aGlzLnVwZGF0ZShmaWx0ZXJlZCk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLnJlbmRlcihmaWx0ZXJlZCk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICB1cGRhdGUocGFyYW1zOiBQYXJhbWV0ZXJzKTogdm9pZCB7XG4gICAgICAgIGlmICghdGhpcy5jb21wb25lbnRSZWYpIHtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IGluc3RhbmNlID0gdGhpcy5jb21wb25lbnRSZWYuaW5zdGFuY2UgYXMgUmVjb3JkPHN0cmluZywgdW5rbm93bj47XG5cbiAgICAgICAgZm9yIChjb25zdCBrZXkgb2YgT2JqZWN0LmtleXMocGFyYW1zKSkge1xuICAgICAgICAgICAgaWYgKGtleSBpbiBpbnN0YW5jZSkge1xuICAgICAgICAgICAgICAgIGluc3RhbmNlW2tleV0gPSBwYXJhbXNba2V5XTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIC8vIHRyaWdnZXIgY2hhbmdlIGRldGVjdGlvblxuICAgICAgICB0aGlzLmNvbXBvbmVudFJlZi5jaGFuZ2VEZXRlY3RvclJlZi5tYXJrRm9yQ2hlY2soKTtcbiAgICB9XG5cbiAgICBwcml2YXRlIHJlbmRlcihwYXJhbWV0ZXJzOiBQYXJhbWV0ZXJzKTogdm9pZCB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgICAvLyBDcmVhdGUgdGhlIGNvbXBvbmVudCB1c2luZyBtb2Rlcm4gQW5ndWxhciBBUElcbiAgICAgICAgICAgIHRoaXMuY29tcG9uZW50UmVmID0gY3JlYXRlQ29tcG9uZW50KHRoaXMub3B0aW9ucy5jb21wb25lbnQsIHtcbiAgICAgICAgICAgICAgICBlbnZpcm9ubWVudEluamVjdG9yOlxuICAgICAgICAgICAgICAgICAgICB0aGlzLm9wdGlvbnMuZW52aXJvbm1lbnRJbmplY3RvciB8fFxuICAgICAgICAgICAgICAgICAgICAodGhpcy5vcHRpb25zLmluamVjdG9yIGFzIEVudmlyb25tZW50SW5qZWN0b3IpLFxuICAgICAgICAgICAgICAgIGVsZW1lbnRJbmplY3RvcjogdGhpcy5vcHRpb25zLmluamVjdG9yLFxuICAgICAgICAgICAgfSk7XG5cbiAgICAgICAgICAgIC8vIFNldCBpbml0aWFsIHBhcmFtZXRlcnNcbiAgICAgICAgICAgIHRoaXMudXBkYXRlKHBhcmFtZXRlcnMpO1xuXG4gICAgICAgICAgICAvLyBHZXQgdGhlIERPTSBlbGVtZW50XG4gICAgICAgICAgICBjb25zdCBob3N0VmlldyA9IHRoaXMuY29tcG9uZW50UmVmLmhvc3RWaWV3IGFzIEVtYmVkZGVkVmlld1JlZjxhbnk+O1xuICAgICAgICAgICAgdGhpcy5fZWxlbWVudCA9IGhvc3RWaWV3LnJvb3ROb2Rlc1swXSBhcyBIVE1MRWxlbWVudDtcblxuICAgICAgICAgICAgLy8gYXR0YWNoIHRvIGNoYW5nZSBkZXRlY3Rpb25cbiAgICAgICAgICAgIHRoaXMuYXBwUmVmLmF0dGFjaFZpZXcoaG9zdFZpZXcpO1xuXG4gICAgICAgICAgICAvLyB0cmlnZ2VyIGNoYW5nZSBkZXRlY3Rpb25cbiAgICAgICAgICAgIHRoaXMuY29tcG9uZW50UmVmLmNoYW5nZURldGVjdG9yUmVmLm1hcmtGb3JDaGVjaygpO1xuICAgICAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgICAgICAgY29uc29sZS5lcnJvcignRXJyb3IgY3JlYXRpbmcgQW5ndWxhciBjb21wb25lbnQ6JywgZXJyb3IpO1xuICAgICAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBkaXNwb3NlKCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5jb21wb25lbnRSZWYpIHtcbiAgICAgICAgICAgIHRoaXMuY29tcG9uZW50UmVmLmRlc3Ryb3koKTtcbiAgICAgICAgICAgIHRoaXMuY29tcG9uZW50UmVmID0gbnVsbDtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLl9lbGVtZW50ID0gbnVsbDtcbiAgICB9XG59XG4iXX0=
|