@hanzo/ui 5.0.2 → 5.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 (371) hide show
  1. package/dist/accordion.js +1 -0
  2. package/dist/accordion.mjs +1 -0
  3. package/dist/alert-dialog.js +1 -0
  4. package/dist/alert-dialog.mjs +1 -0
  5. package/dist/alert.js +1 -0
  6. package/dist/alert.mjs +1 -0
  7. package/dist/avatar.js +1 -0
  8. package/dist/avatar.mjs +1 -0
  9. package/dist/badge.js +1 -0
  10. package/dist/badge.mjs +1 -0
  11. package/dist/breadcrumb.js +1 -0
  12. package/dist/breadcrumb.mjs +1 -0
  13. package/dist/calendar.js +1 -0
  14. package/dist/calendar.mjs +1 -0
  15. package/dist/carousel.js +1 -0
  16. package/dist/carousel.mjs +1 -0
  17. package/dist/checkbox.js +1 -0
  18. package/dist/checkbox.mjs +1 -0
  19. package/dist/chunk-3H5S2OQ3.mjs +1 -0
  20. package/dist/chunk-5GRJ7UQX.js +1 -0
  21. package/dist/chunk-63HNMH7C.js +1 -0
  22. package/dist/chunk-72TOQ4DM.mjs +1 -0
  23. package/dist/chunk-7AEFTV5R.mjs +1 -0
  24. package/dist/chunk-7M4AVV2R.js +1 -0
  25. package/dist/chunk-DKPVJSBC.js +1 -0
  26. package/dist/chunk-EI7MMDWY.js +1 -0
  27. package/dist/chunk-GANGDIZG.mjs +1 -0
  28. package/dist/chunk-GRGT2Z4K.js +1 -0
  29. package/dist/chunk-JCUUC6NY.mjs +1 -0
  30. package/dist/chunk-JUQMWLIN.js +1 -0
  31. package/dist/chunk-PRVEIITE.js +1 -0
  32. package/dist/chunk-SH52AKNZ.js +1 -0
  33. package/dist/chunk-TU67EJEW.mjs +1 -0
  34. package/dist/chunk-WN5KN73U.mjs +1 -0
  35. package/dist/chunk-YSXGDEY5.mjs +1 -0
  36. package/dist/chunk-Z76OOVUE.mjs +1 -0
  37. package/dist/collapsible.js +1 -0
  38. package/dist/collapsible.mjs +1 -0
  39. package/dist/command.js +1 -0
  40. package/dist/command.mjs +1 -0
  41. package/dist/context-menu.js +1 -0
  42. package/dist/context-menu.mjs +1 -0
  43. package/dist/dialog.js +1 -0
  44. package/dist/dialog.mjs +1 -0
  45. package/dist/drawer.js +1 -0
  46. package/dist/drawer.mjs +1 -0
  47. package/dist/dropdown-menu.js +1 -0
  48. package/dist/dropdown-menu.mjs +1 -0
  49. package/dist/form.js +1 -0
  50. package/dist/form.mjs +1 -0
  51. package/dist/hover-card.js +1 -0
  52. package/dist/hover-card.mjs +1 -0
  53. package/dist/index.js +1 -9079
  54. package/dist/index.mjs +1 -8700
  55. package/dist/input-otp.js +1 -0
  56. package/dist/input-otp.mjs +1 -0
  57. package/dist/lib/utils.js +1 -0
  58. package/dist/lib/utils.mjs +1 -0
  59. package/dist/navigation-menu.js +1 -0
  60. package/dist/navigation-menu.mjs +1 -0
  61. package/dist/popover.js +1 -0
  62. package/dist/popover.mjs +1 -0
  63. package/dist/progress.js +1 -0
  64. package/dist/progress.mjs +1 -0
  65. package/dist/radio-group.js +1 -0
  66. package/dist/radio-group.mjs +1 -0
  67. package/dist/resizable.js +1 -0
  68. package/dist/resizable.mjs +1 -0
  69. package/dist/scroll-area.js +1 -0
  70. package/dist/scroll-area.mjs +1 -0
  71. package/dist/select.js +1 -0
  72. package/dist/select.mjs +1 -0
  73. package/dist/separator.js +1 -0
  74. package/dist/separator.mjs +1 -0
  75. package/dist/sheet.js +1 -0
  76. package/dist/sheet.mjs +1 -0
  77. package/dist/skeleton.js +1 -0
  78. package/dist/skeleton.mjs +1 -0
  79. package/dist/slider.js +1 -0
  80. package/dist/slider.mjs +1 -0
  81. package/dist/sonner.js +1 -0
  82. package/dist/sonner.mjs +1 -0
  83. package/dist/src/utils.js +1 -0
  84. package/dist/src/utils.mjs +1 -0
  85. package/dist/switch.js +1 -0
  86. package/dist/switch.mjs +1 -0
  87. package/dist/table.js +1 -0
  88. package/dist/table.mjs +1 -0
  89. package/dist/tabs.js +1 -0
  90. package/dist/tabs.mjs +1 -0
  91. package/dist/tailwind/index.js +1 -0
  92. package/dist/tailwind/index.mjs +1 -0
  93. package/dist/textarea.js +1 -0
  94. package/dist/textarea.mjs +1 -0
  95. package/dist/toggle-group.js +1 -0
  96. package/dist/toggle-group.mjs +1 -0
  97. package/dist/toggle.js +1 -0
  98. package/dist/toggle.mjs +1 -0
  99. package/dist/tooltip.js +1 -0
  100. package/dist/tooltip.mjs +1 -0
  101. package/dist/types/index.js +1 -0
  102. package/dist/types/index.mjs +1 -0
  103. package/package.json +110 -81
  104. package/assets/ai-icons.tsx +0 -207
  105. package/assets/crypto.tsx +0 -33
  106. package/assets/file-type-icon.tsx +0 -66
  107. package/assets/file.tsx +0 -45
  108. package/assets/general.tsx +0 -2318
  109. package/assets/hanzo-logo.svg +0 -9
  110. package/assets/hanzo-logo.tsx +0 -17
  111. package/assets/index.ts +0 -122
  112. package/assets/index.tsx +0 -4
  113. package/assets/llm-provider.tsx +0 -1094
  114. package/blocks/auth/index.ts +0 -6
  115. package/blocks/auth/login-2fa.tsx +0 -165
  116. package/blocks/auth/login-basic.tsx +0 -94
  117. package/blocks/auth/login-social.tsx +0 -148
  118. package/blocks/auth/magic-link.tsx +0 -129
  119. package/blocks/auth/password-reset.tsx +0 -97
  120. package/blocks/auth/signup.tsx +0 -157
  121. package/blocks/components/accordian-block.tsx +0 -48
  122. package/blocks/components/block-component-props.ts +0 -11
  123. package/blocks/components/bullet-cards-block.tsx +0 -46
  124. package/blocks/components/card-block/index.tsx +0 -171
  125. package/blocks/components/card-block/link-out-button.tsx +0 -20
  126. package/blocks/components/card-block/util.ts +0 -28
  127. package/blocks/components/carte-blanche-block/index.tsx +0 -127
  128. package/blocks/components/carte-blanche-block/variant-content-left.tsx +0 -49
  129. package/blocks/components/content.tsx +0 -70
  130. package/blocks/components/cta-block.tsx +0 -115
  131. package/blocks/components/enh-heading-block.tsx +0 -204
  132. package/blocks/components/grid-block/grid-block-mutator.ts +0 -12
  133. package/blocks/components/grid-block/index.tsx +0 -83
  134. package/blocks/components/grid-block/mutator-registry.ts +0 -10
  135. package/blocks/components/grid-block/table-borders.mutator.ts +0 -47
  136. package/blocks/components/group-block.tsx +0 -83
  137. package/blocks/components/heading-block.tsx +0 -88
  138. package/blocks/components/image-block.tsx +0 -111
  139. package/blocks/components/index.ts +0 -30
  140. package/blocks/components/screenful-block/content.tsx +0 -123
  141. package/blocks/components/screenful-block/index.tsx +0 -107
  142. package/blocks/components/screenful-block/poster-background.tsx +0 -34
  143. package/blocks/components/screenful-block/video-background.tsx +0 -45
  144. package/blocks/components/space-block.tsx +0 -66
  145. package/blocks/components/video-block.tsx +0 -138
  146. package/blocks/data-display/activity-feed.tsx +0 -242
  147. package/blocks/data-display/data-table.tsx +0 -235
  148. package/blocks/data-display/stats-grid.tsx +0 -194
  149. package/blocks/def/accordian-block.ts +0 -14
  150. package/blocks/def/block.ts +0 -7
  151. package/blocks/def/bullet-cards-block.ts +0 -22
  152. package/blocks/def/card-block.ts +0 -22
  153. package/blocks/def/carte-blanche-block.ts +0 -21
  154. package/blocks/def/cta-block.ts +0 -19
  155. package/blocks/def/element-block.ts +0 -11
  156. package/blocks/def/enh-heading-block.ts +0 -44
  157. package/blocks/def/grid-block.ts +0 -16
  158. package/blocks/def/group-block.ts +0 -11
  159. package/blocks/def/heading-block.ts +0 -15
  160. package/blocks/def/image-block.ts +0 -31
  161. package/blocks/def/index.ts +0 -35
  162. package/blocks/def/screenful-block.ts +0 -54
  163. package/blocks/def/space-block.ts +0 -64
  164. package/blocks/def/video-block.ts +0 -9
  165. package/blocks/ecommerce/checkout.tsx +0 -242
  166. package/blocks/ecommerce/index.ts +0 -7
  167. package/blocks/ecommerce/product-detail.tsx +0 -257
  168. package/blocks/ecommerce/product-grid.tsx +0 -148
  169. package/blocks/ecommerce/shopping-cart.tsx +0 -181
  170. package/blocks/index.ts +0 -2
  171. package/blocks/marketing/cta-section.tsx +0 -207
  172. package/blocks/marketing/faq.tsx +0 -159
  173. package/blocks/marketing/features-grid.tsx +0 -156
  174. package/blocks/marketing/hero-section.tsx +0 -192
  175. package/blocks/marketing/index.ts +0 -6
  176. package/blocks/marketing/pricing-table.tsx +0 -121
  177. package/blocks/marketing/testimonials.tsx +0 -196
  178. package/components/index.ts +0 -9
  179. package/dist/index.js.map +0 -1
  180. package/dist/index.mjs.map +0 -1
  181. package/dist/tailwind.js +0 -2025
  182. package/dist/tailwind.js.map +0 -1
  183. package/dist/tailwind.mjs +0 -2013
  184. package/dist/tailwind.mjs.map +0 -1
  185. package/dist/types.js +0 -59
  186. package/dist/types.js.map +0 -1
  187. package/dist/types.mjs +0 -53
  188. package/dist/types.mjs.map +0 -1
  189. package/dist/utils.js +0 -30
  190. package/dist/utils.js.map +0 -1
  191. package/dist/utils.mjs +0 -26
  192. package/dist/utils.mjs.map +0 -1
  193. package/frameworks/core/index.ts +0 -6
  194. package/frameworks/core/utils/index.ts +0 -64
  195. package/frameworks/react/components/button.tsx +0 -26
  196. package/frameworks/react/components/index.ts +0 -5
  197. package/frameworks/react/hooks/index.ts +0 -5
  198. package/frameworks/react/index.ts +0 -9
  199. package/frameworks/react/package.json +0 -8
  200. package/frameworks/react/utils/index.ts +0 -2
  201. package/frameworks/react-native/index.ts +0 -9
  202. package/frameworks/react-native/package.json +0 -8
  203. package/frameworks/registry.json +0 -371
  204. package/frameworks/setup.sh +0 -69
  205. package/frameworks/svelte/index.ts +0 -9
  206. package/frameworks/svelte/package.json +0 -8
  207. package/frameworks/tracker.json +0 -1854
  208. package/frameworks/vue/index.ts +0 -9
  209. package/frameworks/vue/package.json +0 -8
  210. package/helpers/file.ts +0 -33
  211. package/helpers/memoization.ts +0 -40
  212. package/primitives/accordion.tsx +0 -74
  213. package/primitives/action-button.tsx +0 -42
  214. package/primitives/alert-dialog.tsx +0 -185
  215. package/primitives/alert.tsx +0 -74
  216. package/primitives/apply-typography.tsx +0 -55
  217. package/primitives/aspect-ratio.tsx +0 -5
  218. package/primitives/avatar.tsx +0 -57
  219. package/primitives/background-beams.tsx +0 -142
  220. package/primitives/badge.tsx +0 -45
  221. package/primitives/breadcrumb.tsx +0 -130
  222. package/primitives/breakpoint-indicator.tsx +0 -19
  223. package/primitives/button.tsx +0 -72
  224. package/primitives/calendar.tsx +0 -72
  225. package/primitives/card.tsx +0 -97
  226. package/primitives/carousel.tsx +0 -238
  227. package/primitives/chat/chat-input-area.tsx +0 -88
  228. package/primitives/chat/chat-input.tsx +0 -71
  229. package/primitives/chat/files-preview.tsx +0 -331
  230. package/primitives/chat/index.ts +0 -6
  231. package/primitives/chat/json-form.tsx +0 -8
  232. package/primitives/chat/message-list.tsx +0 -308
  233. package/primitives/chat/message.tsx +0 -569
  234. package/primitives/chat/sqlite-preview.tsx +0 -215
  235. package/primitives/checkbox.tsx +0 -32
  236. package/primitives/collapsible.tsx +0 -9
  237. package/primitives/combobox.tsx +0 -239
  238. package/primitives/command.tsx +0 -151
  239. package/primitives/context-menu.tsx +0 -206
  240. package/primitives/copy-to-clipboard-icon.tsx +0 -60
  241. package/primitives/dialog-video-controller.tsx +0 -38
  242. package/primitives/dialog.tsx +0 -128
  243. package/primitives/dot-pattern.tsx +0 -57
  244. package/primitives/dots-loader.tsx +0 -13
  245. package/primitives/drawer.tsx +0 -113
  246. package/primitives/dropdown-menu.tsx +0 -199
  247. package/primitives/error-message.tsx +0 -19
  248. package/primitives/file-uploader.tsx +0 -203
  249. package/primitives/form.tsx +0 -185
  250. package/primitives/hover-card.tsx +0 -28
  251. package/primitives/icons/github.tsx +0 -14
  252. package/primitives/icons/index.ts +0 -18
  253. package/primitives/icons/youtube-logo.tsx +0 -59
  254. package/primitives/index-client.ts +0 -4
  255. package/primitives/index-common.ts +0 -304
  256. package/primitives/index-next.ts +0 -4
  257. package/primitives/input-otp.tsx +0 -65
  258. package/primitives/input.tsx +0 -128
  259. package/primitives/label.tsx +0 -21
  260. package/primitives/list-adaptor.ts +0 -12
  261. package/primitives/list-box.tsx +0 -74
  262. package/primitives/loading-spinner.tsx +0 -33
  263. package/primitives/markdown-preview.tsx +0 -612
  264. package/primitives/mermaid.tsx +0 -196
  265. package/primitives/navigation-menu.tsx +0 -147
  266. package/primitives/next/image.tsx +0 -91
  267. package/primitives/next/index.ts +0 -7
  268. package/primitives/next/inline-icon.tsx +0 -36
  269. package/primitives/next/link-element.tsx +0 -109
  270. package/primitives/next/mdx-link.tsx +0 -22
  271. package/primitives/next/media-stack.tsx +0 -52
  272. package/primitives/next/nav-items.tsx +0 -45
  273. package/primitives/next/youtube-embed.tsx +0 -83
  274. package/primitives/pagination.tsx +0 -117
  275. package/primitives/popover.tsx +0 -34
  276. package/primitives/pretty-json-print.tsx +0 -28
  277. package/primitives/progress.tsx +0 -27
  278. package/primitives/prompt-textarea.tsx +0 -72
  279. package/primitives/qr-code.tsx +0 -112
  280. package/primitives/radio-group.tsx +0 -42
  281. package/primitives/resizable.tsx +0 -47
  282. package/primitives/scroll-area.tsx +0 -57
  283. package/primitives/search-input.tsx +0 -66
  284. package/primitives/select.tsx +0 -122
  285. package/primitives/separator.tsx +0 -26
  286. package/primitives/sheet.tsx +0 -139
  287. package/primitives/skeleton.tsx +0 -18
  288. package/primitives/slider.tsx +0 -63
  289. package/primitives/sonner.tsx +0 -35
  290. package/primitives/step-indicator.tsx +0 -69
  291. package/primitives/stepper.tsx +0 -272
  292. package/primitives/switch.tsx +0 -27
  293. package/primitives/table.tsx +0 -105
  294. package/primitives/tabs.tsx +0 -50
  295. package/primitives/text-area.tsx +0 -26
  296. package/primitives/text-link.tsx +0 -27
  297. package/primitives/textarea.tsx +0 -64
  298. package/primitives/textfield.tsx +0 -78
  299. package/primitives/toast.tsx +0 -30
  300. package/primitives/toggle-group.tsx +0 -63
  301. package/primitives/toggle.tsx +0 -44
  302. package/primitives/tooltip.tsx +0 -47
  303. package/primitives/video-player.tsx +0 -23
  304. package/src/button.ts +0 -1
  305. package/src/hooks/index.ts +0 -7
  306. package/src/hooks/use-click-away.ts +0 -31
  307. package/src/hooks/use-combined-refs.ts +0 -22
  308. package/src/hooks/use-copy-clipboard.ts +0 -30
  309. package/src/hooks/use-debounce.ts +0 -17
  310. package/src/hooks/use-fill-ids.ts +0 -25
  311. package/src/hooks/use-map.ts +0 -26
  312. package/src/hooks/use-measure.ts +0 -42
  313. package/src/hooks/use-reverse-video-playback.ts +0 -43
  314. package/src/hooks/use-scroll-restoration.ts +0 -50
  315. package/src/index-lean.ts +0 -87
  316. package/src/index.ts +0 -54
  317. package/src/mcp/README.md +0 -141
  318. package/src/mcp/enhanced-server.ts +0 -1208
  319. package/src/mcp/index.ts +0 -518
  320. package/src/mcp/package.json +0 -10
  321. package/src/registry/api.ts +0 -164
  322. package/src/registry/index.ts +0 -60
  323. package/src/registry/package.json +0 -10
  324. package/src/utils.ts +0 -19
  325. package/tailwind/colors.tailwind.js +0 -53
  326. package/tailwind/fontFamily.tailwind.ts +0 -7
  327. package/tailwind/fontSize.tailwind.ts +0 -13
  328. package/tailwind/index.ts +0 -7
  329. package/tailwind/safelist.tailwind.js +0 -26
  330. package/tailwind/screens.tailwind.js +0 -8
  331. package/tailwind/spacing.tailwind.js +0 -65
  332. package/tailwind/tailwind.config.hanzo-preset.d.ts +0 -5
  333. package/tailwind/tailwind.config.hanzo-preset.js +0 -915
  334. package/tailwind/tw-font-desc.ts +0 -15
  335. package/tailwind/typo-plugin/get-plugin-styles.js +0 -679
  336. package/tailwind/typo-plugin/index.d.ts +0 -9
  337. package/tailwind/typo-plugin/index.js +0 -141
  338. package/tailwind/typo-plugin/utils.js +0 -60
  339. package/tailwind/typography-test.mdx +0 -35
  340. package/tailwind/z-index.tailwind.js +0 -71
  341. package/types/animation-def.ts +0 -3
  342. package/types/breakpoints.ts +0 -11
  343. package/types/bullet-item.ts +0 -10
  344. package/types/button-def.ts +0 -39
  345. package/types/dimensions.ts +0 -8
  346. package/types/grid-def.ts +0 -56
  347. package/types/image-def.ts +0 -32
  348. package/types/index.ts +0 -30
  349. package/types/link-def.ts +0 -56
  350. package/types/media-stack-def.ts +0 -31
  351. package/types/t-shirt-size.ts +0 -5
  352. package/types/tshirt-dimensions.ts +0 -20
  353. package/types/video-def.ts +0 -25
  354. package/util/blob.ts +0 -33
  355. package/util/copy-to-clipboard.ts +0 -17
  356. package/util/create-shadow-root.ts +0 -22
  357. package/util/date.ts +0 -84
  358. package/util/debounce.ts +0 -11
  359. package/util/file.ts +0 -15
  360. package/util/format-and-abbreviate-as-currency.ts +0 -125
  361. package/util/format-text.ts +0 -34
  362. package/util/format-to-max-char.ts +0 -68
  363. package/util/index-client.ts +0 -3
  364. package/util/index.ts +0 -112
  365. package/util/number-abbreviate.ts +0 -49
  366. package/util/specifier.ts +0 -43
  367. package/util/spread-to-transform.ts +0 -25
  368. package/util/step-animation.ts +0 -90
  369. package/util/timing.ts +0 -3
  370. package/util/toasts.tsx +0 -17
  371. package/util/two-way-map.ts +0 -19
