@quaffui/quaff 0.1.0-prealpha16 → 0.1.0-prealpha19

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 (269) hide show
  1. package/README.md +6 -6
  2. package/dist/classes/QContext.svelte.d.ts +42 -0
  3. package/dist/classes/QContext.svelte.js +63 -0
  4. package/dist/classes/QScrollObserver.svelte.d.ts +44 -0
  5. package/dist/classes/QScrollObserver.svelte.js +95 -0
  6. package/dist/classes/QTheme.svelte.d.ts +11 -0
  7. package/dist/classes/QTheme.svelte.js +49 -0
  8. package/dist/classes/Quaff.svelte.d.ts +14 -0
  9. package/dist/classes/Quaff.svelte.js +35 -0
  10. package/dist/components/avatar/QAvatar.scss +97 -0
  11. package/dist/components/avatar/QAvatar.svelte +35 -60
  12. package/dist/components/avatar/QAvatar.svelte.d.ts +2 -25
  13. package/dist/components/avatar/docs.props.js +21 -5
  14. package/dist/components/avatar/index.scss +5 -3
  15. package/dist/components/avatar/props.d.ts +24 -7
  16. package/dist/components/breadcrumbs/QBreadcrumbs.scss +10 -0
  17. package/dist/components/breadcrumbs/QBreadcrumbs.svelte +24 -9
  18. package/dist/components/breadcrumbs/QBreadcrumbs.svelte.d.ts +2 -22
  19. package/dist/components/breadcrumbs/QBreadcrumbsEl.scss +10 -0
  20. package/dist/components/breadcrumbs/QBreadcrumbsEl.svelte +64 -38
  21. package/dist/components/breadcrumbs/QBreadcrumbsEl.svelte.d.ts +2 -25
  22. package/dist/components/breadcrumbs/docs.props.js +27 -27
  23. package/dist/components/breadcrumbs/props.d.ts +25 -24
  24. package/dist/components/button/QBtn.scss +133 -0
  25. package/dist/components/button/QBtn.svelte +88 -48
  26. package/dist/components/button/QBtn.svelte.d.ts +2 -33
  27. package/dist/components/button/docs.props.js +26 -18
  28. package/dist/components/button/props.d.ts +21 -15
  29. package/dist/components/card/QCard.scss +25 -0
  30. package/dist/components/card/QCard.svelte +25 -16
  31. package/dist/components/card/QCard.svelte.d.ts +2 -25
  32. package/dist/components/card/QCardActions.scss +10 -0
  33. package/dist/components/card/QCardActions.svelte +11 -8
  34. package/dist/components/card/QCardActions.svelte.d.ts +2 -21
  35. package/dist/components/card/QCardSection.scss +10 -0
  36. package/dist/components/card/QCardSection.svelte +8 -6
  37. package/dist/components/card/QCardSection.svelte.d.ts +2 -22
  38. package/dist/components/card/docs.props.js +6 -14
  39. package/dist/components/card/props.d.ts +9 -15
  40. package/dist/components/checkbox/QCheckbox.svelte +8 -3
  41. package/dist/components/checkbox/QCheckbox.svelte.d.ts +2 -20
  42. package/dist/components/checkbox/docs.props.js +1 -1
  43. package/dist/components/checkbox/index.scss +3 -1
  44. package/dist/components/checkbox/props.d.ts +1 -2
  45. package/dist/components/chip/QChip.scss +179 -0
  46. package/dist/components/chip/QChip.svelte +95 -70
  47. package/dist/components/chip/QChip.svelte.d.ts +2 -35
  48. package/dist/components/chip/docs.props.js +23 -47
  49. package/dist/components/chip/props.d.ts +21 -34
  50. package/dist/components/codeBlock/QCodeBlock.svelte +64 -42
  51. package/dist/components/codeBlock/QCodeBlock.svelte.d.ts +2 -20
  52. package/dist/components/codeBlock/docs.props.js +10 -2
  53. package/dist/components/codeBlock/props.d.ts +6 -1
  54. package/dist/components/dialog/{index.scss → QDialog.scss} +9 -7
  55. package/dist/components/dialog/QDialog.svelte +72 -70
  56. package/dist/components/dialog/QDialog.svelte.d.ts +6 -36
  57. package/dist/components/dialog/docs.props.d.ts +0 -8
  58. package/dist/components/dialog/docs.props.js +1 -131
  59. package/dist/components/dialog/props.d.ts +0 -16
  60. package/dist/components/drawer/QDrawer.scss +45 -0
  61. package/dist/components/drawer/QDrawer.svelte +87 -91
  62. package/dist/components/drawer/QDrawer.svelte.d.ts +6 -32
  63. package/dist/components/drawer/docs.props.js +3 -3
  64. package/dist/components/drawer/props.d.ts +2 -2
  65. package/dist/components/footer/QFooter.scss +42 -0
  66. package/dist/components/footer/QFooter.svelte +62 -23
  67. package/dist/components/footer/QFooter.svelte.d.ts +2 -23
  68. package/dist/components/footer/docs.props.js +14 -6
  69. package/dist/components/footer/props.d.ts +8 -5
  70. package/dist/components/header/QHeader.scss +54 -0
  71. package/dist/components/header/QHeader.svelte +52 -24
  72. package/dist/components/header/QHeader.svelte.d.ts +2 -23
  73. package/dist/components/header/docs.props.js +23 -7
  74. package/dist/components/header/props.d.ts +11 -3
  75. package/dist/components/icon/{index.scss → QIcon.scss} +2 -4
  76. package/dist/components/icon/QIcon.svelte +29 -16
  77. package/dist/components/icon/QIcon.svelte.d.ts +2 -27
  78. package/dist/components/icon/docs.props.js +3 -3
  79. package/dist/components/icon/props.d.ts +4 -4
  80. package/dist/components/index.d.ts +2 -2
  81. package/dist/components/index.js +2 -2
  82. package/dist/components/input/QInput.svelte +52 -25
  83. package/dist/components/input/QInput.svelte.d.ts +2 -32
  84. package/dist/components/input/docs.props.js +33 -1
  85. package/dist/components/input/props.d.ts +5 -12
  86. package/dist/components/input/props.js +1 -12
  87. package/dist/components/layout/QLayout.scss +178 -0
  88. package/dist/components/layout/QLayout.svelte +100 -80
  89. package/dist/components/layout/QLayout.svelte.d.ts +16 -43
  90. package/dist/components/layout/docs.props.js +57 -1
  91. package/dist/components/layout/props.d.ts +8 -0
  92. package/dist/components/list/QItem.scss +61 -0
  93. package/dist/components/list/QItem.svelte +65 -46
  94. package/dist/components/list/QItem.svelte.d.ts +2 -30
  95. package/dist/components/list/QItemSection.scss +45 -0
  96. package/dist/components/list/QItemSection.svelte +48 -33
  97. package/dist/components/list/QItemSection.svelte.d.ts +2 -24
  98. package/dist/components/list/QList.scss +30 -0
  99. package/dist/components/list/QList.svelte +25 -14
  100. package/dist/components/list/QList.svelte.d.ts +2 -28
  101. package/dist/components/list/docs.props.js +36 -4
  102. package/dist/components/list/props.d.ts +9 -8
  103. package/dist/components/list/props.js +1 -25
  104. package/dist/components/private/ContextReseter.svelte +6 -11
  105. package/dist/components/private/ContextReseter.svelte.d.ts +6 -18
  106. package/dist/components/private/QApi.svelte +117 -103
  107. package/dist/components/private/QApi.svelte.d.ts +4 -16
  108. package/dist/components/private/QDocs.svelte +67 -48
  109. package/dist/components/private/QDocs.svelte.d.ts +9 -20
  110. package/dist/components/private/QDocsSection.svelte +15 -14
  111. package/dist/components/private/QDocsSection.svelte.d.ts +7 -19
  112. package/dist/components/private/QIconSnippet.svelte +12 -0
  113. package/dist/components/private/QIconSnippet.svelte.d.ts +8 -0
  114. package/dist/components/progress/QCircularProgress.scss +63 -0
  115. package/dist/components/progress/QCircularProgress.svelte +104 -28
  116. package/dist/components/progress/QCircularProgress.svelte.d.ts +2 -22
  117. package/dist/components/progress/QLinearProgress.scss +75 -0
  118. package/dist/components/progress/QLinearProgress.svelte +55 -13
  119. package/dist/components/progress/QLinearProgress.svelte.d.ts +2 -20
  120. package/dist/components/progress/docs.props.js +138 -10
  121. package/dist/components/progress/props.d.ts +75 -12
  122. package/dist/components/radio/QRadio.svelte +14 -3
  123. package/dist/components/radio/QRadio.svelte.d.ts +2 -21
  124. package/dist/components/radio/docs.props.js +1 -1
  125. package/dist/components/radio/index.scss +3 -1
  126. package/dist/components/radio/props.d.ts +1 -3
  127. package/dist/components/radio/props.js +1 -8
  128. package/dist/components/railbar/QRailbar.scss +54 -0
  129. package/dist/components/railbar/QRailbar.svelte +43 -66
  130. package/dist/components/railbar/QRailbar.svelte.d.ts +2 -22
  131. package/dist/components/railbar/docs.props.js +4 -4
  132. package/dist/components/railbar/props.d.ts +3 -3
  133. package/dist/components/select/QSelect.svelte +121 -88
  134. package/dist/components/select/QSelect.svelte.d.ts +2 -34
  135. package/dist/components/select/docs.js +7 -0
  136. package/dist/components/select/docs.props.js +41 -1
  137. package/dist/components/select/index.scss +8 -6
  138. package/dist/components/select/props.d.ts +6 -12
  139. package/dist/components/select/props.js +1 -12
  140. package/dist/components/separator/QSeparator.scss +54 -0
  141. package/dist/components/separator/QSeparator.svelte +38 -45
  142. package/dist/components/separator/QSeparator.svelte.d.ts +2 -24
  143. package/dist/components/separator/docs.props.js +4 -4
  144. package/dist/components/separator/props.d.ts +5 -7
  145. package/dist/components/separator/props.js +1 -9
  146. package/dist/components/switch/QSwitch.scss +305 -0
  147. package/dist/components/switch/QSwitch.svelte +96 -0
  148. package/dist/components/switch/QSwitch.svelte.d.ts +3 -0
  149. package/dist/components/{toggle → switch}/docs.d.ts +1 -1
  150. package/dist/components/{toggle → switch}/docs.js +3 -3
  151. package/dist/components/{toggle → switch}/docs.props.d.ts +1 -1
  152. package/dist/components/{toggle → switch}/docs.props.js +30 -6
  153. package/dist/components/switch/props.d.ts +13 -0
  154. package/dist/components/switch/props.js +1 -0
  155. package/dist/components/table/QTable.svelte +99 -85
  156. package/dist/components/table/QTable.svelte.d.ts +3 -29
  157. package/dist/components/table/docs.props.js +9 -1
  158. package/dist/components/table/index.scss +3 -1
  159. package/dist/components/table/props.d.ts +10 -0
  160. package/dist/components/tabs/QTab.scss +71 -0
  161. package/dist/components/tabs/QTab.svelte +74 -90
  162. package/dist/components/tabs/QTab.svelte.d.ts +2 -25
  163. package/dist/components/tabs/QTabs.scss +40 -0
  164. package/dist/components/tabs/QTabs.svelte +110 -58
  165. package/dist/components/tabs/QTabs.svelte.d.ts +6 -31
  166. package/dist/components/tabs/docs.props.js +3 -3
  167. package/dist/components/tabs/index.scss +4 -2
  168. package/dist/components/tabs/props.d.ts +5 -4
  169. package/dist/components/toolbar/QToolbar.svelte +15 -12
  170. package/dist/components/toolbar/QToolbar.svelte.d.ts +2 -23
  171. package/dist/components/toolbar/QToolbarTitle.svelte +8 -7
  172. package/dist/components/toolbar/QToolbarTitle.svelte.d.ts +2 -21
  173. package/dist/components/toolbar/docs.props.js +4 -4
  174. package/dist/components/toolbar/index.scss +12 -14
  175. package/dist/components/toolbar/props.d.ts +4 -5
  176. package/dist/components/tooltip/QTooltip.svelte +5 -9
  177. package/dist/components/tooltip/QTooltip.svelte.d.ts +2 -21
  178. package/dist/components/tooltip/docs.props.js +1 -1
  179. package/dist/components/tooltip/index.scss +3 -1
  180. package/dist/components/tooltip/props.d.ts +1 -1
  181. package/dist/composables/index.d.ts +1 -1
  182. package/dist/composables/index.js +1 -1
  183. package/dist/composables/useSize.d.ts +10 -9
  184. package/dist/composables/useSize.js +32 -20
  185. package/dist/composables/useSizeLegacy.d.ts +9 -0
  186. package/dist/composables/useSizeLegacy.js +25 -0
  187. package/dist/css/_components.scss +31 -0
  188. package/dist/css/_disabled.scss +18 -0
  189. package/dist/css/{ripple.scss → _ripple.scss} +1 -1
  190. package/dist/css/_variables.scss +73 -0
  191. package/dist/css/classes/_design.scss +57 -0
  192. package/dist/css/classes/_flex.scss +62 -0
  193. package/dist/css/classes/_grid.scss +35 -0
  194. package/dist/css/classes/_index.scss +7 -0
  195. package/dist/css/classes/_overflow.scss +7 -0
  196. package/dist/css/classes/_position.scss +7 -0
  197. package/dist/css/classes/_select.scss +6 -0
  198. package/dist/css/classes/_spaces.scss +23 -0
  199. package/dist/css/index.css +1 -1
  200. package/dist/css/index.scss +15 -94
  201. package/dist/css/mixins/_design.scss +63 -0
  202. package/dist/css/mixins/{field-mixins.scss → _field.scss} +16 -5
  203. package/dist/css/mixins/_image.scss +63 -0
  204. package/dist/css/mixins/_index.scss +9 -0
  205. package/dist/css/mixins/_layout.scss +20 -0
  206. package/dist/css/mixins/{menu.scss → _menu.scss} +4 -2
  207. package/dist/css/mixins/{selection.scss → _selection.scss} +7 -67
  208. package/dist/css/mixins/_spaces.scss +36 -0
  209. package/dist/css/mixins/_typography.scss +7 -0
  210. package/dist/css/shared/q-field.scss +62 -32
  211. package/dist/css/theme/_colors.scss +173 -0
  212. package/dist/css/theme/css-variables.scss +5 -0
  213. package/dist/css/theme/page.scss +3 -3
  214. package/dist/css/theme/reset.scss +17 -1
  215. package/dist/css/theme/theme.scss +2 -3
  216. package/dist/css/theme/tokens.scss +0 -159
  217. package/dist/helpers/clickOutside.js +2 -1
  218. package/dist/helpers/ripple.d.ts +1 -1
  219. package/dist/helpers/ripple.js +13 -4
  220. package/dist/helpers/version.d.ts +1 -1
  221. package/dist/helpers/version.js +1 -1
  222. package/dist/index.d.ts +2 -1
  223. package/dist/index.js +2 -1
  224. package/dist/stores/index.d.ts +0 -2
  225. package/dist/stores/index.js +1 -2
  226. package/dist/utils/colors.d.ts +71 -0
  227. package/dist/utils/colors.js +101 -14
  228. package/dist/utils/dom.d.ts +2 -0
  229. package/dist/utils/dom.js +6 -0
  230. package/dist/utils/number.d.ts +2 -0
  231. package/dist/utils/number.js +9 -0
  232. package/dist/utils/props.js +3 -1
  233. package/dist/utils/router.d.ts +17 -0
  234. package/dist/utils/router.js +23 -0
  235. package/dist/utils/string.d.ts +1 -0
  236. package/dist/utils/string.js +3 -0
  237. package/dist/utils/types.d.ts +6 -1
  238. package/dist/utils/types.js +0 -3
  239. package/dist/utils/types.json +8 -5
  240. package/dist/utils/watchable.d.ts +0 -1
  241. package/package.json +40 -37
  242. package/dist/components/breadcrumbs/index.scss +0 -20
  243. package/dist/components/button/index.scss +0 -103
  244. package/dist/components/card/index.scss +0 -56
  245. package/dist/components/chip/index.scss +0 -103
  246. package/dist/components/drawer/index.scss +0 -59
  247. package/dist/components/footer/index.scss +0 -28
  248. package/dist/components/layout/index.scss +0 -387
  249. package/dist/components/list/index.scss +0 -144
  250. package/dist/components/progress/index.scss +0 -82
  251. package/dist/components/railbar/index.scss +0 -39
  252. package/dist/components/separator/index.scss +0 -52
  253. package/dist/components/toggle/QToggle.svelte +0 -34
  254. package/dist/components/toggle/QToggle.svelte.d.ts +0 -23
  255. package/dist/components/toggle/index.scss +0 -31
  256. package/dist/components/toggle/props.d.ts +0 -9
  257. package/dist/components/toggle/props.js +0 -9
  258. package/dist/css/grid.scss +0 -50
  259. package/dist/css/mixins.scss +0 -137
  260. package/dist/css/states.scss +0 -75
  261. package/dist/css/theme/bridge.scss +0 -15
  262. package/dist/css/theme/theme.dark.scss +0 -39
  263. package/dist/css/theme/theme.light.scss +0 -39
  264. package/dist/css/variables-sass.scss +0 -16
  265. package/dist/stores/QTheme.d.ts +0 -42
  266. package/dist/stores/QTheme.js +0 -59
  267. package/dist/stores/Quaff.d.ts +0 -32
  268. package/dist/stores/Quaff.js +0 -58
  269. /package/dist/css/mixins/{table.scss → _table.scss} +0 -0
