@ulu/frontend 0.0.3 → 0.0.6

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 (285) hide show
  1. package/CHANGELOG.md +19 -0
  2. package/README.md +3 -1
  3. package/js/deprecated/mini-collapsible.js +1 -1
  4. package/js/events/index.js +4 -1
  5. package/js/helpers/css-breakpoint.js +5 -7
  6. package/js/helpers/file-save.js +4 -0
  7. package/js/helpers/node-data-manager.js +4 -0
  8. package/js/helpers/pause-youtube-video.js +4 -0
  9. package/js/helpers/scrollbar-width-property.js +6 -2
  10. package/js/index.js +0 -2
  11. package/js/ui/flipcard.js +5 -1
  12. package/js/ui/grid.js +4 -0
  13. package/js/ui/modals.js +4 -1
  14. package/js/ui/overflow-scroller-pager.js +3 -0
  15. package/js/ui/overflow-scroller.js +4 -1
  16. package/js/ui/programmatic-modal.js +3 -0
  17. package/js/ui/resizer.js +3 -0
  18. package/js/ui/slider.js +7 -4
  19. package/js/ui/tabs.js +3 -0
  20. package/js/ui/tooltip.js +3 -0
  21. package/js/utils/logger.js +3 -0
  22. package/package.json +20 -11
  23. package/scss/_breakpoint.scss +3 -4
  24. package/scss/_button.scss +4 -4
  25. package/scss/_color.scss +2 -2
  26. package/scss/_grid.scss +0 -1
  27. package/scss/_layout.scss +2 -3
  28. package/scss/_typography.scss +2 -3
  29. package/scss/_utils.scss +21 -4
  30. package/scss/base/_normalize.scss +1 -1
  31. package/scss/helpers/_units.scss +7 -11
  32. package/scss/stylesheets/full.scss +1 -4
  33. package/js/polyfills/element-closest.js +0 -17
  34. package/js/utils/array.js +0 -28
  35. package/js/utils/dom.js +0 -122
  36. package/js/utils/object.js +0 -22
  37. package/js/utils/performance.js +0 -43
  38. package/js/utils/regex.js +0 -10
  39. package/js/utils/string.js +0 -107
  40. package/trash/js-old/deprecated/doc-ready.js +0 -28
  41. package/trash/js-old/deprecated/jquery-prototypes.js +0 -309
  42. package/trash/js-old/deprecated/mini-collapsible-popper-positioning.js +0 -126
  43. package/trash/js-old/deprecated/mini-collapsible.js +0 -607
  44. package/trash/js-old/deprecated/script-loader.js +0 -60
  45. package/trash/js-old/events/index.js +0 -42
  46. package/trash/js-old/helpers/css-breakpoint.js +0 -247
  47. package/trash/js-old/helpers/file-save.js +0 -48
  48. package/trash/js-old/helpers/node-data-manager.js +0 -74
  49. package/trash/js-old/helpers/pause-youtube-video.js +0 -42
  50. package/trash/js-old/index.js +0 -15
  51. package/trash/js-old/polyfills/element-closest.js +0 -17
  52. package/trash/js-old/ui/flipcard.js +0 -202
  53. package/trash/js-old/ui/grid.js +0 -67
  54. package/trash/js-old/ui/modals.js +0 -219
  55. package/trash/js-old/ui/programmatic-modal.js +0 -91
  56. package/trash/js-old/ui/resizer.js +0 -60
  57. package/trash/js-old/ui/slider.js +0 -469
  58. package/trash/js-old/ui/tabs.js +0 -109
  59. package/trash/js-old/ui/tooltip.js +0 -82
  60. package/trash/js-old/utils/array.js +0 -28
  61. package/trash/js-old/utils/dom.js +0 -122
  62. package/trash/js-old/utils/logger.js +0 -69
  63. package/trash/js-old/utils/object.js +0 -22
  64. package/trash/js-old/utils/performance.js +0 -43
  65. package/trash/js-old/utils/regex.js +0 -10
  66. package/trash/js-old/utils/string.js +0 -107
  67. package/trash/js-old/waypoints/README.md +0 -3
  68. package/trash/js-old/waypoints/anchor-menu.js +0 -76
  69. package/trash/js-old/waypoints/element-waypoint.js +0 -75
  70. package/trash/js-old/waypoints/examples/page-link-menu.md +0 -106
  71. package/trash/js-old/waypoints/state-in-attribute.js +0 -32
  72. package/trash/js-old-230729/deprecated/doc-ready.js +0 -28
  73. package/trash/js-old-230729/deprecated/jquery-prototypes.js +0 -309
  74. package/trash/js-old-230729/deprecated/mini-collapsible-popper-positioning.js +0 -126
  75. package/trash/js-old-230729/deprecated/mini-collapsible.js +0 -607
  76. package/trash/js-old-230729/deprecated/script-loader.js +0 -60
  77. package/trash/js-old-230729/events/index.js +0 -42
  78. package/trash/js-old-230729/helpers/css-breakpoint.js +0 -247
  79. package/trash/js-old-230729/helpers/file-save.js +0 -48
  80. package/trash/js-old-230729/helpers/node-data-manager.js +0 -74
  81. package/trash/js-old-230729/helpers/pause-youtube-video.js +0 -42
  82. package/trash/js-old-230729/helpers/scrollbar-width-property.js +0 -10
  83. package/trash/js-old-230729/index.js +0 -15
  84. package/trash/js-old-230729/polyfills/element-closest.js +0 -17
  85. package/trash/js-old-230729/ui/flipcard.js +0 -202
  86. package/trash/js-old-230729/ui/grid.js +0 -67
  87. package/trash/js-old-230729/ui/modals.js +0 -219
  88. package/trash/js-old-230729/ui/overflow-scroller-pager.js +0 -58
  89. package/trash/js-old-230729/ui/overflow-scroller.js +0 -160
  90. package/trash/js-old-230729/ui/programmatic-modal.js +0 -91
  91. package/trash/js-old-230729/ui/resizer.js +0 -60
  92. package/trash/js-old-230729/ui/slider.js +0 -468
  93. package/trash/js-old-230729/ui/tabs.js +0 -109
  94. package/trash/js-old-230729/ui/tooltip.js +0 -82
  95. package/trash/js-old-230729/utils/array.js +0 -28
  96. package/trash/js-old-230729/utils/dom.js +0 -122
  97. package/trash/js-old-230729/utils/logger.js +0 -69
  98. package/trash/js-old-230729/utils/object.js +0 -22
  99. package/trash/js-old-230729/utils/performance.js +0 -43
  100. package/trash/js-old-230729/utils/regex.js +0 -10
  101. package/trash/js-old-230729/utils/string.js +0 -107
  102. package/trash/js-old-230729/waypoints/README.md +0 -3
  103. package/trash/js-old-230729/waypoints/anchor-menu.js +0 -76
  104. package/trash/js-old-230729/waypoints/element-waypoint.js +0 -75
  105. package/trash/js-old-230729/waypoints/examples/page-link-menu.md +0 -106
  106. package/trash/js-old-230729/waypoints/state-in-attribute.js +0 -32
  107. package/trash/logo-1.svg +0 -13
  108. package/trash/logo.svg +0 -16
  109. package/trash/scss-before-cqc-update/README.md +0 -58
  110. package/trash/scss-before-cqc-update/_breakpoint.scss +0 -190
  111. package/trash/scss-before-cqc-update/_button.scss +0 -229
  112. package/trash/scss-before-cqc-update/_calculate.scss +0 -65
  113. package/trash/scss-before-cqc-update/_color.scss +0 -211
  114. package/trash/scss-before-cqc-update/_cssvar.scss +0 -116
  115. package/trash/scss-before-cqc-update/_element.scss +0 -275
  116. package/trash/scss-before-cqc-update/_index.scss +0 -29
  117. package/trash/scss-before-cqc-update/_layout.scss +0 -247
  118. package/trash/scss-before-cqc-update/_path.scss +0 -59
  119. package/trash/scss-before-cqc-update/_selector.scss +0 -82
  120. package/trash/scss-before-cqc-update/_typography.scss +0 -322
  121. package/trash/scss-before-cqc-update/_units.scss +0 -48
  122. package/trash/scss-before-cqc-update/_utility.scss +0 -13
  123. package/trash/scss-before-cqc-update/_utils.scss +0 -211
  124. package/trash/scss-before-cqc-update/base/_color.scss +0 -14
  125. package/trash/scss-before-cqc-update/base/_elements.scss +0 -189
  126. package/trash/scss-before-cqc-update/base/_index.scss +0 -63
  127. package/trash/scss-before-cqc-update/base/_keyframes.scss +0 -74
  128. package/trash/scss-before-cqc-update/base/_layout.scss +0 -88
  129. package/trash/scss-before-cqc-update/base/_normalize.scss +0 -316
  130. package/trash/scss-before-cqc-update/base/_typography.scss +0 -42
  131. package/trash/scss-before-cqc-update/components/README.md +0 -5
  132. package/trash/scss-before-cqc-update/components/README.todos +0 -15
  133. package/trash/scss-before-cqc-update/components/_button.scss +0 -96
  134. package/trash/scss-before-cqc-update/components/_grid.scss +0 -671
  135. package/trash/scss-before-cqc-update/components/_index.scss +0 -70
  136. package/trash/scss-before-cqc-update/components/_links.scss +0 -35
  137. package/trash/scss-before-cqc-update/components/_list-lines.scss +0 -74
  138. package/trash/scss-before-cqc-update/components/_list-ordered.scss +0 -17
  139. package/trash/scss-before-cqc-update/components/_list-unordered.scss +0 -22
  140. package/trash/scss-before-cqc-update/components/_rule.scss +0 -94
  141. package/trash/scss-before-cqc-update/helpers/_color.scss +0 -15
  142. package/trash/scss-before-cqc-update/helpers/_display.scss +0 -73
  143. package/trash/scss-before-cqc-update/helpers/_index.scss +0 -68
  144. package/trash/scss-before-cqc-update/helpers/_print.scss +0 -59
  145. package/trash/scss-before-cqc-update/helpers/_typography.scss +0 -73
  146. package/trash/scss-before-cqc-update/helpers/_units.scss +0 -79
  147. package/trash/scss-before-cqc-update/helpers/_utilities.scss +0 -88
  148. package/trash/scss-before-cqc-update/stylesheets/README.md +0 -3
  149. package/trash/scss-before-cqc-update/stylesheets/full.scss +0 -17
  150. package/trash/scss-old/README.md +0 -58
  151. package/trash/scss-old/_breakpoint.scss +0 -140
  152. package/trash/scss-old/_button.scss +0 -223
  153. package/trash/scss-old/_calculate.scss +0 -64
  154. package/trash/scss-old/_color.scss +0 -200
  155. package/trash/scss-old/_element.scss +0 -262
  156. package/trash/scss-old/_grid.scss +0 -558
  157. package/trash/scss-old/_index.scss +0 -25
  158. package/trash/scss-old/_layout.scss +0 -170
  159. package/trash/scss-old/_path.scss +0 -58
  160. package/trash/scss-old/_selector.scss +0 -81
  161. package/trash/scss-old/_typography.scss +0 -320
  162. package/trash/scss-old/_units.scss +0 -47
  163. package/trash/scss-old/_utility.scss +0 -12
  164. package/trash/scss-old/_utils.scss +0 -186
  165. package/trash/scss-old/base/_color.scss +0 -13
  166. package/trash/scss-old/base/_elements.scss +0 -183
  167. package/trash/scss-old/base/_index.scss +0 -62
  168. package/trash/scss-old/base/_keyframes.scss +0 -74
  169. package/trash/scss-old/base/_layout.scss +0 -81
  170. package/trash/scss-old/base/_normalize.scss +0 -316
  171. package/trash/scss-old/base/_typography.scss +0 -42
  172. package/trash/scss-old/components/README.md +0 -5
  173. package/trash/scss-old/components/README.todos +0 -15
  174. package/trash/scss-old/components/_button.scss +0 -74
  175. package/trash/scss-old/components/_index.scss +0 -63
  176. package/trash/scss-old/components/_links.scss +0 -34
  177. package/trash/scss-old/components/_list-lines.scss +0 -73
  178. package/trash/scss-old/components/_list-ordered.scss +0 -16
  179. package/trash/scss-old/components/_list-unordered.scss +0 -21
  180. package/trash/scss-old/components/_rule.scss +0 -84
  181. package/trash/scss-old/helpers/_color.scss +0 -14
  182. package/trash/scss-old/helpers/_display.scss +0 -68
  183. package/trash/scss-old/helpers/_index.scss +0 -67
  184. package/trash/scss-old/helpers/_print.scss +0 -59
  185. package/trash/scss-old/helpers/_typography.scss +0 -73
  186. package/trash/scss-old/helpers/_units.scss +0 -68
  187. package/trash/scss-old/helpers/_utilities.scss +0 -82
  188. package/trash/scss-old/packages/README.md +0 -3
  189. package/trash/scss-old/packages/everything.scss +0 -17
  190. package/trash/scss-old-2/README.md +0 -58
  191. package/trash/scss-old-2/_breakpoint.scss +0 -139
  192. package/trash/scss-old-2/_button.scss +0 -223
  193. package/trash/scss-old-2/_calculate.scss +0 -64
  194. package/trash/scss-old-2/_color.scss +0 -202
  195. package/trash/scss-old-2/_element.scss +0 -263
  196. package/trash/scss-old-2/_grid.scss +0 -558
  197. package/trash/scss-old-2/_index.scss +0 -25
  198. package/trash/scss-old-2/_layout.scss +0 -170
  199. package/trash/scss-old-2/_path.scss +0 -58
  200. package/trash/scss-old-2/_selector.scss +0 -81
  201. package/trash/scss-old-2/_typography.scss +0 -320
  202. package/trash/scss-old-2/_units.scss +0 -47
  203. package/trash/scss-old-2/_utility.scss +0 -12
  204. package/trash/scss-old-2/_utils.scss +0 -186
  205. package/trash/scss-old-2/base/_color.scss +0 -13
  206. package/trash/scss-old-2/base/_elements.scss +0 -182
  207. package/trash/scss-old-2/base/_index.scss +0 -62
  208. package/trash/scss-old-2/base/_keyframes.scss +0 -73
  209. package/trash/scss-old-2/base/_layout.scss +0 -83
  210. package/trash/scss-old-2/base/_normalize.scss +0 -315
  211. package/trash/scss-old-2/base/_typography.scss +0 -41
  212. package/trash/scss-old-2/components/README.md +0 -5
  213. package/trash/scss-old-2/components/README.todos +0 -15
  214. package/trash/scss-old-2/components/_button.scss +0 -95
  215. package/trash/scss-old-2/components/_index.scss +0 -63
  216. package/trash/scss-old-2/components/_links.scss +0 -33
  217. package/trash/scss-old-2/components/_list-lines.scss +0 -73
  218. package/trash/scss-old-2/components/_list-ordered.scss +0 -16
  219. package/trash/scss-old-2/components/_list-unordered.scss +0 -21
  220. package/trash/scss-old-2/components/_rule.scss +0 -84
  221. package/trash/scss-old-2/helpers/_color.scss +0 -14
  222. package/trash/scss-old-2/helpers/_display.scss +0 -67
  223. package/trash/scss-old-2/helpers/_index.scss +0 -67
  224. package/trash/scss-old-2/helpers/_print.scss +0 -58
  225. package/trash/scss-old-2/helpers/_typography.scss +0 -72
  226. package/trash/scss-old-2/helpers/_units.scss +0 -68
  227. package/trash/scss-old-2/helpers/_utilities.scss +0 -81
  228. package/trash/scss-old-2/packages/README.md +0 -3
  229. package/trash/scss-old-2/packages/everything.scss +0 -17
  230. package/trash/scss-old-230729/README.md +0 -58
  231. package/trash/scss-old-230729/_breakpoint.scss +0 -139
  232. package/trash/scss-old-230729/_button.scss +0 -223
  233. package/trash/scss-old-230729/_calculate.scss +0 -64
  234. package/trash/scss-old-230729/_color.scss +0 -202
  235. package/trash/scss-old-230729/_element.scss +0 -273
  236. package/trash/scss-old-230729/_grid.scss +0 -694
  237. package/trash/scss-old-230729/_index.scss +0 -25
  238. package/trash/scss-old-230729/_layout.scss +0 -193
  239. package/trash/scss-old-230729/_path.scss +0 -58
  240. package/trash/scss-old-230729/_selector.scss +0 -81
  241. package/trash/scss-old-230729/_typography.scss +0 -320
  242. package/trash/scss-old-230729/_units.scss +0 -47
  243. package/trash/scss-old-230729/_utility.scss +0 -12
  244. package/trash/scss-old-230729/_utils.scss +0 -186
  245. package/trash/scss-old-230729/base/_color.scss +0 -13
  246. package/trash/scss-old-230729/base/_elements.scss +0 -188
  247. package/trash/scss-old-230729/base/_index.scss +0 -62
  248. package/trash/scss-old-230729/base/_keyframes.scss +0 -73
  249. package/trash/scss-old-230729/base/_layout.scss +0 -83
  250. package/trash/scss-old-230729/base/_normalize.scss +0 -315
  251. package/trash/scss-old-230729/base/_typography.scss +0 -41
  252. package/trash/scss-old-230729/components/README.md +0 -5
  253. package/trash/scss-old-230729/components/README.todos +0 -15
  254. package/trash/scss-old-230729/components/_button.scss +0 -95
  255. package/trash/scss-old-230729/components/_index.scss +0 -63
  256. package/trash/scss-old-230729/components/_links.scss +0 -34
  257. package/trash/scss-old-230729/components/_list-lines.scss +0 -73
  258. package/trash/scss-old-230729/components/_list-ordered.scss +0 -16
  259. package/trash/scss-old-230729/components/_list-unordered.scss +0 -21
  260. package/trash/scss-old-230729/components/_rule.scss +0 -93
  261. package/trash/scss-old-230729/helpers/_color.scss +0 -14
  262. package/trash/scss-old-230729/helpers/_display.scss +0 -73
  263. package/trash/scss-old-230729/helpers/_index.scss +0 -67
  264. package/trash/scss-old-230729/helpers/_print.scss +0 -58
  265. package/trash/scss-old-230729/helpers/_typography.scss +0 -72
  266. package/trash/scss-old-230729/helpers/_units.scss +0 -68
  267. package/trash/scss-old-230729/helpers/_utilities.scss +0 -87
  268. package/trash/scss-old-230729/packages/README.md +0 -3
  269. package/trash/scss-old-230729/packages/everything.scss +0 -17
  270. package/trash/vue/directives/background-image-url.js +0 -12
  271. package/trash/vue/helpers/add-required-components.js +0 -14
  272. package/trash/vue/ui/CollapsibleRegion/CollapsibleRegion.vue +0 -277
  273. package/trash/vue/ui/CollapsibleRegion/Demo.vue +0 -101
  274. package/trash/vue/ui/Dropdown/Dropdown.vue +0 -184
  275. package/trash/vue/ui/Modals/components/Modal.vue +0 -49
  276. package/trash/vue/ui/Modals/components/Modals.vue +0 -103
  277. package/trash/vue/ui/Modals/plugin.js +0 -215
  278. package/trash/vue/ui/Modals/readme.note +0 -10
  279. package/trash/vue/ui/Modals/reference/example-usage.vue +0 -27
  280. package/trash/vue/ui/Modals/reference/wcag-example/dialog.js +0 -324
  281. /package/js/{waypoints → deprecated/waypoints}/README.md +0 -0
  282. /package/js/{waypoints → deprecated/waypoints}/anchor-menu.js +0 -0
  283. /package/js/{waypoints → deprecated/waypoints}/element-waypoint.js +0 -0
  284. /package/js/{waypoints → deprecated/waypoints}/examples/page-link-menu.md +0 -0
  285. /package/js/{waypoints → deprecated/waypoints}/state-in-attribute.js +0 -0
