stargazer-ui 1.5.21 → 1.5.23

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 (377) hide show
  1. package/.babelrc.json +10 -0
  2. package/.eslintrc.cjs +18 -0
  3. package/.gitattributes +2 -0
  4. package/LICENSE +21 -0
  5. package/dev/index.html +16 -0
  6. package/dev/index.jsx +46 -0
  7. package/dev/index.scss +74 -0
  8. package/dev/pages/ButtonPage.jsx +44 -0
  9. package/dev/pages/CardPage.jsx +81 -0
  10. package/dev/pages/DropdownPage.jsx +32 -0
  11. package/dev/pages/FormPage.jsx +163 -0
  12. package/dev/pages/ListPage.jsx +52 -0
  13. package/dev/pages/ModalPage.jsx +38 -0
  14. package/dev/pages/OverlayPage.jsx +39 -0
  15. package/dev/pages/components.jsx +19 -0
  16. package/dev/stargazerui.css +3762 -0
  17. package/dev/stargazerui.css.map +1 -0
  18. package/dev/test.jsx +87 -0
  19. package/package.json +79 -1
  20. package/rollup.config.js +140 -0
  21. package/scripts/writePackageJsons.js +42 -0
  22. package/src/Bar/Bar.tsx +0 -0
  23. package/src/Bar/Bar.type.ts +9 -0
  24. package/src/Bar/index.ts +0 -0
  25. package/src/Button/Button.tsx +20 -0
  26. package/src/Button/Button.types.ts +8 -0
  27. package/src/Button/index.ts +3 -0
  28. package/src/ButtonGroup/ButtonGroup.tsx +14 -0
  29. package/src/ButtonGroup/ButtonGroup.types.ts +8 -0
  30. package/src/ButtonGroup/index.ts +3 -0
  31. package/src/Card/Card.tsx +70 -0
  32. package/src/Card/Card.types.ts +33 -0
  33. package/src/Card/index.ts +3 -0
  34. package/src/CloseButton/CloseButton.tsx +14 -0
  35. package/src/CloseButton/CloseButton.types.ts +6 -0
  36. package/src/CloseButton/index.ts +3 -0
  37. package/src/Dropdown/Dropdown.tsx +441 -0
  38. package/src/Dropdown/Dropdown.types.ts +60 -0
  39. package/src/Dropdown/index.ts +4 -0
  40. package/src/FileUploadButton/FileUploadButton.tsx +27 -0
  41. package/src/FileUploadButton/FileUploadButton.types.ts +9 -0
  42. package/src/FileUploadButton/index.ts +3 -0
  43. package/src/FloatingLabel/FloatingLabel.tsx +22 -0
  44. package/src/FloatingLabel/FloatingLabel.types.ts +11 -0
  45. package/src/FloatingLabel/index.ts +3 -0
  46. package/src/Form/Form.tsx +399 -0
  47. package/src/Form/Form.types.ts +169 -0
  48. package/src/Form/FormSelect.tsx +620 -0
  49. package/src/Form/index.ts +4 -0
  50. package/src/InputGroup/InputGroup.tsx +46 -0
  51. package/src/InputGroup/InputGroup.types.ts +22 -0
  52. package/src/InputGroup/index.ts +4 -0
  53. package/src/List/List.tsx +112 -0
  54. package/src/List/List.types.ts +34 -0
  55. package/src/List/index.ts +4 -0
  56. package/src/Modal/Modal.tsx +229 -0
  57. package/src/Modal/Modal.types.ts +49 -0
  58. package/src/Modal/index.ts +4 -0
  59. package/src/Nav/Nav.tsx +43 -0
  60. package/src/Nav/Nav.types.ts +21 -0
  61. package/src/Nav/index.ts +4 -0
  62. package/src/NavBar/Navbar.tsx +57 -0
  63. package/src/NavBar/Navbar.types.ts +24 -0
  64. package/src/NavBar/index.ts +4 -0
  65. package/src/NavDropdown/NavDropdown.tsx +93 -0
  66. package/src/NavDropdown/NavDropdown.types.ts +7 -0
  67. package/src/NavDropdown/index.ts +3 -0
  68. package/src/Overlay/Overlay.tsx +305 -0
  69. package/src/Overlay/Overlay.types.ts +24 -0
  70. package/{Overlay/index.d.ts → src/Overlay/index.ts} +3 -3
  71. package/src/Popout/Popout.tsx +155 -0
  72. package/src/Popout/Popout.types.ts +42 -0
  73. package/src/Popout/index.ts +3 -0
  74. package/src/Spinner/Spinner.tsx +15 -0
  75. package/src/Spinner/Spinner.types.ts +7 -0
  76. package/src/Spinner/index.ts +3 -0
  77. package/src/Table/Table.tsx +16 -0
  78. package/src/Table/Table.types.ts +9 -0
  79. package/src/Table/index.ts +3 -0
  80. package/src/Tabs/Tabs.tsx +233 -0
  81. package/src/Tabs/Tabs.types.ts +52 -0
  82. package/src/Tabs/index.ts +3 -0
  83. package/src/ToggleButton/ToggleButton.tsx +21 -0
  84. package/src/ToggleButton/ToggleButton.types.ts +8 -0
  85. package/src/ToggleButton/index.ts +3 -0
  86. package/src/assets/tooltip-pointer.svg +3 -0
  87. package/src/assets/warning.svg +39 -0
  88. package/{hooks/index.d.ts → src/hooks/index.ts} +7 -6
  89. package/src/hooks/useClassname.ts +5 -0
  90. package/src/hooks/useDraggable.ts +186 -0
  91. package/src/hooks/useKeepElementFocused.ts +37 -0
  92. package/src/hooks/useQueryParams.ts +12 -0
  93. package/src/hooks/useScreenSize.ts +24 -0
  94. package/src/index.ts +21 -0
  95. package/src/styles/_Card.scss +166 -0
  96. package/src/styles/_CloseButton.scss +51 -0
  97. package/src/styles/_CustomButton.scss +134 -0
  98. package/src/styles/_Dropdown.scss +127 -0
  99. package/src/styles/_FloatingLabel.scss +56 -0
  100. package/src/styles/_Forms.scss +7 -0
  101. package/src/styles/_Grid.scss +178 -0
  102. package/src/styles/_InputGroup.scss +71 -0
  103. package/src/styles/_List.scss +62 -0
  104. package/src/styles/_Modal.scss +234 -0
  105. package/src/styles/_ModalOld.scss +242 -0
  106. package/src/styles/_Nav.scss +36 -0
  107. package/src/styles/_NavBar.scss +116 -0
  108. package/src/styles/_NavDropdown.scss +33 -0
  109. package/src/styles/_OffCanvas.scss +260 -0
  110. package/src/styles/_OverLay.scss +79 -0
  111. package/src/styles/_Popout.scss +75 -0
  112. package/src/styles/_Resizable.scss +64 -0
  113. package/src/styles/_Spinner.scss +19 -0
  114. package/src/styles/_Table.scss +34 -0
  115. package/src/styles/_Tabs.scss +129 -0
  116. package/src/styles/_colors.scss +510 -0
  117. package/src/styles/_components.scss +41 -0
  118. package/src/styles/_functions.scss +134 -0
  119. package/src/styles/_mixins.scss +26 -0
  120. package/src/styles/_reset.scss +239 -0
  121. package/src/styles/_utilities.scss +2480 -0
  122. package/src/styles/_variables.scss +164 -0
  123. package/src/styles/forms/_FormCheck.scss +270 -0
  124. package/src/styles/forms/_FormControl.scss +135 -0
  125. package/src/styles/forms/_FormGroup.scss +26 -0
  126. package/src/styles/forms/_FormLabel.scss +3 -0
  127. package/src/styles/forms/_FormSelect.scss +222 -0
  128. package/src/styles/forms/_FormSlider.scss +116 -0
  129. package/src/styles/forms/_FormText.scss +6 -0
  130. package/{utils/BaseTypes.d.ts → src/utils/BaseTypes.ts} +32 -25
  131. package/src/utils/ContrastingColor.ts +25 -0
  132. package/src/utils/CreateSyntheticEvent.ts +30 -0
  133. package/src/utils/FileImportExport.js +50 -0
  134. package/src/utils/IsInputKey.ts +18 -0
  135. package/src/utils/MergeClassnames.ts +5 -0
  136. package/src/utils/MergeRefs.ts +12 -0
  137. package/src/utils/createFastContext.tsx +119 -0
  138. package/src/utils/index.ts +4 -0
  139. package/src/vite-env.d.ts +1 -0
  140. package/tsconfig-build.json +4 -0
  141. package/tsconfig.json +79 -0
  142. package/tsconfig.node.json +10 -0
  143. package/types/BaseTypes.d.ts +19 -0
  144. package/{Button → types/components/Button}/Button.types.d.ts +2 -1
  145. package/types/components/Button/index.d.ts +1 -0
  146. package/{Card → types/components/Card}/Card.d.ts +12 -12
  147. package/{Card → types/components/Card}/Card.types.d.ts +1 -3
  148. package/types/components/Card/index.d.ts +1 -0
  149. package/{CloseButton → types/components/CloseButton}/CloseButton.types.d.ts +1 -1
  150. package/types/components/CloseButton/index.d.ts +1 -0
  151. package/types/components/Dropdown/Dropdown.d.ts +71 -0
  152. package/{Dropdown → types/components/Dropdown}/Dropdown.types.d.ts +12 -13
  153. package/types/components/Dropdown/index.d.ts +1 -0
  154. package/{FloatingLabel → types/components/FloatingLabel}/FloatingLabel.types.d.ts +1 -1
  155. package/types/components/FloatingLabel/index.d.ts +1 -0
  156. package/types/components/Form/Form.d.ts +17 -0
  157. package/types/components/Form/Form.types.d.ts +50 -0
  158. package/types/components/Form/index.d.ts +1 -0
  159. package/types/components/InputGroup/InputGroup.d.ts +6 -0
  160. package/types/components/InputGroup/InputGroup.types.d.ts +10 -0
  161. package/types/components/InputGroup/index.d.ts +1 -0
  162. package/{Modal → types/components/Modal}/Modal.d.ts +19 -19
  163. package/{Modal → types/components/Modal}/Modal.types.d.ts +2 -3
  164. package/types/components/Modal/index.d.ts +1 -0
  165. package/{Nav → types/components/Nav}/Nav.d.ts +12 -12
  166. package/{Nav → types/components/Nav}/Nav.types.d.ts +1 -1
  167. package/types/components/Nav/index.d.ts +1 -0
  168. package/{NavBar → types/components/NavBar}/Navbar.d.ts +8 -7
  169. package/{NavBar → types/components/NavBar}/Navbar.types.d.ts +1 -2
  170. package/types/components/NavBar/index.d.ts +1 -0
  171. package/types/components/NavDropdown/NavDropdown.d.ts +35 -0
  172. package/{NavDropdown → types/components/NavDropdown}/NavDropdown.types.d.ts +1 -2
  173. package/types/components/NavDropdown/index.d.ts +1 -0
  174. package/{Popout → types/components/Popout}/Popout.d.ts +6 -6
  175. package/{Popout → types/components/Popout}/Popout.types.d.ts +1 -1
  176. package/types/components/Popout/index.d.ts +1 -0
  177. package/types/components/Spinner/index.d.ts +1 -0
  178. package/{Table → types/components/Table}/Table.types.d.ts +1 -1
  179. package/types/components/Table/index.d.ts +1 -0
  180. package/{Tabs → types/components/Tabs}/Tabs.types.d.ts +2 -12
  181. package/types/components/Tabs/index.d.ts +1 -0
  182. package/types/components/ToggleButton/ToggleButton.d.ts +9 -0
  183. package/types/components/ToggleButton/ToggleButton.types.d.ts +0 -0
  184. package/types/components/ToggleButton/index.d.ts +1 -0
  185. package/types/components/index.d.ts +16 -0
  186. package/types/index.d.ts +1 -0
  187. package/vite.config.js +57 -0
  188. package/vite.config.js.timestamp-1708777378490-e94428ceb2bf9.mjs +42 -0
  189. package/Bar/Bar.type.d.ts +0 -6
  190. package/Bar/index.js +0 -2
  191. package/Bar/index.js.map +0 -1
  192. package/Bar/package.json +0 -1
  193. package/Button/Button.js +0 -15
  194. package/Button/Button.js.map +0 -1
  195. package/Button/index.d.ts +0 -3
  196. package/Button/index.js +0 -7
  197. package/Button/index.js.map +0 -1
  198. package/Button/package.json +0 -1
  199. package/ButtonGroup/ButtonGroup.d.ts +0 -4
  200. package/ButtonGroup/ButtonGroup.js +0 -11
  201. package/ButtonGroup/ButtonGroup.js.map +0 -1
  202. package/ButtonGroup/ButtonGroup.types.d.ts +0 -7
  203. package/ButtonGroup/index.d.ts +0 -3
  204. package/ButtonGroup/index.js +0 -7
  205. package/ButtonGroup/index.js.map +0 -1
  206. package/ButtonGroup/package.json +0 -1
  207. package/Card/Card.js +0 -42
  208. package/Card/Card.js.map +0 -1
  209. package/Card/index.d.ts +0 -3
  210. package/Card/index.js +0 -7
  211. package/Card/index.js.map +0 -1
  212. package/Card/package.json +0 -1
  213. package/CloseButton/CloseButton.js +0 -11
  214. package/CloseButton/CloseButton.js.map +0 -1
  215. package/CloseButton/index.d.ts +0 -3
  216. package/CloseButton/index.js +0 -7
  217. package/CloseButton/index.js.map +0 -1
  218. package/CloseButton/package.json +0 -1
  219. package/Dropdown/Dropdown.d.ts +0 -39
  220. package/Dropdown/Dropdown.js +0 -380
  221. package/Dropdown/Dropdown.js.map +0 -1
  222. package/Dropdown/index.d.ts +0 -4
  223. package/Dropdown/index.js +0 -8
  224. package/Dropdown/index.js.map +0 -1
  225. package/Dropdown/package.json +0 -1
  226. package/FileUploadButton/FileUploadButton.d.ts +0 -4
  227. package/FileUploadButton/FileUploadButton.js +0 -20
  228. package/FileUploadButton/FileUploadButton.js.map +0 -1
  229. package/FileUploadButton/FileUploadButton.types.d.ts +0 -7
  230. package/FileUploadButton/index.d.ts +0 -3
  231. package/FileUploadButton/index.js +0 -7
  232. package/FileUploadButton/index.js.map +0 -1
  233. package/FileUploadButton/package.json +0 -1
  234. package/FloatingLabel/FloatingLabel.js +0 -15
  235. package/FloatingLabel/FloatingLabel.js.map +0 -1
  236. package/FloatingLabel/index.d.ts +0 -3
  237. package/FloatingLabel/index.js +0 -7
  238. package/FloatingLabel/index.js.map +0 -1
  239. package/FloatingLabel/package.json +0 -1
  240. package/Form/Form.d.ts +0 -37
  241. package/Form/Form.js +0 -227
  242. package/Form/Form.js.map +0 -1
  243. package/Form/Form.types.d.ts +0 -159
  244. package/Form/FormSelect.d.ts +0 -12
  245. package/Form/FormSelect.js +0 -492
  246. package/Form/FormSelect.js.map +0 -1
  247. package/Form/index.d.ts +0 -4
  248. package/Form/index.js +0 -8
  249. package/Form/index.js.map +0 -1
  250. package/Form/package.json +0 -1
  251. package/InputGroup/InputGroup.d.ts +0 -7
  252. package/InputGroup/InputGroup.js +0 -31
  253. package/InputGroup/InputGroup.js.map +0 -1
  254. package/InputGroup/InputGroup.types.d.ts +0 -17
  255. package/InputGroup/index.d.ts +0 -4
  256. package/InputGroup/index.js +0 -7
  257. package/InputGroup/index.js.map +0 -1
  258. package/InputGroup/package.json +0 -1
  259. package/List/List.d.ts +0 -14
  260. package/List/List.js +0 -77
  261. package/List/List.js.map +0 -1
  262. package/List/List.types.d.ts +0 -28
  263. package/List/index.d.ts +0 -3
  264. package/List/index.js +0 -7
  265. package/List/index.js.map +0 -1
  266. package/List/package.json +0 -1
  267. package/Modal/Modal.js +0 -157
  268. package/Modal/Modal.js.map +0 -1
  269. package/Modal/index.d.ts +0 -3
  270. package/Modal/index.js +0 -7
  271. package/Modal/index.js.map +0 -1
  272. package/Modal/package.json +0 -1
  273. package/Nav/Nav.js +0 -29
  274. package/Nav/Nav.js.map +0 -1
  275. package/Nav/index.d.ts +0 -4
  276. package/Nav/index.js +0 -7
  277. package/Nav/index.js.map +0 -1
  278. package/Nav/package.json +0 -1
  279. package/NavBar/Navbar.js +0 -36
  280. package/NavBar/Navbar.js.map +0 -1
  281. package/NavBar/index.d.ts +0 -4
  282. package/NavBar/index.js +0 -8
  283. package/NavBar/index.js.map +0 -1
  284. package/NavBar/package.json +0 -1
  285. package/NavDropdown/NavDropdown.d.ts +0 -19
  286. package/NavDropdown/NavDropdown.js +0 -75
  287. package/NavDropdown/NavDropdown.js.map +0 -1
  288. package/NavDropdown/index.d.ts +0 -3
  289. package/NavDropdown/index.js +0 -7
  290. package/NavDropdown/index.js.map +0 -1
  291. package/NavDropdown/package.json +0 -1
  292. package/Overlay/Overlay.d.ts +0 -4
  293. package/Overlay/Overlay.js +0 -241
  294. package/Overlay/Overlay.js.map +0 -1
  295. package/Overlay/Overlay.types.d.ts +0 -22
  296. package/Overlay/index.js +0 -7
  297. package/Overlay/index.js.map +0 -1
  298. package/Overlay/package.json +0 -1
  299. package/Popout/Popout.js +0 -111
  300. package/Popout/Popout.js.map +0 -1
  301. package/Popout/index.d.ts +0 -3
  302. package/Popout/index.js +0 -7
  303. package/Popout/index.js.map +0 -1
  304. package/Popout/package.json +0 -1
  305. package/Spinner/Spinner.js +0 -11
  306. package/Spinner/Spinner.js.map +0 -1
  307. package/Spinner/index.d.ts +0 -3
  308. package/Spinner/index.js +0 -7
  309. package/Spinner/index.js.map +0 -1
  310. package/Spinner/package.json +0 -1
  311. package/Table/Table.js +0 -12
  312. package/Table/Table.js.map +0 -1
  313. package/Table/index.d.ts +0 -3
  314. package/Table/index.js +0 -7
  315. package/Table/index.js.map +0 -1
  316. package/Table/package.json +0 -1
  317. package/Tabs/Tabs.js +0 -162
  318. package/Tabs/Tabs.js.map +0 -1
  319. package/Tabs/index.d.ts +0 -3
  320. package/Tabs/index.js +0 -7
  321. package/Tabs/index.js.map +0 -1
  322. package/Tabs/package.json +0 -1
  323. package/ToggleButton/ToggleButton.d.ts +0 -4
  324. package/ToggleButton/ToggleButton.js +0 -18
  325. package/ToggleButton/ToggleButton.js.map +0 -1
  326. package/ToggleButton/ToggleButton.types.d.ts +0 -7
  327. package/ToggleButton/index.d.ts +0 -3
  328. package/ToggleButton/index.js +0 -7
  329. package/ToggleButton/index.js.map +0 -1
  330. package/ToggleButton/package.json +0 -1
  331. package/hooks/index.js +0 -7
  332. package/hooks/index.js.map +0 -1
  333. package/hooks/package.json +0 -1
  334. package/hooks/useClassname.d.ts +0 -2
  335. package/hooks/useClassname.js +0 -7
  336. package/hooks/useClassname.js.map +0 -1
  337. package/hooks/useDraggable.d.ts +0 -23
  338. package/hooks/useDraggable.js +0 -147
  339. package/hooks/useDraggable.js.map +0 -1
  340. package/hooks/useKeepElementFocused.d.ts +0 -2
  341. package/hooks/useKeepElementFocused.js +0 -37
  342. package/hooks/useKeepElementFocused.js.map +0 -1
  343. package/hooks/useQueryParams.d.ts +0 -2
  344. package/hooks/useQueryParams.js +0 -13
  345. package/hooks/useQueryParams.js.map +0 -1
  346. package/hooks/useScreenSize.d.ts +0 -5
  347. package/hooks/useScreenSize.js +0 -21
  348. package/hooks/useScreenSize.js.map +0 -1
  349. package/index.d.ts +0 -19
  350. package/index.js +0 -20
  351. package/index.js.map +0 -1
  352. package/styles/stargazerui.css +0 -6658
  353. package/styles/stargazerui.css.map +0 -1
  354. package/utils/ContrastingColor.d.ts +0 -1
  355. package/utils/CreateSyntheticEvent.d.ts +0 -2
  356. package/utils/CreateSyntheticEvent.js +0 -33
  357. package/utils/CreateSyntheticEvent.js.map +0 -1
  358. package/utils/IsInputKey.d.ts +0 -7
  359. package/utils/IsInputKey.js +0 -20
  360. package/utils/IsInputKey.js.map +0 -1
  361. package/utils/MergeClassnames.d.ts +0 -2
  362. package/utils/MergeClassnames.js +0 -7
  363. package/utils/MergeClassnames.js.map +0 -1
  364. package/utils/MergeRefs.d.ts +0 -1
  365. package/utils/MergeRefs.js +0 -16
  366. package/utils/MergeRefs.js.map +0 -1
  367. package/utils/createFastContext.d.ts +0 -16
  368. package/utils/createFastContext.js +0 -101
  369. package/utils/createFastContext.js.map +0 -1
  370. package/utils/index.d.ts +0 -4
  371. /package/{Button → types/components/Button}/Button.d.ts +0 -0
  372. /package/{CloseButton → types/components/CloseButton}/CloseButton.d.ts +0 -0
  373. /package/{FloatingLabel → types/components/FloatingLabel}/FloatingLabel.d.ts +0 -0
  374. /package/{Spinner → types/components/Spinner}/Spinner.d.ts +0 -0
  375. /package/{Spinner → types/components/Spinner}/Spinner.types.d.ts +0 -0
  376. /package/{Table → types/components/Table}/Table.d.ts +0 -0
  377. /package/{Tabs → types/components/Tabs}/Tabs.d.ts +0 -0
