lism-css 0.0.11 → 0.0.13

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 (80) hide show
  1. package/dist/components/Accordion/getProps.js +5 -5
  2. package/dist/components/Accordion/setAccordion.js +6 -6
  3. package/dist/components/Accordion/style.css +1 -1
  4. package/dist/components/Columns/getProps.js +3 -3
  5. package/dist/components/Layer/getProps.js +3 -3
  6. package/dist/components/Modal/getProps.js +5 -5
  7. package/dist/components/Modal/style.css +1 -1
  8. package/dist/components/Tabs/Tab.js +1 -1
  9. package/dist/components/Tabs/TabList.js +1 -1
  10. package/dist/components/Tabs/TabPanel.js +1 -10
  11. package/dist/components/Tabs/style.css +1 -1
  12. package/dist/components/WithSide/getProps.js +1 -1
  13. package/dist/components/getFilterProps.js +7 -7
  14. package/dist/components/getInsetProps.js +4 -4
  15. package/dist/components/getMediaProps.js +4 -11
  16. package/dist/components/getTransformProps.js +4 -4
  17. package/dist/config/prop_list.js +68 -86
  18. package/dist/config/tokens.js +8 -7
  19. package/dist/css/base.css +1 -1
  20. package/dist/css/dynamic.css +1 -1
  21. package/dist/css/layout.css +1 -1
  22. package/dist/css/main.css +1 -0
  23. package/dist/css/main_legacy.css +1 -0
  24. package/dist/css/props.css +1612 -1
  25. package/dist/css/reset.css +1 -1
  26. package/dist/css/state.css +1 -1
  27. package/dist/css/utility.css +1 -1
  28. package/dist/lib/getLismProps.js +87 -76
  29. package/dist/lib/getMaybeCssVar.js +5 -5
  30. package/package.json +2 -3
  31. package/packages/astro/Tabs/Tab.astro +1 -1
  32. package/packages/astro/Tabs/TabList.astro +1 -1
  33. package/packages/astro/Tabs/TabPanel.astro +1 -7
  34. package/packages/types/index.d.ts +4 -8
  35. package/src/scss/__memo/_lh-auto-all.scss +9 -11
  36. package/src/scss/__memo/_lh-auto-h.scss +4 -4
  37. package/src/scss/_auto_output.scss +17 -5
  38. package/src/scss/_props.scss +156 -128
  39. package/src/scss/_setting.scss +2 -2
  40. package/src/scss/base/_dom.scss +27 -40
  41. package/src/scss/base/_property.scss +43 -0
  42. package/src/scss/base/_tokens.scss +128 -160
  43. package/src/scss/base/index.scss +18 -47
  44. package/src/scss/layout/_columns.scss +4 -4
  45. package/src/scss/layout/_divider.scss +1 -1
  46. package/src/scss/layout/_flex.scss +1 -4
  47. package/src/scss/layout/_grid.scss +1 -7
  48. package/src/scss/layout/_withSide.scss +4 -4
  49. package/src/scss/{all.scss → main.scss} +0 -4
  50. package/src/scss/{all_no_layer.scss → main_legacy.scss} +6 -1
  51. package/src/scss/props/_border.scss +2 -2
  52. package/src/scss/props/_color.scss +7 -16
  53. package/src/scss/props/_hover.scss +10 -19
  54. package/src/scss/props/_transition.scss +3 -3
  55. package/src/scss/props/index.scss +2 -1
  56. package/src/scss/state/_container.scss +13 -9
  57. package/src/scss/state/_flow.scss +24 -25
  58. package/src/scss/state/_size.scss +3 -20
  59. package/src/scss/utility/_colbox.scss +5 -13
  60. package/src/scss/utility/index.scss +7 -0
  61. package/dist/css/all.css +0 -1
  62. package/dist/css/all_no_layer.css +0 -1
  63. package/dist/css/with_layer.css +0 -1
  64. package/src/scss/layout/__switcher.scss +0 -11
  65. package/src/scss/props/__/__aspect.bkup.scss +0 -36
  66. package/src/scss/props/__/__border.bkup.scss +0 -197
  67. package/src/scss/props/__/__color.bkup.scss +0 -67
  68. package/src/scss/props/__/__display.bukup.scss +0 -11
  69. package/src/scss/props/__/__flex-props.bkup.scss +0 -66
  70. package/src/scss/props/__/__gap.bkup.scss +0 -18
  71. package/src/scss/props/__/__grid-props.bkup.scss +0 -158
  72. package/src/scss/props/__/__margin.bkup.scss +0 -92
  73. package/src/scss/props/__/__padding.bkup.scss +0 -93
  74. package/src/scss/props/__/__place.bkup.scss +0 -74
  75. package/src/scss/props/__/__radius.bkup.scss +0 -27
  76. package/src/scss/props/__/__sizing.bkup.scss +0 -45
  77. package/src/scss/props/__/__typography.bkup.scss +0 -146
  78. package/src/scss/state/__container.bkup.scss +0 -143
  79. package/src/scss/state/__flow.bkup.scss +0 -52
  80. /package/src/scss/{with_layer.scss → _with_layer.scss} +0 -0
