lism-css 0.0.10 → 0.0.12

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 (51) hide show
  1. package/dist/components/Accordion/setAccordion.js +5 -5
  2. package/dist/components/Accordion/style.css +1 -0
  3. package/dist/components/Modal/style.css +1 -0
  4. package/dist/components/Tabs/style.css +1 -0
  5. package/dist/config/prop_list.js +8 -5
  6. package/dist/css/all.css +1 -0
  7. package/dist/css/all_no_layer.css +1 -0
  8. package/dist/css/base.css +1 -0
  9. package/dist/css/dynamic.css +1 -0
  10. package/dist/css/layout.css +1 -0
  11. package/dist/css/props.css +1 -0
  12. package/dist/css/reset.css +1 -0
  13. package/dist/css/state.css +1 -0
  14. package/dist/css/utility.css +1 -0
  15. package/dist/css/with_layer.css +1 -0
  16. package/dist/lib/getLismProps.js +29 -29
  17. package/package.json +1 -1
  18. package/src/scss/_auto_output.scss +17 -5
  19. package/src/scss/_props.scss +25 -23
  20. package/src/scss/_setting.scss +2 -2
  21. package/src/scss/all.scss +0 -4
  22. package/src/scss/all_no_layer.scss +5 -1
  23. package/src/scss/base/_property.scss +43 -0
  24. package/src/scss/base/_tokens.scss +13 -33
  25. package/src/scss/base/index.scss +2 -1
  26. package/src/scss/props/_border.scss +2 -2
  27. package/src/scss/props/_hover.scss +9 -9
  28. package/src/scss/props/_transition.scss +2 -2
  29. package/src/scss/props/index.scss +1 -0
  30. package/src/scss/state/_container.scss +12 -8
  31. package/src/scss/state/_flow.scss +24 -25
  32. package/src/scss/state/_size.scss +3 -20
  33. package/src/scss/utility/_colbox.scss +18 -0
  34. package/src/scss/utility/_trimHL.scss +18 -0
  35. package/src/scss/utility/index.scss +10 -29
  36. package/src/scss/layout/__switcher.scss +0 -11
  37. package/src/scss/props/__/__aspect.bkup.scss +0 -36
  38. package/src/scss/props/__/__border.bkup.scss +0 -197
  39. package/src/scss/props/__/__color.bkup.scss +0 -67
  40. package/src/scss/props/__/__display.bukup.scss +0 -11
  41. package/src/scss/props/__/__flex-props.bkup.scss +0 -66
  42. package/src/scss/props/__/__gap.bkup.scss +0 -18
  43. package/src/scss/props/__/__grid-props.bkup.scss +0 -158
  44. package/src/scss/props/__/__margin.bkup.scss +0 -92
  45. package/src/scss/props/__/__padding.bkup.scss +0 -93
  46. package/src/scss/props/__/__place.bkup.scss +0 -74
  47. package/src/scss/props/__/__radius.bkup.scss +0 -27
  48. package/src/scss/props/__/__sizing.bkup.scss +0 -45
  49. package/src/scss/props/__/__typography.bkup.scss +0 -146
  50. package/src/scss/state/__container.bkup.scss +0 -143
  51. package/src/scss/state/__flow.bkup.scss +0 -52
@@ -10,11 +10,11 @@ utilities: ユーティリティクラスのセレクタと値のリスト
10
10
  base_type:
11
11
  0 → なし(ユーティリティクラス以外は普通のインラインスタイルのみ)
12
12
  1 → .-d\:{display: var(--d)}  (メリット:importantなしでbp対応できる)
