zs_library 0.0.1 → 0.1.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 +4 -4
- package/dist/Editor/Blocks/CodeBlock/CodeBlock.d.ts +23 -0
- package/dist/Editor/Blocks/CodeBlock/CodeBlock.js +196 -0
- package/dist/Editor/Blocks/CodeBlock/index.d.ts +30 -0
- package/dist/Editor/Blocks/CodeBlock/index.js +21 -0
- package/dist/Editor/index.d.ts +16 -0
- package/dist/Editor/index.js +133 -0
- package/dist/index.d.ts +1 -1
- package/dist/index.js +1 -1
- package/package.json +41 -36
- package/dist/Foo/index.d.ts +0 -5
- package/dist/Foo/index.js +0 -5
package/README.md
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
#
|
|
1
|
+
# zs_library
|
|
2
2
|
|
|
3
|
-
[](https://npmjs.org/package/zs_library)
|
|
4
|
+
[](https://npmjs.org/package/zs_library)
|
|
5
5
|
|
|
6
|
-
|
|
6
|
+
个人业务组件库 React
|
|
7
7
|
|
|
8
8
|
## Usage
|
|
9
9
|
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/// <reference types="ace-builds/ace-modules" />
|
|
2
|
+
import { ReactCustomBlockRenderProps } from '@blocknote/react';
|
|
3
|
+
import '@mantine/core/styles.css';
|
|
4
|
+
import 'ace-builds/src-noconflict/ace';
|
|
5
|
+
import 'ace-builds/src-noconflict/ext-beautify';
|
|
6
|
+
import 'ace-builds/src-noconflict/ext-language_tools';
|
|
7
|
+
import 'ace-builds/src-noconflict/mode-css';
|
|
8
|
+
import 'ace-builds/src-noconflict/mode-dockerfile';
|
|
9
|
+
import 'ace-builds/src-noconflict/mode-html';
|
|
10
|
+
import 'ace-builds/src-noconflict/mode-javascript';
|
|
11
|
+
import 'ace-builds/src-noconflict/mode-json';
|
|
12
|
+
import 'ace-builds/src-noconflict/mode-text';
|
|
13
|
+
import 'ace-builds/src-noconflict/mode-typescript';
|
|
14
|
+
import 'ace-builds/src-noconflict/theme-cloud9_day';
|
|
15
|
+
import 'ace-builds/src-noconflict/theme-cloud9_night';
|
|
16
|
+
import 'ace-builds/src-noconflict/theme-cloud_editor';
|
|
17
|
+
import 'ace-builds/src-noconflict/theme-cloud_editor_dark';
|
|
18
|
+
import 'ace-builds/src-noconflict/theme-github';
|
|
19
|
+
import 'ace-builds/src-noconflict/theme-github_dark';
|
|
20
|
+
import 'ace-builds/src-noconflict/theme-monokai';
|
|
21
|
+
import { FC } from 'react';
|
|
22
|
+
declare const CodeBlock: FC<ReactCustomBlockRenderProps<any, any, any>>;
|
|
23
|
+
export default CodeBlock;
|
|
@@ -0,0 +1,196 @@
|
|
|
1
|
+
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7;
|
|
2
|
+
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
3
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
4
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
5
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
6
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
7
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
8
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
9
|
+
import { css, cx } from '@emotion/css';
|
|
10
|
+
import { Menu, Tooltip, UnstyledButton } from '@mantine/core';
|
|
11
|
+
import '@mantine/core/styles.css';
|
|
12
|
+
import { RiCheckLine, RiFileCopyLine } from '@remixicon/react';
|
|
13
|
+
import 'ace-builds/src-noconflict/ace';
|
|
14
|
+
import 'ace-builds/src-noconflict/ext-beautify';
|
|
15
|
+
import 'ace-builds/src-noconflict/ext-language_tools';
|
|
16
|
+
import 'ace-builds/src-noconflict/mode-css';
|
|
17
|
+
import 'ace-builds/src-noconflict/mode-dockerfile';
|
|
18
|
+
import 'ace-builds/src-noconflict/mode-html';
|
|
19
|
+
import 'ace-builds/src-noconflict/mode-javascript';
|
|
20
|
+
import 'ace-builds/src-noconflict/mode-json';
|
|
21
|
+
import 'ace-builds/src-noconflict/mode-text';
|
|
22
|
+
import 'ace-builds/src-noconflict/mode-typescript';
|
|
23
|
+
import 'ace-builds/src-noconflict/theme-cloud9_day';
|
|
24
|
+
import 'ace-builds/src-noconflict/theme-cloud9_night';
|
|
25
|
+
import 'ace-builds/src-noconflict/theme-cloud_editor';
|
|
26
|
+
import 'ace-builds/src-noconflict/theme-cloud_editor_dark';
|
|
27
|
+
import 'ace-builds/src-noconflict/theme-github';
|
|
28
|
+
import 'ace-builds/src-noconflict/theme-github_dark';
|
|
29
|
+
import 'ace-builds/src-noconflict/theme-monokai';
|
|
30
|
+
import { motion } from 'framer-motion';
|
|
31
|
+
import React, { useState } from 'react';
|
|
32
|
+
import AceEditor from 'react-ace';
|
|
33
|
+
var languages = [{
|
|
34
|
+
title: 'Text',
|
|
35
|
+
value: 'text'
|
|
36
|
+
}, {
|
|
37
|
+
title: 'JavaScript',
|
|
38
|
+
value: 'javascript'
|
|
39
|
+
}, {
|
|
40
|
+
title: 'TypeScript',
|
|
41
|
+
value: 'typescript'
|
|
42
|
+
}, {
|
|
43
|
+
title: 'JSON',
|
|
44
|
+
value: 'json'
|
|
45
|
+
}, {
|
|
46
|
+
title: 'HTML',
|
|
47
|
+
value: 'html'
|
|
48
|
+
}, {
|
|
49
|
+
title: 'CSS',
|
|
50
|
+
value: 'css'
|
|
51
|
+
}, {
|
|
52
|
+
title: 'Dockerfile',
|
|
53
|
+
value: 'dockerfile'
|
|
54
|
+
}];
|
|
55
|
+
var themes = [{
|
|
56
|
+
title: 'Github',
|
|
57
|
+
value: 'github'
|
|
58
|
+
}, {
|
|
59
|
+
title: 'Github Dark',
|
|
60
|
+
value: 'github_dark'
|
|
61
|
+
}, {
|
|
62
|
+
title: 'Monokai',
|
|
63
|
+
value: 'monokai'
|
|
64
|
+
}, {
|
|
65
|
+
title: 'Cloud9 Day',
|
|
66
|
+
value: 'cloud9_day'
|
|
67
|
+
}, {
|
|
68
|
+
title: 'Cloud9 Night',
|
|
69
|
+
value: 'cloud9_night'
|
|
70
|
+
}, {
|
|
71
|
+
title: 'Cloud Editor',
|
|
72
|
+
value: 'cloud_editor'
|
|
73
|
+
}, {
|
|
74
|
+
title: 'Cloud Editor Dark',
|
|
75
|
+
value: 'cloud_editor_dark'
|
|
76
|
+
}];
|
|
77
|
+
var CodeBlock = function CodeBlock(props) {
|
|
78
|
+
var _block$content$0$text, _block$content$, _languages$find, _themes$find;
|
|
79
|
+
var block = props.block,
|
|
80
|
+
editor = props.editor;
|
|
81
|
+
var _block$props = block.props,
|
|
82
|
+
language = _block$props.language,
|
|
83
|
+
theme = _block$props.theme;
|
|
84
|
+
|
|
85
|
+
// eslint-disable-next-line react-hooks/rules-of-hooks
|
|
86
|
+
var _useState = useState(false),
|
|
87
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
88
|
+
copyed = _useState2[0],
|
|
89
|
+
setCopyed = _useState2[1];
|
|
90
|
+
|
|
91
|
+
// @ts-ignore
|
|
92
|
+
var code = (_block$content$0$text = (_block$content$ = block.content[0]) === null || _block$content$ === void 0 ? void 0 : _block$content$.text) !== null && _block$content$0$text !== void 0 ? _block$content$0$text : '';
|
|
93
|
+
var languageTitle = (_languages$find = languages.find(function (item) {
|
|
94
|
+
return item.value === language;
|
|
95
|
+
})) === null || _languages$find === void 0 ? void 0 : _languages$find.title;
|
|
96
|
+
var themeTitle = (_themes$find = themes.find(function (item) {
|
|
97
|
+
return item.value === theme;
|
|
98
|
+
})) === null || _themes$find === void 0 ? void 0 : _themes$find.title;
|
|
99
|
+
var editable = editor.isEditable;
|
|
100
|
+
var menuButtonCss = css(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n cursor: pointer;\n padding: 0.25rem 0.5rem;\n font-size: 0.75rem;\n font-weight: bold;\n "])));
|
|
101
|
+
return /*#__PURE__*/React.createElement("div", {
|
|
102
|
+
className: cx("ace-".concat(theme.replace('_', '-')), "ace-".concat(theme.replace('-', '_')), css(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["\n overflow: hidden;\n border-radius: 0.5rem;\n width: 100%;\n position: relative;\n "]))), !editable && css(_templateObject3 || (_templateObject3 = _taggedTemplateLiteral(["\n &:hover .code-block-copy {\n opacity: 100;\n }\n "])))),
|
|
103
|
+
onMouseLeave: function onMouseLeave() {
|
|
104
|
+
setCopyed(false);
|
|
105
|
+
}
|
|
106
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
107
|
+
className: css(_templateObject4 || (_templateObject4 = _taggedTemplateLiteral(["\n display: inline-flex;\n justify-content: start;\n align-items: center;\n margin-bottom: 0.25rem;\n background-color: rgba(243, 244, 246, 0.1);\n border-radius: 0.25rem 0.25rem 0 0;\n "])))
|
|
108
|
+
}, /*#__PURE__*/React.createElement(Menu, {
|
|
109
|
+
withinPortal: false,
|
|
110
|
+
zIndex: 999999,
|
|
111
|
+
disabled: !editable
|
|
112
|
+
}, /*#__PURE__*/React.createElement(Menu.Target, null, /*#__PURE__*/React.createElement("div", {
|
|
113
|
+
className: menuButtonCss,
|
|
114
|
+
contentEditable: false
|
|
115
|
+
}, languageTitle !== null && languageTitle !== void 0 ? languageTitle : language)), /*#__PURE__*/React.createElement(Menu.Dropdown, null, /*#__PURE__*/React.createElement(Menu.Label, null, "\u8BED\u8A00"), languages.map(function (type) {
|
|
116
|
+
return /*#__PURE__*/React.createElement(Menu.Item, {
|
|
117
|
+
key: type.value,
|
|
118
|
+
onClick: function onClick() {
|
|
119
|
+
return props.editor.updateBlock(block, {
|
|
120
|
+
type: 'codeBlock',
|
|
121
|
+
props: {
|
|
122
|
+
language: type.value
|
|
123
|
+
}
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
}, type.title);
|
|
127
|
+
}))), editable && /*#__PURE__*/React.createElement(Menu, {
|
|
128
|
+
withinPortal: false,
|
|
129
|
+
zIndex: 999999
|
|
130
|
+
}, /*#__PURE__*/React.createElement(Menu.Target, null, /*#__PURE__*/React.createElement("div", {
|
|
131
|
+
className: menuButtonCss,
|
|
132
|
+
contentEditable: false
|
|
133
|
+
}, themeTitle !== null && themeTitle !== void 0 ? themeTitle : theme)), /*#__PURE__*/React.createElement(Menu.Dropdown, null, /*#__PURE__*/React.createElement(Menu.Label, null, "\u4E3B\u9898"), themes.map(function (type) {
|
|
134
|
+
return /*#__PURE__*/React.createElement(Menu.Item, {
|
|
135
|
+
key: type.value,
|
|
136
|
+
onClick: function onClick() {
|
|
137
|
+
return props.editor.updateBlock(block, {
|
|
138
|
+
type: 'codeBlock',
|
|
139
|
+
props: {
|
|
140
|
+
theme: type.value
|
|
141
|
+
}
|
|
142
|
+
});
|
|
143
|
+
}
|
|
144
|
+
}, type.title);
|
|
145
|
+
})))), !editable && /*#__PURE__*/React.createElement("div", {
|
|
146
|
+
className: cx('code-block-copy', css(_templateObject5 || (_templateObject5 = _taggedTemplateLiteral(["\n opacity: 0;\n transition: opacity 0.3s;\n position: absolute;\n right: 0.5rem;\n top: 0.5rem;\n z-index: 10;\n "]))))
|
|
147
|
+
}, /*#__PURE__*/React.createElement(Tooltip, {
|
|
148
|
+
label: "\u590D\u5236"
|
|
149
|
+
}, /*#__PURE__*/React.createElement(UnstyledButton, {
|
|
150
|
+
className: css(_templateObject6 || (_templateObject6 = _taggedTemplateLiteral(["\n transition: all 0.3s;\n cursor: pointer;\n display: flex;\n justify-content: center;\n align-items: center;\n border-radius: 0.25rem;\n width: 2rem;\n height: 2rem;\n &:hover {\n background-color: rgba(243, 244, 246, 0.1);\n }\n "]))),
|
|
151
|
+
onClick: function onClick() {
|
|
152
|
+
navigator.clipboard.writeText(code).then(function () {
|
|
153
|
+
setCopyed(true);
|
|
154
|
+
});
|
|
155
|
+
}
|
|
156
|
+
}, /*#__PURE__*/React.createElement(motion.div, {
|
|
157
|
+
initial: {
|
|
158
|
+
opacity: 0,
|
|
159
|
+
scale: 0.5
|
|
160
|
+
},
|
|
161
|
+
animate: {
|
|
162
|
+
opacity: 1,
|
|
163
|
+
scale: 1
|
|
164
|
+
},
|
|
165
|
+
transition: {
|
|
166
|
+
duration: 0.6
|
|
167
|
+
}
|
|
168
|
+
}, copyed ? /*#__PURE__*/React.createElement(RiCheckLine, {
|
|
169
|
+
size: 18
|
|
170
|
+
}) : /*#__PURE__*/React.createElement(RiFileCopyLine, {
|
|
171
|
+
size: 18
|
|
172
|
+
}))))), /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement(AceEditor, {
|
|
173
|
+
readOnly: !editable,
|
|
174
|
+
className: css(_templateObject7 || (_templateObject7 = _taggedTemplateLiteral(["\n width: 100% !important;\n min-height: 200px;\n "]))),
|
|
175
|
+
enableLiveAutocompletion: true,
|
|
176
|
+
placeholder: "\u8BF7\u8F93\u5165\u4EE3\u7801",
|
|
177
|
+
maxLines: Infinity,
|
|
178
|
+
value: code,
|
|
179
|
+
mode: language,
|
|
180
|
+
theme: theme,
|
|
181
|
+
onChange: function onChange(value) {
|
|
182
|
+
editor.updateBlock(block, {
|
|
183
|
+
content: [{
|
|
184
|
+
type: 'text',
|
|
185
|
+
text: value,
|
|
186
|
+
styles: {}
|
|
187
|
+
}]
|
|
188
|
+
});
|
|
189
|
+
},
|
|
190
|
+
name: "UNIQUE_ID_OF_DIV",
|
|
191
|
+
editorProps: {
|
|
192
|
+
$blockScrolling: true
|
|
193
|
+
}
|
|
194
|
+
})));
|
|
195
|
+
};
|
|
196
|
+
export default CodeBlock;
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
export declare const CodeBlock: {
|
|
2
|
+
config: {
|
|
3
|
+
readonly type: "codeBlock";
|
|
4
|
+
readonly propSchema: {
|
|
5
|
+
readonly language: {
|
|
6
|
+
readonly default: "text";
|
|
7
|
+
readonly values: readonly ["text", "javascript", "typescript", "json", "html", "css", "dockerfile"];
|
|
8
|
+
};
|
|
9
|
+
readonly theme: {
|
|
10
|
+
readonly default: "monokai";
|
|
11
|
+
readonly values: readonly ["github", "github_dark", "monokai", "cloud9_day", "cloud9_night", "cloud_editor", "cloud_editor_dark"];
|
|
12
|
+
};
|
|
13
|
+
};
|
|
14
|
+
readonly content: "inline";
|
|
15
|
+
};
|
|
16
|
+
implementation: import("@blocknote/core").TiptapBlockImplementation<{
|
|
17
|
+
readonly type: "codeBlock";
|
|
18
|
+
readonly propSchema: {
|
|
19
|
+
readonly language: {
|
|
20
|
+
readonly default: "text";
|
|
21
|
+
readonly values: readonly ["text", "javascript", "typescript", "json", "html", "css", "dockerfile"];
|
|
22
|
+
};
|
|
23
|
+
readonly theme: {
|
|
24
|
+
readonly default: "monokai";
|
|
25
|
+
readonly values: readonly ["github", "github_dark", "monokai", "cloud9_day", "cloud9_night", "cloud_editor", "cloud_editor_dark"];
|
|
26
|
+
};
|
|
27
|
+
};
|
|
28
|
+
readonly content: "inline";
|
|
29
|
+
}, any, import("@blocknote/core").InlineContentSchema, import("@blocknote/core").StyleSchema>;
|
|
30
|
+
};
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { createReactBlockSpec } from '@blocknote/react';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import CB from "./CodeBlock";
|
|
4
|
+
export var CodeBlock = createReactBlockSpec({
|
|
5
|
+
type: 'codeBlock',
|
|
6
|
+
propSchema: {
|
|
7
|
+
language: {
|
|
8
|
+
default: 'text',
|
|
9
|
+
values: ['text', 'javascript', 'typescript', 'json', 'html', 'css', 'dockerfile']
|
|
10
|
+
},
|
|
11
|
+
theme: {
|
|
12
|
+
default: 'monokai',
|
|
13
|
+
values: ['github', 'github_dark', 'monokai', 'cloud9_day', 'cloud9_night', 'cloud_editor', 'cloud_editor_dark']
|
|
14
|
+
}
|
|
15
|
+
},
|
|
16
|
+
content: 'inline'
|
|
17
|
+
}, {
|
|
18
|
+
render: function render(props) {
|
|
19
|
+
return /*#__PURE__*/React.createElement(CB, props);
|
|
20
|
+
}
|
|
21
|
+
});
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { defaultBlockSpecs, PartialBlock } from '@blocknote/core';
|
|
2
|
+
import '@blocknote/core/fonts/inter.css';
|
|
3
|
+
import { BlockNoteView } from '@blocknote/mantine';
|
|
4
|
+
import '@blocknote/mantine/style.css';
|
|
5
|
+
import React, { FC } from 'react';
|
|
6
|
+
export type BlockNoteViewProps = React.ComponentProps<typeof BlockNoteView>;
|
|
7
|
+
export interface EditorProps extends Omit<Partial<BlockNoteViewProps>, 'onChange'> {
|
|
8
|
+
/** 希望隐藏的内容块 */
|
|
9
|
+
hideSpecs?: (keyof typeof defaultBlockSpecs)[];
|
|
10
|
+
/** 由于添加了自定义块,导致类型复杂无法在此处设置 typeof schema.BlockNoteEditor['initialContent'] */
|
|
11
|
+
value?: PartialBlock<any>[];
|
|
12
|
+
onChange?: (value: PartialBlock<any>[]) => void;
|
|
13
|
+
uploadFile?: (file: File) => Promise<string>;
|
|
14
|
+
}
|
|
15
|
+
declare const Editor: FC<EditorProps>;
|
|
16
|
+
export default Editor;
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
2
|
+
var _excluded = ["hideSpecs", "value", "onChange", "editable", "uploadFile"];
|
|
3
|
+
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
4
|
+
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
|
5
|
+
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
6
|
+
function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
|
7
|
+
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
|
8
|
+
function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return e; }; var t, e = {}, r = Object.prototype, n = r.hasOwnProperty, o = Object.defineProperty || function (t, e, r) { t[e] = r.value; }, i = "function" == typeof Symbol ? Symbol : {}, a = i.iterator || "@@iterator", c = i.asyncIterator || "@@asyncIterator", u = i.toStringTag || "@@toStringTag"; function define(t, e, r) { return Object.defineProperty(t, e, { value: r, enumerable: !0, configurable: !0, writable: !0 }), t[e]; } try { define({}, ""); } catch (t) { define = function define(t, e, r) { return t[e] = r; }; } function wrap(t, e, r, n) { var i = e && e.prototype instanceof Generator ? e : Generator, a = Object.create(i.prototype), c = new Context(n || []); return o(a, "_invoke", { value: makeInvokeMethod(t, r, c) }), a; } function tryCatch(t, e, r) { try { return { type: "normal", arg: t.call(e, r) }; } catch (t) { return { type: "throw", arg: t }; } } e.wrap = wrap; var h = "suspendedStart", l = "suspendedYield", f = "executing", s = "completed", y = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var p = {}; define(p, a, function () { return this; }); var d = Object.getPrototypeOf, v = d && d(d(values([]))); v && v !== r && n.call(v, a) && (p = v); var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p); function defineIteratorMethods(t) { ["next", "throw", "return"].forEach(function (e) { define(t, e, function (t) { return this._invoke(e, t); }); }); } function AsyncIterator(t, e) { function invoke(r, o, i, a) { var c = tryCatch(t[r], t, o); if ("throw" !== c.type) { var u = c.arg, h = u.value; return h && "object" == _typeof(h) && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) { invoke("next", t, i, a); }, function (t) { invoke("throw", t, i, a); }) : e.resolve(h).then(function (t) { u.value = t, i(u); }, function (t) { return invoke("throw", t, i, a); }); } a(c.arg); } var r; o(this, "_invoke", { value: function value(t, n) { function callInvokeWithMethodAndArg() { return new e(function (e, r) { invoke(t, n, e, r); }); } return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(e, r, n) { var o = h; return function (i, a) { if (o === f) throw new Error("Generator is already running"); if (o === s) { if ("throw" === i) throw a; return { value: t, done: !0 }; } for (n.method = i, n.arg = a;;) { var c = n.delegate; if (c) { var u = maybeInvokeDelegate(c, n); if (u) { if (u === y) continue; return u; } } if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) { if (o === h) throw o = s, n.arg; n.dispatchException(n.arg); } else "return" === n.method && n.abrupt("return", n.arg); o = f; var p = tryCatch(e, r, n); if ("normal" === p.type) { if (o = n.done ? s : l, p.arg === y) continue; return { value: p.arg, done: n.done }; } "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg); } }; } function maybeInvokeDelegate(e, r) { var n = r.method, o = e.iterator[n]; if (o === t) return r.delegate = null, "throw" === n && e.iterator.return && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y; var i = tryCatch(o, e.iterator, r.arg); if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y; var a = i.arg; return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y); } function pushTryEntry(t) { var e = { tryLoc: t[0] }; 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e); } function resetTryEntry(t) { var e = t.completion || {}; e.type = "normal", delete e.arg, t.completion = e; } function Context(t) { this.tryEntries = [{ tryLoc: "root" }], t.forEach(pushTryEntry, this), this.reset(!0); } function values(e) { if (e || "" === e) { var r = e[a]; if (r) return r.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) { var o = -1, i = function next() { for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next; return next.value = t, next.done = !0, next; }; return i.next = i; } } throw new TypeError(_typeof(e) + " is not iterable"); } return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), o(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) { var e = "function" == typeof t && t.constructor; return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name)); }, e.mark = function (t) { return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t; }, e.awrap = function (t) { return { __await: t }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () { return this; }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) { void 0 === i && (i = Promise); var a = new AsyncIterator(wrap(t, r, n, o), i); return e.isGeneratorFunction(r) ? a : a.next().then(function (t) { return t.done ? t.value : a.next(); }); }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () { return this; }), define(g, "toString", function () { return "[object Generator]"; }), e.keys = function (t) { var e = Object(t), r = []; for (var n in e) r.push(n); return r.reverse(), function next() { for (; r.length;) { var t = r.pop(); if (t in e) return next.value = t, next.done = !1, next; } return next.done = !0, next; }; }, e.values = values, Context.prototype = { constructor: Context, reset: function reset(e) { if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t); }, stop: function stop() { this.done = !0; var t = this.tryEntries[0].completion; if ("throw" === t.type) throw t.arg; return this.rval; }, dispatchException: function dispatchException(e) { if (this.done) throw e; var r = this; function handle(n, o) { return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o; } for (var o = this.tryEntries.length - 1; o >= 0; --o) { var i = this.tryEntries[o], a = i.completion; if ("root" === i.tryLoc) return handle("end"); if (i.tryLoc <= this.prev) { var c = n.call(i, "catchLoc"), u = n.call(i, "finallyLoc"); if (c && u) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } else if (c) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); } else { if (!u) throw new Error("try statement without catch or finally"); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } } } }, abrupt: function abrupt(t, e) { for (var r = this.tryEntries.length - 1; r >= 0; --r) { var o = this.tryEntries[r]; if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) { var i = o; break; } } i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null); var a = i ? i.completion : {}; return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a); }, complete: function complete(t, e) { if ("throw" === t.type) throw t.arg; return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y; }, finish: function finish(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y; } }, catch: function _catch(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.tryLoc === t) { var n = r.completion; if ("throw" === n.type) { var o = n.arg; resetTryEntry(r); } return o; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(e, r, n) { return this.delegate = { iterator: values(e), resultName: r, nextLoc: n }, "next" === this.method && (this.arg = t), y; } }, e; }
|
|
9
|
+
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
|
|
10
|
+
function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
|
|
11
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
12
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
13
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
14
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
|
|
15
|
+
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
16
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
17
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
18
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
19
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
20
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
21
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
22
|
+
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
|
|
23
|
+
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
|
24
|
+
import { BlockNoteEditor, BlockNoteSchema, defaultBlockSpecs, filterSuggestionItems, insertOrUpdateBlock, locales } from '@blocknote/core';
|
|
25
|
+
import '@blocknote/core/fonts/inter.css';
|
|
26
|
+
import { BlockNoteView } from '@blocknote/mantine';
|
|
27
|
+
import '@blocknote/mantine/style.css';
|
|
28
|
+
import { getDefaultReactSlashMenuItems, SuggestionMenuController } from '@blocknote/react';
|
|
29
|
+
import { MantineProvider } from '@mantine/core';
|
|
30
|
+
import { RiCodeLine } from '@remixicon/react';
|
|
31
|
+
import React, { useEffect, useMemo, useState } from 'react';
|
|
32
|
+
import { CodeBlock } from "./Blocks/CodeBlock";
|
|
33
|
+
var Editor = function Editor(props) {
|
|
34
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
35
|
+
var _props$hideSpecs = props.hideSpecs,
|
|
36
|
+
hideSpecs = _props$hideSpecs === void 0 ? [] : _props$hideSpecs,
|
|
37
|
+
value = props.value,
|
|
38
|
+
onChange = props.onChange,
|
|
39
|
+
editable = props.editable,
|
|
40
|
+
uploadFile = props.uploadFile,
|
|
41
|
+
rest = _objectWithoutProperties(props, _excluded);
|
|
42
|
+
var _useState = useState(false),
|
|
43
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
44
|
+
init = _useState2[0],
|
|
45
|
+
setInit = _useState2[1];
|
|
46
|
+
var specs = _objectSpread(_objectSpread({}, defaultBlockSpecs), {}, {
|
|
47
|
+
codeBlock: CodeBlock
|
|
48
|
+
});
|
|
49
|
+
var schema = BlockNoteSchema.create({
|
|
50
|
+
blockSpecs: hideSpecs.length > 0 ? Object.fromEntries(Object.entries(specs).filter(function (_ref) {
|
|
51
|
+
var _ref2 = _slicedToArray(_ref, 1),
|
|
52
|
+
key = _ref2[0];
|
|
53
|
+
return !hideSpecs.includes(key);
|
|
54
|
+
})) : specs
|
|
55
|
+
});
|
|
56
|
+
var insertCode = function insertCode(editor) {
|
|
57
|
+
return {
|
|
58
|
+
title: '代码',
|
|
59
|
+
subtext: '插入代码块',
|
|
60
|
+
key: 'code_block',
|
|
61
|
+
onItemClick: function onItemClick() {
|
|
62
|
+
insertOrUpdateBlock(editor, {
|
|
63
|
+
type: 'codeBlock'
|
|
64
|
+
});
|
|
65
|
+
},
|
|
66
|
+
aliases: ['code', 'codeBlock', '代码', '代码块'],
|
|
67
|
+
group: '其他',
|
|
68
|
+
icon: /*#__PURE__*/React.createElement(RiCodeLine, {
|
|
69
|
+
size: 18
|
|
70
|
+
})
|
|
71
|
+
};
|
|
72
|
+
};
|
|
73
|
+
var editor = useMemo(function () {
|
|
74
|
+
return BlockNoteEditor.create({
|
|
75
|
+
schema: schema,
|
|
76
|
+
dictionary: locales.zh,
|
|
77
|
+
uploadFile: uploadFile
|
|
78
|
+
});
|
|
79
|
+
}, [uploadFile, schema]);
|
|
80
|
+
useEffect(function () {
|
|
81
|
+
if (!!value && !!editor) {
|
|
82
|
+
editor.insertBlocks(value, editor.document[0].id);
|
|
83
|
+
setTimeout(function () {
|
|
84
|
+
setInit(true);
|
|
85
|
+
}, 0);
|
|
86
|
+
}
|
|
87
|
+
}, [init, value, editor]);
|
|
88
|
+
return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement(MantineProvider, null, /*#__PURE__*/React.createElement(BlockNoteView, _extends({
|
|
89
|
+
editable: editable
|
|
90
|
+
// @ts-ignore
|
|
91
|
+
,
|
|
92
|
+
editor: editor,
|
|
93
|
+
slashMenu: false,
|
|
94
|
+
onChange: /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
|
|
95
|
+
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
96
|
+
while (1) switch (_context.prev = _context.next) {
|
|
97
|
+
case 0:
|
|
98
|
+
onChange === null || onChange === void 0 || onChange(editor.document);
|
|
99
|
+
case 1:
|
|
100
|
+
case "end":
|
|
101
|
+
return _context.stop();
|
|
102
|
+
}
|
|
103
|
+
}, _callee);
|
|
104
|
+
}))
|
|
105
|
+
}, rest), /*#__PURE__*/React.createElement(SuggestionMenuController, {
|
|
106
|
+
triggerCharacter: '/',
|
|
107
|
+
getItems: ( /*#__PURE__*/function () {
|
|
108
|
+
var _ref4 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(query) {
|
|
109
|
+
return _regeneratorRuntime().wrap(function _callee2$(_context2) {
|
|
110
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
111
|
+
case 0:
|
|
112
|
+
return _context2.abrupt("return", filterSuggestionItems([].concat(_toConsumableArray(getDefaultReactSlashMenuItems(editor)), [insertCode(editor)]).filter(function (i) {
|
|
113
|
+
// @ts-ignore
|
|
114
|
+
var key = i.key.replace(/_(\w)/g, function (_, c) {
|
|
115
|
+
return c.toUpperCase();
|
|
116
|
+
});
|
|
117
|
+
return !hideSpecs.some(function (s) {
|
|
118
|
+
return key.includes(s);
|
|
119
|
+
});
|
|
120
|
+
}), query));
|
|
121
|
+
case 1:
|
|
122
|
+
case "end":
|
|
123
|
+
return _context2.stop();
|
|
124
|
+
}
|
|
125
|
+
}, _callee2);
|
|
126
|
+
}));
|
|
127
|
+
return function (_x) {
|
|
128
|
+
return _ref4.apply(this, arguments);
|
|
129
|
+
};
|
|
130
|
+
}())
|
|
131
|
+
}))));
|
|
132
|
+
};
|
|
133
|
+
export default Editor;
|
package/dist/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export { default as
|
|
1
|
+
export { default as Editor } from './Editor';
|
package/dist/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export { default as
|
|
1
|
+
export { default as Editor } from "./Editor";
|
package/package.json
CHANGED
|
@@ -1,30 +1,40 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "zs_library",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.1.1",
|
|
4
4
|
"description": "A react library developed with dumi",
|
|
5
|
+
"homepage": "https://zs-library.vercel.app",
|
|
6
|
+
"bugs": {
|
|
7
|
+
"url": "https://github.com/virzs/zs_library/issues"
|
|
8
|
+
},
|
|
9
|
+
"repository": {
|
|
10
|
+
"type": "git",
|
|
11
|
+
"url": "git+https://github.com/virzs/zs_library.git"
|
|
12
|
+
},
|
|
13
|
+
"license": "MIT",
|
|
14
|
+
"author": "v",
|
|
15
|
+
"main": ".eslintrc.js",
|
|
5
16
|
"module": "dist/index.js",
|
|
6
17
|
"types": "dist/index.d.ts",
|
|
18
|
+
"directories": {
|
|
19
|
+
"doc": "docs"
|
|
20
|
+
},
|
|
21
|
+
"files": [
|
|
22
|
+
"dist"
|
|
23
|
+
],
|
|
7
24
|
"scripts": {
|
|
8
|
-
"start": "npm run dev",
|
|
9
|
-
"dev": "dumi dev",
|
|
10
25
|
"build": "father build",
|
|
11
26
|
"build:watch": "father dev",
|
|
27
|
+
"dev": "dumi dev",
|
|
12
28
|
"docs:build": "dumi build",
|
|
13
29
|
"docs:preview": "dumi preview",
|
|
14
|
-
"prepare": "husky install && dumi setup",
|
|
15
30
|
"doctor": "father doctor",
|
|
16
31
|
"lint": "npm run lint:es && npm run lint:css",
|
|
17
32
|
"lint:css": "stylelint \"{src,test}/**/*.{css,less}\"",
|
|
18
33
|
"lint:es": "eslint \"{src,test}/**/*.{js,jsx,ts,tsx}\"",
|
|
19
|
-
"
|
|
34
|
+
"prepare": "husky install && dumi setup",
|
|
35
|
+
"prepublishOnly": "father doctor && npm run build",
|
|
36
|
+
"start": "npm run dev"
|
|
20
37
|
},
|
|
21
|
-
"authors": [
|
|
22
|
-
"virs2018@outlook.com"
|
|
23
|
-
],
|
|
24
|
-
"license": "MIT",
|
|
25
|
-
"files": [
|
|
26
|
-
"dist"
|
|
27
|
-
],
|
|
28
38
|
"commitlint": {
|
|
29
39
|
"extends": [
|
|
30
40
|
"@commitlint/config-conventional"
|
|
@@ -47,12 +57,16 @@
|
|
|
47
57
|
"prettier --parser=typescript --write"
|
|
48
58
|
]
|
|
49
59
|
},
|
|
50
|
-
"
|
|
51
|
-
"
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
"
|
|
55
|
-
"
|
|
60
|
+
"dependencies": {
|
|
61
|
+
"@blocknote/core": "^0.15.3",
|
|
62
|
+
"@blocknote/mantine": "^0.15.3",
|
|
63
|
+
"@blocknote/react": "^0.15.3",
|
|
64
|
+
"@emotion/css": "^11.13.0",
|
|
65
|
+
"@mantine/core": "^7.11.2",
|
|
66
|
+
"@remixicon/react": "^4.2.0",
|
|
67
|
+
"ace-builds": "^1.35.4",
|
|
68
|
+
"framer-motion": "^11.3.19",
|
|
69
|
+
"react-ace": "^12.0.0"
|
|
56
70
|
},
|
|
57
71
|
"devDependencies": {
|
|
58
72
|
"@commitlint/cli": "^17.1.2",
|
|
@@ -61,6 +75,7 @@
|
|
|
61
75
|
"@types/react-dom": "^18.0.0",
|
|
62
76
|
"@umijs/lint": "^4.0.0",
|
|
63
77
|
"dumi": "^2.3.0",
|
|
78
|
+
"dumi-theme-antd-style": "^0.31.0",
|
|
64
79
|
"eslint": "^8.23.0",
|
|
65
80
|
"father": "^4.1.0",
|
|
66
81
|
"husky": "^8.0.1",
|
|
@@ -72,24 +87,14 @@
|
|
|
72
87
|
"react-dom": "^18.0.0",
|
|
73
88
|
"stylelint": "^14.9.1"
|
|
74
89
|
},
|
|
75
|
-
"
|
|
76
|
-
|
|
77
|
-
"
|
|
78
|
-
},
|
|
79
|
-
"dependencies": {
|
|
80
|
-
"eslint-plugin-jest": "^27.2.3",
|
|
81
|
-
"eslint-plugin-react": "^7.33.2",
|
|
82
|
-
"eslint-plugin-react-hooks": "^4.6.0",
|
|
83
|
-
"eslint-scope": "^7.2.2",
|
|
84
|
-
"eslint-visitor-keys": "^3.4.3"
|
|
85
|
-
},
|
|
86
|
-
"repository": {
|
|
87
|
-
"type": "git",
|
|
88
|
-
"url": "git+https://github.com/virzs/z_library.git"
|
|
90
|
+
"peerDependencies": {
|
|
91
|
+
"react": ">=16.9.0",
|
|
92
|
+
"react-dom": ">=16.9.0"
|
|
89
93
|
},
|
|
90
|
-
"
|
|
91
|
-
|
|
92
|
-
"url": "https://github.com/virzs/z_library/issues"
|
|
94
|
+
"publishConfig": {
|
|
95
|
+
"access": "public"
|
|
93
96
|
},
|
|
94
|
-
"
|
|
97
|
+
"authors": [
|
|
98
|
+
"virs2018@outlook.com"
|
|
99
|
+
]
|
|
95
100
|
}
|
package/dist/Foo/index.d.ts
DELETED