@mlut/core 1.0.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 (84) hide show
  1. package/README.md +24 -0
  2. package/_index.scss +1 -0
  3. package/_tools.scss +1 -0
  4. package/dist/index.d.ts +2 -0
  5. package/dist/index.js +2 -0
  6. package/dist/jit/JitEngine.d.ts +19 -0
  7. package/dist/jit/JitEngine.js +124 -0
  8. package/dist/jit/index.d.ts +1 -0
  9. package/dist/jit/index.js +1 -0
  10. package/dist/sass/addons/demo-theme.scss +112 -0
  11. package/dist/sass/css/_base-setup.scss +3 -0
  12. package/dist/sass/css/_index.scss +2 -0
  13. package/dist/sass/css/helpers/_index.scss +3 -0
  14. package/dist/sass/css/helpers/btn.scss +28 -0
  15. package/dist/sass/css/helpers/gs-debug.scss +28 -0
  16. package/dist/sass/css/helpers/ratio-box.scss +47 -0
  17. package/dist/sass/css/helpers/row.scss +98 -0
  18. package/dist/sass/css/helpers/wrapper.scss +21 -0
  19. package/dist/sass/css/styles/_index.scss +2 -0
  20. package/dist/sass/css/styles/generic.scss +296 -0
  21. package/dist/sass/css/styles/variables.scss +32 -0
  22. package/dist/sass/css/utils/_bg-bd.scss +27 -0
  23. package/dist/sass/css/utils/_grid.scss +37 -0
  24. package/dist/sass/css/utils/_index.scss +2 -0
  25. package/dist/sass/css/utils/_load.scss +9 -0
  26. package/dist/sass/css/utils/_transition.scss +16 -0
  27. package/dist/sass/css/utils/box-alignment.scss +29 -0
  28. package/dist/sass/css/utils/box-model.scss +48 -0
  29. package/dist/sass/css/utils/grid-system.scss +17 -0
  30. package/dist/sass/css/utils/init.scss +107 -0
  31. package/dist/sass/css/utils/other.scss +35 -0
  32. package/dist/sass/css/utils/text.scss +33 -0
  33. package/dist/sass/css/utils/visual.scss +32 -0
  34. package/dist/sass/index.scss +4 -0
  35. package/dist/sass/tools/_index.scss +4 -0
  36. package/dist/sass/tools/functions/_index.import.scss +3 -0
  37. package/dist/sass/tools/functions/_index.scss +9 -0
  38. package/dist/sass/tools/functions/base/_error.scss +9 -0
  39. package/dist/sass/tools/functions/base/_getters.scss +124 -0
  40. package/dist/sass/tools/functions/base/_index.scss +11 -0
  41. package/dist/sass/tools/functions/base/_list.scss +56 -0
  42. package/dist/sass/tools/functions/base/_math.scss +149 -0
  43. package/dist/sass/tools/functions/base/_string.scss +300 -0
  44. package/dist/sass/tools/functions/common/_custom-units.scss +231 -0
  45. package/dist/sass/tools/functions/common/_forward-tools.scss +2 -0
  46. package/dist/sass/tools/functions/common/_helpers.scss +57 -0
  47. package/dist/sass/tools/functions/common/_index.scss +9 -0
  48. package/dist/sass/tools/functions/common/_utils.scss +211 -0
  49. package/dist/sass/tools/functions/high/_at-rules.scss +296 -0
  50. package/dist/sass/tools/functions/high/_forward-tools.scss +3 -0
  51. package/dist/sass/tools/functions/high/_index.scss +8 -0
  52. package/dist/sass/tools/functions/high/utils/_index.scss +288 -0
  53. package/dist/sass/tools/functions/high/utils/_parse-util.scss +107 -0
  54. package/dist/sass/tools/functions/high/utils/_range-generators.scss +355 -0
  55. package/dist/sass/tools/functions/high/utils/_util-apply-selector.scss +134 -0
  56. package/dist/sass/tools/functions/high/utils/_value-converters.scss +294 -0
  57. package/dist/sass/tools/functions/high/utils/_value-transformers.scss +65 -0
  58. package/dist/sass/tools/mixins/_index.import.scss +2 -0
  59. package/dist/sass/tools/mixins/_index.scss +8 -0
  60. package/dist/sass/tools/mixins/base/_forward-tools.scss +2 -0
  61. package/dist/sass/tools/mixins/base/_index.scss +93 -0
  62. package/dist/sass/tools/mixins/base/_mk-ar.scss +96 -0
  63. package/dist/sass/tools/mixins/base/_mk-state.scss +175 -0
  64. package/dist/sass/tools/mixins/high/_forward-tools.scss +3 -0
  65. package/dist/sass/tools/mixins/high/_index.scss +1 -0
  66. package/dist/sass/tools/mixins/high/utils/_index.scss +188 -0
  67. package/dist/sass/tools/mixins/high/utils/_mk-util.scss +366 -0
  68. package/dist/sass/tools/settings/_index.import.scss +3 -0
  69. package/dist/sass/tools/settings/_index.scss +3 -0
  70. package/dist/sass/tools/settings/base/_general.scss +175 -0
  71. package/dist/sass/tools/settings/base/_index.scss +2 -0
  72. package/dist/sass/tools/settings/base/_utils.scss +578 -0
  73. package/dist/sass/tools/settings/common/_at-rules.scss +213 -0
  74. package/dist/sass/tools/settings/common/_index.scss +2 -0
  75. package/dist/sass/tools/settings/common/_utils.scss +1926 -0
  76. package/dist/sass/tools/settings/high/_forward-tools.scss +2 -0
  77. package/dist/sass/tools/settings/high/_grid.scss +55 -0
  78. package/dist/sass/tools/settings/high/_index.scss +2 -0
  79. package/dist/sass/tools/settings/high/_utils.scss +104 -0
  80. package/dist/utils/index.d.ts +1 -0
  81. package/dist/utils/index.js +1 -0
  82. package/dist/utils/logger.d.ts +7 -0
  83. package/dist/utils/logger.js +13 -0
  84. package/package.json +48 -0
