@indielayer/ui 1.0.10 → 1.2.0

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 (410) hide show
  1. package/lib/_virtual/_plugin-vue_export-helper.js +9 -0
  2. package/lib/common/icons.js +18 -0
  3. package/lib/common/utils.d.ts +4 -0
  4. package/lib/common/utils.js +25 -0
  5. package/lib/components/alert/Alert.theme.d.ts +10 -8
  6. package/lib/components/alert/Alert.theme.js +41 -0
  7. package/lib/components/alert/Alert.vue.d.ts +22 -5
  8. package/lib/components/alert/Alert.vue.js +9 -0
  9. package/lib/components/alert/Alert.vue2.js +62 -0
  10. package/lib/components/alert/Alert.vue3.js +8 -0
  11. package/lib/components/alert/index.d.ts +3 -0
  12. package/lib/components/avatar/Avatar.theme.d.ts +13 -7
  13. package/lib/components/avatar/Avatar.theme.js +25 -0
  14. package/lib/components/avatar/Avatar.vue.d.ts +24 -2
  15. package/lib/components/avatar/Avatar.vue.js +9 -0
  16. package/lib/components/avatar/Avatar.vue2.js +76 -0
  17. package/lib/components/avatar/Avatar.vue3.js +7 -0
  18. package/lib/components/avatar/index.d.ts +3 -0
  19. package/lib/components/badge/Badge.theme.d.ts +10 -8
  20. package/lib/components/badge/Badge.theme.js +12 -0
  21. package/lib/components/badge/Badge.vue.d.ts +45 -8
  22. package/lib/components/badge/Badge.vue.js +94 -0
  23. package/lib/components/badge/Badge.vue2.js +4 -0
  24. package/lib/components/badge/index.d.ts +3 -0
  25. package/lib/components/breadcrumbs/Breadcrumbs.theme.d.ts +10 -8
  26. package/lib/components/breadcrumbs/Breadcrumbs.theme.js +10 -0
  27. package/lib/components/breadcrumbs/Breadcrumbs.vue.d.ts +19 -5
  28. package/lib/components/breadcrumbs/Breadcrumbs.vue.js +79 -0
  29. package/lib/components/breadcrumbs/Breadcrumbs.vue2.js +4 -0
  30. package/lib/components/breadcrumbs/index.d.ts +3 -0
  31. package/lib/components/button/Button.theme.d.ts +12 -9
  32. package/lib/components/button/Button.theme.js +138 -0
  33. package/lib/components/button/Button.vue.d.ts +41 -7
  34. package/lib/components/button/Button.vue.js +9 -0
  35. package/lib/components/button/Button.vue2.js +115 -0
  36. package/lib/components/button/Button.vue3.js +8 -0
  37. package/lib/components/button/ButtonGroup.theme.d.ts +12 -5
  38. package/lib/components/button/ButtonGroup.theme.js +8 -0
  39. package/lib/components/button/ButtonGroup.vue.d.ts +36 -5
  40. package/lib/components/button/ButtonGroup.vue.js +9 -0
  41. package/lib/components/button/ButtonGroup.vue2.js +54 -0
  42. package/lib/components/button/ButtonGroup.vue3.js +7 -0
  43. package/lib/components/button/index.d.ts +6 -0
  44. package/lib/components/card/Card.theme.d.ts +10 -7
  45. package/lib/components/card/Card.theme.js +8 -0
  46. package/lib/components/card/Card.vue.d.ts +9 -0
  47. package/lib/components/card/Card.vue.js +31 -0
  48. package/lib/components/card/Card.vue2.js +4 -0
  49. package/lib/components/card/index.d.ts +3 -0
  50. package/lib/components/checkbox/Checkbox.theme.d.ts +13 -10
  51. package/lib/components/checkbox/Checkbox.theme.js +52 -0
  52. package/lib/components/checkbox/Checkbox.vue.d.ts +35 -4
  53. package/lib/components/checkbox/Checkbox.vue.js +9 -0
  54. package/lib/components/checkbox/Checkbox.vue2.js +108 -0
  55. package/lib/components/checkbox/Checkbox.vue3.js +6 -0
  56. package/lib/components/checkbox/index.d.ts +3 -0
  57. package/lib/components/collapse/Collapse.theme.d.ts +10 -9
  58. package/lib/components/collapse/Collapse.theme.js +10 -0
  59. package/lib/components/collapse/Collapse.vue.d.ts +17 -1
  60. package/lib/components/collapse/Collapse.vue.js +132 -0
  61. package/lib/components/collapse/Collapse.vue2.js +4 -0
  62. package/lib/components/collapse/index.d.ts +3 -0
  63. package/lib/components/container/Container.theme.d.ts +10 -6
  64. package/lib/components/container/Container.theme.js +8 -0
  65. package/lib/components/container/Container.vue.d.ts +8 -0
  66. package/lib/components/container/Container.vue.js +30 -0
  67. package/lib/components/container/Container.vue2.js +4 -0
  68. package/lib/components/container/index.d.ts +3 -0
  69. package/lib/components/divider/Divider.theme.d.ts +10 -9
  70. package/lib/components/divider/Divider.theme.js +10 -0
  71. package/lib/components/divider/Divider.vue.d.ts +6 -0
  72. package/lib/components/divider/Divider.vue.js +53 -0
  73. package/lib/components/divider/Divider.vue2.js +4 -0
  74. package/lib/components/divider/index.d.ts +3 -0
  75. package/lib/components/drawer/Drawer.theme.d.ts +10 -7
  76. package/lib/components/drawer/Drawer.theme.js +9 -0
  77. package/lib/components/drawer/Drawer.vue.d.ts +39 -12
  78. package/lib/components/drawer/Drawer.vue.js +171 -0
  79. package/lib/components/drawer/Drawer.vue2.js +4 -0
  80. package/lib/components/drawer/index.d.ts +3 -0
  81. package/lib/components/form/Form.theme.d.ts +10 -6
  82. package/lib/components/form/Form.theme.js +8 -0
  83. package/lib/components/form/Form.vue.d.ts +25 -4
  84. package/lib/components/form/Form.vue.js +79 -0
  85. package/lib/components/form/Form.vue2.js +4 -0
  86. package/lib/components/form/index.d.ts +3 -0
  87. package/lib/components/helpers/InputError.js +18 -0
  88. package/lib/components/icon/Icon.theme.d.ts +10 -7
  89. package/lib/components/icon/Icon.theme.js +11 -0
  90. package/lib/components/icon/Icon.vue.d.ts +21 -3
  91. package/lib/components/icon/Icon.vue.js +74 -0
  92. package/lib/components/icon/Icon.vue2.js +4 -0
  93. package/lib/components/icon/index.d.ts +3 -0
  94. package/lib/components/image/Image.theme.d.ts +10 -6
  95. package/lib/components/image/Image.theme.js +8 -0
  96. package/lib/components/image/Image.vue.d.ts +5 -0
  97. package/lib/components/image/Image.vue.js +32 -0
  98. package/lib/components/image/Image.vue2.js +4 -0
  99. package/lib/components/image/index.d.ts +3 -0
  100. package/lib/components/index.d.ts +35 -45
  101. package/lib/components/index.js +92 -0
  102. package/lib/components/input/Input.theme.d.ts +12 -10
  103. package/lib/components/input/Input.theme.js +21 -0
  104. package/lib/components/input/Input.vue.d.ts +70 -19
  105. package/lib/components/input/Input.vue.js +140 -0
  106. package/lib/components/input/Input.vue2.js +4 -0
  107. package/lib/components/input/index.d.ts +3 -0
  108. package/lib/components/link/Link.theme.d.ts +10 -8
  109. package/lib/components/link/Link.theme.js +25 -0
  110. package/lib/components/link/Link.vue.d.ts +17 -1
  111. package/lib/components/link/Link.vue.js +9 -0
  112. package/lib/components/link/Link.vue2.js +48 -0
  113. package/lib/components/link/Link.vue3.js +8 -0
  114. package/lib/components/link/index.d.ts +3 -0
  115. package/lib/components/menu/Menu.theme.d.ts +10 -6
  116. package/lib/components/menu/Menu.theme.js +8 -0
  117. package/lib/components/menu/Menu.vue.d.ts +61 -8
  118. package/lib/components/menu/Menu.vue.js +133 -0
  119. package/lib/components/menu/Menu.vue2.js +4 -0
  120. package/lib/components/menu/MenuItem.theme.d.ts +13 -7
  121. package/lib/components/menu/MenuItem.theme.js +86 -0
  122. package/lib/components/menu/MenuItem.vue.d.ts +55 -15
  123. package/lib/components/menu/MenuItem.vue.js +9 -0
  124. package/lib/components/menu/MenuItem.vue2.js +143 -0
  125. package/lib/components/menu/MenuItem.vue3.js +7 -0
  126. package/lib/components/menu/index.d.ts +6 -0
  127. package/lib/components/modal/Modal.theme.d.ts +10 -13
  128. package/lib/components/modal/Modal.theme.js +17 -0
  129. package/lib/components/modal/Modal.vue.d.ts +13 -1
  130. package/lib/components/modal/Modal.vue.js +127 -0
  131. package/lib/components/modal/Modal.vue2.js +4 -0
  132. package/lib/components/modal/index.d.ts +3 -0
  133. package/lib/components/notifications/Notifications.theme.d.ts +10 -8
  134. package/lib/components/notifications/Notifications.theme.js +10 -0
  135. package/lib/components/notifications/Notifications.vue.d.ts +46 -13
  136. package/lib/components/notifications/Notifications.vue.js +234 -0
  137. package/lib/components/notifications/Notifications.vue2.js +4 -0
  138. package/lib/components/notifications/index.d.ts +3 -0
  139. package/lib/components/pagination/Pagination.theme.d.ts +10 -9
  140. package/lib/components/pagination/Pagination.theme.js +13 -0
  141. package/lib/components/pagination/Pagination.vue.d.ts +27 -4
  142. package/lib/components/pagination/Pagination.vue.js +131 -0
  143. package/lib/components/pagination/Pagination.vue2.js +4 -0
  144. package/lib/components/pagination/PaginationItem.theme.d.ts +10 -7
  145. package/lib/components/pagination/PaginationItem.theme.js +8 -0
  146. package/lib/components/pagination/PaginationItem.vue.d.ts +16 -1
  147. package/lib/components/pagination/PaginationItem.vue.js +48 -0
  148. package/lib/components/pagination/PaginationItem.vue2.js +4 -0
  149. package/lib/components/pagination/index.d.ts +6 -0
  150. package/lib/components/popover/Popover.theme.d.ts +10 -7
  151. package/lib/components/popover/Popover.theme.js +9 -0
  152. package/lib/components/popover/Popover.vue.d.ts +40 -10
  153. package/lib/components/popover/Popover.vue.js +9 -0
  154. package/lib/components/popover/Popover.vue2.js +106 -0
  155. package/lib/components/popover/Popover.vue3.js +15 -0
  156. package/lib/components/popover/PopoverContainer.theme.d.ts +10 -6
  157. package/lib/components/popover/PopoverContainer.theme.js +8 -0
  158. package/lib/components/popover/PopoverContainer.vue.d.ts +8 -0
  159. package/lib/components/popover/PopoverContainer.vue.js +30 -0
  160. package/lib/components/popover/PopoverContainer.vue2.js +4 -0
  161. package/lib/components/popover/index.d.ts +6 -0
  162. package/lib/components/progress/Progress.theme.d.ts +10 -12
  163. package/lib/components/progress/Progress.theme.js +18 -0
  164. package/lib/components/progress/Progress.vue.d.ts +19 -0
  165. package/lib/components/progress/Progress.vue.js +51 -0
  166. package/lib/components/progress/Progress.vue2.js +4 -0
  167. package/lib/components/progress/index.d.ts +3 -0
  168. package/lib/components/radio/Radio.theme.d.ts +13 -11
  169. package/lib/components/radio/Radio.theme.js +67 -0
  170. package/lib/components/radio/Radio.vue.d.ts +38 -6
  171. package/lib/components/radio/Radio.vue.js +9 -0
  172. package/lib/components/radio/Radio.vue2.js +117 -0
  173. package/lib/components/radio/Radio.vue3.js +10 -0
  174. package/lib/components/radio/index.d.ts +3 -0
  175. package/lib/components/scroll/Scroll.theme.d.ts +10 -6
  176. package/lib/components/scroll/Scroll.theme.js +8 -0
  177. package/lib/components/scroll/Scroll.vue.d.ts +12 -1
  178. package/lib/components/scroll/Scroll.vue.js +9 -0
  179. package/lib/components/scroll/Scroll.vue2.js +64 -0
  180. package/lib/components/scroll/Scroll.vue3.js +17 -0
  181. package/lib/components/scroll/index.d.ts +3 -0
  182. package/lib/components/select/Select.theme.d.ts +13 -12
  183. package/lib/components/select/Select.theme.js +23 -0
  184. package/lib/components/select/Select.vue.d.ts +33 -4
  185. package/lib/components/select/Select.vue.js +269 -0
  186. package/lib/components/select/Select.vue2.js +4 -0
  187. package/lib/components/select/index.d.ts +3 -0
  188. package/lib/components/skeleton/Skeleton.theme.d.ts +10 -6
  189. package/lib/components/skeleton/Skeleton.theme.js +8 -0
  190. package/lib/components/skeleton/Skeleton.vue.d.ts +8 -0
  191. package/lib/components/skeleton/Skeleton.vue.js +30 -0
  192. package/lib/components/skeleton/Skeleton.vue2.js +4 -0
  193. package/lib/components/skeleton/index.d.ts +3 -0
  194. package/lib/components/slider/Slider.theme.d.ts +10 -10
  195. package/lib/components/slider/Slider.theme.js +20 -0
  196. package/lib/components/slider/Slider.vue.d.ts +40 -4
  197. package/lib/components/slider/Slider.vue.js +148 -0
  198. package/lib/components/slider/Slider.vue2.js +4 -0
  199. package/lib/components/slider/index.d.ts +2 -0
  200. package/lib/components/spacer/Spacer.js +12 -0
  201. package/lib/components/spacer/index.d.ts +1 -0
  202. package/lib/components/spinner/Spinner.vue.d.ts +13 -0
  203. package/lib/components/spinner/Spinner.vue.js +28 -0
  204. package/lib/components/spinner/Spinner.vue2.js +4 -0
  205. package/lib/components/spinner/index.d.ts +2 -0
  206. package/lib/components/tab/Tab.theme.d.ts +12 -9
  207. package/lib/components/tab/Tab.theme.js +13 -0
  208. package/lib/components/tab/Tab.vue.d.ts +31 -9
  209. package/lib/components/tab/Tab.vue.js +129 -0
  210. package/lib/components/tab/Tab.vue2.js +4 -0
  211. package/lib/components/tab/TabGroup.theme.d.ts +10 -10
  212. package/lib/components/tab/TabGroup.theme.js +27 -0
  213. package/lib/components/tab/TabGroup.vue.d.ts +53 -8
  214. package/lib/components/tab/TabGroup.vue.js +133 -0
  215. package/lib/components/tab/TabGroup.vue2.js +4 -0
  216. package/lib/components/tab/index.d.ts +4 -0
  217. package/lib/components/table/Table.theme.d.ts +10 -8
  218. package/lib/components/table/Table.theme.js +12 -0
  219. package/lib/components/table/Table.vue.d.ts +268 -57
  220. package/lib/components/table/Table.vue.js +147 -0
  221. package/lib/components/table/Table.vue2.js +4 -0
  222. package/lib/components/table/TableBody.js +15 -0
  223. package/lib/components/table/TableCell.theme.d.ts +10 -7
  224. package/lib/components/table/TableCell.theme.js +11 -0
  225. package/lib/components/table/TableCell.vue.d.ts +27 -5
  226. package/lib/components/table/TableCell.vue.js +43 -0
  227. package/lib/components/table/TableCell.vue2.js +4 -0
  228. package/lib/components/table/TableHead.js +19 -0
  229. package/lib/components/table/TableHeader.vue.d.ts +26 -8
  230. package/lib/components/table/TableHeader.vue.js +78 -0
  231. package/lib/components/table/TableHeader.vue2.js +4 -0
  232. package/lib/components/table/TableRow.vue.js +32 -0
  233. package/lib/components/table/TableRow.vue2.js +4 -0
  234. package/lib/components/table/index.d.ts +9 -0
  235. package/lib/components/tag/Tag.theme.d.ts +10 -9
  236. package/lib/components/tag/Tag.theme.js +23 -0
  237. package/lib/components/tag/Tag.vue.d.ts +23 -3
  238. package/lib/components/tag/Tag.vue.js +61 -0
  239. package/lib/components/tag/Tag.vue2.js +4 -0
  240. package/lib/components/tag/index.d.ts +2 -0
  241. package/lib/components/textarea/Textarea.theme.d.ts +13 -9
  242. package/lib/components/textarea/Textarea.theme.js +16 -0
  243. package/lib/components/textarea/Textarea.vue.d.ts +56 -14
  244. package/lib/components/textarea/Textarea.vue.js +110 -0
  245. package/lib/components/textarea/Textarea.vue2.js +4 -0
  246. package/lib/components/textarea/index.d.ts +2 -0
  247. package/lib/components/toggle/Toggle.theme.d.ts +10 -11
  248. package/lib/components/toggle/Toggle.theme.js +29 -0
  249. package/lib/components/toggle/Toggle.vue.d.ts +36 -4
  250. package/lib/components/toggle/Toggle.vue.js +110 -0
  251. package/lib/components/toggle/Toggle.vue2.js +4 -0
  252. package/lib/components/toggle/index.d.ts +2 -0
  253. package/lib/components/tooltip/Tooltip.vue.d.ts +3 -0
  254. package/lib/components/tooltip/Tooltip.vue.js +27 -0
  255. package/lib/components/tooltip/Tooltip.vue2.js +4 -0
  256. package/lib/components/tooltip/index.d.ts +2 -0
  257. package/lib/composables/colors-utils.js +19 -0
  258. package/lib/composables/colors.d.ts +2 -1
  259. package/lib/composables/colors.js +52 -0
  260. package/lib/composables/common.d.ts +1 -1
  261. package/lib/composables/common.js +17 -0
  262. package/lib/composables/css.js +26 -0
  263. package/lib/composables/inputtable.d.ts +4 -4
  264. package/lib/composables/inputtable.js +78 -0
  265. package/lib/composables/interactive.js +17 -0
  266. package/lib/composables/keys.d.ts +6 -3
  267. package/lib/composables/keys.js +10 -0
  268. package/lib/composables/notifications.js +9 -0
  269. package/lib/composables/theme.d.ts +13 -7
  270. package/lib/composables/theme.js +59 -0
  271. package/lib/create.js +19 -0
  272. package/lib/index.js +121 -0
  273. package/lib/index.umd.js +1 -0
  274. package/lib/install.js +10 -0
  275. package/lib/node_modules/.pnpm/@vueuse_core@10.2.0_vue@3.3.4/node_modules/@vueuse/core/index.js +379 -0
  276. package/lib/node_modules/.pnpm/@vueuse_shared@10.2.0_vue@3.3.4/node_modules/@vueuse/shared/index.js +90 -0
  277. package/lib/version.d.ts +1 -1
  278. package/lib/version.js +4 -0
  279. package/package.json +10 -9
  280. package/src/common/utils.ts +25 -2
  281. package/src/components/alert/Alert.theme.ts +15 -6
  282. package/src/components/alert/Alert.vue +24 -12
  283. package/src/components/alert/index.ts +3 -0
  284. package/src/components/avatar/Avatar.theme.ts +16 -4
  285. package/src/components/avatar/Avatar.vue +18 -14
  286. package/src/components/avatar/index.ts +3 -0
  287. package/src/components/badge/Badge.theme.ts +13 -3
  288. package/src/components/badge/Badge.vue +30 -15
  289. package/src/components/badge/index.ts +3 -0
  290. package/src/components/breadcrumbs/Breadcrumbs.theme.ts +12 -2
  291. package/src/components/breadcrumbs/Breadcrumbs.vue +24 -21
  292. package/src/components/breadcrumbs/index.ts +3 -0
  293. package/src/components/button/Button.theme.ts +18 -8
  294. package/src/components/button/Button.vue +28 -18
  295. package/src/components/button/ButtonGroup.theme.ts +14 -1
  296. package/src/components/button/ButtonGroup.vue +29 -15
  297. package/src/components/button/index.ts +7 -0
  298. package/src/components/card/Card.theme.ts +13 -3
  299. package/src/components/card/Card.vue +12 -7
  300. package/src/components/card/index.ts +3 -0
  301. package/src/components/checkbox/Checkbox.theme.ts +19 -7
  302. package/src/components/checkbox/Checkbox.vue +20 -11
  303. package/src/components/checkbox/index.ts +3 -0
  304. package/src/components/collapse/Collapse.theme.ts +13 -3
  305. package/src/components/collapse/Collapse.vue +16 -12
  306. package/src/components/collapse/index.ts +3 -0
  307. package/src/components/container/Container.theme.ts +12 -2
  308. package/src/components/container/Container.vue +11 -6
  309. package/src/components/container/index.ts +3 -0
  310. package/src/components/divider/Divider.theme.ts +13 -3
  311. package/src/components/divider/Divider.vue +9 -4
  312. package/src/components/divider/index.ts +3 -0
  313. package/src/components/drawer/Drawer.theme.ts +12 -2
  314. package/src/components/drawer/Drawer.vue +27 -18
  315. package/src/components/drawer/index.ts +3 -0
  316. package/src/components/form/Form.theme.ts +12 -2
  317. package/src/components/form/Form.vue +38 -28
  318. package/src/components/form/index.ts +3 -0
  319. package/src/components/helpers/InputError.tsx +2 -2
  320. package/src/components/icon/Icon.theme.ts +13 -3
  321. package/src/components/icon/Icon.vue +24 -15
  322. package/src/components/icon/__tests__/Icon.spec.ts +5 -1
  323. package/src/components/icon/index.ts +3 -0
  324. package/src/components/image/Image.theme.ts +12 -2
  325. package/src/components/image/Image.vue +8 -4
  326. package/src/components/image/index.ts +3 -0
  327. package/src/components/index.ts +35 -45
  328. package/src/components/input/Input.theme.ts +17 -6
  329. package/src/components/input/Input.vue +31 -20
  330. package/src/components/input/index.ts +3 -0
  331. package/src/components/link/Link.theme.ts +13 -3
  332. package/src/components/link/Link.vue +16 -11
  333. package/src/components/link/index.ts +3 -0
  334. package/src/components/menu/Menu.theme.ts +12 -2
  335. package/src/components/menu/Menu.vue +59 -23
  336. package/src/components/menu/MenuItem.theme.ts +17 -5
  337. package/src/components/menu/MenuItem.vue +56 -48
  338. package/src/components/menu/index.ts +7 -0
  339. package/src/components/modal/Modal.theme.ts +13 -3
  340. package/src/components/modal/Modal.vue +22 -11
  341. package/src/components/modal/index.ts +3 -0
  342. package/src/components/notifications/Notifications.theme.ts +12 -2
  343. package/src/components/notifications/Notifications.vue +53 -49
  344. package/src/components/notifications/index.ts +9 -0
  345. package/src/components/pagination/Pagination.theme.ts +15 -5
  346. package/src/components/pagination/Pagination.vue +24 -18
  347. package/src/components/pagination/PaginationItem.theme.ts +13 -3
  348. package/src/components/pagination/PaginationItem.vue +14 -10
  349. package/src/components/pagination/index.ts +7 -0
  350. package/src/components/popover/Popover.theme.ts +12 -2
  351. package/src/components/popover/Popover.vue +27 -21
  352. package/src/components/popover/PopoverContainer.theme.ts +12 -2
  353. package/src/components/popover/PopoverContainer.vue +11 -6
  354. package/src/components/popover/index.ts +7 -0
  355. package/src/components/progress/Progress.theme.ts +14 -4
  356. package/src/components/progress/Progress.vue +16 -16
  357. package/src/components/progress/index.ts +3 -0
  358. package/src/components/radio/Radio.theme.ts +19 -7
  359. package/src/components/radio/Radio.vue +21 -12
  360. package/src/components/radio/index.ts +3 -0
  361. package/src/components/scroll/Scroll.theme.ts +12 -2
  362. package/src/components/scroll/Scroll.vue +14 -10
  363. package/src/components/scroll/index.ts +3 -0
  364. package/src/components/select/Select.theme.ts +20 -6
  365. package/src/components/select/Select.vue +28 -19
  366. package/src/components/select/index.ts +3 -0
  367. package/src/components/skeleton/Skeleton.theme.ts +12 -2
  368. package/src/components/skeleton/Skeleton.vue +11 -6
  369. package/src/components/skeleton/index.ts +3 -0
  370. package/src/components/slider/Slider.theme.ts +14 -4
  371. package/src/components/slider/Slider.vue +24 -16
  372. package/src/components/slider/index.ts +2 -0
  373. package/src/components/spacer/index.ts +1 -0
  374. package/src/components/spinner/Spinner.vue +18 -8
  375. package/src/components/spinner/index.ts +2 -0
  376. package/src/components/tab/Tab.theme.ts +15 -3
  377. package/src/components/tab/Tab.vue +85 -68
  378. package/src/components/tab/TabGroup.theme.ts +15 -5
  379. package/src/components/tab/TabGroup.vue +67 -22
  380. package/src/components/tab/index.ts +5 -0
  381. package/src/components/table/Table.theme.ts +14 -4
  382. package/src/components/table/Table.vue +41 -31
  383. package/src/components/table/TableCell.theme.ts +13 -3
  384. package/src/components/table/TableCell.vue +22 -16
  385. package/src/components/table/TableHeader.vue +20 -17
  386. package/src/components/table/index.ts +10 -0
  387. package/src/components/tag/Tag.theme.ts +14 -4
  388. package/src/components/tag/Tag.vue +22 -13
  389. package/src/components/tag/index.ts +2 -0
  390. package/src/components/textarea/Textarea.theme.ts +18 -30
  391. package/src/components/textarea/Textarea.vue +28 -19
  392. package/src/components/textarea/index.ts +2 -0
  393. package/src/components/toggle/Toggle.theme.ts +16 -6
  394. package/src/components/toggle/Toggle.vue +21 -12
  395. package/src/components/toggle/index.ts +2 -0
  396. package/src/components/tooltip/Tooltip.vue +5 -0
  397. package/src/components/tooltip/index.ts +2 -0
  398. package/src/composables/colors-utils.ts +1 -78
  399. package/src/composables/colors.ts +6 -4
  400. package/src/composables/common.ts +1 -1
  401. package/src/composables/inputtable.ts +4 -4
  402. package/src/composables/keys.ts +6 -3
  403. package/src/composables/theme.ts +26 -23
  404. package/src/create.ts +1 -2
  405. package/src/version.ts +1 -1
  406. package/volar.d.ts +1 -1
  407. package/lib/components/tooltip/Tooltip.theme.d.ts +0 -11
  408. package/lib/index.cjs.js +0 -1
  409. package/lib/index.es.js +0 -5187
  410. package/src/components/tooltip/Tooltip.theme.ts +0 -51
