@seeqdev/qomponents 0.0.156 → 0.0.158

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 (438) hide show
  1. package/README.md +135 -135
  2. package/dist/Accordion/Accordion.js +7 -0
  3. package/dist/Accordion/Accordion.js.map +1 -0
  4. package/dist/Accordion/Accordion.stories.js +75 -0
  5. package/dist/Accordion/Accordion.stories.js.map +1 -0
  6. package/dist/Accordion/Accordion.test.js +55 -0
  7. package/dist/Accordion/Accordion.test.js.map +1 -0
  8. package/dist/Accordion/Accordion.types.js +2 -0
  9. package/dist/Accordion/Accordion.types.js.map +1 -0
  10. package/dist/Accordion/index.js +2 -0
  11. package/dist/Accordion/index.js.map +1 -0
  12. package/dist/Alert/Alert.js +32 -0
  13. package/dist/Alert/Alert.js.map +1 -0
  14. package/dist/Alert/Alert.stories.js +57 -0
  15. package/dist/Alert/Alert.stories.js.map +1 -0
  16. package/dist/Alert/Alert.test.js +50 -0
  17. package/dist/Alert/Alert.test.js.map +1 -0
  18. package/dist/Alert/Alert.types.js +2 -0
  19. package/dist/Alert/Alert.types.js.map +1 -0
  20. package/dist/Alert/index.js +2 -0
  21. package/dist/Alert/index.js.map +1 -0
  22. package/dist/Button/Button.js +89 -0
  23. package/dist/Button/Button.js.map +1 -0
  24. package/dist/Button/Button.stories.js +25 -0
  25. package/dist/Button/Button.stories.js.map +1 -0
  26. package/dist/Button/Button.test.js +47 -0
  27. package/dist/Button/Button.test.js.map +1 -0
  28. package/dist/Button/Button.types.js +5 -0
  29. package/dist/Button/Button.types.js.map +1 -0
  30. package/dist/Button/index.js +2 -0
  31. package/dist/Button/index.js.map +1 -0
  32. package/dist/ButtonGroup/ButtonGroup.js +35 -0
  33. package/dist/ButtonGroup/ButtonGroup.js.map +1 -0
  34. package/dist/ButtonGroup/ButtonGroup.stories.js +317 -0
  35. package/dist/ButtonGroup/ButtonGroup.stories.js.map +1 -0
  36. package/dist/ButtonGroup/ButtonGroup.test.js +66 -0
  37. package/dist/ButtonGroup/ButtonGroup.test.js.map +1 -0
  38. package/dist/ButtonGroup/ButtonGroup.types.js +2 -0
  39. package/dist/ButtonGroup/ButtonGroup.types.js.map +1 -0
  40. package/dist/ButtonGroup/index.js +2 -0
  41. package/dist/ButtonGroup/index.js.map +1 -0
  42. package/dist/ButtonWithDropdown/ButtonWithDropdown.js +36 -0
  43. package/dist/ButtonWithDropdown/ButtonWithDropdown.js.map +1 -0
  44. package/dist/ButtonWithDropdown/ButtonWithDropdown.stories.js +104 -0
  45. package/dist/ButtonWithDropdown/ButtonWithDropdown.stories.js.map +1 -0
  46. package/dist/ButtonWithDropdown/ButtonWithDropdown.test.js +93 -0
  47. package/dist/ButtonWithDropdown/ButtonWithDropdown.test.js.map +1 -0
  48. package/dist/ButtonWithDropdown/ButtonWithDropdown.types.js +2 -0
  49. package/dist/ButtonWithDropdown/ButtonWithDropdown.types.js.map +1 -0
  50. package/dist/ButtonWithDropdown/index.js +2 -0
  51. package/dist/ButtonWithDropdown/index.js.map +1 -0
  52. package/dist/ButtonWithPopover/ButtonWithPopover.js +55 -0
  53. package/dist/ButtonWithPopover/ButtonWithPopover.js.map +1 -0
  54. package/dist/ButtonWithPopover/ButtonWithPopover.stories.js +25 -0
  55. package/dist/ButtonWithPopover/ButtonWithPopover.stories.js.map +1 -0
  56. package/dist/ButtonWithPopover/ButtonWithPopover.test.js +81 -0
  57. package/dist/ButtonWithPopover/ButtonWithPopover.test.js.map +1 -0
  58. package/dist/ButtonWithPopover/ButtonWithPopover.types.js +2 -0
  59. package/dist/ButtonWithPopover/ButtonWithPopover.types.js.map +1 -0
  60. package/dist/ButtonWithPopover/index.js +2 -0
  61. package/dist/ButtonWithPopover/index.js.map +1 -0
  62. package/dist/Carousel/Carousel.js +75 -0
  63. package/dist/Carousel/Carousel.js.map +1 -0
  64. package/dist/Carousel/Carousel.stories.js +63 -0
  65. package/dist/Carousel/Carousel.stories.js.map +1 -0
  66. package/dist/Carousel/Carousel.test.js +48 -0
  67. package/dist/Carousel/Carousel.test.js.map +1 -0
  68. package/dist/Carousel/Carousel.types.js +2 -0
  69. package/dist/Carousel/Carousel.types.js.map +1 -0
  70. package/dist/Carousel/index.js +2 -0
  71. package/dist/Carousel/index.js.map +1 -0
  72. package/dist/Checkbox/Checkbox.js +24 -0
  73. package/dist/Checkbox/Checkbox.js.map +1 -0
  74. package/dist/Checkbox/Checkbox.stories.js +12 -0
  75. package/dist/Checkbox/Checkbox.stories.js.map +1 -0
  76. package/dist/Checkbox/Checkbox.test.js +94 -0
  77. package/dist/Checkbox/Checkbox.test.js.map +1 -0
  78. package/dist/Checkbox/Checkbox.types.js +2 -0
  79. package/dist/Checkbox/Checkbox.types.js.map +1 -0
  80. package/dist/Checkbox/index.js +2 -0
  81. package/dist/Checkbox/index.js.map +1 -0
  82. package/dist/Collapse/Collapse.js +17 -0
  83. package/dist/Collapse/Collapse.js.map +1 -0
  84. package/dist/Collapse/Collapse.stories.js +15 -0
  85. package/dist/Collapse/Collapse.stories.js.map +1 -0
  86. package/dist/Collapse/Collapse.test.js +17 -0
  87. package/dist/Collapse/Collapse.test.js.map +1 -0
  88. package/dist/Collapse/Collapse.types.js +2 -0
  89. package/dist/Collapse/Collapse.types.js.map +1 -0
  90. package/dist/Collapse/index.js +2 -0
  91. package/dist/Collapse/index.js.map +1 -0
  92. package/dist/Icon/Icon.js +55 -0
  93. package/dist/Icon/Icon.js.map +1 -0
  94. package/dist/Icon/Icon.stories.js +15 -0
  95. package/dist/Icon/Icon.stories.js.map +1 -0
  96. package/dist/Icon/Icon.test.js +55 -0
  97. package/dist/Icon/Icon.test.js.map +1 -0
  98. package/dist/Icon/Icon.types.js +16 -0
  99. package/dist/Icon/Icon.types.js.map +1 -0
  100. package/dist/Icon/index.js +2 -0
  101. package/dist/Icon/index.js.map +1 -0
  102. package/dist/InputGroup/InputGroup.js +34 -0
  103. package/dist/InputGroup/InputGroup.js.map +1 -0
  104. package/dist/InputGroup/InputGroup.stories.js +129 -0
  105. package/dist/InputGroup/InputGroup.stories.js.map +1 -0
  106. package/dist/InputGroup/InputGroup.test.js +42 -0
  107. package/dist/InputGroup/InputGroup.test.js.map +1 -0
  108. package/dist/InputGroup/InputGroup.types.js +2 -0
  109. package/dist/InputGroup/InputGroup.types.js.map +1 -0
  110. package/dist/InputGroup/index.js +2 -0
  111. package/dist/InputGroup/index.js.map +1 -0
  112. package/dist/Modal/Modal.js +76 -0
  113. package/dist/Modal/Modal.js.map +1 -0
  114. package/dist/Modal/Modal.stories.js +44 -0
  115. package/dist/Modal/Modal.stories.js.map +1 -0
  116. package/dist/Modal/Modal.test.js +108 -0
  117. package/dist/Modal/Modal.test.js.map +1 -0
  118. package/dist/Modal/Modal.types.js +2 -0
  119. package/dist/Modal/Modal.types.js.map +1 -0
  120. package/dist/Modal/index.js +2 -0
  121. package/dist/Modal/index.js.map +1 -0
  122. package/dist/ProgressBar/ProgressBar.js +72 -0
  123. package/dist/ProgressBar/ProgressBar.js.map +1 -0
  124. package/dist/ProgressBar/ProgressBar.stories.js +35 -0
  125. package/dist/ProgressBar/ProgressBar.stories.js.map +1 -0
  126. package/dist/ProgressBar/ProgressBar.test.js +43 -0
  127. package/dist/ProgressBar/ProgressBar.test.js.map +1 -0
  128. package/dist/ProgressBar/ProgressBar.types.js +2 -0
  129. package/dist/ProgressBar/ProgressBar.types.js.map +1 -0
  130. package/dist/ProgressBar/index.js +2 -0
  131. package/dist/ProgressBar/index.js.map +1 -0
  132. package/dist/SeeqActionDropdown/SeeqActionDropdown.js +39 -0
  133. package/dist/SeeqActionDropdown/SeeqActionDropdown.js.map +1 -0
  134. package/dist/SeeqActionDropdown/SeeqActionDropdown.stories.js +56 -0
  135. package/dist/SeeqActionDropdown/SeeqActionDropdown.stories.js.map +1 -0
  136. package/dist/SeeqActionDropdown/SeeqActionDropdown.test.js +73 -0
  137. package/dist/SeeqActionDropdown/SeeqActionDropdown.test.js.map +1 -0
  138. package/dist/SeeqActionDropdown/SeeqActionDropdown.types.js +2 -0
  139. package/dist/SeeqActionDropdown/SeeqActionDropdown.types.js.map +1 -0
  140. package/dist/SeeqActionDropdown/index.js +2 -0
  141. package/dist/SeeqActionDropdown/index.js.map +1 -0
  142. package/dist/SeeqActionDropdown/variants.js +29 -0
  143. package/dist/SeeqActionDropdown/variants.js.map +1 -0
  144. package/dist/Select/Select.js +177 -0
  145. package/dist/Select/Select.js.map +1 -0
  146. package/dist/Select/Select.stories.js +40 -0
  147. package/dist/Select/Select.stories.js.map +1 -0
  148. package/dist/Select/Select.test.js +175 -0
  149. package/dist/Select/Select.test.js.map +1 -0
  150. package/dist/Select/Select.types.js +2 -0
  151. package/dist/Select/Select.types.js.map +1 -0
  152. package/dist/Select/index.js +3 -0
  153. package/dist/Select/index.js.map +1 -0
  154. package/dist/Slider/Slider.js +10 -0
  155. package/dist/Slider/Slider.js.map +1 -0
  156. package/dist/Slider/Slider.stories.js +14 -0
  157. package/dist/Slider/Slider.stories.js.map +1 -0
  158. package/dist/Slider/Slider.test.js +32 -0
  159. package/dist/Slider/Slider.test.js.map +1 -0
  160. package/dist/Slider/Slider.types.js +2 -0
  161. package/dist/Slider/Slider.types.js.map +1 -0
  162. package/dist/Slider/index.js +2 -0
  163. package/dist/Slider/index.js.map +1 -0
  164. package/dist/SvgIcon/SvgIcon.js +28 -0
  165. package/dist/SvgIcon/SvgIcon.js.map +1 -0
  166. package/dist/SvgIcon/SvgIcon.stories.js +18 -0
  167. package/dist/SvgIcon/SvgIcon.stories.js.map +1 -0
  168. package/dist/SvgIcon/SvgIcon.test.js +41 -0
  169. package/dist/SvgIcon/SvgIcon.test.js.map +1 -0
  170. package/dist/SvgIcon/SvgIcon.types.js +6 -0
  171. package/dist/SvgIcon/SvgIcon.types.js.map +1 -0
  172. package/dist/SvgIcon/index.js +2 -0
  173. package/dist/SvgIcon/index.js.map +1 -0
  174. package/dist/Tabs/Tabs.js +17 -0
  175. package/dist/Tabs/Tabs.js.map +1 -0
  176. package/dist/Tabs/Tabs.stories.js +73 -0
  177. package/dist/Tabs/Tabs.stories.js.map +1 -0
  178. package/dist/Tabs/Tabs.test.js +86 -0
  179. package/dist/Tabs/Tabs.test.js.map +1 -0
  180. package/dist/Tabs/Tabs.types.js +2 -0
  181. package/dist/Tabs/Tabs.types.js.map +1 -0
  182. package/dist/Tabs/index.js +2 -0
  183. package/dist/Tabs/index.js.map +1 -0
  184. package/dist/TextArea/TextArea.js +25 -0
  185. package/dist/TextArea/TextArea.js.map +1 -0
  186. package/dist/TextArea/TextArea.stories.js +10 -0
  187. package/dist/TextArea/TextArea.stories.js.map +1 -0
  188. package/dist/TextArea/TextArea.test.js +68 -0
  189. package/dist/TextArea/TextArea.test.js.map +1 -0
  190. package/dist/TextArea/TextArea.types.js +2 -0
  191. package/dist/TextArea/TextArea.types.js.map +1 -0
  192. package/dist/TextArea/index.js +2 -0
  193. package/dist/TextArea/index.js.map +1 -0
  194. package/dist/TextField/TextField.js +85 -0
  195. package/dist/TextField/TextField.js.map +1 -0
  196. package/dist/TextField/TextField.stories.js +11 -0
  197. package/dist/TextField/TextField.stories.js.map +1 -0
  198. package/dist/TextField/TextField.test.js +41 -0
  199. package/dist/TextField/TextField.test.js.map +1 -0
  200. package/dist/TextField/TextField.types.js +2 -0
  201. package/dist/TextField/TextField.types.js.map +1 -0
  202. package/dist/TextField/index.js +2 -0
  203. package/dist/TextField/index.js.map +1 -0
  204. package/dist/ToolbarButton/ToolbarButton.js +57 -0
  205. package/dist/ToolbarButton/ToolbarButton.js.map +1 -0
  206. package/dist/ToolbarButton/ToolbarButton.stories.js +28 -0
  207. package/dist/ToolbarButton/ToolbarButton.stories.js.map +1 -0
  208. package/dist/ToolbarButton/ToolbarButton.test.js +85 -0
  209. package/dist/ToolbarButton/ToolbarButton.test.js.map +1 -0
  210. package/dist/ToolbarButton/ToolbarButton.types.js +2 -0
  211. package/dist/ToolbarButton/ToolbarButton.types.js.map +1 -0
  212. package/dist/ToolbarButton/index.js +2 -0
  213. package/dist/ToolbarButton/index.js.map +1 -0
  214. package/dist/Tooltip/QTip.stories.js +18 -0
  215. package/dist/Tooltip/QTip.stories.js.map +1 -0
  216. package/dist/Tooltip/QTip.types.js +2 -0
  217. package/dist/Tooltip/QTip.types.js.map +1 -0
  218. package/dist/Tooltip/QTipPerformance.stories.js +26 -0
  219. package/dist/Tooltip/QTipPerformance.stories.js.map +1 -0
  220. package/dist/Tooltip/Qtip.js +168 -0
  221. package/dist/Tooltip/Qtip.js.map +1 -0
  222. package/dist/Tooltip/Tooltip.js +34 -0
  223. package/dist/Tooltip/Tooltip.js.map +1 -0
  224. package/dist/Tooltip/Tooltip.stories.js +15 -0
  225. package/dist/Tooltip/Tooltip.stories.js.map +1 -0
  226. package/dist/Tooltip/Tooltip.types.js +3 -0
  227. package/dist/Tooltip/Tooltip.types.js.map +1 -0
  228. package/dist/Tooltip/TooltipPerformance.stories.js +26 -0
  229. package/dist/Tooltip/TooltipPerformance.stories.js.map +1 -0
  230. package/dist/Tooltip/index.js +3 -0
  231. package/dist/Tooltip/index.js.map +1 -0
  232. package/dist/Tooltip/qTip.utilities.js +11 -0
  233. package/dist/Tooltip/qTip.utilities.js.map +1 -0
  234. package/dist/example/.eslintrc.cjs +14 -14
  235. package/dist/example/README.md +33 -33
  236. package/dist/example/index.html +13 -13
  237. package/dist/example/package.json +32 -30
  238. package/dist/example/src/ComplexSelectExample.tsx +81 -81
  239. package/dist/example/src/Example.tsx +638 -408
  240. package/dist/example/src/index.css +103 -102
  241. package/dist/example/src/main.tsx +10 -10
  242. package/dist/example/src/vite-env.d.ts +1 -1
  243. package/dist/example/tsconfig.json +33 -33
  244. package/dist/example/tsconfig.node.json +12 -12
  245. package/dist/example/vite.config.ts +13 -12
  246. package/dist/index.esm.js +18318 -11863
  247. package/dist/index.esm.js.map +1 -1
  248. package/dist/index.js +18312 -11857
  249. package/dist/index.js.map +1 -1
  250. package/dist/setupTests.d.ts +1 -0
  251. package/dist/setupTests.js +6 -0
  252. package/dist/setupTests.js.map +1 -0
  253. package/dist/{Accordion → src/Accordion}/Accordion.d.ts +4 -4
  254. package/dist/src/Accordion/Accordion.stories.d.ts +5 -0
  255. package/dist/{Accordion → src/Accordion}/Accordion.test.d.ts +1 -1
  256. package/dist/src/Accordion/Accordion.types.d.ts +86 -0
  257. package/dist/{Accordion → src/Accordion}/index.d.ts +1 -1
  258. package/dist/{Alert → src/Alert}/Alert.d.ts +7 -7
  259. package/dist/src/Alert/Alert.stories.d.ts +5 -0
  260. package/dist/src/Alert/Alert.test.d.ts +1 -0
  261. package/dist/src/Alert/Alert.types.d.ts +63 -0
  262. package/dist/{Alert → src/Alert}/index.d.ts +1 -1
  263. package/dist/{Button → src/Button}/Button.d.ts +10 -10
  264. package/dist/src/Button/Button.stories.d.ts +8 -0
  265. package/dist/{Button → src/Button}/Button.test.d.ts +1 -1
  266. package/dist/src/Button/Button.types.d.ts +148 -0
  267. package/dist/{Button → src/Button}/index.d.ts +1 -1
  268. package/dist/{ButtonGroup → src/ButtonGroup}/ButtonGroup.d.ts +7 -7
  269. package/dist/src/ButtonGroup/ButtonGroup.stories.d.ts +5 -0
  270. package/dist/src/ButtonGroup/ButtonGroup.test.d.ts +1 -0
  271. package/dist/src/ButtonGroup/ButtonGroup.types.d.ts +81 -0
  272. package/dist/{ButtonGroup → src/ButtonGroup}/index.d.ts +1 -1
  273. package/dist/{ButtonWithDropdown → src/ButtonWithDropdown}/ButtonWithDropdown.d.ts +4 -4
  274. package/dist/src/ButtonWithDropdown/ButtonWithDropdown.stories.d.ts +5 -0
  275. package/dist/{ButtonWithDropdown → src/ButtonWithDropdown}/ButtonWithDropdown.test.d.ts +1 -1
  276. package/dist/src/ButtonWithDropdown/ButtonWithDropdown.types.d.ts +233 -0
  277. package/dist/{ButtonWithDropdown → src/ButtonWithDropdown}/index.d.ts +1 -1
  278. package/dist/{ButtonWithPopover → src/ButtonWithPopover}/ButtonWithPopover.d.ts +4 -4
  279. package/dist/src/ButtonWithPopover/ButtonWithPopover.stories.d.ts +5 -0
  280. package/dist/{ButtonWithPopover → src/ButtonWithPopover}/ButtonWithPopover.test.d.ts +1 -1
  281. package/dist/src/ButtonWithPopover/ButtonWithPopover.types.d.ts +134 -0
  282. package/dist/{ButtonWithPopover → src/ButtonWithPopover}/index.d.ts +1 -1
  283. package/dist/{Carousel → src/Carousel}/Carousel.d.ts +9 -9
  284. package/dist/src/Carousel/Carousel.stories.d.ts +5 -0
  285. package/dist/{Carousel → src/Carousel}/Carousel.test.d.ts +1 -1
  286. package/dist/src/Carousel/Carousel.types.d.ts +86 -0
  287. package/dist/{Carousel → src/Carousel}/index.d.ts +1 -1
  288. package/dist/{Checkbox → src/Checkbox}/Checkbox.d.ts +7 -7
  289. package/dist/src/Checkbox/Checkbox.stories.d.ts +5 -0
  290. package/dist/{Checkbox → src/Checkbox}/Checkbox.test.d.ts +1 -1
  291. package/dist/src/Checkbox/Checkbox.types.d.ts +92 -0
  292. package/dist/{Checkbox → src/Checkbox}/index.d.ts +1 -1
  293. package/dist/{Collapse → src/Collapse}/Collapse.d.ts +4 -4
  294. package/dist/src/Collapse/Collapse.stories.d.ts +5 -0
  295. package/dist/{Collapse → src/Collapse}/Collapse.test.d.ts +1 -1
  296. package/dist/src/Collapse/Collapse.types.d.ts +19 -0
  297. package/dist/{Collapse → src/Collapse}/index.d.ts +1 -1
  298. package/dist/{Icon → src/Icon}/Icon.d.ts +10 -10
  299. package/dist/src/Icon/Icon.stories.d.ts +5 -0
  300. package/dist/{Icon → src/Icon}/Icon.test.d.ts +1 -1
  301. package/dist/src/Icon/Icon.types.d.ts +87 -0
  302. package/dist/{Icon → src/Icon}/index.d.ts +1 -1
  303. package/dist/{InputGroup → src/InputGroup}/InputGroup.d.ts +7 -7
  304. package/dist/src/InputGroup/InputGroup.stories.d.ts +5 -0
  305. package/dist/src/InputGroup/InputGroup.test.d.ts +1 -0
  306. package/dist/src/InputGroup/InputGroup.types.d.ts +62 -0
  307. package/dist/{InputGroup → src/InputGroup}/index.d.ts +2 -2
  308. package/dist/{Modal → src/Modal}/Modal.d.ts +5 -5
  309. package/dist/{Modal → src/Modal}/Modal.stories.d.ts +10 -10
  310. package/dist/{Modal → src/Modal}/Modal.test.d.ts +1 -1
  311. package/dist/src/Modal/Modal.types.d.ts +244 -0
  312. package/dist/{Modal → src/Modal}/index.d.ts +1 -1
  313. package/dist/{ProgressBar → src/ProgressBar}/ProgressBar.d.ts +4 -4
  314. package/dist/src/ProgressBar/ProgressBar.stories.d.ts +5 -0
  315. package/dist/src/ProgressBar/ProgressBar.test.d.ts +1 -0
  316. package/dist/src/ProgressBar/ProgressBar.types.d.ts +77 -0
  317. package/dist/src/ProgressBar/index.d.ts +1 -0
  318. package/dist/{SeeqActionDropdown → src/SeeqActionDropdown}/SeeqActionDropdown.d.ts +4 -4
  319. package/dist/src/SeeqActionDropdown/SeeqActionDropdown.stories.d.ts +5 -0
  320. package/dist/{SeeqActionDropdown → src/SeeqActionDropdown}/SeeqActionDropdown.test.d.ts +1 -1
  321. package/dist/src/SeeqActionDropdown/SeeqActionDropdown.types.d.ts +160 -0
  322. package/dist/{SeeqActionDropdown → src/SeeqActionDropdown}/index.d.ts +1 -1
  323. package/dist/{SeeqActionDropdown → src/SeeqActionDropdown}/variants.d.ts +5 -5
  324. package/dist/{Select → src/Select}/Select.d.ts +15 -15
  325. package/dist/src/Select/Select.stories.d.ts +5 -0
  326. package/dist/{Select → src/Select}/Select.test.d.ts +1 -1
  327. package/dist/src/Select/Select.types.d.ts +220 -0
  328. package/dist/{Select → src/Select}/index.d.ts +2 -2
  329. package/dist/{Slider → src/Slider}/Slider.d.ts +6 -6
  330. package/dist/src/Slider/Slider.stories.d.ts +5 -0
  331. package/dist/src/Slider/Slider.test.d.ts +1 -0
  332. package/dist/src/Slider/Slider.types.d.ts +85 -0
  333. package/dist/{Slider → src/Slider}/index.d.ts +1 -1
  334. package/dist/{SvgIcon → src/SvgIcon}/SvgIcon.d.ts +20 -20
  335. package/dist/src/SvgIcon/SvgIcon.stories.d.ts +5 -0
  336. package/dist/{SvgIcon → src/SvgIcon}/SvgIcon.test.d.ts +1 -1
  337. package/dist/src/SvgIcon/SvgIcon.types.d.ts +76 -0
  338. package/dist/{SvgIcon → src/SvgIcon}/index.d.ts +1 -1
  339. package/dist/{Tabs → src/Tabs}/Tabs.d.ts +4 -4
  340. package/dist/src/Tabs/Tabs.stories.d.ts +5 -0
  341. package/dist/{Tabs → src/Tabs}/Tabs.test.d.ts +1 -1
  342. package/dist/src/Tabs/Tabs.types.d.ts +95 -0
  343. package/dist/{Tabs → src/Tabs}/index.d.ts +1 -1
  344. package/dist/{TextArea → src/TextArea}/TextArea.d.ts +7 -7
  345. package/dist/src/TextArea/TextArea.stories.d.ts +5 -0
  346. package/dist/{TextArea → src/TextArea}/TextArea.test.d.ts +1 -1
  347. package/dist/src/TextArea/TextArea.types.d.ts +105 -0
  348. package/dist/{TextArea → src/TextArea}/index.d.ts +1 -1
  349. package/dist/{TextField → src/TextField}/TextField.d.ts +7 -7
  350. package/dist/src/TextField/TextField.stories.d.ts +5 -0
  351. package/dist/{TextField → src/TextField}/TextField.test.d.ts +1 -1
  352. package/dist/src/TextField/TextField.types.d.ts +199 -0
  353. package/dist/{TextField → src/TextField}/index.d.ts +1 -1
  354. package/dist/{ToolbarButton → src/ToolbarButton}/ToolbarButton.d.ts +3 -3
  355. package/dist/src/ToolbarButton/ToolbarButton.stories.d.ts +5 -0
  356. package/dist/{ToolbarButton → src/ToolbarButton}/ToolbarButton.test.d.ts +1 -1
  357. package/dist/src/ToolbarButton/ToolbarButton.types.d.ts +124 -0
  358. package/dist/{ToolbarButton → src/ToolbarButton}/index.d.ts +1 -1
  359. package/dist/src/Tooltip/QTip.stories.d.ts +5 -0
  360. package/dist/{Tooltip → src/Tooltip}/QTip.types.d.ts +13 -13
  361. package/dist/src/Tooltip/QTipPerformance.stories.d.ts +5 -0
  362. package/dist/{Tooltip → src/Tooltip}/Qtip.d.ts +26 -26
  363. package/dist/{Tooltip → src/Tooltip}/Tooltip.d.ts +13 -13
  364. package/dist/src/Tooltip/Tooltip.stories.d.ts +5 -0
  365. package/dist/{Tooltip → src/Tooltip}/Tooltip.types.d.ts +22 -21
  366. package/dist/src/Tooltip/TooltipPerformance.stories.d.ts +5 -0
  367. package/dist/{Tooltip → src/Tooltip}/index.d.ts +2 -2
  368. package/dist/{Tooltip → src/Tooltip}/qTip.utilities.d.ts +3 -3
  369. package/dist/{index.d.ts → src/index.d.ts} +45 -46
  370. package/dist/src/setupTests.d.ts +1 -0
  371. package/dist/{types.d.ts → src/types.d.ts} +2 -2
  372. package/dist/{utils → src/utils}/browserId.d.ts +9 -9
  373. package/dist/{utils → src/utils}/svg.d.ts +15 -15
  374. package/dist/{utils → src/utils}/validateStyleDimension.d.ts +2 -2
  375. package/dist/{utils → src/utils}/validateStyleDimension.test.d.ts +1 -1
  376. package/dist/styles.css +3855 -4011
  377. package/dist/types.js +2 -0
  378. package/dist/types.js.map +1 -0
  379. package/dist/utils/browserId.js +29 -0
  380. package/dist/utils/browserId.js.map +1 -0
  381. package/dist/utils/svg.js +20 -0
  382. package/dist/utils/svg.js.map +1 -0
  383. package/dist/utils/validateStyleDimension.js +14 -0
  384. package/dist/utils/validateStyleDimension.js.map +1 -0
  385. package/dist/utils/validateStyleDimension.test.js +20 -0
  386. package/dist/utils/validateStyleDimension.test.js.map +1 -0
  387. package/package.json +91 -88
  388. package/dist/Accordion/Accordion.stories.d.ts +0 -5
  389. package/dist/Accordion/Accordion.types.d.ts +0 -20
  390. package/dist/Alert/Alert.stories.d.ts +0 -5
  391. package/dist/Alert/Alert.test.d.ts +0 -1
  392. package/dist/Alert/Alert.types.d.ts +0 -13
  393. package/dist/Button/Button.stories.d.ts +0 -8
  394. package/dist/Button/Button.types.d.ts +0 -53
  395. package/dist/ButtonGroup/ButtonGroup.stories.d.ts +0 -5
  396. package/dist/ButtonGroup/ButtonGroup.test.d.ts +0 -1
  397. package/dist/ButtonGroup/ButtonGroup.types.d.ts +0 -39
  398. package/dist/ButtonWithDropdown/ButtonWithDropdown.stories.d.ts +0 -5
  399. package/dist/ButtonWithDropdown/ButtonWithDropdown.types.d.ts +0 -89
  400. package/dist/ButtonWithPopover/ButtonWithPopover.stories.d.ts +0 -5
  401. package/dist/ButtonWithPopover/ButtonWithPopover.types.d.ts +0 -48
  402. package/dist/Carousel/Carousel.stories.d.ts +0 -5
  403. package/dist/Carousel/Carousel.types.d.ts +0 -23
  404. package/dist/Checkbox/Checkbox.stories.d.ts +0 -5
  405. package/dist/Checkbox/Checkbox.types.d.ts +0 -19
  406. package/dist/Collapse/Collapse.stories.d.ts +0 -5
  407. package/dist/Collapse/Collapse.types.d.ts +0 -4
  408. package/dist/Icon/Icon.stories.d.ts +0 -5
  409. package/dist/Icon/Icon.types.d.ts +0 -30
  410. package/dist/InputGroup/InputGroup.stories.d.ts +0 -5
  411. package/dist/InputGroup/InputGroup.test.d.ts +0 -1
  412. package/dist/InputGroup/InputGroup.types.d.ts +0 -35
  413. package/dist/Modal/Modal.types.d.ts +0 -48
  414. package/dist/ProgressBar/ProgressBar.stories.d.ts +0 -7
  415. package/dist/ProgressBar/ProgressBar.test.d.ts +0 -1
  416. package/dist/ProgressBar/ProgressBar.types.d.ts +0 -40
  417. package/dist/ProgressBar/index.d.ts +0 -2
  418. package/dist/SeeqActionDropdown/SeeqActionDropdown.stories.d.ts +0 -5
  419. package/dist/SeeqActionDropdown/SeeqActionDropdown.types.d.ts +0 -57
  420. package/dist/Select/Select.stories.d.ts +0 -5
  421. package/dist/Select/Select.types.d.ts +0 -89
  422. package/dist/Slider/Slider.stories.d.ts +0 -5
  423. package/dist/Slider/Slider.test.d.ts +0 -1
  424. package/dist/Slider/Slider.types.d.ts +0 -16
  425. package/dist/SvgIcon/SvgIcon.stories.d.ts +0 -5
  426. package/dist/SvgIcon/SvgIcon.types.d.ts +0 -24
  427. package/dist/Tabs/Tabs.stories.d.ts +0 -5
  428. package/dist/Tabs/Tabs.types.d.ts +0 -20
  429. package/dist/TextArea/TextArea.stories.d.ts +0 -5
  430. package/dist/TextArea/TextArea.types.d.ts +0 -34
  431. package/dist/TextField/TextField.stories.d.ts +0 -5
  432. package/dist/TextField/TextField.types.d.ts +0 -39
  433. package/dist/ToolbarButton/ToolbarButton.stories.d.ts +0 -5
  434. package/dist/ToolbarButton/ToolbarButton.types.d.ts +0 -53
  435. package/dist/Tooltip/QTip.stories.d.ts +0 -5
  436. package/dist/Tooltip/QTipPerformance.stories.d.ts +0 -5
  437. package/dist/Tooltip/Tooltip.stories.d.ts +0 -5
  438. package/dist/Tooltip/TooltipPerformance.stories.d.ts +0 -5
