revotech-ui-kit 0.0.0 → 0.0.2-beta

Sign up to get free protection for your applications and to get access to all the features.
Files changed (307) hide show
  1. package/.github/workflows/deploy-storybook.yml +107 -0
  2. package/.storybook/main.ts +3 -3
  3. package/assume_role.sh +18 -0
  4. package/dist/183c6c38.js +1 -0
  5. package/dist/f28fd4b1.js +1 -0
  6. package/dist/index.ts +1 -0
  7. package/dist/public/globals.css +2215 -0
  8. package/dist/public/tailwind-lib.css +115 -0
  9. package/dist/src/assets/icons/arrows.icon.js +20 -0
  10. package/dist/src/assets/icons/arrows.icon.js.map +1 -0
  11. package/dist/src/assets/icons/index.js +4 -0
  12. package/dist/src/assets/icons/index.js.map +1 -0
  13. package/dist/src/assets/icons/search.icon.js +19 -0
  14. package/dist/src/assets/icons/search.icon.js.map +1 -0
  15. package/dist/src/assets/icons/tick.icon.js +20 -0
  16. package/dist/src/assets/icons/tick.icon.js.map +1 -0
  17. package/dist/src/components/atoms/alert/alert-description.js +18 -0
  18. package/dist/src/components/atoms/alert/alert-description.js.map +1 -0
  19. package/dist/src/components/atoms/alert/alert-title.js +20 -0
  20. package/dist/src/components/atoms/alert/alert-title.js.map +1 -0
  21. package/dist/src/components/atoms/alert/alert.atom.js +55 -0
  22. package/dist/src/components/atoms/alert/alert.atom.js.map +1 -0
  23. package/dist/src/components/atoms/alert/alert.stories.js +62 -0
  24. package/dist/src/components/atoms/alert/alert.stories.js.map +1 -0
  25. package/dist/src/components/atoms/alert/alert.styles.js +21 -0
  26. package/dist/src/components/atoms/alert/alert.styles.js.map +1 -0
  27. package/dist/src/components/atoms/alert/alert.types.js +2 -0
  28. package/dist/src/components/atoms/alert/alert.types.js.map +1 -0
  29. package/dist/src/components/atoms/badge/badge.atom.js +43 -0
  30. package/dist/src/components/atoms/badge/badge.atom.js.map +1 -0
  31. package/dist/src/components/atoms/badge/badge.stories.js +110 -0
  32. package/dist/src/components/atoms/badge/badge.stories.js.map +1 -0
  33. package/dist/src/components/atoms/badge/badge.style.js +17 -0
  34. package/dist/src/components/atoms/badge/badge.style.js.map +1 -0
  35. package/dist/src/components/atoms/badge/badge.type.js +2 -0
  36. package/dist/src/components/atoms/badge/badge.type.js.map +1 -0
  37. package/dist/src/components/atoms/button/button.atom.js +67 -0
  38. package/dist/src/components/atoms/button/button.atom.js.map +1 -0
  39. package/dist/src/components/atoms/button/button.stories.js +204 -0
  40. package/dist/src/components/atoms/button/button.stories.js.map +1 -0
  41. package/dist/src/components/atoms/button/button.style.js +24 -0
  42. package/dist/src/components/atoms/button/button.style.js.map +1 -0
  43. package/dist/src/components/atoms/button/button.type.js +2 -0
  44. package/dist/src/components/atoms/button/button.type.js.map +1 -0
  45. package/dist/src/components/atoms/card/card-content.js +17 -0
  46. package/dist/src/components/atoms/card/card-content.js.map +1 -0
  47. package/dist/src/components/atoms/card/card-description.js +17 -0
  48. package/dist/src/components/atoms/card/card-description.js.map +1 -0
  49. package/dist/src/components/atoms/card/card-footer.js +17 -0
  50. package/dist/src/components/atoms/card/card-footer.js.map +1 -0
  51. package/dist/src/components/atoms/card/card-header.js +17 -0
  52. package/dist/src/components/atoms/card/card-header.js.map +1 -0
  53. package/dist/src/components/atoms/card/card-title.js +17 -0
  54. package/dist/src/components/atoms/card/card-title.js.map +1 -0
  55. package/dist/src/components/atoms/card/card.atom.js +25 -0
  56. package/dist/src/components/atoms/card/card.atom.js.map +1 -0
  57. package/dist/src/components/atoms/card/card.stories.js +136 -0
  58. package/dist/src/components/atoms/card/card.stories.js.map +1 -0
  59. package/dist/src/components/atoms/checkbox/checkbox.atom.js +87 -0
  60. package/dist/src/components/atoms/checkbox/checkbox.atom.js.map +1 -0
  61. package/dist/src/components/atoms/checkbox/checkbox.stories.js +244 -0
  62. package/dist/src/components/atoms/checkbox/checkbox.stories.js.map +1 -0
  63. package/dist/src/components/atoms/checkbox/checkbox.style.js +3 -0
  64. package/dist/src/components/atoms/checkbox/checkbox.style.js.map +1 -0
  65. package/dist/src/components/atoms/checkbox/checkbox.type.js +2 -0
  66. package/dist/src/components/atoms/checkbox/checkbox.type.js.map +1 -0
  67. package/dist/src/components/atoms/combo-box/combo-box-input.js +47 -0
  68. package/dist/src/components/atoms/combo-box/combo-box-input.js.map +1 -0
  69. package/dist/src/components/atoms/combo-box/combo-box-item.js +85 -0
  70. package/dist/src/components/atoms/combo-box/combo-box-item.js.map +1 -0
  71. package/dist/src/components/atoms/combo-box/combo-box-list.js +67 -0
  72. package/dist/src/components/atoms/combo-box/combo-box-list.js.map +1 -0
  73. package/dist/src/components/atoms/combo-box/combo-box.atom.js +199 -0
  74. package/dist/src/components/atoms/combo-box/combo-box.atom.js.map +1 -0
  75. package/dist/src/components/atoms/combo-box/combo-box.stories.js +86 -0
  76. package/dist/src/components/atoms/combo-box/combo-box.stories.js.map +1 -0
  77. package/dist/src/components/atoms/command-empty/command-empty.atom.js +54 -0
  78. package/dist/src/components/atoms/command-empty/command-empty.atom.js.map +1 -0
  79. package/dist/src/components/atoms/command-group/command-group.atom.js +71 -0
  80. package/dist/src/components/atoms/command-group/command-group.atom.js.map +1 -0
  81. package/dist/src/components/atoms/command-item/command-item.atom.js +80 -0
  82. package/dist/src/components/atoms/command-item/command-item.atom.js.map +1 -0
  83. package/dist/src/components/atoms/command-list/command-list.atom.js +36 -0
  84. package/dist/src/components/atoms/command-list/command-list.atom.js.map +1 -0
  85. package/dist/src/components/atoms/command-separator/command-separator.atom.js +52 -0
  86. package/dist/src/components/atoms/command-separator/command-separator.atom.js.map +1 -0
  87. package/dist/src/components/atoms/dialog/dialog-close.js +47 -0
  88. package/dist/src/components/atoms/dialog/dialog-close.js.map +1 -0
  89. package/dist/src/components/atoms/dialog/dialog-content.js +72 -0
  90. package/dist/src/components/atoms/dialog/dialog-content.js.map +1 -0
  91. package/dist/src/components/atoms/dialog/dialog-footer.js +22 -0
  92. package/dist/src/components/atoms/dialog/dialog-footer.js.map +1 -0
  93. package/dist/src/components/atoms/dialog/dialog-header.js +40 -0
  94. package/dist/src/components/atoms/dialog/dialog-header.js.map +1 -0
  95. package/dist/src/components/atoms/dialog/dialog-overly.js +20 -0
  96. package/dist/src/components/atoms/dialog/dialog-overly.js.map +1 -0
  97. package/dist/src/components/atoms/dialog/dialog-trigger.js +54 -0
  98. package/dist/src/components/atoms/dialog/dialog-trigger.js.map +1 -0
  99. package/dist/src/components/atoms/dialog/dialog.atom.js +79 -0
  100. package/dist/src/components/atoms/dialog/dialog.atom.js.map +1 -0
  101. package/dist/src/components/atoms/dialog/dialog.stories.js +88 -0
  102. package/dist/src/components/atoms/dialog/dialog.stories.js.map +1 -0
  103. package/dist/src/components/atoms/dropdownMenu/dropdown-menu-checkbox-Item.js +117 -0
  104. package/dist/src/components/atoms/dropdownMenu/dropdown-menu-checkbox-Item.js.map +1 -0
  105. package/dist/src/components/atoms/dropdownMenu/dropdown-menu-content.js +81 -0
  106. package/dist/src/components/atoms/dropdownMenu/dropdown-menu-content.js.map +1 -0
  107. package/dist/src/components/atoms/dropdownMenu/dropdown-menu-group.js +71 -0
  108. package/dist/src/components/atoms/dropdownMenu/dropdown-menu-group.js.map +1 -0
  109. package/dist/src/components/atoms/dropdownMenu/dropdown-menu-item.js +80 -0
  110. package/dist/src/components/atoms/dropdownMenu/dropdown-menu-item.js.map +1 -0
  111. package/dist/src/components/atoms/dropdownMenu/dropdown-menu-radio-item.js +118 -0
  112. package/dist/src/components/atoms/dropdownMenu/dropdown-menu-radio-item.js.map +1 -0
  113. package/dist/src/components/atoms/dropdownMenu/dropdown-menu-seperator.js +52 -0
  114. package/dist/src/components/atoms/dropdownMenu/dropdown-menu-seperator.js.map +1 -0
  115. package/dist/src/components/atoms/dropdownMenu/dropdown-menu-shortcut.js +20 -0
  116. package/dist/src/components/atoms/dropdownMenu/dropdown-menu-shortcut.js.map +1 -0
  117. package/dist/src/components/atoms/dropdownMenu/dropdown-menu.atom.js +79 -0
  118. package/dist/src/components/atoms/dropdownMenu/dropdown-menu.atom.js.map +1 -0
  119. package/dist/src/components/atoms/dropdownMenu/dropdownMenu.stories.js +211 -0
  120. package/dist/src/components/atoms/dropdownMenu/dropdownMenu.stories.js.map +1 -0
  121. package/dist/src/components/atoms/dropdownMenu/dropdownMenu.style.js +4 -0
  122. package/dist/src/components/atoms/dropdownMenu/dropdownMenu.style.js.map +1 -0
  123. package/dist/src/components/atoms/index.js +14 -0
  124. package/dist/src/components/atoms/index.js.map +1 -0
  125. package/dist/src/components/atoms/input/input.atom.js +93 -0
  126. package/dist/src/components/atoms/input/input.atom.js.map +1 -0
  127. package/dist/src/components/atoms/input/input.stories.js +382 -0
  128. package/dist/src/components/atoms/input/input.stories.js.map +1 -0
  129. package/dist/src/components/atoms/input/input.styles.js +2 -0
  130. package/dist/src/components/atoms/input/input.styles.js.map +1 -0
  131. package/dist/src/components/atoms/input/input.type.js +2 -0
  132. package/dist/src/components/atoms/input/input.type.js.map +1 -0
  133. package/dist/src/components/atoms/label/label.atom.js +68 -0
  134. package/dist/src/components/atoms/label/label.atom.js.map +1 -0
  135. package/dist/src/components/atoms/label/label.stories.js +85 -0
  136. package/dist/src/components/atoms/label/label.stories.js.map +1 -0
  137. package/dist/src/components/atoms/label/label.style.js +3 -0
  138. package/dist/src/components/atoms/label/label.style.js.map +1 -0
  139. package/dist/src/components/atoms/popover/popover-content.js +64 -0
  140. package/dist/src/components/atoms/popover/popover-content.js.map +1 -0
  141. package/dist/src/components/atoms/popover/popover-trigger.js +51 -0
  142. package/dist/src/components/atoms/popover/popover-trigger.js.map +1 -0
  143. package/dist/src/components/atoms/popover/popover.atom.js +40 -0
  144. package/dist/src/components/atoms/popover/popover.atom.js.map +1 -0
  145. package/dist/src/components/atoms/popover/popover.stories.js +69 -0
  146. package/dist/src/components/atoms/popover/popover.stories.js.map +1 -0
  147. package/dist/src/components/atoms/popover/popover.style.js +21 -0
  148. package/dist/src/components/atoms/popover/popover.style.js.map +1 -0
  149. package/dist/src/components/atoms/popover/popover.types.js +4 -0
  150. package/dist/src/components/atoms/popover/popover.types.js.map +1 -0
  151. package/dist/src/components/atoms/toggle/defs.js +30 -0
  152. package/dist/src/components/atoms/toggle/defs.js.map +1 -0
  153. package/dist/src/components/atoms/toggle/toggle.atom.js +72 -0
  154. package/dist/src/components/atoms/toggle/toggle.atom.js.map +1 -0
  155. package/dist/src/components/atoms/toggle/toggle.stories.js +189 -0
  156. package/dist/src/components/atoms/toggle/toggle.stories.js.map +1 -0
  157. package/dist/src/components/atoms/toggle/toggle.style.js +19 -0
  158. package/dist/src/components/atoms/toggle/toggle.style.js.map +1 -0
  159. package/dist/src/components/command/command.js +410 -0
  160. package/dist/src/components/command/command.js.map +1 -0
  161. package/dist/src/components/command/command.stories.js +153 -0
  162. package/dist/src/components/command/command.stories.js.map +1 -0
  163. package/dist/src/components/index.js +3 -0
  164. package/dist/src/components/index.js.map +1 -0
  165. package/dist/src/components/molecules/command/command.molecules.js +27 -0
  166. package/dist/src/components/molecules/command/command.molecules.js.map +1 -0
  167. package/dist/src/components/molecules/command-input/command-input.atom.js +127 -0
  168. package/dist/src/components/molecules/command-input/command-input.atom.js.map +1 -0
  169. package/dist/src/components/molecules/dropdownMenu/dropdownMenu.molecules.js +2 -0
  170. package/dist/src/components/molecules/dropdownMenu/dropdownMenu.molecules.js.map +1 -0
  171. package/dist/src/components/molecules/index.js +2 -0
  172. package/dist/src/components/molecules/index.js.map +1 -0
  173. package/dist/src/helpers/base-element.js +64 -0
  174. package/dist/src/helpers/base-element.js.map +1 -0
  175. package/dist/src/helpers/index.js +4 -0
  176. package/dist/src/helpers/index.js.map +1 -0
  177. package/dist/src/helpers/mouse-conroller.helper.js +33 -0
  178. package/dist/src/helpers/mouse-conroller.helper.js.map +1 -0
  179. package/dist/src/helpers/style.helpers.js +6 -0
  180. package/dist/src/helpers/style.helpers.js.map +1 -0
  181. package/dist/src/index.js +2 -0
  182. package/dist/src/index.js.map +1 -0
  183. package/dist/src/interfaces/actionable.interface.js +2 -0
  184. package/dist/src/interfaces/actionable.interface.js.map +1 -0
  185. package/dist/src/interfaces/atomic.interface.js +2 -0
  186. package/dist/src/interfaces/atomic.interface.js.map +1 -0
  187. package/dist/src/interfaces/changeable.interface.js +2 -0
  188. package/dist/src/interfaces/changeable.interface.js.map +1 -0
  189. package/dist/src/interfaces/child-support-atomic.interface.js +2 -0
  190. package/dist/src/interfaces/child-support-atomic.interface.js.map +1 -0
  191. package/dist/src/interfaces/index.js +7 -0
  192. package/dist/src/interfaces/index.js.map +1 -0
  193. package/dist/src/interfaces/intractable.interface.js +2 -0
  194. package/dist/src/interfaces/intractable.interface.js.map +1 -0
  195. package/dist/src/interfaces/variant.interface.js +2 -0
  196. package/dist/src/interfaces/variant.interface.js.map +1 -0
  197. package/dist/src/lib/index.js +2 -0
  198. package/dist/src/lib/index.js.map +1 -0
  199. package/dist/src/lib/next/next.lib.js +2 -0
  200. package/dist/src/lib/next/next.lib.js.map +1 -0
  201. package/dist/src/lib/react/react.lib.js +16 -0
  202. package/dist/src/lib/react/react.lib.js.map +1 -0
  203. package/dist/src/lib/tw-styles.js +1956 -0
  204. package/dist/src/lib/tw-styles.js.map +1 -0
  205. package/dist/src/styles/index.js +2 -0
  206. package/dist/src/styles/index.js.map +1 -0
  207. package/dist/src/styles/tw.styles.js +2218 -0
  208. package/dist/src/styles/tw.styles.js.map +1 -0
  209. package/dist/src/wc-ui-app.js +88 -0
  210. package/dist/src/wc-ui-app.js.map +1 -0
  211. package/dist/sw.js +2 -0
  212. package/dist/sw.js.map +1 -0
  213. package/dist/test/wc-ui-app.test.js +18 -0
  214. package/dist/test/wc-ui-app.test.js.map +1 -0
  215. package/dist/tsconfig.tsbuildinfo +1 -0
  216. package/dist/workbox-a523fd56.js +2 -0
  217. package/dist/workbox-a523fd56.js.map +1 -0
  218. package/index.html +18 -66
  219. package/package.json +41 -18
  220. package/rollup.config.js +25 -13
  221. package/src/assets/icons/arrows.icon.ts +20 -0
  222. package/src/assets/icons/index.ts +3 -0
  223. package/src/assets/icons/search.icon.ts +19 -0
  224. package/src/assets/icons/tick.icon.ts +20 -0
  225. package/src/chai-custom.d.ts +0 -0
  226. package/src/components/atoms/alert/alert-description.ts +15 -0
  227. package/src/components/atoms/alert/alert-title.ts +17 -0
  228. package/src/components/atoms/alert/alert.atom.ts +51 -0
  229. package/src/components/atoms/alert/alert.stories.ts +71 -0
  230. package/src/components/atoms/alert/alert.styles.ts +21 -0
  231. package/src/components/atoms/alert/alert.types.ts +1 -0
  232. package/src/components/atoms/badge/badge.atom.ts +40 -0
  233. package/src/components/atoms/badge/badge.stories.ts +118 -0
  234. package/src/components/atoms/badge/badge.style.ts +24 -0
  235. package/src/components/atoms/badge/badge.type.ts +7 -0
  236. package/src/components/atoms/button/button.atom.ts +22 -8
  237. package/src/components/atoms/button/button.stories.ts +177 -139
  238. package/src/components/atoms/card/card-content.ts +15 -0
  239. package/src/components/atoms/card/card-description.ts +15 -0
  240. package/src/components/atoms/card/card-footer.ts +15 -0
  241. package/src/components/atoms/card/card-header.ts +15 -0
  242. package/src/components/atoms/card/card-title.ts +15 -0
  243. package/src/components/atoms/card/card.atom.ts +31 -0
  244. package/src/components/atoms/card/card.stories.ts +149 -0
  245. package/src/components/atoms/checkbox/checkbox.atom.ts +30 -16
  246. package/src/components/atoms/checkbox/checkbox.stories.ts +292 -25
  247. package/src/components/atoms/checkbox/checkbox.style.ts +5 -0
  248. package/src/components/atoms/checkbox/checkbox.type.ts +24 -0
  249. package/src/components/atoms/combo-box/combo-box-input.ts +33 -0
  250. package/src/components/atoms/combo-box/combo-box-item.ts +59 -0
  251. package/src/components/atoms/combo-box/combo-box-list.ts +57 -0
  252. package/src/components/atoms/combo-box/combo-box.atom.ts +187 -0
  253. package/src/components/atoms/combo-box/combo-box.stories.ts +95 -0
  254. package/src/components/atoms/command-empty/command-empty.atom.ts +2 -2
  255. package/src/components/atoms/command-group/command-group.atom.ts +1 -1
  256. package/src/components/atoms/command-item/command-item.atom.ts +2 -2
  257. package/src/components/atoms/command-list/command-list.atom.ts +2 -2
  258. package/src/components/atoms/command-separator/command-separator.atom.ts +2 -2
  259. package/src/components/atoms/dialog/dialog-close.ts +50 -0
  260. package/src/components/atoms/dialog/dialog-content.ts +71 -0
  261. package/src/components/atoms/dialog/dialog-footer.ts +22 -0
  262. package/src/components/atoms/dialog/dialog-header.ts +36 -0
  263. package/src/components/atoms/dialog/dialog-overly.ts +20 -0
  264. package/src/components/atoms/dialog/dialog-trigger.ts +54 -0
  265. package/src/components/atoms/dialog/dialog.atom.ts +3 -226
  266. package/src/components/atoms/dialog/dialog.stories.ts +11 -4
  267. package/src/components/atoms/dropdownMenu/dropdown-menu-checkbox-Item.ts +106 -0
  268. package/src/components/atoms/dropdownMenu/dropdown-menu-content.ts +79 -0
  269. package/src/components/atoms/dropdownMenu/dropdown-menu-group.ts +60 -0
  270. package/src/components/atoms/dropdownMenu/dropdown-menu-item.ts +74 -0
  271. package/src/components/atoms/dropdownMenu/dropdown-menu-radio-item.ts +107 -0
  272. package/src/components/atoms/dropdownMenu/dropdown-menu-seperator.ts +44 -0
  273. package/src/components/atoms/dropdownMenu/dropdown-menu-shortcut.ts +17 -0
  274. package/src/components/atoms/dropdownMenu/dropdown-menu.atom.ts +84 -0
  275. package/src/components/atoms/dropdownMenu/dropdownMenu.stories.ts +220 -0
  276. package/src/components/atoms/dropdownMenu/dropdownMenu.style.ts +7 -0
  277. package/src/components/atoms/index.ts +3 -0
  278. package/src/components/atoms/input/input.atom.ts +64 -10
  279. package/src/components/atoms/input/input.stories.ts +426 -64
  280. package/src/components/atoms/input/input.styles.ts +2 -0
  281. package/src/components/atoms/input/input.type.ts +42 -8
  282. package/src/components/atoms/label/label.atom.ts +31 -7
  283. package/src/components/atoms/label/label.stories.ts +87 -3
  284. package/src/components/atoms/popover/popover-content.ts +58 -0
  285. package/src/components/atoms/popover/popover-trigger.ts +50 -0
  286. package/src/components/atoms/popover/popover.atom.ts +34 -0
  287. package/src/components/atoms/popover/popover.stories.ts +79 -0
  288. package/src/components/atoms/popover/popover.style.ts +25 -0
  289. package/src/components/atoms/popover/popover.types.ts +3 -0
  290. package/src/components/atoms/toggle/defs.ts +29 -0
  291. package/src/components/atoms/toggle/toggle.atom.ts +58 -0
  292. package/src/components/atoms/toggle/toggle.stories.ts +204 -0
  293. package/src/components/atoms/toggle/toggle.style.ts +22 -0
  294. package/src/components/molecules/command/command.molecules.ts +2 -2
  295. package/src/components/molecules/command-input/command-input.atom.ts +3 -3
  296. package/src/components/molecules/dropdownMenu/dropdownMenu.molecules.ts +0 -0
  297. package/src/globals.css +475 -66
  298. package/src/helpers/base-element.ts +79 -0
  299. package/src/helpers/index.ts +1 -0
  300. package/src/index.ts +0 -0
  301. package/src/lib/react/react.lib.ts +18 -0
  302. package/src/lib/tw-styles.ts +1957 -0
  303. package/src/styles/tw.styles.ts +2051 -1699
  304. package/src/tailwind-lib.css +26 -6
  305. package/tailwind.config.js +174 -38
  306. package/tsconfig.json +6 -1
  307. package/src/components/popover.ts +0 -247
