@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
@@ -33,31 +33,31 @@ declare const GlassSurface: {
33
33
  type: import('vue').PropType<number>;
34
34
  default: number;
35
35
  };
36
- opacity: {
36
+ borderRadius: {
37
37
  type: import('vue').PropType<number>;
38
38
  default: number;
39
39
  };
40
- saturation: {
40
+ borderWidth: {
41
41
  type: import('vue').PropType<number>;
42
42
  default: number;
43
43
  };
44
- borderRadius: {
44
+ brightness: {
45
45
  type: import('vue').PropType<number>;
46
46
  default: number;
47
47
  };
48
- borderWidth: {
48
+ opacity: {
49
49
  type: import('vue').PropType<number>;
50
50
  default: number;
51
51
  };
52
- brightness: {
52
+ displace: {
53
53
  type: import('vue').PropType<number>;
54
54
  default: number;
55
55
  };
56
- displace: {
56
+ backgroundOpacity: {
57
57
  type: import('vue').PropType<number>;
58
58
  default: number;
59
59
  };
60
- backgroundOpacity: {
60
+ saturation: {
61
61
  type: import('vue').PropType<number>;
62
62
  default: number;
63
63
  };
@@ -86,20 +86,20 @@ declare const GlassSurface: {
86
86
  default: string;
87
87
  };
88
88
  mixBlendMode: {
89
- type: import('vue').PropType<"normal" | "difference" | "color" | "overlay" | "multiply" | "screen" | "darken" | "lighten" | "color-dodge" | "color-burn" | "hard-light" | "soft-light" | "exclusion" | "hue" | "saturation" | "luminosity" | "plus-darker" | "plus-lighter">;
89
+ type: import('vue').PropType<"normal" | "difference" | "color" | "saturation" | "multiply" | "screen" | "overlay" | "darken" | "lighten" | "color-dodge" | "color-burn" | "hard-light" | "soft-light" | "exclusion" | "hue" | "luminosity" | "plus-darker" | "plus-lighter">;
90
90
  default: string;
91
91
  };
92
92
  }>> & Readonly<{}>, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, import('vue').PublicProps, {
93
93
  width: string | number;
94
94
  height: string | number;
95
95
  blur: number;
96
- opacity: number;
97
- saturation: number;
98
96
  borderRadius: number;
99
97
  borderWidth: number;
100
98
  brightness: number;
99
+ opacity: number;
101
100
  displace: number;
102
101
  backgroundOpacity: number;
102
+ saturation: number;
103
103
  distortionScale: number;
104
104
  redOffset: number;
105
105
  greenOffset: number;
@@ -127,31 +127,31 @@ declare const GlassSurface: {
127
127
  type: import('vue').PropType<number>;
128
128
  default: number;
129
129
  };
130
- opacity: {
130
+ borderRadius: {
131
131
  type: import('vue').PropType<number>;
132
132
  default: number;
133
133
  };
134
- saturation: {
134
+ borderWidth: {
135
135
  type: import('vue').PropType<number>;
136
136
  default: number;
137
137
  };
138
- borderRadius: {
138
+ brightness: {
139
139
  type: import('vue').PropType<number>;
140
140
  default: number;
141
141
  };
142
- borderWidth: {
142
+ opacity: {
143
143
  type: import('vue').PropType<number>;
144
144
  default: number;
145
145
  };
146
- brightness: {
146
+ displace: {
147
147
  type: import('vue').PropType<number>;
148
148
  default: number;
149
149
  };
150
- displace: {
150
+ backgroundOpacity: {
151
151
  type: import('vue').PropType<number>;
152
152
  default: number;
153
153
  };
154
- backgroundOpacity: {
154
+ saturation: {
155
155
  type: import('vue').PropType<number>;
156
156
  default: number;
157
157
  };
@@ -180,20 +180,20 @@ declare const GlassSurface: {
180
180
  default: string;
181
181
  };
182
182
  mixBlendMode: {
183
- type: import('vue').PropType<"normal" | "difference" | "color" | "overlay" | "multiply" | "screen" | "darken" | "lighten" | "color-dodge" | "color-burn" | "hard-light" | "soft-light" | "exclusion" | "hue" | "saturation" | "luminosity" | "plus-darker" | "plus-lighter">;
183
+ type: import('vue').PropType<"normal" | "difference" | "color" | "saturation" | "multiply" | "screen" | "overlay" | "darken" | "lighten" | "color-dodge" | "color-burn" | "hard-light" | "soft-light" | "exclusion" | "hue" | "luminosity" | "plus-darker" | "plus-lighter">;
184
184
  default: string;
185
185
  };
186
186
  }>> & Readonly<{}>, {}, {}, {}, {}, {
187
187
  width: string | number;
188
188
  height: string | number;
189
189
  blur: number;
190
- opacity: number;
191
- saturation: number;
192
190
  borderRadius: number;
193
191
  borderWidth: number;
194
192
  brightness: number;
193
+ opacity: number;
195
194
  displace: number;
196
195
  backgroundOpacity: number;
196
+ saturation: number;
197
197
  distortionScale: number;
198
198
  redOffset: number;
199
199
  greenOffset: number;
@@ -218,31 +218,31 @@ declare const GlassSurface: {
218
218
  type: import('vue').PropType<number>;
219
219
  default: number;
220
220
  };
221
- opacity: {
221
+ borderRadius: {
222
222
  type: import('vue').PropType<number>;
223
223
  default: number;
224
224
  };
225
- saturation: {
225
+ borderWidth: {
226
226
  type: import('vue').PropType<number>;
227
227
  default: number;
228
228
  };
229
- borderRadius: {
229
+ brightness: {
230
230
  type: import('vue').PropType<number>;
231
231
  default: number;
232
232
  };
233
- borderWidth: {
233
+ opacity: {
234
234
  type: import('vue').PropType<number>;
235
235
  default: number;
236
236
  };
237
- brightness: {
237
+ displace: {
238
238
  type: import('vue').PropType<number>;
239
239
  default: number;
240
240
  };
241
- displace: {
241
+ backgroundOpacity: {
242
242
  type: import('vue').PropType<number>;
243
243
  default: number;
244
244
  };
245
- backgroundOpacity: {
245
+ saturation: {
246
246
  type: import('vue').PropType<number>;
247
247
  default: number;
248
248
  };
@@ -271,20 +271,20 @@ declare const GlassSurface: {
271
271
  default: string;
272
272
  };
273
273
  mixBlendMode: {
274
- type: import('vue').PropType<"normal" | "difference" | "color" | "overlay" | "multiply" | "screen" | "darken" | "lighten" | "color-dodge" | "color-burn" | "hard-light" | "soft-light" | "exclusion" | "hue" | "saturation" | "luminosity" | "plus-darker" | "plus-lighter">;
274
+ type: import('vue').PropType<"normal" | "difference" | "color" | "saturation" | "multiply" | "screen" | "overlay" | "darken" | "lighten" | "color-dodge" | "color-burn" | "hard-light" | "soft-light" | "exclusion" | "hue" | "luminosity" | "plus-darker" | "plus-lighter">;
275
275
  default: string;
276
276
  };
277
277
  }>> & Readonly<{}>, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, {
278
278
  width: string | number;
279
279
  height: string | number;
280
280
  blur: number;
281
- opacity: number;
282
- saturation: number;
283
281
  borderRadius: number;
284
282
  borderWidth: number;
285
283
  brightness: number;
284
+ opacity: number;
286
285
  displace: number;
287
286
  backgroundOpacity: number;
287
+ saturation: number;
288
288
  distortionScale: number;
289
289
  redOffset: number;
290
290
  greenOffset: number;
@@ -1,4 +1,4 @@
1
- import { withInstall } from '../utils/withInstall.js';
1
+ import { withInstall } from '../packages/tuffex/packages/utils/withInstall.js';
2
2
  import _sfc_main from './src/TxGlassSurface.vue.js';
3
3
  /* empty css */
4
4
 
@@ -43,13 +43,13 @@ declare const __VLS_component: import('vue').DefineComponent<import('vue').Extra
43
43
  width: string | number;
44
44
  height: string | number;
45
45
  blur: number;
46
- opacity: number;
47
- saturation: number;
48
46
  borderRadius: number;
49
47
  borderWidth: number;
50
48
  brightness: number;
49
+ opacity: number;
51
50
  displace: number;
52
51
  backgroundOpacity: number;
52
+ saturation: number;
53
53
  distortionScale: number;
54
54
  redOffset: number;
55
55
  greenOffset: number;
@@ -1,5 +1,5 @@
1
- import { defineComponent, ref, computed, onMounted, nextTick, watch, createElementBlock, openBlock, normalizeStyle, createElementVNode, renderSlot } from 'vue';
2
- import { hasWindow, hasNavigator, hasDocument } from '../../utils/env.js';
1
+ import { defineComponent, ref, computed, onMounted, nextTick, onBeforeUnmount, watch, createElementBlock, openBlock, normalizeStyle, createElementVNode, renderSlot } from 'vue';
2
+ import { hasWindow, hasNavigator, hasDocument } from '../../packages/tuffex/packages/utils/env.js';
3
3
 
4
4
  const _hoisted_1 = {
5
5
  class: "tx-glass-surface__svg",
@@ -32,7 +32,6 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
32
32
  },
33
33
  setup(__props) {
34
34
  const props = __props;
35
- const isDarkMode = ref(false);
36
35
  const containerRef = ref(null);
37
36
  const feImageRef = ref(null);
38
37
  const redChannelRef = ref(null);
@@ -47,17 +46,6 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
47
46
  const redGradId = `tx-glass-red-grad-${uniqueId}`;
48
47
  const blueGradId = `tx-glass-blue-grad-${uniqueId}`;
49
48
  let resizeObserver = null;
50
- function updateDarkMode() {
51
- if (!hasWindow())
52
- return;
53
- const mediaQuery = window.matchMedia("(prefers-color-scheme: dark)");
54
- isDarkMode.value = mediaQuery.matches;
55
- const handler = (e) => {
56
- isDarkMode.value = e.matches;
57
- };
58
- mediaQuery.addEventListener("change", handler);
59
- return () => mediaQuery.removeEventListener("change", handler);
60
- }
61
49
  function supportsSVGFilters() {
62
50
  if (!hasWindow() || !hasNavigator() || !hasDocument())
63
51
  return false;
@@ -73,6 +61,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
73
61
  function supportsBackdropFilter() {
74
62
  if (!hasWindow())
75
63
  return false;
64
+ if (typeof CSS === "undefined" || typeof CSS.supports !== "function")
65
+ return false;
76
66
  return CSS.supports("backdrop-filter", "blur(10px)");
77
67
  }
78
68
  function generateDisplacementMap() {
@@ -123,6 +113,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
123
113
  }
124
114
  }
125
115
  const containerStyles = computed(() => {
116
+ const monochromeMask = "var(--tx-surface-refraction-mask-rgb, 255 255 255)";
126
117
  const baseStyles = {
127
118
  width: typeof props.width === "number" ? `${props.width}px` : props.width,
128
119
  height: typeof props.height === "number" ? `${props.height}px` : props.height,
@@ -134,43 +125,26 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
134
125
  if (svgSupported) {
135
126
  return {
136
127
  ...baseStyles,
137
- background: isDarkMode.value ? `hsl(0 0% 0% / ${props.backgroundOpacity})` : `hsl(0 0% 100% / ${props.backgroundOpacity})`,
128
+ background: `rgb(${monochromeMask} / ${props.backgroundOpacity})`,
138
129
  backdropFilter: `url(#${filterId}) saturate(${props.saturation})`
139
130
  };
140
131
  }
141
- if (isDarkMode.value) {
142
- if (!backdropFilterSupported) {
143
- return {
144
- ...baseStyles,
145
- background: "rgba(0, 0, 0, 0.4)",
146
- border: "1px solid rgba(255, 255, 255, 0.2)"
147
- };
148
- }
149
- return {
150
- ...baseStyles,
151
- background: "rgba(255, 255, 255, 0.1)",
152
- backdropFilter: `blur(${fallbackBlur}px) saturate(1.8) brightness(1.2)`,
153
- WebkitBackdropFilter: `blur(${fallbackBlur}px) saturate(1.8) brightness(1.2)`,
154
- border: "1px solid rgba(255, 255, 255, 0.2)"
155
- };
156
- }
157
132
  if (!backdropFilterSupported) {
158
133
  return {
159
134
  ...baseStyles,
160
- background: "rgba(255, 255, 255, 0.4)",
161
- border: "1px solid rgba(255, 255, 255, 0.3)"
135
+ background: `rgb(${monochromeMask} / 0.4)`,
136
+ border: `1px solid rgb(${monochromeMask} / 0.24)`
162
137
  };
163
138
  }
164
139
  return {
165
140
  ...baseStyles,
166
- background: "rgba(255, 255, 255, 0.25)",
167
- backdropFilter: `blur(${fallbackBlur}px) saturate(1.8) brightness(1.1)`,
168
- WebkitBackdropFilter: `blur(${fallbackBlur}px) saturate(1.8) brightness(1.1)`,
169
- border: "1px solid rgba(255, 255, 255, 0.3)"
141
+ background: `rgb(${monochromeMask} / 0.22)`,
142
+ backdropFilter: `blur(${fallbackBlur}px) saturate(1.8) brightness(1.06)`,
143
+ WebkitBackdropFilter: `blur(${fallbackBlur}px) saturate(1.8) brightness(1.06)`,
144
+ border: `1px solid rgb(${monochromeMask} / 0.24)`
170
145
  };
171
146
  });
172
147
  onMounted(() => {
173
- updateDarkMode();
174
148
  nextTick(() => {
175
149
  updateDisplacementMap();
176
150
  updateFilterElements();
@@ -182,6 +156,10 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
182
156
  }
183
157
  });
184
158
  });
159
+ onBeforeUnmount(() => {
160
+ resizeObserver?.disconnect();
161
+ resizeObserver = null;
162
+ });
185
163
  watch(
186
164
  [
187
165
  () => props.width,
@@ -11,6 +11,10 @@ declare const GlowText: {
11
11
  type: import('vue').PropType<boolean>;
12
12
  default: boolean;
13
13
  };
14
+ mode: {
15
+ type: import('vue').PropType<"classic" | "adaptive" | "text-clip">;
16
+ default: string;
17
+ };
14
18
  tag: {
15
19
  type: import('vue').PropType<string>;
16
20
  default: string;
@@ -45,11 +49,14 @@ declare const GlowText: {
45
49
  };
46
50
  blendMode: {
47
51
  type: import('vue').PropType<string>;
48
- default: string;
52
+ };
53
+ backdrop: {
54
+ type: import('vue').PropType<string>;
49
55
  };
50
56
  }>> & Readonly<{}>, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, import('vue').PublicProps, {
51
57
  active: boolean;
52
58
  repeat: boolean;
59
+ mode: "classic" | "adaptive" | "text-clip";
53
60
  tag: string;
54
61
  durationMs: number;
55
62
  color: string;
@@ -58,7 +65,6 @@ declare const GlowText: {
58
65
  delayMs: number;
59
66
  angle: number;
60
67
  bandSize: number;
61
- blendMode: string;
62
68
  }, true, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, {}, any, import('vue').ComponentProvideOptions, {
63
69
  P: {};
64
70
  B: {};
@@ -75,6 +81,10 @@ declare const GlowText: {
75
81
  type: import('vue').PropType<boolean>;
76
82
  default: boolean;
77
83
  };
84
+ mode: {
85
+ type: import('vue').PropType<"classic" | "adaptive" | "text-clip">;
86
+ default: string;
87
+ };
78
88
  tag: {
79
89
  type: import('vue').PropType<string>;
80
90
  default: string;
@@ -109,11 +119,14 @@ declare const GlowText: {
109
119
  };
110
120
  blendMode: {
111
121
  type: import('vue').PropType<string>;
112
- default: string;
122
+ };
123
+ backdrop: {
124
+ type: import('vue').PropType<string>;
113
125
  };
114
126
  }>> & Readonly<{}>, {}, {}, {}, {}, {
115
127
  active: boolean;
116
128
  repeat: boolean;
129
+ mode: "classic" | "adaptive" | "text-clip";
117
130
  tag: string;
118
131
  durationMs: number;
119
132
  color: string;
@@ -122,7 +135,6 @@ declare const GlowText: {
122
135
  delayMs: number;
123
136
  angle: number;
124
137
  bandSize: number;
125
- blendMode: string;
126
138
  }>;
127
139
  __isFragment?: never;
128
140
  __isTeleport?: never;
@@ -136,6 +148,10 @@ declare const GlowText: {
136
148
  type: import('vue').PropType<boolean>;
137
149
  default: boolean;
138
150
  };
151
+ mode: {
152
+ type: import('vue').PropType<"classic" | "adaptive" | "text-clip">;
153
+ default: string;
154
+ };
139
155
  tag: {
140
156
  type: import('vue').PropType<string>;
141
157
  default: string;
@@ -170,11 +186,14 @@ declare const GlowText: {
170
186
  };
171
187
  blendMode: {
172
188
  type: import('vue').PropType<string>;
173
- default: string;
189
+ };
190
+ backdrop: {
191
+ type: import('vue').PropType<string>;
174
192
  };
175
193
  }>> & Readonly<{}>, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, {
176
194
  active: boolean;
177
195
  repeat: boolean;
196
+ mode: "classic" | "adaptive" | "text-clip";
178
197
  tag: string;
179
198
  durationMs: number;
180
199
  color: string;
@@ -183,7 +202,6 @@ declare const GlowText: {
183
202
  delayMs: number;
184
203
  angle: number;
185
204
  bandSize: number;
186
- blendMode: string;
187
205
  }, {}, string, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, import('vue').ComponentProvideOptions> & import('vue').VNodeProps & import('vue').AllowedComponentProps & import('vue').ComponentCustomProps & (new () => {
188
206
  $slots: {
189
207
  default?(_: {}): any;
@@ -1,4 +1,4 @@
1
- import { withInstall } from '../utils/withInstall.js';
1
+ import { withInstall } from '../packages/tuffex/packages/utils/withInstall.js';
2
2
  import TxGlowText from './src/TxGlowText.vue.js';
3
3
 
4
4
  const GlowText = withInstall(TxGlowText);
@@ -12,7 +12,7 @@ declare const __VLS_component: import('vue').DefineComponent<import('vue').Extra
12
12
  bandSize: number;
13
13
  color: string;
14
14
  opacity: number;
15
- blendMode: string;
15
+ mode: string;
16
16
  radius: number;
17
17
  repeat: boolean;
18
18
  }>>, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<import('vue').ExtractPropTypes<__VLS_WithDefaults<__VLS_TypePropsToRuntimeProps<GlowTextProps>, {
@@ -24,12 +24,13 @@ declare const __VLS_component: import('vue').DefineComponent<import('vue').Extra
24
24
  bandSize: number;
25
25
  color: string;
26
26
  opacity: number;
27
- blendMode: string;
27
+ mode: string;
28
28
  radius: number;
29
29
  repeat: boolean;
30
30
  }>>> & Readonly<{}>, {
31
31
  active: boolean;
32
32
  repeat: boolean;
33
+ mode: "classic" | "adaptive" | "text-clip";
33
34
  tag: string;
34
35
  durationMs: number;
35
36
  color: string;
@@ -38,7 +39,6 @@ declare const __VLS_component: import('vue').DefineComponent<import('vue').Extra
38
39
  delayMs: number;
39
40
  angle: number;
40
41
  bandSize: number;
41
- blendMode: string;
42
42
  }, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
43
43
  declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, ReturnType<typeof __VLS_template>>;
44
44
  export default _default;
@@ -2,6 +2,6 @@ import _sfc_main from './TxGlowText.vue2.js';
2
2
  /* empty css */
3
3
  import _export_sfc from '../../_virtual/_plugin-vue_export-helper.js';
4
4
 
5
- const TxGlowText = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-66ff95f1"]]);
5
+ const TxGlowText = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-423f7e0c"]]);
6
6
 
7
7
  export { TxGlowText as default };
@@ -1,6 +1,10 @@
1
- import { defineComponent, computed, createBlock, openBlock, resolveDynamicComponent, normalizeStyle, normalizeClass, withCtx, createElementVNode, renderSlot } from 'vue';
1
+ import { defineComponent, ref, watch, nextTick, computed, onMounted, onBeforeUnmount, createBlock, openBlock, resolveDynamicComponent, normalizeStyle, normalizeClass, withCtx, renderSlot, createElementBlock, createCommentVNode, createElementVNode, toDisplayString } from 'vue';
2
2
 
3
- const _hoisted_1 = { class: "tx-glow-text__content" };
3
+ const _hoisted_1 = {
4
+ key: 0,
5
+ class: "tx-glow-text__clip-shine",
6
+ "aria-hidden": "true"
7
+ };
4
8
  const _sfc_main = /* @__PURE__ */ defineComponent({
5
9
  ...{ name: "TxGlowText" },
6
10
  __name: "TxGlowText",
@@ -13,33 +17,112 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
13
17
  bandSize: { default: 38 },
14
18
  color: { default: "rgba(255, 255, 255, 0.9)" },
15
19
  opacity: { default: 0.75 },
16
- blendMode: { default: "screen" },
20
+ blendMode: {},
21
+ mode: { default: "adaptive" },
22
+ backdrop: {},
17
23
  radius: { default: 10 },
18
24
  repeat: { type: Boolean, default: true }
19
25
  },
20
26
  setup(__props) {
21
27
  const props = __props;
22
- const styleVars = computed(() => {
28
+ const rootRef = ref();
29
+ const textMaskContent = ref("");
30
+ let textObserver = null;
31
+ function collectSlotText(node) {
32
+ if (node.nodeType === 3)
33
+ return node.textContent ?? "";
34
+ if (node.nodeType !== 1)
35
+ return "";
36
+ const element = node;
37
+ if (element.classList.contains("tx-glow-text__clip-shine") || element.classList.contains("tx-glow-text__shine")) {
38
+ return "";
39
+ }
40
+ return Array.from(element.childNodes).map(collectSlotText).join("");
41
+ }
42
+ function syncTextMaskContent() {
43
+ const el = rootRef.value;
44
+ if (!el)
45
+ return;
46
+ const text = Array.from(el.childNodes).map(collectSlotText).join("").trim();
47
+ textMaskContent.value = text;
48
+ }
49
+ function disconnectTextObserver() {
50
+ if (!textObserver)
51
+ return;
52
+ textObserver.disconnect();
53
+ textObserver = null;
54
+ }
55
+ function connectTextObserver() {
56
+ const el = rootRef.value;
57
+ if (!el || props.mode !== "text-clip")
58
+ return;
59
+ disconnectTextObserver();
60
+ syncTextMaskContent();
61
+ textObserver = new MutationObserver(() => {
62
+ syncTextMaskContent();
63
+ });
64
+ textObserver.observe(el, {
65
+ childList: true,
66
+ subtree: true,
67
+ characterData: true
68
+ });
69
+ }
70
+ watch(
71
+ () => props.mode,
72
+ async (mode) => {
73
+ if (mode !== "text-clip") {
74
+ disconnectTextObserver();
75
+ textMaskContent.value = "";
76
+ return;
77
+ }
78
+ await nextTick();
79
+ connectTextObserver();
80
+ }
81
+ );
82
+ const rootClasses = computed(() => {
23
83
  return {
84
+ "is-inactive": !props.active,
85
+ "is-once": !props.repeat,
86
+ "is-adaptive": props.mode === "adaptive",
87
+ "is-text-clip": props.mode === "text-clip",
88
+ "has-custom-blend": Boolean(props.blendMode),
89
+ "has-custom-backdrop": Boolean(props.backdrop)
90
+ };
91
+ });
92
+ const styleVars = computed(() => {
93
+ const vars = {
24
94
  "--tx-glow-duration": `${props.durationMs}ms`,
25
95
  "--tx-glow-delay": `${props.delayMs}ms`,
26
96
  "--tx-glow-angle": `${props.angle}deg`,
27
97
  "--tx-glow-band": `${props.bandSize}%`,
28
98
  "--tx-glow-color": props.color,
29
99
  "--tx-glow-opacity": String(props.opacity),
30
- "--tx-glow-radius": `${props.radius}px`,
31
- "--tx-glow-blend-mode": props.blendMode
100
+ "--tx-glow-radius": `${props.radius}px`
32
101
  };
102
+ if (props.blendMode)
103
+ vars["--tx-glow-blend-mode"] = props.blendMode;
104
+ if (props.backdrop)
105
+ vars["--tx-glow-backdrop"] = props.backdrop;
106
+ return vars;
107
+ });
108
+ onMounted(() => {
109
+ if (props.mode !== "text-clip")
110
+ return;
111
+ connectTextObserver();
112
+ });
113
+ onBeforeUnmount(() => {
114
+ disconnectTextObserver();
33
115
  });
34
116
  return (_ctx, _cache) => {
35
117
  return openBlock(), createBlock(resolveDynamicComponent(__props.tag), {
36
- class: normalizeClass(["tx-glow-text", { "is-inactive": !__props.active, "is-once": !__props.repeat }]),
118
+ ref_key: "rootRef",
119
+ ref: rootRef,
120
+ class: normalizeClass(["tx-glow-text", rootClasses.value]),
37
121
  style: normalizeStyle(styleVars.value)
38
122
  }, {
39
123
  default: withCtx(() => [
40
- createElementVNode("span", _hoisted_1, [
41
- renderSlot(_ctx.$slots, "default", {}, void 0, true)
42
- ]),
124
+ renderSlot(_ctx.$slots, "default", {}, void 0, true),
125
+ __props.mode === "text-clip" && textMaskContent.value ? (openBlock(), createElementBlock("span", _hoisted_1, toDisplayString(textMaskContent.value), 1)) : createCommentVNode("", true),
43
126
  _cache[0] || (_cache[0] = createElementVNode("span", {
44
127
  class: "tx-glow-text__shine",
45
128
  "aria-hidden": "true"
@@ -8,6 +8,8 @@ export interface GlowTextProps {
8
8
  color?: string;
9
9
  opacity?: number;
10
10
  blendMode?: string;
11
+ mode?: 'classic' | 'adaptive' | 'text-clip';
12
+ backdrop?: string;
11
13
  radius?: number;
12
14
  repeat?: boolean;
13
15
  }
@@ -1,4 +1,4 @@
1
- import { withInstall } from '../utils/withInstall.js';
1
+ import { withInstall } from '../packages/tuffex/packages/utils/withInstall.js';
2
2
  import TxGradientBorder from './src/TxGradientBorder.vue.js';
3
3
 
4
4
  const GradientBorder = withInstall(TxGradientBorder);