stargazer-ui 1.2.0 → 1.2.1

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 (349) 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 +12 -0
  6. package/dev/index.jsx +49 -0
  7. package/dev/index.scss +59 -0
  8. package/dev/pages/ButtonPage.jsx +44 -0
  9. package/dev/pages/CardPage.jsx +81 -0
  10. package/dev/pages/DropdownPage.jsx +31 -0
  11. package/dev/pages/FormPage.jsx +130 -0
  12. package/dev/pages/ListPage.jsx +52 -0
  13. package/dev/pages/ModalPage.jsx +37 -0
  14. package/dev/pages/OverlayPage.jsx +35 -0
  15. package/dev/pages/components.jsx +19 -0
  16. package/{styles → dev}/stargazerui.css +392 -3075
  17. package/dev/stargazerui.css.map +1 -0
  18. package/dev/test.jsx +88 -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 +17 -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 +358 -0
  38. package/src/Dropdown/Dropdown.types.ts +52 -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 +445 -0
  47. package/src/Form/Form.types.ts +117 -0
  48. package/src/Form/index.ts +4 -0
  49. package/src/InputGroup/InputGroup.tsx +46 -0
  50. package/src/InputGroup/InputGroup.types.ts +21 -0
  51. package/src/InputGroup/index.ts +4 -0
  52. package/src/List/List.tsx +112 -0
  53. package/src/List/List.types.ts +34 -0
  54. package/src/List/index.ts +4 -0
  55. package/src/Modal/Modal.tsx +220 -0
  56. package/src/Modal/Modal.types.ts +49 -0
  57. package/src/Modal/index.ts +4 -0
  58. package/src/Nav/Nav.tsx +43 -0
  59. package/src/Nav/Nav.types.ts +21 -0
  60. package/src/Nav/index.ts +4 -0
  61. package/src/NavBar/Navbar.tsx +57 -0
  62. package/src/NavBar/Navbar.types.ts +24 -0
  63. package/src/NavBar/index.ts +4 -0
  64. package/src/NavDropdown/NavDropdown.tsx +93 -0
  65. package/src/NavDropdown/NavDropdown.types.ts +6 -0
  66. package/src/NavDropdown/index.ts +3 -0
  67. package/src/Overlay/Overlay.tsx +277 -0
  68. package/src/Overlay/Overlay.types.ts +20 -0
  69. package/{Overlay/index.d.ts → src/Overlay/index.ts} +3 -3
  70. package/src/Popout/Popout.tsx +155 -0
  71. package/src/Popout/Popout.types.ts +42 -0
  72. package/src/Popout/index.ts +3 -0
  73. package/src/Spinner/Spinner.tsx +15 -0
  74. package/src/Spinner/Spinner.types.ts +7 -0
  75. package/src/Spinner/index.ts +3 -0
  76. package/src/Table/Table.tsx +16 -0
  77. package/src/Table/Table.types.ts +9 -0
  78. package/src/Table/index.ts +3 -0
  79. package/src/Tabs/Tabs.tsx +215 -0
  80. package/src/Tabs/Tabs.types.ts +49 -0
  81. package/src/Tabs/index.ts +3 -0
  82. package/src/ToggleButton/ToggleButton.tsx +21 -0
  83. package/src/ToggleButton/ToggleButton.types.ts +8 -0
  84. package/src/ToggleButton/index.ts +3 -0
  85. package/{hooks/index.d.ts → src/hooks/index.ts} +6 -5
  86. package/src/hooks/useClassname.ts +5 -0
  87. package/src/hooks/useDraggable.ts +186 -0
  88. package/src/hooks/useKeepElementFocused.ts +37 -0
  89. package/src/hooks/useScreenSize.ts +24 -0
  90. package/src/index.ts +21 -0
  91. package/src/styles/_Card.scss +166 -0
  92. package/src/styles/_CloseButton.scss +51 -0
  93. package/src/styles/_CustomButton.scss +132 -0
  94. package/src/styles/_Dropdown.scss +120 -0
  95. package/src/styles/_FloatingLabel.scss +56 -0
  96. package/src/styles/_Forms.scss +7 -0
  97. package/src/styles/_Grid.scss +178 -0
  98. package/src/styles/_InputGroup.scss +71 -0
  99. package/src/styles/_List.scss +62 -0
  100. package/src/styles/_Modal.scss +234 -0
  101. package/src/styles/_ModalOld.scss +242 -0
  102. package/src/styles/_Nav.scss +36 -0
  103. package/src/styles/_NavBar.scss +116 -0
  104. package/src/styles/_NavDropdown.scss +34 -0
  105. package/src/styles/_OffCanvas.scss +260 -0
  106. package/src/styles/_OverLay.scss +56 -0
  107. package/src/styles/_Popout.scss +75 -0
  108. package/src/styles/_Spinner.scss +19 -0
  109. package/src/styles/_Table.scss +34 -0
  110. package/src/styles/_Tabs.scss +129 -0
  111. package/src/styles/_colors.scss +510 -0
  112. package/src/styles/_components.scss +40 -0
  113. package/src/styles/_functions.scss +134 -0
  114. package/src/styles/_mixins.scss +26 -0
  115. package/src/styles/_reset.scss +231 -0
  116. package/src/styles/_utilities.scss +2480 -0
  117. package/src/styles/_variables.scss +146 -0
  118. package/src/styles/forms/_FormCheck.scss +269 -0
  119. package/src/styles/forms/_FormControl.scss +102 -0
  120. package/src/styles/forms/_FormGroup.scss +21 -0
  121. package/src/styles/forms/_FormLabel.scss +3 -0
  122. package/src/styles/forms/_FormSelect.scss +164 -0
  123. package/src/styles/forms/_FormSlider.scss +116 -0
  124. package/src/styles/forms/_FormText.scss +6 -0
  125. package/{utils/BaseTypes.d.ts → src/utils/BaseTypes.ts} +30 -23
  126. package/src/utils/ContrastingColor.ts +25 -0
  127. package/src/utils/FileImportExport.js +50 -0
  128. package/src/utils/MergeClassnames.ts +5 -0
  129. package/src/utils/MergeRefs.ts +12 -0
  130. package/src/vite-env.d.ts +1 -0
  131. package/tsconfig-build.json +4 -0
  132. package/tsconfig.json +79 -0
  133. package/tsconfig.node.json +10 -0
  134. package/types/BaseTypes.d.ts +19 -0
  135. package/{Button → types/components/Button}/Button.types.d.ts +2 -1
  136. package/types/components/Button/index.d.ts +1 -0
  137. package/{Card → types/components/Card}/Card.types.d.ts +1 -3
  138. package/types/components/Card/index.d.ts +1 -0
  139. package/{CloseButton → types/components/CloseButton}/CloseButton.types.d.ts +1 -1
  140. package/types/components/CloseButton/index.d.ts +1 -0
  141. package/{Dropdown → types/components/Dropdown}/Dropdown.types.d.ts +10 -3
  142. package/types/components/Dropdown/index.d.ts +1 -0
  143. package/{FloatingLabel → types/components/FloatingLabel}/FloatingLabel.types.d.ts +1 -1
  144. package/types/components/FloatingLabel/index.d.ts +1 -0
  145. package/types/components/Form/Form.d.ts +17 -0
  146. package/types/components/Form/Form.types.d.ts +50 -0
  147. package/types/components/Form/index.d.ts +1 -0
  148. package/types/components/InputGroup/InputGroup.d.ts +6 -0
  149. package/types/components/InputGroup/InputGroup.types.d.ts +10 -0
  150. package/types/components/InputGroup/index.d.ts +1 -0
  151. package/{Modal → types/components/Modal}/Modal.d.ts +1 -1
  152. package/{Modal → types/components/Modal}/Modal.types.d.ts +2 -3
  153. package/types/components/Modal/index.d.ts +1 -0
  154. package/{Nav → types/components/Nav}/Nav.types.d.ts +1 -1
  155. package/types/components/Nav/index.d.ts +1 -0
  156. package/{NavBar → types/components/NavBar}/Navbar.d.ts +2 -1
  157. package/{NavBar → types/components/NavBar}/Navbar.types.d.ts +1 -2
  158. package/types/components/NavBar/index.d.ts +1 -0
  159. package/{NavDropdown → types/components/NavDropdown}/NavDropdown.d.ts +2 -2
  160. package/types/components/NavDropdown/index.d.ts +1 -0
  161. package/{Popout → types/components/Popout}/Popout.types.d.ts +1 -1
  162. package/types/components/Popout/index.d.ts +1 -0
  163. package/types/components/Spinner/index.d.ts +1 -0
  164. package/{Table → types/components/Table}/Table.types.d.ts +1 -1
  165. package/types/components/Table/index.d.ts +1 -0
  166. package/{Tabs → types/components/Tabs}/Tabs.types.d.ts +1 -9
  167. package/types/components/Tabs/index.d.ts +1 -0
  168. package/types/components/ToggleButton/ToggleButton.d.ts +9 -0
  169. package/types/components/ToggleButton/ToggleButton.types.d.ts +0 -0
  170. package/types/components/ToggleButton/index.d.ts +1 -0
  171. package/types/components/index.d.ts +16 -0
  172. package/types/index.d.ts +1 -0
  173. package/vite.config.js +57 -0
  174. package/vite.config.js.timestamp-1708777378490-e94428ceb2bf9.mjs +42 -0
  175. package/Bar/Bar.type.d.ts +0 -6
  176. package/Bar/index.js +0 -2
  177. package/Bar/index.js.map +0 -1
  178. package/Bar/package.json +0 -1
  179. package/Button/Button.js +0 -12
  180. package/Button/Button.js.map +0 -1
  181. package/Button/index.d.ts +0 -3
  182. package/Button/index.js +0 -7
  183. package/Button/index.js.map +0 -1
  184. package/Button/package.json +0 -1
  185. package/ButtonGroup/ButtonGroup.d.ts +0 -4
  186. package/ButtonGroup/ButtonGroup.js +0 -10
  187. package/ButtonGroup/ButtonGroup.js.map +0 -1
  188. package/ButtonGroup/ButtonGroup.types.d.ts +0 -7
  189. package/ButtonGroup/index.d.ts +0 -3
  190. package/ButtonGroup/index.js +0 -7
  191. package/ButtonGroup/index.js.map +0 -1
  192. package/ButtonGroup/package.json +0 -1
  193. package/Card/Card.js +0 -41
  194. package/Card/Card.js.map +0 -1
  195. package/Card/index.d.ts +0 -3
  196. package/Card/index.js +0 -7
  197. package/Card/index.js.map +0 -1
  198. package/Card/package.json +0 -1
  199. package/CloseButton/CloseButton.js +0 -11
  200. package/CloseButton/CloseButton.js.map +0 -1
  201. package/CloseButton/index.d.ts +0 -3
  202. package/CloseButton/index.js +0 -7
  203. package/CloseButton/index.js.map +0 -1
  204. package/CloseButton/package.json +0 -1
  205. package/Dropdown/Dropdown.js +0 -292
  206. package/Dropdown/Dropdown.js.map +0 -1
  207. package/Dropdown/index.d.ts +0 -4
  208. package/Dropdown/index.js +0 -8
  209. package/Dropdown/index.js.map +0 -1
  210. package/Dropdown/package.json +0 -1
  211. package/FileUploadButton/FileUploadButton.d.ts +0 -4
  212. package/FileUploadButton/FileUploadButton.js +0 -21
  213. package/FileUploadButton/FileUploadButton.js.map +0 -1
  214. package/FileUploadButton/FileUploadButton.types.d.ts +0 -7
  215. package/FileUploadButton/index.d.ts +0 -3
  216. package/FileUploadButton/index.js +0 -7
  217. package/FileUploadButton/index.js.map +0 -1
  218. package/FileUploadButton/package.json +0 -1
  219. package/FloatingLabel/FloatingLabel.js +0 -17
  220. package/FloatingLabel/FloatingLabel.js.map +0 -1
  221. package/FloatingLabel/index.d.ts +0 -3
  222. package/FloatingLabel/index.js +0 -7
  223. package/FloatingLabel/index.js.map +0 -1
  224. package/FloatingLabel/package.json +0 -1
  225. package/Form/Form.d.ts +0 -38
  226. package/Form/Form.js +0 -308
  227. package/Form/Form.js.map +0 -1
  228. package/Form/Form.types.d.ts +0 -105
  229. package/Form/index.d.ts +0 -4
  230. package/Form/index.js +0 -8
  231. package/Form/index.js.map +0 -1
  232. package/Form/package.json +0 -1
  233. package/InputGroup/InputGroup.d.ts +0 -7
  234. package/InputGroup/InputGroup.js +0 -31
  235. package/InputGroup/InputGroup.js.map +0 -1
  236. package/InputGroup/InputGroup.types.d.ts +0 -16
  237. package/InputGroup/index.d.ts +0 -4
  238. package/InputGroup/index.js +0 -7
  239. package/InputGroup/index.js.map +0 -1
  240. package/InputGroup/package.json +0 -1
  241. package/List/List.d.ts +0 -14
  242. package/List/List.js +0 -76
  243. package/List/List.js.map +0 -1
  244. package/List/List.types.d.ts +0 -28
  245. package/List/index.d.ts +0 -3
  246. package/List/index.js +0 -7
  247. package/List/index.js.map +0 -1
  248. package/List/package.json +0 -1
  249. package/Modal/Modal.js +0 -160
  250. package/Modal/Modal.js.map +0 -1
  251. package/Modal/index.d.ts +0 -3
  252. package/Modal/index.js +0 -7
  253. package/Modal/index.js.map +0 -1
  254. package/Modal/package.json +0 -1
  255. package/Nav/Nav.js +0 -28
  256. package/Nav/Nav.js.map +0 -1
  257. package/Nav/index.d.ts +0 -4
  258. package/Nav/index.js +0 -7
  259. package/Nav/index.js.map +0 -1
  260. package/Nav/package.json +0 -1
  261. package/NavBar/Navbar.js +0 -36
  262. package/NavBar/Navbar.js.map +0 -1
  263. package/NavBar/index.d.ts +0 -4
  264. package/NavBar/index.js +0 -8
  265. package/NavBar/index.js.map +0 -1
  266. package/NavBar/package.json +0 -1
  267. package/NavDropdown/NavDropdown.js +0 -77
  268. package/NavDropdown/NavDropdown.js.map +0 -1
  269. package/NavDropdown/index.d.ts +0 -3
  270. package/NavDropdown/index.js +0 -7
  271. package/NavDropdown/index.js.map +0 -1
  272. package/NavDropdown/package.json +0 -1
  273. package/Overlay/Overlay.d.ts +0 -4
  274. package/Overlay/Overlay.js +0 -228
  275. package/Overlay/Overlay.js.map +0 -1
  276. package/Overlay/Overlay.types.d.ts +0 -18
  277. package/Overlay/index.js +0 -7
  278. package/Overlay/index.js.map +0 -1
  279. package/Overlay/package.json +0 -1
  280. package/Popout/Popout.js +0 -110
  281. package/Popout/Popout.js.map +0 -1
  282. package/Popout/index.d.ts +0 -3
  283. package/Popout/index.js +0 -7
  284. package/Popout/index.js.map +0 -1
  285. package/Popout/package.json +0 -1
  286. package/Spinner/Spinner.js +0 -12
  287. package/Spinner/Spinner.js.map +0 -1
  288. package/Spinner/index.d.ts +0 -3
  289. package/Spinner/index.js +0 -7
  290. package/Spinner/index.js.map +0 -1
  291. package/Spinner/package.json +0 -1
  292. package/Table/Table.js +0 -11
  293. package/Table/Table.js.map +0 -1
  294. package/Table/index.d.ts +0 -3
  295. package/Table/index.js +0 -7
  296. package/Table/index.js.map +0 -1
  297. package/Table/package.json +0 -1
  298. package/Tabs/Tabs.js +0 -158
  299. package/Tabs/Tabs.js.map +0 -1
  300. package/Tabs/index.d.ts +0 -3
  301. package/Tabs/index.js +0 -7
  302. package/Tabs/index.js.map +0 -1
  303. package/Tabs/package.json +0 -1
  304. package/ToggleButton/ToggleButton.d.ts +0 -4
  305. package/ToggleButton/ToggleButton.js +0 -17
  306. package/ToggleButton/ToggleButton.js.map +0 -1
  307. package/ToggleButton/ToggleButton.types.d.ts +0 -7
  308. package/ToggleButton/index.d.ts +0 -3
  309. package/ToggleButton/index.js +0 -7
  310. package/ToggleButton/index.js.map +0 -1
  311. package/ToggleButton/package.json +0 -1
  312. package/hooks/index.js +0 -6
  313. package/hooks/index.js.map +0 -1
  314. package/hooks/package.json +0 -1
  315. package/hooks/useClassname.d.ts +0 -2
  316. package/hooks/useClassname.js +0 -7
  317. package/hooks/useClassname.js.map +0 -1
  318. package/hooks/useDraggable.d.ts +0 -23
  319. package/hooks/useDraggable.js +0 -147
  320. package/hooks/useDraggable.js.map +0 -1
  321. package/hooks/useKeepElementFocused.d.ts +0 -2
  322. package/hooks/useKeepElementFocused.js +0 -37
  323. package/hooks/useKeepElementFocused.js.map +0 -1
  324. package/hooks/useScreenSize.d.ts +0 -5
  325. package/hooks/useScreenSize.js +0 -21
  326. package/hooks/useScreenSize.js.map +0 -1
  327. package/index.d.ts +0 -18
  328. package/index.js +0 -19
  329. package/index.js.map +0 -1
  330. package/styles/stargazerui.css.map +0 -1
  331. package/utils/ContrastingColor.d.ts +0 -1
  332. package/utils/MergeClassnames.d.ts +0 -2
  333. package/utils/MergeClassnames.js +0 -7
  334. package/utils/MergeClassnames.js.map +0 -1
  335. package/utils/MergeRefs.d.ts +0 -2
  336. package/utils/MergeRefs.js +0 -16
  337. package/utils/MergeRefs.js.map +0 -1
  338. /package/{Button → types/components/Button}/Button.d.ts +0 -0
  339. /package/{Card → types/components/Card}/Card.d.ts +0 -0
  340. /package/{CloseButton → types/components/CloseButton}/CloseButton.d.ts +0 -0
  341. /package/{Dropdown → types/components/Dropdown}/Dropdown.d.ts +0 -0
  342. /package/{FloatingLabel → types/components/FloatingLabel}/FloatingLabel.d.ts +0 -0
  343. /package/{Nav → types/components/Nav}/Nav.d.ts +0 -0
  344. /package/{NavDropdown → types/components/NavDropdown}/NavDropdown.types.d.ts +0 -0
  345. /package/{Popout → types/components/Popout}/Popout.d.ts +0 -0
  346. /package/{Spinner → types/components/Spinner}/Spinner.d.ts +0 -0
  347. /package/{Spinner → types/components/Spinner}/Spinner.types.d.ts +0 -0
  348. /package/{Table → types/components/Table}/Table.d.ts +0 -0
  349. /package/{Tabs → types/components/Tabs}/Tabs.d.ts +0 -0
