@asafarim/shared-i18n 0.7.0 → 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 -62
  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 -644
  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,644 +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
- .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
- }
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
+ }