@takuhon/ui 0.8.2 → 0.10.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.
@@ -0,0 +1,116 @@
1
+ .editor {
2
+ max-inline-size: var(--takuhon-max-content-width);
3
+ margin-inline: auto;
4
+ padding: var(--takuhon-space-4);
5
+ font-family: var(--takuhon-font-family);
6
+ color: var(--takuhon-color-text);
7
+ background-color: var(--takuhon-color-bg);
8
+ }
9
+
10
+ .toolbar {
11
+ display: flex;
12
+ flex-wrap: wrap;
13
+ gap: var(--takuhon-space-3);
14
+ align-items: center;
15
+ justify-content: space-between;
16
+ position: sticky;
17
+ inset-block-start: 0;
18
+ z-index: 1;
19
+ padding-block: var(--takuhon-space-3);
20
+ background-color: var(--takuhon-color-bg);
21
+ border-block-end: 1px solid var(--takuhon-color-border);
22
+ }
23
+
24
+ .modes,
25
+ .actions {
26
+ display: flex;
27
+ flex-wrap: wrap;
28
+ gap: var(--takuhon-space-2);
29
+ }
30
+
31
+ .modeButton,
32
+ .primary,
33
+ .secondary {
34
+ min-height: var(--takuhon-tap-target);
35
+ padding-inline: var(--takuhon-space-4);
36
+ border: 1px solid var(--takuhon-color-border);
37
+ border-radius: var(--takuhon-radius-sm);
38
+ background-color: var(--takuhon-color-bg);
39
+ color: var(--takuhon-color-text);
40
+ font-family: var(--takuhon-font-family);
41
+ font-size: var(--takuhon-font-size-base);
42
+ cursor: pointer;
43
+ }
44
+
45
+ .modeButton:focus-visible,
46
+ .primary:focus-visible,
47
+ .secondary:focus-visible {
48
+ outline: 2px solid var(--takuhon-color-primary);
49
+ outline-offset: 2px;
50
+ }
51
+
52
+ .modeActive {
53
+ background-color: var(--takuhon-color-surface);
54
+ font-weight: 600;
55
+ }
56
+
57
+ .primary {
58
+ background-color: var(--takuhon-color-primary);
59
+ color: var(--takuhon-color-primary-contrast);
60
+ border-color: var(--takuhon-color-primary);
61
+ font-weight: 600;
62
+ }
63
+
64
+ .primary:disabled,
65
+ .secondary:disabled {
66
+ opacity: 0.5;
67
+ cursor: not-allowed;
68
+ }
69
+
70
+ .status {
71
+ min-block-size: var(--takuhon-space-5);
72
+ margin: var(--takuhon-space-3) 0;
73
+ font-size: var(--takuhon-font-size-sm);
74
+ }
75
+
76
+ .status[data-tone='success'] {
77
+ color: #027a48;
78
+ }
79
+
80
+ .status[data-tone='error'] {
81
+ color: #b42318;
82
+ }
83
+
84
+ .summary {
85
+ margin-block-end: var(--takuhon-space-4);
86
+ padding: var(--takuhon-space-3);
87
+ border: 1px solid #b42318;
88
+ border-radius: var(--takuhon-radius-sm);
89
+ color: #b42318;
90
+ }
91
+
92
+ .summaryHeading {
93
+ margin: 0 0 var(--takuhon-space-2);
94
+ font-size: var(--takuhon-font-size-base);
95
+ font-weight: 600;
96
+ }
97
+
98
+ .sections {
99
+ display: flex;
100
+ flex-direction: column;
101
+ }
102
+
103
+ @media (prefers-color-scheme: dark) {
104
+ .status[data-tone='success'] {
105
+ color: #6ce9a6;
106
+ }
107
+
108
+ .status[data-tone='error'],
109
+ .summary {
110
+ color: #fda29b;
111
+ }
112
+
113
+ .summary {
114
+ border-color: #fda29b;
115
+ }
116
+ }
@@ -0,0 +1,34 @@
1
+ .field {
2
+ display: flex;
3
+ flex-direction: column;
4
+ gap: var(--takuhon-space-1);
5
+ margin-block-end: var(--takuhon-space-4);
6
+ }
7
+
8
+ .label {
9
+ font-family: var(--takuhon-font-family);
10
+ font-size: var(--takuhon-font-size-sm);
11
+ font-weight: 600;
12
+ color: var(--takuhon-color-text);
13
+ }
14
+
15
+ .hint {
16
+ margin: 0;
17
+ font-family: var(--takuhon-font-family);
18
+ font-size: var(--takuhon-font-size-sm);
19
+ color: var(--takuhon-color-text-muted);
20
+ }
21
+
22
+ .errors {
23
+ margin: 0;
24
+ padding-inline-start: var(--takuhon-space-4);
25
+ font-family: var(--takuhon-font-family);
26
+ font-size: var(--takuhon-font-size-sm);
27
+ color: #b42318;
28
+ }
29
+
30
+ @media (prefers-color-scheme: dark) {
31
+ .errors {
32
+ color: #fda29b;
33
+ }
34
+ }
@@ -0,0 +1,116 @@
1
+ .group {
2
+ display: flex;
3
+ flex-direction: column;
4
+ gap: var(--takuhon-space-1);
5
+ margin-block-end: var(--takuhon-space-4);
6
+ }
7
+
8
+ .groupLabel {
9
+ font-family: var(--takuhon-font-family);
10
+ font-size: var(--takuhon-font-size-sm);
11
+ font-weight: 600;
12
+ color: var(--takuhon-color-text);
13
+ }
14
+
15
+ .hint {
16
+ margin: 0;
17
+ font-family: var(--takuhon-font-family);
18
+ font-size: var(--takuhon-font-size-sm);
19
+ color: var(--takuhon-color-text-muted);
20
+ }
21
+
22
+ .tablist {
23
+ display: flex;
24
+ flex-wrap: wrap;
25
+ gap: var(--takuhon-space-1);
26
+ }
27
+
28
+ .tab {
29
+ min-height: var(--takuhon-tap-target);
30
+ padding-inline: var(--takuhon-space-3);
31
+ border: 1px solid var(--takuhon-color-border);
32
+ border-radius: var(--takuhon-radius-sm) var(--takuhon-radius-sm) 0 0;
33
+ background-color: var(--takuhon-color-surface);
34
+ color: var(--takuhon-color-text-muted);
35
+ font-family: var(--takuhon-font-family);
36
+ font-size: var(--takuhon-font-size-sm);
37
+ cursor: pointer;
38
+ }
39
+
40
+ .tab:focus-visible {
41
+ outline: 2px solid var(--takuhon-color-primary);
42
+ outline-offset: 2px;
43
+ }
44
+
45
+ .tabActive {
46
+ background-color: var(--takuhon-color-bg);
47
+ color: var(--takuhon-color-text);
48
+ border-block-end-color: var(--takuhon-color-bg);
49
+ font-weight: 600;
50
+ }
51
+
52
+ .tabError {
53
+ color: #b42318;
54
+ }
55
+
56
+ .srOnly {
57
+ position: absolute;
58
+ width: 1px;
59
+ height: 1px;
60
+ padding: 0;
61
+ margin: -1px;
62
+ overflow: hidden;
63
+ clip: rect(0, 0, 0, 0);
64
+ white-space: nowrap;
65
+ border: 0;
66
+ }
67
+
68
+ .panel {
69
+ display: flex;
70
+ flex-direction: column;
71
+ gap: var(--takuhon-space-1);
72
+ }
73
+
74
+ .control {
75
+ inline-size: 100%;
76
+ box-sizing: border-box;
77
+ min-height: var(--takuhon-tap-target);
78
+ padding-inline: var(--takuhon-space-3);
79
+ padding-block: var(--takuhon-space-2);
80
+ border: 1px solid var(--takuhon-color-border);
81
+ border-radius: var(--takuhon-radius-sm);
82
+ background-color: var(--takuhon-color-bg);
83
+ color: var(--takuhon-color-text);
84
+ font-family: var(--takuhon-font-family);
85
+ font-size: var(--takuhon-font-size-base);
86
+ line-height: var(--takuhon-line-height);
87
+ }
88
+
89
+ .control:focus-visible {
90
+ outline: 2px solid var(--takuhon-color-primary);
91
+ outline-offset: 2px;
92
+ }
93
+
94
+ .control[aria-invalid='true'] {
95
+ border-color: #b42318;
96
+ }
97
+
98
+ .textarea {
99
+ min-height: calc(var(--takuhon-tap-target) * 2);
100
+ resize: vertical;
101
+ }
102
+
103
+ .errors {
104
+ margin: 0;
105
+ padding-inline-start: var(--takuhon-space-4);
106
+ font-family: var(--takuhon-font-family);
107
+ font-size: var(--takuhon-font-size-sm);
108
+ color: #b42318;
109
+ }
110
+
111
+ @media (prefers-color-scheme: dark) {
112
+ .tabError,
113
+ .errors {
114
+ color: #fda29b;
115
+ }
116
+ }
@@ -0,0 +1,64 @@
1
+ .wrapper {
2
+ margin-block-end: var(--takuhon-space-5);
3
+ }
4
+
5
+ .heading {
6
+ margin: 0 0 var(--takuhon-space-2);
7
+ font-family: var(--takuhon-font-family);
8
+ font-size: var(--takuhon-font-size-xl);
9
+ font-weight: 700;
10
+ color: var(--takuhon-color-text);
11
+ }
12
+
13
+ .hint {
14
+ margin: 0 0 var(--takuhon-space-3);
15
+ font-family: var(--takuhon-font-family);
16
+ font-size: var(--takuhon-font-size-sm);
17
+ color: var(--takuhon-color-text-muted);
18
+ }
19
+
20
+ .textarea {
21
+ inline-size: 100%;
22
+ min-block-size: 60vh;
23
+ box-sizing: border-box;
24
+ padding: var(--takuhon-space-3);
25
+ border: 1px solid var(--takuhon-color-border);
26
+ border-radius: var(--takuhon-radius-sm);
27
+ background-color: var(--takuhon-color-bg);
28
+ color: var(--takuhon-color-text);
29
+ font-family: ui-monospace, 'SFMono-Regular', Menlo, Consolas, monospace;
30
+ font-size: var(--takuhon-font-size-sm);
31
+ line-height: var(--takuhon-line-height);
32
+ resize: vertical;
33
+ }
34
+
35
+ .textarea:focus-visible {
36
+ outline: 2px solid var(--takuhon-color-primary);
37
+ outline-offset: 2px;
38
+ }
39
+
40
+ .textarea[aria-invalid='true'] {
41
+ border-color: #b42318;
42
+ }
43
+
44
+ .problems {
45
+ margin-block-start: var(--takuhon-space-3);
46
+ padding: var(--takuhon-space-3);
47
+ border: 1px solid #b42318;
48
+ border-radius: var(--takuhon-radius-sm);
49
+ font-family: var(--takuhon-font-family);
50
+ font-size: var(--takuhon-font-size-sm);
51
+ color: #b42318;
52
+ }
53
+
54
+ .problemsTitle {
55
+ margin: 0 0 var(--takuhon-space-2);
56
+ font-weight: 600;
57
+ }
58
+
59
+ @media (prefers-color-scheme: dark) {
60
+ .problems {
61
+ color: #fda29b;
62
+ border-color: #fda29b;
63
+ }
64
+ }
@@ -0,0 +1,102 @@
1
+ .fieldset {
2
+ margin: 0;
3
+ margin-block-end: var(--takuhon-space-5);
4
+ padding: var(--takuhon-space-4);
5
+ border: 1px solid var(--takuhon-color-border);
6
+ border-radius: var(--takuhon-radius-md);
7
+ }
8
+
9
+ .legend {
10
+ padding-inline: var(--takuhon-space-2);
11
+ font-family: var(--takuhon-font-family);
12
+ font-size: var(--takuhon-font-size-lg);
13
+ font-weight: 600;
14
+ color: var(--takuhon-color-text);
15
+ }
16
+
17
+ .empty {
18
+ margin: 0 0 var(--takuhon-space-3);
19
+ font-family: var(--takuhon-font-family);
20
+ font-size: var(--takuhon-font-size-sm);
21
+ color: var(--takuhon-color-text-muted);
22
+ }
23
+
24
+ .list {
25
+ list-style: none;
26
+ margin: 0;
27
+ padding: 0;
28
+ display: flex;
29
+ flex-direction: column;
30
+ gap: var(--takuhon-space-4);
31
+ }
32
+
33
+ .item {
34
+ padding: var(--takuhon-space-3);
35
+ border: 1px solid var(--takuhon-color-border);
36
+ border-radius: var(--takuhon-radius-sm);
37
+ background-color: var(--takuhon-color-surface);
38
+ }
39
+
40
+ .itemHeader {
41
+ display: flex;
42
+ flex-wrap: wrap;
43
+ align-items: center;
44
+ justify-content: space-between;
45
+ gap: var(--takuhon-space-2);
46
+ margin-block-end: var(--takuhon-space-3);
47
+ }
48
+
49
+ .itemCaption {
50
+ flex: 1 1 auto;
51
+ min-inline-size: 0;
52
+ overflow-wrap: anywhere;
53
+ font-family: var(--takuhon-font-family);
54
+ font-size: var(--takuhon-font-size-base);
55
+ font-weight: 600;
56
+ color: var(--takuhon-color-text);
57
+ }
58
+
59
+ .itemActions {
60
+ display: flex;
61
+ gap: var(--takuhon-space-1);
62
+ }
63
+
64
+ .itemBody {
65
+ display: flex;
66
+ flex-direction: column;
67
+ }
68
+
69
+ .iconButton,
70
+ .removeButton,
71
+ .addButton {
72
+ min-height: var(--takuhon-tap-target);
73
+ min-width: var(--takuhon-tap-target);
74
+ padding-inline: var(--takuhon-space-3);
75
+ border: 1px solid var(--takuhon-color-border);
76
+ border-radius: var(--takuhon-radius-sm);
77
+ background-color: var(--takuhon-color-bg);
78
+ color: var(--takuhon-color-text);
79
+ font-family: var(--takuhon-font-family);
80
+ font-size: var(--takuhon-font-size-base);
81
+ cursor: pointer;
82
+ }
83
+
84
+ .iconButton:disabled {
85
+ opacity: 0.4;
86
+ cursor: not-allowed;
87
+ }
88
+
89
+ .iconButton:focus-visible,
90
+ .removeButton:focus-visible,
91
+ .addButton:focus-visible {
92
+ outline: 2px solid var(--takuhon-color-primary);
93
+ outline-offset: 2px;
94
+ }
95
+
96
+ .addButton {
97
+ margin-block-start: var(--takuhon-space-4);
98
+ background-color: var(--takuhon-color-primary);
99
+ color: var(--takuhon-color-primary-contrast);
100
+ border-color: var(--takuhon-color-primary);
101
+ font-weight: 600;
102
+ }