@@ -0,0 +1,166 @@
1
+ .sg-card {
2
+ --card-border-radius: 0rem;
3
+ --border-width: -2px;
4
+
5
+ --border-gradient-color: color-mix(in srgb, #{$card-header-bg-color}, white 3%);
6
+ --border-gradient-mix-color: color-mix(in srgb, #{$card-header-bg-color}, white 3%);
7
+
8
+ --background-gradient-color: #{$sg-nav-color};
9
+ --background-gradient-mix-color: color-mix(in srgb, #{$card-header-bg-color}, white 3%);
10
+
11
+ --divider-color: #{$card-border-color};
12
+
13
+ display: flex;
14
+ flex-direction: column;
15
+ border: calc(var(--border-width) * -1) solid transparent;// $card-border-color;
16
+ position: relative;
17
+
18
+ border-radius: var(--card-border-radius);
19
+ background: linear-gradient(71deg,
20
+ var(--background-gradient-color),
21
+ var(--background-gradient-mix-color),
22
+ var(--background-gradient-color)
23
+ );
24
+ background-clip: padding-box;
25
+ &.sg-card-overlay {
26
+ color: $card-text-color;
27
+ border: 1px solid $card-border-color;
28
+ }
29
+
30
+ .sg-card-body {
31
+ flex: 1 1 auto;
32
+ padding: 1em;
33
+ }
34
+
35
+ .sg-card-header {
36
+ margin-bottom: 0;
37
+ padding: 0.5em 1em;
38
+ border-bottom: 1px solid var(--divider-color);
39
+
40
+
41
+ &:first-child {
42
+ border-top-left-radius: var(--card-border-radius);
43
+ border-top-right-radius: var(--card-border-radius);
44
+ }
45
+ }
46
+ .sg-card-title {
47
+ margin: 0;
48
+ }
49
+
50
+ .sg-card-footer {
51
+ padding: 0.5em 1em;
52
+ border-top: 1px solid var(--divider-color);
53
+ &:last-child {
54
+ border-bottom-left-radius: var(--card-border-radius);
55
+ border-bottom-right-radius: var(--card-border-radius);
56
+ }
57
+ }
58
+
59
+ .sg-card-text:last-child {
60
+ margin-bottom: 0;
61
+ }
62
+ }
63
+
64
+ .sg-card::after {
65
+ position: absolute;
66
+ content: "";
67
+ top: var(--border-width);
68
+ bottom: var(--border-width);
69
+ right: var(--border-width);
70
+ left: var(--border-width);
71
+ z-index: -1;
72
+ border-radius: var(--card-border-radius);
73
+ background: linear-gradient(71deg,
74
+ var(--border-gradient-color),
75
+ var(--border-gradient-mix-color),
76
+ var(--border-gradient-color)
77
+ );
78
+ }
79
+
80
+ @mixin invertedColor($color) {
81
+ --border-gradient-color: color-mix(in srgb, #{$color}, black 30%);
82
+ --border-gradient-mix-color: #{$color};
83
+
84
+ --background-gradient-color: color-mix(in srgb, #{$color}, black 0%);
85
+ --background-gradient-mix-color: #{$color};
86
+
87
+ --divider-color: color-mix(in srgb, #{$color}, black 15%);
88
+ //text-shadow: 2px -2px $color, 2px 2px $color, -2px 2px $color, -2px -2px $color;
89
+ /*
90
+ > h1, h2, h3, h4, h5, h6, span, p, small {
91
+ background-color: $color;
92
+ box-shadow: 1px -1px 10px $color, 1px 1px 10px $color, -1px 1px 10px $color, -1px -1px 10px $color;
93
+ }
94
+ */
95
+ }
96
+
97
+ .primary {
98
+ --border-gradient-mix-color: #{$danger};
99
+ grid-column: 2 / 3;
100
+ grid-row: 1;
101
+ &.inverted {
102
+ @include invertedColor($danger);
103
+ color: black;
104
+ }
105
+ }
106
+ .secondary {
107
+ --border-gradient-mix-color: #{$secondary};
108
+ grid-column: 4 / 5;
109
+ grid-row: 1;
110
+ &.inverted {
111
+ @include invertedColor($secondary);
112
+ }
113
+ }
114
+ .success {
115
+ --border-gradient-mix-color: #{$success};
116
+ grid-column: 6 / 7;
117
+ grid-row: 1;
118
+ &.inverted {
119
+ @include invertedColor($success);
120
+ color: black;
121
+ }
122
+ }
123
+ .info {
124
+ --border-gradient-mix-color: #{$info};
125
+ grid-column: 8 / 9;
126
+ grid-row: 1;
127
+ &.inverted {
128
+ @include invertedColor($info);
129
+ color: black;
130
+ }
131
+ }
132
+ .warning {
133
+ --border-gradient-mix-color: #{$warning};
134
+ grid-column: 2 / 3;
135
+ grid-row: 2;
136
+ &.inverted {
137
+ @include invertedColor($warning);
138
+ color: black;
139
+ }
140
+ }
141
+ .danger {
142
+ --border-gradient-mix-color: #{$primary};
143
+ grid-column: 4 / 5;
144
+ grid-row: 2;
145
+ &.inverted {
146
+ @include invertedColor($primary);
147
+ color: black;
148
+ }
149
+ }
150
+ .light {
151
+ --border-gradient-mix-color: #{$light};
152
+ grid-column: 6 / 7;
153
+ grid-row: 2;
154
+ &.inverted {
155
+ @include invertedColor($light);
156
+ color: black;
157
+ }
158
+ }
159
+ .dark {
160
+ --border-gradient-mix-color: #{$dark};
161
+ grid-column: 8 / 9;
162
+ grid-row: 2;
163
+ &.inverted {
164
+ @include invertedColor($dark);
165
+ }
166
+ }
@@ -0,0 +1,51 @@
1
+ @use "functions";
2
+
3
+ $sg-button-close-bg: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='#{black}'><path d='M.293.293a1 1 0 0 1 1.414 0L8 6.586 14.293.293a1 1 0 1 1 1.414 1.414L9.414 8l6.293 6.293a1 1 0 0 1-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 0-1.414z'/></svg>") !default;
4
+
5
+ .sg-button-close {
6
+ box-sizing: content-box;
7
+ width: 1rem;
8
+ height: 1rem;
9
+ padding: 0.25rem 0.25rem;
10
+ color: black;
11
+ background: transparent $sg-button-close-bg center / 1rem auto no-repeat; // include transparent for button elements
12
+ border: 0; // for button elements
13
+ border-radius: 0.125rem;
14
+ opacity: 0.5;
15
+
16
+ // Override <a>'s hover style
17
+ &:hover {
18
+ color: black;
19
+ text-decoration: none;
20
+ opacity: 0.75;
21
+ }
22
+ &:focus-visible, &:focus:not(:focus-visible) {
23
+ box-shadow: 0 0 0 3px black;
24
+ outline: 2px solid white;
25
+ opacity: 1;
26
+ z-index: 5;
27
+ }
28
+
29
+ &:disabled,
30
+ &.disabled {
31
+ pointer-events: none;
32
+ user-select: none;
33
+ opacity:0.25;
34
+ }
35
+ }
36
+
37
+ .sg-button-close-white {
38
+ filter: invert(1) grayscale(100%) brightness(200%);
39
+ }
40
+
41
+ .sg-close-visually-hidden-label {
42
+ position: absolute !important;
43
+ width: 1px !important;
44
+ height: 1px !important;
45
+ padding: 0 !important;
46
+ margin: -1px !important;
47
+ overflow: hidden !important;
48
+ clip: rect(0,0,0,0) !important;
49
+ white-space: nowrap !important;
50
+ border: 0 !important;
51
+ }
@@ -0,0 +1,132 @@
1
+ @use "sass:string";
2
+ @use "sass:color";
3
+ @use "sass:list";
4
+
5
+
6
+ .sg-button {
7
+ --text-color: white;
8
+ --bg-color: #0d6efd;
9
+ --border-color: #0d6efd;
10
+ --bg-hover-color: color.mix(white, #0d6efd, 15%);
11
+ --border-hover-color: color.mix(white, #0d6efd, 15%);
12
+ --bg-active-color: color.mix(white, #0d6efd, 20%);
13
+ --border-active-color: color.mix(white, #0d6efd, 20%);
14
+ --focus-visible-border-color: white;
15
+ --focus-visible-outline-color: #0d6efd;
16
+ --focus-visible-boxshadow-color: white;
17
+
18
+ //border-radius: 0.375rem;
19
+ min-width: fit-content;
20
+ display: inline-block;
21
+ text-align: center;
22
+ vertical-align: middle;
23
+ padding: 0.375rem 0.75rem;
24
+
25
+ background-color: var(--bg-color);
26
+ border: 2px outset color-mix(in oklab, var(--bg-color), var(--text-color) 20%);// 1px solid /*inset*/ var(--border-color);
27
+ color: var(--text-color);
28
+ &:hover, &:focus {
29
+ background-color: var(--bg-hover-color);
30
+ border-color: var(--border-hover-color);
31
+ }
32
+ &:active{
33
+ background-color: var(--bg-active-color);
34
+ border-color: var(--border-active-color);
35
+ border-style: inset;
36
+ }
37
+ /*
38
+ &:focus-visible {
39
+ box-shadow: 0 0 0 3px var(--focus-visible-boxshadow-color);
40
+ border: 1px solid var(--focus-visible-border-color);
41
+ outline: 2px solid var(--focus-visible-outline-color);
42
+ z-index: 5;
43
+ }
44
+ */
45
+ }
46
+
47
+ @each $name, $color in $colors {
48
+ $text-color: color-contrast($color);
49
+ $hover-background: if($text-color == $color-contrast-light, color.mix(black, $color, 15%), color.mix(white, $color, 15%));
50
+ $active-background: if($text-color == $color-contrast-light, color.mix(black, $color, 20%), color.mix(white, $color, 20%));
51
+ .sg-button-#{$name} {
52
+ --text-color: #{$text-color};
53
+ --bg-color: #{$color};
54
+ --border-color: #{$color};
55
+ --bg-hover-color: #{$hover-background};
56
+ --border-hover-color: #{$hover-background};
57
+ --bg-active-color: #{$active-background};
58
+ --border-active-color: #{$active-background};
59
+ --focus-visible-border-color: #{$text-color};
60
+ --focus-visible-outline-color: #{$color};
61
+ --focus-visible-boxshadow-color: #{$text-color};
62
+ }
63
+ .sg-button-group > .btn-#{$name} {
64
+ position: relative;
65
+ flex: 1 1 auto;
66
+ }
67
+ }
68
+
69
+ .sg-button-group, .sg-button-group-vertical {
70
+ position: relative;
71
+ display: inline-flex;
72
+ vertical-align: middle;
73
+ //width: 100%;
74
+ border-radius: 0.375rem;
75
+ //width: 100%;
76
+ > .sg-button {
77
+ position: relative;
78
+ flex: 1 1 auto;
79
+ }
80
+ }
81
+ .sg-button-group {
82
+ // Prevent double borders when buttons are next to each other
83
+ > :not(.sg-button-check:first-child) + .sg-button, > .sg-button-group:not(:first-child) {
84
+ margin-left: -1px;
85
+ }
86
+
87
+ // Reset rounded corners
88
+ > .sg-button:not(:last-child), > .sg-button-group:not(:last-child) > .sg-button {
89
+ border-top-right-radius: 0;
90
+ border-bottom-right-radius: 0;
91
+ }
92
+
93
+ // The left radius should be 0 if the button is:
94
+ // - the "third or more" child
95
+ // - the second child and the previous element isn't `.btn-check` (making it the first child visually)
96
+ // - part of a btn-group which isn't the first child
97
+ > .sg-button:nth-child(n + 3), > :not(.sg-button-check) + .sg-button, > .sg-button-group:not(:first-child) > .sg-button {
98
+ border-top-left-radius: 0;
99
+ border-bottom-left-radius: 0;
100
+ }
101
+ }
102
+
103
+ .sg-button-group-vertical {
104
+ flex-direction: column;
105
+ align-items: flex-start;
106
+ justify-content: center;
107
+
108
+
109
+ > .sg-button,
110
+ > .sg-button-group {
111
+ width: 100%;
112
+ }
113
+
114
+ > .sg-button:not(:first-child),
115
+ > .sg-button-group:not(:first-child) {
116
+ margin-top: -1px;
117
+ }
118
+
119
+ // Reset rounded corners
120
+ > .sg-button:not(:last-child):not(.dropdown-toggle),
121
+ > .sg-button-group:not(:last-child) > .sg-button {
122
+ border-bottom-left-radius: 0;
123
+ border-bottom-right-radius: 0;
124
+ }
125
+
126
+ > .sg-button ~ .sg-button,
127
+ > .sg-button-group:not(:first-child) > .sg-button {
128
+ border-top-left-radius: 0;
129
+ border-top-right-radius: 0;
130
+ }
131
+ }
132
+
@@ -0,0 +1,120 @@
1
+ @use "sass:color";
2
+
3
+ .dropup,
4
+ .dropend,
5
+ .dropdown,
6
+ .dropstart,
7
+ .dropup-center,
8
+ .dropdown-center {
9
+ position: relative;
10
+ }
11
+
12
+ .sg-dropdown {
13
+ --sg-dropdown-list-bg: ${$sg-dropdown-list-bg}
14
+ }
15
+
16
+ .sg-dropdown-list {
17
+ position: absolute;
18
+ z-index: $zindex-dropdown;
19
+ display: none; // none by default, but block on "open" of the menu
20
+ min-width: 10rem;
21
+ padding: 0;
22
+ margin: 0; // Override default margin of ul
23
+ text-align: left; // Ensures proper alignment if parent has it changed (e.g., modal footer)
24
+ list-style: none;
25
+ background-color: $sg-body-bg; //$sg-dropdown-list-bg;
26
+ color: white;
27
+ background-clip: padding-box;
28
+ border: 2px outset color-mix(in oklab, $sg-body-bg, white 60%);// white;
29
+ //border-radius: 0.375rem;
30
+ }
31
+ .sg-dropdown-list.show {
32
+ display: block;
33
+ }
34
+
35
+ .sg-dropdown-toggle {
36
+ white-space: nowrap;
37
+ &::after {
38
+ display: inline-block;
39
+ margin-left: calc(0.3em * 0.85);
40
+ vertical-align: calc(0.3em * 0.85);
41
+ content: "";
42
+ border-top: 0.3em solid;
43
+ border-right: 0.3em solid transparent;
44
+ border-bottom: 0;
45
+ border-left: 0.3em solid transparent;
46
+ }
47
+ &[data-drop="up"]::after {
48
+ transform: rotate(180deg);
49
+ }
50
+ &[data-drop="right"]::after {
51
+ transform: rotate(270deg);
52
+ }
53
+
54
+ &[data-drop="left"]::after {
55
+ display: none;
56
+ }
57
+ &[data-drop="left"]::before {
58
+ display: inline-block;
59
+ margin-right: calc(0.3em * 0.85);
60
+ vertical-align: calc(0.3em * 0.85);
61
+ content: "";
62
+ border-top: 0.3em solid;
63
+ border-right: 0.3em solid transparent;
64
+ border-bottom: 0;
65
+ border-left: 0.3em solid transparent;
66
+ transform: rotate(90deg);
67
+ }
68
+ }
69
+
70
+ .sg-dropdown-divider {
71
+ --line-color: rgba(0, 0, 0, 0.175);
72
+ height: 0;
73
+ margin: 0.5rem 0;
74
+ overflow: hidden;
75
+ border-top: 1px solid var(--line-color);
76
+ opacity: 1; // Revisit in v6 to de-dupe styles that conflict with <hr> element
77
+ }
78
+
79
+ // Links, buttons, and more within the dropdown menu
80
+ //
81
+ // `<button>`-specific styles are denoted with `// For <button>s`
82
+ .sg-dropdown-item {
83
+ display: block;
84
+ width: 100%; // For `<button>`s
85
+ padding: 0.25rem 0.5rem;
86
+ clear: both;
87
+ text-align: inherit; // For `<button>`s
88
+ white-space: nowrap; // prevent links from randomly breaking onto new lines
89
+ background-color: transparent; // For `<button>`s
90
+ color: inherit;
91
+ border: 2px solid transparent; // For `<button>`s
92
+
93
+ &.active,
94
+ &:active {
95
+ background-color: $sg-dropdown-item-action-bg;
96
+ }
97
+
98
+ &.disabled,
99
+ &:disabled {
100
+ background-color: $sg-dropdown-item-disabled-bg;
101
+ opacity: 0.5;
102
+ }
103
+ &.sg-dropdown-item-visual-focus {
104
+ /*
105
+ background-color: $sg-dropdown-item-hover-bg;
106
+ border-top: 1px solid white;
107
+ border-bottom: 1px solid white;
108
+ */
109
+ background-color: color-mix(in oklab, $danger, transparent 50%);
110
+ border: 2px outset color-mix(in oklab, $danger, currentColor 20%)
111
+ //@include sg-focus-visible();
112
+ }
113
+ }
114
+ a.sg-dropdown-item {
115
+ cursor: pointer;
116
+ text-decoration: none;
117
+ }
118
+ [data-nav="true"] .sg-dropdown-item {
119
+ font-size: 0.85rem;
120
+ }
@@ -0,0 +1,56 @@
1
+ .sg-form-floating {
2
+ position: relative;
3
+ --height: calc(3rem + 2px);
4
+ --text-color: #{$input-text-color};
5
+
6
+ > .sg-form-control, > .sg-form-control-plaintext, > .sg-form-select, > .sg-form-select-tag {
7
+ height: var(--height);
8
+ padding-inline: 1.25rem;
9
+ &::placeholder {
10
+ color: transparent;
11
+ }
12
+ &:focus, &:not(:placeholder-shown) {
13
+ padding-top: 1.25rem;
14
+ }
15
+ // Duplicated because `:-webkit-autofill` invalidates other selectors when grouped
16
+ &:-webkit-autofill {
17
+ padding-top: 1.25rem;
18
+ }
19
+ }
20
+
21
+ > .sg-form-floating-label {
22
+ position: absolute;
23
+ top: 0;
24
+ left: 0;
25
+ color: var(--text-color);
26
+ width: 100%;
27
+ height: 100%; // allow textareas
28
+ padding-inline: 1rem;
29
+ padding-block: 0.75rem;
30
+ pointer-events: none;
31
+ transition: transform 0.1s ease-in-out;
32
+ transform-origin: 0 0;
33
+ z-index: 5;
34
+
35
+ text-overflow: ellipsis;
36
+ white-space: nowrap;
37
+ }
38
+ > .sg-form-select {
39
+ padding-inline: 1rem;
40
+ padding-block: 1.5rem 0.5rem;
41
+ }
42
+
43
+ > .sg-form-control:focus,
44
+ > .sg-form-control:not(:placeholder-shown),
45
+ > .sg-form-control-plaintext,
46
+ > .sg-form-select,
47
+ > .sg-form-select-tag {
48
+ ~ .sg-form-floating-label {
49
+ font-size: 0.75rem;
50
+ height: fit-content;
51
+ padding: 0.5rem 0.5rem;
52
+ transform: translate(0, -0.25rem);
53
+ opacity: 0.75;
54
+ }
55
+ }
56
+ }
@@ -0,0 +1,7 @@
1
+ @import "forms/FormCheck";
2
+ @import "forms/FormControl";
3
+ @import "forms/FormGroup";
4
+ @import "forms/FormLabel";
5
+ @import "forms/FormSlider";
6
+ @import "forms/FormSelect";
7
+ @import "forms/FormText";
@@ -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
+ }