@@ -1,671 +0,0 @@
1
- ////
2
- /// @group grid
3
- ////
4
- /// Layout grid that uses attributes instead of classes
5
- /// - See the core layout module for changing defaults
6
-
7
- /// @version: 1.0.7
8
-
9
- /// HTML Attribute to use for selecting
10
- /// @example markup
11
- /// <!-- instead it styles like: -->
12
- /// <div data-grid="columns: 12, gutters: true">
13
- /// <div data-grid-item="width: 4, width-medium: 6, offset-medium: 3">
14
- /// </div>
15
- /// </div>
16
- ///
17
- /// <!-- or if using container -->
18
- /// <div data-grid-container>
19
- /// <div data-grid="columns: 12, gutters: true">
20
- /// <div data-grid-item="width: 4, width-medium: 6, offset-medium: 3">
21
- /// </div>
22
- /// </div>
23
- /// </div>
24
- ///
25
-
26
- @use "sass:map";
27
- @use "sass:math";
28
- @use "../breakpoint";
29
- @use "../color";
30
- @use "../layout";
31
- @use "../utils";
32
-
33
- /// Module Settings
34
- /// @type Map
35
- /// @prop {String} attribute ["data-grid"] Default attribute to use for grid mixin
36
- /// @prop {String} attributeContainer ["data-grid-container"] Default container attribute to use for grid mixin
37
- /// @prop {String} position-class-column-first ["position-column-first"] Classname for position system (JS) grid uses to display rules (layout can flow, script will update classes)
38
- /// @prop {String} position-class-column-last ["position-column-last"] See definition above
39
- /// @prop {String} position-class-row-first ["position-row-first"] See definition above
40
- /// @prop {String} position-class-row-last ["position-row-last"] See definition above
41
-
42
- $config: (
43
- "attribute" : "data-grid",
44
- "attribute-container" : "data-grid-container",
45
- "position-class-column-first": "position-column-first",
46
- "position-class-column-last" : "position-column-last",
47
- "position-class-row-first" : "position-row-first",
48
- "position-class-row-last" : "position-row-last"
49
- ) !default;
50
-
51
- /// Change modules $config
52
- /// @param {Map} $changes Map of changes
53
- /// @example scss
54
- /// @include module-name.set(( "property" : value ));
55
-
56
- @mixin set($changes) {
57
- $config: map.merge($config, $changes) !global;
58
- }
59
-
60
- /// Get a config option
61
- /// @param {Map} $name Name of property
62
- /// @example scss
63
- /// @include module-name.get("property");
64
-
65
- @function get($name) {
66
- @return utils.require-map-get($config, $name, "attribute-grid [config]");
67
- }
68
-
69
- /// Prints the default grid
70
- /// - User can choose not to output this and use `attribute-grid.create()` instead
71
-
72
- @mixin styles {
73
- @include create();
74
- }
75
-
76
-
77
- /// Creates grid css (variation of original data-grid)
78
- /// @param {Number} $columns Columns in grid
79
- /// @param {Number} $breakpoint Breakpoint key for starting the grid
80
- /// @param {Map} $extra-breakpoints Map with other breakpoints to add (map of breakpoint and gutter see config.extra-breakpoints for an example (smalles to largest)
81
- /// @param {Number} $gutter Size in pixels for the gutters
82
- /// @param {Boolean} $include-rules Print styles for including rules
83
- /// @param {Number} $rule-size Size of the rule (border/seperator)
84
- /// @param {Map} $extra-rule-styles Map of other rule styles to add (map of maps of size, and color), key is the styles name ("name": ("size" : 4px, "color" : "color name" || color))
85
- /// @param {String} $extra-gutter-scales A map of gutter scales used like `data-grid="gutter-scale: large`, configuration map property becomes scale name and value is the amount (multiplier) to apply to the grid's gutter ie `( "large" : 2.25 )`
86
- /// @param {Map} $attribute Attribute to use for selecting grid and children. Children attribute get's "-item" as a suffix ("ie. data-grid, data-grid-item")
87
- /// @param {Boolean} $include-container [false] Whether to include container styles, container adds matching grid gutter to left/right side of grid. can be used for edge situations where negative margins are causing overflow
88
- /// @param {String} $container-attribute [defaults to config] Attribute to use for selecting grid container
89
- /// @param {Boolean} $container-gutter-scales [true] Print container styles for all gutter scales passed (reduce output)
90
-
91
- @mixin create(
92
- $columns: 12,
93
- $breakpoint: layout.get-default-breakpoint(),
94
- $extra-breakpoints: if(breakpoint.exists("large"), layout.get("extra-breakpoints"), false),
95
- $gutter: layout.get("gutter"),
96
- $include-rules: false,
97
- $rule-size: 1px,
98
- $rule-color: color.get("rule"),
99
- $extra-rule-styles: null,
100
- $extra-gutter-scales: null,
101
- $attribute: get("attribute"),
102
- $include-container: false,
103
- $container-attribute: get("attribute-container"),
104
- $container-gutter-scales: true
105
- ) {
106
- $attribute-item: "#{ $attribute }-item";
107
- $select-grid: '[#{ $attribute }*="columns: #{ $columns }"]';
108
- $select-item: '[#{ $attribute-item }]';
109
- $select-rule-col: ":before";
110
- $select-rule-row: ":after";
111
- $select-container: "[#{ $container-attribute }]";
112
- // These through off syntax highlighting when inside interpolation
113
- $position-class-column-first: get("position-class-column-first");
114
- $position-class-column-last: get("position-class-column-last");
115
- $position-class-row-first: get("position-class-row-first");
116
- $position-class-row-last: get("position-class-row-last");
117
-
118
- #{ $select-grid } {
119
- @include layout.clearfix(); // For legacy browsers
120
-
121
- // Ensure empty elements still take up space in layout
122
- > #{ $select-item } {
123
- min-height: 1px;
124
- width: 100%;
125
- }
126
- // This is for value of true and also covers all options below
127
- &#{'[#{ $attribute }*="gutters-row:"]'} {
128
- > #{ $select-item } {
129
- padding-top: $gutter;
130
- padding-bottom: $gutter;
131
- }
132
- @if $extra-gutter-scales {
133
- @each $scale, $amount in $extra-gutter-scales {
134
- &#{'[#{ $attribute }*="gutter-scale: #{ $scale }"]'} {
135
- > #{ $select-item } {
136
- padding-top: $gutter * $amount;
137
- padding-bottom: $gutter * $amount;
138
- }
139
- }
140
- }
141
- }
142
- }
143
- &#{'[#{ $attribute }*="gutters-row: top"]'} {
144
- > #{ $select-item } {
145
- &.#{ $position-class-row-last } {
146
- padding-bottom: 0;
147
- }
148
- }
149
- }
150
- &#{'[#{ $attribute }*="gutters-row: bottom"]'} {
151
- > #{ $select-item } {
152
- &.#{ $position-class-row-first } {
153
- padding-top: 0;
154
- }
155
- }
156
- }
157
- &#{'[#{ $attribute }*="gutters-row: fit"]'} {
158
- margin-top: -$gutter;
159
- margin-bottom: -$gutter;
160
- @if $extra-gutter-scales {
161
- @each $scale, $amount in $extra-gutter-scales {
162
- &#{'[#{ $attribute }*="gutter-scale: #{ $scale }"]'} {
163
- margin-top: -($gutter * $amount);
164
- margin-bottom: -($gutter * $amount);
165
- }
166
- }
167
- }
168
- }
169
- // Rules: Row
170
- &#{'[#{ $attribute }*="rules-row:"]'} {
171
- > #{ $select-item } {
172
- &#{ $select-rule-row } {
173
- position: absolute;
174
- left: 0;
175
- right: 0;
176
- height: $rule-size;
177
- background: color.get($rule-color);
178
- }
179
- }
180
- }
181
- // Rules: Applies to both column and row
182
- &#{'[#{ $attribute }*="rules"]'} {
183
- > #{ $select-item } {
184
- position: relative;
185
- }
186
- }
187
- // Rules: Column
188
- &#{'[#{ $attribute }*="rules-column:"]'} {
189
- > #{ $select-item } {
190
- &#{ $select-rule-col } {
191
- position: absolute;
192
- top: 0;
193
- bottom: 0;
194
- width: $rule-size;
195
- background: color.get($rule-color);
196
- }
197
- }
198
- }
199
- // Options for the left or right
200
- @include -create-rule-col-position(
201
- $position: "left",
202
- $size: $rule-size,
203
- $attribute: $attribute,
204
- $select-item: $select-item,
205
- $select-rule-col: $select-rule-col,
206
- $end-class: $position-class-column-first
207
- );
208
- @include -create-rule-col-position(
209
- $position: "right",
210
- $size: $rule-size,
211
- $attribute: $attribute,
212
- $select-item: $select-item,
213
- $select-rule-col: $select-rule-col,
214
- $end-class: $position-class-column-last
215
- );
216
- &#{'[#{ $attribute }*="rules-column-align: gutter"]'} {
217
- > #{ $select-item } {
218
- &#{ $select-rule-col } {
219
- top: $gutter;
220
- bottom: $gutter;
221
- }
222
- }
223
- @if $extra-gutter-scales {
224
- @each $scale, $amount in $extra-gutter-scales {
225
- &#{'[#{ $attribute }*="gutter-scale: #{ $scale }"]'} {
226
- > #{ $select-item } {
227
- &#{ $select-rule-col } {
228
- top: $gutter * $amount;
229
- bottom: $gutter * $amount;
230
- }
231
- }
232
- }
233
- }
234
- }
235
- }
236
- // Options for the left or right
237
- @include -create-rule-row-position(
238
- $position: "top",
239
- $size: $rule-size,
240
- $attribute: $attribute,
241
- $select-item: $select-item,
242
- $select-rule-row: $select-rule-row,
243
- $between: false
244
- );
245
- @include -create-rule-row-position(
246
- $position: "bottom",
247
- $size: $rule-size,
248
- $attribute: $attribute,
249
- $select-item: $select-item,
250
- $select-rule-row: $select-rule-row,
251
- $between: false
252
- );
253
-
254
- &#{'[#{ $attribute }*="rules-row: between"]'} {
255
- > #{ $select-item } {
256
- &#{ $select-rule-row } {
257
- bottom: math.floor(math.div($rule-size, 2)) * -1;
258
- }
259
- // For removing the rule per row (via equal heights for now)
260
- &.#{ $position-class-row-last } {
261
- &#{ $select-rule-row } {
262
- content: none;
263
- }
264
- }
265
- }
266
- }
267
- &#{'[#{ $attribute }*="rules-row-align: gutter"]'} {
268
- > #{ $select-item } {
269
- &#{ $select-rule-row } {
270
- @include breakpoint.min($breakpoint) {
271
- left: $gutter;
272
- right: $gutter;
273
- }
274
- }
275
- }
276
- @if $extra-gutter-scales {
277
- @each $scale, $amount in $extra-gutter-scales {
278
- &#{'[#{ $attribute }*="gutter-scale: #{ $scale }"]'} {
279
- > #{ $select-item } {
280
- &#{ $select-rule-row } {
281
- @include breakpoint.min($breakpoint) {
282
- left: $gutter * $amount;
283
- right: $gutter * $amount;
284
- }
285
- }
286
- }
287
- }
288
- }
289
- }
290
- }
291
- &#{'[#{ $attribute }*="rules-row-persist: true"]'},
292
- &#{'[#{ $attribute }*="rules-row-stacked-only: true"]'} {
293
- > #{ $select-item } {
294
- &#{ $select-rule-row } {
295
- content: '';
296
- }
297
- }
298
- }
299
- // IE for mobile/small (non grid / stacked)
300
- &#{'[#{ $attribute }*="rules-row-stacked-only: true"]'} {
301
- > #{ $select-item } {
302
- &#{ $select-rule-row } {
303
- @include breakpoint.min($breakpoint) {
304
- content: none !important;
305
- }
306
- }
307
- }
308
- }
309
- }
310
-
311
- @include breakpoint.min($breakpoint) {
312
-
313
- $select-gutter-false: '[#{ $attribute }*="gutters: false"]';
314
- $select-gutter-false-child: '#{ $select-container }:has(>#{ $select-gutter-false })';
315
-
316
- @if $include-container {
317
- #{ $select-container } {
318
- padding-left: $gutter;
319
- padding-right: $gutter;
320
- }
321
- #{ $select-gutter-false-child } {
322
- padding-left: 0;
323
- padding-right: 0;
324
- }
325
- @if $extra-gutter-scales and $container-gutter-scales {
326
- @each $scale, $amount in $extra-gutter-scales {
327
- #{'#{ $select-container }:has(>[#{ $attribute }*="gutter-scale: #{ $scale }"])'} {
328
- padding-left: ($gutter * $amount);
329
- padding-right: ($gutter * $amount);
330
- }
331
- }
332
- }
333
- }
334
- // Select the attribute with matching column count
335
- #{ $select-grid } {
336
- // Defaults for grid an item
337
- display: flex;
338
- flex-flow: row wrap;
339
- align-items: stretch;
340
- margin-left: -$gutter;
341
- margin-right: -$gutter;
342
-
343
- > #{ $select-item } {
344
- float: left; // Fallback
345
- padding-left: $gutter;
346
- padding-right: $gutter;
347
- }
348
-
349
- @if $extra-gutter-scales {
350
- @each $scale, $amount in $extra-gutter-scales {
351
- &#{'[#{ $attribute }*="gutter-scale: #{ $scale }"]'} {
352
- margin-left: -($gutter * $amount);
353
- margin-right: -($gutter * $amount);
354
-
355
- > #{ $select-item } {
356
- padding-left: $gutter * $amount;
357
- padding-right: $gutter * $amount;
358
- }
359
- }
360
- }
361
- }
362
-
363
- // Alignment options
364
- &#{'[#{ $attribute }*="justify: center"]'} {
365
- justify-content: center;
366
- }
367
- &#{'[#{ $attribute }*="justify: end"]'} {
368
- justify-content: flex-end;
369
- }
370
- &#{'[#{ $attribute }*="align: center"]'} {
371
- align-items: center;
372
- }
373
- &#{'[#{ $attribute }*="align: end"]'} {
374
- align-items: flex-end;
375
- }
376
- &#{'[#{ $attribute }*="align: start"]'} {
377
- align-items: flex-start;
378
- }
379
- // Alignment of the children when using stretch
380
- // - There is no stetch-start (that's defualt);
381
- // - There is no stetch-middle (that's covered by stretch-);
382
- &#{'[#{ $attribute }*="align: stretch-"]'} {
383
- // set the child to display as a single flex item
384
- > #{ $select-item } {
385
- display: flex;
386
- flex-direction: column;
387
- justify-content: center;
388
- }
389
- }
390
- &#{'[#{ $attribute }*="align: stretch-end"]'} {
391
- > #{ $select-item } {
392
- justify-content: flex-end;
393
- }
394
- }
395
- // Other options
396
- &#{ $select-gutter-false } {
397
- margin-left: 0;
398
- margin-right: 0;
399
- > #{ $select-item } {
400
- padding-left: 0;
401
- padding-right: 0;
402
- }
403
- }
404
- // Activate Rules
405
- &#{'[#{ $attribute }*="rules-column:"]'} {
406
- > #{ $select-item } {
407
- &#{ $select-rule-col } {
408
- content: '';
409
- }
410
- }
411
- }
412
- &#{'[#{ $attribute }*="rules-row:"]'} {
413
- > #{ $select-item } {
414
- &#{ $select-rule-row } {
415
- content: '';
416
- }
417
- }
418
- }
419
- // Override first or last column removing the rule using matching specificity
420
- &#{'[#{ $attribute }*="rules-column:"][#{ $attribute }*="rules-column-ends: true"]'} {
421
- > #{ $select-item } {
422
- &#{ $select-rule-col } {
423
- content: '';
424
- }
425
- }
426
- }
427
- // Generated props for item
428
- @include -create-column-widths(
429
- $columns: $columns,
430
- $attribute-item: $attribute-item,
431
- $suffix: ''
432
- );
433
- @include -create-column-offsets(
434
- $columns: $columns,
435
- $attribute-item: $attribute-item,
436
- $suffix: ''
437
- );
438
- }
439
- }
440
- @if $extra-breakpoints {
441
- @each $name, $options in $extra-breakpoints {
442
- $g: map.get($options, "gutter");
443
- @include -create-extra-breakpoint(
444
- $name: $name,
445
- $breakpoint: map.get($options, "breakpoint"),
446
- $gutter: if($g, $g, $gutter),
447
- $columns: $columns,
448
- $attribute: $attribute,
449
- $attribute-item: $attribute-item,
450
- $select-grid: $select-grid,
451
- $select-item: $select-item,
452
- $extra-gutter-scales: $extra-gutter-scales,
453
- $include-container: $include-container,
454
- $select-container: $select-container,
455
- $container-gutter-scales: $container-gutter-scales
456
- );
457
- }
458
- }
459
- @if $extra-rule-styles {
460
- @each $name, $options in $extra-rule-styles {
461
- $color: utils.require-map-get($options, "color", "grid [extra rule style]");
462
- $size: utils.require-map-get($options, "size", "grid [extra rule style]");
463
- #{ $select-grid } {
464
-
465
- &#{'[#{ $attribute }*="rules-column-style: #{ $name }"]'} {
466
- > #{ $select-item } {
467
- &#{ $select-rule-col } {
468
- background-color: color.get($color);
469
- width: $size;
470
- }
471
- }
472
- @include -create-rule-col-position(
473
- $position: "left",
474
- $size: $size,
475
- $attribute: $attribute,
476
- $select-item: $select-item,
477
- $select-rule-col: $select-rule-col,
478
- $end-class: false
479
- );
480
- @include -create-rule-col-position(
481
- $position: "right",
482
- $size: $size,
483
- $attribute: $attribute,
484
- $select-item: $select-item,
485
- $select-rule-col: $select-rule-col,
486
- $end-class: false
487
- );
488
- }
489
- &#{'[#{ $attribute }*="rules-row-style: #{ $name }"]'} {
490
- > #{ $select-item } {
491
- &#{ $select-rule-row } {
492
- background-color: $color;
493
- height: $size;
494
- }
495
- }
496
- @include -create-rule-row-position(
497
- $position: "top",
498
- $size: $size,
499
- $attribute: $attribute,
500
- $select-item: $select-item,
501
- $select-rule-row: $select-rule-row,
502
- $between: false
503
- );
504
- @include -create-rule-row-position(
505
- $position: "bottom",
506
- $size: $size,
507
- $attribute: $attribute,
508
- $select-item: $select-item,
509
- $select-rule-row: $select-rule-row,
510
- $between: false
511
- );
512
- @include -create-rule-row-position(
513
- $position: "bottom",
514
- $size: $size,
515
- $attribute: $attribute,
516
- $select-item: $select-item,
517
- $select-rule-row: $select-rule-row,
518
- $between: true
519
- );
520
- }
521
- }
522
- }
523
- }
524
- }
525
-
526
- @mixin -create-extra-breakpoint(
527
- $name,
528
- $breakpoint,
529
- $gutter,
530
- $columns,
531
- $attribute,
532
- $attribute-item,
533
- $select-grid,
534
- $select-item,
535
- $extra-gutter-scales,
536
- $include-container,
537
- $select-container,
538
- $container-gutter-scales
539
- ) {
540
- @include breakpoint.min($breakpoint) {
541
-
542
- @if $include-container {
543
- #{ $select-container } {
544
- padding-left: $gutter;
545
- padding-right: $gutter;
546
- }
547
- @if $extra-gutter-scales and $container-gutter-scales {
548
- @each $scale, $amount in $extra-gutter-scales {
549
- #{'#{ $select-container }:has(>[#{ $attribute }*="gutter-scale: #{ $scale }"])'} {
550
- padding-left: ($gutter * $amount);
551
- padding-right: ($gutter * $amount);
552
- }
553
- }
554
- }
555
- }
556
-
557
- #{ $select-grid } {
558
- margin-left: -$gutter;
559
- margin-right: -$gutter;
560
-
561
- > #{ $select-item } {
562
- padding-left: $gutter;
563
- padding-right: $gutter;
564
- }
565
-
566
- @if $extra-gutter-scales {
567
- @each $scale, $amount in $extra-gutter-scales {
568
- &#{'[#{ $attribute }*="gutter-scale: #{ $scale }"]'} {
569
- margin-left: -($gutter * $amount);
570
- margin-right: -($gutter * $amount);
571
- > #{ $select-item } {
572
- padding-left: $gutter * $amount;
573
- padding-right: $gutter * $amount;
574
- }
575
- }
576
- }
577
- }
578
-
579
- @include -create-column-widths(
580
- $columns: $columns,
581
- $attribute-item: $attribute-item,
582
- $suffix: "-#{ $name }"
583
- );
584
- @include -create-column-offsets(
585
- $columns: $columns,
586
- $attribute-item: $attribute-item,
587
- $suffix: "-#{ $name }"
588
- );
589
- }
590
- }
591
- }
592
-
593
- @mixin -create-column-widths(
594
- $columns,
595
- $attribute-item,
596
- $suffix: ''
597
- ) {
598
- $column-width: math.div(100%, $columns);
599
-
600
- @for $i from 1 through $columns {
601
- $width: $column-width * $i;
602
- & > #{'[#{ $attribute-item }*="width#{ $suffix }: #{ $i }"]'} {
603
- width: $width;
604
- flex-basis: $width;
605
- max-width: $width;
606
- }
607
- }
608
- }
609
-
610
- @mixin -create-column-offsets(
611
- $columns,
612
- $attribute-item,
613
- $suffix: ''
614
- ) {
615
- $column-width: math.div(100%, $columns);
616
-
617
- @for $i from 1 through $columns {
618
- & > #{'[#{ $attribute-item }*="offset#{ $suffix }: #{ $i }"]'} {
619
- margin-left: $column-width * $i;
620
- }
621
- }
622
- // For Zero (in case using breakpoints to remove)
623
- & > #{'[#{ $attribute-item }*="offset#{ $suffix }: 0"]'} {
624
- margin-left: 0;
625
- }
626
- }
627
-
628
- @mixin -create-rule-col-position(
629
- $position,
630
- $size,
631
- $attribute,
632
- $select-item,
633
- $select-rule-col,
634
- $end-class: false
635
- ) {
636
- &#{'[#{ $attribute }*="rules-column: #{ $position }"]'} {
637
- > #{ $select-item } {
638
- &#{ $select-rule-col } {
639
- #{$position}: math.floor(math.div($size, 2)) * -1;
640
- }
641
- // For removing the rule per row (via equal heights for now)
642
- @if $end-class {
643
- &.#{ $end-class } {
644
- &#{ $select-rule-col } {
645
- content: none;
646
- }
647
- }
648
- }
649
- }
650
- }
651
- }
652
-
653
- @mixin -create-rule-row-position(
654
- $position,
655
- $size,
656
- $attribute,
657
- $select-item,
658
- $select-rule-row,
659
- $between: false
660
- ) {
661
- $key: if($between, 'between', $position);
662
-
663
- &#{'[#{ $attribute }*="rules-row: #{ $key }"]'} {
664
- > #{ $select-item } {
665
- &#{ $select-rule-row } {
666
- content: $size;
667
- #{ $position }: math.floor(math.div($size, 2)) * -1;
668
- }
669
- }
670
- }
671
- }