package/README.md CHANGED
@@ -1,136 +1,136 @@
1
- <!-- markdownlint-disable-next-line -->
2
- <p align="center">
3
- <img width="150" src="https://seeq.com/sites/default/files/seeq-content/seeq-logo-blue-web-33h.svg" alt="Seeq logo">
4
- </p>
5
- <h1 align="center">qomponents</h1>
6
-
7
-
8
- Seeq qomponents are a collection of UI components, including a Button, a TextField, an Icon, as well as a Tooltip
9
- React component (more coming soon!)
10
-
11
- These components are used by Seeq's application and are made publicly available for Developers who want to expand
12
- the Seeq eco-system with their own plugins and add-ons without having to worry about creating a cohesive Seeq UX
13
- experience. Every component comes fully styled (and with dark mode support).
14
-
15
- ## Installation
16
-
17
- Seeq qomponents are available on npm.
18
-
19
- **npm:**
20
-
21
- ```sh
22
- npm install @seeqdev/qomponents
23
- ```
24
-
25
- **yarn:**
26
-
27
- ```sh
28
- yarn add @seeqdev/qomponents
29
- ```
30
-
31
- ## Getting started with Seeq qomponents
32
-
33
- Prefer a more complete example? <br/>Checkout the example folder provided.
34
- It includes a ready to run example application. Start with the readme in the example folder to get up and running!
35
-
36
- Here is an example of a basic app using the `Button` component:
37
-
38
- ```jsx
39
- import * as React from 'react';
40
- import {Button} from '@seeqdev/qomponents';
41
-
42
- function App() {
43
- return <Button variant="theme" label="Seeq Rocks" />;
44
- }
45
- ```
46
-
47
- To make sure all styles are properly applied be sure to include the qomponents css file in your main css file.
48
-
49
- ```css
50
- @import '@seeqdev/qomponents/dist/styles.css';
51
- ```
52
-
53
- <b>A note on CSS:</b> Seeq's qomponents come fully styled and ready to use. While it is tempting to use the
54
- available <i>extraClassNames</i> property to provide yet additional styling we strongly advise you to use this
55
- property to provide only width, margins and padding. This will ensure for a smooth upgrade experience when
56
- Seeq's look and feel changes.
57
- <br />
58
- <b>Tip:</b>: to indicate missing or wrong user input use the <i>showError</i> property available on TextField,
59
- TextArea, as well as Select.
60
-
61
- ## Frequently asked questions
62
-
63
- <h3>1) I use webpack and I get a strange error once I added qomponents to my package.json!</h3>
64
-
65
- Webpack needs a little help :)
66
- Add the following to the <code>rules</code> array in your <code>webpack.config</code>
67
-
68
- ```
69
- {
70
- test: /@?(seeqdev).*\.(ts|js)x?$/,
71
- loader:'babel-loader'
72
- },
73
- {
74
- test: /\.(woff|woff2|eot|ttf|otf)$/i,
75
- type: 'asset/resource',
76
- }
77
- ```
78
-
79
- If you're using webpack + scss be sure to include a <code>~</code> as part of the css import path:
80
-
81
- ```
82
- @import '~@seeqdev/qomponents/dist/styles.css';
83
- @import '~@fortawesome/fontawesome-free/css/all.css';
84
- ```
85
-
86
- <h3>2) How do I get my Button to be green?</h3>
87
-
88
- The colors of your qomponents are controlled by the "theme". </br>
89
- If you do not provide a theme your qomponents will use the default blue or also known as Topic-based theme.
90
- Themes are applied by adding the class of the desired theme to a wrapper of your application. The theme class can
91
- also be applied to the body tag.
92
-
93
- ```html
94
-
95
- <div class="color_analysis">
96
- ... your application here
97
- </div>
98
-
99
- ```
100
-
101
- There are 3 themes available:
102
-
103
- | Theme | Color | Class | Example |
104
- |:---------|:-------|:---------------|:-----------------------|
105
- | Topic | blue | color_topic | class="color_topic" |
106
- | Analysis | green | color_analysis | class="color_analysis" |
107
- | DataLab | orange | color_datalab | class="color_datalab" |
108
-
109
- <h3>3) How do I use Fontawesome Icons?</h3>
110
- Before you can use Fontawesome icons you must install FontAwesome.
111
-
112
- ```
113
- npm install --save @fortawesome/fontawesome-free
114
- ```
115
-
116
- Once it's installed simply import the required css files. To import all variations of FontAwesome's Icons you can
117
- add the following import to your main css file:
118
-
119
- ```
120
- @import "@fortawesome/fontawesome-free/css/all.css";
121
- ```
122
-
123
- If your project only uses Classic Solid or (Sharp Solids, or any other one kind) it's better to import only the
124
- required css for that Icon type to keep your packages size small.<br/> Note: if you don't import "all" like shown above
125
- be sure to include <code>fontawesome.css</code> in addition to whatever Icon style you require.
126
-
127
- For Example:
128
-
129
- ```
130
- @import "@fortawesome/fontawesome-free/css/fontawesome.css";
131
- @import "@fortawesome/fontawesome-free/css/solid.css";
132
- ```
133
-
134
- <h3>4) How can I see all the props that are available?</h3>
135
- Take a look at the <code>.types.d.ts</code> files that can be found in the <code>dist/{component name}/</code>
1
+ <!-- markdownlint-disable-next-line -->
2
+ <p align="center">
3
+ <img width="150" src="https://seeq.com/sites/default/files/seeq-content/seeq-logo-blue-web-33h.svg" alt="Seeq logo">
4
+ </p>
5
+ <h1 align="center">qomponents</h1>
6
+
7
+
8
+ Seeq qomponents are a collection of UI components, including a Button, a TextField, an Icon, as well as a Tooltip
9
+ React component (more coming soon!)
10
+
11
+ These components are used by Seeq's application and are made publicly available for Developers who want to expand
12
+ the Seeq eco-system with their own plugins and add-ons without having to worry about creating a cohesive Seeq UX
13
+ experience. Every component comes fully styled (and with dark mode support).
14
+
15
+ ## Installation
16
+
17
+ Seeq qomponents are available on npm.
18
+
19
+ **npm:**
20
+
21
+ ```sh
22
+ npm install @seeqdev/qomponents
23
+ ```
24
+
25
+ **yarn:**
26
+
27
+ ```sh
28
+ yarn add @seeqdev/qomponents
29
+ ```
30
+
31
+ ## Getting started with Seeq qomponents
32
+
33
+ Prefer a more complete example? <br/>Checkout the example folder provided.
34
+ It includes a ready to run example application. Start with the readme in the example folder to get up and running!
35
+
36
+ Here is an example of a basic app using the `Button` component:
37
+
38
+ ```jsx
39
+ import * as React from 'react';
40
+ import {Button} from '@seeqdev/qomponents';
41
+
42
+ function App() {
43
+ return <Button variant="theme" label="Seeq Rocks" />;
44
+ }
45
+ ```
46
+
47
+ To make sure all styles are properly applied be sure to include the qomponents css file in your main css file.
48
+
49
+ ```css
50
+ @import '@seeqdev/qomponents/dist/styles.css';
51
+ ```
52
+
53
+ <b>A note on CSS:</b> Seeq's qomponents come fully styled and ready to use. While it is tempting to use the
54
+ available <i>extraClassNames</i> property to provide yet additional styling we strongly advise you to use this
55
+ property to provide only width, margins and padding. This will ensure for a smooth upgrade experience when
56
+ Seeq's look and feel changes.
57
+ <br />
58
+ <b>Tip:</b>: to indicate missing or wrong user input use the <i>showError</i> property available on TextField,
59
+ TextArea, as well as Select.
60
+
61
+ ## Frequently asked questions
62
+
63
+ <h3>1) I use webpack and I get a strange error once I added qomponents to my package.json!</h3>
64
+
65
+ Webpack needs a little help :)
66
+ Add the following to the <code>rules</code> array in your <code>webpack.config</code>
67
+
68
+ ```
69
+ {
70
+ test: /@?(seeqdev).*\.(ts|js)x?$/,
71
+ loader:'babel-loader'
72
+ },
73
+ {
74
+ test: /\.(woff|woff2|eot|ttf|otf)$/i,
75
+ type: 'asset/resource',
76
+ }
77
+ ```
78
+
79
+ If you're using webpack + scss be sure to include a <code>~</code> as part of the css import path:
80
+
81
+ ```
82
+ @import '~@seeqdev/qomponents/dist/styles.css';
83
+ @import '~@fortawesome/fontawesome-free/css/all.css';
84
+ ```
85
+
86
+ <h3>2) How do I get my Button to be green?</h3>
87
+
88
+ The colors of your qomponents are controlled by the "theme". </br>
89
+ If you do not provide a theme your qomponents will use the default blue or also known as Topic-based theme.
90
+ Themes are applied by adding the class of the desired theme to a wrapper of your application. The theme class can
91
+ also be applied to the body tag.
92
+
93
+ ```html
94
+
95
+ <div class="color_analysis">
96
+ ... your application here
97
+ </div>
98
+
99
+ ```
100
+
101
+ There are 3 themes available:
102
+
103
+ | Theme | Color | Class | Example |
104
+ |:---------|:-------|:---------------|:-----------------------|
105
+ | Topic | blue | color_topic | class="color_topic" |
106
+ | Analysis | green | color_analysis | class="color_analysis" |
107
+ | DataLab | orange | color_datalab | class="color_datalab" |
108
+
109
+ <h3>3) How do I use Fontawesome Icons?</h3>
110
+ Before you can use Fontawesome icons you must install FontAwesome.
111
+
112
+ ```
113
+ npm install --save @fortawesome/fontawesome-free
114
+ ```
115
+
116
+ Once it's installed simply import the required css files. To import all variations of FontAwesome's Icons you can
117
+ add the following import to your main css file:
118
+
119
+ ```
120
+ @import "@fortawesome/fontawesome-free/css/all.css";
121
+ ```
122
+
123
+ If your project only uses Classic Solid or (Sharp Solids, or any other one kind) it's better to import only the
124
+ required css for that Icon type to keep your packages size small.<br/> Note: if you don't import "all" like shown above
125
+ be sure to include <code>fontawesome.css</code> in addition to whatever Icon style you require.
126
+
127
+ For Example:
128
+
129
+ ```
130
+ @import "@fortawesome/fontawesome-free/css/fontawesome.css";
131
+ @import "@fortawesome/fontawesome-free/css/solid.css";
132
+ ```
133
+
134
+ <h3>4) How can I see all the props that are available?</h3>
135
+ Take a look at the <code>.types.d.ts</code> files that can be found in the <code>dist/{component name}/</code>
136
136
  folder. This file contains all available properties including some descriptive text that tells you more about them.
