@klodd/ds 5.4.2 → 5.5.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 (44) hide show
  1. package/README.md +4 -3
  2. package/SKILL.md +19 -7
  3. package/css/00-primitives.css +1 -22
  4. package/css/10-semantic.css +22 -100
  5. package/css/components/avatar.css +6 -6
  6. package/css/components/badge.css +2 -2
  7. package/css/components/button.css +1 -2
  8. package/css/components/chip.css +2 -2
  9. package/css/components/feedback.css +4 -4
  10. package/css/components/hero.css +1 -1
  11. package/css/components/hub-card.css +2 -2
  12. package/css/components/inline-edit.css +2 -2
  13. package/css/components/list-row.css +2 -2
  14. package/css/components/nav.css +12 -4
  15. package/css/components/pwa-avatar.css +4 -4
  16. package/css/components/swipe-stack.css +2 -2
  17. package/css/components/upload-spinner.css +2 -2
  18. package/css/index.css +0 -9
  19. package/package.json +1 -1
  20. package/references/02-components.md +1 -1
  21. package/references/04-locked-decisions/0003-radix-colors-oklch.md +1 -1
  22. package/references/04-locked-decisions/0006-mauve-neutral.md +0 -4
  23. package/references/04-locked-decisions/0015-panel-title-tag-doctrine.md +2 -2
  24. package/references/04-locked-decisions/0016-mina-sidor-doctrine.md +0 -2
  25. package/references/04-locked-decisions/0020-domain-to-package-lift.md +2 -2
  26. package/references/04-locked-decisions/0023-progress-list-utility.md +1 -1
  27. package/references/04-locked-decisions/0024-tightened-component-lift-doctrine.md +135 -0
  28. package/references/04-locked-decisions/{0015-turbo-nav-script-init.md → 0025-turbo-nav-script-init.md} +3 -1
  29. package/references/04-locked-decisions/{0016-async-progress-fetch-fn.md → 0026-async-progress-fetch-fn.md} +3 -1
  30. package/references/05-open-decisions/0001-tx-row-to-list-row-migration-CLOSED.md +1 -1
  31. package/references/05-open-decisions/0008-legacy-token-migration-CLOSED.md +6 -6
  32. package/references/05-open-decisions/0014-ekonom-colored-row-migration-CLOSED.md +1 -2
  33. package/references/05-open-decisions/0017-async-progress-pipeline-gaps.md +1 -1
  34. package/references/05-open-decisions/0018-build-ds-prune.md +35 -0
  35. package/references/DESIGN-LANGUAGE.md +1 -1
  36. package/css/components/expandable-row.css +0 -176
  37. package/css/components/icon-circle.css +0 -46
  38. package/css/components/item-stack.css +0 -43
  39. package/css/components/kvp-arrow.css +0 -22
  40. package/css/components/matched-row.css +0 -51
  41. package/css/components/review-banner.css +0 -70
  42. package/css/components/status-icon.css +0 -32
  43. package/css/components/tag-inline.css +0 -21
  44. package/js/index.js +0 -95
