pxd 0.0.60 → 0.0.62
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/dist/components/_internal/dismiss-container.d.vue.ts +28 -0
- package/dist/components/_internal/dismiss-container.vue +162 -0
- package/dist/components/_internal/popover-arrow.d.vue.ts +9 -0
- package/dist/components/_internal/popover-arrow.vue +38 -0
- package/dist/components/active-graph/index.vue +5 -5
- package/dist/components/avatar/index.vue +5 -7
- package/dist/components/avatar-group/index.d.vue.ts +0 -1
- package/dist/components/avatar-group/index.vue +1 -1
- package/dist/components/backtop/index.vue +1 -1
- package/dist/components/badge/index.d.vue.ts +6 -2
- package/dist/components/badge/index.vue +19 -5
- package/dist/components/badge/types.d.ts +5 -0
- package/dist/components/book/index.vue +1 -1
- package/dist/components/browser/index.vue +1 -1
- package/dist/components/bubble/index.d.vue.ts +22 -0
- package/dist/components/bubble/index.vue +59 -0
- package/dist/components/bubble/types.d.ts +6 -0
- package/dist/components/button/index.d.vue.ts +0 -2
- package/dist/components/button/index.vue +31 -22
- package/dist/components/button/types.d.ts +3 -2
- package/dist/components/button-group/index.d.vue.ts +14 -0
- package/dist/components/button-group/index.vue +26 -0
- package/dist/components/button-group/types.d.ts +9 -0
- package/dist/components/carousel/index.d.vue.ts +3 -3
- package/dist/components/carousel/index.vue +146 -113
- package/dist/components/carousel/types.d.ts +1 -1
- package/dist/components/carousel-item/index.vue +22 -17
- package/dist/components/checkbox/index.vue +7 -7
- package/dist/components/checkbox-group/index.d.vue.ts +1 -1
- package/dist/components/chip/index.d.vue.ts +1 -5
- package/dist/components/chip/index.vue +5 -5
- package/dist/components/choicebox/index.vue +1 -1
- package/dist/components/collapse-group/index.vue +1 -1
- package/dist/components/color-selector/index.d.vue.ts +12 -0
- package/dist/components/color-selector/index.vue +64 -0
- package/dist/components/color-selector/types.d.ts +12 -0
- package/dist/components/command-menu/index.d.vue.ts +6 -6
- package/dist/components/command-menu/index.vue +24 -33
- package/dist/components/command-menu/types.d.ts +1 -1
- package/dist/components/command-menu-group/index.vue +15 -6
- package/dist/components/command-menu-group/types.d.ts +1 -1
- package/dist/components/config-provider/index.d.vue.ts +1 -1
- package/dist/components/countdown/index.d.vue.ts +11 -11
- package/dist/components/drawer/index.d.vue.ts +8 -8
- package/dist/components/drawer/index.vue +13 -10
- package/dist/components/drawer/types.d.ts +4 -3
- package/dist/components/ellipsis-text/index.d.vue.ts +4 -1
- package/dist/components/ellipsis-text/index.vue +86 -109
- package/dist/components/ellipsis-text/types.d.ts +2 -1
- package/dist/components/error/index.vue +2 -2
- package/dist/components/fader/index.vue +5 -9
- package/dist/components/gauge/index.vue +34 -29
- package/dist/components/grid/index.vue +1 -1
- package/dist/components/grid-item/index.vue +1 -1
- package/dist/components/hold-button/index.d.vue.ts +8 -10
- package/dist/components/hold-button/index.vue +15 -27
- package/dist/components/hold-button/types.d.ts +5 -6
- package/dist/components/index.d.ts +7 -0
- package/dist/components/index.js +7 -0
- package/dist/components/input/index.d.vue.ts +8 -8
- package/dist/components/input/index.vue +7 -6
- package/dist/components/intersection-observer/index.vue +4 -4
- package/dist/components/kbd/index.vue +2 -2
- package/dist/components/link-button/index.d.vue.ts +4 -4
- package/dist/components/link-button/index.vue +5 -7
- package/dist/components/link-button/types.d.ts +0 -3
- package/dist/components/list/index.d.vue.ts +10 -15
- package/dist/components/list/index.vue +58 -131
- package/dist/components/list/types.d.ts +4 -4
- package/dist/components/list-item/index.d.vue.ts +2 -2
- package/dist/components/list-item/index.vue +45 -40
- package/dist/components/loading-bar/index.vue +9 -8
- package/dist/components/material/index.vue +24 -46
- package/dist/components/menu/index.d.vue.ts +6 -8
- package/dist/components/menu/index.vue +18 -24
- package/dist/components/menu/types.d.ts +1 -2
- package/dist/components/message/composables/use-group-expand.d.ts +13 -0
- package/dist/components/message/composables/use-group-expand.js +50 -0
- package/dist/components/message/composables/use-message-timer.d.ts +9 -0
- package/dist/components/message/composables/use-message-timer.js +61 -0
- package/dist/components/message/composables/use-promise-message.d.ts +4 -0
- package/dist/components/message/composables/use-promise-message.js +49 -0
- package/dist/components/message/index.d.vue.ts +6 -33
- package/dist/components/message/index.vue +33 -185
- package/dist/components/message/types.d.ts +2 -2
- package/dist/components/message-item/index.vue +26 -2
- package/dist/components/modal/index.d.vue.ts +7 -7
- package/dist/components/modal/index.vue +7 -3
- package/dist/components/modal/types.d.ts +7 -3
- package/dist/components/note/index.vue +3 -3
- package/dist/components/number-input/index.d.vue.ts +5 -4
- package/dist/components/number-input/index.vue +3 -0
- package/dist/components/number-input/types.d.ts +1 -0
- package/dist/components/overlay/index.d.vue.ts +6 -3
- package/dist/components/overlay/index.vue +63 -68
- package/dist/components/overlay/types.d.ts +5 -4
- package/dist/components/pagination/index.vue +2 -2
- package/dist/components/pin-input/index.d.vue.ts +2 -2
- package/dist/components/pin-input/index.vue +9 -8
- package/dist/components/placeholder/index.vue +14 -12
- package/dist/components/popover/index.d.vue.ts +8 -9
- package/dist/components/popover/index.vue +150 -240
- package/dist/components/popover/types.d.ts +6 -7
- package/dist/components/progress/index.vue +3 -3
- package/dist/components/project-banner/index.vue +1 -1
- package/dist/components/radio/index.vue +3 -3
- package/dist/components/radio-group/index.vue +1 -1
- package/dist/components/resizable/index.vue +43 -51
- package/dist/components/resizable/types.d.ts +1 -1
- package/dist/components/resizable-handle/index.d.vue.ts +4 -1
- package/dist/components/resizable-handle/index.vue +29 -3
- package/dist/components/resizable-panel/index.vue +3 -7
- package/dist/components/scalable-text/index.d.vue.ts +9 -0
- package/dist/components/scalable-text/index.vue +147 -0
- package/dist/components/scalable-text/types.d.ts +12 -0
- package/dist/components/scrollable/index.d.vue.ts +2 -2
- package/dist/components/scrollable/index.vue +4 -3
- package/dist/components/scrollable/types.d.ts +1 -2
- package/dist/components/separator/index.d.vue.ts +6 -0
- package/dist/components/separator/index.vue +18 -0
- package/dist/components/separator/types.d.ts +5 -0
- package/dist/components/skeleton/index.d.vue.ts +1 -1
- package/dist/components/skeleton/index.vue +1 -1
- package/dist/components/slider/index.d.vue.ts +1 -1
- package/dist/components/slider/index.vue +41 -9
- package/dist/components/snippet/index.vue +18 -15
- package/dist/components/spinner/index.vue +3 -1
- package/dist/components/stack/index.d.vue.ts +1 -1
- package/dist/components/stack/index.vue +2 -2
- package/dist/components/switch/index.d.vue.ts +1 -1
- package/dist/components/switch/index.vue +5 -4
- package/dist/components/switch-item/index.vue +3 -3
- package/dist/components/tabs/index.d.vue.ts +12 -0
- package/dist/components/tabs/index.vue +270 -0
- package/dist/components/tabs/types.d.ts +12 -0
- package/dist/components/tabs-item/index.d.vue.ts +4 -0
- package/dist/components/tabs-item/index.vue +16 -0
- package/dist/components/tabs-item/types.d.ts +10 -0
- package/dist/components/text/index.vue +2 -2
- package/dist/components/textarea/index.d.vue.ts +2 -2
- package/dist/components/textarea/index.vue +3 -3
- package/dist/components/time-picker/index.d.vue.ts +3 -5
- package/dist/components/time-picker/index.vue +54 -46
- package/dist/components/time-picker/types.d.ts +1 -2
- package/dist/components/toggle/index.d.vue.ts +0 -2
- package/dist/components/toggle/index.vue +7 -7
- package/dist/components/toggle-button/index.vue +11 -9
- package/dist/components/toggle-button-group/index.vue +3 -3
- package/dist/components/tooltip/index.d.vue.ts +1 -1
- package/dist/components/tooltip/index.vue +19 -11
- package/dist/components/tooltip/types.d.ts +2 -3
- package/dist/components/virtual-list/index.d.vue.ts +8 -8
- package/dist/components/virtual-list/index.vue +29 -7
- package/dist/components/virtual-list/types.d.ts +3 -0
- package/dist/composables/index.d.ts +4 -1
- package/dist/composables/index.js +4 -1
- package/dist/composables/use-browser-observer.d.ts +1 -1
- package/dist/composables/use-browser-observer.js +2 -2
- package/dist/composables/use-client-online.js +2 -2
- package/dist/composables/use-color-scheme.js +2 -2
- package/dist/composables/use-countdown.js +3 -2
- package/dist/composables/use-deferred-value.js +2 -2
- package/dist/composables/use-delay-destroy.d.ts +1 -1
- package/dist/composables/use-delay-destroy.js +11 -6
- package/dist/composables/use-document-hidden.js +2 -2
- package/dist/composables/use-focus-trap.d.ts +1 -1
- package/dist/composables/use-focus-trap.js +2 -2
- package/dist/composables/use-list-filter.d.ts +11 -0
- package/dist/composables/use-list-filter.js +56 -0
- package/dist/composables/use-list-navigation.d.ts +27 -0
- package/dist/composables/use-list-navigation.js +159 -0
- package/dist/composables/use-lock-scroll.js +12 -12
- package/dist/composables/use-media-query.js +2 -2
- package/dist/composables/use-message.d.ts +1 -1
- package/dist/composables/use-outside-click.d.ts +1 -1
- package/dist/composables/use-outside-click.js +8 -11
- package/dist/composables/use-overlay-manager.d.ts +18 -0
- package/dist/composables/use-overlay-manager.js +80 -0
- package/dist/composables/use-popover-responsive.d.ts +6 -8
- package/dist/composables/use-popover-responsive.js +9 -12
- package/dist/composables/use-repeat-action.d.ts +1 -1
- package/dist/composables/use-repeat-action.js +2 -2
- package/dist/composables/use-swipe-gesture.d.ts +65 -0
- package/dist/composables/use-swipe-gesture.js +99 -0
- package/dist/composables/use-virtual-list.d.ts +6 -4
- package/dist/composables/use-virtual-list.js +25 -14
- package/dist/composables/use-window-size.js +2 -2
- package/dist/constants/size.d.ts +12 -0
- package/dist/constants/size.js +12 -0
- package/dist/contexts/button.d.ts +5 -0
- package/dist/contexts/button.js +5 -0
- package/dist/contexts/carousel.d.ts +3 -2
- package/dist/contexts/checkbox.d.ts +1 -1
- package/dist/contexts/choicebox.d.ts +1 -1
- package/dist/contexts/collapse.d.ts +1 -1
- package/dist/contexts/list.d.ts +23 -3
- package/dist/contexts/list.js +6 -2
- package/dist/contexts/radio.d.ts +1 -1
- package/dist/contexts/resizable.d.ts +3 -11
- package/dist/contexts/switch.d.ts +1 -1
- package/dist/contexts/tabs.d.ts +15 -0
- package/dist/contexts/tabs.js +2 -0
- package/dist/contexts/toggle-button.d.ts +1 -1
- package/dist/locales/en-us.d.ts +4 -4
- package/dist/locales/en-us.js +4 -4
- package/dist/locales/zh-cn.d.ts +4 -4
- package/dist/locales/zh-cn.js +4 -4
- package/dist/plugins/dayjs-millisecond-token.js +1 -1
- package/dist/styles/source.css +133 -128
- package/dist/styles/styles.css +2 -2
- package/dist/styles/tw.css +133 -128
- package/dist/types/shared/props.d.ts +1 -0
- package/dist/types/shared/utils.d.ts +1 -4
- package/dist/utils/date.d.ts +3 -3
- package/dist/utils/dom.d.ts +1 -0
- package/dist/utils/dom.js +4 -0
- package/dist/utils/event.d.ts +2 -1
- package/dist/utils/event.js +7 -1
- package/dist/utils/format.d.ts +3 -3
- package/dist/utils/format.js +5 -4
- package/dist/utils/fuzzy-search.d.ts +7 -0
- package/dist/utils/fuzzy-search.js +61 -0
- package/dist/utils/get.d.ts +2 -0
- package/dist/utils/get.js +15 -1
- package/dist/utils/index.d.ts +10 -11
- package/dist/utils/index.js +2 -3
- package/dist/utils/ref.d.ts +2 -2
- package/dist/utils/{throttle.d.ts → timing.d.ts} +1 -0
- package/dist/utils/{throttle.js → timing.js} +4 -2
- package/package.json +67 -63
- package/volar.d.ts +7 -0
- package/dist/components/overlay/overlay-stack.d.ts +0 -3
- package/dist/components/overlay/overlay-stack.js +0 -17
- package/dist/composables/use-pointer-gesture.d.ts +0 -180
- package/dist/composables/use-pointer-gesture.js +0 -406
- package/dist/utils/debounce.d.ts +0 -1
- package/dist/utils/debounce.js +0 -1
- package/dist/utils/regexp.d.ts +0 -8
- package/dist/utils/regexp.js +0 -8
- package/dist/utils/responsive.d.ts +0 -3
- package/dist/utils/responsive.js +0 -14
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2026 Libon
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import type { ComponentPosition } from '../../types/shared';
|
|
2
|
+
interface Props {
|
|
3
|
+
disabled?: boolean;
|
|
4
|
+
position?: ComponentPosition;
|
|
5
|
+
modelValue?: boolean;
|
|
6
|
+
}
|
|
7
|
+
declare var __VLS_1: {};
|
|
8
|
+
type __VLS_Slots = {} & {
|
|
9
|
+
default?: (props: typeof __VLS_1) => any;
|
|
10
|
+
};
|
|
11
|
+
declare const __VLS_base: import("vue").DefineComponent<Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
|
|
12
|
+
change: () => any;
|
|
13
|
+
"update:modelValue": (value: boolean) => any;
|
|
14
|
+
}, string, import("vue").PublicProps, Readonly<Props> & Readonly<{
|
|
15
|
+
onChange?: (() => any) | undefined;
|
|
16
|
+
"onUpdate:modelValue"?: ((value: boolean) => any) | undefined;
|
|
17
|
+
}>, {
|
|
18
|
+
disabled: boolean;
|
|
19
|
+
position: ComponentPosition;
|
|
20
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
21
|
+
declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
|
|
22
|
+
declare const _default: typeof __VLS_export;
|
|
23
|
+
export default _default;
|
|
24
|
+
type __VLS_WithSlots<T, S> = T & {
|
|
25
|
+
new (): {
|
|
26
|
+
$slots: S;
|
|
27
|
+
};
|
|
28
|
+
};
|
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
import { shallowRef, computed } from "vue";
|
|
3
|
+
import { useModelValue } from "../../composables/use-model-value";
|
|
4
|
+
import { useSwipeGesture } from "../../composables/use-swipe-gesture";
|
|
5
|
+
import { caf, raf } from "../../utils/event";
|
|
6
|
+
defineOptions({
|
|
7
|
+
name: "PDismissContainer",
|
|
8
|
+
inheritAttrs: false
|
|
9
|
+
});
|
|
10
|
+
const props = defineProps({
|
|
11
|
+
disabled: { type: Boolean, required: false, default: false },
|
|
12
|
+
position: { type: null, required: false, default: "bottom" },
|
|
13
|
+
modelValue: { type: Boolean, required: false }
|
|
14
|
+
});
|
|
15
|
+
const emits = defineEmits(["change", "update:modelValue"]);
|
|
16
|
+
const modelValue = useModelValue(props, emits);
|
|
17
|
+
const containerRef = shallowRef();
|
|
18
|
+
const gestureMoveOffset = shallowRef(0);
|
|
19
|
+
const isHorizontal = computed(() => ["left", "right"].find((d) => props.position.startsWith(d)));
|
|
20
|
+
const gestureDirection = computed(() => isHorizontal.value ? "horizontal" : "vertical");
|
|
21
|
+
const computedStyle = computed(() => {
|
|
22
|
+
return {
|
|
23
|
+
transform: gestureMoveOffset.value ? `translate${isHorizontal.value ? "X" : "Y"}(${gestureMoveOffset.value}px) !important` : ""
|
|
24
|
+
};
|
|
25
|
+
});
|
|
26
|
+
const dampingFactor = 9;
|
|
27
|
+
let maxSwipedDamped = 0;
|
|
28
|
+
let hasDraggedInDismissDirection = false;
|
|
29
|
+
let releaseAnimationId = 0;
|
|
30
|
+
function animateRelease(from, decayRate = 0.88) {
|
|
31
|
+
caf(releaseAnimationId);
|
|
32
|
+
const step = () => {
|
|
33
|
+
const next = from * decayRate;
|
|
34
|
+
if (Math.abs(next) < 0.5) {
|
|
35
|
+
gestureMoveOffset.value = 0;
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
from = next;
|
|
39
|
+
gestureMoveOffset.value = from;
|
|
40
|
+
releaseAnimationId = raf(step);
|
|
41
|
+
};
|
|
42
|
+
releaseAnimationId = raf(step);
|
|
43
|
+
}
|
|
44
|
+
useSwipeGesture(containerRef, {
|
|
45
|
+
handleSelector: ".pxd-dismiss-container--handle",
|
|
46
|
+
swipeThreshold: 0,
|
|
47
|
+
disabled: () => props.disabled,
|
|
48
|
+
direction: gestureDirection,
|
|
49
|
+
onPress: ({ size }) => {
|
|
50
|
+
caf(releaseAnimationId);
|
|
51
|
+
maxSwipedDamped = size / dampingFactor;
|
|
52
|
+
hasDraggedInDismissDirection = false;
|
|
53
|
+
gestureMoveOffset.value = 0;
|
|
54
|
+
},
|
|
55
|
+
onFollow: ({ displacement }) => {
|
|
56
|
+
const pos = props.position;
|
|
57
|
+
const dismissDirection = pos.startsWith("bottom") || pos.startsWith("right");
|
|
58
|
+
const isDismissDirection = dismissDirection ? displacement > 0 : displacement < 0;
|
|
59
|
+
if (isDismissDirection) {
|
|
60
|
+
hasDraggedInDismissDirection = true;
|
|
61
|
+
gestureMoveOffset.value = displacement;
|
|
62
|
+
} else if (hasDraggedInDismissDirection) {
|
|
63
|
+
const rubberBand = maxSwipedDamped * Math.sign(displacement);
|
|
64
|
+
const damping = 1 - Math.exp(-Math.abs(displacement) / maxSwipedDamped);
|
|
65
|
+
gestureMoveOffset.value = rubberBand * damping;
|
|
66
|
+
}
|
|
67
|
+
},
|
|
68
|
+
onRelease: async ({ swiped, direction }) => {
|
|
69
|
+
if (swiped && direction === props.position) {
|
|
70
|
+
modelValue.value = false;
|
|
71
|
+
gestureMoveOffset.value = 0;
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
animateRelease(gestureMoveOffset.value);
|
|
75
|
+
}
|
|
76
|
+
});
|
|
77
|
+
</script>
|
|
78
|
+
|
|
79
|
+
<template>
|
|
80
|
+
<div
|
|
81
|
+
ref="containerRef"
|
|
82
|
+
class="pxd-dismiss-container relative"
|
|
83
|
+
:data-disabled="disabled"
|
|
84
|
+
:data-position="position"
|
|
85
|
+
:style="computedStyle"
|
|
86
|
+
v-bind="$attrs"
|
|
87
|
+
>
|
|
88
|
+
<div
|
|
89
|
+
v-if="!disabled"
|
|
90
|
+
class="pxd-dismiss-container--handle absolute rounded-full bg-gray-200"
|
|
91
|
+
></div>
|
|
92
|
+
|
|
93
|
+
<slot />
|
|
94
|
+
</div>
|
|
95
|
+
</template>
|
|
96
|
+
|
|
97
|
+
<style lang="postcss">
|
|
98
|
+
.pxd-dismiss-container {
|
|
99
|
+
--dismiss-handle-x: 3rem;
|
|
100
|
+
--dismiss-handle-y: 0.4rem;
|
|
101
|
+
|
|
102
|
+
&::after {
|
|
103
|
+
content: '';
|
|
104
|
+
width: 100%;
|
|
105
|
+
height: 100%;
|
|
106
|
+
position: absolute;
|
|
107
|
+
background: #fff;
|
|
108
|
+
z-index: -1;
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
&[data-position^='top'][data-disabled='false'] {
|
|
112
|
+
padding-bottom: 1rem;
|
|
113
|
+
|
|
114
|
+
&::after {
|
|
115
|
+
top: -50%;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
&[data-position^='bottom'][data-disabled='false'] {
|
|
119
|
+
padding-top: 1rem;
|
|
120
|
+
|
|
121
|
+
&::after {
|
|
122
|
+
bottom: -50%;
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
&[data-position^='left'][data-disabled='false'] {
|
|
126
|
+
padding-right: 1rem;
|
|
127
|
+
|
|
128
|
+
&::after {
|
|
129
|
+
left: -50%;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
&[data-position^='right'][data-disabled='false'] {
|
|
133
|
+
padding-left: 1rem;
|
|
134
|
+
|
|
135
|
+
&::after {
|
|
136
|
+
right: -50%;
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
&[data-position^='top'],
|
|
141
|
+
&[data-position^='bottom'] {
|
|
142
|
+
.pxd-dismiss-container--handle {
|
|
143
|
+
left: 50%;
|
|
144
|
+
top: 0.3rem;
|
|
145
|
+
transform: translateX(-50%);
|
|
146
|
+
width: var(--dismiss-handle-x);
|
|
147
|
+
height: var(--dismiss-handle-y);
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
&[data-position^='left'],
|
|
152
|
+
&[data-position^='right'] {
|
|
153
|
+
.pxd-dismiss-container--handle {
|
|
154
|
+
left: 0.3rem;
|
|
155
|
+
top: 50%;
|
|
156
|
+
transform: translateY(-50%);
|
|
157
|
+
width: var(--dismiss-handle-y);
|
|
158
|
+
height: var(--dismiss-handle-x);
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
</style>
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { ComponentPosition } from '../../types/shared';
|
|
2
|
+
interface Props {
|
|
3
|
+
position?: ComponentPosition;
|
|
4
|
+
}
|
|
5
|
+
declare const __VLS_export: import("vue").DefineComponent<Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<Props> & Readonly<{}>, {
|
|
6
|
+
position: ComponentPosition;
|
|
7
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
8
|
+
declare const _default: typeof __VLS_export;
|
|
9
|
+
export default _default;
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
defineOptions({
|
|
3
|
+
name: "PPopoverArrow",
|
|
4
|
+
inheritAttrs: false
|
|
5
|
+
});
|
|
6
|
+
defineProps({
|
|
7
|
+
position: { type: null, required: false, default: "bottom" }
|
|
8
|
+
});
|
|
9
|
+
</script>
|
|
10
|
+
|
|
11
|
+
<template>
|
|
12
|
+
<svg
|
|
13
|
+
width="14"
|
|
14
|
+
height="7"
|
|
15
|
+
viewBox="0 0 14 7"
|
|
16
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
17
|
+
class="pxd-popover-arrow"
|
|
18
|
+
:data-position="position"
|
|
19
|
+
v-bind="$attrs"
|
|
20
|
+
>
|
|
21
|
+
<g clip-path="url(#popover_arrow_clip)">
|
|
22
|
+
<path
|
|
23
|
+
d="M15 -0.5V0.5H12.9834L12.8184 0.508789C12.4377 0.550822 12.0853 0.738056 11.8359 1.03418L8.53027 4.95996C7.73114 5.90893 6.26886 5.90892 5.46973 4.95996L2.16406 1.03418C1.87905 0.695733 1.45907 0.5 1.0166 0.5H-1V-0.5H15Z"
|
|
24
|
+
fill="inherit"
|
|
25
|
+
stroke="inherit"
|
|
26
|
+
/>
|
|
27
|
+
</g>
|
|
28
|
+
<defs>
|
|
29
|
+
<clipPath id="popover_arrow_clip">
|
|
30
|
+
<rect width="14" height="7" fill="inherit" />
|
|
31
|
+
</clipPath>
|
|
32
|
+
</defs>
|
|
33
|
+
</svg>
|
|
34
|
+
</template>
|
|
35
|
+
|
|
36
|
+
<style>
|
|
37
|
+
.pxd-popover-arrow[data-position^=bottom]{transform:rotate(180deg)}.pxd-popover-arrow[data-position^=left]{transform:translateX(4px) rotate(-90deg)}.pxd-popover-arrow[data-position^=right]{transform:translateX(-4px) rotate(90deg)}
|
|
38
|
+
</style>
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
<script setup>
|
|
2
2
|
import { computed, onBeforeUnmount, shallowRef } from "vue";
|
|
3
|
-
import { useConfigProvider } from "../../contexts/config-provider";
|
|
4
3
|
import { useDelayChange } from "../../composables/use-delay-change";
|
|
4
|
+
import { useConfigProvider } from "../../contexts/config-provider";
|
|
5
5
|
import { getAllDatesBetween } from "../../utils/date";
|
|
6
6
|
import { getCssUnitValue } from "../../utils/format";
|
|
7
7
|
import { getColorByThreshold } from "../../utils/get";
|
|
@@ -302,7 +302,7 @@ onBeforeUnmount(() => {
|
|
|
302
302
|
<tbody
|
|
303
303
|
ref="tbodyRef"
|
|
304
304
|
class="text-xs"
|
|
305
|
-
:style="{ '--item-radius': getCssUnitValue(itemRadius
|
|
305
|
+
:style="{ '--active-graph-item-radius': getCssUnitValue(itemRadius) }"
|
|
306
306
|
@click="onCellClick"
|
|
307
307
|
@pointerover.capture="onPointerOver"
|
|
308
308
|
>
|
|
@@ -318,7 +318,7 @@ onBeforeUnmount(() => {
|
|
|
318
318
|
<td
|
|
319
319
|
v-for="col of row"
|
|
320
320
|
:key="col.date"
|
|
321
|
-
class="pxd-active-graph--item w-3 min-w-3 rounded-(--item-radius) border border-transparent bg-gray-alpha-100 hover:border-primary motion-safe:transition-
|
|
321
|
+
class="pxd-active-graph--item w-3 min-w-3 rounded-(--active-graph-item-radius) border border-transparent bg-gray-alpha-100 hover:border-primary motion-safe:transition-appearance"
|
|
322
322
|
:data-date="col.date"
|
|
323
323
|
:class="{
|
|
324
324
|
'pointer-events-none invisible': col.hidden,
|
|
@@ -341,7 +341,7 @@ onBeforeUnmount(() => {
|
|
|
341
341
|
<td
|
|
342
342
|
v-for="color in computedColors"
|
|
343
343
|
:key="color"
|
|
344
|
-
class="w-3 h-3 rounded-(--item-radius) bg-gray-alpha-100 motion-safe:transition-colors"
|
|
344
|
+
class="w-3 h-3 rounded-(--active-graph-item-radius) bg-gray-alpha-100 motion-safe:transition-colors"
|
|
345
345
|
:style="`background-color: ${color}`"
|
|
346
346
|
/>
|
|
347
347
|
|
|
@@ -358,7 +358,7 @@ onBeforeUnmount(() => {
|
|
|
358
358
|
<Transition v-if="tooltip" name="pxd-transition--fade" mode="out-in" appear>
|
|
359
359
|
<div
|
|
360
360
|
v-if="showTooltip"
|
|
361
|
-
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-
|
|
361
|
+
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-13 text-gray-100 duration-50 will-change-transform motion-safe:transition-transform"
|
|
362
362
|
:style="`transform: translate(${tooltipInfo.left}px, ${tooltipInfo.top}px);`"
|
|
363
363
|
>
|
|
364
364
|
<slot name="tooltip" :data="tooltipInfo"
|
|
@@ -16,9 +16,7 @@ const props = defineProps({
|
|
|
16
16
|
const emits = defineEmits(["load", "error", "loadstart"]);
|
|
17
17
|
const loadingStatus = shallowRef("idle");
|
|
18
18
|
const avatarGroupContext = useAvatarGroupContext();
|
|
19
|
-
const computedSize = computed(
|
|
20
|
-
() => getCssUnitValue(props.size || avatarGroupContext?.props.size, "32px")
|
|
21
|
-
);
|
|
19
|
+
const computedSize = computed(() => getCssUnitValue(props.size || avatarGroupContext?.props.size));
|
|
22
20
|
const isHideAvatar = computed(
|
|
23
21
|
() => !props.src || props.placeholder || loadingStatus.value === "error"
|
|
24
22
|
);
|
|
@@ -44,7 +42,7 @@ defineExpose({
|
|
|
44
42
|
|
|
45
43
|
<template>
|
|
46
44
|
<div
|
|
47
|
-
class="pxd-avatar relative inline-flex size-(--avatar-size) items-center justify-center rounded-full border border-background-100 bg-background-100 text-
|
|
45
|
+
class="pxd-avatar relative inline-flex size-(--avatar-size) items-center justify-center rounded-full border border-background-100 bg-background-100 text-13 select-none before:default-animation-timing-function! motion-safe:before:[animation-duration:8s]"
|
|
48
46
|
:style="{ '--avatar-size': computedSize }"
|
|
49
47
|
:data-placeholder="placeholder"
|
|
50
48
|
v-bind="$attrs"
|
|
@@ -52,9 +50,9 @@ defineExpose({
|
|
|
52
50
|
<slot>
|
|
53
51
|
<span
|
|
54
52
|
v-if="isHideAvatar"
|
|
55
|
-
class="font-medium px-1 relative flex size-full items-center justify-center overflow-hidden rounded-inherit"
|
|
53
|
+
class="font-medium px-1 relative flex size-full items-center justify-center overflow-hidden rounded-inherit uppercase"
|
|
56
54
|
>
|
|
57
|
-
{{ alt }}
|
|
55
|
+
{{ alt?.slice(0, 2) }}
|
|
58
56
|
</span>
|
|
59
57
|
<img
|
|
60
58
|
v-else
|
|
@@ -111,7 +109,7 @@ defineExpose({
|
|
|
111
109
|
}
|
|
112
110
|
|
|
113
111
|
&::after {
|
|
114
|
-
border: 1px solid var(--color-gray-alpha-
|
|
112
|
+
border: 1px solid var(--color-gray-alpha-300);
|
|
115
113
|
}
|
|
116
114
|
}
|
|
117
115
|
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import type { AvatarGroupProps } from './types';
|
|
2
2
|
declare const __VLS_export: import("vue").DefineComponent<AvatarGroupProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<AvatarGroupProps> & Readonly<{}>, {
|
|
3
|
-
size: number | string;
|
|
4
3
|
max: number;
|
|
5
4
|
options: import("./types").AvatarOptions[];
|
|
6
5
|
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
@@ -8,7 +8,7 @@ defineOptions({
|
|
|
8
8
|
});
|
|
9
9
|
const props = defineProps({
|
|
10
10
|
max: { type: Number, required: false, default: 5 },
|
|
11
|
-
size: { type: [Number, String], required: false
|
|
11
|
+
size: { type: [Number, String], required: false },
|
|
12
12
|
options: { type: Array, required: false, default: () => [] }
|
|
13
13
|
});
|
|
14
14
|
const slicedOptions = computed(() => {
|
|
@@ -3,9 +3,13 @@ declare var __VLS_8: {};
|
|
|
3
3
|
type __VLS_Slots = {} & {
|
|
4
4
|
default?: (props: typeof __VLS_8) => any;
|
|
5
5
|
};
|
|
6
|
-
declare const __VLS_base: import("vue").DefineComponent<BadgeProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
|
|
7
|
-
|
|
6
|
+
declare const __VLS_base: import("vue").DefineComponent<BadgeProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
|
|
7
|
+
close: (args_0: Event) => any;
|
|
8
|
+
}, string, import("vue").PublicProps, Readonly<BadgeProps> & Readonly<{
|
|
9
|
+
onClose?: ((args_0: Event) => any) | undefined;
|
|
10
|
+
}>, {
|
|
8
11
|
variant: import("./types").BadgeVariant;
|
|
12
|
+
as: import("../../types/shared").ComponentAs;
|
|
9
13
|
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
10
14
|
declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
|
|
11
15
|
declare const _default: typeof __VLS_export;
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
<script setup>
|
|
2
|
+
import CrossIcon from "@gdsicon/vue/cross";
|
|
3
|
+
import { tv } from "tailwind-variants";
|
|
2
4
|
import { computed } from "vue";
|
|
3
5
|
import { useConfigProvider } from "../../contexts/config-provider";
|
|
4
|
-
import { tv } from "tailwind-variants";
|
|
5
6
|
defineOptions({
|
|
6
7
|
name: "PBadge",
|
|
7
8
|
inheritAttrs: false
|
|
@@ -10,10 +11,12 @@ const props = defineProps({
|
|
|
10
11
|
as: { type: [String, Object], required: false, default: "span" },
|
|
11
12
|
href: { type: String, required: false },
|
|
12
13
|
size: { type: String, required: false },
|
|
13
|
-
variant: { type: String, required: false, default: "
|
|
14
|
+
variant: { type: String, required: false, default: "pill" },
|
|
15
|
+
closeable: { type: Boolean, required: false }
|
|
14
16
|
});
|
|
17
|
+
const emits = defineEmits(["close"]);
|
|
15
18
|
const badgeVariant = tv({
|
|
16
|
-
base: "pxd-badge font-medium gap-1 inline-flex items-center justify-center rounded-full font-sans text-nowrap whitespace-nowrap no-underline! motion-safe:transition-
|
|
19
|
+
base: "pxd-badge font-medium gap-1 inline-flex items-center justify-center rounded-full font-sans leading-none text-nowrap whitespace-nowrap no-underline! motion-safe:transition-appearance",
|
|
17
20
|
variants: {
|
|
18
21
|
variant: {
|
|
19
22
|
pill: "bg-background-100",
|
|
@@ -40,9 +43,9 @@ const badgeVariant = tv({
|
|
|
40
43
|
turborepo: "text-gray-100 dark:text-gray-1000"
|
|
41
44
|
},
|
|
42
45
|
size: {
|
|
43
|
-
sm: "px-
|
|
46
|
+
sm: "px-1.5 h-5 text-xs",
|
|
44
47
|
md: "px-2.5 h-6 text-xs",
|
|
45
|
-
lg: "px-3 h-
|
|
48
|
+
lg: "px-3 h-8 text-sm"
|
|
46
49
|
}
|
|
47
50
|
},
|
|
48
51
|
compoundVariants: [
|
|
@@ -61,11 +64,22 @@ const computedClasses = computed(() => {
|
|
|
61
64
|
const { variant, size = configProvider.size } = props;
|
|
62
65
|
return badgeVariant({ variant, size });
|
|
63
66
|
});
|
|
67
|
+
function onClose(ev) {
|
|
68
|
+
emits("close", ev);
|
|
69
|
+
}
|
|
64
70
|
</script>
|
|
65
71
|
|
|
66
72
|
<template>
|
|
67
73
|
<Component :is="as" :class="computedClasses" v-bind="$attrs">
|
|
68
74
|
<slot />
|
|
75
|
+
|
|
76
|
+
<button
|
|
77
|
+
v-if="closeable"
|
|
78
|
+
class="pxd-badge--close p-1 -mr-1 relative cursor-pointer appearance-none rounded-full text-[.75em] self-focus-ring hover:bg-gray-alpha-200 active:bg-gray-alpha-300 motion-safe:transition-colors"
|
|
79
|
+
@click.stop="onClose"
|
|
80
|
+
>
|
|
81
|
+
<CrossIcon class="pointer-events-none" />
|
|
82
|
+
</button>
|
|
69
83
|
</Component>
|
|
70
84
|
</template>
|
|
71
85
|
|
|
@@ -48,7 +48,7 @@ const renderIcon = computed(() => isCopied.value ? CheckIcon : CopyIcon);
|
|
|
48
48
|
>
|
|
49
49
|
<LockClosedIcon class="text-sm text-foreground-secondary" />
|
|
50
50
|
|
|
51
|
-
<div class="pl-1.5 min-w-0 flex-1 truncate text-center text-
|
|
51
|
+
<div class="pl-1.5 min-w-0 flex-1 truncate text-center text-13 text-gray-1000">
|
|
52
52
|
{{ address }}
|
|
53
53
|
</div>
|
|
54
54
|
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { BubbleProps } from './types';
|
|
2
|
+
declare var __VLS_1: {}, __VLS_8: {}, __VLS_15: {}, __VLS_17: {};
|
|
3
|
+
type __VLS_Slots = {} & {
|
|
4
|
+
avatar?: (props: typeof __VLS_1) => any;
|
|
5
|
+
} & {
|
|
6
|
+
header?: (props: typeof __VLS_8) => any;
|
|
7
|
+
} & {
|
|
8
|
+
default?: (props: typeof __VLS_15) => any;
|
|
9
|
+
} & {
|
|
10
|
+
footer?: (props: typeof __VLS_17) => any;
|
|
11
|
+
};
|
|
12
|
+
declare const __VLS_base: import("vue").DefineComponent<BubbleProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<BubbleProps> & Readonly<{}>, {
|
|
13
|
+
role: "user" | "assistant";
|
|
14
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
15
|
+
declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
|
|
16
|
+
declare const _default: typeof __VLS_export;
|
|
17
|
+
export default _default;
|
|
18
|
+
type __VLS_WithSlots<T, S> = T & {
|
|
19
|
+
new (): {
|
|
20
|
+
$slots: S;
|
|
21
|
+
};
|
|
22
|
+
};
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
import { computed } from "vue";
|
|
3
|
+
import PAvatar from "../avatar/index.vue";
|
|
4
|
+
defineOptions({
|
|
5
|
+
name: "PBubble",
|
|
6
|
+
inheritAttrs: false
|
|
7
|
+
});
|
|
8
|
+
const props = defineProps({
|
|
9
|
+
role: { type: String, required: false, default: "assistant" },
|
|
10
|
+
header: { type: String, required: false },
|
|
11
|
+
avatar: { type: String, required: false },
|
|
12
|
+
loading: { type: Boolean, required: false }
|
|
13
|
+
});
|
|
14
|
+
const ariaLabel = computed(() => props.role === "user" ? "User message" : "Assistant message");
|
|
15
|
+
</script>
|
|
16
|
+
|
|
17
|
+
<template>
|
|
18
|
+
<article
|
|
19
|
+
class="pxd-bubble group/bubble [&+&]:mt-2 gap-2 flex max-w-full data-[role='user']:flex-row-reverse"
|
|
20
|
+
:aria-busy="loading"
|
|
21
|
+
:aria-label="ariaLabel"
|
|
22
|
+
:data-role="role"
|
|
23
|
+
role="article"
|
|
24
|
+
v-bind="$attrs"
|
|
25
|
+
>
|
|
26
|
+
<div v-if="avatar" data-bubble-avatar class="pxd-bubble--avatar shrink-0" aria-hidden="true">
|
|
27
|
+
<slot name="avatar">
|
|
28
|
+
<PAvatar :src="avatar" :alt="`${role} avatar`" size="32" />
|
|
29
|
+
</slot>
|
|
30
|
+
</div>
|
|
31
|
+
|
|
32
|
+
<div
|
|
33
|
+
class="pxd-bubble--wrapper text-sm gap-1 flex w-max max-w-[calc(100%-2.5rem)] flex-col [[data-bubble-avatar]+&]:max-w-[calc(100%-5rem)]"
|
|
34
|
+
>
|
|
35
|
+
<header
|
|
36
|
+
v-if="header || $slots.header"
|
|
37
|
+
class="pxd-bubble--header flex cursor-default items-center text-13 text-foreground-secondary group-data-[role='user']/bubble:justify-end"
|
|
38
|
+
>
|
|
39
|
+
<slot name="header">
|
|
40
|
+
{{ header }}
|
|
41
|
+
</slot>
|
|
42
|
+
</header>
|
|
43
|
+
|
|
44
|
+
<div
|
|
45
|
+
class="pxd-bubble--content py-2 px-3 overflow-hidden rounded-md border border-gray-alpha-100 bg-background-100 bg-gray-100 break-all whitespace-pre-wrap group-data-[role='assistant']/bubble:rounded-tl-none group-data-[role='user']/bubble:rounded-tr-none"
|
|
46
|
+
>
|
|
47
|
+
<PSpinner v-if="loading" class="translate-y-0.5" />
|
|
48
|
+
<slot v-else />
|
|
49
|
+
</div>
|
|
50
|
+
|
|
51
|
+
<footer
|
|
52
|
+
v-if="$slots.footer"
|
|
53
|
+
class="pxd-bubble--footer flex items-center group-data-[role='user']/bubble:justify-end"
|
|
54
|
+
>
|
|
55
|
+
<slot name="footer" />
|
|
56
|
+
</footer>
|
|
57
|
+
</div>
|
|
58
|
+
</article>
|
|
59
|
+
</template>
|
|
@@ -10,8 +10,6 @@ type __VLS_Slots = {} & {
|
|
|
10
10
|
declare const __VLS_base: import("vue").DefineComponent<ButtonProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ButtonProps> & Readonly<{}>, {
|
|
11
11
|
icon: boolean;
|
|
12
12
|
as: import("../../types/shared").ComponentAs;
|
|
13
|
-
variant: import("./types").ButtonVariant;
|
|
14
|
-
align: "left" | "center" | "right";
|
|
15
13
|
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
16
14
|
declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
|
|
17
15
|
declare const _default: typeof __VLS_export;
|