uikit 3.23.7 → 3.23.8-dev.97ee4c1bb

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 (196) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/build/release.js +1 -1
  3. package/build/scss.js +49 -12
  4. package/build/util.js +2 -0
  5. package/dist/css/uikit-core-rtl.css +1 -1
  6. package/dist/css/uikit-core-rtl.min.css +1 -1
  7. package/dist/css/uikit-core.css +1 -1
  8. package/dist/css/uikit-core.min.css +1 -1
  9. package/dist/css/uikit-rtl.css +1 -1
  10. package/dist/css/uikit-rtl.min.css +1 -1
  11. package/dist/css/uikit.css +1 -1
  12. package/dist/css/uikit.min.css +1 -1
  13. package/dist/js/components/countdown.js +1 -1
  14. package/dist/js/components/countdown.min.js +1 -1
  15. package/dist/js/components/filter.js +1 -1
  16. package/dist/js/components/filter.min.js +1 -1
  17. package/dist/js/components/lightbox-panel.js +7 -2
  18. package/dist/js/components/lightbox-panel.min.js +1 -1
  19. package/dist/js/components/lightbox.js +7 -2
  20. package/dist/js/components/lightbox.min.js +1 -1
  21. package/dist/js/components/notification.js +1 -1
  22. package/dist/js/components/notification.min.js +1 -1
  23. package/dist/js/components/parallax.js +3 -2
  24. package/dist/js/components/parallax.min.js +1 -1
  25. package/dist/js/components/slider-parallax.js +3 -2
  26. package/dist/js/components/slider-parallax.min.js +1 -1
  27. package/dist/js/components/slider.js +3 -2
  28. package/dist/js/components/slider.min.js +1 -1
  29. package/dist/js/components/slideshow-parallax.js +3 -2
  30. package/dist/js/components/slideshow-parallax.min.js +1 -1
  31. package/dist/js/components/slideshow.js +3 -2
  32. package/dist/js/components/slideshow.min.js +1 -1
  33. package/dist/js/components/sortable.js +1 -1
  34. package/dist/js/components/sortable.min.js +1 -1
  35. package/dist/js/components/tooltip.js +1 -1
  36. package/dist/js/components/tooltip.min.js +1 -1
  37. package/dist/js/components/upload.js +1 -1
  38. package/dist/js/components/upload.min.js +1 -1
  39. package/dist/js/uikit-core.js +10 -5
  40. package/dist/js/uikit-core.min.js +1 -1
  41. package/dist/js/uikit-icons.js +1 -1
  42. package/dist/js/uikit-icons.min.js +1 -1
  43. package/dist/js/uikit.js +10 -5
  44. package/dist/js/uikit.min.js +1 -1
  45. package/package.json +1 -1
  46. package/src/js/mixin/modal.js +7 -1
  47. package/src/js/mixin/svg.js +0 -2
  48. package/src/js/util/selector.js +1 -1
  49. package/src/scss/components/accordion.scss +8 -6
  50. package/src/scss/components/alert.scss +10 -8
  51. package/src/scss/components/align.scss +3 -1
  52. package/src/scss/components/animation.scss +3 -1
  53. package/src/scss/components/article.scss +7 -5
  54. package/src/scss/components/background.scss +3 -1
  55. package/src/scss/components/badge.scss +5 -3
  56. package/src/scss/components/base.scss +20 -17
  57. package/src/scss/components/breadcrumb.scss +9 -7
  58. package/src/scss/components/button.scss +25 -23
  59. package/src/scss/components/card.scss +26 -24
  60. package/src/scss/components/close.scss +5 -3
  61. package/src/scss/components/column.scss +3 -1
  62. package/src/scss/components/comment.scss +13 -11
  63. package/src/scss/components/container.scss +14 -11
  64. package/src/scss/components/countdown.scss +8 -6
  65. package/src/scss/components/cover.scss +3 -1
  66. package/src/scss/components/description-list.scss +6 -4
  67. package/src/scss/components/divider.scss +13 -10
  68. package/src/scss/components/dotnav.scss +8 -6
  69. package/src/scss/components/drop.scss +3 -1
  70. package/src/scss/components/dropbar.scss +8 -6
  71. package/src/scss/components/dropdown.scss +12 -10
  72. package/src/scss/components/dropnav.scss +3 -1
  73. package/src/scss/components/flex.scss +3 -1
  74. package/src/scss/components/form-range.scss +13 -10
  75. package/src/scss/components/form.scss +23 -21
  76. package/src/scss/components/grid.scss +5 -3
  77. package/src/scss/components/heading.scss +16 -13
  78. package/src/scss/components/height.scss +3 -1
  79. package/src/scss/components/icon.scss +9 -7
  80. package/src/scss/components/iconnav.scss +7 -5
  81. package/src/scss/components/inverse.scss +4 -2
  82. package/src/scss/components/label.scss +7 -5
  83. package/src/scss/components/leader.scss +4 -2
  84. package/src/scss/components/lightbox.scss +6 -4
  85. package/src/scss/components/link.scss +10 -8
  86. package/src/scss/components/list.scss +5 -3
  87. package/src/scss/components/margin.scss +3 -1
  88. package/src/scss/components/marker.scss +5 -3
  89. package/src/scss/components/mixin.scss +6 -4
  90. package/src/scss/components/modal.scss +18 -16
  91. package/src/scss/components/nav.scss +33 -31
  92. package/src/scss/components/navbar.scss +33 -30
  93. package/src/scss/components/notification.scss +10 -8
  94. package/src/scss/components/offcanvas.scss +6 -4
  95. package/src/scss/components/overlay.scss +7 -5
  96. package/src/scss/components/padding.scss +3 -1
  97. package/src/scss/components/pagination.scss +8 -6
  98. package/src/scss/components/placeholder.scss +4 -2
  99. package/src/scss/components/position.scss +9 -6
  100. package/src/scss/components/print.scss +3 -1
  101. package/src/scss/components/progress.scss +6 -4
  102. package/src/scss/components/search.scss +15 -13
  103. package/src/scss/components/section.scss +9 -7
  104. package/src/scss/components/slidenav.scss +10 -8
  105. package/src/scss/components/slider.scss +4 -2
  106. package/src/scss/components/slideshow.scss +4 -2
  107. package/src/scss/components/sortable.scss +7 -5
  108. package/src/scss/components/spinner.scss +6 -3
  109. package/src/scss/components/sticky.scss +3 -1
  110. package/src/scss/components/subnav.scss +13 -11
  111. package/src/scss/components/svg.scss +3 -1
  112. package/src/scss/components/switcher.scss +3 -1
  113. package/src/scss/components/tab.scss +14 -12
  114. package/src/scss/components/table.scss +17 -14
  115. package/src/scss/components/text.scss +8 -6
  116. package/src/scss/components/thumbnav.scss +7 -5
  117. package/src/scss/components/tile.scss +12 -10
  118. package/src/scss/components/tooltip.scss +4 -2
  119. package/src/scss/components/totop.scss +6 -4
  120. package/src/scss/components/transition.scss +3 -1
  121. package/src/scss/components/utility.scss +8 -6
  122. package/src/scss/components/visibility.scss +3 -1
  123. package/src/scss/components/width.scss +34 -31
  124. package/src/scss/mixins-theme.scss +169 -168
  125. package/src/scss/mixins.scss +175 -175
  126. package/src/scss/uikit-theme.scss +0 -1
  127. package/src/scss/variables-theme.scss +70 -66
  128. package/src/scss/variables.scss +74 -70
  129. package/src/scss/theme/_import.scss +0 -82
  130. package/src/scss/theme/accordion.scss +0 -55
  131. package/src/scss/theme/alert.scss +0 -45
  132. package/src/scss/theme/align.scss +0 -14
  133. package/src/scss/theme/animation.scss +0 -14
  134. package/src/scss/theme/article.scss +0 -49
  135. package/src/scss/theme/background.scss +0 -14
  136. package/src/scss/theme/badge.scss +0 -29
  137. package/src/scss/theme/base.scss +0 -104
  138. package/src/scss/theme/breadcrumb.scss +0 -45
  139. package/src/scss/theme/button.scss +0 -132
  140. package/src/scss/theme/card.scss +0 -111
  141. package/src/scss/theme/close.scss +0 -29
  142. package/src/scss/theme/column.scss +0 -14
  143. package/src/scss/theme/comment.scss +0 -67
  144. package/src/scss/theme/container.scss +0 -14
  145. package/src/scss/theme/countdown.scss +0 -53
  146. package/src/scss/theme/description-list.scss +0 -29
  147. package/src/scss/theme/divider.scss +0 -49
  148. package/src/scss/theme/dotnav.scss +0 -46
  149. package/src/scss/theme/drop.scss +0 -14
  150. package/src/scss/theme/dropbar.scss +0 -38
  151. package/src/scss/theme/dropdown.scss +0 -53
  152. package/src/scss/theme/form-range.scss +0 -51
  153. package/src/scss/theme/form.scss +0 -117
  154. package/src/scss/theme/grid.scss +0 -28
  155. package/src/scss/theme/heading.scss +0 -71
  156. package/src/scss/theme/height.scss +0 -14
  157. package/src/scss/theme/icon.scss +0 -50
  158. package/src/scss/theme/iconnav.scss +0 -39
  159. package/src/scss/theme/inverse.scss +0 -14
  160. package/src/scss/theme/label.scss +0 -41
  161. package/src/scss/theme/leader.scss +0 -26
  162. package/src/scss/theme/lightbox.scss +0 -32
  163. package/src/scss/theme/link.scss +0 -55
  164. package/src/scss/theme/list.scss +0 -34
  165. package/src/scss/theme/margin.scss +0 -14
  166. package/src/scss/theme/marker.scss +0 -29
  167. package/src/scss/theme/modal.scss +0 -77
  168. package/src/scss/theme/nav.scss +0 -131
  169. package/src/scss/theme/navbar.scss +0 -135
  170. package/src/scss/theme/notification.scss +0 -44
  171. package/src/scss/theme/offcanvas.scss +0 -32
  172. package/src/scss/theme/overlay.scss +0 -33
  173. package/src/scss/theme/padding.scss +0 -14
  174. package/src/scss/theme/pagination.scss +0 -41
  175. package/src/scss/theme/placeholder.scss +0 -26
  176. package/src/scss/theme/position.scss +0 -14
  177. package/src/scss/theme/progress.scss +0 -23
  178. package/src/scss/theme/search.scss +0 -101
  179. package/src/scss/theme/section.scss +0 -32
  180. package/src/scss/theme/slidenav.scss +0 -52
  181. package/src/scss/theme/slider.scss +0 -14
  182. package/src/scss/theme/sortable.scss +0 -38
  183. package/src/scss/theme/spinner.scss +0 -14
  184. package/src/scss/theme/sticky.scss +0 -14
  185. package/src/scss/theme/subnav.scss +0 -72
  186. package/src/scss/theme/tab.scss +0 -67
  187. package/src/scss/theme/table.scss +0 -65
  188. package/src/scss/theme/text.scss +0 -49
  189. package/src/scss/theme/thumbnav.scss +0 -40
  190. package/src/scss/theme/tile.scss +0 -52
  191. package/src/scss/theme/tooltip.scss +0 -20
  192. package/src/scss/theme/totop.scss +0 -32
  193. package/src/scss/theme/transition.scss +0 -14
  194. package/src/scss/theme/utility.scss +0 -49
  195. package/src/scss/theme/variables.scss +0 -36
  196. package/src/scss/theme/width.scss +0 -14
