@tiptap/extension-list 3.6.7 → 3.7.0

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.
@@ -1,4 +1,4 @@
1
- import { mergeAttributes, Node } from '@tiptap/core'
1
+ import { mergeAttributes, Node, parseIndentedBlocks } from '@tiptap/core'
2
2
 
3
3
  export interface TaskListOptions {
4
4
  /**
@@ -61,6 +61,110 @@ export const TaskList = Node.create<TaskListOptions>({
61
61
  return ['ul', mergeAttributes(this.options.HTMLAttributes, HTMLAttributes, { 'data-type': this.name }), 0]
62
62
  },
63
63
 
64
+ parseMarkdown: (token, h) => {
65
+ return h.createNode('taskList', {}, h.parseChildren(token.items || []))
66
+ },
67
+
68
+ renderMarkdown: (node, h) => {
69
+ if (!node.content) {
70
+ return ''
71
+ }
72
+
73
+ return h.renderChildren(node.content, '\n')
74
+ },
75
+
76
+ markdownTokenizer: {
77
+ name: 'taskList',
78
+ level: 'block',
79
+ start(src) {
80
+ // Look for the start of a task list item
81
+ const index = src.match(/^\s*[-+*]\s+\[([ xX])\]\s+/)?.index
82
+ return index !== undefined ? index : -1
83
+ },
84
+ tokenize(src, tokens, lexer) {
85
+ // Helper function to recursively parse task lists
86
+ const parseTaskListContent = (content: string): any[] | undefined => {
87
+ const nestedResult = parseIndentedBlocks(
88
+ content,
89
+ {
90
+ itemPattern: /^(\s*)([-+*])\s+\[([ xX])\]\s+(.*)$/,
91
+ extractItemData: match => ({
92
+ indentLevel: match[1].length,
93
+ mainContent: match[4],
94
+ checked: match[3].toLowerCase() === 'x',
95
+ }),
96
+ createToken: (data, nestedTokens) => ({
97
+ type: 'taskItem',
98
+ raw: '',
99
+ mainContent: data.mainContent,
100
+ indentLevel: data.indentLevel,
101
+ checked: data.checked,
102
+ text: data.mainContent,
103
+ tokens: lexer.inlineTokens(data.mainContent),
104
+ nestedTokens,
105
+ }),
106
+ // Allow recursive nesting
107
+ customNestedParser: parseTaskListContent,
108
+ },
109
+ lexer,
110
+ )
111
+
112
+ if (nestedResult) {
113
+ // Return as task list token
114
+ return [
115
+ {
116
+ type: 'taskList',
117
+ raw: nestedResult.raw,
118
+ items: nestedResult.items,
119
+ },
120
+ ]
121
+ }
122
+
123
+ // Fall back to regular markdown parsing if not a task list
124
+ return lexer.blockTokens(content)
125
+ }
126
+
127
+ const result = parseIndentedBlocks(
128
+ src,
129
+ {
130
+ itemPattern: /^(\s*)([-+*])\s+\[([ xX])\]\s+(.*)$/,
131
+ extractItemData: match => ({
132
+ indentLevel: match[1].length,
133
+ mainContent: match[4],
134
+ checked: match[3].toLowerCase() === 'x',
135
+ }),
136
+ createToken: (data, nestedTokens) => ({
137
+ type: 'taskItem',
138
+ raw: '',
139
+ mainContent: data.mainContent,
140
+ indentLevel: data.indentLevel,
141
+ checked: data.checked,
142
+ text: data.mainContent,
143
+ tokens: lexer.inlineTokens(data.mainContent),
144
+ nestedTokens,
145
+ }),
146
+ // Use the recursive parser for nested content
147
+ customNestedParser: parseTaskListContent,
148
+ },
149
+ lexer,
150
+ )
151
+
152
+ if (!result) {
153
+ return undefined
154
+ }
155
+
156
+ return {
157
+ type: 'taskList',
158
+ raw: result.raw,
159
+ items: result.items,
160
+ }
161
+ },
162
+ },
163
+
164
+ markdownOptions: {
165
+ indentsContent: true,
166
+ },
167
+
64
168
  addCommands() {
65
169
  return {
66
170
  toggleTaskList: