-
Notifications
You must be signed in to change notification settings - Fork 147
Expand file tree
/
Copy pathheading.js
More file actions
82 lines (72 loc) · 1.94 KB
/
heading.js
File metadata and controls
82 lines (72 loc) · 1.94 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
import { Node, Attribute } from '@core/index.js';
export const Heading = Node.create({
name: 'heading',
group: 'block',
content: 'inline*',
defining: true,
addOptions() {
return {
levels: [1, 2, 3, 4, 5, 6],
htmlAttributes: {
'aria-label': 'Heading node',
},
};
},
addAttributes() {
return {
level: {
default: 1,
rendered: false,
},
tabStops: { rendered: false },
sdBlockId: {
default: null,
keepOnSplit: false,
parseDOM: (elem) => elem.getAttribute('data-sd-block-id'),
renderDOM: (attrs) => {
return attrs.sdBlockId ? { 'data-sd-block-id': attrs.sdBlockId } : {};
},
},
};
},
parseDOM() {
return this.options.levels.map((level) => ({
tag: `h${level}`,
attrs: { level },
}));
},
renderDOM({ node, htmlAttributes }) {
const hasLevel = this.options.levels.includes(node.attrs.level);
const level = hasLevel ? node.attrs.level : this.options.levels[0];
return [`h${level}`, Attribute.mergeAttributes(this.options.htmlAttributes, htmlAttributes), 0];
},
addCommands() {
return {
setHeading:
(attributes) =>
({ commands }) => {
const containsLevel = this.options.levels.includes(attributes.level);
if (!containsLevel) return false;
return commands.setNode(this.name, attributes);
},
toggleHeading:
(attributes) =>
({ commands }) => {
const containsLevel = this.options.levels.includes(attributes.level);
if (!containsLevel) return false;
return commands.toggleNode(this.name, 'paragraph', attributes);
},
};
},
addShortcuts() {
return this.options.levels.reduce(
(items, level) => ({
...items,
...{
[`Mod-Alt-${level}`]: () => this.editor.commands.toggleHeading({ level }),
},
}),
{},
);
},
});