@@ -1,102 +1,23 @@
1
- @use "sass:map";
2
- @import "./theme/theme.scss";
3
- @import "./grid.scss";
4
- @import "./flex.scss";
1
+ @layer theme, ripple, components, classes, disabled;
5
2
 
6
- $space-base: 16px !default;
7
- $space-x-base: $space-base !default;
8
- $space-y-base: $space-base !default;
9
-
10
- $space-none: 0 !default;
11
- $space-xs: 0.25rem !default;
12
- $space-sm: 0.5rem !default;
13
- $space-md: 1rem !default;
14
- $space-lg: 1.5rem !default;
15
- $space-xl: 2rem !default;
16
-
17
- $spaces: (
18
- "auto": auto,
19
- "none": $space-none,
20
- "xs": $space-xs,
21
- "sm": $space-sm,
22
- "md": $space-md,
23
- "lg": $space-lg,
24
- "xl": $space-xl,
25
- ) !default;
26
-
27
- $positions: (
28
- "t": -top,
29
- "r": -right,
30
- "b": -bottom,
31
- "l": -left,
32
- "x": -inline,
33
- "y": -block,
34
- "a": "",
35
- );
36
-
37
- @import "./theme/theme";
38
- @import "./mixins";
39
- @import "./grid";
40
- @import "./states";
41
- @import "./ripple";
42
- @import "$components/avatar";
43
- @import "$components/breadcrumbs";
44
- @import "$components/button";
45
- @import "$components/card";
46
- @import "$components/checkbox";
47
- @import "$components/chip";
48
- @import "$components/dialog";
49
- @import "$components/drawer";
50
- @import "$components/footer";
51
- @import "$components/icon";
52
- @import "$components/input";
53
- @import "$components/layout";
54
- @import "$components/list";
55
- @import "$components/progress";
56
- @import "$components/radio";
57
- @import "$components/railbar";
58
- @import "$components/select";
59
- @import "$components/separator";
60
- @import "$components/table";
61
- @import "$components/tabs";
62
- @import "$components/toggle";
63
- @import "$components/toolbar";
64
- @import "$components/tooltip";
65
-
66
- html,
67
- body {
68
- height: 100%;
69
- width: 100%;
70
- }
71
-
72
- @each $spaceName, $spaceVal in $spaces {
73
- @each $posName, $_ in $positions {
74
- .q-p#{$posName}-#{$spaceName} {
75
- @include padding($posName, $spaceName);
76
- }
3
+ @layer Quaff {
4
+ @layer theme {
5
+ @import "./theme/theme";
6
+ }
77
7
 
78
- .q-m#{$posName}-#{$spaceName} {
79
- @include margin($posName, $spaceName);
80
- }
8
+ @layer ripple {
9
+ @import "ripple";
81
10
  }
82
11
 
83
- @if $spaceName != "auto" {
84
- .q-gap-#{$spaceName} {
85
- gap: $spaceVal;
86
- }
12
+ @layer components {
13
+ @import "components";
87
14
  }
88
- }
89
15
 
