@onepercentio/one-ui 0.29.4 → 0.29.5

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 (286) hide show
  1. package/dist/components/Switch/Switch.d.ts +1 -1
  2. package/dist/components/Switch/Switch.js +1 -1
  3. package/dist-ts/components/Switch/Switch.d.ts +1 -1
  4. package/package.json +1 -1
  5. package/src/assets/img/svg/checkbox.svg +0 -3
  6. package/src/assets/styles/index.scss +0 -2
  7. package/src/assets/styles/mixins.scss +0 -12
  8. package/src/assets/styles/variables.scss +0 -49
  9. package/src/components/AdaptiveButton/AdaptiveButton.module.scss +0 -7
  10. package/src/components/AdaptiveButton/AdaptiveButton.tsx +0 -26
  11. package/src/components/AdaptiveButton/index.tsx +0 -2
  12. package/src/components/AdaptiveContainer/AdaptiveContainer.module.scss +0 -53
  13. package/src/components/AdaptiveContainer/AdaptiveContainer.tsx +0 -200
  14. package/src/components/AdaptiveContainer/index.tsx +0 -2
  15. package/src/components/AdaptiveDialog/AdaptiveDialog.module.scss +0 -147
  16. package/src/components/AdaptiveDialog/AdaptiveDialog.tsx +0 -97
  17. package/src/components/AdaptiveDialog/index.tsx +0 -2
  18. package/src/components/AdaptiveSidebar/AdaptiveSidebar.module.scss +0 -49
  19. package/src/components/AdaptiveSidebar/AdaptiveSidebar.sample.tsx +0 -10
  20. package/src/components/AdaptiveSidebar/AdaptiveSidebar.tsx +0 -123
  21. package/src/components/AdaptiveSidebar/index.tsx +0 -2
  22. package/src/components/AnchoredTooltip/AnchoredTooltip.module.scss +0 -64
  23. package/src/components/AnchoredTooltip/AnchoredTooltip.tsx +0 -250
  24. package/src/components/AnchoredTooltip/index.tsx +0 -2
  25. package/src/components/AnimatedEntrance/AnimatedEntrance.module.scss +0 -108
  26. package/src/components/AnimatedEntrance/AnimatedEntrance.tsx +0 -227
  27. package/src/components/AnimatedEntrance/index.tsx +0 -2
  28. package/src/components/AsyncWrapper/AsyncWrapper.tsx +0 -38
  29. package/src/components/AsyncWrapper/index.tsx +0 -2
  30. package/src/components/Avatar/Avatar.module.scss +0 -22
  31. package/src/components/Avatar/Avatar.tsx +0 -31
  32. package/src/components/Avatar/index.tsx +0 -2
  33. package/src/components/BucketFill/BucketFill.module.scss +0 -36
  34. package/src/components/BucketFill/BucketFill.tsx +0 -65
  35. package/src/components/BucketFill/index.tsx +0 -2
  36. package/src/components/Button/Button.module.scss +0 -45
  37. package/src/components/Button/Button.tsx +0 -40
  38. package/src/components/Button/index.tsx +0 -2
  39. package/src/components/Card/Card.module.scss +0 -12
  40. package/src/components/Card/Card.tsx +0 -9
  41. package/src/components/Card/index.tsx +0 -2
  42. package/src/components/Chart/Chart.e2e.ts +0 -4
  43. package/src/components/Chart/Chart.logic.tsx +0 -8
  44. package/src/components/Chart/Chart.module.scss +0 -58
  45. package/src/components/Chart/Chart.tsx +0 -2
  46. package/src/components/Chart/Chart.types.ts +0 -35
  47. package/src/components/Chart/Chart.view.tsx +0 -241
  48. package/src/components/Chart/index.tsx +0 -2
  49. package/src/components/CheckBox/CheckBox.module.scss +0 -36
  50. package/src/components/CheckBox/CheckBox.tsx +0 -63
  51. package/src/components/CheckBox/index.tsx +0 -2
  52. package/src/components/CodeInput/CodeInput.module.scss +0 -5
  53. package/src/components/CodeInput/CodeInput.tsx +0 -84
  54. package/src/components/CodeInput/index.tsx +0 -2
  55. package/src/components/Collapsable/Collapsable.module.scss +0 -42
  56. package/src/components/Collapsable/Collapsable.tsx +0 -253
  57. package/src/components/Collapsable/index.tsx +0 -2
  58. package/src/components/Countdown/Countdown.tsx +0 -130
  59. package/src/components/Countdown/index.tsx +0 -2
  60. package/src/components/CurrencyInput/CurrencyInput.hook.ts +0 -37
  61. package/src/components/CurrencyInput/CurrencyInput.tsx +0 -25
  62. package/src/components/CurrencyInput/index.tsx +0 -2
  63. package/src/components/Divider/Divider.module.scss +0 -7
  64. package/src/components/Divider/Divider.tsx +0 -13
  65. package/src/components/Divider/index.tsx +0 -2
  66. package/src/components/EmailInput/EmailInput.module.scss +0 -0
  67. package/src/components/EmailInput/EmailInput.tsx +0 -51
  68. package/src/components/EmailInput/index.tsx +0 -2
  69. package/src/components/FadeIn/FadeIn.module.scss +0 -9
  70. package/src/components/FadeIn/FadeIn.tsx +0 -77
  71. package/src/components/FadeIn/index.tsx +0 -2
  72. package/src/components/FileInput/FileInput.module.scss +0 -6
  73. package/src/components/FileInput/FileInput.tsx +0 -75
  74. package/src/components/FileInput/View/BigFactory/BigFactory.module.scss +0 -20
  75. package/src/components/FileInput/View/BigFactory/BigFactory.tsx +0 -48
  76. package/src/components/FileInput/View/BigFactory/index.tsx +0 -2
  77. package/src/components/FileInput/View/Compact/Compact.module.scss +0 -68
  78. package/src/components/FileInput/View/Compact/Compact.tsx +0 -151
  79. package/src/components/FileInput/View/Compact/index.tsx +0 -2
  80. package/src/components/FileInput/View/View.types.ts +0 -12
  81. package/src/components/FileInput/index.tsx +0 -2
  82. package/src/components/FlowController/FlowController.module.scss +0 -47
  83. package/src/components/FlowController/FlowController.tsx +0 -93
  84. package/src/components/FlowController/index.tsx +0 -2
  85. package/src/components/Form/Form.tsx +0 -243
  86. package/src/components/Form/index.ts +0 -2
  87. package/src/components/Form/v2/Form.hook.ts +0 -341
  88. package/src/components/Form/v2/Form.module.scss +0 -0
  89. package/src/components/Form/v2/Form.tsx +0 -78
  90. package/src/components/Form/v2/Form.types.ts +0 -118
  91. package/src/components/Form/v2/FormField/Extensions/DateField/DateField.module.scss +0 -0
  92. package/src/components/Form/v2/FormField/Extensions/DateField/DateField.tsx +0 -73
  93. package/src/components/Form/v2/FormField/Extensions/DateField/index.tsx +0 -2
  94. package/src/components/Form/v2/FormField/Extensions/PhoneField/PhoneField.module.scss +0 -0
  95. package/src/components/Form/v2/FormField/Extensions/PhoneField/PhoneField.tsx +0 -91
  96. package/src/components/Form/v2/FormField/Extensions/PhoneField/index.tsx +0 -2
  97. package/src/components/Form/v2/FormField/FormField.module.scss +0 -0
  98. package/src/components/Form/v2/FormField/FormField.tsx +0 -378
  99. package/src/components/Form/v2/FormField/FormField.types.ts +0 -129
  100. package/src/components/Form/v2/FormField/index.tsx +0 -2
  101. package/src/components/Form/v2/index.tsx +0 -2
  102. package/src/components/Freeze/Freeze.tsx +0 -9
  103. package/src/components/Freeze/index.tsx +0 -2
  104. package/src/components/HSForms/HSForms.tsx +0 -57
  105. package/src/components/HSForms/index.tsx +0 -2
  106. package/src/components/Header/Header.module.scss +0 -119
  107. package/src/components/Header/Header.tsx +0 -138
  108. package/src/components/Header/index.tsx +0 -2
  109. package/src/components/HeaderCloseBtn/HeaderCloseBtn.module.scss +0 -44
  110. package/src/components/HeaderCloseBtn/HeaderCloseBtn.tsx +0 -28
  111. package/src/components/HeaderCloseBtn/index.tsx +0 -2
  112. package/src/components/InfinityScroll/InfinityScroll.module.scss +0 -30
  113. package/src/components/InfinityScroll/InfinityScroll.tsx +0 -187
  114. package/src/components/InfinityScroll/index.tsx +0 -2
  115. package/src/components/Input/Input.module.scss +0 -71
  116. package/src/components/Input/Input.tsx +0 -134
  117. package/src/components/Input/index.tsx +0 -2
  118. package/src/components/InstantCounter/InstantCounter.tsx +0 -77
  119. package/src/components/InstantCounter/index.tsx +0 -2
  120. package/src/components/LavaLamp/LavaLamp.data.tsx +0 -114
  121. package/src/components/LavaLamp/LavaLamp.module.scss +0 -26
  122. package/src/components/LavaLamp/LavaLamp.tsx +0 -131
  123. package/src/components/LavaLamp/index.tsx +0 -2
  124. package/src/components/LavaLamp/v2/LavaLamp.module.scss +0 -23
  125. package/src/components/LavaLamp/v2/LavaLamp.tsx +0 -197
  126. package/src/components/LinkToId/LinkToId.module.scss +0 -4
  127. package/src/components/LinkToId/LinkToId.tsx +0 -51
  128. package/src/components/LinkToId/index.tsx +0 -2
  129. package/src/components/Loader/Loader.module.scss +0 -40
  130. package/src/components/Loader/Loader.tsx +0 -18
  131. package/src/components/Loader/index.tsx +0 -2
  132. package/src/components/LoaderDotsIndicator/LoaderDotsIndicator.tsx +0 -34
  133. package/src/components/LoaderDotsIndicator/index.tsx +0 -2
  134. package/src/components/LoopableVideo/LoopableVideo.tsx +0 -37
  135. package/src/components/LoopableVideo/index.tsx +0 -2
  136. package/src/components/MainGrid/MainGrid.module.scss +0 -28
  137. package/src/components/MainGrid/MainGrid.tsx +0 -68
  138. package/src/components/MainGrid/index.tsx +0 -2
  139. package/src/components/MutableHamburgerButton/MutableHamburgerButton.module.scss +0 -220
  140. package/src/components/MutableHamburgerButton/MutableHamburgerButton.tsx +0 -38
  141. package/src/components/MutableHamburgerButton/index.tsx +0 -2
  142. package/src/components/Notification/Notification.module.scss +0 -25
  143. package/src/components/Notification/Notification.tsx +0 -13
  144. package/src/components/Notification/index.tsx +0 -2
  145. package/src/components/OrderableList/OrderableList.module.scss +0 -98
  146. package/src/components/OrderableList/OrderableList.tsx +0 -564
  147. package/src/components/OrderableList/index.tsx +0 -2
  148. package/src/components/PaginationIndicator/PaginationIndicator.tsx +0 -365
  149. package/src/components/PaginationIndicator/index.tsx +0 -2
  150. package/src/components/Parallax/Parallax.module.scss +0 -28
  151. package/src/components/Parallax/Parallax.tsx +0 -225
  152. package/src/components/Parallax/index.tsx +0 -2
  153. package/src/components/Parallax/math/helpers.ts +0 -289
  154. package/src/components/PasswordInput/PasswordInput.module.scss +0 -17
  155. package/src/components/PasswordInput/PasswordInput.tsx +0 -154
  156. package/src/components/PasswordInput/index.tsx +0 -2
  157. package/src/components/PingPongText/PingPongText.module.scss +0 -4
  158. package/src/components/PingPongText/PingPongText.tsx +0 -83
  159. package/src/components/PingPongText/index.tsx +0 -2
  160. package/src/components/PixelatedScan/PixelatedScan.module.scss +0 -86
  161. package/src/components/PixelatedScan/PixelatedScan.tsx +0 -175
  162. package/src/components/PixelatedScan/index.tsx +0 -2
  163. package/src/components/Portal/Portal.module.scss +0 -3
  164. package/src/components/Portal/Portal.tsx +0 -68
  165. package/src/components/Portal/index.tsx +0 -2
  166. package/src/components/ProgressBar/ProgressBar.module.scss +0 -44
  167. package/src/components/ProgressBar/ProgressBar.tsx +0 -124
  168. package/src/components/ProgressBar/index.tsx +0 -2
  169. package/src/components/ProgressTexts/ProgressTexts.module.scss +0 -37
  170. package/src/components/ProgressTexts/ProgressTexts.tsx +0 -85
  171. package/src/components/ProgressTexts/index.tsx +0 -2
  172. package/src/components/Radio/Radio.module.scss +0 -36
  173. package/src/components/Radio/Radio.tsx +0 -53
  174. package/src/components/Radio/index.tsx +0 -2
  175. package/src/components/SectionContainer/SectionContainer.module.scss +0 -30
  176. package/src/components/SectionContainer/SectionContainer.tsx +0 -49
  177. package/src/components/SectionContainer/index.tsx +0 -2
  178. package/src/components/Select/Select.module.scss +0 -58
  179. package/src/components/Select/Select.tsx +0 -192
  180. package/src/components/Select/index.tsx +0 -2
  181. package/src/components/Skeleton/Skeleton.module.scss +0 -21
  182. package/src/components/Skeleton/Skeleton.tsx +0 -29
  183. package/src/components/Skeleton/index.tsx +0 -2
  184. package/src/components/Spacing/Spacing.module.scss +0 -13
  185. package/src/components/Spacing/Spacing.tsx +0 -24
  186. package/src/components/Spacing/index.tsx +0 -2
  187. package/src/components/StaticScroller/StaticScroller.module.scss +0 -14
  188. package/src/components/StaticScroller/StaticScroller.tsx +0 -83
  189. package/src/components/StaticScroller/index.tsx +0 -2
  190. package/src/components/Switch/Switch.module.scss +0 -43
  191. package/src/components/Switch/Switch.tsx +0 -41
  192. package/src/components/Switch/index.tsx +0 -2
  193. package/src/components/Table/Table.module.scss +0 -76
  194. package/src/components/Table/Table.tsx +0 -152
  195. package/src/components/Table/index.tsx +0 -2
  196. package/src/components/Tabs/Tabs.module.scss +0 -40
  197. package/src/components/Tabs/Tabs.tsx +0 -104
  198. package/src/components/Tabs/index.tsx +0 -2
  199. package/src/components/Text/Text.module.scss +0 -81
  200. package/src/components/Text/Text.tsx +0 -42
  201. package/src/components/Text/index.tsx +0 -2
  202. package/src/components/Transition/MasksFactory/DiagonalReveal.tsx +0 -47
  203. package/src/components/Transition/MasksFactory/DiagonalSquareToBalls.tsx +0 -78
  204. package/src/components/Transition/MasksFactory/PhysicsSquares.tsx +0 -106
  205. package/src/components/Transition/MasksFactory/SquareToBalls.tsx +0 -66
  206. package/src/components/Transition/MasksFactory/utils.ts +0 -35
  207. package/src/components/Transition/Transition.module.scss +0 -211
  208. package/src/components/Transition/Transition.tsx +0 -495
  209. package/src/components/Transition/index.tsx +0 -2
  210. package/src/components/UncontrolledTransition/UncontrolledTransition.ai.md +0 -9
  211. package/src/components/UncontrolledTransition/UncontrolledTransition.sample.tsx +0 -34
  212. package/src/components/UncontrolledTransition/UncontrolledTransition.tsx +0 -143
  213. package/src/components/UncontrolledTransition/index.tsx +0 -2
  214. package/src/components/WalletConnectionWrapper/WalletConnectionWrapper.tsx +0 -212
  215. package/src/components/WalletConnectionWrapper/index.tsx +0 -2
  216. package/src/components/utilitary/ScrollAndFocusLock/ScrollAndFocusLock.module.scss +0 -5
  217. package/src/components/utilitary/ScrollAndFocusLock/ScrollAndFocusLock.tsx +0 -52
  218. package/src/components/utilitary/ScrollAndFocusLock/index.tsx +0 -2
  219. package/src/context/AsyncProcess.tsx +0 -107
  220. package/src/context/ContextAsyncControl.tsx +0 -89
  221. package/src/context/CustomBrowserRouter.tsx +0 -55
  222. package/src/context/OneUIProvider.tsx +0 -308
  223. package/src/hooks/logs/useDependencyChangeDetection.ts +0 -25
  224. package/src/hooks/logs/useIsMounting.ts +0 -7
  225. package/src/hooks/persistence/useLocalStorage.ts +0 -45
  226. package/src/hooks/shims/ObjectWatchShim.ts +0 -56
  227. package/src/hooks/ui/useAdaptiveImage.tsx +0 -36
  228. package/src/hooks/ui/useAlternating.tsx +0 -22
  229. package/src/hooks/ui/useBreakpoint.tsx +0 -21
  230. package/src/hooks/ui/useCustomScrollbar.module.scss +0 -20
  231. package/src/hooks/ui/useCustomScrollbar.tsx +0 -22
  232. package/src/hooks/ui/useEffectIf.ts +0 -11
  233. package/src/hooks/ui/useMouseHover.tsx +0 -26
  234. package/src/hooks/ui/usePaginationControls.module.scss +0 -16
  235. package/src/hooks/ui/usePaginationControls.tsx +0 -176
  236. package/src/hooks/ui/useSnapToViewport.module.scss +0 -6
  237. package/src/hooks/ui/useSnapToViewport.ts +0 -28
  238. package/src/hooks/ui/useTilt.tsx +0 -219
  239. package/src/hooks/ui/useZoomable.module.scss +0 -34
  240. package/src/hooks/ui/useZoomable.tsx +0 -144
  241. package/src/hooks/useAsyncControl.ai.md +0 -25
  242. package/src/hooks/useAsyncControl.ts +0 -101
  243. package/src/hooks/useContainedRepositioning.ts +0 -110
  244. package/src/hooks/useCustomHistory.ts +0 -14
  245. package/src/hooks/useElementFit.ts +0 -82
  246. package/src/hooks/useFirestoreWatch.ts +0 -54
  247. package/src/hooks/useForm.ts +0 -49
  248. package/src/hooks/useFreeze.ts +0 -12
  249. package/src/hooks/useHero.module.scss +0 -41
  250. package/src/hooks/useHero.ts +0 -514
  251. package/src/hooks/useIntersection.ts +0 -32
  252. package/src/hooks/useMergeRefs.ts +0 -29
  253. package/src/hooks/useObserve.ts +0 -24
  254. package/src/hooks/usePagination.ts +0 -228
  255. package/src/hooks/usePooledOperation.ts +0 -54
  256. package/src/hooks/usePooling.ts +0 -46
  257. package/src/hooks/useRebound.ts +0 -23
  258. package/src/hooks/useShortIntl.ai.md +0 -5
  259. package/src/hooks/useShortIntl.ts +0 -97
  260. package/src/hooks/utility/useAsyncMemo.ts +0 -43
  261. package/src/hooks/utility/useDepChange.ts +0 -11
  262. package/src/hooks/utility/useEvents.ts +0 -33
  263. package/src/hooks/utility/useImmediate.ts +0 -8
  264. package/src/hooks/utility/useManualInit.ts +0 -24
  265. package/src/hooks/utility/useModule.ts +0 -15
  266. package/src/hooks/utility/useQuery.ts +0 -15
  267. package/src/hooks/utility/useUniqueEffect.ts +0 -22
  268. package/src/index.preprocess.ts +0 -82
  269. package/src/index.ts +0 -229
  270. package/src/models/DebugLogger.ts +0 -7
  271. package/src/models/GenericContract.ts +0 -169
  272. package/src/models/Orbs.ts +0 -97
  273. package/src/reac-app-env.d.ts +0 -6
  274. package/src/storybook/assets/video/txt-reversed.mp4 +0 -0
  275. package/src/storybookUtils/index.tsx +0 -53
  276. package/src/test.tsx +0 -0
  277. package/src/type-utils.ts +0 -49
  278. package/src/types.ts +0 -199
  279. package/src/utility.d.ts +0 -70
  280. package/src/utils/blockchain.ts +0 -43
  281. package/src/utils/e2e.ts +0 -55
  282. package/src/utils/flatten.ts +0 -17
  283. package/src/utils/formatters.ts +0 -36
  284. package/src/utils/html.utils.ts +0 -3
  285. package/src/utils/ownEvent.ts +0 -8
  286. package/src/utils/test.ts +0 -20
