@asafarim/shared-i18n 0.6.6 → 0.8.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.
Files changed (80) hide show
  1. package/demo/dist/Icon Dropdown_Limited Languages.png +0 -0
  2. package/demo/dist/Select Dropdown_Text Only.png +0 -0
  3. package/demo/dist/assets/favicon-BZYZvBLo.svg +4 -0
  4. package/demo/dist/assets/index-BdjqKw_N.css +1 -0
  5. package/demo/dist/assets/index-C1Tq1uEr.js +191 -0
  6. package/demo/dist/favicon.svg +4 -0
  7. package/demo/dist/index.html +27 -0
  8. package/demo/dist/logo.svg +24 -0
  9. package/demo/node_modules/.bin/browserslist +21 -0
  10. package/demo/node_modules/.bin/browserslist.CMD +12 -0
  11. package/demo/node_modules/.bin/browserslist.ps1 +41 -0
  12. package/demo/node_modules/.bin/tsc +4 -4
  13. package/demo/node_modules/.bin/tsc.CMD +12 -0
  14. package/demo/node_modules/.bin/tsc.ps1 +41 -0
  15. package/demo/node_modules/.bin/tsserver +4 -4
  16. package/demo/node_modules/.bin/tsserver.CMD +12 -0
  17. package/demo/node_modules/.bin/tsserver.ps1 +41 -0
  18. package/demo/node_modules/.bin/vite +4 -4
  19. package/demo/node_modules/.bin/vite.CMD +12 -0
  20. package/demo/node_modules/.bin/vite.ps1 +41 -0
  21. package/demo/node_modules/.vite/deps/@asafarim_country-language-selector.js +848 -0
  22. package/demo/node_modules/.vite/deps/@asafarim_country-language-selector.js.map +7 -0
  23. package/demo/node_modules/.vite/deps/_metadata.json +76 -0
  24. package/demo/node_modules/.vite/deps/chunk-5WRI5ZAA.js +30 -0
  25. package/demo/node_modules/.vite/deps/chunk-5WRI5ZAA.js.map +7 -0
  26. package/demo/node_modules/.vite/deps/chunk-B3AHR5EX.js +1004 -0
  27. package/demo/node_modules/.vite/deps/chunk-B3AHR5EX.js.map +7 -0
  28. package/demo/node_modules/.vite/deps/chunk-E6BG6WAU.js +292 -0
  29. package/demo/node_modules/.vite/deps/chunk-E6BG6WAU.js.map +7 -0
  30. package/demo/node_modules/.vite/deps/chunk-MVARZQEG.js +280 -0
  31. package/demo/node_modules/.vite/deps/chunk-MVARZQEG.js.map +7 -0
  32. package/demo/node_modules/.vite/deps/i18next-browser-languagedetector.js +400 -0
  33. package/demo/node_modules/.vite/deps/i18next-browser-languagedetector.js.map +7 -0
  34. package/demo/node_modules/.vite/deps/i18next.js +2392 -0
  35. package/demo/node_modules/.vite/deps/i18next.js.map +7 -0
  36. package/demo/node_modules/.vite/deps/package.json +3 -0
  37. package/demo/node_modules/.vite/deps/react-dom.js +6 -0
  38. package/demo/node_modules/.vite/deps/react-dom.js.map +7 -0
  39. package/demo/node_modules/.vite/deps/react-dom_client.js +20217 -0
  40. package/demo/node_modules/.vite/deps/react-dom_client.js.map +7 -0
  41. package/demo/node_modules/.vite/deps/react-i18next.js +869 -0
  42. package/demo/node_modules/.vite/deps/react-i18next.js.map +7 -0
  43. package/demo/node_modules/.vite/deps/react.js +5 -0
  44. package/demo/node_modules/.vite/deps/react.js.map +7 -0
  45. package/demo/node_modules/.vite/deps/react_jsx-dev-runtime.js +278 -0
  46. package/demo/node_modules/.vite/deps/react_jsx-dev-runtime.js.map +7 -0
  47. package/demo/node_modules/.vite/deps/react_jsx-runtime.js +6 -0
  48. package/demo/node_modules/.vite/deps/react_jsx-runtime.js.map +7 -0
  49. package/demo/package.json +27 -24
  50. package/demo/public/favicon.svg +4 -4
  51. package/demo/public/logo.svg +24 -24
  52. package/demo/src/App.tsx +129 -116
  53. package/demo/src/components/CountryLanguageDemo.tsx +140 -0
  54. package/demo/src/components/GetStartedSection.tsx +56 -56
  55. package/demo/src/components/KeyTable.tsx +29 -29
  56. package/demo/src/components/LanguageBar.tsx +102 -18
  57. package/demo/src/components/LanguageSwitcherDemo.module.css +114 -113
  58. package/demo/src/components/LanguageSwitcherDemo.tsx +256 -202
  59. package/demo/src/components/Logo.tsx +6 -6
  60. package/demo/src/components/OverviewSection.tsx +43 -43
  61. package/demo/src/components/Panel.tsx +15 -15
  62. package/demo/src/components/StatusCard.tsx +109 -109
  63. package/demo/src/index.css +644 -605
  64. package/demo/src/locales/de/demo.json +85 -0
  65. package/demo/src/locales/en/demo.json +85 -85
  66. package/demo/src/locales/fr/demo.json +85 -85
  67. package/demo/src/locales/it/demo.json +85 -0
  68. package/demo/src/locales/nl/demo.json +85 -85
  69. package/demo/src/main.tsx +29 -24
  70. package/demo/tsconfig.json +18 -18
  71. package/demo/tsconfig.node.json +10 -10
  72. package/demo/tsconfig.tsbuildinfo +1 -1
  73. package/demo/vite-env.d.ts +7 -7
  74. package/demo/vite.config.d.ts +2 -2
  75. package/demo/vite.config.js +10 -10
  76. package/dist/components/LanguageSwitcher.module.css +303 -303
  77. package/dist/locales/de/common.json +68 -0
  78. package/dist/locales/it/common.json +68 -0
  79. package/dist/tsconfig.tsbuildinfo +1 -1
  80. package/package.json +85 -84
