@talex-touch/tuffex 0.3.3 → 0.3.4

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 (610) hide show
  1. package/README.md +49 -221
  2. package/dist/es/agents/index.js +1 -1
  3. package/dist/es/alert/index.d.ts +104 -1
  4. package/dist/es/alert/index.js +6 -0
  5. package/dist/es/alert/src/TxAlert.vue.d.ts +1 -0
  6. package/dist/es/alert/src/TxAlert.vue.js +2 -2
  7. package/dist/es/alert/src/TxAlert.vue2.js +6 -2
  8. package/dist/es/auto-sizer/index.js +1 -1
  9. package/dist/es/auto-sizer/src/TxAutoSizer.vue.js +2 -2
  10. package/dist/es/avatar/index.js +1 -1
  11. package/dist/es/avatar/src/TxAvatar.vue.js +1 -1
  12. package/dist/es/avatar/src/TxAvatar.vue2.js +47 -6
  13. package/dist/es/avatar/src/TxAvatarGroup.vue.js +1 -1
  14. package/dist/es/avatar/src/TxAvatarGroup.vue2.js +1 -1
  15. package/dist/es/avatar/src/types.d.ts +2 -1
  16. package/dist/es/badge/index.d.ts +78 -1
  17. package/dist/es/badge/index.js +6 -0
  18. package/dist/es/badge/src/TxBadge.vue.js +2 -2
  19. package/dist/es/base-anchor/index.d.ts +464 -0
  20. package/dist/es/base-anchor/index.js +6 -0
  21. package/dist/es/base-anchor/src/TxBaseAnchor.vue.d.ts +124 -0
  22. package/dist/es/base-anchor/src/TxBaseAnchor.vue.js +7 -0
  23. package/dist/es/base-anchor/src/TxBaseAnchor.vue2.js +798 -0
  24. package/dist/es/base-anchor/src/types.d.ts +36 -0
  25. package/dist/es/base-surface/index.d.ts +561 -0
  26. package/dist/es/base-surface/index.js +7 -0
  27. package/dist/es/base-surface/src/TxBaseSurface.vue.d.ts +123 -0
  28. package/dist/es/base-surface/src/TxBaseSurface.vue.js +1012 -0
  29. package/dist/es/base-surface/src/TxBaseSurface.vue2.js +6 -0
  30. package/dist/es/base-surface/src/style/index.css +105 -0
  31. package/dist/es/base-surface/src/types.d.ts +87 -0
  32. package/dist/es/blank-slate/index.d.ts +9 -9
  33. package/dist/es/blank-slate/index.js +1 -1
  34. package/dist/es/button/index.d.ts +45 -15
  35. package/dist/es/button/index.js +2 -1
  36. package/dist/es/button/src/button.vue.d.ts +7 -1
  37. package/dist/es/button/src/button.vue.js +50 -20
  38. package/dist/es/button/src/split-button.vue.js +31 -5
  39. package/dist/es/button/src/style/index.css +72 -15
  40. package/dist/es/button/src/types.d.ts +4 -0
  41. package/dist/es/card/index.d.ts +236 -56
  42. package/dist/es/card/index.js +1 -1
  43. package/dist/es/card/src/TxCard.vue.d.ts +40 -4
  44. package/dist/es/card/src/TxCard.vue.js +1 -1
  45. package/dist/es/card/src/TxCard.vue2.js +288 -57
  46. package/dist/es/card/src/types.d.ts +14 -1
  47. package/dist/es/card-item/index.d.ts +7 -7
  48. package/dist/es/card-item/index.js +1 -1
  49. package/dist/es/cascader/index.d.ts +15 -15
  50. package/dist/es/cascader/index.js +1 -1
  51. package/dist/es/cascader/src/TxCascader.vue.d.ts +1 -1
  52. package/dist/es/cascader/src/TxCascader.vue.js +1 -1
  53. package/dist/es/cascader/src/TxCascader.vue2.js +1 -3
  54. package/dist/es/chat/index.d.ts +18 -18
  55. package/dist/es/chat/index.js +1 -1
  56. package/dist/es/chat/src/TxChatComposer.vue.js +1 -1
  57. package/dist/es/chat/src/TxChatComposer.vue2.js +1 -0
  58. package/dist/es/chat/src/TxTypingIndicator.vue.d.ts +1 -1
  59. package/dist/es/code-editor/index.d.ts +387 -0
  60. package/dist/es/code-editor/index.js +8 -0
  61. package/dist/es/code-editor/src/TxCodeEditor.vue.d.ts +117 -0
  62. package/dist/es/code-editor/src/TxCodeEditor.vue.js +7 -0
  63. package/dist/es/code-editor/src/TxCodeEditor.vue2.js +658 -0
  64. package/dist/es/code-editor/src/TxCodeEditorToolbar.vue.d.ts +40 -0
  65. package/dist/es/code-editor/src/TxCodeEditorToolbar.vue.js +7 -0
  66. package/dist/es/code-editor/src/TxCodeEditorToolbar.vue2.js +89 -0
  67. package/dist/es/code-editor/src/types.d.ts +47 -0
  68. package/dist/es/command-palette/index.js +1 -1
  69. package/dist/es/command-palette/src/TxCommandPalette.vue.js +1 -1
  70. package/dist/es/command-palette/src/TxCommandPalette.vue2.js +128 -21
  71. package/dist/es/components.css +4253 -3117
  72. package/dist/es/components.d.ts +15 -2
  73. package/dist/es/components.js +44 -7
  74. package/dist/es/container/src/TxCol.vue.d.ts +1 -1
  75. package/dist/es/container/src/TxCol.vue2.js +1 -1
  76. package/dist/es/container/src/TxContainer.vue.d.ts +1 -1
  77. package/dist/es/container/src/TxRow.vue.d.ts +2 -2
  78. package/dist/es/container/src/TxRow.vue2.js +1 -1
  79. package/dist/es/context-menu/index.js +1 -1
  80. package/dist/es/context-menu/src/TxContextMenu.vue.js +1 -1
  81. package/dist/es/context-menu/src/TxContextMenu.vue2.js +4 -1
  82. package/dist/es/corner-overlay/index.js +1 -1
  83. package/dist/es/data-table/index.d.ts +15 -15
  84. package/dist/es/data-table/index.js +1 -1
  85. package/dist/es/data-table/src/TxDataTable.vue.d.ts +1 -1
  86. package/dist/es/date-picker/index.js +1 -1
  87. package/dist/es/dialog/index.js +1 -1
  88. package/dist/es/dialog/src/TxBlowDialog.vue.js +6 -2
  89. package/dist/es/dialog/src/TxBottomDialog.vue.js +1 -1
  90. package/dist/es/dialog/src/TxBottomDialog.vue2.js +6 -2
  91. package/dist/es/dialog/src/TxPopperDialog.vue.js +6 -2
  92. package/dist/es/dialog/src/TxTouchTip.vue.js +1 -1
  93. package/dist/es/dialog/src/TxTouchTip.vue2.js +25 -22
  94. package/dist/es/dialog/src/types.d.ts +1 -1
  95. package/dist/es/drawer/index.d.ts +24 -30
  96. package/dist/es/drawer/index.js +1 -1
  97. package/dist/es/drawer/src/TxDrawer.vue.d.ts +1 -4
  98. package/dist/es/drawer/src/TxDrawer.vue.js +8 -2
  99. package/dist/es/dropdown-menu/index.d.ts +81 -18
  100. package/dist/es/dropdown-menu/index.js +1 -1
  101. package/dist/es/dropdown-menu/src/TxDropdownMenu.vue.d.ts +11 -2
  102. package/dist/es/dropdown-menu/src/TxDropdownMenu.vue.js +1 -1
  103. package/dist/es/dropdown-menu/src/TxDropdownMenu.vue2.js +13 -3
  104. package/dist/es/dropdown-menu/src/types.d.ts +8 -1
  105. package/dist/es/edge-fade-mask/index.d.ts +120 -0
  106. package/dist/es/edge-fade-mask/index.js +6 -0
  107. package/dist/es/edge-fade-mask/src/TxEdgeFadeMask.vue.d.ts +51 -0
  108. package/dist/es/edge-fade-mask/src/TxEdgeFadeMask.vue.js +7 -0
  109. package/dist/es/edge-fade-mask/src/TxEdgeFadeMask.vue2.js +154 -0
  110. package/dist/es/edge-fade-mask/src/types.d.ts +9 -0
  111. package/dist/es/empty/index.js +1 -1
  112. package/dist/es/empty-state/index.d.ts +9 -9
  113. package/dist/es/empty-state/index.js +1 -1
  114. package/dist/es/empty-state/src/TxEmptyState.vue.js +1 -1
  115. package/dist/es/empty-state/src/TxEmptyState.vue2.js +25 -17
  116. package/dist/es/error-state/index.d.ts +131 -0
  117. package/dist/es/error-state/index.js +6 -0
  118. package/dist/es/error-state/src/TxErrorState.vue.d.ts +13 -0
  119. package/dist/es/error-state/src/TxErrorState.vue.js +35 -0
  120. package/dist/es/error-state/src/TxErrorState.vue2.js +5 -0
  121. package/dist/es/error-state/src/types.d.ts +3 -0
  122. package/dist/es/file-uploader/index.js +1 -1
  123. package/dist/es/flat-radio/index.d.ts +201 -0
  124. package/dist/es/flat-radio/index.js +8 -0
  125. package/dist/es/flat-radio/src/TxFlatRadio.vue.d.ts +51 -0
  126. package/dist/es/flat-radio/src/TxFlatRadio.vue.js +7 -0
  127. package/dist/es/flat-radio/src/TxFlatRadio.vue2.js +237 -0
  128. package/dist/es/flat-radio/src/TxFlatRadioItem.vue.d.ts +43 -0
  129. package/dist/es/flat-radio/src/TxFlatRadioItem.vue.js +7 -0
  130. package/dist/es/flat-radio/src/TxFlatRadioItem.vue2.js +87 -0
  131. package/dist/es/flat-radio/src/types.d.ts +28 -0
  132. package/dist/es/flat-radio/src/types.js +3 -0
  133. package/dist/es/flat-select/index.d.ts +159 -0
  134. package/dist/es/flat-select/index.js +8 -0
  135. package/dist/es/flat-select/src/TxFlatSelect.vue.d.ts +56 -0
  136. package/dist/es/flat-select/src/TxFlatSelect.vue.js +7 -0
  137. package/dist/es/flat-select/src/TxFlatSelect.vue2.js +208 -0
  138. package/dist/es/flat-select/src/TxFlatSelectItem.vue.d.ts +47 -0
  139. package/dist/es/flat-select/src/TxFlatSelectItem.vue.js +7 -0
  140. package/dist/es/flat-select/src/TxFlatSelectItem.vue2.js +71 -0
  141. package/dist/es/flat-select/src/types.d.ts +21 -0
  142. package/dist/es/flat-select/src/types.js +3 -0
  143. package/dist/es/flex/index.d.ts +33 -33
  144. package/dist/es/flex/index.js +1 -1
  145. package/dist/es/flex/src/TxFlex.vue.d.ts +3 -3
  146. package/dist/es/flip-overlay/index.d.ts +579 -0
  147. package/dist/es/flip-overlay/index.js +7 -0
  148. package/dist/es/flip-overlay/src/TxFlipOverlay.vue.d.ts +175 -0
  149. package/dist/es/flip-overlay/src/TxFlipOverlay.vue.js +982 -0
  150. package/dist/es/flip-overlay/src/TxFlipOverlay.vue3.js +6 -0
  151. package/dist/es/flip-overlay/src/types.d.ts +53 -0
  152. package/dist/es/floating/index.d.ts +145 -0
  153. package/dist/es/floating/index.js +8 -0
  154. package/dist/es/floating/src/TxFloating.vue.d.ts +45 -0
  155. package/dist/es/floating/src/TxFloating.vue.js +7 -0
  156. package/dist/es/floating/src/TxFloating.vue2.js +118 -0
  157. package/dist/es/floating/src/TxFloatingElement.vue.d.ts +39 -0
  158. package/dist/es/floating/src/TxFloatingElement.vue.js +7 -0
  159. package/dist/es/floating/src/TxFloatingElement.vue2.js +43 -0
  160. package/dist/es/floating/src/context.d.ts +7 -0
  161. package/dist/es/floating/src/context.js +3 -0
  162. package/dist/es/floating/src/types.d.ts +10 -0
  163. package/dist/es/form/index.d.ts +9 -9
  164. package/dist/es/form/index.js +1 -1
  165. package/dist/es/fusion/index.d.ts +15 -15
  166. package/dist/es/fusion/index.js +1 -1
  167. package/dist/es/fusion/src/TxFusion.vue.d.ts +1 -1
  168. package/dist/es/glass-surface/index.d.ts +30 -30
  169. package/dist/es/glass-surface/index.js +1 -1
  170. package/dist/es/glass-surface/src/TxGlassSurface.vue.d.ts +2 -2
  171. package/dist/es/glass-surface/src/TxGlassSurface.vue.js +16 -38
  172. package/dist/es/glow-text/index.d.ts +24 -6
  173. package/dist/es/glow-text/index.js +1 -1
  174. package/dist/es/glow-text/src/TxGlowText.vue.d.ts +3 -3
  175. package/dist/es/glow-text/src/TxGlowText.vue.js +1 -1
  176. package/dist/es/glow-text/src/TxGlowText.vue2.js +93 -10
  177. package/dist/es/glow-text/src/types.d.ts +2 -0
  178. package/dist/es/gradient-border/index.js +1 -1
  179. package/dist/es/gradual-blur/index.d.ts +42 -42
  180. package/dist/es/gradual-blur/index.js +1 -1
  181. package/dist/es/gradual-blur/src/TxGradualBlur.vue.d.ts +3 -3
  182. package/dist/es/gradual-blur/src/TxGradualBlur.vue.js +1 -1
  183. package/dist/es/grid/src/TxGrid.vue.d.ts +2 -2
  184. package/dist/es/grid/src/TxGrid.vue2.js +1 -1
  185. package/dist/es/grid-layout/index.js +1 -1
  186. package/dist/es/group-block/index.d.ts +321 -4
  187. package/dist/es/group-block/index.js +8 -2
  188. package/dist/es/group-block/src/TxBlockInput.vue.d.ts +90 -0
  189. package/dist/es/group-block/src/TxBlockInput.vue.js +94 -0
  190. package/dist/es/group-block/src/TxBlockInput.vue3.js +6 -0
  191. package/dist/es/group-block/src/TxBlockSelect.vue.d.ts +73 -0
  192. package/dist/es/group-block/src/TxBlockSelect.vue.js +76 -0
  193. package/dist/es/group-block/src/TxBlockSelect.vue3.js +6 -0
  194. package/dist/es/group-block/src/TxGroupBlock.vue.js +1 -1
  195. package/dist/es/group-block/src/types.d.ts +138 -0
  196. package/dist/es/guide-state/index.d.ts +131 -0
  197. package/dist/es/guide-state/index.js +6 -0
  198. package/dist/es/guide-state/src/TxGuideState.vue.d.ts +13 -0
  199. package/dist/es/guide-state/src/TxGuideState.vue.js +35 -0
  200. package/dist/es/guide-state/src/TxGuideState.vue2.js +5 -0
  201. package/dist/es/guide-state/src/types.d.ts +3 -0
  202. package/dist/es/icon/index.js +1 -1
  203. package/dist/es/icon/src/TxIcon.vue.js +1 -1
  204. package/dist/es/icon/src/TxIcon.vue2.js +10 -4
  205. package/dist/es/image-gallery/index.js +1 -1
  206. package/dist/es/image-uploader/index.js +1 -1
  207. package/dist/es/index.js +53 -13
  208. package/dist/es/input/index.d.ts +211 -1
  209. package/dist/es/input/index.js +2 -1
  210. package/dist/es/input/src/TxInput.vue.d.ts +21 -11
  211. package/dist/es/input/src/TxInput.vue.js +1 -1
  212. package/dist/es/input/src/TxInput.vue2.js +80 -23
  213. package/dist/es/keyframe-stroke-text/index.d.ts +146 -0
  214. package/dist/es/keyframe-stroke-text/index.js +6 -0
  215. package/dist/es/keyframe-stroke-text/src/TxKeyframeStrokeText.vue.d.ts +48 -0
  216. package/dist/es/keyframe-stroke-text/src/TxKeyframeStrokeText.vue.js +7 -0
  217. package/dist/es/keyframe-stroke-text/src/TxKeyframeStrokeText.vue2.js +102 -0
  218. package/dist/es/keyframe-stroke-text/src/types.d.ts +10 -0
  219. package/dist/es/layout-skeleton/index.js +1 -1
  220. package/dist/es/loading-overlay/index.d.ts +15 -15
  221. package/dist/es/loading-overlay/index.js +1 -1
  222. package/dist/es/loading-overlay/src/TxLoadingOverlay.vue.d.ts +1 -1
  223. package/dist/es/loading-overlay/src/TxLoadingOverlay.vue.js +12 -2
  224. package/dist/es/loading-state/index.d.ts +9 -9
  225. package/dist/es/loading-state/index.js +1 -1
  226. package/dist/es/markdown-view/index.d.ts +3 -3
  227. package/dist/es/markdown-view/index.js +1 -1
  228. package/dist/es/markdown-view/src/TxMarkdownView.vue.js +3 -2
  229. package/dist/es/modal/index.js +1 -1
  230. package/dist/es/modal/src/TxModal.vue.js +1 -1
  231. package/dist/es/modal/src/TxModal.vue2.js +26 -4
  232. package/dist/es/nav-bar/index.js +1 -1
  233. package/dist/es/no-data/index.d.ts +9 -9
  234. package/dist/es/no-data/index.js +1 -1
  235. package/dist/es/no-selection/index.d.ts +9 -9
  236. package/dist/es/no-selection/index.js +1 -1
  237. package/dist/es/node_modules/.pnpm/@codemirror_legacy-modes@6.5.2/node_modules/@codemirror/legacy-modes/mode/properties.js +62 -0
  238. package/dist/es/node_modules/.pnpm/@codemirror_legacy-modes@6.5.2/node_modules/@codemirror/legacy-modes/mode/toml.js +76 -0
  239. package/dist/es/node_modules/.pnpm/@lezer_common@1.5.0/node_modules/@lezer/common/dist/index.js +252 -0
  240. package/dist/es/node_modules/.pnpm/@lezer_highlight@1.2.3/node_modules/@lezer/highlight/dist/index.js +682 -0
  241. package/dist/es/offline-state/index.d.ts +9 -9
  242. package/dist/es/offline-state/index.js +1 -1
  243. package/dist/es/outline-border/index.d.ts +18 -18
  244. package/dist/es/outline-border/index.js +1 -1
  245. package/dist/es/outline-border/src/TxOutlineBorder.vue.d.ts +1 -1
  246. package/dist/es/{utils → packages/tuffex/packages/utils}/toast.js +4 -1
  247. package/dist/es/packages/tuffex/packages/utils/z-index-manager.js +114 -0
  248. package/dist/es/packages/utils/env/index.js +8 -0
  249. package/dist/es/permission-state/index.d.ts +9 -9
  250. package/dist/es/permission-state/index.js +1 -1
  251. package/dist/es/picker/index.js +1 -1
  252. package/dist/es/picker/src/TxPicker.vue.js +1 -1
  253. package/dist/es/picker/src/TxPicker.vue2.js +6 -1
  254. package/dist/es/popover/index.d.ts +195 -82
  255. package/dist/es/popover/index.js +1 -1
  256. package/dist/es/popover/src/TxPopover.vue.d.ts +33 -16
  257. package/dist/es/popover/src/TxPopover.vue.js +1 -1
  258. package/dist/es/popover/src/TxPopover.vue2.js +147 -317
  259. package/dist/es/popover/src/types.d.ts +14 -3
  260. package/dist/es/progress-bar/index.d.ts +21 -21
  261. package/dist/es/progress-bar/index.js +1 -1
  262. package/dist/es/progress-bar/src/TxProgressBar.vue.d.ts +1 -1
  263. package/dist/es/radio/index.js +1 -1
  264. package/dist/es/radio/src/TxRadioGroup.vue2.js +1 -1
  265. package/dist/es/scroll/index.d.ts +42 -12
  266. package/dist/es/scroll/index.js +1 -1
  267. package/dist/es/scroll/src/TxScroll.vue.d.ts +11 -1
  268. package/dist/es/scroll/src/TxScroll.vue.js +1 -1
  269. package/dist/es/scroll/src/TxScroll.vue2.js +25 -13
  270. package/dist/es/scroll/src/runtime-capabilities.d.ts +2 -0
  271. package/dist/es/scroll/src/runtime-capabilities.js +67 -0
  272. package/dist/es/search-empty/index.d.ts +9 -9
  273. package/dist/es/search-empty/index.js +1 -1
  274. package/dist/es/search-input/index.js +1 -1
  275. package/dist/es/search-select/index.d.ts +9 -9
  276. package/dist/es/search-select/index.js +1 -1
  277. package/dist/es/search-select/src/TxSearchSelect.vue.d.ts +1 -1
  278. package/dist/es/search-select/src/TxSearchSelect.vue.js +1 -1
  279. package/dist/es/search-select/src/TxSearchSelect.vue2.js +105 -178
  280. package/dist/es/search-select/src/types.d.ts +1 -1
  281. package/dist/es/segmented-slider/index.js +1 -1
  282. package/dist/es/segmented-slider/src/TxSegmentedSlider.vue.js +1 -0
  283. package/dist/es/select/index.d.ts +366 -4
  284. package/dist/es/select/index.js +6 -9
  285. package/dist/es/select/src/TxSelect.vue.d.ts +23 -23
  286. package/dist/es/select/src/TxSelect.vue.js +2 -2
  287. package/dist/es/select/src/TxSelect.vue2.js +203 -152
  288. package/dist/es/select/src/TxSelectItem.vue.js +2 -2
  289. package/dist/es/select/src/TxSelectItem.vue2.js +44 -7
  290. package/dist/es/select/src/types.d.ts +34 -0
  291. package/dist/es/select/src/types.js +3 -0
  292. package/dist/es/skeleton/index.d.ts +7 -7
  293. package/dist/es/skeleton/index.js +1 -1
  294. package/dist/es/slider/index.d.ts +4 -4
  295. package/dist/es/slider/index.js +1 -1
  296. package/dist/es/sortable-list/index.js +1 -1
  297. package/dist/es/sortable-list/src/TxSortableList.vue.js +1 -1
  298. package/dist/es/sortable-list/src/TxSortableList.vue2.js +1 -1
  299. package/dist/es/spinner/index.d.ts +1 -1
  300. package/dist/es/spinner/index.js +1 -1
  301. package/dist/es/splitter/index.d.ts +15 -15
  302. package/dist/es/splitter/index.js +1 -1
  303. package/dist/es/splitter/src/TxSplitter.vue.d.ts +1 -1
  304. package/dist/es/stack/index.d.ts +33 -33
  305. package/dist/es/stack/index.js +1 -1
  306. package/dist/es/stack/src/TxStack.vue.d.ts +3 -3
  307. package/dist/es/stagger/index.d.ts +15 -15
  308. package/dist/es/stagger/index.js +1 -1
  309. package/dist/es/stagger/src/TxStagger.vue.d.ts +1 -1
  310. package/dist/es/stat-card/index.d.ts +46 -3
  311. package/dist/es/stat-card/index.js +1 -1
  312. package/dist/es/stat-card/src/TxStatCard.vue.d.ts +5 -1
  313. package/dist/es/stat-card/src/TxStatCard.vue.js +1 -1
  314. package/dist/es/stat-card/src/TxStatCard.vue2.js +247 -19
  315. package/dist/es/stat-card/src/types.d.ts +15 -0
  316. package/dist/es/status-badge/index.js +1 -1
  317. package/dist/es/switch/index.js +1 -0
  318. package/dist/es/tab-bar/index.d.ts +15 -15
  319. package/dist/es/tab-bar/index.js +1 -1
  320. package/dist/es/tab-bar/src/TxTabBar.vue.d.ts +1 -1
  321. package/dist/es/tabs/index.d.ts +18 -3
  322. package/dist/es/tabs/index.js +1 -1
  323. package/dist/es/tabs/src/TxTabs.vue.d.ts +10 -1
  324. package/dist/es/tabs/src/TxTabs.vue.js +1 -1
  325. package/dist/es/tabs/src/TxTabs.vue2.js +3 -1
  326. package/dist/es/tabs/src/types.d.ts +1 -0
  327. package/dist/es/tag/index.js +1 -1
  328. package/dist/es/tag-input/index.js +1 -1
  329. package/dist/es/text-transformer/index.d.ts +1 -1
  330. package/dist/es/text-transformer/index.js +1 -1
  331. package/dist/es/toast/index.js +1 -1
  332. package/dist/es/toast/src/TxToastHost.vue.js +18 -17
  333. package/dist/es/tooltip/index.d.ts +75 -178
  334. package/dist/es/tooltip/index.js +1 -1
  335. package/dist/es/tooltip/src/TxTooltip.vue.d.ts +21 -40
  336. package/dist/es/tooltip/src/TxTooltip.vue.js +1 -1
  337. package/dist/es/tooltip/src/TxTooltip.vue2.js +102 -350
  338. package/dist/es/tooltip/src/types.d.ts +8 -13
  339. package/dist/es/transfer/index.d.ts +131 -0
  340. package/dist/es/transfer/index.js +6 -0
  341. package/dist/es/transfer/src/TxTransfer.vue.d.ts +48 -0
  342. package/dist/es/transfer/src/TxTransfer.vue.js +7 -0
  343. package/dist/es/transfer/src/TxTransfer.vue2.js +217 -0
  344. package/dist/es/transfer/src/types.d.ts +17 -0
  345. package/dist/es/transition/index.d.ts +30 -30
  346. package/dist/es/transition/index.js +1 -1
  347. package/dist/es/transition/src/TxTransition.vue.d.ts +1 -1
  348. package/dist/es/transition/src/TxTransitionSmoothSize.vue.d.ts +1 -1
  349. package/dist/es/tree/index.d.ts +15 -15
  350. package/dist/es/tree/index.js +1 -1
  351. package/dist/es/tree/src/TxTree.vue.d.ts +1 -1
  352. package/dist/es/tree/src/TxTree.vue.js +1 -1
  353. package/dist/es/tree/src/TxTree.vue2.js +3 -2
  354. package/dist/es/tree/src/types.d.ts +1 -0
  355. package/dist/es/tree-select/index.d.ts +9 -9
  356. package/dist/es/tree-select/index.js +1 -1
  357. package/dist/es/tree-select/src/TxTreeSelect.vue.d.ts +1 -1
  358. package/dist/es/tree-select/src/TxTreeSelect.vue.js +1 -1
  359. package/dist/es/tree-select/src/TxTreeSelect.vue2.js +0 -2
  360. package/dist/es/tuff-logo-stroke/index.d.ts +146 -0
  361. package/dist/es/tuff-logo-stroke/index.js +6 -0
  362. package/dist/es/tuff-logo-stroke/src/TxTuffLogoStroke.vue.d.ts +48 -0
  363. package/dist/es/tuff-logo-stroke/src/TxTuffLogoStroke.vue.js +7 -0
  364. package/dist/es/tuff-logo-stroke/src/TxTuffLogoStroke.vue2.js +147 -0
  365. package/dist/es/tuff-logo-stroke/src/types.d.ts +10 -0
  366. package/dist/es/virtual-list/index.js +1 -1
  367. package/dist/lib/agents/index.js +1 -1
  368. package/dist/lib/alert/index.js +11 -0
  369. package/dist/lib/alert/src/TxAlert.vue.js +2 -2
  370. package/dist/lib/alert/src/TxAlert.vue2.js +5 -1
  371. package/dist/lib/auto-sizer/index.js +1 -1
  372. package/dist/lib/auto-sizer/src/TxAutoSizer.vue.js +2 -2
  373. package/dist/lib/avatar/index.js +1 -1
  374. package/dist/lib/avatar/src/TxAvatar.vue.js +1 -1
  375. package/dist/lib/avatar/src/TxAvatar.vue2.js +47 -6
  376. package/dist/lib/avatar/src/TxAvatarGroup.vue.js +1 -1
  377. package/dist/lib/avatar/src/TxAvatarGroup.vue2.js +1 -1
  378. package/dist/lib/badge/index.js +11 -0
  379. package/dist/lib/badge/src/TxBadge.vue.js +2 -2
  380. package/dist/lib/base-anchor/index.js +12 -0
  381. package/dist/lib/base-anchor/src/TxBaseAnchor.vue.js +11 -0
  382. package/dist/lib/base-anchor/src/TxBaseAnchor.vue2.js +802 -0
  383. package/dist/lib/base-surface/index.js +13 -0
  384. package/dist/lib/base-surface/src/TxBaseSurface.vue.js +1016 -0
  385. package/dist/lib/base-surface/src/TxBaseSurface.vue2.js +10 -0
  386. package/dist/lib/base-surface/src/style/index.css +105 -0
  387. package/dist/lib/blank-slate/index.js +1 -1
  388. package/dist/lib/button/index.js +2 -1
  389. package/dist/lib/button/src/button.vue.js +49 -19
  390. package/dist/lib/button/src/split-button.vue.js +30 -4
  391. package/dist/lib/button/src/style/index.css +72 -15
  392. package/dist/lib/card/index.js +1 -1
  393. package/dist/lib/card/src/TxCard.vue.js +1 -1
  394. package/dist/lib/card/src/TxCard.vue2.js +285 -54
  395. package/dist/lib/card-item/index.js +1 -1
  396. package/dist/lib/cascader/index.js +1 -1
  397. package/dist/lib/cascader/src/TxCascader.vue.js +1 -1
  398. package/dist/lib/cascader/src/TxCascader.vue2.js +1 -3
  399. package/dist/lib/chat/index.js +1 -1
  400. package/dist/lib/chat/src/TxChatComposer.vue.js +1 -1
  401. package/dist/lib/chat/src/TxChatComposer.vue2.js +1 -0
  402. package/dist/lib/code-editor/index.js +16 -0
  403. package/dist/lib/code-editor/src/TxCodeEditor.vue.js +11 -0
  404. package/dist/lib/code-editor/src/TxCodeEditor.vue2.js +662 -0
  405. package/dist/lib/code-editor/src/TxCodeEditorToolbar.vue.js +11 -0
  406. package/dist/lib/code-editor/src/TxCodeEditorToolbar.vue2.js +93 -0
  407. package/dist/lib/command-palette/index.js +1 -1
  408. package/dist/lib/command-palette/src/TxCommandPalette.vue.js +1 -1
  409. package/dist/lib/command-palette/src/TxCommandPalette.vue2.js +127 -20
  410. package/dist/lib/components.css +4253 -3117
  411. package/dist/lib/components.js +255 -178
  412. package/dist/lib/container/src/TxCol.vue2.js +1 -1
  413. package/dist/lib/container/src/TxRow.vue2.js +1 -1
  414. package/dist/lib/context-menu/index.js +1 -1
  415. package/dist/lib/context-menu/src/TxContextMenu.vue.js +1 -1
  416. package/dist/lib/context-menu/src/TxContextMenu.vue2.js +4 -1
  417. package/dist/lib/corner-overlay/index.js +1 -1
  418. package/dist/lib/data-table/index.js +1 -1
  419. package/dist/lib/date-picker/index.js +1 -1
  420. package/dist/lib/dialog/index.js +1 -1
  421. package/dist/lib/dialog/src/TxBlowDialog.vue.js +5 -1
  422. package/dist/lib/dialog/src/TxBottomDialog.vue.js +1 -1
  423. package/dist/lib/dialog/src/TxBottomDialog.vue2.js +5 -1
  424. package/dist/lib/dialog/src/TxPopperDialog.vue.js +5 -1
  425. package/dist/lib/dialog/src/TxTouchTip.vue.js +1 -1
  426. package/dist/lib/dialog/src/TxTouchTip.vue2.js +24 -21
  427. package/dist/lib/drawer/index.js +1 -1
  428. package/dist/lib/drawer/src/TxDrawer.vue.js +8 -2
  429. package/dist/lib/dropdown-menu/index.js +1 -1
  430. package/dist/lib/dropdown-menu/src/TxDropdownMenu.vue.js +1 -1
  431. package/dist/lib/dropdown-menu/src/TxDropdownMenu.vue2.js +13 -3
  432. package/dist/lib/edge-fade-mask/index.js +12 -0
  433. package/dist/lib/edge-fade-mask/src/TxEdgeFadeMask.vue.js +11 -0
  434. package/dist/lib/edge-fade-mask/src/TxEdgeFadeMask.vue2.js +158 -0
  435. package/dist/lib/empty/index.js +1 -1
  436. package/dist/lib/empty-state/index.js +1 -1
  437. package/dist/lib/empty-state/src/TxEmptyState.vue.js +1 -1
  438. package/dist/lib/empty-state/src/TxEmptyState.vue2.js +25 -17
  439. package/dist/lib/error-state/index.js +11 -0
  440. package/dist/lib/error-state/src/TxErrorState.vue.js +39 -0
  441. package/dist/lib/error-state/src/TxErrorState.vue2.js +9 -0
  442. package/dist/lib/file-uploader/index.js +1 -1
  443. package/dist/lib/flat-radio/index.js +16 -0
  444. package/dist/lib/flat-radio/src/TxFlatRadio.vue.js +11 -0
  445. package/dist/lib/flat-radio/src/TxFlatRadio.vue2.js +241 -0
  446. package/dist/lib/flat-radio/src/TxFlatRadioItem.vue.js +11 -0
  447. package/dist/lib/flat-radio/src/TxFlatRadioItem.vue2.js +91 -0
  448. package/dist/lib/flat-radio/src/types.js +7 -0
  449. package/dist/lib/flat-select/index.js +16 -0
  450. package/dist/lib/flat-select/src/TxFlatSelect.vue.js +11 -0
  451. package/dist/lib/flat-select/src/TxFlatSelect.vue2.js +212 -0
  452. package/dist/lib/flat-select/src/TxFlatSelectItem.vue.js +11 -0
  453. package/dist/lib/flat-select/src/TxFlatSelectItem.vue2.js +75 -0
  454. package/dist/lib/flat-select/src/types.js +7 -0
  455. package/dist/lib/flex/index.js +1 -1
  456. package/dist/lib/flip-overlay/index.js +13 -0
  457. package/dist/lib/flip-overlay/src/TxFlipOverlay.vue.js +986 -0
  458. package/dist/lib/flip-overlay/src/TxFlipOverlay.vue3.js +10 -0
  459. package/dist/lib/floating/index.js +16 -0
  460. package/dist/lib/floating/src/TxFloating.vue.js +11 -0
  461. package/dist/lib/floating/src/TxFloating.vue2.js +122 -0
  462. package/dist/lib/floating/src/TxFloatingElement.vue.js +11 -0
  463. package/dist/lib/floating/src/TxFloatingElement.vue2.js +47 -0
  464. package/dist/lib/floating/src/context.js +7 -0
  465. package/dist/lib/form/index.js +1 -1
  466. package/dist/lib/fusion/index.js +1 -1
  467. package/dist/lib/glass-surface/index.js +1 -1
  468. package/dist/lib/glass-surface/src/TxGlassSurface.vue.js +15 -37
  469. package/dist/lib/glow-text/index.js +1 -1
  470. package/dist/lib/glow-text/src/TxGlowText.vue.js +1 -1
  471. package/dist/lib/glow-text/src/TxGlowText.vue2.js +92 -9
  472. package/dist/lib/gradient-border/index.js +1 -1
  473. package/dist/lib/gradual-blur/index.js +1 -1
  474. package/dist/lib/gradual-blur/src/TxGradualBlur.vue.js +1 -1
  475. package/dist/lib/grid/src/TxGrid.vue2.js +1 -1
  476. package/dist/lib/grid-layout/index.js +1 -1
  477. package/dist/lib/group-block/index.js +11 -1
  478. package/dist/lib/group-block/src/TxBlockInput.vue.js +98 -0
  479. package/dist/lib/group-block/src/TxBlockInput.vue3.js +10 -0
  480. package/dist/lib/group-block/src/TxBlockSelect.vue.js +80 -0
  481. package/dist/lib/group-block/src/TxBlockSelect.vue3.js +10 -0
  482. package/dist/lib/group-block/src/TxGroupBlock.vue.js +1 -1
  483. package/dist/lib/guide-state/index.js +11 -0
  484. package/dist/lib/guide-state/src/TxGuideState.vue.js +39 -0
  485. package/dist/lib/guide-state/src/TxGuideState.vue2.js +9 -0
  486. package/dist/lib/icon/index.js +1 -1
  487. package/dist/lib/icon/src/TxIcon.vue.js +1 -1
  488. package/dist/lib/icon/src/TxIcon.vue2.js +9 -3
  489. package/dist/lib/image-gallery/index.js +1 -1
  490. package/dist/lib/image-uploader/index.js +1 -1
  491. package/dist/lib/index.js +269 -182
  492. package/dist/lib/input/index.js +7 -5
  493. package/dist/lib/input/src/TxInput.vue.js +1 -1
  494. package/dist/lib/input/src/TxInput.vue2.js +79 -22
  495. package/dist/lib/keyframe-stroke-text/index.js +12 -0
  496. package/dist/lib/keyframe-stroke-text/src/TxKeyframeStrokeText.vue.js +11 -0
  497. package/dist/lib/keyframe-stroke-text/src/TxKeyframeStrokeText.vue2.js +106 -0
  498. package/dist/lib/layout-skeleton/index.js +1 -1
  499. package/dist/lib/loading-overlay/index.js +1 -1
  500. package/dist/lib/loading-overlay/src/TxLoadingOverlay.vue.js +11 -1
  501. package/dist/lib/loading-state/index.js +1 -1
  502. package/dist/lib/markdown-view/index.js +1 -1
  503. package/dist/lib/markdown-view/src/TxMarkdownView.vue.js +3 -2
  504. package/dist/lib/modal/index.js +1 -1
  505. package/dist/lib/modal/src/TxModal.vue.js +1 -1
  506. package/dist/lib/modal/src/TxModal.vue2.js +25 -3
  507. package/dist/lib/nav-bar/index.js +1 -1
  508. package/dist/lib/no-data/index.js +1 -1
  509. package/dist/lib/no-selection/index.js +1 -1
  510. package/dist/lib/node_modules/.pnpm/@codemirror_legacy-modes@6.5.2/node_modules/@codemirror/legacy-modes/mode/properties.js +66 -0
  511. package/dist/lib/node_modules/.pnpm/@codemirror_legacy-modes@6.5.2/node_modules/@codemirror/legacy-modes/mode/toml.js +80 -0
  512. package/dist/lib/node_modules/.pnpm/@lezer_common@1.5.0/node_modules/@lezer/common/dist/index.js +257 -0
  513. package/dist/lib/node_modules/.pnpm/@lezer_highlight@1.2.3/node_modules/@lezer/highlight/dist/index.js +688 -0
  514. package/dist/lib/offline-state/index.js +1 -1
  515. package/dist/lib/outline-border/index.js +1 -1
  516. package/dist/lib/{utils → packages/tuffex/packages/utils}/toast.js +4 -1
  517. package/dist/lib/packages/tuffex/packages/utils/z-index-manager.js +124 -0
  518. package/dist/lib/packages/utils/env/index.js +13 -0
  519. package/dist/lib/permission-state/index.js +1 -1
  520. package/dist/lib/picker/index.js +1 -1
  521. package/dist/lib/picker/src/TxPicker.vue.js +1 -1
  522. package/dist/lib/picker/src/TxPicker.vue2.js +6 -1
  523. package/dist/lib/popover/index.js +1 -1
  524. package/dist/lib/popover/src/TxPopover.vue.js +1 -1
  525. package/dist/lib/popover/src/TxPopover.vue2.js +146 -316
  526. package/dist/lib/progress-bar/index.js +1 -1
  527. package/dist/lib/radio/index.js +1 -1
  528. package/dist/lib/radio/src/TxRadioGroup.vue2.js +1 -1
  529. package/dist/lib/scroll/index.js +1 -1
  530. package/dist/lib/scroll/src/TxScroll.vue.js +1 -1
  531. package/dist/lib/scroll/src/TxScroll.vue2.js +25 -13
  532. package/dist/lib/scroll/src/runtime-capabilities.js +72 -0
  533. package/dist/lib/search-empty/index.js +1 -1
  534. package/dist/lib/search-input/index.js +1 -1
  535. package/dist/lib/search-select/index.js +1 -1
  536. package/dist/lib/search-select/src/TxSearchSelect.vue.js +1 -1
  537. package/dist/lib/search-select/src/TxSearchSelect.vue2.js +104 -177
  538. package/dist/lib/segmented-slider/index.js +1 -1
  539. package/dist/lib/segmented-slider/src/TxSegmentedSlider.vue.js +1 -0
  540. package/dist/lib/select/index.js +6 -9
  541. package/dist/lib/select/src/TxSelect.vue.js +2 -2
  542. package/dist/lib/select/src/TxSelect.vue2.js +202 -151
  543. package/dist/lib/select/src/TxSelectItem.vue.js +2 -2
  544. package/dist/lib/select/src/TxSelectItem.vue2.js +43 -6
  545. package/dist/lib/select/src/types.js +7 -0
  546. package/dist/lib/skeleton/index.js +1 -1
  547. package/dist/lib/slider/index.js +1 -1
  548. package/dist/lib/sortable-list/index.js +1 -1
  549. package/dist/lib/sortable-list/src/TxSortableList.vue.js +1 -1
  550. package/dist/lib/sortable-list/src/TxSortableList.vue2.js +1 -1
  551. package/dist/lib/spinner/index.js +1 -1
  552. package/dist/lib/splitter/index.js +1 -1
  553. package/dist/lib/stack/index.js +1 -1
  554. package/dist/lib/stagger/index.js +1 -1
  555. package/dist/lib/stat-card/index.js +1 -1
  556. package/dist/lib/stat-card/src/TxStatCard.vue.js +1 -1
  557. package/dist/lib/stat-card/src/TxStatCard.vue2.js +246 -18
  558. package/dist/lib/status-badge/index.js +1 -1
  559. package/dist/lib/switch/index.js +1 -0
  560. package/dist/lib/tab-bar/index.js +1 -1
  561. package/dist/lib/tabs/index.js +1 -1
  562. package/dist/lib/tabs/src/TxTabs.vue.js +1 -1
  563. package/dist/lib/tabs/src/TxTabs.vue2.js +3 -1
  564. package/dist/lib/tag/index.js +1 -1
  565. package/dist/lib/tag-input/index.js +1 -1
  566. package/dist/lib/text-transformer/index.js +1 -1
  567. package/dist/lib/toast/index.js +1 -1
  568. package/dist/lib/toast/src/TxToastHost.vue.js +17 -16
  569. package/dist/lib/tooltip/index.js +1 -1
  570. package/dist/lib/tooltip/src/TxTooltip.vue.js +1 -1
  571. package/dist/lib/tooltip/src/TxTooltip.vue2.js +101 -349
  572. package/dist/lib/transfer/index.js +12 -0
  573. package/dist/lib/transfer/src/TxTransfer.vue.js +11 -0
  574. package/dist/lib/transfer/src/TxTransfer.vue2.js +221 -0
  575. package/dist/lib/transition/index.js +1 -1
  576. package/dist/lib/tree/index.js +1 -1
  577. package/dist/lib/tree/src/TxTree.vue.js +1 -1
  578. package/dist/lib/tree/src/TxTree.vue2.js +3 -2
  579. package/dist/lib/tree-select/index.js +1 -1
  580. package/dist/lib/tree-select/src/TxTreeSelect.vue.js +1 -1
  581. package/dist/lib/tree-select/src/TxTreeSelect.vue2.js +0 -2
  582. package/dist/lib/tuff-logo-stroke/index.js +12 -0
  583. package/dist/lib/tuff-logo-stroke/src/TxTuffLogoStroke.vue.js +11 -0
  584. package/dist/lib/tuff-logo-stroke/src/TxTuffLogoStroke.vue2.js +151 -0
  585. package/dist/lib/virtual-list/index.js +1 -1
  586. package/package.json +37 -25
  587. package/dist/es/button/__tests__/button.test.d.ts +0 -1
  588. package/dist/es/button/__tests__/split-button.test.d.ts +0 -1
  589. package/dist/es/cascader/__tests__/cascader.test.d.ts +0 -1
  590. package/dist/es/command-palette/__tests__/command-palette.test.d.ts +0 -1
  591. package/dist/es/data-table/__tests__/data-table.test.d.ts +0 -1
  592. package/dist/es/file-uploader/__tests__/file-uploader.test.d.ts +0 -1
  593. package/dist/es/form/__tests__/form.test.d.ts +0 -1
  594. package/dist/es/search-select/__tests__/search-select.test.d.ts +0 -1
  595. package/dist/es/tag-input/__tests__/tag-input.test.d.ts +0 -1
  596. package/dist/es/tree/__tests__/tree.test.d.ts +0 -1
  597. package/dist/es/tree-select/__tests__/tree-select.test.d.ts +0 -1
  598. package/dist/es/virtual-list/__tests__/virtual-list.test.d.ts +0 -1
  599. /package/dist/es/{utils → packages/tuffex/packages/utils}/animation/auto-resize.js +0 -0
  600. /package/dist/es/{utils → packages/tuffex/packages/utils}/animation/flip.js +0 -0
  601. /package/dist/es/{utils → packages/tuffex/packages/utils}/dialog-manager.js +0 -0
  602. /package/dist/es/{utils → packages/tuffex/packages/utils}/env.js +0 -0
  603. /package/dist/es/{utils → packages/tuffex/packages/utils}/vibrate.js +0 -0
  604. /package/dist/es/{utils → packages/tuffex/packages/utils}/withInstall.js +0 -0
  605. /package/dist/lib/{utils → packages/tuffex/packages/utils}/animation/auto-resize.js +0 -0
  606. /package/dist/lib/{utils → packages/tuffex/packages/utils}/animation/flip.js +0 -0
  607. /package/dist/lib/{utils → packages/tuffex/packages/utils}/dialog-manager.js +0 -0
  608. /package/dist/lib/{utils → packages/tuffex/packages/utils}/env.js +0 -0
  609. /package/dist/lib/{utils → packages/tuffex/packages/utils}/vibrate.js +0 -0
  610. /package/dist/lib/{utils → packages/tuffex/packages/utils}/withInstall.js +0 -0
