zdp-design-system 0.43.8

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 (110) hide show
  1. package/CHANGELOG.md +449 -0
  2. package/LICENSE +21 -0
  3. package/README.md +568 -0
  4. package/THIRD_PARTY_NOTICES.md +34 -0
  5. package/dist/code.ts +2 -0
  6. package/dist/combobox.ts +9 -0
  7. package/dist/command.ts +1 -0
  8. package/dist/components/Accordion.svelte +97 -0
  9. package/dist/components/Avatar.svelte +90 -0
  10. package/dist/components/Badge.svelte +61 -0
  11. package/dist/components/Breadcrumb.svelte +97 -0
  12. package/dist/components/Button.svelte +163 -0
  13. package/dist/components/Callout.svelte +81 -0
  14. package/dist/components/Card.svelte +151 -0
  15. package/dist/components/CardHeader.svelte +58 -0
  16. package/dist/components/Checkbox.svelte +135 -0
  17. package/dist/components/CodeBlock.svelte +247 -0
  18. package/dist/components/Combobox.svelte +552 -0
  19. package/dist/components/CommandField.svelte +230 -0
  20. package/dist/components/ConfirmAction.svelte +307 -0
  21. package/dist/components/Container.svelte +63 -0
  22. package/dist/components/Dialog.svelte +303 -0
  23. package/dist/components/Disclosure.svelte +176 -0
  24. package/dist/components/Divider.svelte +41 -0
  25. package/dist/components/EmptyState.svelte +79 -0
  26. package/dist/components/ErrorText.svelte +18 -0
  27. package/dist/components/Field.svelte +38 -0
  28. package/dist/components/Grid.svelte +76 -0
  29. package/dist/components/HelpText.svelte +17 -0
  30. package/dist/components/Icon.svelte +45 -0
  31. package/dist/components/IconButton.svelte +162 -0
  32. package/dist/components/IdentityChip.svelte +130 -0
  33. package/dist/components/Inline.svelte +85 -0
  34. package/dist/components/InlineCode.svelte +27 -0
  35. package/dist/components/Input.svelte +109 -0
  36. package/dist/components/Kbd.svelte +63 -0
  37. package/dist/components/KeyValue.svelte +73 -0
  38. package/dist/components/Label.svelte +43 -0
  39. package/dist/components/Link.svelte +70 -0
  40. package/dist/components/LocaleSwitcher.svelte +209 -0
  41. package/dist/components/Menu.svelte +491 -0
  42. package/dist/components/Page.svelte +36 -0
  43. package/dist/components/PageHeader.svelte +93 -0
  44. package/dist/components/Pagination.svelte +297 -0
  45. package/dist/components/Popover.svelte +208 -0
  46. package/dist/components/Progress.svelte +111 -0
  47. package/dist/components/Radio.svelte +132 -0
  48. package/dist/components/Section.svelte +52 -0
  49. package/dist/components/SegmentedControl.svelte +190 -0
  50. package/dist/components/Select.svelte +88 -0
  51. package/dist/components/ShareDock.svelte +304 -0
  52. package/dist/components/Sheet.svelte +332 -0
  53. package/dist/components/ShortcutHint.svelte +52 -0
  54. package/dist/components/Skeleton.svelte +82 -0
  55. package/dist/components/SkipLink.svelte +40 -0
  56. package/dist/components/SortHeader.svelte +138 -0
  57. package/dist/components/Spinner.svelte +82 -0
  58. package/dist/components/Stack.svelte +62 -0
  59. package/dist/components/StatusToast.svelte +133 -0
  60. package/dist/components/Surface.svelte +53 -0
  61. package/dist/components/Switch.svelte +152 -0
  62. package/dist/components/Table.svelte +94 -0
  63. package/dist/components/TableToolbar.svelte +195 -0
  64. package/dist/components/Tabs.svelte +205 -0
  65. package/dist/components/TermSheet.svelte +392 -0
  66. package/dist/components/TermTrigger.svelte +70 -0
  67. package/dist/components/TextScaleControl.svelte +219 -0
  68. package/dist/components/Textarea.svelte +106 -0
  69. package/dist/components/ThemeToggle.svelte +148 -0
  70. package/dist/components/Toast.svelte +180 -0
  71. package/dist/components/Toolbar.svelte +83 -0
  72. package/dist/components/Tooltip.svelte +199 -0
  73. package/dist/components/VisuallyHidden.svelte +18 -0
  74. package/dist/disclosure.ts +11 -0
  75. package/dist/focusable.ts +36 -0
  76. package/dist/identity.ts +5 -0
  77. package/dist/index.d.ts +106 -0
  78. package/dist/index.js +76 -0
  79. package/dist/index.ts +106 -0
  80. package/dist/menu.ts +12 -0
  81. package/dist/modal-layer.ts +108 -0
  82. package/dist/pagination.ts +10 -0
  83. package/dist/preferences.js +14 -0
  84. package/dist/preferences.ts +36 -0
  85. package/dist/progress.ts +4 -0
  86. package/dist/schemas/design-tokens.schema.json +119 -0
  87. package/dist/segmented.ts +8 -0
  88. package/dist/share.d.ts +48 -0
  89. package/dist/share.js +115 -0
  90. package/dist/share.ts +99 -0
  91. package/dist/sheet.ts +3 -0
  92. package/dist/shortcuts.js +125 -0
  93. package/dist/shortcuts.ts +153 -0
  94. package/dist/styles/brand-fonts.css +10 -0
  95. package/dist/styles/components.css +4686 -0
  96. package/dist/styles/expressive-fonts.css +2 -0
  97. package/dist/styles/index.css +2 -0
  98. package/dist/styles/locale-fonts.css +4 -0
  99. package/dist/styles/tokens.css +413 -0
  100. package/dist/table-tools.ts +10 -0
  101. package/dist/term.ts +16 -0
  102. package/dist/theme.ts +2 -0
  103. package/dist/toast.ts +14 -0
  104. package/dist/tokens/zdp.tokens.json +241 -0
  105. package/dist/tokens.js +122 -0
  106. package/dist/tokens.ts +123 -0
  107. package/docs/CONSUMER_CONTRACT.md +482 -0
  108. package/docs/EXTERNAL_UI_ADOPTION.md +141 -0
  109. package/docs/INTERACTIVE_PRIMITIVE_AUDIT.md +127 -0
  110. package/package.json +78 -0
