@seeqdev/qomponents 0.0.158 → 0.0.159

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 (252) hide show
  1. package/dist/index.esm.js +29 -14
  2. package/dist/index.esm.js.map +1 -1
  3. package/dist/index.js +29 -14
  4. package/dist/index.js.map +1 -1
  5. package/dist/styles.css +4 -0
  6. package/dist/types.d.ts.map +1 -0
  7. package/package.json +1 -3
  8. package/dist/Accordion/Accordion.js +0 -7
  9. package/dist/Accordion/Accordion.js.map +0 -1
  10. package/dist/Accordion/Accordion.stories.js +0 -75
  11. package/dist/Accordion/Accordion.stories.js.map +0 -1
  12. package/dist/Accordion/Accordion.test.js +0 -55
  13. package/dist/Accordion/Accordion.test.js.map +0 -1
  14. package/dist/Accordion/Accordion.types.js +0 -2
  15. package/dist/Accordion/Accordion.types.js.map +0 -1
  16. package/dist/Accordion/index.js +0 -2
  17. package/dist/Accordion/index.js.map +0 -1
  18. package/dist/Alert/Alert.js +0 -32
  19. package/dist/Alert/Alert.js.map +0 -1
  20. package/dist/Alert/Alert.stories.js +0 -57
  21. package/dist/Alert/Alert.stories.js.map +0 -1
  22. package/dist/Alert/Alert.test.js +0 -50
  23. package/dist/Alert/Alert.test.js.map +0 -1
  24. package/dist/Alert/Alert.types.js +0 -2
  25. package/dist/Alert/Alert.types.js.map +0 -1
  26. package/dist/Alert/index.js +0 -2
  27. package/dist/Alert/index.js.map +0 -1
  28. package/dist/Button/Button.js +0 -89
  29. package/dist/Button/Button.js.map +0 -1
  30. package/dist/Button/Button.stories.js +0 -25
  31. package/dist/Button/Button.stories.js.map +0 -1
  32. package/dist/Button/Button.test.js +0 -47
  33. package/dist/Button/Button.test.js.map +0 -1
  34. package/dist/Button/Button.types.js +0 -5
  35. package/dist/Button/Button.types.js.map +0 -1
  36. package/dist/Button/index.js +0 -2
  37. package/dist/Button/index.js.map +0 -1
  38. package/dist/ButtonGroup/ButtonGroup.js +0 -35
  39. package/dist/ButtonGroup/ButtonGroup.js.map +0 -1
  40. package/dist/ButtonGroup/ButtonGroup.stories.js +0 -317
  41. package/dist/ButtonGroup/ButtonGroup.stories.js.map +0 -1
  42. package/dist/ButtonGroup/ButtonGroup.test.js +0 -66
  43. package/dist/ButtonGroup/ButtonGroup.test.js.map +0 -1
  44. package/dist/ButtonGroup/ButtonGroup.types.js +0 -2
  45. package/dist/ButtonGroup/ButtonGroup.types.js.map +0 -1
  46. package/dist/ButtonGroup/index.js +0 -2
  47. package/dist/ButtonGroup/index.js.map +0 -1
  48. package/dist/ButtonWithDropdown/ButtonWithDropdown.js +0 -36
  49. package/dist/ButtonWithDropdown/ButtonWithDropdown.js.map +0 -1
  50. package/dist/ButtonWithDropdown/ButtonWithDropdown.stories.js +0 -104
  51. package/dist/ButtonWithDropdown/ButtonWithDropdown.stories.js.map +0 -1
  52. package/dist/ButtonWithDropdown/ButtonWithDropdown.test.js +0 -93
  53. package/dist/ButtonWithDropdown/ButtonWithDropdown.test.js.map +0 -1
  54. package/dist/ButtonWithDropdown/ButtonWithDropdown.types.js +0 -2
  55. package/dist/ButtonWithDropdown/ButtonWithDropdown.types.js.map +0 -1
  56. package/dist/ButtonWithDropdown/index.js +0 -2
  57. package/dist/ButtonWithDropdown/index.js.map +0 -1
  58. package/dist/ButtonWithPopover/ButtonWithPopover.js +0 -55
  59. package/dist/ButtonWithPopover/ButtonWithPopover.js.map +0 -1
  60. package/dist/ButtonWithPopover/ButtonWithPopover.stories.js +0 -25
  61. package/dist/ButtonWithPopover/ButtonWithPopover.stories.js.map +0 -1
  62. package/dist/ButtonWithPopover/ButtonWithPopover.test.js +0 -81
  63. package/dist/ButtonWithPopover/ButtonWithPopover.test.js.map +0 -1
  64. package/dist/ButtonWithPopover/ButtonWithPopover.types.js +0 -2
  65. package/dist/ButtonWithPopover/ButtonWithPopover.types.js.map +0 -1
  66. package/dist/ButtonWithPopover/index.js +0 -2
  67. package/dist/ButtonWithPopover/index.js.map +0 -1
  68. package/dist/Carousel/Carousel.js +0 -75
  69. package/dist/Carousel/Carousel.js.map +0 -1
  70. package/dist/Carousel/Carousel.stories.js +0 -63
  71. package/dist/Carousel/Carousel.stories.js.map +0 -1
  72. package/dist/Carousel/Carousel.test.js +0 -48
  73. package/dist/Carousel/Carousel.test.js.map +0 -1
  74. package/dist/Carousel/Carousel.types.js +0 -2
  75. package/dist/Carousel/Carousel.types.js.map +0 -1
  76. package/dist/Carousel/index.js +0 -2
  77. package/dist/Carousel/index.js.map +0 -1
  78. package/dist/Checkbox/Checkbox.js +0 -24
  79. package/dist/Checkbox/Checkbox.js.map +0 -1
  80. package/dist/Checkbox/Checkbox.stories.js +0 -12
  81. package/dist/Checkbox/Checkbox.stories.js.map +0 -1
  82. package/dist/Checkbox/Checkbox.test.js +0 -94
  83. package/dist/Checkbox/Checkbox.test.js.map +0 -1
  84. package/dist/Checkbox/Checkbox.types.js +0 -2
  85. package/dist/Checkbox/Checkbox.types.js.map +0 -1
  86. package/dist/Checkbox/index.js +0 -2
  87. package/dist/Checkbox/index.js.map +0 -1
  88. package/dist/Collapse/Collapse.js +0 -17
  89. package/dist/Collapse/Collapse.js.map +0 -1
  90. package/dist/Collapse/Collapse.stories.js +0 -15
  91. package/dist/Collapse/Collapse.stories.js.map +0 -1
  92. package/dist/Collapse/Collapse.test.js +0 -17
  93. package/dist/Collapse/Collapse.test.js.map +0 -1
  94. package/dist/Collapse/Collapse.types.js +0 -2
  95. package/dist/Collapse/Collapse.types.js.map +0 -1
  96. package/dist/Collapse/index.js +0 -2
  97. package/dist/Collapse/index.js.map +0 -1
  98. package/dist/Icon/Icon.js +0 -55
  99. package/dist/Icon/Icon.js.map +0 -1
  100. package/dist/Icon/Icon.stories.js +0 -15
  101. package/dist/Icon/Icon.stories.js.map +0 -1
  102. package/dist/Icon/Icon.test.js +0 -55
  103. package/dist/Icon/Icon.test.js.map +0 -1
  104. package/dist/Icon/Icon.types.js +0 -16
  105. package/dist/Icon/Icon.types.js.map +0 -1
  106. package/dist/Icon/index.js +0 -2
  107. package/dist/Icon/index.js.map +0 -1
  108. package/dist/InputGroup/InputGroup.js +0 -34
  109. package/dist/InputGroup/InputGroup.js.map +0 -1
  110. package/dist/InputGroup/InputGroup.stories.js +0 -129
  111. package/dist/InputGroup/InputGroup.stories.js.map +0 -1
  112. package/dist/InputGroup/InputGroup.test.js +0 -42
  113. package/dist/InputGroup/InputGroup.test.js.map +0 -1
  114. package/dist/InputGroup/InputGroup.types.js +0 -2
  115. package/dist/InputGroup/InputGroup.types.js.map +0 -1
  116. package/dist/InputGroup/index.js +0 -2
  117. package/dist/InputGroup/index.js.map +0 -1
  118. package/dist/Modal/Modal.js +0 -76
  119. package/dist/Modal/Modal.js.map +0 -1
  120. package/dist/Modal/Modal.stories.js +0 -44
  121. package/dist/Modal/Modal.stories.js.map +0 -1
  122. package/dist/Modal/Modal.test.js +0 -108
  123. package/dist/Modal/Modal.test.js.map +0 -1
  124. package/dist/Modal/Modal.types.js +0 -2
  125. package/dist/Modal/Modal.types.js.map +0 -1
  126. package/dist/Modal/index.js +0 -2
  127. package/dist/Modal/index.js.map +0 -1
  128. package/dist/ProgressBar/ProgressBar.js +0 -72
  129. package/dist/ProgressBar/ProgressBar.js.map +0 -1
  130. package/dist/ProgressBar/ProgressBar.stories.js +0 -35
  131. package/dist/ProgressBar/ProgressBar.stories.js.map +0 -1
  132. package/dist/ProgressBar/ProgressBar.test.js +0 -43
  133. package/dist/ProgressBar/ProgressBar.test.js.map +0 -1
  134. package/dist/ProgressBar/ProgressBar.types.js +0 -2
  135. package/dist/ProgressBar/ProgressBar.types.js.map +0 -1
  136. package/dist/ProgressBar/index.js +0 -2
  137. package/dist/ProgressBar/index.js.map +0 -1
  138. package/dist/SeeqActionDropdown/SeeqActionDropdown.js +0 -39
  139. package/dist/SeeqActionDropdown/SeeqActionDropdown.js.map +0 -1
  140. package/dist/SeeqActionDropdown/SeeqActionDropdown.stories.js +0 -56
  141. package/dist/SeeqActionDropdown/SeeqActionDropdown.stories.js.map +0 -1
  142. package/dist/SeeqActionDropdown/SeeqActionDropdown.test.js +0 -73
  143. package/dist/SeeqActionDropdown/SeeqActionDropdown.test.js.map +0 -1
  144. package/dist/SeeqActionDropdown/SeeqActionDropdown.types.js +0 -2
  145. package/dist/SeeqActionDropdown/SeeqActionDropdown.types.js.map +0 -1
  146. package/dist/SeeqActionDropdown/index.js +0 -2
  147. package/dist/SeeqActionDropdown/index.js.map +0 -1
  148. package/dist/SeeqActionDropdown/variants.js +0 -29
  149. package/dist/SeeqActionDropdown/variants.js.map +0 -1
  150. package/dist/Select/Select.js +0 -177
  151. package/dist/Select/Select.js.map +0 -1
  152. package/dist/Select/Select.stories.js +0 -40
  153. package/dist/Select/Select.stories.js.map +0 -1
  154. package/dist/Select/Select.test.js +0 -175
  155. package/dist/Select/Select.test.js.map +0 -1
  156. package/dist/Select/Select.types.js +0 -2
  157. package/dist/Select/Select.types.js.map +0 -1
  158. package/dist/Select/index.js +0 -3
  159. package/dist/Select/index.js.map +0 -1
  160. package/dist/Slider/Slider.js +0 -10
  161. package/dist/Slider/Slider.js.map +0 -1
  162. package/dist/Slider/Slider.stories.js +0 -14
  163. package/dist/Slider/Slider.stories.js.map +0 -1
  164. package/dist/Slider/Slider.test.js +0 -32
  165. package/dist/Slider/Slider.test.js.map +0 -1
  166. package/dist/Slider/Slider.types.js +0 -2
  167. package/dist/Slider/Slider.types.js.map +0 -1
  168. package/dist/Slider/index.js +0 -2
  169. package/dist/Slider/index.js.map +0 -1
  170. package/dist/SvgIcon/SvgIcon.js +0 -28
  171. package/dist/SvgIcon/SvgIcon.js.map +0 -1
  172. package/dist/SvgIcon/SvgIcon.stories.js +0 -18
  173. package/dist/SvgIcon/SvgIcon.stories.js.map +0 -1
  174. package/dist/SvgIcon/SvgIcon.test.js +0 -41
  175. package/dist/SvgIcon/SvgIcon.test.js.map +0 -1
  176. package/dist/SvgIcon/SvgIcon.types.js +0 -6
  177. package/dist/SvgIcon/SvgIcon.types.js.map +0 -1
  178. package/dist/SvgIcon/index.js +0 -2
  179. package/dist/SvgIcon/index.js.map +0 -1
  180. package/dist/Tabs/Tabs.js +0 -17
  181. package/dist/Tabs/Tabs.js.map +0 -1
  182. package/dist/Tabs/Tabs.stories.js +0 -73
  183. package/dist/Tabs/Tabs.stories.js.map +0 -1
  184. package/dist/Tabs/Tabs.test.js +0 -86
  185. package/dist/Tabs/Tabs.test.js.map +0 -1
  186. package/dist/Tabs/Tabs.types.js +0 -2
  187. package/dist/Tabs/Tabs.types.js.map +0 -1
  188. package/dist/Tabs/index.js +0 -2
  189. package/dist/Tabs/index.js.map +0 -1
  190. package/dist/TextArea/TextArea.js +0 -25
  191. package/dist/TextArea/TextArea.js.map +0 -1
  192. package/dist/TextArea/TextArea.stories.js +0 -10
  193. package/dist/TextArea/TextArea.stories.js.map +0 -1
  194. package/dist/TextArea/TextArea.test.js +0 -68
  195. package/dist/TextArea/TextArea.test.js.map +0 -1
  196. package/dist/TextArea/TextArea.types.js +0 -2
  197. package/dist/TextArea/TextArea.types.js.map +0 -1
  198. package/dist/TextArea/index.js +0 -2
  199. package/dist/TextArea/index.js.map +0 -1
  200. package/dist/TextField/TextField.js +0 -85
  201. package/dist/TextField/TextField.js.map +0 -1
  202. package/dist/TextField/TextField.stories.js +0 -11
  203. package/dist/TextField/TextField.stories.js.map +0 -1
  204. package/dist/TextField/TextField.test.js +0 -41
  205. package/dist/TextField/TextField.test.js.map +0 -1
  206. package/dist/TextField/TextField.types.js +0 -2
  207. package/dist/TextField/TextField.types.js.map +0 -1
  208. package/dist/TextField/index.js +0 -2
  209. package/dist/TextField/index.js.map +0 -1
  210. package/dist/ToolbarButton/ToolbarButton.js +0 -57
  211. package/dist/ToolbarButton/ToolbarButton.js.map +0 -1
  212. package/dist/ToolbarButton/ToolbarButton.stories.js +0 -28
  213. package/dist/ToolbarButton/ToolbarButton.stories.js.map +0 -1
  214. package/dist/ToolbarButton/ToolbarButton.test.js +0 -85
  215. package/dist/ToolbarButton/ToolbarButton.test.js.map +0 -1
  216. package/dist/ToolbarButton/ToolbarButton.types.js +0 -2
  217. package/dist/ToolbarButton/ToolbarButton.types.js.map +0 -1
  218. package/dist/ToolbarButton/index.js +0 -2
  219. package/dist/ToolbarButton/index.js.map +0 -1
  220. package/dist/Tooltip/QTip.stories.js +0 -18
  221. package/dist/Tooltip/QTip.stories.js.map +0 -1
  222. package/dist/Tooltip/QTip.types.js +0 -2
  223. package/dist/Tooltip/QTip.types.js.map +0 -1
  224. package/dist/Tooltip/QTipPerformance.stories.js +0 -26
  225. package/dist/Tooltip/QTipPerformance.stories.js.map +0 -1
  226. package/dist/Tooltip/Qtip.js +0 -168
  227. package/dist/Tooltip/Qtip.js.map +0 -1
  228. package/dist/Tooltip/Tooltip.js +0 -34
  229. package/dist/Tooltip/Tooltip.js.map +0 -1
  230. package/dist/Tooltip/Tooltip.stories.js +0 -15
  231. package/dist/Tooltip/Tooltip.stories.js.map +0 -1
  232. package/dist/Tooltip/Tooltip.types.js +0 -3
  233. package/dist/Tooltip/Tooltip.types.js.map +0 -1
  234. package/dist/Tooltip/TooltipPerformance.stories.js +0 -26
  235. package/dist/Tooltip/TooltipPerformance.stories.js.map +0 -1
  236. package/dist/Tooltip/index.js +0 -3
  237. package/dist/Tooltip/index.js.map +0 -1
  238. package/dist/Tooltip/qTip.utilities.js +0 -11
  239. package/dist/Tooltip/qTip.utilities.js.map +0 -1
  240. package/dist/setupTests.d.ts +0 -1
  241. package/dist/setupTests.js +0 -6
  242. package/dist/setupTests.js.map +0 -1
  243. package/dist/types.js +0 -2
  244. package/dist/types.js.map +0 -1
  245. package/dist/utils/browserId.js +0 -29
  246. package/dist/utils/browserId.js.map +0 -1
  247. package/dist/utils/svg.js +0 -20
  248. package/dist/utils/svg.js.map +0 -1
  249. package/dist/utils/validateStyleDimension.js +0 -14
  250. package/dist/utils/validateStyleDimension.js.map +0 -1
  251. package/dist/utils/validateStyleDimension.test.js +0 -20
  252. package/dist/utils/validateStyleDimension.test.js.map +0 -1
