@ctzhian/tiptap 1.12.18 → 1.12.20

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.
@@ -152,7 +152,7 @@ var Reader = function Reader() {
152
152
  }
153
153
  return onUpload;
154
154
  }(),
155
- content: "<ol class=\"ordered-list\" data-type=\"orderedList\"><li><p>jfdlsaf</p></li><li><p>sadfsa</p><ol class=\"ordered-list\" data-type=\"orderedList\"><li><p>fjasldkfj</p><ol class=\"ordered-list\" data-type=\"orderedList\"><li><p>fasd</p><ol class=\"ordered-list\" data-type=\"orderedList\"><li><p>fasdjklf</p></li></ol></li><li><p>fjdslkf</p></li><li><p>sjfsadlf</p></li></ol></li></ol></li></ol><ul class=\"bullet-list\" data-type=\"bulletList\"><li><p>fsldjakfjlksd</p></li><li><p>fsadfasd</p><ul class=\"bullet-list\" data-type=\"bulletList\"><li><p>fajsdlkfj</p></li><li><p>fasdjklf</p><ul class=\"bullet-list\" data-type=\"bulletList\"><li><p>fjasldfsa</p><ul class=\"bullet-list\" data-type=\"bulletList\"><li><p>fsadlkj</p></li></ul></li></ul></li></ul></li></ul><p></p>"
155
+ content: "<ul data-type=\"taskList\"><li class=\"task-item\" data-type=\"taskItem\" data-checked=\"false\"><label><input type=\"checkbox\"><span></span></label><div><p>\u653E\u5047\u963F\u65AF\u5229\u5EB7\u90FD\u653E\u5047\u4E86\u770B\u6C99\u53D1</p></div></li><li class=\"task-item\" data-type=\"taskItem\" data-checked=\"false\"><label><input type=\"checkbox\"><span></span></label><div><p>\u53D1\u94FE\u63A5 sd \u5361\u653E\u5047\u963F\u65AF\u5229\u5EB7\u6253\u98DE\u673A\u4E86</p></div></li></ul><ol class=\"ordered-list\" data-type=\"orderedList\"><li><p>jfdlsaf</p></li><li><p>sadfsa</p><ol class=\"ordered-list\" data-type=\"orderedList\"><li><p>fjasldkfj</p><ol class=\"ordered-list\" data-type=\"orderedList\"><li><p>fasd</p><ol class=\"ordered-list\" data-type=\"orderedList\"><li><p>fasdjklf</p></li></ol></li><li><p>fjdslkf</p></li><li><p>sjfsadlf</p></li></ol></li></ol></li></ol><ul class=\"bullet-list\" data-type=\"bulletList\"><li><p>fsldjakfjlksd</p></li><li><p>fsadfasd</p><ul class=\"bullet-list\" data-type=\"bulletList\"><li><p>fajsdlkfj</p></li><li><p>fasdjklf</p><ul class=\"bullet-list\" data-type=\"bulletList\"><li><p>fjasldfsa</p><ul class=\"bullet-list\" data-type=\"bulletList\"><li><p>fsadlkj</p></li></ul></li></ul></li></ul></li></ul><p></p>"
156
156
  }),
157
157
  editor = _useTiptap.editor;
158
158
  return /*#__PURE__*/React.createElement(EditorThemeProvider, {
@@ -155,6 +155,10 @@ var Reader = function Reader() {
155
155
  editor: editor,
156
156
  height: '500px',
157
157
  value: mdContent,
158
+ splitMode: true,
159
+ showToolbar: false,
160
+ defaultDisplayMode: "edit",
161
+ placeholder: "\u8BF7\u8F93\u5165\u5185\u5BB9",
158
162
  onUpload: onUpload,
159
163
  onAceChange: setMdContent
160
164
  })));
@@ -12,13 +12,18 @@ import 'ace-builds/src-noconflict/theme-github';
12
12
  interface EditorMarkdownProps {
13
13
  editor: Editor;
14
14
  value?: string;
15
+ placeholder?: string;
15
16
  height: number | string;
16
17
  onUpload?: UploadFunction;
18
+ defaultDisplayMode?: DisplayMode;
19
+ splitMode?: boolean;
20
+ showToolbar?: boolean;
17
21
  onAceChange?: (value: string) => void;
18
22
  onTiptapChange?: (value: string) => void;
19
23
  }
20
24
  export interface MarkdownEditorRef {
21
25
  scrollToHeading: (headingText: string) => void;
22
26
  }
27
+ type DisplayMode = 'edit' | 'preview' | 'split';
23
28
  declare const EditorMarkdown: React.ForwardRefExoticComponent<EditorMarkdownProps & React.RefAttributes<MarkdownEditorRef>>;