@@ -1,8 +1,16 @@
1
- import type { ThemeParams } from '../../composables/theme'
1
+ import type { ThemeClasses, ThemeComponent } from '../../composables/theme'
2
+ import type { TagProps } from './Tag.vue'
2
3
 
3
- export default {
4
+ type InternalClasses = 'wrapper' | 'loadingWrapper'
5
+
6
+ interface InternalTheme extends ThemeComponent<TagProps, InternalClasses> {}
7
+ export interface TagTheme extends Omit<InternalTheme, 'classes'> {
8
+ classes?: Partial<ThemeClasses<TagProps, InternalClasses>>;
9
+ }
10
+
11
+ const theme: InternalTheme = {
4
12
  classes: {
5
- wrapper: ({ props, data }: ThemeParams) => {
13
+ wrapper: ({ props, data }) => {
6
14
  let c = 'inline-flex items-center leading-none max-w-full'
7
15
 
8
16
  if (props.size === 'xs') c += ' px-2 py-1 text-xs'
@@ -17,7 +25,7 @@ export default {
17
25
  loadingWrapper: 'absolute inset-0 flex items-center justify-center z-40 bg-gray-300 dark:bg-gray-600 rounded opacity-50',
18
26
  },
19
27
 
20
- styles: ({ colors, props, css }: ThemeParams) => {
28
+ styles: ({ colors, props, css }) => {
21
29
  const color = colors.getPalette(props.color)
22
30
 
23
31
  return css.variables({
@@ -30,3 +38,5 @@ export default {
30
38
  })
31
39
  },
32
40
  }
41
+
42
+ export default theme
@@ -1,9 +1,28 @@
1
1
  <script lang="ts">
2
- export default { name: 'XTag' }
2
+ const tagProps = {
3
+ ...useCommon.props(),
4
+ ...useColors.props('gray'),
5
+ tag: {
6
+ type: String,
7
+ default: 'span',
8
+ },
9
+ rounded: Boolean,
10
+ removable: Boolean,
11
+ outlined: Boolean,
12
+ }
13
+
14
+ export type TagProps = ExtractPublicPropTypes<typeof tagProps>
15
+
16
+ export default {
17
+ name: 'XTag',
18
+ validators: {
19
+ ...useCommon.validators(),
20
+ },
21
+ }
3
22
  </script>
4
23
 
5
24
  <script setup lang="ts">
6
- import { computed } from 'vue'
25
+ import { computed, type ExtractPublicPropTypes } from 'vue'
7
26
  import { useColors } from '../../composables/colors'
8
27
  import { useCommon } from '../../composables/common'
9
28
  import { useTheme } from '../../composables/theme'
@@ -13,17 +32,7 @@ import XIcon from '../icon/Icon.vue'
13
32
 
14
33
  import theme from './Tag.theme'
15
34
 
16
- const props = defineProps({
17
- ...useCommon.props(),
18
- ...useColors.props('gray'),
19
- tag: {
20
- type: String,
21
- default: 'span',
22
- },
23
- rounded: Boolean,
24
- removable: Boolean,
25
- outlined: Boolean,
26
- })
35
+ const props = defineProps(tagProps)
27
36
 
28
37
  defineEmits(['remove'])
29
38
 
@@ -0,0 +1,2 @@
1
+ export { default as XTag } from './Tag.vue'
2
+ export type { TagProps } from './Tag.vue'
@@ -1,23 +1,22 @@
1
- import type { ThemeParams } from '../../composables/theme'
1
+ import type { Ref } from 'vue'
2
+ import type { ThemeClasses, ThemeComponent } from '../../composables/theme'
3
+ import type { TextareaProps } from './Textarea.vue'
2
4
 
3
- export default {
4
- classes: {
5
- wrapper: 'inline-block align-bottom text-left',
6
- // wrapper: ({ props, data }: ThemeParams) => {
7
- // let c = 'inline-flex items-center leading-none whitespace-nowrap'
8
-
9
- // if (props.size === 'xs') c += ' px-2 py-1 text-xs'
10
- // else if (props.size === 'sm') c += ' px-2 py-1 text-sm'
11
- // else if (props.size === 'lg') c += ' px-4 py-3 text-lg'
12
- // else if (props.size === 'xl') c += ' px-6 py-6 text-xl'
13
- // else c += ' px-3 py-2'
5
+ type InternalClasses = 'wrapper' | 'label' | 'input'
6
+ type InternalExtraData = {
7
+ errorInternal: Ref<boolean>;
8
+ }
14
9
 
15
- // return c
16
- // },
10
+ interface InternalTheme extends ThemeComponent<TextareaProps, InternalClasses, InternalExtraData> {}
11
+ export interface TextareaTheme extends Omit<InternalTheme, 'classes'> {
12
+ classes?: Partial<ThemeClasses<TextareaProps, InternalClasses, InternalExtraData>>;
13
+ }
17
14
 
18
- // loadingWrapper: 'absolute inset-0 flex items-center justify-center z-40 bg-gray-300 dark:bg-gray-600 rounded opacity-50',
15
+ const theme: InternalTheme = {
16
+ classes: {
17
+ wrapper: 'inline-block align-bottom text-left',
19
18
 
20
- label: ({ props }: ThemeParams) => {
19
+ label: ({ props }) => {
21
20
  const classes = 'font-medium text-gray-800 dark:text-gray-200 mb-1'
22
21
 
23
22
  if (props.size === 'xs') return classes + ' text-xs'
@@ -28,7 +27,7 @@ export default {
28
27
  return classes //+ ' text-sm'
29
28
  },
30
29
 
31
- input: ({ props, data }: ThemeParams) => {
30
+ input: ({ props, data }) => {
32
31
  const classes = ['resize-none appearance-none block w-full placeholder-gray-400 dark:placeholder-gray-500 outline-transparent outline outline-2 outline-offset-[-1px] transition duration-150 ease-in-out border-gray-300 dark:border-gray-700 border shadow-sm rounded-md']
33
32
 
34
33
  if (!data.errorInternal && !props.disabled) classes.push('hover:border-gray-400 dark:hover:border-gray-500')
@@ -46,17 +45,6 @@ export default {
46
45
  return classes
47
46
  },
48
47
  },
49
-
50
- styles: ({ colors, props, css }: ThemeParams) => {
51
- const color = colors.getPalette(props.color)
52
-
53
- return css.variables({
54
- bg: color[100],
55
- text: color[800],
56
- border: color[800],
57
- dark: {
58
- text: props.outlined ? color[200] : color[800],
59
- },
60
- })
61
- },
62
48
  }
49
+
50
+ export default theme
@@ -1,22 +1,5 @@
1
1
  <script lang="ts">
2
- export default { name: 'XTextarea' }
3
- </script>
4
-
5
- <script setup lang="ts">
6
- import { ref, watch } from 'vue'
7
- import { useResizeObserver, useEventListener } from '@vueuse/core'
8
- import { useCSS } from '../../composables/css'
9
- import { useTheme } from '../../composables/theme'
10
- import { useCommon } from '../../composables/common'
11
- import { useColors } from '../../composables/colors'
12
- import { useInputtable } from '../../composables/inputtable'
13
- import { useInteractive } from '../../composables/interactive'
14
-
15
- import XInputError from '../helpers/InputError'
16
-
17
- import theme from './Textarea.theme'
18
-
19
- const props = defineProps({
2
+ const textareaProps = {
20
3
  ...useCommon.props(),
21
4
  ...useInteractive.props(),
22
5
  ...useInputtable.props(),
@@ -38,7 +21,33 @@ const props = defineProps({
38
21
  },
39
22
  preventEnter: Boolean,
40
23
  block: Boolean,
41
- })
24
+ }
25
+
26
+ export type TextareaProps = ExtractPublicPropTypes<typeof textareaProps>
27
+
28
+ export default {
29
+ name: 'XTextarea',
30
+ validators: {
31
+ ...useCommon.validators(),
32
+ },
33
+ }
34
+ </script>
35
+
36
+ <script setup lang="ts">
37
+ import { ref, watch, type ExtractPublicPropTypes } from 'vue'
38
+ import { useResizeObserver, useEventListener } from '@vueuse/core'
39
+ import { useCSS } from '../../composables/css'
40
+ import { useTheme } from '../../composables/theme'
41
+ import { useCommon } from '../../composables/common'
42
+ import { useColors } from '../../composables/colors'
43
+ import { useInputtable } from '../../composables/inputtable'
44
+ import { useInteractive } from '../../composables/interactive'
45
+
46
+ import XInputError from '../helpers/InputError'
47
+
48
+ import theme from './Textarea.theme'
49
+
50
+ const props = defineProps(textareaProps)
42
51
 
43
52
  const emit = defineEmits(useInputtable.emits())
44
53
 
@@ -0,0 +1,2 @@
1
+ export { default as XTextarea } from './Textarea.vue'
2
+ export type { TextareaProps } from './Textarea.vue'
@@ -1,10 +1,18 @@
1
- import type { ThemeParams } from '../../composables/theme'
1
+ import type { ThemeClasses, ThemeComponent } from '../../composables/theme'
2
+ import type { ToggleProps } from './Toggle.vue'
2
3
 
3
- export default {
4
+ type InternalClasses = 'wrapper' | 'label' | 'buttonWrapper' | 'button'
5
+
6
+ interface InternalTheme extends ThemeComponent<ToggleProps, InternalClasses> {}
7
+ export interface ToggleTheme extends Omit<InternalTheme, 'classes'> {
8
+ classes?: Partial<ThemeClasses<ToggleProps, InternalClasses>>;
9
+ }
10
+
11
+ const theme: InternalTheme = {
4
12
  classes: {
5
13
  wrapper: '',
6
14
 
7
- label: ({ props }: ThemeParams) => {
15
+ label: ({ props }) => {
8
16
  const c = 'font-medium text-gray-800 dark:text-gray-200'
9
17
 
10
18
  if (props.size === 'xs') return c + ' text-xs'
@@ -15,7 +23,7 @@ export default {
15
23
  return c + ' text-sm'
16
24
  },
17
25
 
18
- buttonWrapper: ({ props }: ThemeParams) => {
26
+ buttonWrapper: ({ props }) => {
19
27
  let c = 'relative shrink-0'
20
28
 
21
29
  if (props.size === 'sm' || props.size === 'xs') c += ' w-6'
@@ -26,7 +34,7 @@ export default {
26
34
  return c
27
35
  },
28
36
 
29
- button: ({ props }: ThemeParams) => {
37
+ button: ({ props }) => {
30
38
  let c = 'rounded-full shadow transform transition duration-150 shrink-0'
31
39
 
32
40
  if (props.size === 'sm' || props.size === 'xs') c += ' h-3 w-3'
@@ -38,7 +46,7 @@ export default {
38
46
  },
39
47
  },
40
48
 
41
- styles: ({ colors, props, css }: ThemeParams) => {
49
+ styles: ({ colors, props, css }) => {
42
50
  const color = colors.getPalette(props.color)
43
51
 
44
52
  return css.variables({
@@ -49,3 +57,5 @@ export default {
49
57
  })
50
58
  },
51
59
  }
60
+
61
+ export default theme
@@ -1,9 +1,27 @@
1
1
  <script lang="ts">
2
- export default { name: 'XToggle' }
2
+ const toggleProps = {
3
+ ...useCommon.props(),
4
+ ...useColors.props('primary'),
5
+ ...useInteractive.props(),
6
+ ...useInputtable.props(),
7
+ id: String,
8
+ label: String,
9
+ helper: String,
10
+ glow: Boolean,
11
+ }
12
+
13
+ export type ToggleProps = ExtractPublicPropTypes<typeof toggleProps>
14
+
15
+ export default {
16
+ name: 'XToggle',
17
+ validators: {
18
+ ...useCommon.validators(),
19
+ },
20
+ }
3
21
  </script>
4
22
 
5
23
  <script setup lang="ts">
6
- import { computed, ref } from 'vue'
24
+ import { computed, ref, type ExtractPublicPropTypes } from 'vue'
7
25
  import { useTheme } from '../../composables/theme'
8
26
  import { useCommon } from '../../composables/common'
9
27
  import { useColors } from '../../composables/colors'
@@ -15,16 +33,7 @@ import XInputError from '../helpers/InputError'
15
33
 
16
34
  import theme from './Toggle.theme'
17
35
 
18
- const props = defineProps({
19
- ...useCommon.props(),
20
- ...useColors.props('primary'),
21
- ...useInteractive.props(),
22
- ...useInputtable.props(),
23
- id: String,
24
- label: String,
25
- helper: String,
26
- glow: Boolean,
27
- })
36
+ const props = defineProps(toggleProps)
28
37
 
29
38
  const emit = defineEmits(useInputtable.emits(false))
30
39
 
@@ -0,0 +1,2 @@
1
+ export { default as XToggle } from './Toggle.vue'
2
+ export type { ToggleProps } from './Toggle.vue'
@@ -1,8 +1,13 @@
1
1
  <script lang="ts">
2
+ const tooltipProps = {}
3
+
4
+ export type TooltipProps = ExtractPublicPropTypes<typeof tooltipProps>
5
+
2
6
  export default { name: 'XTooltip' }
3
7
  </script>
4
8
 
5
9
  <script setup lang="ts">
10
+ import type { ExtractPublicPropTypes } from 'vue'
6
11
  import XPopover from '../../components/popover/Popover.vue'
7
12
  import XPopoverContainer from '../../components/popover/PopoverContainer.vue'
8
13
  </script>
@@ -0,0 +1,2 @@
1
+ export { default as XTooltip } from './Tooltip.vue'
2
+ export type { TooltipProps } from './Tooltip.vue'
@@ -1,4 +1,4 @@
1
- import type { Tone, ColorLibrary, ColorPalette } from './colors'
1
+ import type { Tone, ColorLibrary } from './colors'
2
2
 
3
3
  const isHex = (hex: string) => /^#(?:[A-Fa-f0-9]{3}){1,2}$/.test(hex)
4
4
  const isRGB = (rgb: string) => /^rgb[(](?:\s*0*(?:\d\d?(?:\.\d+)?(?:\s*%)?|\.\d+\s*%|100(?:\.0*)?\s*%|(?:1\d\d|2[0-4]\d|25[0-5])(?:\.\d+)?)\s*(?:,(?![)])|(?=[)]))){3}[)]$/.test(rgb)
@@ -33,81 +33,4 @@ export const colorShade = (color: string, percentage: number) => {
33
33
  export const shades: Tone[] = ['50', '100', '200', '300', '400', '500', '600', '700', '800', '900']
34
34
  export const indielayerColors = ['primary', 'secondary', 'success', 'warning', 'error']
35
35
 
36
- // calculate custom colors
37
- // export function calculateColors(): ColorLibrary {
38
- // const cc = computedColors
39
- // const customColors: ColorLibrary = {}
40
- // const e = document.createElement('div')
41
-
42
- // document.body.appendChild(e)
43
-
44
- // indielayerColors.forEach((color) => {
45
- // const c: ColorPalette = { ...tailwindColors.gray }
46
-
47
- // shades.forEach((shade) => {
48
- // e.className = `bg-${color}-${shade}`
49
- // c[shade] = window.getComputedStyle(e ,null).getPropertyValue('background-color')
50
- // })
51
-
52
- // customColors[color] = c
53
- // })
54
-
55
- // e.remove()
56
-
57
- // return customColors
58
- // }
59
-
60
- // const computedColors = Object.freeze([
61
- // 'bg-primary-50',
62
- // 'bg-primary-100',
63
- // 'bg-primary-200',
64
- // 'bg-primary-300',
65
- // 'bg-primary-400',
66
- // 'bg-primary-500',
67
- // 'bg-primary-600',
68
- // 'bg-primary-700',
69
- // 'bg-primary-800',
70
- // 'bg-primary-900',
71
- // 'bg-secondary-50',
72
- // 'bg-secondary-100',
73
- // 'bg-secondary-200',
74
- // 'bg-secondary-300',
75
- // 'bg-secondary-400',
76
- // 'bg-secondary-500',
77
- // 'bg-secondary-600',
78
- // 'bg-secondary-700',
79
- // 'bg-secondary-800',
80
- // 'bg-secondary-900',
81
- // 'bg-error-50',
82
- // 'bg-error-100',
83
- // 'bg-error-200',
84
- // 'bg-error-300',
85
- // 'bg-error-400',
86
- // 'bg-error-500',
87
- // 'bg-error-600',
88
- // 'bg-error-700',
89
- // 'bg-error-800',
90
- // 'bg-error-900',
91
- // 'bg-warning-50',
92
- // 'bg-warning-100',
93
- // 'bg-warning-200',
94
- // 'bg-warning-300',
95
- // 'bg-warning-400',
96
- // 'bg-warning-500',
97
- // 'bg-warning-600',
98
- // 'bg-warning-700',
99
- // 'bg-warning-800',
100
- // 'bg-warning-900',
101
- // 'bg-success-50',
102
- // 'bg-success-100',
103
- // 'bg-success-200',
104
- // 'bg-success-300',
105
- // 'bg-success-400',
106
- // 'bg-success-500',
107
- // 'bg-success-600',
108
- // 'bg-success-700',
109
- // 'bg-success-800',
110
- // 'bg-success-900',
111
- // ])
112
-
113
36
  export const tailwindColors: ColorLibrary = Object.freeze({ 'slate': { '50': '#f8fafc', '100': '#f1f5f9', '200': '#e2e8f0', '300': '#cbd5e1', '400': '#94a3b8', '500': '#64748b', '600': '#475569', '700': '#334155', '800': '#1e293b', '900': '#0f172a', '950': '#020617' }, 'gray': { '50': '#f9fafb', '100': '#f3f4f6', '200': '#e5e7eb', '300': '#d1d5db', '400': '#9ca3af', '500': '#6b7280', '600': '#4b5563', '700': '#374151', '800': '#1f2937', '900': '#111827', '950': '#030712' }, 'zinc': { '50': '#fafafa', '100': '#f4f4f5', '200': '#e4e4e7', '300': '#d4d4d8', '400': '#a1a1aa', '500': '#71717a', '600': '#52525b', '700': '#3f3f46', '800': '#27272a', '900': '#18181b', '950': '#09090b' }, 'neutral': { '50': '#fafafa', '100': '#f5f5f5', '200': '#e5e5e5', '300': '#d4d4d4', '400': '#a3a3a3', '500': '#737373', '600': '#525252', '700': '#404040', '800': '#262626', '900': '#171717', '950': '#0a0a0a' }, 'stone': { '50': '#fafaf9', '100': '#f5f5f4', '200': '#e7e5e4', '300': '#d6d3d1', '400': '#a8a29e', '500': '#78716c', '600': '#57534e', '700': '#44403c', '800': '#292524', '900': '#1c1917', '950': '#0c0a09' }, 'red': { '50': '#fef2f2', '100': '#fee2e2', '200': '#fecaca', '300': '#fca5a5', '400': '#f87171', '500': '#ef4444', '600': '#dc2626', '700': '#b91c1c', '800': '#991b1b', '900': '#7f1d1d', '950': '#450a0a' }, 'orange': { '50': '#fff7ed', '100': '#ffedd5', '200': '#fed7aa', '300': '#fdba74', '400': '#fb923c', '500': '#f97316', '600': '#ea580c', '700': '#c2410c', '800': '#9a3412', '900': '#7c2d12', '950': '#431407' }, 'amber': { '50': '#fffbeb', '100': '#fef3c7', '200': '#fde68a', '300': '#fcd34d', '400': '#fbbf24', '500': '#f59e0b', '600': '#d97706', '700': '#b45309', '800': '#92400e', '900': '#78350f', '950': '#451a03' }, 'yellow': { '50': '#fefce8', '100': '#fef9c3', '200': '#fef08a', '300': '#fde047', '400': '#facc15', '500': '#eab308', '600': '#ca8a04', '700': '#a16207', '800': '#854d0e', '900': '#713f12', '950': '#422006' }, 'lime': { '50': '#f7fee7', '100': '#ecfccb', '200': '#d9f99d', '300': '#bef264', '400': '#a3e635', '500': '#84cc16', '600': '#65a30d', '700': '#4d7c0f', '800': '#3f6212', '900': '#365314', '950': '#1a2e05' }, 'green': { '50': '#f0fdf4', '100': '#dcfce7', '200': '#bbf7d0', '300': '#86efac', '400': '#4ade80', '500': '#22c55e', '600': '#16a34a', '700': '#15803d', '800': '#166534', '900': '#14532d', '950': '#052e16' }, 'emerald': { '50': '#ecfdf5', '100': '#d1fae5', '200': '#a7f3d0', '300': '#6ee7b7', '400': '#34d399', '500': '#10b981', '600': '#059669', '700': '#047857', '800': '#065f46', '900': '#064e3b', '950': '#022c22' }, 'teal': { '50': '#f0fdfa', '100': '#ccfbf1', '200': '#99f6e4', '300': '#5eead4', '400': '#2dd4bf', '500': '#14b8a6', '600': '#0d9488', '700': '#0f766e', '800': '#115e59', '900': '#134e4a', '950': '#042f2e' }, 'cyan': { '50': '#ecfeff', '100': '#cffafe', '200': '#a5f3fc', '300': '#67e8f9', '400': '#22d3ee', '500': '#06b6d4', '600': '#0891b2', '700': '#0e7490', '800': '#155e75', '900': '#164e63', '950': '#083344' }, 'sky': { '50': '#f0f9ff', '100': '#e0f2fe', '200': '#bae6fd', '300': '#7dd3fc', '400': '#38bdf8', '500': '#0ea5e9', '600': '#0284c7', '700': '#0369a1', '800': '#075985', '900': '#0c4a6e', '950': '#082f49' }, 'blue': { '50': '#eff6ff', '100': '#dbeafe', '200': '#bfdbfe', '300': '#93c5fd', '400': '#60a5fa', '500': '#3b82f6', '600': '#2563eb', '700': '#1d4ed8', '800': '#1e40af', '900': '#1e3a8a', '950': '#172554' }, 'indigo': { '50': '#eef2ff', '100': '#e0e7ff', '200': '#c7d2fe', '300': '#a5b4fc', '400': '#818cf8', '500': '#6366f1', '600': '#4f46e5', '700': '#4338ca', '800': '#3730a3', '900': '#312e81', '950': '#1e1b4b' }, 'violet': { '50': '#f5f3ff', '100': '#ede9fe', '200': '#ddd6fe', '300': '#c4b5fd', '400': '#a78bfa', '500': '#8b5cf6', '600': '#7c3aed', '700': '#6d28d9', '800': '#5b21b6', '900': '#4c1d95', '950': '#2e1065' }, 'purple': { '50': '#faf5ff', '100': '#f3e8ff', '200': '#e9d5ff', '300': '#d8b4fe', '400': '#c084fc', '500': '#a855f7', '600': '#9333ea', '700': '#7e22ce', '800': '#6b21a8', '900': '#581c87', '950': '#3b0764' }, 'fuchsia': { '50': '#fdf4ff', '100': '#fae8ff', '200': '#f5d0fe', '300': '#f0abfc', '400': '#e879f9', '500': '#d946ef', '600': '#c026d3', '700': '#a21caf', '800': '#86198f', '900': '#701a75', '950': '#4a044e' }, 'pink': { '50': '#fdf2f8', '100': '#fce7f3', '200': '#fbcfe8', '300': '#f9a8d4', '400': '#f472b6', '500': '#ec4899', '600': '#db2777', '700': '#be185d', '800': '#9d174d', '900': '#831843', '950': '#500724' }, 'rose': { '50': '#fff1f2', '100': '#ffe4e6', '200': '#fecdd3', '300': '#fda4af', '400': '#fb7185', '500': '#f43f5e', '600': '#e11d48', '700': '#be123c', '800': '#9f1239', '900': '#881337', '950': '#4c0519' }, 'lightBlue': { '50': '#f0f9ff', '100': '#e0f2fe', '200': '#bae6fd', '300': '#7dd3fc', '400': '#38bdf8', '500': '#0ea5e9', '600': '#0284c7', '700': '#0369a1', '800': '#075985', '900': '#0c4a6e', '950': '#082f49' }, 'warmGray': { '50': '#fafaf9', '100': '#f5f5f4', '200': '#e7e5e4', '300': '#d6d3d1', '400': '#a8a29e', '500': '#78716c', '600': '#57534e', '700': '#44403c', '800': '#292524', '900': '#1c1917', '950': '#0c0a09' }, 'trueGray': { '50': '#fafafa', '100': '#f5f5f5', '200': '#e5e5e5', '300': '#d4d4d4', '400': '#a3a3a3', '500': '#737373', '600': '#525252', '700': '#404040', '800': '#262626', '900': '#171717', '950': '#0a0a0a' }, 'coolGray': { '50': '#f9fafb', '100': '#f3f4f6', '200': '#e5e7eb', '300': '#d1d5db', '400': '#9ca3af', '500': '#6b7280', '600': '#4b5563', '700': '#374151', '800': '#1f2937', '900': '#111827', '950': '#030712' }, 'blueGray': { '50': '#f8fafc', '100': '#f1f5f9', '200': '#e2e8f0', '300': '#cbd5e1', '400': '#94a3b8', '500': '#64748b', '600': '#475569', '700': '#334155', '800': '#1e293b', '900': '#0f172a', '950': '#020617' } })
@@ -1,7 +1,7 @@
1
- import * as R from 'ramda'
2
1
  import { computed, inject, unref } from 'vue'
3
2
  import { injectThemeKey } from './keys'
4
3
  import { isValidColor, tailwindColors, colorShade, setOpacity } from './colors-utils'
4
+ import { mergeRightDeep } from '../common/utils'
5
5
 
6
6
  export type Tone = '50' | '100' | '200' | '300' | '400' | '500' | '600' | '700' | '800' | '900' | '950'
7
7
 
@@ -26,7 +26,7 @@ export interface ColorsProps {
26
26
  }
27
27
 
28
28
  export interface ColorComposition {
29
- getPalette: (color: string) => ColorPalette;
29
+ getPalette: (color?: string) => ColorPalette;
30
30
  getColorOpacity: (color: string, opacity: number) => string;
31
31
  }
32
32
 
@@ -42,13 +42,13 @@ const defaultColors = {
42
42
 
43
43
  export const useColors = (): ColorComposition => {
44
44
  const globalTheme = inject(injectThemeKey, {})
45
- const customColors = computed(() => R.mergeRight(defaultColors, unref(globalTheme).colors))
45
+ const customColors = computed(() => mergeRightDeep(defaultColors, unref(globalTheme).colors || {}))
46
46
 
47
47
  const getTailwindColor = (color: string) => tailwindColors[color]
48
48
 
49
49
  const getColorOpacity = (color: string, opacity: number) => setOpacity(color, opacity)
50
50
 
51
- const getPalette = (color: string): ColorPalette => {
51
+ const getPalette = (color?: string): ColorPalette => {
52
52
  if (!color) return getTailwindColor('gray')
53
53
 
54
54
  const twColor = getTailwindColor(color)
@@ -88,6 +88,8 @@ export const useColors = (): ColorComposition => {
88
88
  }
89
89
  }
90
90
 
91
+ export type UseColorsProps = ReturnType<typeof useColors.props>
92
+
91
93
  useColors.props = (defaultColor?: string) => ({
92
94
  color: {
93
95
  type: String,
@@ -1,6 +1,6 @@
1
1
  import type { PropType } from 'vue'
2
2
 
3
- export type Size = 'xs' | 'sm' | 'md' | 'lg' | 'xl' | undefined
3
+ export type Size = 'xs' | 'sm' | 'md' | 'lg' | 'xl'
4
4
 
5
5
  export const useCommon = () => {}
6
6
 
@@ -1,4 +1,4 @@
1
- import type { Ref, PropType } from 'vue'
1
+ import type { PropType } from 'vue'
2
2
  import { ref, computed, inject, watch, onMounted, onUnmounted } from 'vue'
3
3
  import { injectFormKey } from './keys'
4
4
 
@@ -19,8 +19,8 @@ export const useInputtable = (props: any, { focus, emit, withListeners = true }:
19
19
  watch(() => props.name, (val) => { if (val) nameInternal.value = val })
20
20
 
21
21
  const form = inject(injectFormKey, {
22
- registerInput: (inputName: string, methods: XFormInputMethods) => {},
23
- unregisterInput: (inputName: string) => {},
22
+ registerInput: () => {},
23
+ unregisterInput: () => {},
24
24
  isInsideForm: false,
25
25
  })
26
26
 
@@ -34,7 +34,7 @@ export const useInputtable = (props: any, { focus, emit, withListeners = true }:
34
34
  errorInternal.value = val
35
35
  }
36
36
 
37
- const validate = (val: any): boolean => {
37
+ const validate = (val?: any): boolean => {
38
38
  val = val || props.modelValue
39
39
 
40
40
  isFirstValidation.value = false
@@ -1,9 +1,12 @@
1
1
  import type { InjectionKey } from 'vue'
2
+ import type { FormInjection } from '../components/form/Form.vue'
3
+ import type { TabGroupInjection } from '../components/tab/TabGroup.vue'
4
+ import type { ButtonGroupInjection } from '../components/button/ButtonGroup.vue'
2
5
 
3
- export const injectTabKey = Symbol() as InjectionKey<any>
4
- export const injectFormKey = Symbol() as InjectionKey<any>
6
+ export const injectTabKey = Symbol() as InjectionKey<TabGroupInjection>
7
+ export const injectFormKey = Symbol() as InjectionKey<FormInjection>
5
8
  export const injectThemeKey = Symbol() as InjectionKey<any>
6
9
  export const injectIconsKey = Symbol() as InjectionKey<any>
7
10
  export const injectColorsKey = Symbol() as InjectionKey<any>
8
- export const injectButtonGroupKey = Symbol() as InjectionKey<any>
11
+ export const injectButtonGroupKey = Symbol() as InjectionKey<ButtonGroupInjection>
9
12
  export const injectNotificationKey = Symbol() as InjectionKey<any>
@@ -1,26 +1,30 @@
1
- import { computed, inject, unref, useSlots, type StyleValue } from 'vue'
1
+ import { computed, inject, unref, useSlots, type StyleValue, type Slots, type UnwrapNestedRefs, type UnwrapRef, type MaybeRef } from 'vue'
2
2
  import { injectThemeKey } from './keys'
3
3
  import { useColors, type ColorComposition } from './colors'
4
4
  import { useCSS, type CSSComposition } from './css'
5
- import * as R from 'ramda'
6
- import { smartUnref } from '../common/utils'
5
+ import { isFunction, isObject, mergeRightDeep, smartUnref } from '../common/utils'
7
6
 
8
- import type { Slots } from 'vue'
9
-
10
- export type ThemeParams = {
11
- props: any;
7
+ export type ThemeVueClass = string | Record<string, boolean> | (string | Record<string, boolean>)[]
8
+ export type ThemeClasses<P, K extends string = string, D = undefined> = Record<K, string | ((params: ThemeParams<P, D>) => ThemeVueClass)>
9
+ export type ThemeStyles<P, D> = StyleValue | ((params: ThemeParams<P, D>) => StyleValue);
10
+ export interface ThemeComponent<P = object, K extends string = string, D = object> {
11
+ classes?: ThemeClasses<P, K, D>;
12
+ styles?: ThemeStyles<P, D>;
13
+ }
14
+ export type ThemeParams<P = Record<string, any>, D = Record<string, any>> = {
15
+ props: UnwrapRef<P>;
12
16
  slots: Slots;
13
17
  colors: ColorComposition;
14
18
  css: CSSComposition;
15
19
  rtl?: boolean;
16
- data?: any;
20
+ data: UnwrapNestedRefs<D>;
17
21
  }
18
22
 
19
- export const useTheme = (namespace: string, defaultTheme: any = {}, props: any, data?: any) => {
23
+ export const useTheme = <P extends object = object, K extends string = string, D extends object = object>(namespace: string, defaultTheme: ThemeComponent<P, K, D> = {}, props: MaybeRef<P> = {} as P, data: D = {} as D) => {
20
24
  const userTheme = inject(injectThemeKey, false)
21
25
 
22
26
  const rawClasses = computed(() => {
23
- if (unref(userTheme)?.[namespace]) return R.mergeRight(defaultTheme.classes, unref(userTheme)[namespace].classes || {})
27
+ if (unref(userTheme)?.[namespace]) return mergeRightDeep(defaultTheme.classes, unref(userTheme)[namespace].classes || {})
24
28
 
25
29
  return defaultTheme.classes
26
30
  })
@@ -34,8 +38,7 @@ export const useTheme = (namespace: string, defaultTheme: any = {}, props: any,
34
38
  const slots = useSlots()
35
39
  const colors = useColors()
36
40
  const css = useCSS(namespace)
37
-
38
- const classes = computed(() => getClasses(rawClasses.value, {
41
+ const classes = computed<Record<K, ThemeVueClass>>(() => getClasses(rawClasses.value, {
39
42
  props: unref(props),
40
43
  slots,
41
44
  data: smartUnref(data),
@@ -71,18 +74,18 @@ export const useTheme = (namespace: string, defaultTheme: any = {}, props: any,
71
74
  }
72
75
  }
73
76
 
74
- function getClasses(xs: any, params: ThemeParams): any {
75
- return R.map((x) => R.is(Function, x)
76
- ? x(params)
77
- : R.is(Object, x) || R.is(Array, x)
78
- ? getClasses(x, params)
79
- : x, xs)
77
+ function getClasses(classes: any, params: ThemeParams): any {
78
+ const parsedClasses: Record<string, string> = {}
79
+
80
+ Object.keys(classes).forEach((key) => {
81
+ const x = classes[key]
82
+
83
+ parsedClasses[key] = isFunction(x) ? x(params) : (isObject(x) ? getClasses(x, params) : x)
84
+ })
85
+
86
+ return parsedClasses
80
87
  }
81
88
 
82
89
  function getStyles(styles: any, params: ThemeParams) {
83
- return R.is(Function, styles)
84
- ? styles(params) || {}
85
- : R.is(Object, styles)
86
- ? styles
87
- : {}
90
+ return isFunction(styles) ? (styles(params) || {}) : (isObject(styles) ? styles : {})
88
91
  }
package/src/create.ts CHANGED
@@ -24,10 +24,9 @@ const create = (createOptions: IndielayerUIOptions = {}) => {
24
24
 
25
25
  if (options.components)
26
26
  options.components.forEach((component: any) => {
27
- // TODO: remove me
28
27
  const name = component.name.startsWith('X') ? component.name.slice(1) : component.name
29
28
 
30
- app.component(`${options.prefix}${name}`, component)
29
+ if (!app.component(`${options.prefix}${name}`)) app.component(`${options.prefix}${name}`, component)
31
30
  })
32
31
 
33
32
  app.provide(injectColorsKey, options.colors)
package/src/version.ts CHANGED
@@ -1 +1 @@
1
- export default '1.0.10'
1
+ export default '1.2.0'
package/volar.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- declare module '@vue/runtime-core' {
1
+ declare module 'vue' {
2
2
  export interface GlobalComponents {
3
3
  XAlert: typeof import('@indielayer/ui')['XAlert']
4
4
  XAvatar: typeof import('@indielayer/ui')['XAvatar']