banhaten 0.1.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 (201) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +361 -0
  3. package/banhaten.config.example.json +13 -0
  4. package/package.json +59 -0
  5. package/registry/assets/activity-feed-avatar.png +0 -0
  6. package/registry/assets/avatars/avatar-01.jpg +0 -0
  7. package/registry/assets/avatars/avatar-02.jpg +0 -0
  8. package/registry/assets/avatars/avatar-03.jpg +0 -0
  9. package/registry/assets/avatars/avatar-04.jpg +0 -0
  10. package/registry/assets/avatars/avatar-05.jpg +0 -0
  11. package/registry/assets/avatars/avatar-06.jpg +0 -0
  12. package/registry/assets/avatars/avatar-07.jpg +0 -0
  13. package/registry/assets/avatars/avatar-08.jpg +0 -0
  14. package/registry/assets/avatars/avatar-09.jpg +0 -0
  15. package/registry/assets/avatars/avatar-10.jpg +0 -0
  16. package/registry/assets/avatars/avatar-11.jpg +0 -0
  17. package/registry/assets/avatars/avatar-12.jpg +0 -0
  18. package/registry/assets/avatars/avatar-13.jpg +0 -0
  19. package/registry/assets/avatars/avatar-14.jpg +0 -0
  20. package/registry/assets/avatars/avatar-15.jpg +0 -0
  21. package/registry/assets/avatars/avatar-16.jpg +0 -0
  22. package/registry/assets/avatars/avatar-17.jpg +0 -0
  23. package/registry/assets/avatars/avatar-18.jpg +0 -0
  24. package/registry/assets/avatars/avatar-19.jpg +0 -0
  25. package/registry/assets/avatars/avatar-20.jpg +0 -0
  26. package/registry/assets/avatars/avatar-21.jpg +0 -0
  27. package/registry/assets/avatars/avatar-22.jpg +0 -0
  28. package/registry/assets/avatars/avatar-23.jpg +0 -0
  29. package/registry/assets/avatars/avatar-24.jpg +0 -0
  30. package/registry/assets/avatars/avatar-25.jpg +0 -0
  31. package/registry/assets/avatars/avatar-26.jpg +0 -0
  32. package/registry/assets/avatars/avatar-27.jpg +0 -0
  33. package/registry/assets/avatars/avatar-28.jpg +0 -0
  34. package/registry/assets/avatars/avatar-29.jpg +0 -0
  35. package/registry/assets/avatars/avatar-30.jpg +0 -0
  36. package/registry/assets/avatars/avatar-31.jpg +0 -0
  37. package/registry/assets/avatars/avatar-32.jpg +0 -0
  38. package/registry/assets/avatars/avatar-33.jpg +0 -0
  39. package/registry/assets/avatars/avatar-34.jpg +0 -0
  40. package/registry/assets/avatars/avatar-35.jpg +0 -0
  41. package/registry/assets/image-assets.json +744 -0
  42. package/registry/assets/images/art-01.jpg +0 -0
  43. package/registry/assets/images/art-02.jpg +0 -0
  44. package/registry/assets/images/art-03.jpg +0 -0
  45. package/registry/assets/images/art-04.jpg +0 -0
  46. package/registry/assets/images/art-05.jpg +0 -0
  47. package/registry/assets/images/art-06.jpg +0 -0
  48. package/registry/assets/images/art-07.jpg +0 -0
  49. package/registry/assets/images/art-08.jpg +0 -0
  50. package/registry/assets/images/art-09.jpg +0 -0
  51. package/registry/assets/images/art-10.jpg +0 -0
  52. package/registry/assets/images/art-11.jpg +0 -0
  53. package/registry/assets/images/art-12.jpg +0 -0
  54. package/registry/assets/images/art-13.jpg +0 -0
  55. package/registry/assets/images/art-14.jpg +0 -0
  56. package/registry/assets/images/art-15.jpg +0 -0
  57. package/registry/assets/images/art-16.jpg +0 -0
  58. package/registry/assets/images/art-17.jpg +0 -0
  59. package/registry/assets/images/art-18.jpg +0 -0
  60. package/registry/assets/images/art-19.jpg +0 -0
  61. package/registry/assets/images/art-20.jpg +0 -0
  62. package/registry/assets/images/art-21.jpg +0 -0
  63. package/registry/assets/images/art-22.jpg +0 -0
  64. package/registry/assets/images/art-23.jpg +0 -0
  65. package/registry/assets/images/art-24.jpg +0 -0
  66. package/registry/assets/images/art-25.jpg +0 -0
  67. package/registry/assets/images/art-26.jpg +0 -0
  68. package/registry/assets/images/art-27.jpg +0 -0
  69. package/registry/assets/images/nature-01.jpg +0 -0
  70. package/registry/assets/images/nature-02.jpg +0 -0
  71. package/registry/assets/images/nature-03.jpg +0 -0
  72. package/registry/assets/images/nature-04.jpg +0 -0
  73. package/registry/assets/images/nature-05.jpg +0 -0
  74. package/registry/assets/images/nature-06.jpg +0 -0
  75. package/registry/assets/images/nature-07.jpg +0 -0
  76. package/registry/assets/images/nature-08.jpg +0 -0
  77. package/registry/assets/images/nature-09.jpg +0 -0
  78. package/registry/assets/images/nature-10.jpg +0 -0
  79. package/registry/assets/images/nature-11.jpg +0 -0
  80. package/registry/assets/images/nature-12.jpg +0 -0
  81. package/registry/assets/images/nature-13.jpg +0 -0
  82. package/registry/assets/images/nature-14.jpg +0 -0
  83. package/registry/assets/images/nature-15.jpg +0 -0
  84. package/registry/assets/images/nature-16.jpg +0 -0
  85. package/registry/assets/images/nature-17.jpg +0 -0
  86. package/registry/assets/images/nature-18.jpg +0 -0
  87. package/registry/assets/images/nature-19.jpg +0 -0
  88. package/registry/assets/images/nature-20.jpg +0 -0
  89. package/registry/components/accordion.tsx +119 -0
  90. package/registry/components/alert.tsx +282 -0
  91. package/registry/components/attribute.tsx +452 -0
  92. package/registry/components/avatar.tsx +142 -0
  93. package/registry/components/badge.tsx +567 -0
  94. package/registry/components/button-group.tsx +246 -0
  95. package/registry/components/button.tsx +102 -0
  96. package/registry/components/card.tsx +613 -0
  97. package/registry/components/checkbox.tsx +244 -0
  98. package/registry/components/date-picker.tsx +1143 -0
  99. package/registry/components/divider.tsx +82 -0
  100. package/registry/components/expanded/ActivityFeed.tsx +226 -0
  101. package/registry/components/expanded/Banner.tsx +145 -0
  102. package/registry/components/expanded/BannerBoard.tsx +225 -0
  103. package/registry/components/expanded/Breadcrumbs.tsx +156 -0
  104. package/registry/components/expanded/CatalogComponentsShowcase.tsx +211 -0
  105. package/registry/components/expanded/CatalogDivider.tsx +48 -0
  106. package/registry/components/expanded/CatalogTag.tsx +92 -0
  107. package/registry/components/expanded/CommandBar.tsx +406 -0
  108. package/registry/components/expanded/FileUpload.tsx +231 -0
  109. package/registry/components/expanded/IconExplorer.tsx +612 -0
  110. package/registry/components/expanded/OnboardingStepListItem.tsx +67 -0
  111. package/registry/components/expanded/PageHeader.tsx +184 -0
  112. package/registry/components/expanded/Slideout.tsx +514 -0
  113. package/registry/components/expanded/Steps.tsx +266 -0
  114. package/registry/components/expanded/Table.tsx +1014 -0
  115. package/registry/components/expanded/Tabs.tsx +86 -0
  116. package/registry/components/expanded/Timeline.tsx +235 -0
  117. package/registry/components/expanded/TimelineShowcase.tsx +158 -0
  118. package/registry/components/expanded/activityFeed.css +292 -0
  119. package/registry/components/expanded/banner.css +312 -0
  120. package/registry/components/expanded/breadcrumbs.css +140 -0
  121. package/registry/components/expanded/catalogComponentsShowcase.css +87 -0
  122. package/registry/components/expanded/commandBar.css +473 -0
  123. package/registry/components/expanded/divider.css +75 -0
  124. package/registry/components/expanded/fileUpload.css +228 -0
  125. package/registry/components/expanded/iconExplorer.css +764 -0
  126. package/registry/components/expanded/iconPacks.ts +866 -0
  127. package/registry/components/expanded/onboardingStepListItem.css +126 -0
  128. package/registry/components/expanded/pageHeader.css +287 -0
  129. package/registry/components/expanded/slideout.css +955 -0
  130. package/registry/components/expanded/steps.css +329 -0
  131. package/registry/components/expanded/table.css +607 -0
  132. package/registry/components/expanded/tabs.css +197 -0
  133. package/registry/components/expanded/tag.css +148 -0
  134. package/registry/components/expanded/timeline.css +282 -0
  135. package/registry/components/input-content.ts +106 -0
  136. package/registry/components/input.tsx +866 -0
  137. package/registry/components/menu.tsx +758 -0
  138. package/registry/components/modal.tsx +799 -0
  139. package/registry/components/pagination.tsx +543 -0
  140. package/registry/components/progress-slider.tsx +216 -0
  141. package/registry/components/progress.tsx +367 -0
  142. package/registry/components/radio-card.tsx +654 -0
  143. package/registry/components/radio-group.tsx +570 -0
  144. package/registry/components/select-content.tsx +313 -0
  145. package/registry/components/select.tsx +871 -0
  146. package/registry/components/slider.tsx +380 -0
  147. package/registry/components/social-button.tsx +360 -0
  148. package/registry/components/spinner.tsx +31 -0
  149. package/registry/components/tag.tsx +423 -0
  150. package/registry/components/textarea.tsx +625 -0
  151. package/registry/components/toggle.tsx +272 -0
  152. package/registry/components/toolbar.tsx +467 -0
  153. package/registry/components/tooltip.tsx +427 -0
  154. package/registry/examples/accordion-demo.tsx +34 -0
  155. package/registry/examples/alert-demo.tsx +14 -0
  156. package/registry/examples/attribute-demo.tsx +65 -0
  157. package/registry/examples/avatar-demo.tsx +74 -0
  158. package/registry/examples/badge-demo.tsx +53 -0
  159. package/registry/examples/button-demo.tsx +83 -0
  160. package/registry/examples/button-group-demo.tsx +42 -0
  161. package/registry/examples/card-demo.tsx +48 -0
  162. package/registry/examples/checkbox-demo.tsx +67 -0
  163. package/registry/examples/date-picker-demo.tsx +74 -0
  164. package/registry/examples/divider-demo.tsx +17 -0
  165. package/registry/examples/expanded/activity-feed-demo.tsx +22 -0
  166. package/registry/examples/expanded/banner-demo.tsx +23 -0
  167. package/registry/examples/expanded/catalog-components-demo.tsx +5 -0
  168. package/registry/examples/expanded/command-bar-demo.tsx +10 -0
  169. package/registry/examples/expanded/icons-demo.tsx +5 -0
  170. package/registry/examples/expanded/onboarding-step-demo.tsx +11 -0
  171. package/registry/examples/expanded/page-header-demo.tsx +19 -0
  172. package/registry/examples/expanded/slideout-demo.tsx +15 -0
  173. package/registry/examples/expanded/steps-demo.tsx +18 -0
  174. package/registry/examples/expanded/tabs-demo.tsx +13 -0
  175. package/registry/examples/expanded/timeline-demo.tsx +18 -0
  176. package/registry/examples/input-demo.tsx +87 -0
  177. package/registry/examples/menu-demo.tsx +109 -0
  178. package/registry/examples/modal-demo.tsx +16 -0
  179. package/registry/examples/pagination-demo.tsx +17 -0
  180. package/registry/examples/progress-demo.tsx +37 -0
  181. package/registry/examples/progress-slider-demo.tsx +29 -0
  182. package/registry/examples/radio-card-demo.tsx +51 -0
  183. package/registry/examples/radio-group-demo.tsx +62 -0
  184. package/registry/examples/select-demo.tsx +73 -0
  185. package/registry/examples/slider-demo.tsx +31 -0
  186. package/registry/examples/social-button-demo.tsx +51 -0
  187. package/registry/examples/tag-demo.tsx +29 -0
  188. package/registry/examples/textarea-demo.tsx +79 -0
  189. package/registry/examples/toggle-demo.tsx +59 -0
  190. package/registry/examples/toolbar-demo.tsx +80 -0
  191. package/registry/examples/tooltip-demo.tsx +115 -0
  192. package/registry/hooks/use-direction.ts +27 -0
  193. package/registry/index.json +1213 -0
  194. package/registry/styles/globals.css +4600 -0
  195. package/registry/utils/cn.ts +6 -0
  196. package/src/cli/index.js +826 -0
  197. package/tokens/Color mode.zip +0 -0
  198. package/tokens/Numbers.zip +0 -0
  199. package/tokens/Radius.zip +0 -0
  200. package/tokens/Theme.zip +0 -0
  201. package/tokens/banhaten.tokens.json +5525 -0
