pxd 0.0.35 → 0.0.37
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/dist/components/active-graph/index.vue +7 -8
- package/dist/components/countdown/index.vue +8 -5
- package/dist/components/drawer/index.vue +4 -4
- package/dist/components/drawer/index.vue.d.ts +1 -1
- package/dist/components/input/index.vue +5 -5
- package/dist/components/material/index.vue +3 -2
- package/dist/components/message/index.vue.d.ts +2 -2
- package/dist/components/modal/index.vue +4 -4
- package/dist/components/modal/index.vue.d.ts +1 -1
- package/dist/components/overlay/index.vue +12 -9
- package/dist/components/stack/index.vue +2 -2
- package/dist/components/toggle/index.vue +45 -16
- package/dist/components/toggle/index.vue.d.ts +13 -8
- package/dist/composables/use-countdown.d.ts +5 -0
- package/dist/composables/use-countdown.js +39 -15
- package/dist/composables/use-delay-change.d.ts +2 -3
- package/dist/composables/use-delay-change.js +9 -10
- package/dist/composables/use-message.d.ts +1 -1
- package/dist/index.d.ts +2 -1
- package/dist/index.js +1 -1
- package/dist/styles/styles.css +1 -1
- package/dist/styles/tw.css +6 -2
- package/dist/types/shared/props.d.ts +2 -0
- package/dist/utils/{dates.d.ts → date.d.ts} +4 -1
- package/dist/utils/{dates.js → date.js} +7 -0
- package/dist/utils/dom.d.ts +9 -3
- package/dist/utils/dom.js +30 -35
- package/package.json +1 -1
|
@@ -3,7 +3,7 @@ import { computed, onBeforeUnmount, shallowRef } from "vue";
|
|
|
3
3
|
import { useConfigProvider } from "../../composables/use-config-provider-context";
|
|
4
4
|
import { useDelayChange } from "../../composables/use-delay-change";
|
|
5
5
|
import { getColorByThreshold } from "../../utils/colors";
|
|
6
|
-
import { getAllDatesBetween } from "../../utils/
|
|
6
|
+
import { getAllDatesBetween } from "../../utils/date";
|
|
7
7
|
defineOptions({
|
|
8
8
|
name: "PActiveGraph"
|
|
9
9
|
});
|
|
@@ -206,8 +206,7 @@ let tbodyRect;
|
|
|
206
206
|
const tbodyRef = shallowRef();
|
|
207
207
|
const {
|
|
208
208
|
value: showTooltip,
|
|
209
|
-
setValue: setShowTooltip
|
|
210
|
-
setValueDelay: setShowTooltipDelay
|
|
209
|
+
setValue: setShowTooltip
|
|
211
210
|
} = useDelayChange(false, 500);
|
|
212
211
|
const tooltipInfo = shallowRef({});
|
|
213
212
|
const formatTooltipText = computed(() => {
|
|
@@ -218,25 +217,25 @@ const formatTooltipText = computed(() => {
|
|
|
218
217
|
return "";
|
|
219
218
|
});
|
|
220
219
|
function onMouseLeave() {
|
|
221
|
-
setShowTooltip(false);
|
|
220
|
+
setShowTooltip(false, true);
|
|
222
221
|
tooltipInfo.value = {};
|
|
223
222
|
tbodyRect = null;
|
|
224
223
|
}
|
|
225
224
|
async function onMouseOver(ev) {
|
|
226
225
|
const targetEl = ev.target;
|
|
227
226
|
if (targetEl.tagName !== "TD") {
|
|
228
|
-
|
|
227
|
+
setShowTooltip(false);
|
|
229
228
|
return;
|
|
230
229
|
}
|
|
231
230
|
const date = targetEl.dataset.date;
|
|
232
231
|
if (!date) {
|
|
233
|
-
setShowTooltip(false);
|
|
232
|
+
setShowTooltip(false, true);
|
|
234
233
|
return;
|
|
235
234
|
}
|
|
236
235
|
if (!tbodyRect) {
|
|
237
236
|
tbodyRect = tbodyRef.value.getBoundingClientRect();
|
|
238
237
|
}
|
|
239
|
-
setShowTooltip(true);
|
|
238
|
+
setShowTooltip(true, true);
|
|
240
239
|
const rect = targetEl.getBoundingClientRect();
|
|
241
240
|
let top = rect.top - tbodyRect.top - CELL_SIZE;
|
|
242
241
|
if (props.graphOnly) {
|
|
@@ -326,7 +325,7 @@ onBeforeUnmount(() => {
|
|
|
326
325
|
<div
|
|
327
326
|
v-if="showTooltip"
|
|
328
327
|
class="pxd-active-graph--tooltip left-0 top-0 px-2 py-1 pointer-events-none absolute z-1 w-max rounded-sm bg-gray-1000 text-[13px] text-gray-100 duration-50 will-change-transform motion-safe:transition-transform"
|
|
329
|
-
:style="`transform:
|
|
328
|
+
:style="`transform: translate3d(${tooltipInfo.left}px, ${tooltipInfo.top}px, 0);`"
|
|
330
329
|
>
|
|
331
330
|
<slot name="tooltip" :data="tooltipInfo">
|
|
332
331
|
{{ formatTooltipText }}
|
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
<script setup>
|
|
2
|
-
import dayjs from "dayjs/esm/index.js";
|
|
3
|
-
import durationPlugin from "dayjs/esm/plugin/duration/index.js";
|
|
4
2
|
import { computed, onBeforeUnmount } from "vue";
|
|
5
3
|
import { useCountdown } from "../../composables/use-countdown";
|
|
6
|
-
import
|
|
4
|
+
import {
|
|
5
|
+
dayjs,
|
|
6
|
+
dayjsDurationPlugin,
|
|
7
|
+
dayjsMillisecondTokenPlugin
|
|
8
|
+
} from "../../utils/date";
|
|
7
9
|
defineOptions({
|
|
8
10
|
name: "PCountDown"
|
|
9
11
|
});
|
|
@@ -11,6 +13,7 @@ const props = defineProps({
|
|
|
11
13
|
format: { type: String, required: false, default: "HH:mm:ss" },
|
|
12
14
|
invert: { type: Boolean, required: false },
|
|
13
15
|
active: { type: Boolean, required: false, default: false },
|
|
16
|
+
startAt: { type: Number, required: false },
|
|
14
17
|
endTime: { type: Number, required: false, default: 0 },
|
|
15
18
|
autoReset: { type: Boolean, required: false, default: true },
|
|
16
19
|
durations: { type: Number, required: false, default: 0 },
|
|
@@ -18,8 +21,8 @@ const props = defineProps({
|
|
|
18
21
|
millisecond: { type: Boolean, required: false, default: true }
|
|
19
22
|
});
|
|
20
23
|
const emits = defineEmits(["change", "reset", "finish"]);
|
|
21
|
-
dayjs.extend(
|
|
22
|
-
dayjs.extend(
|
|
24
|
+
dayjs.extend(dayjsDurationPlugin);
|
|
25
|
+
dayjs.extend(dayjsMillisecondTokenPlugin);
|
|
23
26
|
const {
|
|
24
27
|
stop,
|
|
25
28
|
reset,
|
|
@@ -17,7 +17,7 @@ const props = defineProps({
|
|
|
17
17
|
title: { type: [String, Number, Array, null], required: false },
|
|
18
18
|
subtitle: { type: [String, Number, Array, null], required: false },
|
|
19
19
|
size: { type: [Number, String], required: false },
|
|
20
|
-
|
|
20
|
+
loading: { type: Boolean, required: false },
|
|
21
21
|
position: { type: String, required: false, default: "right" },
|
|
22
22
|
modelValue: { type: Boolean, required: false, default: false },
|
|
23
23
|
appendToBody: { type: Boolean, required: false, default: true },
|
|
@@ -48,13 +48,13 @@ const computedStyle = computed(() => {
|
|
|
48
48
|
});
|
|
49
49
|
function onOverlayClick(ev) {
|
|
50
50
|
emits("click-outside", ev);
|
|
51
|
-
if (!props.closeOnClickOverlay || props.
|
|
51
|
+
if (!props.closeOnClickOverlay || props.loading) {
|
|
52
52
|
return;
|
|
53
53
|
}
|
|
54
54
|
isVisible.value = false;
|
|
55
55
|
}
|
|
56
56
|
function onUpdateModelValue(visible) {
|
|
57
|
-
if (!visible && props.
|
|
57
|
+
if (!visible && props.loading) {
|
|
58
58
|
return;
|
|
59
59
|
}
|
|
60
60
|
isVisible.value = visible;
|
|
@@ -92,7 +92,7 @@ watch(() => isVisible.value, (visible) => {
|
|
|
92
92
|
class="pxd-drawer--header p-6 sm:pb-4 relative shrink-0 empty:py-3"
|
|
93
93
|
:class="{ 'sm:pt-4 border-b bg-background-200 dark:bg-background-100': headerStylize }"
|
|
94
94
|
>
|
|
95
|
-
<h3 v-if="$slots.title || title" class="text-xl font-semibold tracking-tight">
|
|
95
|
+
<h3 v-if="$slots.title || title" class="text-xl font-semibold tracking-tight m-0">
|
|
96
96
|
<slot name="title">
|
|
97
97
|
{{ title }}
|
|
98
98
|
</slot>
|
|
@@ -60,7 +60,7 @@ const isComposing = shallowRef(false);
|
|
|
60
60
|
const isPasswordVisible = shallowRef(!props.password);
|
|
61
61
|
const internalInputType = computed(() => props.inputType || isPasswordVisible.value ? "text" : "password");
|
|
62
62
|
const computedClass = computed(() => {
|
|
63
|
-
const classes = ["pxd-input--border relative flex items-center overflow-hidden rounded-md bg-background-100 motion-safe:transition-all"];
|
|
63
|
+
const classes = ["pxd-input--border group relative flex items-center overflow-hidden rounded-md bg-background-100 data-[disabled=true]:cursor-not-allowed data-[disabled=true]:bg-gray-100 motion-safe:transition-all"];
|
|
64
64
|
classes.push(getFallbackValue(props.size, SIZES, config.size));
|
|
65
65
|
if (isTruthyProp(props.disabled)) {
|
|
66
66
|
classes.push("is-disabled");
|
|
@@ -161,11 +161,11 @@ defineExpose({
|
|
|
161
161
|
<slot name="label">{{ label }}</slot>
|
|
162
162
|
</div>
|
|
163
163
|
|
|
164
|
-
<div :class="computedClass">
|
|
164
|
+
<div :data-disabled="disabled" :class="computedClass">
|
|
165
165
|
<div
|
|
166
166
|
v-if="$slots.prefix"
|
|
167
167
|
class="pxd-input--prefix text-sm flex h-full items-center text-gray-700"
|
|
168
|
-
:class="{ 'px-3 rounded-l-inherit border-r bg-background-200': prefixStyle }"
|
|
168
|
+
:class="{ 'px-3 rounded-l-inherit border-r border-gray-300 bg-background-200': prefixStyle }"
|
|
169
169
|
>
|
|
170
170
|
<slot name="prefix" />
|
|
171
171
|
</div>
|
|
@@ -173,7 +173,7 @@ defineExpose({
|
|
|
173
173
|
<input
|
|
174
174
|
:id="uniqueId"
|
|
175
175
|
ref="inputRef"
|
|
176
|
-
class="px-3 size-full rounded-inherit bg-transparent outline-none file:font-medium file:border-0 file:bg-transparent placeholder:text-gray-600 placeholder:select-none disabled:cursor-not-allowed disabled:
|
|
176
|
+
class="px-3 size-full rounded-inherit bg-transparent outline-none file:font-medium file:border-0 file:bg-transparent placeholder:text-gray-600 placeholder:select-none disabled:cursor-not-allowed disabled:text-gray-700 disabled:placeholder:text-gray-500"
|
|
177
177
|
:class="{ 'pr-9': password || allowClear, [ALIGN[align]]: true }"
|
|
178
178
|
:type="internalInputType"
|
|
179
179
|
:min="min"
|
|
@@ -217,7 +217,7 @@ defineExpose({
|
|
|
217
217
|
<div
|
|
218
218
|
v-if="$slots.suffix"
|
|
219
219
|
class="pxd-input--suffix text-sm flex h-full items-center text-gray-700"
|
|
220
|
-
:class="{ 'px-3 rounded-r-inherit border-l bg-background-200': suffixStyle }"
|
|
220
|
+
:class="{ 'px-3 rounded-r-inherit border-l border-gray-300 bg-background-200': suffixStyle }"
|
|
221
221
|
>
|
|
222
222
|
<slot name="suffix" />
|
|
223
223
|
</div>
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
<script setup>
|
|
2
2
|
import PStack from "../stack/index.vue";
|
|
3
3
|
defineOptions({
|
|
4
|
-
name: "PMaterial"
|
|
4
|
+
name: "PMaterial",
|
|
5
|
+
inheritAttrs: false
|
|
5
6
|
});
|
|
6
7
|
defineProps({
|
|
7
8
|
variant: { type: String, required: false, default: "default" }
|
|
@@ -9,7 +10,7 @@ defineProps({
|
|
|
9
10
|
</script>
|
|
10
11
|
|
|
11
12
|
<template>
|
|
12
|
-
<PStack class="pxd-material w-full bg-background-100" :class="variant">
|
|
13
|
+
<PStack class="pxd-material w-full bg-background-100" :class="variant" v-bind="$attrs">
|
|
13
14
|
<slot />
|
|
14
15
|
</PStack>
|
|
15
16
|
</template>
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { MessageItem } from '../../composables/use-message';
|
|
2
2
|
import type { ComponentPosition } from '../../types/shared/props';
|
|
3
3
|
interface Props {
|
|
4
4
|
max?: number;
|
|
@@ -37,7 +37,7 @@ declare const _default: import("vue").DefineComponent<Props, {
|
|
|
37
37
|
durations: number;
|
|
38
38
|
closeable: boolean;
|
|
39
39
|
type?: "info" | "success" | "warning" | "error" | "loading" | "" | false | undefined;
|
|
40
|
-
}[],
|
|
40
|
+
}[], MessageItem[] | {
|
|
41
41
|
message: string | import("vue").VNode;
|
|
42
42
|
_timerId?: ReturnType<typeof setTimeout>;
|
|
43
43
|
_remainingMs?: number;
|
|
@@ -15,7 +15,7 @@ const props = defineProps({
|
|
|
15
15
|
title: { type: [String, Number, Array, null], required: false },
|
|
16
16
|
subtitle: { type: [String, Number, Array, null], required: false },
|
|
17
17
|
width: { type: [Number, String], required: false },
|
|
18
|
-
|
|
18
|
+
loading: { type: Boolean, required: false },
|
|
19
19
|
modelValue: { type: Boolean, required: false, default: false },
|
|
20
20
|
appendToBody: { type: Boolean, required: false, default: true },
|
|
21
21
|
headerStylize: { type: Boolean, required: false, default: false },
|
|
@@ -30,13 +30,13 @@ const isVisible = useModelValue(props, emits);
|
|
|
30
30
|
useFocusTrap(modalRef);
|
|
31
31
|
function onOverlayClick(ev) {
|
|
32
32
|
emits("click-outside", ev);
|
|
33
|
-
if (!props.closeOnClickOverlay || props.
|
|
33
|
+
if (!props.closeOnClickOverlay || props.loading) {
|
|
34
34
|
return;
|
|
35
35
|
}
|
|
36
36
|
isVisible.value = false;
|
|
37
37
|
}
|
|
38
38
|
function onUpdateModelValue(visible) {
|
|
39
|
-
if (!visible && props.
|
|
39
|
+
if (!visible && props.loading) {
|
|
40
40
|
return;
|
|
41
41
|
}
|
|
42
42
|
isVisible.value = visible;
|
|
@@ -73,7 +73,7 @@ watch(() => isVisible.value, (visible) => {
|
|
|
73
73
|
class="pxd-modal--header p-6 sm:pb-4 relative shrink-0 empty:py-3"
|
|
74
74
|
:class="{ 'sm:pt-4 border-b bg-background-200 dark:bg-background-100': headerStylize }"
|
|
75
75
|
>
|
|
76
|
-
<h3 v-if="$slots.title || title" class="text-xl font-semibold tracking-tight">
|
|
76
|
+
<h3 v-if="$slots.title || title" class="text-xl font-semibold tracking-tight m-0">
|
|
77
77
|
<slot name="title">
|
|
78
78
|
{{ title }}
|
|
79
79
|
</slot>
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
<script setup>
|
|
2
2
|
import { computed, nextTick, onBeforeUnmount, shallowRef, watch } from "vue";
|
|
3
|
-
import { getScrollContainer, getScrollElByContainer } from "../../utils/dom";
|
|
3
|
+
import { getScrollContainer, getScrollElByContainer, hasScrollbar, isScrollable } from "../../utils/dom";
|
|
4
4
|
import { optimizedOff, optimizedOn } from "../../utils/events";
|
|
5
5
|
import { isServer } from "../../utils/is";
|
|
6
6
|
import PTeleport from "../teleport/index.vue";
|
|
@@ -34,7 +34,7 @@ function onOverlayClick(ev) {
|
|
|
34
34
|
emits("update:modelValue", false);
|
|
35
35
|
}
|
|
36
36
|
function onOverlayKeydown(ev) {
|
|
37
|
-
if (!props.closeOnPressEscape) {
|
|
37
|
+
if (!props.closeOnPressEscape || !props.modelValue) {
|
|
38
38
|
return;
|
|
39
39
|
}
|
|
40
40
|
if (ev.ctrlKey || ev.metaKey || ev.altKey || ev.shiftKey) {
|
|
@@ -49,19 +49,20 @@ function addScrollDisabled() {
|
|
|
49
49
|
if (!scrollContainer) {
|
|
50
50
|
return;
|
|
51
51
|
}
|
|
52
|
-
const {
|
|
53
|
-
|
|
54
|
-
|
|
52
|
+
const { x: xScrollbar, y: yScrollbar } = hasScrollbar(scrollContainer);
|
|
53
|
+
const { x: xScrollable, y: yScrollable } = isScrollable(scrollContainer);
|
|
54
|
+
if (xScrollbar && xScrollable) {
|
|
55
|
+
scrollContainer.classList.add("scrollbar-stable", "scroll-disabled-x");
|
|
55
56
|
}
|
|
56
|
-
if (
|
|
57
|
-
scrollContainer.classList.add("scroll-disabled-y");
|
|
57
|
+
if (yScrollbar && yScrollable) {
|
|
58
|
+
scrollContainer.classList.add("scrollbar-stable", "scroll-disabled-y");
|
|
58
59
|
}
|
|
59
60
|
}
|
|
60
61
|
function removeScrollDisabled() {
|
|
61
62
|
if (!scrollContainer) {
|
|
62
63
|
return;
|
|
63
64
|
}
|
|
64
|
-
scrollContainer.classList.remove("scroll-disabled-x", "scroll-disabled-y");
|
|
65
|
+
scrollContainer.classList.remove("scroll-disabled-x", "scroll-disabled-y", "scrollbar-stable");
|
|
65
66
|
}
|
|
66
67
|
watch(() => props.modelValue, (visible) => {
|
|
67
68
|
if (isServer) {
|
|
@@ -74,7 +75,9 @@ watch(() => props.modelValue, (visible) => {
|
|
|
74
75
|
}
|
|
75
76
|
nextTick(() => {
|
|
76
77
|
if (!scrollContainer) {
|
|
77
|
-
scrollContainer = getScrollElByContainer(
|
|
78
|
+
scrollContainer = getScrollElByContainer(
|
|
79
|
+
getScrollContainer(overlayRef.value, true)
|
|
80
|
+
);
|
|
78
81
|
}
|
|
79
82
|
addScrollDisabled();
|
|
80
83
|
optimizedOn(document, "keydown", onOverlayKeydown);
|
|
@@ -66,8 +66,8 @@ const formattedGap = computed(() => {
|
|
|
66
66
|
});
|
|
67
67
|
const formattedDirection = computed(() => {
|
|
68
68
|
const { direction } = props;
|
|
69
|
-
const defaultDirection = typeof direction === "string" ? direction : direction.xs
|
|
70
|
-
const defaultDirs = { xs: defaultDirection
|
|
69
|
+
const defaultDirection = typeof direction === "string" ? direction : direction.xs ?? "horizontal";
|
|
70
|
+
const defaultDirs = { xs: presetDirClasses[`xs:${defaultDirection}`] };
|
|
71
71
|
if (typeof direction === "object") {
|
|
72
72
|
return Object.entries(direction).reduce((acc, [bp, value]) => {
|
|
73
73
|
acc[bp] = presetDirClasses[`${bp}:${value}`];
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
<script setup>
|
|
2
|
+
import LoaderCircleIcon from "@gdsicon/vue/loader-circle";
|
|
2
3
|
import { computed } from "vue";
|
|
3
4
|
import { useConfigProvider } from "../../composables/use-config-provider-context";
|
|
4
5
|
import { useModelValue } from "../../composables/use-model-value";
|
|
@@ -14,15 +15,18 @@ defineOptions({
|
|
|
14
15
|
const props = defineProps({
|
|
15
16
|
size: { type: String, required: false },
|
|
16
17
|
label: { type: [String, Number, Array, null], required: false },
|
|
18
|
+
loading: { type: Boolean, required: false },
|
|
19
|
+
disabled: { type: Boolean, required: false },
|
|
17
20
|
modelValue: { type: [Boolean, Number, String], required: false },
|
|
18
21
|
activeValue: { type: [Boolean, Number, String], required: false, default: true },
|
|
19
22
|
inactiveValue: { type: [Boolean, Number, String], required: false, default: false },
|
|
23
|
+
beforeChange: { type: Function, required: false },
|
|
24
|
+
activeColor: { type: String, required: false, default: "var(--color-primary)" },
|
|
25
|
+
inactiveColor: { type: String, required: false, default: "var(--color-gray-alpha-100)" },
|
|
20
26
|
activeLabel: { type: String, required: false },
|
|
21
|
-
inactiveLabel: { type: String, required: false }
|
|
22
|
-
activeBgColor: { type: String, required: false, default: "var(--color-primary)" },
|
|
23
|
-
inactiveBgColor: { type: String, required: false, default: "var(--color-gray-alpha-200)" }
|
|
27
|
+
inactiveLabel: { type: String, required: false }
|
|
24
28
|
});
|
|
25
|
-
const emits = defineEmits(["update:modelValue"]);
|
|
29
|
+
const emits = defineEmits(["change", "update:modelValue"]);
|
|
26
30
|
const SIZES = {
|
|
27
31
|
sm: "w-7 h-4",
|
|
28
32
|
md: "w-9 h-5",
|
|
@@ -33,9 +37,22 @@ const config = useConfigProvider();
|
|
|
33
37
|
const modelValue = useModelValue(props, emits);
|
|
34
38
|
const isChecked = computed(() => modelValue.value === props.activeValue);
|
|
35
39
|
const computedSize = computed(() => getFallbackValue(props.size, SIZES, config.size));
|
|
36
|
-
function onCheckboxChange(e) {
|
|
37
|
-
|
|
38
|
-
|
|
40
|
+
async function onCheckboxChange(e) {
|
|
41
|
+
if (props.loading) {
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
const input = e.target;
|
|
45
|
+
const rawValue = input.checked;
|
|
46
|
+
if (typeof props.beforeChange === "function") {
|
|
47
|
+
input.checked = !rawValue;
|
|
48
|
+
const isAllowed = await props.beforeChange(modelValue.value);
|
|
49
|
+
if (!isAllowed) {
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
const changedValue = rawValue ? props.activeValue : props.inactiveValue;
|
|
54
|
+
modelValue.value = changedValue;
|
|
55
|
+
emits("change", changedValue);
|
|
39
56
|
}
|
|
40
57
|
</script>
|
|
41
58
|
|
|
@@ -45,8 +62,8 @@ function onCheckboxChange(e) {
|
|
|
45
62
|
class="pxd-toggle group/toggle inline-flex cursor-pointer touch-manipulation flex-col select-none"
|
|
46
63
|
:aria-label="modelValue ? activeLabel : inactiveLabel"
|
|
47
64
|
:style="{
|
|
48
|
-
'--
|
|
49
|
-
'--
|
|
65
|
+
'--ac': activeColor,
|
|
66
|
+
'--ic': inactiveColor,
|
|
50
67
|
}"
|
|
51
68
|
:for="uniqueId"
|
|
52
69
|
>
|
|
@@ -58,9 +75,10 @@ function onCheckboxChange(e) {
|
|
|
58
75
|
<input
|
|
59
76
|
:id="uniqueId"
|
|
60
77
|
type="checkbox"
|
|
78
|
+
:disabled="disabled || loading"
|
|
61
79
|
:checked="isChecked"
|
|
62
|
-
class="peer smallest"
|
|
63
|
-
@change="onCheckboxChange"
|
|
80
|
+
class="pxd-toggle--input peer smallest"
|
|
81
|
+
@change.prevent="onCheckboxChange"
|
|
64
82
|
>
|
|
65
83
|
|
|
66
84
|
<span
|
|
@@ -69,13 +87,18 @@ function onCheckboxChange(e) {
|
|
|
69
87
|
>{{ inactiveLabel }}</span>
|
|
70
88
|
|
|
71
89
|
<div
|
|
72
|
-
class="pxd-toggle--handle rounded-full border border-input bg-(--
|
|
90
|
+
class="pxd-toggle--handle rounded-full border border-input bg-(--ic) p-px peer-focus-ring [--tx:0] peer-checked:bg-(--ac) peer-checked:[--tx:100%] peer-disabled:cursor-not-allowed motion-safe:transition-all"
|
|
73
91
|
:class="computedSize"
|
|
74
92
|
>
|
|
75
|
-
<
|
|
76
|
-
<
|
|
77
|
-
|
|
78
|
-
|
|
93
|
+
<div class="pxd-toggle--handle-icon text-xs shadow-sm relative flex aspect-square h-full translate-x-(--tx) transform-gpu items-center justify-center overflow-hidden rounded-full bg-background-100 text-foreground-secondary motion-safe:transition-transform">
|
|
94
|
+
<div class="inset-0 absolute flex items-center justify-center">
|
|
95
|
+
<Transition name="pxd-transition--fade" mode="out-in">
|
|
96
|
+
<LoaderCircleIcon v-if="loading" class="motion-safe:animate-spin" />
|
|
97
|
+
<slot v-else-if="modelValue" name="checked" />
|
|
98
|
+
<slot v-else name="unchecked" />
|
|
99
|
+
</Transition>
|
|
100
|
+
</div>
|
|
101
|
+
</div>
|
|
79
102
|
</div>
|
|
80
103
|
|
|
81
104
|
<span
|
|
@@ -85,3 +108,9 @@ function onCheckboxChange(e) {
|
|
|
85
108
|
</div>
|
|
86
109
|
</label>
|
|
87
110
|
</template>
|
|
111
|
+
|
|
112
|
+
<style lang="postcss">
|
|
113
|
+
.pxd-toggle--input:checked:disabled + .pxd-toggle--handle {
|
|
114
|
+
background-color: var(--color-gray-300)
|
|
115
|
+
}
|
|
116
|
+
</style>
|
|
@@ -1,33 +1,38 @@
|
|
|
1
|
-
import type { ComponentLabel, ComponentSize } from '../../types/shared';
|
|
1
|
+
import type { ComponentBeforeChange, ComponentLabel, ComponentSize } from '../../types/shared';
|
|
2
2
|
type ValueType = boolean | number | string;
|
|
3
3
|
interface Props {
|
|
4
4
|
size?: ComponentSize;
|
|
5
5
|
label?: ComponentLabel;
|
|
6
|
+
loading?: boolean;
|
|
7
|
+
disabled?: boolean;
|
|
6
8
|
modelValue?: ValueType;
|
|
7
9
|
activeValue?: ValueType;
|
|
8
10
|
inactiveValue?: ValueType;
|
|
11
|
+
beforeChange?: ComponentBeforeChange<ValueType>;
|
|
12
|
+
activeColor?: string;
|
|
13
|
+
inactiveColor?: string;
|
|
9
14
|
activeLabel?: string;
|
|
10
15
|
inactiveLabel?: string;
|
|
11
|
-
activeBgColor?: string;
|
|
12
|
-
inactiveBgColor?: string;
|
|
13
16
|
}
|
|
14
|
-
declare var __VLS_1: {},
|
|
17
|
+
declare var __VLS_1: {}, __VLS_13: {}, __VLS_15: {};
|
|
15
18
|
type __VLS_Slots = {} & {
|
|
16
19
|
label?: (props: typeof __VLS_1) => any;
|
|
17
20
|
} & {
|
|
18
|
-
|
|
21
|
+
checked?: (props: typeof __VLS_13) => any;
|
|
19
22
|
} & {
|
|
20
|
-
|
|
23
|
+
unchecked?: (props: typeof __VLS_15) => any;
|
|
21
24
|
};
|
|
22
25
|
declare const __VLS_component: import("vue").DefineComponent<Props, void, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
|
|
26
|
+
change: (args_0: NonNullable<ValueType>) => any;
|
|
23
27
|
"update:modelValue": (args_0: NonNullable<ValueType>) => any;
|
|
24
28
|
}, string, import("vue").PublicProps, Readonly<Props> & Readonly<{
|
|
29
|
+
onChange?: (args_0: NonNullable<ValueType>) => any;
|
|
25
30
|
"onUpdate:modelValue"?: (args_0: NonNullable<ValueType>) => any;
|
|
26
31
|
}>, {
|
|
27
32
|
activeValue: ValueType;
|
|
28
33
|
inactiveValue: ValueType;
|
|
29
|
-
|
|
30
|
-
|
|
34
|
+
activeColor: string;
|
|
35
|
+
inactiveColor: string;
|
|
31
36
|
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
|
|
32
37
|
declare const _default: __VLS_WithSlots<typeof __VLS_component, __VLS_Slots>;
|
|
33
38
|
export default _default;
|
|
@@ -1,25 +1,45 @@
|
|
|
1
1
|
import { computed, shallowRef, watch } from "vue";
|
|
2
|
-
const UPDATE_INTERVAL =
|
|
3
|
-
const MILLISECOND_LENGTH = 13;
|
|
2
|
+
const UPDATE_INTERVAL = Math.ceil(1e3 / 25);
|
|
4
3
|
export function useCountdown(props, emits) {
|
|
5
4
|
let startTimestamp = -1;
|
|
6
5
|
let isFinished = false;
|
|
7
6
|
let isPaused = false;
|
|
7
|
+
let previousFrameTime = 0;
|
|
8
8
|
const timeRef = shallowRef(0);
|
|
9
9
|
const totalDuration = computed(() => {
|
|
10
|
-
const { endTime, durations
|
|
10
|
+
const { endTime, durations } = props;
|
|
11
11
|
if (endTime) {
|
|
12
|
-
const end = (
|
|
12
|
+
const end = formatTime(endTime) - Date.now();
|
|
13
13
|
return Math.max(0, end);
|
|
14
14
|
}
|
|
15
|
-
|
|
16
|
-
|
|
15
|
+
if (props.invert && [void 0, 0].includes(durations)) {
|
|
16
|
+
return Infinity;
|
|
17
|
+
}
|
|
18
|
+
return Math.max(0, formatTime(durations ?? 0));
|
|
17
19
|
});
|
|
20
|
+
const isInfiniteCountup = computed(
|
|
21
|
+
() => props.invert && totalDuration.value === Infinity
|
|
22
|
+
);
|
|
23
|
+
function formatTime(time = 0) {
|
|
24
|
+
return props.millisecond ? Math.round(time) : Math.round(time * 1e3);
|
|
25
|
+
}
|
|
18
26
|
function getCurrent(now) {
|
|
19
27
|
return props.invert ? now - startTimestamp : totalDuration.value + startTimestamp - now;
|
|
20
28
|
}
|
|
21
29
|
function setCurrent() {
|
|
22
|
-
|
|
30
|
+
const startAtValue = formatTime(props.startAt);
|
|
31
|
+
if (props.invert) {
|
|
32
|
+
timeRef.value = isInfiniteCountup.value ? startAtValue : Math.min(startAtValue, totalDuration.value);
|
|
33
|
+
} else {
|
|
34
|
+
timeRef.value = Math.max(0, totalDuration.value - startAtValue);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
function shouldFinish(current) {
|
|
38
|
+
if (!props.invert) {
|
|
39
|
+
return current <= 0;
|
|
40
|
+
} else {
|
|
41
|
+
return !isInfiniteCountup.value && current >= totalDuration.value;
|
|
42
|
+
}
|
|
23
43
|
}
|
|
24
44
|
function finish() {
|
|
25
45
|
timeRef.value = props.invert ? totalDuration.value : 0;
|
|
@@ -27,7 +47,7 @@ export function useCountdown(props, emits) {
|
|
|
27
47
|
emits("finish");
|
|
28
48
|
}
|
|
29
49
|
function reset() {
|
|
30
|
-
startTimestamp = performance.now();
|
|
50
|
+
startTimestamp = performance.now() - formatTime(props.startAt);
|
|
31
51
|
isFinished = false;
|
|
32
52
|
isPaused = false;
|
|
33
53
|
setCurrent();
|
|
@@ -36,13 +56,12 @@ export function useCountdown(props, emits) {
|
|
|
36
56
|
frame();
|
|
37
57
|
}
|
|
38
58
|
}
|
|
39
|
-
let previousFrameTime = 0;
|
|
40
59
|
function frame(timestamp) {
|
|
41
60
|
const now = performance.now();
|
|
42
61
|
const current = getCurrent(now);
|
|
43
62
|
let isLastFrame = false;
|
|
44
63
|
if (isPaused) {
|
|
45
|
-
if (
|
|
64
|
+
if (shouldFinish(current)) {
|
|
46
65
|
isLastFrame = true;
|
|
47
66
|
} else {
|
|
48
67
|
return;
|
|
@@ -53,11 +72,15 @@ export function useCountdown(props, emits) {
|
|
|
53
72
|
return;
|
|
54
73
|
}
|
|
55
74
|
previousFrameTime = timestamp;
|
|
56
|
-
if (
|
|
75
|
+
if (shouldFinish(current)) {
|
|
57
76
|
finish();
|
|
58
77
|
return;
|
|
59
78
|
}
|
|
60
|
-
|
|
79
|
+
if (props.invert) {
|
|
80
|
+
timeRef.value = isInfiniteCountup.value ? current : Math.min(current, totalDuration.value);
|
|
81
|
+
} else {
|
|
82
|
+
timeRef.value = Math.max(0, current);
|
|
83
|
+
}
|
|
61
84
|
requestAnimationFrame(frame);
|
|
62
85
|
}
|
|
63
86
|
const unwatchActive = watch(
|
|
@@ -66,9 +89,10 @@ export function useCountdown(props, emits) {
|
|
|
66
89
|
emits("change", isActive);
|
|
67
90
|
if (isActive) {
|
|
68
91
|
if (isPaused) {
|
|
69
|
-
|
|
92
|
+
const elapsed = props.invert ? timeRef.value : totalDuration.value - timeRef.value;
|
|
93
|
+
startTimestamp = performance.now() - elapsed;
|
|
70
94
|
} else {
|
|
71
|
-
startTimestamp = performance.now();
|
|
95
|
+
startTimestamp = performance.now() - formatTime(props.startAt);
|
|
72
96
|
}
|
|
73
97
|
isPaused = false;
|
|
74
98
|
if (isFinished && props.autoReset) {
|
|
@@ -84,7 +108,7 @@ export function useCountdown(props, emits) {
|
|
|
84
108
|
{ immediate: true }
|
|
85
109
|
);
|
|
86
110
|
const unwatchTimes = watch(
|
|
87
|
-
() => [props.durations, props.endTime],
|
|
111
|
+
() => [props.durations, props.endTime, props.startAt],
|
|
88
112
|
() => {
|
|
89
113
|
setCurrent();
|
|
90
114
|
isFinished = false;
|
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
import type { Ref } from 'vue';
|
|
2
2
|
interface UseDelayChangeReturnType<T> {
|
|
3
3
|
value: Ref<T>;
|
|
4
|
-
setValue: (value: T) => void;
|
|
5
|
-
setValueDelay: (value: T) => void;
|
|
4
|
+
setValue: (value: T, immediate?: boolean) => void;
|
|
6
5
|
}
|
|
7
|
-
export declare function useDelayChange<T>(defaultValue: T,
|
|
6
|
+
export declare function useDelayChange<T>(defaultValue: T, delayMs?: number): UseDelayChangeReturnType<T>;
|
|
8
7
|
export {};
|
|
@@ -1,20 +1,19 @@
|
|
|
1
1
|
import { shallowRef } from "vue";
|
|
2
|
-
export function useDelayChange(defaultValue,
|
|
3
|
-
const delayValue = shallowRef(defaultValue);
|
|
2
|
+
export function useDelayChange(defaultValue, delayMs = 1e3) {
|
|
4
3
|
let timerId;
|
|
5
|
-
|
|
4
|
+
const delayValue = shallowRef(defaultValue);
|
|
5
|
+
function setValue(newValue, immediate = false) {
|
|
6
6
|
clearTimeout(timerId);
|
|
7
|
+
if (immediate) {
|
|
8
|
+
delayValue.value = newValue;
|
|
9
|
+
return;
|
|
10
|
+
}
|
|
7
11
|
timerId = setTimeout(() => {
|
|
8
|
-
|
|
9
|
-
},
|
|
10
|
-
}
|
|
11
|
-
function setValue(value) {
|
|
12
|
-
clearTimeout(timerId);
|
|
13
|
-
delayValue.value = value;
|
|
12
|
+
delayValue.value = newValue;
|
|
13
|
+
}, delayMs);
|
|
14
14
|
}
|
|
15
15
|
return {
|
|
16
16
|
value: delayValue,
|
|
17
|
-
setValueDelay,
|
|
18
17
|
setValue
|
|
19
18
|
};
|
|
20
19
|
}
|
|
@@ -10,7 +10,7 @@ interface Options {
|
|
|
10
10
|
}
|
|
11
11
|
type RequireAllExcept<T, K extends keyof T> = Required<Omit<T, K>> & Pick<T, K>;
|
|
12
12
|
type RequiredOptionsExceptType = RequireAllExcept<Options, 'type'>;
|
|
13
|
-
export interface
|
|
13
|
+
export interface MessageItem extends RequiredOptionsExceptType {
|
|
14
14
|
message: string | VNode;
|
|
15
15
|
_timerId?: ReturnType<typeof setTimeout>;
|
|
16
16
|
_remainingMs?: number;
|
package/dist/index.d.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import type { App } from 'vue';
|
|
2
2
|
export * from './components/index.js';
|
|
3
3
|
export * from './composables/index.js';
|
|
4
|
-
export
|
|
4
|
+
export type * from './types/shared';
|
|
5
|
+
export declare const version = "0.0.37";
|
|
5
6
|
export default function install(app: App, prefix?: string): void;
|
package/dist/index.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import * as components from "./components/index.js";
|
|
2
2
|
export * from "./components/index.js";
|
|
3
3
|
export * from "./composables/index.js";
|
|
4
|
-
export const version = "0.0.
|
|
4
|
+
export const version = "0.0.37";
|
|
5
5
|
export default function install(app, prefix = "P") {
|
|
6
6
|
Object.entries(components).forEach(([key, component]) => {
|
|
7
7
|
app.component(`${prefix}${key}`, component);
|
package/dist/styles/styles.css
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/*! tailwindcss v4.1.11 | MIT License | https://tailwindcss.com */
|
|
2
|
-
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-content:""}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-700:hsl(var(--color-red-700-value));--color-red-800:hsl(var(--color-red-800-value));--color-red-900:hsl(var(--color-red-900-value));--color-amber-600:hsl(var(--color-amber-600-value));--color-amber-700:hsl(var(--color-amber-700-value));--color-amber-800:hsl(var(--color-amber-800-value));--color-green-300:hsl(var(--color-green-300-value));--color-green-500:hsl(var(--color-green-500-value));--color-green-700:hsl(var(--color-green-700-value));--color-green-900:hsl(var(--color-green-900-value));--color-blue-700:hsl(var(--color-blue-700-value));--color-violet-100:oklch(94.3% .029 294.588);--color-violet-200:oklch(89.4% .057 293.283);--color-violet-400:oklch(70.2% .183 293.541);--color-violet-900:oklch(38% .189 293.745);--color-gray-100:hsl(var(--color-gray-100-value));--color-gray-200:hsl(var(--color-gray-200-value));--color-gray-300:hsl(var(--color-gray-300-value));--color-gray-500:hsl(var(--color-gray-500-value));--color-gray-600:hsl(var(--color-gray-600-value));--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-xs:20rem;--container-sm:24rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-base:1rem;--text-base--line-height:calc(1.5/1);--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--tracking-tight:-.025em;--radius-xs:.125rem;--animate-spin:spin 1s linear infinite;--blur-xs:4px;--default-transition-duration:.2s;--default-transition-timing-function:ease-in-out;--color-primary:hsl(var(--primary));--color-border:hsl(var(--color-gray-300-value));--color-foreground:hsl(var(--color-gray-1000-value));--color-foreground-secondary:hsl(var(--color-gray-900-value));--color-background-100:hsl(var(--background-100-value));--color-gray-alpha-100:var(--color-gray-alpha-100-value);--color-gray-alpha-200:var(--color-gray-alpha-200-value);--color-gray-alpha-300:var(--color-gray-alpha-300-value);--color-gray-alpha-400:var(--color-gray-alpha-400-value);--color-gray-alpha-500:var(--color-gray-alpha-500-value);--color-gray-alpha-600:var(--color-gray-alpha-600-value);--shadow-border-default:var(--shadow-border-default-value);--shadow-border-small:var(--shadow-border-small-value);--shadow-border-medium:var(--shadow-border-medium-value);--shadow-border-large:var(--shadow-border-large-value);--shadow-border-tooltip:var(--shadow-border-tooltip-value);--shadow-border-menu:var(--shadow-border-menu-value);--shadow-border-modal:var(--shadow-border-modal-value);--shadow-border-fullscreen:var(--shadow-border-fullscreen-value)}}@layer base{*{border-color:hsl(var(--color-gray-300-value))}}@layer components{.pxd-input--border{border:1px solid var(--border-color,var(--color-gray-alpha-300))}.pxd-input--border:not(.is-disabled,.is-readonly):hover,.pxd-input--border:not(.is-disabled,.is-readonly):focus-within{--border-color:var(--color-primary)}.pxd-input--border:not(.is-disabled,.is-readonly):focus-within{box-shadow:0 0 0 3px hsla(var(--primary),.2)}.pxd-input--border.is-error:not(:focus)::placeholder{color:var(--color-red-900)!important}.pxd-input--border.is-error,.pxd-input--border.is-error:focus-within{--border-color:hsl(var(--color-red-900-value));box-shadow:0 0 0 3px hsl(var(--color-red-300-value))}.pxd-input--border.is-error:focus-within,.pxd-input--border.is-error:not(.is-disabled,.is-readonly):hover{--border-color:hsl(var(--color-red-900-value));box-shadow:0 0 0 3px hsl(var(--color-red-500-value))}.pxd-form--label{max-width:100%;margin-bottom:calc(var(--spacing)*1.5);font-size:var(--text-sm);color:var(--color-foreground-secondary)}}@layer utilities{.pointer-events-none{pointer-events:none}.invisible{visibility:hidden}.visible{visibility:visible}.smallest{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.-inset-px{inset:-1px}.inset-0{inset:calc(var(--spacing)*0)}.-top-1{top:calc(var(--spacing)*-1)}.top-0{top:calc(var(--spacing)*0)}.top-1\.5{top:calc(var(--spacing)*1.5)}.top-1\/2{top:50%}.-right-5{right:calc(var(--spacing)*-5)}.right-0{right:calc(var(--spacing)*0)}.right-1{right:calc(var(--spacing)*1)}.right-1\.5{right:calc(var(--spacing)*1.5)}.-bottom-1{bottom:calc(var(--spacing)*-1)}.bottom-0{bottom:calc(var(--spacing)*0)}.-left-1{left:calc(var(--spacing)*-1)}.-left-5{left:calc(var(--spacing)*-5)}.left-0{left:calc(var(--spacing)*0)}.left-px{left:1px}.isolate{isolation:isolate}.z-\(--z\,10\){z-index:var(--z,10)}.z-0{z-index:0}.z-1{z-index:1}.z-10{z-index:10}.z-20{z-index:20}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.container\!{width:100%!important}@media (min-width:40rem){.container\!{max-width:40rem!important}}@media (min-width:48rem){.container\!{max-width:48rem!important}}@media (min-width:64rem){.container\!{max-width:64rem!important}}@media (min-width:80rem){.container\!{max-width:80rem!important}}@media (min-width:96rem){.container\!{max-width:96rem!important}}.m-0{margin:calc(var(--spacing)*0)}.mx-auto{margin-inline:auto}.mx-px{margin-inline:1px}.mt-\(--mt\){margin-top:var(--mt)}.mt-0\.5{margin-top:calc(var(--spacing)*.5)}.mt-1\.5{margin-top:calc(var(--spacing)*1.5)}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-3{margin-top:calc(var(--spacing)*3)}.mt-4{margin-top:calc(var(--spacing)*4)}.mr-1{margin-right:calc(var(--spacing)*1)}.mr-1\.5{margin-right:calc(var(--spacing)*1.5)}.mr-2{margin-right:calc(var(--spacing)*2)}.mr-3{margin-right:calc(var(--spacing)*3)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.-ml-0\.5{margin-left:calc(var(--spacing)*-.5)}.-ml-3{margin-left:calc(var(--spacing)*-3)}.ml-1{margin-left:calc(var(--spacing)*1)}.ml-1\.5{margin-left:calc(var(--spacing)*1.5)}.ml-3{margin-left:calc(var(--spacing)*3)}.scrollbar-hidden{scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}.scrollbar-hidden::-webkit-scrollbar{display:none}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.aspect-square{aspect-ratio:1}.size-\(--size\){width:var(--size);height:var(--size)}.size-1\/2{width:50%;height:50%}.size-3{width:calc(var(--spacing)*3);height:calc(var(--spacing)*3)}.size-4{width:calc(var(--spacing)*4);height:calc(var(--spacing)*4)}.size-6{width:calc(var(--spacing)*6);height:calc(var(--spacing)*6)}.size-15{width:calc(var(--spacing)*15);height:calc(var(--spacing)*15)}.size-\[calc\(1em\/4\)\]{width:.25em;height:.25em}.size-em{width:1em;height:1em}.size-full{width:100%;height:100%}.size-max{width:max-content;height:max-content}.h-\(--h\){height:var(--h)}.h-\(--scrollbar-size\){height:var(--scrollbar-size)}.h-0\.5{height:calc(var(--spacing)*.5)}.h-2{height:calc(var(--spacing)*2)}.h-2\.5{height:calc(var(--spacing)*2.5)}.h-3{height:calc(var(--spacing)*3)}.h-3\.5{height:calc(var(--spacing)*3.5)}.h-4{height:calc(var(--spacing)*4)}.h-4\.5{height:calc(var(--spacing)*4.5)}.h-5{height:calc(var(--spacing)*5)}.h-6{height:calc(var(--spacing)*6)}.h-7\.5{height:calc(var(--spacing)*7.5)}.h-9{height:calc(var(--spacing)*9)}.h-10{height:calc(var(--spacing)*10)}.h-full{height:100%}.h-max{height:max-content}.max-h-68{max-height:calc(var(--spacing)*68)}.max-h-full{max-height:100%}.min-h-0{min-height:calc(var(--spacing)*0)}.min-h-3\.5{min-height:calc(var(--spacing)*3.5)}.min-h-7\.5{min-height:calc(var(--spacing)*7.5)}.min-h-9{min-height:calc(var(--spacing)*9)}.min-h-10{min-height:calc(var(--spacing)*10)}.min-h-13{min-height:calc(var(--spacing)*13)}.min-h-\[inherit\]{min-height:inherit}.w-\(--scrollbar-size\){width:var(--scrollbar-size)}.w-\(--w\){width:var(--w)}.w-1\.5{width:calc(var(--spacing)*1.5)}.w-2{width:calc(var(--spacing)*2)}.w-2\.5{width:calc(var(--spacing)*2.5)}.w-3{width:calc(var(--spacing)*3)}.w-6{width:calc(var(--spacing)*6)}.w-7{width:calc(var(--spacing)*7)}.w-7\.5{width:calc(var(--spacing)*7.5)}.w-9{width:calc(var(--spacing)*9)}.w-10{width:calc(var(--spacing)*10)}.w-11{width:calc(var(--spacing)*11)}.w-fit{width:fit-content}.w-full{width:100%}.w-max{width:max-content}.max-w-full{max-width:100%}.max-w-sm{max-width:var(--container-sm)}.min-w-0{min-width:calc(var(--spacing)*0)}.min-w-3{min-width:calc(var(--spacing)*3)}.min-w-full{min-width:100%}.flex-1{flex:1}.shrink-0{flex-shrink:0}.border-separate{border-collapse:separate}.-translate-x-1\/2{--tw-translate-x:calc(calc(1/2*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-x-\(--tx\){--tw-translate-x:var(--tx);translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-x-1\/2{--tw-translate-x:calc(1/2*100%);translate:var(--tw-translate-x)var(--tw-translate-y)}.-translate-y-1\/2{--tw-translate-y:calc(calc(1/2*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.-translate-y-1\/3{--tw-translate-y:calc(calc(1/3*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-z-0{--tw-translate-z:calc(var(--spacing)*0);translate:var(--tw-translate-x)var(--tw-translate-y)var(--tw-translate-z)}.scale-125{--tw-scale-x:125%;--tw-scale-y:125%;--tw-scale-z:125%;scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-130{--tw-scale-x:130%;--tw-scale-y:130%;--tw-scale-z:130%;scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-y-90{--tw-scale-y:90%;scale:var(--tw-scale-x)var(--tw-scale-y)}.-rotate-\[85deg\]{rotate:-85deg}.rotate-180{rotate:180deg}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.transform-gpu{transform:translateZ(0)var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.touch-manipulation{touch-action:manipulation}.touch-none{touch-action:none}.resize{resize:both}.resize-none{resize:none}.list-none{list-style-type:none}.appearance-none{appearance:none}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.items-stretch{align-items:stretch}.justify-around{justify-content:space-around}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-evenly{justify-content:space-evenly}.justify-start{justify-content:flex-start}.justify-stretch{justify-content:stretch}.gap-\(--gap-xs\){gap:var(--gap-xs)}.gap-1{gap:calc(var(--spacing)*1)}.gap-1\.5{gap:calc(var(--spacing)*1.5)}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*6)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*6)*calc(1 - var(--tw-space-y-reverse)))}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-scroll{overflow:scroll}.overflow-visible{overflow:visible}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-inherit{border-radius:inherit}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-none{border-radius:0}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:calc(var(--radius) + 4px)}.rounded-xs{border-radius:var(--radius-xs)}.rounded-t-lg{border-top-left-radius:var(--radius);border-top-right-radius:var(--radius)}.rounded-l-inherit{border-top-left-radius:inherit;border-bottom-left-radius:inherit}.rounded-r-inherit{border-top-right-radius:inherit;border-bottom-right-radius:inherit}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-none{--tw-border-style:none;border-style:none}.border-amber-100{border-color:hsl(var(--color-amber-100-value))}.border-amber-500{border-color:hsl(var(--color-amber-500-value))}.border-background-100{border-color:hsl(var(--background-100-value))}.border-blue-100{border-color:hsl(var(--color-blue-100-value))}.border-blue-500{border-color:hsl(var(--color-blue-500-value))}.border-gray-100{border-color:hsl(var(--color-gray-100-value))}.border-gray-400{border-color:hsl(var(--color-gray-400-value))}.border-gray-500{border-color:hsl(var(--color-gray-500-value))}.border-gray-600{border-color:hsl(var(--color-gray-600-value))}.border-gray-alpha-300{border-color:var(--color-gray-alpha-300-value)}.border-gray-alpha-400{border-color:var(--color-gray-alpha-400-value)}.border-input{border-color:var(--color-gray-alpha-300)}.border-primary{border-color:hsl(var(--primary))}.border-red-100{border-color:hsl(var(--color-red-100-value))}.border-red-500{border-color:hsl(var(--color-red-500-value))}.border-teal-100{border-color:hsl(var(--color-teal-100-value))}.border-teal-400{border-color:hsl(var(--color-teal-400-value))}.border-transparent{border-color:#0000}.border-violet-100{border-color:var(--color-violet-100)}.border-violet-400{border-color:var(--color-violet-400)}.\!bg-primary{background-color:hsl(var(--primary))!important}.bg-\(--color\){background-color:var(--color)}.bg-\(--ibc\){background-color:var(--ibc)}.bg-\(--mc\){background-color:var(--mc)}.bg-\(--scrollbar-color\){background-color:var(--scrollbar-color)}.bg-\[\#26C941\]{background-color:#26c941}.bg-\[\#FE5F57\]{background-color:#fe5f57}.bg-\[\#FEBB2E\]{background-color:#febb2e}.bg-amber-200{background-color:hsl(var(--color-amber-200-value))}.bg-amber-600{background-color:hsl(var(--color-amber-600-value))}.bg-amber-700{background-color:hsl(var(--color-amber-700-value))}.bg-amber-800{background-color:hsl(var(--color-amber-800-value))}.bg-background-100{background-color:hsl(var(--background-100-value))}.bg-background-200{background-color:hsl(var(--background-200-value))}.bg-black\/40{background-color:#0006}@supports (color:color-mix(in lab, red, red)){.bg-black\/40{background-color:color-mix(in oklab,var(--color-black)40%,transparent)}}.bg-blue-200{background-color:hsl(var(--color-blue-200-value))}.bg-blue-700{background-color:hsl(var(--color-blue-700-value))}.bg-border{background-color:hsl(var(--color-gray-300-value))}.bg-current{background-color:currentColor}.bg-gray-100{background-color:hsl(var(--color-gray-100-value))}.bg-gray-200{background-color:hsl(var(--color-gray-200-value))}.bg-gray-600{background-color:hsl(var(--color-gray-600-value))}.bg-gray-700{background-color:hsl(var(--color-gray-700-value))}.bg-gray-900{background-color:hsl(var(--color-gray-900-value))}.bg-gray-1000{background-color:hsl(var(--color-gray-1000-value))}.bg-gray-alpha-100{background-color:var(--color-gray-alpha-100-value)}.bg-gray-alpha-200{background-color:var(--color-gray-alpha-200-value)}.bg-gray-alpha-400{background-color:var(--color-gray-alpha-400-value)}.bg-green-200{background-color:hsl(var(--color-green-200-value))}.bg-green-700{background-color:hsl(var(--color-green-700-value))}.bg-green-800{background-color:hsl(var(--color-green-800-value))}.bg-pink-200{background-color:hsl(var(--color-pink-200-value))}.bg-pink-700{background-color:hsl(var(--color-pink-700-value))}.bg-primary{background-color:hsl(var(--primary))}.bg-purple-200{background-color:hsl(var(--color-purple-200-value))}.bg-purple-700{background-color:hsl(var(--color-purple-700-value))}.bg-red-200{background-color:hsl(var(--color-red-200-value))}.bg-red-700{background-color:hsl(var(--color-red-700-value))}.bg-red-800{background-color:hsl(var(--color-red-800-value))}.bg-teal-200{background-color:hsl(var(--color-teal-200-value))}.bg-teal-600{background-color:hsl(var(--color-teal-600-value))}.bg-teal-700{background-color:hsl(var(--color-teal-700-value))}.bg-transparent{background-color:#0000}.bg-violet-200{background-color:var(--color-violet-200)}.bg-cover{background-size:cover}.object-cover{object-fit:cover}.\!p-0{padding:calc(var(--spacing)*0)!important}.p-0{padding:calc(var(--spacing)*0)}.p-1{padding:calc(var(--spacing)*1)}.p-1\.5{padding:calc(var(--spacing)*1.5)}.p-2{padding:calc(var(--spacing)*2)}.p-3{padding:calc(var(--spacing)*3)}.p-3\.5{padding:calc(var(--spacing)*3.5)}.p-4{padding:calc(var(--spacing)*4)}.p-6{padding:calc(var(--spacing)*6)}.p-px{padding:1px}.px-1{padding-inline:calc(var(--spacing)*1)}.px-1\.5{padding-inline:calc(var(--spacing)*1.5)}.px-2{padding-inline:calc(var(--spacing)*2)}.px-2\.5{padding-inline:calc(var(--spacing)*2.5)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-3\.5{padding-inline:calc(var(--spacing)*3.5)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-5{padding-inline:calc(var(--spacing)*5)}.px-6{padding-inline:calc(var(--spacing)*6)}.px-18{padding-inline:calc(var(--spacing)*18)}.py-1{padding-block:calc(var(--spacing)*1)}.py-1\.5{padding-block:calc(var(--spacing)*1.5)}.py-2{padding-block:calc(var(--spacing)*2)}.py-2\.5{padding-block:calc(var(--spacing)*2.5)}.py-3{padding-block:calc(var(--spacing)*3)}.py-12{padding-block:calc(var(--spacing)*12)}.py-\[3px\]{padding-block:3px}.pr-0{padding-right:calc(var(--spacing)*0)}.pr-0\.5{padding-right:calc(var(--spacing)*.5)}.pr-1{padding-right:calc(var(--spacing)*1)}.pr-1\.5{padding-right:calc(var(--spacing)*1.5)}.pr-2{padding-right:calc(var(--spacing)*2)}.pr-2\.5{padding-right:calc(var(--spacing)*2.5)}.pr-3\.5{padding-right:calc(var(--spacing)*3.5)}.pr-5{padding-right:calc(var(--spacing)*5)}.pr-6{padding-right:calc(var(--spacing)*6)}.pr-9{padding-right:calc(var(--spacing)*9)}.pr-12{padding-right:calc(var(--spacing)*12)}.pr-\[3px\]{padding-right:3px}.pb-5{padding-bottom:calc(var(--spacing)*5)}.pl-0\.5{padding-left:calc(var(--spacing)*.5)}.pl-1\.5{padding-left:calc(var(--spacing)*1.5)}.pl-2{padding-left:calc(var(--spacing)*2)}.pl-2\.5{padding-left:calc(var(--spacing)*2.5)}.pl-3\.5{padding-left:calc(var(--spacing)*3.5)}.pl-6{padding-left:calc(var(--spacing)*6)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-mono{font-family:var(--font-mono)}.font-sans{font-family:var(--font-sans)}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[13px\]{font-size:13px}.leading-4{--tw-leading:calc(var(--spacing)*4);line-height:calc(var(--spacing)*4)}.leading-none{--tw-leading:1;line-height:1}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.text-balance{text-wrap:balance}.text-nowrap{text-wrap:nowrap}.break-words{overflow-wrap:break-word}.break-all{word-break:break-all}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-line{white-space:pre-line}.text-amber-900{color:hsl(var(--color-amber-900-value))}.text-background-100{color:hsl(var(--background-100-value))}.text-black{color:var(--color-black)}.text-blue-900{color:hsl(var(--color-blue-900-value))}.text-foreground{color:hsl(var(--color-gray-1000-value))}.text-foreground-secondary{color:hsl(var(--color-gray-900-value))}.text-gray-100{color:hsl(var(--color-gray-100-value))}.text-gray-500{color:hsl(var(--color-gray-500-value))}.text-gray-700{color:hsl(var(--color-gray-700-value))}.text-gray-900{color:hsl(var(--color-gray-900-value))}.text-gray-1000{color:hsl(var(--color-gray-1000-value))}.text-green-900{color:hsl(var(--color-green-900-value))}.text-pink-900{color:hsl(var(--color-pink-900-value))}.text-primary{color:hsl(var(--primary))}.text-purple-900{color:hsl(var(--color-purple-900-value))}.text-red-900{color:hsl(var(--color-red-900-value))}.text-teal-900{color:hsl(var(--color-teal-900-value))}.text-violet-900{color:var(--color-violet-900)}.text-white{color:var(--color-white)}.capitalize{text-transform:capitalize}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,)var(--tw-slashed-zero,)var(--tw-numeric-figure,)var(--tw-numeric-spacing,)var(--tw-numeric-fraction,)}.\!no-underline{text-decoration-line:none!important}.underline{text-decoration-line:underline}.opacity-\(--sv\){opacity:var(--sv)}.opacity-0{opacity:0}.opacity-20{opacity:.2}.opacity-50{opacity:.5}.opacity-100{opacity:1}.mix-blend-overlay{mix-blend-mode:overlay}.shadow-border-menu{--tw-shadow:var(--shadow-border-menu-value);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-border-modal{--tw-shadow:var(--shadow-border-modal-value);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-border-small{--tw-shadow:var(--shadow-border-small-value);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-border-tooltip{--tw-shadow:var(--shadow-border-tooltip-value);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.peer:focus-visible~.peer-focus-ring,.self-focus-ring:focus-visible{box-shadow:0 0 0 2px var(--color-background-100),0 0 0 4px hsl(var(--ring))}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.backdrop-blur-xs{--tw-backdrop-blur:blur(var(--blur-xs));-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,visibility,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.duration-50{--tw-duration:50ms;transition-duration:50ms}.duration-300{--tw-duration:.3s;transition-duration:.3s}.duration-500{--tw-duration:.5s;transition-duration:.5s}.will-change-transform{will-change:transform}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.\[--book-width\:var\(--width-xs\)\]{--book-width:var(--width-xs)}.\[--mt\:2px\]{--mt:2px}.\[--mt\:4px\]{--mt:4px}.\[--tx\:0\]{--tx:0}.transform-3d{transform-style:preserve-3d}@media (hover:hover){.group-hover\:text-foreground:is(:where(.group):hover *){color:hsl(var(--color-gray-1000-value))}.group-hover\/checkbox\:bg-gray-200:is(:where(.group\/checkbox):hover *){background-color:hsl(var(--color-gray-200-value))}.group-hover\/collapse\:will-change-\[height\]:is(:where(.group\/collapse):hover *){will-change:height}.group-hover\/radio\:bg-gray-200:is(:where(.group\/radio):hover *){background-color:hsl(var(--color-gray-200-value))}.group-hover\/toggle\:will-change-transform:is(:where(.group\/toggle):hover *){will-change:transform}}.group-data-\[direction\=horizontal\]\:flex:is(:where(.group)[data-direction=horizontal] *){display:flex}.group-data-\[direction\=vertical\]\:rotate-90:is(:where(.group)[data-direction=vertical] *){rotate:90deg}.group-data-\[header\=true\]\:pt-5:is(:where(.group)[data-header=true] *){padding-top:calc(var(--spacing)*5)}.group-data-\[indicator-position\=left\]\:flex-col:is(:where(.group)[data-indicator-position=left] *),.group-data-\[indicator-position\=right\]\:flex-col:is(:where(.group)[data-indicator-position=right] *){flex-direction:column}.group-data-\[state\=open\]\/collapse\:-rotate-180:is(:where(.group\/collapse)[data-state=open] *){rotate:-180deg}.peer-checked\:bg-\(--abc\):is(:where(.peer):checked~*){background-color:var(--abc)}.peer-checked\:bg-gray-100:is(:where(.peer):checked~*){background-color:hsl(var(--color-gray-100-value))}.peer-checked\:text-foreground:is(:where(.peer):checked~*){color:hsl(var(--color-gray-1000-value))}.peer-checked\:opacity-50:is(:where(.peer):checked~*){opacity:.5}.peer-checked\:opacity-100:is(:where(.peer):checked~*){opacity:1}.peer-checked\:\[--tx\:100\%\]:is(:where(.peer):checked~*){--tx:100%}.peer-disabled\:cursor-not-allowed:is(:where(.peer):disabled~*){cursor:not-allowed}.peer-disabled\:text-gray-800:is(:where(.peer):disabled~*){color:hsl(var(--color-gray-800-value))}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:font-medium::file-selector-button{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.placeholder\:text-gray-600::placeholder{color:hsl(var(--color-gray-600-value))}.placeholder\:select-none::placeholder{-webkit-user-select:none;user-select:none}.before\:content-\[attr\(data-prompt\)\]:before{content:var(--tw-content);--tw-content:attr(data-prompt);content:var(--tw-content)}.before\:select-none:before{content:var(--tw-content);-webkit-user-select:none;user-select:none}.after\:size-2:after{content:var(--tw-content);width:calc(var(--spacing)*2);height:calc(var(--spacing)*2)}.after\:scale-40:after{content:var(--tw-content);--tw-scale-x:40%;--tw-scale-y:40%;--tw-scale-z:40%;scale:var(--tw-scale-x)var(--tw-scale-y)}.after\:rounded-full:after{content:var(--tw-content);border-radius:3.40282e38px}.after\:bg-gray-500:after{content:var(--tw-content);background-color:hsl(var(--color-gray-500-value))}.after\:bg-primary:after{content:var(--tw-content);background-color:hsl(var(--primary))}.after\:opacity-0:after{content:var(--tw-content);opacity:0}.after\:content-\[attr\(aria-label\)\]:after{content:var(--tw-content);--tw-content:attr(aria-label);content:var(--tw-content)}.peer-checked\:after\:scale-100:is(:where(.peer):checked~*):after{content:var(--tw-content);--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x)var(--tw-scale-y)}.peer-checked\:after\:opacity-100:is(:where(.peer):checked~*):after{content:var(--tw-content);opacity:1}.first\:justify-start:first-child{justify-content:flex-start}.last\:justify-end:last-child{justify-content:flex-end}.empty\:hidden:empty{display:none}.empty\:py-3:empty{padding-block:calc(var(--spacing)*3)}@media (hover:hover){.hover\:z-1:hover{z-index:1}.hover\:scale-130:hover{--tw-scale-x:130%;--tw-scale-y:130%;--tw-scale-z:130%;scale:var(--tw-scale-x)var(--tw-scale-y)}.hover\:border-gray-500:hover{border-color:hsl(var(--color-gray-500-value))}.hover\:bg-\(--scrollbar-hover-color\):hover{background-color:var(--scrollbar-hover-color)}.hover\:bg-amber-700:hover{background-color:hsl(var(--color-amber-700-value))}.hover\:bg-background-hover:hover{background-color:var(--color-gray-alpha-200-value)}.hover\:bg-gray-100:hover{background-color:hsl(var(--color-gray-100-value))}.hover\:bg-gray-alpha-400:hover{background-color:var(--color-gray-alpha-400-value)}.hover\:bg-green-700:hover{background-color:hsl(var(--color-green-700-value))}.hover\:bg-primary\/80:hover{background-color:hsl(var(--primary))}@supports (color:color-mix(in lab, red, red)){.hover\:bg-primary\/80:hover{background-color:color-mix(in oklab,hsl(var(--primary))80%,transparent)}}.hover\:bg-red-700:hover{background-color:hsl(var(--color-red-700-value))}.hover\:text-foreground:hover{color:hsl(var(--color-gray-1000-value))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-60:hover{opacity:.6}.hover\:will-change-transform:hover{will-change:transform}.hover\:\[--sv\:1\]:hover{--sv:1}.hover\:after\:bg-primary\/20:hover:after{content:var(--tw-content);background-color:hsl(var(--primary))}@supports (color:color-mix(in lab, red, red)){.hover\:after\:bg-primary\/20:hover:after{background-color:color-mix(in oklab,hsl(var(--primary))20%,transparent)}}}.focus\:placeholder\:opacity-0:focus::placeholder{opacity:0}.active\:z-1:active{z-index:1}.active\:scale-130:active{--tw-scale-x:130%;--tw-scale-y:130%;--tw-scale-z:130%;scale:var(--tw-scale-x)var(--tw-scale-y)}.active\:bg-\(--scrollbar-hover-color\):active{background-color:var(--scrollbar-hover-color)}.active\:bg-amber-900:active{background-color:hsl(var(--color-amber-900-value))}.active\:bg-background-active:active{background-color:var(--color-gray-alpha-300-value)}.active\:bg-gray-100:active{background-color:hsl(var(--color-gray-100-value))}.active\:bg-gray-900:active{background-color:hsl(var(--color-gray-900-value))}.active\:bg-green-900:active{background-color:hsl(var(--color-green-900-value))}.active\:bg-red-900:active{background-color:hsl(var(--color-red-900-value))}.active\:opacity-80:active{opacity:.8}.active\:opacity-100:active{opacity:1}.active\:select-none:active{-webkit-user-select:none;user-select:none}.active\:after\:bg-primary\/30:active:after{content:var(--tw-content);background-color:hsl(var(--primary))}@supports (color:color-mix(in lab, red, red)){.active\:after\:bg-primary\/30:active:after{background-color:color-mix(in oklab,hsl(var(--primary))30%,transparent)}}@media (hover:hover){.enabled\:hover\:bg-background-hover:enabled:hover{background-color:var(--color-gray-alpha-200-value)}.enabled\:hover\:text-gray-1000:enabled:hover{color:hsl(var(--color-gray-1000-value))}}.enabled\:active\:bg-background-active:enabled:active{background-color:var(--color-gray-alpha-300-value)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:border-gray-300:disabled{border-color:hsl(var(--color-gray-300-value))}.disabled\:bg-gray-100:disabled{background-color:hsl(var(--color-gray-100-value))}.disabled\:text-gray-700:disabled{color:hsl(var(--color-gray-700-value))}.disabled\:placeholder\:text-gray-400:disabled::placeholder{color:hsl(var(--color-gray-400-value))}.data-\[blur\=true\]\:backdrop-blur-xs[data-blur=true]{--tw-backdrop-blur:blur(var(--blur-xs));-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.data-\[direction\=vertical\]\:flex-col[data-direction=vertical]{flex-direction:column}.data-\[disabled\=true\]\:pointer-events-none[data-disabled=true]{pointer-events:none}.data-\[disabled\=true\]\:text-gray-700[data-disabled=true]{color:hsl(var(--color-gray-700-value))}.data-\[enterable\=false\]\:pointer-events-none[data-enterable=false]{pointer-events:none}.data-\[selected\=true\]\:bg-amber-100[data-selected=true]{background-color:hsl(var(--color-amber-100-value))}.data-\[selected\=true\]\:bg-gray-alpha-100[data-selected=true]{background-color:var(--color-gray-alpha-100-value)}.data-\[selected\=true\]\:bg-red-100[data-selected=true]{background-color:hsl(var(--color-red-100-value))}@media (prefers-reduced-motion:no-preference){.motion-safe\:animate-spin{animation:var(--animate-spin)}.motion-safe\:transition-all{transition-property:all;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:duration-200{--tw-duration:.2s;transition-duration:.2s}}.after\:motion-safe\:transition-colors:after{content:var(--tw-content)}@media (prefers-reduced-motion:no-preference){.after\:motion-safe\:transition-colors:after{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:after\:transition-all:after{content:var(--tw-content);transition-property:all;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}}@media (prefers-reduced-motion:reduce){.motion-reduce\:opacity-20{opacity:.2}.motion-reduce\:opacity-50{opacity:.5}.motion-reduce\:opacity-80{opacity:.8}}@media not all and (min-width:64rem){.max-lg\:hidden{display:none}}@media not all and (min-width:48rem){.max-md\:hidden{display:none}.max-md\:first\:flex-none:first-child{flex:none}}@media (min-width:40rem){.sm\:top-1\/2{top:50%}.sm\:left-1\/2{left:50%}.sm\:w-\[calc\(var\(--w\,540\)\*1px\)\]{width:calc(var(--w,540)*1px)}.sm\:max-w-\(--max-width\){max-width:var(--max-width)}.sm\:-translate-x-1\/2{--tw-translate-x:calc(calc(1/2*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.sm\:-translate-y-1\/2{--tw-translate-y:calc(calc(1/2*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.sm\:flex-col{flex-direction:column}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:gap-\(--gap-sm\){gap:var(--gap-sm)}.sm\:rounded-xl{border-radius:calc(var(--radius) + 4px)}.sm\:bg-background-100\/80{background-color:hsl(var(--background-100-value))}@supports (color:color-mix(in lab, red, red)){.sm\:bg-background-100\/80{background-color:color-mix(in oklab,hsl(var(--background-100-value))80%,transparent)}}.sm\:pt-4{padding-top:calc(var(--spacing)*4)}.sm\:pb-4{padding-bottom:calc(var(--spacing)*4)}.sm\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.sm\:\[--book-width\:var\(--width-sm\)\]{--book-width:var(--width-sm)}.sm\:\[--h\:30vw\]{--h:30vw}.sm\:\[--o\:0\]{--o:0}.sm\:\[--sv\:0\]{--sv:0}.sm\:\[--t\:scale\(0\.98\)\]{--t:scale(.98)}.sm\:\[--w\:30vw\]{--w:30vw}.not-empty\:sm\:pointer-events-auto:not(:empty){pointer-events:auto}}@media (min-width:48rem){.md\:flex-col{flex-direction:column}.md\:flex-row{flex-direction:row}.md\:gap-\(--gap-md\){gap:var(--gap-md)}.md\:gap-6{gap:calc(var(--spacing)*6)}.md\:\[--book-width\:var\(--width-md\)\]{--book-width:var(--width-md)}.md\:first\:max-w-\[140px\]:first-child,.md\:last\:max-w-\[140px\]:last-child{max-width:140px}}@media (min-width:64rem){.lg\:max-w-xs{max-width:var(--container-xs)}.lg\:flex-col{flex-direction:column}.lg\:flex-row{flex-direction:row}.lg\:gap-\(--gap-lg\){gap:var(--gap-lg)}.lg\:text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.lg\:\[--book-width\:var\(--width-lg\)\]{--book-width:var(--width-lg)}}@media (min-width:80rem){.xl\:flex-col{flex-direction:column}.xl\:flex-row{flex-direction:row}.xl\:gap-\(--gap-xl\){gap:var(--gap-xl)}.xl\:text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.xl\:\[--book-width\:var\(--width-xl\)\]{--book-width:var(--width-xl)}}.dark\:bg-background-100:is(.dark *){background-color:hsl(var(--background-100-value))}.dark\:bg-background-200:is(.dark *){background-color:hsl(var(--background-200-value))}.dark\:text-gray-100:is(.dark *){color:hsl(var(--color-gray-100-value))}.dark\:text-gray-1000:is(.dark *){color:hsl(var(--color-gray-1000-value))}.\[\&\:nth-child\(n\+2\)\]\:-ml-2\.5:nth-child(n+2){margin-left:calc(var(--spacing)*-2.5)}}:root{--radius:.5rem;--background-100-value:0,0%,100%;--background-200-value:0,0%,97%;--ring:var(--color-blue-900-value);--primary:var(--color-gray-1000-value);--color-gray-alpha-100-value:#0000000d;--color-gray-alpha-200-value:#00000015;--color-gray-alpha-300-value:#0000001f;--color-gray-alpha-400-value:#0000002b;--color-gray-alpha-500-value:#00000036;--color-gray-alpha-600-value:#00000057;--color-gray-alpha-700-value:#00000070;--color-gray-alpha-800-value:#00000082;--color-gray-alpha-900-value:#0000009c;--color-gray-alpha-1000-value:#000000e8;--color-gray-100-value:0,0%,95%;--color-gray-200-value:0,0%,93%;--color-gray-300-value:0,0%,90%;--color-gray-400-value:0,0%,85%;--color-gray-500-value:0,0%,79%;--color-gray-600-value:0,0%,66%;--color-gray-700-value:0,0%,56%;--color-gray-800-value:0,0%,49%;--color-gray-900-value:0,0%,40%;--color-gray-1000-value:0,0%,9%;--color-blue-100-value:212,100%,97%;--color-blue-200-value:210,100%,96%;--color-blue-300-value:210,100%,94%;--color-blue-400-value:209,100%,90%;--color-blue-500-value:209,100%,80%;--color-blue-600-value:208,100%,66%;--color-blue-700-value:212,100%,48%;--color-blue-800-value:212,100%,41%;--color-blue-900-value:211,100%,42%;--color-blue-1000-value:211,100%,15%;--color-red-100-value:0,100%,97%;--color-red-200-value:0,100%,96%;--color-red-300-value:0,100%,95%;--color-red-400-value:0,90%,92%;--color-red-500-value:0,82%,85%;--color-red-600-value:359,90%,71%;--color-red-700-value:358,75%,59%;--color-red-800-value:358,70%,52%;--color-red-900-value:358,66%,48%;--color-red-1000-value:355,49%,15%;--color-amber-100-value:39,100%,95%;--color-amber-200-value:44,100%,92%;--color-amber-300-value:43,96%,90%;--color-amber-400-value:42,100%,78%;--color-amber-500-value:38,100%,71%;--color-amber-600-value:36,90%,62%;--color-amber-700-value:39,100%,57%;--color-amber-800-value:35,100%,52%;--color-amber-900-value:30,100%,32%;--color-amber-1000-value:20,79%,17%;--color-green-100-value:120,60%,96%;--color-green-200-value:120,60%,95%;--color-green-300-value:120,60%,91%;--color-green-400-value:122,60%,86%;--color-green-500-value:124,60%,75%;--color-green-600-value:125,60%,64%;--color-green-700-value:131,41%,46%;--color-green-800-value:132,43%,39%;--color-green-900-value:133,50%,32%;--color-green-1000-value:128,29%,15%;--color-teal-100-value:169,70%,96%;--color-teal-200-value:167,70%,94%;--color-teal-300-value:168,70%,90%;--color-teal-400-value:170,70%,85%;--color-teal-500-value:170,70%,72%;--color-teal-600-value:170,70%,57%;--color-teal-700-value:173,80%,36%;--color-teal-800-value:173,83%,30%;--color-teal-900-value:174,91%,25%;--color-teal-1000-value:171,80%,13%;--color-purple-100-value:276,100%,97%;--color-purple-200-value:277,87%,97%;--color-purple-300-value:274,78%,95%;--color-purple-400-value:276,71%,92%;--color-purple-500-value:274,70%,82%;--color-purple-600-value:273,72%,73%;--color-purple-700-value:272,51%,54%;--color-purple-800-value:272,47%,45%;--color-purple-900-value:274,71%,43%;--color-purple-1000-value:276,100%,15%;--color-pink-100-value:330,100%,96%;--color-pink-200-value:340,90%,96%;--color-pink-300-value:340,82%,94%;--color-pink-400-value:341,76%,91%;--color-pink-500-value:340,75%,84%;--color-pink-600-value:341,75%,73%;--color-pink-700-value:336,80%,58%;--color-pink-800-value:336,74%,51%;--color-pink-900-value:336,65%,45%;--color-pink-1000-value:333,74%,15%;--shadow-border-default-value:0 0 0 1px #00000014;--shadow-border-small-value:0 0 0 1px #00000014,0 1px 2px 0 #0000000a;--shadow-border-medium-value:0 0 0 1px #00000014,0px 2px 2px #0000000a,0px 8px 8px -8px #0000000a;--shadow-border-large-value:0 0 0 1px #00000014,0px 2px 2px #0000000a,0px 8px 16px -4px #0000000a;--shadow-border-tooltip-value:0 0 0 1px #00000014,0px 1px 1px #00000005,0px 4px 8px #0000000a;--shadow-border-menu-value:0 0 0 1px #00000014,0px 1px 1px #00000005,0px 4px 8px -4px #0000000a,0px 16px 24px -8px #0000000f;--shadow-border-modal-value:0 0 0 1px #00000014,0px 1px 1px #00000005,0px 8px 16px -4px #0000000a,0px 24px 32px -8px #0000000f;--shadow-border-fullscreen-value:0 0 0 1px #00000014,0px 1px 1px #00000005,0px 8px 16px -4px #0000000a,0px 24px 32px -8px #0000000f;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:none;-moz-text-size-adjust:none;text-size-adjust:none;text-autospace:auto;font-synthesis:none;color-scheme:light;background-color:var(--color-background-100);color:var(--color-foreground)}:root.dark{--background-100-value:0,0%,5%;--background-200-value:0,0%,0%;--color-gray-alpha-100-value:#ffffff0f;--color-gray-alpha-200-value:#ffffff17;--color-gray-alpha-300-value:#ffffff21;--color-gray-alpha-400-value:#ffffff24;--color-gray-alpha-500-value:#ffffff3d;--color-gray-alpha-600-value:#ffffff82;--color-gray-alpha-700-value:#ffffff8a;--color-gray-alpha-800-value:#ffffff78;--color-gray-alpha-900-value:#ffffff9c;--color-gray-alpha-1000-value:#ffffffeb;--color-gray-100-value:0,0%,10%;--color-gray-200-value:0,0%,12%;--color-gray-300-value:0,0%,16%;--color-gray-400-value:0,0%,18%;--color-gray-500-value:0,0%,27%;--color-gray-600-value:0,0%,53%;--color-gray-700-value:0,0%,56%;--color-gray-800-value:0,0%,49%;--color-gray-900-value:0,0%,63%;--color-gray-1000-value:0,0%,93%;--color-blue-100-value:216,50%,12%;--color-blue-200-value:214,59%,15%;--color-blue-300-value:213,71%,20%;--color-blue-400-value:212,78%,23%;--color-blue-500-value:211,86%,27%;--color-blue-600-value:206,100%,50%;--color-blue-700-value:212,100%,48%;--color-blue-800-value:212,100%,41%;--color-blue-900-value:210,100%,66%;--color-blue-1000-value:206,100%,96%;--color-red-100-value:357,37%,12%;--color-red-200-value:357,46%,16%;--color-red-300-value:356,54%,22%;--color-red-400-value:357,55%,26%;--color-red-500-value:357,60%,32%;--color-red-600-value:358,75%,59%;--color-red-700-value:358,75%,59%;--color-red-800-value:358,69%,52%;--color-red-900-value:358,100%,69%;--color-red-1000-value:353,90%,96%;--color-amber-100-value:35,100%,8%;--color-amber-200-value:32,100%,10%;--color-amber-300-value:33,100%,15%;--color-amber-400-value:35,100%,17%;--color-amber-500-value:35,91%,22%;--color-amber-600-value:39,85%,49%;--color-amber-700-value:39,100%,57%;--color-amber-800-value:35,100%,52%;--color-amber-900-value:39,90%,50%;--color-amber-1000-value:40,94%,93%;--color-green-100-value:136,50%,9%;--color-green-200-value:137,50%,12%;--color-green-300-value:136,50%,14%;--color-green-400-value:135,70%,16%;--color-green-500-value:135,70%,23%;--color-green-600-value:135,70%,34%;--color-green-700-value:131,41%,46%;--color-green-800-value:132,43%,39%;--color-green-900-value:131,43%,57%;--color-green-1000-value:136,73%,94%;--color-teal-100-value:169,78%,7%;--color-teal-200-value:170,74%,9%;--color-teal-300-value:171,75%,13%;--color-teal-400-value:171,85%,13%;--color-teal-500-value:172,85%,20%;--color-teal-600-value:172,85%,32%;--color-teal-700-value:173,80%,36%;--color-teal-800-value:173,83%,30%;--color-teal-900-value:174,90%,41%;--color-teal-1000-value:166,71%,93%;--color-purple-100-value:283,30%,12%;--color-purple-200-value:281,38%,16%;--color-purple-300-value:279,44%,23%;--color-purple-400-value:277,46%,28%;--color-purple-500-value:274,49%,35%;--color-purple-600-value:272,51%,54%;--color-purple-700-value:272,51%,54%;--color-purple-800-value:272,47%,45%;--color-purple-900-value:275,80%,71%;--color-purple-1000-value:281,73%,96%;--color-pink-100-value:335,32%,12%;--color-pink-200-value:335,43%,16%;--color-pink-300-value:335,47%,21%;--color-pink-400-value:335,51%,22%;--color-pink-500-value:335,57%,27%;--color-pink-600-value:336,75%,40%;--color-pink-700-value:336,80%,58%;--color-pink-800-value:336,74%,51%;--color-pink-900-value:341,90%,67%;--color-pink-1000-value:333,90%,96%;--shadow-border-default-value:0 0 0 1px #ffffff25;--shadow-border-small-value:0 0 0 1px #ffffff25,0 1px 2px 0 #0000000a;--shadow-border-medium-value:0 0 0 1px #ffffff25,0px 2px 2px #00000052,0px 8px 8px -8px #00000029;--shadow-border-large-value:0 0 0 1px #ffffff25,0px 2px 2px #0000000a,0px 8px 16px -4px #0000000a;--shadow-border-tooltip-value:0 0 0 1px #ffffff25,0px 1px 1px #00000005,0px 4px 8px #0000000a;--shadow-border-menu-value:0 0 0 1px #ffffff25,0px 1px 1px #00000005,0px 4px 8px -4px #0000000a,0px 16px 24px -8px #0000000f;--shadow-border-modal-value:0 0 0 1px #ffffff25,0px 1px 1px #00000005,0px 8px 16px -4px #0000000a,0px 24px 32px -8px #0000000f;--shadow-border-fullscreen-value:0 0 0 1px #ffffff25,0px 1px 1px #00000005,0px 8px 16px -4px #0000000a,0px 24px 32px -8px #0000000f;color-scheme:dark}@media (prefers-reduced-motion:reduce){:root{--default-transition-duration:0!important}}.pxd-transition--fade-enter-active,.pxd-transition--fade-leave-active{transition:opacity var(--default-transition-duration)var(--default-transition-timing-function)}.pxd-transition--fade-enter-from,.pxd-transition--fade-leave-to{opacity:0;will-change:opacity}.pxd-transition--fade-scale-move,.pxd-transition--fade-scale-enter-active,.pxd-transition--fade-scale-leave-active{transition:var(--default-transition-duration)var(--default-transition-timing-function);will-change:opacity,transform;transition-property:opacity,transform}.pxd-transition--fade-scale-enter-from,.pxd-transition--fade-scale-leave-to{opacity:0;transform:scale(var(--scale,.8))translateZ(0)}.line-clamp{text-overflow:ellipsis;-webkit-line-clamp:var(--line-clamp,1);-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.scroll-disabled-x{scrollbar-gutter:stable!important;overflow-x:clip!important}.scroll-disabled-y{scrollbar-gutter:stable!important;overflow-y:clip!important}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-content{syntax:"*";inherits:false;initial-value:""}@keyframes spin{to{transform:rotate(360deg)}}
|
|
2
|
+
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-content:""}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-700:hsl(var(--color-red-700-value));--color-red-800:hsl(var(--color-red-800-value));--color-red-900:hsl(var(--color-red-900-value));--color-amber-600:hsl(var(--color-amber-600-value));--color-amber-700:hsl(var(--color-amber-700-value));--color-amber-800:hsl(var(--color-amber-800-value));--color-green-300:hsl(var(--color-green-300-value));--color-green-500:hsl(var(--color-green-500-value));--color-green-700:hsl(var(--color-green-700-value));--color-green-900:hsl(var(--color-green-900-value));--color-blue-700:hsl(var(--color-blue-700-value));--color-violet-100:oklch(94.3% .029 294.588);--color-violet-200:oklch(89.4% .057 293.283);--color-violet-400:oklch(70.2% .183 293.541);--color-violet-900:oklch(38% .189 293.745);--color-gray-100:hsl(var(--color-gray-100-value));--color-gray-200:hsl(var(--color-gray-200-value));--color-gray-300:hsl(var(--color-gray-300-value));--color-gray-500:hsl(var(--color-gray-500-value));--color-gray-600:hsl(var(--color-gray-600-value));--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-xs:20rem;--container-sm:24rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-base:1rem;--text-base--line-height:calc(1.5/1);--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--tracking-tight:-.025em;--radius-xs:.125rem;--animate-spin:spin 1s linear infinite;--blur-xs:4px;--default-transition-duration:.2s;--default-transition-timing-function:ease-in-out;--color-primary:hsl(var(--primary));--color-border:hsl(var(--color-gray-300-value));--color-foreground:hsl(var(--color-gray-1000-value));--color-foreground-secondary:hsl(var(--color-gray-900-value));--color-background-100:hsl(var(--background-100-value));--color-gray-alpha-100:var(--color-gray-alpha-100-value);--color-gray-alpha-200:var(--color-gray-alpha-200-value);--color-gray-alpha-300:var(--color-gray-alpha-300-value);--color-gray-alpha-400:var(--color-gray-alpha-400-value);--color-gray-alpha-500:var(--color-gray-alpha-500-value);--color-gray-alpha-600:var(--color-gray-alpha-600-value);--shadow-border-default:var(--shadow-border-default-value);--shadow-border-small:var(--shadow-border-small-value);--shadow-border-medium:var(--shadow-border-medium-value);--shadow-border-large:var(--shadow-border-large-value);--shadow-border-tooltip:var(--shadow-border-tooltip-value);--shadow-border-menu:var(--shadow-border-menu-value);--shadow-border-modal:var(--shadow-border-modal-value);--shadow-border-fullscreen:var(--shadow-border-fullscreen-value)}}@layer base{*{border-color:hsl(var(--color-gray-300-value))}}@layer components{.pxd-input--border{border:1px solid var(--border-color,var(--color-gray-alpha-300))}.pxd-input--border:not(.is-disabled,.is-readonly):hover,.pxd-input--border:not(.is-disabled,.is-readonly):focus-within{--border-color:var(--color-primary)}.pxd-input--border:not(.is-disabled,.is-readonly):focus-within{box-shadow:0 0 0 3px hsla(var(--primary),.2)}.pxd-input--border.is-error:not(:focus)::placeholder{color:var(--color-red-900)!important}.pxd-input--border.is-error,.pxd-input--border.is-error:focus-within{--border-color:hsl(var(--color-red-900-value));box-shadow:0 0 0 3px hsl(var(--color-red-300-value))}.pxd-input--border.is-error:focus-within,.pxd-input--border.is-error:not(.is-disabled,.is-readonly):hover{--border-color:hsl(var(--color-red-900-value));box-shadow:0 0 0 3px hsl(var(--color-red-500-value))}.pxd-form--label{max-width:100%;margin-bottom:calc(var(--spacing)*1.5);font-size:var(--text-sm);color:var(--color-foreground-secondary)}}@layer utilities{.pointer-events-none{pointer-events:none}.invisible{visibility:hidden}.visible{visibility:visible}.smallest{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.-inset-px{inset:-1px}.inset-0{inset:calc(var(--spacing)*0)}.-top-1{top:calc(var(--spacing)*-1)}.top-0{top:calc(var(--spacing)*0)}.top-1\.5{top:calc(var(--spacing)*1.5)}.top-1\/2{top:50%}.-right-5{right:calc(var(--spacing)*-5)}.right-0{right:calc(var(--spacing)*0)}.right-1{right:calc(var(--spacing)*1)}.right-1\.5{right:calc(var(--spacing)*1.5)}.-bottom-1{bottom:calc(var(--spacing)*-1)}.bottom-0{bottom:calc(var(--spacing)*0)}.-left-1{left:calc(var(--spacing)*-1)}.-left-5{left:calc(var(--spacing)*-5)}.left-0{left:calc(var(--spacing)*0)}.left-px{left:1px}.isolate{isolation:isolate}.z-\(--z\,10\){z-index:var(--z,10)}.z-0{z-index:0}.z-1{z-index:1}.z-10{z-index:10}.z-20{z-index:20}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.container\!{width:100%!important}@media (min-width:40rem){.container\!{max-width:40rem!important}}@media (min-width:48rem){.container\!{max-width:48rem!important}}@media (min-width:64rem){.container\!{max-width:64rem!important}}@media (min-width:80rem){.container\!{max-width:80rem!important}}@media (min-width:96rem){.container\!{max-width:96rem!important}}.m-0{margin:calc(var(--spacing)*0)}.mx-auto{margin-inline:auto}.mx-px{margin-inline:1px}.mt-\(--mt\){margin-top:var(--mt)}.mt-0\.5{margin-top:calc(var(--spacing)*.5)}.mt-1\.5{margin-top:calc(var(--spacing)*1.5)}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-3{margin-top:calc(var(--spacing)*3)}.mt-4{margin-top:calc(var(--spacing)*4)}.mr-1{margin-right:calc(var(--spacing)*1)}.mr-1\.5{margin-right:calc(var(--spacing)*1.5)}.mr-2{margin-right:calc(var(--spacing)*2)}.mr-3{margin-right:calc(var(--spacing)*3)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.-ml-0\.5{margin-left:calc(var(--spacing)*-.5)}.-ml-3{margin-left:calc(var(--spacing)*-3)}.ml-1{margin-left:calc(var(--spacing)*1)}.ml-1\.5{margin-left:calc(var(--spacing)*1.5)}.ml-3{margin-left:calc(var(--spacing)*3)}.scrollbar-hidden{scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}.scrollbar-hidden::-webkit-scrollbar{display:none}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.aspect-square{aspect-ratio:1}.size-\(--size\){width:var(--size);height:var(--size)}.size-1\/2{width:50%;height:50%}.size-3{width:calc(var(--spacing)*3);height:calc(var(--spacing)*3)}.size-4{width:calc(var(--spacing)*4);height:calc(var(--spacing)*4)}.size-6{width:calc(var(--spacing)*6);height:calc(var(--spacing)*6)}.size-15{width:calc(var(--spacing)*15);height:calc(var(--spacing)*15)}.size-\[calc\(1em\/4\)\]{width:.25em;height:.25em}.size-em{width:1em;height:1em}.size-full{width:100%;height:100%}.size-max{width:max-content;height:max-content}.h-\(--h\){height:var(--h)}.h-\(--scrollbar-size\){height:var(--scrollbar-size)}.h-0\.5{height:calc(var(--spacing)*.5)}.h-2{height:calc(var(--spacing)*2)}.h-2\.5{height:calc(var(--spacing)*2.5)}.h-3{height:calc(var(--spacing)*3)}.h-3\.5{height:calc(var(--spacing)*3.5)}.h-4{height:calc(var(--spacing)*4)}.h-4\.5{height:calc(var(--spacing)*4.5)}.h-5{height:calc(var(--spacing)*5)}.h-6{height:calc(var(--spacing)*6)}.h-7\.5{height:calc(var(--spacing)*7.5)}.h-9{height:calc(var(--spacing)*9)}.h-10{height:calc(var(--spacing)*10)}.h-full{height:100%}.h-max{height:max-content}.max-h-68{max-height:calc(var(--spacing)*68)}.max-h-full{max-height:100%}.min-h-0{min-height:calc(var(--spacing)*0)}.min-h-3\.5{min-height:calc(var(--spacing)*3.5)}.min-h-7\.5{min-height:calc(var(--spacing)*7.5)}.min-h-9{min-height:calc(var(--spacing)*9)}.min-h-10{min-height:calc(var(--spacing)*10)}.min-h-13{min-height:calc(var(--spacing)*13)}.min-h-\[inherit\]{min-height:inherit}.w-\(--scrollbar-size\){width:var(--scrollbar-size)}.w-\(--w\){width:var(--w)}.w-1\.5{width:calc(var(--spacing)*1.5)}.w-2{width:calc(var(--spacing)*2)}.w-2\.5{width:calc(var(--spacing)*2.5)}.w-3{width:calc(var(--spacing)*3)}.w-6{width:calc(var(--spacing)*6)}.w-7{width:calc(var(--spacing)*7)}.w-7\.5{width:calc(var(--spacing)*7.5)}.w-9{width:calc(var(--spacing)*9)}.w-10{width:calc(var(--spacing)*10)}.w-11{width:calc(var(--spacing)*11)}.w-fit{width:fit-content}.w-full{width:100%}.w-max{width:max-content}.max-w-full{max-width:100%}.max-w-sm{max-width:var(--container-sm)}.min-w-0{min-width:calc(var(--spacing)*0)}.min-w-3{min-width:calc(var(--spacing)*3)}.min-w-full{min-width:100%}.flex-1{flex:1}.shrink-0{flex-shrink:0}.border-separate{border-collapse:separate}.-translate-x-1\/2{--tw-translate-x:calc(calc(1/2*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-x-\(--tx\){--tw-translate-x:var(--tx);translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-x-1\/2{--tw-translate-x:calc(1/2*100%);translate:var(--tw-translate-x)var(--tw-translate-y)}.-translate-y-1\/2{--tw-translate-y:calc(calc(1/2*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.-translate-y-1\/3{--tw-translate-y:calc(calc(1/3*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-z-0{--tw-translate-z:calc(var(--spacing)*0);translate:var(--tw-translate-x)var(--tw-translate-y)var(--tw-translate-z)}.scale-125{--tw-scale-x:125%;--tw-scale-y:125%;--tw-scale-z:125%;scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-130{--tw-scale-x:130%;--tw-scale-y:130%;--tw-scale-z:130%;scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-y-90{--tw-scale-y:90%;scale:var(--tw-scale-x)var(--tw-scale-y)}.-rotate-\[85deg\]{rotate:-85deg}.rotate-180{rotate:180deg}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.transform-gpu{transform:translateZ(0)var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.touch-manipulation{touch-action:manipulation}.touch-none{touch-action:none}.resize{resize:both}.resize-none{resize:none}.list-none{list-style-type:none}.appearance-none{appearance:none}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.items-stretch{align-items:stretch}.justify-around{justify-content:space-around}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-evenly{justify-content:space-evenly}.justify-start{justify-content:flex-start}.justify-stretch{justify-content:stretch}.gap-\(--gap-xs\){gap:var(--gap-xs)}.gap-1{gap:calc(var(--spacing)*1)}.gap-1\.5{gap:calc(var(--spacing)*1.5)}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*6)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*6)*calc(1 - var(--tw-space-y-reverse)))}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-scroll{overflow:scroll}.overflow-visible{overflow:visible}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-inherit{border-radius:inherit}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-none{border-radius:0}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:calc(var(--radius) + 4px)}.rounded-xs{border-radius:var(--radius-xs)}.rounded-t-lg{border-top-left-radius:var(--radius);border-top-right-radius:var(--radius)}.rounded-l-inherit{border-top-left-radius:inherit;border-bottom-left-radius:inherit}.rounded-r-inherit{border-top-right-radius:inherit;border-bottom-right-radius:inherit}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-none{--tw-border-style:none;border-style:none}.border-amber-100{border-color:hsl(var(--color-amber-100-value))}.border-amber-500{border-color:hsl(var(--color-amber-500-value))}.border-background-100{border-color:hsl(var(--background-100-value))}.border-blue-100{border-color:hsl(var(--color-blue-100-value))}.border-blue-500{border-color:hsl(var(--color-blue-500-value))}.border-gray-100{border-color:hsl(var(--color-gray-100-value))}.border-gray-300{border-color:hsl(var(--color-gray-300-value))}.border-gray-400{border-color:hsl(var(--color-gray-400-value))}.border-gray-500{border-color:hsl(var(--color-gray-500-value))}.border-gray-600{border-color:hsl(var(--color-gray-600-value))}.border-gray-alpha-300{border-color:var(--color-gray-alpha-300-value)}.border-gray-alpha-400{border-color:var(--color-gray-alpha-400-value)}.border-input{border-color:var(--color-gray-alpha-300)}.border-primary{border-color:hsl(var(--primary))}.border-red-100{border-color:hsl(var(--color-red-100-value))}.border-red-500{border-color:hsl(var(--color-red-500-value))}.border-teal-100{border-color:hsl(var(--color-teal-100-value))}.border-teal-400{border-color:hsl(var(--color-teal-400-value))}.border-transparent{border-color:#0000}.border-violet-100{border-color:var(--color-violet-100)}.border-violet-400{border-color:var(--color-violet-400)}.\!bg-primary{background-color:hsl(var(--primary))!important}.bg-\(--color\){background-color:var(--color)}.bg-\(--ic\){background-color:var(--ic)}.bg-\(--mc\){background-color:var(--mc)}.bg-\(--scrollbar-color\){background-color:var(--scrollbar-color)}.bg-\[\#26C941\]{background-color:#26c941}.bg-\[\#FE5F57\]{background-color:#fe5f57}.bg-\[\#FEBB2E\]{background-color:#febb2e}.bg-amber-200{background-color:hsl(var(--color-amber-200-value))}.bg-amber-600{background-color:hsl(var(--color-amber-600-value))}.bg-amber-700{background-color:hsl(var(--color-amber-700-value))}.bg-amber-800{background-color:hsl(var(--color-amber-800-value))}.bg-background-100{background-color:hsl(var(--background-100-value))}.bg-background-200{background-color:hsl(var(--background-200-value))}.bg-black\/40{background-color:#0006}@supports (color:color-mix(in lab, red, red)){.bg-black\/40{background-color:color-mix(in oklab,var(--color-black)40%,transparent)}}.bg-blue-200{background-color:hsl(var(--color-blue-200-value))}.bg-blue-700{background-color:hsl(var(--color-blue-700-value))}.bg-border{background-color:hsl(var(--color-gray-300-value))}.bg-current{background-color:currentColor}.bg-gray-100{background-color:hsl(var(--color-gray-100-value))}.bg-gray-200{background-color:hsl(var(--color-gray-200-value))}.bg-gray-600{background-color:hsl(var(--color-gray-600-value))}.bg-gray-700{background-color:hsl(var(--color-gray-700-value))}.bg-gray-900{background-color:hsl(var(--color-gray-900-value))}.bg-gray-1000{background-color:hsl(var(--color-gray-1000-value))}.bg-gray-alpha-100{background-color:var(--color-gray-alpha-100-value)}.bg-gray-alpha-200{background-color:var(--color-gray-alpha-200-value)}.bg-gray-alpha-400{background-color:var(--color-gray-alpha-400-value)}.bg-green-200{background-color:hsl(var(--color-green-200-value))}.bg-green-700{background-color:hsl(var(--color-green-700-value))}.bg-green-800{background-color:hsl(var(--color-green-800-value))}.bg-pink-200{background-color:hsl(var(--color-pink-200-value))}.bg-pink-700{background-color:hsl(var(--color-pink-700-value))}.bg-primary{background-color:hsl(var(--primary))}.bg-purple-200{background-color:hsl(var(--color-purple-200-value))}.bg-purple-700{background-color:hsl(var(--color-purple-700-value))}.bg-red-200{background-color:hsl(var(--color-red-200-value))}.bg-red-700{background-color:hsl(var(--color-red-700-value))}.bg-red-800{background-color:hsl(var(--color-red-800-value))}.bg-teal-200{background-color:hsl(var(--color-teal-200-value))}.bg-teal-600{background-color:hsl(var(--color-teal-600-value))}.bg-teal-700{background-color:hsl(var(--color-teal-700-value))}.bg-transparent{background-color:#0000}.bg-violet-200{background-color:var(--color-violet-200)}.bg-cover{background-size:cover}.object-cover{object-fit:cover}.\!p-0{padding:calc(var(--spacing)*0)!important}.p-0{padding:calc(var(--spacing)*0)}.p-1{padding:calc(var(--spacing)*1)}.p-1\.5{padding:calc(var(--spacing)*1.5)}.p-2{padding:calc(var(--spacing)*2)}.p-3{padding:calc(var(--spacing)*3)}.p-3\.5{padding:calc(var(--spacing)*3.5)}.p-4{padding:calc(var(--spacing)*4)}.p-6{padding:calc(var(--spacing)*6)}.p-px{padding:1px}.px-1{padding-inline:calc(var(--spacing)*1)}.px-1\.5{padding-inline:calc(var(--spacing)*1.5)}.px-2{padding-inline:calc(var(--spacing)*2)}.px-2\.5{padding-inline:calc(var(--spacing)*2.5)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-3\.5{padding-inline:calc(var(--spacing)*3.5)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-5{padding-inline:calc(var(--spacing)*5)}.px-6{padding-inline:calc(var(--spacing)*6)}.px-18{padding-inline:calc(var(--spacing)*18)}.py-1{padding-block:calc(var(--spacing)*1)}.py-1\.5{padding-block:calc(var(--spacing)*1.5)}.py-2{padding-block:calc(var(--spacing)*2)}.py-2\.5{padding-block:calc(var(--spacing)*2.5)}.py-3{padding-block:calc(var(--spacing)*3)}.py-12{padding-block:calc(var(--spacing)*12)}.py-\[3px\]{padding-block:3px}.pr-0{padding-right:calc(var(--spacing)*0)}.pr-0\.5{padding-right:calc(var(--spacing)*.5)}.pr-1{padding-right:calc(var(--spacing)*1)}.pr-1\.5{padding-right:calc(var(--spacing)*1.5)}.pr-2{padding-right:calc(var(--spacing)*2)}.pr-2\.5{padding-right:calc(var(--spacing)*2.5)}.pr-3\.5{padding-right:calc(var(--spacing)*3.5)}.pr-5{padding-right:calc(var(--spacing)*5)}.pr-6{padding-right:calc(var(--spacing)*6)}.pr-9{padding-right:calc(var(--spacing)*9)}.pr-12{padding-right:calc(var(--spacing)*12)}.pr-\[3px\]{padding-right:3px}.pb-5{padding-bottom:calc(var(--spacing)*5)}.pl-0\.5{padding-left:calc(var(--spacing)*.5)}.pl-1\.5{padding-left:calc(var(--spacing)*1.5)}.pl-2{padding-left:calc(var(--spacing)*2)}.pl-2\.5{padding-left:calc(var(--spacing)*2.5)}.pl-3\.5{padding-left:calc(var(--spacing)*3.5)}.pl-6{padding-left:calc(var(--spacing)*6)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-mono{font-family:var(--font-mono)}.font-sans{font-family:var(--font-sans)}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[13px\]{font-size:13px}.leading-4{--tw-leading:calc(var(--spacing)*4);line-height:calc(var(--spacing)*4)}.leading-none{--tw-leading:1;line-height:1}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.text-balance{text-wrap:balance}.text-nowrap{text-wrap:nowrap}.break-words{overflow-wrap:break-word}.break-all{word-break:break-all}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-line{white-space:pre-line}.text-amber-900{color:hsl(var(--color-amber-900-value))}.text-background-100{color:hsl(var(--background-100-value))}.text-black{color:var(--color-black)}.text-blue-900{color:hsl(var(--color-blue-900-value))}.text-foreground{color:hsl(var(--color-gray-1000-value))}.text-foreground-secondary{color:hsl(var(--color-gray-900-value))}.text-gray-100{color:hsl(var(--color-gray-100-value))}.text-gray-500{color:hsl(var(--color-gray-500-value))}.text-gray-700{color:hsl(var(--color-gray-700-value))}.text-gray-900{color:hsl(var(--color-gray-900-value))}.text-gray-1000{color:hsl(var(--color-gray-1000-value))}.text-green-900{color:hsl(var(--color-green-900-value))}.text-pink-900{color:hsl(var(--color-pink-900-value))}.text-primary{color:hsl(var(--primary))}.text-purple-900{color:hsl(var(--color-purple-900-value))}.text-red-900{color:hsl(var(--color-red-900-value))}.text-teal-900{color:hsl(var(--color-teal-900-value))}.text-violet-900{color:var(--color-violet-900)}.text-white{color:var(--color-white)}.capitalize{text-transform:capitalize}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,)var(--tw-slashed-zero,)var(--tw-numeric-figure,)var(--tw-numeric-spacing,)var(--tw-numeric-fraction,)}.\!no-underline{text-decoration-line:none!important}.underline{text-decoration-line:underline}.opacity-\(--sv\){opacity:var(--sv)}.opacity-0{opacity:0}.opacity-20{opacity:.2}.opacity-50{opacity:.5}.opacity-100{opacity:1}.mix-blend-overlay{mix-blend-mode:overlay}.shadow-border-menu{--tw-shadow:var(--shadow-border-menu-value);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-border-modal{--tw-shadow:var(--shadow-border-modal-value);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-border-small{--tw-shadow:var(--shadow-border-small-value);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-border-tooltip{--tw-shadow:var(--shadow-border-tooltip-value);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.peer:focus-visible~.peer-focus-ring,.self-focus-ring:focus-visible{box-shadow:0 0 0 2px var(--color-background-100),0 0 0 4px hsl(var(--ring))}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.backdrop-blur-xs{--tw-backdrop-blur:blur(var(--blur-xs));-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,visibility,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.duration-50{--tw-duration:50ms;transition-duration:50ms}.duration-300{--tw-duration:.3s;transition-duration:.3s}.duration-500{--tw-duration:.5s;transition-duration:.5s}.will-change-transform{will-change:transform}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.\[--book-width\:var\(--width-xs\)\]{--book-width:var(--width-xs)}.\[--mt\:2px\]{--mt:2px}.\[--mt\:4px\]{--mt:4px}.\[--tx\:0\]{--tx:0}.transform-3d{transform-style:preserve-3d}@media (hover:hover){.group-hover\:text-foreground:is(:where(.group):hover *){color:hsl(var(--color-gray-1000-value))}.group-hover\/checkbox\:bg-gray-200:is(:where(.group\/checkbox):hover *){background-color:hsl(var(--color-gray-200-value))}.group-hover\/collapse\:will-change-\[height\]:is(:where(.group\/collapse):hover *){will-change:height}.group-hover\/radio\:bg-gray-200:is(:where(.group\/radio):hover *){background-color:hsl(var(--color-gray-200-value))}}.group-data-\[direction\=horizontal\]\:flex:is(:where(.group)[data-direction=horizontal] *){display:flex}.group-data-\[direction\=vertical\]\:rotate-90:is(:where(.group)[data-direction=vertical] *){rotate:90deg}.group-data-\[header\=true\]\:pt-5:is(:where(.group)[data-header=true] *){padding-top:calc(var(--spacing)*5)}.group-data-\[indicator-position\=left\]\:flex-col:is(:where(.group)[data-indicator-position=left] *),.group-data-\[indicator-position\=right\]\:flex-col:is(:where(.group)[data-indicator-position=right] *){flex-direction:column}.group-data-\[state\=open\]\/collapse\:-rotate-180:is(:where(.group\/collapse)[data-state=open] *){rotate:-180deg}.peer-checked\:bg-\(--ac\):is(:where(.peer):checked~*){background-color:var(--ac)}.peer-checked\:bg-gray-100:is(:where(.peer):checked~*){background-color:hsl(var(--color-gray-100-value))}.peer-checked\:text-foreground:is(:where(.peer):checked~*){color:hsl(var(--color-gray-1000-value))}.peer-checked\:opacity-50:is(:where(.peer):checked~*){opacity:.5}.peer-checked\:opacity-100:is(:where(.peer):checked~*){opacity:1}.peer-checked\:\[--tx\:100\%\]:is(:where(.peer):checked~*){--tx:100%}.peer-disabled\:cursor-not-allowed:is(:where(.peer):disabled~*){cursor:not-allowed}.peer-disabled\:text-gray-800:is(:where(.peer):disabled~*){color:hsl(var(--color-gray-800-value))}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:font-medium::file-selector-button{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.placeholder\:text-gray-600::placeholder{color:hsl(var(--color-gray-600-value))}.placeholder\:select-none::placeholder{-webkit-user-select:none;user-select:none}.before\:content-\[attr\(data-prompt\)\]:before{content:var(--tw-content);--tw-content:attr(data-prompt);content:var(--tw-content)}.before\:select-none:before{content:var(--tw-content);-webkit-user-select:none;user-select:none}.after\:size-2:after{content:var(--tw-content);width:calc(var(--spacing)*2);height:calc(var(--spacing)*2)}.after\:scale-40:after{content:var(--tw-content);--tw-scale-x:40%;--tw-scale-y:40%;--tw-scale-z:40%;scale:var(--tw-scale-x)var(--tw-scale-y)}.after\:rounded-full:after{content:var(--tw-content);border-radius:3.40282e38px}.after\:bg-gray-500:after{content:var(--tw-content);background-color:hsl(var(--color-gray-500-value))}.after\:bg-primary:after{content:var(--tw-content);background-color:hsl(var(--primary))}.after\:opacity-0:after{content:var(--tw-content);opacity:0}.after\:content-\[attr\(aria-label\)\]:after{content:var(--tw-content);--tw-content:attr(aria-label);content:var(--tw-content)}.peer-checked\:after\:scale-100:is(:where(.peer):checked~*):after{content:var(--tw-content);--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x)var(--tw-scale-y)}.peer-checked\:after\:opacity-100:is(:where(.peer):checked~*):after{content:var(--tw-content);opacity:1}.first\:justify-start:first-child{justify-content:flex-start}.last\:justify-end:last-child{justify-content:flex-end}.empty\:hidden:empty{display:none}.empty\:py-3:empty{padding-block:calc(var(--spacing)*3)}@media (hover:hover){.hover\:z-1:hover{z-index:1}.hover\:scale-130:hover{--tw-scale-x:130%;--tw-scale-y:130%;--tw-scale-z:130%;scale:var(--tw-scale-x)var(--tw-scale-y)}.hover\:border-gray-500:hover{border-color:hsl(var(--color-gray-500-value))}.hover\:bg-\(--scrollbar-hover-color\):hover{background-color:var(--scrollbar-hover-color)}.hover\:bg-amber-700:hover{background-color:hsl(var(--color-amber-700-value))}.hover\:bg-background-hover:hover{background-color:var(--color-gray-alpha-200-value)}.hover\:bg-gray-100:hover{background-color:hsl(var(--color-gray-100-value))}.hover\:bg-gray-alpha-400:hover{background-color:var(--color-gray-alpha-400-value)}.hover\:bg-green-700:hover{background-color:hsl(var(--color-green-700-value))}.hover\:bg-primary\/80:hover{background-color:hsl(var(--primary))}@supports (color:color-mix(in lab, red, red)){.hover\:bg-primary\/80:hover{background-color:color-mix(in oklab,hsl(var(--primary))80%,transparent)}}.hover\:bg-red-700:hover{background-color:hsl(var(--color-red-700-value))}.hover\:text-foreground:hover{color:hsl(var(--color-gray-1000-value))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-60:hover{opacity:.6}.hover\:will-change-transform:hover{will-change:transform}.hover\:\[--sv\:1\]:hover{--sv:1}.hover\:after\:bg-primary\/20:hover:after{content:var(--tw-content);background-color:hsl(var(--primary))}@supports (color:color-mix(in lab, red, red)){.hover\:after\:bg-primary\/20:hover:after{background-color:color-mix(in oklab,hsl(var(--primary))20%,transparent)}}}.focus\:placeholder\:opacity-0:focus::placeholder{opacity:0}.active\:z-1:active{z-index:1}.active\:scale-130:active{--tw-scale-x:130%;--tw-scale-y:130%;--tw-scale-z:130%;scale:var(--tw-scale-x)var(--tw-scale-y)}.active\:bg-\(--scrollbar-hover-color\):active{background-color:var(--scrollbar-hover-color)}.active\:bg-amber-900:active{background-color:hsl(var(--color-amber-900-value))}.active\:bg-background-active:active{background-color:var(--color-gray-alpha-300-value)}.active\:bg-gray-100:active{background-color:hsl(var(--color-gray-100-value))}.active\:bg-gray-900:active{background-color:hsl(var(--color-gray-900-value))}.active\:bg-green-900:active{background-color:hsl(var(--color-green-900-value))}.active\:bg-red-900:active{background-color:hsl(var(--color-red-900-value))}.active\:opacity-80:active{opacity:.8}.active\:opacity-100:active{opacity:1}.active\:select-none:active{-webkit-user-select:none;user-select:none}.active\:after\:bg-primary\/30:active:after{content:var(--tw-content);background-color:hsl(var(--primary))}@supports (color:color-mix(in lab, red, red)){.active\:after\:bg-primary\/30:active:after{background-color:color-mix(in oklab,hsl(var(--primary))30%,transparent)}}@media (hover:hover){.enabled\:hover\:bg-background-hover:enabled:hover{background-color:var(--color-gray-alpha-200-value)}.enabled\:hover\:text-gray-1000:enabled:hover{color:hsl(var(--color-gray-1000-value))}}.enabled\:active\:bg-background-active:enabled:active{background-color:var(--color-gray-alpha-300-value)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:border-gray-300:disabled{border-color:hsl(var(--color-gray-300-value))}.disabled\:bg-gray-100:disabled{background-color:hsl(var(--color-gray-100-value))}.disabled\:text-gray-700:disabled{color:hsl(var(--color-gray-700-value))}.disabled\:placeholder\:text-gray-400:disabled::placeholder{color:hsl(var(--color-gray-400-value))}.disabled\:placeholder\:text-gray-500:disabled::placeholder{color:hsl(var(--color-gray-500-value))}.data-\[blur\=true\]\:backdrop-blur-xs[data-blur=true]{--tw-backdrop-blur:blur(var(--blur-xs));-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.data-\[direction\=vertical\]\:flex-col[data-direction=vertical]{flex-direction:column}.data-\[disabled\=true\]\:pointer-events-none[data-disabled=true]{pointer-events:none}.data-\[disabled\=true\]\:cursor-not-allowed[data-disabled=true]{cursor:not-allowed}.data-\[disabled\=true\]\:bg-gray-100[data-disabled=true]{background-color:hsl(var(--color-gray-100-value))}.data-\[disabled\=true\]\:text-gray-700[data-disabled=true]{color:hsl(var(--color-gray-700-value))}.data-\[enterable\=false\]\:pointer-events-none[data-enterable=false]{pointer-events:none}.data-\[selected\=true\]\:bg-amber-100[data-selected=true]{background-color:hsl(var(--color-amber-100-value))}.data-\[selected\=true\]\:bg-gray-alpha-100[data-selected=true]{background-color:var(--color-gray-alpha-100-value)}.data-\[selected\=true\]\:bg-red-100[data-selected=true]{background-color:hsl(var(--color-red-100-value))}@media (prefers-reduced-motion:no-preference){.motion-safe\:animate-spin{animation:var(--animate-spin)}.motion-safe\:transition-all{transition-property:all;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:duration-200{--tw-duration:.2s;transition-duration:.2s}}.after\:motion-safe\:transition-colors:after{content:var(--tw-content)}@media (prefers-reduced-motion:no-preference){.after\:motion-safe\:transition-colors:after{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:after\:transition-all:after{content:var(--tw-content);transition-property:all;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}}@media (prefers-reduced-motion:reduce){.motion-reduce\:opacity-20{opacity:.2}.motion-reduce\:opacity-50{opacity:.5}.motion-reduce\:opacity-80{opacity:.8}}@media not all and (min-width:64rem){.max-lg\:hidden{display:none}}@media not all and (min-width:48rem){.max-md\:hidden{display:none}.max-md\:first\:flex-none:first-child{flex:none}}@media (min-width:40rem){.sm\:top-1\/2{top:50%}.sm\:left-1\/2{left:50%}.sm\:w-\[calc\(var\(--w\,540\)\*1px\)\]{width:calc(var(--w,540)*1px)}.sm\:max-w-\(--max-width\){max-width:var(--max-width)}.sm\:-translate-x-1\/2{--tw-translate-x:calc(calc(1/2*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.sm\:-translate-y-1\/2{--tw-translate-y:calc(calc(1/2*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.sm\:flex-col{flex-direction:column}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:gap-\(--gap-sm\){gap:var(--gap-sm)}.sm\:rounded-xl{border-radius:calc(var(--radius) + 4px)}.sm\:bg-background-100\/80{background-color:hsl(var(--background-100-value))}@supports (color:color-mix(in lab, red, red)){.sm\:bg-background-100\/80{background-color:color-mix(in oklab,hsl(var(--background-100-value))80%,transparent)}}.sm\:pt-4{padding-top:calc(var(--spacing)*4)}.sm\:pb-4{padding-bottom:calc(var(--spacing)*4)}.sm\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.sm\:\[--book-width\:var\(--width-sm\)\]{--book-width:var(--width-sm)}.sm\:\[--h\:30vw\]{--h:30vw}.sm\:\[--o\:0\]{--o:0}.sm\:\[--sv\:0\]{--sv:0}.sm\:\[--t\:scale\(0\.98\)\]{--t:scale(.98)}.sm\:\[--w\:30vw\]{--w:30vw}.not-empty\:sm\:pointer-events-auto:not(:empty){pointer-events:auto}}@media (min-width:48rem){.md\:flex-col{flex-direction:column}.md\:flex-row{flex-direction:row}.md\:gap-\(--gap-md\){gap:var(--gap-md)}.md\:gap-6{gap:calc(var(--spacing)*6)}.md\:\[--book-width\:var\(--width-md\)\]{--book-width:var(--width-md)}.md\:first\:max-w-\[140px\]:first-child,.md\:last\:max-w-\[140px\]:last-child{max-width:140px}}@media (min-width:64rem){.lg\:max-w-xs{max-width:var(--container-xs)}.lg\:flex-col{flex-direction:column}.lg\:flex-row{flex-direction:row}.lg\:gap-\(--gap-lg\){gap:var(--gap-lg)}.lg\:text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.lg\:\[--book-width\:var\(--width-lg\)\]{--book-width:var(--width-lg)}}@media (min-width:80rem){.xl\:flex-col{flex-direction:column}.xl\:flex-row{flex-direction:row}.xl\:gap-\(--gap-xl\){gap:var(--gap-xl)}.xl\:text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.xl\:\[--book-width\:var\(--width-xl\)\]{--book-width:var(--width-xl)}}.dark\:bg-background-100:is(.dark *){background-color:hsl(var(--background-100-value))}.dark\:bg-background-200:is(.dark *){background-color:hsl(var(--background-200-value))}.dark\:text-gray-100:is(.dark *){color:hsl(var(--color-gray-100-value))}.dark\:text-gray-1000:is(.dark *){color:hsl(var(--color-gray-1000-value))}.\[\&\:nth-child\(n\+2\)\]\:-ml-2\.5:nth-child(n+2){margin-left:calc(var(--spacing)*-2.5)}}:root{--radius:.5rem;--background-100-value:0,0%,100%;--background-200-value:0,0%,97%;--ring:var(--color-blue-900-value);--primary:var(--color-gray-1000-value);--color-gray-alpha-100-value:#0000000d;--color-gray-alpha-200-value:#00000015;--color-gray-alpha-300-value:#0000001f;--color-gray-alpha-400-value:#0000002b;--color-gray-alpha-500-value:#00000036;--color-gray-alpha-600-value:#00000057;--color-gray-alpha-700-value:#00000070;--color-gray-alpha-800-value:#00000082;--color-gray-alpha-900-value:#0000009c;--color-gray-alpha-1000-value:#000000e8;--color-gray-100-value:0,0%,95%;--color-gray-200-value:0,0%,93%;--color-gray-300-value:0,0%,90%;--color-gray-400-value:0,0%,85%;--color-gray-500-value:0,0%,79%;--color-gray-600-value:0,0%,66%;--color-gray-700-value:0,0%,56%;--color-gray-800-value:0,0%,49%;--color-gray-900-value:0,0%,40%;--color-gray-1000-value:0,0%,9%;--color-blue-100-value:212,100%,97%;--color-blue-200-value:210,100%,96%;--color-blue-300-value:210,100%,94%;--color-blue-400-value:209,100%,90%;--color-blue-500-value:209,100%,80%;--color-blue-600-value:208,100%,66%;--color-blue-700-value:212,100%,48%;--color-blue-800-value:212,100%,41%;--color-blue-900-value:211,100%,42%;--color-blue-1000-value:211,100%,15%;--color-red-100-value:0,100%,97%;--color-red-200-value:0,100%,96%;--color-red-300-value:0,100%,95%;--color-red-400-value:0,90%,92%;--color-red-500-value:0,82%,85%;--color-red-600-value:359,90%,71%;--color-red-700-value:358,75%,59%;--color-red-800-value:358,70%,52%;--color-red-900-value:358,66%,48%;--color-red-1000-value:355,49%,15%;--color-amber-100-value:39,100%,95%;--color-amber-200-value:44,100%,92%;--color-amber-300-value:43,96%,90%;--color-amber-400-value:42,100%,78%;--color-amber-500-value:38,100%,71%;--color-amber-600-value:36,90%,62%;--color-amber-700-value:39,100%,57%;--color-amber-800-value:35,100%,52%;--color-amber-900-value:30,100%,32%;--color-amber-1000-value:20,79%,17%;--color-green-100-value:120,60%,96%;--color-green-200-value:120,60%,95%;--color-green-300-value:120,60%,91%;--color-green-400-value:122,60%,86%;--color-green-500-value:124,60%,75%;--color-green-600-value:125,60%,64%;--color-green-700-value:131,41%,46%;--color-green-800-value:132,43%,39%;--color-green-900-value:133,50%,32%;--color-green-1000-value:128,29%,15%;--color-teal-100-value:169,70%,96%;--color-teal-200-value:167,70%,94%;--color-teal-300-value:168,70%,90%;--color-teal-400-value:170,70%,85%;--color-teal-500-value:170,70%,72%;--color-teal-600-value:170,70%,57%;--color-teal-700-value:173,80%,36%;--color-teal-800-value:173,83%,30%;--color-teal-900-value:174,91%,25%;--color-teal-1000-value:171,80%,13%;--color-purple-100-value:276,100%,97%;--color-purple-200-value:277,87%,97%;--color-purple-300-value:274,78%,95%;--color-purple-400-value:276,71%,92%;--color-purple-500-value:274,70%,82%;--color-purple-600-value:273,72%,73%;--color-purple-700-value:272,51%,54%;--color-purple-800-value:272,47%,45%;--color-purple-900-value:274,71%,43%;--color-purple-1000-value:276,100%,15%;--color-pink-100-value:330,100%,96%;--color-pink-200-value:340,90%,96%;--color-pink-300-value:340,82%,94%;--color-pink-400-value:341,76%,91%;--color-pink-500-value:340,75%,84%;--color-pink-600-value:341,75%,73%;--color-pink-700-value:336,80%,58%;--color-pink-800-value:336,74%,51%;--color-pink-900-value:336,65%,45%;--color-pink-1000-value:333,74%,15%;--shadow-border-default-value:0 0 0 1px #00000014;--shadow-border-small-value:0 0 0 1px #00000014,0 1px 2px 0 #0000000a;--shadow-border-medium-value:0 0 0 1px #00000014,0px 2px 2px #0000000a,0px 8px 8px -8px #0000000a;--shadow-border-large-value:0 0 0 1px #00000014,0px 2px 2px #0000000a,0px 8px 16px -4px #0000000a;--shadow-border-tooltip-value:0 0 0 1px #00000014,0px 1px 1px #00000005,0px 4px 8px #0000000a;--shadow-border-menu-value:0 0 0 1px #00000014,0px 1px 1px #00000005,0px 4px 8px -4px #0000000a,0px 16px 24px -8px #0000000f;--shadow-border-modal-value:0 0 0 1px #00000014,0px 1px 1px #00000005,0px 8px 16px -4px #0000000a,0px 24px 32px -8px #0000000f;--shadow-border-fullscreen-value:0 0 0 1px #00000014,0px 1px 1px #00000005,0px 8px 16px -4px #0000000a,0px 24px 32px -8px #0000000f;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:none;-moz-text-size-adjust:none;text-size-adjust:none;text-autospace:auto;font-synthesis:none;color-scheme:light;background-color:var(--color-background-100);color:var(--color-foreground)}:root.dark{--background-100-value:0,0%,5%;--background-200-value:0,0%,0%;--color-gray-alpha-100-value:#ffffff0f;--color-gray-alpha-200-value:#ffffff17;--color-gray-alpha-300-value:#ffffff21;--color-gray-alpha-400-value:#ffffff24;--color-gray-alpha-500-value:#ffffff3d;--color-gray-alpha-600-value:#ffffff82;--color-gray-alpha-700-value:#ffffff8a;--color-gray-alpha-800-value:#ffffff78;--color-gray-alpha-900-value:#ffffff9c;--color-gray-alpha-1000-value:#ffffffeb;--color-gray-100-value:0,0%,10%;--color-gray-200-value:0,0%,12%;--color-gray-300-value:0,0%,16%;--color-gray-400-value:0,0%,18%;--color-gray-500-value:0,0%,27%;--color-gray-600-value:0,0%,53%;--color-gray-700-value:0,0%,56%;--color-gray-800-value:0,0%,49%;--color-gray-900-value:0,0%,63%;--color-gray-1000-value:0,0%,93%;--color-blue-100-value:216,50%,12%;--color-blue-200-value:214,59%,15%;--color-blue-300-value:213,71%,20%;--color-blue-400-value:212,78%,23%;--color-blue-500-value:211,86%,27%;--color-blue-600-value:206,100%,50%;--color-blue-700-value:212,100%,48%;--color-blue-800-value:212,100%,41%;--color-blue-900-value:210,100%,66%;--color-blue-1000-value:206,100%,96%;--color-red-100-value:357,37%,12%;--color-red-200-value:357,46%,16%;--color-red-300-value:356,54%,22%;--color-red-400-value:357,55%,26%;--color-red-500-value:357,60%,32%;--color-red-600-value:358,75%,59%;--color-red-700-value:358,75%,59%;--color-red-800-value:358,69%,52%;--color-red-900-value:358,100%,69%;--color-red-1000-value:353,90%,96%;--color-amber-100-value:35,100%,8%;--color-amber-200-value:32,100%,10%;--color-amber-300-value:33,100%,15%;--color-amber-400-value:35,100%,17%;--color-amber-500-value:35,91%,22%;--color-amber-600-value:39,85%,49%;--color-amber-700-value:39,100%,57%;--color-amber-800-value:35,100%,52%;--color-amber-900-value:39,90%,50%;--color-amber-1000-value:40,94%,93%;--color-green-100-value:136,50%,9%;--color-green-200-value:137,50%,12%;--color-green-300-value:136,50%,14%;--color-green-400-value:135,70%,16%;--color-green-500-value:135,70%,23%;--color-green-600-value:135,70%,34%;--color-green-700-value:131,41%,46%;--color-green-800-value:132,43%,39%;--color-green-900-value:131,43%,57%;--color-green-1000-value:136,73%,94%;--color-teal-100-value:169,78%,7%;--color-teal-200-value:170,74%,9%;--color-teal-300-value:171,75%,13%;--color-teal-400-value:171,85%,13%;--color-teal-500-value:172,85%,20%;--color-teal-600-value:172,85%,32%;--color-teal-700-value:173,80%,36%;--color-teal-800-value:173,83%,30%;--color-teal-900-value:174,90%,41%;--color-teal-1000-value:166,71%,93%;--color-purple-100-value:283,30%,12%;--color-purple-200-value:281,38%,16%;--color-purple-300-value:279,44%,23%;--color-purple-400-value:277,46%,28%;--color-purple-500-value:274,49%,35%;--color-purple-600-value:272,51%,54%;--color-purple-700-value:272,51%,54%;--color-purple-800-value:272,47%,45%;--color-purple-900-value:275,80%,71%;--color-purple-1000-value:281,73%,96%;--color-pink-100-value:335,32%,12%;--color-pink-200-value:335,43%,16%;--color-pink-300-value:335,47%,21%;--color-pink-400-value:335,51%,22%;--color-pink-500-value:335,57%,27%;--color-pink-600-value:336,75%,40%;--color-pink-700-value:336,80%,58%;--color-pink-800-value:336,74%,51%;--color-pink-900-value:341,90%,67%;--color-pink-1000-value:333,90%,96%;--shadow-border-default-value:0 0 0 1px #ffffff25;--shadow-border-small-value:0 0 0 1px #ffffff25,0 1px 2px 0 #0000000a;--shadow-border-medium-value:0 0 0 1px #ffffff25,0px 2px 2px #00000052,0px 8px 8px -8px #00000029;--shadow-border-large-value:0 0 0 1px #ffffff25,0px 2px 2px #0000000a,0px 8px 16px -4px #0000000a;--shadow-border-tooltip-value:0 0 0 1px #ffffff25,0px 1px 1px #00000005,0px 4px 8px #0000000a;--shadow-border-menu-value:0 0 0 1px #ffffff25,0px 1px 1px #00000005,0px 4px 8px -4px #0000000a,0px 16px 24px -8px #0000000f;--shadow-border-modal-value:0 0 0 1px #ffffff25,0px 1px 1px #00000005,0px 8px 16px -4px #0000000a,0px 24px 32px -8px #0000000f;--shadow-border-fullscreen-value:0 0 0 1px #ffffff25,0px 1px 1px #00000005,0px 8px 16px -4px #0000000a,0px 24px 32px -8px #0000000f;color-scheme:dark}@media (prefers-reduced-motion:reduce){:root{--default-transition-duration:0!important}}.pxd-transition--fade-enter-active,.pxd-transition--fade-leave-active{transition:opacity var(--default-transition-duration)var(--default-transition-timing-function)}.pxd-transition--fade-enter-from,.pxd-transition--fade-leave-to{opacity:0;will-change:opacity}.pxd-transition--fade-scale-move,.pxd-transition--fade-scale-enter-active,.pxd-transition--fade-scale-leave-active{transition:var(--default-transition-duration)var(--default-transition-timing-function);will-change:opacity,transform;transition-property:opacity,transform}.pxd-transition--fade-scale-enter-from,.pxd-transition--fade-scale-leave-to{opacity:0;transform:scale(var(--scale,.8))translateZ(0)}.line-clamp{text-overflow:ellipsis;-webkit-line-clamp:var(--line-clamp,1);-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.scrollbar-stable{scrollbar-gutter:stable}.scroll-disabled-both,.scroll-disabled-x{overflow-x:clip!important}.scroll-disabled-both,.scroll-disabled-y{overflow-y:clip!important}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-content{syntax:"*";inherits:false;initial-value:""}@keyframes spin{to{transform:rotate(360deg)}}
|
package/dist/styles/tw.css
CHANGED
|
@@ -503,12 +503,16 @@
|
|
|
503
503
|
-webkit-box-orient: vertical;
|
|
504
504
|
}
|
|
505
505
|
|
|
506
|
+
.scrollbar-stable {
|
|
507
|
+
scrollbar-gutter: stable;
|
|
508
|
+
}
|
|
509
|
+
|
|
510
|
+
.scroll-disabled-both,
|
|
506
511
|
.scroll-disabled-x {
|
|
507
512
|
overflow-x: clip !important;
|
|
508
|
-
scrollbar-gutter: stable !important;
|
|
509
513
|
}
|
|
510
514
|
|
|
515
|
+
.scroll-disabled-both,
|
|
511
516
|
.scroll-disabled-y {
|
|
512
517
|
overflow-y: clip !important;
|
|
513
|
-
scrollbar-gutter: stable !important;
|
|
514
518
|
}
|
|
@@ -1,3 +1,7 @@
|
|
|
1
|
+
import dayjs from 'dayjs/esm/index.js';
|
|
2
|
+
import dayjsDurationPlugin from 'dayjs/esm/plugin/duration/index.js';
|
|
3
|
+
import dayjsMillisecondTokenPlugin from './dayjs-millisecond-token.js';
|
|
4
|
+
export { dayjs, dayjsDurationPlugin, dayjsMillisecondTokenPlugin, };
|
|
1
5
|
interface Result<T> {
|
|
2
6
|
years: number[];
|
|
3
7
|
months: number[];
|
|
@@ -20,4 +24,3 @@ export declare function getMonthDays(year: number, month: number): {
|
|
|
20
24
|
firstDay: 0 | 2 | 1 | 3 | 4 | 5 | 6;
|
|
21
25
|
lastDay: 0 | 2 | 1 | 3 | 4 | 5 | 6;
|
|
22
26
|
};
|
|
23
|
-
export {};
|
|
@@ -1,4 +1,11 @@
|
|
|
1
1
|
import dayjs from "dayjs/esm/index.js";
|
|
2
|
+
import dayjsDurationPlugin from "dayjs/esm/plugin/duration/index.js";
|
|
3
|
+
import dayjsMillisecondTokenPlugin from "./dayjs-millisecond-token.js";
|
|
4
|
+
export {
|
|
5
|
+
dayjs,
|
|
6
|
+
dayjsDurationPlugin,
|
|
7
|
+
dayjsMillisecondTokenPlugin
|
|
8
|
+
};
|
|
2
9
|
export function getAllDatesBetween(startDate, endDate, format = "string") {
|
|
3
10
|
let start = dayjs(startDate);
|
|
4
11
|
let end = dayjs(endDate);
|
package/dist/utils/dom.d.ts
CHANGED
|
@@ -11,9 +11,15 @@ export declare function getElementRectFromContainer(elementOrRect: HTMLElement |
|
|
|
11
11
|
scrollLeft: number;
|
|
12
12
|
scrollRight: number;
|
|
13
13
|
};
|
|
14
|
-
export declare function getStyle(element: HTMLElement,
|
|
15
|
-
export declare function
|
|
16
|
-
|
|
14
|
+
export declare function getStyle(element: HTMLElement, styleNames: keyof CSSProperties | (keyof CSSProperties)[]): string[];
|
|
15
|
+
export declare function isScrollable(el: HTMLElement): {
|
|
16
|
+
x: boolean;
|
|
17
|
+
y: boolean;
|
|
18
|
+
};
|
|
19
|
+
export declare function hasScrollbar(el: HTMLElement): {
|
|
20
|
+
x: boolean;
|
|
21
|
+
y: boolean;
|
|
22
|
+
};
|
|
17
23
|
export declare function getScrollContainer(el: HTMLElement, isVertical?: boolean): Window | HTMLElement;
|
|
18
24
|
export declare function getScrollPositions(el: HTMLElement | Window | Document): {
|
|
19
25
|
scrollTop: number;
|
package/dist/utils/dom.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { camelize } from "./format.js";
|
|
1
|
+
import { camelize, toArray } from "./format.js";
|
|
2
2
|
import { isServer } from "./is.js";
|
|
3
3
|
export function getElementRectFromContainer(elementOrRect, containerOrRect) {
|
|
4
4
|
const selfRect = elementOrRect instanceof HTMLElement ? elementOrRect.getBoundingClientRect() : elementOrRect;
|
|
@@ -16,48 +16,43 @@ export function getElementRectFromContainer(elementOrRect, containerOrRect) {
|
|
|
16
16
|
scrollRight: selfRect.right - wrapRect.left
|
|
17
17
|
};
|
|
18
18
|
}
|
|
19
|
-
export function getStyle(element,
|
|
20
|
-
if (isServer || !element || !
|
|
21
|
-
return
|
|
22
|
-
}
|
|
23
|
-
let key = camelize(styleName);
|
|
24
|
-
if (key === "float") {
|
|
25
|
-
key = "cssFloat";
|
|
26
|
-
}
|
|
27
|
-
try {
|
|
28
|
-
const style = element.style[key];
|
|
29
|
-
if (style) {
|
|
30
|
-
return style;
|
|
31
|
-
}
|
|
32
|
-
const computed = document.defaultView?.getComputedStyle(element, "");
|
|
33
|
-
return computed ? computed[key] : "";
|
|
34
|
-
} catch {
|
|
35
|
-
return element.style[key];
|
|
19
|
+
export function getStyle(element, styleNames) {
|
|
20
|
+
if (isServer || !element || !styleNames) {
|
|
21
|
+
return [];
|
|
36
22
|
}
|
|
23
|
+
const keys = toArray(styleNames).map((k) => {
|
|
24
|
+
return k === "float" ? "cssFloat" : camelize(k);
|
|
25
|
+
});
|
|
26
|
+
const computedStyle = document.defaultView?.getComputedStyle(element, "") || element.style;
|
|
27
|
+
return keys.map((k) => computedStyle[k]);
|
|
37
28
|
}
|
|
38
|
-
export function
|
|
39
|
-
|
|
40
|
-
|
|
29
|
+
export function isScrollable(el) {
|
|
30
|
+
const [x, y] = getStyle(el, ["overflow-x", "overflow-y"]);
|
|
31
|
+
const allowValues = ["scroll", "auto", "overlay"];
|
|
32
|
+
if (el.tagName === "HTML") {
|
|
33
|
+
allowValues.push("visible");
|
|
41
34
|
}
|
|
42
|
-
return
|
|
35
|
+
return {
|
|
36
|
+
x: allowValues.includes(x),
|
|
37
|
+
y: allowValues.includes(y)
|
|
38
|
+
};
|
|
43
39
|
}
|
|
44
|
-
export function
|
|
45
|
-
const
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
}
|
|
50
|
-
const overflow = getStyle(el, key);
|
|
51
|
-
return ["scroll", "auto", "overlay"].some((s) => overflow.includes(s));
|
|
40
|
+
export function hasScrollbar(el) {
|
|
41
|
+
const { scrollHeight, clientHeight, scrollWidth, clientWidth } = el;
|
|
42
|
+
return {
|
|
43
|
+
x: scrollWidth > clientWidth,
|
|
44
|
+
y: scrollHeight > clientHeight
|
|
45
|
+
};
|
|
52
46
|
}
|
|
53
47
|
export function getScrollContainer(el, isVertical) {
|
|
54
48
|
const windowTop = [window, document, document.documentElement];
|
|
55
49
|
let parent = el;
|
|
50
|
+
const direction = isVertical ? "y" : "x";
|
|
56
51
|
while (parent) {
|
|
57
52
|
if (windowTop.includes(parent)) {
|
|
58
53
|
return window;
|
|
59
54
|
}
|
|
60
|
-
if (isScrollable(parent
|
|
55
|
+
if (isScrollable(parent)[direction] && hasScrollbar(parent)[direction]) {
|
|
61
56
|
return parent;
|
|
62
57
|
}
|
|
63
58
|
parent = parent.parentNode;
|
|
@@ -100,10 +95,10 @@ export function getScrollbarSize(element) {
|
|
|
100
95
|
document.body.removeChild(div);
|
|
101
96
|
return size;
|
|
102
97
|
}
|
|
103
|
-
const
|
|
104
|
-
const
|
|
105
|
-
const hasVerticalScrollbar =
|
|
106
|
-
const hasHorizontalScrollbar =
|
|
98
|
+
const { x: isXScrollable, y: isYScrollable } = isScrollable(element);
|
|
99
|
+
const { x: hasXScrollbar, y: hasYScrollbar } = hasScrollbar(element);
|
|
100
|
+
const hasVerticalScrollbar = isYScrollable && hasYScrollbar;
|
|
101
|
+
const hasHorizontalScrollbar = isXScrollable && hasXScrollbar;
|
|
107
102
|
if (hasVerticalScrollbar || hasHorizontalScrollbar) {
|
|
108
103
|
const clone = element.cloneNode(true);
|
|
109
104
|
clone.style.visibility = "hidden";
|