@@ -0,0 +1,97 @@
1
+ <script lang="ts">
2
+ import Disclosure from './Disclosure.svelte';
3
+ import type {
4
+ ZdpAccordionItem,
5
+ ZdpAccordionMode,
6
+ ZdpDisclosureHeadingLevel
7
+ } from '../disclosure';
8
+
9
+ export let items: readonly ZdpAccordionItem[] = [];
10
+ export let mode: ZdpAccordionMode = 'multiple';
11
+ export let ariaLabel = 'Collapsed sections';
12
+ export let headingLevel: ZdpDisclosureHeadingLevel | null = 3;
13
+ export let onOpenChange:
14
+ | ((
15
+ item: ZdpAccordionItem,
16
+ open: boolean,
17
+ openIds: readonly string[]
18
+ ) => void)
19
+ | null = null;
20
+
21
+ let openIds: readonly string[] = [];
22
+ let itemOpenSignature = '';
23
+
24
+ $: nextItemOpenSignature = `${mode}|${items
25
+ .map((item) => `${item.id}:${item.open === true}:${item.disabled === true}`)
26
+ .join('|')}`;
27
+ $: if (nextItemOpenSignature !== itemOpenSignature) {
28
+ openIds = normalizeInitialOpenIds(items, mode);
29
+ itemOpenSignature = nextItemOpenSignature;
30
+ }
31
+
32
+ function normalizeInitialOpenIds(
33
+ sourceItems: readonly ZdpAccordionItem[],
34
+ currentMode: ZdpAccordionMode
35
+ ): readonly string[] {
36
+ const initialOpenIds = sourceItems.filter((item) => item.open && !item.disabled).map((item) => item.id);
37
+
38
+ return currentMode === 'single' ? initialOpenIds.slice(0, 1) : initialOpenIds;
39
+ }
40
+
41
+ function isItemOpen(id: string): boolean {
42
+ return openIds.includes(id);
43
+ }
44
+
45
+ function handleItemOpenChange(item: ZdpAccordionItem, nextOpen: boolean): void {
46
+ if (item.disabled) {
47
+ return;
48
+ }
49
+
50
+ const nextOpenIds = resolveNextOpenIds(item.id, nextOpen);
51
+ openIds = nextOpenIds;
52
+ onOpenChange?.(item, nextOpen, nextOpenIds);
53
+ }
54
+
55
+ function resolveNextOpenIds(itemId: string, nextOpen: boolean): readonly string[] {
56
+ if (mode === 'single') {
57
+ return nextOpen ? [itemId] : [];
58
+ }
59
+
60
+ if (nextOpen) {
61
+ return openIds.includes(itemId) ? openIds : [...openIds, itemId];
62
+ }
63
+
64
+ return openIds.filter((id) => id !== itemId);
65
+ }
66
+ </script>
67
+
68
+ <div class="zdp-accordion" role="list" aria-label={ariaLabel}>
69
+ {#each items as item (item.id)}
70
+ <div class="zdp-accordion__item" role="listitem">
71
+ <Disclosure
72
+ id={item.id}
73
+ title={item.title}
74
+ open={isItemOpen(item.id)}
75
+ disabled={item.disabled ?? false}
76
+ {headingLevel}
77
+ onOpenChange={(nextOpen) => handleItemOpenChange(item, nextOpen)}
78
+ >
79
+ <p>{item.content}</p>
80
+ </Disclosure>
81
+ </div>
82
+ {/each}
83
+ </div>
84
+
85
+ <style>
86
+ .zdp-accordion {
87
+ color: var(--zdp-color-ink-normal);
88
+ display: grid;
89
+ font-family: var(--zdp-font-family-sans);
90
+ gap: var(--zdp-space-2);
91
+ min-width: 0;
92
+ }
93
+
94
+ .zdp-accordion__item {
95
+ min-width: 0;
96
+ }
97
+ </style>
@@ -0,0 +1,90 @@
1
+ <script lang="ts">
2
+ import type { ZdpAvatarSize, ZdpAvatarTone } from '../identity';
3
+
4
+ export let label: string | null = null;
5
+ export let initials: string | null = null;
6
+ export let imageSrc: string | null = null;
7
+ export let size: ZdpAvatarSize = 'md';
8
+ export let tone: ZdpAvatarTone = 'neutral';
9
+ export let decorative = false;
10
+
11
+ $: resolvedLabel = label?.trim() || 'User';
12
+ $: resolvedInitials = initials?.trim() ?? '';
13
+ $: accessibilityLabel = decorative ? undefined : resolvedLabel;
14
+ </script>
15
+
16
+ <span
17
+ class={`zdp-avatar zdp-avatar--${size} zdp-avatar--${tone}`}
18
+ role={decorative ? undefined : 'img'}
19
+ aria-label={accessibilityLabel}
20
+ aria-hidden={decorative ? 'true' : undefined}
21
+ >
22
+ {#if imageSrc}
23
+ <img class="zdp-avatar__image" src={imageSrc} alt="" />
24
+ {:else if resolvedInitials}
25
+ <span class="zdp-avatar__initials" aria-hidden="true">{resolvedInitials}</span>
26
+ {:else}
27
+ <span class="zdp-avatar__initials" aria-hidden="true"></span>
28
+ {/if}
29
+ </span>
30
+
31
+ <style>
32
+ .zdp-avatar {
33
+ align-items: center;
34
+ background: var(--zdp-color-surface-raised);
35
+ border: var(--zdp-control-border-width) solid var(--zdp-color-line-subtle);
36
+ border-radius: 50%;
37
+ box-sizing: border-box;
38
+ color: var(--zdp-color-ink-strong);
39
+ display: inline-flex;
40
+ flex: 0 0 auto;
41
+ font-family: var(--zdp-font-family-sans);
42
+ font-weight: var(--zdp-font-weight-medium);
43
+ justify-content: center;
44
+ line-height: 1;
45
+ overflow: hidden;
46
+ text-align: center;
47
+ vertical-align: middle;
48
+ }
49
+
50
+ .zdp-avatar--sm {
51
+ font-size: var(--zdp-font-size-xs);
52
+ height: var(--zdp-control-height-sm);
53
+ width: var(--zdp-control-height-sm);
54
+ }
55
+
56
+ .zdp-avatar--md {
57
+ font-size: var(--zdp-type-caption-size);
58
+ height: var(--zdp-control-height-md);
59
+ width: var(--zdp-control-height-md);
60
+ }
61
+
62
+ .zdp-avatar--lg {
63
+ font-size: var(--zdp-type-body-size);
64
+ height: calc(var(--zdp-control-height-md) + var(--zdp-space-4));
65
+ width: calc(var(--zdp-control-height-md) + var(--zdp-space-4));
66
+ }
67
+
68
+ .zdp-avatar--primary {
69
+ background: var(--zdp-color-accent-primary-soft);
70
+ border-color: var(--zdp-color-accent-primary-strong);
71
+ }
72
+
73
+ .zdp-avatar__image {
74
+ display: block;
75
+ height: 100%;
76
+ object-fit: cover;
77
+ width: 100%;
78
+ }
79
+
80
+ .zdp-avatar__initials {
81
+ display: block;
82
+ max-width: 100%;
83
+ overflow: hidden;
84
+ padding: 0 var(--zdp-space-1);
85
+ text-overflow: ellipsis;
86
+ -webkit-user-select: none;
87
+ user-select: none;
88
+ white-space: nowrap;
89
+ }
90
+ </style>
@@ -0,0 +1,61 @@
1
+ <script lang="ts">
2
+ export let tone: 'neutral' | 'primary' | 'success' | 'warning' | 'danger' = 'neutral';
3
+ export let size: 'sm' | 'md' = 'md';
4
+ </script>
5
+
6
+ <span class={`zdp-badge zdp-badge--${tone} zdp-badge--${size}`}>
7
+ <slot />
8
+ </span>
9
+
10
+ <style>
11
+ .zdp-badge {
12
+ align-items: center;
13
+ background: var(--zdp-color-surface-panel);
14
+ border: 1px solid var(--zdp-color-line-strong);
15
+ border-radius: var(--zdp-control-radius);
16
+ box-sizing: border-box;
17
+ color: var(--zdp-color-ink-strong);
18
+ display: inline-flex;
19
+ font-family: var(--zdp-font-family-sans);
20
+ font-weight: var(--zdp-font-weight-medium);
21
+ justify-content: center;
22
+ line-height: var(--zdp-type-caption-line-height);
23
+ max-width: 100%;
24
+ min-width: 0;
25
+ text-decoration: none;
26
+ white-space: nowrap;
27
+ }
28
+
29
+ .zdp-badge--sm {
30
+ font-size: var(--zdp-font-size-xs);
31
+ min-height: var(--zdp-control-height-sm);
32
+ padding: 0 var(--zdp-space-2);
33
+ }
34
+
35
+ .zdp-badge--md {
36
+ font-size: var(--zdp-type-caption-size);
37
+ min-height: var(--zdp-control-height-sm);
38
+ padding: 0 var(--zdp-space-3);
39
+ }
40
+
41
+ .zdp-badge--primary {
42
+ background: var(--zdp-color-accent-primary-soft);
43
+ border-color: var(--zdp-color-accent-primary-strong);
44
+ color: var(--zdp-color-ink-strong);
45
+ }
46
+
47
+ .zdp-badge--success {
48
+ border-color: var(--zdp-color-accent-success);
49
+ color: var(--zdp-color-ink-strong);
50
+ }
51
+
52
+ .zdp-badge--warning {
53
+ border-color: var(--zdp-color-accent-warning);
54
+ color: var(--zdp-color-ink-strong);
55
+ }
56
+
57
+ .zdp-badge--danger {
58
+ border-color: var(--zdp-color-accent-danger);
59
+ color: var(--zdp-color-accent-danger);
60
+ }
61
+ </style>
@@ -0,0 +1,97 @@
1
+ <script lang="ts">
2
+ interface BreadcrumbItem {
3
+ readonly label: string;
4
+ readonly href?: string;
5
+ readonly current?: boolean;
6
+ }
7
+
8
+ export let items: readonly BreadcrumbItem[] = [];
9
+ export let ariaLabel = 'Breadcrumb';
10
+
11
+ $: normalizedItems = items.map((item, index) => ({
12
+ ...item,
13
+ current: item.current === true || index === items.length - 1
14
+ }));
15
+ </script>
16
+
17
+ <nav class="zdp-breadcrumb" aria-label={ariaLabel}>
18
+ <ol class="zdp-breadcrumb__list">
19
+ {#each normalizedItems as item, index}
20
+ <li class="zdp-breadcrumb__item">
21
+ {#if index > 0}
22
+ <span class="zdp-breadcrumb__separator" aria-hidden="true">/</span>
23
+ {/if}
24
+
25
+ {#if item.href && !item.current}
26
+ <a class="zdp-breadcrumb__link" href={item.href}>{item.label}</a>
27
+ {:else}
28
+ <span class="zdp-breadcrumb__current" aria-current={item.current ? 'page' : undefined}>
29
+ {item.label}
30
+ </span>
31
+ {/if}
32
+ </li>
33
+ {/each}
34
+ </ol>
35
+ </nav>
36
+
37
+ <style>
38
+ .zdp-breadcrumb {
39
+ color: var(--zdp-color-ink-muted);
40
+ font-family: var(--zdp-font-family-sans);
41
+ font-size: var(--zdp-type-body-small-size);
42
+ line-height: var(--zdp-type-body-small-line-height);
43
+ min-width: 0;
44
+ }
45
+
46
+ .zdp-breadcrumb__list {
47
+ align-items: center;
48
+ display: flex;
49
+ flex-wrap: wrap;
50
+ gap: var(--zdp-space-2);
51
+ list-style: none;
52
+ margin: 0;
53
+ min-width: 0;
54
+ padding: 0;
55
+ }
56
+
57
+ .zdp-breadcrumb__item {
58
+ align-items: center;
59
+ display: inline-flex;
60
+ gap: var(--zdp-space-2);
61
+ min-width: 0;
62
+ }
63
+
64
+ .zdp-breadcrumb__link {
65
+ border-bottom: var(--zdp-control-focus-underline-width) solid transparent;
66
+ color: var(--zdp-color-ink-normal);
67
+ overflow-wrap: var(--zdp-i18n-overflow-wrap);
68
+ text-decoration-line: none;
69
+ transition:
70
+ background-color var(--zdp-motion-fast) ease,
71
+ border-color var(--zdp-motion-fast) ease,
72
+ color var(--zdp-motion-fast) ease;
73
+ }
74
+
75
+ .zdp-breadcrumb__link:hover {
76
+ color: var(--zdp-color-ink-strong);
77
+ }
78
+
79
+ .zdp-breadcrumb__link:focus-visible {
80
+ background: var(--zdp-color-focus-surface);
81
+ border-bottom-color: var(--zdp-color-focus-line);
82
+ color: var(--zdp-color-focus-text);
83
+ outline: 0;
84
+ }
85
+
86
+ .zdp-breadcrumb__current {
87
+ color: var(--zdp-color-ink-strong);
88
+ font-weight: var(--zdp-font-weight-medium);
89
+ overflow-wrap: var(--zdp-i18n-overflow-wrap);
90
+ }
91
+
92
+ .zdp-breadcrumb__separator {
93
+ color: var(--zdp-color-line-strong);
94
+ -webkit-user-select: none;
95
+ user-select: none;
96
+ }
97
+ </style>
@@ -0,0 +1,163 @@
1
+ <script lang="ts">
2
+ export let variant: 'primary' | 'secondary' | 'danger' = 'primary';
3
+ export let size: 'sm' | 'md' = 'md';
4
+ export let type: 'button' | 'submit' | 'reset' = 'button';
5
+ export let disabled = false;
6
+ export let id: string | null = null;
7
+ export let name: string | null = null;
8
+ export let value: string | null = null;
9
+ export let form: string | null = null;
10
+ export let ariaLabel: string | null = null;
11
+ export let ariaControls: string | null = null;
12
+ export let ariaDescribedBy: string | null = null;
13
+ export let ariaExpanded: boolean | null = null;
14
+ export let ariaPressed: boolean | null = null;
15
+ export let ariaKeyShortcuts: string | null = null;
16
+ export let onclick: ((event: MouseEvent) => void) | null = null;
17
+ </script>
18
+
19
+ <button
20
+ class={`zdp-button zdp-button--${variant} zdp-button--${size}`}
21
+ {id}
22
+ {name}
23
+ {value}
24
+ {form}
25
+ {type}
26
+ {disabled}
27
+ aria-disabled={disabled}
28
+ aria-label={ariaLabel ?? undefined}
29
+ aria-controls={ariaControls ?? undefined}
30
+ aria-describedby={ariaDescribedBy ?? undefined}
31
+ aria-expanded={ariaExpanded ?? undefined}
32
+ aria-pressed={ariaPressed ?? undefined}
33
+ aria-keyshortcuts={ariaKeyShortcuts ?? undefined}
34
+ onclick={onclick ?? undefined}
35
+ >
36
+ <slot />
37
+ </button>
38
+
39
+ <style>
40
+ .zdp-button {
41
+ align-items: center;
42
+ border: var(--zdp-control-border-width) solid var(--zdp-color-line-strong);
43
+ border-radius: var(--zdp-control-radius);
44
+ cursor: pointer;
45
+ display: inline-flex;
46
+ font-family: var(--zdp-font-family-sans);
47
+ font-weight: var(--zdp-font-weight-medium);
48
+ gap: var(--zdp-space-2);
49
+ justify-content: center;
50
+ font-size: var(--zdp-type-control-size);
51
+ line-height: var(--zdp-type-control-line-height);
52
+ min-height: var(--zdp-control-height-md);
53
+ text-decoration: none;
54
+ text-align: center;
55
+ transition:
56
+ background-color var(--zdp-motion-fast) ease,
57
+ border-color var(--zdp-motion-fast) ease,
58
+ color var(--zdp-motion-fast) ease;
59
+ -webkit-user-select: none;
60
+ user-select: none;
61
+ }
62
+
63
+ .zdp-button--sm {
64
+ font-size: var(--zdp-font-size-sm);
65
+ min-height: var(--zdp-control-height-sm);
66
+ padding: 0 var(--zdp-space-3);
67
+ }
68
+
69
+ .zdp-button--md {
70
+ font-size: var(--zdp-type-control-size);
71
+ min-height: var(--zdp-control-height-md);
72
+ padding: 0 var(--zdp-space-4);
73
+ }
74
+
75
+ .zdp-button--primary {
76
+ background: var(--zdp-color-accent-primary);
77
+ border-color: var(--zdp-color-accent-primary-strong);
78
+ color: var(--zdp-color-ink-strong);
79
+ }
80
+
81
+ .zdp-button--primary:hover:not(:disabled) {
82
+ background: var(--zdp-color-accent-primary-strong);
83
+ border-color: var(--zdp-color-accent-primary-strong);
84
+ }
85
+
86
+ .zdp-button--primary:active:not(:disabled) {
87
+ background: var(--zdp-color-accent-primary-strong);
88
+ border-color: var(--zdp-color-accent-primary-strong);
89
+ }
90
+
91
+ :global([data-zdp-theme="dark"]) .zdp-button--primary {
92
+ color: var(--zdp-color-ink-inverse);
93
+ }
94
+
95
+ .zdp-button--secondary {
96
+ background: var(--zdp-color-surface-panel);
97
+ border-color: var(--zdp-color-line-subtle);
98
+ color: var(--zdp-color-ink-strong);
99
+ }
100
+
101
+ .zdp-button--secondary:hover:not(:disabled) {
102
+ background: var(--zdp-color-surface-raised);
103
+ border-color: var(--zdp-color-line-strong);
104
+ color: var(--zdp-color-ink-strong);
105
+ }
106
+
107
+ .zdp-button--secondary:active:not(:disabled) {
108
+ background: var(--zdp-color-surface-raised);
109
+ border-color: var(--zdp-color-line-strong);
110
+ }
111
+
112
+ :global([data-zdp-theme="dark"]) .zdp-button--secondary {
113
+ background: var(--zdp-color-surface-panel);
114
+ border-color: var(--zdp-color-line-subtle);
115
+ color: var(--zdp-color-ink-muted);
116
+ }
117
+
118
+ :global([data-zdp-theme="dark"]) .zdp-button--secondary:hover:not(:disabled) {
119
+ background: var(--zdp-color-surface-raised);
120
+ border-color: var(--zdp-color-line-strong);
121
+ color: var(--zdp-color-ink-strong);
122
+ }
123
+
124
+ .zdp-button--danger {
125
+ background: var(--zdp-color-surface-panel);
126
+ border-color: var(--zdp-color-accent-danger);
127
+ color: var(--zdp-color-accent-danger);
128
+ }
129
+
130
+ :global([data-zdp-theme="dark"]) .zdp-button--danger {
131
+ background: transparent;
132
+ border-color: var(--zdp-color-accent-danger);
133
+ color: var(--zdp-color-accent-danger);
134
+ }
135
+
136
+ .zdp-button--danger:hover:not(:disabled) {
137
+ background: var(--zdp-color-surface-raised);
138
+ }
139
+
140
+ :global([data-zdp-theme="dark"]) .zdp-button--danger:hover:not(:disabled) {
141
+ background: var(--zdp-color-surface-raised);
142
+ border-color: var(--zdp-color-accent-danger);
143
+ color: var(--zdp-color-accent-danger);
144
+ }
145
+
146
+ .zdp-button--danger:active:not(:disabled) {
147
+ background: var(--zdp-color-surface-raised);
148
+ border-color: var(--zdp-color-accent-danger);
149
+ color: var(--zdp-color-accent-danger);
150
+ }
151
+
152
+ .zdp-button:focus-visible {
153
+ border-color: var(--zdp-color-focus-line);
154
+ outline: var(--zdp-control-focus-outline-width) solid var(--zdp-color-focus-surface);
155
+ outline-offset: var(--zdp-control-focus-outline-offset);
156
+ }
157
+
158
+ .zdp-button:disabled {
159
+ cursor: not-allowed;
160
+ opacity: 0.56;
161
+ }
162
+
163
+ </style>
@@ -0,0 +1,81 @@
1
+ <script lang="ts">
2
+ export let tone: 'neutral' | 'info' | 'success' | 'warning' | 'danger' = 'neutral';
3
+ export let labelledBy: string | null = null;
4
+ export let semanticRole: 'note' | 'status' | 'alert' | null = null;
5
+ </script>
6
+
7
+ <section
8
+ class={`zdp-callout zdp-callout--${tone}`}
9
+ aria-labelledby={labelledBy ?? undefined}
10
+ role={semanticRole ?? undefined}
11
+ >
12
+ <span class="zdp-callout__mark" aria-hidden="true"></span>
13
+ <div class="zdp-callout__body">
14
+ <slot />
15
+ </div>
16
+ </section>
17
+
18
+ <style>
19
+ .zdp-callout {
20
+ align-items: start;
21
+ background: var(--zdp-color-surface-panel);
22
+ border: 1px solid var(--zdp-color-line-subtle);
23
+ border-radius: var(--zdp-control-radius);
24
+ box-sizing: border-box;
25
+ color: var(--zdp-color-ink-normal);
26
+ display: grid;
27
+ font-family: var(--zdp-font-family-sans);
28
+ gap: var(--zdp-space-3);
29
+ grid-template-columns: var(--zdp-space-2) minmax(0, 1fr);
30
+ line-height: var(--zdp-type-body-small-line-height);
31
+ min-width: 0;
32
+ padding: var(--zdp-space-4);
33
+ }
34
+
35
+ .zdp-callout__mark {
36
+ align-self: start;
37
+ background: var(--zdp-color-line-strong);
38
+ border-radius: var(--zdp-radius-sm);
39
+ display: block;
40
+ height: calc(var(--zdp-type-body-small-size) * var(--zdp-type-body-small-line-height));
41
+ -webkit-user-select: none;
42
+ user-select: none;
43
+ width: var(--zdp-space-2);
44
+ }
45
+
46
+ .zdp-callout__body {
47
+ display: grid;
48
+ gap: var(--zdp-space-2);
49
+ min-width: 0;
50
+ }
51
+
52
+ .zdp-callout__body :global(*) {
53
+ margin-bottom: 0;
54
+ margin-top: 0;
55
+ }
56
+
57
+ .zdp-callout__body :global(strong) {
58
+ color: var(--zdp-color-ink-strong);
59
+ font-weight: var(--zdp-font-weight-semibold);
60
+ }
61
+
62
+ .zdp-callout--info .zdp-callout__mark {
63
+ background: var(--zdp-color-accent-primary);
64
+ }
65
+
66
+ .zdp-callout--success .zdp-callout__mark {
67
+ background: var(--zdp-color-accent-success);
68
+ }
69
+
70
+ .zdp-callout--warning .zdp-callout__mark {
71
+ background: var(--zdp-color-accent-warning);
72
+ }
73
+
74
+ .zdp-callout--danger {
75
+ border-color: var(--zdp-color-accent-danger);
76
+ }
77
+
78
+ .zdp-callout--danger .zdp-callout__mark {
79
+ background: var(--zdp-color-accent-danger);
80
+ }
81
+ </style>