@jonsoc/console-app 1.1.34 → 1.1.46

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 (83) hide show
  1. package/package.json +5 -1
  2. package/public/robots.txt +5 -5
  3. package/script/generate-sitemap.ts +0 -0
  4. package/src/app.css +1 -1
  5. package/src/asset/brand/opencode-logo-dark.svg +16 -16
  6. package/src/asset/brand/opencode-logo-light.svg +16 -16
  7. package/src/asset/brand/opencode-wordmark-dark.svg +30 -30
  8. package/src/asset/brand/opencode-wordmark-light.svg +30 -30
  9. package/src/asset/brand/opencode-wordmark-simple-dark.svg +22 -22
  10. package/src/asset/brand/opencode-wordmark-simple-light.svg +22 -22
  11. package/src/asset/lander/brand-assets-dark.svg +10 -10
  12. package/src/asset/lander/brand-assets-light.svg +10 -10
  13. package/src/asset/lander/check.svg +3 -3
  14. package/src/asset/lander/copy.svg +3 -3
  15. package/src/asset/lander/logo-dark.svg +11 -11
  16. package/src/asset/lander/logo-light.svg +11 -11
  17. package/src/asset/lander/opencode-logo-dark.svg +11 -11
  18. package/src/asset/lander/opencode-logo-light.svg +11 -11
  19. package/src/asset/lander/opencode-wordmark-dark.svg +25 -25
  20. package/src/asset/lander/opencode-wordmark-light.svg +25 -25
  21. package/src/asset/lander/wordmark-dark.svg +3 -3
  22. package/src/asset/lander/wordmark-light.svg +3 -3
  23. package/src/asset/logo-ornate-dark.svg +18 -18
  24. package/src/asset/logo-ornate-light.svg +18 -18
  25. package/src/asset/logo.svg +18 -18
  26. package/src/asset/zen-ornate-dark.svg +8 -8
  27. package/src/asset/zen-ornate-light.svg +8 -8
  28. package/src/component/dropdown.css +80 -80
  29. package/src/component/header-context-menu.css +63 -63
  30. package/src/component/modal.css +66 -66
  31. package/src/component/spotlight.css +15 -15
  32. package/src/routes/[...404].css +130 -130
  33. package/src/routes/black/workspace.css +214 -214
  34. package/src/routes/black.css +828 -828
  35. package/src/routes/brand/index.css +555 -555
  36. package/src/routes/changelog/index.css +477 -477
  37. package/src/routes/download/index.css +750 -750
  38. package/src/routes/enterprise/index.css +578 -578
  39. package/src/routes/index.css +1251 -1251
  40. package/src/routes/legal/privacy-policy/index.css +343 -343
  41. package/src/routes/legal/terms-of-service/index.css +254 -254
  42. package/src/routes/user-menu.css +18 -18
  43. package/src/routes/workspace/[id]/billing/billing-section.module.css +185 -185
  44. package/src/routes/workspace/[id]/billing/black-section.module.css +142 -142
  45. package/src/routes/workspace/[id]/billing/black-waitlist-section.module.css +23 -23
  46. package/src/routes/workspace/[id]/billing/monthly-limit-section.module.css +96 -96
  47. package/src/routes/workspace/[id]/billing/payment-section.module.css +93 -93
  48. package/src/routes/workspace/[id]/billing/reload-section.module.css +261 -261
  49. package/src/routes/workspace/[id]/graph-section.module.css +145 -145
  50. package/src/routes/workspace/[id]/keys/key-section.module.css +197 -197
  51. package/src/routes/workspace/[id]/members/member-section.module.css +249 -249
  52. package/src/routes/workspace/[id]/members/role-dropdown.css +72 -72
  53. package/src/routes/workspace/[id]/model-section.module.css +173 -173
  54. package/src/routes/workspace/[id]/new-user-section.module.css +143 -143
  55. package/src/routes/workspace/[id]/provider-section.module.css +138 -138
  56. package/src/routes/workspace/[id]/settings/settings-section.module.css +94 -94
  57. package/src/routes/workspace/[id]/usage-section.module.css +185 -185
  58. package/src/routes/workspace/[id].css +308 -308
  59. package/src/routes/workspace-picker.css +74 -74
  60. package/src/routes/workspace.css +107 -107
  61. package/src/routes/zen/index.css +866 -866
  62. package/src/style/base.css +21 -21
  63. package/src/style/component/button.css +102 -102
  64. package/src/style/index.css +8 -8
  65. package/src/style/reset.css +76 -76
  66. package/src/style/token/color.css +91 -91
  67. package/src/style/token/font.css +21 -21
  68. package/src/style/token/space.css +46 -46
  69. package/public/apple-touch-icon-v3.png +0 -1
  70. package/public/apple-touch-icon.png +0 -1
  71. package/public/email +0 -1
  72. package/public/favicon-96x96-v3.png +0 -1
  73. package/public/favicon-96x96.png +0 -1
  74. package/public/favicon-v3.ico +0 -1
  75. package/public/favicon-v3.svg +0 -1
  76. package/public/favicon.ico +0 -1
  77. package/public/favicon.svg +0 -1
  78. package/public/site.webmanifest +0 -1
  79. package/public/social-share-black.png +0 -1
  80. package/public/social-share-zen.png +0 -1
  81. package/public/social-share.png +0 -1
  82. package/public/web-app-manifest-192x192.png +0 -1
  83. package/public/web-app-manifest-512x512.png +0 -1