@@ -1,29 +1,41 @@
1
1
  import { LitElement, html, css } from 'lit';
2
- import { property, customElement } from 'lit/decorators.js';
3
- import { cn } from '@/helpers';
2
+ import { customElement, property } from 'lit/decorators.js';
3
+ import { cn, BaseElement } from '../../../helpers';
4
4
  import { ButtonSize, ButtonType, ButtonVariant } from './button.type';
5
5
  import { buttonStyle } from './button.style';
6
- import { TWStyles } from '@/styles';
6
+ import { TWStyles } from '../../../styles';
7
+ import { spread } from '@open-wc/lit-helpers';
7
8
 
8
9
  @customElement('rtg-button')
9
- export class Button extends LitElement {
10
+ export class Button extends BaseElement {
10
11
  static buttonVariants = buttonStyle;
11
12
 
13
+ @property({ type: Function }) click = () => {};
12
14
  @property({ type: Boolean }) disabled = false;
13
-
14
15
  @property({ type: String }) type: ButtonType = 'button';
15
-
16
16
  @property({ type: String }) variant: ButtonVariant = 'default';
17
-
18
17
  @property({ type: String }) size: ButtonSize = 'default';
19
18
 
20
19
  static styles = [css``, TWStyles];
21
20
 
21
+ private handleClick(e: MouseEvent) {
22
+ e.stopPropagation();
23
+ if (!this.disabled) {
24
+ this.click();
25
+ }
26
+ }
27
+
28
+ protected getAttributesToExclude(): string[] {
29
+ return ['click', 'disabled', 'type', 'variant', 'size', 'data-testid'];
30
+ }
31
+
22
32
  render() {
33
+ const attributes = this.getFilteredAttributes();
34
+
23
35
  return html`
24
36
  <button
25
37
  type="${this.type}"
26
- ?disabled=${this.disabled}
38
+ ?disabled="${this.disabled}"
27
39
  class="${cn(
28
40
  Button.buttonVariants({
29
41
  variant: this.variant,
@@ -31,6 +43,8 @@ export class Button extends LitElement {
31
43
  className: this.className,
32
44
  })
33
45
  )}"
46
+ @click="${this.handleClick}"
47
+ ${spread(attributes)}
34
48
  >
35
49
  <slot></slot>
36
50
  </button>
@@ -1,7 +1,8 @@
1
1
  import type { Meta, StoryObj } from '@storybook/web-components';
2
- import { action } from '@storybook/addon-actions';
3
2
  import { html } from 'lit';
4
3
  import './button.atom';
4
+ import { expect, within, fn, waitFor, userEvent } from '@storybook/test';
5
+ import { Button } from './button.atom';
5
6
 
6
7
  const meta: Meta = {
7
8
  component: 'components/button',
@@ -19,168 +20,205 @@ const meta: Meta = {
19
20
  'ghost',
20
21
  'link',
21
22
  ],
23
+ defaultValue: 'default',
24
+ description: 'Choose the visual style of the button.',
25
+ table: {
26
+ defaultValue: { summary: 'default' },
27
+ },
22
28
  },
23
29
  size: {
24
30
  control: {
25
31
  type: 'select',
26
32
  },
27
33
  options: ['default', 'sm', 'lg', 'icon'],
34
+ description: 'Choose the visual style of the button.',
35
+ defaultValue: 'default',
36
+ table: {
37
+ defaultValue: { summary: 'default' },
38
+ },
39
+ },
40
+ disabled: {
41
+ control: 'boolean',
42
+ description: 'Disable the button to prevent interactions.',
43
+ table: {
44
+ defaultValue: { summary: 'false' },
45
+ },
46
+ },
47
+ label: {
48
+ control: 'text',
49
+ description:
50
+ 'The text displayed on the button. Can also be a function returning the label dynamically.',
51
+ type: 'string',
52
+ table: {
53
+ defaultValue: { summary: 'Button' },
54
+ },
55
+ },
56
+ icon: {
57
+ control: 'boolean',
58
+ description: 'Add an icon before the button text.',
59
+ table: {
60
+ defaultValue: { summary: 'false' },
61
+ },
62
+ },
63
+ animation: {
64
+ control: 'boolean',
65
+ description: 'Enable/disable icon animations.',
66
+ table: {
67
+ defaultValue: { summary: 'false' },
68
+ },
69
+ if: { arg: 'icon', neq: false },
70
+ },
71
+ click: {
72
+ action: '',
73
+ description:
74
+ 'Triggered when the button is clicked. Receives the button instance as an argument.',
75
+ table: {
76
+ type: { summary: '(() => void)' },
77
+ defaultValue: { summary: '-' },
78
+ },
28
79
  },
29
- disabled: { control: 'boolean' },
30
- onClick: { action: 'button-click' },
31
80
  },
32
81
  };
33
- export default meta;
34
- type Story = StoryObj;
35
82
 
36
- const logger = () => {
37
- console.log('Btn Clicked!');
38
- };
83
+ const testButtonBehavior = async (
84
+ args: any,
85
+ canvasElement: any,
86
+ mockHandler: any
87
+ ) => {
88
+ const canvas = within(canvasElement);
89
+ const button = await waitFor(() => canvas.getByTestId('btn-id'));
39
90
 
40
- export const Default: Story = {
41
- args: {
42
- label: 'Default',
43
- variant: 'default',
44
- size: 'lg',
45
- disabled: false,
46
- },
91
+ if (button.shadowRoot) {
92
+ const innerButton = button.shadowRoot.querySelector(
93
+ '[data-testchild="children-id"]'
94
+ );
47
95
 
48
- render: ({ label, variant, size, disabled }) =>
49
- html`<rtg-button
50
- .onClick=${action('button-click')}
51
- variant=${variant}
52
- size=${size}
53
- ?disabled=${disabled}
54
- >
55
- ${label}</rtg-button
56
- >`,
57
- };
96
+ // 1. Test: Button should have correct type attribute
97
+ expect(innerButton).toHaveAttribute('type', 'button');
58
98
 
59
- export const Primary: Story = {
60
- args: {
61
- label: 'Primary',
62
- variant: 'default',
63
- size: 'lg',
64
- disabled: false,
65
- },
66
- render: ({ label, variant, size, disabled }) =>
67
- html`<rtg-button
68
- .onClick=${logger}
69
- variant=${variant}
70
- size=${size}
71
- ?disabled=${disabled}
72
- >${label}</rtg-button
73
- > `,
74
- };
99
+ // 2. Test: Button should handle click events when not disabled
100
+ if (!args.disabled && innerButton) {
101
+ await userEvent.click(innerButton);
102
+ if (mockHandler) {
103
+ expect(mockHandler).toHaveBeenCalled();
104
+ }
105
+ }
75
106
 
76
- export const Destructive: Story = {
77
- args: {
78
- label: 'Destructive',
79
- variant: 'destructive',
80
- size: 'lg',
81
- disabled: false,
82
- },
83
- render: ({ label, variant, size, disabled }) =>
84
- html`<rtg-button
85
- .onClick=${logger}
86
- variant=${variant}
87
- size=${size}
88
- ?disabled=${disabled}
89
- >${label}</rtg-button
90
- > `,
91
- };
107
+ // 3. Test: Button should not handle click events when disabled
108
+ if (args.disabled) {
109
+ expect(mockHandler).not.toHaveBeenCalled();
110
+ }
92
111
 
93
- export const Outline: Story = {
94
- args: {
95
- label: 'Outline',
96
- variant: 'outline',
97
- size: 'lg',
98
- disabled: false,
99
- },
100
- render: ({ label, variant, size, disabled }) =>
101
- html`<rtg-button
102
- .onClick=${logger}
103
- variant=${variant}
104
- size=${size}
105
- ?disabled=${disabled}
106
- >${label}</rtg-button
107
- > `,
108
- };
112
+ // 4. Test: Button should be disabled when the `disabled` prop is true
113
+ if (args.disabled) {
114
+ expect(innerButton).toBeDisabled();
115
+ } else {
116
+ expect(innerButton).not.toBeDisabled();
117
+ }
109
118
 
110
- export const Ghost: Story = {
111
- args: {
112
- variant: 'ghost',
113
- label: 'Ghost',
114
- size: 'lg',
115
- disabled: false,
116
- },
117
- render: ({ label, variant, size, disabled }) =>
118
- html`<rtg-button
119
- .onClick=${logger}
120
- variant=${variant}
121
- size=${size}
122
- ?disabled=${disabled}
123
- >${label}</rtg-button
124
- > `,
125
- };
119
+ // 5. Test: Button should apply the correct variant classes
120
+ const expectedClasses = Button.buttonVariants({
121
+ variant: args.variant,
122
+ size: args.size,
123
+ className: '',
124
+ });
125
+ expect(innerButton).toHaveClass(expectedClasses);
126
126
 
127
- export const Link: Story = {
128
- args: {
129
- variant: 'link',
130
- label: 'Link',
131
- size: 'lg',
132
- disabled: false,
133
- },
134
- render: ({ label, variant, size, disabled }) =>
135
- html`<rtg-button
136
- .onClick=${logger}
137
- variant=${variant}
138
- size=${size}
139
- ?disabled=${disabled}
140
- >${label}</rtg-button
141
- > `,
127
+ // 6. Test: Button should apply the correct size classes
128
+ const expectedSizeClasses = Button.buttonVariants({
129
+ variant: args.variant,
130
+ size: args.size,
131
+ className: '',
132
+ });
133
+ expect(innerButton).toHaveClass(expectedSizeClasses);
134
+ }
142
135
  };
143
136
 
144
- export const IconButton: Story = {
145
- args: {
146
- variant: 'outline',
147
- size: 'icon',
148
- disabled: false,
149
- },
150
- render: ({ variant, size }) =>
151
- html`<rtg-button .onClick=${logger} variant=${variant} size=${size}>
152
- <iconify-icon icon="mdi:home"></iconify-icon>
153
- </rtg-button> `,
154
- };
137
+ export default meta;
138
+ type Story = StoryObj;
139
+
140
+ const mockOnClickHandler = fn(event => {
141
+ console.log('Mock onClick handler called');
142
+ });
155
143
 
156
- export const ButtonWithIcon: Story = {
144
+ export const Buttons: Story = {
157
145
  args: {
158
- label: 'Home Page',
146
+ label: 'Button',
159
147
  variant: 'default',
160
148
  size: 'default',
161
149
  disabled: false,
150
+ icon: false,
151
+ animation: false,
162
152
  },
163
- render: ({ variant, label, size, disabled }) =>
164
- html`
165
- <rtg-button varian=${variant} ?disabled=${disabled} size=${size}
166
- ><iconify-icon class="mr-2" icon="mdi:home"></iconify-icon>
167
- ${label}</rtg-button
168
- >
169
- `,
170
- };
171
-
172
- export const animationButton: Story = {
173
- args: {
174
- label: 'Home Page',
175
- variant: 'default',
176
- size: 'default',
177
- disabled: true,
153
+ render: ({ label, variant, size, disabled, icon, animation }) => {
154
+ console.log('disabled', disabled);
155
+ if (disabled == true)
156
+ return html`
157
+ <rtg-button
158
+ method="post"
159
+ .click=${mockOnClickHandler}
160
+ data-testid="btn-id"
161
+ data-testchild="children-id"
162
+ variant=${variant}
163
+ size=${size}
164
+ disabled=${true}
165
+ >
166
+ ${icon
167
+ ? html`<iconify-icon
168
+ class=${animation
169
+ ? `${label ? 'mr-2 ' : ' '}animate-spin`
170
+ : `${label ? 'mr-2 ' : ''}`}
171
+ icon="mdi:home"
172
+ ></iconify-icon>`
173
+ : ''}
174
+ ${label}</rtg-button
175
+ >
176
+ `;
177
+ else if (disabled == false)
178
+ return html`
179
+ <rtg-button
180
+ method="post"
181
+ .click=${mockOnClickHandler}
182
+ data-testid="btn-id"
183
+ data-testchild="children-id"
184
+ variant=${variant}
185
+ size=${size}
186
+ ?disabled=${false}
187
+ >
188
+ ${icon
189
+ ? html`<iconify-icon
190
+ class=${animation
191
+ ? `${label ? 'mr-2 ' : ' '}animate-spin`
192
+ : `${label ? 'mr-2 ' : ''}`}
193
+ icon="mdi:home"
194
+ ></iconify-icon>`
195
+ : ''}
196
+ ${label}</rtg-button
197
+ >
198
+ `;
199
+ else
200
+ return html`
201
+ <rtg-button
202
+ method="post"
203
+ .click=${mockOnClickHandler}
204
+ data-testid="btn-id"
205
+ data-testchild="children-id"
206
+ variant=${variant}
207
+ size=${size}
208
+ >
209
+ ${icon
210
+ ? html`<iconify-icon
211
+ class=${animation
212
+ ? `${label ? 'mr-2 ' : ' '}animate-spin`
213
+ : `${label ? 'mr-2 ' : ''}`}
214
+ icon="mdi:home"
215
+ ></iconify-icon>`
216
+ : ''}
217
+ ${label}</rtg-button
218
+ >
219
+ `;
220
+ },
221
+ play: async ({ args, canvasElement }) => {
222
+ await testButtonBehavior(args, canvasElement, mockOnClickHandler);
178
223
  },
179
- render: ({ variant, label, size, disabled }) =>
180
- html`
181
- <rtg-button varian=${variant} ?disabled=${disabled} size=${size}
182
- ><iconify-icon class="mr-2 animate-spin" icon="mdi:home"></iconify-icon>
183
- ${label}</rtg-button
184
- >
185
- `,
186
224
  };
@@ -0,0 +1,15 @@
1
+ import { css, html, LitElement } from 'lit';
2
+ import { customElement } from 'lit/decorators.js';
3
+ import { TWStyles } from '../../../styles';
4
+
5
+ @customElement('rtg-card-content')
6
+ export class CardContent extends LitElement {
7
+ static styles = [css``, TWStyles];
8
+
9
+
10
+ render() {
11
+ return html`
12
+ <slot></slot>
13
+ `;
14
+ }
15
+ }
@@ -0,0 +1,15 @@
1
+ import { css, html, LitElement } from 'lit';
2
+ import { customElement } from 'lit/decorators.js';
3
+ import { TWStyles } from '../../../styles';
4
+
5
+ @customElement('rtg-card-description')
6
+ export class CardDescription extends LitElement {
7
+ static styles = [css``, TWStyles];
8
+
9
+
10
+ render() {
11
+ return html`
12
+ <slot></slot>
13
+ `;
14
+ }
15
+ }
@@ -0,0 +1,15 @@
1
+ import { css, html, LitElement } from 'lit';
2
+ import { customElement } from 'lit/decorators.js';
3
+ import { TWStyles } from '../../../styles';
4
+
5
+ @customElement('rtg-card-footer')
6
+ export class CardFooter extends LitElement {
7
+ static styles = [css``, TWStyles];
8
+
9
+
10
+ render() {
11
+ return html`
12
+ <slot></slot>
13
+ `;
14
+ }
15
+ }
@@ -0,0 +1,15 @@
1
+ import { css, html, LitElement } from 'lit';
2
+ import { customElement } from 'lit/decorators.js';
3
+ import { TWStyles } from '../../../styles';
4
+
5
+ @customElement('rtg-card-header')
6
+ export class CardHeader extends LitElement {
7
+ static styles = [css``, TWStyles];
8
+
9
+
10
+ render() {
11
+ return html`
12
+ <slot></slot>
13
+ `;
14
+ }
15
+ }
@@ -0,0 +1,15 @@
1
+ import { css, html, LitElement } from 'lit';
2
+ import { customElement } from 'lit/decorators.js';
3
+ import { TWStyles } from '../../../styles';
4
+
5
+ @customElement('rtg-card-title')
6
+ export class CardTitle extends LitElement {
7
+ static styles = [css``, TWStyles];
8
+
9
+
10
+ render() {
11
+ return html`
12
+ <slot></slot>
13
+ `;
14
+ }
15
+ }
@@ -0,0 +1,31 @@
1
+ import { css, html, LitElement } from 'lit';
2
+ import { customElement } from 'lit/decorators.js';
3
+ import { CardTitle } from './card-title';
4
+ import { CardHeader } from './card-header';
5
+ import { CardFooter } from './card-footer';
6
+ import { CardDescription } from './card-description';
7
+ import { CardContent } from './card-content';
8
+ import { TWStyles } from '../../../styles';
9
+
10
+ @customElement('rtg-card')
11
+ class Card extends LitElement {
12
+ static styles = [css``, TWStyles];
13
+
14
+ render() {
15
+ return html`<div
16
+ class="rounded-lg border bg-card text-card-foreground shadow-sm p-6"
17
+ id="rtg-card-id"
18
+ >
19
+ <slot></slot>
20
+ </div>`;
21
+ }
22
+ }
23
+
24
+ export {
25
+ Card,
26
+ CardTitle,
27
+ CardHeader,
28
+ CardFooter,
29
+ CardDescription,
30
+ CardContent,
31
+ };
@@ -0,0 +1,149 @@
1
+ import { html } from 'lit';
2
+ import type { Meta, StoryFn, StoryObj } from '@storybook/web-components';
3
+ import { expect, within, fn, waitFor, userEvent } from '@storybook/test';
4
+ import './card.atom';
5
+
6
+ export default {
7
+ component: 'components/card',
8
+ tags: ['autodocs'],
9
+ } as Meta;
10
+
11
+ type Story = StoryObj;
12
+
13
+ const testCardBehavior = async (args: any, canvasElement: HTMLElement) => {
14
+ const canvas = within(canvasElement);
15
+ const card = await waitFor(() => canvas.getByTestId('card-id'));
16
+ const cardHeader = await waitFor(() => canvas.getByTestId('card-header-id'));
17
+ const cardTitle = await waitFor(() => canvas.getByTestId('card-title-id'));
18
+ const cardDescription = await waitFor(() =>
19
+ canvas.getByTestId('card-description-id')
20
+ );
21
+ const cardContent = await waitFor(() =>
22
+ canvas.getByTestId('card-content-id')
23
+ );
24
+ const cardFooter = await waitFor(() => canvas.getByTestId('card-footer-id'));
25
+ expect(card).toBeVisible();
26
+ expect(cardHeader).toBeVisible();
27
+ expect(cardTitle).toBeVisible();
28
+ expect(cardDescription).toBeVisible();
29
+ expect(cardContent).toBeVisible();
30
+ expect(cardFooter).toBeVisible();
31
+
32
+ if (card.shadowRoot) {
33
+ const cardItem = await card.shadowRoot.getElementById('rtg-card-id');
34
+ expect(cardItem).toHaveClass(
35
+ 'rounded-lg border bg-card text-card-foreground shadow-sm p-6'
36
+ );
37
+ }
38
+ if (cardTitle) {
39
+ expect(cardTitle.textContent).toContain('Create project');
40
+ expect(cardTitle.tagName.toLowerCase()).toEqual('cardtitle');
41
+ }
42
+ if (cardDescription) {
43
+ expect(cardDescription.textContent).toContain(
44
+ 'Deploy your new project in one-click.'
45
+ );
46
+ expect(cardDescription.tagName.toLowerCase()).toEqual('carddescription');
47
+ }
48
+ };
49
+
50
+ export const Cards: Story = {
51
+ name: 'Cards',
52
+ render: () => html`
53
+ <rtg-card data-testid="card-id">
54
+ <CardHeader data-testid="card-header-id">
55
+ <CardTitle data-testid="card-title-id">
56
+ <h3>Create project</h3>
57
+ </CardTitle>
58
+ <CardDescription data-testid="card-description-id">
59
+ <p class="text-sm text-muted-foreground">
60
+ Deploy your new project in one-click.
61
+ </p>
62
+ </CardDescription>
63
+ </CardHeader>
64
+ <CardContent data-testid="card-content-id">
65
+ <form class="pt-4">
66
+ <div class="grid w-full items-center gap-4">
67
+ <div class="flex flex-col space-y-1.5">
68
+ <label
69
+ class="text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70"
70
+ for="name"
71
+ >Name</label
72
+ ><input
73
+ class="flex h-10 w-full rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background file:border-0 file:bg-transparent file:text-sm file:font-medium file:text-foreground placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50"
74
+ id="name"
75
+ placeholder="Name of your project"
76
+ />
77
+ </div>
78
+ <div class="flex flex-col space-y-1.5">
79
+ <label
80
+ class="text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70"
81
+ for="framework"
82
+ >Framework</label
83
+ ><button
84
+ type="button"
85
+ role="combobox"
86
+ aria-controls="radix-:r2b:"
87
+ aria-expanded="false"
88
+ aria-autocomplete="none"
89
+ dir="ltr"
90
+ data-state="closed"
91
+ data-placeholder=""
92
+ class="flex h-10 w-full items-center justify-between rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background placeholder:text-muted-foreground focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 [&amp;>span]:line-clamp-1"
93
+ id="framework"
94
+ >
95
+ <span style="pointer-events: none;">Select</span
96
+ ><svg
97
+ xmlns="http://www.w3.org/2000/svg"
98
+ width="24"
99
+ height="24"
100
+ viewBox="0 0 24 24"
101
+ fill="none"
102
+ stroke="currentColor"
103
+ stroke-width="2"
104
+ stroke-linecap="round"
105
+ stroke-linejoin="round"
106
+ class="lucide lucide-chevron-down h-4 w-4 opacity-50"
107
+ aria-hidden="true"
108
+ >
109
+ <path d="m6 9 6 6 6-6"></path>
110
+ </svg></button
111
+ ><select
112
+ aria-hidden="true"
113
+ tabindex="-1"
114
+ style="position: absolute; border: 0px; width: 1px; height: 1px; padding: 0px; margin: -1px; overflow: hidden; clip: rect(0px, 0px, 0px, 0px); white-space: nowrap; overflow-wrap: normal;"
115
+ >
116
+ <option value=""></option>
117
+ <option value="next">Next.js</option>
118
+ <option value="sveltekit">SvelteKit</option>
119
+ <option value="astro">Astro</option>
120
+ <option value="nuxt">Nuxt.js</option>
121
+ </select>
122
+ </div>
123
+ </div>
124
+ </form>
125
+ </CardContent>
126
+ <CardFooter data-testid="card-footer-id">
127
+ <div class="items-center pt-4 flex justify-between">
128
+ <button
129
+ class="inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 border border-input bg-background hover:bg-accent hover:text-accent-foreground h-10 px-4 py-2"
130
+ >
131
+ Cancel
132
+ </button>
133
+ <button
134
+ class="inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 bg-primary text-primary-foreground hover:bg-primary/90 h-10 px-4 py-2"
135
+ >
136
+ Deploy
137
+ </button>
138
+ </div>
139
+ </CardFooter>
140
+ </rtg-card>
141
+ `,
142
+ play: async ({ args, canvasElement }) => {
143
+ try {
144
+ await testCardBehavior(args, canvasElement);
145
+ } catch (error) {
146
+ console.error('An error occurred during the play function:', error);
147
+ }
148
+ },
149
+ };