90
- .no-overflow {
91
- overflow: hidden;
92
- }
93
- .scroll {
94
- overflow: scroll;
95
- }
16
+ @layer classes {
17
+ @import "classes";
18
+ }
96
19
 
97
- .no-select {
98
- -webkit-user-select: none;
99
- -moz-user-select: none;
100
- -ms-user-select: none;
101
- user-select: none;
20
+ @layer disabled {
21
+ @import "disabled";
22
+ }
102
23
  }
@@ -0,0 +1,63 @@
1
+ @use "../variables";
2
+
3
+ @mixin elevate($strength, $position: null) {
4
+ $coeff: 1;
5
+ @if $position == "top" {
6
+ $coeff: -1;
7
+ }
8
+ $elevate: 0.125rem * $strength;
9
+
10
+ box-shadow: 0 $elevate * $coeff $elevate 0 with-alpha(var(--shadow), calc(24% + (8% * $strength)));
11
+ }
12
+
13
+ @mixin border($color: var(--outline), $position: variables.$border-positions) {
14
+ @if index($list: $position, $value: top) {
15
+ border-top: 0.0625rem solid $color;
16
+ }
17
+
18
+ @if index($list: $position, $value: right) {
19
+ border-right: 0.0625rem solid $color;
20
+ }
21
+
22
+ @if index($list: $position, $value: bottom) {
23
+ border-bottom: 0.0625rem solid $color;
24
+ }
25
+
26
+ @if index($list: $position, $value: left) {
27
+ border-left: 0.0625rem solid $color;
28
+ }
29
+ }
30
+
31
+ @mixin transparent($ripple: false) {
32
+ background-color: transparent;
33
+ background: transparent;
34
+ color: inherit;
35
+
36
+ &:is(:focus, :hover) > .q-icon {
37
+ font-variation-settings: "FILL" 1;
38
+ }
39
+
40
+ @if $ripple {
41
+ &::after {
42
+ background-image: radial-gradient(circle, rgb(150, 150, 150, 0.2) 1%, transparent 1%);
43
+ }
44
+ }
45
+ }
46
+
47
+ @mixin overlay($color: null, $opacity: null) {
48
+ content: "";
49
+ position: absolute;
50
+ top: 0;
51
+ right: 0;
52
+ bottom: 0;
53
+ left: 0;
54
+
55
+ border-radius: inherit;
56
+
57
+ background-color: $color;
58
+ opacity: $opacity;
59
+ }
60
+
61
+ @function with-alpha($color-variable: null, $percentage: null) {
62
+ @return color-mix(in srgb, $color-variable $percentage, transparent);
63
+ }
@@ -1,3 +1,5 @@
1
+ @use "sass:math";
2
+
1
3
  @mixin reset-form-element {
2
4
  padding: 0px;
3
5
  background: none;
@@ -19,8 +21,8 @@
19
21
  );