@@ -1,17 +0,0 @@
1
- export async function copyToClipboard(text: string) {
2
- try {
3
- await navigator.clipboard.writeText(text);
4
- } catch {
5
- // Fallback for browsers where the Clipboard API is not supported
6
- const textarea = document.createElement('textarea');
7
- textarea.style.position = 'fixed';
8
- textarea.style.top = '-9999px';
9
- textarea.style.left = '-9999px';
10
- textarea.innerText = text;
11
- document.body.appendChild(textarea);
12
- textarea.focus();
13
- textarea.select();
14
- document.execCommand('copy');
15
- textarea.remove();
16
- }
17
- }
@@ -1,22 +0,0 @@
1
- import { createRoot } from 'react-dom/client';
2
-
3
- /**
4
- * Creates a shadow root with the specified styles and returns a React root in it.
5
- * @param {string} tagName - Node name to be applied to the shadow root.
6
- * @param {string} styles - CSS styles to be applied to the shadow root.
7
- * @returns {ReactRoot} - React root rendered inside the shadow root.
8
- */
9
-
10
- export function createShadowRoot(tagName: string, styles: string) {
11
- const container = document.createElement(tagName);
12
- const shadow = container.attachShadow({ mode: 'open' });
13
-
14
- // Create a new CSS style sheet and apply the specified styles and apply the style sheet to the shadow root
15
- const globalStyleSheet = new CSSStyleSheet();
16
- globalStyleSheet.replaceSync(styles);
17
- shadow.adoptedStyleSheets = [globalStyleSheet];
18
-
19
- const html = document.querySelector('html') as HTMLHtmlElement;
20
- html.prepend(container);
21
- return createRoot(shadow);
22
- }
package/util/date.ts DELETED
@@ -1,84 +0,0 @@
1
- // import { FormattedMessage } from '@hanzo_network/hanzo-node-state/v2/queries/getChatConversation/types';
2
- type FormattedMessage = any;
3
-
4
- export type ChatConversationMessage = {
5
- hash: string;
6
- parentHash: string;
7
- inboxId: string;
8
- scheduledTime: string | undefined;
9
- content: string;
10
- isLocal: boolean;
11
- sender: {
12
- avatar: string;
13
- };
14
- fileInbox?: {
15
- id: string;
16
- files: {
17
- name: string;
18
- preview?: string;
19
- }[];
20
- };
21
- };
22
- export type GetChatConversationOutput = ChatConversationMessage[];
23
-
24
- export const formatDateToUSLocaleString = (date: Date | undefined) => {
25
- if (!date) return '-';
26
- return new Date(date).toLocaleDateString('en-US', {
27
- year: 'numeric',
28
- month: 'numeric',
29
- day: 'numeric',
30
- });
31
- };
32
- export const formatDateToLocaleStringWithTime = (date: Date | undefined) => {
33
- if (!date) return '-';
34
- return new Date(date).toLocaleDateString('en-US', {
35
- year: 'numeric',
36
- month: 'numeric',
37
- day: 'numeric',
38
- hour: 'numeric',
39
- minute: 'numeric',
40
- });
41
- };
42
-
43
- export const getRelativeDateLabel = (date: Date): string => {
44
- const today = new Date();
45
- const yesterday = new Date();
46
- yesterday.setDate(today.getDate() - 1);
47
- if (date.toDateString() === today.toDateString()) {
48
- return 'today';
49
- } else if (date.toDateString() === yesterday.toDateString()) {
50
- return 'yesterday';
51
- } else {
52
- return date.toDateString();
53
- }
54
- };
55
-
56
- export const groupMessagesByDate = (messages: FormattedMessage[]) => {
57
- const groupedMessages: Record<string, FormattedMessage[]> = {};
58
- for (const message of messages) {
59
- const date = new Date(message.createdAt ?? '').toDateString();
60
- if (!groupedMessages[date]) {
61
- groupedMessages[date] = [];
62
- }
63
- groupedMessages[date].push(message);
64
- }
65
- return groupedMessages;
66
- };
67
-
68
- export const formatDateToMonthAndDay = (date: Date): string => {
69
- const today = new Date();
70
- if (
71
- date.getDate() === today.getDate() &&
72
- date.getMonth() === today.getMonth() &&
73
- date.getFullYear() === today.getFullYear()
74
- ) {
75
- return date.toLocaleTimeString('en-US', {
76
- hour: 'numeric',
77
- minute: 'numeric',
78
- hour12: true,
79
- });
80
- }
81
- const month = date.getMonth() + 1;
82
- const day = date.getDate();
83
- return `${month}/${day}`;
84
- };
package/util/debounce.ts DELETED
@@ -1,11 +0,0 @@
1
- export const debounce = (func: Function, delay: number) => {
2
- let timeoutId: NodeJS.Timeout | null = null;
3
- return (...args: any[]) => {
4
- if (timeoutId) {
5
- clearTimeout(timeoutId);
6
- }
7
- timeoutId = setTimeout(() => {
8
- func(...args);
9
- }, delay);
10
- };
11
- };
package/util/file.ts DELETED
@@ -1,15 +0,0 @@
1
- export const getFileName = (fileName: string): string => {
2
- const nameParts = fileName.split('.');
3
- return nameParts.slice(0, -1).join('.');
4
- };
5
- export const getFileExt = (fileName: string): string => {
6
- const nameParts = fileName.split('.');
7
- return nameParts.pop() || '';
8
- };
9
-
10
- export const isFileTypeImageOrPdf = (file: File): boolean => {
11
- if (!file) return false;
12
- return (
13
- file?.type.startsWith('image/') || file?.type.startsWith('application/pdf')
14
- );
15
- };
@@ -1,125 +0,0 @@
1
- import Abbr, { QuantityAbbrSymbol, ABBR_SYMBOLS_ARRAY } from './number-abbreviate'
2
-
3
- interface FormatThreshold {
4
- from: number
5
- use: QuantityAbbrSymbol
6
- }
7
-
8
- const usdFormatter = Intl.NumberFormat('en-US', {
9
- style: 'currency',
10
- currency: 'USD',
11
- minimumFractionDigits: 2,
12
- })
13
-
14
- const formatAsUSCurrency = (n: number) => {
15
- let result = usdFormatter.format(n)
16
- return result.endsWith('.00') ? result.slice(0, -3) : result
17
- }
18
-
19
- const formatAndAbbreviateAsCurrency = (
20
- n: number | null,
21
- thresholds: FormatThreshold[] = [{
22
- from: 1000000000,
23
- use: 'M'
24
- }],
25
- /**
26
- * Chars that will be added by ui if the number is rounded.
27
- * For example, if the desired output for 10.15 is "~10.1",
28
- * the tilda counts as 1 char.
29
- */
30
- roundingAdds: number = 1,
31
- maxDecimal: number = 2
32
- ): {
33
- full: string
34
- result: string
35
- change: 'rounded' | 'none' | 'abbr' | 'empty'
36
- } => {
37
- if (n === null) {
38
- return {
39
- full: '',
40
- result: '',
41
- change: 'empty'
42
- }
43
- }
44
-
45
- const formatted = formatAsUSCurrency(n)
46
-
47
- if (n < thresholds[0].from) {
48
- return {
49
- full: formatted,
50
- result: formatted,
51
- change: 'none'
52
- }
53
- }
54
-
55
- // Get operative FormatThreshold pair...
56
- let threshold: FormatThreshold
57
- for (
58
- let i = 0;
59
- i < thresholds.length && n >= thresholds[i].from;
60
- threshold = thresholds[i], i++
61
- ) {}
62
-
63
- // Build up units array to all units
64
- // up to threshold.use
65
- const units: QuantityAbbrSymbol[] = []
66
- for (let i = 0; i < ABBR_SYMBOLS_ARRAY.length; i++) {
67
- const current = ABBR_SYMBOLS_ARRAY[i]
68
- units.push(current)
69
- if (current === threshold!.use) {
70
- break
71
- }
72
- }
73
-
74
- const abbreviator = new Abbr(units)
75
-
76
- // Use threshold.from as a guide to how many chars are available:
77
- // first digit + comma = 2
78
- // Possible trailing cents: '.xx'.length = 3
79
- // 3 - 2 = 1
80
- const charsAvail = formatAsUSCurrency(threshold!.from).length + 1
81
- const abbr = abbreviator.abbreviate(n, charsAvail) // arbitrary, but good approx
82
- const numStr = abbr.slice(0, -1)
83
- const abbreviation = abbr.slice(-1)
84
- const numerical = parseFloat(numStr)
85
-
86
- const integral = Math.floor(numerical)
87
- const integralString = formatAsUSCurrency(integral)
88
- const commas = integralString.split(',').length - 1
89
-
90
- // minus abbr, dec point, dollar sign, and roundingAdds / tilda,
91
- // (1 + 1 + 1 + roundingAdds)
92
- // ("precision" does NOT include the decimal point itself,
93
- // so we have to explicitly factor it in.)
94
- const roundedString = numerical.toPrecision(charsAvail - commas - (3 + roundingAdds))
95
- // remove trailing zeros, if any
96
- const roundedNumerical = parseFloat(roundedString)
97
- const roundedIntegral = Math.trunc(roundedNumerical)
98
- const roundedIntegralString = formatAsUSCurrency(roundedIntegral)
99
-
100
- let decimalPortion = roundedNumerical - roundedIntegral
101
- let result
102
- if (decimalPortion !== 0) {
103
- // remove trailing zeros if any
104
- decimalPortion = parseFloat(decimalPortion.toFixed(maxDecimal))
105
- const decimalPortionString = decimalPortion.toString()
106
- const afterDecimalString = decimalPortionString.slice(decimalPortionString.indexOf('.') + 1)
107
- result = roundedIntegralString + '.' + afterDecimalString + abbreviation
108
- }
109
- else {
110
- result = roundedIntegralString + abbreviation
111
- }
112
- // Did we lose any precision?
113
- const rounded = (roundedIntegral + decimalPortion !== n)
114
- return {
115
- full: formatted,
116
- result,
117
- change: rounded ? 'rounded' : 'abbr'
118
- }
119
- }
120
-
121
- export {
122
- formatAndAbbreviateAsCurrency as default,
123
- type FormatThreshold,
124
- type QuantityAbbrSymbol
125
- }
@@ -1,34 +0,0 @@
1
- // import { HanzoToolHeader } from '@hanzo_network/hanzo-message-ts/api/tools/types';
2
- type HanzoToolHeader = any;
3
-
4
- export const formatText = (text: string) => {
5
- const camelToSpaces = text.replace(/([a-z])([A-Z])/g, '$1 $2');
6
- const snakeToSpaces = camelToSpaces.replace(/_/g, ' ');
7
- return snakeToSpaces
8
- .split(' ')
9
- .map((word) => word.charAt(0).toUpperCase() + word.slice(1))
10
- .join(' ');
11
- };
12
-
13
- export const formatCamelCaseText = (text: string) => {
14
- const words = text.split(/(?=[A-Z])/);
15
-
16
- const formattedWords = words.map((word) => {
17
- return word.charAt(0).toUpperCase() + word.slice(1).toLowerCase();
18
- });
19
-
20
- const result = formattedWords.join(' ');
21
-
22
- return result.charAt(0).toUpperCase() + result.slice(1);
23
- };
24
-
25
- export const getVersionFromTool = (toolRouterKey: HanzoToolHeader) => {
26
- if (toolRouterKey.version) {
27
- return toolRouterKey.version;
28
- }
29
- const parts = toolRouterKey.name.split(':::');
30
- if (parts.length === 4) {
31
- return parts[3];
32
- }
33
- return 'latest';
34
- };
@@ -1,68 +0,0 @@
1
- import Abbr from './number-abbreviate'
2
-
3
- const abbr = new Abbr(['K', 'M', 'B', 'T'])
4
-
5
- const formatToMaxChar = (
6
- n: number | null,
7
- maxChars: number,
8
- /**
9
- * Chars that will be added by ui if the number is rounded.
10
- * For example, if the desired output for 10.15 is "~10.1",
11
- * the tilda counts as 1 char.
12
- */
13
- roundingAdds: number = 1
14
- ): {
15
- result: string
16
- change: 'rounded' | 'none' | 'abbr' | 'empty'
17
- } => {
18
- if (n === null) {
19
- return {
20
- result: '',
21
- change: 'empty'
22
- }
23
- }
24
- const s = n.toString()
25
- if (s.length > maxChars) {
26
- // Highest number that can be rounded down to an
27
- // acceptable string.
28
- // Decimal point, plus one decimal place = 2 chars
29
- const cuttoff = Math.pow(10, maxChars - 2 - roundingAdds) - 0.05
30
- if (n < cuttoff) {
31
- const intPortion = Math.floor(n)
32
- const len = intPortion.toString().length
33
- // 1 is for dec point itself
34
- const availDecimals = maxChars - len - 1 - roundingAdds
35
- // removes trailing zeros, if any
36
- const roundedNumerical = parseFloat(n.toFixed(availDecimals))
37
- return {
38
- result: roundedNumerical.toString(),
39
- change: 'rounded'
40
- }
41
- }
42
- else {
43
-
44
- const str = abbr.abbreviate(n, maxChars)
45
- const numStr = str.slice(0, -1)
46
- const abbreviation = str.slice(-1)
47
- const numerical = parseFloat(numStr)
48
-
49
- // minus abbr, dec point, and roundingAdds / tilda,
50
- // (1 + 1 + roundingAdds)
51
- // ("precision" does NOT include the decimal point itself,
52
- // so we have to explicitly factor it in.)
53
- const roundedString = numerical.toPrecision(maxChars - (2 + roundingAdds))
54
- // remove trailing zeros, if any
55
- const roundedNumerical = parseFloat(roundedString)
56
- return {
57
- result: roundedNumerical.toString() + abbreviation,
58
- change: roundedNumerical === numerical ? 'abbr' : 'rounded'
59
- }
60
- }
61
- }
62
- return {
63
- result: s,
64
- change: 'none'
65
- }
66
- }
67
-
68
- export default formatToMaxChar
@@ -1,3 +0,0 @@
1
- export * from './index'
2
- // Must be imported from 'use client'
3
- export * from './step-animation'
package/util/index.ts DELETED
@@ -1,112 +0,0 @@
1
- // Export all utilities
2
- export * from './date';
3
- export * from './file';
4
- export * from './create-shadow-root';
5
- export * from './timing';
6
- export * from './blob';
7
- export * from './copy-to-clipboard';
8
- export * from './format-text';
9
- export * from './toasts';
10
- export * from './debounce';
11
- export { default as spreadToTransform } from './spread-to-transform';
12
- export * from './specifier';
13
- export * from './number-abbreviate';
14
- export * from './format-to-max-char';
15
- export * from './format-and-abbreviate-as-currency';
16
- export * from './two-way-map';
17
-
18
- // Import and re-export cn utility and other common functions
19
- import { type ClassValue, clsx } from 'clsx';
20
- import { twMerge } from 'tailwind-merge';
21
-
22
- export function cn(...inputs: ClassValue[]) {
23
- return twMerge(clsx(inputs));
24
- }
25
-
26
- export function formatDate(input: string | number): string {
27
- const date = new Date(input);
28
- return date.toLocaleDateString('en-US', {
29
- month: 'long',
30
- day: 'numeric',
31
- year: 'numeric',
32
- });
33
- }
34
-
35
- export function absoluteUrl(path: string): string {
36
- if (typeof window !== 'undefined') return path;
37
- if (process.env.VERCEL_URL) return `https://${process.env.VERCEL_URL}${path}`;
38
- return `http://localhost:${process.env.PORT ?? 3000}${path}`;
39
- }
40
-
41
- // Export VariantProps type from class-variance-authority
42
- export type { VariantProps } from 'class-variance-authority';
43
-
44
- // For backward compatibility with components importing from util
45
- export function constrain(value: number, min: number, max: number): number;
46
- export function constrain(dim: { w: number; h: number }, constrainTo: { w: number; h: number }): { w: number; h: number };
47
- export function constrain(
48
- value: number | { w: number; h: number },
49
- minOrConstrainTo: number | { w: number; h: number },
50
- max?: number
51
- ): number | { w: number; h: number } {
52
- if (typeof value === 'number' && typeof minOrConstrainTo === 'number' && typeof max === 'number') {
53
- return Math.min(Math.max(value, minOrConstrainTo), max);
54
- }
55
-
56
- if (typeof value === 'object' && typeof minOrConstrainTo === 'object') {
57
- const dim = value;
58
- const constrainTo = minOrConstrainTo;
59
- const aspectRatio = dim.w / dim.h;
60
- const constrainAspectRatio = constrainTo.w / constrainTo.h;
61
-
62
- if (aspectRatio > constrainAspectRatio) {
63
- // constrain by width
64
- return {
65
- w: constrainTo.w,
66
- h: constrainTo.w / aspectRatio
67
- };
68
- } else {
69
- // constrain by height
70
- return {
71
- w: constrainTo.h * aspectRatio,
72
- h: constrainTo.h
73
- };
74
- }
75
- }
76
-
77
- throw new Error('Invalid parameters for constrain function');
78
- }
79
-
80
- // Export round, pxToRem, pxToEm for tailwind plugin
81
- export function round(value: number): number {
82
- return Math.round(value * 100) / 100;
83
- }
84
-
85
- export function pxToRem(px: number, base = 16): string {
86
- return `${px / base}rem`;
87
- }
88
-
89
- export function pxToEm(px: number, base = 16): string {
90
- return `${px / base}em`;
91
- }
92
-
93
- // Missing utility functions
94
- export function containsToken(text: string, token: string): boolean {
95
- return text.toLowerCase().includes(token.toLowerCase());
96
- }
97
-
98
- export function ldMerge(...objects: any[]): any {
99
- // Simple merge function for lodash compatibility
100
- const result = {};
101
- for (const obj of objects) {
102
- if (obj && typeof obj === 'object') {
103
- Object.assign(result, obj);
104
- }
105
- }
106
- return result;
107
- }
108
-
109
- export function asNum(value: any, defaultValue = 0): number {
110
- const num = Number(value);
111
- return isNaN(num) ? defaultValue : num;
112
- }
@@ -1,49 +0,0 @@
1
- // cf: https://github.com/domharrington/js-number-abbreviate/blob/master/index.js
2
-
3
- type QuantityAbbrSymbol = 'K' | 'M' | 'B' | 'T'
4
- const ABBR_SYMBOLS_ARRAY = ['K', 'M', 'B', 'T'] satisfies QuantityAbbrSymbol[]
5
-
6
- class NumberAbbreviator {
7
-
8
- private _units: QuantityAbbrSymbol[]
9
-
10
- constructor(units?: QuantityAbbrSymbol[]) {
11
- this._units = units ?? ABBR_SYMBOLS_ARRAY
12
- }
13
-
14
- private _abbreviate = (
15
- n: number,
16
- decPlaces: number,
17
- log: boolean = false
18
- ): string => {
19
-
20
- const _decPlaces = Math.pow(10, decPlaces)
21
- let _n = n
22
-
23
- let _unit
24
- for (let i = this._units.length - 1; i >= 0; i--) {
25
- const size = Math.pow(10, (i + 1) * 3)
26
- if (size <= _n) {
27
- _n = Math.round(_n * _decPlaces / size) / _decPlaces
28
- if ((_n === 1000) && (i < this._units.length - 1)) {
29
- _n = 1
30
- i++
31
- }
32
- _unit = this._units[i]
33
- break
34
- }
35
- }
36
- return _n.toString() + (_unit ?? '')
37
- }
38
-
39
- abbreviate = (n: number, decPlaces: number, log: boolean = false) => {
40
- const abbreviatedNumber = this._abbreviate(Math.abs(n), decPlaces, log)
41
- return n < 0 ? '-' + abbreviatedNumber : abbreviatedNumber
42
- }
43
- }
44
-
45
- export {
46
- type QuantityAbbrSymbol,
47
- ABBR_SYMBOLS_ARRAY,
48
- NumberAbbreviator as default
49
- }
package/util/specifier.ts DELETED
@@ -1,43 +0,0 @@
1
- import type { Dimensions, TShirtSize } from '../types'
2
- import type { TypographySize } from '../primitives/apply-typography'
3
-
4
- export const getPrimaryStartingWith = (s: string, toFind: string) => {
5
- const tokenArray = s.split(' ')
6
- return tokenArray.find((tok) => (tok.startsWith(`${toFind}-`)))
7
- }
8
-
9
- export const getTShirtSize = (s: string): TShirtSize | undefined => {
10
- const subTokenArray = s.split('-')
11
- return subTokenArray[subTokenArray.length - 1] as TShirtSize
12
- }
13
-
14
- export const getTypographySize = (s: string): TypographySize | undefined => {
15
- const subTokenArray = s.split('-')
16
- return subTokenArray[subTokenArray.length - 1] as TypographySize
17
- }
18
-
19
- export const getDim = (s: string): Dimensions | undefined => {
20
- const subTokenArray = s.split('-')
21
- const dimStr = subTokenArray[subTokenArray.length - 1]
22
- if (dimStr) {
23
- const dimTokenArray = s.split('x')
24
- return dimTokenArray ? {
25
- w: Number(dimTokenArray[0]),
26
- h: Number(dimTokenArray[1])
27
- } : undefined
28
- }
29
- return undefined
30
- }
31
-
32
- export function getSpecifierData<T>(
33
- main: string,
34
- getPrimary: (s: string) => string | undefined,
35
- getData: (s: string) => T | undefined,
36
- def?: T
37
- ): T | undefined {
38
- const primary = getPrimary(main)
39
- if (primary) {
40
- return getData(primary) ?? def
41
- }
42
- return def ?? undefined
43
- }
@@ -1,25 +0,0 @@
1
- import type { MediaTransform } from '../types'
2
-
3
- export function spreadToTransform(t: MediaTransform) {
4
- let transformStrings: string[] = []
5
- const scaleVal = 'scale' in t ? t.scale : undefined
6
- if (scaleVal) {
7
- if (typeof scaleVal === 'number') {
8
- transformStrings.push(`scale(${scaleVal})`)
9
- }
10
- else if (
11
- Array.isArray(scaleVal) &&
12
- scaleVal.length == 2 &&
13
- typeof scaleVal[0] === 'number'
14
- ) {
15
- transformStrings.push(`scale(${scaleVal[0]}, ${scaleVal[1]})`)
16
- }
17
- else {
18
- throw new Error("parsing MediaTransform: Unrecognized value for 'scale'!")
19
- }
20
- }
21
-
22
- return transformStrings.length > 0 ? { transform: transformStrings.join(' ') } : {}
23
- }
24
-
25
- export default spreadToTransform