solforge 0.2.12 → 0.2.14

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 (175) hide show
  1. package/package.json +1 -5
  2. package/start.cjs +19 -23
  3. package/docs/API.md +0 -379
  4. package/docs/CONFIGURATION.md +0 -407
  5. package/docs/bun-single-file-executable.md +0 -585
  6. package/docs/cli-plan.md +0 -154
  7. package/docs/data-indexing-plan.md +0 -214
  8. package/docs/gui-roadmap.md +0 -202
  9. package/scripts/decode-b58.ts +0 -10
  10. package/scripts/install.sh +0 -112
  11. package/server/index.ts +0 -5
  12. package/server/lib/base58.ts +0 -33
  13. package/server/lib/faucet.ts +0 -110
  14. package/server/lib/instruction-parser.ts +0 -328
  15. package/server/lib/parsers/spl-associated-token-account.ts +0 -50
  16. package/server/lib/parsers/spl-token.ts +0 -340
  17. package/server/lib/spl-token.ts +0 -57
  18. package/server/methods/TEMPLATE.md +0 -117
  19. package/server/methods/account/get-account-info.ts +0 -86
  20. package/server/methods/account/get-balance.ts +0 -23
  21. package/server/methods/account/get-multiple-accounts.ts +0 -84
  22. package/server/methods/account/get-parsed-account-info.ts +0 -17
  23. package/server/methods/account/index.ts +0 -12
  24. package/server/methods/account/parsers/index.ts +0 -52
  25. package/server/methods/account/parsers/loader-upgradeable.ts +0 -79
  26. package/server/methods/account/parsers/spl-token.ts +0 -256
  27. package/server/methods/account/parsers/system.ts +0 -4
  28. package/server/methods/account/request-airdrop.ts +0 -271
  29. package/server/methods/admin/adopt-mint-authority.ts +0 -94
  30. package/server/methods/admin/clone-program-accounts.ts +0 -55
  31. package/server/methods/admin/clone-program.ts +0 -152
  32. package/server/methods/admin/clone-token-accounts.ts +0 -117
  33. package/server/methods/admin/clone-token-mint.ts +0 -82
  34. package/server/methods/admin/create-mint.ts +0 -114
  35. package/server/methods/admin/create-token-account.ts +0 -137
  36. package/server/methods/admin/helpers.ts +0 -70
  37. package/server/methods/admin/index.ts +0 -10
  38. package/server/methods/admin/list-mints.ts +0 -21
  39. package/server/methods/admin/load-program.ts +0 -52
  40. package/server/methods/admin/mint-to.ts +0 -266
  41. package/server/methods/block/get-block-height.ts +0 -5
  42. package/server/methods/block/get-block.ts +0 -31
  43. package/server/methods/block/get-blocks-with-limit.ts +0 -19
  44. package/server/methods/block/get-latest-blockhash.ts +0 -12
  45. package/server/methods/block/get-slot.ts +0 -5
  46. package/server/methods/block/index.ts +0 -6
  47. package/server/methods/block/is-blockhash-valid.ts +0 -19
  48. package/server/methods/epoch/get-cluster-nodes.ts +0 -17
  49. package/server/methods/epoch/get-epoch-info.ts +0 -16
  50. package/server/methods/epoch/get-epoch-schedule.ts +0 -15
  51. package/server/methods/epoch/get-highest-snapshot-slot.ts +0 -9
  52. package/server/methods/epoch/get-leader-schedule.ts +0 -8
  53. package/server/methods/epoch/get-max-retransmit-slot.ts +0 -9
  54. package/server/methods/epoch/get-max-shred-insert-slot.ts +0 -9
  55. package/server/methods/epoch/get-slot-leader.ts +0 -6
  56. package/server/methods/epoch/get-slot-leaders.ts +0 -9
  57. package/server/methods/epoch/get-stake-activation.ts +0 -9
  58. package/server/methods/epoch/get-stake-minimum-delegation.ts +0 -9
  59. package/server/methods/epoch/get-vote-accounts.ts +0 -19
  60. package/server/methods/epoch/index.ts +0 -13
  61. package/server/methods/epoch/minimum-ledger-slot.ts +0 -5
  62. package/server/methods/fee/get-fee-calculator-for-blockhash.ts +0 -12
  63. package/server/methods/fee/get-fee-for-message.ts +0 -8
  64. package/server/methods/fee/get-fee-rate-governor.ts +0 -16
  65. package/server/methods/fee/get-fees.ts +0 -14
  66. package/server/methods/fee/get-recent-prioritization-fees.ts +0 -22
  67. package/server/methods/fee/index.ts +0 -5
  68. package/server/methods/get-address-lookup-table.ts +0 -27
  69. package/server/methods/index.ts +0 -265
  70. package/server/methods/performance/get-recent-performance-samples.ts +0 -25
  71. package/server/methods/performance/get-transaction-count.ts +0 -5
  72. package/server/methods/performance/index.ts +0 -2
  73. package/server/methods/program/get-block-commitment.ts +0 -9
  74. package/server/methods/program/get-block-production.ts +0 -14
  75. package/server/methods/program/get-block-time.ts +0 -21
  76. package/server/methods/program/get-blocks.ts +0 -11
  77. package/server/methods/program/get-first-available-block.ts +0 -9
  78. package/server/methods/program/get-genesis-hash.ts +0 -6
  79. package/server/methods/program/get-identity.ts +0 -6
  80. package/server/methods/program/get-inflation-governor.ts +0 -15
  81. package/server/methods/program/get-inflation-rate.ts +0 -10
  82. package/server/methods/program/get-inflation-reward.ts +0 -12
  83. package/server/methods/program/get-largest-accounts.ts +0 -8
  84. package/server/methods/program/get-parsed-program-accounts.ts +0 -12
  85. package/server/methods/program/get-parsed-token-accounts-by-delegate.ts +0 -12
  86. package/server/methods/program/get-parsed-token-accounts-by-owner.ts +0 -12
  87. package/server/methods/program/get-program-accounts.ts +0 -221
  88. package/server/methods/program/get-supply.ts +0 -13
  89. package/server/methods/program/get-token-account-balance.ts +0 -60
  90. package/server/methods/program/get-token-accounts-by-delegate.ts +0 -82
  91. package/server/methods/program/get-token-accounts-by-owner.ts +0 -416
  92. package/server/methods/program/get-token-largest-accounts.ts +0 -81
  93. package/server/methods/program/get-token-supply.ts +0 -39
  94. package/server/methods/program/index.ts +0 -21
  95. package/server/methods/solforge/index.ts +0 -158
  96. package/server/methods/system/get-health.ts +0 -5
  97. package/server/methods/system/get-minimum-balance-for-rent-exemption.ts +0 -13
  98. package/server/methods/system/get-version.ts +0 -9
  99. package/server/methods/system/index.ts +0 -3
  100. package/server/methods/transaction/get-confirmed-transaction.ts +0 -11
  101. package/server/methods/transaction/get-parsed-transaction.ts +0 -17
  102. package/server/methods/transaction/get-signature-statuses.ts +0 -79
  103. package/server/methods/transaction/get-signatures-for-address.ts +0 -41
  104. package/server/methods/transaction/get-transaction.ts +0 -639
  105. package/server/methods/transaction/index.ts +0 -7
  106. package/server/methods/transaction/inner-instructions.test.ts +0 -104
  107. package/server/methods/transaction/send-transaction.ts +0 -469
  108. package/server/methods/transaction/simulate-transaction.ts +0 -57
  109. package/server/rpc-server.ts +0 -521
  110. package/server/types.ts +0 -109
  111. package/server/ws-server.ts +0 -178
  112. package/src/api-server-entry.ts +0 -109
  113. package/src/cli/bootstrap.ts +0 -67
  114. package/src/cli/commands/airdrop.ts +0 -37
  115. package/src/cli/commands/config.ts +0 -39
  116. package/src/cli/commands/mint.ts +0 -187
  117. package/src/cli/commands/program-clone.ts +0 -122
  118. package/src/cli/commands/program-load.ts +0 -64
  119. package/src/cli/commands/rpc-start.ts +0 -49
  120. package/src/cli/commands/token-adopt-authority.ts +0 -37
  121. package/src/cli/commands/token-clone.ts +0 -112
  122. package/src/cli/commands/token-create.ts +0 -81
  123. package/src/cli/main.ts +0 -158
  124. package/src/cli/run-solforge.ts +0 -112
  125. package/src/cli/setup-utils.ts +0 -54
  126. package/src/cli/setup-wizard.ts +0 -258
  127. package/src/cli/utils/args.ts +0 -15
  128. package/src/commands/add-program.ts +0 -333
  129. package/src/commands/init.ts +0 -122
  130. package/src/commands/list.ts +0 -136
  131. package/src/commands/mint.ts +0 -287
  132. package/src/commands/start.ts +0 -881
  133. package/src/commands/status.ts +0 -99
  134. package/src/commands/stop.ts +0 -405
  135. package/src/config/index.ts +0 -146
  136. package/src/config/manager.ts +0 -157
  137. package/src/db/index.ts +0 -83
  138. package/src/db/schema/accounts.ts +0 -23
  139. package/src/db/schema/address-signatures.ts +0 -31
  140. package/src/db/schema/index.ts +0 -6
  141. package/src/db/schema/meta-kv.ts +0 -9
  142. package/src/db/schema/transactions.ts +0 -36
  143. package/src/db/schema/tx-account-states.ts +0 -23
  144. package/src/db/schema/tx-accounts.ts +0 -33
  145. package/src/db/tx-store.ts +0 -264
  146. package/src/gui/public/app.css +0 -1556
  147. package/src/gui/public/build/main.css +0 -1569
  148. package/src/gui/public/build/main.js +0 -303
  149. package/src/gui/public/build/main.js.txt +0 -231
  150. package/src/gui/public/index.html +0 -19
  151. package/src/gui/server.ts +0 -296
  152. package/src/gui/src/api.ts +0 -127
  153. package/src/gui/src/app.tsx +0 -441
  154. package/src/gui/src/components/airdrop-mint-form.tsx +0 -246
  155. package/src/gui/src/components/clone-program-modal.tsx +0 -202
  156. package/src/gui/src/components/clone-token-modal.tsx +0 -230
  157. package/src/gui/src/components/modal.tsx +0 -134
  158. package/src/gui/src/components/programs-panel.tsx +0 -124
  159. package/src/gui/src/components/status-panel.tsx +0 -136
  160. package/src/gui/src/components/tokens-panel.tsx +0 -122
  161. package/src/gui/src/hooks/use-interval.ts +0 -17
  162. package/src/gui/src/index.css +0 -557
  163. package/src/gui/src/main.tsx +0 -17
  164. package/src/index.ts +0 -216
  165. package/src/migrations-bundled.ts +0 -23
  166. package/src/rpc/start.ts +0 -44
  167. package/src/services/api-server.ts +0 -504
  168. package/src/services/port-manager.ts +0 -174
  169. package/src/services/process-registry.ts +0 -153
  170. package/src/services/program-cloner.ts +0 -317
  171. package/src/services/token-cloner.ts +0 -811
  172. package/src/services/validator.ts +0 -293
  173. package/src/types/config.ts +0 -110
  174. package/src/utils/shell.ts +0 -110
  175. package/src/utils/token-loader.ts +0 -115
