pxd 0.0.31 → 0.0.32
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 +1 -1
- package/dist/components/avatar/index.vue +1 -1
- package/dist/components/avatar-group/index.vue +1 -1
- package/dist/components/browser/index.vue +5 -3
- package/dist/components/countdown/index.vue +25 -7
- package/dist/components/drawer/index.vue +4 -4
- package/dist/components/error/index.vue +1 -1
- package/dist/components/message/index.vue +6 -6
- package/dist/components/modal/index.vue +4 -4
- package/dist/components/more-button/index.vue +1 -1
- package/dist/components/popover/index.vue +30 -43
- package/dist/components/slider/index.vue +2 -2
- package/dist/components/snippet/index.vue +8 -7
- package/dist/components/stack/index.vue +1 -1
- package/dist/components/tooltip/index.vue +22 -6
- package/dist/composables/use-copy-click.d.ts +2 -3
- package/dist/composables/use-copy-click.js +23 -20
- package/dist/composables/use-countdown.d.ts +8 -7
- package/dist/composables/use-countdown.js +92 -89
- package/dist/index.d.ts +1 -1
- package/dist/index.js +1 -1
- package/dist/styles/styles.css +1 -1
- package/dist/utils/dates.d.ts +2 -2
- package/dist/utils/dates.js +18 -26
- package/dist/utils/dayjs-millisecond-token.d.ts +3 -0
- package/dist/utils/dayjs-millisecond-token.js +41 -0
- package/dist/utils/format.d.ts +5 -0
- package/dist/utils/format.js +3 -0
- package/package.json +7 -5
|
@@ -325,7 +325,7 @@ onBeforeUnmount(() => {
|
|
|
325
325
|
<Transition name="pxd-transition--fade">
|
|
326
326
|
<div
|
|
327
327
|
v-if="showTooltip"
|
|
328
|
-
class="pxd-active-graph--tooltip left-0 top-0 px-2 py-1 pointer-events-none absolute z-
|
|
328
|
+
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
329
|
:style="`transform: translate(${tooltipInfo.left}px, ${tooltipInfo.top}px);`"
|
|
330
330
|
>
|
|
331
331
|
<slot name="tooltip" :data="tooltipInfo">
|
|
@@ -64,7 +64,7 @@ defineExpose({
|
|
|
64
64
|
|
|
65
65
|
<div
|
|
66
66
|
v-if="$slots.icon"
|
|
67
|
-
class="-bottom-1 -left-1 absolute z-
|
|
67
|
+
class="-bottom-1 -left-1 absolute z-1 flex size-1/2 items-center overflow-hidden rounded-full border border-background-100 bg-background-100"
|
|
68
68
|
>
|
|
69
69
|
<slot name="icon" />
|
|
70
70
|
</div>
|
|
@@ -27,7 +27,7 @@ provideAvatarGroupContext(props);
|
|
|
27
27
|
:src="option.src"
|
|
28
28
|
:alt="option.alt"
|
|
29
29
|
:loading="option.loading"
|
|
30
|
-
class="[&:nth-child(n+2)]:-ml-
|
|
30
|
+
class="[&:nth-child(n+2)]:-ml-2.5 hover:z-1"
|
|
31
31
|
/>
|
|
32
32
|
|
|
33
33
|
<PAvatar v-if="slicedOptions.length < options.length" class="text-xs -ml-3 bg-gray-1000 text-gray-100">
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
<script setup>
|
|
2
2
|
import ArrowLeftIcon from "@gdsicon/vue/arrow-left";
|
|
3
|
+
import CheckIcon from "@gdsicon/vue/check";
|
|
4
|
+
import CopyIcon from "@gdsicon/vue/copy";
|
|
3
5
|
import LockClosedIcon from "@gdsicon/vue/lock-closed";
|
|
4
6
|
import RefreshClockwiseIcon from "@gdsicon/vue/refresh-clockwise";
|
|
5
7
|
import { useCopyClick } from "../../composables/use-copy-click";
|
|
@@ -10,7 +12,7 @@ defineOptions({
|
|
|
10
12
|
defineProps({
|
|
11
13
|
address: { type: String, required: false }
|
|
12
14
|
});
|
|
13
|
-
const {
|
|
15
|
+
const { isCopied, copyText } = useCopyClick();
|
|
14
16
|
</script>
|
|
15
17
|
|
|
16
18
|
<template>
|
|
@@ -38,9 +40,9 @@ const { renderAs, onCopyClick } = useCopyClick();
|
|
|
38
40
|
{{ address }}
|
|
39
41
|
</div>
|
|
40
42
|
|
|
41
|
-
<PButton variant="ghost" size="xs" shape="rounded" class="size-6" icon @click="
|
|
43
|
+
<PButton variant="ghost" size="xs" shape="rounded" class="size-6" icon @click="copyText(address)">
|
|
42
44
|
<Transition name="pxd-transition--fade-scale" mode="out-in">
|
|
43
|
-
<component :is="
|
|
45
|
+
<component :is="isCopied ? CheckIcon : CopyIcon" class="text-sm text-foreground-secondary" />
|
|
44
46
|
</Transition>
|
|
45
47
|
</PButton>
|
|
46
48
|
</div>
|
|
@@ -1,11 +1,15 @@
|
|
|
1
1
|
<script setup>
|
|
2
|
-
import
|
|
2
|
+
import dayjs from "dayjs";
|
|
3
|
+
import dayjsDuration from "dayjs/plugin/duration";
|
|
4
|
+
import { computed, onBeforeUnmount } from "vue";
|
|
3
5
|
import { useCountdown } from "../../composables/use-countdown";
|
|
6
|
+
import millisecondTokenPlugin from "../../utils/dayjs-millisecond-token";
|
|
4
7
|
defineOptions({
|
|
5
8
|
name: "PCountDown"
|
|
6
9
|
});
|
|
7
10
|
const props = defineProps({
|
|
8
|
-
format: { type: String, required: false, default: "
|
|
11
|
+
format: { type: String, required: false, default: "HH:mm:ss" },
|
|
12
|
+
invert: { type: Boolean, required: false },
|
|
9
13
|
active: { type: Boolean, required: false, default: false },
|
|
10
14
|
endTime: { type: Number, required: false, default: 0 },
|
|
11
15
|
autoReset: { type: Boolean, required: false, default: true },
|
|
@@ -14,15 +18,29 @@ const props = defineProps({
|
|
|
14
18
|
millisecond: { type: Boolean, required: false, default: true }
|
|
15
19
|
});
|
|
16
20
|
const emits = defineEmits(["change", "reset", "finish"]);
|
|
21
|
+
dayjs.extend(dayjsDuration);
|
|
22
|
+
dayjs.extend(millisecondTokenPlugin);
|
|
17
23
|
const {
|
|
24
|
+
clean,
|
|
18
25
|
reset,
|
|
19
|
-
|
|
26
|
+
timestamp
|
|
20
27
|
} = useCountdown(props, emits);
|
|
28
|
+
const times = computed(() => {
|
|
29
|
+
const t = dayjs.duration(timestamp.value);
|
|
30
|
+
return {
|
|
31
|
+
dd: t.format("DD"),
|
|
32
|
+
hh: t.format("HH"),
|
|
33
|
+
mm: t.format("mm"),
|
|
34
|
+
ss: t.format("ss"),
|
|
35
|
+
ms: t.format("SSS")
|
|
36
|
+
};
|
|
37
|
+
});
|
|
21
38
|
const displayTimes = computed(() => {
|
|
22
|
-
const
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
39
|
+
const time = dayjs.duration(timestamp.value).format(props.format);
|
|
40
|
+
return time;
|
|
41
|
+
});
|
|
42
|
+
onBeforeUnmount(() => {
|
|
43
|
+
clean();
|
|
26
44
|
});
|
|
27
45
|
defineExpose({
|
|
28
46
|
reset,
|
|
@@ -101,16 +101,16 @@ watch(() => isVisible.value, (visible) => {
|
|
|
101
101
|
:style="computedStyle"
|
|
102
102
|
>
|
|
103
103
|
<header
|
|
104
|
-
class="pxd-drawer--header
|
|
104
|
+
class="pxd-drawer--header p-6 sm:py-4 relative shrink-0 empty:py-3"
|
|
105
105
|
:class="{ 'border-b bg-background-200 dark:bg-background-100': headerStyle }"
|
|
106
106
|
>
|
|
107
|
-
<h3 v-if="$slots.title || title" class="text-
|
|
107
|
+
<h3 v-if="$slots.title || title" class="text-xl font-semibold tracking-tight">
|
|
108
108
|
<slot name="title">
|
|
109
109
|
{{ title }}
|
|
110
110
|
</slot>
|
|
111
111
|
</h3>
|
|
112
112
|
|
|
113
|
-
<div v-if="$slots.subtitle || subtitle" class="mt-
|
|
113
|
+
<div v-if="$slots.subtitle || subtitle" class="mt-3 text-sm text-muted-foreground">
|
|
114
114
|
<slot name="subtitle">
|
|
115
115
|
{{ subtitle }}
|
|
116
116
|
</slot>
|
|
@@ -121,7 +121,7 @@ watch(() => isVisible.value, (visible) => {
|
|
|
121
121
|
v-if="$slots.default"
|
|
122
122
|
:data-header="headerStyle"
|
|
123
123
|
class="pxd-drawer--content group flex-1"
|
|
124
|
-
content-class="group-data-[header=true]:pt-
|
|
124
|
+
content-class="group-data-[header=true]:pt-5 px-6 pb-5"
|
|
125
125
|
>
|
|
126
126
|
<slot />
|
|
127
127
|
</PScrollable>
|
|
@@ -28,7 +28,7 @@ const computedClass = computed(() => {
|
|
|
28
28
|
|
|
29
29
|
<template>
|
|
30
30
|
<div :class="computedClass">
|
|
31
|
-
<StopIcon class="size-4
|
|
31
|
+
<StopIcon class="size-4 mr-2 mt-(--mt) shrink-0" />
|
|
32
32
|
|
|
33
33
|
<div class="flex-1">
|
|
34
34
|
<b v-if="label || error?.label" class="font-medium whitespace-nowrap">{{ label || error?.label }}:</b>
|
|
@@ -80,14 +80,14 @@ function onPointerOut(e) {
|
|
|
80
80
|
<template>
|
|
81
81
|
<PTeleport to="body">
|
|
82
82
|
<div
|
|
83
|
-
class="pxd-message p-4
|
|
83
|
+
class="pxd-message p-4 fixed z-10 w-full empty:pointer-events-none"
|
|
84
84
|
:style="{ zIndex }"
|
|
85
85
|
:data-position="position"
|
|
86
86
|
>
|
|
87
87
|
<TransitionGroup
|
|
88
88
|
name="pxd-transition--fade-scale"
|
|
89
89
|
tag="div"
|
|
90
|
-
class="pxd-message--group gap-3
|
|
90
|
+
class="pxd-message--group gap-3 relative flex"
|
|
91
91
|
appear
|
|
92
92
|
@pointerover="onPointerOver"
|
|
93
93
|
@pointerout="onPointerOut"
|
|
@@ -99,10 +99,10 @@ function onPointerOut(e) {
|
|
|
99
99
|
aria-live="polite"
|
|
100
100
|
:data-key="item.key"
|
|
101
101
|
:data-type="item.type"
|
|
102
|
-
:class="item.class"
|
|
103
|
-
class="pxd-message--item
|
|
102
|
+
:class="[item.class, { 'pr-9': item.closeable }]"
|
|
103
|
+
class="pxd-message--item py-2 px-3 text-sm relative flex w-max max-w-full rounded-lg bg-background-100 break-all shadow-border-modal"
|
|
104
104
|
>
|
|
105
|
-
<component :is="TYPE_ICONS[item.type]" v-if="item.type" class="pxd-message--icon mr-2 shrink-0" :class="item.type" />
|
|
105
|
+
<component :is="TYPE_ICONS[item.type]" v-if="item.type" class="pxd-message--icon size-4 mr-2 mt-0.5 shrink-0" :class="item.type" />
|
|
106
106
|
|
|
107
107
|
<span v-if="typeof item.message === 'string'">
|
|
108
108
|
{{ item.message }}
|
|
@@ -114,7 +114,7 @@ function onPointerOut(e) {
|
|
|
114
114
|
icon
|
|
115
115
|
size="xs"
|
|
116
116
|
variant="ghost"
|
|
117
|
-
class="
|
|
117
|
+
class="right-1.5 top-1.5 absolute z-1 touch-none text-foreground-secondary"
|
|
118
118
|
@click="closeMessage(item.key)"
|
|
119
119
|
>
|
|
120
120
|
<CloseIcon />
|
|
@@ -68,16 +68,16 @@ watch(() => isVisible.value, (visible) => {
|
|
|
68
68
|
:style="{ '--w': width }"
|
|
69
69
|
>
|
|
70
70
|
<header
|
|
71
|
-
class="pxd-modal--header
|
|
71
|
+
class="pxd-modal--header p-6 sm:py-4 relative shrink-0 empty:py-3"
|
|
72
72
|
:class="{ 'border-b bg-background-200 dark:bg-background-100': headerStyle }"
|
|
73
73
|
>
|
|
74
|
-
<h3 v-if="$slots.title || title" class="text-
|
|
74
|
+
<h3 v-if="$slots.title || title" class="text-xl font-semibold tracking-tight">
|
|
75
75
|
<slot name="title">
|
|
76
76
|
{{ title }}
|
|
77
77
|
</slot>
|
|
78
78
|
</h3>
|
|
79
79
|
|
|
80
|
-
<div v-if="$slots.subtitle || subtitle" class="mt-
|
|
80
|
+
<div v-if="$slots.subtitle || subtitle" class="mt-3 text-sm text-muted-foreground">
|
|
81
81
|
<slot name="subtitle">
|
|
82
82
|
{{ subtitle }}
|
|
83
83
|
</slot>
|
|
@@ -88,7 +88,7 @@ watch(() => isVisible.value, (visible) => {
|
|
|
88
88
|
v-if="$slots.default"
|
|
89
89
|
:data-header="headerStyle"
|
|
90
90
|
class="pxd-modal--content group flex-1"
|
|
91
|
-
content-class="group-data-[header=true]:pt-
|
|
91
|
+
content-class="group-data-[header=true]:pt-5 px-6 pb-5"
|
|
92
92
|
>
|
|
93
93
|
<slot />
|
|
94
94
|
</PScrollable>
|
|
@@ -37,7 +37,7 @@ function onToggleExpand() {
|
|
|
37
37
|
|
|
38
38
|
<template>
|
|
39
39
|
<div class="pxd-more-button px-4 mt-4 flex w-full items-center">
|
|
40
|
-
<PButton class="relative z-
|
|
40
|
+
<PButton class="relative z-1" v-bind="buttonProps" @click="onToggleExpand">
|
|
41
41
|
{{ isExpanded ? lessText : moreText }}
|
|
42
42
|
|
|
43
43
|
<template #suffix>
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
<script setup>
|
|
2
2
|
import { computed, nextTick, onBeforeUnmount, onMounted, shallowRef, watch } from "vue";
|
|
3
3
|
import { useDelayDestroy } from "../../composables/use-delay-destroy";
|
|
4
|
-
import { PRESET_MEDIA_QUERIES, useMediaQuery } from "../../composables/use-media-query";
|
|
5
4
|
import {
|
|
6
5
|
getElementRectFromContainer,
|
|
7
6
|
getScrollContainer,
|
|
@@ -67,7 +66,6 @@ const {
|
|
|
67
66
|
default: props.visible,
|
|
68
67
|
delay: props.destroyDelay
|
|
69
68
|
});
|
|
70
|
-
const isSmUp = useMediaQuery(PRESET_MEDIA_QUERIES.SM_UP);
|
|
71
69
|
const triggerMethods = computed(() => toArray(props.trigger));
|
|
72
70
|
let cachedScrollTop = 0;
|
|
73
71
|
let cachedBasePosition = null;
|
|
@@ -309,46 +307,35 @@ function updateContentPosition() {
|
|
|
309
307
|
left = `${scrollLeft + width}px`;
|
|
310
308
|
translateX = "-100%";
|
|
311
309
|
}
|
|
312
|
-
if (!isSmUp.value) {
|
|
313
|
-
left = "";
|
|
314
|
-
translateX = "0";
|
|
315
|
-
}
|
|
316
310
|
} else if (isHorizontal) {
|
|
317
|
-
if (
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
} else if (position === "left-start") {
|
|
329
|
-
top = `${scrollTop}px`;
|
|
330
|
-
left = `${scrollLeft}px`;
|
|
331
|
-
translateX = "-100%";
|
|
332
|
-
translateY = "0";
|
|
333
|
-
} else if (position === "left-end") {
|
|
334
|
-
top = `${scrollTop + height}px`;
|
|
335
|
-
left = `${scrollLeft}px`;
|
|
336
|
-
translateX = "-100%";
|
|
337
|
-
translateY = "-100%";
|
|
338
|
-
} else if (position === "right-start") {
|
|
339
|
-
top = `${scrollTop}px`;
|
|
340
|
-
left = `${scrollLeft + width}px`;
|
|
341
|
-
} else if (position === "right-end") {
|
|
342
|
-
top = `${scrollTop + height}px`;
|
|
343
|
-
left = `${scrollLeft + width}px`;
|
|
344
|
-
translateX = "0";
|
|
345
|
-
translateY = "-100%";
|
|
346
|
-
}
|
|
347
|
-
} else {
|
|
311
|
+
if (position === "left") {
|
|
312
|
+
top = `${scrollTop + height / 2}px`;
|
|
313
|
+
left = `${scrollLeft}px`;
|
|
314
|
+
translateX = "-100%";
|
|
315
|
+
translateY = "-50%";
|
|
316
|
+
} else if (position === "right") {
|
|
317
|
+
top = `${scrollTop + height / 2}px`;
|
|
318
|
+
left = `${scrollLeft + width}px`;
|
|
319
|
+
translateX = "0";
|
|
320
|
+
translateY = "-50%";
|
|
321
|
+
} else if (position === "left-start") {
|
|
348
322
|
top = `${scrollTop}px`;
|
|
349
|
-
left =
|
|
323
|
+
left = `${scrollLeft}px`;
|
|
324
|
+
translateX = "-100%";
|
|
325
|
+
translateY = "0";
|
|
326
|
+
} else if (position === "left-end") {
|
|
327
|
+
top = `${scrollTop + height}px`;
|
|
328
|
+
left = `${scrollLeft}px`;
|
|
329
|
+
translateX = "-100%";
|
|
330
|
+
translateY = "-100%";
|
|
331
|
+
} else if (position === "right-start") {
|
|
332
|
+
top = `${scrollTop}px`;
|
|
333
|
+
left = `${scrollLeft + width}px`;
|
|
334
|
+
} else if (position === "right-end") {
|
|
335
|
+
top = `${scrollTop + height}px`;
|
|
336
|
+
left = `${scrollLeft + width}px`;
|
|
337
|
+
translateX = "0";
|
|
350
338
|
translateY = "-100%";
|
|
351
|
-
localPosition.value = "top-start";
|
|
352
339
|
}
|
|
353
340
|
}
|
|
354
341
|
wrapperStyle.value = {
|
|
@@ -591,22 +578,22 @@ defineExpose({
|
|
|
591
578
|
|
|
592
579
|
&[data-position='left-start'] .pxd-popover--arrow,
|
|
593
580
|
&[data-position='right-start'] .pxd-popover--arrow {
|
|
594
|
-
top:
|
|
581
|
+
top: 16px;
|
|
595
582
|
}
|
|
596
583
|
|
|
597
584
|
&[data-position='left-end'] .pxd-popover--arrow,
|
|
598
585
|
&[data-position='right-end'] .pxd-popover--arrow {
|
|
599
|
-
bottom:
|
|
586
|
+
bottom: 16px;
|
|
600
587
|
}
|
|
601
588
|
|
|
602
589
|
&[data-position='top-start'] .pxd-popover--arrow,
|
|
603
590
|
&[data-position='bottom-start'] .pxd-popover--arrow {
|
|
604
|
-
left:
|
|
591
|
+
left: 16px;
|
|
605
592
|
}
|
|
606
593
|
|
|
607
594
|
&[data-position='top-end'] .pxd-popover--arrow,
|
|
608
595
|
&[data-position='bottom-end'] .pxd-popover--arrow {
|
|
609
|
-
right:
|
|
596
|
+
right: 16px;
|
|
610
597
|
}
|
|
611
598
|
}
|
|
612
599
|
|
|
@@ -214,14 +214,14 @@ onBeforeUnmount(() => {
|
|
|
214
214
|
|
|
215
215
|
<div
|
|
216
216
|
v-if="props.range"
|
|
217
|
-
class="pxd-slider--thumb rounded-xs absolute -translate-x-1/2 touch-none bg-background-100 hover:scale-130 active:z-
|
|
217
|
+
class="pxd-slider--thumb rounded-xs absolute -translate-x-1/2 touch-none bg-background-100 hover:scale-130 active:z-1 active:scale-130 motion-safe:transition-transform"
|
|
218
218
|
:class="[{ 'scale-130': activeThumb === 'start', 'pointer-events-none': disabled }, computedSize.thumb]"
|
|
219
219
|
:style="{ left: `${startPercentage}%` }"
|
|
220
220
|
@pointerdown.prevent.stop="startDragging($event, 'start')"
|
|
221
221
|
/>
|
|
222
222
|
|
|
223
223
|
<div
|
|
224
|
-
class="pxd-slider--thumb rounded-xs absolute -translate-x-1/2 touch-none bg-background-100 hover:scale-130 active:z-
|
|
224
|
+
class="pxd-slider--thumb rounded-xs absolute -translate-x-1/2 touch-none bg-background-100 hover:scale-130 active:z-1 active:scale-130 motion-safe:transition-transform"
|
|
225
225
|
:class="[{ 'scale-130': activeThumb === 'end', 'pointer-events-none': disabled }, computedSize.thumb]"
|
|
226
226
|
:style="{ left: `${endPercentage}%` }"
|
|
227
227
|
@pointerdown.prevent.stop="startDragging($event, 'end')"
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
<script setup>
|
|
2
|
-
import
|
|
2
|
+
import CheckIcon from "@gdsicon/vue/check";
|
|
3
|
+
import CopyIcon from "@gdsicon/vue/copy";
|
|
4
|
+
import { computed } from "vue";
|
|
3
5
|
import { useConfigProvider } from "../../composables/use-config-provider-context";
|
|
4
6
|
import { useCopyClick } from "../../composables/use-copy-click";
|
|
5
7
|
import { getCssUnitValue, toArray } from "../../utils/format";
|
|
@@ -15,7 +17,6 @@ const props = defineProps({
|
|
|
15
17
|
variant: { type: String, required: false, default: "default" }
|
|
16
18
|
});
|
|
17
19
|
const emits = defineEmits(["copy"]);
|
|
18
|
-
const isCopied = ref(false);
|
|
19
20
|
const SIZES = {
|
|
20
21
|
sm: "min-h-7.5 pl-3.5 pr-1.5 py-2 text-sm",
|
|
21
22
|
md: "min-h-9 pl-3.5 pr-2.5 py-2.5 text-sm",
|
|
@@ -31,7 +32,7 @@ const VARIANTS = {
|
|
|
31
32
|
const config = useConfigProvider();
|
|
32
33
|
const computedClass = computed(() => {
|
|
33
34
|
const classes = [
|
|
34
|
-
"pxd-snippet pr-
|
|
35
|
+
"pxd-snippet pr-12 relative flex items-center rounded-lg border motion-safe:transition-all",
|
|
35
36
|
getFallbackValue(props.variant, VARIANTS),
|
|
36
37
|
getFallbackValue(props.size, SIZES, config.size)
|
|
37
38
|
];
|
|
@@ -41,10 +42,10 @@ const computedClass = computed(() => {
|
|
|
41
42
|
return classes.join(" ");
|
|
42
43
|
});
|
|
43
44
|
const computedTextArray = computed(() => toArray(props.text));
|
|
44
|
-
const {
|
|
45
|
+
const { isCopied, copyText } = useCopyClick();
|
|
45
46
|
async function onCopyButtonClick() {
|
|
46
47
|
const text = computedTextArray.value.join("\n");
|
|
47
|
-
await
|
|
48
|
+
await copyText(text);
|
|
48
49
|
emits("copy", text);
|
|
49
50
|
}
|
|
50
51
|
</script>
|
|
@@ -56,12 +57,12 @@ async function onCopyButtonClick() {
|
|
|
56
57
|
</div>
|
|
57
58
|
|
|
58
59
|
<div
|
|
59
|
-
class="right-1 p-2 absolute top-1/2 -translate-y-1/2 cursor-pointer rounded-md hover:bg-background-hover active:bg-background-active"
|
|
60
|
+
class="right-1 p-2 absolute top-1/2 -translate-y-1/2 cursor-pointer touch-none rounded-md select-none hover:bg-background-hover active:bg-background-active"
|
|
60
61
|
:class="{ copied: isCopied }"
|
|
61
62
|
@click="onCopyButtonClick"
|
|
62
63
|
>
|
|
63
64
|
<Transition name="pxd-transition--fade-scale" mode="out-in">
|
|
64
|
-
<component :is="
|
|
65
|
+
<component :is="isCopied ? CheckIcon : CopyIcon" class="text-sm" />
|
|
65
66
|
</Transition>
|
|
66
67
|
</div>
|
|
67
68
|
</div>
|
|
@@ -90,7 +90,7 @@ const computedClass = computed(() => {
|
|
|
90
90
|
</script>
|
|
91
91
|
|
|
92
92
|
<template>
|
|
93
|
-
<component :is="props.as" :class="computedClass" v-bind="$attrs" :style="formattedGap">
|
|
93
|
+
<component :is="props.as" :class="computedClass" :data-direction="direction" v-bind="$attrs" :style="formattedGap">
|
|
94
94
|
<slot />
|
|
95
95
|
</component>
|
|
96
96
|
</template>
|
|
@@ -21,17 +21,33 @@ const props = defineProps({
|
|
|
21
21
|
popoverStyle: { type: [Object, String], required: false, default: "" }
|
|
22
22
|
});
|
|
23
23
|
const VARIANTS = {
|
|
24
|
-
primary:
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
24
|
+
primary: {
|
|
25
|
+
bg: "var(--color-primary)",
|
|
26
|
+
text: "text-gray-100"
|
|
27
|
+
},
|
|
28
|
+
error: {
|
|
29
|
+
bg: "var(--color-red-700)",
|
|
30
|
+
text: "text-gray-100 dark:text-gray-1000"
|
|
31
|
+
},
|
|
32
|
+
warning: {
|
|
33
|
+
bg: "var(--color-amber-700)",
|
|
34
|
+
text: "text-gray-1000 dark:text-gray-100"
|
|
35
|
+
},
|
|
36
|
+
success: {
|
|
37
|
+
bg: "var(--color-green-700)",
|
|
38
|
+
text: "text-gray-100 dark:text-gray-1000"
|
|
39
|
+
}
|
|
28
40
|
};
|
|
29
41
|
const computedVariant = computed(() => getFallbackValue(props.variant, VARIANTS, "primary"));
|
|
30
42
|
const computedDisabled = computed(() => {
|
|
31
43
|
return props.disabled || props.desktopOnly && isTouchDevice();
|
|
32
44
|
});
|
|
33
45
|
const computedPopoverClass = computed(() => {
|
|
34
|
-
return [
|
|
46
|
+
return [
|
|
47
|
+
"px-3 py-2 rounded-md text-[13px] break-words whitespace-pre-line shadow-border-tooltip bg-(--color)",
|
|
48
|
+
computedVariant.value.text,
|
|
49
|
+
props.popoverClass
|
|
50
|
+
].join(" ");
|
|
35
51
|
});
|
|
36
52
|
</script>
|
|
37
53
|
|
|
@@ -41,7 +57,7 @@ const computedPopoverClass = computed(() => {
|
|
|
41
57
|
show-arrow
|
|
42
58
|
:position="position"
|
|
43
59
|
:disabled="computedDisabled"
|
|
44
|
-
:arrow-color="computedVariant"
|
|
60
|
+
:arrow-color="computedVariant.bg"
|
|
45
61
|
:trigger-class="triggerClass"
|
|
46
62
|
:trigger-style="triggerStyle"
|
|
47
63
|
:popover-class="computedPopoverClass"
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
export declare function useCopyClick(): {
|
|
2
|
-
isCopied: import("vue").
|
|
3
|
-
|
|
4
|
-
onCopyClick: (text: string | undefined) => Promise<void>;
|
|
2
|
+
isCopied: import("vue").ShallowRef<boolean, boolean>;
|
|
3
|
+
copyText: (text?: string | undefined) => Promise<void>;
|
|
5
4
|
};
|
|
@@ -1,31 +1,34 @@
|
|
|
1
|
-
import
|
|
2
|
-
import CopyIcon from "@gdsicon/vue/copy";
|
|
3
|
-
import { computed, markRaw, ref } from "vue";
|
|
1
|
+
import { shallowRef } from "vue";
|
|
4
2
|
export function useCopyClick() {
|
|
5
3
|
let copiedTimer;
|
|
6
|
-
|
|
7
|
-
const
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
clearTimeout(copiedTimer);
|
|
12
|
-
if (typeof navigator.clipboard !== "undefined") {
|
|
13
|
-
await navigator.clipboard.writeText(text || "");
|
|
14
|
-
} else {
|
|
15
|
-
hackCopy(text || "");
|
|
4
|
+
let copyPromise = null;
|
|
5
|
+
const isCopied = shallowRef(false);
|
|
6
|
+
async function copyText(text = "") {
|
|
7
|
+
if (copyPromise) {
|
|
8
|
+
return copyPromise;
|
|
16
9
|
}
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
10
|
+
try {
|
|
11
|
+
await navigator.clipboard.writeText(text);
|
|
12
|
+
} catch {
|
|
13
|
+
legacyCopyText(text);
|
|
14
|
+
}
|
|
15
|
+
copyPromise = new Promise((resolve) => {
|
|
16
|
+
isCopied.value = true;
|
|
17
|
+
resolve();
|
|
18
|
+
clearTimeout(copiedTimer);
|
|
19
|
+
copiedTimer = setTimeout(() => {
|
|
20
|
+
isCopied.value = false;
|
|
21
|
+
copyPromise = null;
|
|
22
|
+
}, 1500);
|
|
23
|
+
});
|
|
24
|
+
return copyPromise;
|
|
21
25
|
}
|
|
22
26
|
return {
|
|
23
27
|
isCopied,
|
|
24
|
-
|
|
25
|
-
onCopyClick
|
|
28
|
+
copyText
|
|
26
29
|
};
|
|
27
30
|
}
|
|
28
|
-
function
|
|
31
|
+
function legacyCopyText(text) {
|
|
29
32
|
const textarea = document.createElement("textarea");
|
|
30
33
|
textarea.value = text;
|
|
31
34
|
document.body.appendChild(textarea);
|
|
@@ -1,5 +1,11 @@
|
|
|
1
1
|
import type { EmitFn } from 'vue';
|
|
2
2
|
export interface Options {
|
|
3
|
+
/**
|
|
4
|
+
* 是否启用正计时
|
|
5
|
+
* Whether to enable count up mode.
|
|
6
|
+
* @default false
|
|
7
|
+
*/
|
|
8
|
+
invert?: boolean;
|
|
3
9
|
/**
|
|
4
10
|
* 是否激活
|
|
5
11
|
* Whether the countdown is active.
|
|
@@ -37,12 +43,7 @@ export interface Options {
|
|
|
37
43
|
millisecond?: boolean;
|
|
38
44
|
}
|
|
39
45
|
export declare function useCountdown<T extends Record<string, any>>(props: Options, emits: EmitFn<T>): {
|
|
46
|
+
clean: () => void;
|
|
40
47
|
reset: () => void;
|
|
41
|
-
|
|
42
|
-
dd: string;
|
|
43
|
-
hh: string;
|
|
44
|
-
mm: string;
|
|
45
|
-
ss: string;
|
|
46
|
-
ms: string;
|
|
47
|
-
}>;
|
|
48
|
+
timestamp: import("vue").ShallowRef<number, number>;
|
|
48
49
|
};
|
|
@@ -1,130 +1,133 @@
|
|
|
1
|
-
import { computed,
|
|
1
|
+
import { computed, shallowRef, watch } from "vue";
|
|
2
|
+
const UPDATE_INTERVAL = 34;
|
|
3
|
+
const MILLISECOND_LENGTH = 13;
|
|
4
|
+
function normalizeEndTime(endTime) {
|
|
5
|
+
return String(endTime).length >= MILLISECOND_LENGTH ? endTime : endTime * 1e3;
|
|
6
|
+
}
|
|
7
|
+
function normalizeDuration(duration, millisecond = true) {
|
|
8
|
+
return millisecond ? Math.round(duration) : Math.round(duration * 1e3);
|
|
9
|
+
}
|
|
2
10
|
export function useCountdown(props, emits) {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
const TIME_CONSTANTS = {
|
|
8
|
-
DAY: 864e5,
|
|
9
|
-
HOUR: 36e5,
|
|
10
|
-
MINUTE: 6e4,
|
|
11
|
-
SECOND: 1e3
|
|
11
|
+
const state = {
|
|
12
|
+
startTime: -1,
|
|
13
|
+
isFinished: false,
|
|
14
|
+
isPaused: false
|
|
12
15
|
};
|
|
13
16
|
const distanceRef = shallowRef(0);
|
|
14
|
-
const
|
|
15
|
-
const { endTime, durations
|
|
17
|
+
const durationRef = computed(() => {
|
|
18
|
+
const { endTime, durations = 0, millisecond, invert } = props;
|
|
16
19
|
if (endTime) {
|
|
17
|
-
const end = (
|
|
18
|
-
return Math.max(0, end);
|
|
20
|
+
const end = normalizeEndTime(endTime) - Date.now();
|
|
21
|
+
return invert ? Math.max(0, -end) : Math.max(0, end);
|
|
19
22
|
}
|
|
20
|
-
const time =
|
|
23
|
+
const time = normalizeDuration(durations, millisecond);
|
|
21
24
|
return Math.max(0, time);
|
|
22
25
|
});
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
return {
|
|
29
|
-
dd: String(dd).padStart(2, "0"),
|
|
30
|
-
hh: String(hh).padStart(2, "0"),
|
|
31
|
-
mm: String(mm).padStart(2, "0"),
|
|
32
|
-
ss: String(ss).padStart(2, "0"),
|
|
33
|
-
ms: formatMs.toString().padStart(props.precision || 0, "0")
|
|
34
|
-
};
|
|
35
|
-
});
|
|
36
|
-
function getTimeInfo(time) {
|
|
37
|
-
const dd = Math.floor(time / TIME_CONSTANTS.DAY);
|
|
38
|
-
const hh = Math.floor(time % TIME_CONSTANTS.DAY / TIME_CONSTANTS.HOUR);
|
|
39
|
-
const mm = Math.floor(time % TIME_CONSTANTS.HOUR / TIME_CONSTANTS.MINUTE);
|
|
40
|
-
const ss = Math.floor(time % TIME_CONSTANTS.MINUTE / TIME_CONSTANTS.SECOND);
|
|
41
|
-
const ms = Math.floor(time % TIME_CONSTANTS.SECOND);
|
|
42
|
-
return { dd, hh, mm, ss, ms };
|
|
43
|
-
}
|
|
44
|
-
function getDistance(time) {
|
|
45
|
-
return durations.value + pnow - time;
|
|
26
|
+
function getCurrentDistance(currentTime) {
|
|
27
|
+
if (props.invert) {
|
|
28
|
+
return currentTime - state.startTime;
|
|
29
|
+
}
|
|
30
|
+
return durationRef.value + state.startTime - currentTime;
|
|
46
31
|
}
|
|
47
|
-
function
|
|
48
|
-
distanceRef.value =
|
|
32
|
+
function setInitialDistance() {
|
|
33
|
+
distanceRef.value = props.invert ? 0 : durationRef.value;
|
|
49
34
|
}
|
|
50
|
-
function
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
35
|
+
function checkFinish(distance) {
|
|
36
|
+
const { durations, invert } = props;
|
|
37
|
+
if (invert) {
|
|
38
|
+
return durations !== void 0 && durations > 0 && distance >= durations;
|
|
39
|
+
}
|
|
40
|
+
return distance <= 0;
|
|
54
41
|
}
|
|
55
42
|
function reset() {
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
isPaused = false;
|
|
59
|
-
|
|
43
|
+
state.startTime = performance.now();
|
|
44
|
+
state.isFinished = false;
|
|
45
|
+
state.isPaused = false;
|
|
46
|
+
setInitialDistance();
|
|
60
47
|
emits("reset");
|
|
61
48
|
if (props.active) {
|
|
62
|
-
|
|
49
|
+
startFrameLoop();
|
|
63
50
|
}
|
|
64
51
|
}
|
|
65
52
|
let previousFrameTime = 0;
|
|
66
|
-
function
|
|
67
|
-
const
|
|
53
|
+
function startFrameLoop(timestamp) {
|
|
54
|
+
const currentTime = performance.now();
|
|
55
|
+
const distance = getCurrentDistance(currentTime);
|
|
68
56
|
let isLastFrame = false;
|
|
69
|
-
if (isPaused) {
|
|
57
|
+
if (state.isPaused) {
|
|
70
58
|
if (distance < UPDATE_INTERVAL) {
|
|
71
59
|
isLastFrame = true;
|
|
72
60
|
} else {
|
|
73
61
|
return;
|
|
74
62
|
}
|
|
75
63
|
}
|
|
76
|
-
if (
|
|
77
|
-
requestAnimationFrame(
|
|
64
|
+
if (currentTime - previousFrameTime < UPDATE_INTERVAL && !isLastFrame) {
|
|
65
|
+
requestAnimationFrame(startFrameLoop);
|
|
78
66
|
return;
|
|
79
67
|
}
|
|
80
|
-
previousFrameTime = timestamp;
|
|
81
|
-
if (distance
|
|
82
|
-
|
|
68
|
+
previousFrameTime = timestamp || currentTime;
|
|
69
|
+
if (checkFinish(distance)) {
|
|
70
|
+
onFinish();
|
|
83
71
|
return;
|
|
84
72
|
}
|
|
85
73
|
distanceRef.value = Math.max(0, distance);
|
|
86
|
-
requestAnimationFrame(
|
|
74
|
+
requestAnimationFrame(startFrameLoop);
|
|
87
75
|
}
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
(
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
}
|
|
104
|
-
frame();
|
|
76
|
+
function onFinish() {
|
|
77
|
+
const { durations, invert } = props;
|
|
78
|
+
if (invert && durations !== void 0 && durations > 0) {
|
|
79
|
+
distanceRef.value = durations;
|
|
80
|
+
} else if (!invert) {
|
|
81
|
+
distanceRef.value = 0;
|
|
82
|
+
}
|
|
83
|
+
state.isFinished = true;
|
|
84
|
+
emits("finish");
|
|
85
|
+
}
|
|
86
|
+
function onActiveChange(isActive) {
|
|
87
|
+
emits("change", isActive);
|
|
88
|
+
if (isActive) {
|
|
89
|
+
if (state.isPaused) {
|
|
90
|
+
state.startTime = performance.now() - distanceRef.value;
|
|
105
91
|
} else {
|
|
106
|
-
|
|
92
|
+
state.startTime = performance.now();
|
|
93
|
+
if (props.invert) {
|
|
94
|
+
distanceRef.value = 0;
|
|
95
|
+
}
|
|
107
96
|
}
|
|
108
|
-
|
|
109
|
-
|
|
97
|
+
state.isPaused = false;
|
|
98
|
+
if (state.isFinished && props.autoReset) {
|
|
99
|
+
reset();
|
|
100
|
+
} else if (state.isFinished) {
|
|
101
|
+
return;
|
|
102
|
+
}
|
|
103
|
+
startFrameLoop();
|
|
104
|
+
} else {
|
|
105
|
+
state.isPaused = true;
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
function onTimeChange() {
|
|
109
|
+
setInitialDistance();
|
|
110
|
+
state.isFinished = false;
|
|
111
|
+
if (props.active) {
|
|
112
|
+
reset();
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
const unwatchActive = watch(
|
|
116
|
+
() => props.active,
|
|
117
|
+
(isActive) => onActiveChange(isActive || false)
|
|
110
118
|
);
|
|
111
119
|
const unwatchTimes = watch(
|
|
112
120
|
() => [props.durations, props.endTime],
|
|
113
|
-
() =>
|
|
114
|
-
setDistance();
|
|
115
|
-
finished = false;
|
|
116
|
-
if (props.active) {
|
|
117
|
-
reset();
|
|
118
|
-
}
|
|
119
|
-
},
|
|
120
|
-
{ immediate: true }
|
|
121
|
+
() => onTimeChange()
|
|
121
122
|
);
|
|
122
|
-
|
|
123
|
+
function clean() {
|
|
123
124
|
unwatchTimes();
|
|
124
125
|
unwatchActive();
|
|
125
|
-
}
|
|
126
|
+
}
|
|
127
|
+
setInitialDistance();
|
|
126
128
|
return {
|
|
129
|
+
clean,
|
|
127
130
|
reset,
|
|
128
|
-
|
|
131
|
+
timestamp: distanceRef
|
|
129
132
|
};
|
|
130
133
|
}
|
package/dist/index.d.ts
CHANGED
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.32";
|
|
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-yellow-500:oklch(79.5% .184 86.047);--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-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);--text-2xl:1.5rem;--text-2xl--line-height:calc(2/1.5);--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\/2{top:50%}.-right-5{right:calc(var(--spacing)*-5)}.right-0{right:calc(var(--spacing)*0)}.right-1{right:calc(var(--spacing)*1)}.-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}.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-1\.5{margin-top:calc(var(--spacing)*1.5)}.mt-2{margin-top:calc(var(--spacing)*2)}.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-4{min-width:calc(var(--spacing)*4)}.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-\(--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-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-600{background-color:hsl(var(--color-green-600-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-600{background-color:hsl(var(--color-red-600-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-700{background-color:hsl(var(--color-teal-700-value))}.bg-transparent{background-color:#0000}.bg-violet-200{background-color:var(--color-violet-200)}.bg-yellow-500{background-color:var(--color-yellow-500)}.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-2\.5{padding:calc(var(--spacing)*2.5)}.p-3{padding:calc(var(--spacing)*3)}.p-3\.5{padding:calc(var(--spacing)*3.5)}.p-4{padding:calc(var(--spacing)*4)}.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-4{padding-block:calc(var(--spacing)*4)}.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-14{padding-right:calc(var(--spacing)*14)}.pr-\[3px\]{padding-right:3px}.pb-6{padding-bottom:calc(var(--spacing)*6)}.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{padding-left:calc(var(--spacing)*3)}.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-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-6:is(:where(.group)[data-header=true] *){padding-top:calc(var(--spacing)*6)}.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\:z-10:hover{z-index:10}.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-10:active{z-index:10}.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\: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-\[enterable\=false\]\:pointer-events-none[data-enterable=false]{pointer-events:none}.data-\[selected\=true\]\:bg-gray-alpha-100[data-selected=true]{background-color:var(--color-gray-alpha-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\:pointer-events-auto{pointer-events:auto}.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\:p-0{padding:calc(var(--spacing)*0)}.sm\:py-6{padding-block:calc(var(--spacing)*6)}.sm\:text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.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\:\[--o\:0\]{--o:0}.sm\:\[--sv\:0\]{--sv:0}.sm\:\[--t\:scale\(0\.98\)\]{--t:scale(.98)}}@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-3:nth-child(n+2){margin-left:calc(var(--spacing)*-3)}}: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:#00000014;--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{scrollbar-gutter:stable!important;overflow: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-yellow-500:oklch(79.5% .184 86.047);--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-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}.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-\(--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-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-600{background-color:hsl(var(--color-green-600-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-600{background-color:hsl(var(--color-red-600-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-700{background-color:hsl(var(--color-teal-700-value))}.bg-transparent{background-color:#0000}.bg-violet-200{background-color:var(--color-violet-200)}.bg-yellow-500{background-color:var(--color-yellow-500)}.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-2\.5{padding:calc(var(--spacing)*2.5)}.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\:pointer-events-none:empty{pointer-events:none}.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\: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-\[enterable\=false\]\:pointer-events-none[data-enterable=false]{pointer-events:none}.data-\[selected\=true\]\:bg-gray-alpha-100[data-selected=true]{background-color:var(--color-gray-alpha-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\:p-0{padding:calc(var(--spacing)*0)}.sm\:py-4{padding-block: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\:\[--o\:0\]{--o:0}.sm\:\[--sv\:0\]{--sv:0}.sm\:\[--t\:scale\(0\.98\)\]{--t:scale(.98)}}@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:#00000014;--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{scrollbar-gutter:stable!important;overflow: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/utils/dates.d.ts
CHANGED
|
@@ -17,7 +17,7 @@ export declare function getAllDatesBetween(startDate: Date | string, endDate: Da
|
|
|
17
17
|
*/
|
|
18
18
|
export declare function getMonthDays(year: number, month: number): {
|
|
19
19
|
days: number;
|
|
20
|
-
firstDay:
|
|
21
|
-
lastDay:
|
|
20
|
+
firstDay: 0 | 2 | 1 | 3 | 4 | 5 | 6;
|
|
21
|
+
lastDay: 0 | 2 | 1 | 3 | 4 | 5 | 6;
|
|
22
22
|
};
|
|
23
23
|
export {};
|
package/dist/utils/dates.js
CHANGED
|
@@ -1,35 +1,27 @@
|
|
|
1
|
-
|
|
2
|
-
const year = date.getFullYear();
|
|
3
|
-
const month = String(date.getMonth() + 1).padStart(2, "0");
|
|
4
|
-
const day = String(date.getDate()).padStart(2, "0");
|
|
5
|
-
return `${year}-${month}-${day}`;
|
|
6
|
-
}
|
|
1
|
+
import dayjs from "dayjs";
|
|
7
2
|
export function getAllDatesBetween(startDate, endDate, format = "string") {
|
|
8
|
-
let start =
|
|
9
|
-
let end =
|
|
10
|
-
if (
|
|
3
|
+
let start = dayjs(startDate);
|
|
4
|
+
let end = dayjs(endDate);
|
|
5
|
+
if (!start.isValid() || !end.isValid()) {
|
|
11
6
|
throw new TypeError("\u65E0\u6548\u7684\u65E5\u671F\u8F93\u5165");
|
|
12
7
|
}
|
|
13
|
-
if (start
|
|
8
|
+
if (start.isAfter(end)) {
|
|
14
9
|
[start, end] = [end, start];
|
|
15
10
|
}
|
|
16
11
|
const years = /* @__PURE__ */ new Set();
|
|
17
12
|
const months = /* @__PURE__ */ new Set();
|
|
18
13
|
const weeks = /* @__PURE__ */ new Set();
|
|
19
14
|
const dates = [];
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
months.add(currentDate.getMonth() + 1);
|
|
27
|
-
weeks.add(currentDate.getDay());
|
|
15
|
+
let currentDate = start.startOf("day");
|
|
16
|
+
const endDateTime = end.startOf("day");
|
|
17
|
+
while (!currentDate.isAfter(endDateTime)) {
|
|
18
|
+
years.add(currentDate.year());
|
|
19
|
+
months.add(currentDate.month() + 1);
|
|
20
|
+
weeks.add(currentDate.day());
|
|
28
21
|
dates.push(
|
|
29
|
-
format === "object" ?
|
|
30
|
-
// YYYY-MM-DD
|
|
22
|
+
format === "object" ? currentDate.toDate() : currentDate.format("YYYY-MM-DD")
|
|
31
23
|
);
|
|
32
|
-
currentDate
|
|
24
|
+
currentDate = currentDate.add(1, "day");
|
|
33
25
|
}
|
|
34
26
|
return {
|
|
35
27
|
years: Array.from(years),
|
|
@@ -39,11 +31,11 @@ export function getAllDatesBetween(startDate, endDate, format = "string") {
|
|
|
39
31
|
};
|
|
40
32
|
}
|
|
41
33
|
export function getMonthDays(year, month) {
|
|
42
|
-
const firstDay =
|
|
43
|
-
const lastDay =
|
|
34
|
+
const firstDay = dayjs().year(year).month(month - 1).date(1);
|
|
35
|
+
const lastDay = firstDay.endOf("month");
|
|
44
36
|
return {
|
|
45
|
-
days: lastDay.
|
|
46
|
-
firstDay: firstDay.
|
|
47
|
-
lastDay: lastDay.
|
|
37
|
+
days: lastDay.date(),
|
|
38
|
+
firstDay: firstDay.day(),
|
|
39
|
+
lastDay: lastDay.day()
|
|
48
40
|
};
|
|
49
41
|
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
function replaceMillisecondToken(formatStr, matcher, replacer) {
|
|
2
|
+
return formatStr.replace(matcher, replacer);
|
|
3
|
+
}
|
|
4
|
+
function padToThreeDigits(value) {
|
|
5
|
+
const normalized = Math.max(0, Math.min(999, Math.trunc(value)));
|
|
6
|
+
return String(normalized).padStart(3, "0");
|
|
7
|
+
}
|
|
8
|
+
const millisecondTokenPlugin = (_opts, DayjsClass, dayjsFactory) => {
|
|
9
|
+
const processFormat = (ms, formatStr) => {
|
|
10
|
+
const ms3 = padToThreeDigits(ms);
|
|
11
|
+
return replaceMillisecondToken(formatStr, /S+/g, (match) => {
|
|
12
|
+
const len = Math.min(match.length, 3);
|
|
13
|
+
return ms3.slice(0, len);
|
|
14
|
+
});
|
|
15
|
+
};
|
|
16
|
+
const originalFormat = DayjsClass.prototype.format;
|
|
17
|
+
DayjsClass.prototype.format = function(formatStr) {
|
|
18
|
+
if (!formatStr || typeof formatStr !== "string") {
|
|
19
|
+
return originalFormat.call(this, formatStr);
|
|
20
|
+
}
|
|
21
|
+
return originalFormat.call(this, processFormat(this.millisecond(), formatStr));
|
|
22
|
+
};
|
|
23
|
+
try {
|
|
24
|
+
const isDurationInjected = typeof dayjsFactory.duration === "function";
|
|
25
|
+
if (!isDurationInjected) {
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
const durationProto = Object.getPrototypeOf(dayjsFactory.duration(0));
|
|
29
|
+
if (durationProto?.format) {
|
|
30
|
+
const originalDurationFormat = durationProto.format;
|
|
31
|
+
durationProto.format = function(formatStr) {
|
|
32
|
+
if (!formatStr || typeof formatStr !== "string") {
|
|
33
|
+
return originalDurationFormat.call(this, formatStr);
|
|
34
|
+
}
|
|
35
|
+
return originalDurationFormat.call(this, processFormat(this.milliseconds(), formatStr));
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
} catch {
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
export default millisecondTokenPlugin;
|
package/dist/utils/format.d.ts
CHANGED
|
@@ -1,7 +1,12 @@
|
|
|
1
1
|
import type { Nullable } from '../types/shared';
|
|
2
|
+
/** string -> String */
|
|
2
3
|
export declare function capitalize(text: string): string;
|
|
4
|
+
/** kabab-case -> kababCase */
|
|
3
5
|
export declare function camelize(str: string): string;
|
|
6
|
+
/** kabab-case -> KababCase */
|
|
4
7
|
export declare function pascalize(text: string): string;
|
|
8
|
+
/** KababCase -> kabab-case */
|
|
9
|
+
export declare function uncapitalize(text: string): string;
|
|
5
10
|
export declare function isTruthyProp(value: unknown): unknown;
|
|
6
11
|
export declare function isExternalLink(href: string): boolean;
|
|
7
12
|
export declare function toArray(value: unknown | unknown[]): any[];
|
package/dist/utils/format.js
CHANGED
|
@@ -8,6 +8,9 @@ export function camelize(str) {
|
|
|
8
8
|
export function pascalize(text) {
|
|
9
9
|
return text.charAt(0).toUpperCase() + text.slice(1).replace(camelizeRE, (_, c) => c ? c.toUpperCase() : "");
|
|
10
10
|
}
|
|
11
|
+
export function uncapitalize(text) {
|
|
12
|
+
return text.charAt(0).toLowerCase() + text.slice(1).replace(/([A-Z])/g, "-$1").toLowerCase();
|
|
13
|
+
}
|
|
11
14
|
export function isTruthyProp(value) {
|
|
12
15
|
return value || value === "";
|
|
13
16
|
}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "pxd",
|
|
3
3
|
"type": "module",
|
|
4
|
-
"version": "0.0.
|
|
4
|
+
"version": "0.0.32",
|
|
5
5
|
"description": "A universal UI component library for Vue2&3.",
|
|
6
6
|
"author": "libondev <bon.li@outlook.com>",
|
|
7
7
|
"license": "MIT",
|
|
@@ -90,7 +90,8 @@
|
|
|
90
90
|
"vue": ">=2.7.0 || >=3.2.0"
|
|
91
91
|
},
|
|
92
92
|
"dependencies": {
|
|
93
|
-
"@gdsicon/vue": "^1.0.4"
|
|
93
|
+
"@gdsicon/vue": "^1.0.4",
|
|
94
|
+
"dayjs": "^1.11.13"
|
|
94
95
|
},
|
|
95
96
|
"devDependencies": {
|
|
96
97
|
"@antfu/eslint-config": "^4.19.0",
|
|
@@ -123,9 +124,10 @@
|
|
|
123
124
|
"dev": "run-s dev:lib dev:docs",
|
|
124
125
|
"dev:lib": "unbuild --stub",
|
|
125
126
|
"dev:docs": "pnpm --filter docs dev",
|
|
126
|
-
"build": "run-s update-exports build:
|
|
127
|
-
"build:lib": "
|
|
128
|
-
"build:
|
|
127
|
+
"build": "run-s update-exports build:core build:docs",
|
|
128
|
+
"build:lib": "run-s update-exports build:core build:style build:types",
|
|
129
|
+
"build:core": "unbuild",
|
|
130
|
+
"build:only": "run-s build:core build:docs",
|
|
129
131
|
"build:docs": "pnpm --filter docs build",
|
|
130
132
|
"build:style": "run-s gen-styles-file gen-tw-css-file",
|
|
131
133
|
"build:types": "vue-tsc -p tsconfig.type.json",
|