@@ -1,93 +0,0 @@
1
- // @use '../query' as query;
2
- @use '../setting' as setting;
3
-
4
- /* stylelint-disable */
5
-
6
- // 優先度が 全方向 < x,y < 個別方向 になるように注意。
7
-
8
- .-p\:box { --p: var(--p--box);}
9
- .-p\:box\:s { --p: var(--p--box--s);}
10
- .-p\:box\:l { --p: var(--p--box--l);}
11
-
12
- // utilあり
13
- [class*="-p:"] {
14
- padding: var(--p) !important;
15
- }
16
- [class*="-px:"] {
17
- padding-inline: var(--px) !important;
18
- }
19
- [class*="-py:"] {
20
- padding-block: var(--py) !important;
21
- }
22
-
23
- .-pt\: { padding-top: var(--pt) !important;}
24
- .-pb\: { padding-bottom: var(--pb) !important;}
25
- .-pl\: { padding-left: var(--pl) !important;}
26
- .-pr\: { padding-right: var(--pr) !important;}
27
- .-pis\: { padding-inline-start: var(--pis) !important;}
28
- .-pbs\: { padding-block-start: var(--pbs) !important;}
29
- // .-pe\: { padding-inline-end: var(--pe) !important;}
30
- // .-pbe\: { padding-block-end: var(--pbe) !important;}
31
-
32
- // 0 は全てで用意しておく
33
- .-p\:0 {--p: 0}
34
- .-px\:0 {--px: 0}
35
- .-py\:0 {--py: 0}
36
- .-pt\:0 { padding-top: 0 !important;}
37
- .-pb\:0 { padding-bottom: 0 !important;}
38
- .-pl\:0 { padding-left: 0 !important;}
39
- .-pr\:0 { padding-right: 0 !important;}
40
- .-pis\:0 { padding-inline-start: 0 !important;}
41
- .-pbs\:0 { padding-block-start: 0 !important;}
42
-
43
- @each $s in setting.$util_spaces {
44
- .-p\:#{$s} {--p: var(--s--#{$s});}
45
- .-px\:#{$s} {--px: var(--s--#{$s});}
46
- .-py\:#{$s} {--py: var(--s--#{$s});}
47
- // .-pl\:#{$s} {--pl: var(--s--#{$s});}
48
- // .-pr\:#{$s} {--pr: var(--s--#{$s});}
49
- // .-pt\:#{$s} {--pt: var(--s--#{$s});}
50
- // .-pb\:#{$s} {--pb: var(--s--#{$s});}
51
- }
52
- @each $em in setting.$util_em_tokens {
53
- .-p\:em#{$em} {--p: var(--em--#{$em});}
54
- .-px\:em#{$em} {--px: var(--em--#{$em});}
55
- .-py\:em#{$em} {--py: var(--em--#{$em});}
56
- }
57
-
58
-
59
- // @include query.bp-up('sm'){
60
- // .-p\@sm { padding: var(--p--sm) !important;}
61
- // .-px\@sm { padding-inline: var(--px--sm) !important;}
62
- // .-py\@sm { padding-block: var(--py--sm) !important;}
63
- // // .-pt\@sm { padding-top: var(--pt--sm) !important;}
64
- // // .-pr\@sm { padding-right: var(--pr--sm) !important;}
65
- // // .-pb\@sm { padding-bottom: var(--pb--sm) !important;}
66
- // // .-pl\@sm { padding-left: var(--pl--sm) !important;}
67
- // .-pis\@sm { padding-inline-start: var(--pis--sm) !important;}
68
- // .-pbs\@sm { padding-block-start: var(--pbs--sm) !important;}
69
- // }
70
-
71
- // @include query.bp-up('md'){
72
- // .-p\@md { padding: var(--p--md) !important;}
73
- // .-px\@md { padding-inline: var(--px--md) !important;}
74
- // .-py\@md { padding-block: var(--py--md) !important;}
75
- // // .-pt\@md { padding-top: var(--pt--md) !important;}
76
- // // .-pr\@md { padding-right: var(--pr--md) !important;}
77
- // // .-pb\@md { padding-bottom: var(--pb--md) !important;}
78
- // // .-pl\@md { padding-left: var(--pl--md) !important;}
79
- // .-pis\@md { padding-inline-start: var(--pis--md) !important;}
80
- // .-pbs\@md { padding-block-start: var(--pbs--md) !important;}
81
- // }
82
-
83
- // @include query.bp-up('lg'){
84
- // .-p\@lg { padding: var(--p--lg) !important;}
85
- // .-px\@lg { padding-inline: var(--px--lg) !important;}
86
- // .-py\@lg { padding-block: var(--py--lg) !important;}
87
- // // .-pt\@lg { padding-top: var(--pt--lg) !important;}
88
- // // .-pr\@lg { padding-right: var(--pr--lg) !important;}
89
- // // .-pb\@lg { padding-bottom: var(--pb--lg) !important;}
90
- // // .-pl\@lg { padding-left: var(--pl--lg) !important;}
91
- // .-pis\@lg { padding-inline-start: var(--pis--lg) !important;}
92
- // .-pbs\@lg { padding-block-start: var(--pbs--lg) !important;}
93
- // }
@@ -1,74 +0,0 @@
1
-
2
- /* stylelint-disable */
3
- // .-pi\:c{place-items: center;}
4
- // .-pi\:s{place-items: start;}
5
- // .-pi\:e{place-items: end;}
6
- // .-pc\:c{place-content: center;}
7
- // .-pc\:s{place-content: start;}
8
- // .-pc\:e{place-content: end;}
9
- // .-ps\:c{place-content: center;}
10
- // .-ps\:s{place-content: start;}
11
- // .-ps\:e{place-content: end;}
12
-
13
-
14
- // align-items
15
- // .-ai\:{align-items: var(--ai);}
16
- .-ai\:c{align-items: center;}
17
- .-ai\:s{align-items: start;}
18
- .-ai\:e{align-items: end;}
19
- .-ai\:fs{align-items: flex-start;}
20
- .-ai\:fe{align-items: flex-end;}
21
- .-ai\:str{align-items: stretch;}
22
-
23
- // justify-items
24
- // .-ji\:{justify-items: var(--ji);}
25
- .-ji\:c{justify-items: center;}
26
- .-ji\:s{justify-items: start;}
27
- .-ji\:e{justify-items: end;}
28
- .-ji\:fs{justify-items: flex-start;}
29
- .-ji\:fe{justify-items: flex-end;}
30
- .-ji\:str{justify-items: stretch;}
31
-
32
-
33
- // justify-content
34
- // .-jc\:{justify-content: var(--jc);}
35
- .-jc\:c{justify-content: center;}
36
- .-jc\:s{justify-content: start;}
37
- .-jc\:e{justify-content: end;}
38
- .-jc\:fs{justify-content: flex-start;}
39
- .-jc\:fe{justify-content: flex-end;}
40
- .-jc\:sb{justify-content: space-between;}
41
-
42
- // align-content
43
- // .-ac\:{align-content: var(--ac);}
44
- .-ac\:c{align-content: center;}
45
- .-ac\:s{align-content: start;}
46
- .-ac\:e{align-content: end;}
47
- .-ac\:fs{align-content: flex-start;}
48
- .-ac\:fe{align-content: flex-end;}
49
- .-ac\:sb{align-content: space-between;}
50
-
51
-
52
- // self系
53
- .-aslf\:c{align-self: center;}
54
- .-aslf\:s{align-self: start;}
55
- .-aslf\:e{align-self: end;}
56
- .-aslf\:fs{align-self: flex-start;}
57
- .-aslf\:fe{align-self: flex-end;}
58
- // self-start, self-end ?
59
-
60
- .-jslf\:c{justify-self: center;}
61
- .-jslf\:s{justify-self: start;}
62
- .-jslf\:e{justify-self: end;}
63
- .-jslf\:fs{justify-self: flex-start;}
64
- .-jslf\:fe{justify-self: flex-end;}
65
-
66
- // rtl言語でも左右を反転させない時に使える
67
- // .-ji\:l{justify-items: left;}
68
- // .-ji\:r{justify-items: right;}
69
- // .-jc\:l{justify-content: left;}
70
- // .-jc\:r{justify-content: right;}
71
-
72
- // ↓ ml:a , mr:a で左右よせはできる
73
- // .-js\:l{justify-self: left;}
74
- // .-js\:r{justify-self: right;}
@@ -1,27 +0,0 @@
1
- /* stylelint-disable */
2
-
3
-
4
- // bdrs は変数管理した方が便利
5
- [class*="-bdrs:"]{
6
- border-radius: var(--bdrs);
7
- }
8
- .-bdrs\:0{--bdrs: 0;}
9
- // .-bdrs\:1{--bdrs: 1px;}
10
- .-bdrs\:xs{--bdrs: var(--radius--xs)}
11
- .-bdrs\:s{--bdrs: var(--radius--s)}
12
- .-bdrs\:m{--bdrs: var(--radius--m)}
13
- .-bdrs\:l{--bdrs: var(--radius--l)}
14
- .-bdrs\:xl{--bdrs: var(--radius--xl)}
15
- .-bdrs\:full{--bdrs: var(--radius--full)}
16
-
17
- // .-bdrs\:l→ leftと勘違いしていまいそう。(bdrsは left 単体はないよ)
18
-
19
- // .-bdtlrs\:0 {border-top-left-radius: 0;}
20
- // .-bdtrrs\:0 {border-top-right-radius: 0;}
21
- // .-bdbrrs\:0 {border-bottom-right-radius: 0;}
22
- // .-bdblrs\:0 {border-bottom-left-radius: 0;}
23
-
24
- .-bdssrs\:0 {border-start-start-radius: 0;}
25
- .-bdsers\:0 {border-start-end-radius: 0;}
26
- .-bdeers\:0 {border-end-end-radius: 0;}
27
- .-bdesrs\:0 {border-end-start-radius: 0;}
@@ -1,45 +0,0 @@
1
- // @use '../query' as query;
2
- /* stylelint-disable */
3
-
4
- // [class*="-xxx:"] を使うと ユーティリティに important 不要になる
5
-
6
- // .-w\:,
7
- .-w\: { width: var(--w) }
8
- .-w\:fit { width: fit-content}
9
- .-w\:100 { width: 100% }
10
- // .-w\:75 { width: 75% }
11
- // .-w\:50 { width: 50% }
12
- // .-w\:25 { width: 25% }
13
-
14
- // .-h\:,
15
- .-h\: { height: var(--h) }
16
- .-h\:100 { height: 100% }
17
- .-h\:fit { height: fit-content }
18
- // .-h\:un { height: unset}
19
- .-h\:screen { height: 100vh; height: 100dvh; }
20
- // .-h\:screen { height: calc(100vw - var(--sbar)) }
21
-
22
-
23
- // max-is, max-w, max-h ?
24
- .-maxW\: { max-width: var(--maxW) }
25
- .-maxW\:100 {max-width: 100%;}
26
- // .-maxW\:un {max-width: unset;}
27
-
28
- .-maxH\: { max-height: var(--maxH) }
29
- .-maxH\:100 {max-height: 100%;}
30
- // .-maxH\:un {max-height: unset;}
31
-
32
- // min
33
- .-minW\: { min-width: var(--minW) }
34
- .-minW\:100 {min-width: 100%;}
35
-
36
- .-minH\: { min-height: var(--minH) }
37
- .-minH\:100 {min-height: 100%;}
38
-
39
- // .-minW\:un {min-width: unset;}
40
- // .-minH\:un {min-height: unset;}
41
-
42
- // コンテンツサイズ用
43
- // .-maxIs\:s{ max-inline-size: var(--size--s) }
44
- // .-maxIs\:m{ max-inline-size: var(--size--m) }
45
-
@@ -1,146 +0,0 @@
1
- /* stylelint-disable */
2
-
3
- // [class*="-lh:"]{
4
- // line-height: var(--lh);
5
- // }
6
-
7
- /* ------------------------------------------------------------
8
- font
9
- ------------------------------------------------------------ */
10
- .-f\:i{font: inherit;}
11
-
12
- /* ------------------------------------------------------------
13
- font-size
14
- ------------------------------------------------------------ */
15
-
16
- // .-fz\:
17
- [class*='-fz:'] { font-size: var(--fz) !important}
18
-
19
- .-fz\:r { font-size: 1rem }
20
- .-fz\:2xs { --fz: var(--fz--2xs) }
21
- .-fz\:xs { --fz: var(--fz--xs) }
22
- .-fz\:s { --fz: var(--fz--s) }
23
- .-fz\:m { --fz: var(--fz--m) }
24
- .-fz\:l { --fz: var(--fz--l) }
25
- .-fz\:xl { --fz: var(--fz--xl) }
26
- .-fz\:2xl { --fz: var(--fz--2xl) }
27
- .-fz\:3xl { --fz: var(--fz--3xl) }
28
- .-fz\:4xl { --fz: var(--fz--4xl) }
29
- .-fz\:5xl { --fz: var(--fz--5xl) }
30
-
31
- // 流体サイズ ?
32
- // .-fz\:fluid {
33
- // --fz: var(--fz-fluid);
34
- // }
35
-
36
- // .-fz\:fluid\:s {
37
- // --fz: var(--fz-fluid--s);
38
- // }
39
- // .-fz\:fluid\:l {
40
- // --fz: var(--fz-fluid--l);
41
- // }
42
-
43
-
44
- /* ------------------------------------------------------------
45
- line-height
46
- ------------------------------------------------------------ */
47
-
48
- // line-height
49
-
50
- // [class*='-lh:'] { line-height: var(--lh) }
51
- .-lh\:1 { line-height: 1 }
52
- .-lh\:root { line-height: var(--lh--root) }
53
- .-lh\:xs { line-height: var(--lh--xs) }
54
- .-lh\:s { line-height: var(--lh--s) }
55
- .-lh\:l { line-height: var(--lh--l) }
56
- .-lh\:xl { line-height: var(--lh--xl) }
57
-
58
-
59
- /* ------------------------------------------------------------
60
- font-family
61
- ------------------------------------------------------------ */
62
-
63
- .-ff\:sans {font-family: var(--ff--sans)}
64
- .-ff\:serif {font-family: var(--ff--serif)}
65
- .-ff\:mono {font-family: var(--ff--mono)}
66
- .-ff\:emoji {font-family: var(--ff--emoji)}
67
-
68
- /* ------------------------------------------------------------
69
- letter-spacing
70
- ------------------------------------------------------------ */
71
- // [class*='-lts:'] {
72
- // letter-spacing: var(--lts);
73
- // }
74
- .-lts\:root {letter-spacing: var(--lts--root)}
75
- .-lts\:s {letter-spacing: var(--lts--s)}
76
- .-lts\:l {letter-spacing: var(--lts--l)}
77
- .-lts\:xl {letter-spacing: var(--lts--xl)}
78
-
79
- // .-lts\:-2 {letter-spacing: var(--lts---2);}
80
- // .-lts\:-1 {letter-spacing: var(--lts---1);}
81
- // .-lts\:0 {letter-spacing: 0;}
82
- // .-lts\:1 {letter-spacing: var(--lts--1);}
83
- // .-lts\:2 {letter-spacing: var(--lts--2);}
84
- // .-lts\:3 {letter-spacing: var(--lts--3);}
85
- // .-lts\:4 {letter-spacing: var(--lts--4);}
86
- // .-lts\:5 {letter-spacing: var(--lts--5);}
87
- // .-lts\:6 {letter-spacing: var(--lts--6);}
88
-
89
-
90
- // text-align
91
- .-ta\:c{text-align: center;}
92
- .-ta\:r{text-align: right;}
93
- .-ta\:l{text-align: left;}
94
-
95
- // font-weight
96
- .-fw\:bold{font-weight: var(--fw--bold);}
97
- .-fw\:thin{font-weight: var(--fw--thin);}
98
-
99
- // .-fw\:100{font-weight: 100;}
100
- // .-fw\:300{font-weight: 300;}
101
- // .-fw\:400{font-weight: 400;}
102
- // .-fw\:500{font-weight: 500;}
103
- // .-fw\:700{font-weight: 700;}
104
- // .-fw\:900{font-weight: 900;}
105
-
106
- .-fs\:n{font-style: normal;}
107
- .-fs\:i{font-style: italic;}
108
-
109
-
110
-
111
-
112
- // ---------------------------------------------------------------------
113
- // lh 自動計算
114
- // ---------------------------------------------------------------------
115
-
116
- // @layer lism-init {
117
- // // :where(:is(h1, h2, h3, h4, h5, h6, p)) {
118
- // // font-size: var(--fz, inherit);
119
- // // line-height: var(--lh, inherit);
120
- // // }
121
-
122
- // :root {
123
- // --lh--min: 1.25em;
124
- // --lh--max: 1.75em;
125
- // --lh--slope: 0.3; // 自動計算用の傾き
126
- // }
127
-
128
- // :is(h1, h2, h3, h4, h5, h6),
129
- // [class*='-fz\:'] {
130
- // --base: calc(var(--lh--base) * 1em); // 計算ように単位をつけておく
131
-
132
- // // 計算結果
133
- // --calced: calc((var(--slope) * 1em) + var(--base) - (var(--lh--slope) * var(--fz)));
134
-
135
- // // 上限値を var(--base) にすることで、フォントサイズが大きい場合にのみ計算を適用することも可能
136
- // line-height: clamp(var(--lh--min), var(--calced), var(--lh--max));
137
- // }
138
- // }
139
-
140
- // 1.75em - fz*slope + slope*1em
141
- // slop .4, fz 2em → 1.75em - .4*2em + .4*1em → 1.15em
142
- // slop .35, fz 2em → 1.75em - .35*2em + .35*1em → 1.2em
143
- // slop .3, fz 2em → 1.75em - .3*2em + .3*1em → 1.25em
144
- // slop .3, fz 1.5em → 1.75em - .3*1.5em + .3*1em → 1.3em
145
- // slop .3, fz 2em → 1.5em - .3*2em + .3*1em → 1.1em
146
- // slop .2, fz 2em → 1.5em - .2*2em + .2*1em → 1.2em
@@ -1,143 +0,0 @@
1
- // 内部のコンテンツ幅を制御する。
2
- // .l--container {
3
- // container-type: inline-size;
4
- // margin-inline: auto;
5
- // inline-size: 100%; // gridやflex内での挙動を考慮。(container-type:inline-sizeだと横幅つぶれる)
6
- // }
7
-
8
- // -container:fit
9
-
10
- // l--container--constrained
11
- // それぞれの直下要素( > * ) に対してスタイルをセットした方が、ネスト時の影響をなくせるが、constrainedのネストが多様されることは少ないと思うので、一旦親側の変数管理のみで実装。
12
- .is--container {
13
- container-type: inline-size;
14
- margin-inline: auto;
15
- inline-size: 100%; // gridやflex内での挙動を考慮。(container-type:inline-sizeだと横幅つぶれる)
16
- }
17
-
18
- // l--container[data-content-size='']
19
-
20
- [class*='is--container:'] {
21
- container-type: inline-size;
22
- --contentSize: var(--size--m);
23
- --size--wide: var(--size--l);
24
-
25
- > * {
26
- max-inline-size: min(100%, var(--contentSize));
27
- margin-inline: auto;
28
- }
29
- }
30
-
31
- // .is--container.-contents\:m{}
32
-
33
- // -content:s
34
-
35
- // l--container -container:s
36
- // is--flow:
37
-
38
- // -container:m, -container:s, -container:l
39
- // [data-content-size='']
40
- .is--container\:xs {
41
- --contentSize: var(--size--xs);
42
- --size--wide: var(--size--s);
43
- }
44
- .is--container\:s {
45
- --contentSize: var(--size--s);
46
- --size--wide: var(--size--m);
47
- }
48
- .is--container\:m {
49
- --contentSize: var(--size--m);
50
- --size--wide: var(--size--l);
51
- }
52
- .is--container\:l {
53
- --contentSize: var(--size--l);
54
- --size--wide: 100%;
55
- }
56
- .is--container\:full {
57
- --contentSize: 100%;
58
- --size--wide: 100%;
59
- }
60
- // .is--constrained\:
61
-
62
- // is--container かつ is--constrained を考慮するか?
63
-
64
- // .is--container {
65
- // --containerSize: var(--size--m);
66
- // }
67
- // .is--container\:s {
68
- // --containerSize: var(--size--s);
69
- // }
70
- // .is--container\:l {
71
- // --containerSize: var(--size--l);
72
- // }
73
- // .is--container\:full {max-inline-size: 100%;} // これは → .is--container.alignfull でできる
74
-
75
- // Note: 詳細度は flow より強く、ユーティリティより弱く。(flowの後で定義し、0-1-0 を超えないように)
76
- :where(.is--fullwide) + .is--fullwide {
77
- margin-block-start: 0;
78
- }
79
-
80
- // Note: .is--container より後にかく。
81
- // :is(.alignfull, .is--fullwide),
82
- .is--fullwide {
83
- // container-type: inline-size;
84
- max-inline-size: 100%;
85
-
86
- :where(.has--gutter) > & {
87
- // --contentSize 変数は min()で100%と比較してるので、直接セット
88
- max-inline-size: calc(100% + var(--gutter) * 2);
89
- margin-inline: calc(var(--gutter) * -1);
90
- }
91
- }
92
-
93
- // :is(.alignwide, .is--wide)
94
- .is--wide {
95
- // container-type: inline-size;
96
- max-inline-size: var(--size--wide, 100%);
97
- }
98
-
99
- // .has--gutter\:s {
100
- // padding-inline: var(--gutter--s);
101
- // }
102
-
103
- :root {
104
- --size--full: 100vw;
105
- }
106
- .is--overwide {
107
- max-inline-size: var(--size--full);
108
- margin-inline: calc(50% - var(--size--full) / 2);
109
- }
110
-
111
- // @property が使える環境であればコンテナのさらに親要素の幅を参照できるので、containerを1段階飛び出せる。
112
- // ↓ @property の疑似サポートチェック
113
- // - @propety : chirome(85~),edge(85~),opera(71~),Samsung(14~)
114
- // - content-visibility : chirome(85~),edge(85~),opera(71~), safari:x,firefox:x, Samsung(14~)
115
- // - <length> lh : Safari(16.4~), Firefox(120~121 ?), Chrome,Edge(109~), Opera(95~), Samsung(21~)
116
- // ↓
117
- // @supports (content-visibility: auto) or (top: 0lh)
118
- @supports (content-visibility: auto) or (top: 0lh) {
119
- // cqw を算出値で保持するために登録済みカスタムプロパティとして定義
120
- @property --size--full {
121
- syntax: '<length-percentage>';
122
- initial-value: 100%;
123
- inherits: true;
124
- }
125
-
126
- :is(.is--container, [class*='is--container:']) {
127
- --size--full: 100cqw; // is--container が配置された時点での 100cqw をセット
128
- }
129
-
130
- // bodyにコンテナ適用して直下要素に100cqwをセットできればいいが、コンテナ内の fixed要素の挙動が変わるので廃止。
131
- // @property --size--screenW {
132
- // syntax: '<length-percentage>';
133
- // initial-value: 100vw;
134
- // inherits: true;
135
- // }
136
- // body {
137
- // --size--screenW: 100cqw;
138
- // }
139
- // .alignscreen {
140
- // max-inline-size: var(--size--screenW);
141
- // margin-inline: calc(50% - var(--size--screenW) / 2);
142
- // }
143
- }
@@ -1,52 +0,0 @@
1
- /*
2
- flowGap はクエリ調整不可。クエリ調整必要な場合はStack使ってもらえばいい。
3
- end:0 がどうせ :first-child に必要なので、 mbs も > * + * 使わず上書き形式で。
4
-
5
- memo: :first-child , :last-child の詳細度は 0-1-0
6
-
7
- .-mbs で上書きできるように 0-1-0 を超えないように注意。
8
- */
9
-
10
- :where(.is--flow) > * {
11
- --mbs: var(--flowGap--m); // --base?
12
- }
13
- :where(.is--flow\:s) > * {
14
- --mbs: var(--flowGap--s);
15
- }
16
- :where(.is--flow\:l) > * {
17
- --mbs: var(--flowGap--l);
18
- }
19
- // カスタム値 Note: ネストに注意が必要
20
- :where(.is--flow\:) > * {
21
- --mbs: var(--flowGap);
22
- }
23
- // [data-flow-gap]
24
-
25
- // 見出しの上部余白は少しだけ広くする. ただし、見出し直後の見出しの場合を除く。
26
- // Note: :first-child での打消しのほうが優先度高くなるように注意する
27
- :where(h1, h2, h3:not(h2 + h3), h4:not(h3 + h4), h5:not(h4 + h5), h6:not(h5 + h6)) {
28
- --mbs: var(--flowGap--htag);
29
- }
30
- // :where(:is(h1, h2, h3, h4, h5, h6):not(:is(h1, h2, h3, h4, h5, h6) + :is(h1, h2, h3, h4, h5, h6))) {
31
- // --mbs: var(--flowGap--htag);
32
- // }
33
-
34
- // :first-child への上書きのほうが優先度高くなるように。
35
- :is(.is--flow, [class*='is--flow:']) {
36
- > * {
37
- margin-block-end: 0;
38
- margin-block-start: var(--mbs); // resetCSSがlismであれば、これは不要
39
- }
40
-
41
- // :empty どうする?
42
- > :where(:first-child) {
43
- --mbs: 0;
44
- }
45
- }
46
-
47
- // .is--skipFlow の次の要素は mbs を 0 にする。
48
- // hidden要素 や absoluteな要素が先頭に入り込んでいる時などに活用できる。
49
- .is--skipFlow + * {
50
- // margin-block-start: 0;
51
- --mbs: 0;
52
- }
File without changes