summaryrefslogtreecommitdiff
path: root/packages/client/src/scripts/popout.ts
blob: 580031d0a382ec688dc2f21443b9436e2f9ed1ca (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
import * as config from '@/config';
import { appendQuery } from './url';

export function popout(path: string, w?: HTMLElement) {
	let url = path.startsWith('http://') || path.startsWith('https://') ? path : config.url + path;
	url = appendQuery(url, 'zen');
	if (w) {
		const position = w.getBoundingClientRect();
		const width = parseInt(getComputedStyle(w, '').width, 10);
		const height = parseInt(getComputedStyle(w, '').height, 10);
		const x = window.screenX + position.left;
		const y = window.screenY + position.top;
		window.open(url, url,
			`width=${width}, height=${height}, top=${y}, left=${x}`);
	} else {
		const width = 400;
		const height = 500;
		const x = window.top.outerHeight / 2 + window.top.screenY - (height / 2);
		const y = window.top.outerWidth / 2 + window.top.screenX - (width / 2);
		window.open(url, url,
			`width=${width}, height=${height}, top=${x}, left=${y}`);
	}
}