-
1
-
2
-
3
-
4
-
5
-
6
-
7
-
8
-
9
-
10
-
11
-
12
-
13
-
14
-
15
-
16
-
17
-
18
-
19
-
20
-
21
-
22
-
23
-
24
-
25
-
26
-
27
-
28
-
29
-
30
-
31
-
32
-
33
-
34
-
35
-
36
-
37
-
38
-
39
-
40
-
41
-
42
-
43
-
44
-
45
-
46
-
47
-
48
-
49
-
50
-
51
-
52
-
53
-
54
-
55
-
56
-
57
-
58
-
59
-
60
-
61
-
62
-
63
-
64
-
65
-
66
-
67
-
68
-
69
-
70
-
71
-
72
-
73
-
74
-
75
-
76
-
77
-
78
-
79
-
80
-
81
-
82
-
83
-
84
-
85
-
86
-
87
-
88
-
89
-
90
-
91
-
92
-
93
-
94
-
95
-
96
-
97
-
98
-
99
-
100
-
101
-
102
-
103
-
104
-
105
-
106
-
107
-
108
-
109
-
110
-
111
import { attr, el, className, svg } from "../../dom";
import { effect } from "../../signal";
import { iconButton } from "../iconButton/iconButton";
export const styles = /* css */ `
.fp-root {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-color: var(--bg);
color: var(--fg);
}
.fp-close {
position: absolute;
right: 8px;
top: 8px;
background-color: inherit;
border-radius: var(--panel-radii);
z-index: calc(var(--z-index) + 5);
opacity: 0.5;
}
.fp-close:hover, .fp-close:focus-within {
opacity: 1;
}
.fp-close-icon {
font-size: calc(var(--font-size) * 1.1);
}
.fp-body {
max-width: 100%;
max-height: 100%;
padding: 16px;
box-sizing: border-box;
overflow-y: auto;
}
`;
interface FullscreenPanelProps {
body: Parameters<typeof el>[2];
onClose?(): void;
}
export function fullscreenPanel({
body,
onClose,
}: FullscreenPanelProps): HTMLElement {
effect(() => {
if (!onClose) {
return;
}
const onEsc = (ev: KeyboardEvent) => {
if (ev.key !== "Escape") {
return;
}
ev.preventDefault();
ev.stopPropagation();
onClose();
};
document.addEventListener("keydown", onEsc);
return () => {
document.removeEventListener("keydown", onEsc);
};
});
return el(
"div",
[className("fp-root")],
[
onClose
? el(
"div",
[className("fp-close")],
[
iconButton({
title: "Close",
icon: svg(
"svg",
[
className("fp-close-icon"),
attr("viewBox", "0 0 10 10"),
attr("fill", "none"),
attr("stroke", "currentColor"),
],
[svg("path", [attr("d", "M2,2 L8,8 M8,2 L2,8")])],
),
onClick() {
onClose();
},
}),
],
)
: null,
el("div", [className("fp-body")], body),
],
);
}