dockview 1.4.2 → 1.4.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/README.md +4 -195
- package/dist/cjs/api/component.api.d.ts +5 -0
- package/dist/cjs/api/component.api.js +13 -1
- package/dist/cjs/api/component.api.js.map +1 -1
- package/dist/cjs/dnd/droptarget.d.ts +1 -2
- package/dist/cjs/dockview/deserializer.d.ts +0 -12
- package/dist/cjs/dockview/deserializer.js +0 -52
- package/dist/cjs/dockview/deserializer.js.map +1 -1
- package/dist/cjs/dockview/dockviewComponent.d.ts +5 -7
- package/dist/cjs/dockview/dockviewComponent.js +77 -40
- package/dist/cjs/dockview/dockviewComponent.js.map +1 -1
- package/dist/cjs/dockview/options.d.ts +6 -1
- package/dist/cjs/gridview/baseComponentGridview.d.ts +4 -2
- package/dist/cjs/gridview/baseComponentGridview.js +1 -1
- package/dist/cjs/gridview/baseComponentGridview.js.map +1 -1
- package/dist/cjs/gridview/gridviewComponent.d.ts +1 -0
- package/dist/cjs/gridview/gridviewComponent.js +26 -18
- package/dist/cjs/gridview/gridviewComponent.js.map +1 -1
- package/dist/cjs/groupview/groupview.d.ts +4 -3
- package/dist/cjs/groupview/groupview.js +15 -6
- package/dist/cjs/groupview/groupview.js.map +1 -1
- package/dist/cjs/groupview/groupviewPanel.d.ts +2 -2
- package/dist/cjs/groupview/groupviewPanel.js.map +1 -1
- package/dist/cjs/groupview/titlebar/tabsContainer.d.ts +2 -2
- package/dist/cjs/groupview/titlebar/tabsContainer.js.map +1 -1
- package/dist/cjs/index.d.ts +1 -0
- package/dist/cjs/index.js +1 -0
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/paneview/defaultPaneviewHeader.js +6 -4
- package/dist/cjs/paneview/defaultPaneviewHeader.js.map +1 -1
- package/dist/cjs/paneview/paneviewComponent.d.ts +2 -0
- package/dist/cjs/paneview/paneviewComponent.js +19 -16
- package/dist/cjs/paneview/paneviewComponent.js.map +1 -1
- package/dist/cjs/react/dockview/dockview.d.ts +2 -3
- package/dist/cjs/react/dockview/dockview.js.map +1 -1
- package/dist/cjs/splitview/splitviewComponent.d.ts +2 -0
- package/dist/cjs/splitview/splitviewComponent.js +20 -17
- package/dist/cjs/splitview/splitviewComponent.js.map +1 -1
- package/dist/dockview.amd.js +122 -87
- package/dist/dockview.amd.min.js +2 -2
- package/dist/dockview.amd.min.noStyle.js +2 -2
- package/dist/dockview.amd.noStyle.js +121 -86
- package/dist/dockview.cjs.js +122 -87
- package/dist/dockview.esm.js +118 -83
- package/dist/dockview.esm.min.js +2 -2
- package/dist/dockview.js +122 -87
- package/dist/dockview.min.js +2 -2
- package/dist/dockview.min.noStyle.js +2 -2
- package/dist/dockview.noStyle.js +121 -86
- package/dist/esm/api/component.api.d.ts +5 -0
- package/dist/esm/api/component.api.js +13 -1
- package/dist/esm/dnd/droptarget.d.ts +1 -2
- package/dist/esm/dockview/deserializer.d.ts +0 -12
- package/dist/esm/dockview/deserializer.js +1 -27
- package/dist/esm/dockview/dockviewComponent.d.ts +5 -7
- package/dist/esm/dockview/dockviewComponent.js +49 -23
- package/dist/esm/dockview/options.d.ts +6 -1
- package/dist/esm/gridview/baseComponentGridview.d.ts +4 -2
- package/dist/esm/gridview/baseComponentGridview.js +1 -1
- package/dist/esm/gridview/gridviewComponent.d.ts +1 -0
- package/dist/esm/gridview/gridviewComponent.js +15 -7
- package/dist/esm/groupview/groupview.d.ts +4 -3
- package/dist/esm/groupview/groupview.js +15 -6
- package/dist/esm/groupview/groupviewPanel.d.ts +2 -2
- package/dist/esm/groupview/titlebar/tabsContainer.d.ts +2 -2
- package/dist/esm/index.d.ts +1 -0
- package/dist/esm/index.js +1 -0
- package/dist/esm/paneview/defaultPaneviewHeader.js +6 -4
- package/dist/esm/paneview/paneviewComponent.d.ts +2 -0
- package/dist/esm/paneview/paneviewComponent.js +8 -5
- package/dist/esm/react/dockview/dockview.d.ts +2 -3
- package/dist/esm/splitview/splitviewComponent.d.ts +2 -0
- package/dist/esm/splitview/splitviewComponent.js +9 -6
- package/dist/styles/dockview.css +5 -0
- package/package.json +2 -2
package/README.md
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
<div align="center">
|
|
2
2
|
<h1>dockview</h1>
|
|
3
3
|
|
|
4
|
-
<p>Zero dependency layout manager supporting tabs, grids and splitviews with ReactJS support</p>
|
|
4
|
+
<p>Zero dependency layout manager supporting tabs, grids and splitviews with ReactJS support written in TypeScript</p>
|
|
5
5
|
|
|
6
6
|
</div>
|
|
7
7
|
|
|
@@ -15,12 +15,7 @@
|
|
|
15
15
|
|
|
16
16
|
##
|
|
17
17
|
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
- [➡️](https://mathuo.github.io/dockview/docs) Documentation
|
|
21
|
-
- [➡️](https://mathuo.github.io/dockview/) Live demo
|
|
22
|
-
- [➡️](https://github.com/mathuo/dockview/tree/master/packages/dockview-demo/src/stories) Code examples
|
|
23
|
-
- [➡️](https://mathuo.github.io/dockview/output/docs/index.html) Generated TypeDocs
|
|
18
|
+
Please see the website: https://mathuo.github.io/dockview/docs
|
|
24
19
|
|
|
25
20
|
Want to inspect the latest deployment? Go to https://unpkg.com/browse/dockview@latest/
|
|
26
21
|
|
|
@@ -34,27 +29,17 @@ Want to inspect the latest deployment? Go to https://unpkg.com/browse/dockview@l
|
|
|
34
29
|
- Tabular docking and Drag and Drop support
|
|
35
30
|
- Documentation and examples
|
|
36
31
|
|
|
37
|
-
## Table of contents
|
|
38
|
-
|
|
39
|
-
- [Quick start](#quick-start)
|
|
40
|
-
- [Sandbox examples](#sandbox-examples)
|
|
41
|
-
- [Serializated layouts](#serializated-layouts)
|
|
42
|
-
- [Drag and drop](#drag-and-drop)
|
|
43
|
-
- [Theming](#theming)
|
|
44
|
-
- [Performance](#performance)
|
|
45
|
-
- [FAQ](#faq)
|
|
46
|
-
|
|
47
32
|
This project was inspired by many popular IDE editors. Some parts of the core resizable panelling are inspired by code found in the VSCode codebase, [splitview](https://github.com/microsoft/vscode/tree/main/src/vs/base/browser/ui/splitview) and [gridview](https://github.com/microsoft/vscode/tree/main/src/vs/base/browser/ui/grid).
|
|
48
33
|
|
|
49
34
|
## Quick start
|
|
50
35
|
|
|
51
|
-
Dockview has a peer dependency on `react >= 16.8.0` and `react-dom >= 16.8.0`. You can install dockview from [npm](https://www.npmjs.com/package/dockview).
|
|
36
|
+
Dockview has a peer dependency on `react >= 16.8.0` and `react-dom >= 16.8.0`. You can install dockview from [npm](https://www.npmjs.com/package/dockview). Please see the [Getting Started Guide](https://mathuo.github.io/dockview/docs/).
|
|
52
37
|
|
|
53
38
|
```
|
|
54
39
|
npm install --save dockview
|
|
55
40
|
```
|
|
56
41
|
|
|
57
|
-
Within your project you must import or reference the stylesheet at `dockview/dist/styles/dockview.css
|
|
42
|
+
Within your project you must import or reference the stylesheet at `dockview/dist/styles/dockview.css` and attach a theme.
|
|
58
43
|
|
|
59
44
|
```css
|
|
60
45
|
@import '~dockview/dist/styles/dockview.css';
|
|
@@ -65,179 +50,3 @@ You should also attach a dockview theme to an element containing your components
|
|
|
65
50
|
```html
|
|
66
51
|
<body classname="dockview-theme-dark"></body>
|
|
67
52
|
```
|
|
68
|
-
|
|
69
|
-
Demonstrated below is a high level example of a `DockviewReact` component. You can follow a similar pattern for `GridviewReact`, `SplitviewReact` and `PaneviewReact` components too, see examples for more.
|
|
70
|
-
|
|
71
|
-
```tsx
|
|
72
|
-
import {
|
|
73
|
-
DockviewReact,
|
|
74
|
-
DockviewReadyEvent,
|
|
75
|
-
PanelCollection,
|
|
76
|
-
IDockviewPanelProps,
|
|
77
|
-
IDockviewPanelHeaderProps,
|
|
78
|
-
} from 'dockview';
|
|
79
|
-
|
|
80
|
-
const components: PanelCollection<IDockviewPanelProps> = {
|
|
81
|
-
default: (props: IDockviewPanelProps<{ someProps: string }>) => {
|
|
82
|
-
return <div>{props.params.someProps}</div>;
|
|
83
|
-
},
|
|
84
|
-
};
|
|
85
|
-
|
|
86
|
-
const headers: PanelCollection<IDockviewPanelHeaderProps> = {
|
|
87
|
-
customTab: (props: IDockviewPanelHeaderProps) => {
|
|
88
|
-
return (
|
|
89
|
-
<div>
|
|
90
|
-
<span>{props.api.title}</span>
|
|
91
|
-
<span onClick={() => props.api.close()}>{'[x]'}</span>
|
|
92
|
-
</div>
|
|
93
|
-
);
|
|
94
|
-
},
|
|
95
|
-
};
|
|
96
|
-
|
|
97
|
-
const Component = () => {
|
|
98
|
-
const onReady = (event: DockviewReadyEvent) => {
|
|
99
|
-
event.api.addPanel({
|
|
100
|
-
id: 'panel1',
|
|
101
|
-
component: 'default',
|
|
102
|
-
tabComponent: 'customTab', // optional custom header
|
|
103
|
-
params: {
|
|
104
|
-
someProps: 'Hello',
|
|
105
|
-
},
|
|
106
|
-
});
|
|
107
|
-
event.api.addPanel({
|
|
108
|
-
id: 'panel2',
|
|
109
|
-
component: 'default',
|
|
110
|
-
params: {
|
|
111
|
-
someProps: 'World',
|
|
112
|
-
},
|
|
113
|
-
position: { referencePanel: 'panel1', direction: 'below' },
|
|
114
|
-
});
|
|
115
|
-
};
|
|
116
|
-
|
|
117
|
-
return (
|
|
118
|
-
<DockviewReact
|
|
119
|
-
components={components}
|
|
120
|
-
tabComponents={headers} // optional headers renderer
|
|
121
|
-
onReady={onReady}
|
|
122
|
-
/>
|
|
123
|
-
);
|
|
124
|
-
};
|
|
125
|
-
```
|
|
126
|
-
|
|
127
|
-
Specifically for `DockviewReact` there exists higher-order components to encapsulate both the tab and contents into one logical component for the user making state sharing between the two simple, which is an optional feature.
|
|
128
|
-
|
|
129
|
-
```tsx
|
|
130
|
-
const components: PanelCollection<IDockviewPanelProps> = {
|
|
131
|
-
default: (props: IDockviewPanelProps<{ someProps: string }>) => {
|
|
132
|
-
return <div>{props.params.someProps}</div>;
|
|
133
|
-
},
|
|
134
|
-
fancy: (props: IDockviewPanelProps) => {
|
|
135
|
-
return (
|
|
136
|
-
<DockviewComponents.Panel>
|
|
137
|
-
<DockviewComponents.Tab>
|
|
138
|
-
<div>
|
|
139
|
-
<span>{props.api.title}</span>
|
|
140
|
-
<span onClick={() => props.api.close()}>{'Close'}</span>
|
|
141
|
-
</div>
|
|
142
|
-
</DockviewComponents.Tab>
|
|
143
|
-
<DockviewComponents.Content>
|
|
144
|
-
<div>{'Hello world'}</div>
|
|
145
|
-
</DockviewComponents.Content>
|
|
146
|
-
</DockviewComponents.Panel>
|
|
147
|
-
);
|
|
148
|
-
},
|
|
149
|
-
};
|
|
150
|
-
```
|
|
151
|
-
|
|
152
|
-
## Sandbox examples
|
|
153
|
-
|
|
154
|
-
- [Dockview](https://codesandbox.io/s/simple-dockview-t6491)
|
|
155
|
-
- [Gridview](https://codesandbox.io/s/simple-gridview-jrp0n)
|
|
156
|
-
- [Splitview](https://codesandbox.io/s/simple-splitview-l53nn)
|
|
157
|
-
- [Paneview](https://codesandbox.io/s/simple-paneview-v8qvb)
|
|
158
|
-
|
|
159
|
-
## Serializated layouts
|
|
160
|
-
|
|
161
|
-
All view components support the methods `toJSON()`, `fromJSON(...)` and `onDidLayoutChange()`.
|
|
162
|
-
|
|
163
|
-
See example [here](https://codesandbox.io/s/workspace-saving-example-euo5d).
|
|
164
|
-
|
|
165
|
-
## Drag and drop
|
|
166
|
-
|
|
167
|
-
Both `DockviewReact` and `PaneviewReact` support drag and drop functionality out of the box.
|
|
168
|
-
|
|
169
|
-
- `DockviewReact` allows tabs to be repositioned using drag and drop.
|
|
170
|
-
- `PaneviewReact` allows the repositioning of views using drag and drop on the header section.
|
|
171
|
-
|
|
172
|
-
You can use the utility methods `getPaneData` and `getPanelData` to manually extract the data transfer metadata associated with an active drag and drop event for either of the above components.
|
|
173
|
-
|
|
174
|
-
```tsx
|
|
175
|
-
import {
|
|
176
|
-
getPaneData,
|
|
177
|
-
getPanelData,
|
|
178
|
-
PanelTransfer,
|
|
179
|
-
PaneTransfer,
|
|
180
|
-
} from 'dockview';
|
|
181
|
-
|
|
182
|
-
const panelData: PanelTransfer | undefined = getPanelData();
|
|
183
|
-
|
|
184
|
-
if (panelData) {
|
|
185
|
-
// DockviewReact: data transfer metadata associated with the active drag and drop event
|
|
186
|
-
const { viewId, groupId, panelId } = panelData; // deconstructed object
|
|
187
|
-
}
|
|
188
|
-
|
|
189
|
-
const paneData: PaneTransfer | undefined = getPaneData();
|
|
190
|
-
|
|
191
|
-
if (paneData) {
|
|
192
|
-
// PaneviewReact: data transfer metadata associated with the active drag and drop event
|
|
193
|
-
const { viewId, paneId } = paneData; // deconstructed object
|
|
194
|
-
}
|
|
195
|
-
```
|
|
196
|
-
|
|
197
|
-
You can also intercept custom drag and drop events allowing dockview components to interact with and react to external drag events. `PaneviewReact` supports the method `onDidDrop` and `DockviewReact` supports the methods `onDidDrop` and `showDndOverlay`.
|
|
198
|
-
|
|
199
|
-
## Theming
|
|
200
|
-
|
|
201
|
-
The theme can be customized using the below set of CSS properties. You can find the built in themes [here](https://github.com/mathuo/dockview/blob/master/packages/dockview/src/theme.scss) which could be used as an example to extend upon or build your own theme.
|
|
202
|
-
|
|
203
|
-
| CSS Property | Description |
|
|
204
|
-
| ---------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------ |
|
|
205
|
-
| **General** |
|
|
206
|
-
| --dv-active-sash-color | The background color a dividing sash during an interaction |
|
|
207
|
-
| --dv-separator-border | The color of the seperator between panels |
|
|
208
|
-
| **Paneview** |
|
|
209
|
-
| --dv-paneview-header-border-color | - |
|
|
210
|
-
| --dv-paneview-active-outline-color | The primary accent color, used for example to highlight the active panel in Paneviews |
|
|
211
|
-
| **Dockview -> Dragging** |
|
|
212
|
-
| --dv-drag-over-background-color | The overlay color applied to a group when a moving tab is dragged over |
|
|
213
|
-
| **Dockview -> Tabs container** |
|
|
214
|
-
| --dv-tabs-and-actions-container-font-size | - |
|
|
215
|
-
| --dv-tabs-and-actions-container-height | Default tab height |
|
|
216
|
-
| --dv-tabs-and-actions-container-background-color | - |
|
|
217
|
-
| --dv-tabs-container-scrollbar-color | - |
|
|
218
|
-
| --dv-group-view-background-color | - |
|
|
219
|
-
| **Dockview -> Tabs** | (see [dockviewComponent.scss](https://github.com/mathuo/dockview/blob/master/packages/dockview/src/dockview/dockviewComponent.scss)) |
|
|
220
|
-
| --dv-activegroup-visiblepanel-tab-background-color | The background color of the tab for the visible panel in the active group |
|
|
221
|
-
| --dv-activegroup-hiddenpanel-tab-background-color | The background color of the tab for the hidden panel/s in the active group |
|
|
222
|
-
| --dv-inactivegroup-visiblepanel-tab-background-color | The background color of the tab for the visible panel in groups other than the active group |
|
|
223
|
-
| --dv-inactivegroup-hiddenpanel-tab-background-color | The background color of the tab for the hidden panel/s in groups other than the active group |
|
|
224
|
-
| --dv-activegroup-visiblepanel-tab-color | The color of the tab for the visible panel in the active group |
|
|
225
|
-
| --dv-activegroup-hiddenpanel-tab-color | The color of the tab for the hidden panel/s in the active group |
|
|
226
|
-
| --dv-inactivegroup-visiblepanel-tab-color | The color of the tab for the visible panel in groups other than the active group |
|
|
227
|
-
| --dv-inactivegroup-hiddenpanel-tab-color | The color of the tab for the hidden panel/s in groups other than the active group |
|
|
228
|
-
| --dv-tab-divider-color | - |
|
|
229
|
-
| --dv-tab-close-icon | Default tab close icon |
|
|
230
|
-
|
|
231
|
-
## Performance
|
|
232
|
-
|
|
233
|
-
Consider using React.lazy(...) to defer the importing of your panels until they are required. This has the potential to reduce the initial import cost when your application starts.
|
|
234
|
-
|
|
235
|
-
## FAQ
|
|
236
|
-
|
|
237
|
-
**Q: Can I use this library without React?**
|
|
238
|
-
|
|
239
|
-
**A:** In theory, yes. The library is written in plain-old JS and the parts written in ReactJS are merely wrappers around the plain-old JS components. Currently everything is published as one package though so maybe that's something to change in the future.
|
|
240
|
-
|
|
241
|
-
**Q: Can I use this library with AngularJS/Vue.js or any other arbitrarily named JavaScript library/framework?**
|
|
242
|
-
|
|
243
|
-
**A:** Yes but with some extra work. Dockview is written in plain-old JS so you can either interact directly with the plain-old JS components or create a wrapper using your prefered library/framework. The React wrapper may give some ideas on how this wrapper implementation could be done for other libraries/frameworks. Maybe that's something to change in the future.
|
|
@@ -21,6 +21,7 @@ export interface CommonApi<T = any> {
|
|
|
21
21
|
layout(width: number, height: number): void;
|
|
22
22
|
fromJSON(data: T): void;
|
|
23
23
|
toJSON(): T;
|
|
24
|
+
clear(): void;
|
|
24
25
|
}
|
|
25
26
|
export declare class SplitviewApi implements CommonApi<SerializedSplitview> {
|
|
26
27
|
private readonly component;
|
|
@@ -45,6 +46,7 @@ export declare class SplitviewApi implements CommonApi<SerializedSplitview> {
|
|
|
45
46
|
movePanel(from: number, to: number): void;
|
|
46
47
|
fromJSON(data: SerializedSplitview): void;
|
|
47
48
|
toJSON(): SerializedSplitview;
|
|
49
|
+
clear(): void;
|
|
48
50
|
}
|
|
49
51
|
export declare class PaneviewApi implements CommonApi<SerializedPaneview> {
|
|
50
52
|
private readonly component;
|
|
@@ -67,6 +69,7 @@ export declare class PaneviewApi implements CommonApi<SerializedPaneview> {
|
|
|
67
69
|
addPanel(options: AddPaneviewComponentOptions): IPaneviewPanel;
|
|
68
70
|
fromJSON(data: SerializedPaneview): void;
|
|
69
71
|
toJSON(): SerializedPaneview;
|
|
72
|
+
clear(): void;
|
|
70
73
|
}
|
|
71
74
|
export declare class GridviewApi implements CommonApi<SerializedGridview> {
|
|
72
75
|
private readonly component;
|
|
@@ -97,6 +100,7 @@ export declare class GridviewApi implements CommonApi<SerializedGridview> {
|
|
|
97
100
|
getPanel(id: string): IGridviewPanel | undefined;
|
|
98
101
|
fromJSON(data: SerializedGridview): void;
|
|
99
102
|
toJSON(): SerializedGridview;
|
|
103
|
+
clear(): void;
|
|
100
104
|
}
|
|
101
105
|
export declare class DockviewApi implements CommonApi<SerializedDockview> {
|
|
102
106
|
private readonly component;
|
|
@@ -136,4 +140,5 @@ export declare class DockviewApi implements CommonApi<SerializedDockview> {
|
|
|
136
140
|
getGroup(id: string): GroupPanel | undefined;
|
|
137
141
|
fromJSON(data: SerializedDockview): void;
|
|
138
142
|
toJSON(): SerializedDockview;
|
|
143
|
+
clear(): void;
|
|
139
144
|
}
|
|
@@ -121,6 +121,9 @@ var SplitviewApi = /** @class */ (function () {
|
|
|
121
121
|
SplitviewApi.prototype.toJSON = function () {
|
|
122
122
|
return this.component.toJSON();
|
|
123
123
|
};
|
|
124
|
+
SplitviewApi.prototype.clear = function () {
|
|
125
|
+
this.component.clear();
|
|
126
|
+
};
|
|
124
127
|
return SplitviewApi;
|
|
125
128
|
}());
|
|
126
129
|
exports.SplitviewApi = SplitviewApi;
|
|
@@ -231,6 +234,9 @@ var PaneviewApi = /** @class */ (function () {
|
|
|
231
234
|
PaneviewApi.prototype.toJSON = function () {
|
|
232
235
|
return this.component.toJSON();
|
|
233
236
|
};
|
|
237
|
+
PaneviewApi.prototype.clear = function () {
|
|
238
|
+
this.component.clear();
|
|
239
|
+
};
|
|
234
240
|
return PaneviewApi;
|
|
235
241
|
}());
|
|
236
242
|
exports.PaneviewApi = PaneviewApi;
|
|
@@ -357,6 +363,9 @@ var GridviewApi = /** @class */ (function () {
|
|
|
357
363
|
GridviewApi.prototype.toJSON = function () {
|
|
358
364
|
return this.component.toJSON();
|
|
359
365
|
};
|
|
366
|
+
GridviewApi.prototype.clear = function () {
|
|
367
|
+
this.component.clear();
|
|
368
|
+
};
|
|
360
369
|
return GridviewApi;
|
|
361
370
|
}());
|
|
362
371
|
exports.GridviewApi = GridviewApi;
|
|
@@ -464,7 +473,7 @@ var DockviewApi = /** @class */ (function () {
|
|
|
464
473
|
});
|
|
465
474
|
Object.defineProperty(DockviewApi.prototype, "onDidLayoutFromJSON", {
|
|
466
475
|
get: function () {
|
|
467
|
-
return this.component.
|
|
476
|
+
return this.component.onDidLayoutFromJSON;
|
|
468
477
|
},
|
|
469
478
|
enumerable: false,
|
|
470
479
|
configurable: true
|
|
@@ -554,6 +563,9 @@ var DockviewApi = /** @class */ (function () {
|
|
|
554
563
|
DockviewApi.prototype.toJSON = function () {
|
|
555
564
|
return this.component.toJSON();
|
|
556
565
|
};
|
|
566
|
+
DockviewApi.prototype.clear = function () {
|
|
567
|
+
this.component.clear();
|
|
568
|
+
};
|
|
557
569
|
return DockviewApi;
|
|
558
570
|
}());
|
|
559
571
|
exports.DockviewApi = DockviewApi;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"component.api.js","sourceRoot":"","sources":["../../../src/api/component.api.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAiCA,oCAA2C;
|
|
1
|
+
{"version":3,"file":"component.api.js","sourceRoot":"","sources":["../../../src/api/component.api.ts"],"names":[],"mappings":"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"}
|
|
@@ -7,7 +7,7 @@ export declare enum Position {
|
|
|
7
7
|
Right = "Right",
|
|
8
8
|
Center = "Center"
|
|
9
9
|
}
|
|
10
|
-
declare type Quadrant = 'top' | 'bottom' | 'left' | 'right';
|
|
10
|
+
export declare type Quadrant = 'top' | 'bottom' | 'left' | 'right';
|
|
11
11
|
export interface DroptargetEvent {
|
|
12
12
|
position: Position;
|
|
13
13
|
nativeEvent: DragEvent;
|
|
@@ -35,4 +35,3 @@ export declare class Droptarget extends CompositeDisposable {
|
|
|
35
35
|
private calculateQuadrant;
|
|
36
36
|
private removeDropTarget;
|
|
37
37
|
}
|
|
38
|
-
export {};
|
|
@@ -1,17 +1,5 @@
|
|
|
1
|
-
import { IGridView, ISerializedLeafNode, IViewDeserializer } from '../gridview/gridview';
|
|
2
1
|
import { GroupviewPanelState, IDockviewPanel } from '../groupview/groupPanel';
|
|
3
|
-
import { GroupPanelViewState } from '../groupview/groupview';
|
|
4
2
|
import { GroupPanel } from '../groupview/groupviewPanel';
|
|
5
|
-
import { DockviewComponent } from './dockviewComponent';
|
|
6
3
|
export interface IPanelDeserializer {
|
|
7
4
|
fromJSON(panelData: GroupviewPanelState, group: GroupPanel): IDockviewPanel;
|
|
8
5
|
}
|
|
9
|
-
export interface PanelDeserializerOptions {
|
|
10
|
-
createPanel: (id: string, group: GroupPanel) => IDockviewPanel;
|
|
11
|
-
}
|
|
12
|
-
export declare class DefaultDeserializer implements IViewDeserializer {
|
|
13
|
-
private readonly layout;
|
|
14
|
-
private panelDeserializer;
|
|
15
|
-
constructor(layout: DockviewComponent, panelDeserializer: PanelDeserializerOptions);
|
|
16
|
-
fromJSON(node: ISerializedLeafNode<GroupPanelViewState>): IGridView;
|
|
17
|
-
}
|
|
@@ -1,55 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __values = (this && this.__values) || function(o) {
|
|
3
|
-
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
|
|
4
|
-
if (m) return m.call(o);
|
|
5
|
-
if (o && typeof o.length === "number") return {
|
|
6
|
-
next: function () {
|
|
7
|
-
if (o && i >= o.length) o = void 0;
|
|
8
|
-
return { value: o && o[i++], done: !o };
|
|
9
|
-
}
|
|
10
|
-
};
|
|
11
|
-
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
|
|
12
|
-
};
|
|
13
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
-
exports.DefaultDeserializer = void 0;
|
|
15
|
-
var DefaultDeserializer = /** @class */ (function () {
|
|
16
|
-
function DefaultDeserializer(layout, panelDeserializer) {
|
|
17
|
-
this.layout = layout;
|
|
18
|
-
this.panelDeserializer = panelDeserializer;
|
|
19
|
-
}
|
|
20
|
-
DefaultDeserializer.prototype.fromJSON = function (node) {
|
|
21
|
-
var e_1, _a;
|
|
22
|
-
var data = node.data;
|
|
23
|
-
var children = data.views;
|
|
24
|
-
var active = data.activeView;
|
|
25
|
-
var group = this.layout.createGroup({
|
|
26
|
-
id: data.id,
|
|
27
|
-
locked: !!data.locked,
|
|
28
|
-
hideHeader: !!data.hideHeader,
|
|
29
|
-
});
|
|
30
|
-
try {
|
|
31
|
-
for (var children_1 = __values(children), children_1_1 = children_1.next(); !children_1_1.done; children_1_1 = children_1.next()) {
|
|
32
|
-
var child = children_1_1.value;
|
|
33
|
-
var panel = this.panelDeserializer.createPanel(child, group);
|
|
34
|
-
var isActive = typeof active === 'string' && active === panel.id;
|
|
35
|
-
group.model.openPanel(panel, {
|
|
36
|
-
skipSetActive: !isActive,
|
|
37
|
-
});
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
41
|
-
finally {
|
|
42
|
-
try {
|
|
43
|
-
if (children_1_1 && !children_1_1.done && (_a = children_1.return)) _a.call(children_1);
|
|
44
|
-
}
|
|
45
|
-
finally { if (e_1) throw e_1.error; }
|
|
46
|
-
}
|
|
47
|
-
if (!group.activePanel && group.panels.length > 0) {
|
|
48
|
-
group.model.openPanel(group.panels[group.panels.length - 1]);
|
|
49
|
-
}
|
|
50
|
-
return group;
|
|
51
|
-
};
|
|
52
|
-
return DefaultDeserializer;
|
|
53
|
-
}());
|
|
54
|
-
exports.DefaultDeserializer = DefaultDeserializer;
|
|
55
3
|
//# sourceMappingURL=deserializer.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"deserializer.js","sourceRoot":"","sources":["../../../src/dockview/deserializer.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"deserializer.js","sourceRoot":"","sources":["../../../src/dockview/deserializer.ts"],"names":[],"mappings":""}
|
|
@@ -37,6 +37,7 @@ export interface SerializedDockview {
|
|
|
37
37
|
export declare type DockviewComponentUpdateOptions = Pick<DockviewComponentOptions, 'orientation' | 'components' | 'frameworkComponents' | 'tabComponents' | 'frameworkTabComponents' | 'showDndOverlay' | 'watermarkFrameworkComponent'>;
|
|
38
38
|
export interface DockviewDropEvent extends GroupviewDropEvent {
|
|
39
39
|
api: DockviewApi;
|
|
40
|
+
group: GroupPanel;
|
|
40
41
|
}
|
|
41
42
|
export interface IDockviewComponent extends IBaseGrid<GroupPanel> {
|
|
42
43
|
readonly activePanel: IDockviewPanel | undefined;
|
|
@@ -53,11 +54,9 @@ export interface IDockviewComponent extends IBaseGrid<GroupPanel> {
|
|
|
53
54
|
addPanel(options: AddPanelOptions): IDockviewPanel;
|
|
54
55
|
removePanel(panel: IDockviewPanel): void;
|
|
55
56
|
getGroupPanel: (id: string) => IDockviewPanel | undefined;
|
|
56
|
-
fireMouseEvent(event: LayoutMouseEvent): void;
|
|
57
57
|
createWatermarkComponent(): IWatermarkRenderer;
|
|
58
58
|
addEmptyGroup(options?: AddGroupOptions): void;
|
|
59
59
|
closeAllGroups(): void;
|
|
60
|
-
onTabInteractionEvent: Event<LayoutMouseEvent>;
|
|
61
60
|
onTabContextMenu: Event<TabContextMenuEvent>;
|
|
62
61
|
moveToNext(options?: MovementOptions): void;
|
|
63
62
|
moveToPrevious(options?: MovementOptions): void;
|
|
@@ -67,15 +66,13 @@ export interface IDockviewComponent extends IBaseGrid<GroupPanel> {
|
|
|
67
66
|
fromJSON(data: SerializedDockview): void;
|
|
68
67
|
readonly onDidRemovePanel: Event<IDockviewPanel>;
|
|
69
68
|
readonly onDidAddPanel: Event<IDockviewPanel>;
|
|
70
|
-
readonly
|
|
69
|
+
readonly onDidLayoutFromJSON: Event<void>;
|
|
71
70
|
readonly onDidActivePanelChange: Event<IDockviewPanel | undefined>;
|
|
72
71
|
}
|
|
73
72
|
export declare class DockviewComponent extends BaseGrid<GroupPanel> implements IDockviewComponent {
|
|
74
73
|
private _deserializer;
|
|
75
74
|
private _api;
|
|
76
75
|
private _options;
|
|
77
|
-
private readonly _onTabInteractionEvent;
|
|
78
|
-
readonly onTabInteractionEvent: Event<LayoutMouseEvent>;
|
|
79
76
|
private readonly _onTabContextMenu;
|
|
80
77
|
readonly onTabContextMenu: Event<TabContextMenuEvent>;
|
|
81
78
|
private readonly _onDidDrop;
|
|
@@ -84,8 +81,8 @@ export declare class DockviewComponent extends BaseGrid<GroupPanel> implements I
|
|
|
84
81
|
readonly onDidRemovePanel: Event<IDockviewPanel>;
|
|
85
82
|
private readonly _onDidAddPanel;
|
|
86
83
|
readonly onDidAddPanel: Event<IDockviewPanel>;
|
|
87
|
-
private readonly
|
|
88
|
-
readonly
|
|
84
|
+
private readonly _onDidLayoutFromJSON;
|
|
85
|
+
readonly onDidLayoutFromJSON: Event<void>;
|
|
89
86
|
private readonly _onDidActivePanelChange;
|
|
90
87
|
readonly onDidActivePanelChange: Event<IDockviewPanel | undefined>;
|
|
91
88
|
get totalPanels(): number;
|
|
@@ -110,6 +107,7 @@ export declare class DockviewComponent extends BaseGrid<GroupPanel> implements I
|
|
|
110
107
|
*/
|
|
111
108
|
toJSON(): SerializedDockview;
|
|
112
109
|
fromJSON(data: SerializedDockview): void;
|
|
110
|
+
clear(): void;
|
|
113
111
|
closeAllGroups(): void;
|
|
114
112
|
fireMouseEvent(event: LayoutMouseEvent): void;
|
|
115
113
|
addPanel(options: AddPanelOptions): IDockviewPanel;
|