@fremtind/jokul 3.5.2 → 3.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (284) hide show
  1. package/build/_commonjsHelpers-C37NGDzP.cjs +2 -0
  2. package/build/_commonjsHelpers-C37NGDzP.cjs.map +1 -0
  3. package/build/_commonjsHelpers-CXUWDbkB.js +2 -0
  4. package/build/_commonjsHelpers-CXUWDbkB.js.map +1 -0
  5. package/build/build-stats.html +1 -1
  6. package/build/cjs/components/autosuggest/BaseAutosuggest.cjs +1 -1
  7. package/build/cjs/components/autosuggest/BaseAutosuggest.cjs.map +1 -1
  8. package/build/cjs/components/datepicker/DatePicker.cjs +1 -1
  9. package/build/cjs/components/datepicker/DatePicker.cjs.map +1 -1
  10. package/build/cjs/components/datepicker/internal/Calendar.cjs +1 -1
  11. package/build/cjs/components/datepicker/internal/Calendar.cjs.map +1 -1
  12. package/build/cjs/components/datepicker/internal/useCalendar.cjs +1 -1
  13. package/build/cjs/components/datepicker/internal/useCalendar.cjs.map +1 -1
  14. package/build/cjs/components/datepicker/internal/utils.cjs +1 -1
  15. package/build/cjs/components/datepicker/internal/utils.cjs.map +1 -1
  16. package/build/cjs/components/table/TableHeader.cjs +1 -1
  17. package/build/cjs/components/table/TableHeader.cjs.map +1 -1
  18. package/build/cjs/core/tokens/build-tailwind-4.cjs +2 -0
  19. package/build/cjs/core/tokens/build-tailwind-4.cjs.map +1 -0
  20. package/build/cjs/core/tokens/build-tailwind-4.d.cts +1 -0
  21. package/build/es/components/autosuggest/BaseAutosuggest.js +1 -1
  22. package/build/es/components/autosuggest/BaseAutosuggest.js.map +1 -1
  23. package/build/es/components/datepicker/DatePicker.js +1 -1
  24. package/build/es/components/datepicker/DatePicker.js.map +1 -1
  25. package/build/es/components/datepicker/internal/Calendar.js +1 -1
  26. package/build/es/components/datepicker/internal/Calendar.js.map +1 -1
  27. package/build/es/components/datepicker/internal/useCalendar.js +1 -1
  28. package/build/es/components/datepicker/internal/useCalendar.js.map +1 -1
  29. package/build/es/components/datepicker/internal/utils.js +1 -1
  30. package/build/es/components/datepicker/internal/utils.js.map +1 -1
  31. package/build/es/components/table/TableHeader.js +1 -1
  32. package/build/es/components/table/TableHeader.js.map +1 -1
  33. package/build/es/core/tokens/build-tailwind-4.d.ts +1 -0
  34. package/build/es/core/tokens/build-tailwind-4.js +2 -0
  35. package/build/es/core/tokens/build-tailwind-4.js.map +1 -0
  36. package/build/utils-CcE6HjQp.js +2 -0
  37. package/build/utils-CcE6HjQp.js.map +1 -0
  38. package/build/utils-DxmZDrR9.cjs +2 -0
  39. package/build/utils-DxmZDrR9.cjs.map +1 -0
  40. package/package.json +2 -2
  41. package/styles/components/checkbox/checkbox.css +4 -4
  42. package/styles/components/checkbox/checkbox.min.css +1 -1
  43. package/styles/components/checkbox/development/public/fonts/webfonts.css +115 -0
  44. package/styles/components/checkbox/development/public/fonts/webfonts.min.css +1 -0
  45. package/styles/components/checkbox-panel/checkbox-panel.css +6 -6
  46. package/styles/components/checkbox-panel/checkbox-panel.min.css +1 -1
  47. package/styles/components/countdown/countdown.css +2 -2
  48. package/styles/components/countdown/countdown.min.css +1 -1
  49. package/styles/components/feedback/feedback.css +2 -2
  50. package/styles/components/feedback/feedback.min.css +1 -1
  51. package/styles/components/file-input/development/public/fonts/_index.scss +1 -0
  52. package/styles/components/file-input/development/public/fonts/webfonts.css +108 -0
  53. package/styles/components/file-input/development/public/fonts/webfonts.min.css +1 -0
  54. package/styles/components/file-input/development/public/fonts/webfonts.scss +137 -0
  55. package/styles/components/file-input/file-input.css +9 -9
  56. package/styles/components/file-input/file-input.min.css +1 -1
  57. package/styles/components/input-group/input-group.css +2 -2
  58. package/styles/components/input-group/input-group.min.css +1 -1
  59. package/styles/components/loader/loader.css +6 -6
  60. package/styles/components/loader/loader.min.css +1 -1
  61. package/styles/components/loader/skeleton-loader.css +3 -3
  62. package/styles/components/loader/skeleton-loader.min.css +1 -1
  63. package/styles/components/menu/development/public/fonts/_index.scss +1 -0
  64. package/styles/components/menu/development/public/fonts/webfonts.css +108 -0
  65. package/styles/components/menu/development/public/fonts/webfonts.min.css +1 -0
  66. package/styles/components/menu/development/public/fonts/webfonts.scss +137 -0
  67. package/styles/components/message/message.css +2 -2
  68. package/styles/components/message/message.min.css +1 -1
  69. package/styles/components/progress-bar/progress-bar.css +1 -1
  70. package/styles/components/progress-bar/progress-bar.min.css +1 -1
  71. package/styles/components/radio-button/development/public/fonts/_index.scss +1 -0
  72. package/styles/components/radio-button/development/public/fonts/webfonts.css +115 -0
  73. package/styles/components/radio-button/development/public/fonts/webfonts.min.css +1 -0
  74. package/styles/components/radio-button/development/public/fonts/webfonts.scss +145 -0
  75. package/styles/components/radio-button/radio-button.css +2 -2
  76. package/styles/components/radio-button/radio-button.min.css +1 -1
  77. package/styles/components/radio-panel/radio-panel.css +2 -2
  78. package/styles/components/radio-panel/radio-panel.min.css +1 -1
  79. package/styles/components/segmented-control/segmented-control.css +4 -4
  80. package/styles/components/segmented-control/segmented-control.min.css +1 -1
  81. package/styles/components/system-message/system-message.css +2 -2
  82. package/styles/components/system-message/system-message.min.css +1 -1
  83. package/styles/components/table/table.css +6 -6
  84. package/styles/components/table/table.min.css +1 -1
  85. package/styles/components/text-input/development/public/fonts/_index.scss +1 -0
  86. package/styles/components/text-input/development/public/fonts/webfonts.css +115 -0
  87. package/styles/components/text-input/development/public/fonts/webfonts.min.css +1 -0
  88. package/styles/components/text-input/development/public/fonts/webfonts.scss +145 -0
  89. package/styles/components/toast/toast.css +4 -4
  90. package/styles/components/toast/toast.min.css +1 -1
  91. package/styles/components/toggle-switch/development/public/fonts/_index.scss +1 -0
  92. package/styles/components/toggle-switch/development/public/fonts/webfonts.css +115 -0
  93. package/styles/components/toggle-switch/development/public/fonts/webfonts.min.css +1 -0
  94. package/styles/components/toggle-switch/development/public/fonts/webfonts.scss +145 -0
  95. package/styles/styles.css +40 -40
  96. package/styles/styles.min.css +2 -2
  97. package/styles/components/autosuggest/_index.scss +0 -2
  98. package/styles/components/autosuggest/autosuggest.scss +0 -87
  99. package/styles/components/breadcrumb/_index.scss +0 -2
  100. package/styles/components/breadcrumb/breadcrumb.scss +0 -38
  101. package/styles/components/button/_index.scss +0 -2
  102. package/styles/components/button/button.scss +0 -169
  103. package/styles/components/card/_index.scss +0 -3
  104. package/styles/components/card/card.scss +0 -105
  105. package/styles/components/checkbox/_index.scss +0 -1
  106. package/styles/components/checkbox/checkbox.scss +0 -248
  107. package/styles/components/checkbox-panel/_index.scss +0 -1
  108. package/styles/components/checkbox-panel/checkbox-panel.scss +0 -95
  109. package/styles/components/checkbox-panel/development/styles.scss +0 -27
  110. package/styles/components/chip/_index.scss +0 -2
  111. package/styles/components/chip/chip.scss +0 -104
  112. package/styles/components/combobox/_index.scss +0 -6
  113. package/styles/components/combobox/combobox.scss +0 -238
  114. package/styles/components/cookie-consent/_index.scss +0 -5
  115. package/styles/components/cookie-consent/cookie-consent.scss +0 -31
  116. package/styles/components/countdown/_index.scss +0 -1
  117. package/styles/components/countdown/countdown.scss +0 -25
  118. package/styles/components/datepicker/_calendar-date-button.scss +0 -85
  119. package/styles/components/datepicker/_calendar-navigation-dropdown.scss +0 -52
  120. package/styles/components/datepicker/_calendar-navigation.scss +0 -12
  121. package/styles/components/datepicker/_calendar-table.scss +0 -27
  122. package/styles/components/datepicker/_calendar.scss +0 -36
  123. package/styles/components/datepicker/_index.scss +0 -6
  124. package/styles/components/datepicker/datepicker.scss +0 -47
  125. package/styles/components/description-list/_index.scss +0 -1
  126. package/styles/components/description-list/description-list.scss +0 -58
  127. package/styles/components/expander/_index.scss +0 -4
  128. package/styles/components/expander/expandable.scss +0 -141
  129. package/styles/components/feedback/_index.scss +0 -10
  130. package/styles/components/feedback/feedback.scss +0 -113
  131. package/styles/components/file/_index.scss +0 -3
  132. package/styles/components/file/file.scss +0 -164
  133. package/styles/components/file-input/_index.scss +0 -5
  134. package/styles/components/file-input/file-input.scss +0 -130
  135. package/styles/components/flex/_index.scss +0 -1
  136. package/styles/components/flex/flex.scss +0 -252
  137. package/styles/components/help/_index.scss +0 -2
  138. package/styles/components/help/help.scss +0 -47
  139. package/styles/components/icon/_base-styles.scss +0 -21
  140. package/styles/components/icon/_index.scss +0 -1
  141. package/styles/components/icon/development/internal/icons-example-grid.scss +0 -13
  142. package/styles/components/icon/icon.scss +0 -139
  143. package/styles/components/icon-button/_index.scss +0 -1
  144. package/styles/components/icon-button/icon-button.scss +0 -38
  145. package/styles/components/image/_index.scss +0 -1
  146. package/styles/components/image/development/style.scss +0 -9
  147. package/styles/components/image/image.scss +0 -37
  148. package/styles/components/image/stories/styles.scss +0 -9
  149. package/styles/components/input-group/_field-group.scss +0 -5
  150. package/styles/components/input-group/_index.scss +0 -3
  151. package/styles/components/input-group/_labels.scss +0 -159
  152. package/styles/components/input-group/input-group.scss +0 -11
  153. package/styles/components/input-panel/input-panel.scss +0 -84
  154. package/styles/components/link/_index.scss +0 -1
  155. package/styles/components/link/link.scss +0 -62
  156. package/styles/components/link-list/_index.scss +0 -2
  157. package/styles/components/link-list/link-list.scss +0 -94
  158. package/styles/components/list/_index.scss +0 -1
  159. package/styles/components/list/list.scss +0 -98
  160. package/styles/components/loader/_index.scss +0 -2
  161. package/styles/components/loader/development/styles.scss +0 -11
  162. package/styles/components/loader/loader.scss +0 -139
  163. package/styles/components/loader/skeleton-loader.scss +0 -137
  164. package/styles/components/logo/_index.scss +0 -1
  165. package/styles/components/logo/development/styles.scss +0 -9
  166. package/styles/components/logo/logo.scss +0 -90
  167. package/styles/components/menu/_index.scss +0 -1
  168. package/styles/components/menu/_menu-divider.scss +0 -10
  169. package/styles/components/menu/_menu-item.scss +0 -71
  170. package/styles/components/menu/menu.scss +0 -40
  171. package/styles/components/message/_index.scss +0 -2
  172. package/styles/components/message/message.scss +0 -187
  173. package/styles/components/modal/_index.scss +0 -3
  174. package/styles/components/modal/modal.scss +0 -107
  175. package/styles/components/nav-link/_index.scss +0 -1
  176. package/styles/components/nav-link/nav-link.scss +0 -66
  177. package/styles/components/pagination/_index.scss +0 -5
  178. package/styles/components/pagination/development/styles.scss +0 -35
  179. package/styles/components/pagination/pagination.scss +0 -49
  180. package/styles/components/popover/_index.scss +0 -1
  181. package/styles/components/popover/popover.scss +0 -19
  182. package/styles/components/progress-bar/_index.scss +0 -1
  183. package/styles/components/progress-bar/progress-bar.scss +0 -27
  184. package/styles/components/radio-button/_index.scss +0 -2
  185. package/styles/components/radio-button/radio-button.scss +0 -219
  186. package/styles/components/radio-panel/_index.scss +0 -1
  187. package/styles/components/radio-panel/development/styles.scss +0 -27
  188. package/styles/components/radio-panel/radio-panel.scss +0 -82
  189. package/styles/components/segmented-control/_index.scss +0 -3
  190. package/styles/components/segmented-control/segmented-control.scss +0 -99
  191. package/styles/components/select/_index.scss +0 -3
  192. package/styles/components/select/select.scss +0 -299
  193. package/styles/components/summary-table/_index.scss +0 -1
  194. package/styles/components/summary-table/development/summary-table-example.scss +0 -10
  195. package/styles/components/summary-table/summary-table.scss +0 -49
  196. package/styles/components/system-message/_index.scss +0 -2
  197. package/styles/components/system-message/system-message.scss +0 -177
  198. package/styles/components/table/_index.scss +0 -6
  199. package/styles/components/table/_table-caption.scss +0 -7
  200. package/styles/components/table/_table-cell.scss +0 -86
  201. package/styles/components/table/_table-head.scss +0 -36
  202. package/styles/components/table/_table-header.scss +0 -65
  203. package/styles/components/table/_table-pagination.scss +0 -126
  204. package/styles/components/table/_table-row.scss +0 -177
  205. package/styles/components/table/table.scss +0 -53
  206. package/styles/components/table-of-contents/_index.scss +0 -1
  207. package/styles/components/tabs/_index.scss +0 -1
  208. package/styles/components/tabs/tabs.scss +0 -114
  209. package/styles/components/tag/_index.scss +0 -3
  210. package/styles/components/tag/tag.scss +0 -65
  211. package/styles/components/text-area/_index.scss +0 -4
  212. package/styles/components/text-area/text-area.scss +0 -111
  213. package/styles/components/text-input/_index.scss +0 -4
  214. package/styles/components/text-input/text-input.scss +0 -43
  215. package/styles/components/toast/_index.scss +0 -4
  216. package/styles/components/toast/toast.scss +0 -219
  217. package/styles/components/toggle-switch/_index.scss +0 -2
  218. package/styles/components/toggle-switch/_toggle-slider.scss +0 -123
  219. package/styles/components/toggle-switch/toggle-switch.scss +0 -137
  220. package/styles/components/tooltip/_index.scss +0 -3
  221. package/styles/components/tooltip/popuptip.scss +0 -5
  222. package/styles/components/tooltip/tooltip.scss +0 -87
  223. package/styles/components-beta/description-list/_index.scss +0 -1
  224. package/styles/components-beta/description-list/description-list.scss +0 -80
  225. package/styles/components-beta/link-list/_index.scss +0 -2
  226. package/styles/components-beta/link-list/link-list.scss +0 -81
  227. package/styles/components-beta/nav-link/_index.scss +0 -1
  228. package/styles/components-beta/nav-link/navlink.scss +0 -66
  229. package/styles/components-beta/search/_index.scss +0 -4
  230. package/styles/components-beta/search/search-with-submit-button.scss +0 -37
  231. package/styles/components-beta/search/search.scss +0 -106
  232. package/styles/components-beta/select/_index.scss +0 -3
  233. package/styles/components-beta/select/select.scss +0 -128
  234. package/styles/components-beta/table-of-contents/_index.scss +0 -2
  235. package/styles/components-beta/table-of-contents/table-of-contents.scss +0 -88
  236. package/styles/core/_layers.scss +0 -3
  237. package/styles/core/core.scss +0 -6
  238. package/styles/core/global/_base-class.scss +0 -36
  239. package/styles/core/global/_index.scss +0 -2
  240. package/styles/core/global/_top-layer.scss +0 -20
  241. package/styles/core/jkl/_colors.scss +0 -26
  242. package/styles/core/jkl/_convert.scss +0 -102
  243. package/styles/core/jkl/_helpers.scss +0 -26
  244. package/styles/core/jkl/_index.scss +0 -18
  245. package/styles/core/jkl/_motion.scss +0 -63
  246. package/styles/core/jkl/_navigation.scss +0 -9
  247. package/styles/core/jkl/_ornaments.scss +0 -28
  248. package/styles/core/jkl/_reset.scss +0 -45
  249. package/styles/core/jkl/_responsive-units.scss +0 -30
  250. package/styles/core/jkl/_screenreader.scss +0 -59
  251. package/styles/core/jkl/_screens.scss +0 -135
  252. package/styles/core/jkl/_shadows.scss +0 -25
  253. package/styles/core/jkl/_spacing.scss +0 -149
  254. package/styles/core/jkl/_theme.scss +0 -119
  255. package/styles/core/jkl/_tokens.scss +0 -58
  256. package/styles/core/jkl/_typography.scss +0 -269
  257. package/styles/core/jkl/_underline.scss +0 -16
  258. package/styles/core/jkl/_z-index.scss +0 -23
  259. package/styles/core/jkl/legacy/_dynamic-colors.scss +0 -40
  260. package/styles/core/jkl/legacy/_index.scss +0 -2
  261. package/styles/core/jkl/legacy/_tokens.scss +0 -396
  262. package/styles/core/resets/_index.scss +0 -2
  263. package/styles/core/resets/_normalize.scss +0 -251
  264. package/styles/core/resets/_reset.scss +0 -68
  265. package/styles/core/theme/_color-tokens.scss +0 -73
  266. package/styles/core/theme/_dynamic-spacing.scss +0 -55
  267. package/styles/core/theme/_index.scss +0 -8
  268. package/styles/core/theme/_legacy-color-tokens.scss +0 -81
  269. package/styles/core/theme/_legacy-tokens.scss +0 -159
  270. package/styles/core/theme/_old-vars.scss +0 -30
  271. package/styles/core/theme/_spacing-tokens.scss +0 -32
  272. package/styles/core/theme/_tokens.scss +0 -32
  273. package/styles/core/theme/_typography.scss +0 -27
  274. package/styles/core/utility/_headings.scss +0 -31
  275. package/styles/core/utility/_index.scss +0 -4
  276. package/styles/core/utility/_paragraphs.scss +0 -18
  277. package/styles/core/utility/_screen-reader.scss +0 -11
  278. package/styles/core/utility/_spacing.scss +0 -49
  279. package/styles/hooks/stories/styles.scss +0 -78
  280. package/styles/shared/input/shared-input-styles.scss +0 -181
  281. package/styles/shared/track/track.scss +0 -27
  282. package/styles/styles.scss +0 -52
  283. /package/styles/{fonts → components/checkbox/development/public/fonts}/_index.scss +0 -0
  284. /package/styles/{fonts → components/checkbox/development/public/fonts}/webfonts.scss +0 -0
