@lobehub/ui 1.29.0 → 1.29.1

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.
@@ -16,5 +16,4 @@ export declare const Provider: ({ createStore, children }: {
16
16
  destroy: () => void;
17
17
  };
18
18
  export { type MessageDispatch, messagesReducer } from './messageReducer';
19
- export * from './selectors';
20
19
  export type { ChatStore } from './store';
@@ -12,5 +12,4 @@ var _createContext = createContext(),
12
12
  useStore = _createContext.useStore,
13
13
  useStoreApi = _createContext.useStoreApi;
14
14
  export { Provider, useStore, useStoreApi };
15
- export { messagesReducer } from "./messageReducer";
16
- export * from "./selectors";
15
+ export { messagesReducer } from "./messageReducer";
package/es/index.d.ts CHANGED
@@ -8,7 +8,6 @@ export { default as ChatItem, type ChatItemProps } from './ChatItem';
8
8
  export { default as ChatList, type ChatListProps } from './ChatList';
9
9
  export { default as ColorScales, type ColorScalesProps } from './ColorScales';
10
10
  export { default as ContextMenu, type ContextMenuProps } from './ContextMenu';
11
- export { default as Conversation, type ConversationProps } from './Conversation';
12
11
  export { default as CopyButton, type CopyButtonProps } from './CopyButton';
13
12
  export { default as DraggablePanel, type DraggablePanelProps } from './DraggablePanel';
14
13
  export { default as EditableMessage, type EditableMessageProps } from './EditableMessage';
package/es/index.js CHANGED
@@ -7,7 +7,6 @@ export { default as ChatItem } from "./ChatItem";
7
7
  export { default as ChatList } from "./ChatList";
8
8
  export { default as ColorScales } from "./ColorScales";
9
9
  export { default as ContextMenu } from "./ContextMenu";
10
- export { default as Conversation } from "./Conversation";
11
10
  export { default as CopyButton } from "./CopyButton";
12
11
  export { default as DraggablePanel } from "./DraggablePanel";
13
12
  export { default as EditableMessage } from "./EditableMessage";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lobehub/ui",
3
- "version": "1.29.0",
3
+ "version": "1.29.1",
4
4
  "description": "Lobe UI is an open-source UI component library for building chatbot web apps",
5
5
  "keywords": [
6
6
  "lobehub",
@@ -73,7 +73,6 @@
73
73
  "@ant-design/colors": "^7",
74
74
  "@ant-design/icons": "^5",
75
75
  "@babel/runtime": "^7",
76
- "@dqbd/tiktoken": "^1",
77
76
  "@floating-ui/react": "^0",
78
77
  "@react-spring/web": "^9",
79
78
  "ahooks": "^3",
@@ -1,9 +0,0 @@
1
- import type { ChatStore } from './store';
2
- export declare const chatSelectors: {
3
- agentTokenCount: (s: ChatStore) => number;
4
- disableInput: (s: ChatStore) => boolean;
5
- messagesTokenCount: (s: ChatStore) => number;
6
- messagesTokens: (s: ChatStore) => number[];
7
- totalTokenCount: (s: ChatStore) => number;
8
- totalTokens: (s: ChatStore) => number[];
9
- };
@@ -1,44 +0,0 @@
1
- import { get_encoding } from '@dqbd/tiktoken';
2
- var tiktoken = get_encoding('cl100k_base');
3
- var encode = function encode(text) {
4
- if (!text) return [];
5
- var tokens = tiktoken.encode(text);
6
- return tokens;
7
- };
8
- var disableInputSel = function disableInputSel(s) {
9
- return s.changingSystemRole;
10
- };
11
- var messagesTokens = function messagesTokens(s) {
12
- return encode(s.messages.map(function (m) {
13
- return m.content;
14
- }).join(''));
15
- };
16
- var agentContentTokens = function agentContentTokens(s) {
17
- return encode(s.messages.filter(function (s) {
18
- return s.role === 'system';
19
- }).map(function (c) {
20
- return c.content;
21
- }).join('') || '');
22
- };
23
- var totalTokens = function totalTokens(s) {
24
- return encode(s.messages.map(function (m) {
25
- return m.content;
26
- }).join(''));
27
- };
28
- var totalTokenCount = function totalTokenCount(s) {
29
- return totalTokens(s).length;
30
- };
31
- var agentTokenCount = function agentTokenCount(s) {
32
- return agentContentTokens(s).length;
33
- };
34
- var messagesTokenCount = function messagesTokenCount(s) {
35
- return messagesTokens(s).length;
36
- };
37
- export var chatSelectors = {
38
- agentTokenCount: agentTokenCount,
39
- disableInput: disableInputSel,
40
- messagesTokenCount: messagesTokenCount,
41
- messagesTokens: messagesTokens,
42
- totalTokenCount: totalTokenCount,
43
- totalTokens: totalTokens
44
- };
@@ -1,15 +0,0 @@
1
- /// <reference types="react" />
2
- export interface AppProps {
3
- /**
4
- * @description Whether to include system messages in the chat.
5
- * @default true
6
- */
7
- includeSystem?: boolean;
8
- /**
9
- * @description Whether the component is in readonly mode.
10
- * @default false
11
- */
12
- readonly?: boolean;
13
- }
14
- declare const _default: import("react").NamedExoticComponent<AppProps>;
15
- export default _default;
@@ -1,43 +0,0 @@
1
- import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
2
- import { Typography } from 'antd';
3
- import isEqual from 'fast-deep-equal';
4
- import { memo } from 'react';
5
- import { Flexbox } from 'react-layout-kit';
6
- import { useStore } from "../Chat/store";
7
- import ChatList from "./ChatList";
8
- import InputArea from "./InputArea";
9
- import { jsx as _jsx } from "react/jsx-runtime";
10
- import { jsxs as _jsxs } from "react/jsx-runtime";
11
- var ChatContainer = function ChatContainer(_ref) {
12
- var readonly = _ref.readonly,
13
- _ref$includeSystem = _ref.includeSystem,
14
- includeSystem = _ref$includeSystem === void 0 ? true : _ref$includeSystem;
15
- var _useStore = useStore(function (s) {
16
- return [!s.changingSystemRole, s.title, s.description];
17
- }, isEqual),
18
- _useStore2 = _slicedToArray(_useStore, 3),
19
- showInput = _useStore2[0],
20
- title = _useStore2[1],
21
- description = _useStore2[2];
22
- if (readonly) return /*#__PURE__*/_jsx(ChatList, {
23
- includeSystem: includeSystem,
24
- readonly: true
25
- });
26
- return /*#__PURE__*/_jsxs(Flexbox, {
27
- gap: 24,
28
- height: '100%',
29
- width: '100%',
30
- children: [title || description ? /*#__PURE__*/_jsxs(Flexbox, {
31
- children: [/*#__PURE__*/_jsx(Typography.Title, {
32
- level: 4,
33
- children: title
34
- }), /*#__PURE__*/_jsx(Typography.Text, {
35
- type: 'secondary',
36
- children: description
37
- })]
38
- }) : undefined, /*#__PURE__*/_jsx(ChatList, {
39
- includeSystem: includeSystem
40
- }), showInput ? /*#__PURE__*/_jsx(InputArea, {}) : undefined]
41
- });
42
- };
43
- export default /*#__PURE__*/memo(ChatContainer);
@@ -1,8 +0,0 @@
1
- import { FC } from 'react';
2
- import { ChatMessage } from "../../../Chat/types";
3
- export interface ContentProps extends Pick<ChatMessage, 'content' | 'role' | 'error'> {
4
- index: number;
5
- loading: boolean;
6
- }
7
- declare const Content: FC<ContentProps>;
8
- export default Content;
@@ -1,104 +0,0 @@
1
- import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
2
- import { LoadingOutlined } from '@ant-design/icons';
3
- import { Alert, Button } from 'antd';
4
- import { memo } from 'react';
5
- import { shallow } from 'zustand/shallow';
6
- import { useStore } from "../../../Chat/store";
7
- import Markdown from "../../../Markdown";
8
- import MessageInput from "../../../MessageInput";
9
- import { jsx as _jsx } from "react/jsx-runtime";
10
- import { jsxs as _jsxs } from "react/jsx-runtime";
11
- import { Fragment as _Fragment } from "react/jsx-runtime";
12
- var Content = /*#__PURE__*/memo(function (_ref) {
13
- var content = _ref.content,
14
- role = _ref.role,
15
- index = _ref.index,
16
- error = _ref.error,
17
- loading = _ref.loading;
18
- var _useStore = useStore(function (s) {
19
- return [s.editingMessageId, s.dispatchMessage, s.handleMessageEditing, s.resendMessage];
20
- }, shallow),
21
- _useStore2 = _slicedToArray(_useStore, 4),
22
- editingMessageId = _useStore2[0],
23
- dispatchMessage = _useStore2[1],
24
- handleMessageEditing = _useStore2[2],
25
- resendMessage = _useStore2[3];
26
- var isEditing = editingMessageId === index;
27
- var isUser = role === 'user';
28
- if (isEditing) {
29
- return /*#__PURE__*/_jsx(MessageInput, {
30
- defaultValue: content,
31
- renderButtons: function renderButtons(text) {
32
- return [{
33
- children: isUser ? '更新并重新生成' : '更新',
34
- onClick: function onClick() {
35
- dispatchMessage({
36
- index: index,
37
- message: text,
38
- type: 'updateMessage'
39
- });
40
- handleMessageEditing();
41
-
42
- // 如果是用户的消息,那么重新生成下一条消息
43
- if (isUser) {
44
- resendMessage(index + 1);
45
- }
46
- },
47
- type: 'primary'
48
- }, isUser ? {
49
- children: '仅更新',
50
- onClick: function onClick() {
51
- dispatchMessage({
52
- index: index,
53
- message: text,
54
- type: 'updateMessage'
55
- });
56
- handleMessageEditing();
57
- }
58
- } : undefined, {
59
- children: '取消',
60
- onClick: function onClick() {
61
- return handleMessageEditing();
62
- },
63
- type: 'text'
64
- }].filter(Boolean);
65
- }
66
- });
67
- }
68
- return /*#__PURE__*/_jsxs(_Fragment, {
69
- children: [loading ? error ? undefined : /*#__PURE__*/_jsx("div", {
70
- children: /*#__PURE__*/_jsx(LoadingOutlined, {
71
- spin: true,
72
- style: {
73
- fontSize: 20
74
- }
75
- })
76
- }) : /*#__PURE__*/_jsx(Markdown, {
77
- children: content
78
- }), error && /*#__PURE__*/_jsx(Alert, {
79
- action: /*#__PURE__*/_jsx(Button, {
80
- onClick: function onClick() {
81
- return resendMessage(index);
82
- },
83
- children: "\u91CD\u8BD5"
84
- }),
85
- description: error.type === 'openai' ? /*#__PURE__*/_jsxs("div", {
86
- children: [error.message, " \uFF08\u9519\u8BEF\u7801\uFF1A", /*#__PURE__*/_jsx("code", {
87
- children: error.status
88
- }), "\uFF0C\u8BE6\u60C5\u53EF\u67E5\u770B", ' ', /*#__PURE__*/_jsx("a", {
89
- href: "https://platform.openai.com/docs/guides/error-codes",
90
- rel: "noreferrer",
91
- target: '_blank',
92
- children: "\u5B98\u65B9\u6587\u6863"
93
- }), "\uFF09"]
94
- }) : error.message,
95
- message: error.type === 'openai' ? "\u8BF7\u6C42 OpenAI \u670D\u52A1\u51FA\u9519" : "\u4F1A\u8BDD\u51FA\u9519\u5566\uFF08\u9519\u8BEF\u7801 ".concat(error.status, "\uFF09"),
96
- showIcon: true,
97
- style: {
98
- marginTop: 12
99
- },
100
- type: 'error'
101
- })]
102
- });
103
- });
104
- export default Content;
@@ -1,10 +0,0 @@
1
- import { FC } from 'react';
2
- export interface ToolbarProps {
3
- className?: string;
4
- content: string;
5
- index: number;
6
- isUser?: boolean;
7
- readonly?: boolean;
8
- }
9
- declare const Toolbar: FC<ToolbarProps>;
10
- export default Toolbar;
@@ -1,91 +0,0 @@
1
- import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
2
- import _taggedTemplateLiteral from "@babel/runtime/helpers/esm/taggedTemplateLiteral";
3
- var _templateObject;
4
- import { Popconfirm } from 'antd';
5
- import { createStyles } from 'antd-style';
6
- import { EditIcon, RotateCwIcon, TrashIcon } from 'lucide-react';
7
- import { rgba } from 'polished';
8
- import { memo } from 'react';
9
- import { Flexbox } from 'react-layout-kit';
10
- import { shallow } from 'zustand/shallow';
11
- import IconAction from "../../../ActionIcon";
12
- import { useStore } from "../../../Chat/store";
13
- import CopyButton from "../../../CopyButton";
14
- import { jsx as _jsx } from "react/jsx-runtime";
15
- import { Fragment as _Fragment } from "react/jsx-runtime";
16
- import { jsxs as _jsxs } from "react/jsx-runtime";
17
- var useStyles = createStyles(function (_ref) {
18
- var css = _ref.css,
19
- token = _ref.token,
20
- stylish = _ref.stylish,
21
- cx = _ref.cx;
22
- return {
23
- container: cx(stylish.blur, css(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n background: ", ";\n border-radius: 4px;\n "])), rgba(token.colorBgElevated, 0.2)))
24
- };
25
- });
26
- var Toolbar = /*#__PURE__*/memo(function (_ref2) {
27
- var content = _ref2.content,
28
- isUser = _ref2.isUser,
29
- index = _ref2.index,
30
- readonly = _ref2.readonly,
31
- className = _ref2.className;
32
- var _useStyles = useStyles(),
33
- styles = _useStyles.styles,
34
- cx = _useStyles.cx;
35
- var _useStore = useStore(function (s) {
36
- return [s.dispatchMessage, s.handleMessageEditing, s.resendMessage];
37
- }, shallow),
38
- _useStore2 = _slicedToArray(_useStore, 3),
39
- dispatchMessage = _useStore2[0],
40
- handleMessageEditing = _useStore2[1],
41
- resendMessage = _useStore2[2];
42
- return /*#__PURE__*/_jsxs(Flexbox, {
43
- className: cx(className, styles.container),
44
- gap: 4,
45
- horizontal: true,
46
- children: [/*#__PURE__*/_jsx(CopyButton, {
47
- content: content,
48
- placement: 'top',
49
- size: 'small',
50
- title: '复制'
51
- }), readonly ? undefined : /*#__PURE__*/_jsxs(_Fragment, {
52
- children: [/*#__PURE__*/_jsx(IconAction, {
53
- icon: RotateCwIcon,
54
- onClick: function onClick() {
55
- resendMessage(isUser ? index + 1 : index);
56
- },
57
- placement: 'top',
58
- size: 'small',
59
- title: isUser ? '重新生成回答' : '重新生成'
60
- }), /*#__PURE__*/_jsx(IconAction, {
61
- icon: EditIcon,
62
- onClick: function onClick() {
63
- return handleMessageEditing(index);
64
- },
65
- placement: 'top',
66
- size: 'small',
67
- title: '编辑'
68
- }), /*#__PURE__*/_jsx(Popconfirm, {
69
- okButtonProps: {
70
- danger: true
71
- },
72
- onConfirm: function onConfirm() {
73
- dispatchMessage({
74
- index: index,
75
- type: 'deleteMessage'
76
- });
77
- },
78
- title: '确定要删除这条消息吗?',
79
- children: /*#__PURE__*/_jsx(IconAction
80
- // type={'danger'}
81
- , {
82
- icon: TrashIcon,
83
- placement: 'top',
84
- size: 'small',
85
- title: '删除'
86
- })
87
- })]
88
- })]
89
- });
90
- });
91
- export default Toolbar;
@@ -1,9 +0,0 @@
1
- import { FC } from 'react';
2
- import { ChatMessage } from "../../../Chat/types";
3
- export interface MessageItemProps extends ChatMessage {
4
- index: number;
5
- readonly?: boolean;
6
- userAvatarImg?: string;
7
- }
8
- declare const MessageItem: FC<MessageItemProps>;
9
- export default MessageItem;
@@ -1,126 +0,0 @@
1
- import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
2
- import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
3
- import _taggedTemplateLiteral from "@babel/runtime/helpers/esm/taggedTemplateLiteral";
4
- var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8;
5
- import { ConfigProvider, Divider, Typography } from 'antd';
6
- import { createStyles, useResponsive } from 'antd-style';
7
- import { memo, useState } from 'react';
8
- import { Center, Flexbox } from 'react-layout-kit';
9
- import { shallow } from 'zustand/shallow';
10
- import Avatar from "../../../Avatar";
11
- import { LOADING_FLAT } from "../../../Chat/const";
12
- import { useStore } from "../../../Chat/store";
13
- import Content from "./Content";
14
- import Toolbar from "./Toolbar";
15
- import { jsx as _jsx } from "react/jsx-runtime";
16
- import { jsxs as _jsxs } from "react/jsx-runtime";
17
- import { Fragment as _Fragment } from "react/jsx-runtime";
18
- var useStyles = createStyles(function (_ref) {
19
- var css = _ref.css,
20
- cx = _ref.cx,
21
- responsive = _ref.responsive,
22
- token = _ref.token;
23
- var toolbarClassName = 'chat-float-toolbar';
24
- return {
25
- assistant: css(_templateObject || (_templateObject = _taggedTemplateLiteral([""]))),
26
- choice: css(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["\n cursor: pointer;\n\n width: 20px;\n height: 20px;\n\n font-size: 12px;\n color: ", ";\n\n background: ", ";\n border-radius: 50%;\n "])), token.colorTextTertiary, token.colorFillContent),
27
- choiceActive: css(_templateObject3 || (_templateObject3 = _taggedTemplateLiteral(["\n color: ", ";\n background: ", ";\n "])), token.colorTextLightSolid, token.colorPrimary),
28
- container: css(_templateObject4 || (_templateObject4 = _taggedTemplateLiteral(["\n position: relative;\n padding: 12px;\n border-radius: 4px;\n\n ", " {\n padding-inline: 0;\n }\n\n &:hover {\n background: ", ";\n\n .", " {\n opacity: 1;\n }\n }\n "])), responsive.mobile, token.colorFillQuaternary, toolbarClassName),
29
- floatAction: cx(toolbarClassName, css(_templateObject5 || (_templateObject5 = _taggedTemplateLiteral(["\n position: absolute;\n z-index: ", ";\n top: 4px;\n right: 4px;\n\n opacity: 0;\n "])), token.zIndexPopupBase - 100)),
30
- md: css(_templateObject6 || (_templateObject6 = _taggedTemplateLiteral(["\n overflow-x: hidden;\n overflow-y: auto;\n max-width: 100%;\n .", " {\n max-width: 100%;\n }\n "])), responsive.mobile),
31
- system: css(_templateObject7 || (_templateObject7 = _taggedTemplateLiteral(["\n filter: invert(1);\n "]))),
32
- user: css(_templateObject8 || (_templateObject8 = _taggedTemplateLiteral(["\n background: linear-gradient(to right, ", ", ", ");\n "])), token.green3, token.gold3)
33
- };
34
- });
35
- var MessageItem = /*#__PURE__*/memo(function (_ref2) {
36
- var content = _ref2.content,
37
- error = _ref2.error,
38
- userAvatarImg = _ref2.userAvatarImg,
39
- choices = _ref2.choices,
40
- role = _ref2.role,
41
- index = _ref2.index,
42
- readonly = _ref2.readonly;
43
- var _useStyles = useStyles(),
44
- styles = _useStyles.styles,
45
- cx = _useStyles.cx;
46
- var _useResponsive = useResponsive(),
47
- mobile = _useResponsive.mobile;
48
- var _useState = useState(0),
49
- _useState2 = _slicedToArray(_useState, 2),
50
- activeChoice = _useState2[0],
51
- setActiveChoice = _useState2[1];
52
- var _useStore = useStore(function (s) {
53
- return [s.editingMessageId];
54
- }, shallow),
55
- _useStore2 = _slicedToArray(_useStore, 1),
56
- editingMessageId = _useStore2[0];
57
- var isEditing = editingMessageId === index;
58
- var fullChoices = choices ? [content].concat(_toConsumableArray(choices)) : [content];
59
- var displayContent = fullChoices[activeChoice];
60
- var isSystem = role === 'system';
61
- var isUser = role === 'user';
62
- return /*#__PURE__*/_jsxs(_Fragment, {
63
- children: [/*#__PURE__*/_jsxs(Flexbox, {
64
- className: styles.container,
65
- gap: 12,
66
- horizontal: true,
67
- id: "message-item-".concat(index),
68
- children: [isEditing || mobile ? undefined : /*#__PURE__*/_jsx(Toolbar, {
69
- className: styles.floatAction,
70
- content: content,
71
- index: index,
72
- isUser: isUser,
73
- readonly: readonly
74
- }), /*#__PURE__*/_jsxs(Flexbox, {
75
- align: 'center',
76
- gap: 8,
77
- children: [/*#__PURE__*/_jsx(ConfigProvider, {
78
- theme: {
79
- token: {
80
- fontSize: 14
81
- }
82
- },
83
- children: /*#__PURE__*/_jsx(Avatar, {
84
- avatar: role === 'user' ? userAvatarImg : '',
85
- shape: 'circle'
86
- // className={cx(styles[role])}
87
- })
88
- }), choices ? fullChoices.map(function (choice, index) {
89
- return /*#__PURE__*/_jsx(Center, {
90
- className: cx(styles.choice, activeChoice === index && styles.choiceActive),
91
- onClick: function onClick() {
92
- setActiveChoice(index);
93
- },
94
- onKeyDown: function onKeyDown(e) {
95
- if (e.key === 'Enter') {
96
- setActiveChoice(index);
97
- }
98
- },
99
- tabIndex: 10,
100
- children: index + 1
101
- }, index);
102
- }) : undefined]
103
- }), /*#__PURE__*/_jsx(Flexbox, {
104
- className: styles.md,
105
- flex: 1,
106
- children: /*#__PURE__*/_jsx(Content, {
107
- content: displayContent,
108
- error: error,
109
- index: index,
110
- loading: displayContent === LOADING_FLAT,
111
- role: role
112
- })
113
- })]
114
- }), isSystem && /*#__PURE__*/_jsx(Divider, {
115
- children: /*#__PURE__*/_jsx(Typography.Text, {
116
- style: {
117
- fontSize: 14,
118
- fontWeight: 'normal'
119
- },
120
- type: 'secondary',
121
- children: "\u5F00\u59CB\u5BF9\u8BDD"
122
- })
123
- })]
124
- });
125
- });
126
- export default MessageItem;
@@ -1,14 +0,0 @@
1
- import { CSSProperties, FC } from 'react';
2
- interface ChatListProps {
3
- /**
4
- * @title 是否包含系统消息
5
- */
6
- includeSystem?: boolean;
7
- /**
8
- * @title 是否只读
9
- */
10
- readonly?: boolean;
11
- style?: CSSProperties;
12
- }
13
- declare const ChatList: FC<ChatListProps>;
14
- export default ChatList;
@@ -1,62 +0,0 @@
1
- import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
2
- import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
3
- import _taggedTemplateLiteral from "@babel/runtime/helpers/esm/taggedTemplateLiteral";
4
- var _templateObject, _templateObject2;
5
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
6
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
7
- import { createStyles } from 'antd-style';
8
- import isEqual from 'fast-deep-equal';
9
- import { memo } from 'react';
10
- import { Center, Flexbox } from 'react-layout-kit';
11
- import { useStore } from "../../Chat/store";
12
- import MessageItem from "./MessageItem";
13
- import { jsx as _jsx } from "react/jsx-runtime";
14
- import { jsxs as _jsxs } from "react/jsx-runtime";
15
- var useStyles = createStyles(function (_ref) {
16
- var css = _ref.css,
17
- token = _ref.token;
18
- return {
19
- btn: css(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n font-size: 12px;\n color: ", ";\n background: transparent;\n border: 2px solid ", " !important;\n "])), token.colorTextSecondary, token.colorBorderSecondary),
20
- loading: css(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["\n padding: 12px;\n background: ", ";\n border-radius: 8px;\n "])), token.colorFillQuaternary)
21
- };
22
- });
23
- var ChatList = /*#__PURE__*/memo(function (_ref2) {
24
- var readonly = _ref2.readonly,
25
- _ref2$includeSystem = _ref2.includeSystem,
26
- includeSystem = _ref2$includeSystem === void 0 ? false : _ref2$includeSystem,
27
- style = _ref2.style;
28
- // const [messages, loading] = useStore((s) => [s.messages, s.loading], isEqual);
29
- var _useStyles = useStyles(),
30
- styles = _useStyles.styles;
31
- var _useStore = useStore(function (s) {
32
- return [s.messages, s.loading];
33
- }, isEqual),
34
- _useStore2 = _slicedToArray(_useStore, 2),
35
- messages = _useStore2[0],
36
- loading = _useStore2[1];
37
- return !messages || messages.length === 0 ? undefined : /*#__PURE__*/_jsxs(Flexbox, {
38
- gap: 8,
39
- style: style,
40
- children: [messages
41
- // 根据情况确认是否包含系统
42
- .filter(function (s) {
43
- return includeSystem ? Boolean(s) : s.role !== 'system';
44
- }).map(function (item, index) {
45
- return /*#__PURE__*/_jsx(MessageItem, _objectSpread({
46
- index: index,
47
- readonly: readonly
48
- }, item), index);
49
- }), loading ? /*#__PURE__*/_jsx(Center, {
50
- className: styles.loading,
51
- id: 'for-loading',
52
- children: /*#__PURE__*/_jsxs(Flexbox, {
53
- align: 'center',
54
- distribution: 'space-between',
55
- gap: 24,
56
- horizontal: true,
57
- children: [/*#__PURE__*/_jsx("div", {}), "\u6B63\u5728\u751F\u6210...", /*#__PURE__*/_jsx("div", {})]
58
- })
59
- }) : undefined]
60
- });
61
- });
62
- export default ChatList;
@@ -1,4 +0,0 @@
1
- /// <reference types="react" />
2
- export declare const ActionBar: () => import("react/jsx-runtime").JSX.Element | undefined;
3
- declare const _default: import("react").NamedExoticComponent<object>;
4
- export default _default;
@@ -1,71 +0,0 @@
1
- import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
2
- import _taggedTemplateLiteral from "@babel/runtime/helpers/esm/taggedTemplateLiteral";
3
- var _templateObject;
4
- import { ConfigProvider, Popconfirm, Tooltip } from 'antd';
5
- import { createStyles } from 'antd-style';
6
- import { EraserIcon } from 'lucide-react';
7
- import { memo } from 'react';
8
- import { Flexbox } from 'react-layout-kit';
9
- import { shallow } from 'zustand/shallow';
10
- import IconAction from "../../ActionIcon";
11
- import { chatSelectors, useStore } from "../../Chat/store";
12
- import { jsx as _jsx } from "react/jsx-runtime";
13
- import { jsxs as _jsxs } from "react/jsx-runtime";
14
- var useStyles = createStyles(function (_ref) {
15
- var css = _ref.css,
16
- token = _ref.token;
17
- return {
18
- extra: css(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n color: ", ";\n "])), token.colorTextTertiary)
19
- };
20
- });
21
- export var ActionBar = function ActionBar() {
22
- var _useStore = useStore(function (s) {
23
- return [chatSelectors.totalTokenCount(s), chatSelectors.agentTokenCount(s), chatSelectors.messagesTokenCount(s), s.dispatchMessage];
24
- }, shallow),
25
- _useStore2 = _slicedToArray(_useStore, 4),
26
- totalToken = _useStore2[0],
27
- agentToken = _useStore2[1],
28
- messagesToken = _useStore2[2],
29
- dispatchMessage = _useStore2[3];
30
- var _useStyles = useStyles(),
31
- styles = _useStyles.styles,
32
- theme = _useStyles.theme;
33
- return totalToken > 0 ? /*#__PURE__*/_jsx(ConfigProvider, {
34
- theme: {
35
- token: {
36
- colorText: theme.colorTextSecondary
37
- }
38
- },
39
- children: /*#__PURE__*/_jsxs(Flexbox, {
40
- align: 'center',
41
- className: styles.extra,
42
- direction: 'horizontal-reverse',
43
- gap: 8,
44
- paddingInline: 12,
45
- children: [/*#__PURE__*/_jsx(Popconfirm, {
46
- okButtonProps: {
47
- danger: true
48
- },
49
- okText: '清空会话',
50
- onConfirm: function onConfirm() {
51
- dispatchMessage({
52
- type: 'resetMessages'
53
- });
54
- },
55
- title: '你即将要清空会话,清空后将无法找回。是否清空当前会话?',
56
- children: /*#__PURE__*/_jsx(IconAction, {
57
- icon: EraserIcon,
58
- size: 'small',
59
- title: '清空当前会话'
60
- })
61
- }), /*#__PURE__*/_jsx(Tooltip, {
62
- title: [agentToken > 0 ? "\u89D2\u8272\u5B9A\u4E49: ".concat(agentToken) : undefined, messagesToken > 0 ? "\u4F1A\u8BDD: ".concat(messagesToken) : undefined].filter(Boolean).join(' | '),
63
- children: /*#__PURE__*/_jsxs(Flexbox, {
64
- gap: 4,
65
- children: [" Tokens: ", totalToken]
66
- })
67
- })]
68
- })
69
- }) : undefined;
70
- };
71
- export default /*#__PURE__*/memo(ActionBar);
@@ -1,4 +0,0 @@
1
- /// <reference types="react" />
2
- export declare const InputArea: () => import("react/jsx-runtime").JSX.Element;
3
- declare const _default: import("react").MemoExoticComponent<() => import("react/jsx-runtime").JSX.Element>;
4
- export default _default;
@@ -1,99 +0,0 @@
1
- import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
2
- import _taggedTemplateLiteral from "@babel/runtime/helpers/esm/taggedTemplateLiteral";
3
- var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
4
- import { SendOutlined } from '@ant-design/icons';
5
- import { Button, ConfigProvider, Input } from 'antd';
6
- import { createStyles, useResponsive } from 'antd-style';
7
- import { memo, useRef } from 'react';
8
- import { Flexbox } from 'react-layout-kit';
9
- import { shallow } from 'zustand/shallow';
10
- import { chatSelectors, useStore, useStoreApi } from "../../Chat/store";
11
- import ActionBar from "./ActionBar";
12
- import { jsx as _jsx } from "react/jsx-runtime";
13
- import { jsxs as _jsxs } from "react/jsx-runtime";
14
- var useStyles = createStyles(function (_ref) {
15
- var css = _ref.css,
16
- responsive = _ref.responsive,
17
- token = _ref.token;
18
- return {
19
- boxShadow: css(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n position: relative;\n border-radius: 8px;\n box-shadow: ", ";\n "])), token.boxShadowSecondary),
20
- btn: css(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["\n position: absolute;\n z-index: 10;\n right: 8px;\n bottom: 8px;\n\n color: ", ";\n\n &:hover {\n color: ", ";\n }\n "])), token.colorTextTertiary, token.colorTextSecondary),
21
- container: css(_templateObject3 || (_templateObject3 = _taggedTemplateLiteral(["\n position: sticky;\n z-index: ", ";\n bottom: 0;\n\n padding-top: 12px;\n padding-bottom: 24px;\n\n background-image: linear-gradient(to top, ", " 88%, transparent 100%);\n\n ", " {\n width: 100%;\n }\n "])), token.zIndexPopupBase, token.colorBgLayout, responsive.mobile),
22
- extra: css(_templateObject4 || (_templateObject4 = _taggedTemplateLiteral(["\n color: ", ";\n "])), token.colorTextTertiary),
23
- input: css(_templateObject5 || (_templateObject5 = _taggedTemplateLiteral(["\n width: 100%;\n border-radius: 8px;\n "])))
24
- };
25
- });
26
- export var InputArea = function InputArea() {
27
- var _useStore = useStore(function (s) {
28
- return [s.message, s.sendMessage, s.loading, chatSelectors.disableInput(s)];
29
- }, shallow),
30
- _useStore2 = _slicedToArray(_useStore, 4),
31
- message = _useStore2[0],
32
- sendMessage = _useStore2[1],
33
- isLoading = _useStore2[2],
34
- disabled = _useStore2[3];
35
- var isChineseInput = useRef(false);
36
- var _useStyles = useStyles(),
37
- styles = _useStyles.styles,
38
- theme = _useStyles.theme;
39
- var _useResponsive = useResponsive(),
40
- mobile = _useResponsive.mobile;
41
- var storeApi = useStoreApi();
42
- return /*#__PURE__*/_jsx(ConfigProvider, {
43
- theme: {
44
- token: {
45
- borderRadius: 4,
46
- colorBgContainer: theme.colorBgElevated,
47
- colorBorder: 'transparent',
48
- colorPrimaryHover: 'transparent',
49
- controlHeightLG: 48,
50
- fontSize: 16
51
- }
52
- },
53
- children: /*#__PURE__*/_jsxs(Flexbox, {
54
- className: styles.container,
55
- gap: 8,
56
- children: [/*#__PURE__*/_jsx(ActionBar, {}), /*#__PURE__*/_jsxs(Flexbox, {
57
- align: 'center',
58
- className: styles.boxShadow,
59
- gap: 8,
60
- horizontal: true,
61
- children: [/*#__PURE__*/_jsx(Input.TextArea, {
62
- autoSize: {
63
- maxRows: 8
64
- },
65
- className: styles.input,
66
- disabled: disabled,
67
- onChange: function onChange(e) {
68
- storeApi.setState({
69
- message: e.target.value
70
- });
71
- },
72
- onCompositionEnd: function onCompositionEnd() {
73
- isChineseInput.current = false;
74
- },
75
- onCompositionStart: function onCompositionStart() {
76
- isChineseInput.current = true;
77
- },
78
- onPressEnter: function onPressEnter(e) {
79
- if (!isLoading && !e.shiftKey && !isChineseInput.current) {
80
- e.preventDefault();
81
- sendMessage();
82
- }
83
- },
84
- placeholder: "\u8BF7\u8F93\u5165\u5185\u5BB9...",
85
- size: 'large',
86
- value: message
87
- }), mobile ? undefined : /*#__PURE__*/_jsx(Button, {
88
- className: styles.btn,
89
- disabled: disabled,
90
- icon: /*#__PURE__*/_jsx(SendOutlined, {}),
91
- loading: isLoading,
92
- onClick: sendMessage,
93
- type: "text"
94
- })]
95
- })]
96
- })
97
- });
98
- };
99
- export default /*#__PURE__*/memo(InputArea);
@@ -1,7 +0,0 @@
1
- import { FC } from 'react';
2
- import { ChatStore } from '../Chat/store';
3
- import { InternalChatContext } from '../Chat/types';
4
- export interface StoreUpdaterProps extends Partial<InternalChatContext>, Pick<ChatStore, 'onMessagesChange' | 'onAgentChange' | 'onResponseFinished' | 'onResponseStart'> {
5
- }
6
- declare const StoreUpdater: FC<StoreUpdaterProps>;
7
- export default StoreUpdater;
@@ -1,25 +0,0 @@
1
- import { createStoreUpdater } from 'zustand-utils';
2
- import { useStoreApi } from "../Chat/store";
3
- var StoreUpdater = function StoreUpdater(_ref) {
4
- var updateAt = _ref.updateAt,
5
- createAt = _ref.createAt,
6
- title = _ref.title,
7
- description = _ref.description,
8
- messages = _ref.messages,
9
- onAgentChange = _ref.onAgentChange,
10
- onMessagesChange = _ref.onMessagesChange,
11
- onResponseFinished = _ref.onResponseFinished,
12
- onResponseStart = _ref.onResponseStart;
13
- var useStoreUpdater = createStoreUpdater(useStoreApi());
14
- useStoreUpdater('onAgentChange', onAgentChange);
15
- useStoreUpdater('messages', messages);
16
- useStoreUpdater('onMessagesChange', onMessagesChange);
17
- useStoreUpdater('onResponseFinished', onResponseFinished);
18
- useStoreUpdater('onResponseStart', onResponseStart);
19
- useStoreUpdater('title', title);
20
- useStoreUpdater('description', description);
21
- useStoreUpdater('createAt', createAt);
22
- useStoreUpdater('updateAt', updateAt);
23
- return false;
24
- };
25
- export default StoreUpdater;
@@ -1,12 +0,0 @@
1
- /// <reference types="react" />
2
- import { AppProps } from './App';
3
- import { StoreUpdaterProps } from './StoreUpdater';
4
- export interface ConversationProps extends StoreUpdaterProps, AppProps {
5
- /**
6
- * @description Whether to enable devtools or not
7
- * @default false
8
- */
9
- devtools?: boolean;
10
- }
11
- declare const Conversation: import("react").NamedExoticComponent<ConversationProps>;
12
- export default Conversation;
@@ -1,28 +0,0 @@
1
- import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
2
- import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
3
- var _excluded = ["readonly", "devtools", "includeSystem"];
4
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
5
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
6
- import { memo, useRef } from 'react';
7
- import { Provider, createChatStore } from "../Chat/store";
8
- import ChatContainer from "./App";
9
- import StoreUpdater from "./StoreUpdater";
10
- import { jsx as _jsx } from "react/jsx-runtime";
11
- import { jsxs as _jsxs } from "react/jsx-runtime";
12
- var Conversation = /*#__PURE__*/memo(function (_ref) {
13
- var readonly = _ref.readonly,
14
- devtools = _ref.devtools,
15
- includeSystem = _ref.includeSystem,
16
- res = _objectWithoutProperties(_ref, _excluded);
17
- var reference = useRef(function () {
18
- return createChatStore(devtools);
19
- });
20
- return /*#__PURE__*/_jsxs(Provider, {
21
- createStore: reference.current,
22
- children: [/*#__PURE__*/_jsx(ChatContainer, {
23
- includeSystem: includeSystem,
24
- readonly: readonly
25
- }), /*#__PURE__*/_jsx(StoreUpdater, _objectSpread({}, res))]
26
- });
27
- });
28
- export default Conversation;