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,178 @@
1
+ @use 'sass:math';
2
+
3
+ $grid-columns: 12 !default;
4
+ $grid-gutter-width: 1.5rem !default;
5
+ $grid-row-columns: 6 !default;
6
+ $container-padding-x: $grid-gutter-width !default;
7
+
8
+
9
+ @function breakpoint-infix($name, $breakpoints: $grid-breakpoints) {
10
+ @return if(breakpoint-min($name, $breakpoints) == null, "", "-#{$name}");
11
+ }
12
+ @function breakpoint-min($name, $breakpoints: $grid-breakpoints) {
13
+ $min: map-get($breakpoints, $name);
14
+ @return if($min != 0, $min, null);
15
+ }
16
+
17
+ @mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {
18
+ $min: breakpoint-min($name, $breakpoints);
19
+ @if $min {
20
+ @media (min-width: $min) {
21
+ @content;
22
+ }
23
+ } @else {
24
+ @content;
25
+ }
26
+ }
27
+ @mixin row-cols($count) {
28
+ > * {
29
+ flex: 0 0 auto;
30
+ width: math.div(100%, $count);
31
+ }
32
+ }
33
+ @mixin make-col-auto() {
34
+ flex: 0 0 auto;
35
+ width: auto;
36
+ }
37
+ @mixin make-col($size: false, $columns: $grid-columns) {
38
+ @if $size {
39
+ flex: 0 0 auto;
40
+ width: percentage(math.div($size, $columns));
41
+
42
+ } @else {
43
+ flex: 1 1 0;
44
+ max-width: 100%;
45
+ }
46
+ }
47
+ @mixin make-col-offset($size, $columns: $grid-columns) {
48
+ $num: math.div($size, $columns);
49
+ margin-left: if($num == 0, 0, percentage($num));
50
+ }
51
+
52
+ @mixin make-grid-columns($columns: $grid-columns, $gutter: $grid-gutter-width, $breakpoints: $grid-breakpoints) {
53
+ @each $breakpoint in map-keys($breakpoints) {
54
+ $infix: breakpoint-infix($breakpoint, $breakpoints);
55
+
56
+ @include media-breakpoint-up($breakpoint, $breakpoints) {
57
+ // Provide basic `.col-{bp}` classes for equal-width flexbox columns
58
+ .sg-col#{$infix} {
59
+ flex: 1 0 0%; // Flexbugs #4: https://github.com/philipwalton/flexbugs#flexbug-4
60
+ }
61
+
62
+ .sg-row-cols#{$infix}-auto > * {
63
+ @include make-col-auto();
64
+ }
65
+
66
+ @if $grid-row-columns > 0 {
67
+ @for $i from 1 through $grid-row-columns {
68
+ .sg-row-cols#{$infix}-#{$i} {
69
+ @include row-cols($i);
70
+ }
71
+ }
72
+ }
73
+
74
+ .sg-col#{$infix}-auto {
75
+ @include make-col-auto();
76
+ }
77
+
78
+ @if $columns > 0 {
79
+ @for $i from 1 through $columns {
80
+ .sg-col#{$infix}-#{$i} {
81
+ @include make-col($i, $columns);
82
+ }
83
+ }
84
+
85
+
86
+ // `$columns - 1` because offsetting by the width of an entire row isn't possible
87
+ @for $i from 0 through ($columns - 1) {
88
+ @if not ($infix == "" and $i == 0) { // Avoid emitting useless .offset-0
89
+ .sg-offset#{$infix}-#{$i} {
90
+ @include make-col-offset($i, $columns);
91
+ }
92
+ }
93
+ }
94
+ }
95
+
96
+ }
97
+ }
98
+ }
99
+ @mixin make-row($gutter: $grid-gutter-width) {
100
+ --sg-gutter-x: #{$gutter};
101
+ --sg-gutter-y: 0;
102
+ display: flex;
103
+ flex-wrap: wrap;
104
+ margin-top: calc(-1 * var(--sg-gutter-y)); // stylelint-disable-line function-disallowed-list
105
+ margin-right: calc(-.5 * var(--sg-gutter-x)); // stylelint-disable-line function-disallowed-list
106
+ margin-left: calc(-.5 * var(--sg-gutter-x)); // stylelint-disable-line function-disallowed-list
107
+ }
108
+
109
+ @mixin make-col-ready() {
110
+ // Add box sizing if only the grid is loaded
111
+ // Prevent columns from becoming too narrow when at smaller grid tiers by
112
+ // always setting `width: 100%;`. This works because we set the width
113
+ // later on to override this initial width.
114
+ flex-shrink: 0;
115
+ width: 100%;
116
+ max-width: 100%; // Prevent `.col-auto`, `.col` (& responsive variants) from breaking out the grid
117
+ padding-right: calc(var(--sg-gutter-x) * .5); // stylelint-disable-line function-disallowed-list
118
+ padding-left: calc(var(--sg-gutter-x) * .5); // stylelint-disable-line function-disallowed-list
119
+ margin-top: var(--sg-gutter-y);
120
+ }
121
+
122
+
123
+
124
+ .sg-row {
125
+ @include make-row();
126
+
127
+ > * {
128
+ @include make-col-ready();
129
+ }
130
+ }
131
+
132
+ @include make-grid-columns();
133
+
134
+
135
+ /* Containers */
136
+
137
+ @mixin make-container($gutter: $container-padding-x) {
138
+ --sg-gutter-x: #{$gutter};
139
+ --sg-gutter-y: 0;
140
+ width: 100%;
141
+ padding-right: calc(var(--sg-gutter-x) * .5); // stylelint-disable-line function-disallowed-list
142
+ padding-left: calc(var(--sg-gutter-x) * .5); // stylelint-disable-line function-disallowed-list
143
+ margin-right: auto;
144
+ margin-left: auto;
145
+ }
146
+
147
+ .sg-container, // Single container class with breakpoint max-widths
148
+ .sg-container-fluid { // 100% wide container at all breakpoints
149
+ @include make-container();
150
+ }
151
+ // Responsive containers that are 100% wide until a breakpoint
152
+ @each $breakpoint, $container-max-width in $container-max-widths {
153
+ .sg-container-#{$breakpoint} {
154
+ @extend .sg-container-fluid;
155
+ }
156
+
157
+ @include media-breakpoint-up($breakpoint, $grid-breakpoints) {
158
+ %responsive-sg-container-#{$breakpoint} {
159
+ max-width: $container-max-width;
160
+ }
161
+
162
+ // Extend each breakpoint which is smaller or equal to the current breakpoint
163
+ $extend-breakpoint: true;
164
+
165
+ @each $name, $width in $grid-breakpoints {
166
+ @if ($extend-breakpoint) {
167
+ .sg-container#{breakpoint-infix($name, $grid-breakpoints)} {
168
+ @extend %responsive-sg-container-#{$breakpoint};
169
+ }
170
+
171
+ // Once the current breakpoint is reached, stop extending
172
+ @if ($breakpoint == $name) {
173
+ $extend-breakpoint: false;
174
+ }
175
+ }
176
+ }
177
+ }
178
+ }
@@ -0,0 +1,71 @@
1
+ .sg-input-group {
2
+ display: flex;
3
+ flex-wrap: wrap;
4
+ align-items: stretch;
5
+ width: 100%;
6
+ //padding-bottom: 0.5rem;
7
+ > .sg-form-control,
8
+ > .sg-form-control-plaintext,
9
+ > .sg-form-select,
10
+ > .sg-form-select-tag
11
+ {
12
+ flex: 1 1 auto;
13
+ width: 1%;
14
+ min-width: 5rem;
15
+ }
16
+
17
+ > .sg-button, > button {
18
+ position: relative;
19
+ z-index: 2;
20
+ }
21
+
22
+ > :not(:first-child):not(:last-child) {
23
+ border-radius: 0;
24
+ }
25
+ > :first-child {
26
+ border-top-right-radius: 0;
27
+ border-bottom-right-radius: 0;
28
+ }
29
+ > :last-child {
30
+ border-top-left-radius: 0;
31
+ border-bottom-left-radius: 0;
32
+ }
33
+ }
34
+ .sg-input-group-text {
35
+ display: flex;
36
+ flex: 0 1 auto;
37
+ overflow: auto;
38
+ width: fit-content;
39
+ max-width: 8rem;
40
+ align-items: center;
41
+ text-align: center;
42
+ font-size: 0.85rem;
43
+
44
+ padding: $input-padding-x $input-padding-y;
45
+
46
+ white-space: nowrap;
47
+
48
+ background-color: $input-border-color;
49
+ color: $input-text-color;
50
+ border: $input-border-width outset $input-border-color;
51
+ border-right-width: 0;
52
+ border-radius: $input-border-radius;
53
+ }
54
+ .sg-form-control + .sg-input-group-text {
55
+ border-left-width: 0;
56
+ border-right-width: $input-border-width;
57
+ }
58
+
59
+ .sg-input-group-grid {
60
+ display: flex;
61
+ flex-wrap: wrap;
62
+ width: 100%;
63
+ align-items: stretch;
64
+ padding-bottom: 0.5rem;
65
+ > .sg-input-group, > .sg-form-floating {
66
+ flex: 1 1 auto;
67
+ width: 1%;
68
+ min-width: 13rem;
69
+ padding-bottom: 0;
70
+ }
71
+ }
@@ -0,0 +1,62 @@
1
+ .sg-list {
2
+ --padding: 0rem;
3
+ list-style-type: none;
4
+ padding: 0;
5
+ margin: 0;
6
+ padding-left: var(--padding);
7
+
8
+ span {
9
+ display: list-item;
10
+ }
11
+
12
+ .sg-list {
13
+ --padding: 0.5rem;
14
+ }
15
+ }
16
+
17
+
18
+ .sg-sublist {
19
+ list-style-type: none;
20
+ padding: 0;
21
+ margin: 0;
22
+ }
23
+
24
+ .sg-list-label {
25
+ background-color: black;
26
+ }
27
+
28
+ .sg-list-item {
29
+ margin: 0;
30
+ background-color: black;
31
+
32
+ > * {
33
+ user-select: inherit;
34
+ }
35
+ }
36
+
37
+ .moving {
38
+ position:absolute;
39
+ top: 0;
40
+ left: 0;
41
+ z-index: $zindex-popover;
42
+ }
43
+
44
+ .phantom {
45
+ position: relative;
46
+ display: list-item;
47
+
48
+ border: 1px solid transparent;
49
+
50
+ margin-left: calc( (var(--depth) - 1) * 0.5rem );
51
+
52
+ transition: all 0.2s ease-in-out;
53
+ outline: 2px solid red;
54
+
55
+ animation: size 0.3s ease-in-out
56
+ }
57
+
58
+ @keyframes size {
59
+ from {
60
+ height: 10px;
61
+ }
62
+ }
@@ -0,0 +1,234 @@
1
+ @use "sass:color";
2
+ @use "mixins";
3
+
4
+ $sg-modal-margin: 0.5rem;
5
+ $sg-modal-background-color: $sg-body-bg;// #2e3236;
6
+ $sg-modal-text-color: white;
7
+ $sg-modal-radius: 0.5rem;
8
+ $sg-modal-transition: transform .3s ease-out;
9
+
10
+ .sg-modal-tag::backdrop {
11
+ z-index: calc($zindex-modal);
12
+ background: hsla(0, 0%, 0%);
13
+ opacity: 0.5;
14
+ animation-name: fade-in-backdrop;
15
+ animation-duration: 0.3s;
16
+ animation-timing-function: ease-in-out;
17
+ animation-fill-mode: forwards;
18
+ &.close {
19
+ background: transparent;
20
+ opacity: 0;
21
+ animation-name: fade-out-backdrop;
22
+ animation-duration: 0.3s;
23
+ animation-timing-function: ease-in-out;
24
+ animation-fill-mode: backwards;
25
+ }
26
+ }
27
+ @keyframes fade-in-backdrop {
28
+ from {
29
+ opacity: 0;
30
+ }
31
+ to {
32
+ opacity: 0.5;
33
+ }
34
+ }
35
+ @keyframes fade-out-backdrop {
36
+ from {
37
+ opacity: 0.5;
38
+ }
39
+ to {
40
+ opacity: 0;
41
+ }
42
+ }
43
+
44
+ .sg-modal-tag { //shell to position modal with bottom-padding
45
+ --height: fit-content;
46
+ z-index: calc($zindex-modal + 1);
47
+
48
+ padding: 0;
49
+ top: 10%;
50
+ height: var(--height);
51
+ max-height: 80%;
52
+ margin-right: auto;
53
+ margin-left: auto;
54
+
55
+ color: $sg-modal-text-color;
56
+ background-color: $sg-modal-background-color;
57
+ background-clip: padding-box;
58
+ border: 2px outset color-mix(in oklab, $sg-modal-background-color, currentColor 60%);// 1px solid $sg-modal-text-color;
59
+ //border-radius: $sg-modal-radius;
60
+ flex-direction: column;
61
+ overflow: auto;
62
+
63
+ &[open=""] {
64
+ display: grid;
65
+ width: 100%;
66
+ grid-template-rows: [header-start] auto [header-end body-start] 1fr [body-end footer-start] auto [footer-end] ;// auto 1fr auto;
67
+ animation-name: fade-in-modal;
68
+ animation-duration: .3s;
69
+ animation-timing-function: ease-in-out;
70
+ animation-fill-mode: forwards;
71
+ }
72
+
73
+ &.close {
74
+ animation: fade-out-modal 0.3s ease-in-out;
75
+ animation-fill-mode: forwards;
76
+ }
77
+
78
+ > form {
79
+ display: grid;
80
+ grid-template-rows: [body-start] 1fr [body-end footer-start] auto [footer-end];
81
+ @supports (grid-template-rows: subgrid) {
82
+ grid-row-start: body-start;
83
+ grid-row-end: footer-end;
84
+ grid-template-rows: subgrid;
85
+ }
86
+ .sg-modal-body {
87
+ grid-row: body;
88
+ }
89
+ .sg-moda-footer {
90
+ grid-row: footer;
91
+ }
92
+ }
93
+ }
94
+ @keyframes fade-out-modal {
95
+ to { transform: translateY(10%); opacity: 0;}
96
+ }
97
+ @keyframes fade-in-modal {
98
+ from {transform: translateY(-10%); opacity: 0.5;}
99
+ }
100
+
101
+
102
+ .sg-modal-fill {
103
+ margin: auto;
104
+ top: 0;
105
+ height: 100%;
106
+ width: 100%;
107
+ }
108
+
109
+ .sg-modal-header {
110
+ grid-row: header;// 1 / span 1;
111
+ display: flex;
112
+ align-items: center;
113
+ justify-content: space-between; // Put modal header elements (title and dismiss) on opposite ends
114
+ padding: 0.75rem;
115
+ //border-bottom: 1px solid $sg-modal-text-color;
116
+ //@include border-top-radius($sg-modal-radius);
117
+
118
+ margin: 0;
119
+
120
+ .sg-button-close {
121
+ padding: 0.5rem 0.5rem;
122
+ margin: calc(-.5 * $sg-modal-margin) calc(-.5 * $sg-modal-margin) calc(-.5 * $sg-modal-margin) auto;
123
+ }
124
+ }
125
+ .sg-modal-title {
126
+ margin: 0;
127
+ }
128
+ .sg-modal-body {
129
+ grid-row: body;// 2 / span 1;
130
+ position: relative;
131
+ padding: 1rem;
132
+ background-color: color-mix(in oklab, $sg-modal-background-color, currentColor 5%);
133
+
134
+ min-height: fit-content;
135
+
136
+ overflow: auto;
137
+ p {
138
+ margin: 0;
139
+ }
140
+ }
141
+ .sg-modal-footer {
142
+ grid-row: footer;// 3 / span 1;
143
+ display: flex;
144
+ flex-shrink: 0;
145
+ flex-wrap: wrap;
146
+ align-items: center;
147
+ justify-content: flex-end;
148
+ padding: 0.75rem;
149
+ background-color: $sg-modal-background-color;
150
+ //border-top: 1px solid $sg-modal-background-color; //$sg-modal-text-color;
151
+ //@include border-bottom-radius($sg-modal-radius);
152
+
153
+ gap: 0.5rem;
154
+ }
155
+
156
+
157
+ $modal-sm: 300px !default;
158
+ $modal-md: 500px !default;
159
+ $modal-lg: 700px !default;
160
+
161
+ $container-max-widths: ( sm: 540px, md: 720px, lg: 960px, xl: 1140px, xxl: 1320px ) !default;
162
+ $grid-breakpoints: (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px, xxl: 1400px ) !default;
163
+ //300, 500, 800
164
+ .sg-modal-sm {
165
+ max-width: $modal-sm;
166
+ }
167
+ .sg-modal-md {
168
+ max-width: $modal-md;
169
+ }
170
+ .sg-modal-lg {
171
+ max-width: $modal-lg;
172
+ }
173
+ @media (max-width: 324px) {
174
+ .sg-modal-tag {
175
+ margin: auto;
176
+ top: 0;
177
+ width: 100%;
178
+ }
179
+ }
180
+ @media (min-width: 325px) and (max-width: 575px) {
181
+ .sg-modal-md, .sg-modal-lg {
182
+ max-width: $modal-sm;
183
+ }
184
+ }
185
+ @media (min-width: 576px) and (max-width:767px) {
186
+ .sg-modal-lg {
187
+ max-width: $modal-md;
188
+ }
189
+ }
190
+ @media (min-width: 768px) {
191
+ .sg-modal-lg {
192
+ max-width: $modal-lg;
193
+ }
194
+ }
195
+
196
+
197
+
198
+ /*
199
+ @each $breakpoint, $value in $grid-breakpoints {
200
+ @if $breakpoint == "xs" {
201
+ @media (max-width: 575px) {
202
+ .sg-modal-tag {
203
+ margin: 0.5rem auto;
204
+ }
205
+ }
206
+ }
207
+ @if $breakpoint == "sm" {
208
+ @media (min-width: 576px) {
209
+ .sg-modal-tag {
210
+ max-width: 500px;
211
+ margin-right: auto;
212
+ margin-left: auto;
213
+ }
214
+ .sg-modal-sm {
215
+ max-width: 300px
216
+ }
217
+ }
218
+ }
219
+ @else if $breakpoint == "lg" {
220
+ @media (min-width: 992px) {
221
+ .modal-lg, .modal-xl {
222
+ max-width: 800px;
223
+ }
224
+ }
225
+ }
226
+ @else if $breakpoint == "xl" {
227
+ @media (min-width: 1200px) {
228
+ .modal-xl {
229
+ max-width: 1140px;
230
+ }
231
+ }
232
+ }
233
+ }
234
+ */