@@ -1,99 +0,0 @@
1
- @charset "UTF-8";
2
- @use "../../core/jkl";
3
- @use "../../components/radio-button";
4
-
5
- @include jkl.comfortable-density-variables {
6
- --jkl-segmented-controls-padding: #{jkl.$unit-02};
7
- --jkl-segmented-controls-margin: 1.5ch;
8
-
9
- @include jkl.declare-font-variables("jkl-segmented-control", "body");
10
- }
11
-
12
- @include jkl.compact-density-variables {
13
- --jkl-segmented-controls-padding: 0;
14
- --jkl-segmented-controls-margin: 1ch;
15
-
16
- @include jkl.declare-font-variables("jkl-segmented-control", "small");
17
- }
18
-
19
- .jkl-segmented-control {
20
- @include jkl.use-font-variables("jkl-segmented-control");
21
-
22
- @include jkl.small-device {
23
- @include jkl.declare-font-variables("jkl-segmented-control", "small");
24
- }
25
-
26
- .jkl-segmented-control-legend {
27
- margin-block-end: 0.25lh;
28
- }
29
-
30
- .jkl-segmented-control-item {
31
- --jkl-segmented-control-border-width: 1px;
32
- --jkl-segmented-controls-border-radius: 2lh;
33
-
34
- cursor: pointer;
35
- position: relative;
36
- display: inline-flex;
37
- align-items: center;
38
- background-color: var(--jkl-color-background-interactive);
39
- border: var(--jkl-segmented-control-border-width) solid var(--jkl-color-border-separator);
40
- border-radius: 0; // Gjør det enklere å behandle separering senere
41
- margin-inline-end: calc(var(--jkl-segmented-control-border-width) * -1);
42
- margin-block-end: 0.5lh;
43
-
44
- @include jkl.motion("easeInBounceOut", "expressive", border background);
45
-
46
- label {
47
- cursor: pointer;
48
- padding-block: var(--jkl-segmented-controls-padding);
49
- padding-inline: 1ch 1.5ch;
50
- }
51
-
52
- &:hover {
53
- background-color: var(--jkl-color-background-interactive-hover);
54
- border-color: var(--jkl-color-border-separator-hover);
55
- z-index: 2;
56
- }
57
-
58
- &:has(input:checked) {
59
- background-color: var(--jkl-color-background-container-high);
60
- border-color: var(--jkl-color-border-separator);
61
- z-index: 1;
62
- }
63
-
64
- // Kontrollerer border og margin på separerte items + border-radius til neste sibling
65
- &:has(input[data-separated="true"]) {
66
- border-radius: var(--jkl-segmented-controls-border-radius);
67
- margin-inline-start: var(--jkl-segmented-controls-margin);
68
-
69
- &:first-of-type {
70
- margin-inline-start: 0;
71
- }
72
-
73
- + span + .jkl-segmented-control-item {
74
- border-end-start-radius: var(--jkl-segmented-controls-border-radius);
75
- border-start-start-radius: var(--jkl-segmented-controls-border-radius);
76
-
77
- margin-inline-start: var(--jkl-segmented-controls-margin);
78
- }
79
- }
80
-
81
- // Første element skal alltid ha border-radius på starten
82
- &:first-of-type {
83
- border-end-start-radius: var(--jkl-segmented-controls-border-radius);
84
- border-start-start-radius: var(--jkl-segmented-controls-border-radius);
85
- }
86
-
87
- // Siste element skal alltid ha border-radius på slutten
88
- &:last-of-type {
89
- border-end-end-radius: var(--jkl-segmented-controls-border-radius);
90
- border-start-end-radius: var(--jkl-segmented-controls-border-radius);
91
- }
92
-
93
- // Dersom nærmeste sibling er separert skal slutten ha border radius
94
- &:has(+ span + .jkl-segmented-control-item > input[data-separated="true"]) {
95
- border-end-end-radius: var(--jkl-segmented-controls-border-radius);
96
- border-start-end-radius: var(--jkl-segmented-controls-border-radius);
97
- }
98
- }
99
- }
@@ -1,3 +0,0 @@
1
- @forward "select";
2
- @use "../icon" as icon;
3
- @use "../input-group" as input-group;
@@ -1,299 +0,0 @@
1
- @charset "UTF-8";
2
- @use "sass:color";
3
- @use "sass:math";
4
- @use "../../core/jkl";
5
- @use "../../core/jkl/colors";
6
-
7
- @include jkl.compact-density-variables {
8
- --jkl-select-input-height: #{jkl.$unit-40};
9
- --jkl-select-arrow-right: #{jkl.$unit-05};
10
- --jkl-select-button-padding: #{jkl.$unit-05} #{jkl.$unit-40} #{jkl.$unit-05}
11
- #{jkl.$unit-10};
12
- --jkl-select-search-input-padding: #{jkl.$unit-05} #{jkl.$unit-10};
13
- --jkl-select-native-padding: #{jkl.$unit-05} #{jkl.$unit-30} #{jkl.$unit-05}
14
- #{jkl.$unit-05};
15
- --jkl-select-option-padding: #{jkl.$unit-05} #{jkl.$unit-10};
16
-
17
- @include jkl.declare-font-variables("jkl-select", "small");
18
- }
19
-
20
- @include jkl.comfortable-density-variables {
21
- --jkl-select-input-height: #{jkl.$unit-60};
22
- --jkl-select-arrow-right: #{jkl.$unit-10};
23
- --jkl-select-button-padding: #{jkl.$unit-10} #{jkl.rem(36px)} #{jkl.$unit-10}
24
- #{jkl.$unit-15};
25
- --jkl-select-search-input-padding: var(--jkl-select-button-padding);
26
- --jkl-select-native-padding: 0 #{jkl.$unit-50} 0 #{jkl.$unit-10};
27
- --jkl-select-option-padding: #{jkl.$unit-10} #{jkl.$unit-15};
28
-
29
- @include jkl.declare-font-variables("jkl-select", "body");
30
-
31
- @include jkl.small-device {
32
- --jkl-select-input-height: #{jkl.rem(44px)};
33
- }
34
- }
35
-
36
- .jkl-select {
37
- display: block;
38
- position: relative;
39
-
40
- @include jkl.reset-outline;
41
-
42
- & *:focus-visible {
43
- outline: none;
44
- }
45
-
46
- & .jkl-tooltip-question-button:focus {
47
- @include jkl.focus-outline($offset: 0);
48
- }
49
-
50
- & select {
51
- appearance: none;
52
-
53
- &::ms-expand {
54
- display: none;
55
- }
56
-
57
- &:-moz-focusring {
58
- color: transparent;
59
- text-shadow: 0 0 0 var(--jkl-color-text-subdued);
60
- }
61
-
62
- & option {
63
- font-weight: normal;
64
- font-family: sans-serif;
65
- color: var(--jkl-color-text-subdued);
66
- background-color: var(--jkl-color-background-container-high);
67
- }
68
- }
69
-
70
- &__outer-wrapper {
71
- position: relative;
72
- width: 15rem;
73
- min-width: 7rem;
74
- max-width: 100%;
75
- }
76
-
77
- &__search-input {
78
- box-sizing: border-box;
79
- padding: var(--jkl-select-search-input-padding);
80
- color: var(--jkl-color-text-subdued);
81
- }
82
-
83
- &__search-input,
84
- &__button {
85
- overflow: hidden;
86
- text-overflow: ellipsis;
87
- white-space: nowrap;
88
- background-color: transparent;
89
- color: var(--jkl-color-text-subdued);
90
- cursor: pointer;
91
-
92
- height: var(--jkl-select-input-height);
93
- border-radius: jkl.rem(3px);
94
- border: jkl.rem(1px) solid var(--jkl-color-border-input);
95
- box-shadow: 0 0 0 jkl.rem(1px) transparent;
96
- text-align: left;
97
- width: 100%;
98
-
99
- transition-property: color, border-color, box-shadow;
100
-
101
- @include jkl.motion;
102
- @include jkl.use-font-variables("jkl-select");
103
-
104
- &--active-value {
105
- color: var(--jkl-color-text-default);
106
- }
107
-
108
- &:hover {
109
- border-color: var(--jkl-color-border-input-focus);
110
- box-shadow: 0 0 0 jkl.rem(1px) var(--jkl-color-border-input-focus);
111
-
112
- & ~ .jkl-select__arrow {
113
- transform: translateY(calc(-50% + #{jkl.rem(3px)}));
114
- }
115
- }
116
-
117
- &:focus-visible {
118
- outline: none;
119
- }
120
- }
121
-
122
- @include jkl.keyboard-navigation {
123
- &__search-input,
124
- &__button {
125
- &:focus-visible,
126
- &:has(:focus-visible) {
127
- @include jkl.focus-outline;
128
- }
129
- }
130
-
131
- &:has(:focus-visible) {
132
- .jkl-select__button,
133
- .jkl-select__search-input {
134
- @include jkl.focus-outline;
135
- }
136
- }
137
- }
138
-
139
- &__button {
140
- padding: var(--jkl-select-button-padding);
141
- }
142
-
143
- & select.jkl-select__button {
144
- padding: var(--jkl-select-native-padding);
145
- }
146
-
147
- &__arrow {
148
- pointer-events: none;
149
- position: absolute;
150
- right: var(--jkl-select-arrow-right);
151
- top: 50%;
152
- color: var(--jkl-color-text-default);
153
-
154
- transform: translateY(-50%);
155
- transition-property: transform, color;
156
-
157
- @include jkl.motion;
158
- @include jkl.forced-colors-svg-fallback(
159
- $stroke: CanvasText,
160
- $fill: CanvasText
161
- );
162
-
163
- .jkl-select:has([aria-invalid="true"]) & {
164
- color: var(--jkl-color-text-on-alert);
165
- }
166
- }
167
-
168
- &__options-menu {
169
- position: absolute;
170
- left: jkl.rem(-1px);
171
- right: jkl.rem(-1px);
172
- top: 100%;
173
- z-index: jkl.$z-index--dropdown;
174
-
175
- background-color: var(--jkl-color-background-container-high);
176
- border: jkl.rem(2px) solid var(--jkl-color-border-input-focus);
177
- border-top: none;
178
- border-radius: 0 0 jkl.rem(3px) jkl.rem(3px);
179
- box-sizing: border-box;
180
-
181
- overflow-y: auto;
182
- // Sett makshøyde på listen til høyden av (maxShownOptions + 0.5) ganger høyden på ett enlinjes valg
183
- max-height: calc(
184
- calc(var(--jkl-select-max-shown-options, 5) + 0.5) *
185
- var(--jkl-select-input-height)
186
- );
187
-
188
- transition-property: height;
189
-
190
- @include jkl.motion;
191
- }
192
-
193
- &__option-wrapper {
194
- margin: 0;
195
- padding: 0;
196
-
197
- list-style-type: none;
198
- -webkit-overflow-scrolling: touch;
199
- }
200
-
201
- &__option {
202
- color: unset;
203
- border: 0; // removes native styling
204
- width: 100%;
205
- background-color: inherit;
206
- min-height: var(--jkl-select-input-height);
207
- text-align: left;
208
- transition-property: color, background-color;
209
- position: relative;
210
- padding: var(--jkl-select-option-padding);
211
- cursor: pointer;
212
-
213
- @include jkl.motion;
214
- @include jkl.use-font-variables("jkl-select");
215
-
216
- /* For å unngå "dobbel" markering skrur vi av markering på hover i React-
217
- komponenten med data-focus="controlled". Uten dette satt vil valgene
218
- markeres ved hover som normalt. */
219
- &:focus,
220
- :not([data-focus="controlled"]) > &:hover {
221
- color: var(--jkl-color-text-default);
222
- background-color: var(--jkl-color-background-interactive-hover);
223
- }
224
-
225
- &-description {
226
- color: var(--jkl-color-text-subdued);
227
- display: block;
228
- width: 100%;
229
-
230
- @include jkl.text-style("small");
231
- }
232
- }
233
-
234
- /* --------
235
- VARIANTS
236
- -------- */
237
-
238
- &--inline {
239
- display: inline-block;
240
- vertical-align: top;
241
- }
242
-
243
- &--open {
244
- .jkl-select__search-input,
245
- .jkl-select__button {
246
- border-bottom-left-radius: 0;
247
- border-bottom-right-radius: 0;
248
- border-color: var(--jkl-color-border-input-focus);
249
- background-color: var(--jkl-color-background-container-high);
250
- box-shadow: 0 0 0 jkl.rem(1px) var(--jkl-color-border-input-focus);
251
-
252
- &:hover ~ .jkl-select__arrow {
253
- transform: translateY(calc(-50% + #{jkl.rem(-3px)}));
254
- }
255
- }
256
- }
257
-
258
- &--invalid {
259
- .jkl-select__search-input,
260
- .jkl-select__button {
261
- background-color: var(--jkl-color-background-alert-error);
262
- color: var(--jkl-color-text-on-alert-subdued);
263
-
264
- &--active-value {
265
- color: revert;
266
- }
267
- }
268
- }
269
-
270
- @include jkl.forced-colors-mode {
271
- // Vi er en button (hvis ikke native) og får ButtonText, men vi later som vi er en select, og den har CanvasText
272
- & .jkl-select__button,
273
- & .jkl-select__search-input {
274
- color: CanvasText;
275
- border: 2px solid ButtonText;
276
- background-color: Canvas;
277
- outline: revert;
278
-
279
- &:hover {
280
- border-color: Highlight;
281
- }
282
- }
283
-
284
- & .jkl-select__option {
285
- color: CanvasText;
286
-
287
- border-top: 1px solid Canvas;
288
- border-bottom: 1px solid Canvas;
289
-
290
- &:hover,
291
- &:focus {
292
- border-top: 1px solid SelectedItem;
293
- border-bottom: 1px solid SelectedItem;
294
-
295
- @include jkl.no-grow-bold;
296
- }
297
- }
298
- }
299
- }
@@ -1 +0,0 @@
1
- @forward "summary-table";
@@ -1,10 +0,0 @@
1
- @use "../../core/jkl";
2
-
3
- .summary-table-example {
4
- max-width: 500px;
5
- width: 100%;
6
-
7
- &__custom-row {
8
- color: var(--jkl-color-text-subdued);
9
- }
10
- }
@@ -1,49 +0,0 @@
1
- @charset "UTF-8";
2
- @use "../../core/jkl";
3
-
4
- @layer jokul.components {
5
- .jkl-summary-table {
6
- display: flex;
7
- flex-direction: column;
8
- overflow-wrap: anywhere;
9
- width: 100%;
10
-
11
- tr {
12
- display: flex;
13
- justify-content: space-between;
14
- padding-bottom: jkl.$spacing-8;
15
- }
16
-
17
- th,
18
- td {
19
- flex-basis: 50%;
20
- padding-right: jkl.$spacing-16;
21
-
22
- &:first-child {
23
- text-align: left;
24
- }
25
-
26
- &:last-child {
27
- text-align: right;
28
- padding-right: 0;
29
- }
30
- }
31
-
32
- & > tbody {
33
- th {
34
- font-weight: jkl.$typography-weight-normal;
35
- }
36
- }
37
-
38
- & > tfoot {
39
- border-top: jkl.rem(1px) solid var(--jkl-color-border-separator-strong);
40
- border-bottom: jkl.rem(1px) solid var(--jkl-color-border-separator-strong);
41
- padding-top: jkl.$spacing-8;
42
-
43
- th,
44
- td {
45
- font-weight: jkl.$typography-weight-bold;
46
- }
47
- }
48
- }
49
- }
@@ -1,2 +0,0 @@
1
- @forward "system-message";
2
- @use "../icon";
@@ -1,177 +0,0 @@
1
- @charset "UTF-8";
2
- @use "sass:string";
3
- @use "../../core/jkl";
4
- @use "../../core/jkl/colors";
5
-
6
- $_dismiss-animation-name: jkl-dismiss-#{string.unique-id()};
7
- $_dismiss-animation-duration: jkl.timing("lazy");
8
-
9
- @include jkl.comfortable-density-variables {
10
- --jkl-system-message-icon-height: #{jkl.rem(24px)};
11
- --jkl-system-message-icon-padding: #{jkl.rem(3px)} 0 0 0;
12
- --jkl-system-message-content-padding: #{jkl.$spacing-24};
13
- --jkl-system-message-dismiss-button-size: #{jkl.rem(44px)};
14
- --jkl-system-message-dismiss-button-margin: -#{jkl.rem(6.5px)} -#{jkl.rem(
15
- 18px)
16
- }
17
-
18
- -#{jkl.rem(6.5px)} auto;
19
- --jkl-system-message-message-margin: 0 #{jkl.$spacing-16};
20
-
21
- @include jkl.declare-font-variables("jkl-system-message-message", "body");
22
- }
23
-
24
- @include jkl.compact-density-variables {
25
- --jkl-system-message-icon-height: #{jkl.rem(20px)};
26
- --jkl-system-message-icon-padding: #{jkl.rem(1px)} 0 0 0;
27
- --jkl-system-message-content-padding: #{jkl.$spacing-8};
28
- --jkl-system-message-dismiss-button-size: #{jkl.rem(32px)};
29
- --jkl-system-message-dismiss-button-margin: -#{jkl.rem(3px)} -#{jkl.rem(
30
- 6px)
31
- }
32
-
33
- -#{jkl.rem(4.5px)} auto;
34
- --jkl-system-message-message-margin: 0 #{jkl.$spacing-12};
35
-
36
- @include jkl.declare-font-variables("jkl-system-message-message", "small");
37
- }
38
-
39
- .jkl-system-message {
40
- --background-color: var(--jkl-color-background-alert-neutral);
41
- --text-color: var(--jkl-color-text-on-alert);
42
-
43
- width: 100%;
44
- background-color: var(--background-color);
45
- color: var(--text-color);
46
- transition-behavior: allow-discrete;
47
- box-sizing: border-box;
48
-
49
- &__content {
50
- box-sizing: border-box;
51
- padding: var(--jkl-system-message-content-padding);
52
- display: grid;
53
- grid-template-columns: min-content 1fr min-content;
54
- align-items: flex-start;
55
- width: 100%;
56
- margin: 0 auto;
57
- }
58
-
59
- &__icon {
60
- height: var(--jkl-system-message-icon-height);
61
- margin: var(--jkl-system-message-icon-padding);
62
- flex-shrink: 0;
63
-
64
- @include jkl.forced-colors-svg-fallback($stroke: CanvasText);
65
- }
66
-
67
- &__message {
68
- @include jkl.use-font-variables("jkl-system-message-message");
69
- margin: var(--jkl-system-message-message-margin);
70
- }
71
-
72
- &__dismiss-button {
73
- background-color: transparent;
74
- padding: 0;
75
- cursor: pointer;
76
- display: grid;
77
- place-content: center;
78
- position: relative;
79
- flex-shrink: 0;
80
- margin-top: jkl.rem(3px); // visual alignment with text
81
- color: inherit;
82
-
83
- // Sørg for å ha en stor nok touch target.
84
- &::after {
85
- content: "";
86
- position: absolute;
87
- display: block;
88
- width: var(--jkl-system-message-dismiss-button-size);
89
- height: var(--jkl-system-message-dismiss-button-size);
90
- top: 50%;
91
- left: 50%;
92
- transform: translate(-50%, -50%);
93
- }
94
-
95
- @include jkl.forced-colors-svg-fallback($stroke: ButtonText);
96
-
97
- @include jkl.forced-colors-mode {
98
- background-color: ButtonFace;
99
- }
100
-
101
- @include jkl.reset-outline;
102
-
103
- &:hover {
104
- color: var(--jkl-color-text-interactive-hover);
105
-
106
- @include jkl.forced-colors-svg-fallback($stroke: ButtonText);
107
- }
108
-
109
- &:focus-visible {
110
- @include jkl.focus-outline;
111
-
112
- @include jkl.forced-colors-mode {
113
- outline: 2px solid ButtonText;
114
- outline-offset: 2px;
115
- }
116
- }
117
- }
118
-
119
- &__message,
120
- &__message:last-child {
121
- margin-bottom: 0;
122
- }
123
-
124
- &--dismissed {
125
- animation: $_dismiss-animation-name jkl.timing("lazy") forwards;
126
- transition: block jkl.timing("lazy") jkl.timing("lazy");
127
- }
128
-
129
- &--info {
130
- --background-color: var(--jkl-color-background-alert-info);
131
- }
132
-
133
- &--warning {
134
- --background-color: var(--jkl-color-background-alert-warning);
135
- }
136
-
137
- &--error {
138
- --background-color: var(--jkl-color-background-alert-error);
139
- }
140
-
141
- &--success {
142
- --background-color: var(--jkl-color-background-alert-success);
143
- }
144
-
145
- @include jkl.forced-colors-mode {
146
- border: 2px solid CanvasText;
147
-
148
- &--info {
149
- border-style: dotted;
150
- }
151
-
152
- &--warning {
153
- border-style: dashed;
154
- }
155
-
156
- &--error {
157
- border-style: double;
158
- border-width: 4px;
159
- }
160
- }
161
- }
162
-
163
- @keyframes #{$_dismiss-animation-name} {
164
- from {
165
- opacity: 1;
166
- transform: translateY(0);
167
- filter: saturate(1);
168
- display: block;
169
- }
170
-
171
- to {
172
- opacity: 0;
173
- transform: translateY(-10%);
174
- filter: saturate(0.7);
175
- display: none;
176
- }
177
- }
@@ -1,6 +0,0 @@
1
- @forward "table";
2
- @use "../expander" as expander;
3
- @use "../icon" as icon;
4
-
5
- // TablePagination avhenger av en del stiler, men komponenten
6
- // kan heller skilles ut til en egen "pakke"
@@ -1,7 +0,0 @@
1
- @use "../../core/jkl";
2
-
3
- .jkl-table-caption {
4
- &--sr-only {
5
- @include jkl.screenreader-only;
6
- }
7
- }