react-markdown-typer 0.0.1 → 1.0.0-beta.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.
- package/README.md +875 -0
- package/README.zh.md +8 -11
- package/es/Markdown/index.d.ts +5 -0
- package/es/Markdown/index.d.ts.map +1 -0
- package/es/Markdown/index.js +62 -0
- package/es/Markdown/index.js.map +1 -0
- package/es/MarkdownCMD/index.d.ts +4 -0
- package/es/MarkdownCMD/index.d.ts.map +1 -0
- package/es/MarkdownCMD/index.js +160 -0
- package/es/MarkdownCMD/index.js.map +1 -0
- package/es/components/HighReactMarkdown/index.d.ts +9 -0
- package/es/components/HighReactMarkdown/index.d.ts.map +1 -0
- package/es/components/HighReactMarkdown/index.js +7 -0
- package/es/components/HighReactMarkdown/index.js.map +1 -0
- package/es/constant.d.ts +4 -0
- package/es/constant.d.ts.map +1 -0
- package/es/constant.js +4 -0
- package/es/constant.js.map +1 -0
- package/{dist/cjs/index.d.ts → es/defined.d.ts} +47 -21
- package/es/defined.d.ts.map +1 -0
- package/es/defined.js +2 -0
- package/es/defined.js.map +1 -0
- package/es/hooks/useTypingTask.d.ts +32 -0
- package/es/hooks/useTypingTask.d.ts.map +1 -0
- package/{dist/esm/index.js → es/hooks/useTypingTask.js} +7 -260
- package/es/hooks/useTypingTask.js.map +1 -0
- package/es/index.d.ts +7 -0
- package/es/index.d.ts.map +1 -0
- package/es/index.js +5 -0
- package/es/index.js.map +1 -0
- package/package.json +11 -15
- package/dist/cjs/index.js +0 -570
- package/dist/cjs/index.js.map +0 -1
- package/dist/esm/index.d.ts +0 -77
- package/dist/esm/index.js.map +0 -1
package/README.zh.md
CHANGED
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
# react-markdown-typer
|
|
2
2
|
|
|
3
|
-
> 🚀
|
|
3
|
+
> 🚀 React Markdown 打字动画组件
|
|
4
4
|
|
|
5
|
-
|
|
5
|
+
**如果您需要带有样式,支持数据公式、mermaid图表渲染,推荐您用 [ds-markdown](https://github.com/onshinpei/ds-markdown)**
|
|
6
|
+
|
|
7
|
+
**🇨🇳 中文 | [🇺🇸 English](./README.md) **
|
|
6
8
|
|
|
7
9
|
一个专为现代 AI 应用设计的 React 组件,提供流畅的实时打字动画和完整的 Markdown 渲染能力。
|
|
8
10
|
|
|
@@ -14,7 +16,7 @@
|
|
|
14
16
|
|
|
15
17
|
[📖 在线演示](https://onshinpei.github.io/react-markdown-typer/)
|
|
16
18
|
|
|
17
|
-
[DEMO:🔧 StackBlitz 体验](https://stackblitz.com/edit/vitejs-vite-
|
|
19
|
+
[DEMO:🔧 StackBlitz 体验](https://stackblitz.com/edit/vitejs-vite-ndgqzcbp?file=README.md)
|
|
18
20
|
|
|
19
21
|
---
|
|
20
22
|
|
|
@@ -31,7 +33,7 @@
|
|
|
31
33
|
体积小、性能优,适配移动端和桌面端。核心依赖 [react-markdown](https://github.com/remarkjs/react-markdown)(业界主流、成熟的 Markdown 渲染库),无其它重量级依赖,开箱即用。
|
|
32
34
|
|
|
33
35
|
- **多主题与插件化架构**
|
|
34
|
-
|
|
36
|
+
兼容 [react-markdown](https://github.com/remarkjs/react-markdown) remark/rehype 插件,满足个性化和高级扩展需求。
|
|
35
37
|
|
|
36
38
|
- **适用场景广泛**
|
|
37
39
|
- AI 聊天机器人/助手
|
|
@@ -121,18 +123,14 @@ pnpm add react-markdown-typer
|
|
|
121
123
|
|
|
122
124
|
### 基础用法
|
|
123
125
|
|
|
124
|
-
|
|
126
|
+
[DEMO](https://stackblitz.com/edit/vitejs-vite-ndgqzcbp?file=src%2FApp.tsx)
|
|
125
127
|
|
|
126
128
|
```tsx
|
|
127
129
|
import MarkdownTyper from 'react-markdown-typer';
|
|
128
130
|
import 'react-markdown-typer/style.css';
|
|
129
131
|
|
|
130
132
|
function App() {
|
|
131
|
-
return
|
|
132
|
-
<MarkdownTyper interval={20} answerType="answer">
|
|
133
|
-
# Hello react-markdown-typer 这是一个**高性能**的打字动画组件! ## 特性 - ⚡ 零延迟流式处理 - 🎬 流畅打字动画 - 🎯 完美语法支持
|
|
134
|
-
</MarkdownTyper>
|
|
135
|
-
);
|
|
133
|
+
return <MarkdownTyper interval={20}># Hello react-markdown-typer 这是一个**高性能**的打字动画组件! ## 特性 - ⚡ 零延迟流式处理 - 🎬 流畅打字动画 - 🎯 完美语法支持</MarkdownTyper>;
|
|
136
134
|
}
|
|
137
135
|
```
|
|
138
136
|
|
|
@@ -439,7 +437,6 @@ import MarkdownTyper, { MarkdownCMD } from 'react-markdown-typer';
|
|
|
439
437
|
| `interval` | `number` | 打字间隔 (毫秒) | `30` |
|
|
440
438
|
| `timerType` | `'setTimeout'` \| `'requestAnimationFrame'` | 定时器类型,不支持动态修改 | 当前默认值是`setTimeout`,后期会改为`requestAnimationFrame` |
|
|
441
439
|
| `theme` | `'light'` \| `'dark'` | 主题类型 | `'light'` |
|
|
442
|
-
| `plugins` | `IMarkdownPlugin[]` | 插件配置 | `[]` |
|
|
443
440
|
| `math` | [IMarkdownMath](#IMarkdownMath) | 数学公式配置 | `{ splitSymbol: 'dollar' }` |
|
|
444
441
|
| `onEnd` | `(data: EndData) => void` | 打字结束回调 | - |
|
|
445
442
|
| `onStart` | `(data: StartData) => void` | 打字开始回调 | - |
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/Markdown/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA4E,MAAM,OAAO,CAAC;AAEjG,OAAO,EAAkB,aAAa,EAAe,MAAM,YAAY,CAAC;;AAoExE,wBAA8B"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { forwardRef, memo, useEffect, useImperativeHandle, useMemo, useRef } from 'react';
|
|
3
|
+
import { __DEV__ } from '../constant.js';
|
|
4
|
+
import MarkdownCMD from '../MarkdownCMD/index.js';
|
|
5
|
+
const MarkdownInner = ({ children: _children = '', markdownRef, ...rest }) => {
|
|
6
|
+
const cmdRef = useRef(null);
|
|
7
|
+
const prefixRef = useRef('');
|
|
8
|
+
const content = useMemo(() => {
|
|
9
|
+
if (typeof _children === 'string') {
|
|
10
|
+
return _children;
|
|
11
|
+
}
|
|
12
|
+
if (__DEV__) {
|
|
13
|
+
console.error('Markdown component must have a string child');
|
|
14
|
+
}
|
|
15
|
+
return '';
|
|
16
|
+
}, [_children]);
|
|
17
|
+
useEffect(() => {
|
|
18
|
+
if (prefixRef.current !== content) {
|
|
19
|
+
let newContent = '';
|
|
20
|
+
if (prefixRef.current === '') {
|
|
21
|
+
newContent = content;
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
if (content.startsWith(prefixRef.current)) {
|
|
25
|
+
newContent = content.slice(prefixRef.current.length);
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
newContent = content;
|
|
29
|
+
cmdRef.current.clear();
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
cmdRef.current.push(newContent);
|
|
33
|
+
prefixRef.current = content;
|
|
34
|
+
}
|
|
35
|
+
}, [content]);
|
|
36
|
+
useImperativeHandle(markdownRef, () => ({
|
|
37
|
+
stop: () => {
|
|
38
|
+
cmdRef.current.stop();
|
|
39
|
+
},
|
|
40
|
+
resume: () => {
|
|
41
|
+
cmdRef.current.resume();
|
|
42
|
+
},
|
|
43
|
+
start: () => {
|
|
44
|
+
cmdRef.current.start();
|
|
45
|
+
},
|
|
46
|
+
restart: () => {
|
|
47
|
+
cmdRef.current.restart();
|
|
48
|
+
},
|
|
49
|
+
}));
|
|
50
|
+
return _jsx(MarkdownCMD, { ref: cmdRef, ...rest });
|
|
51
|
+
};
|
|
52
|
+
const Markdown = forwardRef((props, ref) => {
|
|
53
|
+
const { children = '' } = props;
|
|
54
|
+
if (__DEV__) {
|
|
55
|
+
if (typeof children !== 'string') {
|
|
56
|
+
throw new Error('Markdown component must have a string child');
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
return _jsx(MarkdownInner, { ...props, markdownRef: ref });
|
|
60
|
+
});
|
|
61
|
+
export default memo(Markdown);
|
|
62
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/Markdown/index.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,IAAI,EAAE,SAAS,EAAE,mBAAmB,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AACjG,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAEtC,OAAO,WAAW,MAAM,gBAAgB,CAAC;AAMzC,MAAM,aAAa,GAAiC,CAAC,EAAE,QAAQ,EAAE,SAAS,GAAG,EAAE,EAAE,WAAW,EAAE,GAAG,IAAI,EAAE,EAAE,EAAE;IACzG,MAAM,MAAM,GAAG,MAAM,CAAiB,IAAK,CAAC,CAAC;IAC7C,MAAM,SAAS,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;IAC7B,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,EAAE;QAC3B,IAAI,OAAO,SAAS,KAAK,QAAQ,EAAE,CAAC;YAClC,OAAO,SAAS,CAAC;QACnB,CAAC;QACD,IAAI,OAAO,EAAE,CAAC;YACZ,OAAO,CAAC,KAAK,CAAC,6CAA6C,CAAC,CAAC;QAC/D,CAAC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;IAEhB,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,SAAS,CAAC,OAAO,KAAK,OAAO,EAAE,CAAC;YAClC,IAAI,UAAU,GAAG,EAAE,CAAC;YACpB,IAAI,SAAS,CAAC,OAAO,KAAK,EAAE,EAAE,CAAC;gBAC7B,UAAU,GAAG,OAAO,CAAC;YACvB,CAAC;iBAAM,CAAC;gBACN,IAAI,OAAO,CAAC,UAAU,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC;oBAC1C,UAAU,GAAG,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;gBACvD,CAAC;qBAAM,CAAC;oBACN,UAAU,GAAG,OAAO,CAAC;oBACrB,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;gBACzB,CAAC;YACH,CAAC;YACD,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAChC,SAAS,CAAC,OAAO,GAAG,OAAO,CAAC;QAC9B,CAAC;IACH,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;IAEd,mBAAmB,CAAC,WAAW,EAAE,GAAG,EAAE,CAAC,CAAC;QACtC,IAAI,EAAE,GAAG,EAAE;YACT,MAAM,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;QACxB,CAAC;QACD,MAAM,EAAE,GAAG,EAAE;YACX,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;QAC1B,CAAC;QACD,KAAK,EAAE,GAAG,EAAE;YACV,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACzB,CAAC;QACD,OAAO,EAAE,GAAG,EAAE;YACZ,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;QAC3B,CAAC;KACF,CAAC,CAAC,CAAC;IAEJ,OAAO,KAAC,WAAW,IAAC,GAAG,EAAE,MAAM,KAAM,IAAI,GAAI,CAAC;AAChD,CAAC,CAAC;AAEF,MAAM,QAAQ,GAAG,UAAU,CAA6B,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;IACrE,MAAM,EAAE,QAAQ,GAAG,EAAE,EAAE,GAAG,KAAK,CAAC;IAEhC,IAAI,OAAO,EAAE,CAAC;QACZ,IAAI,OAAO,QAAQ,KAAK,QAAQ,EAAE,CAAC;YACjC,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAC;QACjE,CAAC;IACH,CAAC;IAED,OAAO,KAAC,aAAa,OAAK,KAAK,EAAE,WAAW,EAAE,GAAG,GAAI,CAAC;AACxD,CAAC,CAAC,CAAC;AAEH,eAAe,IAAI,CAAC,QAAQ,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/MarkdownCMD/index.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAwB,cAAc,EAAE,MAAM,YAAY,CAAC;AAMpF,QAAA,MAAM,WAAW,6GA2KhB,CAAC;AAMF,eAAe,WAAW,CAAC"}
|
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { forwardRef, useImperativeHandle, useRef, useState } from 'react';
|
|
3
|
+
import { __DEV__ } from '../constant.js';
|
|
4
|
+
import { useTypingTask } from '../hooks/useTypingTask.js';
|
|
5
|
+
import HighReactMarkdown from '../components/HighReactMarkdown/index.js';
|
|
6
|
+
const MarkdownCMD = forwardRef(({ interval = 30, onEnd, onStart, onTypedChar, onBeforeTypedChar, timerType = 'setTimeout', math, reactMarkdownProps, disableTyping = false, autoStartTyping = true }, ref) => {
|
|
7
|
+
/** 是否自动开启打字动画, 后面发生变化将不会生效 */
|
|
8
|
+
const autoStartTypingRef = useRef(autoStartTyping);
|
|
9
|
+
/** 是否打过字 */
|
|
10
|
+
const isStartedTypingRef = useRef(false);
|
|
11
|
+
/** 当前需要打字的内容 */
|
|
12
|
+
const charsRef = useRef([]);
|
|
13
|
+
/**
|
|
14
|
+
* 打字是否已经完全结束
|
|
15
|
+
* 如果打字已经完全结束,则不会再触发打字效果
|
|
16
|
+
*/
|
|
17
|
+
const isWholeTypedEndRef = useRef(false);
|
|
18
|
+
const charIndexRef = useRef(0);
|
|
19
|
+
/** 整个内容引用 */
|
|
20
|
+
const wholeContentRef = useRef({
|
|
21
|
+
content: '',
|
|
22
|
+
length: 0,
|
|
23
|
+
prevLength: 0,
|
|
24
|
+
});
|
|
25
|
+
const [, setUpdate] = useState(0);
|
|
26
|
+
const triggerUpdate = () => {
|
|
27
|
+
setUpdate((prev) => prev + 1);
|
|
28
|
+
};
|
|
29
|
+
/**
|
|
30
|
+
* 处理字符显示逻辑
|
|
31
|
+
*/
|
|
32
|
+
const processCharDisplay = (char) => {
|
|
33
|
+
if (!isStartedTypingRef.current) {
|
|
34
|
+
isStartedTypingRef.current = true;
|
|
35
|
+
}
|
|
36
|
+
wholeContentRef.current.prevLength = wholeContentRef.current.length;
|
|
37
|
+
wholeContentRef.current.content += char.content;
|
|
38
|
+
wholeContentRef.current.length += char.content.length;
|
|
39
|
+
triggerUpdate();
|
|
40
|
+
};
|
|
41
|
+
const resetWholeContent = () => {
|
|
42
|
+
wholeContentRef.current.content = '';
|
|
43
|
+
wholeContentRef.current.length = 0;
|
|
44
|
+
wholeContentRef.current.prevLength = 0;
|
|
45
|
+
};
|
|
46
|
+
// 使用新的打字任务 hook
|
|
47
|
+
const typingTask = useTypingTask({
|
|
48
|
+
timerType,
|
|
49
|
+
interval,
|
|
50
|
+
charsRef,
|
|
51
|
+
onEnd,
|
|
52
|
+
onStart,
|
|
53
|
+
onTypedChar,
|
|
54
|
+
onBeforeTypedChar,
|
|
55
|
+
processCharDisplay,
|
|
56
|
+
wholeContentRef,
|
|
57
|
+
disableTyping,
|
|
58
|
+
triggerUpdate,
|
|
59
|
+
resetWholeContent,
|
|
60
|
+
});
|
|
61
|
+
/**
|
|
62
|
+
* 内部推送处理逻辑
|
|
63
|
+
*/
|
|
64
|
+
const processHasTypingPush = (content) => {
|
|
65
|
+
if (content.length === 0) {
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
charsRef.current.push(...content.split('').map((chatStr) => {
|
|
69
|
+
const index = charIndexRef.current++;
|
|
70
|
+
const charObj = {
|
|
71
|
+
content: chatStr,
|
|
72
|
+
tokenId: 0,
|
|
73
|
+
index,
|
|
74
|
+
};
|
|
75
|
+
return charObj;
|
|
76
|
+
}));
|
|
77
|
+
// 如果关闭了自动打字, 并且没有打过字, 则不开启打字动画
|
|
78
|
+
if (!autoStartTypingRef.current && !isStartedTypingRef.current) {
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
if (!typingTask.isTyping()) {
|
|
82
|
+
typingTask.start();
|
|
83
|
+
}
|
|
84
|
+
};
|
|
85
|
+
const processNoTypingPush = (content) => {
|
|
86
|
+
wholeContentRef.current.content += content;
|
|
87
|
+
// 记录打字前的长度
|
|
88
|
+
wholeContentRef.current.prevLength = wholeContentRef.current.length;
|
|
89
|
+
wholeContentRef.current.length += content.length;
|
|
90
|
+
triggerUpdate();
|
|
91
|
+
onEnd === null || onEnd === void 0 ? void 0 : onEnd({
|
|
92
|
+
str: content,
|
|
93
|
+
manual: false,
|
|
94
|
+
});
|
|
95
|
+
};
|
|
96
|
+
useImperativeHandle(ref, () => ({
|
|
97
|
+
/**
|
|
98
|
+
* 添加内容
|
|
99
|
+
* @param content 内容 {string}
|
|
100
|
+
* @param answerType 回答类型 {AnswerType}
|
|
101
|
+
*/
|
|
102
|
+
push: (content) => {
|
|
103
|
+
if (disableTyping) {
|
|
104
|
+
processNoTypingPush(content);
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
107
|
+
processHasTypingPush(content);
|
|
108
|
+
},
|
|
109
|
+
/**
|
|
110
|
+
* 清除打字任务
|
|
111
|
+
*/
|
|
112
|
+
clear: () => {
|
|
113
|
+
typingTask.stop();
|
|
114
|
+
typingTask.typedIsManualStopRef.current = false;
|
|
115
|
+
charsRef.current = [];
|
|
116
|
+
resetWholeContent();
|
|
117
|
+
isWholeTypedEndRef.current = false;
|
|
118
|
+
charIndexRef.current = 0;
|
|
119
|
+
isStartedTypingRef.current = false;
|
|
120
|
+
triggerUpdate();
|
|
121
|
+
},
|
|
122
|
+
/** 开启打字,只有在关闭了自动打字才生效 */
|
|
123
|
+
start: () => {
|
|
124
|
+
if (!autoStartTypingRef.current) {
|
|
125
|
+
typingTask.start();
|
|
126
|
+
}
|
|
127
|
+
},
|
|
128
|
+
/** 停止打字任务 */
|
|
129
|
+
stop: () => {
|
|
130
|
+
typingTask.stop();
|
|
131
|
+
},
|
|
132
|
+
/** 重新开始打字任务 */
|
|
133
|
+
resume: () => {
|
|
134
|
+
typingTask.resume();
|
|
135
|
+
},
|
|
136
|
+
/**
|
|
137
|
+
* 主动触发打字结束
|
|
138
|
+
*/
|
|
139
|
+
triggerWholeEnd: () => {
|
|
140
|
+
isWholeTypedEndRef.current = true;
|
|
141
|
+
if (!typingTask.isTyping()) {
|
|
142
|
+
// 这里需要手动触发结束回调,因为 hook 中的 triggerOnEnd 不能直接调用
|
|
143
|
+
onEnd === null || onEnd === void 0 ? void 0 : onEnd({
|
|
144
|
+
str: wholeContentRef.current.content,
|
|
145
|
+
manual: true,
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
},
|
|
149
|
+
/** 重新开始打字任务 */
|
|
150
|
+
restart: () => {
|
|
151
|
+
typingTask.restart();
|
|
152
|
+
},
|
|
153
|
+
}));
|
|
154
|
+
return _jsx(HighReactMarkdown, { reactMarkdownProps: reactMarkdownProps, children: wholeContentRef.current.content });
|
|
155
|
+
});
|
|
156
|
+
if (__DEV__) {
|
|
157
|
+
MarkdownCMD.displayName = 'MarkdownCMD';
|
|
158
|
+
}
|
|
159
|
+
export default MarkdownCMD;
|
|
160
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/MarkdownCMD/index.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Options } from 'react-markdown';
|
|
3
|
+
interface HighReactMarkdownProps {
|
|
4
|
+
reactMarkdownProps?: Options;
|
|
5
|
+
children: string;
|
|
6
|
+
}
|
|
7
|
+
declare const HighReactMarkdown: React.FC<HighReactMarkdownProps>;
|
|
8
|
+
export default HighReactMarkdown;
|
|
9
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/HighReactMarkdown/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAkB,MAAM,OAAO,CAAC;AACvC,OAAsB,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AAExD,UAAU,sBAAsB;IAC9B,kBAAkB,CAAC,EAAE,OAAO,CAAC;IAC7B,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,QAAA,MAAM,iBAAiB,EAAE,KAAK,CAAC,EAAE,CAAC,sBAAsB,CAEvD,CAAC;AAEF,eAAe,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import ReactMarkdown from 'react-markdown';
|
|
3
|
+
const HighReactMarkdown = ({ reactMarkdownProps, children }) => {
|
|
4
|
+
return _jsx(ReactMarkdown, { ...reactMarkdownProps, children: children });
|
|
5
|
+
};
|
|
6
|
+
export default HighReactMarkdown;
|
|
7
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/HighReactMarkdown/index.tsx"],"names":[],"mappings":";AACA,OAAO,aAA0B,MAAM,gBAAgB,CAAC;AAOxD,MAAM,iBAAiB,GAAqC,CAAC,EAAE,kBAAkB,EAAE,QAAQ,EAAE,EAAE,EAAE;IAC/F,OAAO,KAAC,aAAa,OAAK,kBAAkB,YAAG,QAAQ,GAAiB,CAAC;AAC3E,CAAC,CAAC;AAEF,eAAe,iBAAiB,CAAC"}
|
package/es/constant.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constant.d.ts","sourceRoot":"","sources":["../src/constant.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,OAAO,SAAyC,CAAC;AAE9D,eAAe;AACf,eAAO,MAAM,OAAO,eAAkB,CAAC"}
|
package/es/constant.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constant.js","sourceRoot":"","sources":["../src/constant.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,aAAa,CAAC;AAE9D,eAAe;AACf,MAAM,CAAC,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC"}
|
|
@@ -1,20 +1,41 @@
|
|
|
1
|
-
import * as react from 'react';
|
|
2
|
-
import react__default from 'react';
|
|
3
1
|
import { Options } from 'react-markdown';
|
|
4
|
-
|
|
5
|
-
|
|
2
|
+
/**
|
|
3
|
+
* 字符接口
|
|
4
|
+
*/
|
|
5
|
+
export interface IChar {
|
|
6
|
+
content: string;
|
|
7
|
+
tokenId: number;
|
|
8
|
+
/** 字符索引 */
|
|
9
|
+
index: number;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* 段落类型
|
|
13
|
+
* 段落类型为br时,表示换行
|
|
14
|
+
* 段落类型为text时,表示文本
|
|
15
|
+
*/
|
|
16
|
+
export interface IParagraph {
|
|
17
|
+
/** 段落内容 */
|
|
18
|
+
content?: string;
|
|
19
|
+
/** 是否已打字 */
|
|
20
|
+
isTyped: boolean;
|
|
21
|
+
}
|
|
22
|
+
export interface ITokensReference {
|
|
23
|
+
startIndex: number;
|
|
24
|
+
raw: string;
|
|
25
|
+
}
|
|
26
|
+
export interface IOnTypedCharData {
|
|
6
27
|
currentIndex: number;
|
|
7
28
|
currentChar: string;
|
|
8
29
|
prevStr: string;
|
|
9
30
|
}
|
|
10
|
-
interface ITypedChar extends IOnTypedCharData {
|
|
31
|
+
export interface ITypedChar extends IOnTypedCharData {
|
|
11
32
|
percent: number;
|
|
12
33
|
currentStr: string;
|
|
13
34
|
}
|
|
14
|
-
interface IBeforeTypedChar extends IOnTypedCharData {
|
|
35
|
+
export interface IBeforeTypedChar extends IOnTypedCharData {
|
|
15
36
|
percent: number;
|
|
16
37
|
}
|
|
17
|
-
interface MarkdownBaseProps {
|
|
38
|
+
export interface MarkdownBaseProps {
|
|
18
39
|
reactMarkdownProps?: Options;
|
|
19
40
|
/** 计时类型: 支持setTimeout和requestAnimationFrame */
|
|
20
41
|
timerType?: 'setTimeout' | 'requestAnimationFrame';
|
|
@@ -38,40 +59,45 @@ interface MarkdownBaseProps {
|
|
|
38
59
|
autoStartTyping?: boolean;
|
|
39
60
|
math?: IMarkdownMath;
|
|
40
61
|
}
|
|
41
|
-
interface MarkdownProps extends MarkdownBaseProps {
|
|
62
|
+
export interface MarkdownProps extends MarkdownBaseProps {
|
|
42
63
|
children: string | undefined;
|
|
43
64
|
}
|
|
44
65
|
/** MarkdownCMD 组件不需要 children */
|
|
45
|
-
interface MarkdownCMDProps extends MarkdownBaseProps {
|
|
66
|
+
export interface MarkdownCMDProps extends MarkdownBaseProps {
|
|
46
67
|
children?: undefined;
|
|
47
68
|
}
|
|
48
|
-
interface
|
|
69
|
+
export interface IMarkdownPlugin {
|
|
70
|
+
remarkPlugin?: unknown;
|
|
71
|
+
rehypePlugin?: unknown;
|
|
72
|
+
type: 'buildIn' | 'custom';
|
|
73
|
+
id?: any;
|
|
74
|
+
}
|
|
75
|
+
export interface IMarkdownMath {
|
|
49
76
|
/** 是括号还是$作为分隔符, 默认是$ */
|
|
50
77
|
splitSymbol: 'bracket' | 'dollar';
|
|
51
78
|
}
|
|
52
|
-
interface
|
|
79
|
+
export interface IWholeContent {
|
|
80
|
+
content: string;
|
|
81
|
+
length: number;
|
|
82
|
+
prevLength: number;
|
|
83
|
+
}
|
|
84
|
+
export interface MarkdownBaseRef {
|
|
53
85
|
stop: () => void;
|
|
54
86
|
resume: () => void;
|
|
55
87
|
start: () => void;
|
|
56
88
|
restart: () => void;
|
|
57
89
|
}
|
|
58
90
|
/** Markdown 组件的ref 类型 */
|
|
59
|
-
type MarkdownRef = MarkdownBaseRef;
|
|
91
|
+
export type MarkdownRef = MarkdownBaseRef;
|
|
60
92
|
/** MarkdownCMD 组件的 ref 类型 */
|
|
61
|
-
interface MarkdownCMDRef extends MarkdownBaseRef {
|
|
93
|
+
export interface MarkdownCMDRef extends MarkdownBaseRef {
|
|
62
94
|
push: (content: string) => void;
|
|
63
95
|
clear: () => void;
|
|
64
96
|
triggerWholeEnd: () => void;
|
|
65
97
|
}
|
|
66
|
-
interface IEndData {
|
|
98
|
+
export interface IEndData {
|
|
67
99
|
manual: boolean;
|
|
68
100
|
/** 打字机打过的字符串, 和answerStr 相同 */
|
|
69
101
|
str: string;
|
|
70
102
|
}
|
|
71
|
-
|
|
72
|
-
declare const MarkdownCMD: react.ForwardRefExoticComponent<MarkdownCMDProps & react.RefAttributes<MarkdownCMDRef>>;
|
|
73
|
-
|
|
74
|
-
declare const _default: react__default.NamedExoticComponent<MarkdownProps & react__default.RefAttributes<MarkdownBaseRef>>;
|
|
75
|
-
|
|
76
|
-
export { _default as Markdown, MarkdownCMD, _default as default };
|
|
77
|
-
export type { IMarkdownMath, ITypedChar, MarkdownCMDProps, MarkdownCMDRef, MarkdownProps, MarkdownRef };
|
|
103
|
+
//# sourceMappingURL=defined.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"defined.d.ts","sourceRoot":"","sources":["../src/defined.ts"],"names":[],"mappings":"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"}
|
package/es/defined.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"defined.js","sourceRoot":"","sources":["../src/defined.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { IChar, ITypedChar, IWholeContent, MarkdownProps, IEndData, IBeforeTypedChar } from '../defined';
|
|
2
|
+
interface UseTypingTaskOptions {
|
|
3
|
+
timerType: MarkdownProps['timerType'];
|
|
4
|
+
interval: number;
|
|
5
|
+
charsRef: React.RefObject<IChar[]>;
|
|
6
|
+
onEnd?: (data?: IEndData) => void;
|
|
7
|
+
onStart?: (data?: {
|
|
8
|
+
currentIndex: number;
|
|
9
|
+
currentChar: string;
|
|
10
|
+
prevStr: string;
|
|
11
|
+
}) => void;
|
|
12
|
+
onBeforeTypedChar?: (data?: IBeforeTypedChar) => Promise<void>;
|
|
13
|
+
onTypedChar?: (data?: ITypedChar) => void;
|
|
14
|
+
processCharDisplay: (char: IChar) => void;
|
|
15
|
+
wholeContentRef: React.RefObject<IWholeContent>;
|
|
16
|
+
disableTyping: boolean;
|
|
17
|
+
triggerUpdate: () => void;
|
|
18
|
+
resetWholeContent: () => void;
|
|
19
|
+
}
|
|
20
|
+
export interface TypingTaskController {
|
|
21
|
+
start: () => void;
|
|
22
|
+
stop: () => void;
|
|
23
|
+
clear: () => void;
|
|
24
|
+
isTyping: () => boolean;
|
|
25
|
+
/** 是否主动调用 stop 方法 */
|
|
26
|
+
typedIsManualStopRef: React.RefObject<boolean>;
|
|
27
|
+
resume: () => void;
|
|
28
|
+
restart: () => void;
|
|
29
|
+
}
|
|
30
|
+
export declare const useTypingTask: (options: UseTypingTaskOptions) => TypingTaskController;
|
|
31
|
+
export {};
|
|
32
|
+
//# sourceMappingURL=useTypingTask.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useTypingTask.d.ts","sourceRoot":"","sources":["../../src/hooks/useTypingTask.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,aAAa,EAAE,aAAa,EAAE,QAAQ,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAEzG,UAAU,oBAAoB;IAC5B,SAAS,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC;IACtC,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC;IACnC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,QAAQ,KAAK,IAAI,CAAC;IAClC,OAAO,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE;QAAE,YAAY,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,KAAK,IAAI,CAAC;IAC1F,iBAAiB,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,gBAAgB,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC/D,WAAW,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,UAAU,KAAK,IAAI,CAAC;IAC1C,kBAAkB,EAAE,CAAC,IAAI,EAAE,KAAK,KAAK,IAAI,CAAC;IAC1C,eAAe,EAAE,KAAK,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;IAChD,aAAa,EAAE,OAAO,CAAC;IACvB,aAAa,EAAE,MAAM,IAAI,CAAC;IAC1B,iBAAiB,EAAE,MAAM,IAAI,CAAC;CAC/B;AAED,MAAM,WAAW,oBAAoB;IACnC,KAAK,EAAE,MAAM,IAAI,CAAC;IAClB,IAAI,EAAE,MAAM,IAAI,CAAC;IACjB,KAAK,EAAE,MAAM,IAAI,CAAC;IAClB,QAAQ,EAAE,MAAM,OAAO,CAAC;IACxB,qBAAqB;IACrB,oBAAoB,EAAE,KAAK,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;IAC/C,MAAM,EAAE,MAAM,IAAI,CAAC;IACnB,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB;AAED,eAAO,MAAM,aAAa,GAAI,SAAS,oBAAoB,KAAG,oBAmX7D,CAAC"}
|