@hanzo/ui 4.7.0 → 4.8.2

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 (272) hide show
  1. package/assets/ai-icons.tsx +207 -0
  2. package/assets/crypto.tsx +33 -0
  3. package/assets/file-type-icon.tsx +66 -0
  4. package/assets/file.tsx +45 -0
  5. package/assets/general.tsx +2318 -0
  6. package/assets/hanzo-logo.svg +9 -0
  7. package/assets/hanzo-logo.tsx +17 -0
  8. package/assets/index.ts +122 -0
  9. package/assets/index.tsx +4 -0
  10. package/assets/llm-provider.tsx +1094 -0
  11. package/blocks/auth/index.ts +6 -0
  12. package/blocks/auth/login-2fa.tsx +165 -0
  13. package/blocks/auth/login-basic.tsx +94 -0
  14. package/blocks/auth/login-social.tsx +148 -0
  15. package/blocks/auth/magic-link.tsx +129 -0
  16. package/blocks/auth/password-reset.tsx +97 -0
  17. package/blocks/auth/signup.tsx +157 -0
  18. package/blocks/components/accordian-block.tsx +48 -0
  19. package/blocks/components/block-component-props.ts +11 -0
  20. package/blocks/components/bullet-cards-block.tsx +46 -0
  21. package/blocks/components/card-block/index.tsx +171 -0
  22. package/blocks/components/card-block/link-out-button.tsx +20 -0
  23. package/blocks/components/card-block/util.ts +28 -0
  24. package/blocks/components/carte-blanche-block/index.tsx +127 -0
  25. package/blocks/components/carte-blanche-block/variant-content-left.tsx +49 -0
  26. package/blocks/components/content.tsx +70 -0
  27. package/blocks/components/cta-block.tsx +115 -0
  28. package/blocks/components/enh-heading-block.tsx +204 -0
  29. package/blocks/components/grid-block/grid-block-mutator.ts +12 -0
  30. package/blocks/components/grid-block/index.tsx +83 -0
  31. package/blocks/components/grid-block/mutator-registry.ts +10 -0
  32. package/blocks/components/grid-block/table-borders.mutator.ts +47 -0
  33. package/blocks/components/group-block.tsx +83 -0
  34. package/blocks/components/heading-block.tsx +88 -0
  35. package/blocks/components/image-block.tsx +111 -0
  36. package/blocks/components/index.ts +30 -0
  37. package/blocks/components/screenful-block/content.tsx +123 -0
  38. package/blocks/components/screenful-block/index.tsx +107 -0
  39. package/blocks/components/screenful-block/poster-background.tsx +34 -0
  40. package/blocks/components/screenful-block/video-background.tsx +45 -0
  41. package/blocks/components/space-block.tsx +66 -0
  42. package/blocks/components/video-block.tsx +138 -0
  43. package/blocks/data-display/activity-feed.tsx +242 -0
  44. package/blocks/data-display/data-table.tsx +235 -0
  45. package/blocks/data-display/stats-grid.tsx +194 -0
  46. package/blocks/def/accordian-block.ts +14 -0
  47. package/blocks/def/block.ts +7 -0
  48. package/blocks/def/bullet-cards-block.ts +22 -0
  49. package/blocks/def/card-block.ts +22 -0
  50. package/blocks/def/carte-blanche-block.ts +21 -0
  51. package/blocks/def/cta-block.ts +19 -0
  52. package/blocks/def/element-block.ts +11 -0
  53. package/blocks/def/enh-heading-block.ts +44 -0
  54. package/blocks/def/grid-block.ts +16 -0
  55. package/blocks/def/group-block.ts +11 -0
  56. package/blocks/def/heading-block.ts +15 -0
  57. package/blocks/def/image-block.ts +31 -0
  58. package/blocks/def/index.ts +35 -0
  59. package/blocks/def/screenful-block.ts +54 -0
  60. package/blocks/def/space-block.ts +64 -0
  61. package/blocks/def/video-block.ts +9 -0
  62. package/blocks/ecommerce/checkout.tsx +242 -0
  63. package/blocks/ecommerce/index.ts +7 -0
  64. package/blocks/ecommerce/product-detail.tsx +257 -0
  65. package/blocks/ecommerce/product-grid.tsx +148 -0
  66. package/blocks/ecommerce/shopping-cart.tsx +181 -0
  67. package/blocks/index.ts +2 -0
  68. package/blocks/marketing/cta-section.tsx +207 -0
  69. package/blocks/marketing/faq.tsx +159 -0
  70. package/blocks/marketing/features-grid.tsx +156 -0
  71. package/blocks/marketing/hero-section.tsx +192 -0
  72. package/blocks/marketing/index.ts +6 -0
  73. package/blocks/marketing/pricing-table.tsx +121 -0
  74. package/blocks/marketing/testimonials.tsx +196 -0
  75. package/components/index.ts +9 -0
  76. package/dist/index.js +1407 -1514
  77. package/dist/index.mjs +1363 -1472
  78. package/dist/tailwind/index.js +3 -1
  79. package/dist/tailwind/index.mjs +3 -1
  80. package/dist/util/format-text.js +51 -0
  81. package/dist/util/format-text.mjs +32 -0
  82. package/dist/util/index.js +384 -0
  83. package/dist/util/index.mjs +363 -0
  84. package/frameworks/core/index.ts +6 -0
  85. package/frameworks/core/utils/index.ts +64 -0
  86. package/frameworks/react/components/button.tsx +26 -0
  87. package/frameworks/react/components/index.ts +5 -0
  88. package/frameworks/react/hooks/index.ts +5 -0
  89. package/frameworks/react/index.ts +9 -0
  90. package/frameworks/react/package.json +8 -0
  91. package/frameworks/react/utils/index.ts +2 -0
  92. package/frameworks/react-native/index.ts +9 -0
  93. package/frameworks/react-native/package.json +8 -0
  94. package/frameworks/registry.json +371 -0
  95. package/frameworks/setup.sh +69 -0
  96. package/frameworks/svelte/index.ts +9 -0
  97. package/frameworks/svelte/package.json +8 -0
  98. package/frameworks/tracker.json +1854 -0
  99. package/frameworks/vue/index.ts +9 -0
  100. package/frameworks/vue/package.json +8 -0
  101. package/helpers/file.ts +33 -0
  102. package/helpers/memoization.ts +40 -0
  103. package/package.json +49 -11
  104. package/primitives/accordion.tsx +74 -0
  105. package/primitives/action-button.tsx +42 -0
  106. package/primitives/alert-dialog.tsx +185 -0
  107. package/primitives/alert.tsx +74 -0
  108. package/primitives/apply-typography.tsx +55 -0
  109. package/primitives/aspect-ratio.tsx +5 -0
  110. package/primitives/avatar.tsx +57 -0
  111. package/primitives/background-beams.tsx +142 -0
  112. package/primitives/badge.tsx +45 -0
  113. package/primitives/breadcrumb.tsx +130 -0
  114. package/primitives/breakpoint-indicator.tsx +19 -0
  115. package/primitives/button.tsx +72 -0
  116. package/primitives/calendar.tsx +72 -0
  117. package/primitives/card.tsx +97 -0
  118. package/primitives/carousel.tsx +238 -0
  119. package/primitives/chat/chat-input-area.tsx +88 -0
  120. package/primitives/chat/chat-input.tsx +71 -0
  121. package/primitives/chat/files-preview.tsx +331 -0
  122. package/primitives/chat/index.ts +6 -0
  123. package/primitives/chat/json-form.tsx +8 -0
  124. package/primitives/chat/message-list.tsx +308 -0
  125. package/primitives/chat/message.tsx +569 -0
  126. package/primitives/chat/sqlite-preview.tsx +215 -0
  127. package/primitives/checkbox.tsx +32 -0
  128. package/primitives/collapsible.tsx +9 -0
  129. package/primitives/combobox.tsx +239 -0
  130. package/primitives/command.tsx +151 -0
  131. package/primitives/context-menu.tsx +206 -0
  132. package/primitives/copy-to-clipboard-icon.tsx +60 -0
  133. package/primitives/dialog-video-controller.tsx +38 -0
  134. package/primitives/dialog.tsx +128 -0
  135. package/primitives/dot-pattern.tsx +57 -0
  136. package/primitives/dots-loader.tsx +13 -0
  137. package/primitives/drawer.tsx +113 -0
  138. package/primitives/dropdown-menu.tsx +199 -0
  139. package/primitives/error-message.tsx +19 -0
  140. package/primitives/file-uploader.tsx +202 -0
  141. package/primitives/form.tsx +183 -0
  142. package/primitives/hover-card.tsx +28 -0
  143. package/primitives/icons/github.tsx +14 -0
  144. package/primitives/icons/index.ts +18 -0
  145. package/primitives/icons/youtube-logo.tsx +59 -0
  146. package/primitives/index-common.ts +304 -0
  147. package/primitives/index-next.ts +4 -0
  148. package/primitives/input-otp.tsx +65 -0
  149. package/primitives/input.tsx +126 -0
  150. package/primitives/label.tsx +21 -0
  151. package/primitives/list-adaptor.ts +12 -0
  152. package/primitives/list-box.tsx +74 -0
  153. package/primitives/loading-spinner.tsx +33 -0
  154. package/primitives/markdown-preview.tsx +612 -0
  155. package/primitives/mermaid.tsx +191 -0
  156. package/primitives/navigation-menu.tsx +147 -0
  157. package/primitives/next/image.tsx +91 -0
  158. package/primitives/next/index.ts +7 -0
  159. package/primitives/next/inline-icon.tsx +36 -0
  160. package/primitives/next/link-element.tsx +109 -0
  161. package/primitives/next/mdx-link.tsx +22 -0
  162. package/primitives/next/media-stack.tsx +52 -0
  163. package/primitives/next/nav-items.tsx +45 -0
  164. package/primitives/next/youtube-embed.tsx +83 -0
  165. package/primitives/pagination.tsx +117 -0
  166. package/primitives/popover.tsx +34 -0
  167. package/primitives/pretty-json-print.tsx +28 -0
  168. package/primitives/progress.tsx +27 -0
  169. package/primitives/prompt-textarea.tsx +72 -0
  170. package/primitives/qr-code.tsx +112 -0
  171. package/primitives/radio-group.tsx +42 -0
  172. package/primitives/resizable.tsx +47 -0
  173. package/primitives/scroll-area.tsx +57 -0
  174. package/primitives/search-input.tsx +66 -0
  175. package/primitives/select.tsx +122 -0
  176. package/primitives/separator.tsx +26 -0
  177. package/primitives/sheet.tsx +139 -0
  178. package/primitives/skeleton.tsx +18 -0
  179. package/primitives/slider.tsx +63 -0
  180. package/primitives/sonner.tsx +35 -0
  181. package/primitives/step-indicator.tsx +69 -0
  182. package/primitives/stepper.tsx +272 -0
  183. package/primitives/switch.tsx +27 -0
  184. package/primitives/table.tsx +105 -0
  185. package/primitives/tabs.tsx +50 -0
  186. package/primitives/text-area.tsx +26 -0
  187. package/primitives/text-link.tsx +25 -0
  188. package/primitives/textarea.tsx +62 -0
  189. package/primitives/textfield.tsx +76 -0
  190. package/primitives/toast.tsx +30 -0
  191. package/primitives/toggle-group.tsx +63 -0
  192. package/primitives/toggle.tsx +44 -0
  193. package/primitives/tooltip.tsx +47 -0
  194. package/primitives/video-player.tsx +23 -0
  195. package/src/button.ts +1 -0
  196. package/src/hooks/index.ts +7 -0
  197. package/src/hooks/use-click-away.ts +31 -0
  198. package/src/hooks/use-combined-refs.ts +22 -0
  199. package/src/hooks/use-copy-clipboard.ts +30 -0
  200. package/src/hooks/use-debounce.ts +17 -0
  201. package/src/hooks/use-fill-ids.ts +25 -0
  202. package/src/hooks/use-map.ts +26 -0
  203. package/src/hooks/use-measure.ts +42 -0
  204. package/src/hooks/use-reverse-video-playback.ts +43 -0
  205. package/src/hooks/use-scroll-restoration.ts +50 -0
  206. package/src/index-lean.ts +87 -0
  207. package/src/index.ts +54 -0
  208. package/src/mcp/README.md +141 -0
  209. package/src/mcp/enhanced-server.ts +1208 -0
  210. package/src/mcp/index.ts +518 -0
  211. package/src/mcp/package.json +10 -0
  212. package/src/registry/api.ts +164 -0
  213. package/src/registry/index.ts +60 -0
  214. package/src/registry/package.json +10 -0
  215. package/src/utils.ts +19 -0
  216. package/tailwind/colors.tailwind.js +53 -0
  217. package/tailwind/fontFamily.tailwind.ts +7 -0
  218. package/tailwind/fontSize.tailwind.ts +13 -0
  219. package/tailwind/index.ts +7 -0
  220. package/tailwind/safelist.tailwind.js +26 -0
  221. package/tailwind/screens.tailwind.js +8 -0
  222. package/tailwind/spacing.tailwind.js +65 -0
  223. package/tailwind/tailwind.config.hanzo-preset.d.ts +5 -0
  224. package/tailwind/tailwind.config.hanzo-preset.js +915 -0
  225. package/tailwind/tw-font-desc.ts +15 -0
  226. package/tailwind/typo-plugin/get-plugin-styles.js +679 -0
  227. package/tailwind/typo-plugin/index.d.ts +9 -0
  228. package/tailwind/typo-plugin/index.js +141 -0
  229. package/tailwind/typo-plugin/utils.js +60 -0
  230. package/tailwind/typography-test.mdx +35 -0
  231. package/tailwind/z-index.tailwind.js +71 -0
  232. package/types/animation-def.ts +3 -0
  233. package/types/breakpoints.ts +11 -0
  234. package/types/bullet-item.ts +10 -0
  235. package/types/button-def.ts +39 -0
  236. package/types/dimensions.ts +8 -0
  237. package/types/grid-def.ts +56 -0
  238. package/types/image-def.ts +32 -0
  239. package/types/index.ts +30 -0
  240. package/types/link-def.ts +56 -0
  241. package/types/media-stack-def.ts +31 -0
  242. package/types/t-shirt-size.ts +5 -0
  243. package/types/tshirt-dimensions.ts +20 -0
  244. package/types/video-def.ts +25 -0
  245. package/util/blob.ts +33 -0
  246. package/util/copy-to-clipboard.ts +17 -0
  247. package/util/create-shadow-root.ts +22 -0
  248. package/util/date.ts +84 -0
  249. package/util/debounce.ts +11 -0
  250. package/util/file.ts +15 -0
  251. package/util/format-and-abbreviate-as-currency.ts +125 -0
  252. package/util/format-text.ts +34 -0
  253. package/util/format-to-max-char.ts +68 -0
  254. package/util/index-client.ts +3 -0
  255. package/util/index.ts +112 -0
  256. package/util/number-abbreviate.ts +49 -0
  257. package/util/specifier.ts +43 -0
  258. package/util/spread-to-transform.ts +25 -0
  259. package/util/step-animation.ts +90 -0
  260. package/util/timing.ts +3 -0
  261. package/util/toasts.tsx +17 -0
  262. package/util/two-way-map.ts +19 -0
  263. package/dist/index.d.mts +0 -16
  264. package/dist/index.d.ts +0 -16
  265. package/dist/lib/utils.d.mts +0 -2
  266. package/dist/lib/utils.d.ts +0 -2
  267. package/dist/src/utils.d.mts +0 -7
  268. package/dist/src/utils.d.ts +0 -7
  269. package/dist/tailwind/index.d.mts +0 -2
  270. package/dist/tailwind/index.d.ts +0 -2
  271. package/dist/types/index.d.mts +0 -12
  272. package/dist/types/index.d.ts +0 -12
