@stack-spot/citric-react 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (345) hide show
  1. package/dist/citric.css +2580 -0
  2. package/dist/components/Accordion.d.ts +33 -0
  3. package/dist/components/Accordion.d.ts.map +1 -0
  4. package/dist/components/Accordion.js +19 -0
  5. package/dist/components/Accordion.js.map +1 -0
  6. package/dist/components/Alert.d.ts +11 -0
  7. package/dist/components/Alert.d.ts.map +1 -0
  8. package/dist/components/Alert.js +5 -0
  9. package/dist/components/Alert.js.map +1 -0
  10. package/dist/components/AsyncContent.d.ts +30 -0
  11. package/dist/components/AsyncContent.d.ts.map +1 -0
  12. package/dist/components/AsyncContent.js +33 -0
  13. package/dist/components/AsyncContent.js.map +1 -0
  14. package/dist/components/Avatar.d.ts +22 -0
  15. package/dist/components/Avatar.d.ts.map +1 -0
  16. package/dist/components/Avatar.js +9 -0
  17. package/dist/components/Avatar.js.map +1 -0
  18. package/dist/components/AvatarGroup.d.ts +25 -0
  19. package/dist/components/AvatarGroup.d.ts.map +1 -0
  20. package/dist/components/AvatarGroup.js +9 -0
  21. package/dist/components/AvatarGroup.js.map +1 -0
  22. package/dist/components/Badge.d.ts +18 -0
  23. package/dist/components/Badge.d.ts.map +1 -0
  24. package/dist/components/Badge.js +7 -0
  25. package/dist/components/Badge.js.map +1 -0
  26. package/dist/components/Blockquote.d.ts +5 -0
  27. package/dist/components/Blockquote.d.ts.map +1 -0
  28. package/dist/components/Blockquote.js +4 -0
  29. package/dist/components/Blockquote.js.map +1 -0
  30. package/dist/components/Breadcrumb.d.ts +12 -0
  31. package/dist/components/Breadcrumb.d.ts.map +1 -0
  32. package/dist/components/Breadcrumb.js +8 -0
  33. package/dist/components/Breadcrumb.js.map +1 -0
  34. package/dist/components/Button.d.ts +42 -0
  35. package/dist/components/Button.d.ts.map +1 -0
  36. package/dist/components/Button.js +25 -0
  37. package/dist/components/Button.js.map +1 -0
  38. package/dist/components/Card.d.ts +19 -0
  39. package/dist/components/Card.d.ts.map +1 -0
  40. package/dist/components/Card.js +5 -0
  41. package/dist/components/Card.js.map +1 -0
  42. package/dist/components/Checkbox.d.ts +14 -0
  43. package/dist/components/Checkbox.d.ts.map +1 -0
  44. package/dist/components/Checkbox.js +7 -0
  45. package/dist/components/Checkbox.js.map +1 -0
  46. package/dist/components/CheckboxGroup.d.ts +53 -0
  47. package/dist/components/CheckboxGroup.d.ts.map +1 -0
  48. package/dist/components/CheckboxGroup.js +17 -0
  49. package/dist/components/CheckboxGroup.js.map +1 -0
  50. package/dist/components/Circle.d.ts +18 -0
  51. package/dist/components/Circle.d.ts.map +1 -0
  52. package/dist/components/Circle.js +5 -0
  53. package/dist/components/Circle.js.map +1 -0
  54. package/dist/components/CitricComponent.d.ts +14 -0
  55. package/dist/components/CitricComponent.d.ts.map +1 -0
  56. package/dist/components/CitricComponent.js +15 -0
  57. package/dist/components/CitricComponent.js.map +1 -0
  58. package/dist/components/Divider.d.ts +14 -0
  59. package/dist/components/Divider.d.ts.map +1 -0
  60. package/dist/components/Divider.js +5 -0
  61. package/dist/components/Divider.js.map +1 -0
  62. package/dist/components/ErrorBoundary.d.ts +32 -0
  63. package/dist/components/ErrorBoundary.d.ts.map +1 -0
  64. package/dist/components/ErrorBoundary.js +46 -0
  65. package/dist/components/ErrorBoundary.js.map +1 -0
  66. package/dist/components/ErrorMessage.d.ts +4 -0
  67. package/dist/components/ErrorMessage.d.ts.map +1 -0
  68. package/dist/components/ErrorMessage.js +7 -0
  69. package/dist/components/ErrorMessage.js.map +1 -0
  70. package/dist/components/FallbackBoundary.d.ts +13 -0
  71. package/dist/components/FallbackBoundary.d.ts.map +1 -0
  72. package/dist/components/FallbackBoundary.js +11 -0
  73. package/dist/components/FallbackBoundary.js.map +1 -0
  74. package/dist/components/Favorite.d.ts +23 -0
  75. package/dist/components/Favorite.d.ts.map +1 -0
  76. package/dist/components/Favorite.js +5 -0
  77. package/dist/components/Favorite.js.map +1 -0
  78. package/dist/components/FieldGroup.d.ts +14 -0
  79. package/dist/components/FieldGroup.d.ts.map +1 -0
  80. package/dist/components/FieldGroup.js +5 -0
  81. package/dist/components/FieldGroup.js.map +1 -0
  82. package/dist/components/Form.d.ts +5 -0
  83. package/dist/components/Form.d.ts.map +1 -0
  84. package/dist/components/Form.js +6 -0
  85. package/dist/components/Form.js.map +1 -0
  86. package/dist/components/FormGroup.d.ts +22 -0
  87. package/dist/components/FormGroup.d.ts.map +1 -0
  88. package/dist/components/FormGroup.js +8 -0
  89. package/dist/components/FormGroup.js.map +1 -0
  90. package/dist/components/IconBox.d.ts +46 -0
  91. package/dist/components/IconBox.d.ts.map +1 -0
  92. package/dist/components/IconBox.js +29 -0
  93. package/dist/components/IconBox.js.map +1 -0
  94. package/dist/components/Input.d.ts +15 -0
  95. package/dist/components/Input.d.ts.map +1 -0
  96. package/dist/components/Input.js +18 -0
  97. package/dist/components/Input.js.map +1 -0
  98. package/dist/components/Link.d.ts +20 -0
  99. package/dist/components/Link.d.ts.map +1 -0
  100. package/dist/components/Link.js +21 -0
  101. package/dist/components/Link.js.map +1 -0
  102. package/dist/components/LoadingPanel.d.ts +2 -0
  103. package/dist/components/LoadingPanel.d.ts.map +1 -0
  104. package/dist/components/LoadingPanel.js +5 -0
  105. package/dist/components/LoadingPanel.js.map +1 -0
  106. package/dist/components/MenuOverlay/Menu.d.ts +6 -0
  107. package/dist/components/MenuOverlay/Menu.d.ts.map +1 -0
  108. package/dist/components/MenuOverlay/Menu.js +100 -0
  109. package/dist/components/MenuOverlay/Menu.js.map +1 -0
  110. package/dist/components/MenuOverlay/context.d.ts +6 -0
  111. package/dist/components/MenuOverlay/context.d.ts.map +1 -0
  112. package/dist/components/MenuOverlay/context.js +16 -0
  113. package/dist/components/MenuOverlay/context.js.map +1 -0
  114. package/dist/components/MenuOverlay/index.d.ts +3 -0
  115. package/dist/components/MenuOverlay/index.d.ts.map +1 -0
  116. package/dist/components/MenuOverlay/index.js +23 -0
  117. package/dist/components/MenuOverlay/index.js.map +1 -0
  118. package/dist/components/MenuOverlay/keyboard.d.ts +2 -0
  119. package/dist/components/MenuOverlay/keyboard.d.ts.map +1 -0
  120. package/dist/components/MenuOverlay/keyboard.js +66 -0
  121. package/dist/components/MenuOverlay/keyboard.js.map +1 -0
  122. package/dist/components/MenuOverlay/types.d.ts +166 -0
  123. package/dist/components/MenuOverlay/types.d.ts.map +1 -0
  124. package/dist/components/MenuOverlay/types.js +2 -0
  125. package/dist/components/MenuOverlay/types.js.map +1 -0
  126. package/dist/components/Overlay/context.d.ts +4 -0
  127. package/dist/components/Overlay/context.d.ts.map +1 -0
  128. package/dist/components/Overlay/context.js +7 -0
  129. package/dist/components/Overlay/context.js.map +1 -0
  130. package/dist/components/Overlay/index.d.ts +14 -0
  131. package/dist/components/Overlay/index.d.ts.map +1 -0
  132. package/dist/components/Overlay/index.js +120 -0
  133. package/dist/components/Overlay/index.js.map +1 -0
  134. package/dist/components/Overlay/types.d.ts +67 -0
  135. package/dist/components/Overlay/types.d.ts.map +1 -0
  136. package/dist/components/Overlay/types.js +2 -0
  137. package/dist/components/Overlay/types.js.map +1 -0
  138. package/dist/components/Pagination.d.ts +28 -0
  139. package/dist/components/Pagination.d.ts.map +1 -0
  140. package/dist/components/Pagination.js +30 -0
  141. package/dist/components/Pagination.js.map +1 -0
  142. package/dist/components/ProgressBar.d.ts +12 -0
  143. package/dist/components/ProgressBar.d.ts.map +1 -0
  144. package/dist/components/ProgressBar.js +7 -0
  145. package/dist/components/ProgressBar.js.map +1 -0
  146. package/dist/components/ProgressCircular.d.ts +16 -0
  147. package/dist/components/ProgressCircular.d.ts.map +1 -0
  148. package/dist/components/ProgressCircular.js +7 -0
  149. package/dist/components/ProgressCircular.js.map +1 -0
  150. package/dist/components/RadioGroup.d.ts +48 -0
  151. package/dist/components/RadioGroup.d.ts.map +1 -0
  152. package/dist/components/RadioGroup.js +17 -0
  153. package/dist/components/RadioGroup.js.map +1 -0
  154. package/dist/components/Rating.d.ts +13 -0
  155. package/dist/components/Rating.d.ts.map +1 -0
  156. package/dist/components/Rating.js +4 -0
  157. package/dist/components/Rating.js.map +1 -0
  158. package/dist/components/Select/RichSelect.d.ts +5 -0
  159. package/dist/components/Select/RichSelect.d.ts.map +1 -0
  160. package/dist/components/Select/RichSelect.js +152 -0
  161. package/dist/components/Select/RichSelect.js.map +1 -0
  162. package/dist/components/Select/SimpleSelect.d.ts +5 -0
  163. package/dist/components/Select/SimpleSelect.d.ts.map +1 -0
  164. package/dist/components/Select/SimpleSelect.js +24 -0
  165. package/dist/components/Select/SimpleSelect.js.map +1 -0
  166. package/dist/components/Select/index.d.ts +4 -0
  167. package/dist/components/Select/index.d.ts.map +1 -0
  168. package/dist/components/Select/index.js +7 -0
  169. package/dist/components/Select/index.js.map +1 -0
  170. package/dist/components/Select/types.d.ts +118 -0
  171. package/dist/components/Select/types.d.ts.map +1 -0
  172. package/dist/components/Select/types.js +2 -0
  173. package/dist/components/Select/types.js.map +1 -0
  174. package/dist/components/SelectBox.d.ts +65 -0
  175. package/dist/components/SelectBox.d.ts.map +1 -0
  176. package/dist/components/SelectBox.js +26 -0
  177. package/dist/components/SelectBox.js.map +1 -0
  178. package/dist/components/Skeleton.d.ts +30 -0
  179. package/dist/components/Skeleton.d.ts.map +1 -0
  180. package/dist/components/Skeleton.js +5 -0
  181. package/dist/components/Skeleton.js.map +1 -0
  182. package/dist/components/Slider.d.ts +32 -0
  183. package/dist/components/Slider.d.ts.map +1 -0
  184. package/dist/components/Slider.js +19 -0
  185. package/dist/components/Slider.js.map +1 -0
  186. package/dist/components/SmartTable.d.ts +87 -0
  187. package/dist/components/SmartTable.d.ts.map +1 -0
  188. package/dist/components/SmartTable.js +16 -0
  189. package/dist/components/SmartTable.js.map +1 -0
  190. package/dist/components/Stepper.d.ts +52 -0
  191. package/dist/components/Stepper.d.ts.map +1 -0
  192. package/dist/components/Stepper.js +53 -0
  193. package/dist/components/Stepper.js.map +1 -0
  194. package/dist/components/Switch.d.ts +10 -0
  195. package/dist/components/Switch.d.ts.map +1 -0
  196. package/dist/components/Switch.js +7 -0
  197. package/dist/components/Switch.js.map +1 -0
  198. package/dist/components/Table.d.ts +106 -0
  199. package/dist/components/Table.d.ts.map +1 -0
  200. package/dist/components/Table.js +86 -0
  201. package/dist/components/Table.js.map +1 -0
  202. package/dist/components/Tabs/TabController.d.ts +11 -0
  203. package/dist/components/Tabs/TabController.d.ts.map +1 -0
  204. package/dist/components/Tabs/TabController.js +39 -0
  205. package/dist/components/Tabs/TabController.js.map +1 -0
  206. package/dist/components/Tabs/index.d.ts +5 -0
  207. package/dist/components/Tabs/index.d.ts.map +1 -0
  208. package/dist/components/Tabs/index.js +37 -0
  209. package/dist/components/Tabs/index.js.map +1 -0
  210. package/dist/components/Tabs/types.d.ts +46 -0
  211. package/dist/components/Tabs/types.d.ts.map +1 -0
  212. package/dist/components/Tabs/types.js +2 -0
  213. package/dist/components/Tabs/types.js.map +1 -0
  214. package/dist/components/Tabs/utils.d.ts +3 -0
  215. package/dist/components/Tabs/utils.d.ts.map +1 -0
  216. package/dist/components/Tabs/utils.js +5 -0
  217. package/dist/components/Tabs/utils.js.map +1 -0
  218. package/dist/components/Text.d.ts +27 -0
  219. package/dist/components/Text.d.ts.map +1 -0
  220. package/dist/components/Text.js +45 -0
  221. package/dist/components/Text.js.map +1 -0
  222. package/dist/components/Textarea.d.ts +8 -0
  223. package/dist/components/Textarea.d.ts.map +1 -0
  224. package/dist/components/Textarea.js +4 -0
  225. package/dist/components/Textarea.js.map +1 -0
  226. package/dist/components/Tooltip.d.ts +25 -0
  227. package/dist/components/Tooltip.d.ts.map +1 -0
  228. package/dist/components/Tooltip.js +18 -0
  229. package/dist/components/Tooltip.js.map +1 -0
  230. package/dist/components/layout.d.ts +46 -0
  231. package/dist/components/layout.d.ts.map +1 -0
  232. package/dist/components/layout.js +18 -0
  233. package/dist/components/layout.js.map +1 -0
  234. package/dist/context/CitricContext.d.ts +3 -0
  235. package/dist/context/CitricContext.d.ts.map +1 -0
  236. package/dist/context/CitricContext.js +3 -0
  237. package/dist/context/CitricContext.js.map +1 -0
  238. package/dist/context/CitricProvider.d.ts +9 -0
  239. package/dist/context/CitricProvider.d.ts.map +1 -0
  240. package/dist/context/CitricProvider.js +8 -0
  241. package/dist/context/CitricProvider.js.map +1 -0
  242. package/dist/context/hooks.d.ts +2 -0
  243. package/dist/context/hooks.d.ts.map +1 -0
  244. package/dist/context/hooks.js +6 -0
  245. package/dist/context/hooks.js.map +1 -0
  246. package/dist/index.d.ts +48 -0
  247. package/dist/index.d.ts.map +1 -0
  248. package/dist/index.js +48 -0
  249. package/dist/index.js.map +1 -0
  250. package/dist/overlay.d.ts +83 -0
  251. package/dist/overlay.d.ts.map +1 -0
  252. package/dist/overlay.js +199 -0
  253. package/dist/overlay.js.map +1 -0
  254. package/dist/theme.css +419 -0
  255. package/dist/types.d.ts +175 -0
  256. package/dist/types.d.ts.map +1 -0
  257. package/dist/types.js +2 -0
  258. package/dist/types.js.map +1 -0
  259. package/dist/utils/ValueController.d.ts +10 -0
  260. package/dist/utils/ValueController.d.ts.map +1 -0
  261. package/dist/utils/ValueController.js +32 -0
  262. package/dist/utils/ValueController.js.map +1 -0
  263. package/dist/utils/acessibility.d.ts +52 -0
  264. package/dist/utils/acessibility.d.ts.map +1 -0
  265. package/dist/utils/acessibility.js +80 -0
  266. package/dist/utils/acessibility.js.map +1 -0
  267. package/dist/utils/css.d.ts +12 -0
  268. package/dist/utils/css.d.ts.map +1 -0
  269. package/dist/utils/css.js +72 -0
  270. package/dist/utils/css.js.map +1 -0
  271. package/dist/utils/options.d.ts +3 -0
  272. package/dist/utils/options.d.ts.map +1 -0
  273. package/dist/utils/options.js +7 -0
  274. package/dist/utils/options.js.map +1 -0
  275. package/package.json +51 -0
  276. package/scripts/build-css.ts +49 -0
  277. package/src/components/Accordion.tsx +74 -0
  278. package/src/components/Alert.tsx +16 -0
  279. package/src/components/AsyncContent.tsx +54 -0
  280. package/src/components/Avatar.tsx +34 -0
  281. package/src/components/AvatarGroup.tsx +40 -0
  282. package/src/components/Badge.tsx +28 -0
  283. package/src/components/Blockquote.tsx +9 -0
  284. package/src/components/Breadcrumb.tsx +24 -0
  285. package/src/components/Button.tsx +88 -0
  286. package/src/components/Card.tsx +32 -0
  287. package/src/components/Checkbox.tsx +36 -0
  288. package/src/components/CheckboxGroup.tsx +93 -0
  289. package/src/components/Circle.tsx +26 -0
  290. package/src/components/CitricComponent.ts +34 -0
  291. package/src/components/Divider.tsx +22 -0
  292. package/src/components/ErrorBoundary.tsx +62 -0
  293. package/src/components/ErrorMessage.tsx +11 -0
  294. package/src/components/FallbackBoundary.tsx +29 -0
  295. package/src/components/Favorite.tsx +37 -0
  296. package/src/components/FieldGroup.tsx +22 -0
  297. package/src/components/Form.tsx +17 -0
  298. package/src/components/FormGroup.tsx +45 -0
  299. package/src/components/IconBox.tsx +78 -0
  300. package/src/components/Input.tsx +32 -0
  301. package/src/components/Link.tsx +40 -0
  302. package/src/components/LoadingPanel.tsx +8 -0
  303. package/src/components/MenuOverlay/Menu.tsx +157 -0
  304. package/src/components/MenuOverlay/context.ts +20 -0
  305. package/src/components/MenuOverlay/index.tsx +35 -0
  306. package/src/components/MenuOverlay/keyboard.ts +60 -0
  307. package/src/components/MenuOverlay/types.ts +178 -0
  308. package/src/components/Overlay/context.ts +10 -0
  309. package/src/components/Overlay/index.tsx +137 -0
  310. package/src/components/Overlay/types.ts +71 -0
  311. package/src/components/Pagination.tsx +90 -0
  312. package/src/components/ProgressBar.tsx +25 -0
  313. package/src/components/ProgressCircular.tsx +29 -0
  314. package/src/components/RadioGroup.tsx +87 -0
  315. package/src/components/Rating.tsx +25 -0
  316. package/src/components/Select/RichSelect.tsx +214 -0
  317. package/src/components/Select/SimpleSelect.tsx +66 -0
  318. package/src/components/Select/index.tsx +8 -0
  319. package/src/components/Select/types.ts +121 -0
  320. package/src/components/SelectBox.tsx +134 -0
  321. package/src/components/Skeleton.tsx +41 -0
  322. package/src/components/Slider.tsx +77 -0
  323. package/src/components/SmartTable.tsx +148 -0
  324. package/src/components/Stepper.tsx +142 -0
  325. package/src/components/Switch.tsx +29 -0
  326. package/src/components/Table.tsx +219 -0
  327. package/src/components/Tabs/TabController.ts +40 -0
  328. package/src/components/Tabs/index.tsx +64 -0
  329. package/src/components/Tabs/types.ts +48 -0
  330. package/src/components/Tabs/utils.ts +6 -0
  331. package/src/components/Text.ts +75 -0
  332. package/src/components/Textarea.tsx +12 -0
  333. package/src/components/Tooltip.tsx +53 -0
  334. package/src/components/layout.tsx +53 -0
  335. package/src/context/CitricContext.tsx +4 -0
  336. package/src/context/CitricProvider.tsx +14 -0
  337. package/src/context/hooks.ts +6 -0
  338. package/src/index.ts +47 -0
  339. package/src/overlay.ts +276 -0
  340. package/src/types.ts +226 -0
  341. package/src/utils/ValueController.ts +28 -0
  342. package/src/utils/acessibility.ts +92 -0
  343. package/src/utils/css.ts +106 -0
  344. package/src/utils/options.ts +7 -0
  345. package/tsconfig.json +10 -0