@@ -1,557 +0,0 @@
1
- @tailwind base;
2
- @tailwind components;
3
- @tailwind utilities;
4
-
5
- :root {
6
- color-scheme: dark;
7
-
8
- /* Professional Color Palette */
9
- --color-bg-base: #0a0a0f;
10
- --color-bg-surface: #12121a;
11
- --color-bg-elevated: #1a1a24;
12
- --color-bg-hover: #22222e;
13
- --color-bg-active: #2a2a38;
14
-
15
- /* Accent Colors - Purple/Violet gradient */
16
- --color-accent-primary: #8b5cf6;
17
- --color-accent-secondary: #a78bfa;
18
- --color-accent-tertiary: #c4b5fd;
19
- --color-accent-glow: rgba(139, 92, 246, 0.4);
20
-
21
- /* Status Colors */
22
- --color-success: #10b981;
23
- --color-warning: #f59e0b;
24
- --color-error: #ef4444;
25
- --color-info: #3b82f6;
26
-
27
- /* Text Colors */
28
- --color-text-primary: #f3f4f6;
29
- --color-text-secondary: #9ca3af;
30
- --color-text-tertiary: #6b7280;
31
- --color-text-muted: #4b5563;
32
-
33
- /* Borders */
34
- --color-border-subtle: rgba(255, 255, 255, 0.06);
35
- --color-border-default: rgba(255, 255, 255, 0.1);
36
- --color-border-strong: rgba(255, 255, 255, 0.15);
37
-
38
- /* Shadows */
39
- --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
40
- --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
41
- --shadow-lg:
42
- 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
43
- --shadow-xl:
44
- 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
45
- --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / 0.25);
46
- --shadow-glow: 0 0 50px rgba(139, 92, 246, 0.3);
47
-
48
- /* Animations */
49
- --transition-base: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
50
- --transition-smooth: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
51
- --transition-spring: all 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
52
- }
53
-
54
- * {
55
- box-sizing: border-box;
56
- margin: 0;
57
- padding: 0;
58
- }
59
-
60
- html {
61
- font-family: "Inter", system-ui, -apple-system, sans-serif;
62
- font-feature-settings: "cv11", "ss01";
63
- font-variation-settings: "opsz" 32;
64
- scroll-behavior: smooth;
65
- }
66
-
67
- body {
68
- @apply antialiased;
69
- background: var(--color-bg-base);
70
- color: var(--color-text-primary);
71
- min-height: 100vh;
72
- position: relative;
73
- overflow-x: hidden;
74
- }
75
-
76
- /* Background gradient effect */
77
- body::before {
78
- content: "";
79
- position: fixed;
80
- top: 0;
81
- left: 0;
82
- right: 0;
83
- bottom: 0;
84
- background:
85
- radial-gradient(
86
- ellipse at top left,
87
- rgba(139, 92, 246, 0.15) 0%,
88
- transparent 50%
89
- ),
90
- radial-gradient(
91
- ellipse at bottom right,
92
- rgba(167, 139, 250, 0.1) 0%,
93
- transparent 50%
94
- );
95
- pointer-events: none;
96
- z-index: 0;
97
- }
98
-
99
- #root {
100
- position: relative;
101
- z-index: 1;
102
- }
103
-
104
- /* Custom Scrollbar */
105
- ::-webkit-scrollbar {
106
- width: 12px;
107
- height: 12px;
108
- }
109
-
110
- ::-webkit-scrollbar-track {
111
- background: var(--color-bg-surface);
112
- border-radius: 6px;
113
- }
114
-
115
- ::-webkit-scrollbar-thumb {
116
- background: linear-gradient(
117
- 180deg,
118
- var(--color-accent-primary),
119
- var(--color-accent-secondary)
120
- );
121
- border-radius: 6px;
122
- border: 2px solid var(--color-bg-surface);
123
- }
124
-
125
- ::-webkit-scrollbar-thumb:hover {
126
- background: linear-gradient(
127
- 180deg,
128
- var(--color-accent-secondary),
129
- var(--color-accent-tertiary)
130
- );
131
- }
132
-
133
- /* Animations */
134
- @keyframes fadeIn {
135
- from {
136
- opacity: 0;
137
- transform: translateY(10px);
138
- }
139
- to {
140
- opacity: 1;
141
- transform: translateY(0);
142
- }
143
- }
144
-
145
- @keyframes slideIn {
146
- from {
147
- opacity: 0;
148
- transform: translateX(-20px);
149
- }
150
- to {
151
- opacity: 1;
152
- transform: translateX(0);
153
- }
154
- }
155
-
156
- @keyframes pulse {
157
- 0%,
158
- 100% {
159
- opacity: 1;
160
- }
161
- 50% {
162
- opacity: 0.5;
163
- }
164
- }
165
-
166
- @keyframes shimmer {
167
- 0% {
168
- background-position: -1000px 0;
169
- }
170
- 100% {
171
- background-position: 1000px 0;
172
- }
173
- }
174
-
175
- @keyframes glow {
176
- 0%,
177
- 100% {
178
- box-shadow:
179
- 0 0 20px rgba(139, 92, 246, 0.5),
180
- inset 0 0 20px rgba(139, 92, 246, 0.1);
181
- }
182
- 50% {
183
- box-shadow:
184
- 0 0 40px rgba(139, 92, 246, 0.8),
185
- inset 0 0 30px rgba(139, 92, 246, 0.2);
186
- }
187
- }
188
-
189
- /* Component Classes */
190
- @layer components {
191
- /* Glass Morphism Panel */
192
- .glass-panel {
193
- @apply rounded-2xl border;
194
- background: linear-gradient(
195
- 135deg,
196
- rgba(255, 255, 255, 0.03) 0%,
197
- rgba(255, 255, 255, 0.01) 100%
198
- );
199
- border-color: var(--color-border-default);
200
- backdrop-filter: blur(20px);
201
- box-shadow:
202
- var(--shadow-xl),
203
- inset 0 1px 0 0 rgba(255, 255, 255, 0.05);
204
- transition: var(--transition-base);
205
- }
206
-
207
- .glass-panel:hover {
208
- border-color: var(--color-border-strong);
209
- box-shadow:
210
- var(--shadow-2xl),
211
- var(--shadow-glow),
212
- inset 0 1px 0 0 rgba(255, 255, 255, 0.08);
213
- }
214
-
215
- /* Card Styles */
216
- .card {
217
- @apply rounded-xl p-6;
218
- background: var(--color-bg-surface);
219
- border: 1px solid var(--color-border-subtle);
220
- transition: var(--transition-smooth);
221
- animation: fadeIn 0.5s ease-out;
222
- }
223
-
224
- .card:hover {
225
- background: var(--color-bg-elevated);
226
- border-color: var(--color-border-default);
227
- transform: translateY(-2px);
228
- box-shadow: var(--shadow-lg);
229
- }
230
-
231
- .card-interactive {
232
- @apply card cursor-pointer;
233
- }
234
-
235
- .card-interactive:active {
236
- transform: scale(0.98);
237
- }
238
-
239
- /* Modern Buttons */
240
- .btn {
241
- @apply inline-flex items-center justify-center gap-2 rounded-xl px-5 py-2.5 font-medium;
242
- transition: var(--transition-base);
243
- position: relative;
244
- overflow: hidden;
245
- text-transform: none;
246
- letter-spacing: 0.01em;
247
- }
248
-
249
- .btn-primary {
250
- @apply btn;
251
- background: linear-gradient(
252
- 135deg,
253
- var(--color-accent-primary),
254
- var(--color-accent-secondary)
255
- );
256
- color: white;
257
- box-shadow: 0 4px 15px rgba(139, 92, 246, 0.3);
258
- }
259
-
260
- .btn-primary:hover {
261
- box-shadow: 0 6px 25px rgba(139, 92, 246, 0.5);
262
- transform: translateY(-2px);
263
- }
264
-
265
- .btn-primary:active {
266
- transform: translateY(0);
267
- }
268
-
269
- .btn-secondary {
270
- @apply btn;
271
- background: var(--color-bg-elevated);
272
- color: var(--color-text-primary);
273
- border: 1px solid var(--color-border-default);
274
- }
275
-
276
- .btn-secondary:hover {
277
- background: var(--color-bg-hover);
278
- border-color: var(--color-accent-primary);
279
- box-shadow: inset 0 0 0 1px var(--color-accent-primary);
280
- }
281
-
282
- .btn-ghost {
283
- @apply btn;
284
- background: transparent;
285
- color: var(--color-text-secondary);
286
- }
287
-
288
- .btn-ghost:hover {
289
- background: var(--color-bg-elevated);
290
- color: var(--color-text-primary);
291
- }
292
-
293
- .btn-icon {
294
- @apply inline-flex items-center justify-center;
295
- width: 40px;
296
- height: 40px;
297
- border-radius: 12px;
298
- background: var(--color-bg-elevated);
299
- border: 1px solid var(--color-border-subtle);
300
- color: var(--color-text-secondary);
301
- transition: var(--transition-base);
302
- }
303
-
304
- .btn-icon:hover {
305
- background: var(--color-bg-hover);
306
- color: var(--color-accent-primary);
307
- border-color: var(--color-accent-primary);
308
- transform: scale(1.05);
309
- }
310
-
311
- /* Modern Input Fields */
312
- .input {
313
- @apply w-full rounded-xl px-4 py-3 text-sm;
314
- background: var(--color-bg-surface);
315
- border: 1px solid var(--color-border-subtle);
316
- color: var(--color-text-primary);
317
- transition: var(--transition-base);
318
- font-family: "Inter", sans-serif;
319
- }
320
-
321
- .input:hover {
322
- background: var(--color-bg-elevated);
323
- border-color: var(--color-border-default);
324
- }
325
-
326
- .input:focus {
327
- outline: none;
328
- border-color: var(--color-accent-primary);
329
- box-shadow: 0 0 0 3px var(--color-accent-glow);
330
- background: var(--color-bg-elevated);
331
- }
332
-
333
- .input::placeholder {
334
- color: var(--color-text-muted);
335
- }
336
-
337
- /* Select */
338
- .select {
339
- @apply input cursor-pointer;
340
- padding-right: 40px;
341
- background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%239ca3af'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");
342
- background-repeat: no-repeat;
343
- background-position: right 12px center;
344
- background-size: 20px;
345
- }
346
-
347
- /* Checkbox */
348
- .checkbox {
349
- @apply h-5 w-5 rounded-md;
350
- background: var(--color-bg-surface);
351
- border: 1px solid var(--color-border-default);
352
- cursor: pointer;
353
- transition: var(--transition-base);
354
- }
355
-
356
- .checkbox:checked {
357
- background: linear-gradient(
358
- 135deg,
359
- var(--color-accent-primary),
360
- var(--color-accent-secondary)
361
- );
362
- border-color: var(--color-accent-primary);
363
- }
364
-
365
- .checkbox:focus {
366
- outline: none;
367
- box-shadow: 0 0 0 3px var(--color-accent-glow);
368
- }
369
-
370
- /* Tables */
371
- .table-modern {
372
- @apply w-full;
373
- border-collapse: separate;
374
- border-spacing: 0;
375
- }
376
-
377
- .table-modern thead {
378
- background: var(--color-bg-surface);
379
- }
380
-
381
- .table-modern th {
382
- @apply px-4 py-3 text-left text-xs font-semibold uppercase tracking-wider;
383
- color: var(--color-text-tertiary);
384
- border-bottom: 1px solid var(--color-border-subtle);
385
- }
386
-
387
- .table-modern td {
388
- @apply px-4 py-3 text-sm;
389
- color: var(--color-text-primary);
390
- border-bottom: 1px solid var(--color-border-subtle);
391
- }
392
-
393
- .table-modern tbody tr {
394
- transition: var(--transition-base);
395
- }
396
-
397
- .table-modern tbody tr:hover {
398
- background: var(--color-bg-elevated);
399
- }
400
-
401
- /* Badges */
402
- .badge {
403
- @apply inline-flex items-center gap-1.5 rounded-full px-3 py-1 text-xs font-medium;
404
- background: var(--color-bg-elevated);
405
- color: var(--color-text-secondary);
406
- border: 1px solid var(--color-border-subtle);
407
- }
408
-
409
- .badge-success {
410
- background: rgba(16, 185, 129, 0.1);
411
- color: #10b981;
412
- border-color: rgba(16, 185, 129, 0.2);
413
- }
414
-
415
- .badge-warning {
416
- background: rgba(245, 158, 11, 0.1);
417
- color: #f59e0b;
418
- border-color: rgba(245, 158, 11, 0.2);
419
- }
420
-
421
- .badge-error {
422
- background: rgba(239, 68, 68, 0.1);
423
- color: #ef4444;
424
- border-color: rgba(239, 68, 68, 0.2);
425
- }
426
-
427
- .badge-info {
428
- background: rgba(59, 130, 246, 0.1);
429
- color: #3b82f6;
430
- border-color: rgba(59, 130, 246, 0.2);
431
- }
432
-
433
- /* Loading States */
434
- .skeleton {
435
- @apply rounded-lg;
436
- background: linear-gradient(
437
- 90deg,
438
- var(--color-bg-surface) 25%,
439
- var(--color-bg-elevated) 50%,
440
- var(--color-bg-surface) 75%
441
- );
442
- background-size: 1000px 100%;
443
- animation: shimmer 2s infinite;
444
- }
445
-
446
- .spinner {
447
- border: 3px solid var(--color-border-subtle);
448
- border-top-color: var(--color-accent-primary);
449
- border-radius: 50%;
450
- width: 20px;
451
- height: 20px;
452
- animation: spin 1s linear infinite;
453
- }
454
-
455
- @keyframes spin {
456
- to {
457
- transform: rotate(360deg);
458
- }
459
- }
460
-
461
- /* Tooltips */
462
- .tooltip {
463
- @apply absolute z-50 rounded-lg px-3 py-2 text-xs font-medium;
464
- background: var(--color-bg-elevated);
465
- color: var(--color-text-primary);
466
- border: 1px solid var(--color-border-default);
467
- box-shadow: var(--shadow-xl);
468
- pointer-events: none;
469
- opacity: 0;
470
- transition: opacity 0.2s;
471
- }
472
-
473
- .tooltip.show {
474
- opacity: 1;
475
- }
476
-
477
- /* Dividers */
478
- .divider {
479
- @apply my-6;
480
- height: 1px;
481
- background: linear-gradient(
482
- 90deg,
483
- transparent,
484
- var(--color-border-default) 50%,
485
- transparent
486
- );
487
- }
488
-
489
- /* Status Indicators */
490
- .status-dot {
491
- @apply inline-block h-2 w-2 rounded-full;
492
- animation: pulse 2s infinite;
493
- }
494
-
495
- .status-dot.online {
496
- background: var(--color-success);
497
- box-shadow: 0 0 8px var(--color-success);
498
- }
499
-
500
- .status-dot.offline {
501
- background: var(--color-text-muted);
502
- }
503
-
504
- .status-dot.error {
505
- background: var(--color-error);
506
- box-shadow: 0 0 8px var(--color-error);
507
- }
508
-
509
- /* Code blocks */
510
- .code-block {
511
- @apply rounded-xl p-4;
512
- background: var(--color-bg-base);
513
- border: 1px solid var(--color-border-subtle);
514
- font-family: "JetBrains Mono", monospace;
515
- font-size: 0.875rem;
516
- line-height: 1.5;
517
- overflow-x: auto;
518
- }
519
-
520
- .code-inline {
521
- @apply rounded px-1.5 py-0.5;
522
- background: var(--color-bg-elevated);
523
- border: 1px solid var(--color-border-subtle);
524
- font-family: "JetBrains Mono", monospace;
525
- font-size: 0.875em;
526
- }
527
-
528
- /* Responsive utilities */
529
- @media (max-width: 640px) {
530
- .hide-mobile {
531
- display: none;
532
- }
533
- }
534
-
535
- @media (min-width: 641px) {
536
- .show-mobile {
537
- display: none;
538
- }
539
- }
540
- }
541
-
542
- /* Tailwind overrides for consistency */
543
- .text-mono {
544
- font-family: "JetBrains Mono", monospace;
545
- }
546
-
547
- /* Focus visible styles */
548
- *:focus-visible {
549
- outline: 2px solid var(--color-accent-primary);
550
- outline-offset: 2px;
551
- }
552
-
553
- /* Selection styles */
554
- ::selection {
555
- background: var(--color-accent-primary);
556
- color: white;
557
- }
@@ -1,17 +0,0 @@
1
- import { createRoot } from "react-dom/client";
2
- import "../public/app.css";
3
- import { App } from "./app";
4
-
5
- function render() {
6
- const el = document.getElementById("root");
7
- if (!el) return;
8
- const root = createRoot(el);
9
- root.render(<App />);
10
- }
11
-
12
- // Ensure we render whether or not DOMContentLoaded has already fired
13
- if (document.readyState === "loading") {
14
- document.addEventListener("DOMContentLoaded", render);
15
- } else {
16
- render();
17
- }