@@ -0,0 +1,2 @@
1
+ @forward '../base';
2
+ @forward '../common';
@@ -0,0 +1,55 @@
1
+ @use 'sass:map';
2
+ @use 'sass:list';
3
+ @use 'forward-tools' as ml;
4
+
5
+ // Grid system
6
+ //
7
+ // Settings that affect the work of grid system both modern and legacy.
8
+ //
9
+ // - **modern** grid is based on [CSS Grid](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Grid_Layout) and is built using common grid utilities, such as [Gtc](section-utils-reference.html#kssref-utils-reference-gtc), [Gap](section-utils-reference.html#kssref-utils-reference-gap) etc
10
+ // - **legacy** grid system is based on flexbox and works with [helpers](section-css_lib.html#kssref-css_lib-helpers-row) and custom utilities, such as [-Gscc](section-utils-reference.html#kssref-utils-reference--gscc), [-Gsf](section-utils-reference.html#kssref-utils-reference--gsf) etc.
11
+ //
12
+ // $legacy-grid-system = false - enable legacy grid system and generate some CSS for it
13
+ // $gs-default-gtr = 4u - default gutter on large width screen. Used as fallback for `--ml-gg`.
14
+ // $gs-columns = 12 - columns count.
15
+ // $gs-gutters - map with grid gutters on breakpoints.
16
+ //
17
+ // Styleguide: settings.gs
18
+
19
+ // Gutters
20
+ //
21
+ // The gutters are stored in `$gs-gutters` map. The keys in it are the names of the breakpoints, and the values are gutter. It is automatically filled out based on breakpoints. If you want to supplement or change gutters, use `$gs-gutters-ext`. If you want to completely overwrite the initial values, specify them in `$gs-gutters` in the config. Pay attention that this behavior is different from all other settings like a [breakpoints](section-settings.html#kssref-settings-at_rules-breakpoints)
22
+ //
23
+ // Gutters value on breakpoints:
24
+ //
25
+ // Breakpoint | Gutter
26
+ // :---: | :---:
27
+ // <sm | 3u
28
+ // sm | 3u
29
+ // md | 3u
30
+ // lg | 4u
31
+ // xl | 4u
32
+ // xxl | 4u
33
+ //
34
+ // Styleguide: settings.gs.gtr
35
+
36
+ $legacy-grid-system: false !default;
37
+ $gs-columns: 12 !default;
38
+ $gs-default-gtr: (ml.$su * 4) !default;
39
+ $gs-gutters: () !default;
40
+ $gs-gutters-ext: () !default;
41
+ $gtr-first: (ml.$su * 3);
42
+
43
+ $gs-debug-col-color: #d15 !default;
44
+ $gs-debug-gtr-color: #336 !default;
45
+
46
+ @if $gs-gutters == () {
47
+ @each $bp, $gtr in list.zip(
48
+ ml.$bp-keys, ($gtr-first, $gtr-first, $gs-default-gtr, $gs-default-gtr)
49
+ ) {
50
+ $gs-gutters: map.set($gs-gutters, $bp, $gtr);
51
+ }
52
+ }
53
+
54
+ $gs-gutters: map.merge($gs-gutters, $gs-gutters-ext);
55
+ $gtr-first: list.nth(list.nth($gs-gutters, 1), 2);
@@ -0,0 +1,2 @@
1
+ @forward 'grid';
2
+ @forward 'utils';
@@ -0,0 +1,104 @@
1
+ @use 'sass:map';
2
+ @use 'forward-tools' as ml;
3
+
4
+ $utils-groups: () !default;
5
+ $utils-groups-ext: () !default;
6
+
7
+ $utils-groups-db: (
8
+ 'Borders': (
9
+ 'members': (
10
+ Bd, Bdt, Bdr, '#{ml.$cArStBp}Bdb_-btc', '#{ml.$cArStBp}Bdl_-btc', -Bdx, -Bdy,
11
+ ),
12
+ ),
13
+ 'BdWidth': (
14
+ 'members': (
15
+ Bdw, Bdtw, Bdrw, '#{ml.$cArStBp}Bdbw_-btc', '#{ml.$cArStBp}Bdlw_-btc', -Bdxw, -Bdyw,
16
+ ),
17
+ ),
18
+ 'BdStyle': (
19
+ 'members': (
20
+ Bds, Bdts, Bdrs, '#{ml.$cArStBp}Bdbs_-btc', '#{ml.$cArStBp}Bdls_-btc', -Bdxs, -Bdys,
21
+ ),
22
+ ),
23
+ 'BdSidesColor': (
24
+ 'members': (
25
+ Bdtc, Bdrc, '#{ml.$cArStBp}Bdbc_-btc', '#{ml.$cArStBp}Bdlc_-btc', -Bdxc, -Bdyc,
26
+ ),
27
+ ),
28
+ 'BdRadius': (
29
+ 'members': (
30
+ Bdrd, Bdtrr, Bdtlr, Bdbrr, Bdblr, -Bdtrd, -Bdbrd,
31
+ ),
32
+ ),
33
+ 'Overflows': (
34
+ 'members': (
35
+ Ov, Ovx, Ovy,
36
+ ),
37
+ ),
38
+ 'Margins': (
39
+ 'members': (
40
+ M, Mt, Mr, '#{ml.$cArStBp}Mb_-btc', '#{ml.$cArStBp}Ml_-btc', -Mx, -My,
41
+ ),
42
+ ),
43
+ 'MarginsNoR': (
44
+ 'members': (
45
+ M, Mt, '#{ml.$cArStBp}Mb_-btc', '#{ml.$cArStBp}Ml_-btc', -Mx, -My,
46
+ ),
47
+ ),
48
+ 'Paddings': (
49
+ 'members': (
50
+ P, Pt, Pr, Pb, Pl, -Px, -Py,
51
+ ),
52
+ ),
53
+ 'Spaces': (
54
+ 'members': (
55
+ M, Mt, Mr, '#{ml.$cArStBp}Mb_-btc', '#{ml.$cArStBp}Ml_-btc', -Mx, -My,
56
+ P, Pt, Pr, Pb, Pl, -Px, -Py,
57
+ -I, -X, -Y, T, R, B, L,
58
+ W, H, Gap, Clmg, Rwg
59
+ ),
60
+ ),
61
+ 'Offsets': (
62
+ 'members': (
63
+ -I, -X, -Y, T, R, B, L,
64
+ ),
65
+ ),
66
+ 'Colors': (
67
+ 'members': (
68
+ C, Bgc, Bdc,
69
+ ),
70
+ ),
71
+ 'ColorsExt': (
72
+ 'members': (
73
+ C, Bgc, Bdc, Olc, Txdc
74
+ ),
75
+ ),
76
+ 'Translates': (
77
+ 'members': (
78
+ -Tr, -Trx, -Try,
79
+ ),
80
+ ),
81
+ 'AllGaps': (
82
+ 'members': (
83
+ Gap, Clmg, Rwg,
84
+ ),
85
+ ),
86
+ 'Sizes': (
87
+ 'members': (
88
+ W, H, Mxw, Mnh,
89
+ ),
90
+ ),
91
+ 'Overscrolls': (
92
+ 'members': (
93
+ Ovsb, Ovsbx, Ovsby
94
+ ),
95
+ ),
96
+ 'Periods': (
97
+ 'members': (
98
+ Tsd, Tsdl, And, Andl,
99
+ ),
100
+ ),
101
+ ) !default;
102
+
103
+ $utils-groups-db: map.deep-merge($utils-groups-db, $utils-groups);
104
+ $utils-groups-db: map.deep-merge($utils-groups-db, $utils-groups-ext);
@@ -0,0 +1 @@
1
+ export * from './logger.js';
@@ -0,0 +1 @@
1
+ export * from './logger.js';
@@ -0,0 +1,7 @@
1
+ export declare class Logger {
2
+ private readonly sign;
3
+ info(message: unknown, ...args: unknown[]): void;
4
+ warn(message: unknown, ...args: unknown[]): void;
5
+ error(message: unknown, ...args: unknown[]): void;
6
+ }
7
+ export declare const logger: Logger;
@@ -0,0 +1,13 @@
1
+ export class Logger {
2
+ sign = '[mlut]';
3
+ info(message, ...args) {
4
+ console.log(this.sign, message, ...args);
5
+ }
6
+ warn(message, ...args) {
7
+ console.warn(this.sign, message, ...args);
8
+ }
9
+ error(message, ...args) {
10
+ console.error(this.sign, message, ...args);
11
+ }
12
+ }
13
+ export const logger = new Logger();
package/package.json ADDED
@@ -0,0 +1,48 @@
1
+ {
2
+ "name": "@mlut/core",
3
+ "version": "1.0.0",
4
+ "description": "Atomic CSS toolkit with Sass and ergonomics for creating styles of any complexity",
5
+ "author": "mr150",
6
+ "type": "module",
7
+ "license": "MIT",
8
+ "homepage": "https://mr150.github.io/mlut/",
9
+ "types": "dist/index.d.ts",
10
+ "keywords": [
11
+ "mlut",
12
+ "sass",
13
+ "scss",
14
+ "css",
15
+ "atomic css",
16
+ "functional css",
17
+ "utility-first",
18
+ "framework",
19
+ "toolkit"
20
+ ],
21
+ "repository": {
22
+ "type": "git",
23
+ "directory": "packages/core",
24
+ "url": "https://github.com/mr150/mlut.git"
25
+ },
26
+ "bugs": {
27
+ "url": "https://github.com/mr150/mlut/issues"
28
+ },
29
+ "exports": {
30
+ ".": {
31
+ "default": "./dist/index.js"
32
+ }
33
+ },
34
+ "scripts": {
35
+ "build": "rm -rf dist && tsc && cp src/sass dist/ -r"
36
+ },
37
+ "files": [
38
+ "_index.scss",
39
+ "_tools.scss",
40
+ "dist"
41
+ ],
42
+ "devDependencies": {
43
+ "@types/node": "^20.10.5",
44
+ "sass-embedded": "^1.71.0",
45
+ "sass": "^1.71.0",
46
+ "typescript": "^5.3.3"
47
+ }
48
+ }