@@ -305,11 +305,13 @@ for (let i = 0; i <= 50; i++) {
305
305
  var z_index_tailwind_default = zIndex;
306
306
 
307
307
  // tailwind/typo-plugin/index.js
308
- var import_plugin = __toESM(require("tailwindcss/plugin"));
308
+ var import_plugin = __toESM(require("tailwindcss/plugin.js"));
309
309
  var import_lodash2 = __toESM(require("lodash.merge"));
310
310
  var import_lodash3 = __toESM(require("lodash.castarray"));
311
311
 
312
312
  // util/index.ts
313
+ var import_clsx = require("clsx");
314
+ var import_tailwind_merge = require("tailwind-merge");
313
315
  function round(value) {
314
316
  return Math.round(value * 100) / 100;
315
317
  }
@@ -271,11 +271,13 @@ for (let i = 0; i <= 50; i++) {
271
271
  var z_index_tailwind_default = zIndex;
272
272
 
273
273
  // tailwind/typo-plugin/index.js
274
- import plugin from "tailwindcss/plugin";
274
+ import plugin from "tailwindcss/plugin.js";
275
275
  import merge from "lodash.merge";
276
276
  import castArray from "lodash.castarray";
277
277
 
278
278
  // util/index.ts
279
+ import { clsx } from "clsx";
280
+ import { twMerge } from "tailwind-merge";
279
281
  function round(value) {
280
282
  return Math.round(value * 100) / 100;
281
283
  }
@@ -0,0 +1,51 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
20
+
21
+ // util/format-text.ts
22
+ var format_text_exports = {};
23
+ __export(format_text_exports, {
24
+ formatCamelCaseText: () => formatCamelCaseText,
25
+ formatText: () => formatText,
26
+ getVersionFromTool: () => getVersionFromTool
27
+ });
28
+ module.exports = __toCommonJS(format_text_exports);
29
+ var formatText = /* @__PURE__ */ __name((text) => {
30
+ const camelToSpaces = text.replace(/([a-z])([A-Z])/g, "$1 $2");
31
+ const snakeToSpaces = camelToSpaces.replace(/_/g, " ");
32
+ return snakeToSpaces.split(" ").map((word) => word.charAt(0).toUpperCase() + word.slice(1)).join(" ");
33
+ }, "formatText");
34
+ var formatCamelCaseText = /* @__PURE__ */ __name((text) => {
35
+ const words = text.split(/(?=[A-Z])/);
36
+ const formattedWords = words.map((word) => {
37
+ return word.charAt(0).toUpperCase() + word.slice(1).toLowerCase();
38
+ });
39
+ const result = formattedWords.join(" ");
40
+ return result.charAt(0).toUpperCase() + result.slice(1);
41
+ }, "formatCamelCaseText");
42
+ var getVersionFromTool = /* @__PURE__ */ __name((toolRouterKey) => {
43
+ if (toolRouterKey.version) {
44
+ return toolRouterKey.version;
45
+ }
46
+ const parts = toolRouterKey.name.split(":::");
47
+ if (parts.length === 4) {
48
+ return parts[3];
49
+ }
50
+ return "latest";
51
+ }, "getVersionFromTool");
@@ -0,0 +1,32 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
+
4
+ // util/format-text.ts
5
+ var formatText = /* @__PURE__ */ __name((text) => {
6
+ const camelToSpaces = text.replace(/([a-z])([A-Z])/g, "$1 $2");
7
+ const snakeToSpaces = camelToSpaces.replace(/_/g, " ");
8
+ return snakeToSpaces.split(" ").map((word) => word.charAt(0).toUpperCase() + word.slice(1)).join(" ");
9
+ }, "formatText");
10
+ var formatCamelCaseText = /* @__PURE__ */ __name((text) => {
11
+ const words = text.split(/(?=[A-Z])/);
12
+ const formattedWords = words.map((word) => {
13
+ return word.charAt(0).toUpperCase() + word.slice(1).toLowerCase();
14
+ });
15
+ const result = formattedWords.join(" ");
16
+ return result.charAt(0).toUpperCase() + result.slice(1);
17
+ }, "formatCamelCaseText");
18
+ var getVersionFromTool = /* @__PURE__ */ __name((toolRouterKey) => {
19
+ if (toolRouterKey.version) {
20
+ return toolRouterKey.version;
21
+ }
22
+ const parts = toolRouterKey.name.split(":::");
23
+ if (parts.length === 4) {
24
+ return parts[3];
25
+ }
26
+ return "latest";
27
+ }, "getVersionFromTool");
28
+ export {
29
+ formatCamelCaseText,
30
+ formatText,
31
+ getVersionFromTool
32
+ };
@@ -0,0 +1,384 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
20
+
21
+ // util/index.ts
22
+ var util_exports = {};
23
+ __export(util_exports, {
24
+ ABBR_SYMBOLS_ARRAY: () => ABBR_SYMBOLS_ARRAY,
25
+ absoluteUrl: () => absoluteUrl,
26
+ asNum: () => asNum,
27
+ blobToBase64: () => blobToBase64,
28
+ cn: () => cn,
29
+ constrain: () => constrain,
30
+ containsToken: () => containsToken,
31
+ copyToClipboard: () => copyToClipboard,
32
+ createShadowRoot: () => createShadowRoot,
33
+ dataUrlToFile: () => dataUrlToFile,
34
+ debounce: () => debounce,
35
+ delay: () => delay,
36
+ formatCamelCaseText: () => formatCamelCaseText,
37
+ formatDate: () => formatDate,
38
+ formatDateToLocaleStringWithTime: () => formatDateToLocaleStringWithTime,
39
+ formatDateToMonthAndDay: () => formatDateToMonthAndDay,
40
+ formatDateToUSLocaleString: () => formatDateToUSLocaleString,
41
+ formatText: () => formatText,
42
+ getDim: () => getDim,
43
+ getFileExt: () => getFileExt,
44
+ getFileName: () => getFileName,
45
+ getPrimaryStartingWith: () => getPrimaryStartingWith,
46
+ getRelativeDateLabel: () => getRelativeDateLabel,
47
+ getSpecifierData: () => getSpecifierData,
48
+ getTShirtSize: () => getTShirtSize,
49
+ getTypographySize: () => getTypographySize,
50
+ getVersionFromTool: () => getVersionFromTool,
51
+ groupMessagesByDate: () => groupMessagesByDate,
52
+ isFileTypeImageOrPdf: () => isFileTypeImageOrPdf,
53
+ ldMerge: () => ldMerge,
54
+ pxToEm: () => pxToEm,
55
+ pxToRem: () => pxToRem,
56
+ round: () => round,
57
+ spreadToTransform: () => spread_to_transform_default,
58
+ submitRegistrationNoCodeError: () => submitRegistrationNoCodeError,
59
+ submitRegistrationNoCodeNonPristineError: () => submitRegistrationNoCodeNonPristineError
60
+ });
61
+ module.exports = __toCommonJS(util_exports);
62
+
63
+ // util/date.ts
64
+ var formatDateToUSLocaleString = /* @__PURE__ */ __name((date) => {
65
+ if (!date) return "-";
66
+ return new Date(date).toLocaleDateString("en-US", {
67
+ year: "numeric",
68
+ month: "numeric",
69
+ day: "numeric"
70
+ });
71
+ }, "formatDateToUSLocaleString");
72
+ var formatDateToLocaleStringWithTime = /* @__PURE__ */ __name((date) => {
73
+ if (!date) return "-";
74
+ return new Date(date).toLocaleDateString("en-US", {
75
+ year: "numeric",
76
+ month: "numeric",
77
+ day: "numeric",
78
+ hour: "numeric",
79
+ minute: "numeric"
80
+ });
81
+ }, "formatDateToLocaleStringWithTime");
82
+ var getRelativeDateLabel = /* @__PURE__ */ __name((date) => {
83
+ const today = /* @__PURE__ */ new Date();
84
+ const yesterday = /* @__PURE__ */ new Date();
85
+ yesterday.setDate(today.getDate() - 1);
86
+ if (date.toDateString() === today.toDateString()) {
87
+ return "today";
88
+ } else if (date.toDateString() === yesterday.toDateString()) {
89
+ return "yesterday";
90
+ } else {
91
+ return date.toDateString();
92
+ }
93
+ }, "getRelativeDateLabel");
94
+ var groupMessagesByDate = /* @__PURE__ */ __name((messages) => {
95
+ const groupedMessages = {};
96
+ for (const message of messages) {
97
+ const date = new Date(message.createdAt ?? "").toDateString();
98
+ if (!groupedMessages[date]) {
99
+ groupedMessages[date] = [];
100
+ }
101
+ groupedMessages[date].push(message);
102
+ }
103
+ return groupedMessages;
104
+ }, "groupMessagesByDate");
105
+ var formatDateToMonthAndDay = /* @__PURE__ */ __name((date) => {
106
+ const today = /* @__PURE__ */ new Date();
107
+ if (date.getDate() === today.getDate() && date.getMonth() === today.getMonth() && date.getFullYear() === today.getFullYear()) {
108
+ return date.toLocaleTimeString("en-US", {
109
+ hour: "numeric",
110
+ minute: "numeric",
111
+ hour12: true
112
+ });
113
+ }
114
+ const month = date.getMonth() + 1;
115
+ const day = date.getDate();
116
+ return `${month}/${day}`;
117
+ }, "formatDateToMonthAndDay");
118
+
119
+ // util/file.ts
120
+ var getFileName = /* @__PURE__ */ __name((fileName) => {
121
+ const nameParts = fileName.split(".");
122
+ return nameParts.slice(0, -1).join(".");
123
+ }, "getFileName");
124
+ var getFileExt = /* @__PURE__ */ __name((fileName) => {
125
+ const nameParts = fileName.split(".");
126
+ return nameParts.pop() || "";
127
+ }, "getFileExt");
128
+ var isFileTypeImageOrPdf = /* @__PURE__ */ __name((file) => {
129
+ if (!file) return false;
130
+ return file?.type.startsWith("image/") || file?.type.startsWith("application/pdf");
131
+ }, "isFileTypeImageOrPdf");
132
+
133
+ // util/create-shadow-root.ts
134
+ var import_client = require("react-dom/client");
135
+ function createShadowRoot(tagName, styles) {
136
+ const container = document.createElement(tagName);
137
+ const shadow = container.attachShadow({ mode: "open" });
138
+ const globalStyleSheet = new CSSStyleSheet();
139
+ globalStyleSheet.replaceSync(styles);
140
+ shadow.adoptedStyleSheets = [globalStyleSheet];
141
+ const html = document.querySelector("html");
142
+ html.prepend(container);
143
+ return (0, import_client.createRoot)(shadow);
144
+ }
145
+ __name(createShadowRoot, "createShadowRoot");
146
+
147
+ // util/timing.ts
148
+ function delay(e = 1e3) {
149
+ return new Promise((t) => setTimeout(t, e));
150
+ }
151
+ __name(delay, "delay");
152
+
153
+ // util/blob.ts
154
+ var blobToBase64 = /* @__PURE__ */ __name((blob) => {
155
+ const reader = new FileReader();
156
+ reader.readAsDataURL(blob);
157
+ return new Promise((resolve) => {
158
+ reader.onloadend = () => {
159
+ resolve(reader.result);
160
+ };
161
+ });
162
+ }, "blobToBase64");
163
+ var dataUrlToFile = /* @__PURE__ */ __name((dataUrl, filename) => {
164
+ const arr = dataUrl.split(",");
165
+ if (arr.length < 2) {
166
+ return void 0;
167
+ }
168
+ const mimeArr = arr[0].match(/:(.*?);/);
169
+ if (!mimeArr || mimeArr.length < 2) {
170
+ return void 0;
171
+ }
172
+ const mime = mimeArr[1];
173
+ const binaryString = atob(arr[1]);
174
+ const bytes = new Uint8Array(binaryString.length);
175
+ for (let i = 0; i < binaryString.length; i++) {
176
+ bytes[i] = binaryString.charCodeAt(i);
177
+ }
178
+ return new File([bytes], filename, { type: mime });
179
+ }, "dataUrlToFile");
180
+
181
+ // util/copy-to-clipboard.ts
182
+ async function copyToClipboard(text) {
183
+ try {
184
+ await navigator.clipboard.writeText(text);
185
+ } catch {
186
+ const textarea = document.createElement("textarea");
187
+ textarea.style.position = "fixed";
188
+ textarea.style.top = "-9999px";
189
+ textarea.style.left = "-9999px";
190
+ textarea.innerText = text;
191
+ document.body.appendChild(textarea);
192
+ textarea.focus();
193
+ textarea.select();
194
+ document.execCommand("copy");
195
+ textarea.remove();
196
+ }
197
+ }
198
+ __name(copyToClipboard, "copyToClipboard");
199
+
200
+ // util/format-text.ts
201
+ var formatText = /* @__PURE__ */ __name((text) => {
202
+ const camelToSpaces = text.replace(/([a-z])([A-Z])/g, "$1 $2");
203
+ const snakeToSpaces = camelToSpaces.replace(/_/g, " ");
204
+ return snakeToSpaces.split(" ").map((word) => word.charAt(0).toUpperCase() + word.slice(1)).join(" ");
205
+ }, "formatText");
206
+ var formatCamelCaseText = /* @__PURE__ */ __name((text) => {
207
+ const words = text.split(/(?=[A-Z])/);
208
+ const formattedWords = words.map((word) => {
209
+ return word.charAt(0).toUpperCase() + word.slice(1).toLowerCase();
210
+ });
211
+ const result = formattedWords.join(" ");
212
+ return result.charAt(0).toUpperCase() + result.slice(1);
213
+ }, "formatCamelCaseText");
214
+ var getVersionFromTool = /* @__PURE__ */ __name((toolRouterKey) => {
215
+ if (toolRouterKey.version) {
216
+ return toolRouterKey.version;
217
+ }
218
+ const parts = toolRouterKey.name.split(":::");
219
+ if (parts.length === 4) {
220
+ return parts[3];
221
+ }
222
+ return "latest";
223
+ }, "getVersionFromTool");
224
+
225
+ // util/toasts.tsx
226
+ var import_sonner = require("sonner");
227
+ var import_jsx_runtime = require("react/jsx-runtime");
228
+ var submitRegistrationNoCodeNonPristineError = /* @__PURE__ */ __name(() => {
229
+ return import_sonner.toast.error(
230
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { children: "Your Hanzo Node is currently locked by existing keys, please restore your connection or reset your Hanzo Node Storage" }),
231
+ { position: "bottom-center" }
232
+ );
233
+ }, "submitRegistrationNoCodeNonPristineError");
234
+ var submitRegistrationNoCodeError = /* @__PURE__ */ __name(() => {
235
+ return import_sonner.toast.error(/* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { children: "Error connecting to your Hanzo Node" }), {
236
+ position: "bottom-center"
237
+ });
238
+ }, "submitRegistrationNoCodeError");
239
+
240
+ // util/debounce.ts
241
+ var debounce = /* @__PURE__ */ __name((func, delay2) => {
242
+ let timeoutId = null;
243
+ return (...args) => {
244
+ if (timeoutId) {
245
+ clearTimeout(timeoutId);
246
+ }
247
+ timeoutId = setTimeout(() => {
248
+ func(...args);
249
+ }, delay2);
250
+ };
251
+ }, "debounce");
252
+
253
+ // util/spread-to-transform.ts
254
+ function spreadToTransform(t) {
255
+ let transformStrings = [];
256
+ const scaleVal = "scale" in t ? t.scale : void 0;
257
+ if (scaleVal) {
258
+ if (typeof scaleVal === "number") {
259
+ transformStrings.push(`scale(${scaleVal})`);
260
+ } else if (Array.isArray(scaleVal) && scaleVal.length == 2 && typeof scaleVal[0] === "number") {
261
+ transformStrings.push(`scale(${scaleVal[0]}, ${scaleVal[1]})`);
262
+ } else {
263
+ throw new Error("parsing MediaTransform: Unrecognized value for 'scale'!");
264
+ }
265
+ }
266
+ return transformStrings.length > 0 ? { transform: transformStrings.join(" ") } : {};
267
+ }
268
+ __name(spreadToTransform, "spreadToTransform");
269
+ var spread_to_transform_default = spreadToTransform;
270
+
271
+ // util/specifier.ts
272
+ var getPrimaryStartingWith = /* @__PURE__ */ __name((s, toFind) => {
273
+ const tokenArray = s.split(" ");
274
+ return tokenArray.find((tok) => tok.startsWith(`${toFind}-`));
275
+ }, "getPrimaryStartingWith");
276
+ var getTShirtSize = /* @__PURE__ */ __name((s) => {
277
+ const subTokenArray = s.split("-");
278
+ return subTokenArray[subTokenArray.length - 1];
279
+ }, "getTShirtSize");
280
+ var getTypographySize = /* @__PURE__ */ __name((s) => {
281
+ const subTokenArray = s.split("-");
282
+ return subTokenArray[subTokenArray.length - 1];
283
+ }, "getTypographySize");
284
+ var getDim = /* @__PURE__ */ __name((s) => {
285
+ const subTokenArray = s.split("-");
286
+ const dimStr = subTokenArray[subTokenArray.length - 1];
287
+ if (dimStr) {
288
+ const dimTokenArray = s.split("x");
289
+ return dimTokenArray ? {
290
+ w: Number(dimTokenArray[0]),
291
+ h: Number(dimTokenArray[1])
292
+ } : void 0;
293
+ }
294
+ return void 0;
295
+ }, "getDim");
296
+ function getSpecifierData(main, getPrimary, getData, def) {
297
+ const primary = getPrimary(main);
298
+ if (primary) {
299
+ return getData(primary) ?? def;
300
+ }
301
+ return def ?? void 0;
302
+ }
303
+ __name(getSpecifierData, "getSpecifierData");
304
+
305
+ // util/number-abbreviate.ts
306
+ var ABBR_SYMBOLS_ARRAY = ["K", "M", "B", "T"];
307
+
308
+ // util/index.ts
309
+ var import_clsx = require("clsx");
310
+ var import_tailwind_merge = require("tailwind-merge");
311
+ function cn(...inputs) {
312
+ return (0, import_tailwind_merge.twMerge)((0, import_clsx.clsx)(inputs));
313
+ }
314
+ __name(cn, "cn");
315
+ function formatDate(input) {
316
+ const date = new Date(input);
317
+ return date.toLocaleDateString("en-US", {
318
+ month: "long",
319
+ day: "numeric",
320
+ year: "numeric"
321
+ });
322
+ }
323
+ __name(formatDate, "formatDate");
324
+ function absoluteUrl(path) {
325
+ if (typeof window !== "undefined") return path;
326
+ if (process.env.VERCEL_URL) return `https://${process.env.VERCEL_URL}${path}`;
327
+ return `http://localhost:${process.env.PORT ?? 3e3}${path}`;
328
+ }
329
+ __name(absoluteUrl, "absoluteUrl");
330
+ function constrain(value, minOrConstrainTo, max) {
331
+ if (typeof value === "number" && typeof minOrConstrainTo === "number" && typeof max === "number") {
332
+ return Math.min(Math.max(value, minOrConstrainTo), max);
333
+ }
334
+ if (typeof value === "object" && typeof minOrConstrainTo === "object") {
335
+ const dim = value;
336
+ const constrainTo = minOrConstrainTo;
337
+ const aspectRatio = dim.w / dim.h;
338
+ const constrainAspectRatio = constrainTo.w / constrainTo.h;
339
+ if (aspectRatio > constrainAspectRatio) {
340
+ return {
341
+ w: constrainTo.w,
342
+ h: constrainTo.w / aspectRatio
343
+ };
344
+ } else {
345
+ return {
346
+ w: constrainTo.h * aspectRatio,
347
+ h: constrainTo.h
348
+ };
349
+ }
350
+ }
351
+ throw new Error("Invalid parameters for constrain function");
352
+ }
353
+ __name(constrain, "constrain");
354
+ function round(value) {
355
+ return Math.round(value * 100) / 100;
356
+ }
357
+ __name(round, "round");
358
+ function pxToRem(px, base = 16) {
359
+ return `${px / base}rem`;
360
+ }
361
+ __name(pxToRem, "pxToRem");
362
+ function pxToEm(px, base = 16) {
363
+ return `${px / base}em`;
364
+ }
365
+ __name(pxToEm, "pxToEm");
366
+ function containsToken(text, token) {
367
+ return text.toLowerCase().includes(token.toLowerCase());
368
+ }
369
+ __name(containsToken, "containsToken");
370
+ function ldMerge(...objects) {
371
+ const result = {};
372
+ for (const obj of objects) {
373
+ if (obj && typeof obj === "object") {
374
+ Object.assign(result, obj);
375
+ }
376
+ }
377
+ return result;
378
+ }
379
+ __name(ldMerge, "ldMerge");
380
+ function asNum(value, defaultValue = 0) {
381
+ const num = Number(value);
382
+ return isNaN(num) ? defaultValue : num;
383
+ }
384
+ __name(asNum, "asNum");