@hanzo/ui 5.3.25 → 5.3.28
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.
- package/content/index.ts +26 -0
- package/docs/_registry/index.ts +426 -0
- package/docs/_registry/layout/docs-min.tsx +197 -0
- package/docs/_registry/layout/page-min.tsx +128 -0
- package/docs/components/accordion.tsx +118 -0
- package/docs/components/banner.tsx +144 -0
- package/docs/components/callout.tsx +112 -0
- package/docs/components/card.tsx +52 -0
- package/docs/components/codeblock.tsx +258 -0
- package/docs/components/dialog/search-algolia.tsx +132 -0
- package/docs/components/dialog/search-default.tsx +131 -0
- package/docs/components/dialog/search-orama.tsx +143 -0
- package/docs/components/dialog/search.tsx +529 -0
- package/docs/components/dynamic-codeblock.tsx +129 -0
- package/docs/components/files.tsx +81 -0
- package/docs/components/github-info.tsx +107 -0
- package/docs/components/heading.tsx +33 -0
- package/docs/components/image-zoom.css +77 -0
- package/docs/components/image-zoom.tsx +58 -0
- package/docs/components/index.ts +7 -0
- package/docs/components/inline-toc.tsx +48 -0
- package/docs/components/sidebar/base.tsx +451 -0
- package/docs/components/sidebar/link-item.tsx +65 -0
- package/docs/components/sidebar/page-tree.tsx +113 -0
- package/docs/components/sidebar/tabs/dropdown.tsx +109 -0
- package/docs/components/sidebar/tabs/index.tsx +89 -0
- package/docs/components/steps.tsx +9 -0
- package/docs/components/tabs.tsx +203 -0
- package/docs/components/toc/clerk.tsx +173 -0
- package/docs/components/toc/default.tsx +57 -0
- package/docs/components/toc/index.tsx +136 -0
- package/docs/components/type-table.tsx +174 -0
- package/docs/components/ui/accordion.tsx +88 -0
- package/docs/components/ui/button.tsx +28 -0
- package/docs/components/ui/collapsible.tsx +42 -0
- package/docs/components/ui/navigation-menu.tsx +83 -0
- package/docs/components/ui/popover.tsx +32 -0
- package/docs/components/ui/scroll-area.tsx +59 -0
- package/docs/components/ui/tabs.tsx +145 -0
- package/docs/contexts/i18n.tsx +56 -0
- package/docs/contexts/search.tsx +165 -0
- package/docs/contexts/tree.tsx +65 -0
- package/docs/css/black.css +39 -0
- package/docs/css/catppuccin.css +49 -0
- package/docs/css/colors/index.css +51 -0
- package/docs/css/dusk.css +47 -0
- package/docs/css/layouts/docs.css +1 -0
- package/docs/css/layouts/home.css +1 -0
- package/docs/css/layouts/notebook.css +1 -0
- package/docs/css/neutral.css +7 -0
- package/docs/css/ocean.css +48 -0
- package/docs/css/preset.css +305 -0
- package/docs/css/purple.css +39 -0
- package/docs/css/shadcn.css +36 -0
- package/docs/css/shiki.css +90 -0
- package/docs/css/solar.css +75 -0
- package/docs/css/style.css +9 -0
- package/docs/css/vitepress.css +77 -0
- package/docs/i18n.tsx +30 -0
- package/docs/icons.tsx +354 -0
- package/docs/layouts/docs/client.tsx +129 -0
- package/docs/layouts/docs/index.tsx +321 -0
- package/docs/layouts/docs/page/client.tsx +376 -0
- package/docs/layouts/docs/page/index.tsx +251 -0
- package/docs/layouts/docs/sidebar.tsx +265 -0
- package/docs/layouts/home/client.tsx +375 -0
- package/docs/layouts/home/index.tsx +51 -0
- package/docs/layouts/home/navbar.tsx +55 -0
- package/docs/layouts/notebook/client.tsx +281 -0
- package/docs/layouts/notebook/index.tsx +461 -0
- package/docs/layouts/notebook/page/client.tsx +375 -0
- package/docs/layouts/notebook/page/index.tsx +251 -0
- package/docs/layouts/notebook/sidebar.tsx +248 -0
- package/docs/layouts/shared/index.tsx +89 -0
- package/docs/layouts/shared/language-toggle.tsx +66 -0
- package/docs/layouts/shared/link-item.tsx +119 -0
- package/docs/layouts/shared/search-toggle.tsx +78 -0
- package/docs/layouts/shared/theme-toggle.tsx +86 -0
- package/docs/mdx.server.tsx +37 -0
- package/docs/mdx.tsx +97 -0
- package/docs/og.tsx +101 -0
- package/docs/page.tsx +85 -0
- package/docs/provider/base.tsx +173 -0
- package/docs/provider/next.tsx +23 -0
- package/docs/provider/react-router.tsx +23 -0
- package/docs/provider/tanstack.tsx +23 -0
- package/docs/provider/waku.tsx +23 -0
- package/docs/source.ts +3 -0
- package/docs/theme/typography/LICENSE +21 -0
- package/docs/theme/typography/index.ts +201 -0
- package/docs/theme/typography/styles.ts +449 -0
- package/docs/utils/cn.ts +1 -0
- package/docs/utils/is-active.ts +23 -0
- package/docs/utils/merge-refs.ts +15 -0
- package/docs/utils/use-copy-button.ts +39 -0
- package/docs/utils/use-footer-items.ts +27 -0
- package/docs/utils/use-is-scroll-top.ts +21 -0
- package/package.json +8 -2
- package/dist/3d/button.js +0 -298
- package/dist/3d/button.mjs +0 -273
- package/dist/3d/card.js +0 -234
- package/dist/3d/card.mjs +0 -207
- package/dist/3d/carousel.js +0 -371
- package/dist/3d/carousel.mjs +0 -344
- package/dist/3d/grid.js +0 -362
- package/dist/3d/grid.mjs +0 -337
- package/dist/3d/index.js +0 -1518
- package/dist/3d/index.mjs +0 -1472
- package/dist/3d/marquee.js +0 -352
- package/dist/3d/marquee.mjs +0 -327
- package/dist/3d/pin.js +0 -46
- package/dist/3d/pin.mjs +0 -24
- package/dist/accordion.js +0 -80
- package/dist/accordion.mjs +0 -55
- package/dist/alert-dialog.js +0 -220
- package/dist/alert-dialog.mjs +0 -187
- package/dist/alert.js +0 -68
- package/dist/alert.mjs +0 -64
- package/dist/animation/animated-background.js +0 -424
- package/dist/animation/animated-background.mjs +0 -418
- package/dist/animation/animated-beam.js +0 -119
- package/dist/animation/animated-beam.mjs +0 -97
- package/dist/animation/animated-cursor.js +0 -275
- package/dist/animation/animated-cursor.mjs +0 -270
- package/dist/animation/animated-icon.js +0 -357
- package/dist/animation/animated-icon.mjs +0 -351
- package/dist/animation/animated-list.js +0 -339
- package/dist/animation/animated-list.mjs +0 -333
- package/dist/animation/animated-number.js +0 -283
- package/dist/animation/animated-number.mjs +0 -277
- package/dist/animation/animated-testimonials.js +0 -97
- package/dist/animation/animated-testimonials.mjs +0 -75
- package/dist/animation/animated-tooltip.js +0 -67
- package/dist/animation/animated-tooltip.mjs +0 -45
- package/dist/animation/apple-cards-carousel.js +0 -308
- package/dist/animation/apple-cards-carousel.mjs +0 -285
- package/dist/animation/apple-hello-effect.js +0 -60
- package/dist/animation/apple-hello-effect.mjs +0 -38
- package/dist/animation/index.js +0 -1952
- package/dist/animation/index.mjs +0 -1921
- package/dist/avatar.js +0 -71
- package/dist/avatar.mjs +0 -47
- package/dist/badge.js +0 -66
- package/dist/badge.mjs +0 -40
- package/dist/blocks/index.js +0 -1665
- package/dist/blocks/index.mjs +0 -1626
- package/dist/breadcrumb.js +0 -107
- package/dist/breadcrumb.mjs +0 -99
- package/dist/calendar.js +0 -189
- package/dist/calendar.mjs +0 -164
- package/dist/carousel.js +0 -278
- package/dist/carousel.mjs +0 -249
- package/dist/checkbox.js +0 -60
- package/dist/checkbox.mjs +0 -35
- package/dist/code/block.js +0 -226
- package/dist/code/block.mjs +0 -203
- package/dist/code/compare.js +0 -446
- package/dist/code/compare.mjs +0 -423
- package/dist/code/diff.js +0 -430
- package/dist/code/diff.mjs +0 -407
- package/dist/code/editor.js +0 -243
- package/dist/code/editor.mjs +0 -218
- package/dist/code/explorer.js +0 -291
- package/dist/code/explorer.mjs +0 -268
- package/dist/code/index.js +0 -2551
- package/dist/code/index.mjs +0 -2510
- package/dist/code/preview.js +0 -400
- package/dist/code/preview.mjs +0 -377
- package/dist/code/snippet.js +0 -274
- package/dist/code/snippet.mjs +0 -250
- package/dist/code/tabs.js +0 -75
- package/dist/code/tabs.mjs +0 -53
- package/dist/code/terminal.js +0 -437
- package/dist/code/terminal.mjs +0 -414
- package/dist/collapsible.js +0 -33
- package/dist/collapsible.mjs +0 -9
- package/dist/command.js +0 -262
- package/dist/command.mjs +0 -232
- package/dist/context-menu.js +0 -207
- package/dist/context-menu.mjs +0 -171
- package/dist/device/index.js +0 -3
- package/dist/device/index.mjs +0 -2
- package/dist/dialog.js +0 -151
- package/dist/dialog.mjs +0 -121
- package/dist/dock/basic.js +0 -174
- package/dist/dock/basic.mjs +0 -151
- package/dist/dock/index.js +0 -628
- package/dist/dock/index.mjs +0 -601
- package/dist/dock/limelight-nav.js +0 -295
- package/dist/dock/limelight-nav.mjs +0 -274
- package/dist/dock/macos.js +0 -141
- package/dist/dock/macos.mjs +0 -118
- package/dist/dock/menu.js +0 -70
- package/dist/dock/menu.mjs +0 -48
- package/dist/dock/message.js +0 -144
- package/dist/dock/message.mjs +0 -122
- package/dist/drawer.js +0 -115
- package/dist/drawer.mjs +0 -103
- package/dist/dropdown-menu.js +0 -202
- package/dist/dropdown-menu.mjs +0 -166
- package/dist/finance/AdvancedChart.js +0 -48
- package/dist/finance/AdvancedChart.mjs +0 -46
- package/dist/finance/CompanyProfile.js +0 -48
- package/dist/finance/CompanyProfile.mjs +0 -46
- package/dist/finance/CryptoScreener.js +0 -45
- package/dist/finance/CryptoScreener.mjs +0 -43
- package/dist/finance/Financials.js +0 -52
- package/dist/finance/Financials.mjs +0 -50
- package/dist/finance/ForexScreener.js +0 -46
- package/dist/finance/ForexScreener.mjs +0 -44
- package/dist/finance/MarketOverview.js +0 -104
- package/dist/finance/MarketOverview.mjs +0 -102
- package/dist/finance/NewsTimeline.js +0 -44
- package/dist/finance/NewsTimeline.mjs +0 -42
- package/dist/finance/OrderEntry.js +0 -131
- package/dist/finance/OrderEntry.mjs +0 -129
- package/dist/finance/OrdersHistory.js +0 -64
- package/dist/finance/OrdersHistory.mjs +0 -62
- package/dist/finance/PositionsList.js +0 -80
- package/dist/finance/PositionsList.mjs +0 -78
- package/dist/finance/StockScreener.js +0 -46
- package/dist/finance/StockScreener.mjs +0 -44
- package/dist/finance/SymbolInfo.js +0 -46
- package/dist/finance/SymbolInfo.mjs +0 -44
- package/dist/finance/TechnicalAnalysis.js +0 -54
- package/dist/finance/TechnicalAnalysis.mjs +0 -52
- package/dist/finance/TickerTape.js +0 -56
- package/dist/finance/TickerTape.mjs +0 -54
- package/dist/finance/TradingPanel.js +0 -191
- package/dist/finance/TradingPanel.mjs +0 -189
- package/dist/finance/index.js +0 -930
- package/dist/finance/index.mjs +0 -914
- package/dist/form/index.js +0 -155
- package/dist/form/index.mjs +0 -125
- package/dist/form.js +0 -172
- package/dist/form.mjs +0 -142
- package/dist/hover-card.js +0 -58
- package/dist/hover-card.mjs +0 -34
- package/dist/index.js +0 -10179
- package/dist/index.mjs +0 -9785
- package/dist/input-otp.js +0 -79
- package/dist/input-otp.mjs +0 -54
- package/dist/lib/utils.js +0 -28
- package/dist/lib/utils.mjs +0 -24
- package/dist/navigation/index.js +0 -98
- package/dist/navigation/index.mjs +0 -79
- package/dist/navigation-menu.js +0 -149
- package/dist/navigation-menu.mjs +0 -116
- package/dist/pattern/grid-pattern.js +0 -333
- package/dist/pattern/grid-pattern.mjs +0 -310
- package/dist/pattern/index.js +0 -333
- package/dist/pattern/index.mjs +0 -310
- package/dist/popover.js +0 -63
- package/dist/popover.mjs +0 -37
- package/dist/primitives/index.js +0 -10179
- package/dist/primitives/index.mjs +0 -9785
- package/dist/primitives-export.js +0 -10179
- package/dist/primitives-export.mjs +0 -9785
- package/dist/progress.js +0 -62
- package/dist/progress.mjs +0 -37
- package/dist/project/gantt.js +0 -65
- package/dist/project/gantt.mjs +0 -43
- package/dist/project/index.js +0 -636
- package/dist/project/index.mjs +0 -611
- package/dist/project/kanban.js +0 -597
- package/dist/project/kanban.mjs +0 -572
- package/dist/project/list.js +0 -35
- package/dist/project/list.mjs +0 -12
- package/dist/radio-group.js +0 -68
- package/dist/radio-group.mjs +0 -45
- package/dist/resizable.js +0 -72
- package/dist/resizable.mjs +0 -48
- package/dist/scroll-area.js +0 -89
- package/dist/scroll-area.mjs +0 -66
- package/dist/select.js +0 -140
- package/dist/select.mjs +0 -111
- package/dist/separator.js +0 -59
- package/dist/separator.mjs +0 -34
- package/dist/sheet.js +0 -148
- package/dist/sheet.mjs +0 -117
- package/dist/skeleton.js +0 -32
- package/dist/skeleton.mjs +0 -27
- package/dist/slider.js +0 -99
- package/dist/slider.mjs +0 -73
- package/dist/sonner.js +0 -34
- package/dist/sonner.mjs +0 -29
- package/dist/switch.js +0 -62
- package/dist/switch.mjs +0 -37
- package/dist/table.js +0 -110
- package/dist/table.mjs +0 -101
- package/dist/tabs.js +0 -82
- package/dist/tabs.mjs +0 -57
- package/dist/tailwind/index.js +0 -2023
- package/dist/tailwind/index.mjs +0 -2011
- package/dist/textarea.js +0 -78
- package/dist/textarea.mjs +0 -56
- package/dist/toggle-group.js +0 -118
- package/dist/toggle-group.mjs +0 -93
- package/dist/toggle.js +0 -71
- package/dist/toggle.mjs +0 -48
- package/dist/tooltip.js +0 -67
- package/dist/tooltip.mjs +0 -40
- package/dist/types/index.js +0 -57
- package/dist/types/index.mjs +0 -51
- package/dist/ui/announcement.js +0 -129
- package/dist/ui/announcement.mjs +0 -107
- package/dist/ui/avatar-group.js +0 -88
- package/dist/ui/avatar-group.mjs +0 -65
- package/dist/ui/banner.js +0 -85
- package/dist/ui/banner.mjs +0 -62
- package/dist/ui/cursor.js +0 -78
- package/dist/ui/cursor.mjs +0 -56
- package/dist/ui/index.js +0 -475
- package/dist/ui/index.mjs +0 -442
- package/dist/ui/marquee.js +0 -74
- package/dist/ui/marquee.mjs +0 -52
- package/dist/ui/pill.js +0 -85
- package/dist/ui/pill.mjs +0 -62
- package/dist/ui/spinner.js +0 -28
- package/dist/ui/spinner.mjs +0 -26
- package/dist/ui/tags.js +0 -101
- package/dist/ui/tags.mjs +0 -79
- package/dist/ui/ticker.js +0 -73
- package/dist/ui/ticker.mjs +0 -51
- package/dist/util/index.js +0 -457
- package/dist/util/index.mjs +0 -399
package/dist/util/index.mjs
DELETED
|
@@ -1,399 +0,0 @@
|
|
|
1
|
-
import { createRoot } from 'react-dom/client';
|
|
2
|
-
import { Buffer } from 'buffer';
|
|
3
|
-
import { toast } from 'sonner';
|
|
4
|
-
import { jsx } from 'react/jsx-runtime';
|
|
5
|
-
import * as React from 'react';
|
|
6
|
-
import { useRef, useEffect } from 'react';
|
|
7
|
-
import { clsx } from 'clsx';
|
|
8
|
-
import { twMerge } from 'tailwind-merge';
|
|
9
|
-
import { reaction, computed, makeObservable, action, observable } from 'mobx';
|
|
10
|
-
|
|
11
|
-
var __defProp = Object.defineProperty;
|
|
12
|
-
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
13
|
-
|
|
14
|
-
// util/date.ts
|
|
15
|
-
var formatDateToUSLocaleString = /* @__PURE__ */ __name((date) => {
|
|
16
|
-
if (!date) return "-";
|
|
17
|
-
return new Date(date).toLocaleDateString("en-US", {
|
|
18
|
-
year: "numeric",
|
|
19
|
-
month: "numeric",
|
|
20
|
-
day: "numeric"
|
|
21
|
-
});
|
|
22
|
-
}, "formatDateToUSLocaleString");
|
|
23
|
-
var formatDateToLocaleStringWithTime = /* @__PURE__ */ __name((date) => {
|
|
24
|
-
if (!date) return "-";
|
|
25
|
-
return new Date(date).toLocaleDateString("en-US", {
|
|
26
|
-
year: "numeric",
|
|
27
|
-
month: "numeric",
|
|
28
|
-
day: "numeric",
|
|
29
|
-
hour: "numeric",
|
|
30
|
-
minute: "numeric"
|
|
31
|
-
});
|
|
32
|
-
}, "formatDateToLocaleStringWithTime");
|
|
33
|
-
var getRelativeDateLabel = /* @__PURE__ */ __name((date) => {
|
|
34
|
-
const today = /* @__PURE__ */ new Date();
|
|
35
|
-
const yesterday = /* @__PURE__ */ new Date();
|
|
36
|
-
yesterday.setDate(today.getDate() - 1);
|
|
37
|
-
if (date.toDateString() === today.toDateString()) {
|
|
38
|
-
return "today";
|
|
39
|
-
} else if (date.toDateString() === yesterday.toDateString()) {
|
|
40
|
-
return "yesterday";
|
|
41
|
-
} else {
|
|
42
|
-
return date.toDateString();
|
|
43
|
-
}
|
|
44
|
-
}, "getRelativeDateLabel");
|
|
45
|
-
var groupMessagesByDate = /* @__PURE__ */ __name((messages) => {
|
|
46
|
-
const groupedMessages = {};
|
|
47
|
-
for (const message of messages) {
|
|
48
|
-
const date = new Date(message.createdAt ?? "").toDateString();
|
|
49
|
-
if (!groupedMessages[date]) {
|
|
50
|
-
groupedMessages[date] = [];
|
|
51
|
-
}
|
|
52
|
-
groupedMessages[date].push(message);
|
|
53
|
-
}
|
|
54
|
-
return groupedMessages;
|
|
55
|
-
}, "groupMessagesByDate");
|
|
56
|
-
var formatDateToMonthAndDay = /* @__PURE__ */ __name((date) => {
|
|
57
|
-
const today = /* @__PURE__ */ new Date();
|
|
58
|
-
if (date.getDate() === today.getDate() && date.getMonth() === today.getMonth() && date.getFullYear() === today.getFullYear()) {
|
|
59
|
-
return date.toLocaleTimeString("en-US", {
|
|
60
|
-
hour: "numeric",
|
|
61
|
-
minute: "numeric",
|
|
62
|
-
hour12: true
|
|
63
|
-
});
|
|
64
|
-
}
|
|
65
|
-
const month = date.getMonth() + 1;
|
|
66
|
-
const day = date.getDate();
|
|
67
|
-
return `${month}/${day}`;
|
|
68
|
-
}, "formatDateToMonthAndDay");
|
|
69
|
-
|
|
70
|
-
// util/file.ts
|
|
71
|
-
var getFileName = /* @__PURE__ */ __name((fileName) => {
|
|
72
|
-
const nameParts = fileName.split(".");
|
|
73
|
-
return nameParts.slice(0, -1).join(".");
|
|
74
|
-
}, "getFileName");
|
|
75
|
-
var getFileExt = /* @__PURE__ */ __name((fileName) => {
|
|
76
|
-
const nameParts = fileName.split(".");
|
|
77
|
-
return nameParts.pop() || "";
|
|
78
|
-
}, "getFileExt");
|
|
79
|
-
var isFileTypeImageOrPdf = /* @__PURE__ */ __name((file) => {
|
|
80
|
-
if (!file) return false;
|
|
81
|
-
return file?.type.startsWith("image/") || file?.type.startsWith("application/pdf");
|
|
82
|
-
}, "isFileTypeImageOrPdf");
|
|
83
|
-
function createShadowRoot(tagName, styles) {
|
|
84
|
-
const container = document.createElement(tagName);
|
|
85
|
-
const shadow = container.attachShadow({ mode: "open" });
|
|
86
|
-
const globalStyleSheet = new CSSStyleSheet();
|
|
87
|
-
globalStyleSheet.replaceSync(styles);
|
|
88
|
-
shadow.adoptedStyleSheets = [globalStyleSheet];
|
|
89
|
-
const html = document.querySelector("html");
|
|
90
|
-
html.prepend(container);
|
|
91
|
-
return createRoot(shadow);
|
|
92
|
-
}
|
|
93
|
-
__name(createShadowRoot, "createShadowRoot");
|
|
94
|
-
|
|
95
|
-
// util/timing.ts
|
|
96
|
-
function delay(e = 1e3) {
|
|
97
|
-
return new Promise((t) => setTimeout(t, e));
|
|
98
|
-
}
|
|
99
|
-
__name(delay, "delay");
|
|
100
|
-
var blobToBase64 = /* @__PURE__ */ __name((blob) => {
|
|
101
|
-
const reader = new FileReader();
|
|
102
|
-
reader.readAsDataURL(blob);
|
|
103
|
-
return new Promise((resolve) => {
|
|
104
|
-
reader.onloadend = () => {
|
|
105
|
-
resolve(reader.result);
|
|
106
|
-
};
|
|
107
|
-
});
|
|
108
|
-
}, "blobToBase64");
|
|
109
|
-
var dataUrlToFile = /* @__PURE__ */ __name((dataUrl, filename) => {
|
|
110
|
-
const arr = dataUrl.split(",");
|
|
111
|
-
if (arr.length < 2) {
|
|
112
|
-
return void 0;
|
|
113
|
-
}
|
|
114
|
-
const mimeArr = arr[0].match(/:(.*?);/);
|
|
115
|
-
if (!mimeArr || mimeArr.length < 2) {
|
|
116
|
-
return void 0;
|
|
117
|
-
}
|
|
118
|
-
const mime = mimeArr[1];
|
|
119
|
-
const buff = Buffer.from(arr[1], "base64");
|
|
120
|
-
return new File([buff], filename, { type: mime });
|
|
121
|
-
}, "dataUrlToFile");
|
|
122
|
-
|
|
123
|
-
// util/copy-to-clipboard.ts
|
|
124
|
-
async function copyToClipboard(text) {
|
|
125
|
-
try {
|
|
126
|
-
await navigator.clipboard.writeText(text);
|
|
127
|
-
} catch {
|
|
128
|
-
const textarea = document.createElement("textarea");
|
|
129
|
-
textarea.style.position = "fixed";
|
|
130
|
-
textarea.style.top = "-9999px";
|
|
131
|
-
textarea.style.left = "-9999px";
|
|
132
|
-
textarea.innerText = text;
|
|
133
|
-
document.body.appendChild(textarea);
|
|
134
|
-
textarea.focus();
|
|
135
|
-
textarea.select();
|
|
136
|
-
document.execCommand("copy");
|
|
137
|
-
textarea.remove();
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
__name(copyToClipboard, "copyToClipboard");
|
|
141
|
-
|
|
142
|
-
// util/format-text.ts
|
|
143
|
-
var formatText = /* @__PURE__ */ __name((text) => {
|
|
144
|
-
const camelToSpaces = text.replace(/([a-z])([A-Z])/g, "$1 $2");
|
|
145
|
-
const snakeToSpaces = camelToSpaces.replace(/_/g, " ");
|
|
146
|
-
return snakeToSpaces.split(" ").map((word) => word.charAt(0).toUpperCase() + word.slice(1)).join(" ");
|
|
147
|
-
}, "formatText");
|
|
148
|
-
var formatCamelCaseText = /* @__PURE__ */ __name((text) => {
|
|
149
|
-
const words = text.split(/(?=[A-Z])/);
|
|
150
|
-
const formattedWords = words.map((word) => {
|
|
151
|
-
return word.charAt(0).toUpperCase() + word.slice(1).toLowerCase();
|
|
152
|
-
});
|
|
153
|
-
const result = formattedWords.join(" ");
|
|
154
|
-
return result.charAt(0).toUpperCase() + result.slice(1);
|
|
155
|
-
}, "formatCamelCaseText");
|
|
156
|
-
var getVersionFromTool = /* @__PURE__ */ __name((toolRouterKey) => {
|
|
157
|
-
if (toolRouterKey.version) {
|
|
158
|
-
return toolRouterKey.version;
|
|
159
|
-
}
|
|
160
|
-
const parts = toolRouterKey.name.split(":::");
|
|
161
|
-
if (parts.length === 4) {
|
|
162
|
-
return parts[3];
|
|
163
|
-
}
|
|
164
|
-
return "latest";
|
|
165
|
-
}, "getVersionFromTool");
|
|
166
|
-
var submitRegistrationNoCodeNonPristineError = /* @__PURE__ */ __name(() => {
|
|
167
|
-
return toast.error(
|
|
168
|
-
/* @__PURE__ */ jsx("div", { children: "Your Hanzo Node is currently locked by existing keys, please restore your connection or reset your Hanzo Node Storage" }),
|
|
169
|
-
{ position: "bottom-center" }
|
|
170
|
-
);
|
|
171
|
-
}, "submitRegistrationNoCodeNonPristineError");
|
|
172
|
-
var submitRegistrationNoCodeError = /* @__PURE__ */ __name(() => {
|
|
173
|
-
return toast.error(/* @__PURE__ */ jsx("div", { children: "Error connecting to your Hanzo Node" }), {
|
|
174
|
-
position: "bottom-center"
|
|
175
|
-
});
|
|
176
|
-
}, "submitRegistrationNoCodeError");
|
|
177
|
-
|
|
178
|
-
// util/debounce.ts
|
|
179
|
-
var debounce = /* @__PURE__ */ __name((func, delay2) => {
|
|
180
|
-
let timeoutId = null;
|
|
181
|
-
return (...args) => {
|
|
182
|
-
if (timeoutId) {
|
|
183
|
-
clearTimeout(timeoutId);
|
|
184
|
-
}
|
|
185
|
-
timeoutId = setTimeout(() => {
|
|
186
|
-
func(...args);
|
|
187
|
-
}, delay2);
|
|
188
|
-
};
|
|
189
|
-
}, "debounce");
|
|
190
|
-
|
|
191
|
-
// util/spread-to-transform.ts
|
|
192
|
-
function spreadToTransform(t) {
|
|
193
|
-
let transformStrings = [];
|
|
194
|
-
const scaleVal = "scale" in t ? t.scale : void 0;
|
|
195
|
-
if (scaleVal) {
|
|
196
|
-
if (typeof scaleVal === "number") {
|
|
197
|
-
transformStrings.push(`scale(${scaleVal})`);
|
|
198
|
-
} else if (Array.isArray(scaleVal) && scaleVal.length == 2 && typeof scaleVal[0] === "number") {
|
|
199
|
-
transformStrings.push(`scale(${scaleVal[0]}, ${scaleVal[1]})`);
|
|
200
|
-
} else {
|
|
201
|
-
throw new Error("parsing MediaTransform: Unrecognized value for 'scale'!");
|
|
202
|
-
}
|
|
203
|
-
}
|
|
204
|
-
return transformStrings.length > 0 ? { transform: transformStrings.join(" ") } : {};
|
|
205
|
-
}
|
|
206
|
-
__name(spreadToTransform, "spreadToTransform");
|
|
207
|
-
var spread_to_transform_default = spreadToTransform;
|
|
208
|
-
|
|
209
|
-
// util/specifier.ts
|
|
210
|
-
var getPrimaryStartingWith = /* @__PURE__ */ __name((s, toFind) => {
|
|
211
|
-
const tokenArray = s.split(" ");
|
|
212
|
-
return tokenArray.find((tok) => tok.startsWith(`${toFind}-`));
|
|
213
|
-
}, "getPrimaryStartingWith");
|
|
214
|
-
var getTShirtSize = /* @__PURE__ */ __name((s) => {
|
|
215
|
-
const subTokenArray = s.split("-");
|
|
216
|
-
return subTokenArray[subTokenArray.length - 1];
|
|
217
|
-
}, "getTShirtSize");
|
|
218
|
-
var getTypographySize = /* @__PURE__ */ __name((s) => {
|
|
219
|
-
const subTokenArray = s.split("-");
|
|
220
|
-
return subTokenArray[subTokenArray.length - 1];
|
|
221
|
-
}, "getTypographySize");
|
|
222
|
-
var getDim = /* @__PURE__ */ __name((s) => {
|
|
223
|
-
const subTokenArray = s.split("-");
|
|
224
|
-
const dimStr = subTokenArray[subTokenArray.length - 1];
|
|
225
|
-
if (dimStr) {
|
|
226
|
-
const dimTokenArray = s.split("x");
|
|
227
|
-
return dimTokenArray ? {
|
|
228
|
-
w: Number(dimTokenArray[0]),
|
|
229
|
-
h: Number(dimTokenArray[1])
|
|
230
|
-
} : void 0;
|
|
231
|
-
}
|
|
232
|
-
return void 0;
|
|
233
|
-
}, "getDim");
|
|
234
|
-
function getSpecifierData(main, getPrimary, getData, def) {
|
|
235
|
-
const primary = getPrimary(main);
|
|
236
|
-
if (primary) {
|
|
237
|
-
return getData(primary) ?? def;
|
|
238
|
-
}
|
|
239
|
-
return def ?? void 0;
|
|
240
|
-
}
|
|
241
|
-
__name(getSpecifierData, "getSpecifierData");
|
|
242
|
-
|
|
243
|
-
// util/number-abbreviate.ts
|
|
244
|
-
var ABBR_SYMBOLS_ARRAY = ["K", "M", "B", "T"];
|
|
245
|
-
var MOBILE_BREAKPOINT = 768;
|
|
246
|
-
function useIsMobile() {
|
|
247
|
-
const [isMobile, setIsMobile] = React.useState(void 0);
|
|
248
|
-
React.useEffect(() => {
|
|
249
|
-
const mql = window.matchMedia(`(max-width: ${MOBILE_BREAKPOINT - 1}px)`);
|
|
250
|
-
const onChange = /* @__PURE__ */ __name(() => {
|
|
251
|
-
setIsMobile(window.innerWidth < MOBILE_BREAKPOINT);
|
|
252
|
-
}, "onChange");
|
|
253
|
-
mql.addEventListener("change", onChange);
|
|
254
|
-
setIsMobile(window.innerWidth < MOBILE_BREAKPOINT);
|
|
255
|
-
return () => mql.removeEventListener("change", onChange);
|
|
256
|
-
}, []);
|
|
257
|
-
return !!isMobile;
|
|
258
|
-
}
|
|
259
|
-
__name(useIsMobile, "useIsMobile");
|
|
260
|
-
function cn(...inputs) {
|
|
261
|
-
return twMerge(clsx(inputs));
|
|
262
|
-
}
|
|
263
|
-
__name(cn, "cn");
|
|
264
|
-
function formatDate(input) {
|
|
265
|
-
const date = new Date(input);
|
|
266
|
-
return date.toLocaleDateString("en-US", {
|
|
267
|
-
month: "long",
|
|
268
|
-
day: "numeric",
|
|
269
|
-
year: "numeric"
|
|
270
|
-
});
|
|
271
|
-
}
|
|
272
|
-
__name(formatDate, "formatDate");
|
|
273
|
-
function absoluteUrl(path) {
|
|
274
|
-
return `${process.env.NEXT_PUBLIC_APP_URL || ""}${path}`;
|
|
275
|
-
}
|
|
276
|
-
__name(absoluteUrl, "absoluteUrl");
|
|
277
|
-
|
|
278
|
-
// util/index.ts
|
|
279
|
-
function constrain(value, minOrConstrainTo, max) {
|
|
280
|
-
if (typeof value === "number" && typeof minOrConstrainTo === "number" && typeof max === "number") {
|
|
281
|
-
return Math.min(Math.max(value, minOrConstrainTo), max);
|
|
282
|
-
}
|
|
283
|
-
if (typeof value === "object" && typeof minOrConstrainTo === "object") {
|
|
284
|
-
const dim = value;
|
|
285
|
-
const constrainTo = minOrConstrainTo;
|
|
286
|
-
const aspectRatio = dim.w / dim.h;
|
|
287
|
-
const constrainAspectRatio = constrainTo.w / constrainTo.h;
|
|
288
|
-
if (aspectRatio > constrainAspectRatio) {
|
|
289
|
-
return {
|
|
290
|
-
w: constrainTo.w,
|
|
291
|
-
h: constrainTo.w / aspectRatio
|
|
292
|
-
};
|
|
293
|
-
} else {
|
|
294
|
-
return {
|
|
295
|
-
w: constrainTo.h * aspectRatio,
|
|
296
|
-
h: constrainTo.h
|
|
297
|
-
};
|
|
298
|
-
}
|
|
299
|
-
}
|
|
300
|
-
throw new Error("Invalid parameters for constrain function");
|
|
301
|
-
}
|
|
302
|
-
__name(constrain, "constrain");
|
|
303
|
-
function round(value) {
|
|
304
|
-
return Math.round(value * 100) / 100;
|
|
305
|
-
}
|
|
306
|
-
__name(round, "round");
|
|
307
|
-
function pxToRem(px, base = 16) {
|
|
308
|
-
return `${px / base}rem`;
|
|
309
|
-
}
|
|
310
|
-
__name(pxToRem, "pxToRem");
|
|
311
|
-
function pxToEm(px, base = 16) {
|
|
312
|
-
return `${px / base}em`;
|
|
313
|
-
}
|
|
314
|
-
__name(pxToEm, "pxToEm");
|
|
315
|
-
function containsToken(text, token) {
|
|
316
|
-
if (!text) return false;
|
|
317
|
-
return text.toLowerCase().includes(token.toLowerCase());
|
|
318
|
-
}
|
|
319
|
-
__name(containsToken, "containsToken");
|
|
320
|
-
function ldMerge(...objects) {
|
|
321
|
-
const result = {};
|
|
322
|
-
for (const obj of objects) {
|
|
323
|
-
if (obj && typeof obj === "object") {
|
|
324
|
-
Object.assign(result, obj);
|
|
325
|
-
}
|
|
326
|
-
}
|
|
327
|
-
return result;
|
|
328
|
-
}
|
|
329
|
-
__name(ldMerge, "ldMerge");
|
|
330
|
-
function asNum(value, defaultValue = 0) {
|
|
331
|
-
const num = Number(value);
|
|
332
|
-
return isNaN(num) ? defaultValue : num;
|
|
333
|
-
}
|
|
334
|
-
__name(asNum, "asNum");
|
|
335
|
-
var _MyStepAnimation = class _MyStepAnimation {
|
|
336
|
-
/** initialStep: false -> true: step 0
|
|
337
|
-
true -> false: step 1
|
|
338
|
-
after intervals[0] : step 2
|
|
339
|
-
after intervals[1] : step 3
|
|
340
|
-
|
|
341
|
-
initialStep must contain at least one mobx observable and return boolean
|
|
342
|
-
see: https://mobx.js.org/reactions.html#reaction
|
|
343
|
-
*/
|
|
344
|
-
constructor(initialStep, intervals) {
|
|
345
|
-
this._step = -1;
|
|
346
|
-
this._reactionDisposer = void 0;
|
|
347
|
-
// This is separated out because reactions have to be created
|
|
348
|
-
// once we have a valid doc / window etc. (mobx internals)
|
|
349
|
-
// Can't just do it in constructor and assign to ref
|
|
350
|
-
this.initialize = /* @__PURE__ */ __name(() => {
|
|
351
|
-
const fireNext = /* @__PURE__ */ __name(() => {
|
|
352
|
-
this._setStep(this._step + 1);
|
|
353
|
-
if (this._step <= this._intervals.length) {
|
|
354
|
-
setTimeout(() => {
|
|
355
|
-
fireNext();
|
|
356
|
-
}, this._intervals[this._step - 1]);
|
|
357
|
-
}
|
|
358
|
-
}, "fireNext");
|
|
359
|
-
this._reactionDisposer = reaction(
|
|
360
|
-
this._initialStep,
|
|
361
|
-
(triggered) => {
|
|
362
|
-
if (triggered && this._step === -1) {
|
|
363
|
-
this._setStep(0);
|
|
364
|
-
} else if (this._step === 0) {
|
|
365
|
-
fireNext();
|
|
366
|
-
}
|
|
367
|
-
}
|
|
368
|
-
);
|
|
369
|
-
}, "initialize");
|
|
370
|
-
this._setStep = /* @__PURE__ */ __name((v) => {
|
|
371
|
-
this._step = v;
|
|
372
|
-
}, "_setStep");
|
|
373
|
-
this.dispose = /* @__PURE__ */ __name(() => {
|
|
374
|
-
if (this._reactionDisposer) {
|
|
375
|
-
this._reactionDisposer();
|
|
376
|
-
}
|
|
377
|
-
}, "dispose");
|
|
378
|
-
// https://mobx.js.org/computeds-with-args.html#2-close-over-the-arguments
|
|
379
|
-
this.notPast = /* @__PURE__ */ __name((step) => computed(() => this._step > -1 && this._step <= step).get(), "notPast");
|
|
380
|
-
this._initialStep = initialStep;
|
|
381
|
-
this._intervals = intervals;
|
|
382
|
-
makeObservable(this, {
|
|
383
|
-
_step: observable,
|
|
384
|
-
_setStep: action
|
|
385
|
-
});
|
|
386
|
-
}
|
|
387
|
-
};
|
|
388
|
-
__name(_MyStepAnimation, "MyStepAnimation");
|
|
389
|
-
var MyStepAnimation = _MyStepAnimation;
|
|
390
|
-
var useStepAnimation = /* @__PURE__ */ __name((initialStep, intervals) => {
|
|
391
|
-
const animRef = useRef(new MyStepAnimation(initialStep, intervals));
|
|
392
|
-
useEffect(() => {
|
|
393
|
-
animRef.current.initialize();
|
|
394
|
-
return animRef.current.dispose;
|
|
395
|
-
}, []);
|
|
396
|
-
return animRef.current;
|
|
397
|
-
}, "useStepAnimation");
|
|
398
|
-
|
|
399
|
-
export { ABBR_SYMBOLS_ARRAY, absoluteUrl, asNum, blobToBase64, cn, constrain, containsToken, copyToClipboard, createShadowRoot, dataUrlToFile, debounce, delay, formatCamelCaseText, formatDate, formatDateToLocaleStringWithTime, formatDateToMonthAndDay, formatDateToUSLocaleString, formatText, getDim, getFileExt, getFileName, getPrimaryStartingWith, getRelativeDateLabel, getSpecifierData, getTShirtSize, getTypographySize, getVersionFromTool, groupMessagesByDate, isFileTypeImageOrPdf, ldMerge, pxToEm, pxToRem, round, spread_to_transform_default as spreadToTransform, submitRegistrationNoCodeError, submitRegistrationNoCodeNonPristineError, useIsMobile, useStepAnimation };
|