@@ -0,0 +1,197 @@
1
+ .ds-tabs {
2
+ --tabs-bg-neutral-subtle: var(--bh-bg-neutral-subtle);
3
+ --tabs-bg-default: var(--bh-bg-default);
4
+ --tabs-border-default: var(--bh-border-default);
5
+ --tabs-content-brand: var(--bh-content-brand-default);
6
+ --tabs-content-default: var(--bh-content-default);
7
+ --tabs-content-subtle: var(--bh-content-subtle);
8
+ --tabs-radius-md: var(--bh-radius-md-6);
9
+ --tabs-radius-lg: var(--bh-radius-lg-8);
10
+ --tabs-radius-full: var(--bh-radius-full);
11
+ --tabs-space-xxs: var(--bh-space-xxs-2);
12
+ --tabs-space-xs: var(--bh-space-xs-4);
13
+ --tabs-space-sm: var(--bh-space-sm-6);
14
+ --tabs-space-md: var(--bh-space-md-8);
15
+ --tabs-space-lg: var(--bh-space-lg-10);
16
+ --tabs-space-xl: var(--bh-space-xl-12);
17
+ --tabs-space-3xl: var(--bh-space-3xl-16);
18
+ --tabs-label-padding-x: var(--tabs-space-xxs);
19
+ --tabs-height-segment-md: var(--bh-space-7xl-40);
20
+ --tabs-height-segment-sm: calc(var(--bh-space-6xl-32) + var(--bh-space-xs-4));
21
+ --tabs-height-segment-xs: var(--bh-space-6xl-32);
22
+ --tabs-height-underline-md: calc(var(--bh-space-8xl-48) + var(--bh-space-md-8));
23
+ --tabs-height-underline-sm: var(--bh-space-8xl-48);
24
+ --tabs-height-underline-content: calc(var(--bh-space-6xl-32) + var(--bh-space-xs-4));
25
+ --tabs-shadow-selected: var(--shadow-button-soft);
26
+
27
+ box-sizing: border-box;
28
+ display: flex;
29
+ position: relative;
30
+ max-width: 100%;
31
+ min-width: 0;
32
+ overflow-x: auto;
33
+ overflow-y: visible;
34
+ color: var(--tabs-content-subtle);
35
+ font-family: var(--bh-font-family);
36
+ font-size: var(--bh-text-body-md-regular-font-size);
37
+ font-style: normal;
38
+ font-weight: var(--bh-text-body-md-regular-font-weight);
39
+ line-height: var(--bh-text-body-md-regular-line-height);
40
+ letter-spacing: var(--bh-text-body-md-regular-letter-spacing);
41
+ }
42
+
43
+ .ds-tabs *,
44
+ .ds-tabs *::before,
45
+ .ds-tabs *::after {
46
+ box-sizing: border-box;
47
+ }
48
+
49
+ .ds-tabs--full {
50
+ width: 100%;
51
+ }
52
+
53
+ .ds-tabs--segment,
54
+ .ds-tabs--rounded {
55
+ align-items: center;
56
+ gap: var(--tabs-space-xxs);
57
+ padding: var(--tabs-space-xxs);
58
+ background: var(--tabs-bg-neutral-subtle);
59
+ }
60
+
61
+ .ds-tabs--segment {
62
+ border-radius: var(--tabs-radius-full);
63
+ }
64
+
65
+ .ds-tabs--rounded {
66
+ border-radius: var(--tabs-radius-lg);
67
+ }
68
+
69
+ .ds-tabs--underline {
70
+ align-items: center;
71
+ gap: var(--tabs-space-3xl);
72
+ border-bottom: var(--bh-space-xxxs-1) solid var(--tabs-border-default);
73
+ }
74
+
75
+ .ds-tabs__tab {
76
+ appearance: none;
77
+ border: 0;
78
+ margin: 0;
79
+ padding: 0;
80
+ position: relative;
81
+ display: flex;
82
+ align-items: center;
83
+ justify-content: center;
84
+ min-width: 0;
85
+ color: var(--tabs-content-subtle);
86
+ background: transparent;
87
+ font: inherit;
88
+ text-align: start;
89
+ white-space: nowrap;
90
+ cursor: pointer;
91
+ }
92
+
93
+ .ds-tabs__tab:focus-visible {
94
+ outline: var(--tabs-space-xxs) solid var(--tabs-content-brand);
95
+ outline-offset: var(--tabs-space-xxs);
96
+ }
97
+
98
+ .ds-tabs__content {
99
+ display: flex;
100
+ align-items: center;
101
+ justify-content: center;
102
+ gap: var(--tabs-space-xs);
103
+ min-width: 0;
104
+ }
105
+
106
+ .ds-tabs__label {
107
+ display: block;
108
+ flex: 0 0 auto;
109
+ padding-inline: var(--tabs-label-padding-x);
110
+ color: currentColor;
111
+ font: inherit;
112
+ white-space: nowrap;
113
+ word-break: break-word;
114
+ }
115
+
116
+ .ds-tabs__tab[aria-selected="true"] {
117
+ color: var(--tabs-content-default);
118
+ font-weight: var(--bh-font-weight-medium);
119
+ }
120
+
121
+ .ds-tabs--segment .ds-tabs__tab,
122
+ .ds-tabs--rounded .ds-tabs__tab {
123
+ gap: var(--tabs-space-xs);
124
+ }
125
+
126
+ .ds-tabs--segment .ds-tabs__tab {
127
+ border-radius: var(--tabs-radius-full);
128
+ }
129
+
130
+ .ds-tabs--rounded .ds-tabs__tab {
131
+ border-radius: var(--tabs-radius-md);
132
+ }
133
+
134
+ .ds-tabs--segment .ds-tabs__tab[aria-selected="true"],
135
+ .ds-tabs--rounded .ds-tabs__tab[aria-selected="true"] {
136
+ background: var(--tabs-bg-default);
137
+ box-shadow: var(--tabs-shadow-selected);
138
+ }
139
+
140
+ .ds-tabs--segment.ds-tabs--md .ds-tabs__tab,
141
+ .ds-tabs--rounded.ds-tabs--md .ds-tabs__tab {
142
+ min-height: var(--tabs-height-segment-md);
143
+ padding: var(--tabs-space-md) var(--tabs-space-xl);
144
+ }
145
+
146
+ .ds-tabs--segment.ds-tabs--sm .ds-tabs__tab,
147
+ .ds-tabs--rounded.ds-tabs--sm .ds-tabs__tab {
148
+ min-height: var(--tabs-height-segment-sm);
149
+ padding: var(--tabs-space-sm) var(--tabs-space-lg);
150
+ }
151
+
152
+ .ds-tabs--segment.ds-tabs--xs .ds-tabs__tab,
153
+ .ds-tabs--rounded.ds-tabs--xs .ds-tabs__tab {
154
+ min-height: var(--tabs-height-segment-xs);
155
+ padding: var(--tabs-space-xs) var(--tabs-space-lg);
156
+ }
157
+
158
+ .ds-tabs--segment.ds-tabs--full .ds-tabs__tab,
159
+ .ds-tabs--rounded.ds-tabs--full .ds-tabs__tab {
160
+ flex: 1 0 0;
161
+ }
162
+
163
+ .ds-tabs--underline .ds-tabs__tab {
164
+ border-bottom: var(--tabs-space-xxs) solid transparent;
165
+ }
166
+
167
+ .ds-tabs--underline .ds-tabs__tab[aria-selected="true"] {
168
+ border-bottom-color: var(--tabs-content-brand);
169
+ }
170
+
171
+ .ds-tabs--underline.ds-tabs--md .ds-tabs__tab {
172
+ min-height: var(--tabs-height-underline-md);
173
+ padding-block: var(--tabs-space-md);
174
+ }
175
+
176
+ .ds-tabs--underline.ds-tabs--sm .ds-tabs__tab,
177
+ .ds-tabs--underline.ds-tabs--xs .ds-tabs__tab {
178
+ min-height: var(--tabs-height-underline-sm);
179
+ }
180
+
181
+ .ds-tabs--underline.ds-tabs--sm .ds-tabs__content,
182
+ .ds-tabs--underline.ds-tabs--xs .ds-tabs__content {
183
+ height: var(--tabs-height-underline-content);
184
+ }
185
+
186
+ .ds-tabs--underline.ds-tabs--full .ds-tabs__tab {
187
+ flex: 1 0 0;
188
+ }
189
+
190
+ .ds-tabs--rtl .ds-tabs__tab {
191
+ text-align: right;
192
+ }
193
+
194
+ .ds-tabs--rtl {
195
+ --tabs-label-padding-x: var(--tabs-space-xxs);
196
+ font-family: var(--bh-font-family);
197
+ }
@@ -0,0 +1,148 @@
1
+ .ds-tag {
2
+ --tag-bg: var(--bh-bg-default);
3
+ --tag-border: var(--bh-border-default);
4
+ --tag-color: var(--bh-content-default);
5
+
6
+ box-sizing: border-box;
7
+ width: max-content;
8
+ max-width: 100%;
9
+ display: inline-flex;
10
+ align-items: center;
11
+ justify-content: center;
12
+ gap: var(--bh-space-xs-4);
13
+ border: var(--bh-space-xxxs-1) solid var(--tag-border);
14
+ border-radius: var(--bh-radius-full);
15
+ background: var(--tag-bg);
16
+ color: var(--tag-color);
17
+ font-family: var(--bh-font-family);
18
+ font-weight: var(--bh-font-weight-medium);
19
+ letter-spacing: 0;
20
+ white-space: nowrap;
21
+ }
22
+
23
+ .ds-tag *,
24
+ .ds-tag *::before,
25
+ .ds-tag *::after {
26
+ box-sizing: border-box;
27
+ }
28
+
29
+ .ds-tag--xs {
30
+ min-height: var(--bh-space-5xl-24);
31
+ padding-inline: var(--bh-space-md-8);
32
+ font-size: var(--bh-text-body-2xs-regular-font-size);
33
+ line-height: var(--bh-text-body-2xs-regular-line-height);
34
+ }
35
+
36
+ .ds-tag--md {
37
+ min-height: calc(var(--bh-space-5xl-24) + var(--bh-space-xs-4));
38
+ padding-inline: var(--bh-space-lg-10);
39
+ font-size: var(--bh-text-body-xs-regular-font-size);
40
+ line-height: var(--bh-text-body-sm-regular-line-height);
41
+ }
42
+
43
+ .ds-tag--lg {
44
+ min-height: calc(var(--bh-space-6xl-32) + var(--bh-space-xs-4));
45
+ padding-inline: var(--bh-space-xl-12);
46
+ font-size: var(--bh-text-body-md-font-size);
47
+ line-height: var(--bh-text-body-md-line-height);
48
+ }
49
+
50
+ .ds-tag--closeable {
51
+ padding-inline-end: var(--bh-space-sm-6);
52
+ }
53
+
54
+ .ds-tag__label {
55
+ min-width: 0;
56
+ overflow: hidden;
57
+ text-overflow: ellipsis;
58
+ }
59
+
60
+ .ds-tag__leading {
61
+ width: var(--bh-space-4xl-20);
62
+ height: var(--bh-space-4xl-20);
63
+ flex: 0 0 auto;
64
+ display: inline-grid;
65
+ place-items: center;
66
+ }
67
+
68
+ .ds-tag__leading svg {
69
+ width: var(--bh-space-3xl-16);
70
+ height: var(--bh-space-3xl-16);
71
+ display: block;
72
+ }
73
+
74
+ .ds-tag__dot {
75
+ width: var(--bh-space-md-8);
76
+ height: var(--bh-space-md-8);
77
+ border-radius: var(--bh-radius-full);
78
+ background: var(--bh-content-success-default);
79
+ }
80
+
81
+ .ds-tag__flag {
82
+ width: calc(var(--bh-space-3xl-16) + var(--bh-space-xxs-2));
83
+ height: var(--bh-space-xl-12);
84
+ border-radius: var(--bh-radius-xs-2);
85
+ background:
86
+ linear-gradient(var(--bh-bg-danger-default) 0 33%, var(--bh-bg-raised) 33% 66%, var(--bh-bg-inverse) 66% 100%);
87
+ box-shadow: inset 0 0 0 var(--bh-space-xxxs-1) var(--bh-border-default);
88
+ }
89
+
90
+ .ds-tag__avatar {
91
+ width: var(--bh-space-4xl-20);
92
+ height: var(--bh-space-4xl-20);
93
+ display: inline-grid;
94
+ place-items: center;
95
+ border-radius: var(--bh-radius-full);
96
+ background: var(--bh-bg-brand-soft);
97
+ color: var(--bh-content-brand-default);
98
+ font-size: var(--bh-text-body-3xs-regular-font-size);
99
+ font-weight: var(--bh-font-weight-bold);
100
+ }
101
+
102
+ .ds-tag__close {
103
+ width: calc(var(--bh-space-3xl-16) + var(--bh-space-xxs-2));
104
+ height: calc(var(--bh-space-3xl-16) + var(--bh-space-xxs-2));
105
+ border: 0;
106
+ border-radius: var(--bh-radius-full);
107
+ display: inline-grid;
108
+ place-items: center;
109
+ background: transparent;
110
+ color: currentColor;
111
+ padding: 0;
112
+ cursor: pointer;
113
+ }
114
+
115
+ .ds-tag__close svg {
116
+ width: var(--bh-space-2xl-14);
117
+ height: var(--bh-space-2xl-14);
118
+ }
119
+
120
+ .ds-tag__close:hover:not(:disabled) {
121
+ background: var(--bh-interactive-ghost-hover);
122
+ }
123
+
124
+ .ds-tag:hover {
125
+ --tag-bg: var(--bh-interactive-ghost-hover);
126
+ }
127
+
128
+ .ds-tag--active {
129
+ --tag-bg: var(--bh-bg-brand-soft);
130
+ --tag-border: var(--bh-border-brand-strong);
131
+ --tag-color: var(--bh-content-brand-default);
132
+ }
133
+
134
+ .ds-tag:focus-visible {
135
+ --tag-border: var(--bh-border-brand-strong);
136
+ box-shadow: var(--shadow-button-focus);
137
+ }
138
+
139
+ .ds-tag--disabled {
140
+ --tag-bg: var(--bh-bg-muted);
141
+ --tag-border: var(--bh-border-subtle);
142
+ --tag-color: var(--bh-content-muted);
143
+ opacity: var(--bh-opacity-tag-muted);
144
+ }
145
+
146
+ .ds-tag[dir="rtl"] {
147
+ font-family: var(--bh-font-family);
148
+ }
@@ -0,0 +1,282 @@
1
+ .ds-timeline,
2
+ .ds-timeline-item {
3
+ --timeline-bg-brand: var(--bh-bg-brand-default);
4
+ --timeline-bg-default: var(--bh-bg-default);
5
+ --timeline-bg-muted: var(--bh-bg-muted);
6
+ --timeline-border-brand: var(--bh-border-brand-strong);
7
+ --timeline-border-default: var(--bh-border-default);
8
+ --timeline-border-muted: var(--bh-border-subtle);
9
+ --timeline-content-default: var(--bh-content-default);
10
+ --timeline-content-on-brand: var(--bh-content-on-brand);
11
+ --timeline-content-subtle: var(--bh-content-subtle);
12
+ --timeline-radius-full: var(--bh-radius-full);
13
+ --timeline-space-xxs: var(--bh-space-xxs-2);
14
+ --timeline-space-xs: var(--bh-space-xs-4);
15
+ --timeline-space-sm: var(--bh-space-sm-6);
16
+ --timeline-space-lg: var(--bh-space-lg-10);
17
+ --timeline-space-xl: var(--bh-space-xl-12);
18
+
19
+ box-sizing: border-box;
20
+ color: var(--timeline-content-default);
21
+ font-family: inherit;
22
+ letter-spacing: 0;
23
+ }
24
+
25
+ .ds-timeline {
26
+ font-family: var(--bh-font-family);
27
+ }
28
+
29
+ .ds-timeline *,
30
+ .ds-timeline *::before,
31
+ .ds-timeline *::after,
32
+ .ds-timeline-item *,
33
+ .ds-timeline-item *::before,
34
+ .ds-timeline-item *::after {
35
+ box-sizing: border-box;
36
+ }
37
+
38
+ .ds-timeline--vertical {
39
+ display: flex;
40
+ flex-direction: column;
41
+ align-items: stretch;
42
+ width: min(var(--bh-timeline-narrow-width), 100%);
43
+ min-width: 0;
44
+ }
45
+
46
+ .ds-timeline--horizontal {
47
+ display: flex;
48
+ align-items: flex-start;
49
+ width: min(var(--bh-timeline-grid-width), 100%);
50
+ min-width: 0;
51
+ }
52
+
53
+ .ds-timeline--rtl,
54
+ .ds-timeline-item--rtl {
55
+ font-family: var(--bh-font-family);
56
+ }
57
+
58
+ .ds-timeline-item {
59
+ font-family: var(--bh-font-family);
60
+ }
61
+
62
+ .ds-timeline-item--vertical {
63
+ display: flex;
64
+ align-items: flex-start;
65
+ gap: var(--timeline-space-xl);
66
+ width: 100%;
67
+ min-height: calc(var(--bh-space-9xl-64) + var(--bh-space-xl-12));
68
+ }
69
+
70
+ .ds-timeline-item--vertical.ds-timeline-item--rtl {
71
+ justify-content: flex-end;
72
+ }
73
+
74
+ .ds-timeline-item--horizontal {
75
+ display: flex;
76
+ flex: 1 0 0;
77
+ flex-direction: column;
78
+ gap: var(--timeline-space-lg);
79
+ align-items: flex-start;
80
+ min-width: 0;
81
+ width: var(--bh-timeline-sidebar-width);
82
+ }
83
+
84
+ .ds-timeline-item--horizontal.ds-timeline-item--rtl {
85
+ align-items: flex-end;
86
+ }
87
+
88
+ .ds-timeline__indicator {
89
+ flex: 0 0 auto;
90
+ display: flex;
91
+ align-items: center;
92
+ direction: ltr;
93
+ }
94
+
95
+ .ds-timeline__indicator--vertical {
96
+ align-self: stretch;
97
+ flex-direction: column;
98
+ padding-top: var(--timeline-space-xxs);
99
+ }
100
+
101
+ .ds-timeline__indicator--horizontal {
102
+ width: 100%;
103
+ min-width: 0;
104
+ flex-direction: row;
105
+ }
106
+
107
+ .ds-timeline-item--icon .ds-timeline__indicator {
108
+ gap: var(--timeline-space-xxs);
109
+ }
110
+
111
+ .ds-timeline__marker {
112
+ position: relative;
113
+ z-index: 1;
114
+ display: inline-flex;
115
+ flex: 0 0 auto;
116
+ align-items: center;
117
+ justify-content: center;
118
+ color: var(--timeline-bg-brand);
119
+ }
120
+
121
+ .ds-timeline__marker--default {
122
+ width: var(--bh-space-4xl-20);
123
+ height: var(--bh-space-4xl-20);
124
+ }
125
+
126
+ .ds-timeline__marker--default::before {
127
+ content: "";
128
+ width: var(--bh-space-lg-10);
129
+ height: var(--bh-space-lg-10);
130
+ border: var(--bh-space-xxs-2) solid currentColor;
131
+ border-radius: var(--timeline-radius-full);
132
+ background: var(--timeline-bg-default);
133
+ }
134
+
135
+ .ds-timeline__marker--default.ds-timeline__marker--inactive {
136
+ color: var(--timeline-border-muted);
137
+ }
138
+
139
+ .ds-timeline__marker--icon {
140
+ width: calc(var(--bh-space-5xl-24) + var(--bh-space-xs-4));
141
+ height: calc(var(--bh-space-5xl-24) + var(--bh-space-xs-4));
142
+ border-radius: var(--timeline-radius-full);
143
+ color: var(--timeline-content-on-brand);
144
+ background: var(--timeline-bg-brand);
145
+ }
146
+
147
+ .ds-timeline__marker--icon.ds-timeline__marker--inactive {
148
+ border: var(--bh-space-xxxs-1) solid var(--timeline-border-default);
149
+ color: var(--timeline-content-default);
150
+ background: var(--timeline-bg-muted);
151
+ }
152
+
153
+ .ds-timeline__check {
154
+ width: calc(var(--bh-space-3xl-16) + var(--bh-space-xxs-2));
155
+ height: calc(var(--bh-space-3xl-16) + var(--bh-space-xxs-2));
156
+ display: block;
157
+ }
158
+
159
+ .ds-timeline__line {
160
+ display: block;
161
+ flex: 1 0 0;
162
+ min-width: var(--bh-space-xxxs-1);
163
+ min-height: var(--bh-space-xxxs-1);
164
+ border-radius: var(--timeline-radius-full);
165
+ background: var(--timeline-border-default);
166
+ }
167
+
168
+ .ds-timeline__line--finished {
169
+ background: var(--timeline-border-brand);
170
+ }
171
+
172
+ .ds-timeline__indicator--vertical .ds-timeline__line {
173
+ width: calc(var(--bh-space-xxs-2) + var(--bh-space-xxxs-1) / 2);
174
+ }
175
+
176
+ .ds-timeline__indicator--horizontal .ds-timeline__line {
177
+ height: calc(var(--bh-space-xxs-2) + var(--bh-space-xxxs-1));
178
+ }
179
+
180
+ .ds-timeline__body {
181
+ display: flex;
182
+ flex: 1 0 0;
183
+ flex-direction: column;
184
+ gap: var(--timeline-space-xs);
185
+ align-items: flex-start;
186
+ min-width: 0;
187
+ color: var(--timeline-content-default);
188
+ }
189
+
190
+ .ds-timeline-item--rtl .ds-timeline__body {
191
+ align-items: flex-end;
192
+ text-align: right;
193
+ }
194
+
195
+ .ds-timeline-item--horizontal .ds-timeline__body {
196
+ flex: 0 0 auto;
197
+ width: 100%;
198
+ padding-right: var(--timeline-space-xl);
199
+ }
200
+
201
+ .ds-timeline-item--horizontal.ds-timeline-item--rtl .ds-timeline__body {
202
+ padding-right: 0;
203
+ padding-left: var(--timeline-space-xl);
204
+ }
205
+
206
+ .ds-timeline__copy {
207
+ display: flex;
208
+ flex-direction: column;
209
+ gap: var(--timeline-space-xs);
210
+ width: 100%;
211
+ min-width: 0;
212
+ }
213
+
214
+ .ds-timeline__label,
215
+ .ds-timeline__caption,
216
+ .ds-timeline__date {
217
+ display: block;
218
+ min-width: 0;
219
+ margin: 0;
220
+ overflow-wrap: anywhere;
221
+ letter-spacing: 0;
222
+ }
223
+
224
+ .ds-timeline__label {
225
+ color: var(--timeline-content-default);
226
+ font-size: var(--bh-text-body-md-font-size);
227
+ font-weight: var(--bh-font-weight-semibold);
228
+ line-height: var(--bh-text-body-md-line-height);
229
+ }
230
+
231
+ .ds-timeline__caption {
232
+ color: var(--timeline-content-subtle);
233
+ font-size: var(--bh-text-body-sm-regular-font-size);
234
+ font-weight: var(--bh-font-weight-regular);
235
+ line-height: var(--bh-text-body-sm-regular-line-height);
236
+ }
237
+
238
+ .ds-timeline__date {
239
+ color: var(--timeline-content-subtle);
240
+ font-size: var(--bh-text-body-2xs-regular-font-size);
241
+ font-weight: var(--bh-font-weight-regular);
242
+ line-height: var(--bh-text-body-2xs-regular-line-height);
243
+ white-space: nowrap;
244
+ }
245
+
246
+ .ds-timeline__date--leading {
247
+ flex: 0 0 auto;
248
+ padding-top: var(--timeline-space-xs);
249
+ }
250
+
251
+ .ds-timeline-item--vertical.ds-timeline-item--ltr .ds-timeline__date--leading {
252
+ text-align: right;
253
+ }
254
+
255
+ .ds-timeline-item--horizontal .ds-timeline__date--leading {
256
+ width: 100%;
257
+ padding-top: 0;
258
+ text-align: start;
259
+ }
260
+
261
+ .ds-timeline-item--rtl .ds-timeline__date--leading,
262
+ .ds-timeline-item--rtl .ds-timeline__date--top,
263
+ .ds-timeline-item--rtl .ds-timeline__date--bottom {
264
+ text-align: right;
265
+ }
266
+
267
+ .ds-timeline__date--top {
268
+ width: 100%;
269
+ padding-top: var(--timeline-space-xs);
270
+ }
271
+
272
+ .ds-timeline__date--bottom {
273
+ width: 100%;
274
+ padding-top: var(--timeline-space-sm);
275
+ }
276
+
277
+ .ds-timeline__bottom-space {
278
+ display: block;
279
+ width: 100%;
280
+ height: var(--bh-space-5xl-24);
281
+ flex: 0 0 auto;
282
+ }