@@ -0,0 +1,802 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: 'Module' } });
4
+
5
+ const vue = require('vue');
6
+ const vue$1 = require('@floating-ui/vue');
7
+ const gsap = require('gsap');
8
+ const env = require('../../packages/tuffex/packages/utils/env.js');
9
+ const zIndexManager = require('../../packages/tuffex/packages/utils/z-index-manager.js');
10
+ const TxCard = require('../../card/src/TxCard.vue.js');
11
+
12
+ const _hoisted_1 = ["data-side", "data-bg"];
13
+ const _hoisted_2 = ["data-side"];
14
+ const _hoisted_3 = ["viewBox"];
15
+ const _hoisted_4 = ["d"];
16
+ const REFRACTION_CLOSE_PREPARE_MS = 180;
17
+ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
18
+ ...{ name: "TxBaseAnchor", inheritAttrs: false },
19
+ __name: "TxBaseAnchor",
20
+ props: {
21
+ modelValue: { type: Boolean, default: void 0 },
22
+ disabled: { type: Boolean, default: false },
23
+ eager: { type: Boolean, default: false },
24
+ placement: { default: "bottom-start" },
25
+ offset: { default: 8 },
26
+ width: { default: 0 },
27
+ minWidth: { default: 0 },
28
+ maxWidth: { default: 360 },
29
+ maxHeight: { default: 420 },
30
+ unlimitedHeight: { type: Boolean, default: false },
31
+ matchReferenceWidth: { type: Boolean, default: false },
32
+ referenceClass: {},
33
+ duration: { default: 432 },
34
+ ease: { default: "back.out(2)" },
35
+ useCard: { type: Boolean, default: true },
36
+ panelVariant: { default: "plain" },
37
+ panelBackground: { default: "refraction" },
38
+ panelShadow: { default: "soft" },
39
+ panelRadius: { default: 18 },
40
+ panelPadding: { default: 10 },
41
+ panelCard: {},
42
+ surfaceMotionAdaptation: {},
43
+ showArrow: { type: Boolean, default: false },
44
+ arrowSize: { default: 10 },
45
+ keepAliveContent: { type: Boolean, default: false },
46
+ closeOnClickOutside: { type: Boolean, default: true },
47
+ closeOnEsc: { type: Boolean, default: true },
48
+ toggleOnReferenceClick: { type: Boolean, default: true }
49
+ },
50
+ emits: ["update:modelValue", "open", "close"],
51
+ setup(__props, { expose: __expose, emit: __emit }) {
52
+ const props = __props;
53
+ const emit = __emit;
54
+ const attrs = vue.useAttrs();
55
+ const internalOpen = vue.ref(false);
56
+ const isUnlimitedHeight = vue.computed(() => props.unlimitedHeight || props.maxHeight <= 0);
57
+ const open = vue.computed({
58
+ get: () => typeof props.modelValue === "boolean" ? props.modelValue : internalOpen.value,
59
+ set: (v) => {
60
+ if (props.disabled && v)
61
+ return;
62
+ const current = typeof props.modelValue === "boolean" ? props.modelValue : internalOpen.value;
63
+ if (current === v)
64
+ return;
65
+ internalOpen.value = v;
66
+ emit("update:modelValue", v);
67
+ if (v)
68
+ emit("open");
69
+ else
70
+ emit("close");
71
+ }
72
+ });
73
+ const referenceRef = vue.ref(null);
74
+ const floatingRef = vue.ref(null);
75
+ const clipRef = vue.ref(null);
76
+ const contentRef = vue.ref(null);
77
+ const arrowRef = vue.ref(null);
78
+ const outlineW = vue.ref(0);
79
+ const outlineH = vue.ref(0);
80
+ const zIndex = vue.ref(zIndexManager.getZIndex());
81
+ const mounted = vue.ref(false);
82
+ const cleanupAutoUpdate = vue.ref(null);
83
+ const cleanupResizeObserver = vue.ref(null);
84
+ const lastOpenedAt = vue.ref(0);
85
+ const panelSurfaceMoving = vue.ref(false);
86
+ let lastReferenceRect = null;
87
+ let panelSurfaceMoveTimer = null;
88
+ let closePrepareTimer = null;
89
+ let tl = null;
90
+ let runId = 0;
91
+ const { floatingStyles, middlewareData, placement, update } = vue$1.useFloating(referenceRef, floatingRef, {
92
+ placement: vue.computed(() => props.placement),
93
+ strategy: "fixed",
94
+ transform: false,
95
+ middleware: [
96
+ vue$1.offset(() => props.offset),
97
+ vue$1.flip({ padding: 8 }),
98
+ vue$1.shift({ padding: 8 }),
99
+ vue$1.size({
100
+ padding: 8,
101
+ apply({ rects, availableHeight, elements }) {
102
+ const baseW = rects.reference.width;
103
+ const minW = Math.max(0, props.minWidth ?? 0);
104
+ const style = elements.floating.style;
105
+ style.width = "";
106
+ style.minWidth = "";
107
+ if (props.width > 0) {
108
+ style.width = `${props.width}px`;
109
+ } else if (props.matchReferenceWidth) {
110
+ style.width = `${Math.max(baseW, minW)}px`;
111
+ } else if (minW > 0) {
112
+ style.minWidth = `${minW}px`;
113
+ }
114
+ style.maxWidth = `${props.maxWidth}px`;
115
+ if (isUnlimitedHeight.value) {
116
+ elements.floating.style.setProperty("--tx-ba-max-height", "none");
117
+ return;
118
+ }
119
+ const maxH = Math.max(0, Math.min(availableHeight, props.maxHeight));
120
+ elements.floating.style.setProperty("--tx-ba-max-height", `${maxH}px`);
121
+ }
122
+ }),
123
+ vue$1.arrow({ element: arrowRef, padding: 6 })
124
+ ]
125
+ });
126
+ const side = vue.computed(() => placement.value?.split("-")[0] ?? "bottom");
127
+ const floatingClass = vue.computed(
128
+ () => attrs.class
129
+ );
130
+ const floatingStyle = vue.computed(() => attrs.style);
131
+ const floatingAttrs = vue.computed(() => {
132
+ const source = attrs;
133
+ const next = {};
134
+ for (const [key, value] of Object.entries(source)) {
135
+ if (key === "class" || key === "style")
136
+ continue;
137
+ next[key] = value;
138
+ }
139
+ return next;
140
+ });
141
+ const panelCardProps = vue.computed(() => {
142
+ const shouldFallbackSurface = panelSurfaceMoving.value;
143
+ const refractionSurfaceDefaults = props.panelBackground === "refraction" ? {
144
+ glassOverlayOpacity: 0.15,
145
+ maskOpacity: 0.78
146
+ } : void 0;
147
+ return {
148
+ ...refractionSurfaceDefaults ?? {},
149
+ ...props.panelCard ?? {},
150
+ variant: props.panelVariant,
151
+ background: props.panelBackground,
152
+ shadow: props.panelShadow,
153
+ radius: props.panelRadius,
154
+ padding: props.panelPadding,
155
+ surfaceMoving: shouldFallbackSurface
156
+ };
157
+ });
158
+ const arrowStyle = vue.computed(() => {
159
+ if (!props.showArrow || !arrowRef.value)
160
+ return { display: "none" };
161
+ const data = middlewareData.value?.arrow;
162
+ if (!data || data.x == null && data.y == null)
163
+ return { display: "none" };
164
+ const base = {
165
+ "display": "block",
166
+ "position": "absolute",
167
+ "--tx-ba-arrow-size": `${props.arrowSize ?? 10}px`
168
+ };
169
+ if (data.x != null)
170
+ base.left = `${data.x}px`;
171
+ if (data.y != null)
172
+ base.top = `${data.y}px`;
173
+ const staticSideMap = {
174
+ top: "bottom",
175
+ right: "left",
176
+ bottom: "top",
177
+ left: "right"
178
+ };
179
+ const staticSide = staticSideMap[side.value] ?? "top";
180
+ const half = Math.round((props.arrowSize ?? 10) / 2);
181
+ base[staticSide] = `-${half}px`;
182
+ return base;
183
+ });
184
+ function fmt(value) {
185
+ return Number(value.toFixed(2)).toString();
186
+ }
187
+ function syncOutlineSize() {
188
+ const el = contentRef.value;
189
+ if (!el) {
190
+ outlineW.value = 0;
191
+ outlineH.value = 0;
192
+ return;
193
+ }
194
+ outlineW.value = Math.max(0, el.offsetWidth);
195
+ outlineH.value = Math.max(0, el.offsetHeight);
196
+ }
197
+ function setupResizeObserver() {
198
+ cleanupResizeObserver.value?.();
199
+ cleanupResizeObserver.value = null;
200
+ if (!env.hasWindow() || !contentRef.value || typeof ResizeObserver === "undefined")
201
+ return;
202
+ const observer = new ResizeObserver(() => {
203
+ syncOutlineSize();
204
+ });
205
+ observer.observe(contentRef.value);
206
+ cleanupResizeObserver.value = () => observer.disconnect();
207
+ }
208
+ const outlinePath = vue.computed(() => {
209
+ if (!props.useCard)
210
+ return "";
211
+ const w = outlineW.value;
212
+ const h = outlineH.value;
213
+ if (!w || !h)
214
+ return "";
215
+ const r = Math.min(Math.max(0, props.panelRadius ?? 18), w / 2, h / 2);
216
+ const borderInset = 0.5;
217
+ const left = borderInset;
218
+ const top = borderInset;
219
+ const right = w - borderInset;
220
+ const bottom = h - borderInset;
221
+ const radius = Math.max(0, r - borderInset);
222
+ const topStart = left + radius;
223
+ const topEnd = right - radius;
224
+ const rightStart = top + radius;
225
+ const rightEnd = bottom - radius;
226
+ const bottomStart = left + radius;
227
+ const leftStart = top + radius;
228
+ const leftEnd = bottom - radius;
229
+ return [
230
+ `M ${fmt(topStart)} ${fmt(top)}`,
231
+ `L ${fmt(topEnd)} ${fmt(top)}`,
232
+ `Q ${fmt(right)} ${fmt(top)} ${fmt(right)} ${fmt(rightStart)}`,
233
+ `L ${fmt(right)} ${fmt(rightEnd)}`,
234
+ `Q ${fmt(right)} ${fmt(bottom)} ${fmt(topEnd)} ${fmt(bottom)}`,
235
+ `L ${fmt(bottomStart)} ${fmt(bottom)}`,
236
+ `Q ${fmt(left)} ${fmt(bottom)} ${fmt(left)} ${fmt(leftEnd)}`,
237
+ `L ${fmt(left)} ${fmt(leftStart)}`,
238
+ `Q ${fmt(left)} ${fmt(top)} ${fmt(topStart)} ${fmt(top)}`
239
+ ].join(" ");
240
+ });
241
+ const bouncePad = vue.computed(() => {
242
+ const pad = "10px";
243
+ switch (side.value) {
244
+ case "bottom":
245
+ return { paddingBottom: pad };
246
+ case "top":
247
+ return { paddingTop: pad };
248
+ case "left":
249
+ return { paddingLeft: pad };
250
+ case "right":
251
+ return { paddingRight: pad };
252
+ default:
253
+ return { paddingBottom: pad };
254
+ }
255
+ });
256
+ function getTranslate() {
257
+ const d = 30;
258
+ switch (side.value) {
259
+ case "bottom":
260
+ return { x: 0, y: -d };
261
+ case "top":
262
+ return { x: 0, y: d };
263
+ case "left":
264
+ return { x: d, y: 0 };
265
+ case "right":
266
+ return { x: -d, y: 0 };
267
+ default:
268
+ return { x: 0, y: -d };
269
+ }
270
+ }
271
+ function getClipPath(progress) {
272
+ const p = `${Math.max(0, (1 - progress) * 100)}%`;
273
+ switch (side.value) {
274
+ case "bottom":
275
+ return `inset(0 0 ${p} 0)`;
276
+ case "top":
277
+ return `inset(${p} 0 0 0)`;
278
+ case "left":
279
+ return `inset(0 0 0 ${p})`;
280
+ case "right":
281
+ return `inset(0 ${p} 0 0)`;
282
+ default:
283
+ return `inset(0 0 ${p} 0)`;
284
+ }
285
+ }
286
+ function getArrowInsetTranslate() {
287
+ const d = Math.max(4, Math.round((props.arrowSize ?? 10) * 0.45));
288
+ switch (side.value) {
289
+ case "bottom":
290
+ return { x: 0, y: d };
291
+ case "top":
292
+ return { x: 0, y: -d };
293
+ case "left":
294
+ return { x: -d, y: 0 };
295
+ case "right":
296
+ return { x: d, y: 0 };
297
+ default:
298
+ return { x: 0, y: d };
299
+ }
300
+ }
301
+ function clearTimeline() {
302
+ if (closePrepareTimer != null) {
303
+ clearTimeout(closePrepareTimer);
304
+ closePrepareTimer = null;
305
+ }
306
+ if (tl) {
307
+ tl.kill();
308
+ tl = null;
309
+ }
310
+ }
311
+ function clearPanelSurfaceMoveTimer() {
312
+ if (panelSurfaceMoveTimer == null)
313
+ return;
314
+ clearTimeout(panelSurfaceMoveTimer);
315
+ panelSurfaceMoveTimer = null;
316
+ }
317
+ function setPanelSurfaceMoving(value) {
318
+ if (!props.useCard) {
319
+ panelSurfaceMoving.value = false;
320
+ clearPanelSurfaceMoveTimer();
321
+ return;
322
+ }
323
+ panelSurfaceMoving.value = value;
324
+ if (!value)
325
+ clearPanelSurfaceMoveTimer();
326
+ }
327
+ function pulsePanelSurfaceMoving(duration = 96) {
328
+ if (!props.useCard)
329
+ return;
330
+ panelSurfaceMoving.value = true;
331
+ clearPanelSurfaceMoveTimer();
332
+ panelSurfaceMoveTimer = setTimeout(() => {
333
+ panelSurfaceMoving.value = false;
334
+ panelSurfaceMoveTimer = null;
335
+ }, Math.max(40, duration));
336
+ }
337
+ function settleOpenVisualStateForFollow() {
338
+ const clip = clipRef.value;
339
+ const content = contentRef.value;
340
+ const arrowEl = arrowRef.value;
341
+ if (!clip || !content || !env.hasWindow())
342
+ return;
343
+ clearTimeline();
344
+ if (props.panelBackground !== "refraction") {
345
+ pulsePanelSurfaceMoving(120);
346
+ }
347
+ clip.style.visibility = "visible";
348
+ clip.style.clipPath = "none";
349
+ clip.style.overflow = "visible";
350
+ clip.style.willChange = "auto";
351
+ gsap.set(content, { clearProps: "transform" });
352
+ content.style.willChange = "auto";
353
+ if (arrowEl)
354
+ gsap.set(arrowEl, { clearProps: "transform,opacity,willChange" });
355
+ }
356
+ function readReferenceRect() {
357
+ const el = referenceRef.value;
358
+ if (!el)
359
+ return null;
360
+ const rect = el.getBoundingClientRect();
361
+ return {
362
+ x: rect.x,
363
+ y: rect.y,
364
+ width: rect.width,
365
+ height: rect.height
366
+ };
367
+ }
368
+ function hasReferenceMoved() {
369
+ const current = readReferenceRect();
370
+ if (!current)
371
+ return false;
372
+ if (!lastReferenceRect) {
373
+ lastReferenceRect = current;
374
+ return false;
375
+ }
376
+ const moveThreshold = 1.5;
377
+ const moved = Math.abs(current.x - lastReferenceRect.x) > moveThreshold || Math.abs(current.y - lastReferenceRect.y) > moveThreshold || Math.abs(current.width - lastReferenceRect.width) > moveThreshold || Math.abs(current.height - lastReferenceRect.height) > moveThreshold;
378
+ lastReferenceRect = current;
379
+ return moved;
380
+ }
381
+ function animateOpen(currentRunId) {
382
+ const clip = clipRef.value;
383
+ const content = contentRef.value;
384
+ const arrowEl = arrowRef.value;
385
+ if (isUnlimitedHeight.value) {
386
+ clearTimeline();
387
+ if (!clip || !content) {
388
+ mounted.value = true;
389
+ setPanelSurfaceMoving(false);
390
+ return;
391
+ }
392
+ clip.style.visibility = "visible";
393
+ clip.style.clipPath = "none";
394
+ clip.style.overflow = "visible";
395
+ clip.style.willChange = "auto";
396
+ gsap.set(content, { clearProps: "transform" });
397
+ content.style.willChange = "auto";
398
+ if (arrowEl)
399
+ gsap.set(arrowEl, { clearProps: "transform,opacity,willChange" });
400
+ setPanelSurfaceMoving(false);
401
+ tl = null;
402
+ return;
403
+ }
404
+ if (!clip || !content || !env.hasWindow()) {
405
+ mounted.value = true;
406
+ setPanelSurfaceMoving(false);
407
+ return;
408
+ }
409
+ clearTimeline();
410
+ setPanelSurfaceMoving(true);
411
+ const durMs = Math.max(0, props.duration);
412
+ if (durMs <= 0) {
413
+ clip.style.visibility = "visible";
414
+ clip.style.clipPath = "none";
415
+ clip.style.overflow = "visible";
416
+ clip.style.willChange = "auto";
417
+ gsap.set(content, { clearProps: "transform" });
418
+ content.style.willChange = "auto";
419
+ if (props.showArrow && arrowEl) {
420
+ gsap.set(arrowEl, {
421
+ x: 0,
422
+ y: 0,
423
+ scale: 1,
424
+ opacity: 1,
425
+ clearProps: "willChange"
426
+ });
427
+ }
428
+ setPanelSurfaceMoving(false);
429
+ tl = null;
430
+ return;
431
+ }
432
+ const hiddenT = getTranslate();
433
+ const dur = durMs / 1e3;
434
+ clip.style.overflow = "hidden";
435
+ clip.style.visibility = "visible";
436
+ clip.style.clipPath = getClipPath(0);
437
+ clip.style.willChange = "clip-path";
438
+ content.style.willChange = "transform";
439
+ gsap.set(content, { x: hiddenT.x, y: hiddenT.y });
440
+ if (props.showArrow && arrowEl) {
441
+ const insetT = getArrowInsetTranslate();
442
+ gsap.set(arrowEl, {
443
+ x: insetT.x,
444
+ y: insetT.y,
445
+ scale: 0.72,
446
+ opacity: 0,
447
+ willChange: "transform,opacity"
448
+ });
449
+ }
450
+ const clipState = { progress: 0 };
451
+ const arrowEnterDur = Math.min(0.16, Math.max(0.09, dur * 0.28));
452
+ tl = gsap.timeline({
453
+ onComplete: () => {
454
+ if (currentRunId !== runId)
455
+ return;
456
+ clip.style.clipPath = "none";
457
+ clip.style.overflow = "visible";
458
+ clip.style.willChange = "auto";
459
+ gsap.set(content, { clearProps: "transform" });
460
+ content.style.willChange = "auto";
461
+ if (arrowEl)
462
+ gsap.set(arrowEl, { clearProps: "willChange" });
463
+ setPanelSurfaceMoving(false);
464
+ tl = null;
465
+ }
466
+ });
467
+ tl.to(clipState, {
468
+ progress: 1,
469
+ duration: dur * 0.85,
470
+ ease: "power2.inOut",
471
+ onUpdate() {
472
+ clip.style.clipPath = getClipPath(clipState.progress);
473
+ }
474
+ }, 0);
475
+ tl.to(content, {
476
+ x: 0,
477
+ y: 0,
478
+ duration: dur,
479
+ ease: props.ease
480
+ }, 0);
481
+ if (props.showArrow && arrowEl) {
482
+ tl.to(arrowEl, {
483
+ x: 0,
484
+ y: 0,
485
+ scale: 1,
486
+ opacity: 1,
487
+ duration: arrowEnterDur,
488
+ ease: "power2.out"
489
+ }, Math.max(0, dur - arrowEnterDur * 0.85));
490
+ }
491
+ }
492
+ function animateClose(currentRunId) {
493
+ const clip = clipRef.value;
494
+ const content = contentRef.value;
495
+ const arrowEl = arrowRef.value;
496
+ if (isUnlimitedHeight.value) {
497
+ clearTimeline();
498
+ if (!clip || !content) {
499
+ mounted.value = false;
500
+ setPanelSurfaceMoving(false);
501
+ return;
502
+ }
503
+ clip.style.visibility = "hidden";
504
+ clip.style.clipPath = "none";
505
+ clip.style.overflow = "hidden";
506
+ clip.style.willChange = "auto";
507
+ gsap.set(content, { clearProps: "transform" });
508
+ content.style.willChange = "auto";
509
+ if (arrowEl)
510
+ gsap.set(arrowEl, { clearProps: "transform,opacity,willChange" });
511
+ if (!props.keepAliveContent)
512
+ mounted.value = false;
513
+ setPanelSurfaceMoving(false);
514
+ tl = null;
515
+ return;
516
+ }
517
+ if (!clip || !content || !env.hasWindow()) {
518
+ mounted.value = false;
519
+ setPanelSurfaceMoving(false);
520
+ return;
521
+ }
522
+ clearTimeline();
523
+ setPanelSurfaceMoving(true);
524
+ const durMs = Math.max(0, props.duration * 0.45);
525
+ if (durMs <= 0) {
526
+ clip.style.visibility = "hidden";
527
+ clip.style.clipPath = "none";
528
+ clip.style.overflow = "hidden";
529
+ clip.style.willChange = "auto";
530
+ gsap.set(content, { clearProps: "transform" });
531
+ content.style.willChange = "auto";
532
+ if (arrowEl)
533
+ gsap.set(arrowEl, { clearProps: "transform,opacity,willChange" });
534
+ if (!props.keepAliveContent)
535
+ mounted.value = false;
536
+ setPanelSurfaceMoving(false);
537
+ tl = null;
538
+ return;
539
+ }
540
+ const startCloseMotion = () => {
541
+ if (currentRunId !== runId || open.value) {
542
+ return;
543
+ }
544
+ clip.style.willChange = "clip-path";
545
+ content.style.willChange = "transform";
546
+ clip.style.overflow = "hidden";
547
+ clip.style.clipPath = getClipPath(1);
548
+ const hiddenT = getTranslate();
549
+ const dur = durMs / 1e3;
550
+ const clipState = { progress: 1 };
551
+ const hasArrow = !!(props.showArrow && arrowEl);
552
+ const arrowInsetT = hasArrow ? getArrowInsetTranslate() : { x: 0, y: 0 };
553
+ const arrowHideDur = hasArrow ? Math.min(0.11, Math.max(0.07, dur * 0.4)) : 0;
554
+ const motionStart = arrowHideDur;
555
+ tl = gsap.timeline({
556
+ onComplete: () => {
557
+ if (currentRunId !== runId)
558
+ return;
559
+ clip.style.visibility = "hidden";
560
+ clip.style.clipPath = "none";
561
+ clip.style.willChange = "auto";
562
+ content.style.willChange = "auto";
563
+ if (arrowEl)
564
+ gsap.set(arrowEl, { clearProps: "transform,opacity,willChange" });
565
+ if (!props.keepAliveContent)
566
+ mounted.value = false;
567
+ setPanelSurfaceMoving(false);
568
+ tl = null;
569
+ }
570
+ });
571
+ if (hasArrow && arrowEl) {
572
+ gsap.set(arrowEl, { willChange: "transform,opacity" });
573
+ tl.to(arrowEl, {
574
+ x: arrowInsetT.x,
575
+ y: arrowInsetT.y,
576
+ scale: 0.72,
577
+ opacity: 0,
578
+ duration: arrowHideDur,
579
+ ease: "power2.in"
580
+ }, 0);
581
+ }
582
+ tl.to(content, {
583
+ x: hiddenT.x,
584
+ y: hiddenT.y,
585
+ duration: dur,
586
+ ease: "power3.in"
587
+ }, motionStart);
588
+ tl.to(clipState, {
589
+ progress: 0,
590
+ duration: dur,
591
+ ease: "power3.in",
592
+ onUpdate() {
593
+ clip.style.clipPath = getClipPath(clipState.progress);
594
+ }
595
+ }, motionStart);
596
+ };
597
+ if (props.panelBackground === "refraction") {
598
+ closePrepareTimer = setTimeout(() => {
599
+ closePrepareTimer = null;
600
+ startCloseMotion();
601
+ }, REFRACTION_CLOSE_PREPARE_MS);
602
+ return;
603
+ }
604
+ startCloseMotion();
605
+ }
606
+ function toggle() {
607
+ if (props.disabled)
608
+ return;
609
+ if (!open.value)
610
+ lastOpenedAt.value = performance.now();
611
+ open.value = !open.value;
612
+ }
613
+ function handleReferenceClick() {
614
+ if (!props.toggleOnReferenceClick)
615
+ return;
616
+ toggle();
617
+ }
618
+ function close() {
619
+ open.value = false;
620
+ }
621
+ __expose({
622
+ close,
623
+ toggle
624
+ });
625
+ function isEventInside(e, el) {
626
+ if (!el)
627
+ return false;
628
+ const anyE = e;
629
+ const path = typeof anyE.composedPath === "function" ? anyE.composedPath() : void 0;
630
+ if (path && path.length)
631
+ return path.includes(el);
632
+ const t = e.target ?? null;
633
+ return !!t && el.contains(t);
634
+ }
635
+ function handleOutside(e) {
636
+ if (!props.closeOnClickOutside)
637
+ return;
638
+ if (!open.value)
639
+ return;
640
+ if (performance.now() - lastOpenedAt.value < 60)
641
+ return;
642
+ const inRef = isEventInside(e, referenceRef.value);
643
+ const inFloat = isEventInside(e, floatingRef.value);
644
+ if (!inRef && !inFloat)
645
+ close();
646
+ }
647
+ function handleEsc(e) {
648
+ if (!props.closeOnEsc)
649
+ return;
650
+ if (e.key !== "Escape")
651
+ return;
652
+ if (!open.value)
653
+ return;
654
+ close();
655
+ }
656
+ vue.watch(
657
+ open,
658
+ async (v) => {
659
+ runId++;
660
+ const currentRunId = runId;
661
+ if (!v) {
662
+ cleanupAutoUpdate.value?.();
663
+ cleanupAutoUpdate.value = null;
664
+ cleanupResizeObserver.value?.();
665
+ cleanupResizeObserver.value = null;
666
+ lastReferenceRect = null;
667
+ animateClose(currentRunId);
668
+ return;
669
+ }
670
+ mounted.value = true;
671
+ zIndex.value = zIndexManager.nextZIndex();
672
+ lastOpenedAt.value = performance.now();
673
+ await vue.nextTick();
674
+ await update();
675
+ syncOutlineSize();
676
+ setupResizeObserver();
677
+ if (referenceRef.value && floatingRef.value) {
678
+ cleanupAutoUpdate.value?.();
679
+ cleanupAutoUpdate.value = vue$1.autoUpdate(
680
+ referenceRef.value,
681
+ floatingRef.value,
682
+ () => {
683
+ const referenceMoved = hasReferenceMoved();
684
+ update();
685
+ if (referenceMoved && open.value && props.panelBackground !== "refraction") {
686
+ pulsePanelSurfaceMoving(120);
687
+ }
688
+ if (referenceMoved && tl && open.value)
689
+ settleOpenVisualStateForFollow();
690
+ },
691
+ { animationFrame: true }
692
+ );
693
+ }
694
+ await vue.nextTick();
695
+ lastReferenceRect = readReferenceRect();
696
+ syncOutlineSize();
697
+ animateOpen(currentRunId);
698
+ },
699
+ { flush: "post" }
700
+ );
701
+ vue.watch(
702
+ () => props.disabled,
703
+ (disabled) => {
704
+ if (!disabled)
705
+ return;
706
+ open.value = false;
707
+ }
708
+ );
709
+ vue.onMounted(async () => {
710
+ document.addEventListener("pointerdown", handleOutside, true);
711
+ document.addEventListener("keydown", handleEsc);
712
+ await vue.nextTick();
713
+ if (referenceRef.value) {
714
+ await update();
715
+ syncOutlineSize();
716
+ setupResizeObserver();
717
+ }
718
+ });
719
+ vue.onBeforeUnmount(() => {
720
+ document.removeEventListener("pointerdown", handleOutside, true);
721
+ document.removeEventListener("keydown", handleEsc);
722
+ cleanupAutoUpdate.value?.();
723
+ cleanupAutoUpdate.value = null;
724
+ cleanupResizeObserver.value?.();
725
+ cleanupResizeObserver.value = null;
726
+ setPanelSurfaceMoving(false);
727
+ clearTimeline();
728
+ });
729
+ return (_ctx, _cache) => {
730
+ return vue.openBlock(), vue.createElementBlock(vue.Fragment, null, [
731
+ vue.createElementVNode("div", {
732
+ ref_key: "referenceRef",
733
+ ref: referenceRef,
734
+ class: vue.normalizeClass(["tx-base-anchor__reference", props.referenceClass]),
735
+ onClickCapture: handleReferenceClick
736
+ }, [
737
+ vue.renderSlot(_ctx.$slots, "reference", {}, void 0, true)
738
+ ], 34),
739
+ (vue.openBlock(), vue.createBlock(vue.Teleport, { to: "body" }, [
740
+ mounted.value || open.value || props.eager ? (vue.openBlock(), vue.createElementBlock("div", vue.mergeProps({
741
+ key: 0,
742
+ ref_key: "floatingRef",
743
+ ref: floatingRef
744
+ }, floatingAttrs.value, {
745
+ class: ["tx-base-anchor", [floatingClass.value, { "is-open": open.value, "is-unlimited-height": isUnlimitedHeight.value }]],
746
+ style: [floatingStyle.value, vue.unref(floatingStyles), { zIndex: zIndex.value, "--tx-ba-max-height": isUnlimitedHeight.value ? "none" : void 0 }]
747
+ }), [
748
+ props.showArrow ? (vue.openBlock(), vue.createElementBlock("span", {
749
+ key: 0,
750
+ ref_key: "arrowRef",
751
+ ref: arrowRef,
752
+ class: "tx-base-anchor__arrow",
753
+ "data-side": side.value,
754
+ "data-bg": props.panelBackground,
755
+ style: vue.normalizeStyle(arrowStyle.value),
756
+ "aria-hidden": "true"
757
+ }, null, 12, _hoisted_1)) : vue.createCommentVNode("", true),
758
+ vue.createElementVNode("div", {
759
+ ref_key: "clipRef",
760
+ ref: clipRef,
761
+ class: "tx-base-anchor__clip",
762
+ "data-side": side.value,
763
+ style: vue.normalizeStyle(bouncePad.value)
764
+ }, [
765
+ vue.createElementVNode("div", {
766
+ ref_key: "contentRef",
767
+ ref: contentRef,
768
+ class: "tx-base-anchor__content"
769
+ }, [
770
+ props.useCard ? (vue.openBlock(), vue.createBlock(TxCard.default, vue.mergeProps({
771
+ key: 0,
772
+ class: "tx-base-anchor__card"
773
+ }, panelCardProps.value), {
774
+ default: vue.withCtx(() => [
775
+ vue.renderSlot(_ctx.$slots, "default", { side: side.value }, void 0, true)
776
+ ]),
777
+ _: 3
778
+ }, 16)) : vue.renderSlot(_ctx.$slots, "default", {
779
+ key: 1,
780
+ side: side.value
781
+ }, void 0, true),
782
+ props.useCard && outlinePath.value ? (vue.openBlock(), vue.createElementBlock("svg", {
783
+ key: 2,
784
+ class: "tx-base-anchor__outline",
785
+ viewBox: `0 0 ${outlineW.value} ${outlineH.value}`,
786
+ "aria-hidden": "true"
787
+ }, [
788
+ vue.createElementVNode("path", {
789
+ class: "tx-base-anchor__outline-path",
790
+ d: outlinePath.value
791
+ }, null, 8, _hoisted_4)
792
+ ], 8, _hoisted_3)) : vue.createCommentVNode("", true)
793
+ ], 512)
794
+ ], 12, _hoisted_2)
795
+ ], 16)) : vue.createCommentVNode("", true)
796
+ ]))
797
+ ], 64);
798
+ };
799
+ }
800
+ });
801
+
802
+ exports.default = _sfc_main;