@@ -0,0 +1,222 @@
1
+
2
+ .sg-form-select-tag {
3
+ --input-text-color: #{$input-text-color};
4
+ --input-background-color: #{$input-background-color};
5
+ --input-border-color: #{$input-border-color};
6
+ --input-border-color-focus: #{$input-border-color-focus};
7
+ --input-border-color-invalid: #{$input-border-color-invalid};
8
+ --input-disabled-color: #{$input-disabled-color};
9
+
10
+ position: relative;
11
+ display: block;
12
+ width: 100%;
13
+ padding-block: $input-padding-x;
14
+ padding-inline: $input-padding-y calc(3 * $input-padding-y);
15
+ color: var(--input-text-color);
16
+
17
+ background-color: var(--input-background-color);
18
+ background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
19
+ background-repeat: no-repeat;
20
+ background-position: right $input-padding-x center;
21
+ background-size: 1em 0.75em;
22
+
23
+ border: $input-border-width $input-border-style var(--input-border-color);
24
+ border-radius: $input-border-radius;
25
+
26
+ appearance: none;
27
+
28
+ &:focus-visible, &:focus {
29
+ //@include sg-focus-visible()
30
+ border-color: var(--input-border-color-focus);
31
+ outline: 0;
32
+ box-shadow: 0;
33
+ }
34
+ &[multiple], &[size]:not([size="1"]) {
35
+ padding-right: $input-padding-x;
36
+ background-image: none;
37
+ }
38
+ &:disabled, .disabled {
39
+ --input-background-color: rgba(255, 255, 255, 0.04);
40
+ --input-placeholder-color: color-mix(in oklab, #{$input-placeholder-color}, white 40%);
41
+ --input-text-color: color-mix(in oklab, #{$input-placeholder-color}, white 40%);
42
+ cursor:not-allowed;
43
+ opacity: 1;
44
+ }
45
+ &.invalid, &:user-invalid, &[aria-invalid="true"] {
46
+ box-shadow: 0 0 4px 2px var(--input-border-color-invalid);
47
+ z-index: 2;
48
+ }
49
+ }
50
+
51
+
52
+ .sg-form-select {
53
+ --input-text-color: #{$input-text-color};
54
+ --input-background-color: #{$input-background-color};
55
+ --input-border-color: #{$input-border-color};
56
+ --input-border-color-focus: #{$input-border-color-focus};
57
+ --input-border-color-invalid: #{$input-border-color-invalid};
58
+ --input-border-width: #{$input-border-width};
59
+ --input-disabled-color: #{$input-disabled-color};
60
+
61
+ position: relative;
62
+ display: block;
63
+
64
+ height: calc(1.4rem + $input-padding-x + $input-padding-x);
65
+ min-width: min(12rem, 100%);
66
+ max-width: 15rem;
67
+
68
+ padding-block: $input-padding-x;
69
+ padding-inline: $input-padding-y calc(3 * $input-padding-y);
70
+ color: var(--input-text-color);
71
+
72
+ background-color: var(--input-background-color);
73
+ background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16"><path fill="none" stroke="%236e7b80ff" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="m2 5 6 6 6-6"/></svg>');
74
+ //background-image: ("./down_caret.svg");
75
+ background-repeat: no-repeat;
76
+ background-position: right $input-padding-x center;
77
+ background-size: 1em 0.75em;
78
+ border: $input-border-width outset var(--input-border-color);
79
+ border-radius: $input-border-radius;
80
+
81
+ font-size: 0.85rem;
82
+ line-height: 1.4;
83
+
84
+ span {
85
+ pointer-events:visible;
86
+ display: inline-block;
87
+ width: 100%;
88
+ max-width: 100%;
89
+ white-space: nowrap;
90
+ overflow: hidden;
91
+ text-overflow: ellipsis;
92
+ }
93
+
94
+ &:focus-within {
95
+ //@include sg-focus-visible()
96
+ border-color: var(--input-border-color-focus);
97
+ outline: 0;
98
+ box-shadow: 0;
99
+ }
100
+ .disabled {
101
+ --input-background-color: rgba(255, 255, 255, 0.04);
102
+ --input-placeholder-color: color-mix(in oklab, #{$input-placeholder-color}, white 40%);
103
+ --input-text-color: color-mix(in oklab, #{$input-placeholder-color}, white 40%);
104
+ }
105
+ }
106
+
107
+ .sg-select-control {
108
+ text-align: start;
109
+
110
+ cursor: default;
111
+
112
+ &:disabled {
113
+ --input-background-color: rgba(255, 255, 255, 0.04);
114
+ --input-placeholder-color: color-mix(in oklab, #{$input-placeholder-color}, white 40%);
115
+ --input-text-color: color-mix(in oklab, #{$input-placeholder-color}, white 40%);
116
+ cursor: not-allowed;
117
+ opacity: 1;
118
+ }
119
+ &:user-invalid, &.invalid, &[aria-invalid="true"] {
120
+ //outline: 2px solid $input-border-color-invalid;
121
+ box-shadow: 0 0 4px 2px var(--input-border-color-invalid);
122
+ }
123
+ }
124
+
125
+ .sg-select-input {
126
+ background-color: inherit;
127
+ border: none;
128
+ height: 100%;
129
+ max-width: 80%;
130
+ color: inherit;
131
+
132
+ &[multiple], &[size]:not([size="1"]) {
133
+ padding-right: $input-padding-x;
134
+ background-image: none;
135
+ }
136
+ &:disabled {
137
+ color: inherit;
138
+ background-color: inherit;
139
+ opacity: 1;
140
+ }
141
+ &:focus, &:focus-within, &:focus-visible {
142
+ border-color: transparent;
143
+ outline: none;
144
+ }
145
+ &::placeholder {
146
+ color: $input-placeholder-color;
147
+ opacity: 1;
148
+ }
149
+
150
+ }
151
+
152
+ .sg-select-list {
153
+ --input-text-color: #{$input-text-color};
154
+ --input-background-color: #{$input-background-color};
155
+ --input-border-color: #{$input-border-color};
156
+ --input-border-color-focus: #{$input-border-color-focus};
157
+ --input-border-color-invalid: #{$input-border-color-invalid};
158
+ --input-border-width: #{$input-border-width};
159
+ --input-disabled-color: #{$input-disabled-color};
160
+ --bg-color: #{$input-background-color};
161
+ --txt-color: black;
162
+ --z-index: #{$zindex-dropdown};
163
+ overflow-y: auto;
164
+
165
+ background-color: var(--bg-color);
166
+ color: inherit;
167
+
168
+ position: absolute;
169
+ top: calc(100% + var(--input-border-width)*1px);
170
+ left: 0;
171
+ width: 100%;
172
+ padding: 0;
173
+
174
+ border-radius: 0;// 0.375rem;
175
+ //border: 1px solid color-mix(in srgb, currentColor, white);
176
+ border: 2px outset color-mix(in oklab, $sg-body-bg, white 60%);
177
+
178
+ list-style-type: none;
179
+
180
+ z-index: var(--z-index);
181
+ }
182
+
183
+ .sg-select-list-item {
184
+ --z-index: #{$zindex-dropdown};
185
+ --padding-right: 3ex;
186
+ position: relative;
187
+ padding: 0.25rem 0.5rem;
188
+ padding-right: var(--padding-right);
189
+ font-size: 0.85rem;
190
+ user-select: none;
191
+
192
+ z-index: calc( var(--z-index) + 1);
193
+
194
+ &.focus {
195
+ background-color: color-mix(in oklab, var(--input-background-color), white 20%);
196
+ &:active {
197
+ background-color: color-mix(in oklab, var(--input-background-color), white 25%);
198
+ }
199
+ }
200
+
201
+ &:first-child {
202
+ border-top-right-radius: inherit;
203
+ border-top-left-radius: inherit;
204
+ }
205
+ &:last-child {
206
+ border-bottom-left-radius: inherit;
207
+ border-bottom-right-radius: inherit;
208
+ }
209
+ .sg-form-select-check-icon-wrapper {
210
+ height: 100%;
211
+ width: var(--padding-right);
212
+ position: absolute;
213
+ right: 0;
214
+ top: 0;
215
+ display: grid;
216
+ place-items: center;
217
+ }
218
+ .sg-form-select-check-icon {
219
+
220
+ margin-block: auto;
221
+ }
222
+ }
@@ -0,0 +1,116 @@
1
+ @mixin slider-cap {
2
+ --cap-height: calc( 1 - 2*var(--padding-block-fraction));
3
+ box-sizing: border-box;
4
+ content: "";
5
+ position: absolute;
6
+ top: calc(100% * var(--padding-block-fraction));
7
+ height: calc( 100% * var(--cap-height));
8
+ width: calc(var(--slider-thumb-width) * 0.5);
9
+ // give background-color and the position of the pseudo element as a content block
10
+ @content
11
+ }
12
+
13
+ .sg-form-slider {
14
+ --slider-height: #{$slider-height};
15
+
16
+ --slider-filled-color: #{$slider-filled-color};
17
+ --slider-filled-border-color: #{$slider-filled-border-color};
18
+
19
+ --slider-empty-color: #{$slider-empty-color};
20
+ --slider-empty-border-color: #{$slider-empty-border-color};
21
+
22
+ --padding-block-fraction: 1/3;
23
+
24
+ --slider-thumb-width: #{$slider-thumb-width};
25
+ --slider-thumb-height: #{$slider-thumb-height};
26
+ --slider-thumb-border-color: #{$input-border-color};
27
+ --filled: 40%;
28
+
29
+ &:focus-within {
30
+ //outline: 2px outset $danger;
31
+ }
32
+
33
+ display: grid;
34
+ grid-template-columns: var(--filled) auto calc(100% - var(--filled));
35
+ position: relative;
36
+ height: var(--slider-height);
37
+ //border: $input-border-width $input-border-style $input-border-color;
38
+ padding-block: calc(var(--slider-height)*var(--padding-block-fraction));
39
+ padding-inline: calc(var(--slider-thumb-width) * 0.5);
40
+
41
+ &:hover {
42
+ --slider-filled-color: #{$slider-filled-hover-color};
43
+ --slider-filled-border-color: #{$slider-filled-border-hover-color};
44
+ --slider-empty-color: #{$slider-empty-bover-color};
45
+ --slider-empty-border-color: #{$slider-empty-border-hover-color};
46
+ }
47
+
48
+ .sg-form-slider-filled {
49
+ display: block;
50
+ background-color: var(--slider-filled-color);
51
+ border: $slider-border-width outset var(--slider-filled-border-color);
52
+ border-left: none;
53
+ border-right: none;
54
+ height: 100%;
55
+ width: 100%;
56
+ &::before {
57
+ @include slider-cap {
58
+ background-color: var(--slider-filled-color);
59
+ border: $slider-border-width outset var(--slider-filled-border-color);
60
+ border-right: none;
61
+ left: 0;
62
+ }
63
+ }
64
+ }
65
+ .sg-form-slider-thumb {
66
+ cursor: grab;
67
+ &[data-grabbing="true"] {
68
+ cursor: grabbing;
69
+ }
70
+ position: relative;
71
+ display: block;
72
+
73
+ height: 100%;
74
+ //width: var(--slider-thumb-width);
75
+
76
+ &:focus-visible {
77
+ --slider-thumb-border-color: white;
78
+ }
79
+ &::before {
80
+ content: "";
81
+ position: absolute;
82
+ box-sizing: border-box;
83
+ left: calc(var(--slider-thumb-width) * -0.5);
84
+ top: calc(-1 * var(--padding-block-fraction)*100% );
85
+ height: calc( (2*var(--padding-block-fraction) + 1) * 100%);
86
+ width: var(--slider-thumb-width);
87
+ background-color: $input-border-color;// transparent;// $danger;
88
+ //background-image: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="https://www.w3.org/2000/svg" viewBox="0 0 166 166"><polygon fill="'+$farbe+'" points="83 26.8 65.7 61.8 27.1 67.4 55 94.7 48.5 133.2 83 115 117.5 133.2 111 94.7 138.9 67.4 100.3 61.8 83 26.8 83 26.8"/></svg>');
89
+ border: $input-border-width $input-border-style var(--slider-thumb-border-color);
90
+ }
91
+ &:focus-visible {
92
+ --focus-outline: 2px outset $danger;
93
+ outline: 0;
94
+ box-shadow: none;
95
+ }
96
+ }
97
+ .sg-form-slider-empty {
98
+ display: block;
99
+ background-color: var(--slider-empty-color);
100
+ border: $slider-border-width outset var(--slider-empty-border-color);
101
+ border-left: none;
102
+ border-right: none;
103
+ height: 100%;
104
+ width: 100%;
105
+
106
+ &::after {
107
+ @include slider-cap {
108
+ background-color: var(--slider-empty-color);
109
+ border: $slider-border-width outset var(--slider-empty-border-color);
110
+ border-left: none;
111
+ right: 0;
112
+ z-index: -1;
113
+ }
114
+ }
115
+ }
116
+ }
@@ -0,0 +1,6 @@
1
+ .sg-form-text {
2
+ font-size: 0.75em;
3
+ padding-inline: 0.5em;
4
+ opacity: 0.8;
5
+ margin-top: 0.25em;
6
+ }
@@ -1,25 +1,32 @@
1
- import React from "react";
2
- type BaseAnchorType = React.DetailedHTMLProps<React.AnchorHTMLAttributes<HTMLAnchorElement>, HTMLAnchorElement>;
3
- type BaseButtonType = React.DetailedHTMLProps<React.ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>;
4
- type BaseDialogType = React.DetailedHTMLProps<React.DialogHTMLAttributes<HTMLDialogElement>, HTMLDialogElement>;
5
- type BaseDivType = React.DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, HTMLDivElement>;
6
- type BaseFormType = React.DetailedHTMLProps<React.FormHTMLAttributes<HTMLFormElement>, HTMLFormElement>;
7
- type BaseHeadingType = React.DetailedHTMLProps<React.HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>;
8
- type BaseInputType = React.DetailedHTMLProps<React.InputHTMLAttributes<HTMLInputElement>, HTMLInputElement>;
9
- type BaseHrType = React.DetailedHTMLProps<React.HTMLAttributes<HTMLHRElement>, HTMLHRElement>;
10
- type BaseLabelType = React.DetailedHTMLProps<React.LabelHTMLAttributes<HTMLLabelElement>, HTMLLabelElement>;
11
- type BaseLItemType = React.DetailedHTMLProps<React.LiHTMLAttributes<HTMLLIElement>, HTMLLIElement>;
12
- type BaseMeterType = React.DetailedHTMLProps<React.MeterHTMLAttributes<HTMLMeterElement>, HTMLMeterElement>;
13
- type BaseNavType = React.DetailedHTMLProps<React.HTMLAttributes<HTMLElement>, HTMLElement>;
14
- type BaseParagraphType = React.DetailedHTMLProps<React.HTMLAttributes<HTMLParagraphElement>, HTMLParagraphElement>;
15
- type BaseProgressBarType = React.DetailedHTMLProps<React.ProgressHTMLAttributes<HTMLProgressElement>, HTMLProgressElement>;
16
- type BaseSelectType = React.DetailedHTMLProps<React.SelectHTMLAttributes<HTMLSelectElement>, HTMLSelectElement>;
17
- type BaseSliderType = React.DetailedHTMLProps<React.InputHTMLAttributes<HTMLInputElement>, HTMLInputElement>;
18
- type BaseSmallType = React.DetailedHTMLProps<React.HTMLAttributes<HTMLElement>, HTMLElement>;
19
- type BaseSpanType = React.DetailedHTMLProps<React.HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>;
20
- type BaseSVGType = React.SVGProps<SVGSVGElement>;
21
- type BaseTableType = React.DetailedHTMLProps<React.TableHTMLAttributes<HTMLTableElement>, HTMLTableElement>;
22
- type BaseUListType = React.DetailedHTMLProps<React.HTMLAttributes<HTMLUListElement>, HTMLUListElement>;
23
- type BaseElementType = React.DetailedHTMLProps<React.HTMLAttributes<HTMLElement>, HTMLElement>;
24
- type BaseElementType2 = React.DetailedHTMLProps<React.HTMLAttributes<Element>, Element>;
25
- export { BaseAnchorType, BaseButtonType, BaseDialogType, BaseDivType, BaseElementType, BaseElementType2, BaseFormType, BaseHeadingType, BaseHrType, BaseInputType, BaseLItemType, BaseLabelType, BaseSliderType, BaseMeterType, BaseNavType, BaseParagraphType, BaseProgressBarType, BaseSelectType, BaseSmallType, BaseSpanType, BaseSVGType, BaseTableType, BaseUListType };
1
+ import React from "react";
2
+
3
+ type BaseAnchorType = React.DetailedHTMLProps<React.AnchorHTMLAttributes<HTMLAnchorElement>, HTMLAnchorElement>;
4
+ type BaseButtonType = React.DetailedHTMLProps<React.ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>;
5
+ type BaseDialogType = React.DetailedHTMLProps<React.DialogHTMLAttributes<HTMLDialogElement>, HTMLDialogElement>;
6
+ type BaseDivType = React.DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, HTMLDivElement>;
7
+ type BaseFormType = React.DetailedHTMLProps<React.FormHTMLAttributes<HTMLFormElement>, HTMLFormElement>;
8
+ type BaseHeadingType = React.DetailedHTMLProps<React.HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>;
9
+ type BaseInputType = React.DetailedHTMLProps<React.InputHTMLAttributes<HTMLInputElement>, HTMLInputElement>;
10
+ type BaseHrType = React.DetailedHTMLProps<React.HTMLAttributes<HTMLHRElement>, HTMLHRElement>;
11
+ type BaseLabelType = React.DetailedHTMLProps<React.LabelHTMLAttributes<HTMLLabelElement>, HTMLLabelElement>;
12
+ type BaseLItemType = React.DetailedHTMLProps<React.LiHTMLAttributes<HTMLLIElement>, HTMLLIElement>;
13
+ type BaseMeterType = React.DetailedHTMLProps<React.MeterHTMLAttributes<HTMLMeterElement>, HTMLMeterElement>;
14
+ type BaseNavType = React.DetailedHTMLProps<React.HTMLAttributes<HTMLElement>, HTMLElement>;
15
+ type BaseParagraphType = React.DetailedHTMLProps<React.HTMLAttributes<HTMLParagraphElement>, HTMLParagraphElement>;
16
+ type BaseProgressBarType = React.DetailedHTMLProps<React.ProgressHTMLAttributes<HTMLProgressElement>, HTMLProgressElement>;
17
+ type BaseSelectType = React.DetailedHTMLProps<React.SelectHTMLAttributes<HTMLSelectElement>, HTMLSelectElement>;
18
+ type BaseSliderType = React.DetailedHTMLProps<React.InputHTMLAttributes<HTMLInputElement>, HTMLInputElement>;
19
+ type BaseSmallType = React.DetailedHTMLProps<React.HTMLAttributes<HTMLElement>, HTMLElement>;
20
+ type BaseSpanType = React.DetailedHTMLProps<React.HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>;
21
+ type BaseSVGType = React.SVGProps<SVGSVGElement>
22
+ type BaseTableType = React.DetailedHTMLProps<React.TableHTMLAttributes<HTMLTableElement>, HTMLTableElement>;
23
+ type BaseUListType = React.DetailedHTMLProps<React.HTMLAttributes<HTMLUListElement>, HTMLUListElement>;
24
+
25
+ type BaseElementType = React.DetailedHTMLProps<React.HTMLAttributes<HTMLElement>, HTMLElement>;
26
+ type BaseElementType2 = React.DetailedHTMLProps<React.HTMLAttributes<Element>, Element>;
27
+
28
+ export {
29
+ BaseAnchorType, BaseButtonType, BaseDialogType, BaseDivType, BaseElementType, BaseElementType2, BaseFormType, BaseHeadingType, BaseHrType,
30
+ BaseInputType, BaseLItemType, BaseLabelType, BaseSliderType, BaseMeterType, BaseNavType, BaseParagraphType, BaseProgressBarType, BaseSelectType, BaseSmallType, BaseSpanType,
31
+ BaseSVGType, BaseTableType, BaseUListType
32
+ }
@@ -0,0 +1,25 @@
1
+ export default function contrastingColor(color: string)
2
+ {
3
+ return (luma(color) >= 165) ? '000' : 'fff';
4
+ }
5
+
6
+ function luma(color: string) // color can be a hx string or an array of RGB values 0-255
7
+ {
8
+ let rgb = (typeof color === 'string') ? hexToRGBArray(color) : color;
9
+ return (0.2126 * rgb[0]) + (0.7152 * rgb[1]) + (0.0722 * rgb[2]); // SMPTE C, Rec. 709 weightings
10
+ }
11
+
12
+ function hexToRGBArray(color: string)
13
+ {
14
+ if(color.startsWith("#")) {
15
+ color = color.replace("#", "")
16
+ }
17
+ if (color.length === 3)
18
+ color = color.charAt(0) + color.charAt(0) + color.charAt(1) + color.charAt(1) + color.charAt(2) + color.charAt(2);
19
+ else if (color.length !== 6)
20
+ throw new Error('Invalid hex color: ' + color)
21
+ let rgb = [];
22
+ for (let i = 0; i <= 2; i++)
23
+ rgb[i] = parseInt(color.substr(i * 2, 2), 16)
24
+ return rgb;
25
+ }
@@ -0,0 +1,30 @@
1
+ const createSyntheticEvent = <T extends Element, E extends Event>(event: E): React.SyntheticEvent<T, E> => {
2
+ let isDefaultPrevented = false;
3
+ let isPropagationStopped = false;
4
+ const preventDefault = () => {
5
+ isDefaultPrevented = true;
6
+ event.preventDefault();
7
+ }
8
+ const stopPropagation = () => {
9
+ isPropagationStopped = true;
10
+ event.stopPropagation();
11
+ }
12
+ return {
13
+ nativeEvent: event,
14
+ currentTarget: event.currentTarget as EventTarget & T,
15
+ target: event.target as EventTarget & T,
16
+ bubbles: event.bubbles,
17
+ cancelable: event.cancelable,
18
+ defaultPrevented: event.defaultPrevented,
19
+ eventPhase: event.eventPhase,
20
+ isTrusted: event.isTrusted,
21
+ preventDefault,
22
+ isDefaultPrevented: () => isDefaultPrevented,
23
+ stopPropagation,
24
+ isPropagationStopped: () => isPropagationStopped,
25
+ persist: () => {},
26
+ timeStamp: event.timeStamp,
27
+ type: event.type,
28
+ };
29
+ }
30
+ export default createSyntheticEvent
@@ -0,0 +1,50 @@
1
+ const downloadFile = ({ data, fileName, fileType }) => {
2
+ // Create a blob with the data we want to download as a file
3
+ const blob = new Blob([data], { type: fileType })
4
+ // Create an anchor element and dispatch a click event on it
5
+ // to trigger a download
6
+ const a = document.createElement('a')
7
+ a.download = fileName
8
+ a.href = window.URL.createObjectURL(blob)
9
+ const clickEvt = new MouseEvent('click', {
10
+ view: window,
11
+ bubbles: true,
12
+ cancelable: true,
13
+ })
14
+ a.dispatchEvent(clickEvt)
15
+ a.remove()
16
+ }
17
+
18
+ export const exportToJson = (event, charName, currentState) => {
19
+ event.preventDefault()
20
+ let test = ""
21
+ if(charName === "") {
22
+ test = "character"
23
+ }
24
+ else {
25
+ let test1 = charName.split(" ")
26
+ test1.map(word => (
27
+ test += word
28
+ ))
29
+ }
30
+ downloadFile({
31
+ data: JSON.stringify(currentState, null, "\t"),
32
+ fileName: test +'.json',
33
+ fileType: 'text/json',
34
+ })
35
+ }
36
+
37
+ export const readFileOnUpload = (uploadedFile, onUploadFunction) => {
38
+ const fileReader = new FileReader();
39
+ fileReader.onloadend = () => {
40
+ try {
41
+ //dispatch(importState(JSON.parse(fileReader.result), dispatch))
42
+ onUploadFunction(fileReader.result)
43
+ } catch(e) {
44
+ console.log("**Not valid JSON file!**");
45
+ }
46
+ }
47
+ if( uploadedFile!== undefined) {
48
+ fileReader.readAsText(uploadedFile);
49
+ }
50
+ }
@@ -0,0 +1,18 @@
1
+ export type InputKeyType = {id:string, alt?:boolean, shift?: boolean, ctrl?: boolean}
2
+
3
+ export const isValidInputKey = (event: React.KeyboardEvent | KeyboardEvent, inputKeys: InputKeyType[]) => {
4
+ const isValidKey = inputKeys.find(inputKey => inputKey.id === event.key)
5
+ if(!isValidKey) return
6
+
7
+ let isCtrl = true, isAlt = true, isShift = true
8
+ if (event.altKey && !isValidKey.alt) {
9
+ isAlt = false
10
+ }
11
+ if (event.ctrlKey && !isValidKey.ctrl) {
12
+ isCtrl = false
13
+ }
14
+ if (event.shiftKey && !isValidKey.shift) {
15
+ isShift = false
16
+ }
17
+ return isValidKey && isAlt && isCtrl && isShift
18
+ }
@@ -0,0 +1,5 @@
1
+ const mergeClassnames = (...args: (string | undefined)[]) => {
2
+ return args.filter(arg => arg != undefined).join(" ")
3
+ }
4
+
5
+ export default mergeClassnames
@@ -0,0 +1,12 @@
1
+ export default function mergeRefs<T = any>(refs: Array<React.MutableRefObject<T> | React.LegacyRef<T> | undefined | null>
2
+ ): React.RefCallback<T> {
3
+ return (value) => {
4
+ refs.forEach((ref) => {
5
+ if (typeof ref === "function") {
6
+ ref(value)
7
+ } else if (ref != null) {
8
+ (ref as React.MutableRefObject<T | null>).current = value;
9
+ }
10
+ })
11
+ }
12
+ }
@@ -0,0 +1,119 @@
1
+ import { type ReactNode, useRef, useMemo, useCallback, createContext, useContext, useSyncExternalStore } from "react";
2
+ import { isEqual } from "lodash";
3
+ //type Store = {first:string, last:string, isAllowed?: boolean, number?: number}
4
+
5
+ const createFastContext = <Store,>() => {
6
+ type SelectorType = (store: Store) => (Store[keyof Store] | Store | Array<Store[keyof Store]>)
7
+ type IsEqualFunction = (oldValue: ReturnType<SelectorType>, newValue: ReturnType<SelectorType>) => boolean
8
+ type SetStore = Partial<Store> | ( (store: Store) => Store )
9
+ type GetStoreReturn<T> = T extends SelectorType ? ReturnType<T>: T extends undefined ? Store : never
10
+ type SetStoreReturn = (setProp: SetStore) => void
11
+
12
+
13
+ function useStoreData(initialState:Store, refreshKeys: Array<keyof Store> = []) : {
14
+ get: () => Store,
15
+ set: (setProp: SetStore) => void,
16
+ subscribe: (callback: () => void) => () => void,
17
+ } {
18
+ const store = useRef(initialState)
19
+ const subscribers = useRef(new Set<() => void>())
20
+
21
+ refreshKeys.forEach(key => {
22
+ if(initialState[key] != store.current[key]) store.current[key] = initialState[key]
23
+ })
24
+ const get = useCallback( () => {
25
+ return store.current
26
+ }, [])
27
+ const set = useCallback( (setProp: SetStore) => {
28
+ if( typeof setProp === "function") {
29
+ store.current = setProp(store.current)
30
+ }
31
+ else store.current = {...store.current, ...setProp}
32
+ subscribers.current.forEach((callback) => callback())
33
+ }, [])
34
+ const subscribe = useCallback( (callback: any) => {
35
+ subscribers.current.add(callback)
36
+ return () => {subscribers.current.delete(callback)}
37
+ }, [])
38
+ return {get, set, subscribe}
39
+ }
40
+
41
+
42
+ const StoreContext = createContext<ReturnType<typeof useStoreData> | null>(null);
43
+ const StoreContextProvider = ({children, initialState, refreshKeys}:{children:ReactNode, initialState: Store, refreshKeys?: Array<keyof Store>}) => {
44
+ return(
45
+ <StoreContext.Provider value={useStoreData(initialState, refreshKeys)}>
46
+ {children}
47
+ </StoreContext.Provider>
48
+ )
49
+ }
50
+
51
+ function getStore<T extends SelectorType, >(selector: T, equalityFunction?:IsEqualFunction, id?: string): GetStoreReturn<T>
52
+ function getStore<T extends undefined, >(selector?: T, equalityFunction?:IsEqualFunction, id?: string): GetStoreReturn<T>
53
+ function getStore<T extends SelectorType, >(selector: T, equalityFunction?:IsEqualFunction, id?: string): GetStoreReturn<T> {
54
+ const store = useContext(StoreContext)
55
+ if(!store) {
56
+ throw new Error("You have to use useStore within the proper provider!")
57
+ }
58
+ const storeGet:SelectorType = (store) => {
59
+ return store
60
+ }
61
+
62
+ let getSnapshot = useMemo(() => {
63
+ const selectorInternal = selector !== undefined ? selector : storeGet
64
+ //memoization through closures
65
+ let hasMemo = false
66
+ let memoState: Store | undefined
67
+ let memoSelected: ReturnType<SelectorType>
68
+ const memoSelector = (newState: Store) => {
69
+ if(!hasMemo) {
70
+ hasMemo = true
71
+ memoState = newState
72
+ memoSelected = selectorInternal(newState)
73
+ return memoSelected
74
+ }
75
+ const oldState = memoState
76
+ if(isEqual(oldState, newState)) return memoSelected
77
+ const oldSelected = memoSelected
78
+ const newSelected = selectorInternal(newState)
79
+ if(id) console.log(id, oldSelected == newSelected)
80
+ if(equalityFunction && equalityFunction(oldSelected, newSelected)) {
81
+ //console.log(oldSelected, newSelected, equalityFunction(oldSelected, newSelected))
82
+ return memoSelected
83
+ }
84
+ if(isEqual(oldSelected, newSelected)) return memoSelected
85
+ memoState = newState
86
+ memoSelected = newSelected
87
+ return newSelected
88
+ }
89
+
90
+ return () => memoSelector(store.get()) as GetStoreReturn<T>
91
+ }, [selector])
92
+
93
+ //const getSnapshot = () => (selectorInternal!(store.get()) as GetStoreReturn<T>)
94
+
95
+ const state = useSyncExternalStore< GetStoreReturn<T> >(store.subscribe, getSnapshot)
96
+ return state
97
+ }
98
+ function setStore(): SetStoreReturn {
99
+ const store = useContext(StoreContext)
100
+ if(!store) {
101
+ throw new Error("You have to use useStore within the proper provider!")
102
+ }
103
+ return store.set
104
+ }
105
+ function checkContext():boolean {
106
+ const store = useContext(StoreContext)
107
+ console.log("check ", store != null)
108
+ return store != null
109
+ }
110
+
111
+ return {
112
+ Provider: StoreContextProvider,
113
+ getStore: getStore,
114
+ setStore: setStore,
115
+ checkContext
116
+ }
117
+ }
118
+ export default createFastContext
119
+ export type StoreType = Parameters<ReturnType<typeof createFastContext>["Provider"]>[0]["initialState"]