-
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
---
// SPDX-FileCopyrightText: 2024 Shota FUJI <pockawoooh@gmail.com>
// SPDX-License-Identifier: AGPL-3.0-only
const { defaultOpened = true, title } = Astro.props;
---
<style>
.wrapper {
display: block;
margin: var(--space-px-6) 0;
}
.collapsible {
display: block;
min-width: 0;
width: 100%;
}
.toggle {
display: flex;
justify-content: space-between;
align-items: center;
min-width: 0;
width: 100%;
border: 1px solid transparent;
padding: var(--space-px-4) var(--space-px-5);
font-size: var(--font-sm);
font-weight: bold;
border-radius: 4px;
cursor: pointer;
}
.toggle:hover {
background-color: oklch(var(--color-fg) / 5%);
}
.toggle:focus-visible {
border-color: oklch(var(--color-border) / var(--alpha-border-strong));
}
.toggle-indicator::before {
content: "+";
}
.collapsible[open] .toggle-indicator::before {
content: "-";
}
.list {
display: flex;
flex-direction: column;
padding-inline-start: var(--space-px-6);
}
</style>
<li class="wrapper">
<details class="collapsible" open={defaultOpened}>
<summary class="toggle">
<span>{title}</span>
<span class="toggle-indicator" />
</summary>
<ul class="list">
<slot />
</ul>
</details>
</li>