package/dist/theme.css ADDED
@@ -0,0 +1,419 @@
1
+ [data-theme] {
2
+ /* border-radius */
3
+ --radius-full: 600rem;
4
+ --radius-xxl: 8rem;
5
+ --radius-xl: 4rem;
6
+ --radius-lg: 2rem;
7
+ --radius-md: 1rem;
8
+ --radius-sm: 0.5rem;
9
+ --radius-xs: 0.25rem;
10
+ --radius-xxs: 0.125rem;
11
+
12
+ /* spacings */
13
+ --spacing-0: 0;
14
+ --spacing-1: 0.125rem;
15
+ --spacing-2: 0.25rem;
16
+ --spacing-3: 0.5rem;
17
+ --spacing-4: 0.75rem;
18
+ --spacing-5: 1rem;
19
+ --spacing-6: 1.25rem;
20
+ --spacing-7: 1.5rem;
21
+ --spacing-8: 2rem;
22
+ --spacing-9: 2.25rem;
23
+ --spacing-10: 2.5;
24
+ --spacing-11: 2.75rem;
25
+ --spacing-12: 3rem;
26
+ --spacing-13: 3.25rem;
27
+ --spacing-14: 3.5rem;
28
+ --spacing-15: 3.75rem;
29
+ --spacing-16: 4rem;
30
+ --spacing-17: 4.25rem;
31
+ --spacing-18: 4.5rem;
32
+ --spacing-19: 4.75;
33
+ }
34
+
35
+ [data-theme] {
36
+ --font-body1: 400 1rem/1.5 Roboto, sans-serif;
37
+ --font-body2: 400 0.875rem/1.714 Roboto, sans-serif;
38
+ --font-code1: 400 1rem/1.5 Roboto Mono, monospace;
39
+ --font-code2: 400 0.875rem/1.714 Roboto Mono, monospace;
40
+ --font-display1: 600 clamp(2.25rem,4vw + 1rem,4rem)/1.125 Inter;
41
+ --font-h1: 600 clamp(2.25rem,4vw + 1rem,2.5rem)/1.2 Inter;
42
+ --font-h2: 600 clamp(1.5rem,4vw + 1rem,2rem)/1.25 Inter;
43
+ --font-h3: 600 clamp(1.75rem,4vw + 1rem,1.375rem)/1.333 Inter;
44
+ --font-h4: 600 clamp(1.125rem,4vw + 1rem,1.25rem)/1.2 Inter;
45
+ --font-h5: 600 1rem/1.25 Inter;
46
+ --font-h6: 600 1rem/1.429 Inter;
47
+ --font-microtext1: 400 0.75rem/1.333 Roboto Mono, monospace;
48
+ --font-subtitle1: 400 1.5rem/1.333 Roboto Mono, monospace;
49
+ --font-subtitle2: 400 1.25rem/1.6 Roboto Mono, monospace;
50
+ --font-subtitle3: 400 1rem/1.5 Roboto Mono, monospace;
51
+ --font-subtitle4: 400 0.875rem/1.714 Roboto Mono, monospace;
52
+ --font-overheader1: 600 0.875rem/1.5 Roboto Mono, monospace;
53
+ --font-overheader2: 600 0.75rem/1.5 Roboto Mono, monospace;
54
+ }
55
+
56
+
57
+ [data-theme] {
58
+ --primary-700: #5C2512;
59
+ --primary-600: #AD4523;
60
+ --primary-500: #FF6900;
61
+ --primary-400: #FF9775;
62
+ --primary-300: #FFC8B5;
63
+ --primary-contrastText: #000000;
64
+ --secondary-700: #14135C;
65
+ --secondary-600: #2623AD;
66
+ --secondary-500: #3834FF;
67
+ --secondary-400: #7875FF;
68
+ --secondary-300: #B7B6FF;
69
+ --secondary-contrastText: #FFFFFF;
70
+ --tertiary-700: #25124A;
71
+ --tertiary-600: #45238A;
72
+ --tertiary-500: #6633CC;
73
+ --tertiary-400: #9775DC;
74
+ --tertiary-300: #C8B5ED;
75
+ --tertiary-contrastText: #FFFFFF;
76
+ --highlight-700: #5C3700;
77
+ --highlight-600: #AD6800;
78
+ --highlight-500: #FF9900;
79
+ --highlight-400: #FFBA52;
80
+ --highlight-300: #FFDAA3;
81
+ --highlight-contrastText: #000000;
82
+ --danger-700: #5C3232;
83
+ --danger-600: #AD5E5E;
84
+ --danger-500: #FF8A8A;
85
+ --danger-400: #FFB0B0;
86
+ --danger-300: #FFD5D5;
87
+ --danger-contrastText: #000000;
88
+ --warning-700: #59512E;
89
+ --warning-600: #A89857;
90
+ --warning-500: #F8E080;
91
+ --warning-400: #FAEAA9;
92
+ --warning-300: #FCF4D1;
93
+ --warning-contrastText: #000000;
94
+ --success-700: #344B34;
95
+ --success-600: #628E62;
96
+ --success-500: #91D191;
97
+ --success-400: #B4E0B4;
98
+ --success-300: #D7EED7;
99
+ --success-contrastText: #000000;
100
+ --light-700: #BCBCCF;
101
+ --light-600: #2F2F3C;
102
+ --light-500: #262631;
103
+ --light-400: #1D1D25;
104
+ --light-300: #14141A;
105
+ --light-contrastText: #FAFAFB;
106
+ --inverse-700: #707075;
107
+ --inverse-600: #BCBCCF;
108
+ --inverse-500: #D1D1DE;
109
+ --inverse-400: #E5E5ED;
110
+ --inverse-300: #F7F7F8;
111
+ --inverse-contrastText: #0B0B0E;
112
+ --blue-50: #D6F5FF;
113
+ --blue-100: #B5EDFF;
114
+ --blue-200: #95E4FF;
115
+ --blue-300: #75DCFF;
116
+ --blue-400: #54D4FF;
117
+ --blue-500: #33CCFF;
118
+ --blue-600: #2BABD6;
119
+ --blue-700: #238AAD;
120
+ --blue-800: #1B6A85;
121
+ --blue-900: #124A5C;
122
+ --cyan-50: #E0FFFF;
123
+ --cyan-100: #B3FFFF;
124
+ --cyan-200: #80FFFF;
125
+ --cyan-300: #4DFFFF;
126
+ --cyan-400: #1AFFFF;
127
+ --cyan-500: #00E5FF;
128
+ --cyan-600: #00B2E5;
129
+ --cyan-700: #0080B2;
130
+ --cyan-800: #004D80;
131
+ --cyan-900: #001A4D;
132
+ --gray-50: #EAEAEC;
133
+ --gray-100: #C1C1C5;
134
+ --gray-200: #97979E;
135
+ --gray-300: #6D6D77;
136
+ --gray-400: #444450;
137
+ --gray-500: #444450;
138
+ --gray-600: #2F2F3C;
139
+ --gray-700: #1C1C24;
140
+ --gray-800: #09090E;
141
+ --gray-900: #000002;
142
+ --indigo-50: #D7D6FF;
143
+ --indigo-100: #B7B6FF;
144
+ --indigo-200: #9795FF;
145
+ --indigo-300: #7875FF;
146
+ --indigo-400: #5855FF;
147
+ --indigo-500: #3834FF;
148
+ --indigo-600: #2F2CD6;
149
+ --indigo-700: #2623AD;
150
+ --indigo-800: #1D1B85;
151
+ --indigo-900: #14135C;
152
+ --moss-50: #F0F3CC;
153
+ --moss-100: #E3E9A3;
154
+ --moss-200: #D7DF7A;
155
+ --moss-300: #CBD652;
156
+ --moss-400: #BECC29;
157
+ --moss-500: #B2C200;
158
+ --moss-600: #95A300;
159
+ --moss-700: #798400;
160
+ --moss-800: #5D6500;
161
+ --moss-900: #404600;
162
+ --orange-50: #FFE7D6;
163
+ --orange-100: #FFD4B5;
164
+ --orange-200: #FFC195;
165
+ --orange-300: #FFAE75;
166
+ --orange-400: #FF9B54;
167
+ --orange-500: #FF8833;
168
+ --orange-600: #D6722B;
169
+ --orange-700: #AD5C23;
170
+ --orange-800: #85471B;
171
+ --orange-900: #5C3112;
172
+ --pink-50: #FFE0F5;
173
+ --pink-100: #FFC8ED;
174
+ --pink-200: #FFAFE4;
175
+ --pink-300: #FF97DC;
176
+ --pink-400: #FF7FD4;
177
+ --pink-500: #FF66CC;
178
+ --pink-600: #D656AB;
179
+ --pink-700: #AD458A;
180
+ --pink-800: #85356A;
181
+ --pink-900: #5C254A;
182
+ --purple-50: #E2D8F6;
183
+ --purple-100: #CAB8EF;
184
+ --purple-200: #B298E8;
185
+ --purple-300: #9B79E0;
186
+ --purple-400: #845AD9;
187
+ --purple-500: #6C3AD2;
188
+ --purple-600: #5B31B0;
189
+ --purple-700: #49278E;
190
+ --purple-800: #381E6E;
191
+ --purple-900: #27154C;
192
+ --red-50: #FFCCCC;
193
+ --red-100: #FFA3A3;
194
+ --red-200: #FF7A7A;
195
+ --red-300: #FF5252;
196
+ --red-400: #FF2929;
197
+ --red-500: #FF0000;
198
+ --red-600: #D60000;
199
+ --red-700: #AD0000;
200
+ --red-800: #850000;
201
+ --red-900: #5C0000;
202
+ --teal-50: #CCF5EB;
203
+ --teal-100: #A3EDDA;
204
+ --teal-200: #7AE4CA;
205
+ --teal-300: #52DCBA;
206
+ --teal-400: #29D4A9;
207
+ --teal-500: #00CC99;
208
+ --teal-600: #00AB80;
209
+ --teal-700: #008A68;
210
+ --teal-800: #006A50;
211
+ --teal-900: #004A37;
212
+ --yellow-50: #FFF5CC;
213
+ --yellow-100: #FFEDA3;
214
+ --yellow-200: #FFE47A;
215
+ --yellow-300: #FFDC52;
216
+ --yellow-400: #FFD429;
217
+ --yellow-500: #FFCC00;
218
+ --yellow-600: #D6AB00;
219
+ --yellow-700: #AD8A00;
220
+ --yellow-800: #856A00;
221
+ --yellow-900: #5C4A00;
222
+ --backdrop-color: rgba(0, 0, 0, 0.5)
223
+ }
224
+
225
+ [data-theme="light"] {
226
+ color-scheme: light;
227
+ --primary-700: #5C2512;
228
+ --primary-600: #AD4523;
229
+ --primary-500: #FF6900;
230
+ --primary-400: #FF9775;
231
+ --primary-300: #FFC8B5;
232
+ --primary-contrastText: #000000;
233
+ --secondary-700: #14135C;
234
+ --secondary-600: #2623AD;
235
+ --secondary-500: #3834FF;
236
+ --secondary-400: #7875FF;
237
+ --secondary-300: #B7B6FF;
238
+ --secondary-contrastText: #FFFFFF;
239
+ --tertiary-700: #25124A;
240
+ --tertiary-600: #45238A;
241
+ --tertiary-500: #6633CC;
242
+ --tertiary-400: #9775DC;
243
+ --tertiary-300: #C8B5ED;
244
+ --tertiary-contrastText: #FFFFFF;
245
+ --highlight-700: #054C91;
246
+ --highlight-600: #0660B5;
247
+ --highlight-500: #0867DA;
248
+ --highlight-400: #4A8EF1;
249
+ --highlight-300: #8CB2F8;
250
+ --highlight-contrastText: #FFFFFF;
251
+ --danger-700: #7A2929;
252
+ --danger-600: #922C2C;
253
+ --danger-500: #B03B3B;
254
+ --danger-400: #C76666;
255
+ --danger-300: #DD9191;
256
+ --danger-contrastText: #FFFFFF;
257
+ --warning-700: #C79300;
258
+ --warning-600: #D4A100;
259
+ --warning-500: #E6B800;
260
+ --warning-400: #F7D055;
261
+ --warning-300: #FFF4CC;
262
+ --warning-contrastText: #000000;
263
+ --success-700: #1A4721;
264
+ --success-600: #25632A;
265
+ --success-500: #317131;
266
+ --success-400: #4D8B4D;
267
+ --success-300: #75B175;
268
+ --success-contrastText: #FFFFFF;
269
+ --light-700: #636366;
270
+ --light-600: #E0E0E3;
271
+ --light-500: #EDEDEF;
272
+ --light-400: #F3F3F3;
273
+ --light-300: #FCFCFD;
274
+ --light-contrastText: #000000;
275
+ --inverse-700: #BCBCCF;
276
+ --inverse-600: #2F2F3C;
277
+ --inverse-500: #262631;
278
+ --inverse-400: #1D1D25;
279
+ --inverse-300: #14141A;
280
+ --inverse-contrastText: #FAFAFB;
281
+
282
+ --indigo-900: #F0E6FF;
283
+ --indigo-800: #DBCCEF;
284
+ --indigo-700: #C6B3DF;
285
+ --indigo-600: #B199CF;
286
+ --indigo-500: #9C80BF;
287
+ --indigo-400: #874699;
288
+ --indigo-300: #723C7A;
289
+ --indigo-200: #5D235A;
290
+ --indigo-100: #490D40;
291
+ --indigo-50: #340026;
292
+ --blue-900: #E6F4FF;
293
+ --blue-800: #CCE8FF;
294
+ --blue-700: #99CCFF;
295
+ --blue-600: #66B2FF;
296
+ --blue-500: #3399FF;
297
+ --blue-400: #007FFF;
298
+ --blue-300: #0066CC;
299
+ --blue-200: #004C99;
300
+ --blue-100: #003366;
301
+ --blue-50: #001A33;
302
+ --moss-900: #F3F7EA;
303
+ --moss-800: #E1EAD6;
304
+ --moss-700: #CFDDC1;
305
+ --moss-600: #BDD1AD;
306
+ --moss-500: #ABC499;
307
+ --moss-400: #99B784;
308
+ --moss-300: #879A70;
309
+ --moss-200: #758D5B;
310
+ --moss-100: #647F47;
311
+ --moss-50: #536B32;
312
+ --orange-900: #FFF3E0;
313
+ --orange-800: #FFE9CE;
314
+ --orange-700: #FFD3A1;
315
+ --orange-600: #FFBC74;
316
+ --orange-500: #FFA447;
317
+ --orange-400: #FF8C1A;
318
+ --orange-300: #E6731D;
319
+ --orange-200: #B35816;
320
+ --orange-100: #803C0F;
321
+ --orange-50: #4A2008;
322
+ --cyan-900: #E0FFFF;
323
+ --cyan-800: #B3FFFF;
324
+ --cyan-700: #80FFFF;
325
+ --cyan-600: #4DFFFF;
326
+ --cyan-500: #1AFFFF;
327
+ --cyan-400: #00E5FF;
328
+ --cyan-300: #00B2E5;
329
+ --cyan-200: #0080B2;
330
+ --cyan-100: #004D80;
331
+ --cyan-50: #001A4D;
332
+ --gray-900: #F2F2F2;
333
+ --gray-800: #E5E5E5;
334
+ --gray-700: #CCCCCC;
335
+ --gray-600: #B3B3B3;
336
+ --gray-500: #999999;
337
+ --gray-400: #808080;
338
+ --gray-300: #666666;
339
+ --gray-200: #4D4D4D;
340
+ --gray-100: #333333;
341
+ --gray-50: #1C1C1C;
342
+ --purple-900: #F2E6FF;
343
+ --purple-800: #E0CCFF;
344
+ --purple-700: #CEB3FF;
345
+ --purple-600: #BB99FF;
346
+ --purple-500: #A980FF;
347
+ --purple-400: #9666FF;
348
+ --purple-300: #834DFF;
349
+ --purple-200: #7024FF;
350
+ --purple-100: #5D00EB;
351
+ --purple-50: #4A00D1;
352
+ --pink-900: #FFE6F9;
353
+ --pink-800: #FFCCF2;
354
+ --pink-700: #FFB3EC;
355
+ --pink-600: #FF99E6;
356
+ --pink-500: #FF80E0;
357
+ --pink-400: #FF66DA;
358
+ --pink-300: #FF4CD4;
359
+ --pink-200: #443692;
360
+ --pink-100: #E100AA;
361
+ --pink-50: #B9007C;
362
+ --yellow-900: #FFF9E6;
363
+ --yellow-800: #FFF2CC;
364
+ --yellow-700: #FFEBB3;
365
+ --yellow-600: #FFE499;
366
+ --yellow-500: #FFDD80;
367
+ --yellow-400: #FFD666;
368
+ --yellow-300: #FFCF4D;
369
+ --yellow-200: #FFC833;
370
+ --yellow-100: #FFC11A;
371
+ --yellow-50: #B38F00;
372
+ --red-900: #FFE6E6;
373
+ --red-800: #FFCCCC;
374
+ --red-700: #FFB3B3;
375
+ --red-600: #FF9999;
376
+ --red-500: #FF8080;
377
+ --red-400: #FF6666;
378
+ --red-300: #FF4D4D;
379
+ --red-200: #FF3333;
380
+ --red-100: #FF1A1A;
381
+ --red-50: #CC0000
382
+ }
383
+
384
+
385
+ [data-theme="dark"] {
386
+ color-scheme: dark;
387
+ --light-300: #14141A;
388
+ --light-400: #1D1D25;
389
+ --light-500: #262631;
390
+ --light-600: #2F2F3C;
391
+ --light-700: #BCBCCF;
392
+ --light-contrastText: #FAFAFB;
393
+ --inverse-300: #F7F7F8;
394
+ --inverse-400: #E5E5ED;
395
+ --inverse-500: #D1D1DE;
396
+ --inverse-600: #BCBCCF;
397
+ --inverse-700: #707075;
398
+ --inverse-contrastText: #0B0B0E;
399
+ }
400
+
401
+ [data-theme="stackspot"] {
402
+ color-scheme: dark;
403
+ --light-300: #0E1222;
404
+ --light-400: #131726;
405
+ --light-500: #171B2B;
406
+ --light-600: #212533;
407
+ --light-700: #CFD0D3;
408
+ --light-contrastText: #FAFAFB;
409
+ --inverse-300: #F5F7FF;
410
+ --inverse-400: #EBEDF6;
411
+ --inverse-500: #D8D9E4;
412
+ --inverse-600: #CDCDDA;
413
+ --inverse-700: #171B2B;
414
+ --inverse-contrastText: #0E1222;
415
+ }
416
+
417
+ [data-theme-kind="light"] {
418
+ --backdrop-color: rgba(0, 0, 0, 0.5)
419
+ }
@@ -0,0 +1,175 @@
1
+ import { ColorKey, ColorPaletteName, ColorSchemeName } from '@stack-spot/portal-theme';
2
+ import { RadiusKey, SpacingKey } from '@stack-spot/portal-theme/dist/definition.js';
3
+ export interface WithColorScheme {
4
+ colorScheme?: ColorSchemeName;
5
+ }
6
+ export interface WithColorPalette {
7
+ colorPalette?: ColorPaletteName;
8
+ }
9
+ export interface WithColor {
10
+ color?: ColorKey;
11
+ }
12
+ export type WithDataAttributes = {
13
+ [key: `data-${string}`]: string | undefined;
14
+ };
15
+ export type TextAppearance = 'body1' | 'body2' | 'code1' | 'code2' | 'display1' | 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6' | 'microtext1' | 'overheader1' | 'overheader2' | 'subtitle1' | 'subtitle2' | 'subtitle3' | 'subtitle4';
16
+ export type HTMLExtension<K extends keyof React.JSX.IntrinsicElements, Props, Omitted extends string = ''> = (Omitted extends '' ? React.JSX.IntrinsicElements[K] : Omit<React.JSX.IntrinsicElements[K], Omitted>) & Props;
17
+ export interface WithStyleShortcuts {
18
+ /**
19
+ * Sets a theme color for the background.
20
+ */
21
+ bg?: ColorKey;
22
+ /**
23
+ * Sets a theme color for the foreground.
24
+ */
25
+ fg?: ColorKey;
26
+ /**
27
+ * Sets a theme color for the border and set it to 1px width.
28
+ */
29
+ border?: ColorKey;
30
+ /**
31
+ * Sets the border radius.
32
+ */
33
+ radius?: RadiusKey;
34
+ /**
35
+ * Sets the margin for every side.
36
+ *
37
+ * When a number is provided, the theme variable is used "spacing-1, ..., spacing-19". When a list of numbers is provided, the theme
38
+ * variable is used for each of the positions, following the CSS order ([top, right, bottom, left]) When a string is provided, this acts
39
+ * as a shortcut for `style.margin`.
40
+ */
41
+ m?: SpacingKey | SpacingKey[] | string;
42
+ /**
43
+ * Sets the margin from the top.
44
+ *
45
+ * When a number is provided, the theme variable is used "spacing-1, ..., spacing-19". When a string is provided, this acts as a shortcut
46
+ * for `style.marginTop`.
47
+ */
48
+ mt?: SpacingKey | string;
49
+ /**
50
+ * Sets the margin from the bottom.
51
+ *
52
+ * When a number is provided, the theme variable is used "spacing-1, ..., spacing-19". When a string is provided, this acts as a shortcut
53
+ * for `style.marginBottom`.
54
+ */
55
+ mb?: SpacingKey | string;
56
+ /**
57
+ * Sets the margin from the left.
58
+ *
59
+ * When a number is provided, the theme variable is used "spacing-1, ..., spacing-19". When a string is provided, this acts as a shortcut
60
+ * for `style.marginLeft`.
61
+ */
62
+ ml?: SpacingKey | string;
63
+ /**
64
+ * Sets the margin from the right.
65
+ *
66
+ * When a number is provided, the theme variable is used "spacing-1, ..., spacing-19". When a string is provided, this acts as a shortcut
67
+ * for `style.marginRight`.
68
+ */
69
+ mr?: SpacingKey | string;
70
+ /**
71
+ * Sets the padding for every side.
72
+ *
73
+ * When a number is provided, the theme variable is used "spacing-1, ..., spacing-19". When a list of numbers is provided, the theme
74
+ * variable is used for each of the positions, following the CSS order ([top, right, bottom, left]) When a string is provided, this acts
75
+ * as a shortcut for `style.padding`.
76
+ */
77
+ p?: SpacingKey | SpacingKey[] | string;
78
+ /**
79
+ * Sets the padding from the top.
80
+ *
81
+ * When a number is provided, the theme variable is used "spacing-1, ..., spacing-19". When a string is provided, this acts as a shortcut
82
+ * for `style.paddingTop`.
83
+ */
84
+ pt?: SpacingKey | string;
85
+ /**
86
+ * Sets the padding from the bottom.
87
+ *
88
+ * When a number is provided, the theme variable is used "spacing-1, ..., spacing-19". When a string is provided, this acts as a shortcut
89
+ * for `style.paddingBottom`.
90
+ */
91
+ pb?: SpacingKey | string;
92
+ /**
93
+ * Sets the padding from the left.
94
+ *
95
+ * When a number is provided, the theme variable is used "spacing-1, ..., spacing-19". When a string is provided, this acts as a shortcut
96
+ * for `style.paddingLeft`.
97
+ */
98
+ pl?: SpacingKey | string;
99
+ /**
100
+ * Sets the padding from the right.
101
+ *
102
+ * When a number is provided, the theme variable is used "spacing-1, ..., spacing-19". When a string is provided, this acts as a shortcut
103
+ * for `style.paddingRight`.
104
+ */
105
+ pr?: SpacingKey | string;
106
+ /**
107
+ * Shortcut for `style.width`.
108
+ */
109
+ w?: string | number;
110
+ /**
111
+ * Shortcut for `style.height`.
112
+ */
113
+ h?: string | number;
114
+ /**
115
+ * Shortcut for `style.flex`.
116
+ */
117
+ flex?: React.CSSProperties['flex'];
118
+ /**
119
+ * Shortcut for `style.justifyContent`.
120
+ */
121
+ justifyContent?: React.CSSProperties['justifyContent'];
122
+ /**
123
+ * Shortcut for `style.alignItems`.
124
+ */
125
+ alignItems?: React.CSSProperties['alignItems'];
126
+ /**
127
+ * Shortcut for `style.gap`.
128
+ */
129
+ gap?: React.CSSProperties['gap'];
130
+ }
131
+ export interface CitricController {
132
+ /**
133
+ * If set, instead of rendering the HTML tag "a", the Link component will render the return value of this function.
134
+ * @param props the props for the anchor element
135
+ * @returns
136
+ */
137
+ renderLink?: (props: JSX.IntrinsicElements['a']) => React.ReactElement;
138
+ /**
139
+ * A function to run whenever the component Button is clicked.
140
+ * @param event the click event.
141
+ * @param analytics true if analytics are enabled for this button, false otherwise.
142
+ */
143
+ onClickButton?: (event: React.MouseEvent<HTMLButtonElement>, analytics: boolean) => void;
144
+ /**
145
+ * A function to run whenever the component Link is clicked.
146
+ * @param event the click event.
147
+ * @param analytics true if analytics are enabled for this link, false otherwise.
148
+ */
149
+ onClickLink?: (event: React.MouseEvent<HTMLAnchorElement>, analytics: boolean) => void;
150
+ /**
151
+ * A custom renderer for error feedbacks.
152
+ *
153
+ * By default, a simple text with the error message is rendered.
154
+ *
155
+ * Errors are rendered when they're caught in an ErrorBoundary or AsyncContent.
156
+ * @param error the error caught.
157
+ * @returns the UI for the feedback.
158
+ */
159
+ renderError?: (error: any) => React.ReactElement;
160
+ /**
161
+ * A custom renderer for loading feedbacks.
162
+ *
163
+ * By default, the component "ProgressCircular" is rendered with some padding.
164
+ *
165
+ * Loadings are rendered in Suspended calls or in AsyncContent.
166
+ * @returns the UI for the feedback.
167
+ */
168
+ renderLoading?: () => void;
169
+ /**
170
+ * Function to run whenever an Error is caught.
171
+ * @param error the error caught.
172
+ */
173
+ onError?: (error: any) => void;
174
+ }
175
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"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"}
package/dist/types.js ADDED
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,10 @@
1
+ export type ValueListener<T> = (value: T) => void;
2
+ export declare class ValueController<T> {
3
+ protected value: T;
4
+ private listeners;
5
+ constructor(value: T);
6
+ onChange(listener: ValueListener<T>): () => void;
7
+ setValue(value: T): void;
8
+ getValue(): T;
9
+ }
10
+ //# sourceMappingURL=ValueController.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ValueController.d.ts","sourceRoot":"","sources":["../../src/utils/ValueController.ts"],"names":[],"mappings":"AAEA,MAAM,MAAM,aAAa,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,KAAK,IAAI,CAAA;AAEjD,qBAAa,eAAe,CAAC,CAAC;IAC5B,SAAS,CAAC,KAAK,EAAE,CAAC,CAAA;IAClB,OAAO,CAAC,SAAS,CAAyB;gBAE9B,KAAK,EAAE,CAAC;IAIpB,QAAQ,CAAC,QAAQ,EAAE,aAAa,CAAC,CAAC,CAAC;IAOnC,QAAQ,CAAC,KAAK,EAAE,CAAC;IAKjB,QAAQ;CAGT"}
@@ -0,0 +1,32 @@
1
+ import { pull } from 'lodash';
2
+ export class ValueController {
3
+ constructor(value) {
4
+ Object.defineProperty(this, "value", {
5
+ enumerable: true,
6
+ configurable: true,
7
+ writable: true,
8
+ value: void 0
9
+ });
10
+ Object.defineProperty(this, "listeners", {
11
+ enumerable: true,
12
+ configurable: true,
13
+ writable: true,
14
+ value: []
15
+ });
16
+ this.value = value;
17
+ }
18
+ onChange(listener) {
19
+ this.listeners.push(listener);
20
+ return () => {
21
+ pull(this.listeners, listener);
22
+ };
23
+ }
24
+ setValue(value) {
25
+ this.value = value;
26
+ this.listeners.forEach(l => l(value));
27
+ }
28
+ getValue() {
29
+ return this.value;
30
+ }
31
+ }
32
+ //# sourceMappingURL=ValueController.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ValueController.js","sourceRoot":"","sources":["../../src/utils/ValueController.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAA;AAI7B,MAAM,OAAO,eAAe;IAI1B,YAAY,KAAQ;QAHV;;;;;WAAQ;QACV;;;;mBAAgC,EAAE;WAAA;QAGxC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;IACpB,CAAC;IAED,QAAQ,CAAC,QAA0B;QACjC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;QAC7B,OAAO,GAAG,EAAE;YACV,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAA;QAChC,CAAC,CAAA;IACH,CAAC;IAED,QAAQ,CAAC,KAAQ;QACf,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;QAClB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAA;IACvC,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,KAAK,CAAA;IACnB,CAAC;CACF"}