package/dist/index.js CHANGED
@@ -1332,7 +1332,7 @@ const arrow$4 = options => ({
1332
1332
  * clipping boundary. Alternative to `autoPlacement`.
1333
1333
  * @see https://floating-ui.com/docs/flip
1334
1334
  */
1335
- const flip$3 = function (options) {
1335
+ const flip$4 = function (options) {
1336
1336
  if (options === void 0) {
1337
1337
  options = {};
1338
1338
  }
@@ -1618,7 +1618,7 @@ const offset$2 = function (options) {
1618
1618
  * keep it in view when it will overflow the clipping boundary.
1619
1619
  * @see https://floating-ui.com/docs/shift
1620
1620
  */
1621
- const shift$2 = function (options) {
1621
+ const shift$3 = function (options) {
1622
1622
  if (options === void 0) {
1623
1623
  options = {};
1624
1624
  }
@@ -2672,7 +2672,7 @@ const offset$1 = offset$2;
2672
2672
  * keep it in view when it will overflow the clipping boundary.
2673
2673
  * @see https://floating-ui.com/docs/shift
2674
2674
  */
2675
- const shift$1 = shift$2;
2675
+ const shift$2 = shift$3;
2676
2676
 
2677
2677
  /**
2678
2678
  * Optimizes the visibility of the floating element by flipping the `placement`
@@ -2680,7 +2680,7 @@ const shift$1 = shift$2;
2680
2680
  * clipping boundary. Alternative to `autoPlacement`.
2681
2681
  * @see https://floating-ui.com/docs/flip
2682
2682
  */
2683
- const flip$2 = flip$3;
2683
+ const flip$3 = flip$4;
2684
2684
 
2685
2685
  /**
2686
2686
  * Provides data that allows you to change the size of the floating element —
@@ -3019,8 +3019,8 @@ const offset = (options, deps) => ({
3019
3019
  * keep it in view when it will overflow the clipping boundary.
3020
3020
  * @see https://floating-ui.com/docs/shift
3021
3021
  */
3022
- const shift = (options, deps) => ({
3023
- ...shift$1(options),
3022
+ const shift$1 = (options, deps) => ({
3023
+ ...shift$2(options),
3024
3024
  options: [options, deps]
3025
3025
  });
3026
3026
 
@@ -3038,8 +3038,8 @@ const limitShift = (options, deps) => ({
3038
3038
  * clipping boundary. Alternative to `autoPlacement`.
3039
3039
  * @see https://floating-ui.com/docs/flip
3040
3040
  */
3041
- const flip$1 = (options, deps) => ({
3042
- ...flip$2(options),
3041
+ const flip$2 = (options, deps) => ({
3042
+ ...flip$3(options),
3043
3043
  options: [options, deps]
3044
3044
  });
3045
3045
 
@@ -3206,13 +3206,13 @@ var PopperContent = React__namespace.forwardRef(
3206
3206
  },
3207
3207
  middleware: [
3208
3208
  offset({ mainAxis: sideOffset + arrowHeight, alignmentAxis: alignOffset }),
3209
- avoidCollisions && shift({
3209
+ avoidCollisions && shift$1({
3210
3210
  mainAxis: true,
3211
3211
  crossAxis: false,
3212
3212
  limiter: sticky === "partial" ? limitShift() : void 0,
3213
3213
  ...detectOverflowOptions
3214
3214
  }),
3215
- avoidCollisions && flip$1({ ...detectOverflowOptions }),
3215
+ avoidCollisions && flip$2({ ...detectOverflowOptions }),
3216
3216
  size({
3217
3217
  ...detectOverflowOptions,
3218
3218
  apply: ({ elements, rects, availableWidth, availableHeight }) => {
@@ -6900,6 +6900,21 @@ function autoUpdate(reference, floating, update, options) {
6900
6900
  };
6901
6901
  }
6902
6902
 
6903
+ /**
6904
+ * Optimizes the visibility of the floating element by shifting it in order to
6905
+ * keep it in view when it will overflow the clipping boundary.
6906
+ * @see https://floating-ui.com/docs/shift
6907
+ */
6908
+ const shift = shift$3;
6909
+
6910
+ /**
6911
+ * Optimizes the visibility of the floating element by flipping the `placement`
6912
+ * in order to keep it in view when the preferred placement(s) will overflow the
6913
+ * clipping boundary. Alternative to `autoPlacement`.
6914
+ * @see https://floating-ui.com/docs/flip
6915
+ */
6916
+ const flip$1 = flip$4;
6917
+
6903
6918
  /**
6904
6919
  * Provides data to position an inner element of the floating element so that it
6905
6920
  * appears centered to the reference element.
@@ -7421,8 +7436,8 @@ const QTip = () => {
7421
7436
  if (tooltipRef.current && tooltipTarget.current) {
7422
7437
  computePosition(tooltipTarget.current, tooltipRef.current, {
7423
7438
  placement: position,
7424
- middleware: [offset$2(10), arrow({ element: tooltipArrowRef.current })],
7425
- }).then(({ x, y, middlewareData }) => {
7439
+ middleware: [offset$2(10), flip$1(), shift({ padding: 8 }), arrow({ element: tooltipArrowRef.current })],
7440
+ }).then(({ x, y, middlewareData, placement: finalPlacement }) => {
7426
7441
  Object.assign(tooltipRef.current?.style, {
7427
7442
  left: `${x}px`,
7428
7443
  top: `${y}px`,
@@ -7432,7 +7447,7 @@ const QTip = () => {
7432
7447
  const arrowWidth = tooltipArrowRef.current?.offsetHeight / 2;
7433
7448
  const tooltipHeight = tooltipRef.current?.offsetHeight;
7434
7449
  const tooltipWidth = tooltipRef.current?.offsetWidth;
7435
- const style = getArrowStyle(position, x || y, arrowWidth, tooltipHeight, tooltipWidth);
7450
+ const style = getArrowStyle(finalPlacement, x || y, arrowWidth, tooltipHeight, tooltipWidth);
7436
7451
  Object.assign(tooltipArrowRef.current.style, style);
7437
7452
  }
7438
7453
  setShow(true);
@@ -7446,7 +7461,7 @@ const QTip = () => {
7446
7461
  : positionTooltip();
7447
7462
  }
7448
7463
  };
7449
- return (jsxRuntime.jsx(jsxRuntime.Fragment, { children: jsxRuntime.jsxs("div", { onMouseEnter: () => setOverTooltip(true), onMouseLeave: () => setOverTooltip(false), "data-testid": tooltipTestId, ref: tooltipRef, className: 'tw-absolute tw-rounded tw-bg-black tw-p-2 tw-text-xs tw-text-white tw-z-[9999] fade-in ' +
7464
+ return (jsxRuntime.jsx(jsxRuntime.Fragment, { children: jsxRuntime.jsxs("div", { onMouseEnter: () => setOverTooltip(true), onMouseLeave: () => setOverTooltip(false), "data-testid": tooltipTestId, ref: tooltipRef, className: 'tw-absolute tw-rounded tw-bg-black tw-max-w-96 tw-p-2 tw-text-xs tw-text-white tw-z-[9999] fade-in ' +
7450
7465
  (show ? 'tw-visible' : 'tw-invisible tw-pointer-events-none'), children: [html ? jsxRuntime.jsx(HTMLTip, { text: tooltipText }) : tooltipText, jsxRuntime.jsx("div", { className: "tw-absolute tw-w-[10px] tw-h-[10px] tw-rotate-45 tw-bg-black", ref: tooltipArrowRef })] }) }));
7451
7466
  };
7452
7467