package/CHANGELOG.md CHANGED
@@ -1,5 +1,11 @@
1
1
  # Changelog
2
2
 
3
+ ## WIP
4
+
5
+ ### Fixed
6
+
7
+ - Fix setting focus to Modal/Offcanvas Toggle component after close
8
+
3
9
  ## 3.23.7 (May 9, 2025)
4
10
 
5
11
  ### Fixed
package/build/release.js CHANGED
@@ -112,7 +112,7 @@ async function deploy(version) {
112
112
  const notes = (await read('./Changelog.md'))
113
113
  .match(/## \d.*?$\s*(.*?)\s*(?=## \d)/ms)[1]
114
114
  .replace(/(["`])/g, '\\$1');
115
- await $$`gh release create v${version} --notes ${notes} ./dist/uikit-${version}.zip`;
115
+ await $$`gh release create v${version} --repo uikit/uikit --notes ${notes} ./dist/uikit-${version}.zip`;
116
116
 
117
117
  await $$`git checkout develop`;
118
118
  await $$`git merge ${tag} --commit --no-ff -m ${`Merge tag '${tag}' into develop`}`;
package/build/scss.js CHANGED
@@ -1,3 +1,4 @@
1
+ import { emptyDir } from 'fs-extra';
1
2
  import { glob } from 'glob';
2
3
  import NP from 'number-precision';
3
4
  import path from 'path';
@@ -11,7 +12,8 @@ const coreVariables = {};
11
12
  const themeVariables = {};
12
13
  const inverseComponentMixins = [];
13
14
 
14
- /* First Step: Go through all files */
15
+ await emptyDir('src/scss/');
16
+
15
17
  for (const file of (await glob('src/less/**/*.less'))
16
18
  .sort()
17
19
  .sort((a, b) => a.endsWith('/inverse.less') - b.endsWith('/inverse.less'))) {
@@ -78,7 +80,9 @@ for (const file of (await glob('src/less/**/*.less'))
78
80
  );
79
81
  } else if (source.match(/hook-inverse(?!-)/)) {
80
82
  source = source.replace(/hook-inverse(?!-)/, `hook-inverse-component-${filename}`);
81
- inverseComponentMixins.push(`hook-inverse-component-${filename}`);
83
+ if (!inverseComponentMixins.includes(`hook-inverse-component-${filename}`)) {
84
+ inverseComponentMixins.push(`hook-inverse-component-${filename}`);
85
+ }
82
86
  }
83
87
 
84
88
  /* get all the mixins and remove them from the file */
@@ -90,11 +94,7 @@ for (const file of (await glob('src/less/**/*.less'))
90
94
  if (filename === 'uikit.theme') {
91
95
  /* remove the theme import first place */
92
96
  source = source.replace(/\/\/\n\/\/ Theme\n\/\/\n\n@import "theme\/_import.scss";/, '');
93
- /* add uikit-mixins and uikit-variables include to the uikit.scss file and change order, to load theme files first */
94
- source = source.replace(
95
- /\/\/ Core\n\/\//g,
96
- '// Theme\n//\n\n@import "theme/_import.scss";',
97
- );
97
+ source = source.replace(/\/\/ Core\n\/\//g, '// Theme\n//\n');
98
98
  }
99
99
 
100
100
  /* mixin.less needs to be fully replaced by the new mixin file*/
@@ -102,18 +102,22 @@ for (const file of (await glob('src/less/**/*.less'))
102
102
  source = await read('build/scss/mixin.scss');
103
103
  }
104
104
 
105
- await write(file.replace(/less/g, 'scss').replace('.theme.', '-theme.'), source);
105
+ if (!file.includes('theme/')) {
106
+ await write(
107
+ file.replace(/less/g, 'scss').replace('.theme.', '-theme.'),
108
+ useSassModules(source),
109
+ );
110
+ }
106
111
  }
107
112
 
108
- /* Second Step: write all new needed files for Sass */
109
-
110
113
  /* write mixins files */
111
114
  for (const [vars, file] of [
112
115
  [coreMixins, 'mixins'],
113
116
  [themeMixins, 'mixins-theme'],
114
117
  ]) {
115
118
  delete vars['svg-fill'];
116
- await write(`src/scss/${file}.scss`, Object.values(vars).join('\n'));
119
+
120
+ await write(`src/scss/${file}.scss`, useSassModules(Object.values(vars).join('\n')));
117
121
  }
118
122
 
119
123
  /* write variables files */
@@ -125,7 +129,40 @@ for (const [vars, file] of [
125
129
  (dependencies, key) => resolveDependencies(vars, key, dependencies),
126
130
  new Set(),
127
131
  );
128
- await write(`src/scss/${file}.scss`, Array.from(variables).join('\n'));
132
+ await write(`src/scss/${file}.scss`, useSassModules(Array.from(variables).join('\n')));
133
+ }
134
+
135
+ /*
136
+ * add prefix of origin to methods
137
+ */
138
+ function useSassModules(source) {
139
+ const modules = new Set();
140
+
141
+ for (const [module, search, replacement] of [
142
+ ['meta', /(?<=\W)mixin-exists\(/g, 'meta.$&'],
143
+ ['string', /(?<=\W)(un)?quote\(/g, 'string.$&'],
144
+ ['string', /(?<=\W)str-(index|slice|length)\(/g, 'string.$1('],
145
+ ['math', /(?<=\W)(floor|round)\(/g, 'math.$&'],
146
+ ['color', /(?<=\W)mix\(/g, 'color.$&'],
147
+ ['color', /(?<=\W)lighten\((.*),\s*(.*)\)/g, 'color.adjust($1, $lightness: $2)'],
148
+ ['color', /(?<=\W)darken\((.*),\s*(.*)\)/g, 'color.adjust($1, $lightness: -$2)'],
149
+ ['color', /(?<=\W)fade-in\(([^,]*),\s*(.*)\)/g, 'color.adjust($1, $alpha: $2)'],
150
+ ['color', /(?<=\W)fade-out\(([^,]*),\s*(.*)\)/g, 'color.adjust($1, $alpha: -$2)'],
151
+ ['color', /(?<=\W)adjust-hue\(([^,]*),\s*(.*)\)/g, 'color.adjust($1, $hue: $2)'],
152
+ ]) {
153
+ const prev = source;
154
+ source = source.replaceAll(search, replacement);
155
+
156
+ if (source !== prev) {
157
+ modules.add(module);
158
+ }
159
+ }
160
+
161
+ return modules.size
162
+ ? `${Array.from(modules)
163
+ .map((module) => `@use "sass:${module}";`)
164
+ .join('\n')}\n\n${source}`
165
+ : source;
129
166
  }
130
167
 
131
168
  /*
package/build/util.js CHANGED
@@ -30,6 +30,8 @@ export function read(file) {
30
30
  }
31
31
 
32
32
  export async function write(dest, data) {
33
+ fs.ensureDir(path.dirname(dest));
34
+
33
35
  await fs.writeFile(dest, data);
34
36
  await logFile(dest);
35
37
 
@@ -1,4 +1,4 @@
1
- /*! UIkit 3.23.7 | https://www.getuikit.com | (c) 2014 - 2025 YOOtheme | MIT License */
1
+ /*! UIkit 3.23.8-dev.97ee4c1bb | https://www.getuikit.com | (c) 2014 - 2025 YOOtheme | MIT License */
2
2
  /* ========================================================================
3
3
  Component: Base
4
4
  ========================================================================== */