@@ -1,185 +1,185 @@
1
- .root {
2
- [data-slot="reload-error"] {
3
- display: flex;
4
- align-items: center;
5
- justify-content: space-between;
6
- gap: var(--space-4);
7
-
8
- p {
9
- color: var(--color-danger);
10
- font-size: var(--font-size-sm);
11
- line-height: 1.4;
12
- margin: 0;
13
- flex: 1;
14
- }
15
-
16
- [data-slot="create-form"] {
17
- display: flex;
18
- gap: var(--space-2);
19
- margin: 0;
20
- flex-shrink: 0;
21
- }
22
- }
23
-
24
- [data-slot="section-content"] {
25
- display: flex;
26
- flex-direction: column;
27
- gap: var(--space-3);
28
- }
29
-
30
- [data-slot="balance-display"] {
31
- display: flex;
32
- align-items: flex-start;
33
- gap: var(--space-3);
34
-
35
- @media (max-width: 30rem) {
36
- flex-direction: column;
37
- align-items: flex-start;
38
- gap: var(--space-2);
39
- }
40
-
41
- [data-slot="balance-amount"] {
42
- display: flex;
43
- flex-direction: column;
44
- align-items: center;
45
- justify-content: center;
46
- text-align: center;
47
- padding: var(--space-4);
48
- border: 1px solid var(--color-border);
49
- border-radius: var(--border-radius-sm);
50
- background-color: var(--color-bg-surface);
51
- align-self: stretch;
52
-
53
- [data-slot="balance-label"] {
54
- font-size: var(--font-size-sm);
55
- color: var(--color-text-muted);
56
- margin-top: var(--space-2);
57
- font-weight: 400;
58
- }
59
-
60
- [data-slot="balance-value"] {
61
- font-size: var(--font-size-2xl);
62
- font-weight: 600;
63
- color: var(--color-text);
64
- }
65
- }
66
-
67
- [data-slot="balance-right-section"] {
68
- display: flex;
69
- flex-direction: column;
70
- gap: var(--space-3);
71
- flex: 1;
72
- }
73
-
74
- [data-slot="add-balance-form-container"] {
75
- display: flex;
76
- flex-direction: column;
77
- gap: var(--space-2);
78
- }
79
-
80
- [data-slot="add-balance-form"] {
81
- display: flex;
82
- flex-direction: row;
83
- align-items: center;
84
- gap: var(--space-3);
85
-
86
- label {
87
- font-size: var(--font-size-sm);
88
- font-weight: 500;
89
- color: var(--color-text-muted);
90
- white-space: nowrap;
91
- }
92
-
93
- input[data-component="input"] {
94
- padding: var(--space-2) var(--space-3);
95
- border: 1px solid var(--color-border);
96
- border-radius: var(--border-radius-sm);
97
- background-color: var(--color-bg);
98
- color: var(--color-text);
99
- font-size: var(--font-size-sm);
100
- line-height: 1.5;
101
-
102
- &:focus {
103
- outline: none;
104
- border-color: var(--color-accent);
105
- box-shadow: 0 0 0 3px var(--color-accent-alpha);
106
- }
107
-
108
- &::placeholder {
109
- color: var(--color-text-disabled);
110
- }
111
- }
112
-
113
- [data-slot="form-actions"] {
114
- display: flex;
115
- gap: var(--space-2);
116
- }
117
- }
118
-
119
- [data-slot="form-error"] {
120
- color: var(--color-danger);
121
- font-size: var(--font-size-sm);
122
- line-height: 1.4;
123
- }
124
-
125
- [data-slot="credit-card"] {
126
- padding: var(--space-2) var(--space-4);
127
- background-color: var(--color-bg-surface);
128
- border-radius: var(--border-radius-sm);
129
- display: flex;
130
- align-items: center;
131
- gap: var(--space-3);
132
- min-width: 150px;
133
- align-self: flex-start;
134
-
135
- [data-slot="card-icon"] {
136
- display: flex;
137
- align-items: center;
138
- color: var(--color-text-muted);
139
- }
140
-
141
- [data-slot="card-details"] {
142
- display: flex;
143
- align-items: baseline;
144
- gap: var(--space-1);
145
- flex: 1;
146
- justify-content: flex-end;
147
-
148
- [data-slot="secret"] {
149
- font-size: var(--font-size-sm);
150
- color: var(--color-text-muted);
151
- font-weight: 400;
152
- }
153
-
154
- [data-slot="number"] {
155
- font-size: var(--font-size-sm);
156
- font-weight: 500;
157
- color: var(--color-text-muted);
158
- }
159
-
160
- [data-slot="type"] {
161
- font-size: var(--font-size-sm);
162
- font-weight: 400;
163
- color: var(--color-text-muted);
164
- }
165
- }
166
-
167
- button {
168
- white-space: nowrap;
169
- flex-shrink: 0;
170
- }
171
- }
172
-
173
- button {
174
- align-self: flex-start;
175
- white-space: nowrap;
176
- flex-shrink: 0;
177
- }
178
- }
179
-
180
- [data-slot="enable-billing-button"] {
181
- align-self: flex-start;
182
- padding: var(--space-4);
183
- min-width: 150px;
184
- }
185
- }
1
+ .root {
2
+ [data-slot="reload-error"] {
3
+ display: flex;
4
+ align-items: center;
5
+ justify-content: space-between;
6
+ gap: var(--space-4);
7
+
8
+ p {
9
+ color: var(--color-danger);
10
+ font-size: var(--font-size-sm);
11
+ line-height: 1.4;
12
+ margin: 0;
13
+ flex: 1;
14
+ }
15
+
16
+ [data-slot="create-form"] {
17
+ display: flex;
18
+ gap: var(--space-2);
19
+ margin: 0;
20
+ flex-shrink: 0;
21
+ }
22
+ }
23
+
24
+ [data-slot="section-content"] {
25
+ display: flex;
26
+ flex-direction: column;
27
+ gap: var(--space-3);
28
+ }
29
+
30
+ [data-slot="balance-display"] {
31
+ display: flex;
32
+ align-items: flex-start;
33
+ gap: var(--space-3);
34
+
35
+ @media (max-width: 30rem) {
36
+ flex-direction: column;
37
+ align-items: flex-start;
38
+ gap: var(--space-2);
39
+ }
40
+
41
+ [data-slot="balance-amount"] {
42
+ display: flex;
43
+ flex-direction: column;
44
+ align-items: center;
45
+ justify-content: center;
46
+ text-align: center;
47
+ padding: var(--space-4);
48
+ border: 1px solid var(--color-border);
49
+ border-radius: var(--border-radius-sm);
50
+ background-color: var(--color-bg-surface);
51
+ align-self: stretch;
52
+
53
+ [data-slot="balance-label"] {
54
+ font-size: var(--font-size-sm);
55
+ color: var(--color-text-muted);
56
+ margin-top: var(--space-2);
57
+ font-weight: 400;
58
+ }
59
+
60
+ [data-slot="balance-value"] {
61
+ font-size: var(--font-size-2xl);
62
+ font-weight: 600;
63
+ color: var(--color-text);
64
+ }
65
+ }
66
+
67
+ [data-slot="balance-right-section"] {
68
+ display: flex;
69
+ flex-direction: column;
70
+ gap: var(--space-3);
71
+ flex: 1;
72
+ }
73
+
74
+ [data-slot="add-balance-form-container"] {
75
+ display: flex;
76
+ flex-direction: column;
77
+ gap: var(--space-2);
78
+ }
79
+
80
+ [data-slot="add-balance-form"] {
81
+ display: flex;
82
+ flex-direction: row;
83
+ align-items: center;
84
+ gap: var(--space-3);
85
+
86
+ label {
87
+ font-size: var(--font-size-sm);
88
+ font-weight: 500;
89
+ color: var(--color-text-muted);
90
+ white-space: nowrap;
91
+ }
92
+
93
+ input[data-component="input"] {
94
+ padding: var(--space-2) var(--space-3);
95
+ border: 1px solid var(--color-border);
96
+ border-radius: var(--border-radius-sm);
97
+ background-color: var(--color-bg);
98
+ color: var(--color-text);
99
+ font-size: var(--font-size-sm);
100
+ line-height: 1.5;
101
+
102
+ &:focus {
103
+ outline: none;
104
+ border-color: var(--color-accent);
105
+ box-shadow: 0 0 0 3px var(--color-accent-alpha);
106
+ }
107
+
108
+ &::placeholder {
109
+ color: var(--color-text-disabled);
110
+ }
111
+ }
112
+
113
+ [data-slot="form-actions"] {
114
+ display: flex;
115
+ gap: var(--space-2);
116
+ }
117
+ }
118
+
119
+ [data-slot="form-error"] {
120
+ color: var(--color-danger);
121
+ font-size: var(--font-size-sm);
122
+ line-height: 1.4;
123
+ }
124
+
125
+ [data-slot="credit-card"] {
126
+ padding: var(--space-2) var(--space-4);
127
+ background-color: var(--color-bg-surface);
128
+ border-radius: var(--border-radius-sm);
129
+ display: flex;
130
+ align-items: center;
131
+ gap: var(--space-3);
132
+ min-width: 150px;
133
+ align-self: flex-start;
134
+
135
+ [data-slot="card-icon"] {
136
+ display: flex;
137
+ align-items: center;
138
+ color: var(--color-text-muted);
139
+ }
140
+
141
+ [data-slot="card-details"] {
142
+ display: flex;
143
+ align-items: baseline;
144
+ gap: var(--space-1);
145
+ flex: 1;
146
+ justify-content: flex-end;
147
+
148
+ [data-slot="secret"] {
149
+ font-size: var(--font-size-sm);
150
+ color: var(--color-text-muted);
151
+ font-weight: 400;
152
+ }
153
+
154
+ [data-slot="number"] {
155
+ font-size: var(--font-size-sm);
156
+ font-weight: 500;
157
+ color: var(--color-text-muted);
158
+ }
159
+
160
+ [data-slot="type"] {
161
+ font-size: var(--font-size-sm);
162
+ font-weight: 400;
163
+ color: var(--color-text-muted);
164
+ }
165
+ }
166
+
167
+ button {
168
+ white-space: nowrap;
169
+ flex-shrink: 0;
170
+ }
171
+ }
172
+
173
+ button {
174
+ align-self: flex-start;
175
+ white-space: nowrap;
176
+ flex-shrink: 0;
177
+ }
178
+ }
179
+
180
+ [data-slot="enable-billing-button"] {
181
+ align-self: flex-start;
182
+ padding: var(--space-4);
183
+ min-width: 150px;
184
+ }
185
+ }
@@ -1,142 +1,142 @@
1
- .root {
2
- [data-slot="title-row"] {
3
- display: flex;
4
- justify-content: space-between;
5
- align-items: center;
6
- gap: var(--space-4);
7
- }
8
-
9
- [data-slot="usage"] {
10
- display: flex;
11
- gap: var(--space-6);
12
- margin-top: var(--space-4);
13
-
14
- @media (max-width: 40rem) {
15
- flex-direction: column;
16
- gap: var(--space-4);
17
- }
18
- }
19
-
20
- [data-slot="usage-item"] {
21
- flex: 1;
22
- display: flex;
23
- flex-direction: column;
24
- gap: var(--space-2);
25
- }
26
-
27
- [data-slot="usage-header"] {
28
- display: flex;
29
- justify-content: space-between;
30
- align-items: baseline;
31
- }
32
-
33
- [data-slot="usage-label"] {
34
- font-size: var(--font-size-md);
35
- font-weight: 500;
36
- color: var(--color-text);
37
- }
38
-
39
- [data-slot="usage-value"] {
40
- font-size: var(--font-size-sm);
41
- color: var(--color-text-muted);
42
- }
43
-
44
- [data-slot="progress"] {
45
- height: 8px;
46
- background-color: var(--color-bg-surface);
47
- border-radius: var(--border-radius-sm);
48
- overflow: hidden;
49
- }
50
-
51
- [data-slot="progress-bar"] {
52
- height: 100%;
53
- background-color: var(--color-accent);
54
- border-radius: var(--border-radius-sm);
55
- transition: width 0.3s ease;
56
- }
57
-
58
- [data-slot="reset-time"] {
59
- font-size: var(--font-size-sm);
60
- color: var(--color-text-muted);
61
- }
62
-
63
- [data-slot="setting-row"] {
64
- display: flex;
65
- align-items: center;
66
- justify-content: space-between;
67
- gap: var(--space-3);
68
- margin-top: var(--space-4);
69
-
70
- p {
71
- font-size: var(--font-size-sm);
72
- line-height: 1.5;
73
- color: var(--color-text-secondary);
74
- margin: 0;
75
- }
76
- }
77
-
78
- [data-slot="toggle-label"] {
79
- position: relative;
80
- display: inline-block;
81
- width: 2.5rem;
82
- height: 1.5rem;
83
- cursor: pointer;
84
- flex-shrink: 0;
85
-
86
- input {
87
- opacity: 0;
88
- width: 0;
89
- height: 0;
90
- }
91
-
92
- span {
93
- position: absolute;
94
- inset: 0;
95
- background-color: #ccc;
96
- border: 1px solid #bbb;
97
- border-radius: 1.5rem;
98
- transition: all 0.3s ease;
99
- cursor: pointer;
100
-
101
- &::before {
102
- content: "";
103
- position: absolute;
104
- top: 50%;
105
- left: 0.125rem;
106
- width: 1.25rem;
107
- height: 1.25rem;
108
- background-color: white;
109
- border: 1px solid #ddd;
110
- border-radius: 50%;
111
- transform: translateY(-50%);
112
- transition: all 0.3s ease;
113
- }
114
- }
115
-
116
- input:checked + span {
117
- background-color: #21ad0e;
118
- border-color: #148605;
119
-
120
- &::before {
121
- transform: translateX(1rem) translateY(-50%);
122
- }
123
- }
124
-
125
- &:hover span {
126
- box-shadow: 0 0 0 2px rgba(34, 197, 94, 0.2);
127
- }
128
-
129
- input:checked:hover + span {
130
- box-shadow: 0 0 0 2px rgba(34, 197, 94, 0.3);
131
- }
132
-
133
- &:has(input:disabled) {
134
- cursor: not-allowed;
135
- }
136
-
137
- input:disabled + span {
138
- opacity: 0.5;
139
- cursor: not-allowed;
140
- }
141
- }
142
- }
1
+ .root {
2
+ [data-slot="title-row"] {
3
+ display: flex;
4
+ justify-content: space-between;
5
+ align-items: center;
6
+ gap: var(--space-4);
7
+ }
8
+
9
+ [data-slot="usage"] {
10
+ display: flex;
11
+ gap: var(--space-6);
12
+ margin-top: var(--space-4);
13
+
14
+ @media (max-width: 40rem) {
15
+ flex-direction: column;
16
+ gap: var(--space-4);
17
+ }
18
+ }
19
+
20
+ [data-slot="usage-item"] {
21
+ flex: 1;
22
+ display: flex;
23
+ flex-direction: column;
24
+ gap: var(--space-2);
25
+ }
26
+
27
+ [data-slot="usage-header"] {
28
+ display: flex;
29
+ justify-content: space-between;
30
+ align-items: baseline;
31
+ }
32
+
33
+ [data-slot="usage-label"] {
34
+ font-size: var(--font-size-md);
35
+ font-weight: 500;
36
+ color: var(--color-text);
37
+ }
38
+
39
+ [data-slot="usage-value"] {
40
+ font-size: var(--font-size-sm);
41
+ color: var(--color-text-muted);
42
+ }
43
+
44
+ [data-slot="progress"] {
45
+ height: 8px;
46
+ background-color: var(--color-bg-surface);
47
+ border-radius: var(--border-radius-sm);
48
+ overflow: hidden;
49
+ }
50
+
51
+ [data-slot="progress-bar"] {
52
+ height: 100%;
53
+ background-color: var(--color-accent);
54
+ border-radius: var(--border-radius-sm);
55
+ transition: width 0.3s ease;
56
+ }
57
+
58
+ [data-slot="reset-time"] {
59
+ font-size: var(--font-size-sm);
60
+ color: var(--color-text-muted);
61
+ }
62
+
63
+ [data-slot="setting-row"] {
64
+ display: flex;
65
+ align-items: center;
66
+ justify-content: space-between;
67
+ gap: var(--space-3);
68
+ margin-top: var(--space-4);
69
+
70
+ p {
71
+ font-size: var(--font-size-sm);
72
+ line-height: 1.5;
73
+ color: var(--color-text-secondary);
74
+ margin: 0;
75
+ }
76
+ }
77
+
78
+ [data-slot="toggle-label"] {
79
+ position: relative;
80
+ display: inline-block;
81
+ width: 2.5rem;
82
+ height: 1.5rem;
83
+ cursor: pointer;
84
+ flex-shrink: 0;
85
+
86
+ input {
87
+ opacity: 0;
88
+ width: 0;
89
+ height: 0;
90
+ }
91
+
92
+ span {
93
+ position: absolute;
94
+ inset: 0;
95
+ background-color: #ccc;
96
+ border: 1px solid #bbb;
97
+ border-radius: 1.5rem;
98
+ transition: all 0.3s ease;
99
+ cursor: pointer;
100
+
101
+ &::before {
102
+ content: "";
103
+ position: absolute;
104
+ top: 50%;
105
+ left: 0.125rem;
106
+ width: 1.25rem;
107
+ height: 1.25rem;
108
+ background-color: white;
109
+ border: 1px solid #ddd;
110
+ border-radius: 50%;
111
+ transform: translateY(-50%);
112
+ transition: all 0.3s ease;
113
+ }
114
+ }
115
+
116
+ input:checked + span {
117
+ background-color: #21ad0e;
118
+ border-color: #148605;
119
+
120
+ &::before {
121
+ transform: translateX(1rem) translateY(-50%);
122
+ }
123
+ }
124
+
125
+ &:hover span {
126
+ box-shadow: 0 0 0 2px rgba(34, 197, 94, 0.2);
127
+ }
128
+
129
+ input:checked:hover + span {
130
+ box-shadow: 0 0 0 2px rgba(34, 197, 94, 0.3);
131
+ }
132
+
133
+ &:has(input:disabled) {
134
+ cursor: not-allowed;
135
+ }
136
+
137
+ input:disabled + span {
138
+ opacity: 0.5;
139
+ cursor: not-allowed;
140
+ }
141
+ }
142
+ }