Skip to content

Commit

Permalink
feat: persist custom popout group urls
Browse files Browse the repository at this point in the history
  • Loading branch information
mathuo committed Nov 15, 2024
1 parent 24cc974 commit 461c30d
Show file tree
Hide file tree
Showing 3 changed files with 150 additions and 10 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -5191,6 +5191,126 @@ describe('dockviewComponent', () => {
expect(dockview.groups.length).toBe(2);
expect(dockview.panels.length).toBe(3);
});

test('persistance with custom url', async () => {
const container = document.createElement('div');

window.open = () => setupMockWindow();

const dockview = new DockviewComponent(container, {
createComponent(options) {
switch (options.name) {
case 'default':
return new PanelContentPartTest(
options.id,
options.name
);
default:
throw new Error(`unsupported`);
}
},
});

dockview.layout(1000, 500);

dockview.addPanel({
id: 'panel_1',
component: 'default',
});

const panel2 = dockview.addPanel({
id: 'panel_2',
component: 'default',
position: { direction: 'right' },
});

const panel3 = dockview.addPanel({
id: 'panel_3',
component: 'default',
position: { direction: 'right' },
});

expect(await dockview.addPopoutGroup(panel2.group)).toBeTruthy();
expect(
await dockview.addPopoutGroup(panel3.group, {
popoutUrl: '/custom.html',
})
).toBeTruthy();

const state = dockview.toJSON();

expect(state.popoutGroups).toEqual([
{
data: {
activeView: 'panel_2',
id: '4',
views: ['panel_2'],
},
gridReferenceGroup: '2',
position: {
height: 2001,
left: undefined,
top: undefined,
width: 1001,
},
url: undefined,
},
{
data: {
activeView: 'panel_3',
id: '5',
views: ['panel_3'],
},
gridReferenceGroup: '3',
position: {
height: 2001,
left: undefined,
top: undefined,
width: 1001,
},
url: '/custom.html',
},
]);

dockview.clear();
expect(dockview.groups.length).toBe(0);

dockview.fromJSON(state);
await new Promise((resolve) => setTimeout(resolve, 0)); // popout views are completed as a promise so must complete microtask-queue

expect(dockview.toJSON().popoutGroups).toEqual([
{
data: {
activeView: 'panel_2',
id: '4',
views: ['panel_2'],
},
gridReferenceGroup: '2',
position: {
height: 2001,
left: undefined,
top: undefined,
width: 1001,
},
url: undefined,
},
{
data: {
activeView: 'panel_3',
id: '5',
views: ['panel_3'],
},
gridReferenceGroup: '3',
position: {
height: 2001,
left: undefined,
top: undefined,
width: 1001,
},
url: '/custom.html',
},
]);
});
});

describe('maximized group', () => {
Expand Down
38 changes: 29 additions & 9 deletions packages/dockview-core/src/dockview/dockviewComponent.ts
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,22 @@ function moveGroupWithoutDestroying(options: {
});
}

export interface DockviewPopoutGroupOptions {
/**
* The position of the popout group
*/
position?: Box;
/**
* The same-origin path at which the popout window will be created
*
* Defaults to `/popout.html` if not provided
*/
popoutUrl?: string;
onDidOpen?: (event: { id: string; window: Window }) => void;
onWillClose?: (event: { id: string; window: Window }) => void;
overridePopoutGroup?: DockviewGroupPanel;
}

export interface PanelReference {
update: (event: { params: { [key: string]: any } }) => void;
remove: () => void;
Expand All @@ -110,6 +126,7 @@ export interface SerializedFloatingGroup {

export interface SerializedPopoutGroup {
data: GroupPanelViewState;
url?: string;
gridReferenceGroup?: string;
position: Box | null;
}
Expand Down Expand Up @@ -566,13 +583,7 @@ export class DockviewComponent

addPopoutGroup(
itemToPopout: DockviewPanel | DockviewGroupPanel,
options?: {
position?: Box;
popoutUrl?: string;
onDidOpen?: (event: { id: string; window: Window }) => void;
onWillClose?: (event: { id: string; window: Window }) => void;
overridePopoutGroup?: DockviewGroupPanel;
}
options?: DockviewPopoutGroupOptions
): Promise<boolean> {
if (
itemToPopout instanceof DockviewPanel &&
Expand Down Expand Up @@ -608,7 +619,10 @@ export class DockviewComponent
`${this.id}-${groupId}`, // unique id
theme ?? '',
{
url: options?.popoutUrl ?? '/popout.html',
url:
options?.popoutUrl ??
this.options?.popoutUrl ??
'/popout.html',
left: window.screenX + box.left,
top: window.screenY + box.top,
width: box.width,
Expand Down Expand Up @@ -709,6 +723,7 @@ export class DockviewComponent
group.model.location = {
type: 'popout',
getWindow: () => _window.window!,
popoutUrl: options?.popoutUrl,
};

if (
Expand Down Expand Up @@ -1198,6 +1213,10 @@ export class DockviewComponent
data: group.popoutGroup.toJSON() as GroupPanelViewState,
gridReferenceGroup: group.referenceGroup,
position: group.window.dimensions(),
url:
group.popoutGroup.api.location.type === 'popout'
? group.popoutGroup.api.location.popoutUrl
: undefined,
};
}
);
Expand Down Expand Up @@ -1321,7 +1340,7 @@ export class DockviewComponent
const serializedPopoutGroups = data.popoutGroups ?? [];

for (const serializedPopoutGroup of serializedPopoutGroups) {
const { data, position, gridReferenceGroup } =
const { data, position, gridReferenceGroup, url } =
serializedPopoutGroup;

const group = createGroupFromSerializedState(data);
Expand All @@ -1335,6 +1354,7 @@ export class DockviewComponent
overridePopoutGroup: gridReferenceGroup
? group
: undefined,
popoutUrl: url,
}
);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -196,7 +196,7 @@ export interface IDockviewGroupPanelModel extends IPanel {
export type DockviewGroupLocation =
| { type: 'grid' }
| { type: 'floating' }
| { type: 'popout'; getWindow: () => Window };
| { type: 'popout'; getWindow: () => Window; popoutUrl?: string };

export class WillShowOverlayLocationEvent implements IDockviewEvent {
get kind(): DockviewGroupDropLocation {
Expand Down

0 comments on commit 461c30d

Please sign in to comment.