@placeholderco/placeholder-ui 1.0.3 → 1.0.6
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/LICENSE +26 -26
- package/README.md +179 -179
- package/dist/display/Alert.svelte +179 -179
- package/dist/display/Avatar.svelte +166 -166
- package/dist/display/LinkCollection.svelte +161 -161
- package/dist/display/Paper.svelte +118 -118
- package/dist/form/Autocomplete.svelte +223 -191
- package/dist/form/Autocomplete.svelte.d.ts +3 -1
- package/dist/form/AutocompleteMulti.svelte +356 -0
- package/dist/form/AutocompleteMulti.svelte.d.ts +28 -0
- package/dist/form/Checkbox.svelte +201 -201
- package/dist/form/Chips.svelte +128 -128
- package/dist/form/ComboBox.svelte +158 -158
- package/dist/form/ComboBox.svelte.d.ts +1 -1
- package/dist/form/ComboBoxItemBuilder.svelte +460 -460
- package/dist/form/ComboBoxMulti.svelte +197 -197
- package/dist/form/ComboBoxMulti.svelte.d.ts +1 -1
- package/dist/form/CronBuilder.svelte +693 -693
- package/dist/form/DatePicker.svelte +672 -672
- package/dist/form/DateTimePicker.svelte +712 -712
- package/dist/form/FileInput.svelte +235 -235
- package/dist/form/FormGroup.svelte +68 -68
- package/dist/form/Number.svelte +238 -238
- package/dist/form/PasswordInput.svelte +252 -252
- package/dist/form/RadioGroup.svelte +210 -210
- package/dist/form/Rating.svelte +235 -235
- package/dist/form/SegmentedControl.svelte +149 -149
- package/dist/form/Select.svelte +590 -590
- package/dist/form/Select.svelte.d.ts +1 -1
- package/dist/form/SelectMulti.svelte +613 -613
- package/dist/form/SelectMulti.svelte.d.ts +1 -1
- package/dist/form/Slider.svelte +358 -358
- package/dist/form/Switch.svelte +147 -147
- package/dist/form/TextArea.svelte +148 -148
- package/dist/form/Textbox.svelte +228 -228
- package/dist/form/TimePicker.svelte +267 -267
- package/dist/icon/Icon.svelte +52 -52
- package/dist/icon/alert-octagon.svg +5 -5
- package/dist/icon/alert-triangle.svg +5 -5
- package/dist/icon/archive.svg +1 -1
- package/dist/icon/arrow-down.svg +1 -1
- package/dist/icon/arrow-left.svg +1 -1
- package/dist/icon/arrow-right.svg +1 -1
- package/dist/icon/arrow-up.svg +1 -1
- package/dist/icon/at.svg +1 -1
- package/dist/icon/bell.svg +1 -1
- package/dist/icon/bookmark.svg +1 -1
- package/dist/icon/calendar.svg +1 -1
- package/dist/icon/camera.svg +1 -1
- package/dist/icon/chart-bar.svg +1 -1
- package/dist/icon/chart-line.svg +1 -1
- package/dist/icon/chart-pie.svg +1 -1
- package/dist/icon/checkbox.svg +1 -1
- package/dist/icon/checklist.svg +1 -1
- package/dist/icon/circle-check.svg +1 -1
- package/dist/icon/circle-x.svg +1 -1
- package/dist/icon/clock.svg +1 -1
- package/dist/icon/credit-card.svg +1 -1
- package/dist/icon/dots-vertical.svg +1 -1
- package/dist/icon/dots.svg +1 -1
- package/dist/icon/external-link.svg +1 -1
- package/dist/icon/eye-off.svg +1 -1
- package/dist/icon/eye.svg +1 -1
- package/dist/icon/filter.svg +1 -1
- package/dist/icon/fingerprint.svg +1 -1
- package/dist/icon/flag.svg +1 -1
- package/dist/icon/heart.svg +1 -1
- package/dist/icon/home.svg +1 -1
- package/dist/icon/key.svg +1 -1
- package/dist/icon/list-check.svg +1 -1
- package/dist/icon/login.svg +1 -1
- package/dist/icon/logout.svg +1 -1
- package/dist/icon/map-pin.svg +1 -1
- package/dist/icon/maximize.svg +1 -1
- package/dist/icon/microphone.svg +1 -1
- package/dist/icon/minimize.svg +1 -1
- package/dist/icon/note.svg +1 -1
- package/dist/icon/player-pause.svg +1 -1
- package/dist/icon/printer.svg +1 -1
- package/dist/icon/qrcode.svg +1 -1
- package/dist/icon/send.svg +1 -1
- package/dist/icon/settings.svg +1 -1
- package/dist/icon/share.svg +1 -1
- package/dist/icon/shopping-cart.svg +1 -1
- package/dist/icon/sort-ascending.svg +1 -1
- package/dist/icon/sort-descending.svg +1 -1
- package/dist/icon/star.svg +1 -1
- package/dist/icon/tag.svg +1 -1
- package/dist/icon/trending-down.svg +1 -1
- package/dist/icon/trending-up.svg +1 -1
- package/dist/icon/upload.svg +1 -1
- package/dist/icon/volume-off.svg +1 -1
- package/dist/icon/volume.svg +1 -1
- package/dist/icon/world.svg +1 -1
- package/dist/icon/zoom-in.svg +1 -1
- package/dist/icon/zoom-out.svg +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.js +1 -0
- package/dist/layout/AppShell.svelte +169 -169
- package/dist/layout/CustomNavbar.svelte +61 -61
- package/dist/layout/Navbar.svelte +206 -206
- package/dist/layout/NavbarItemDisplay.svelte +29 -29
- package/dist/layout/Sidenav.svelte +712 -712
- package/dist/styles/components.css +199 -199
- package/dist/styles/dark.css +146 -146
- package/dist/styles/index.css +116 -116
- package/dist/styles/reset.css +110 -110
- package/dist/styles/semantic.css +86 -86
- package/dist/styles/tokens.css +203 -197
- package/dist/styles/utilities.css +523 -523
- package/dist/ui/Accordion.svelte +289 -289
- package/dist/ui/ActionIcon.svelte +76 -76
- package/dist/ui/Badge.svelte +329 -279
- package/dist/ui/Breadcrumbs.svelte +131 -131
- package/dist/ui/Button.svelte +432 -370
- package/dist/ui/ButtonVariant.d.ts +1 -1
- package/dist/ui/Dialog.svelte +307 -307
- package/dist/ui/Drawer.svelte +524 -524
- package/dist/ui/Dropdown.svelte +97 -97
- package/dist/ui/Dropzone.svelte +122 -122
- package/dist/ui/Link.svelte +32 -32
- package/dist/ui/Loader.svelte +70 -70
- package/dist/ui/LoadingOverlay.svelte +53 -53
- package/dist/ui/Pagination.svelte +135 -135
- package/dist/ui/Popover.svelte +225 -225
- package/dist/ui/Progress.svelte +191 -191
- package/dist/ui/RingProgress.svelte +141 -141
- package/dist/ui/Skeleton.svelte +85 -85
- package/dist/ui/Stepper.svelte +355 -355
- package/dist/ui/Table.svelte +345 -345
- package/dist/ui/Tabs.svelte +146 -146
- package/dist/ui/ThemeSwitcher.svelte +39 -39
- package/dist/ui/Timeline.svelte +225 -225
- package/dist/ui/Toaster.svelte +6 -6
- package/dist/ui/Tooltip.svelte +434 -434
- package/package.json +14 -14
package/dist/ui/Popover.svelte
CHANGED
|
@@ -1,225 +1,225 @@
|
|
|
1
|
-
<!-- drop down component that displays a button, when clicked on the children expand -->
|
|
2
|
-
<script lang="ts">
|
|
3
|
-
import type { Snippet } from "svelte";
|
|
4
|
-
import Button from "./Button.svelte";
|
|
5
|
-
import { clickOutside } from "../actions/ClickOutside.js";
|
|
6
|
-
|
|
7
|
-
type PopoverPosition = "top" | "bottom" | "left" | "right";
|
|
8
|
-
type PopoverTrigger = "click" | "hover";
|
|
9
|
-
|
|
10
|
-
interface Props {
|
|
11
|
-
show?: boolean;
|
|
12
|
-
label?: string | undefined;
|
|
13
|
-
position?: PopoverPosition;
|
|
14
|
-
class?: string;
|
|
15
|
-
cssWidth?: string;
|
|
16
|
-
button?: Snippet;
|
|
17
|
-
children?: Snippet;
|
|
18
|
-
trigger?: PopoverTrigger;
|
|
19
|
-
hoverDelay?: number;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
let {
|
|
23
|
-
show = $bindable(false),
|
|
24
|
-
label,
|
|
25
|
-
position = "bottom",
|
|
26
|
-
class: classes = "",
|
|
27
|
-
cssWidth = "auto",
|
|
28
|
-
button,
|
|
29
|
-
children,
|
|
30
|
-
trigger = "click",
|
|
31
|
-
hoverDelay = 1000,
|
|
32
|
-
}: Props = $props();
|
|
33
|
-
|
|
34
|
-
let hoverTimeout: ReturnType<typeof setTimeout> | null = null;
|
|
35
|
-
let isHovering = false;
|
|
36
|
-
|
|
37
|
-
function handleMouseEnter() {
|
|
38
|
-
if (trigger === "hover") {
|
|
39
|
-
isHovering = true;
|
|
40
|
-
hoverTimeout = setTimeout(() => {
|
|
41
|
-
if (isHovering) {
|
|
42
|
-
show = true;
|
|
43
|
-
}
|
|
44
|
-
}, hoverDelay);
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
function handleMouseLeave() {
|
|
49
|
-
if (trigger === "hover") {
|
|
50
|
-
isHovering = false;
|
|
51
|
-
if (hoverTimeout) {
|
|
52
|
-
clearTimeout(hoverTimeout);
|
|
53
|
-
hoverTimeout = null;
|
|
54
|
-
}
|
|
55
|
-
// Add a small delay before closing to prevent flickering when moving to content
|
|
56
|
-
setTimeout(() => {
|
|
57
|
-
if (!isHovering) {
|
|
58
|
-
show = false;
|
|
59
|
-
}
|
|
60
|
-
}, 100);
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
function handleClick() {
|
|
65
|
-
if (trigger === "click") {
|
|
66
|
-
show = !show;
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
function handleContentMouseEnter() {
|
|
71
|
-
if (trigger === "hover") {
|
|
72
|
-
isHovering = true;
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
function handleContentMouseLeave() {
|
|
77
|
-
if (trigger === "hover") {
|
|
78
|
-
isHovering = false;
|
|
79
|
-
setTimeout(() => {
|
|
80
|
-
if (!isHovering) {
|
|
81
|
-
show = false;
|
|
82
|
-
}
|
|
83
|
-
}, 100);
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
</script>
|
|
87
|
-
|
|
88
|
-
<div class="popover-wrapper">
|
|
89
|
-
<div
|
|
90
|
-
class="popover {classes}"
|
|
91
|
-
use:clickOutside={() => trigger === "click" && (show = false)}
|
|
92
|
-
>
|
|
93
|
-
{#if button}
|
|
94
|
-
<!-- svelte-ignore a11y_no_static_element_interactions -->
|
|
95
|
-
<!-- svelte-ignore a11y_mouse_events_have_key_events -->
|
|
96
|
-
<button
|
|
97
|
-
onclick={handleClick}
|
|
98
|
-
onmouseenter={handleMouseEnter}
|
|
99
|
-
onmouseleave={handleMouseLeave}
|
|
100
|
-
>
|
|
101
|
-
{@render button?.()}
|
|
102
|
-
</button>
|
|
103
|
-
{:else}
|
|
104
|
-
<!-- svelte-ignore a11y_no_static_element_interactions -->
|
|
105
|
-
<!-- svelte-ignore a11y_mouse_events_have_key_events -->
|
|
106
|
-
<div
|
|
107
|
-
onmouseenter={handleMouseEnter}
|
|
108
|
-
onmouseleave={handleMouseLeave}
|
|
109
|
-
>
|
|
110
|
-
<Button onclick={handleClick}>
|
|
111
|
-
{label}
|
|
112
|
-
</Button>
|
|
113
|
-
</div>
|
|
114
|
-
{/if}
|
|
115
|
-
{#if show}
|
|
116
|
-
<!-- svelte-ignore a11y_click_events_have_key_events -->
|
|
117
|
-
<!-- svelte-ignore a11y_no_static_element_interactions -->
|
|
118
|
-
<!-- svelte-ignore a11y_mouse_events_have_key_events -->
|
|
119
|
-
<div
|
|
120
|
-
class="popover-content popover-{position}"
|
|
121
|
-
onclick={(e) => e.stopPropagation()}
|
|
122
|
-
onmouseenter={handleContentMouseEnter}
|
|
123
|
-
onmouseleave={handleContentMouseLeave}
|
|
124
|
-
style="width: {cssWidth}"
|
|
125
|
-
>
|
|
126
|
-
{@render children?.()}
|
|
127
|
-
</div>
|
|
128
|
-
{/if}
|
|
129
|
-
</div>
|
|
130
|
-
</div>
|
|
131
|
-
|
|
132
|
-
<style>
|
|
133
|
-
.popover-wrapper {
|
|
134
|
-
display: flex;
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
.popover {
|
|
138
|
-
position: relative;
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
.popover-content {
|
|
142
|
-
display: block;
|
|
143
|
-
position: absolute;
|
|
144
|
-
background-color: var(--pui-paper-body-bg);
|
|
145
|
-
border: 1px solid var(--pui-border-default);
|
|
146
|
-
min-width: 160px;
|
|
147
|
-
box-shadow: var(--pui-shadow-lg);
|
|
148
|
-
z-index: var(--pui-z-dropdown);
|
|
149
|
-
border-radius: var(--pui-radius-base);
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
/* Position-specific styles */
|
|
153
|
-
.popover-bottom {
|
|
154
|
-
top: 100%;
|
|
155
|
-
left: 50%;
|
|
156
|
-
transform: translateX(-50%);
|
|
157
|
-
margin-top: var(--pui-spacing-1);
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
.popover-top {
|
|
161
|
-
bottom: 100%;
|
|
162
|
-
left: 50%;
|
|
163
|
-
transform: translateX(-50%);
|
|
164
|
-
margin-bottom: var(--pui-spacing-1);
|
|
165
|
-
}
|
|
166
|
-
|
|
167
|
-
.popover-right {
|
|
168
|
-
top: 50%;
|
|
169
|
-
left: 100%;
|
|
170
|
-
transform: translateY(-50%);
|
|
171
|
-
margin-left: var(--pui-spacing-1);
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
.popover-left {
|
|
175
|
-
top: 50%;
|
|
176
|
-
right: 100%;
|
|
177
|
-
transform: translateY(-50%);
|
|
178
|
-
margin-right: var(--pui-spacing-1);
|
|
179
|
-
}
|
|
180
|
-
|
|
181
|
-
/* Arrow indicators for each position */
|
|
182
|
-
.popover-content::before {
|
|
183
|
-
content: "";
|
|
184
|
-
position: absolute;
|
|
185
|
-
border: 6px solid transparent;
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
.popover-bottom::before {
|
|
189
|
-
top: -12px;
|
|
190
|
-
left: 50%;
|
|
191
|
-
transform: translateX(-50%);
|
|
192
|
-
border-bottom-color: var(--pui-border-default);
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
.popover-top::before {
|
|
196
|
-
bottom: -12px;
|
|
197
|
-
left: 50%;
|
|
198
|
-
transform: translateX(-50%);
|
|
199
|
-
border-top-color: var(--pui-border-default);
|
|
200
|
-
}
|
|
201
|
-
|
|
202
|
-
.popover-right::before {
|
|
203
|
-
top: 50%;
|
|
204
|
-
left: -12px;
|
|
205
|
-
transform: translateY(-50%);
|
|
206
|
-
border-right-color: var(--pui-border-default);
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
.popover-left::before {
|
|
210
|
-
top: 50%;
|
|
211
|
-
right: -12px;
|
|
212
|
-
transform: translateY(-50%);
|
|
213
|
-
border-left-color: var(--pui-border-default);
|
|
214
|
-
}
|
|
215
|
-
|
|
216
|
-
/* clear all button styles */
|
|
217
|
-
.popover button {
|
|
218
|
-
background: none;
|
|
219
|
-
border: none;
|
|
220
|
-
color: inherit;
|
|
221
|
-
cursor: pointer;
|
|
222
|
-
padding: 0;
|
|
223
|
-
font: inherit;
|
|
224
|
-
}
|
|
225
|
-
</style>
|
|
1
|
+
<!-- drop down component that displays a button, when clicked on the children expand -->
|
|
2
|
+
<script lang="ts">
|
|
3
|
+
import type { Snippet } from "svelte";
|
|
4
|
+
import Button from "./Button.svelte";
|
|
5
|
+
import { clickOutside } from "../actions/ClickOutside.js";
|
|
6
|
+
|
|
7
|
+
type PopoverPosition = "top" | "bottom" | "left" | "right";
|
|
8
|
+
type PopoverTrigger = "click" | "hover";
|
|
9
|
+
|
|
10
|
+
interface Props {
|
|
11
|
+
show?: boolean;
|
|
12
|
+
label?: string | undefined;
|
|
13
|
+
position?: PopoverPosition;
|
|
14
|
+
class?: string;
|
|
15
|
+
cssWidth?: string;
|
|
16
|
+
button?: Snippet;
|
|
17
|
+
children?: Snippet;
|
|
18
|
+
trigger?: PopoverTrigger;
|
|
19
|
+
hoverDelay?: number;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
let {
|
|
23
|
+
show = $bindable(false),
|
|
24
|
+
label,
|
|
25
|
+
position = "bottom",
|
|
26
|
+
class: classes = "",
|
|
27
|
+
cssWidth = "auto",
|
|
28
|
+
button,
|
|
29
|
+
children,
|
|
30
|
+
trigger = "click",
|
|
31
|
+
hoverDelay = 1000,
|
|
32
|
+
}: Props = $props();
|
|
33
|
+
|
|
34
|
+
let hoverTimeout: ReturnType<typeof setTimeout> | null = null;
|
|
35
|
+
let isHovering = false;
|
|
36
|
+
|
|
37
|
+
function handleMouseEnter() {
|
|
38
|
+
if (trigger === "hover") {
|
|
39
|
+
isHovering = true;
|
|
40
|
+
hoverTimeout = setTimeout(() => {
|
|
41
|
+
if (isHovering) {
|
|
42
|
+
show = true;
|
|
43
|
+
}
|
|
44
|
+
}, hoverDelay);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
function handleMouseLeave() {
|
|
49
|
+
if (trigger === "hover") {
|
|
50
|
+
isHovering = false;
|
|
51
|
+
if (hoverTimeout) {
|
|
52
|
+
clearTimeout(hoverTimeout);
|
|
53
|
+
hoverTimeout = null;
|
|
54
|
+
}
|
|
55
|
+
// Add a small delay before closing to prevent flickering when moving to content
|
|
56
|
+
setTimeout(() => {
|
|
57
|
+
if (!isHovering) {
|
|
58
|
+
show = false;
|
|
59
|
+
}
|
|
60
|
+
}, 100);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
function handleClick() {
|
|
65
|
+
if (trigger === "click") {
|
|
66
|
+
show = !show;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
function handleContentMouseEnter() {
|
|
71
|
+
if (trigger === "hover") {
|
|
72
|
+
isHovering = true;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
function handleContentMouseLeave() {
|
|
77
|
+
if (trigger === "hover") {
|
|
78
|
+
isHovering = false;
|
|
79
|
+
setTimeout(() => {
|
|
80
|
+
if (!isHovering) {
|
|
81
|
+
show = false;
|
|
82
|
+
}
|
|
83
|
+
}, 100);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
</script>
|
|
87
|
+
|
|
88
|
+
<div class="popover-wrapper">
|
|
89
|
+
<div
|
|
90
|
+
class="popover {classes}"
|
|
91
|
+
use:clickOutside={() => trigger === "click" && (show = false)}
|
|
92
|
+
>
|
|
93
|
+
{#if button}
|
|
94
|
+
<!-- svelte-ignore a11y_no_static_element_interactions -->
|
|
95
|
+
<!-- svelte-ignore a11y_mouse_events_have_key_events -->
|
|
96
|
+
<button
|
|
97
|
+
onclick={handleClick}
|
|
98
|
+
onmouseenter={handleMouseEnter}
|
|
99
|
+
onmouseleave={handleMouseLeave}
|
|
100
|
+
>
|
|
101
|
+
{@render button?.()}
|
|
102
|
+
</button>
|
|
103
|
+
{:else}
|
|
104
|
+
<!-- svelte-ignore a11y_no_static_element_interactions -->
|
|
105
|
+
<!-- svelte-ignore a11y_mouse_events_have_key_events -->
|
|
106
|
+
<div
|
|
107
|
+
onmouseenter={handleMouseEnter}
|
|
108
|
+
onmouseleave={handleMouseLeave}
|
|
109
|
+
>
|
|
110
|
+
<Button onclick={handleClick}>
|
|
111
|
+
{label}
|
|
112
|
+
</Button>
|
|
113
|
+
</div>
|
|
114
|
+
{/if}
|
|
115
|
+
{#if show}
|
|
116
|
+
<!-- svelte-ignore a11y_click_events_have_key_events -->
|
|
117
|
+
<!-- svelte-ignore a11y_no_static_element_interactions -->
|
|
118
|
+
<!-- svelte-ignore a11y_mouse_events_have_key_events -->
|
|
119
|
+
<div
|
|
120
|
+
class="popover-content popover-{position}"
|
|
121
|
+
onclick={(e) => e.stopPropagation()}
|
|
122
|
+
onmouseenter={handleContentMouseEnter}
|
|
123
|
+
onmouseleave={handleContentMouseLeave}
|
|
124
|
+
style="width: {cssWidth}"
|
|
125
|
+
>
|
|
126
|
+
{@render children?.()}
|
|
127
|
+
</div>
|
|
128
|
+
{/if}
|
|
129
|
+
</div>
|
|
130
|
+
</div>
|
|
131
|
+
|
|
132
|
+
<style>
|
|
133
|
+
.popover-wrapper {
|
|
134
|
+
display: flex;
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
.popover {
|
|
138
|
+
position: relative;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
.popover-content {
|
|
142
|
+
display: block;
|
|
143
|
+
position: absolute;
|
|
144
|
+
background-color: var(--pui-paper-body-bg);
|
|
145
|
+
border: 1px solid var(--pui-border-default);
|
|
146
|
+
min-width: 160px;
|
|
147
|
+
box-shadow: var(--pui-shadow-lg);
|
|
148
|
+
z-index: var(--pui-z-dropdown);
|
|
149
|
+
border-radius: var(--pui-radius-base);
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
/* Position-specific styles */
|
|
153
|
+
.popover-bottom {
|
|
154
|
+
top: 100%;
|
|
155
|
+
left: 50%;
|
|
156
|
+
transform: translateX(-50%);
|
|
157
|
+
margin-top: var(--pui-spacing-1);
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
.popover-top {
|
|
161
|
+
bottom: 100%;
|
|
162
|
+
left: 50%;
|
|
163
|
+
transform: translateX(-50%);
|
|
164
|
+
margin-bottom: var(--pui-spacing-1);
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
.popover-right {
|
|
168
|
+
top: 50%;
|
|
169
|
+
left: 100%;
|
|
170
|
+
transform: translateY(-50%);
|
|
171
|
+
margin-left: var(--pui-spacing-1);
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
.popover-left {
|
|
175
|
+
top: 50%;
|
|
176
|
+
right: 100%;
|
|
177
|
+
transform: translateY(-50%);
|
|
178
|
+
margin-right: var(--pui-spacing-1);
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
/* Arrow indicators for each position */
|
|
182
|
+
.popover-content::before {
|
|
183
|
+
content: "";
|
|
184
|
+
position: absolute;
|
|
185
|
+
border: 6px solid transparent;
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
.popover-bottom::before {
|
|
189
|
+
top: -12px;
|
|
190
|
+
left: 50%;
|
|
191
|
+
transform: translateX(-50%);
|
|
192
|
+
border-bottom-color: var(--pui-border-default);
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
.popover-top::before {
|
|
196
|
+
bottom: -12px;
|
|
197
|
+
left: 50%;
|
|
198
|
+
transform: translateX(-50%);
|
|
199
|
+
border-top-color: var(--pui-border-default);
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
.popover-right::before {
|
|
203
|
+
top: 50%;
|
|
204
|
+
left: -12px;
|
|
205
|
+
transform: translateY(-50%);
|
|
206
|
+
border-right-color: var(--pui-border-default);
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
.popover-left::before {
|
|
210
|
+
top: 50%;
|
|
211
|
+
right: -12px;
|
|
212
|
+
transform: translateY(-50%);
|
|
213
|
+
border-left-color: var(--pui-border-default);
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
/* clear all button styles */
|
|
217
|
+
.popover button {
|
|
218
|
+
background: none;
|
|
219
|
+
border: none;
|
|
220
|
+
color: inherit;
|
|
221
|
+
cursor: pointer;
|
|
222
|
+
padding: 0;
|
|
223
|
+
font: inherit;
|
|
224
|
+
}
|
|
225
|
+
</style>
|