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.
Files changed (242) hide show
  1. package/LICENSE +21 -0
  2. package/dist/components/_internal/dismiss-container.d.vue.ts +28 -0
  3. package/dist/components/_internal/dismiss-container.vue +162 -0
  4. package/dist/components/_internal/popover-arrow.d.vue.ts +9 -0
  5. package/dist/components/_internal/popover-arrow.vue +38 -0
  6. package/dist/components/active-graph/index.vue +5 -5
  7. package/dist/components/avatar/index.vue +5 -7
  8. package/dist/components/avatar-group/index.d.vue.ts +0 -1
  9. package/dist/components/avatar-group/index.vue +1 -1
  10. package/dist/components/backtop/index.vue +1 -1
  11. package/dist/components/badge/index.d.vue.ts +6 -2
  12. package/dist/components/badge/index.vue +19 -5
  13. package/dist/components/badge/types.d.ts +5 -0
  14. package/dist/components/book/index.vue +1 -1
  15. package/dist/components/browser/index.vue +1 -1
  16. package/dist/components/bubble/index.d.vue.ts +22 -0
  17. package/dist/components/bubble/index.vue +59 -0
  18. package/dist/components/bubble/types.d.ts +6 -0
  19. package/dist/components/button/index.d.vue.ts +0 -2
  20. package/dist/components/button/index.vue +31 -22
  21. package/dist/components/button/types.d.ts +3 -2
  22. package/dist/components/button-group/index.d.vue.ts +14 -0
  23. package/dist/components/button-group/index.vue +26 -0
  24. package/dist/components/button-group/types.d.ts +9 -0
  25. package/dist/components/carousel/index.d.vue.ts +3 -3
  26. package/dist/components/carousel/index.vue +146 -113
  27. package/dist/components/carousel/types.d.ts +1 -1
  28. package/dist/components/carousel-item/index.vue +22 -17
  29. package/dist/components/checkbox/index.vue +7 -7
  30. package/dist/components/checkbox-group/index.d.vue.ts +1 -1
  31. package/dist/components/chip/index.d.vue.ts +1 -5
  32. package/dist/components/chip/index.vue +5 -5
  33. package/dist/components/choicebox/index.vue +1 -1
  34. package/dist/components/collapse-group/index.vue +1 -1
  35. package/dist/components/color-selector/index.d.vue.ts +12 -0
  36. package/dist/components/color-selector/index.vue +64 -0
  37. package/dist/components/color-selector/types.d.ts +12 -0
  38. package/dist/components/command-menu/index.d.vue.ts +6 -6
  39. package/dist/components/command-menu/index.vue +24 -33
  40. package/dist/components/command-menu/types.d.ts +1 -1
  41. package/dist/components/command-menu-group/index.vue +15 -6
  42. package/dist/components/command-menu-group/types.d.ts +1 -1
  43. package/dist/components/config-provider/index.d.vue.ts +1 -1
  44. package/dist/components/countdown/index.d.vue.ts +11 -11
  45. package/dist/components/drawer/index.d.vue.ts +8 -8
  46. package/dist/components/drawer/index.vue +13 -10
  47. package/dist/components/drawer/types.d.ts +4 -3
  48. package/dist/components/ellipsis-text/index.d.vue.ts +4 -1
  49. package/dist/components/ellipsis-text/index.vue +86 -109
  50. package/dist/components/ellipsis-text/types.d.ts +2 -1
  51. package/dist/components/error/index.vue +2 -2
  52. package/dist/components/fader/index.vue +5 -9
  53. package/dist/components/gauge/index.vue +34 -29
  54. package/dist/components/grid/index.vue +1 -1
  55. package/dist/components/grid-item/index.vue +1 -1
  56. package/dist/components/hold-button/index.d.vue.ts +8 -10
  57. package/dist/components/hold-button/index.vue +15 -27
  58. package/dist/components/hold-button/types.d.ts +5 -6
  59. package/dist/components/index.d.ts +7 -0
  60. package/dist/components/index.js +7 -0
  61. package/dist/components/input/index.d.vue.ts +8 -8
  62. package/dist/components/input/index.vue +7 -6
  63. package/dist/components/intersection-observer/index.vue +4 -4
  64. package/dist/components/kbd/index.vue +2 -2
  65. package/dist/components/link-button/index.d.vue.ts +4 -4
  66. package/dist/components/link-button/index.vue +5 -7
  67. package/dist/components/link-button/types.d.ts +0 -3
  68. package/dist/components/list/index.d.vue.ts +10 -15
  69. package/dist/components/list/index.vue +58 -131
  70. package/dist/components/list/types.d.ts +4 -4
  71. package/dist/components/list-item/index.d.vue.ts +2 -2
  72. package/dist/components/list-item/index.vue +45 -40
  73. package/dist/components/loading-bar/index.vue +9 -8
  74. package/dist/components/material/index.vue +24 -46
  75. package/dist/components/menu/index.d.vue.ts +6 -8
  76. package/dist/components/menu/index.vue +18 -24
  77. package/dist/components/menu/types.d.ts +1 -2
  78. package/dist/components/message/composables/use-group-expand.d.ts +13 -0
  79. package/dist/components/message/composables/use-group-expand.js +50 -0
  80. package/dist/components/message/composables/use-message-timer.d.ts +9 -0
  81. package/dist/components/message/composables/use-message-timer.js +61 -0
  82. package/dist/components/message/composables/use-promise-message.d.ts +4 -0
  83. package/dist/components/message/composables/use-promise-message.js +49 -0
  84. package/dist/components/message/index.d.vue.ts +6 -33
  85. package/dist/components/message/index.vue +33 -185
  86. package/dist/components/message/types.d.ts +2 -2
  87. package/dist/components/message-item/index.vue +26 -2
  88. package/dist/components/modal/index.d.vue.ts +7 -7
  89. package/dist/components/modal/index.vue +7 -3
  90. package/dist/components/modal/types.d.ts +7 -3
  91. package/dist/components/note/index.vue +3 -3
  92. package/dist/components/number-input/index.d.vue.ts +5 -4
  93. package/dist/components/number-input/index.vue +3 -0
  94. package/dist/components/number-input/types.d.ts +1 -0
  95. package/dist/components/overlay/index.d.vue.ts +6 -3
  96. package/dist/components/overlay/index.vue +63 -68
  97. package/dist/components/overlay/types.d.ts +5 -4
  98. package/dist/components/pagination/index.vue +2 -2
  99. package/dist/components/pin-input/index.d.vue.ts +2 -2
  100. package/dist/components/pin-input/index.vue +9 -8
  101. package/dist/components/placeholder/index.vue +14 -12
  102. package/dist/components/popover/index.d.vue.ts +8 -9
  103. package/dist/components/popover/index.vue +150 -240
  104. package/dist/components/popover/types.d.ts +6 -7
  105. package/dist/components/progress/index.vue +3 -3
  106. package/dist/components/project-banner/index.vue +1 -1
  107. package/dist/components/radio/index.vue +3 -3
  108. package/dist/components/radio-group/index.vue +1 -1
  109. package/dist/components/resizable/index.vue +43 -51
  110. package/dist/components/resizable/types.d.ts +1 -1
  111. package/dist/components/resizable-handle/index.d.vue.ts +4 -1
  112. package/dist/components/resizable-handle/index.vue +29 -3
  113. package/dist/components/resizable-panel/index.vue +3 -7
  114. package/dist/components/scalable-text/index.d.vue.ts +9 -0
  115. package/dist/components/scalable-text/index.vue +147 -0
  116. package/dist/components/scalable-text/types.d.ts +12 -0
  117. package/dist/components/scrollable/index.d.vue.ts +2 -2
  118. package/dist/components/scrollable/index.vue +4 -3
  119. package/dist/components/scrollable/types.d.ts +1 -2
  120. package/dist/components/separator/index.d.vue.ts +6 -0
  121. package/dist/components/separator/index.vue +18 -0
  122. package/dist/components/separator/types.d.ts +5 -0
  123. package/dist/components/skeleton/index.d.vue.ts +1 -1
  124. package/dist/components/skeleton/index.vue +1 -1
  125. package/dist/components/slider/index.d.vue.ts +1 -1
  126. package/dist/components/slider/index.vue +41 -9
  127. package/dist/components/snippet/index.vue +18 -15
  128. package/dist/components/spinner/index.vue +3 -1
  129. package/dist/components/stack/index.d.vue.ts +1 -1
  130. package/dist/components/stack/index.vue +2 -2
  131. package/dist/components/switch/index.d.vue.ts +1 -1
  132. package/dist/components/switch/index.vue +5 -4
  133. package/dist/components/switch-item/index.vue +3 -3
  134. package/dist/components/tabs/index.d.vue.ts +12 -0
  135. package/dist/components/tabs/index.vue +270 -0
  136. package/dist/components/tabs/types.d.ts +12 -0
  137. package/dist/components/tabs-item/index.d.vue.ts +4 -0
  138. package/dist/components/tabs-item/index.vue +16 -0
  139. package/dist/components/tabs-item/types.d.ts +10 -0
  140. package/dist/components/text/index.vue +2 -2
  141. package/dist/components/textarea/index.d.vue.ts +2 -2
  142. package/dist/components/textarea/index.vue +3 -3
  143. package/dist/components/time-picker/index.d.vue.ts +3 -5
  144. package/dist/components/time-picker/index.vue +54 -46
  145. package/dist/components/time-picker/types.d.ts +1 -2
  146. package/dist/components/toggle/index.d.vue.ts +0 -2
  147. package/dist/components/toggle/index.vue +7 -7
  148. package/dist/components/toggle-button/index.vue +11 -9
  149. package/dist/components/toggle-button-group/index.vue +3 -3
  150. package/dist/components/tooltip/index.d.vue.ts +1 -1
  151. package/dist/components/tooltip/index.vue +19 -11
  152. package/dist/components/tooltip/types.d.ts +2 -3
  153. package/dist/components/virtual-list/index.d.vue.ts +8 -8
  154. package/dist/components/virtual-list/index.vue +29 -7
  155. package/dist/components/virtual-list/types.d.ts +3 -0
  156. package/dist/composables/index.d.ts +4 -1
  157. package/dist/composables/index.js +4 -1
  158. package/dist/composables/use-browser-observer.d.ts +1 -1
  159. package/dist/composables/use-browser-observer.js +2 -2
  160. package/dist/composables/use-client-online.js +2 -2
  161. package/dist/composables/use-color-scheme.js +2 -2
  162. package/dist/composables/use-countdown.js +3 -2
  163. package/dist/composables/use-deferred-value.js +2 -2
  164. package/dist/composables/use-delay-destroy.d.ts +1 -1
  165. package/dist/composables/use-delay-destroy.js +11 -6
  166. package/dist/composables/use-document-hidden.js +2 -2
  167. package/dist/composables/use-focus-trap.d.ts +1 -1
  168. package/dist/composables/use-focus-trap.js +2 -2
  169. package/dist/composables/use-list-filter.d.ts +11 -0
  170. package/dist/composables/use-list-filter.js +56 -0
  171. package/dist/composables/use-list-navigation.d.ts +27 -0
  172. package/dist/composables/use-list-navigation.js +159 -0
  173. package/dist/composables/use-lock-scroll.js +12 -12
  174. package/dist/composables/use-media-query.js +2 -2
  175. package/dist/composables/use-message.d.ts +1 -1
  176. package/dist/composables/use-outside-click.d.ts +1 -1
  177. package/dist/composables/use-outside-click.js +8 -11
  178. package/dist/composables/use-overlay-manager.d.ts +18 -0
  179. package/dist/composables/use-overlay-manager.js +80 -0
  180. package/dist/composables/use-popover-responsive.d.ts +6 -8
  181. package/dist/composables/use-popover-responsive.js +9 -12
  182. package/dist/composables/use-repeat-action.d.ts +1 -1
  183. package/dist/composables/use-repeat-action.js +2 -2
  184. package/dist/composables/use-swipe-gesture.d.ts +65 -0
  185. package/dist/composables/use-swipe-gesture.js +99 -0
  186. package/dist/composables/use-virtual-list.d.ts +6 -4
  187. package/dist/composables/use-virtual-list.js +25 -14
  188. package/dist/composables/use-window-size.js +2 -2
  189. package/dist/constants/size.d.ts +12 -0
  190. package/dist/constants/size.js +12 -0
  191. package/dist/contexts/button.d.ts +5 -0
  192. package/dist/contexts/button.js +5 -0
  193. package/dist/contexts/carousel.d.ts +3 -2
  194. package/dist/contexts/checkbox.d.ts +1 -1
  195. package/dist/contexts/choicebox.d.ts +1 -1
  196. package/dist/contexts/collapse.d.ts +1 -1
  197. package/dist/contexts/list.d.ts +23 -3
  198. package/dist/contexts/list.js +6 -2
  199. package/dist/contexts/radio.d.ts +1 -1
  200. package/dist/contexts/resizable.d.ts +3 -11
  201. package/dist/contexts/switch.d.ts +1 -1
  202. package/dist/contexts/tabs.d.ts +15 -0
  203. package/dist/contexts/tabs.js +2 -0
  204. package/dist/contexts/toggle-button.d.ts +1 -1
  205. package/dist/locales/en-us.d.ts +4 -4
  206. package/dist/locales/en-us.js +4 -4
  207. package/dist/locales/zh-cn.d.ts +4 -4
  208. package/dist/locales/zh-cn.js +4 -4
  209. package/dist/plugins/dayjs-millisecond-token.js +1 -1
  210. package/dist/styles/source.css +133 -128
  211. package/dist/styles/styles.css +2 -2
  212. package/dist/styles/tw.css +133 -128
  213. package/dist/types/shared/props.d.ts +1 -0
  214. package/dist/types/shared/utils.d.ts +1 -4
  215. package/dist/utils/date.d.ts +3 -3
  216. package/dist/utils/dom.d.ts +1 -0
  217. package/dist/utils/dom.js +4 -0
  218. package/dist/utils/event.d.ts +2 -1
  219. package/dist/utils/event.js +7 -1
  220. package/dist/utils/format.d.ts +3 -3
  221. package/dist/utils/format.js +5 -4
  222. package/dist/utils/fuzzy-search.d.ts +7 -0
  223. package/dist/utils/fuzzy-search.js +61 -0
  224. package/dist/utils/get.d.ts +2 -0
  225. package/dist/utils/get.js +15 -1
  226. package/dist/utils/index.d.ts +10 -11
  227. package/dist/utils/index.js +2 -3
  228. package/dist/utils/ref.d.ts +2 -2
  229. package/dist/utils/{throttle.d.ts → timing.d.ts} +1 -0
  230. package/dist/utils/{throttle.js → timing.js} +4 -2
  231. package/package.json +67 -63
  232. package/volar.d.ts +7 -0
  233. package/dist/components/overlay/overlay-stack.d.ts +0 -3
  234. package/dist/components/overlay/overlay-stack.js +0 -17
  235. package/dist/composables/use-pointer-gesture.d.ts +0 -180
  236. package/dist/composables/use-pointer-gesture.js +0 -406
  237. package/dist/utils/debounce.d.ts +0 -1
  238. package/dist/utils/debounce.js +0 -1
  239. package/dist/utils/regexp.d.ts +0 -8
  240. package/dist/utils/regexp.js +0 -8
  241. package/dist/utils/responsive.d.ts +0 -3
  242. 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, '2px') }"
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-all"
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-13px text-gray-100 duration-50 will-change-transform motion-safe:transition-transform"
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-13px select-none before:default-animation-timing-function! motion-safe:before:[animation-duration:8s]"
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-400);
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, default: 32 },
11
+ size: { type: [Number, String], required: false },
12
12
  options: { type: Array, required: false, default: () => [] }