@@ -1,241 +0,0 @@
1
- import React, {
2
- ComponentRef,
3
- ElementRef,
4
- PropsWithChildren,
5
- ReactNode,
6
- useEffect,
7
- useLayoutEffect,
8
- useMemo,
9
- useRef,
10
- useState,
11
- } from "react";
12
- import throttle from "lodash/throttle";
13
- import { ChartViewProps } from "./Chart.types";
14
- import Styles from "./Chart.module.scss";
15
- import { ChartDataTestIds } from "./Chart.e2e";
16
- import AnchoredTooltip from "../AnchoredTooltip";
17
-
18
- const DEFAULT_STYLE = {
19
- lineColor: "#000",
20
- pointColor: "#000",
21
- textColor: "#fff",
22
- };
23
-
24
- function FloatingTooltip({
25
- children,
26
- x,
27
- y,
28
- hoverOnly,
29
- height,
30
- style,
31
- }: {
32
- children: ReactNode;
33
- x: number;
34
- y: number;
35
- hoverOnly: boolean;
36
- height: number;
37
- style: Pick<
38
- NonNullable<NonNullable<ChartViewProps["style"]>[number]>,
39
- "pointColor" | "lineColor" | "textColor"
40
- >;
41
- }) {
42
- const [ope, setOpen] = useState(() => (hoverOnly ? false : true));
43
- const ref = useRef<ComponentRef<typeof AnchoredTooltip>>(null);
44
- const circleRef = useRef<SVGCircleElement>(null);
45
- useEffect(() => {
46
- const animateEl = circleRef.current!.children.item(0) as SVGAnimateElement;
47
- let interval: NodeJS.Timeout;
48
- animateEl.addEventListener("beginEvent", () => {
49
- interval = setInterval(() => ref.current!.updatePosition(), 1000 / 24);
50
- });
51
- animateEl.addEventListener("endEvent", () => {
52
- clearInterval(interval);
53
- ref.current!.updatePosition();
54
- });
55
- }, []);
56
-
57
- const actions = useMemo(
58
- () =>
59
- hoverOnly
60
- ? {
61
- onMouseEnter: () => setOpen(true),
62
- onMouseOut: () => setOpen(false),
63
- }
64
- : {},
65
- [hoverOnly]
66
- );
67
-
68
- return (
69
- <>
70
- <circle
71
- ref={circleRef}
72
- r={height * 0.01}
73
- cx={x}
74
- cy={y}
75
- style={
76
- {
77
- "--point-color": style.pointColor,
78
- } as any
79
- }
80
- {...actions}
81
- >
82
- <animate attributeName="cy" values={`${height};${y}`} dur="1s" />
83
- </circle>
84
- <AnchoredTooltip
85
- ref={ref}
86
- containInViewport={false}
87
- anchorRef={circleRef as any}
88
- open={ope}
89
- className={Styles.tooltipContainer}
90
- style={{
91
- "--line-color": style.lineColor,
92
- "--text-color": style.textColor,
93
- }}
94
- >
95
- {children as any}
96
- </AnchoredTooltip>
97
- </>
98
- );
99
- }
100
-
101
- /**
102
- * Draws a simple line chart with some animation
103
- **/
104
- export default function ChartView({
105
- bounds: [[startX, endX, stepsX], [startY, endY, stepsY]],
106
- data = [],
107
- points = [],
108
- label,
109
- style: groupStyle = [],
110
- }: ChartViewProps) {
111
- const [dim, setDIm] = useState<{ width: number; height: number }>();
112
- const chartRef = useRef<HTMLDivElement>(null);
113
- useLayoutEffect(() => {
114
- setDIm({
115
- width: chartRef.current!.clientWidth,
116
- height: chartRef.current!.clientHeight,
117
- });
118
- }, []);
119
- const { width, height } = dim || {};
120
-
121
- const howMuchStepsY = useMemo(
122
- () => (endY - startY) / stepsY + 1,
123
- [endY, startY, stepsY]
124
- );
125
- const yAxis = useMemo(() => {
126
- return new Array(howMuchStepsY).fill(undefined).map((_, i) => {
127
- return <span>{label.y(endY - i * stepsY)}</span>;
128
- });
129
- }, [startY, endY, stepsY, howMuchStepsY]);
130
-
131
- const howMuchStepsX = useMemo(
132
- () => (endX - startX) / stepsX + 1,
133
- [endX, startX, stepsX]
134
- );
135
- const xAxis = useMemo(() => {
136
- return new Array(howMuchStepsX).fill(undefined).map((_, i) => {
137
- return <span>{label.x(startX + i * stepsX)}</span>;
138
- });
139
- }, [startX, endX, stepsX]);
140
-
141
- const { polylines, tooltips } = useMemo(() => {
142
- const calculate =
143
- (end: number, start: number, overrideScale: number = 100) =>
144
- (point: number) => {
145
- const max = end - start;
146
- const current = point - start;
147
-
148
- return (current * overrideScale) / max;
149
- };
150
- const calculateX = calculate(endX, startX, width);
151
- const calculateY = calculate(endY, startY, height);
152
- return {
153
- tooltips: points.map((pointsCategory, i) => {
154
- const style = groupStyle[i] || DEFAULT_STYLE;
155
- return pointsCategory.map(([x, y, label, onlyOnHover = false]) => {
156
- return (
157
- <FloatingTooltip
158
- x={calculateX(x)}
159
- y={height! - calculateY(y)}
160
- height={height!}
161
- style={style}
162
- hoverOnly={onlyOnHover}
163
- >
164
- {label}
165
- </FloatingTooltip>
166
- );
167
- });
168
- }),
169
- polylines: data.map((lineData, i) => {
170
- const style = groupStyle[i] || DEFAULT_STYLE;
171
- const calculateLines = (yOverride?: number) => {
172
- return lineData
173
- .map(
174
- ([x, y]) =>
175
- `${calculateX(x)},${
176
- yOverride === undefined ? height! - calculateY(y) : yOverride
177
- }`
178
- )
179
- .join(" ");
180
- };
181
- return (
182
- <polyline
183
- strokeLinejoin="round"
184
- strokeLinecap="round"
185
- points={calculateLines()}
186
- fill="none"
187
- strokeWidth={5}
188
- style={
189
- {
190
- "--line-color": style.lineColor,
191
- } as any
192
- }
193
- >
194
- <animate
195
- attributeName="points"
196
- attributeType="XML"
197
- values={[calculateLines(height), calculateLines()].join("; ")}
198
- dur="1s"
199
- />
200
- </polyline>
201
- );
202
- }),
203
- };
204
- }, [data, width, height]);
205
-
206
- const paddingY = useMemo(() => {
207
- const stepSizeY = height! / (howMuchStepsY - 1);
208
- return stepSizeY / 2;
209
- }, [howMuchStepsY, height]);
210
-
211
- const paddingX = useMemo(() => {
212
- const stepSizeX = width! / (howMuchStepsX - 1);
213
- return stepSizeX / 2;
214
- }, [howMuchStepsX, width]);
215
-
216
- return (
217
- <div className={Styles.chartRoot}>
218
- <div className={Styles.yAxis} data-testid={ChartDataTestIds.Y_AXIS}>
219
- {yAxis}
220
- </div>
221
- <div ref={chartRef} className={Styles.chartContainer}>
222
- {width && (
223
- <svg
224
- className={Styles.chart}
225
- viewBox={`${-paddingX} ${-paddingY} ${width + paddingX * 2} ${
226
- height! + paddingY * 2
227
- }`}
228
- preserveAspectRatio="none"
229
- >
230
- {polylines}
231
- {tooltips}
232
- </svg>
233
- )}
234
- </div>
235
- &nbsp;
236
- <div className={Styles.xAxis} data-testid={ChartDataTestIds.X_AXIS}>
237
- {xAxis}
238
- </div>
239
- </div>
240
- );
241
- }
@@ -1,2 +0,0 @@
1
- export { default } from "./Chart";
2
- export * from "./Chart";
@@ -1,36 +0,0 @@
1
- @import "../../assets/styles/index.scss";
2
-
3
- .container {
4
- display: flex;
5
- line-height: 1.5em;
6
- vertical-align: middle;
7
- input {
8
- max-width: 0px;
9
- max-height: 0px;
10
- width: 0;
11
- height: 0;
12
- opacity: 0;
13
- }
14
-
15
- > span:first-child {
16
- visibility: visible;
17
- width: 1.5em;
18
- height: 1.5em;
19
- border-radius: 0.45em;
20
- background-image: url("../../assets/img/svg/checkbox.svg");
21
- background-color: transparent;
22
- transition: background-color 250ms, border 250ms, box-shadow 250ms;
23
- border: 1px solid rgb(40, 43, 53);
24
- box-shadow: 0px 0px 0px -4px $digitalBlue;
25
- flex-shrink: 0;
26
-
27
- &.wContent {
28
- margin-right: 0.45em;
29
- }
30
- }
31
- > span:first-child.checked {
32
- background-color: $digitalBlue;
33
- border: 1px solid $digitalBlue;
34
- box-shadow: 0px 0px 12px -4px $digitalBlue;
35
- }
36
- }
@@ -1,63 +0,0 @@
1
- import React, { PropsWithChildren } from "react";
2
- import { useOneUIConfig } from "../../context/OneUIProvider";
3
- import Styles from "./CheckBox.module.scss";
4
-
5
- /**
6
- * A simple checkbox with nissan guidelines
7
- **/
8
- export default function CheckBox({
9
- checked,
10
- onToggle,
11
- label,
12
- className = "",
13
- size = undefined,
14
- groupId,
15
- value,
16
- ...props
17
- }: PropsWithChildren<{
18
- checked: boolean;
19
- onToggle: (checked: boolean) => void;
20
- label: React.ReactNode;
21
- className?: string;
22
- size?: number;
23
- groupId: string;
24
- value: string;
25
- }> &
26
- Omit<
27
- React.DetailedHTMLProps<
28
- React.HTMLAttributes<HTMLSpanElement>,
29
- HTMLSpanElement
30
- >,
31
- "onToggle"
32
- >) {
33
- const Checkbox = useOneUIConfig(
34
- "component.checkbox.Component",
35
- "span" as any
36
- ) as any;
37
- return (
38
- <label
39
- className={`${Styles.container} ${className}`}
40
- style={{ fontSize: size }}
41
- onClick={(e) => {
42
- onToggle(!checked);
43
- e.preventDefault();
44
- }}
45
- >
46
- <Checkbox
47
- {...props}
48
- className={`${checked ? Styles.checked : ""} ${
49
- label ? Styles.wContent : ""
50
- }`}
51
- />
52
- <input
53
- type="checkbox"
54
- name={groupId}
55
- id={value}
56
- checked={checked}
57
- readOnly
58
- />
59
-
60
- {label}
61
- </label>
62
- );
63
- }
@@ -1,2 +0,0 @@
1
- export { default } from "./CheckBox";
2
- export * from "./CheckBox";
@@ -1,5 +0,0 @@
1
- .root {
2
- min-height: 150px;
3
- height: 100%;
4
- flex: 1;
5
- }
@@ -1,84 +0,0 @@
1
- import React, { useEffect, useMemo, useRef } from "react";
2
- import { Uri } from "monaco-editor";
3
- import Styles from "./CodeInput.module.scss";
4
- import Loader from "../Loader";
5
- import useModule from "../../hooks/utility/useModule";
6
-
7
- window.MonacoEnvironment = {
8
- getWorkerUrl: function (moduleId, label) {
9
- if (label === "typescript" || label === "javascript")
10
- return "./ts.worker.js";
11
- return "./editor.worker.js";
12
- },
13
- };
14
-
15
- /**
16
- * Allows the user to input code using monaco editor
17
- **/
18
- export default function CodeInput({
19
- codeSample,
20
- onChange,
21
- mode,
22
- }: {
23
- codeSample?: string;
24
- onChange?: (code: string) => void;
25
- mode?: "dark" | "light";
26
- }) {
27
- const divRef = useRef<HTMLDivElement>(null);
28
- const Monaco = useModule(() => import("monaco-editor"));
29
- const content = useMemo(() => {
30
- if (!Monaco) return <Loader />;
31
- else {
32
- return null;
33
- }
34
- }, [Monaco]);
35
- const editorRef =
36
- useRef<import("monaco-editor").editor.IStandaloneCodeEditor>(undefined);
37
- useEffect(() => {
38
- if (Monaco) {
39
- Monaco.languages.typescript.typescriptDefaults.setDiagnosticsOptions({
40
- noSemanticValidation: true,
41
- });
42
- const editor = Monaco.editor.create(divRef.current!, {
43
- language: "typescript",
44
- scrollBeyondLastLine: false,
45
- minimap: { enabled: false },
46
- folding: false,
47
- readOnly: !onChange,
48
- theme: mode === "dark" ? "vs-dark" : undefined,
49
- automaticLayout: true
50
- });
51
- editor.onDidContentSizeChange(() => {
52
- if (!editorRef.current) {
53
- editorRef.current = editor;
54
- }
55
- });
56
- editor.onDidChangeModelContent(() => {
57
- if (onChange) onChange(editor.getModel()!.getValue());
58
- });
59
- const model = Monaco.editor.createModel(
60
- codeSample || "",
61
- "typescript",
62
- Uri.file(`example.tsx`)
63
- );
64
- editor.setModel(model);
65
- return () => {
66
- model.dispose();
67
- };
68
- }
69
- }, [Monaco]);
70
- useEffect(() => {
71
- if (!codeSample) return;
72
- const editor = editorRef.current;
73
- if (!editor) return;
74
- const model = editor.getModel();
75
- if (!model) return;
76
- const currentValue = model.getValue();
77
- if (codeSample !== currentValue) model.setValue(codeSample);
78
- }, [codeSample]);
79
- return (
80
- <div ref={divRef} className={Styles.root}>
81
- {content}
82
- </div>
83
- );
84
- }
@@ -1,2 +0,0 @@
1
- export { default } from "./CodeInput";
2
- export * from "./CodeInput";
@@ -1,42 +0,0 @@
1
- @import "../../assets/styles/index.scss";
2
-
3
- .container {
4
- > .title {
5
- cursor: pointer;
6
- margin: 0px;
7
- display: block;
8
- }
9
- }
10
-
11
- .open .title::after {
12
- transform: translateX(-0.5em) rotateX(180deg) rotateZ(45deg);
13
- }
14
- .closed .title::after {
15
- transform: translateX(-0.5em) rotateX(0deg) rotateZ(45deg);
16
- }
17
-
18
- .content {
19
- width: 100%;
20
- max-width: 500px;
21
- overflow: hidden;
22
- transition: height $fast ease-in;
23
- height: 0px;
24
- &.float {
25
- width: initial;
26
- max-width: initial;
27
- position: fixed;
28
- z-index: 100;
29
- background: $mainBackgroundColor;
30
- overflow: auto;
31
- }
32
- &.block {
33
- box-sizing: initial;
34
- }
35
- &.transitionMarginTop {
36
- transition: height $fast ease-in, margin-top $fast ease-in;
37
- }
38
- }
39
-
40
- .open {
41
- transition: height $fast ease-out;
42
- }