20
22
  }
21
23
 
22
- @mixin border-substitute($variant: "outlined") {
23
- $border-radius: if($variant == "outlined", 0.25rem, calc(var(--wrapper-height) / 2));
24
+ @mixin border-substitute($variant: "outlined", $wrapper-height, $dense: false) {
25
+ $border-radius: if($variant == "outlined", 0.25rem, math.div($wrapper-height, 2));
24
26
 
25
27
  &::before,
26
28
  &::after {
@@ -28,8 +30,8 @@
28
30
  position: absolute;
29
31
  top: -0.0625rem;
30
32
  bottom: -0.0625rem;
31
- width: calc(var(--wrapper-height) / 2);
32
- height: var(--wrapper-height);
33
+ width: math.div($wrapper-height, 2);
34
+ height: $wrapper-height;
33
35
  border: 0.0625rem solid transparent;
34
36
  border-top-color: var(--decorator-color);
35
37
  border-radius: $border-radius;
@@ -41,7 +43,16 @@
41
43
  border-top-right-radius: 0px;
42
44
  border-bottom-right-radius: 0px;
43
45
  $clip-height: 0.25rem;
44
- $clip-width: if($variant == "outlined", 0.9375rem, 0.3125rem);
46
+ $clip-width: if($variant == "outlined", 0.9375rem, 0.25rem);
47
+
48
+ @if $dense == true and $variant == "outlined" {
49
+ $clip-width: math.div($clip-width, 1.4);
50
+ }
51
+
52
+ @if $dense == true and $variant != "outlined" {
53
+ $clip-width: 0rem;
54
+ }
55
+
45
56
  @include clip-border($clip-width, $clip-height);
46
57
  }
47
58
 
@@ -0,0 +1,63 @@
1
+ @use "$css/variables";
2
+
3
+ @mixin responsive($parent: null) {
4
+ object-fit: cover;
5
+ object-position: center;
6
+ transition:
7
+ variables.$speed3 transform,
8
+ variables.$speed3 border-radius,
9
+ variables.$speed3 padding;
10
+ width: 100%;
11
+ height: 100%;
12
+
13
+ @include margin("x-auto");
14
+
15
+ @if $parent != null {
16
+ width: 2.5rem;
17
+ border: 0.25rem solid transparent;
18
+ }
19
+ }
20
+
21
+ @mixin btn-image($parent: "btn") {
22
+ &.q-#{$parent}--sm > .q-#{$parent}__img--responsive {
23
+ height: 2rem;
24
+ width: 2rem;
25
+ }
26
+
27
+ &.q-#{$parent}--lg > .q-#{$parent}__img--responsive {
28
+ height: 3rem;
29
+ width: 3rem;
30
+ }
31
+
32
+ &.q-#{$parent}--xl > .q-#{$parent}__img--responsive {
33
+ height: 3.5rem;
34
+ width: 3.5rem;
35
+ }
36
+
37
+ & > .q-#{$parent}__img {
38
+ margin-inline: -0.5rem;
39
+ }
40
+
41
+ & > .q-#{$parent}__img:not(.q-#{$parent}__img--responsive) {
42
+ min-width: 1.5rem;
43
+ max-width: 1.5rem;
44
+ min-height: 1.5rem;
45
+ max-height: 1.5rem;
46
+ }
47
+
48
+ & > .q-#{$parent}__img.q-#{$parent}__img--responsive {
49
+ @include responsive($parent);
50
+
51
+ $marginSize: -1.5rem;
52
+ @if $parent == "chip" {
53
+ $marginSize: -1rem;
54
+ }
55
+
56
+ margin-left: $marginSize !important;
57
+
58
+ &.q-#{$parent}__img--trailing {
59
+ margin-left: -0.5rem;
60
+ margin-right: $marginSize;
61
+ }
62
+ }
63
+ }
@@ -0,0 +1,9 @@
1
+ @import "design";
2
+ @import "field";
3
+ @import "image";
4
+ @import "layout";
5
+ @import "menu";
6
+ @import "selection";
7
+ @import "spaces";
8
+ @import "table";
9
+ @import "typography";
@@ -0,0 +1,20 @@
1
+ @use "../variables";
2
+
3
+ @mixin include-drawers($baseWidth, $pos, $el) {
4
+ // Left drawer
5
+ &.q-drawer--left ~ .q-#{$el} {
6
+ width: calc(#{$baseWidth} - #{variables.$left-drawer});
7
+ }
8
+
9
+ // Right drawer
10
+ &.q-drawer--right ~ .q-#{$el} {
11
+ width: calc(#{$baseWidth} - #{variables.$right-drawer});
12
+ }
13
+
14
+ // Left drawer + Right drawer
15
+ &.q-drawer--left
16
+ ~ .q-drawer--active.q-drawer--right:not(.q-drawer--offset-#{$pos}, .q-drawer--overlay)
17
+ ~ .q-#{$el} {
18
+ width: calc(#{$baseWidth} - #{variables.$left-right-drawer});
19
+ }
20
+ }
@@ -1,3 +1,5 @@
1
+ @use "$css/variables";
2
+
1
3
  @mixin menu {
2
4
  opacity: 0;
3
5
  visibility: hidden;
@@ -23,7 +25,7 @@
23
25
  border-radius: 0.25rem;
24
26
  transform: scale(0.8) translateY(120%);
25
27
  transition:
26
- var(--speed2) all,
28
+ variables.$speed2 all,
27
29
  0s background-color;
28
30
 
29
31
  &--active {
@@ -46,7 +48,7 @@
46
48
  }
47
49
 
48
50
  > a:is(:hover, :focus, .active) {
49
- background-color: var(--active);
51
+ background-color: var(--secondary-container);
50
52
  }
51
53
 
52
54
  &__dense {
@@ -1,3 +1,6 @@
1
+ @use "$css/mixins/design";
2
+ @use "$css/variables";
3
+
1
4
  // type can be: checkbox, radio or switch
2
5
  @mixin selection($type) {
3
6
  width: auto;
@@ -20,8 +23,8 @@
20
23
  }
21
24
 
22
25
  > input:is(:focus, :hover) + span::before {
23
- background-color: var(--active);
24
- box-shadow: 0 0 0 0.5rem var(--active);
26
+ background-color: design.with-alpha(var(--primary), 10%);
27
+ box-shadow: 0 0 0 0.5rem design.with-alpha(var(--primary), 10%);
25
28
  }
26
29
 
27
30
  > input:checked + span::before,
@@ -68,71 +71,8 @@
68
71
  border-radius: 50%;
69
72
  user-select: none;
70
73
  z-index: 1;
71
- box-shadow: 0 0 0 0 var(--active);
72
- transition: var(--speed1) all;
73
- }
74
-
75
- @if $type == switch {
76
- > input {
77
- width: 3.25rem;
78
- height: 2rem;
79
- opacity: 0;
80
- }
81
-
82
- > span::before,
83
- &--icon > span > i {
84
- position: absolute;
85
- left: 0;
86
- top: 50%;
87
- display: inline-flex;
88
- align-items: center;
89
- justify-content: center;
90
- border-radius: 50%;
91
- transition: var(--speed2) all;
92
- font-size: 1rem;
93
- user-select: none;
94
- min-width: auto;
95
- content: "";
96
- color: var(--surface-variant);
97
- background-color: var(--outline);
98
- transform: translate(-3rem, -50%) scale(0.6);
99
- }
100
-
101
- &--icon > span > i {
102
- transform: translate(-3rem, -50%) scale(1);
103
- }
104
-
105
- > input:is(:focus, :hover) + span::before,
106
- &--icon > input:is(:focus, :hover) + span > i {
107
- box-shadow: 0 0 0 0.5rem var(--active);
108
- }
109
-
110
- > input:checked + span::after {
111
- border: none;
112
- background-color: var(--primary);
113
- }
114
-
115
- > input:checked + span::before,
116
- &--icon > input:checked + span > i {
117
- content: "check";
118
- color: var(--primary);
119
- background-color: var(--on-primary);
120
- transform: translate(-1.75rem, -50%) scale(1);
121
- }
122
-
123
- > span::after {
124
- content: "";
125
- position: absolute;
126
- left: 0;
127
- top: 50%;
128
- background-color: var(--active);
129
- border: 0.125rem solid var(--outline);
130
- box-sizing: border-box;
131
- width: 3.25rem;
132
- height: 2rem;
133
- border-radius: 2rem;
134
- transform: translate(-3.25rem, -50%);
135
- }
74
+ box-shadow: 0 0 0 0 design.with-alpha(var(--primary), 10%);
75
+ transition: variables.$speed1 all;
136
76
  }
137
77
 
138
78
  @if $type == checkbox {
@@ -0,0 +1,36 @@
1
+ @use "sass:map";
2
+ @use "sass:string";
3
+ @use "../variables";
4
+
5
+ @mixin space($type: null, $spaces...) {
6
+ @each $space in $spaces {
7
+ $pos: string.slice($space, 1, 1);
8
+ @if not map.has-key(variables.$positions, $pos) {
9
+ @error "Position error for #{$type}, \"#{$pos}\" is not a valid position. Should be one of a, x, y, t, r, b or l";
10
+ }
11
+ $pos: map.get(variables.$positions, $pos);
12
+
13
+ $spacing: string.slice($space, 3);
14
+ @if not map.has-key(variables.$spaces, $spacing) {
15
+ @error "Spacing error for #{$type}, \"#{$space}\" is not a valid spacing. Should be one of auto, none, xs, sm, md, lg or xl";
16
+ }
17
+ $spacing: map.get(variables.$spaces, $spacing);
18
+
19
+ #{$type}#{$pos}: $spacing;
20
+ }
21
+ }
22
+
23
+ @mixin padding($paddings...) {
24
+ @include space("padding", $paddings...);
25
+ }
26
+
27
+ @mixin margin($margins...) {
28
+ @include space("margin", $margins...);
29
+ }
30
+
31
+ @mixin gap($space: "sm") {
32
+ @if not map.has-key(variables.$spaces, $space) {
33
+ @error "Spacing error for gap, \"#{$space}\" is not a valid spacing. Should be one of auto, none, xs, sm, md, lg or xl";
34
+ }
35
+ gap: map.get(variables.$spaces, $space);
36
+ }
@@ -0,0 +1,7 @@
1
+ @mixin typography($name: null) {
2
+ font-family: var(--typescale-#{$name}-font-family-name);
3
+ font-weight: var(--typescale-#{$name}-font-weight);
4
+ font-size: var(--typescale-#{$name}-font-size);
5
+ line-height: var(--typescale-#{$name}-line-height);
6
+ letter-spacing: var(--typescale-#{$name}-letter-spacing);
7
+ }