13
13
  });
14
14
  const slicedOptions = computed(() => {
@@ -56,7 +56,7 @@ onBeforeUnmount(() => {
56
56
  </script>
57
57
 
58
58
  <template>
59
- <Transition name="pxd-transition--fade-scale" appear>
59
+ <Transition name="pxd-transition--fade-scale" mode="out-in" appear>
60
60
  <div
61
61
  v-show="scrollTop >= visibleThreshold"
62
62
  ref="wrapperRef"
@@ -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, {}, string, import("vue").PublicProps, Readonly<BadgeProps> & Readonly<{}>, {
7
- as: import("../../types/shared").ComponentAs;
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: "gray" }
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-all",
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-2 h-5 text-xs",
46
+ sm: "px-1.5 h-5 text-xs",
44
47
  md: "px-2.5 h-6 text-xs",
45
- lg: "px-3 h-7.5 text-sm"
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
 
@@ -29,4 +29,9 @@ export interface BadgeProps {
29
29
  href?: string
30
30
  size?: ComponentSize
31
31
  variant?: BadgeVariant
32
+ closeable?: boolean
33
+ }
34
+
35
+ export interface BadgeEmits {
36
+ close: [Event]
32
37
  }
@@ -1,6 +1,6 @@
1
1
  <script setup>
2
2
  import { computed } from "vue";
3
- import { getResponsiveValue } from "../../utils/responsive";
3
+ import { getResponsiveValue } from "../../utils/get";
4
4
  defineOptions({
5
5
  name: "PBook",
6
6
  inheritAttrs: false
@@ -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-13px text-gray-1000">
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>
@@ -0,0 +1,6 @@
1
+ export interface BubbleProps {
2
+ role?: 'user' | 'assistant'
3
+ header?: string
4
+ avatar?: string
5
+ loading?: boolean
6
+ }
@@ -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;