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,140 @@
1
+ .ds-breadcrumbs {
2
+ --breadcrumbs-color: var(--bh-content-subtle);
3
+ --breadcrumbs-current: var(--bh-content-default);
4
+ --breadcrumbs-border: var(--bh-border-subtle);
5
+ --breadcrumbs-surface: var(--bh-bg-raised);
6
+ --breadcrumbs-radius: var(--bh-radius-lg-8);
7
+
8
+ box-sizing: border-box;
9
+ display: block;
10
+ max-width: 100%;
11
+ min-width: 0;
12
+ overflow-x: auto;
13
+ overflow-y: hidden;
14
+ color: var(--breadcrumbs-color);
15
+ font-family: var(--bh-font-family);
16
+ font-size: var(--bh-text-body-md-font-size);
17
+ font-weight: var(--bh-font-weight-medium);
18
+ letter-spacing: 0;
19
+ line-height: var(--bh-text-body-md-line-height);
20
+ }
21
+
22
+ .ds-breadcrumbs *,
23
+ .ds-breadcrumbs *::before,
24
+ .ds-breadcrumbs *::after {
25
+ box-sizing: border-box;
26
+ }
27
+
28
+ .ds-breadcrumbs ol {
29
+ display: inline-flex;
30
+ align-items: center;
31
+ gap: var(--bh-space-xs-4);
32
+ max-width: 100%;
33
+ min-width: 0;
34
+ margin: 0;
35
+ padding: 0;
36
+ list-style: none;
37
+ }
38
+
39
+ .ds-breadcrumbs--raised ol {
40
+ gap: var(--bh-space-md-8);
41
+ padding: var(--bh-space-xl-12);
42
+ border: var(--bh-space-xxxs-1) solid var(--breadcrumbs-border);
43
+ border-radius: var(--breadcrumbs-radius);
44
+ background: var(--breadcrumbs-surface);
45
+ }
46
+
47
+ .ds-breadcrumbs li,
48
+ .ds-breadcrumbs a,
49
+ .ds-breadcrumbs li > span {
50
+ min-width: 0;
51
+ display: inline-flex;
52
+ align-items: center;
53
+ gap: var(--bh-space-xs-4);
54
+ }
55
+
56
+ .ds-breadcrumbs a {
57
+ color: inherit;
58
+ text-decoration: none;
59
+ }
60
+
61
+ .ds-breadcrumbs a:hover {
62
+ color: var(--breadcrumbs-current);
63
+ }
64
+
65
+ .ds-breadcrumbs a:focus-visible {
66
+ border-radius: var(--bh-radius-sm-4);
67
+ outline: var(--bh-space-xxs-2) solid var(--bh-border-focus);
68
+ outline-offset: var(--bh-space-xxs-2);
69
+ }
70
+
71
+ .ds-breadcrumbs .is-current {
72
+ color: var(--breadcrumbs-current);
73
+ }
74
+
75
+ .ds-breadcrumbs__icon {
76
+ width: var(--bh-space-4xl-20);
77
+ height: var(--bh-space-4xl-20);
78
+ flex: 0 0 auto;
79
+ display: inline-grid;
80
+ place-items: center;
81
+ color: currentColor;
82
+ }
83
+
84
+ .ds-breadcrumbs__icon:empty {
85
+ display: none;
86
+ }
87
+
88
+ .ds-breadcrumbs__icon svg {
89
+ width: var(--bh-space-4xl-20);
90
+ height: var(--bh-space-4xl-20);
91
+ display: block;
92
+ }
93
+
94
+ .ds-breadcrumbs__label {
95
+ max-width: 20ch;
96
+ overflow: hidden;
97
+ text-overflow: ellipsis;
98
+ white-space: nowrap;
99
+ }
100
+
101
+ .ds-breadcrumbs__label--hidden {
102
+ position: absolute;
103
+ width: var(--bh-space-xxxs-1);
104
+ height: var(--bh-space-xxxs-1);
105
+ overflow: hidden;
106
+ clip: rect(0 0 0 0);
107
+ white-space: nowrap;
108
+ }
109
+
110
+ .ds-breadcrumbs__separator {
111
+ width: var(--bh-space-3xl-16);
112
+ height: var(--bh-space-3xl-16);
113
+ display: inline-flex;
114
+ align-items: center;
115
+ justify-content: center;
116
+ color: var(--breadcrumbs-color);
117
+ line-height: var(--bh-text-body-2xs-regular-line-height);
118
+ }
119
+
120
+ .ds-breadcrumbs__separator svg {
121
+ width: var(--bh-space-3xl-16);
122
+ height: var(--bh-space-3xl-16);
123
+ display: block;
124
+ }
125
+
126
+ .ds-breadcrumbs[dir="rtl"] .ds-breadcrumbs__separator svg {
127
+ transform: scaleX(-1);
128
+ }
129
+
130
+ .ds-breadcrumbs--icon-only a,
131
+ .ds-breadcrumbs--icon-only li > span:not(.ds-breadcrumbs__separator) {
132
+ width: var(--bh-space-6xl-32);
133
+ height: var(--bh-space-6xl-32);
134
+ justify-content: center;
135
+ border-radius: var(--breadcrumbs-radius);
136
+ }
137
+
138
+ .ds-breadcrumbs--icon-only a:hover {
139
+ background: var(--bh-interactive-ghost-hover);
140
+ }
@@ -0,0 +1,87 @@
1
+ .catalog-showcase {
2
+ min-width: 0;
3
+ max-width: 100%;
4
+ display: grid;
5
+ grid-template-columns: repeat(2, minmax(0, 1fr));
6
+ gap: var(--bh-space-4xl-20);
7
+ }
8
+
9
+ .catalog-showcase__card {
10
+ min-width: 0;
11
+ display: grid;
12
+ gap: calc(var(--bh-space-xl-12) + var(--bh-space-sm-6));
13
+ align-content: start;
14
+ border: var(--bh-space-xxxs-1) solid var(--bh-border-subtle);
15
+ border-radius: var(--bh-radius-lg-8);
16
+ background: var(--bh-bg-raised);
17
+ padding: var(--bh-space-4xl-20);
18
+ box-shadow: var(--shadow-component-default);
19
+ }
20
+
21
+ .catalog-showcase__card:nth-child(4),
22
+ .catalog-showcase__card:nth-child(5) {
23
+ grid-column: 1 / -1;
24
+ }
25
+
26
+ .catalog-showcase__card-header {
27
+ min-width: 0;
28
+ display: grid;
29
+ gap: var(--bh-space-xs-4);
30
+ }
31
+
32
+ .catalog-showcase__card h3,
33
+ .catalog-showcase__card p {
34
+ margin: 0;
35
+ }
36
+
37
+ .catalog-showcase__card h3 {
38
+ color: var(--bh-content-default);
39
+ font-size: var(--bh-text-heading-xs-semibold-font-size);
40
+ font-weight: var(--bh-text-heading-xs-semibold-font-weight);
41
+ line-height: var(--bh-text-heading-xs-semibold-line-height);
42
+ }
43
+
44
+ .catalog-showcase__card p {
45
+ color: var(--bh-content-subtle);
46
+ font-size: var(--bh-text-body-xs-regular-font-size);
47
+ line-height: var(--bh-text-body-sm-regular-line-height);
48
+ }
49
+
50
+ .catalog-showcase__stack {
51
+ min-width: 0;
52
+ display: grid;
53
+ gap: var(--bh-space-2xl-14);
54
+ }
55
+
56
+ .catalog-showcase__tag-grid {
57
+ display: flex;
58
+ flex-wrap: wrap;
59
+ align-items: center;
60
+ gap: var(--bh-space-lg-10);
61
+ }
62
+
63
+ .catalog-showcase__upload-grid {
64
+ display: grid;
65
+ grid-template-columns: minmax(var(--bh-catalog-file-grid-min), var(--bh-catalog-file-grid-max)) minmax(var(--bh-catalog-file-preview-min), var(--bh-catalog-file-preview-max));
66
+ gap: calc(var(--bh-space-xl-12) + var(--bh-space-sm-6));
67
+ align-items: start;
68
+ }
69
+
70
+ /* Approved exception: media query breakpoints stay literal because CSS vars are not reliable in query conditions. */
71
+ @media (max-width: 1100px) {
72
+ .catalog-showcase,
73
+ .catalog-showcase__upload-grid {
74
+ grid-template-columns: minmax(0, 1fr);
75
+ }
76
+
77
+ .catalog-showcase__card:nth-child(4),
78
+ .catalog-showcase__card:nth-child(5) {
79
+ grid-column: auto;
80
+ }
81
+ }
82
+
83
+ @media (max-width: 640px) {
84
+ .catalog-showcase__card {
85
+ padding: var(--bh-space-3xl-16);
86
+ }
87
+ }
@@ -0,0 +1,473 @@
1
+ .ds-command-bar {
2
+ --command-bg-raised: var(--bh-bg-raised);
3
+ --command-bg-neutral-soft: var(--bh-bg-neutral-soft);
4
+ --command-bg-neutral-subtle: var(--bh-bg-neutral-subtle);
5
+ --command-border-default: var(--bh-border-default);
6
+ --command-border-input: var(--bh-border-input);
7
+ --command-border-subtle: var(--bh-border-subtle);
8
+ --command-content-default: var(--bh-content-default);
9
+ --command-content-muted: var(--bh-content-muted);
10
+ --command-content-subtle: var(--bh-content-subtle);
11
+ --command-control-default: var(--bh-control-default);
12
+ --command-input-default: var(--bh-interactive-input-default);
13
+ --command-interactive-hover: var(--bh-interactive-ghost-hover);
14
+ --command-interactive-secondary: var(--bh-interactive-secondary-default);
15
+ --command-interactive-soft: var(--bh-interactive-soft-default);
16
+ --command-radius-3xl: var(--bh-radius-3xl-16);
17
+ --command-radius-full: var(--bh-radius-full);
18
+ --command-radius-lg: var(--bh-radius-lg-8);
19
+ --command-radius-md: var(--bh-radius-md-6);
20
+ --command-space-xs: var(--bh-space-xs-4);
21
+ --command-space-sm: var(--bh-space-sm-6);
22
+ --command-space-md: var(--bh-space-md-8);
23
+ --command-space-xl: var(--bh-space-xl-12);
24
+ --command-space-3xl: var(--bh-space-3xl-16);
25
+ --command-space-4xl: var(--bh-space-4xl-20);
26
+ --command-space-5xl: var(--bh-space-5xl-24);
27
+ --command-space-10xl: var(--bh-space-10xl-80);
28
+ --command-width-desktop: calc(var(--bh-space-18xl-320) + var(--bh-space-18xl-320));
29
+ --command-width-mobile: calc(var(--bh-space-19xl-384) - var(--bh-space-md-8) - var(--bh-space-xxxs-1));
30
+ --command-height-mobile: calc(var(--bh-space-19xl-384) + var(--bh-space-19xl-384) + var(--bh-space-7xl-40) + var(--bh-space-xs-4));
31
+ --command-height-default: calc(var(--bh-space-8xl-48) + var(--bh-space-xl-12));
32
+ --command-height-recent: calc(var(--bh-space-19xl-384) + var(--bh-space-18xl-320) + var(--bh-space-xs-4));
33
+ --command-height-results: calc(var(--bh-space-19xl-384) + var(--bh-space-18xl-320));
34
+ --command-height-empty: calc(var(--bh-space-18xl-320) - var(--bh-space-xs-4));
35
+ --command-content-height-recent: calc(var(--bh-space-19xl-384) + var(--bh-space-14xl-192) + var(--bh-space-5xl-24));
36
+ --command-content-height-results: calc(var(--bh-space-19xl-384) + var(--bh-space-14xl-192) + var(--bh-space-4xl-20));
37
+ --command-search-mobile-height: var(--bh-space-8xl-48);
38
+ --command-item-height: calc(var(--bh-space-8xl-48) + var(--bh-space-md-8));
39
+ --command-icon-size: var(--bh-space-6xl-32);
40
+ --command-close-size: var(--bh-space-5xl-24);
41
+ --command-shortcut-min-width: calc(var(--bh-space-5xl-24) + var(--bh-space-xs-4));
42
+ --command-tag-height: calc(var(--bh-space-6xl-32) + var(--bh-space-xs-4));
43
+ --command-empty-mobile-padding: calc(var(--bh-space-13xl-160) + var(--bh-space-5xl-24));
44
+ --command-shadow-surface: var(--shadow-component-default);
45
+
46
+ box-sizing: border-box;
47
+ display: flex;
48
+ flex-direction: column;
49
+ align-items: stretch;
50
+ width: var(--command-width-desktop);
51
+ max-width: var(--command-width-desktop);
52
+ overflow: hidden;
53
+ border: var(--bh-space-xxxs-1) solid var(--command-border-subtle);
54
+ background: var(--command-bg-raised);
55
+ color: var(--command-content-default);
56
+ font-family: var(--bh-font-family);
57
+ font-size: var(--bh-text-body-md-regular-font-size);
58
+ font-style: normal;
59
+ font-weight: var(--bh-text-body-md-regular-font-weight);
60
+ letter-spacing: var(--bh-text-body-md-regular-letter-spacing);
61
+ line-height: var(--bh-text-body-md-regular-line-height);
62
+ }
63
+
64
+ .ds-command-bar *,
65
+ .ds-command-bar *::before,
66
+ .ds-command-bar *::after {
67
+ box-sizing: border-box;
68
+ }
69
+
70
+ .ds-command-bar button {
71
+ font: inherit;
72
+ }
73
+
74
+ .ds-command-bar svg {
75
+ display: block;
76
+ flex: 0 0 auto;
77
+ }
78
+
79
+ .ds-command-bar--desktop {
80
+ border-radius: var(--command-radius-3xl);
81
+ box-shadow: var(--command-shadow-surface);
82
+ }
83
+
84
+ .ds-command-bar--mobile {
85
+ width: var(--command-width-mobile);
86
+ height: var(--command-height-mobile);
87
+ max-width: var(--command-width-mobile);
88
+ border-radius: 0;
89
+ box-shadow: none;
90
+ }
91
+
92
+ .ds-command-bar--desktop.ds-command-bar--default {
93
+ height: var(--command-height-default);
94
+ }
95
+
96
+ .ds-command-bar--desktop.ds-command-bar--recent {
97
+ height: var(--command-height-recent);
98
+ }
99
+
100
+ .ds-command-bar--desktop.ds-command-bar--results {
101
+ height: var(--command-height-results);
102
+ }
103
+
104
+ .ds-command-bar--desktop.ds-command-bar--no-result {
105
+ height: var(--command-height-empty);
106
+ }
107
+
108
+ .ds-command-bar--rtl {
109
+ font-family: var(--bh-font-family);
110
+ }
111
+
112
+ .ds-command-bar__input-wrap {
113
+ width: 100%;
114
+ padding: var(--command-space-3xl) var(--command-space-3xl) 0;
115
+ }
116
+
117
+ .ds-command-bar__search {
118
+ appearance: none;
119
+ width: 100%;
120
+ min-height: var(--command-height-default);
121
+ border: 0;
122
+ display: flex;
123
+ align-items: center;
124
+ justify-content: space-between;
125
+ gap: var(--command-space-md);
126
+ margin: 0;
127
+ background: var(--command-bg-raised);
128
+ color: var(--command-content-subtle);
129
+ padding: var(--command-space-3xl) var(--command-space-4xl) var(--command-space-3xl) var(--command-space-3xl);
130
+ text-align: start;
131
+ }
132
+
133
+ .ds-command-bar__search--default {
134
+ cursor: pointer;
135
+ }
136
+
137
+ .ds-command-bar__search--divider {
138
+ border-bottom: var(--bh-space-xxxs-1) solid var(--command-border-input);
139
+ }
140
+
141
+ .ds-command-bar--mobile .ds-command-bar__search {
142
+ min-height: var(--command-search-mobile-height);
143
+ border: var(--bh-space-xxxs-1) solid var(--command-border-input);
144
+ border-radius: var(--command-radius-lg);
145
+ background: var(--command-input-default);
146
+ padding: var(--command-space-xl);
147
+ }
148
+
149
+ .ds-command-bar--desktop.ds-command-bar--rtl .ds-command-bar__search {
150
+ padding-right: var(--command-space-3xl);
151
+ padding-left: var(--command-space-4xl);
152
+ }
153
+
154
+ .ds-command-bar__search-content {
155
+ display: flex;
156
+ flex: 1 0 0;
157
+ align-items: center;
158
+ gap: var(--command-space-md);
159
+ min-width: 0;
160
+ }
161
+
162
+ .ds-command-bar__placeholder,
163
+ .ds-command-bar__search-text {
164
+ display: block;
165
+ flex: 1 0 0;
166
+ min-width: 0;
167
+ overflow: hidden;
168
+ line-height: var(--bh-text-body-md-regular-line-height);
169
+ text-align: start;
170
+ text-overflow: ellipsis;
171
+ white-space: nowrap;
172
+ word-break: break-word;
173
+ }
174
+
175
+ .ds-command-bar__placeholder {
176
+ color: var(--command-content-muted);
177
+ }
178
+
179
+ .ds-command-bar__search-text {
180
+ color: var(--command-content-default);
181
+ }
182
+
183
+ .ds-command-bar__shortcut {
184
+ min-width: var(--command-shortcut-min-width);
185
+ border: var(--bh-space-xxxs-1) solid var(--command-border-default);
186
+ border-radius: var(--command-radius-md);
187
+ display: inline-flex;
188
+ flex: 0 0 auto;
189
+ align-items: center;
190
+ justify-content: center;
191
+ background: var(--command-interactive-soft);
192
+ color: var(--command-content-subtle);
193
+ font-family: inherit;
194
+ font-size: var(--bh-text-body-md-regular-font-size);
195
+ font-style: normal;
196
+ font-weight: var(--bh-text-body-md-regular-font-weight);
197
+ line-height: var(--bh-text-body-md-regular-line-height);
198
+ padding: var(--bh-space-xxs-2) var(--command-space-sm);
199
+ }
200
+
201
+ .ds-command-bar__close {
202
+ appearance: none;
203
+ width: var(--command-close-size);
204
+ height: var(--command-close-size);
205
+ border: 0;
206
+ border-radius: var(--command-radius-full);
207
+ display: inline-grid;
208
+ flex: 0 0 auto;
209
+ place-items: center;
210
+ background: transparent;
211
+ color: var(--command-content-subtle);
212
+ cursor: pointer;
213
+ padding: 0;
214
+ }
215
+
216
+ .ds-command-bar__close:focus-visible,
217
+ .ds-command-bar__search:focus-visible,
218
+ .ds-command-bar__item:focus-visible,
219
+ .ds-command-bar__tag:focus-visible {
220
+ outline: var(--bh-space-xxs-2) solid var(--bh-border-focus);
221
+ outline-offset: var(--bh-space-xxs-2);
222
+ }
223
+
224
+ .ds-command-bar__content {
225
+ width: 100%;
226
+ overflow: hidden;
227
+ padding-block: var(--command-space-3xl);
228
+ }
229
+
230
+ .ds-command-bar--desktop.ds-command-bar--recent .ds-command-bar__content {
231
+ height: var(--command-content-height-recent);
232
+ }
233
+
234
+ .ds-command-bar--desktop.ds-command-bar--results .ds-command-bar__content {
235
+ height: var(--command-content-height-results);
236
+ }
237
+
238
+ .ds-command-bar--mobile .ds-command-bar__content {
239
+ flex: 1 1 auto;
240
+ min-height: 0;
241
+ padding-block: var(--command-space-3xl);
242
+ }
243
+
244
+ .ds-command-bar__main {
245
+ display: flex;
246
+ flex-direction: column;
247
+ gap: var(--command-space-5xl);
248
+ min-width: 0;
249
+ }
250
+
251
+ .ds-command-bar__section {
252
+ display: flex;
253
+ flex-direction: column;
254
+ gap: var(--command-space-md);
255
+ width: 100%;
256
+ }
257
+
258
+ .ds-command-bar__section-heading {
259
+ display: flex;
260
+ width: 100%;
261
+ padding-inline: var(--command-space-4xl);
262
+ }
263
+
264
+ .ds-command-bar--mobile .ds-command-bar__section-heading {
265
+ padding-inline: var(--command-space-3xl);
266
+ }
267
+
268
+ .ds-command-bar__section-heading span {
269
+ flex: 1 0 0;
270
+ min-width: 0;
271
+ color: var(--command-content-subtle);
272
+ line-height: var(--bh-text-body-md-regular-line-height);
273
+ text-align: start;
274
+ }
275
+
276
+ .ds-command-bar__group {
277
+ display: flex;
278
+ flex-direction: column;
279
+ width: 100%;
280
+ padding-inline: var(--command-space-md);
281
+ }
282
+
283
+ .ds-command-bar--mobile .ds-command-bar__group {
284
+ padding-inline: var(--command-space-xs);
285
+ }
286
+
287
+ .ds-command-bar__item {
288
+ appearance: none;
289
+ width: 100%;
290
+ min-height: var(--command-item-height);
291
+ border: 0;
292
+ border-radius: var(--command-radius-lg);
293
+ display: flex;
294
+ align-items: center;
295
+ gap: var(--command-space-xl);
296
+ margin: 0;
297
+ background: transparent;
298
+ color: var(--command-content-default);
299
+ cursor: pointer;
300
+ padding: var(--command-space-xl);
301
+ text-align: start;
302
+ }
303
+
304
+ .ds-command-bar__item.is-highlighted,
305
+ .ds-command-bar__item:hover {
306
+ background: var(--command-interactive-hover);
307
+ }
308
+
309
+ .ds-command-bar__icon-wrap,
310
+ .ds-command-bar__avatar {
311
+ width: var(--command-icon-size);
312
+ height: var(--command-icon-size);
313
+ border-radius: var(--command-radius-md);
314
+ display: inline-grid;
315
+ flex: 0 0 auto;
316
+ place-items: center;
317
+ }
318
+
319
+ .ds-command-bar__icon-wrap {
320
+ background: var(--command-bg-neutral-soft);
321
+ color: var(--command-content-subtle);
322
+ }
323
+
324
+ .ds-command-bar__avatar {
325
+ overflow: hidden;
326
+ border: var(--bh-space-xxxs-1) solid var(--command-border-subtle);
327
+ border-radius: var(--command-radius-full);
328
+ background:
329
+ radial-gradient(circle at 42% 34%, var(--bh-bg-accent-amber-soft) 0 10%, transparent 11%),
330
+ radial-gradient(circle at 52% 42%, var(--bh-bg-accent-amber-default) 0 20%, transparent 21%),
331
+ linear-gradient(135deg, var(--bh-bg-inverse), var(--bh-bg-brand-strong) 42%, var(--bh-bg-always-dark));
332
+ }
333
+
334
+ .ds-command-bar__item-copy {
335
+ display: flex;
336
+ flex: 1 0 0;
337
+ flex-direction: column;
338
+ min-width: 0;
339
+ text-align: start;
340
+ word-break: break-word;
341
+ }
342
+
343
+ .ds-command-bar__item-copy strong {
344
+ width: 100%;
345
+ overflow: hidden;
346
+ color: var(--command-content-default);
347
+ font-size: var(--bh-text-body-md-medium-font-size);
348
+ font-weight: var(--bh-text-body-md-medium-font-weight);
349
+ line-height: var(--bh-text-body-md-medium-line-height);
350
+ text-overflow: ellipsis;
351
+ white-space: nowrap;
352
+ }
353
+
354
+ .ds-command-bar__item-copy span {
355
+ width: 100%;
356
+ overflow: hidden;
357
+ color: var(--command-content-subtle);
358
+ font-size: var(--bh-text-body-2xs-regular-font-size);
359
+ font-weight: var(--bh-text-body-2xs-regular-font-weight);
360
+ line-height: var(--bh-text-body-2xs-regular-line-height);
361
+ text-overflow: ellipsis;
362
+ white-space: nowrap;
363
+ }
364
+
365
+ .ds-command-bar__filter {
366
+ display: flex;
367
+ flex-direction: column;
368
+ gap: var(--command-space-3xl);
369
+ width: 100%;
370
+ padding-inline: var(--command-space-4xl);
371
+ }
372
+
373
+ .ds-command-bar--mobile .ds-command-bar__filter {
374
+ padding-inline: var(--command-space-3xl);
375
+ }
376
+
377
+ .ds-command-bar__filter .ds-command-bar__section-heading {
378
+ padding-inline: 0;
379
+ }
380
+
381
+ .ds-command-bar__tags {
382
+ display: flex;
383
+ gap: var(--command-space-md);
384
+ max-width: 100%;
385
+ overflow: hidden;
386
+ }
387
+
388
+ .ds-command-bar__tag {
389
+ appearance: none;
390
+ height: var(--command-tag-height);
391
+ border: var(--bh-space-xxxs-1) solid var(--command-border-default);
392
+ border-radius: var(--command-control-default);
393
+ display: inline-flex;
394
+ flex: 0 0 auto;
395
+ align-items: center;
396
+ justify-content: center;
397
+ background: var(--command-interactive-secondary);
398
+ color: var(--command-content-default);
399
+ cursor: pointer;
400
+ font-size: var(--bh-text-body-md-medium-font-size);
401
+ font-weight: var(--bh-text-body-md-medium-font-weight);
402
+ line-height: var(--bh-text-body-md-medium-line-height);
403
+ padding-inline: var(--command-space-xl);
404
+ text-align: center;
405
+ white-space: nowrap;
406
+ }
407
+
408
+ .ds-command-bar__empty {
409
+ width: 100%;
410
+ display: grid;
411
+ flex: 1 1 auto;
412
+ place-items: center;
413
+ padding: var(--command-space-10xl) var(--command-space-4xl);
414
+ }
415
+
416
+ .ds-command-bar--mobile .ds-command-bar__empty {
417
+ align-items: start;
418
+ padding-top: var(--command-empty-mobile-padding);
419
+ }
420
+
421
+ .ds-command-bar__empty-wrap {
422
+ display: grid;
423
+ place-items: center;
424
+ gap: var(--command-space-xs);
425
+ text-align: center;
426
+ }
427
+
428
+ .ds-command-bar__empty-icon {
429
+ width: var(--bh-space-7xl-40);
430
+ height: var(--bh-space-7xl-40);
431
+ border: var(--bh-space-xxxs-1) solid var(--command-border-subtle);
432
+ border-radius: var(--command-radius-full);
433
+ display: grid;
434
+ place-items: center;
435
+ background: var(--command-bg-neutral-subtle);
436
+ color: var(--command-content-default);
437
+ }
438
+
439
+ .ds-command-bar__empty-wrap strong {
440
+ color: var(--command-content-default);
441
+ font-size: var(--bh-text-body-lg-medium-font-size);
442
+ font-weight: var(--bh-text-body-lg-medium-font-weight);
443
+ line-height: var(--bh-text-body-lg-medium-line-height);
444
+ }
445
+
446
+ .ds-command-bar__empty-wrap span:last-child {
447
+ color: var(--command-content-subtle);
448
+ font-size: var(--bh-text-body-md-regular-font-size);
449
+ line-height: var(--bh-text-body-md-regular-line-height);
450
+ }
451
+
452
+ .ds-command-bar__footer {
453
+ width: 100%;
454
+ border-top: var(--bh-space-xxxs-1) solid var(--command-border-subtle);
455
+ display: flex;
456
+ align-items: center;
457
+ background: var(--command-bg-raised);
458
+ color: var(--command-content-subtle);
459
+ padding: var(--command-space-xl);
460
+ }
461
+
462
+ .ds-command-bar__footer-content {
463
+ display: flex;
464
+ align-items: center;
465
+ gap: var(--command-space-3xl);
466
+ }
467
+
468
+ .ds-command-bar__footer-hint {
469
+ display: inline-flex;
470
+ align-items: center;
471
+ gap: var(--command-space-xs);
472
+ white-space: nowrap;
473
+ }