@@ -1,605 +1,644 @@
1
- @import "@asafarim/design-tokens/css";
2
-
3
- * {
4
- margin: 0;
5
- padding: 0;
6
- box-sizing: border-box;
7
- }
8
-
9
- body {
10
- font-family: var(--asm-font-family-base, 'Inter', sans-serif);
11
- -webkit-font-smoothing: antialiased;
12
- -moz-osx-font-smoothing: grayscale;
13
- background-color: var(--asm-color-bg);
14
- color: var(--asm-color-text);
15
- }
16
-
17
- .app-container {
18
- min-height: 100vh;
19
- display: flex;
20
- flex-direction: column;
21
- }
22
-
23
- .app-header {
24
- background-color: var(--asm-color-primary-600);
25
- color: var(--asm-color-bg);
26
- padding: var(--asm-space-10);
27
- box-shadow: var(--asm-effect-shadow-md);
28
- display: flex;
29
- justify-content: space-between;
30
- align-items: flex-start;
31
- gap: var(--asm-space-6);
32
- flex-wrap: wrap;
33
- }
34
-
35
- .header-content {
36
- flex: 1;
37
- min-width: 300px;
38
- }
39
-
40
- .app-header h1 {
41
- font-size: 2rem;
42
- margin-bottom: var(--asm-space-2);
43
- }
44
-
45
- .subtitle {
46
- font-size: 0.95rem;
47
- opacity: 0.9;
48
- }
49
-
50
- .app-main {
51
- flex: 1;
52
- max-width: 1200px;
53
- width: 100%;
54
- margin: 0 auto;
55
- padding: var(--asm-space-10);
56
- gap: var(--asm-space-10);
57
- display: flex;
58
- flex-direction: column;
59
- }
60
-
61
- .panel {
62
- background-color: var(--asm-color-surface);
63
- border: 1px solid var(--asm-color-border);
64
- border-radius: var(--asm-radius-lg);
65
- padding: var(--asm-space-6);
66
- box-shadow: var(--asm-effect-shadow-sm);
67
- }
68
-
69
- .panel-title {
70
- font-size: 1.25rem;
71
- font-weight: 600;
72
- margin-bottom: var(--asm-space-4);
73
- color: var(--asm-color-text);
74
- }
75
-
76
- .panel-grid {
77
- display: grid;
78
- grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
79
- gap: var(--asm-space-6);
80
- }
81
-
82
- .panel-grid h3 {
83
- font-size: 1rem;
84
- margin-bottom: var(--asm-space-3);
85
- color: var(--asm-color-text-muted);
86
- }
87
-
88
- .key-table {
89
- width: 100%;
90
- border-collapse: collapse;
91
- font-size: 0.9rem;
92
- }
93
-
94
- .key-table th,
95
- .key-table td {
96
- padding: var(--asm-space-4);
97
- text-align: left;
98
- border-bottom: 1px solid var(--asm-color-border);
99
- }
100
-
101
- .key-table th {
102
- background-color: var(--asm-color-surface-muted);
103
- font-weight: 600;
104
- color: var(--asm-color-text-muted);
105
- }
106
-
107
- .key-table tr:hover {
108
- background-color: var(--asm-color-surface-muted);
109
- }
110
-
111
- .language-bar {
112
- display: flex;
113
- gap: var(--asm-space-3);
114
- }
115
-
116
- .lang-button {
117
- padding: var(--asm-space-2) var(--asm-space-4);
118
- border: 2px solid var(--asm-color-bg);
119
- background-color: transparent;
120
- color: var(--asm-color-bg);
121
- border-radius: var(--asm-radius-md);
122
- cursor: pointer;
123
- font-size: 0.95rem;
124
- font-weight: 500;
125
- transition: all 0.2s ease;
126
- }
127
-
128
- .lang-button:hover:not(:disabled) {
129
- background-color: var(--asm-color-button-ghost-bg-hover);
130
- }
131
-
132
- .lang-button.active {
133
- background-color: var(--asm-color-bg);
134
- color: var(--asm-color-primary-600);
135
- }
136
-
137
- .lang-button:disabled {
138
- opacity: 0.6;
139
- cursor: not-allowed;
140
- }
141
-
142
- .interpolation-demo {
143
- display: flex;
144
- flex-direction: column;
145
- gap: var(--asm-space-6);
146
- }
147
-
148
- .demo-item {
149
- padding: var(--asm-space-6);
150
- background-color: var(--asm-color-surface-muted);
151
- border-radius: var(--asm-radius-md);
152
- border-left: 4px solid var(--asm-color-primary-600);
153
- }
154
-
155
- .demo-item h4 {
156
- font-size: 0.95rem;
157
- margin-bottom: var(--asm-space-3);
158
- color: var(--asm-color-text-muted);
159
- }
160
-
161
- .demo-output {
162
- font-size: 1rem;
163
- color: var(--asm-color-text);
164
- font-weight: 500;
165
- }
166
-
167
- .status-grid {
168
- display: grid;
169
- grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
170
- gap: var(--asm-space-6);
171
- }
172
-
173
- .status-card {
174
- background-color: var(--asm-color-surface-muted);
175
- border: 1px solid var(--asm-color-border);
176
- border-radius: var(--asm-radius-md);
177
- padding: var(--asm-space-6);
178
- }
179
-
180
- .status-card h4 {
181
- font-size: 0.9rem;
182
- color: var(--asm-color-text-muted);
183
- margin-bottom: var(--asm-space-2);
184
- text-transform: uppercase;
185
- letter-spacing: 0.05em;
186
- }
187
-
188
- .status-card p {
189
- font-size: 1rem;
190
- color: var(--asm-color-text);
191
- word-break: break-all;
192
- }
193
-
194
- .status-list {
195
- list-style: none;
196
- margin-top: var(--asm-space-3);
197
- }
198
-
199
- .status-list li {
200
- padding: var(--asm-space-2) 0;
201
- color: var(--asm-color-text);
202
- font-size: 0.95rem;
203
- }
204
-
205
- .sync-button {
206
- margin-top: var(--asm-space-4);
207
- padding: var(--asm-space-3) var(--asm-space-6);
208
- background-color: var(--asm-color-button-primary-bg);
209
- color: var(--asm-color-button-primary-text);
210
- border: none;
211
- border-radius: var(--asm-radius-md);
212
- cursor: pointer;
213
- font-size: 0.95rem;
214
- font-weight: 500;
215
- transition: all 0.2s ease;
216
- }
217
-
218
- .sync-button:hover:not(:disabled) {
219
- background-color: var(--asm-color-button-primary-bg-hover);
220
- box-shadow: var(--asm-effect-shadow-sm);
221
- }
222
-
223
- .sync-button:disabled {
224
- opacity: 0.6;
225
- cursor: not-allowed;
226
- }
227
-
228
- .sync-result {
229
- margin-top: var(--asm-space-3);
230
- padding: var(--asm-space-4);
231
- border-radius: var(--asm-radius-md);
232
- font-size: 0.9rem;
233
- }
234
-
235
- .sync-result.success {
236
- background-color: var(--asm-color-success-100);
237
- color: var(--asm-color-success-600);
238
- border: 1px solid var(--asm-color-success-200);
239
- }
240
-
241
- .sync-result.error {
242
- background-color: var(--asm-color-danger-100);
243
- color: var(--asm-color-danger-600);
244
- border: 1px solid var(--asm-color-danger-200);
245
- }
246
-
247
- .nav-tabs {
248
- display: flex;
249
- gap: var(--asm-space-2);
250
- margin-bottom: var(--asm-space-6);
251
- border-bottom: 2px solid var(--asm-color-border);
252
- overflow-x: auto;
253
- }
254
-
255
- .nav-tab {
256
- padding: var(--asm-space-3) var(--asm-space-4);
257
- background: none;
258
- border: none;
259
- border-bottom: 3px solid transparent;
260
- color: var(--asm-color-text-muted);
261
- cursor: pointer;
262
- font-size: 0.95rem;
263
- font-weight: 500;
264
- transition: all var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
265
- white-space: nowrap;
266
- }
267
-
268
- .nav-tab:hover {
269
- color: var(--asm-color-text);
270
- }
271
-
272
- .nav-tab.active {
273
- color: var(--asm-color-primary-600);
274
- border-bottom-color: var(--asm-color-primary-600);
275
- }
276
-
277
- .overview-section {
278
- animation: fadeIn var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
279
- }
280
-
281
- .overview-header {
282
- margin-bottom: var(--asm-space-8);
283
- }
284
-
285
- .overview-title {
286
- font-size: 2rem;
287
- font-weight: 700;
288
- color: var(--asm-color-text);
289
- margin-bottom: var(--asm-space-3);
290
- }
291
-
292
- .overview-description {
293
- font-size: 1.125rem;
294
- color: var(--asm-color-text-muted);
295
- line-height: 1.6;
296
- }
297
-
298
- .overview-grid {
299
- display: grid;
300
- grid-template-columns: repeat(auto-fit, minmax(380px, 1fr));
301
- gap: var(--asm-space-6);
302
- }
303
-
304
- .feature-card {
305
- background: linear-gradient(135deg, var(--asm-color-surface) 0%, var(--asm-color-surface-muted) 100%);
306
- border: 1px solid var(--asm-color-border);
307
- border-radius: var(--asm-radius-lg);
308
- padding: var(--asm-space-6);
309
- transition: all var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
310
- }
311
-
312
- .feature-card:hover {
313
- transform: translateY(-4px);
314
- box-shadow: var(--asm-effect-shadow-lg);
315
- border-color: var(--asm-color-primary-600);
316
- }
317
-
318
- .feature-icon {
319
- font-size: 2.5rem;
320
- margin-bottom: var(--asm-space-3);
321
- display: inline-block;
322
- }
323
-
324
- .feature-card h3 {
325
- font-size: 1.25rem;
326
- font-weight: 600;
327
- color: var(--asm-color-text);
328
- margin-bottom: var(--asm-space-4);
329
- }
330
-
331
- .feature-list {
332
- list-style: none;
333
- display: flex;
334
- flex-direction: column;
335
- gap: var(--asm-space-3);
336
- }
337
-
338
- .feature-list li {
339
- display: flex;
340
- align-items: flex-start;
341
- gap: var(--asm-space-2);
342
- color: var(--asm-color-text);
343
- line-height: 1.5;
344
- }
345
-
346
- .feature-dot {
347
- color: var(--asm-color-primary-600);
348
- font-weight: bold;
349
- flex-shrink: 0;
350
- }
351
-
352
- .get-started-section {
353
- animation: fadeIn var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
354
- }
355
-
356
- .gs-header {
357
- margin-bottom: var(--asm-space-8);
358
- }
359
-
360
- .gs-title {
361
- font-size: 2rem;
362
- font-weight: 700;
363
- color: var(--asm-color-text);
364
- margin-bottom: var(--asm-space-3);
365
- }
366
-
367
- .gs-intro {
368
- font-size: 1.125rem;
369
- color: var(--asm-color-text-muted);
370
- line-height: 1.6;
371
- }
372
-
373
- .steps-container {
374
- display: flex;
375
- flex-direction: column;
376
- gap: var(--asm-space-4);
377
- margin-bottom: var(--asm-space-8);
378
- }
379
-
380
- .step-item {
381
- border: 1px solid var(--asm-color-border);
382
- border-radius: var(--asm-radius-lg);
383
- overflow: hidden;
384
- transition: all var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
385
- }
386
-
387
- .step-item:hover {
388
- border-color: var(--asm-color-primary-600);
389
- box-shadow: var(--asm-effect-shadow-md);
390
- }
391
-
392
- .step-header {
393
- width: 100%;
394
- display: flex;
395
- align-items: center;
396
- gap: var(--asm-space-4);
397
- padding: var(--asm-space-4) var(--asm-space-6);
398
- background-color: var(--asm-color-surface);
399
- border: none;
400
- cursor: pointer;
401
- transition: all var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
402
- }
403
-
404
- .step-header:hover {
405
- background-color: var(--asm-color-surface-muted);
406
- }
407
-
408
- .step-header.expanded {
409
- background-color: var(--asm-color-surface-muted);
410
- }
411
-
412
- .step-number {
413
- display: flex;
414
- align-items: center;
415
- justify-content: center;
416
- width: 40px;
417
- height: 40px;
418
- border-radius: var(--asm-radius-full);
419
- background: linear-gradient(135deg, var(--asm-color-primary-600) 0%, var(--asm-color-primary-700) 100%);
420
- color: white;
421
- font-weight: 700;
422
- font-size: 1.125rem;
423
- flex-shrink: 0;
424
- }
425
-
426
- .step-info {
427
- flex: 1;
428
- text-align: left;
429
- }
430
-
431
- .step-info h3 {
432
- font-size: 1rem;
433
- font-weight: 600;
434
- color: var(--asm-color-text);
435
- margin-bottom: var(--asm-space-1);
436
- }
437
-
438
- .step-info p {
439
- font-size: 0.9rem;
440
- color: var(--asm-color-text-muted);
441
- }
442
-
443
- .step-toggle {
444
- font-size: 1.5rem;
445
- color: var(--asm-color-primary-600);
446
- font-weight: bold;
447
- flex-shrink: 0;
448
- }
449
-
450
- .step-content {
451
- padding: var(--asm-space-6);
452
- background-color: var(--asm-color-surface-muted);
453
- border-top: 1px solid var(--asm-color-border);
454
- animation: slideDown var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
455
- }
456
-
457
- .code-block {
458
- background-color: var(--asm-color-text);
459
- color: var(--asm-color-bg);
460
- padding: var(--asm-space-4);
461
- border-radius: var(--asm-radius-md);
462
- overflow-x: auto;
463
- font-family: var(--asm-font-family-mono, monospace);
464
- font-size: 0.85rem;
465
- line-height: 1.5;
466
- margin: 0;
467
- }
468
-
469
- .tips-section {
470
- display: flex;
471
- gap: var(--asm-space-6);
472
- padding: var(--asm-space-6);
473
- background: linear-gradient(135deg, var(--asm-color-primary-50) 0%, var(--asm-color-secondary-50) 100%);
474
- border: 2px solid var(--asm-color-primary-200);
475
- border-radius: var(--asm-radius-lg);
476
- }
477
-
478
- .tips-icon {
479
- font-size: 2rem;
480
- flex-shrink: 0;
481
- }
482
-
483
- .tips-content h3 {
484
- font-size: 1.125rem;
485
- font-weight: 600;
486
- color: var(--asm-color-text);
487
- margin-bottom: var(--asm-space-3);
488
- }
489
-
490
- .tips-list {
491
- list-style: none;
492
- display: flex;
493
- flex-direction: column;
494
- gap: var(--asm-space-2);
495
- }
496
-
497
- .tips-list li {
498
- display: flex;
499
- align-items: flex-start;
500
- gap: var(--asm-space-2);
501
- color: var(--asm-color-text);
502
- font-size: 0.95rem;
503
- line-height: 1.5;
504
- }
505
-
506
- .tips-list li::before {
507
- content: "✓";
508
- color: var(--asm-color-semantic-success);
509
- font-weight: bold;
510
- flex-shrink: 0;
511
- }
512
-
513
- @media (max-width: 768px) {
514
- .app-header {
515
- flex-direction: column;
516
- }
517
-
518
- .app-main {
519
- padding: var(--asm-space-6);
520
- }
521
-
522
- .panel-grid {
523
- grid-template-columns: 1fr;
524
- }
525
-
526
- .app-header h1 {
527
- font-size: 1.5rem;
528
- }
529
-
530
- .overview-grid {
531
- grid-template-columns: 1fr;
532
- }
533
-
534
- .tips-section {
535
- flex-direction: column;
536
- }
537
-
538
- .step-header {
539
- flex-direction: column;
540
- align-items: flex-start;
541
- }
542
-
543
- .step-toggle {
544
- align-self: flex-end;
545
- margin-top: calc(var(--asm-space-4) * -1);
546
- }
547
- }
548
-
549
- @keyframes fadeIn {
550
- from {
551
- opacity: 0;
552
- transform: translateY(8px);
553
- }
554
- to {
555
- opacity: 1;
556
- transform: translateY(0);
557
- }
558
- }
559
-
560
- @keyframes slideDown {
561
- from {
562
- opacity: 0;
563
- max-height: 0;
564
- }
565
- to {
566
- opacity: 1;
567
- max-height: 500px;
568
- }
569
- }
570
-
571
- .logo {
572
- width: 70px;
573
- height: 70px;
574
- }
575
-
576
- .logo img {
577
- width: 100%;
578
- height: 100%;
579
- }
580
-
581
-
582
-
583
- /* Mobile adjustments */
584
- @media (max-width: 768px) {
585
- .logo {
586
- width: 50px;
587
- height: 50px;
588
- }
589
- }
590
-
591
- /* Tablet adjustments */
592
- @media (min-width: 769px) and (max-width: 1024px) {
593
- .logo {
594
- width: 60px;
595
- height: 60px;
596
- }
597
- }
598
-
599
- /* Desktop adjustments */
600
- @media (min-width: 1025px) {
601
- .logo {
602
- width: 70px;
603
- height: 70px;
604
- }
605
- }
1
+ @import "@asafarim/design-tokens/css";
2
+
3
+ * {
4
+ margin: 0;
5
+ padding: 0;
6
+ box-sizing: border-box;
7
+ }
8
+
9
+ body {
10
+ font-family: var(--asm-font-family-base, 'Inter', sans-serif);
11
+ -webkit-font-smoothing: antialiased;
12
+ -moz-osx-font-smoothing: grayscale;
13
+ background-color: var(--asm-color-bg);
14
+ color: var(--asm-color-text);
15
+ }
16
+
17
+ .app-container {
18
+ min-height: 100vh;
19
+ display: flex;
20
+ flex-direction: column;
21
+ }
22
+
23
+ .app-header {
24
+ background-color: var(--asm-color-primary-600);
25
+ color: var(--asm-color-bg);
26
+ padding: var(--asm-space-10);
27
+ box-shadow: var(--asm-effect-shadow-md);
28
+ display: flex;
29
+ justify-content: space-between;
30
+ align-items: flex-start;
31
+ gap: var(--asm-space-6);
32
+ flex-wrap: wrap;
33
+ }
34
+
35
+ .header-content {
36
+ flex: 1;
37
+ min-width: 300px;
38
+ }
39
+
40
+ .app-header h1 {
41
+ font-size: 2rem;
42
+ margin-bottom: var(--asm-space-2);
43
+ }
44
+
45
+ .subtitle {
46
+ font-size: 0.95rem;
47
+ opacity: 0.9;
48
+ }
49
+
50
+ .app-main {
51
+ flex: 1;
52
+ max-width: 1200px;
53
+ width: 100%;
54
+ margin: 0 auto;
55
+ padding: var(--asm-space-10);
56
+ gap: var(--asm-space-10);
57
+ display: flex;
58
+ flex-direction: column;
59
+ }
60
+
61
+ .panel {
62
+ background-color: var(--asm-color-surface);
63
+ border: 1px solid var(--asm-color-border);
64
+ border-radius: var(--asm-radius-lg);
65
+ padding: var(--asm-space-6);
66
+ box-shadow: var(--asm-effect-shadow-sm);
67
+ }
68
+
69
+ .panel-title {
70
+ font-size: 1.25rem;
71
+ font-weight: 600;
72
+ margin-bottom: var(--asm-space-4);
73
+ color: var(--asm-color-text);
74
+ }
75
+
76
+ .panel-grid {
77
+ display: grid;
78
+ grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
79
+ gap: var(--asm-space-6);
80
+ }
81
+
82
+ .panel-grid h3 {
83
+ font-size: 1rem;
84
+ margin-bottom: var(--asm-space-3);
85
+ color: var(--asm-color-text-muted);
86
+ }
87
+
88
+ .key-table {
89
+ width: 100%;
90
+ border-collapse: collapse;
91
+ font-size: 0.9rem;
92
+ }
93
+
94
+ .key-table th,
95
+ .key-table td {
96
+ padding: var(--asm-space-4);
97
+ text-align: left;
98
+ border-bottom: 1px solid var(--asm-color-border);
99
+ }
100
+
101
+ .key-table th {
102
+ background-color: var(--asm-color-surface-muted);
103
+ font-weight: 600;
104
+ color: var(--asm-color-text-muted);
105
+ }
106
+
107
+ .key-table tr:hover {
108
+ background-color: var(--asm-color-surface-muted);
109
+ }
110
+
111
+ .language-bar {
112
+ display: flex;
113
+ gap: var(--asm-space-3);
114
+ }
115
+
116
+ .package-source-actions {
117
+ display: flex;
118
+ align-items: center;
119
+ gap: var(--asm-space-2);
120
+ }
121
+
122
+ .icon-button {
123
+ display: inline-flex;
124
+ align-items: center;
125
+ justify-content: center;
126
+ width: 2.5rem;
127
+ height: 2.5rem;
128
+ padding: 0;
129
+ border: 1px solid var(--asm-color-border);
130
+ background: var(--asm-color-surface);
131
+ border-radius: var(--asm-radius-md);
132
+ color: var(--asm-color-text);
133
+ cursor: pointer;
134
+ font-size: 1rem;
135
+ transition: all var(--asm-motion-duration-fast) var(--asm-motion-easing-standard);
136
+ text-decoration: none;
137
+ }
138
+
139
+ .icon-button:hover:not(:disabled) {
140
+ background: var(--asm-color-surface-muted);
141
+ border-color: var(--asm-color-primary-600);
142
+ box-shadow: var(--asm-effect-shadow-sm);
143
+ }
144
+
145
+ .icon-button:disabled {
146
+ opacity: 0.5;
147
+ cursor: not-allowed;
148
+ }
149
+
150
+ .icon-button:focus {
151
+ outline: 2px solid var(--asm-color-primary-600);
152
+ outline-offset: 2px;
153
+ }
154
+
155
+ .lang-button {
156
+ padding: var(--asm-space-2) var(--asm-space-4);
157
+ border: 2px solid var(--asm-color-bg);
158
+ background-color: transparent;
159
+ color: var(--asm-color-bg);
160
+ border-radius: var(--asm-radius-md);
161
+ cursor: pointer;
162
+ font-size: 0.95rem;
163
+ font-weight: 500;
164
+ transition: all 0.2s ease;
165
+ }
166
+
167
+ .lang-button:hover:not(:disabled) {
168
+ background-color: var(--asm-color-button-ghost-bg-hover);
169
+ }
170
+
171
+ .lang-button.active {
172
+ background-color: var(--asm-color-bg);
173
+ color: var(--asm-color-primary-600);
174
+ }
175
+
176
+ .lang-button:disabled {
177
+ opacity: 0.6;
178
+ cursor: not-allowed;
179
+ }
180
+
181
+ .interpolation-demo {
182
+ display: flex;
183
+ flex-direction: column;
184
+ gap: var(--asm-space-6);
185
+ }
186
+
187
+ .demo-item {
188
+ padding: var(--asm-space-6);
189
+ background-color: var(--asm-color-surface-muted);
190
+ border-radius: var(--asm-radius-md);
191
+ border-left: 4px solid var(--asm-color-primary-600);
192
+ }
193
+
194
+ .demo-item h4 {
195
+ font-size: 0.95rem;
196
+ margin-bottom: var(--asm-space-3);
197
+ color: var(--asm-color-text-muted);
198
+ }
199
+
200
+ .demo-output {
201
+ font-size: 1rem;
202
+ color: var(--asm-color-text);
203
+ font-weight: 500;
204
+ }
205
+
206
+ .status-grid {
207
+ display: grid;
208
+ grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
209
+ gap: var(--asm-space-6);
210
+ }
211
+
212
+ .status-card {
213
+ background-color: var(--asm-color-surface-muted);
214
+ border: 1px solid var(--asm-color-border);
215
+ border-radius: var(--asm-radius-md);
216
+ padding: var(--asm-space-6);
217
+ }
218
+
219
+ .status-card h4 {
220
+ font-size: 0.9rem;
221
+ color: var(--asm-color-text-muted);
222
+ margin-bottom: var(--asm-space-2);
223
+ text-transform: uppercase;
224
+ letter-spacing: 0.05em;
225
+ }
226
+
227
+ .status-card p {
228
+ font-size: 1rem;
229
+ color: var(--asm-color-text);
230
+ word-break: break-all;
231
+ }
232
+
233
+ .status-list {
234
+ list-style: none;
235
+ margin-top: var(--asm-space-3);
236
+ }
237
+
238
+ .status-list li {
239
+ padding: var(--asm-space-2) 0;
240
+ color: var(--asm-color-text);
241
+ font-size: 0.95rem;
242
+ }
243
+
244
+ .sync-button {
245
+ margin-top: var(--asm-space-4);
246
+ padding: var(--asm-space-3) var(--asm-space-6);
247
+ background-color: var(--asm-color-button-primary-bg);
248
+ color: var(--asm-color-button-primary-text);
249
+ border: none;
250
+ border-radius: var(--asm-radius-md);
251
+ cursor: pointer;
252
+ font-size: 0.95rem;
253
+ font-weight: 500;
254
+ transition: all 0.2s ease;
255
+ }
256
+
257
+ .sync-button:hover:not(:disabled) {
258
+ background-color: var(--asm-color-button-primary-bg-hover);
259
+ box-shadow: var(--asm-effect-shadow-sm);
260
+ }
261
+
262
+ .sync-button:disabled {
263
+ opacity: 0.6;
264
+ cursor: not-allowed;
265
+ }
266
+
267
+ .sync-result {
268
+ margin-top: var(--asm-space-3);
269
+ padding: var(--asm-space-4);
270
+ border-radius: var(--asm-radius-md);
271
+ font-size: 0.9rem;
272
+ }
273
+
274
+ .sync-result.success {
275
+ background-color: var(--asm-color-success-100);
276
+ color: var(--asm-color-success-600);
277
+ border: 1px solid var(--asm-color-success-200);
278
+ }
279
+
280
+ .sync-result.error {
281
+ background-color: var(--asm-color-danger-100);
282
+ color: var(--asm-color-danger-600);
283
+ border: 1px solid var(--asm-color-danger-200);
284
+ }
285
+
286
+ .nav-tabs {
287
+ display: flex;
288
+ gap: var(--asm-space-2);
289
+ margin-bottom: var(--asm-space-6);
290
+ border-bottom: 2px solid var(--asm-color-border);
291
+ overflow-x: auto;
292
+ }
293
+
294
+ .nav-tab {
295
+ padding: var(--asm-space-3) var(--asm-space-4);
296
+ background: none;
297
+ border: none;
298
+ border-bottom: 3px solid transparent;
299
+ color: var(--asm-color-text-muted);
300
+ cursor: pointer;
301
+ font-size: 0.95rem;
302
+ font-weight: 500;
303
+ transition: all var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
304
+ white-space: nowrap;
305
+ }
306
+
307
+ .nav-tab:hover {
308
+ color: var(--asm-color-text);
309
+ }
310
+
311
+ .nav-tab.active {
312
+ color: var(--asm-color-primary-600);
313
+ border-bottom-color: var(--asm-color-primary-600);
314
+ }
315
+
316
+ .overview-section {
317
+ animation: fadeIn var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
318
+ }
319
+
320
+ .overview-header {
321
+ margin-bottom: var(--asm-space-8);
322
+ }
323
+
324
+ .overview-title {
325
+ font-size: 2rem;
326
+ font-weight: 700;
327
+ color: var(--asm-color-text);
328
+ margin-bottom: var(--asm-space-3);
329
+ }
330
+
331
+ .overview-description {
332
+ font-size: 1.125rem;
333
+ color: var(--asm-color-text-muted);
334
+ line-height: 1.6;
335
+ }
336
+
337
+ .overview-grid {
338
+ display: grid;
339
+ grid-template-columns: repeat(auto-fit, minmax(380px, 1fr));
340
+ gap: var(--asm-space-6);
341
+ }
342
+
343
+ .feature-card {
344
+ background: linear-gradient(135deg, var(--asm-color-surface) 0%, var(--asm-color-surface-muted) 100%);
345
+ border: 1px solid var(--asm-color-border);
346
+ border-radius: var(--asm-radius-lg);
347
+ padding: var(--asm-space-6);
348
+ transition: all var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
349
+ }
350
+
351
+ .feature-card:hover {
352
+ transform: translateY(-4px);
353
+ box-shadow: var(--asm-effect-shadow-lg);
354
+ border-color: var(--asm-color-primary-600);
355
+ }
356
+
357
+ .feature-icon {
358
+ font-size: 2.5rem;
359
+ margin-bottom: var(--asm-space-3);
360
+ display: inline-block;
361
+ }
362
+
363
+ .feature-card h3 {
364
+ font-size: 1.25rem;
365
+ font-weight: 600;
366
+ color: var(--asm-color-text);
367
+ margin-bottom: var(--asm-space-4);
368
+ }
369
+
370
+ .feature-list {
371
+ list-style: none;
372
+ display: flex;
373
+ flex-direction: column;
374
+ gap: var(--asm-space-3);
375
+ }
376
+
377
+ .feature-list li {
378
+ display: flex;
379
+ align-items: flex-start;
380
+ gap: var(--asm-space-2);
381
+ color: var(--asm-color-text);
382
+ line-height: 1.5;
383
+ }
384
+
385
+ .feature-dot {
386
+ color: var(--asm-color-primary-600);
387
+ font-weight: bold;
388
+ flex-shrink: 0;
389
+ }
390
+
391
+ .get-started-section {
392
+ animation: fadeIn var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
393
+ }
394
+
395
+ .gs-header {
396
+ margin-bottom: var(--asm-space-8);
397
+ }
398
+
399
+ .gs-title {
400
+ font-size: 2rem;
401
+ font-weight: 700;
402
+ color: var(--asm-color-text);
403
+ margin-bottom: var(--asm-space-3);
404
+ }
405
+
406
+ .gs-intro {
407
+ font-size: 1.125rem;
408
+ color: var(--asm-color-text-muted);
409
+ line-height: 1.6;
410
+ }
411
+
412
+ .steps-container {
413
+ display: flex;
414
+ flex-direction: column;
415
+ gap: var(--asm-space-4);
416
+ margin-bottom: var(--asm-space-8);
417
+ }
418
+
419
+ .step-item {
420
+ border: 1px solid var(--asm-color-border);
421
+ border-radius: var(--asm-radius-lg);
422
+ overflow: hidden;
423
+ transition: all var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
424
+ }
425
+
426
+ .step-item:hover {
427
+ border-color: var(--asm-color-primary-600);
428
+ box-shadow: var(--asm-effect-shadow-md);
429
+ }
430
+
431
+ .step-header {
432
+ width: 100%;
433
+ display: flex;
434
+ align-items: center;
435
+ gap: var(--asm-space-4);
436
+ padding: var(--asm-space-4) var(--asm-space-6);
437
+ background-color: var(--asm-color-surface);
438
+ border: none;
439
+ cursor: pointer;
440
+ transition: all var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
441
+ }
442
+
443
+ .step-header:hover {
444
+ background-color: var(--asm-color-surface-muted);
445
+ }
446
+
447
+ .step-header.expanded {
448
+ background-color: var(--asm-color-surface-muted);
449
+ }
450
+
451
+ .step-number {
452
+ display: flex;
453
+ align-items: center;
454
+ justify-content: center;
455
+ width: 40px;
456
+ height: 40px;
457
+ border-radius: var(--asm-radius-full);
458
+ background: linear-gradient(135deg, var(--asm-color-primary-600) 0%, var(--asm-color-primary-700) 100%);
459
+ color: white;
460
+ font-weight: 700;
461
+ font-size: 1.125rem;
462
+ flex-shrink: 0;
463
+ }
464
+
465
+ .step-info {
466
+ flex: 1;
467
+ text-align: left;
468
+ }
469
+
470
+ .step-info h3 {
471
+ font-size: 1rem;
472
+ font-weight: 600;
473
+ color: var(--asm-color-text);
474
+ margin-bottom: var(--asm-space-1);
475
+ }
476
+
477
+ .step-info p {
478
+ font-size: 0.9rem;
479
+ color: var(--asm-color-text-muted);
480
+ }
481
+
482
+ .step-toggle {
483
+ font-size: 1.5rem;
484
+ color: var(--asm-color-primary-600);
485
+ font-weight: bold;
486
+ flex-shrink: 0;
487
+ }
488
+
489
+ .step-content {
490
+ padding: var(--asm-space-6);
491
+ background-color: var(--asm-color-surface-muted);
492
+ border-top: 1px solid var(--asm-color-border);
493
+ animation: slideDown var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
494
+ }
495
+
496
+ .code-block {
497
+ background-color: var(--asm-color-text);
498
+ color: var(--asm-color-bg);
499
+ padding: var(--asm-space-4);
500
+ border-radius: var(--asm-radius-md);
501
+ overflow-x: auto;
502
+ font-family: var(--asm-font-family-mono, monospace);
503
+ font-size: 0.85rem;
504
+ line-height: 1.5;
505
+ margin: 0;
506
+ }
507
+
508
+ .tips-section {
509
+ display: flex;
510
+ gap: var(--asm-space-6);
511
+ padding: var(--asm-space-6);
512
+ background: linear-gradient(135deg, var(--asm-color-primary-50) 0%, var(--asm-color-secondary-50) 100%);
513
+ border: 2px solid var(--asm-color-primary-200);
514
+ border-radius: var(--asm-radius-lg);
515
+ }
516
+
517
+ .tips-icon {
518
+ font-size: 2rem;
519
+ flex-shrink: 0;
520
+ }
521
+
522
+ .tips-content h3 {
523
+ font-size: 1.125rem;
524
+ font-weight: 600;
525
+ color: var(--asm-color-text);
526
+ margin-bottom: var(--asm-space-3);
527
+ }
528
+
529
+ .tips-list {
530
+ list-style: none;
531
+ display: flex;
532
+ flex-direction: column;
533
+ gap: var(--asm-space-2);
534
+ }
535
+
536
+ .tips-list li {
537
+ display: flex;
538
+ align-items: flex-start;
539
+ gap: var(--asm-space-2);
540
+ color: var(--asm-color-text);
541
+ font-size: 0.95rem;
542
+ line-height: 1.5;
543
+ }
544
+
545
+ .tips-list li::before {
546
+ content: "✓";
547
+ color: var(--asm-color-semantic-success);
548
+ font-weight: bold;
549
+ flex-shrink: 0;
550
+ }
551
+
552
+ @media (max-width: 768px) {
553
+ .app-header {
554
+ flex-direction: column;
555
+ }
556
+
557
+ .app-main {
558
+ padding: var(--asm-space-6);
559
+ }
560
+
561
+ .panel-grid {
562
+ grid-template-columns: 1fr;
563
+ }
564
+
565
+ .app-header h1 {
566
+ font-size: 1.5rem;
567
+ }
568
+
569
+ .overview-grid {
570
+ grid-template-columns: 1fr;
571
+ }
572
+
573
+ .tips-section {
574
+ flex-direction: column;
575
+ }
576
+
577
+ .step-header {
578
+ flex-direction: column;
579
+ align-items: flex-start;
580
+ }
581
+
582
+ .step-toggle {
583
+ align-self: flex-end;
584
+ margin-top: calc(var(--asm-space-4) * -1);
585
+ }
586
+ }
587
+
588
+ @keyframes fadeIn {
589
+ from {
590
+ opacity: 0;
591
+ transform: translateY(8px);
592
+ }
593
+ to {
594
+ opacity: 1;
595
+ transform: translateY(0);
596
+ }
597
+ }
598
+
599
+ @keyframes slideDown {
600
+ from {
601
+ opacity: 0;
602
+ max-height: 0;
603
+ }
604
+ to {
605
+ opacity: 1;
606
+ max-height: 500px;
607
+ }
608
+ }
609
+
610
+ .logo {
611
+ width: 70px;
612
+ height: 70px;
613
+ }
614
+
615
+ .logo img {
616
+ width: 100%;
617
+ height: 100%;
618
+ }
619
+
620
+
621
+
622
+ /* Mobile adjustments */
623
+ @media (max-width: 768px) {
624
+ .logo {
625
+ width: 50px;
626
+ height: 50px;
627
+ }
628
+ }
629
+
630
+ /* Tablet adjustments */
631
+ @media (min-width: 769px) and (max-width: 1024px) {
632
+ .logo {
633
+ width: 60px;
634
+ height: 60px;
635
+ }
636
+ }
637
+
638
+ /* Desktop adjustments */
639
+ @media (min-width: 1025px) {
640
+ .logo {
641
+ width: 70px;
642
+ height: 70px;
643
+ }
644
+ }