24
29
  export default EditorMarkdown;
@@ -23,12 +23,19 @@ import 'ace-builds/src-noconflict/theme-github';
23
23
  var EditorMarkdown = /*#__PURE__*/forwardRef(function (_ref, ref) {
24
24
  var editor = _ref.editor,
25
25
  value = _ref.value,
26
+ placeholder = _ref.placeholder,
26
27
  onAceChange = _ref.onAceChange,
27
28
  height = _ref.height,
28
- onUpload = _ref.onUpload;
29
+ onUpload = _ref.onUpload,
30
+ _ref$splitMode = _ref.splitMode,
31
+ splitMode = _ref$splitMode === void 0 ? false : _ref$splitMode,
32
+ _ref$defaultDisplayMo = _ref.defaultDisplayMode,
33
+ defaultDisplayMode = _ref$defaultDisplayMo === void 0 ? 'edit' : _ref$defaultDisplayMo,
34
+ _ref$showToolbar = _ref.showToolbar,
35
+ showToolbar = _ref$showToolbar === void 0 ? true : _ref$showToolbar;
29
36
  var theme = useTheme();
30
37
  var aceEditorRef = useRef(null);
31
- var _useState = useState('edit'),
38
+ var _useState = useState(defaultDisplayMode),
32
39
  _useState2 = _slicedToArray(_useState, 2),
33
40
  displayMode = _useState2[0],
34
41
  setDisplayMode = _useState2[1];
@@ -85,7 +92,7 @@ var EditorMarkdown = /*#__PURE__*/forwardRef(function (_ref, ref) {
85
92
  right: 0,
86
93
  zIndex: 2000
87
94
  })
88
- }, /*#__PURE__*/React.createElement(Stack, {
95
+ }, showToolbar && /*#__PURE__*/React.createElement(Stack, {
89
96
  direction: "row",
90
97
  alignItems: 'center',
91
98
  justifyContent: 'space-between',
@@ -161,7 +168,7 @@ var EditorMarkdown = /*#__PURE__*/forwardRef(function (_ref, ref) {
161
168
  onClick: function onClick() {
162
169
  return setDisplayMode('preview');
163
170
  }
164
- }, "\u9884\u89C8\u6A21\u5F0F"), /*#__PURE__*/React.createElement(Box, {
171
+ }, "\u9884\u89C8\u6A21\u5F0F"), splitMode && /*#__PURE__*/React.createElement(Box, {
165
172
  className: displayMode === 'split' ? 'md-display-mode-active' : 'md-display-mode',
166
173
  sx: {
167
174
  px: 1,
@@ -202,7 +209,7 @@ var EditorMarkdown = /*#__PURE__*/forwardRef(function (_ref, ref) {
202
209
  wrapEnabled: true,
203
210
  readOnly: loading,
204
211
  showPrintMargin: false,
205
- placeholder: MARKDOWN_EDITOR_PLACEHOLDER,
212
+ placeholder: placeholder || MARKDOWN_EDITOR_PLACEHOLDER,
206
213
  fontSize: 16,
207
214
  editorProps: {
208
215
  $blockScrolling: true
@@ -66,7 +66,9 @@ export var InlineLinkExtension = Node.create({
66
66
  HTMLAttributes: {
67
67
  target: '_blank',
68
68
  class: null,
69
- type: 'icon'
69
+ type: 'icon',
70
+ rel: null,
71
+ title: null
70
72
  },
71
73
  isAllowedUri: function isAllowedUri(url, ctx) {
72
74
  return !!_isAllowedUri(url, ctx.protocols);
package/dist/index.css CHANGED
@@ -179,10 +179,11 @@
179
179
  .tiptap.ProseMirror ul[data-type='taskList'] li {
180
180
  align-items: flex-start;
181
181
  display: flex;
182
+ flex-direction: row;
182
183
  }
183
184
 
184
185
  .tiptap.ProseMirror ul[data-type='taskList'] li>label {
185
- flex: 0 0 auto;
186
+ flex-shrink: 0;
186
187
  user-select: none;
187
188
  margin-right: 8px;
188
189
  height: 28px;
@@ -192,7 +193,7 @@
192
193
  }
193
194
 
194
195
  .tiptap.ProseMirror ul[data-type='taskList'] li>div {
195
- flex: 1 1 auto;
196
+ flex-grow: 1;
196
197
  }
197
198
 
198
199
  .tiptap.ProseMirror ul[data-type='taskList'] li[data-checked='true']>div {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ctzhian/tiptap",
3
- "version": "1.12.18",
3
+ "version": "1.12.20",
4
4
  "description": "基于 Tiptap 二次开发的编辑器组件",
5
5
  "main": "dist/index.js",
6
6
  "module": "dist/index.js",