@burger-editor/client 4.0.0-alpha.2 → 4.0.0-alpha.20

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.
package/dist/client.css CHANGED
@@ -1,10 +1,10 @@
1
- @charset "UTF-8";
2
- dl.svelte-s2t554 {
1
+ @charset "utf-8";
2
+ dl.svelte-zdu8xx {
3
3
  padding: 0;
4
4
  margin: 0;
5
5
  }
6
6
 
7
- dt.svelte-s2t554 {
7
+ dt.svelte-zdu8xx {
8
8
  margin-block-end: 10px;
9
9
  font-size: 1.1em;
10
10
  font-weight: bold;
@@ -12,51 +12,54 @@
12
12
  border-block-end: 1px #565a49 dotted;
13
13
  }
14
14
 
15
- dl.svelte-s2t554 > div:where(.svelte-s2t554) {
15
+ dl.svelte-zdu8xx > div:where(.svelte-zdu8xx) {
16
16
  display: grid;
17
17
  grid-template-columns: repeat(auto-fill, minmax(6em, 1fr));
18
18
  gap: 0.5em;
19
19
  }
20
20
 
21
- dd.svelte-s2t554 {
21
+ dd.svelte-zdu8xx {
22
22
  padding: 0;
23
23
  margin: 0;
24
24
  }
25
25
 
26
- button.svelte-s2t554 {
26
+ button.svelte-zdu8xx {
27
27
  display: flex;
28
28
  align-items: start;
29
29
  inline-size: 100%;
30
30
  block-size: 100%;
31
- padding: 0.5em 0.5em;
31
+ padding: 0.5em;
32
32
  margin: 0;
33
33
  appearance: none;
34
34
  }
35
35
 
36
- figure.svelte-s2t554 {
37
- margin: 0 auto;
36
+ figure.svelte-zdu8xx {
37
+ margin-block: 0;
38
+ margin-inline: auto;
38
39
  }
39
40
 
40
- .img.svelte-s2t554 > :where(.svelte-s2t554) {
41
+ .img.svelte-zdu8xx > :where(.svelte-zdu8xx) {
41
42
  display: block;
42
43
  inline-size: 71px;
43
44
  block-size: 56px;
44
- margin: 0 auto;
45
+ margin-block: 0;
46
+ margin-inline: auto;
45
47
  background-repeat: no-repeat;
46
48
  border-radius: 10px;
47
49
  }
48
50
 
49
- figcaption.svelte-s2t554 {
51
+ figcaption.svelte-zdu8xx {
50
52
  padding-block-start: 0.5em;
51
53
  font-size: 0.6em;
52
54
  font-weight: bold;
53
55
  text-align: center;
54
56
  }
55
57
 
56
- button.svelte-1m6pw9u {
58
+ button.svelte-1l34gy2 {
57
59
  anchor-name: var(--name);
58
60
  display: block;
59
- padding: 0.2em 0.5em;
61
+ padding-block: 0.2em;
62
+ padding-inline: 0.5em;
60
63
  font-size: 1.5em;
61
64
  color: var(--bge-lightest-color);
62
65
  pointer-events: all;
@@ -64,7 +67,7 @@
64
67
  border: none;
65
68
  }
66
69
 
67
- div.svelte-1m6pw9u:is(:where(.svelte-1m6pw9u):hover, :where(.svelte-1m6pw9u):focus-within) button:where(.svelte-1m6pw9u) {
70
+ div.svelte-1l34gy2:is(:where(.svelte-1l34gy2):hover, :where(.svelte-1l34gy2):focus-within) button:where(.svelte-1l34gy2) {
68
71
  background-color: color-mix(
69
72
  in srgb,
70
73
  var(--bge-ui-primary-color) 70%,
@@ -72,7 +75,7 @@
72
75
  );
73
76
  }
74
77
 
75
- span.svelte-1m6pw9u {
78
+ span.svelte-1l34gy2 {
76
79
  position: absolute;
77
80
  z-index: 1000;
78
81
  display: none;
@@ -88,11 +91,11 @@
88
91
  border-radius: 0.6em;
89
92
  }
90
93
 
91
- div.svelte-1m6pw9u:is(:where(.svelte-1m6pw9u):hover, :where(.svelte-1m6pw9u):focus-within) span:where(.svelte-1m6pw9u) {
94
+ div.svelte-1l34gy2:is(:where(.svelte-1l34gy2):hover, :where(.svelte-1l34gy2):focus-within) span:where(.svelte-1l34gy2) {
92
95
  display: block;
93
96
  }
94
97
 
95
- .bge-menu-base.svelte-15fci6 {
98
+ .bge-menu-base.svelte-1w3vxpg {
96
99
  position: absolute;
97
100
  inset-block-start: var(--y);
98
101
  inset-inline-start: var(--x);
@@ -101,9 +104,8 @@
101
104
  pointer-events: none;
102
105
  }
103
106
 
104
- .bge-menu-margin.svelte-15fci6 {
107
+ .bge-menu-margin.svelte-1w3vxpg {
105
108
  --_line-color: rgb(from var(--bge-ui-primary-color) r g b / 10%);
106
- container: margin-view / size;
107
109
  position: absolute;
108
110
  inset-block-end: 0;
109
111
  inset-inline-start: 0;
@@ -113,6 +115,7 @@
113
115
  justify-content: center;
114
116
  inline-size: 100%;
115
117
  block-size: var(--margin-block-end);
118
+ container: margin-view / size;
116
119
  font-size: 0.8em;
117
120
  font-weight: bold;
118
121
  color: var(--bge-ui-primary-color);
@@ -127,9 +130,10 @@
127
130
  }
128
131
 
129
132
  @container margin-view (height < 1em) {
130
- .bge-menu-margin.svelte-15fci6 {
131
- span:where(.svelte-15fci6) {
132
- padding: 0.2em 0.4em;
133
+ .bge-menu-margin.svelte-1w3vxpg {
134
+ span:where(.svelte-1w3vxpg) {
135
+ padding-block: 0.2em;
136
+ padding-inline: 0.4em;
133
137
  color: var(--bge-lightest-color);
134
138
  background: var(--bge-ui-primary-color);
135
139
  border-radius: 0.2em;
@@ -137,7 +141,7 @@
137
141
  }
138
142
  }
139
143
 
140
- .bge-menu.svelte-15fci6 {
144
+ .bge-menu.svelte-1w3vxpg {
141
145
  --gap: 0.2em;
142
146
  display: flex;
143
147
  align-items: start;
@@ -149,8 +153,8 @@
149
153
  outline: 4px solid var(--bge-ui-primary-color);
150
154
  }
151
155
 
152
- .bge-move-group.svelte-15fci6,
153
- .bge-standard-group.svelte-15fci6 {
156
+ .bge-move-group.svelte-1w3vxpg,
157
+ .bge-standard-group.svelte-1w3vxpg {
154
158
  inset-block-start: 0;
155
159
  display: flex;
156
160
  gap: var(--gap);
@@ -158,55 +162,57 @@
158
162
  padding: var(--gap);
159
163
  }
160
164
 
161
- .draft-btn.svelte-1t1s8gh {
165
+ .draft-btn.svelte-ivdvt5 {
162
166
  display: flex;
163
167
  justify-content: space-between;
164
168
  }
165
169
 
166
- button.svelte-1t1s8gh {
170
+ button.svelte-ivdvt5 {
167
171
  display: block;
168
- padding: 3px 5px;
172
+ padding-block: 3px;
173
+ padding-inline: 5px;
169
174
  color: #333;
170
175
  text-decoration: none;
171
176
  background-color: var(--bge-background-color01);
172
177
  border: var(--bge-border-primary-color) solid 1px;
173
178
  }
174
179
 
175
- .draft-tab-btn.svelte-1t1s8gh {
180
+ .draft-tab-btn.svelte-ivdvt5 {
176
181
  display: flex;
177
182
  }
178
183
 
179
184
  /* stylelint-disable declaration-no-important */
180
- .draft-tab-btn.svelte-1t1s8gh button[aria-pressed='true']:where(.svelte-1t1s8gh) {
185
+ .draft-tab-btn.svelte-ivdvt5 button[aria-pressed='true']:where(.svelte-ivdvt5) {
181
186
  color: var(--bge-lightest-color) !important;
182
187
  background-color: var(--bge-background-color02) !important;
183
188
  border-color: var(--bge-background-color02) !important;
184
189
  }
190
+
185
191
  /* stylelint-enable declaration-no-important */
186
192
 
187
- .draft-tab-btn.svelte-1t1s8gh button:where(.svelte-1t1s8gh):hover {
193
+ .draft-tab-btn.svelte-ivdvt5 button:where(.svelte-ivdvt5):hover {
188
194
  cursor: pointer;
189
195
  background-color: var(--bge-border-primary-color);
190
196
  }
191
197
 
192
- .draft-tab-btn.svelte-1t1s8gh button:where(.svelte-1t1s8gh) span:where(.svelte-1t1s8gh) {
198
+ .draft-tab-btn.svelte-ivdvt5 button:where(.svelte-ivdvt5) span:where(.svelte-ivdvt5) {
193
199
  margin-inline-start: 0.5em;
194
200
  font-size: 0.8em;
195
201
  }
196
202
 
197
- .draft-tab-btn.svelte-1t1s8gh button:where(.svelte-1t1s8gh) span:where(.svelte-1t1s8gh)::before {
203
+ .draft-tab-btn.svelte-ivdvt5 button:where(.svelte-ivdvt5) span:where(.svelte-ivdvt5)::before {
198
204
  content: '(';
199
205
  }
200
206
 
201
- .draft-tab-btn.svelte-1t1s8gh button:where(.svelte-1t1s8gh) span:where(.svelte-1t1s8gh)::after {
207
+ .draft-tab-btn.svelte-ivdvt5 button:where(.svelte-ivdvt5) span:where(.svelte-ivdvt5)::after {
202
208
  content: ')';
203
209
  }
204
210
 
205
- .draft-copy-btn.svelte-1t1s8gh {
211
+ .draft-copy-btn.svelte-ivdvt5 {
206
212
  display: flex;
207
213
  }
208
214
 
209
- .draft-copy-btn.svelte-1t1s8gh button:where(.svelte-1t1s8gh):hover {
215
+ .draft-copy-btn.svelte-ivdvt5 button:where(.svelte-ivdvt5):hover {
210
216
  cursor: pointer;
211
217
  background-color: var(--bge-border-primary-color);
212
218
  }
@@ -449,316 +455,549 @@
449
455
  list-style: none;
450
456
  }
451
457
 
458
+ :root {
459
+ --border-radius: 0.5em;
460
+ }
461
+
462
+ [role='tablist'].svelte-13cbjzo {
463
+ display: flex;
464
+ gap: 0.5em;
465
+ align-items: center;
466
+ padding-inline: var(--border-radius);
467
+ }
468
+
469
+ [role='tab'].svelte-13cbjzo {
470
+ position: relative;
471
+ border: 1px solid var(--bge-border-color);
472
+ border-end-start-radius: 0;
473
+ border-end-end-radius: 0;
474
+
475
+ &[aria-selected='true'] {
476
+ border-block-end: none;
477
+
478
+ &::after {
479
+ position: absolute;
480
+ inset-block-start: 100%;
481
+ inset-inline-start: 50%;
482
+ display: block;
483
+ inline-size: 1em;
484
+ block-size: 0.5em;
485
+ content: '';
486
+ background-color: var(--bge-ui-primary-color);
487
+ clip-path: polygon(0 0, 50% 100%, 100% 0);
488
+ translate: -50% 0;
489
+ }
490
+ }
491
+ }
492
+
493
+
452
494
  :root {
453
- --bge-lightest-color: #fff;
454
- --bge-darkest-color: #000;
455
- --bge-border-primary-color: #cfd1cf;
456
- --bge-background-color01: #f5f5f5;
457
- --bge-background-color02: #555;
458
- --bge-border-color: #c6c6d8;
459
- --bge-ui-primary-color: #0c7e9e;
460
- --bge-ui-background-color: #eaedf0;
461
- --bge-button-background-color: var(--bge-lightest-color);
462
- --bge-dialog-font-color: #0f1533;
463
- --bge-dialog-background-color: var(--bge-ui-background-color);
464
- --bge-focus-outline-width: 2px;
465
- --bge-tooltip-background-color: rgba(0 0 0 / 60%);
495
+ --bge-lightest-color: #fff;
496
+ --bge-darkest-color: #000;
497
+ --bge-border-primary-color: #cfd1cf;
498
+ --bge-background-color01: #f5f5f5;
499
+ --bge-background-color02: #555;
500
+ --bge-border-color: #c6c6d8;
501
+ --bge-ui-primary-color: #0c7e9e;
502
+ --bge-ui-background-color: #eaedf0;
503
+ --bge-button-background-color: var(--bge-lightest-color);
504
+ --bge-dialog-font-color: #0f1533;
505
+ --bge-dialog-background-color: var(--bge-ui-background-color);
506
+ --bge-focus-outline-width: 2px;
507
+ --bge-tooltip-background-color: rgb(0 0 0 / 60%);
508
+ --bge-font-family-monospace: 'Courier New', monospace;
466
509
  }
467
510
 
468
511
  :where(body:has(dialog[open])) {
469
- overflow: hidden;
512
+ overflow: hidden;
470
513
  }
471
514
 
472
515
  :where(dialog[open]) {
473
- --dialog-margin: 40px;
474
- --dialog-margin-inline: var(--dialog-margin);
475
- --dialog-margin-block: var(--dialog-margin);
476
- --border-radius: 0.5em;
477
- display: grid;
478
- grid-template-rows: minmax(0, 1fr) auto;
479
- inline-size: calc(100vw - var(--dialog-margin-inline) * 2);
480
- max-inline-size: 40em;
481
- max-block-size: calc(100vh - var(--dialog-margin-block) * 2);
482
- padding: 0;
483
- padding-block: 1em;
484
- overscroll-behavior: contain;
485
- color: var(--bge-dialog-font-color);
486
- resize: both;
487
- background: var(--bge-dialog-background-color);
488
- border: none;
489
- border-radius: var(--border-radius);
490
- }
491
- :where(:where(dialog[open]) *) {
492
- box-sizing: border-box;
493
- }
494
- :where(dialog[open])::backdrop {
495
- background: rgba(0, 0, 1, 0.6);
496
- }
497
- :where(dialog[open]):has([data-bge-dialog="2col"]), :where(dialog[open]):has([data-bge-dialog=wide]) {
498
- max-inline-size: 80em;
499
- }
500
- :where(dialog[open])[style*="width:"] {
501
- max-inline-size: none;
502
- }
503
- :where(dialog[open]) > div {
504
- --padding-block: 0em;
505
- --padding-inline: 1em;
506
- padding-block: calc(var(--padding-block) + var(--bge-focus-outline-width));
507
- padding-inline: calc(var(--padding-inline) + var(--bge-focus-outline-width));
508
- overflow: auto;
509
- outline: none;
510
- }
511
- :where(dialog[open]) > div > form {
512
- block-size: max-content;
513
- margin: 0;
514
- }
515
- :where(dialog[open]) > footer {
516
- --padding-block: 1em;
517
- --padding-inline: 1em;
518
- display: flex;
519
- gap: 0.5em;
520
- justify-content: flex-end;
521
- padding-block-start: calc(var(--padding-block) + var(--bge-focus-outline-width));
522
- padding-inline: calc(var(--padding-inline) + var(--bge-focus-outline-width));
523
- background: var(--bge-dialog-background-color);
524
- }
525
- :where(dialog[open]) [data-bge-dialog="2col"] {
526
- display: flex;
527
- gap: 2em;
528
- align-items: flex-start;
529
- }
530
- :where(dialog[open]) [data-bge-dialog="2col"] > div {
531
- flex: 0 0 calc(50% - 1em);
532
- }
533
- :where(dialog[open]) [data-bge-dialog-ui*=sticky] {
534
- position: sticky;
535
- inset-block-start: 0;
536
- z-index: 1;
537
- background: var(--bge-dialog-background-color);
538
- }
516
+ --dialog-margin: 40px;
517
+ --dialog-margin-inline: var(--dialog-margin);
518
+ --dialog-margin-block: var(--dialog-margin);
519
+ --border-radius: 0.5em;
520
+ display: grid;
521
+ grid-template-rows: minmax(0, 1fr) auto;
522
+ inline-size: calc(100vw - (var(--dialog-margin-inline) * 2));
523
+ max-inline-size: 40em;
524
+ max-block-size: calc(100vh - (var(--dialog-margin-block) * 2));
525
+ padding: 0;
526
+ padding-block: 1em;
527
+ overscroll-behavior: contain;
528
+ font-size: 16px;
529
+ color: var(--bge-dialog-font-color);
530
+ resize: both;
531
+ background: var(--bge-dialog-background-color);
532
+ border: none;
533
+ border-radius: var(--border-radius);
539
534
 
540
- :where(dialog[open], [data-bge-component=block-menu]) :where(input:is(:not([type]),
541
- [type=text],
542
- [type=number],
543
- [type=password],
544
- [type=email],
545
- [type=url],
546
- [type=tel],
547
- [type=search],
548
- [type=color],
549
- [type=date],
550
- [type=time],
551
- [type=datetime-local],
552
- [type=month],
553
- [type=week]),
554
- select,
555
- textarea) {
556
- inline-size: 100%;
557
- padding: 0.5em 0.7em;
558
- font-size: inherit;
559
- line-height: 1.1;
560
- border: 1px solid var(--bge-border-color);
561
- border-radius: var(--border-radius);
562
- }
563
- :where(dialog[open], [data-bge-component=block-menu]) :where(input:not([type=radio], [type=checkbox], [type=range]),
564
- select,
565
- textarea,
566
- [contenteditable]) {
567
- background: var(--bge-lightest-color);
568
- }
569
- :where(dialog[open], [data-bge-component=block-menu]) :where(input:not([type=radio], [type=checkbox], [type=range]),
570
- select,
571
- textarea,
572
- [contenteditable]):disabled {
573
- background: initial;
574
- }
575
- :where(dialog[open], [data-bge-component=block-menu]) :where(input, textarea, select, button, [contenteditable]):focus-visible {
576
- --bge-border-color: var(--bge-ui-primary-color);
577
- --bge-outline-color: var(--bge-ui-primary-color);
578
- --allow-color: var(--bge-ui-primary-color);
579
- outline: var(--bge-focus-outline-width) solid var(--bge-outline-color);
580
- }
581
- :where(dialog[open], [data-bge-component=block-menu]) :where(select) {
582
- --allow-size: 0.4em;
583
- --allow-padding: 0.5em;
584
- --allow-color: currentColor;
585
- --separator-width: 1px;
586
- --separator-height: calc(100% - 4px * 2);
587
- --separator-color: var(--bge-border-color);
588
- appearance: none;
589
- background-image: linear-gradient(45deg, transparent 50%, var(--allow-color) 50%), linear-gradient(135deg, var(--allow-color) 50%, transparent 50%), linear-gradient(to right, var(--separator-color), var(--separator-color));
590
- background-repeat: no-repeat;
591
- background-position: right calc(var(--allow-padding) + var(--allow-size) * 2) center, right calc(var(--allow-padding) + var(--allow-size) * 1 + 1px) center, right calc(var(--allow-padding) * 2 + var(--allow-size) * 4) center;
592
- background-size: var(--allow-size) var(--allow-size), var(--allow-size) var(--allow-size), var(--separator-width) var(--separator-height);
593
- }
594
- :where(dialog[open], [data-bge-component=block-menu]) :where(textarea) {
595
- field-sizing: content;
596
- max-block-size: 50vh;
597
- }
598
- :where(dialog[open], [data-bge-component=block-menu]) :where(button) {
599
- padding: 0.5em 1em;
600
- font-size: inherit;
601
- line-height: 1.1;
602
- appearance: none;
603
- cursor: pointer;
604
- background: var(--bge-button-background-color);
605
- border: 1px solid var(--bge-border-color);
606
- border-radius: 0.5em;
607
- }
608
- :where(dialog[open], [data-bge-component=block-menu]) :where(button)[aria-pressed=true] {
609
- color: #fff;
610
- background-color: var(--bge-ui-primary-color);
611
- }
612
- :where(dialog[open], [data-bge-component=block-menu]) :where(button)[aria-pressed=true]:focus-visible {
613
- box-shadow: 0 0 0 2px #fff inset;
614
- }
615
- :where(dialog[open], [data-bge-component=block-menu]) :where(input:is([type=checkbox], [type=radio], [type=range])) {
616
- inline-size: 1.5em;
617
- block-size: 1.5em;
618
- margin: 0;
619
- accent-color: var(--bge-ui-primary-color);
620
- }
621
- :where(dialog[open], [data-bge-component=block-menu]) :where(input:is([type=range])) {
622
- inline-size: 100%;
623
- }
624
- :where(dialog[open], [data-bge-component=block-menu]) :where(label:not([for], :has(+ button))):last-of-type {
625
- padding-block-end: 0;
626
- border-block-end: none;
627
- }
628
- :where(dialog[open], [data-bge-component=block-menu]) :where(label:not([for], :has(+ button))):has(+ small[id]):has(input[aria-describedby]) {
629
- margin-block-end: 0.3em;
630
- }
631
- :where(dialog[open], [data-bge-component=block-menu]) :where(label:not([for])) {
632
- display: block;
633
- }
634
- :where(dialog[open], [data-bge-component=block-menu]) :where(:is(label:not([for]), small[id]) + :is(label:not([for], :has([type=checkbox], [type=radio], [type=range])))) {
635
- padding-block-start: 1em;
636
- margin-block-start: 1em;
637
- border-block-start: 1px solid var(--bge-border-color);
638
- }
639
- :where(dialog[open], [data-bge-component=block-menu]) :where(:is(label:not([for]), small[id]) + fieldset) {
640
- margin-block-start: 1em;
641
- }
642
- :where(dialog[open], [data-bge-component=block-menu]) :where(label:not([for]) > span:has(+ input, + select, + textarea)) {
643
- display: block;
644
- margin-block-end: 0.3em;
645
- }
646
- :where(dialog[open], [data-bge-component=block-menu]) :where(label:not([for]):has(input:is([type=checkbox], [type=radio]))) {
647
- display: flex;
648
- gap: 0.3em;
649
- align-items: center;
650
- }
651
- :where(dialog[open], [data-bge-component=block-menu]) :where(fieldset) {
652
- padding: 1em;
653
- margin-block-end: 1em;
654
- border: 1px solid var(--bge-border-color);
655
- border-radius: 0.5em;
656
- }
657
- :where(dialog[open], [data-bge-component=block-menu]) :where([role=radiogroup]) {
658
- display: flex;
659
- flex-wrap: wrap;
660
- gap: 1em;
661
- margin-block: 0.3em;
662
- }
663
- :where(dialog[open], [data-bge-component=block-menu]) :where([role=radiogroup]) > :not(label):first-child::after {
664
- content: ":";
665
- }
666
- :where(dialog[open], [data-bge-component=block-menu]) :where([role=radiogroup]) > label {
667
- padding: 0;
668
- margin: 0;
669
- border: none;
670
- }
671
- :where(dialog[open], [data-bge-component=block-menu]) :where(hr) {
672
- block-size: 1px;
673
- margin-block: 1em;
674
- background: var(--bge-border-color);
675
- border: none;
676
- }
677
- :where(dialog[open], [data-bge-component=block-menu]) :where(div:has(input):has(> button:last-child)) {
678
- display: flex;
679
- gap: 0.5em;
680
- align-items: center;
681
- justify-content: flex-end;
682
- }
683
- :where(dialog[open], [data-bge-component=block-menu]) :where(div:has(input):has(> button:last-child)):has(> label) {
684
- align-items: flex-end;
685
- }
686
- :where(dialog[open], [data-bge-component=block-menu]) :where(div:has(input):has(> button:last-child)):has(> label) > label {
687
- flex-grow: 1;
688
- }
689
- :where(dialog[open], [data-bge-component=block-menu]) :where(iframe) {
690
- display: block;
691
- inline-size: 100%;
692
- border: none;
693
- }
694
- :where(dialog[open], [data-bge-component=block-menu]) :where(code) {
695
- display: inline-block;
696
- padding: 0.1em 0.3em;
697
- font-weight: bold;
698
- vertical-align: middle;
699
- color: color-mix(in srgb, currentcolor 80%, var(--bge-lightest-color) 20%);
700
- background: color-mix(in srgb, var(--bge-dialog-background-color) 80%, var(--bge-lightest-color) 20%);
701
- border: 1px solid color-mix(in srgb, var(--bge-border-color) 80%, var(--bge-lightest-color) 20%);
702
- border-radius: 0.3em;
703
- }
704
- :where(dialog[open], [data-bge-component=block-menu]) :where([data-bge-editor-ui]) {
705
- margin-block-start: 1em;
706
- }
707
- :where(dialog[open], [data-bge-component=block-menu]) :where([data-bge-editor-ui]):first-child {
708
- margin-block-start: 0;
709
- }
535
+ :where(&, *) {
536
+ box-sizing: border-box;
537
+ }
710
538
 
711
- [data-bge-component$=-editable-area][data-bge-component-mode=visual] iframe {
712
- display: block;
713
- margin: 0 auto;
714
- overflow: hidden;
715
- border: none;
716
- }
717
- [data-bge-component$=-editable-area][data-bge-component-mode=visual] textarea {
718
- display: none;
719
- }
720
- [data-bge-component$=-editable-area][data-bge-component-mode=source] iframe {
721
- display: none;
722
- }
539
+ &::backdrop {
540
+ background: rgb(0 0 1 / 60%);
541
+ }
723
542
 
724
- [data-bgi] {
725
- min-inline-size: 20px;
726
- min-block-size: 20px;
727
- outline: 1px #a6a6a6 dotted;
728
- }
729
- [data-bgi]:hover {
730
- cursor: pointer;
731
- outline: 1px solid var(--bge-ui-primary-color);
732
- background-color: var(--bge-ui-background-color);
543
+ &:has([data-bge-dialog='2col']),
544
+ &:has([data-bge-dialog='wide']) {
545
+ max-inline-size: 80em;
546
+ }
547
+
548
+ &[style*='width:'] {
549
+ max-inline-size: none;
550
+ }
551
+
552
+ > div {
553
+ --padding-block: 0em; /* stylelint-disable-line length-zero-no-unit */
554
+ --padding-inline: 1em;
555
+ padding-block: calc(var(--padding-block) + var(--bge-focus-outline-width));
556
+ padding-inline: calc(var(--padding-inline) + var(--bge-focus-outline-width));
557
+ overflow: auto;
558
+ outline: none;
559
+ }
560
+
561
+ > div > form {
562
+ block-size: max-content;
563
+ margin: 0;
564
+ }
565
+
566
+ > footer {
567
+ --padding-block: 1em;
568
+ --padding-inline: 1em;
569
+ display: flex;
570
+ gap: 0.5em;
571
+ justify-content: flex-end;
572
+ padding-block-start: calc(var(--padding-block) + var(--bge-focus-outline-width));
573
+ padding-inline: calc(var(--padding-inline) + var(--bge-focus-outline-width));
574
+ background: var(--bge-dialog-background-color);
575
+ }
576
+
577
+ [data-bge-dialog='2col'] {
578
+ display: flex;
579
+ gap: 2em;
580
+ align-items: flex-start;
581
+ }
582
+
583
+ [data-bge-dialog='2col'] > div {
584
+ flex: 0 0 calc(50% - 2em / 2);
585
+ }
586
+
587
+ [data-bge-dialog-ui*='sticky'] {
588
+ position: sticky;
589
+ inset-block-start: 0;
590
+ z-index: 1;
591
+ background: var(--bge-dialog-background-color);
592
+ }
593
+ }
594
+
595
+ :where(dialog[open], [data-bge-component='block-menu']) {
596
+ :where(
597
+ input:is(
598
+ :not([type]),
599
+ [type='text'],
600
+ [type='number'],
601
+ [type='password'],
602
+ [type='email'],
603
+ [type='url'],
604
+ [type='tel'],
605
+ [type='search'],
606
+ [type='color'],
607
+ [type='date'],
608
+ [type='time'],
609
+ [type='datetime-local'],
610
+ [type='month'],
611
+ [type='week']
612
+ ),
613
+ select,
614
+ textarea
615
+ ) {
616
+ inline-size: 100%;
617
+ padding-block: 0.5em;
618
+ padding-inline: 0.7em;
619
+ font-size: 1em;
620
+ line-height: 1.1;
621
+ }
622
+
623
+ :where(
624
+ input:not([type='radio'], [type='checkbox'], [type='range']),
625
+ select,
626
+ textarea,
627
+ [contenteditable]
628
+ ) {
629
+ background: var(--bge-lightest-color);
630
+ border: 1px solid var(--bge-border-color);
631
+ border-radius: var(--border-radius);
632
+
633
+ &:disabled {
634
+ background: initial;
635
+ }
636
+ }
637
+
638
+ :where(input, textarea, select, button, [contenteditable]):focus-visible {
639
+ --bge-border-color: var(--bge-ui-primary-color);
640
+ --bge-outline-color: var(--bge-ui-primary-color);
641
+ --allow-color: var(--bge-ui-primary-color);
642
+ outline: var(--bge-focus-outline-width) solid var(--bge-outline-color);
643
+ }
644
+
645
+ :where(select) {
646
+ --allow-size: 0.4em;
647
+ --allow-padding: 0.5em;
648
+ --allow-color: currentColor;
649
+ --separator-width: 1px;
650
+ --separator-height: calc(100% - 4px * 2);
651
+ --separator-color: var(--bge-border-color);
652
+ appearance: none;
653
+ background-image:
654
+ linear-gradient(45deg, transparent 50%, var(--allow-color) 50%),
655
+ linear-gradient(135deg, var(--allow-color) 50%, transparent 50%),
656
+ linear-gradient(to right, var(--separator-color), var(--separator-color));
657
+ background-repeat: no-repeat;
658
+ background-position:
659
+ right calc(var(--allow-padding) + var(--allow-size) * 2) center,
660
+ right calc(var(--allow-padding) + var(--allow-size) * 1 + 1px) center,
661
+ right calc(var(--allow-padding) * 2 + var(--allow-size) * 4) center;
662
+ background-size:
663
+ var(--allow-size) var(--allow-size),
664
+ var(--allow-size) var(--allow-size),
665
+ var(--separator-width) var(--separator-height);
666
+ }
667
+
668
+ :where(textarea) {
669
+ field-sizing: content;
670
+ max-block-size: 50vh;
671
+ }
672
+
673
+ :where(button) {
674
+ padding-block: 0.5em;
675
+ padding-inline: 1em;
676
+ font-size: inherit;
677
+ line-height: 1.1;
678
+ appearance: none;
679
+ cursor: pointer;
680
+ background: var(--bge-button-background-color);
681
+ border: 1px solid var(--bge-border-color);
682
+ border-radius: var(--border-radius);
683
+ }
684
+
685
+ :where(button:is([aria-pressed='true'], [aria-selected='true'])) {
686
+ color: #fff;
687
+ background-color: var(--bge-ui-primary-color);
688
+
689
+ &:focus-visible {
690
+ box-shadow: 0 0 0 2px #fff inset;
691
+ }
692
+ }
693
+
694
+ :where(input:is([type='checkbox'], [type='radio'], [type='range'])) {
695
+ inline-size: 1.5em;
696
+ block-size: 1.5em;
697
+ margin: 0;
698
+ accent-color: var(--bge-ui-primary-color);
699
+ }
700
+
701
+ :where(input:is([type='range'])) {
702
+ inline-size: 100%;
703
+ }
704
+
705
+ :where(label:not([for], :has(+ button))) {
706
+ &:last-of-type {
707
+ padding-block-end: 0;
708
+ border-block-end: none;
709
+ }
710
+
711
+ &:has(+ small[id]):has(input[aria-describedby]) {
712
+ margin-block-end: 0.3em;
713
+ }
714
+ }
715
+
716
+ :where(label:not([for])) {
717
+ display: block;
718
+ }
719
+
720
+ :where(
721
+ :is(label:not([for]), small[id], [role='radiogroup'])
722
+ ~ :is(
723
+ label:not([for]),
724
+ div:has(> label, > span > label):has(> :is(input, select, textarea)),
725
+ [role='radiogroup']
726
+ )
727
+ ) {
728
+ padding-block-start: 1em;
729
+ margin-block-start: 1em;
730
+ border-block-start: 1px solid var(--bge-border-color);
731
+ }
732
+
733
+ :where(:is(label:not([for]), small[id]) + fieldset) {
734
+ margin-block-start: 1em;
735
+ }
736
+
737
+ :where(label:not([for]) > span:has(+ input, + select, + textarea)) {
738
+ display: block;
739
+ margin-block-end: 0.3em;
740
+ }
741
+
742
+ :where(label:not([for]):has(input:is([type='checkbox'], [type='radio']))) {
743
+ display: flex;
744
+ gap: 0.3em;
745
+ align-items: center;
746
+ }
747
+
748
+ :where(fieldset) {
749
+ padding: 1em;
750
+ margin-block-start: 1em;
751
+ border: 1px solid var(--bge-border-color);
752
+ border-radius: var(--border-radius);
753
+
754
+ &:first-child {
755
+ margin-block-start: 0;
756
+ }
757
+ }
758
+
759
+ :where([role='radiogroup']) {
760
+ display: flex;
761
+ flex-wrap: wrap;
762
+ gap: 1em;
763
+
764
+ > :not(label):first-child {
765
+ &::after {
766
+ content: ':';
767
+ }
768
+ }
769
+
770
+ > label {
771
+ padding: 0;
772
+ margin: 0;
773
+ border: none;
774
+ }
775
+ }
776
+
777
+ :where(div:has(input):has(> button:last-child)) {
778
+ display: flex;
779
+ gap: 0.5em;
780
+ align-items: center;
781
+ justify-content: flex-end;
782
+
783
+ &:has(> label) {
784
+ align-items: flex-end;
785
+
786
+ > label {
787
+ flex-grow: 1;
788
+ }
789
+ }
790
+ }
791
+
792
+ :where(iframe) {
793
+ display: block;
794
+ inline-size: 100%;
795
+ border: none;
796
+ }
797
+
798
+ :where(code) {
799
+ display: inline-block;
800
+ padding-block: 0.1em;
801
+ padding-inline: 0.3em;
802
+ font-size: 0.75em;
803
+ font-weight: bold;
804
+ vertical-align: middle;
805
+ color: color-mix(in srgb, currentcolor 80%, var(--bge-lightest-color) 20%);
806
+ background: color-mix(
807
+ in srgb,
808
+ var(--bge-dialog-background-color) 80%,
809
+ var(--bge-lightest-color) 20%
810
+ );
811
+ border: 1px solid
812
+ color-mix(in srgb, var(--bge-border-color) 80%, var(--bge-lightest-color) 20%);
813
+ border-radius: 0.3em;
814
+ }
815
+
816
+ :where(p) {
817
+ &:first-child {
818
+ margin-block-start: 0;
819
+ }
820
+
821
+ &:last-child {
822
+ margin-block-end: 0;
823
+ }
824
+ }
825
+
826
+ :where([data-bge-editor-ui]) {
827
+ margin-block-start: 1em;
828
+
829
+ &:first-child {
830
+ margin-block-start: 0;
831
+ }
832
+ }
833
+
834
+ bge-wysiwyg-editor {
835
+ display: block;
836
+ margin-block-start: 1em;
837
+
838
+ > fieldset {
839
+ margin-block: 0;
840
+ }
841
+
842
+ &:first-child {
843
+ margin-block-start: 0;
844
+ }
845
+
846
+ [data-bge-toolbar] {
847
+ display: flex;
848
+ flex-wrap: wrap;
849
+ gap: 0.25em;
850
+ align-items: center;
851
+ justify-content: space-between;
852
+ margin-block-end: 0.5em;
853
+ }
854
+
855
+ [data-bge-toolbar-group] {
856
+ display: flex;
857
+ flex-wrap: wrap;
858
+ gap: 0.25em;
859
+ align-items: center;
860
+ }
861
+
862
+ [data-bge-toolbar-button] {
863
+ --size: 1lh;
864
+ --stroke-width: 1.5;
865
+ --padding: 0.25em;
866
+ padding: 0.25em;
867
+ font-size: inherit;
868
+ cursor: pointer;
869
+ background: var(--bge-lightest-color);
870
+ border: 1px solid var(--bge-border-color);
871
+ border-radius: var(--border-radius);
872
+
873
+ &:hover,
874
+ &:focus-visible {
875
+ --bge-border-color: var(--bge-ui-primary-color);
876
+ --bge-outline-color: var(--bge-ui-primary-color);
877
+ outline: var(--bge-focus-outline-width) solid var(--bge-outline-color);
878
+ }
879
+
880
+ &:disabled {
881
+ color: inherit;
882
+ cursor: not-allowed;
883
+ outline: none;
884
+ opacity: 0.3;
885
+ }
886
+
887
+ &[aria-pressed='true'] {
888
+ --stroke-width: 2;
889
+ color: #fff;
890
+ background-color: var(--bge-ui-primary-color);
891
+
892
+ &:focus-visible {
893
+ box-shadow: 0 0 0 2px #fff inset;
894
+ }
895
+ }
896
+
897
+ &:not(:has(svg)) {
898
+ padding-inline: calc(var(--padding) * 3);
899
+ }
900
+
901
+ svg {
902
+ inline-size: var(--size);
903
+ block-size: var(--size);
904
+ stroke: currentcolor;
905
+ stroke-width: var(--stroke-width);
906
+ }
907
+
908
+ [data-bge-rotate] {
909
+ display: block;
910
+ rotate: -90deg;
911
+ }
912
+ }
913
+ }
733
914
  }
734
- [data-bgi]:hover img {
735
- filter: brightness(90%);
915
+
916
+ [data-bge-component$='-editable-area'] {
917
+ &[data-bge-component-mode='visual'] {
918
+ iframe {
919
+ display: block;
920
+ margin-block: 0;
921
+ margin-inline: auto;
922
+ overflow: hidden;
923
+ border: none;
924
+ }
925
+
926
+ textarea {
927
+ display: none;
928
+ }
929
+ }
930
+
931
+ &[data-bge-component-mode='source'] {
932
+ iframe {
933
+ display: none;
934
+ }
935
+ }
736
936
  }
737
- [data-bgi] a,
738
- [data-bgi] area,
739
- [data-bgi] button,
740
- [data-bgi] input,
741
- [data-bgi] label,
742
- [data-bgi] select,
743
- [data-bgi] summary,
744
- [data-bgi] textarea,
745
- [data-bgi] iframe {
746
- pointer-events: none;
937
+
938
+ [data-bge-component='editable-area'] [data-bgi] {
939
+ --outline: none;
940
+ min-inline-size: 20px;
941
+ min-block-size: 20px;
942
+ outline: var(--outline);
943
+
944
+ &:where([data-bge-container]:hover &) {
945
+ --outline: 1px #a6a6a6 dotted;
946
+ }
947
+
948
+ &:hover {
949
+ --outline: 1px solid var(--bge-ui-primary-color);
950
+ cursor: pointer;
951
+ background-color: oklch(from currentcolor l c h / 5%);
952
+ background-blend-mode: darken;
953
+
954
+ img {
955
+ filter: brightness(90%);
956
+ }
957
+ }
958
+
959
+ a,
960
+ area,
961
+ button,
962
+ input,
963
+ label,
964
+ select,
965
+ summary,
966
+ textarea,
967
+ iframe {
968
+ pointer-events: none;
969
+ }
747
970
  }
748
971
 
749
972
  button svg.tabler-icon {
750
- inline-size: auto;
751
- block-size: 1em;
973
+ inline-size: auto;
974
+ block-size: 1em;
975
+ }
976
+
977
+ [data-bge-editor-ui-component='thumbnail'] svg.tabler-icon {
978
+ inline-size: 100%;
979
+ block-size: 100%;
752
980
  }
753
981
 
754
- [data-bge-editor-ui-component=thumbnail] svg.tabler-icon {
755
- inline-size: 100%;
756
- block-size: 100%;
982
+ label:has(input[type='radio'][name='bge-scale-type'][value='container']) {
983
+ & > span {
984
+ &::before {
985
+ content: 'コンテナ';
986
+ }
987
+
988
+ &:is([data-bge-container^='grid:'] *, [data-bge-container='grid'] *) {
989
+ &::before {
990
+ content: 'グリッド';
991
+ }
992
+ }
993
+ }
757
994
  }
758
995
 
759
- label:has(input[type=radio][name=bge-scale-type][value=container]) > span::before {
760
- content: "コンテナ";
996
+ [data-bge-editor-ui='tabs'] {
997
+ & + * {
998
+ padding: 1em;
999
+ margin-block: -1px 1em;
1000
+ border: 1px solid var(--bge-border-color);
1001
+ border-radius: 0.5em;
1002
+ }
761
1003
  }
762
- label:has(input[type=radio][name=bge-scale-type][value=container]) > span:is([data-bge-container^="grid:"] *, [data-bge-container=grid] *)::before {
763
- content: "グリッド";
764
- }