@@ -1,70 +0,0 @@
1
- /* ================================================================
2
- components/review-banner.css
3
- Generic warning-CTA-banner: titel + meta + chevron i pill-form.
4
- Anvands for "X att granska/atgarda"-rader som lankar till en
5
- review-vy. Warning-toned bakgrund.
6
-
7
- Lyft fran Ekonom v4.4.0 (ADR 0020). Konsumeras av alla appar som
8
- har en granskning/atgards-flow.
9
-
10
- Blocks:
11
- .review-banner - klickbar warning-CTA-banner
12
-
13
- Element:
14
- .review-banner__title - rubrik-text (fs-14 medium)
15
- .review-banner__meta - underrubrik (fs-12 subtle)
16
- .review-banner__chev - chevron-svg, hoger-stalld
17
-
18
- HTML:
19
- <a href="/granskning" class="review-banner">
20
- <div>
21
- <p class="review-banner__title">X att granska</p>
22
- <p class="review-banner__meta">Mojliga utgifter</p>
23
- </div>
24
- <svg class="review-banner__chev"...></svg>
25
- </a>
26
- ================================================================ */
27
- .review-banner {
28
- display: flex;
29
- align-items: center;
30
- justify-content: space-between;
31
- gap: var(--space-12);
32
- background: var(--warning-dim);
33
- border: var(--bw-hairline) solid var(--warning-border);
34
- border-radius: var(--radius-14);
35
- padding: var(--space-14) var(--space-16);
36
- margin-bottom: var(--space-14);
37
- color: var(--text-default);
38
- text-decoration: none;
39
- transition: var(--tr-bg-base);
40
- }
41
-
42
- @media (hover: hover) and (pointer: fine) {
43
- .review-banner:hover {
44
- text-decoration: none;
45
- background: var(--warning-hover, var(--warning-dim));
46
- }
47
- }
48
-
49
- .review-banner:focus-visible {
50
- outline: 2px solid var(--accent-9);
51
- outline-offset: 2px;
52
- }
53
-
54
- .review-banner__title {
55
- font-size: var(--fs-14);
56
- font-weight: var(--fw-medium);
57
- color: var(--text-default);
58
- margin: 0;
59
- }
60
-
61
- .review-banner__meta {
62
- font-size: var(--fs-12);
63
- color: var(--text-subtle);
64
- margin: var(--space-2) 0 0;
65
- }
66
-
67
- .review-banner__chev {
68
- opacity: 0.7;
69
- flex-shrink: 0;
70
- }
@@ -1,32 +0,0 @@
1
- /* ================================================================
2
- components/status-icon.css
3
- Inline status-icon i text-flow (clock, alert, check). Tightare
4
- pa baseline + flex-shrink:0 sa den inte staucher i smala containers.
5
-
6
- Anvands typiskt efter en description-text for att signalera tillstand:
7
- pending, stale, success, warning.
8
-
9
- Lyft fran Ekonom v4.4.0 (var .tx-pending-icon, ADR 0020).
10
-
11
- Blocks:
12
- .status-icon - inline-flex SVG-wrapper for status-indicator
13
-
14
- Modifiers:
15
- .status-icon--pending - default muted-color (clock-icon)
16
- .status-icon--stale - warning-color (clock som blivit gammal)
17
- .status-icon--success - positive-color (check)
18
- .status-icon--warning - warning-color (alert)
19
- ================================================================ */
20
- .status-icon {
21
- display: inline-flex;
22
- align-items: center;
23
- margin-left: var(--space-6);
24
- color: var(--text-muted);
25
- vertical-align: -2px;
26
- flex-shrink: 0;
27
- }
28
-
29
- .status-icon--pending { color: var(--text-muted); }
30
- .status-icon--stale { color: var(--warning); }
31
- .status-icon--success { color: var(--positive); }
32
- .status-icon--warning { color: var(--warning); }
@@ -1,21 +0,0 @@
1
- /* ================================================================
2
- components/tag-inline.css
3
- Diskret inline-tag som markerar metadata in-line med brodtext.
4
- Mindre an .chip - har ingen pill-bakgrund. Bara avvikande font-
5
- storlek + muted color + slight tracking.
6
-
7
- Anvands typiskt for inline-status (estimat, beta, deprecated) som
8
- ska synas men inte dominera surrounding text.
9
-
10
- Lyft fran Ekonom v4.4.0 (var .estimat-tag, ADR 0020).
11
-
12
- Blocks:
13
- .tag-inline - inline-tag i muted text-stil
14
- ================================================================ */
15
- .tag-inline {
16
- font-style: normal;
17
- font-size: var(--fs-11);
18
- color: var(--text-muted);
19
- font-weight: var(--fw-regular);
20
- letter-spacing: var(--ls-tracker, 0.02em);
21
- }
package/js/index.js DELETED
@@ -1,95 +0,0 @@
1
- /* @klodd/ds - JavaScript entry point.
2
- *
3
- * Convenience-aggregator som kor enskilda init-funktioner. Default
4
- * fungerar utan konfiguration (LLM-vanligt). Konfig-objektet kan
5
- * over-rida vad som ska aktiveras.
6
- *
7
- * Anvandning:
8
- *
9
- * <script src="https://unpkg.com/@klodd/ds/js/index.js" defer></script>
10
- * <script>
11
- * window.addEventListener('DOMContentLoaded', () => {
12
- * KloddDS.init();
13
- * });
14
- * </script>
15
- *
16
- * Eller med konfig:
17
- *
18
- * KloddDS.init({
19
- * swPath: '/service-worker.js',
20
- * lucide: true,
21
- * barStyles: true,
22
- * heroRoll: true,
23
- * pullToRefresh: false,
24
- * turboNav: false,
25
- * navOptimistic: true,
26
- * sheetDrag: true,
27
- * pwaRegister: false, // satt true + swPath for SW + install-prompts
28
- * });
29
- *
30
- * Individuella moduler kan ocksa importeras separat fran js/-mappen.
31
- * KloddDS.init() ar bara en convenience-wrapper - den inkluderar inte
32
- * filerna sjalv, dvs varje modul-fil maste laddas via <script>-tag.
33
- *
34
- * Defaults ar konservativa: heavy beteenden (PtR, Turbo Drive, PWA
35
- * register) ar OFF default. App-mantainern aktiverar opt-in.
36
- */
37
- 'use strict';
38
-
39
- (function (root) {
40
- const defaults = {
41
- lucide: true,
42
- barStyles: true,
43
- heroRoll: true,
44
- navOptimistic: true,
45
- sheetDrag: true,
46
- pullToRefresh: false,
47
- turboNav: false,
48
- pwaRegister: false,
49
- swPath: '/static/sw.js',
50
- };
51
-
52
- const KloddDS = {
53
- init(config) {
54
- const cfg = Object.assign({}, defaults, config || {});
55
-
56
- if (cfg.lucide && typeof root.initLucide === 'function') {
57
- root.initLucide();
58
- } else if (cfg.lucide && root.lucide && typeof root.lucide.createIcons === 'function') {
59
- root.lucide.createIcons();
60
- }
61
-
62
- if (cfg.barStyles && typeof root.initBarStyles === 'function') {
63
- root.initBarStyles();
64
- }
65
-
66
- if (cfg.heroRoll && typeof root.initHeroRoll === 'function') {
67
- root.initHeroRoll();
68
- }
69
-
70
- if (cfg.navOptimistic && typeof root.initNavOptimistic === 'function') {
71
- root.initNavOptimistic();
72
- }
73
-
74
- if (cfg.sheetDrag && typeof root.initSheetDrag === 'function') {
75
- root.initSheetDrag();
76
- }
77
-
78
- if (cfg.pullToRefresh && typeof root.initPullToRefresh === 'function') {
79
- root.initPullToRefresh();
80
- }
81
-
82
- if (cfg.turboNav && typeof root.initTurboNav === 'function') {
83
- root.initTurboNav();
84
- }
85
-
86
- if (cfg.pwaRegister && typeof root.initPwaRegister === 'function') {
87
- root.initPwaRegister({ swPath: cfg.swPath });
88
- }
89
- },
90
-
91
- version: '2.0.0',
92
- };
93
-
94
- root.KloddDS = KloddDS;
95
- })(typeof window !== 'undefined' ? window : globalThis);