@@ -0,0 +1,7 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Root, Item, Trigger, Content } from '@radix-ui/react-accordion';
3
+ const Accordion = ({ accordionItems, defaultValue, value, onItemSelect, disabled, extraClassNames, testId, }) => {
4
+ return (_jsx(Root, { className: `tw-rounded-md tw-w-full focus-visible:tw-outline-none ${extraClassNames || ''}`, type: "single", defaultValue: defaultValue, value: value, collapsible: true, "data-testid": testId, onValueChange: (_value) => onItemSelect(_value), children: accordionItems.map((item) => (_jsxs(Item, { className: `tw-bg-transparent tw-p-0 tw-flex tw-flex-col tw-w-full`, disabled: disabled, value: item.value, children: [_jsx(Trigger, { disabled: disabled, className: `tw-w-full tw-cursor-default focus-visible:tw-outline-none`, children: item.trigger }), _jsx(Content, { className: `data-[state=open]:tw-animate-slideDown data-[state=closed]:tw-animate-slideUp tw-overflow-hidden focus-visible:tw-outline-none ${item.contentClassNames || ''}`, children: item.content })] }, item.value))) }));
5
+ };
6
+ export default Accordion;
7
+ //# sourceMappingURL=Accordion.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Accordion.js","sourceRoot":"","sources":["../../src/Accordion/Accordion.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AAGzE,MAAM,SAAS,GAA4C,CAAC,EAC1D,cAAc,EACd,YAAY,EACZ,KAAK,EACL,YAAY,EACZ,QAAQ,EACR,eAAe,EACf,MAAM,GACP,EAAE,EAAE;IACH,OAAO,CACL,KAAC,IAAI,IACH,SAAS,EAAE,yDAAyD,eAAe,IAAI,EAAE,EAAE,EAC3F,IAAI,EAAC,QAAQ,EACb,YAAY,EAAE,YAAY,EAC1B,KAAK,EAAE,KAAK,EACZ,WAAW,uBACE,MAAM,EACnB,aAAa,EAAE,CAAC,MAAM,EAAE,EAAE,CAAC,YAAY,CAAC,MAAM,CAAC,YAC9C,cAAc,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAC5B,MAAC,IAAI,IACH,SAAS,EAAE,wDAAwD,EAEnE,QAAQ,EAAE,QAAQ,EAClB,KAAK,EAAE,IAAI,CAAC,KAAK,aACjB,KAAC,OAAO,IAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,2DAA2D,YAChG,IAAI,CAAC,OAAO,GACL,EACV,KAAC,OAAO,IACN,SAAS,EAAE,kIACT,IAAI,CAAC,iBAAiB,IAAI,EAC5B,EAAE,YACD,IAAI,CAAC,OAAO,GACL,KAXL,IAAI,CAAC,KAAK,CAYV,CACR,CAAC,GACG,CACR,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,SAAS,CAAC"}
@@ -0,0 +1,75 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import React from 'react';
3
+ import Accordion from './Accordion';
4
+ import { QTip } from '../Tooltip/Qtip';
5
+ import Icon from '../Icon';
6
+ import Tabs from '../Tabs';
7
+ import Button from '../Button';
8
+ export default {
9
+ title: 'Accordion',
10
+ };
11
+ const Trigger = ({ label }) => (_jsxs("div", { className: "tw-flex tw-justify-start tw-items-center tw-border-b tw-px-2 tw-text-sq-color-dark", children: [_jsx(Icon, { icon: "fc-arrow-dropdown", extraClassNames: "tw-text-sq-color-dark tw-mr-[0.5rem] tw-text-[0.75rem]", type: "text" }), label] }));
12
+ const TriggerSecond = ({ label }) => (_jsxs("div", { className: "tw-flex tw-justify-between tw-items-center tw-border-b tw-px-2 tw-text-sq-color-dark tw-py-2", children: [label, _jsx(Icon, { icon: "fc-arrow-dropdown", extraClassNames: "tw-text-sq-color-dark tw-mr-[0.5rem] tw-text-[0.75rem]", type: "text" })] }));
13
+ const renderData = () => (_jsxs("div", { className: "tw-text-sq-color-gray dark:tw-text-sq-white", children: [_jsx("p", { className: "tw-mb-5 tw-text-[0.9375rem] tw-leading-normal", children: "This is a data tab to show details about your data. You can make changes to your account" }), _jsx(Button, { variant: "outline", label: "Save data" })] }));
14
+ const renderTools = () => (_jsxs("div", { className: "tw-text-sq-color-gray dark:tw-text-sq-white", children: [_jsx("p", { className: "tw-mb-5 tw-text-[0.9375rem] tw-leading-normal", children: "Make changes to your account here. Click save when you're done." }), _jsx(Button, { variant: "outline", label: "Save tools" })] }));
15
+ const renderJournal = () => (_jsxs("div", { className: "tw-text-sq-color-gray dark:tw-text-sq-white", children: [_jsx("p", { className: "tw-mb-5 tw-text-[0.9375rem] tw-leading-normal", children: "Make changes to your account here. Click save when you're done." }), _jsx(Button, { variant: "outline", label: "Save journal" })] }));
16
+ const tabsList = [
17
+ {
18
+ id: 'data',
19
+ label: 'Data',
20
+ icon: 'fc-data',
21
+ content: renderData(),
22
+ },
23
+ {
24
+ id: 'tools',
25
+ label: 'Tools',
26
+ icon: 'fc-gears-2',
27
+ content: renderTools(),
28
+ },
29
+ {
30
+ id: 'journal',
31
+ label: 'Journal',
32
+ icon: 'fc-workbook-lock',
33
+ content: renderJournal(),
34
+ },
35
+ ];
36
+ export const AllAccordionVariants = () => {
37
+ const [activeTab, setActiveTab] = React.useState('data');
38
+ const [value, setValue] = React.useState('oranges');
39
+ const accordionItems = [
40
+ {
41
+ value: 'oranges',
42
+ id: 'oranges',
43
+ itemTestId: 'oranges',
44
+ trigger: _jsx(Trigger, { label: "Oranges" }),
45
+ content: (_jsx("div", { className: "tw-p-2 tw-text-[0.8125rem] dark:tw-text-sq-white", children: "Oranges are the fruit of the citrus species Citrus \u00D7 sinensis in the family Rutaceae. They are also called sweet oranges to distinguish them from the related Citrus \u00D7 aurantium, referred to as bitter oranges. They are round and orange, and usually have a sour or bitter taste. Oranges are a good source of vitamin C." })),
46
+ },
47
+ {
48
+ value: 'apples',
49
+ id: 'apples',
50
+ itemTestId: 'apples',
51
+ trigger: _jsx(Trigger, { label: "Apples" }),
52
+ content: (_jsx("div", { children: _jsx("div", { className: "tw-p-4", children: _jsx(Tabs, { stretchTabs: true, activeTab: activeTab, onTabSelect: setActiveTab, defaultActiveTab: "data", tabs: tabsList }) }) })),
53
+ },
54
+ {
55
+ value: 'bananas',
56
+ id: 'bananas',
57
+ trigger: _jsx(Trigger, { label: "Bananas" }),
58
+ itemTestId: 'bananas',
59
+ content: (_jsx("div", { children: "A banana is an elongated, edible fruit \u2013 botanically a berry \u2013 produced by several kinds of large herbaceous flowering plants in the genus Musa. In some countries, bananas used for cooking may be called \"plantains\", distinguishing them from dessert bananas. The fruit is variable in size, color, and firmness, but is usually elongated and curved, with soft flesh rich in starch covered with a rind, which may be green, yellow, red, purple, or brown when ripe." })),
60
+ },
61
+ {
62
+ value: 'pineapples',
63
+ id: 'pineapples',
64
+ trigger: _jsx(Trigger, { label: "Pineapples" }),
65
+ itemTestId: 'pineapples',
66
+ content: (_jsx("div", { children: "The pineapple is a tropical plant with an edible fruit and the most economically significant plant in the family Bromeliaceae. The pineapple is indigenous to South America, where it has been cultivated for many centuries. The introduction of the pineapple to Europe in the 17th century made it a significant cultural icon of luxury. Since the 1820s, pineapple has been commercially grown in greenhouses and many tropical plantations." })),
67
+ },
68
+ ];
69
+ const allAccordions = (isDark) => (_jsx("div", { className: isDark ? 'tw-dark tw-bg-sq-dark-background' : '', children: _jsx("div", { className: "tw-p-5 ", children: _jsx(Accordion, { accordionItems: isDark
70
+ ? accordionItems
71
+ : accordionItems.map((item) => ({ ...item, trigger: _jsx(TriggerSecond, { label: item.value.toUpperCase() }) })), value: value, testId: "basic-accordion1", onItemSelect: (value) => setValue(value) }) }) }));
72
+ const renderAllVariations = (isDark) => _jsx("div", { className: "tw-p-4", children: allAccordions(isDark) });
73
+ return (_jsxs(_Fragment, { children: [_jsxs("div", { className: "tw-grid tw-grid-cols-4 tw-gap-4", children: [_jsx(QTip, {}), _jsxs("div", { className: "color_topic", children: [_jsx("b", { children: "Topic Colors" }), renderAllVariations()] }), _jsxs("div", { className: "color_analysis", children: [_jsx("b", { children: "Analysis Colors" }), renderAllVariations()] }), _jsxs("div", { className: "color_datalab", children: [_jsx("b", { children: "Datalab Colors" }), renderAllVariations()] }), _jsxs("div", { className: "color_vantage", children: [_jsx("b", { children: "Vantage Colors" }), renderAllVariations()] })] }), _jsxs("div", { className: "tw-dark tw-bg-sq-dark-background tw-grid tw-grid-cols-4 tw-gap-4 tw-py-4", children: [_jsxs("div", { className: "color_topic dark:tw-text-sq-white tw-text-center", children: [_jsx("b", { children: "Topic Colors" }), renderAllVariations(true)] }), _jsxs("div", { className: "color_analysis dark:tw-text-sq-white tw-text-center", children: [_jsx("b", { children: "Analysis Colors" }), renderAllVariations(true)] }), _jsxs("div", { className: "color_datalab dark:tw-text-sq-white tw-text-center", children: [_jsx("b", { children: "Datalab Colors" }), renderAllVariations(true)] }), _jsxs("div", { className: "color_vantage dark:tw-text-sq-white tw-text-center", children: [_jsx("b", { children: "Vantage Colors" }), renderAllVariations(true)] })] })] }));
74
+ };
75
+ //# sourceMappingURL=Accordion.stories.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Accordion.stories.js","sourceRoot":"","sources":["../../src/Accordion/Accordion.stories.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,55 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import '@testing-library/jest-dom';
3
+ import { render, screen } from '@testing-library/react';
4
+ import userEvent from '@testing-library/user-event';
5
+ import Accordion from './Accordion';
6
+ describe('Accordion', () => {
7
+ const mockOnItemSelect = jest.fn();
8
+ class Context {
9
+ testId = 'buttonTestId';
10
+ label = 'button label';
11
+ props = {
12
+ accordionItems: [
13
+ {
14
+ id: 'item1',
15
+ value: 'item1',
16
+ trigger: 'Item 1',
17
+ content: 'Content 1',
18
+ },
19
+ {
20
+ id: 'item2',
21
+ value: 'item2',
22
+ trigger: 'Item 2',
23
+ content: 'Content 2',
24
+ },
25
+ ],
26
+ defaultValue: 'item1',
27
+ value: 'item1',
28
+ onItemSelect: (key) => mockOnItemSelect(key),
29
+ disabled: false,
30
+ extraClassNames: 'extra-class',
31
+ testId: this.testId,
32
+ };
33
+ }
34
+ let tc;
35
+ beforeEach(() => {
36
+ tc = new Context();
37
+ });
38
+ const renderAccordion = (props) => render(_jsx(Accordion, { ...props }));
39
+ it('renders accordion items', () => {
40
+ renderAccordion(tc.props);
41
+ expect(screen.getByText('Item 1')).toBeInTheDocument();
42
+ expect(screen.getByText('Item 2')).toBeInTheDocument();
43
+ });
44
+ it('renders accordion content', () => {
45
+ renderAccordion(tc.props);
46
+ expect(screen.getByText('Content 1')).toBeInTheDocument();
47
+ expect(screen.queryByText('Content 2')).not.toBeInTheDocument();
48
+ });
49
+ it('calls onItemSelect when an item is selected', async () => {
50
+ renderAccordion(tc.props);
51
+ await userEvent.click(screen.getByText('Item 2'));
52
+ expect(mockOnItemSelect).toHaveBeenCalledWith('item2');
53
+ });
54
+ });
55
+ //# sourceMappingURL=Accordion.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Accordion.test.js","sourceRoot":"","sources":["../../src/Accordion/Accordion.test.tsx"],"names":[],"mappings":";AACA,OAAO,2BAA2B,CAAC;AACnC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,SAAS,MAAM,6BAA6B,CAAC;AAEpD,OAAO,SAAS,MAAM,aAAa,CAAC;AAGpC,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,MAAM,gBAAgB,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;IACnC,MAAM,OAAO;QACX,MAAM,GAAG,cAAc,CAAC;QACxB,KAAK,GAAG,cAAc,CAAC;QACvB,KAAK,GAAmB;YACtB,cAAc,EAAE;gBACd;oBACE,EAAE,EAAE,OAAO;oBACX,KAAK,EAAE,OAAO;oBACd,OAAO,EAAE,QAAQ;oBACjB,OAAO,EAAE,WAAW;iBACrB;gBACD;oBACE,EAAE,EAAE,OAAO;oBACX,KAAK,EAAE,OAAO;oBACd,OAAO,EAAE,QAAQ;oBACjB,OAAO,EAAE,WAAW;iBACrB;aACF;YACD,YAAY,EAAE,OAAO;YACrB,KAAK,EAAE,OAAO;YACd,YAAY,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,gBAAgB,CAAC,GAAG,CAAC;YAC5C,QAAQ,EAAE,KAAK;YACf,eAAe,EAAE,aAAa;YAC9B,MAAM,EAAE,IAAI,CAAC,MAAM;SACpB,CAAC;KACH;IAED,IAAI,EAAW,CAAC;IAChB,UAAU,CAAC,GAAG,EAAE;QACd,EAAE,GAAG,IAAI,OAAO,EAAE,CAAC;IACrB,CAAC,CAAC,CAAC;IAEH,MAAM,eAAe,GAAG,CAAC,KAAqB,EAAE,EAAE,CAAC,MAAM,CAAC,KAAC,SAAS,OAAK,KAAK,GAAI,CAAC,CAAC;IAEpF,EAAE,CAAC,yBAAyB,EAAE,GAAG,EAAE;QACjC,eAAe,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;QAC1B,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;QACvD,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;IACzD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE,GAAG,EAAE;QACnC,eAAe,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;QAC1B,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;QAC1D,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC,CAAC,GAAG,CAAC,iBAAiB,EAAE,CAAC;IAClE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE,KAAK,IAAI,EAAE;QAC3D,eAAe,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;QAC1B,MAAM,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;QAClD,MAAM,CAAC,gBAAgB,CAAC,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC;IACzD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=Accordion.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Accordion.types.js","sourceRoot":"","sources":["../../src/Accordion/Accordion.types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,2 @@
1
+ export { default } from './Accordion';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/Accordion/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC"}
@@ -0,0 +1,32 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import '../styles.css';
3
+ import Icon from '../Icon';
4
+ const baseClasses = 'tw-mx-auto tw-p-4 tw-leading-normal tw-outline-none tw-py-2 tw-px-3 tw-rounded-[10px] tw-w-full tw-relative' +
5
+ ' tw-border-solid tw-border tw-text-sm tw-flex tw-flex-col tw-justify-center tw-items-center';
6
+ const darkTheme = 'dark:tw-bg-sq-colored-hover-dark dark:tw-text-sq-dark-text';
7
+ const lightTheme = 'tw-text-sq-text-color tw-bg-sq-colored-hover';
8
+ const errorClasses = 'tw-border-sq-danger-color';
9
+ const borderColorClasses = 'tw-border-sq-color-dark';
10
+ /**
11
+ * Alert.
12
+ */
13
+ export const Alert = ({ children, dismissible = true, onClose, show = true, variant, testId = 'alert-id', id, extraClassNames, ...tooltipProps }) => {
14
+ const appliedTheme = {
15
+ theme: `${lightTheme} ${darkTheme}`,
16
+ danger: 'tw-text-sq-text-color tw-bg-sq-danger-color',
17
+ warning: 'tw-bg-sq-bg-warning-color tw-text-sq-text-color',
18
+ gray: 'tw-bg-sq-light-gray tw-text-sq-text-color dark:tw-bg-sq-worksheetspanel-gray-dark dark:tw-text-sq-dark-text',
19
+ };
20
+ const appliedBorderTheme = {
21
+ theme: borderColorClasses,
22
+ danger: errorClasses,
23
+ warning: 'tw-border-none',
24
+ gray: 'tw-border-sq-darkish-gray',
25
+ };
26
+ const appliedClasses = `${baseClasses} ${appliedTheme[variant]} ${extraClassNames} ${appliedBorderTheme[variant]}`;
27
+ if (!show) {
28
+ return _jsx("div", {});
29
+ }
30
+ return (_jsxs("div", { "data-testid": testId, id: id, className: appliedClasses, children: [children, dismissible && (_jsx(Icon, { icon: "fc-delete", type: variant.match(/danger|warning/) ? 'color' : 'theme', color: variant.match(/danger|warning/) ? 'inherit' : undefined, extraClassNames: `tw-self-end tw-text-[0.6875rem] tw-cursor-pointer tw-absolute tw-right-[10px] tw-top-[10px] ${variant.match(/danger|warning|gray/) ? 'tw-text-sq-text-color dark:tw-text-sq-dark-text' : ''}`, testId: `${testId}-close-btn`, onClick: onClose, ...tooltipProps }))] }));
31
+ };
32
+ //# sourceMappingURL=Alert.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Alert.js","sourceRoot":"","sources":["../../src/Alert/Alert.tsx"],"names":[],"mappings":";AACA,OAAO,eAAe,CAAC;AACvB,OAAO,IAAI,MAAM,SAAS,CAAC;AAG3B,MAAM,WAAW,GACf,6GAA6G;IAC7G,6FAA6F,CAAC;AAEhG,MAAM,SAAS,GAAG,4DAA4D,CAAC;AAC/E,MAAM,UAAU,GAAG,8CAA8C,CAAC;AAElE,MAAM,YAAY,GAAG,2BAA2B,CAAC;AAEjD,MAAM,kBAAkB,GAAG,yBAAyB,CAAC;AAErD;;GAEG;AACH,MAAM,CAAC,MAAM,KAAK,GAAwC,CAAC,EACzD,QAAQ,EACR,WAAW,GAAG,IAAI,EAClB,OAAO,EACP,IAAI,GAAG,IAAI,EACX,OAAO,EACP,MAAM,GAAG,UAAU,EACnB,EAAE,EACF,eAAe,EACf,GAAG,YAAY,EAChB,EAAE,EAAE;IACH,MAAM,YAAY,GAA0C;QAC1D,KAAK,EAAE,GAAG,UAAU,IAAI,SAAS,EAAE;QACnC,MAAM,EAAE,6CAA6C;QACrD,OAAO,EAAE,iDAAiD;QAC1D,IAAI,EAAE,6GAA6G;KACpH,CAAC;IACF,MAAM,kBAAkB,GAA0C;QAChE,KAAK,EAAE,kBAAkB;QACzB,MAAM,EAAE,YAAY;QACpB,OAAO,EAAE,gBAAgB;QACzB,IAAI,EAAE,2BAA2B;KAClC,CAAC;IACF,MAAM,cAAc,GAAG,GAAG,WAAW,IAAI,YAAY,CAAC,OAAO,CAAC,IAAI,eAAe,IAAI,kBAAkB,CAAC,OAAO,CAAC,EAAE,CAAC;IAEnH,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,OAAO,eAAO,CAAC;IACjB,CAAC;IACD,OAAO,CACL,8BAAkB,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,SAAS,EAAE,cAAc,aACxD,QAAQ,EACR,WAAW,IAAI,CACd,KAAC,IAAI,IACH,IAAI,EAAC,WAAW,EAChB,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,EACzD,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,EAC9D,eAAe,EAAE,+FACf,OAAO,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,iDAAiD,CAAC,CAAC,CAAC,EAC7F,EAAE,EACF,MAAM,EAAE,GAAG,MAAM,YAAY,EAC7B,OAAO,EAAE,OAAO,KACZ,YAAY,GAChB,CACH,IACG,CACP,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,57 @@
1
+ import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
2
+ import { Alert } from './Alert';
3
+ import { QTip } from '../Tooltip';
4
+ const Template = ({ variant }) => {
5
+ return (_jsxs("div", { className: "tw-text-sq-color-gray dark:tw-text-sq-white", children: [_jsxs("h3", { className: "tw-mb-5 tw-text-[0.9375rem] tw-leading-normal", children: ["This is a ", variant, " alert, it looks very pleasing and is very useful for showing alerts to the user"] }), _jsx(Alert, { variant: variant, dismissible: true, show: true, extraClassNames: "tw-h-[200px]", tooltip: "This is a small close alert icon", tooltipDelay: 0, tooltipPlacement: "top", isHtmlTooltip: false, children: "This is a dismissible alert, it looks very pleasing and is very useful for showing alerts to the user" }), _jsx(QTip, {})] }));
6
+ };
7
+ export const ThemedAlert = Template.bind({});
8
+ ThemedAlert.args = {
9
+ variant: "theme",
10
+ };
11
+ export const WarningAlert = Template.bind({});
12
+ WarningAlert.args = {
13
+ variant: "warning",
14
+ };
15
+ export const DangerAlert = Template.bind({});
16
+ DangerAlert.args = {
17
+ variant: "danger",
18
+ };
19
+ export const GrayAlert = Template.bind({});
20
+ GrayAlert.args = {
21
+ variant: "gray",
22
+ };
23
+ const colors = ['topic', 'analysis', 'datalab', 'vantage'];
24
+ const renderAlert = ({ text, dismissable, variant, }) => (_jsxs("div", { className: "tw-text-sq-color-gray dark:tw-text-sq-white", children: [_jsx("p", { className: "tw-mb-5 tw-text-[0.9375rem] tw-leading-normal" }), _jsx(Alert, { variant: variant, dismissible: dismissable, show: true, extraClassNames: "tw-h-[200px]", tooltip: "This is a small close alert icon", tooltipDelay: 0, tooltipPlacement: "top", isHtmlTooltip: false, children: text })] }));
25
+ export const AllAlertsVariants = () => {
26
+ const renderAllVariations = (color) => (_jsxs("div", { children: [_jsx("div", { className: "tw-p-4", children: renderAlert({
27
+ text: 'This is a dismissible alert, it looks very pleasing and is very useful for showing alerts to the user',
28
+ dismissable: true,
29
+ variant: 'theme',
30
+ }) }), _jsx("div", { className: "tw-p-4", children: renderAlert({
31
+ text: 'This is a non dismissable alert, it looks very pleasing and is very useful for showing alerts to the user',
32
+ dismissable: false,
33
+ variant: 'theme',
34
+ }) }), _jsx("div", { className: "tw-p-4", children: renderAlert({
35
+ text: 'This is a warning alert, it is used to display a warning',
36
+ dismissable: false,
37
+ variant: 'warning',
38
+ }) }), _jsx("div", { className: "tw-p-4", children: renderAlert({
39
+ text: 'This is an error alert, it is used to display an error',
40
+ dismissable: false,
41
+ variant: 'danger',
42
+ }) }), _jsx("div", { className: "tw-p-4", children: renderAlert({
43
+ text: 'This is a gray alert, it is used to display a neutral alert',
44
+ dismissable: true,
45
+ variant: 'gray',
46
+ }) }), _jsx("div", { className: "tw-p-4", children: renderAlert({
47
+ text: 'This is an error alert that is dismissible, it is used to display an error',
48
+ dismissable: true,
49
+ variant: 'danger',
50
+ }) })] }, color + '_wrapper'));
51
+ return (_jsxs("div", { children: [_jsx(QTip, {}), _jsx("div", { className: "tw-grid tw-grid-cols-4 tw-gap-4", children: colors.map((color) => {
52
+ return _jsx("div", { className: `color_${color}`, children: renderAllVariations(color) });
53
+ }) }), _jsx("div", { className: "tw-dark tw-bg-sq-dark-background tw-grid tw-grid-cols-4 tw-gap-4", children: colors.map((color) => {
54
+ return _jsx("div", { className: `color_${color}`, children: renderAllVariations(color) });
55
+ }) })] }));
56
+ };
57
+ //# sourceMappingURL=Alert.stories.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Alert.stories.js","sourceRoot":"","sources":["../../src/Alert/Alert.stories.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAChC,OAAO,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;AAIjC,MAAM,QAAQ,GAAsB,CAAC,EAAE,OAAO,EAAC,EAAE,EAAE;IAClD,OAAO,CACL,eAAK,SAAS,EAAC,6CAA6C,aAC1D,cAAI,SAAS,EAAC,+CAA+C,2BAChD,OAAO,wFACf,EACL,KAAC,KAAK,IACJ,OAAO,EAAE,OAAO,EAChB,WAAW,EAAE,IAAI,EACjB,IAAI,QACJ,eAAe,EAAC,cAAc,EAC9B,OAAO,EAAC,kCAAkC,EAC1C,YAAY,EAAE,CAAC,EACf,gBAAgB,EAAC,KAAK,EACtB,aAAa,EAAE,KAAK,sHAEd,EACR,KAAC,IAAI,KAAG,IACJ,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AAC7C,WAAW,CAAC,IAAI,GAAG;IACjB,OAAO,EAAE,OAAO;CACjB,CAAC;AACF,MAAM,CAAC,MAAM,YAAY,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AAC9C,YAAY,CAAC,IAAI,GAAG;IAClB,OAAO,EAAE,SAAS;CACnB,CAAC;AACF,MAAM,CAAC,MAAM,WAAW,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AAC7C,WAAW,CAAC,IAAI,GAAG;IACjB,OAAO,EAAE,QAAQ;CAClB,CAAC;AACF,MAAM,CAAC,MAAM,SAAS,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AAC3C,SAAS,CAAC,IAAI,GAAG;IACf,OAAO,EAAE,MAAM;CAChB,CAAC;AAGF,MAAM,MAAM,GAAG,CAAC,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;AAE3D,MAAM,WAAW,GAAG,CAAC,EACnB,IAAI,EACJ,WAAW,EACX,OAAO,GAKR,EAAE,EAAE,CAAC,CACJ,eAAK,SAAS,EAAC,6CAA6C,aAC1D,YAAG,SAAS,EAAC,+CAA+C,GAAK,EACjE,KAAC,KAAK,IACJ,OAAO,EAAE,OAAO,EAChB,WAAW,EAAE,WAAW,EACxB,IAAI,QACJ,eAAe,EAAC,cAAc,EAC9B,OAAO,EAAC,kCAAkC,EAC1C,YAAY,EAAE,CAAC,EACf,gBAAgB,EAAC,KAAK,EACtB,aAAa,EAAE,KAAK,YACnB,IAAI,GACC,IACJ,CACP,CAAC;AAEF,MAAM,CAAC,MAAM,iBAAiB,GAAG,GAAG,EAAE;IACpC,MAAM,mBAAmB,GAAG,CAAC,KAAa,EAAE,EAAE,CAAC,CAC7C,0BACE,cAAK,SAAS,EAAC,QAAQ,YACpB,WAAW,CAAC;oBACX,IAAI,EAAE,uGAAuG;oBAC7G,WAAW,EAAE,IAAI;oBACjB,OAAO,EAAE,OAAO;iBACjB,CAAC,GACE,EACN,cAAK,SAAS,EAAC,QAAQ,YACpB,WAAW,CAAC;oBACX,IAAI,EAAE,2GAA2G;oBACjH,WAAW,EAAE,KAAK;oBAClB,OAAO,EAAE,OAAO;iBACjB,CAAC,GACE,EACN,cAAK,SAAS,EAAC,QAAQ,YACpB,WAAW,CAAC;oBACX,IAAI,EAAE,0DAA0D;oBAChE,WAAW,EAAE,KAAK;oBAClB,OAAO,EAAE,SAAS;iBACnB,CAAC,GACE,EACN,cAAK,SAAS,EAAC,QAAQ,YACpB,WAAW,CAAC;oBACX,IAAI,EAAE,wDAAwD;oBAC9D,WAAW,EAAE,KAAK;oBAClB,OAAO,EAAE,QAAQ;iBAClB,CAAC,GACE,EACN,cAAK,SAAS,EAAC,QAAQ,YACpB,WAAW,CAAC;oBACX,IAAI,EAAE,6DAA6D;oBACnE,WAAW,EAAE,IAAI;oBACjB,OAAO,EAAE,MAAM;iBAChB,CAAC,GACE,EACN,cAAK,SAAS,EAAC,QAAQ,YACpB,WAAW,CAAC;oBACX,IAAI,EAAE,4EAA4E;oBAClF,WAAW,EAAE,IAAI;oBACjB,OAAO,EAAE,QAAQ;iBAClB,CAAC,GACE,KA1CE,KAAK,GAAG,UAAU,CA2CtB,CACP,CAAC;IACF,OAAO,CACL,0BACE,KAAC,IAAI,KAAG,EACR,cAAK,SAAS,EAAC,iCAAiC,YAC7C,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;oBACpB,OAAO,cAAK,SAAS,EAAE,SAAS,KAAK,EAAE,YAAG,mBAAmB,CAAC,KAAK,CAAC,GAAO,CAAC;gBAC9E,CAAC,CAAC,GACE,EACN,cAAK,SAAS,EAAC,kEAAkE,YAC9E,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;oBACpB,OAAO,cAAK,SAAS,EAAE,SAAS,KAAK,EAAE,YAAG,mBAAmB,CAAC,KAAK,CAAC,GAAO,CAAC;gBAC9E,CAAC,CAAC,GACE,IACF,CACP,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,50 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { fireEvent, render, screen } from '@testing-library/react';
3
+ import { Alert } from './Alert';
4
+ describe('Alert Component', () => {
5
+ const defaultProps = {
6
+ children: 'Test Alert',
7
+ dismissible: true,
8
+ onClose: jest.fn(),
9
+ show: true,
10
+ variant: 'theme',
11
+ testId: 'alert-test-id',
12
+ id: 'alert-id',
13
+ extraClassNames: '',
14
+ };
15
+ it('should render the Alert component', () => {
16
+ render(_jsx(Alert, { ...defaultProps }));
17
+ const alertElement = screen.getByTestId('alert-test-id');
18
+ expect(alertElement).toBeInTheDocument();
19
+ });
20
+ it('should render children correctly', () => {
21
+ render(_jsx(Alert, { ...defaultProps }));
22
+ const alertElement = screen.getByTestId('alert-test-id');
23
+ expect(alertElement).toHaveTextContent('Test Alert');
24
+ });
25
+ it('should apply the correct classes based on variant', () => {
26
+ const { rerender } = render(_jsx(Alert, { ...defaultProps, variant: "danger" }));
27
+ let alertElement = screen.getByTestId('alert-test-id');
28
+ expect(alertElement).toHaveClass('tw-text-sq-text-color tw-bg-sq-danger-color');
29
+ rerender(_jsx(Alert, { ...defaultProps, variant: "warning" }));
30
+ alertElement = screen.getByTestId('alert-test-id');
31
+ expect(alertElement).toHaveClass('tw-bg-sq-bg-warning-color tw-text-sq-text-color');
32
+ });
33
+ it('should call onClose when dismissible icon is clicked', () => {
34
+ render(_jsx(Alert, { ...defaultProps }));
35
+ const closeButton = screen.getByTestId('alert-test-id-close-btn');
36
+ fireEvent.click(closeButton);
37
+ expect(defaultProps.onClose).toHaveBeenCalled();
38
+ });
39
+ it('should not render when show is false', () => {
40
+ render(_jsx(Alert, { ...defaultProps, show: false }));
41
+ const alertElement = screen.queryByTestId('alert-test-id');
42
+ expect(alertElement).not.toBeInTheDocument();
43
+ });
44
+ it('should apply extra class names', () => {
45
+ render(_jsx(Alert, { ...defaultProps, extraClassNames: "extra-class" }));
46
+ const alertElement = screen.getByTestId('alert-test-id');
47
+ expect(alertElement).toHaveClass('extra-class');
48
+ });
49
+ });
50
+ //# sourceMappingURL=Alert.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Alert.test.js","sourceRoot":"","sources":["../../src/Alert/Alert.test.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=Alert.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Alert.types.js","sourceRoot":"","sources":["../../src/Alert/Alert.types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,2 @@
1
+ export { Alert as default } from './Alert';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/Alert/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,IAAI,OAAO,EAAE,MAAM,SAAS,CAAC"}