@emblemvault/hustle-react 1.4.4 → 1.4.6
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/dist/browser/hustle-react.js +105 -39
- package/dist/browser/hustle-react.js.map +1 -1
- package/dist/components/index.cjs +104 -38
- package/dist/components/index.cjs.map +1 -1
- package/dist/components/index.d.cts +2 -2
- package/dist/components/index.d.ts +2 -2
- package/dist/components/index.js +104 -38
- package/dist/components/index.js.map +1 -1
- package/dist/index.cjs +105 -38
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +7 -1
- package/dist/index.d.ts +7 -1
- package/dist/index.js +105 -39
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
|
@@ -15817,12 +15817,16 @@ function SettingsIcon() {
|
|
|
15817
15817
|
function AttachIcon() {
|
|
15818
15818
|
return /* @__PURE__ */ jsx("svg", { width: "16", height: "16", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", children: /* @__PURE__ */ jsx("path", { d: "M21.44 11.05l-9.19 9.19a6 6 0 0 1-8.49-8.49l9.19-9.19a4 4 0 0 1 5.66 5.66l-9.2 9.19a2 2 0 0 1-2.83-2.83l8.49-8.48" }) });
|
|
15819
15819
|
}
|
|
15820
|
+
|
|
15821
|
+
// src/constants/index.ts
|
|
15822
|
+
var AGENT_HUSTLE_ICON = "";
|
|
15820
15823
|
var sizeConfigs = {
|
|
15821
15824
|
sm: { width: "320px", height: "400px" },
|
|
15822
15825
|
md: { width: "380px", height: "520px" },
|
|
15823
15826
|
lg: { width: "420px", height: "600px" },
|
|
15824
15827
|
xl: { width: "480px", height: "700px" },
|
|
15825
|
-
full: { width: "100vw", height: "100vh" }
|
|
15828
|
+
full: { width: "100vw", height: "100vh" },
|
|
15829
|
+
sideDock: { width: "380px", height: "100vh" }
|
|
15826
15830
|
};
|
|
15827
15831
|
var widgetStyles = {
|
|
15828
15832
|
// Container for absolute positioning
|
|
@@ -15900,6 +15904,21 @@ var widgetStyles = {
|
|
|
15900
15904
|
width: "100vw",
|
|
15901
15905
|
height: "100vh"
|
|
15902
15906
|
},
|
|
15907
|
+
// Side dock mode overrides
|
|
15908
|
+
panelSideDock: {
|
|
15909
|
+
position: "fixed",
|
|
15910
|
+
top: 0,
|
|
15911
|
+
right: 0,
|
|
15912
|
+
bottom: 0,
|
|
15913
|
+
borderRadius: 0,
|
|
15914
|
+
width: "380px",
|
|
15915
|
+
height: "100vh",
|
|
15916
|
+
borderLeft: `1px solid ${tokens.colors.borderPrimary}`,
|
|
15917
|
+
boxShadow: `-4px 0 24px rgba(0, 0, 0, 0.3)`
|
|
15918
|
+
},
|
|
15919
|
+
// Hustle avatar in launcher
|
|
15920
|
+
launcherAvatar: {
|
|
15921
|
+
borderRadius: tokens.radius.full},
|
|
15903
15922
|
// Close button in panel header
|
|
15904
15923
|
closeBtn: {
|
|
15905
15924
|
width: "32px",
|
|
@@ -15919,23 +15938,35 @@ var widgetStyles = {
|
|
|
15919
15938
|
color: tokens.colors.textPrimary
|
|
15920
15939
|
}
|
|
15921
15940
|
};
|
|
15922
|
-
function ChatIcon() {
|
|
15923
|
-
return /* @__PURE__ */ jsx("svg", { width: "24", height: "24", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: /* @__PURE__ */ jsx("path", { d: "M21 15a2 2 0 0 1-2 2H7l-4 4V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2z" }) });
|
|
15924
|
-
}
|
|
15925
15941
|
function CloseIcon() {
|
|
15926
15942
|
return /* @__PURE__ */ jsxs("svg", { width: "18", height: "18", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [
|
|
15927
15943
|
/* @__PURE__ */ jsx("line", { x1: "18", y1: "6", x2: "6", y2: "18" }),
|
|
15928
15944
|
/* @__PURE__ */ jsx("line", { x1: "6", y1: "6", x2: "18", y2: "18" })
|
|
15929
15945
|
] });
|
|
15930
15946
|
}
|
|
15931
|
-
function
|
|
15947
|
+
function ExpandIcon() {
|
|
15932
15948
|
return /* @__PURE__ */ jsxs("svg", { width: "18", height: "18", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [
|
|
15933
|
-
/* @__PURE__ */ jsx("polyline", { points: "
|
|
15934
|
-
/* @__PURE__ */ jsx("polyline", { points: "
|
|
15935
|
-
/* @__PURE__ */ jsx("line", { x1: "
|
|
15949
|
+
/* @__PURE__ */ jsx("polyline", { points: "15 3 21 3 21 9" }),
|
|
15950
|
+
/* @__PURE__ */ jsx("polyline", { points: "9 21 3 21 3 15" }),
|
|
15951
|
+
/* @__PURE__ */ jsx("line", { x1: "21", y1: "3", x2: "14", y2: "10" }),
|
|
15936
15952
|
/* @__PURE__ */ jsx("line", { x1: "3", y1: "21", x2: "10", y2: "14" })
|
|
15937
15953
|
] });
|
|
15938
15954
|
}
|
|
15955
|
+
function AgentHustleAvatar({ size = 40 }) {
|
|
15956
|
+
return /* @__PURE__ */ jsx(
|
|
15957
|
+
"img",
|
|
15958
|
+
{
|
|
15959
|
+
src: AGENT_HUSTLE_ICON,
|
|
15960
|
+
alt: "Agent Hustle",
|
|
15961
|
+
style: {
|
|
15962
|
+
width: size,
|
|
15963
|
+
height: size,
|
|
15964
|
+
borderRadius: "50%",
|
|
15965
|
+
objectFit: "cover"
|
|
15966
|
+
}
|
|
15967
|
+
}
|
|
15968
|
+
);
|
|
15969
|
+
}
|
|
15939
15970
|
function HustleChatWidget({
|
|
15940
15971
|
config = {},
|
|
15941
15972
|
...chatProps
|
|
@@ -15943,7 +15974,7 @@ function HustleChatWidget({
|
|
|
15943
15974
|
const {
|
|
15944
15975
|
position = "bottom-right",
|
|
15945
15976
|
size = "md",
|
|
15946
|
-
title = "
|
|
15977
|
+
title = "Agent Hustle",
|
|
15947
15978
|
defaultOpen = false,
|
|
15948
15979
|
launcherIcon,
|
|
15949
15980
|
offset = { x: 24, y: 24 },
|
|
@@ -16018,7 +16049,7 @@ function HustleChatWidget({
|
|
|
16018
16049
|
style: {
|
|
16019
16050
|
...widgetStyles.panel,
|
|
16020
16051
|
...positionStyles.panel,
|
|
16021
|
-
...size === "full" ? widgetStyles.panelFull : {
|
|
16052
|
+
...size === "full" ? widgetStyles.panelFull : size === "sideDock" ? widgetStyles.panelSideDock : {
|
|
16022
16053
|
width: sizeConfig.width,
|
|
16023
16054
|
height: sizeConfig.height
|
|
16024
16055
|
},
|
|
@@ -16036,35 +16067,70 @@ function HustleChatWidget({
|
|
|
16036
16067
|
padding: `${tokens.spacing.md} ${tokens.spacing.lg}`,
|
|
16037
16068
|
background: tokens.colors.bgPrimary,
|
|
16038
16069
|
borderBottom: `1px solid ${tokens.colors.borderPrimary}`,
|
|
16039
|
-
borderRadius: `${tokens.radius.xl} ${tokens.radius.xl} 0 0`,
|
|
16070
|
+
borderRadius: size === "sideDock" || size === "full" ? 0 : `${tokens.radius.xl} ${tokens.radius.xl} 0 0`,
|
|
16040
16071
|
flexShrink: 0
|
|
16041
16072
|
},
|
|
16042
16073
|
children: [
|
|
16043
|
-
/* @__PURE__ */
|
|
16044
|
-
|
|
16045
|
-
{
|
|
16046
|
-
|
|
16047
|
-
|
|
16048
|
-
|
|
16049
|
-
|
|
16050
|
-
|
|
16051
|
-
|
|
16052
|
-
|
|
16053
|
-
|
|
16054
|
-
|
|
16055
|
-
|
|
16056
|
-
|
|
16057
|
-
|
|
16058
|
-
|
|
16059
|
-
|
|
16060
|
-
|
|
16061
|
-
|
|
16062
|
-
|
|
16063
|
-
|
|
16064
|
-
|
|
16065
|
-
|
|
16066
|
-
|
|
16067
|
-
|
|
16074
|
+
/* @__PURE__ */ jsxs("div", { style: { display: "flex", alignItems: "center", gap: tokens.spacing.md }, children: [
|
|
16075
|
+
/* @__PURE__ */ jsx(AgentHustleAvatar, { size: 32 }),
|
|
16076
|
+
/* @__PURE__ */ jsxs("div", { children: [
|
|
16077
|
+
/* @__PURE__ */ jsx(
|
|
16078
|
+
"span",
|
|
16079
|
+
{
|
|
16080
|
+
style: {
|
|
16081
|
+
display: "block",
|
|
16082
|
+
fontWeight: tokens.typography.fontWeightSemibold,
|
|
16083
|
+
color: tokens.colors.textPrimary,
|
|
16084
|
+
fontSize: tokens.typography.fontSizeMd
|
|
16085
|
+
},
|
|
16086
|
+
children: title
|
|
16087
|
+
}
|
|
16088
|
+
),
|
|
16089
|
+
/* @__PURE__ */ jsx(
|
|
16090
|
+
"span",
|
|
16091
|
+
{
|
|
16092
|
+
style: {
|
|
16093
|
+
display: "block",
|
|
16094
|
+
fontSize: tokens.typography.fontSizeXs,
|
|
16095
|
+
color: tokens.colors.textTertiary
|
|
16096
|
+
},
|
|
16097
|
+
children: "Protocol Companion"
|
|
16098
|
+
}
|
|
16099
|
+
)
|
|
16100
|
+
] })
|
|
16101
|
+
] }),
|
|
16102
|
+
/* @__PURE__ */ jsxs("div", { style: { display: "flex", alignItems: "center", gap: tokens.spacing.xs }, children: [
|
|
16103
|
+
size === "sideDock" && /* @__PURE__ */ jsx(
|
|
16104
|
+
"button",
|
|
16105
|
+
{
|
|
16106
|
+
onClick: () => {
|
|
16107
|
+
},
|
|
16108
|
+
onMouseEnter: () => {
|
|
16109
|
+
},
|
|
16110
|
+
onMouseLeave: () => {
|
|
16111
|
+
},
|
|
16112
|
+
style: {
|
|
16113
|
+
...widgetStyles.closeBtn
|
|
16114
|
+
},
|
|
16115
|
+
title: "Expand",
|
|
16116
|
+
children: /* @__PURE__ */ jsx(ExpandIcon, {})
|
|
16117
|
+
}
|
|
16118
|
+
),
|
|
16119
|
+
/* @__PURE__ */ jsx(
|
|
16120
|
+
"button",
|
|
16121
|
+
{
|
|
16122
|
+
onClick: toggle,
|
|
16123
|
+
onMouseEnter: () => setCloseHovered(true),
|
|
16124
|
+
onMouseLeave: () => setCloseHovered(false),
|
|
16125
|
+
style: {
|
|
16126
|
+
...widgetStyles.closeBtn,
|
|
16127
|
+
...closeHovered ? widgetStyles.closeBtnHover : {}
|
|
16128
|
+
},
|
|
16129
|
+
title: "Close chat",
|
|
16130
|
+
children: size === "full" || size === "sideDock" ? /* @__PURE__ */ jsx(CloseIcon, {}) : /* @__PURE__ */ jsx(CloseIcon, {})
|
|
16131
|
+
}
|
|
16132
|
+
)
|
|
16133
|
+
] })
|
|
16068
16134
|
]
|
|
16069
16135
|
}
|
|
16070
16136
|
),
|
|
@@ -16072,7 +16138,7 @@ function HustleChatWidget({
|
|
|
16072
16138
|
]
|
|
16073
16139
|
}
|
|
16074
16140
|
),
|
|
16075
|
-
(size !== "full" || !isOpen) && /* @__PURE__ */ jsxs(
|
|
16141
|
+
(size !== "full" && size !== "sideDock" || !isOpen) && /* @__PURE__ */ jsxs(
|
|
16076
16142
|
"button",
|
|
16077
16143
|
{
|
|
16078
16144
|
onClick: toggle,
|
|
@@ -16088,7 +16154,7 @@ function HustleChatWidget({
|
|
|
16088
16154
|
title: isOpen ? "Close chat" : "Open chat",
|
|
16089
16155
|
"aria-label": isOpen ? "Close chat" : "Open chat",
|
|
16090
16156
|
children: [
|
|
16091
|
-
launcherIcon || /* @__PURE__ */ jsx(
|
|
16157
|
+
launcherIcon || /* @__PURE__ */ jsx(AgentHustleAvatar, { size: 40 }),
|
|
16092
16158
|
showBadge && badgeContent && !isOpen && /* @__PURE__ */ jsx("span", { style: widgetStyles.badge, children: badgeContent })
|
|
16093
16159
|
]
|
|
16094
16160
|
}
|
|
@@ -16182,6 +16248,6 @@ var DEFAULTS = {
|
|
|
16182
16248
|
EMBLEM_MODAL_URL: "https://emblemvault.ai/connect"
|
|
16183
16249
|
};
|
|
16184
16250
|
|
|
16185
|
-
export { DEFAULTS, HustleChat, HustleChatWidget, HustleProvider, MarkdownContent, STORAGE_KEYS, availablePlugins, debounce, formatFileSize, getAvailablePlugin, hydratePlugin, migrateFunPlugin, pluginRegistry, predictionMarketPlugin, tokens, useHustle, usePlugins };
|
|
16251
|
+
export { AGENT_HUSTLE_ICON, DEFAULTS, HustleChat, HustleChatWidget, HustleProvider, MarkdownContent, STORAGE_KEYS, availablePlugins, debounce, formatFileSize, getAvailablePlugin, hydratePlugin, migrateFunPlugin, pluginRegistry, predictionMarketPlugin, tokens, useHustle, usePlugins };
|
|
16186
16252
|
//# sourceMappingURL=hustle-react.js.map
|
|
16187
16253
|
//# sourceMappingURL=hustle-react.js.map
|