13
- 2 → [class*='-p\:'] {padding: var(--p);} のように出力される
14
- トークンが定義されているような主要なプロパティは基本これ。
15
- メリット: ユーティリティクラスも変数を使えるので、数が多ければ文字数省略できる
16
- 全て変数で出力されるようになるので、他の処理と絡ませることがしやすい。
17
- デメリット: *= は処理負荷が高い。
13
+ 2 → .-p, [class*='-p\:'] {padding: var(--p);} の形式で、BPクラス含めて全て変数にセットするもの。
14
+ 常に変数で管理されるようになるので、他の処理と絡ませることがしやすい。
15
+ デメリット: *= は処理負荷が高い。また、途中のBPから使えるようにするにはCSS記述増える)
16
+
17
+ 3 → BPクラスには変数使わないが、文字数省略のため baseのProp classだけ変数化して *= セレクタ使う
18
18
 
19
19
 
20
20
  bp:1 は基本 base_type:1. --bdw などは base_type:0.
@@ -71,7 +71,6 @@ $place_utils: (
71
71
  $props: (
72
72
  'w': (
73
73
  prop: 'width',
74
- base_type: 1,
75
74
  utilities: (
76
75
  // 'a': 'auto',
77
76
  'fit': 'fit-content',
@@ -81,7 +80,6 @@ $props: (
81
80
  ),
82
81
  'h': (
83
82
  prop: 'height',
84
- base_type: 1,
85
83
  utilities: (
86
84
  // 'a': 'auto',
87
85
  'fit': 'fit-content',
@@ -93,7 +91,6 @@ $props: (
93
91
  ),
94
92
  'maxW': (
95
93
  prop: 'max-width',
96
- base_type: 1,
97
94
  utilities: (
98
95
  '100\\%': '100%',
99
96
  ),
@@ -101,7 +98,6 @@ $props: (
101
98
  ),
102
99
  'minW': (
103
100
  prop: 'min-width',
104
- base_type: 1,
105
101
  utilities: (
106
102
  '100\\%': '100%',
107
103
  ),
@@ -109,7 +105,6 @@ $props: (
109
105
  ),
110
106
  'maxH': (
111
107
  prop: 'max-height',
112
- base_type: 1,
113
108
  utilities: (
114
109
  '100\\%': '100%',
115
110
  ),
@@ -117,7 +112,6 @@ $props: (
117
112
  ),
118
113
  'minH': (
119
114
  prop: 'min-height',
120
- base_type: 1,
121
115
  utilities: (
122
116
  '100\\%': '100%',
123
117
  '100lvh': '100lvh',
@@ -296,9 +290,9 @@ $props: (
296
290
  'f': 'flex',
297
291
  'g': 'grid',
298
292
  'i': 'inline',
293
+ 'ib': 'inline-block',
299
294
  'if': 'inline-flex',
300
295
  'ig': 'inline-grid',
301
- 'ib': 'inline-block',
302
296
  ),
303
297
  ),
304
298
  'v': (
@@ -354,14 +348,10 @@ $props: (
354
348
  '4': 'var(--bdrs--4)',
355
349
  '5': 'var(--bdrs--5)',
356
350
  '99': 'var(--bdrs--99)',
357
- 'inner': (
358
- 'border-radius': 'calc(var(--bdrs, 0) - var(--p, 0) * 0.9)',
359
- ),
360
351
  ),
361
352
  ),
362
353
  'bxsh': (
363
354
  prop: 'box-shadow',
364
- base_type: 2,
365
355
  utilities: (
366
356
  '0': '0',
367
357
  '1': 'var(--bxsh--1)',
@@ -381,13 +371,13 @@ $props: (
381
371
  ),
382
372
  'px': (
383
373
  prop: 'padding-inline',
384
- base_type: 2,
374
+ base_type: 3,
385
375
  bp: 1,
386
376
  utilities: $space_values,
387
377
  ),
388
378
  'py': (
389
379
  prop: 'padding-block',
390
- base_type: 2,
380
+ base_type: 3,
391
381
  bp: 1,
392
382
  utilities: $space_values,
393
383
  ),
@@ -409,13 +399,13 @@ $props: (
409
399
  ),
410
400
  'pis': (
411
401
  prop: 'padding-inline-start',
412
- base_type: 2,
402
+ base_type: 3,
413
403
  bp: 1,
414
404
  utilities: $space_values,
415
405
  ),
416
406
  'pbs': (
417
407
  prop: 'padding-block-start',
418
- base_type: 2,
408
+ base_type: 3,
419
409
  bp: 1,
420
410
  utilities: $space_values,
421
411
  ),
@@ -457,13 +447,13 @@ $props: (
457
447
  ),
458
448
  'mis': (
459
449
  prop: 'margin-inline-start',
460
- base_type: 2,
450
+ base_type: 3,
461
451
  bp: 1,
462
452
  utilities: map.merge($auto, $space_values),
463
453
  ),
464
454
  'mbs': (
465
455
  prop: 'margin-block-start',
466
- base_type: 2,
456
+ base_type: 3,
467
457
  bp: 1,
468
458
  utilities: map.merge($auto, $space_values),
469
459
  ),
@@ -592,10 +582,16 @@ $props: (
592
582
  'gtc': (
593
583
  prop: 'grid-template-columns',
594
584
  bp: 1,
585
+ utilities: (
586
+ 'subgrid': 'subgrid',
587
+ ),
595
588
  ),
596
589
  'gtr': (
597
590
  prop: 'grid-template-rows',
598
591
  bp: 1,
592
+ utilities: (
593
+ 'subgrid': 'subgrid',
594
+ ),
599
595
  ),
600
596
  'gaf': (
601
597
  prop: 'grid-auto-flow',
@@ -626,10 +622,16 @@ $props: (
626
622
  'gr': (
627
623
  prop: 'grid-row',
628
624
  bp: 1,
625
+ // utilities: (
626
+ // 'full': '1/-1',
627
+ // ),
629
628
  ),
630
629
  'gc': (
631
630
  prop: 'grid-column',
632
631
  bp: 1,
632
+ // utilities: (
633
+ // 'full': '1/-1',
634
+ // ),
633
635
  ),
634
636
  'ai': (
635
637
  prop: 'align-items',
@@ -683,7 +685,7 @@ $props: (
683
685
  '-45': '-45deg',
684
686
  '90': '90deg',
685
687
  '-90': '-90deg',
686
- '180': '180deg',
688
+ // '180': '180deg',
687
689
  ),
688
690
  ),
689
691
  'whs': (
@@ -3,10 +3,10 @@
3
3
 
4
4
  @use './props' as props;
5
5
 
6
- $layer_mode: 0 !default;
6
+ $layer_mode: 1 !default;
7
7
  $default_important: 0 !default;
8
8
  $is_container_query: 1 !default;
9
- $common_support_bp: 'lg' !default;
9
+ $common_support_bp: 'md' !default;
10
10
 
11
11
  $breakpoints: () !default;
12
12
  $breakpoints: map.merge(
package/src/scss/all.scss CHANGED
@@ -1,10 +1,6 @@
1
1
  /*
2
2
  @layer 使う
3
3
  */
4
- @use './setting' with (
5
- $layer_mode: 1
6
- );
7
-
8
4
  @use './with_layer';
9
5
  @use './utility/index' as utility;
10
6
  @use './props/index' as props;
@@ -1,6 +1,10 @@
1
1
  /*
2
- resetした上で、 各要素の標準スタイルを定義する
2
+ @layerなし
3
3
  */
4
+ @use './setting' with (
5
+ $layer_mode: 0
6
+ );
7
+
4
8
  // reset
5
9
  @use './reset' as reset;
6
10
 
@@ -0,0 +1,43 @@
1
+ // @property が使える環境であればコンテナのさらに親要素の幅を参照できるので、containerを1段階飛び出せる。
2
+ // cqw を算出値で保持するために登録済みカスタムプロパティとして定義
3
+ @property --overwideSize {
4
+ syntax: '<length-percentage>';
5
+ initial-value: 100%;
6
+ inherits: true;
7
+ }
8
+
9
+ // @property --flowM {
10
+ // syntax: '*';
11
+ // inherits: true;
12
+ // }
13
+
14
+ /* ------------------------------------------------------------
15
+ ハーフレディング
16
+
17
+ Memo: --herfLeadingとは別に--negativeHLを定義しているのは、トリミングをしないために 0px に上書きした要素でも --herfLeading 自体の値は無効にしないようにするため。
18
+ これにより、imgに対してmargin-block-start:var(--herfLeading) を適用して余白を揃えたりできる。
19
+ */
20
+ @property --herfLeading {
21
+ syntax: '*';
22
+ inherits: false;
23
+ initial-value: calc((1lh - 1em) / 2);
24
+ }
25
+
26
+ // トリミングするネガティブマージン
27
+ // Memo: initial-valueでvar(--herfLeading)は使えなかった
28
+ @property --trimHL {
29
+ syntax: '*';
30
+ inherits: false;
31
+ initial-value: calc((1lh - 1em) / 2 * -1);
32
+ }
33
+
34
+ // :lang(en) {
35
+ // --herfLeading: calc((1lh - 1cap) / 2);
36
+ // }
37
+
38
+ // lh非サポートブラウザ用のフォールバック
39
+ // @supports not (gap: 1lh) {
40
+ // :root {
41
+ // --herfLeading: 0px;
42
+ // }
43
+ // }
@@ -15,7 +15,6 @@
15
15
  /* ------------------------------------------------------------
16
16
  Spacing
17
17
  ------------------------------------------------------------ */
18
- --herfLeading: calc((1lh - 1em) / 2);
19
18
 
20
19
  // フィボナッチ数列 0, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89,
21
20
  // 0 .25rem, .5rem, .75rem, 1.25rem, M:(8):2rem, 3.25rem, 5.25rem, 8.5rem
@@ -34,18 +33,11 @@
34
33
  --s80: 11.125rem;
35
34
  // --s90: 18rem;
36
35
 
37
- // テキストのline-height分を考慮した上下左右の余白
38
- // --p--box--s: 0.75em; //calc(0.75em - var(--herfLeading)) 0.75em; //0.625em 0.75em;
39
- // --p--box: calc(1.25em - var(--herfLeading)) 1.25em;
40
- // --p--box--l: calc(1.75em - var(--herfLeading)) 1.75em; //1.375em 1.5em;
41
-
42
36
  // .is--flow の余白
43
- // --flowGap-offset: calc(var(--herfLeading) * 2);
44
- --flowGap--s: var(--s30);
45
- --flowGap--m: var(--s40);
46
- --flowGap--l: var(--s50);
47
- --flowGap--h: 2.5em;
48
- // --flowGap: var(--flowGap--m);
37
+ --flowM--s: var(--s20);
38
+ --flowM--m: var(--s40);
39
+ // --flowM--l: var(--s50);
40
+ --flowM--h: 1em; /* --flowM に追加する値 */
49
41
 
50
42
  // コンテンツの左右の余白
51
43
  --gutter: var(--s40);
@@ -199,13 +191,12 @@
199
191
  // base
200
192
  // --c--base: hsl(225 8% 98%);
201
193
  --c--base: hsl(224 6% 99%);
202
- --c--base-2: hsl(224 10% 94%);
194
+ --c--base-2: hsl(224 10% 94%); // secondary
203
195
  // --c--base-3: hsl(220 8% 86%); // border用
204
196
 
205
197
  // text
206
- --c--text-hsl: 224 4% 8%; // shadowにも使う
207
- --c--text: hsl(var(--c--text-hsl));
208
- --c--text-2: hsl(224 4% 40%);
198
+ --c--text: hsl(224 4% 8%);
199
+ --c--text-2: hsl(224 4% 40%); // secondary
209
200
  // --text-3: hsl(224, 4%, 50%); //hsl(200, 12%, 92%);
210
201
 
211
202
  // --sh-hsl
@@ -236,11 +227,11 @@
236
227
  radius
237
228
  ------------------------------------------------------------ */
238
229
  // 等比
239
- --bdrs--1: 0.125rem; // base
240
- --bdrs--2: 0.25rem; // * 2
241
- --bdrs--3: 0.5rem; // * 4
242
- --bdrs--4: 1rem; // * 8
243
- --bdrs--5: 2rem; // * 16
230
+ --bdrs--1: 2px;
231
+ --bdrs--2: 4px;
232
+ --bdrs--3: 0.5rem; // 8px
233
+ --bdrs--4: 1rem; // 16px
234
+ --bdrs--5: 2rem; // 32px
244
235
  --bdrs--99: 99rem;
245
236
 
246
237
  // 1, 2, 3, 5, 8, 13,
@@ -254,8 +245,7 @@
254
245
  /* ------------------------------------------------------------
255
246
  shadow
256
247
  ------------------------------------------------------------ */
257
- // --sh-hsl: 220 20% 20%;
258
- --sh-hsl: var(--c--text-hsl);
248
+ --sh-hsl: 220 4% 8%;
259
249
  --sh-a: 5%;
260
250
 
261
251
  // --sh-a--base: calc(var(--sh-a) - 4%);
@@ -295,13 +285,3 @@
295
285
  // --filter--lighten: brightness(1.15);
296
286
  // --filter--darken: brightness(0.85);
297
287
  }
298
-
299
- // :lang(en) {
300
- // --herfLeading: calc((1lh - 1cap) / 2);
301
- // }
302
- // lh非サポートブラウザ用のフォールバック
303
- @supports not (gap: 1lh) {
304
- :root {
305
- --herfLeading: 0.125em;
306
- }
307
- }
@@ -1,5 +1,6 @@
1
1
  @use '../_mixin' as mixin;
2
2
 
3
+ @forward './property';
3
4
  @forward './tokens';
4
5
 
5
6
  // 各html要素のベーススタイル
@@ -15,7 +16,7 @@
15
16
  --hov-trsdu: 0.3s;
16
17
 
17
18
  // is--overwide で使用
18
- --overwide-size: 100vw;
19
+ --overwideSize: 100vw;
19
20
 
20
21
  // :rootで初期セットしてないが定義可能な変数
21
22
  // --heading-ff
@@ -13,14 +13,14 @@
13
13
 
14
14
  // bdc, bdw などでカラーや太さを上書きできるように border 自体を変数管理
15
15
  // :where(.has--bd),
16
- @include mixin.maybe_where('[class*="-bd:"]', 'base') {
16
+ @include mixin.maybe_where('.-bd,[class*="-bd:"]', 'base') {
17
17
  --bds: solid;
18
18
  --bdw: 1px;
19
19
  --bdc: currentColor;
20
20
  --bd: var(--bdw) var(--bds) var(--bdc);
21
21
  }
22
22
  // .has--bd:where(:not([class*='-bd:'])) {
23
- .-bd\: {
23
+ .-bd {
24
24
  border-style: var(--bds);
25
25
  border-width: var(--bdw);
26
26
  border-color: var(--bdc);
@@ -27,23 +27,23 @@
27
27
  // ------------------------------------------------------------
28
28
  // 値指定
29
29
  // ------------------------------------------------------------
30
- .-hov\:c\::hover {
31
- color: var(--hov-c) !important;
30
+ .-hov\:c:hover {
31
+ color: var(--hov-c);
32
32
  }
33
- .-hov\:bdc\::hover {
34
- border-color: var(--hov-bdc) !important;
33
+ .-hov\:bdc:hover {
34
+ border-color: var(--hov-bdc);
35
35
  }
36
- .-hov\:bgc\::hover {
37
- background-color: var(--hov-bgc) !important;
36
+ .-hov\:bgc:hover {
37
+ background-color: var(--hov-bgc);
38
38
  }
39
- .-hov\:bxsh\::hover {
39
+ .-hov\:bxsh:hover {
40
40
  box-shadow: var(--hov-bxsh);
41
41
  }
42
42
 
43
- // .-hov\:op\::hover {
43
+ // .-hov\:op:hover {
44
44
  // opacity: var(--hov-op) !important;
45
45
  // }
46
- // .-hov\:filter\::hover {
46
+ // .-hov\:filter:hover {
47
47
  // filter: var(--hov-filter) !important;
48
48
  // }
49
49
  .-hov\:set:hover {
@@ -1,13 +1,13 @@
1
1
  @use '../_mixin' as mixin;
2
2
 
3
3
  // 変数初期セット(親子関係で影響しないように)
4
- @include mixin.maybe_where('.-trs\\:', 'base') {
4
+ @include mixin.maybe_where('.-trs', 'base') {
5
5
  --trsdu: var(--trsdu--default);
6
6
  --trsp: all;
7
7
  --trstf: ease;
8
8
  }
9
9
 
10
- .-trs\: {
10
+ .-trs {
11
11
  transition: var(--trsdu) var(--trstf);
12
12
  transition-property: var(--trsp);
13
13
  // transition-duration: var(--trsdu);
@@ -9,4 +9,5 @@
9
9
  // 自動生成
10
10
  @forward '../auto_output';
11
11
 
12
+ // Prop Classの最後で読み込む
12
13
  @forward './hover';
@@ -3,9 +3,13 @@
3
3
  container-type: inline-size;
4
4
  margin-inline: auto;
5
5
  inline-size: 100%; // gridやflex内での挙動を考慮。(container-type:inline-sizeだと横幅つぶれる)
6
- // --wide-size: 100%;
6
+ // --wideSize: 100%;
7
+
8
+ // .is--overwide のサイズを is--container ごとにセット。
9
+ --overwideSize: 100cqw;
10
+
7
11
  > * {
8
- --maxIs: var(--item-size, 100%);
12
+ --maxIs: var(--contentSize, 100%);
9
13
  max-inline-size: min(100%, var(--maxIs, 100%));
10
14
  margin-inline: auto;
11
15
  }
@@ -13,14 +17,14 @@
13
17
 
14
18
  // Memo: それぞれの直下要素( > * ) に対してスタイルをセットした方が、ネスト時の影響をなくせるが、constrainedのネストが多様されることは少ないので親側の変数管理のみで実装。
15
19
  .-container\:s {
16
- --item-size: var(--size--s);
17
- --wide-size: var(--size--m);
20
+ --contentSize: var(--size--s);
21
+ --wideSize: var(--size--m);
18
22
  }
19
23
  .-container\:m {
20
- --item-size: var(--size--m);
21
- --wide-size: var(--size--l);
24
+ --contentSize: var(--size--m);
25
+ --wideSize: var(--size--l);
22
26
  }
23
27
  .-container\:l {
24
- --item-size: var(--size--l);
25
- --wide-size: var(--size--xl);
28
+ --contentSize: var(--size--l);
29
+ --wideSize: var(--size--xl);
26
30
  }
@@ -1,46 +1,45 @@
1
1
  /*
2
- flowG はクエリ調整不可。クエリ調整必要な場合はStack使ってもらえばいい。
3
- end:0 がどうせ :first-child に必要なので、 mbs も > * + * 使わず上書き形式で。
4
-
5
- memo: :first-child , :last-child の詳細度は 0-1-0
6
-
7
- .-mbs で上書きできるように 0-1-0 を超えないように注意。
2
+ Meomo: end:0 がどうせ :first-child に必要なので、 mbs も > * + * 使わず上書き形式で。
3
+ is--containerと合わせて、カスタム値のセットは is--flow + 変数定義だけでできるように。
8
4
  */
9
5
 
10
6
  .is--flow {
11
- // --flowGap: var(--flowGap--m)
7
+ display: flow-root;
8
+ // --_fgap: var(--flowM, var(--flowM--m));
9
+
12
10
  > * {
13
- --mbs: var(--flowGap, var(--flowGap--m));
11
+ --mbs: var(--flowM, var(--flowM--m));
14
12
  margin-block: var(--mbs) 0;
15
13
  }
16
14
  }
17
-
18
15
  .-flow\:s > * {
19
- --flowGap: var(--flowGap--s);
20
- }
21
-
22
- .-flow\:ms > * {
23
- // --flowGap: var(--flowGap--m);
24
- --flowGap: var(--flowGap--m);
16
+ --mbs: var(--flowM--s);
25
17
  }
26
- .-flow\:l > * {
27
- --flowGap: var(--flowGap--l);
18
+ .-flow\:m > * {
19
+ --mbs: var(--flowM--m);
28
20
  }
29
-
30
- // :where(.is--flow\:) > * {
31
- // --mbs: var(--flowG);
21
+ // .-flow\:l > * {
22
+ // --flowM: var(--flowM--l);
23
+ // }
24
+ // .-flow\: > * {
25
+ // --mbs: var(--flowM);
32
26
  // }
33
27
 
34
28
  // 見出しの上部余白は少しだけ広くする. ただし、見出し直後の見出しの場合を除く。
35
29
  // Note: :first-child での打消しのほうが優先度高くなるように注意する
36
- .is--flow > :where(h1, h2, h3:not(h2 + h3)) {
37
- // --mbsではなく--flowGapを使うことで、is--flow単体(標準時)の直下でのみ効かせる。
38
- --flowGap: var(--flowGap--h);
30
+ .is--flow > :where(h1, h2, h3, h4) {
31
+ margin-block-start: calc(var(--mbs) + var(--flowM--h));
32
+ }
33
+ // :where(h2 + h3, h3 + h4) {
34
+ // --flowM--h: 0px;
35
+ // }
36
+
37
+ // fullwideの連結に余白は基本不要
38
+ .is--flow > :where(.is--fullwide + .is--fullwide) {
39
+ --mbs: 0;
39
40
  }
40
41
 
41
42
  // :first-child への上書きのほうが優先度高くなるように。
42
43
  .is--flow > :first-child {
43
- // --mbs への上書きが気軽に書けるよう、--flowGap を 0 に。
44
- // --flowGap を 0にすると、子要素に影響するので margin-block-startへ直セット
45
44
  margin-block-start: 0;
46
45
  }
@@ -10,30 +10,13 @@
10
10
  }
11
11
  }
12
12
 
13
- // Note: 詳細度は 0-1-0 より大きく.
14
- .is--fullwide + .is--fullwide {
15
- --flowGap: 0;
16
- }
17
-
18
13
  // :is(.alignwide, .is--wide)
19
14
  .is--wide {
20
15
  // container-type: inline-size;
21
- max-inline-size: var(--wide-size, 100%);
16
+ max-inline-size: var(--wideSize, 100%);
22
17
  }
23
18
 
24
19
  .is--overwide {
25
- max-inline-size: var(--overwide-size, 100vw);
26
- margin-inline: calc(50% - var(--overwide-size) / 2);
27
- }
28
-
29
- // @property が使える環境であればコンテナのさらに親要素の幅を参照できるので、containerを1段階飛び出せる。
30
- // cqw を算出値で保持するために登録済みカスタムプロパティとして定義
31
- @property --overwide-size {
32
- syntax: '<length-percentage>';
33
- initial-value: 100%;
34
- inherits: true;
35
- }
36
- // is--container でその時点のサイズをセットする
37
- .is--container {
38
- --overwide-size: 100cqw;
20
+ max-inline-size: var(--overwideSize, 100vw);
21
+ margin-inline: calc(50% - var(--overwideSize) / 2);
39
22
  }
@@ -0,0 +1,18 @@
1
+ /*
2
+ Note: c,bgc,bdc Prop Class より前で読み込む(優先度を下げる)こと。
3
+ */
4
+ .u--colbox {
5
+ --c: var(--c--text);
6
+ --bgc: var(--c--base-2);
7
+ color: var(--c);
8
+ background-color: var(--bgc);
9
+ }
10
+ @supports (color: color-mix(in srgb, #000, #fff)) {
11
+ // --keycol は 必須. 親から引き継ぎたいこともあるかもしれないので、初期セットはしない
12
+ .u--colbox {
13
+ --c: color-mix(in srgb, var(--c--text), var(--keycol) var(--colbox-pct--c, 20%));
14
+ --c--link: var(--c);
15
+ --bgc: color-mix(in srgb, var(--c--base), var(--keycol) var(--colbox-pct--bg, 5%));
16
+ --bdc: var(--keycol);
17
+ }
18
+ }
@@ -0,0 +1,18 @@
1
+ table,
2
+ figure,
3
+ img,
4
+ video {
5
+ --trimHL: 0px;
6
+ }
7
+
8
+ .u--trimHL {
9
+ margin-block: var(--trimHL);
10
+ }
11
+ .u--trimBox {
12
+ > :first-child {
13
+ margin-block-start: var(--trimHL);
14
+ }
15
+ > :last-child {
16
+ margin-block-end: var(--trimHL);
17
+ }
18
+ }
@@ -1,3 +1,6 @@
1
+ @forward './trimHL';
2
+ @forward './colbox';
3
+
1
4
  // for screen reader
2
5
  .u--hidden {
3
6
  position: absolute;
@@ -11,35 +14,6 @@
11
14
  border-width: 0;
12
15
  }
13
16
 
14
- .u--trimHL {
15
- > :where(p, h1, h2, h3, h4, h5, h6):first-child {
16
- margin-block-start: calc(var(--herfLeading) * -1);
17
- }
18
- > :where(p, h1, h2, h3, h4, h5, h6):last-child {
19
- margin-block-end: calc(var(--herfLeading) * -1);
20
- }
21
- }
22
-
23
- /*
24
- Note: c,bgc,bdc Prop Class より前で読み込むこと。
25
- */
26
- // 優先度的なことを考慮をすると state系列にするより u-- の方がいい
27
- .u--colbox {
28
- --c: var(--c--text);
29
- --bgc: var(--c--base-2);
30
- color: var(--c);
31
- background-color: var(--bgc);
32
- }
33
- @supports (color: color-mix(in srgb, #000, #fff)) {
34
- // --keycol は 必須. 親から引き継ぎたいこともあるかもしれないので、初期セットはしない
35
- .u--colbox {
36
- --c: color-mix(in srgb, var(--c--text), var(--keycol) var(--colbox-pct--c, 40%));
37
- --bgc: color-mix(in srgb, var(--c--base), var(--keycol) var(--colbox-pct--bg, 5%));
38
- --bdc: color-mix(in srgb, var(--c--base), var(--keycol) var(--colbox-pct--bdc, 25%));
39
- --c--link: var(--c);
40
- }
41
- }
42
-
43
17
  .u--overlayLink {
44
18
  text-decoration: none;
45
19
  position: static;
@@ -64,3 +38,10 @@
64
38
  -webkit-background-clip: text !important;
65
39
  background-clip: text !important;
66
40
  }
41
+
42
+ .u--outerR {
43
+ --inner-bdrs: calc(var(--bdrs, 0px) - var(--p, 0px));
44
+ }
45
+ .u--innerR {
46
+ border-radius: var(--inner-bdrs);
47
+ }