@ecodev/natural-editor 42.0.0 → 42.3.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.
- package/esm2020/lib/class-dialog/class-dialog.component.mjs +37 -0
- package/esm2020/lib/color-dialog/color-dialog.component.mjs +184 -0
- package/esm2020/lib/custom-css/custom-css.directive.mjs +78 -0
- package/esm2020/lib/editor/editor.component.mjs +8 -8
- package/esm2020/lib/editor.module.mjs +24 -16
- package/esm2020/lib/link-dialog/link-dialog.component.mjs +3 -3
- package/esm2020/lib/utils/image.mjs +3 -3
- package/esm2020/lib/utils/items/cell-background-color-item.mjs +55 -0
- package/esm2020/lib/utils/items/class-item.mjs +86 -0
- package/esm2020/lib/utils/items/horizontal-rule-item.mjs +24 -0
- package/esm2020/lib/utils/items/item.mjs +39 -0
- package/esm2020/lib/utils/items/link-item.mjs +40 -0
- package/esm2020/lib/utils/items/table-item.mjs +43 -0
- package/esm2020/lib/utils/items/text-align-item.mjs +78 -0
- package/esm2020/lib/utils/items/utils.mjs +41 -0
- package/esm2020/lib/utils/items/wrap-list-item.mjs +6 -0
- package/esm2020/lib/utils/menu.mjs +45 -128
- package/esm2020/lib/utils/schema/paragraph-with-alignment.mjs +50 -0
- package/esm2020/lib/utils/schema/schema.mjs +51 -0
- package/esm2020/lib/utils/schema/table.mjs +113 -0
- package/esm2020/public-api.mjs +2 -1
- package/fesm2015/ecodev-natural-editor.mjs +754 -194
- package/fesm2015/ecodev-natural-editor.mjs.map +1 -1
- package/fesm2020/ecodev-natural-editor.mjs +748 -196
- package/fesm2020/ecodev-natural-editor.mjs.map +1 -1
- package/lib/class-dialog/class-dialog.component.d.ts +24 -0
- package/lib/color-dialog/color-dialog.component.d.ts +26 -0
- package/lib/custom-css/custom-css.directive.d.ts +29 -0
- package/lib/editor.module.d.ts +19 -16
- package/lib/utils/items/cell-background-color-item.d.ts +5 -0
- package/lib/utils/items/class-item.d.ts +6 -0
- package/lib/utils/items/horizontal-rule-item.d.ts +5 -0
- package/lib/utils/{item.d.ts → items/item.d.ts} +0 -0
- package/lib/utils/items/link-item.d.ts +6 -0
- package/lib/utils/items/table-item.d.ts +4 -0
- package/lib/utils/{text-align-item.d.ts → items/text-align-item.d.ts} +0 -0
- package/lib/utils/items/utils.d.ts +18 -0
- package/lib/utils/items/wrap-list-item.d.ts +3 -0
- package/lib/utils/menu.d.ts +2 -2
- package/lib/utils/schema/paragraph-with-alignment.d.ts +8 -0
- package/lib/utils/{schema.d.ts → schema/schema.d.ts} +0 -0
- package/lib/utils/schema/table.d.ts +9 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/esm2020/lib/utils/item.mjs +0 -39
- package/esm2020/lib/utils/paragraph-with-alignment.mjs +0 -43
- package/esm2020/lib/utils/schema.mjs +0 -51
- package/esm2020/lib/utils/table.mjs +0 -37
- package/esm2020/lib/utils/text-align-item.mjs +0 -81
- package/lib/utils/paragraph-with-alignment.d.ts +0 -2
- package/lib/utils/table.d.ts +0 -8
|
@@ -1,120 +1,42 @@
|
|
|
1
1
|
import { blockTypeItem, joinUpItem, liftItem, redoItem, selectParentNodeItem, undoItem, wrapItem, } from 'prosemirror-menu';
|
|
2
|
-
import { toggleMark } from 'prosemirror-commands';
|
|
3
|
-
import { wrapInList } from 'prosemirror-schema-list';
|
|
4
|
-
import { LinkDialogComponent } from '../link-dialog/link-dialog.component';
|
|
5
2
|
import { addColumnAfter, addColumnBefore, addRowAfter, addRowBefore, deleteColumn, deleteRow, deleteTable, mergeCells, splitCell, toggleHeaderCell, toggleHeaderColumn, toggleHeaderRow, } from 'prosemirror-tables';
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
}
|
|
16
|
-
function canInsert(state, nodeType) {
|
|
17
|
-
const $from = state.selection.$from;
|
|
18
|
-
for (let d = $from.depth; d >= 0; d--) {
|
|
19
|
-
const index = $from.index(d);
|
|
20
|
-
if ($from.node(d).canReplaceWith(index, index, nodeType)) {
|
|
21
|
-
return true;
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
return false;
|
|
25
|
-
}
|
|
26
|
-
function cmdItem(cmd, options = {}, useEnable = false) {
|
|
27
|
-
const passedOptions = {
|
|
28
|
-
run: cmd,
|
|
29
|
-
...options,
|
|
30
|
-
};
|
|
31
|
-
if ((!options.enable || useEnable) && !options.select) {
|
|
32
|
-
passedOptions[options.enable ? 'enable' : 'select'] = (state) => cmd(state);
|
|
33
|
-
}
|
|
34
|
-
return new Item(passedOptions);
|
|
35
|
-
}
|
|
36
|
-
function markActive(state, type) {
|
|
37
|
-
const { from, $from, to, empty } = state.selection;
|
|
38
|
-
if (empty) {
|
|
39
|
-
return !!type.isInSet(state.storedMarks || $from.marks());
|
|
40
|
-
}
|
|
41
|
-
else {
|
|
42
|
-
return state.doc.rangeHasMark(from, to, type);
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
function markItem(markType, options = {}) {
|
|
46
|
-
const passedOptions = {
|
|
47
|
-
active(state) {
|
|
48
|
-
return markActive(state, markType);
|
|
49
|
-
},
|
|
50
|
-
...options,
|
|
51
|
-
};
|
|
52
|
-
return cmdItem(toggleMark(markType), passedOptions, true);
|
|
53
|
-
}
|
|
54
|
-
function linkItem(markType, dialog) {
|
|
55
|
-
return new Item({
|
|
56
|
-
active(state) {
|
|
57
|
-
return markActive(state, markType);
|
|
58
|
-
},
|
|
59
|
-
enable(state) {
|
|
60
|
-
return !state.selection.empty;
|
|
61
|
-
},
|
|
62
|
-
run(state, dispatch, view) {
|
|
63
|
-
if (markActive(state, markType)) {
|
|
64
|
-
toggleMark(markType)(state, dispatch);
|
|
65
|
-
return true;
|
|
66
|
-
}
|
|
67
|
-
dialog
|
|
68
|
-
.open(LinkDialogComponent, {
|
|
69
|
-
data: {
|
|
70
|
-
href: '',
|
|
71
|
-
title: '',
|
|
72
|
-
},
|
|
73
|
-
})
|
|
74
|
-
.afterClosed()
|
|
75
|
-
.subscribe(result => {
|
|
76
|
-
if (result) {
|
|
77
|
-
if (!result.title) {
|
|
78
|
-
delete result.title;
|
|
79
|
-
}
|
|
80
|
-
toggleMark(markType, result)(view.state, view.dispatch);
|
|
81
|
-
}
|
|
82
|
-
view.focus();
|
|
83
|
-
});
|
|
84
|
-
},
|
|
85
|
-
});
|
|
86
|
-
}
|
|
87
|
-
function wrapListItem(nodeType) {
|
|
88
|
-
return cmdItem(wrapInList(nodeType));
|
|
89
|
-
}
|
|
3
|
+
import { paragraphWithAlignment } from './schema/paragraph-with-alignment';
|
|
4
|
+
import { TextAlignItem } from './items/text-align-item';
|
|
5
|
+
import { CellBackgroundColorItem } from './items/cell-background-color-item';
|
|
6
|
+
import { LinkItem } from './items/link-item';
|
|
7
|
+
import { HorizontalRuleItem } from './items/horizontal-rule-item';
|
|
8
|
+
import { cmdToItem, markTypeToItem, menuItemToItem } from './items/utils';
|
|
9
|
+
import { wrapListItem } from './items/wrap-list-item';
|
|
10
|
+
import { ClassItem } from './items/class-item';
|
|
11
|
+
import { AddTableItem } from './items/table-item';
|
|
90
12
|
/**
|
|
91
13
|
* Given a schema, look for default mark and node types in it and
|
|
92
14
|
* return an object with relevant menu items relating to those marks:
|
|
93
15
|
*/
|
|
94
16
|
export function buildMenuItems(schema, dialog) {
|
|
95
17
|
const r = {
|
|
96
|
-
joinUp:
|
|
97
|
-
lift:
|
|
98
|
-
selectParentNode:
|
|
99
|
-
undo:
|
|
100
|
-
redo:
|
|
18
|
+
joinUp: menuItemToItem(joinUpItem),
|
|
19
|
+
lift: menuItemToItem(liftItem),
|
|
20
|
+
selectParentNode: menuItemToItem(selectParentNodeItem),
|
|
21
|
+
undo: menuItemToItem(undoItem),
|
|
22
|
+
redo: menuItemToItem(redoItem),
|
|
101
23
|
};
|
|
102
24
|
let type;
|
|
103
25
|
type = schema.marks.strong;
|
|
104
26
|
if (type) {
|
|
105
|
-
r.toggleStrong =
|
|
27
|
+
r.toggleStrong = markTypeToItem(type);
|
|
106
28
|
}
|
|
107
29
|
type = schema.marks.em;
|
|
108
30
|
if (type) {
|
|
109
|
-
r.toggleEm =
|
|
31
|
+
r.toggleEm = markTypeToItem(type);
|
|
110
32
|
}
|
|
111
33
|
type = schema.marks.code;
|
|
112
34
|
if (type) {
|
|
113
|
-
r.toggleCode =
|
|
35
|
+
r.toggleCode = markTypeToItem(type);
|
|
114
36
|
}
|
|
115
37
|
type = schema.marks.link;
|
|
116
38
|
if (type) {
|
|
117
|
-
r.toggleLink =
|
|
39
|
+
r.toggleLink = new LinkItem(type, dialog);
|
|
118
40
|
}
|
|
119
41
|
type = schema.nodes.bullet_list;
|
|
120
42
|
if (type) {
|
|
@@ -126,59 +48,54 @@ export function buildMenuItems(schema, dialog) {
|
|
|
126
48
|
}
|
|
127
49
|
type = schema.nodes.blockquote;
|
|
128
50
|
if (type) {
|
|
129
|
-
r.wrapBlockQuote =
|
|
51
|
+
r.wrapBlockQuote = menuItemToItem(wrapItem(type, {}));
|
|
130
52
|
}
|
|
131
53
|
type = schema.nodes.paragraph;
|
|
132
54
|
if (type) {
|
|
133
|
-
r.makeParagraph =
|
|
55
|
+
r.makeParagraph = menuItemToItem(blockTypeItem(type, {}));
|
|
134
56
|
if (type.spec === paragraphWithAlignment) {
|
|
135
57
|
r.alignLeft = new TextAlignItem('left');
|
|
136
58
|
r.alignRight = new TextAlignItem('right');
|
|
137
59
|
r.alignCenter = new TextAlignItem('center');
|
|
138
60
|
r.alignJustify = new TextAlignItem('justify');
|
|
61
|
+
r.paragraphClass = new ClassItem(dialog, type);
|
|
139
62
|
}
|
|
140
63
|
}
|
|
141
64
|
type = schema.nodes.code_block;
|
|
142
65
|
if (type) {
|
|
143
|
-
r.makeCodeBlock =
|
|
66
|
+
r.makeCodeBlock = menuItemToItem(blockTypeItem(type, {}));
|
|
144
67
|
}
|
|
145
68
|
type = schema.nodes.heading;
|
|
146
69
|
if (type) {
|
|
147
|
-
r.makeHead1 =
|
|
148
|
-
r.makeHead2 =
|
|
149
|
-
r.makeHead3 =
|
|
150
|
-
r.makeHead4 =
|
|
151
|
-
r.makeHead5 =
|
|
152
|
-
r.makeHead6 =
|
|
70
|
+
r.makeHead1 = menuItemToItem(blockTypeItem(type, { attrs: { level: 1 } }));
|
|
71
|
+
r.makeHead2 = menuItemToItem(blockTypeItem(type, { attrs: { level: 2 } }));
|
|
72
|
+
r.makeHead3 = menuItemToItem(blockTypeItem(type, { attrs: { level: 3 } }));
|
|
73
|
+
r.makeHead4 = menuItemToItem(blockTypeItem(type, { attrs: { level: 4 } }));
|
|
74
|
+
r.makeHead5 = menuItemToItem(blockTypeItem(type, { attrs: { level: 5 } }));
|
|
75
|
+
r.makeHead6 = menuItemToItem(blockTypeItem(type, { attrs: { level: 6 } }));
|
|
153
76
|
}
|
|
154
77
|
type = schema.nodes.horizontal_rule;
|
|
155
78
|
if (type) {
|
|
156
|
-
|
|
157
|
-
r.insertHorizontalRule = new Item({
|
|
158
|
-
enable(state) {
|
|
159
|
-
return canInsert(state, hr);
|
|
160
|
-
},
|
|
161
|
-
run(state, dispatch) {
|
|
162
|
-
dispatch(state.tr.replaceSelectionWith(hr.create()));
|
|
163
|
-
},
|
|
164
|
-
});
|
|
79
|
+
r.insertHorizontalRule = new HorizontalRuleItem(type);
|
|
165
80
|
}
|
|
166
81
|
type = schema.nodes.table;
|
|
167
82
|
if (type) {
|
|
168
|
-
r.insertTable = new
|
|
169
|
-
r.addColumnBefore =
|
|
170
|
-
r.addColumnAfter =
|
|
171
|
-
r.deleteColumn =
|
|
172
|
-
r.addRowBefore =
|
|
173
|
-
r.addRowAfter =
|
|
174
|
-
r.deleteRow =
|
|
175
|
-
r.deleteTable =
|
|
176
|
-
r.mergeCells =
|
|
177
|
-
r.splitCell =
|
|
178
|
-
r.toggleHeaderColumn =
|
|
179
|
-
r.toggleHeaderRow =
|
|
180
|
-
r.toggleHeaderCell =
|
|
83
|
+
r.insertTable = new AddTableItem();
|
|
84
|
+
r.addColumnBefore = cmdToItem(addColumnBefore);
|
|
85
|
+
r.addColumnAfter = cmdToItem(addColumnAfter);
|
|
86
|
+
r.deleteColumn = cmdToItem(deleteColumn);
|
|
87
|
+
r.addRowBefore = cmdToItem(addRowBefore);
|
|
88
|
+
r.addRowAfter = cmdToItem(addRowAfter);
|
|
89
|
+
r.deleteRow = cmdToItem(deleteRow);
|
|
90
|
+
r.deleteTable = cmdToItem(deleteTable);
|
|
91
|
+
r.mergeCells = cmdToItem(mergeCells);
|
|
92
|
+
r.splitCell = cmdToItem(splitCell);
|
|
93
|
+
r.toggleHeaderColumn = cmdToItem(toggleHeaderColumn);
|
|
94
|
+
r.toggleHeaderRow = cmdToItem(toggleHeaderRow);
|
|
95
|
+
r.toggleHeaderCell = cmdToItem(toggleHeaderCell);
|
|
96
|
+
r.cellBackgroundColor = new CellBackgroundColorItem(dialog);
|
|
97
|
+
r.tableClass = new ClassItem(dialog, type);
|
|
181
98
|
}
|
|
182
99
|
return r;
|
|
183
100
|
}
|
|
184
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.js","sourceRoot":"","sources":["../../../../../projects/natural-editor/src/lib/utils/menu.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    blockTypeItem,\n    joinUpItem,\n    liftItem,\n    MenuItem,\n    MenuItemSpec,\n    redoItem,\n    selectParentNodeItem,\n    undoItem,\n    wrapItem,\n} from 'prosemirror-menu';\nimport {EditorState, Transaction} from 'prosemirror-state';\nimport {Command, toggleMark} from 'prosemirror-commands';\nimport {wrapInList} from 'prosemirror-schema-list';\nimport {MarkType, NodeType, Schema} from 'prosemirror-model';\nimport {MatDialog} from '@angular/material/dialog';\nimport {LinkDialogComponent, LinkDialogData} from '../link-dialog/link-dialog.component';\nimport {EditorView} from 'prosemirror-view';\nimport {\n    addColumnAfter,\n    addColumnBefore,\n    addRowAfter,\n    addRowBefore,\n    deleteColumn,\n    deleteRow,\n    deleteTable,\n    mergeCells,\n    splitCell,\n    toggleHeaderCell,\n    toggleHeaderColumn,\n    toggleHeaderRow,\n} from 'prosemirror-tables';\nimport {addTable} from './table';\nimport {Item} from './item';\nimport {paragraphWithAlignment} from './paragraph-with-alignment';\nimport {TextAlignItem} from './text-align-item';\n\n/**\n * Convert built-in `MenuItem` into our Angular specific `Item`\n */\nfunction toItem(item: MenuItem): Item {\n    return new Item(item.spec);\n}\n\nfunction canInsert(state: EditorState, nodeType: NodeType): boolean {\n    const $from = state.selection.$from;\n    for (let d = $from.depth; d >= 0; d--) {\n        const index = $from.index(d);\n        if ($from.node(d).canReplaceWith(index, index, nodeType)) {\n            return true;\n        }\n    }\n\n    return false;\n}\n\nfunction cmdItem(cmd: Command, options: Partial<MenuItemSpec> = {}, useEnable = false): Item {\n    const passedOptions: MenuItemSpec = {\n        run: cmd,\n        ...options,\n    };\n\n    if ((!options.enable || useEnable) && !options.select) {\n        passedOptions[options.enable ? 'enable' : 'select'] = (state: EditorState) => cmd(state);\n    }\n\n    return new Item(passedOptions);\n}\n\nfunction markActive(state: EditorState, type: MarkType): boolean {\n    const {from, $from, to, empty} = state.selection;\n    if (empty) {\n        return !!type.isInSet(state.storedMarks || $from.marks());\n    } else {\n        return state.doc.rangeHasMark(from, to, type);\n    }\n}\n\nfunction markItem(markType: MarkType, options: Partial<MenuItemSpec> = {}): Item {\n    const passedOptions: Partial<MenuItemSpec> = {\n        active(state: EditorState): boolean {\n            return markActive(state, markType);\n        },\n        ...options,\n    };\n\n    return cmdItem(toggleMark(markType), passedOptions, true);\n}\n\nfunction linkItem(markType: MarkType, dialog: MatDialog): Item {\n    return new Item({\n        active(state: EditorState): boolean {\n            return markActive(state, markType);\n        },\n        enable(state: EditorState): boolean {\n            return !state.selection.empty;\n        },\n        run(state: EditorState, dispatch: (p: Transaction) => void, view: EditorView): boolean | void {\n            if (markActive(state, markType)) {\n                toggleMark(markType)(state, dispatch);\n                return true;\n            }\n\n            dialog\n                .open<LinkDialogComponent, LinkDialogData, LinkDialogData>(LinkDialogComponent, {\n                    data: {\n                        href: '',\n                        title: '',\n                    },\n                })\n                .afterClosed()\n                .subscribe(result => {\n                    if (result) {\n                        if (!result.title) {\n                            delete result.title;\n                        }\n\n                        toggleMark(markType, result)(view.state, view.dispatch);\n                    }\n\n                    view.focus();\n                });\n        },\n    });\n}\n\nfunction wrapListItem(nodeType: NodeType): Item {\n    return cmdItem(wrapInList(nodeType));\n}\n\nexport type Key =\n    | 'toggleStrong'\n    | 'toggleEm'\n    | 'toggleCode'\n    | 'toggleLink'\n    | 'wrapBulletList'\n    | 'wrapOrderedList'\n    | 'wrapBlockQuote'\n    | 'makeParagraph'\n    | 'makeCodeBlock'\n    | 'makeHead1'\n    | 'makeHead2'\n    | 'makeHead3'\n    | 'makeHead4'\n    | 'makeHead5'\n    | 'makeHead6'\n    | 'alignLeft'\n    | 'alignRight'\n    | 'alignCenter'\n    | 'alignJustify'\n    | 'insertHorizontalRule'\n    | 'joinUp'\n    | 'lift'\n    | 'selectParentNode'\n    | 'undo'\n    | 'redo'\n    | 'insertTable'\n    | 'addColumnBefore'\n    | 'addColumnAfter'\n    | 'deleteColumn'\n    | 'addRowBefore'\n    | 'addRowAfter'\n    | 'deleteRow'\n    | 'deleteTable'\n    | 'mergeCells'\n    | 'splitCell'\n    | 'toggleHeaderColumn'\n    | 'toggleHeaderRow'\n    | 'toggleHeaderCell';\n\nexport type MenuItems = Partial<Record<Key, Item>>;\n\n/**\n * Given a schema, look for default mark and node types in it and\n * return an object with relevant menu items relating to those marks:\n */\nexport function buildMenuItems(schema: Schema, dialog: MatDialog): MenuItems {\n    const r: MenuItems = {\n        joinUp: toItem(joinUpItem),\n        lift: toItem(liftItem),\n        selectParentNode: toItem(selectParentNodeItem),\n        undo: toItem(undoItem as unknown as MenuItem), // Typing is incorrect, so we force it\n        redo: toItem(redoItem as unknown as MenuItem),\n    };\n\n    let type: MarkType | NodeType | undefined;\n    type = schema.marks.strong;\n    if (type) {\n        r.toggleStrong = markItem(type);\n    }\n\n    type = schema.marks.em;\n    if (type) {\n        r.toggleEm = markItem(type);\n    }\n\n    type = schema.marks.code;\n    if (type) {\n        r.toggleCode = markItem(type);\n    }\n\n    type = schema.marks.link;\n    if (type) {\n        r.toggleLink = linkItem(type, dialog);\n    }\n\n    type = schema.nodes.bullet_list;\n    if (type) {\n        r.wrapBulletList = wrapListItem(type);\n    }\n\n    type = schema.nodes.ordered_list;\n    if (type) {\n        r.wrapOrderedList = wrapListItem(type);\n    }\n\n    type = schema.nodes.blockquote;\n    if (type) {\n        r.wrapBlockQuote = toItem(wrapItem(type, {}));\n    }\n\n    type = schema.nodes.paragraph;\n    if (type) {\n        r.makeParagraph = toItem(blockTypeItem(type, {}));\n\n        if (type.spec === paragraphWithAlignment) {\n            r.alignLeft = new TextAlignItem('left');\n            r.alignRight = new TextAlignItem('right');\n            r.alignCenter = new TextAlignItem('center');\n            r.alignJustify = new TextAlignItem('justify');\n        }\n    }\n\n    type = schema.nodes.code_block;\n    if (type) {\n        r.makeCodeBlock = toItem(blockTypeItem(type, {}));\n    }\n\n    type = schema.nodes.heading;\n    if (type) {\n        r.makeHead1 = toItem(blockTypeItem(type, {attrs: {level: 1}}));\n        r.makeHead2 = toItem(blockTypeItem(type, {attrs: {level: 2}}));\n        r.makeHead3 = toItem(blockTypeItem(type, {attrs: {level: 3}}));\n        r.makeHead4 = toItem(blockTypeItem(type, {attrs: {level: 4}}));\n        r.makeHead5 = toItem(blockTypeItem(type, {attrs: {level: 5}}));\n        r.makeHead6 = toItem(blockTypeItem(type, {attrs: {level: 6}}));\n    }\n\n    type = schema.nodes.horizontal_rule;\n    if (type) {\n        const hr = type;\n        r.insertHorizontalRule = new Item({\n            enable(state): boolean {\n                return canInsert(state, hr);\n            },\n            run(state, dispatch): void {\n                dispatch(state.tr.replaceSelectionWith(hr.create()));\n            },\n        });\n    }\n\n    type = schema.nodes.table;\n    if (type) {\n        r.insertTable = new Item({run: (e, tr) => addTable(e, tr)});\n        r.addColumnBefore = new Item({run: addColumnBefore});\n        r.addColumnAfter = new Item({run: addColumnAfter});\n        r.deleteColumn = new Item({run: deleteColumn});\n        r.addRowBefore = new Item({run: addRowBefore});\n        r.addRowAfter = new Item({run: addRowAfter});\n        r.deleteRow = new Item({run: deleteRow});\n        r.deleteTable = new Item({run: deleteTable});\n        r.mergeCells = new Item({run: mergeCells});\n        r.splitCell = new Item({run: splitCell});\n        r.toggleHeaderColumn = new Item({run: toggleHeaderColumn});\n        r.toggleHeaderRow = new Item({run: toggleHeaderRow});\n        r.toggleHeaderCell = new Item({run: toggleHeaderCell});\n    }\n\n    return r;\n}\n"]}
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.js","sourceRoot":"","sources":["../../../../../projects/natural-editor/src/lib/utils/menu.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    blockTypeItem,\n    joinUpItem,\n    liftItem,\n    MenuItem,\n    redoItem,\n    selectParentNodeItem,\n    undoItem,\n    wrapItem,\n} from 'prosemirror-menu';\nimport {MarkType, NodeType, Schema} from 'prosemirror-model';\nimport {MatDialog} from '@angular/material/dialog';\nimport {\n    addColumnAfter,\n    addColumnBefore,\n    addRowAfter,\n    addRowBefore,\n    deleteColumn,\n    deleteRow,\n    deleteTable,\n    mergeCells,\n    splitCell,\n    toggleHeaderCell,\n    toggleHeaderColumn,\n    toggleHeaderRow,\n} from 'prosemirror-tables';\nimport {Item} from './items/item';\nimport {paragraphWithAlignment} from './schema/paragraph-with-alignment';\nimport {TextAlignItem} from './items/text-align-item';\nimport {CellBackgroundColorItem} from './items/cell-background-color-item';\nimport {LinkItem} from './items/link-item';\nimport {HorizontalRuleItem} from './items/horizontal-rule-item';\nimport {cmdToItem, markTypeToItem, menuItemToItem} from './items/utils';\nimport {wrapListItem} from './items/wrap-list-item';\nimport {ClassItem} from './items/class-item';\nimport {AddTableItem} from './items/table-item';\n\nexport type Key =\n    | 'toggleStrong'\n    | 'toggleEm'\n    | 'toggleCode'\n    | 'toggleLink'\n    | 'wrapBulletList'\n    | 'wrapOrderedList'\n    | 'wrapBlockQuote'\n    | 'makeParagraph'\n    | 'makeCodeBlock'\n    | 'makeHead1'\n    | 'makeHead2'\n    | 'makeHead3'\n    | 'makeHead4'\n    | 'makeHead5'\n    | 'makeHead6'\n    | 'alignLeft'\n    | 'alignRight'\n    | 'alignCenter'\n    | 'alignJustify'\n    | 'insertHorizontalRule'\n    | 'joinUp'\n    | 'lift'\n    | 'selectParentNode'\n    | 'undo'\n    | 'redo'\n    | 'insertTable'\n    | 'addColumnBefore'\n    | 'addColumnAfter'\n    | 'deleteColumn'\n    | 'addRowBefore'\n    | 'addRowAfter'\n    | 'deleteRow'\n    | 'deleteTable'\n    | 'mergeCells'\n    | 'splitCell'\n    | 'toggleHeaderColumn'\n    | 'toggleHeaderRow'\n    | 'toggleHeaderCell'\n    | 'cellBackgroundColor'\n    | 'tableClass'\n    | 'paragraphClass';\n\nexport type MenuItems = Partial<Record<Key, Item>>;\n\n/**\n * Given a schema, look for default mark and node types in it and\n * return an object with relevant menu items relating to those marks:\n */\nexport function buildMenuItems(schema: Schema, dialog: MatDialog): MenuItems {\n    const r: MenuItems = {\n        joinUp: menuItemToItem(joinUpItem),\n        lift: menuItemToItem(liftItem),\n        selectParentNode: menuItemToItem(selectParentNodeItem),\n        undo: menuItemToItem(undoItem as unknown as MenuItem), // Typing is incorrect, so we force it\n        redo: menuItemToItem(redoItem as unknown as MenuItem),\n    };\n\n    let type: MarkType | NodeType | undefined;\n    type = schema.marks.strong;\n    if (type) {\n        r.toggleStrong = markTypeToItem(type);\n    }\n\n    type = schema.marks.em;\n    if (type) {\n        r.toggleEm = markTypeToItem(type);\n    }\n\n    type = schema.marks.code;\n    if (type) {\n        r.toggleCode = markTypeToItem(type);\n    }\n\n    type = schema.marks.link;\n    if (type) {\n        r.toggleLink = new LinkItem(type, dialog);\n    }\n\n    type = schema.nodes.bullet_list;\n    if (type) {\n        r.wrapBulletList = wrapListItem(type);\n    }\n\n    type = schema.nodes.ordered_list;\n    if (type) {\n        r.wrapOrderedList = wrapListItem(type);\n    }\n\n    type = schema.nodes.blockquote;\n    if (type) {\n        r.wrapBlockQuote = menuItemToItem(wrapItem(type, {}));\n    }\n\n    type = schema.nodes.paragraph;\n    if (type) {\n        r.makeParagraph = menuItemToItem(blockTypeItem(type, {}));\n\n        if (type.spec === paragraphWithAlignment) {\n            r.alignLeft = new TextAlignItem('left');\n            r.alignRight = new TextAlignItem('right');\n            r.alignCenter = new TextAlignItem('center');\n            r.alignJustify = new TextAlignItem('justify');\n            r.paragraphClass = new ClassItem(dialog, type);\n        }\n    }\n\n    type = schema.nodes.code_block;\n    if (type) {\n        r.makeCodeBlock = menuItemToItem(blockTypeItem(type, {}));\n    }\n\n    type = schema.nodes.heading;\n    if (type) {\n        r.makeHead1 = menuItemToItem(blockTypeItem(type, {attrs: {level: 1}}));\n        r.makeHead2 = menuItemToItem(blockTypeItem(type, {attrs: {level: 2}}));\n        r.makeHead3 = menuItemToItem(blockTypeItem(type, {attrs: {level: 3}}));\n        r.makeHead4 = menuItemToItem(blockTypeItem(type, {attrs: {level: 4}}));\n        r.makeHead5 = menuItemToItem(blockTypeItem(type, {attrs: {level: 5}}));\n        r.makeHead6 = menuItemToItem(blockTypeItem(type, {attrs: {level: 6}}));\n    }\n\n    type = schema.nodes.horizontal_rule;\n    if (type) {\n        r.insertHorizontalRule = new HorizontalRuleItem(type);\n    }\n\n    type = schema.nodes.table;\n    if (type) {\n        r.insertTable = new AddTableItem();\n        r.addColumnBefore = cmdToItem(addColumnBefore);\n        r.addColumnAfter = cmdToItem(addColumnAfter);\n        r.deleteColumn = cmdToItem(deleteColumn);\n        r.addRowBefore = cmdToItem(addRowBefore);\n        r.addRowAfter = cmdToItem(addRowAfter);\n        r.deleteRow = cmdToItem(deleteRow);\n        r.deleteTable = cmdToItem(deleteTable);\n        r.mergeCells = cmdToItem(mergeCells);\n        r.splitCell = cmdToItem(splitCell);\n        r.toggleHeaderColumn = cmdToItem(toggleHeaderColumn);\n        r.toggleHeaderRow = cmdToItem(toggleHeaderRow);\n        r.toggleHeaderCell = cmdToItem(toggleHeaderCell);\n        r.cellBackgroundColor = new CellBackgroundColorItem(dialog);\n        r.tableClass = new ClassItem(dialog, type);\n    }\n\n    return r;\n}\n"]}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
const ALIGN_PATTERN = /(left|right|center|justify)/;
|
|
2
|
+
/**
|
|
3
|
+
* A plain paragraph textblock. Represented in the DOM
|
|
4
|
+
* as a `<p>` element.
|
|
5
|
+
*
|
|
6
|
+
* https://github.com/ProseMirror/prosemirror-schema-basic/blob/master/src/schema-basic.js
|
|
7
|
+
*/
|
|
8
|
+
export const paragraphWithAlignment = {
|
|
9
|
+
attrs: {
|
|
10
|
+
align: { default: null },
|
|
11
|
+
class: { default: null },
|
|
12
|
+
id: { default: null },
|
|
13
|
+
},
|
|
14
|
+
content: 'inline*',
|
|
15
|
+
group: 'block',
|
|
16
|
+
parseDOM: [
|
|
17
|
+
{
|
|
18
|
+
tag: 'p',
|
|
19
|
+
getAttrs: (dom) => {
|
|
20
|
+
if (!(dom instanceof HTMLElement)) {
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
const { textAlign } = dom.style;
|
|
24
|
+
let align = dom.getAttribute('align') || textAlign || '';
|
|
25
|
+
align = ALIGN_PATTERN.test(align) ? align : null;
|
|
26
|
+
const id = dom.getAttribute('id') || '';
|
|
27
|
+
return { align, class: dom.className, id };
|
|
28
|
+
},
|
|
29
|
+
},
|
|
30
|
+
],
|
|
31
|
+
toDOM: node => {
|
|
32
|
+
const { align, id } = node.attrs;
|
|
33
|
+
const attrs = {};
|
|
34
|
+
let style = '';
|
|
35
|
+
if (align && align !== 'left') {
|
|
36
|
+
style += `text-align: ${align};`;
|
|
37
|
+
}
|
|
38
|
+
if (style) {
|
|
39
|
+
attrs.style = style;
|
|
40
|
+
}
|
|
41
|
+
if (id) {
|
|
42
|
+
attrs.id = id;
|
|
43
|
+
}
|
|
44
|
+
if (node.attrs.class) {
|
|
45
|
+
attrs.class = node.attrs.class;
|
|
46
|
+
}
|
|
47
|
+
return ['p', attrs, 0];
|
|
48
|
+
},
|
|
49
|
+
};
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyYWdyYXBoLXdpdGgtYWxpZ25tZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC1lZGl0b3Ivc3JjL2xpYi91dGlscy9zY2hlbWEvcGFyYWdyYXBoLXdpdGgtYWxpZ25tZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sYUFBYSxHQUFHLDZCQUE2QixDQUFDO0FBT3BEOzs7OztHQUtHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQWE7SUFDNUMsS0FBSyxFQUFFO1FBQ0gsS0FBSyxFQUFFLEVBQUMsT0FBTyxFQUFFLElBQUksRUFBQztRQUN0QixLQUFLLEVBQUUsRUFBQyxPQUFPLEVBQUUsSUFBSSxFQUFDO1FBQ3RCLEVBQUUsRUFBRSxFQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUM7S0FDdEI7SUFDRCxPQUFPLEVBQUUsU0FBUztJQUNsQixLQUFLLEVBQUUsT0FBTztJQUNkLFFBQVEsRUFBRTtRQUNOO1lBQ0ksR0FBRyxFQUFFLEdBQUc7WUFDUixRQUFRLEVBQUUsQ0FBQyxHQUFrQixFQUEwQixFQUFFO2dCQUNyRCxJQUFJLENBQUMsQ0FBQyxHQUFHLFlBQVksV0FBVyxDQUFDLEVBQUU7b0JBQy9CLE9BQU87aUJBQ1Y7Z0JBRUQsTUFBTSxFQUFDLFNBQVMsRUFBQyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUM7Z0JBRTlCLElBQUksS0FBSyxHQUFrQixHQUFHLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxJQUFJLFNBQVMsSUFBSSxFQUFFLENBQUM7Z0JBQ3hFLEtBQUssR0FBRyxhQUFhLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztnQkFFakQsTUFBTSxFQUFFLEdBQUcsR0FBRyxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7Z0JBRXhDLE9BQU8sRUFBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEdBQUcsQ0FBQyxTQUFTLEVBQUUsRUFBRSxFQUFDLENBQUM7WUFDN0MsQ0FBQztTQUNKO0tBQ0o7SUFDRCxLQUFLLEVBQUUsSUFBSSxDQUFDLEVBQUU7UUFDVixNQUFNLEVBQUMsS0FBSyxFQUFFLEVBQUUsRUFBQyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUM7UUFDL0IsTUFBTSxLQUFLLEdBQTRCLEVBQUUsQ0FBQztRQUUxQyxJQUFJLEtBQUssR0FBRyxFQUFFLENBQUM7UUFDZixJQUFJLEtBQUssSUFBSSxLQUFLLEtBQUssTUFBTSxFQUFFO1lBQzNCLEtBQUssSUFBSSxlQUFlLEtBQUssR0FBRyxDQUFDO1NBQ3BDO1FBRUQsSUFBSSxLQUFLLEVBQUU7WUFDUCxLQUFLLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztTQUN2QjtRQUVELElBQUksRUFBRSxFQUFFO1lBQ0osS0FBSyxDQUFDLEVBQUUsR0FBRyxFQUFFLENBQUM7U0FDakI7UUFFRCxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxFQUFFO1lBQ2xCLEtBQUssQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUM7U0FDbEM7UUFFRCxPQUFPLENBQUMsR0FBRyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQztJQUMzQixDQUFDO0NBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Tm9kZVNwZWN9IGZyb20gJ3Byb3NlbWlycm9yLW1vZGVsJztcblxuY29uc3QgQUxJR05fUEFUVEVSTiA9IC8obGVmdHxyaWdodHxjZW50ZXJ8anVzdGlmeSkvO1xudHlwZSBBdHRyaWJ1dGVzID0ge1xuICAgIGFsaWduOiBudWxsIHwgc3RyaW5nO1xuICAgIGNsYXNzOiBzdHJpbmc7XG4gICAgaWQ6IHN0cmluZztcbn07XG5cbi8qKlxuICogQSBwbGFpbiBwYXJhZ3JhcGggdGV4dGJsb2NrLiBSZXByZXNlbnRlZCBpbiB0aGUgRE9NXG4gKiBhcyBhIGA8cD5gIGVsZW1lbnQuXG4gKlxuICogaHR0cHM6Ly9naXRodWIuY29tL1Byb3NlTWlycm9yL3Byb3NlbWlycm9yLXNjaGVtYS1iYXNpYy9ibG9iL21hc3Rlci9zcmMvc2NoZW1hLWJhc2ljLmpzXG4gKi9cbmV4cG9ydCBjb25zdCBwYXJhZ3JhcGhXaXRoQWxpZ25tZW50OiBOb2RlU3BlYyA9IHtcbiAgICBhdHRyczoge1xuICAgICAgICBhbGlnbjoge2RlZmF1bHQ6IG51bGx9LFxuICAgICAgICBjbGFzczoge2RlZmF1bHQ6IG51bGx9LFxuICAgICAgICBpZDoge2RlZmF1bHQ6IG51bGx9LFxuICAgIH0sXG4gICAgY29udGVudDogJ2lubGluZSonLFxuICAgIGdyb3VwOiAnYmxvY2snLFxuICAgIHBhcnNlRE9NOiBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIHRhZzogJ3AnLFxuICAgICAgICAgICAgZ2V0QXR0cnM6IChkb206IE5vZGUgfCBzdHJpbmcpOiB1bmRlZmluZWQgfCBBdHRyaWJ1dGVzID0+IHtcbiAgICAgICAgICAgICAgICBpZiAoIShkb20gaW5zdGFuY2VvZiBIVE1MRWxlbWVudCkpIHtcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgIGNvbnN0IHt0ZXh0QWxpZ259ID0gZG9tLnN0eWxlO1xuXG4gICAgICAgICAgICAgICAgbGV0IGFsaWduOiBzdHJpbmcgfCBudWxsID0gZG9tLmdldEF0dHJpYnV0ZSgnYWxpZ24nKSB8fCB0ZXh0QWxpZ24gfHwgJyc7XG4gICAgICAgICAgICAgICAgYWxpZ24gPSBBTElHTl9QQVRURVJOLnRlc3QoYWxpZ24pID8gYWxpZ24gOiBudWxsO1xuXG4gICAgICAgICAgICAgICAgY29uc3QgaWQgPSBkb20uZ2V0QXR0cmlidXRlKCdpZCcpIHx8ICcnO1xuXG4gICAgICAgICAgICAgICAgcmV0dXJuIHthbGlnbiwgY2xhc3M6IGRvbS5jbGFzc05hbWUsIGlkfTtcbiAgICAgICAgICAgIH0sXG4gICAgICAgIH0sXG4gICAgXSxcbiAgICB0b0RPTTogbm9kZSA9PiB7XG4gICAgICAgIGNvbnN0IHthbGlnbiwgaWR9ID0gbm9kZS5hdHRycztcbiAgICAgICAgY29uc3QgYXR0cnM6IHtba2V5OiBzdHJpbmddOiBzdHJpbmd9ID0ge307XG5cbiAgICAgICAgbGV0IHN0eWxlID0gJyc7XG4gICAgICAgIGlmIChhbGlnbiAmJiBhbGlnbiAhPT0gJ2xlZnQnKSB7XG4gICAgICAgICAgICBzdHlsZSArPSBgdGV4dC1hbGlnbjogJHthbGlnbn07YDtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChzdHlsZSkge1xuICAgICAgICAgICAgYXR0cnMuc3R5bGUgPSBzdHlsZTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChpZCkge1xuICAgICAgICAgICAgYXR0cnMuaWQgPSBpZDtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChub2RlLmF0dHJzLmNsYXNzKSB7XG4gICAgICAgICAgICBhdHRycy5jbGFzcyA9IG5vZGUuYXR0cnMuY2xhc3M7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gWydwJywgYXR0cnMsIDBdO1xuICAgIH0sXG59O1xuIl19
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { marks, nodes } from 'prosemirror-schema-basic';
|
|
2
|
+
import { addListNodes } from 'prosemirror-schema-list';
|
|
3
|
+
import { Schema } from 'prosemirror-model';
|
|
4
|
+
import { paragraphWithAlignment } from './paragraph-with-alignment';
|
|
5
|
+
import { tableNodes } from './table';
|
|
6
|
+
const basicNodes = {
|
|
7
|
+
heading: nodes.heading,
|
|
8
|
+
doc: nodes.doc,
|
|
9
|
+
paragraph: nodes.paragraph,
|
|
10
|
+
text: nodes.text,
|
|
11
|
+
hard_break: nodes.hard_break,
|
|
12
|
+
};
|
|
13
|
+
const basicMarks = {
|
|
14
|
+
link: marks.link,
|
|
15
|
+
em: marks.em,
|
|
16
|
+
strong: marks.strong,
|
|
17
|
+
};
|
|
18
|
+
const tmpSchema = new Schema({ nodes: basicNodes, marks: basicMarks });
|
|
19
|
+
export const basicSchema = new Schema({
|
|
20
|
+
nodes: addListNodes(tmpSchema.spec.nodes, 'paragraph block*', 'block'),
|
|
21
|
+
marks: tmpSchema.spec.marks,
|
|
22
|
+
});
|
|
23
|
+
const tmpSchema2 = new Schema({
|
|
24
|
+
nodes: {
|
|
25
|
+
...nodes,
|
|
26
|
+
...tableNodes({
|
|
27
|
+
tableGroup: 'block',
|
|
28
|
+
cellContent: 'block+',
|
|
29
|
+
cellAttributes: {
|
|
30
|
+
background: {
|
|
31
|
+
default: null,
|
|
32
|
+
getFromDOM(dom) {
|
|
33
|
+
return dom.style.backgroundColor || null;
|
|
34
|
+
},
|
|
35
|
+
setDOMAttr(value, attrs) {
|
|
36
|
+
if (value) {
|
|
37
|
+
attrs.style = (attrs.style || '') + `background-color: ${value};`;
|
|
38
|
+
}
|
|
39
|
+
},
|
|
40
|
+
},
|
|
41
|
+
},
|
|
42
|
+
}),
|
|
43
|
+
paragraph: paragraphWithAlignment,
|
|
44
|
+
},
|
|
45
|
+
marks: basicMarks,
|
|
46
|
+
});
|
|
47
|
+
export const advancedSchema = new Schema({
|
|
48
|
+
nodes: addListNodes(tmpSchema2.spec.nodes, 'paragraph block*', 'block'),
|
|
49
|
+
marks: basicMarks,
|
|
50
|
+
});
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC1lZGl0b3Ivc3JjL2xpYi91dGlscy9zY2hlbWEvc2NoZW1hLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxLQUFLLEVBQUUsS0FBSyxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDdEQsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ3JELE9BQU8sRUFBQyxNQUFNLEVBQUMsTUFBTSxtQkFBbUIsQ0FBQztBQUN6QyxPQUFPLEVBQUMsc0JBQXNCLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUNsRSxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sU0FBUyxDQUFDO0FBSW5DLE1BQU0sVUFBVSxHQUFlO0lBQzNCLE9BQU8sRUFBRSxLQUFLLENBQUMsT0FBTztJQUN0QixHQUFHLEVBQUUsS0FBSyxDQUFDLEdBQUc7SUFDZCxTQUFTLEVBQUUsS0FBSyxDQUFDLFNBQVM7SUFDMUIsSUFBSSxFQUFFLEtBQUssQ0FBQyxJQUFJO0lBQ2hCLFVBQVUsRUFBRSxLQUFLLENBQUMsVUFBVTtDQUMvQixDQUFDO0FBR0YsTUFBTSxVQUFVLEdBQWU7SUFDM0IsSUFBSSxFQUFFLEtBQUssQ0FBQyxJQUFJO0lBQ2hCLEVBQUUsRUFBRSxLQUFLLENBQUMsRUFBRTtJQUNaLE1BQU0sRUFBRSxLQUFLLENBQUMsTUFBTTtDQUN2QixDQUFDO0FBRUYsTUFBTSxTQUFTLEdBQUcsSUFBSSxNQUFNLENBQUMsRUFBQyxLQUFLLEVBQUUsVUFBVSxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUMsQ0FBQyxDQUFDO0FBRXJFLE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyxJQUFJLE1BQU0sQ0FBQztJQUNsQyxLQUFLLEVBQUUsWUFBWSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLGtCQUFrQixFQUFFLE9BQU8sQ0FBQztJQUN0RSxLQUFLLEVBQUUsU0FBUyxDQUFDLElBQUksQ0FBQyxLQUFLO0NBQzlCLENBQUMsQ0FBQztBQUVILE1BQU0sVUFBVSxHQUFHLElBQUksTUFBTSxDQUFDO0lBQzFCLEtBQUssRUFBRTtRQUNILEdBQUcsS0FBSztRQUNSLEdBQUcsVUFBVSxDQUFDO1lBQ1YsVUFBVSxFQUFFLE9BQU87WUFDbkIsV0FBVyxFQUFFLFFBQVE7WUFDckIsY0FBYyxFQUFFO2dCQUNaLFVBQVUsRUFBRTtvQkFDUixPQUFPLEVBQUUsSUFBSTtvQkFDYixVQUFVLENBQUMsR0FBWTt3QkFDbkIsT0FBUSxHQUFtQixDQUFDLEtBQUssQ0FBQyxlQUFlLElBQUksSUFBSSxDQUFDO29CQUM5RCxDQUFDO29CQUNELFVBQVUsQ0FBQyxLQUFVLEVBQUUsS0FBVTt3QkFDN0IsSUFBSSxLQUFLLEVBQUU7NEJBQ1AsS0FBSyxDQUFDLEtBQUssR0FBRyxDQUFDLEtBQUssQ0FBQyxLQUFLLElBQUksRUFBRSxDQUFDLEdBQUcscUJBQXFCLEtBQUssR0FBRyxDQUFDO3lCQUNyRTtvQkFDTCxDQUFDO2lCQUNKO2FBQ0o7U0FDSixDQUFDO1FBQ0YsU0FBUyxFQUFFLHNCQUFzQjtLQUNwQztJQUNELEtBQUssRUFBRSxVQUFVO0NBQ3BCLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRyxJQUFJLE1BQU0sQ0FBQztJQUNyQyxLQUFLLEVBQUUsWUFBWSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLGtCQUFrQixFQUFFLE9BQU8sQ0FBQztJQUN2RSxLQUFLLEVBQUUsVUFBVTtDQUNwQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge21hcmtzLCBub2Rlc30gZnJvbSAncHJvc2VtaXJyb3Itc2NoZW1hLWJhc2ljJztcbmltcG9ydCB7YWRkTGlzdE5vZGVzfSBmcm9tICdwcm9zZW1pcnJvci1zY2hlbWEtbGlzdCc7XG5pbXBvcnQge1NjaGVtYX0gZnJvbSAncHJvc2VtaXJyb3ItbW9kZWwnO1xuaW1wb3J0IHtwYXJhZ3JhcGhXaXRoQWxpZ25tZW50fSBmcm9tICcuL3BhcmFncmFwaC13aXRoLWFsaWdubWVudCc7XG5pbXBvcnQge3RhYmxlTm9kZXN9IGZyb20gJy4vdGFibGUnO1xuXG4vLyBLZWVwIG9ubHkgYmFzaWMgZWxlbWVudHNcbnR5cGUgQmFzaWNOb2RlcyA9IE9taXQ8dHlwZW9mIG5vZGVzLCAnaW1hZ2UnIHwgJ2NvZGVfYmxvY2snIHwgJ2Jsb2NrcXVvdGUnIHwgJ2hvcml6b250YWxfcnVsZSc+O1xuY29uc3QgYmFzaWNOb2RlczogQmFzaWNOb2RlcyA9IHtcbiAgICBoZWFkaW5nOiBub2Rlcy5oZWFkaW5nLFxuICAgIGRvYzogbm9kZXMuZG9jLFxuICAgIHBhcmFncmFwaDogbm9kZXMucGFyYWdyYXBoLFxuICAgIHRleHQ6IG5vZGVzLnRleHQsXG4gICAgaGFyZF9icmVhazogbm9kZXMuaGFyZF9icmVhayxcbn07XG5cbnR5cGUgQmFzaWNNYXJrcyA9IE9taXQ8dHlwZW9mIG1hcmtzLCAnY29kZSc+O1xuY29uc3QgYmFzaWNNYXJrczogQmFzaWNNYXJrcyA9IHtcbiAgICBsaW5rOiBtYXJrcy5saW5rLFxuICAgIGVtOiBtYXJrcy5lbSxcbiAgICBzdHJvbmc6IG1hcmtzLnN0cm9uZyxcbn07XG5cbmNvbnN0IHRtcFNjaGVtYSA9IG5ldyBTY2hlbWEoe25vZGVzOiBiYXNpY05vZGVzLCBtYXJrczogYmFzaWNNYXJrc30pO1xuXG5leHBvcnQgY29uc3QgYmFzaWNTY2hlbWEgPSBuZXcgU2NoZW1hKHtcbiAgICBub2RlczogYWRkTGlzdE5vZGVzKHRtcFNjaGVtYS5zcGVjLm5vZGVzLCAncGFyYWdyYXBoIGJsb2NrKicsICdibG9jaycpLFxuICAgIG1hcmtzOiB0bXBTY2hlbWEuc3BlYy5tYXJrcyxcbn0pO1xuXG5jb25zdCB0bXBTY2hlbWEyID0gbmV3IFNjaGVtYSh7XG4gICAgbm9kZXM6IHtcbiAgICAgICAgLi4ubm9kZXMsXG4gICAgICAgIC4uLnRhYmxlTm9kZXMoe1xuICAgICAgICAgICAgdGFibGVHcm91cDogJ2Jsb2NrJyxcbiAgICAgICAgICAgIGNlbGxDb250ZW50OiAnYmxvY2srJyxcbiAgICAgICAgICAgIGNlbGxBdHRyaWJ1dGVzOiB7XG4gICAgICAgICAgICAgICAgYmFja2dyb3VuZDoge1xuICAgICAgICAgICAgICAgICAgICBkZWZhdWx0OiBudWxsLFxuICAgICAgICAgICAgICAgICAgICBnZXRGcm9tRE9NKGRvbTogRWxlbWVudCk6IHN0cmluZyB8IG51bGwge1xuICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIChkb20gYXMgSFRNTEVsZW1lbnQpLnN0eWxlLmJhY2tncm91bmRDb2xvciB8fCBudWxsO1xuICAgICAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgICAgICBzZXRET01BdHRyKHZhbHVlOiBhbnksIGF0dHJzOiBhbnkpOiB2b2lkIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmICh2YWx1ZSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGF0dHJzLnN0eWxlID0gKGF0dHJzLnN0eWxlIHx8ICcnKSArIGBiYWNrZ3JvdW5kLWNvbG9yOiAke3ZhbHVlfTtgO1xuICAgICAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB9LFxuICAgICAgICB9KSxcbiAgICAgICAgcGFyYWdyYXBoOiBwYXJhZ3JhcGhXaXRoQWxpZ25tZW50LFxuICAgIH0sXG4gICAgbWFya3M6IGJhc2ljTWFya3MsXG59KTtcblxuZXhwb3J0IGNvbnN0IGFkdmFuY2VkU2NoZW1hID0gbmV3IFNjaGVtYSh7XG4gICAgbm9kZXM6IGFkZExpc3ROb2Rlcyh0bXBTY2hlbWEyLnNwZWMubm9kZXMsICdwYXJhZ3JhcGggYmxvY2sqJywgJ2Jsb2NrJyksXG4gICAgbWFya3M6IGJhc2ljTWFya3MsXG59KTtcbiJdfQ==
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
function getCellAttrs(dom, extraAttrs) {
|
|
2
|
+
if (!(dom instanceof HTMLElement)) {
|
|
3
|
+
return;
|
|
4
|
+
}
|
|
5
|
+
const widthAttr = dom.getAttribute('data-colwidth');
|
|
6
|
+
const widths = widthAttr && /^\d+(,\d+)*$/.test(widthAttr) ? widthAttr.split(',').map(s => Number(s)) : null;
|
|
7
|
+
const colspan = Number(dom.getAttribute('colspan') || 1);
|
|
8
|
+
const result = {
|
|
9
|
+
colspan,
|
|
10
|
+
rowspan: Number(dom.getAttribute('rowspan') || 1),
|
|
11
|
+
colwidth: widths && widths.length == colspan ? widths : null,
|
|
12
|
+
};
|
|
13
|
+
for (const prop in extraAttrs) {
|
|
14
|
+
const getter = extraAttrs[prop].getFromDOM;
|
|
15
|
+
const value = getter && getter(dom);
|
|
16
|
+
if (value != null)
|
|
17
|
+
result[prop] = value;
|
|
18
|
+
}
|
|
19
|
+
return result;
|
|
20
|
+
}
|
|
21
|
+
function setCellAttrs(node, extraAttrs) {
|
|
22
|
+
const attrs = {};
|
|
23
|
+
if (node.attrs.colspan != 1)
|
|
24
|
+
attrs.colspan = node.attrs.colspan;
|
|
25
|
+
if (node.attrs.rowspan != 1)
|
|
26
|
+
attrs.rowspan = node.attrs.rowspan;
|
|
27
|
+
if (node.attrs.colwidth)
|
|
28
|
+
attrs['data-colwidth'] = node.attrs.colwidth.join(',');
|
|
29
|
+
for (const prop in extraAttrs) {
|
|
30
|
+
const setter = extraAttrs[prop].setDOMAttr;
|
|
31
|
+
if (setter)
|
|
32
|
+
setter(node.attrs[prop], attrs);
|
|
33
|
+
}
|
|
34
|
+
return attrs;
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* This function creates a set of [node
|
|
38
|
+
* specs](http://prosemirror.net/docs/ref/#model.SchemaSpec.nodes) for
|
|
39
|
+
* `table`, `table_row`, and `table_cell` nodes types.
|
|
40
|
+
*
|
|
41
|
+
* It is very directly inspired by prosemirror-table
|
|
42
|
+
*/
|
|
43
|
+
export function tableNodes(options) {
|
|
44
|
+
const extraAttrs = options.cellAttributes || {};
|
|
45
|
+
const cellAttrs = {
|
|
46
|
+
colspan: { default: 1 },
|
|
47
|
+
rowspan: { default: 1 },
|
|
48
|
+
colwidth: { default: null },
|
|
49
|
+
};
|
|
50
|
+
for (const prop in extraAttrs) {
|
|
51
|
+
cellAttrs[prop] = {
|
|
52
|
+
default: extraAttrs[prop].default,
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
return {
|
|
56
|
+
table: {
|
|
57
|
+
attrs: {
|
|
58
|
+
class: { default: null },
|
|
59
|
+
},
|
|
60
|
+
content: 'table_row+',
|
|
61
|
+
tableRole: 'table',
|
|
62
|
+
isolating: true,
|
|
63
|
+
group: options.tableGroup,
|
|
64
|
+
parseDOM: [
|
|
65
|
+
{
|
|
66
|
+
tag: 'table',
|
|
67
|
+
getAttrs: (dom) => {
|
|
68
|
+
if (!(dom instanceof HTMLElement)) {
|
|
69
|
+
return;
|
|
70
|
+
}
|
|
71
|
+
return { class: dom.className };
|
|
72
|
+
},
|
|
73
|
+
},
|
|
74
|
+
],
|
|
75
|
+
toDOM: node => {
|
|
76
|
+
const attrs = {};
|
|
77
|
+
if (node.attrs.class) {
|
|
78
|
+
attrs.class = node.attrs.class;
|
|
79
|
+
}
|
|
80
|
+
return ['table', attrs, ['tbody', 0]];
|
|
81
|
+
},
|
|
82
|
+
},
|
|
83
|
+
table_row: {
|
|
84
|
+
content: '(table_cell | table_header)*',
|
|
85
|
+
tableRole: 'row',
|
|
86
|
+
parseDOM: [{ tag: 'tr' }],
|
|
87
|
+
toDOM: () => {
|
|
88
|
+
return ['tr', 0];
|
|
89
|
+
},
|
|
90
|
+
},
|
|
91
|
+
table_cell: {
|
|
92
|
+
content: options.cellContent,
|
|
93
|
+
attrs: cellAttrs,
|
|
94
|
+
tableRole: 'cell',
|
|
95
|
+
isolating: true,
|
|
96
|
+
parseDOM: [{ tag: 'td', getAttrs: dom => getCellAttrs(dom, extraAttrs) }],
|
|
97
|
+
toDOM: node => {
|
|
98
|
+
return ['td', setCellAttrs(node, extraAttrs), 0];
|
|
99
|
+
},
|
|
100
|
+
},
|
|
101
|
+
table_header: {
|
|
102
|
+
content: options.cellContent,
|
|
103
|
+
attrs: cellAttrs,
|
|
104
|
+
tableRole: 'header_cell',
|
|
105
|
+
isolating: true,
|
|
106
|
+
parseDOM: [{ tag: 'th', getAttrs: dom => getCellAttrs(dom, extraAttrs) }],
|
|
107
|
+
toDOM: node => {
|
|
108
|
+
return ['th', setCellAttrs(node, extraAttrs), 0];
|
|
109
|
+
},
|
|
110
|
+
},
|
|
111
|
+
};
|
|
112
|
+
}
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.js","sourceRoot":"","sources":["../../../../../../projects/natural-editor/src/lib/utils/schema/table.ts"],"names":[],"mappings":"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","sourcesContent":["import {TableNodes, TableNodesOptions} from 'prosemirror-tables';\nimport {Node as ProsemirrorNode} from 'prosemirror-model';\n\ntype CellAttributes = TableNodesOptions['cellAttributes'];\ntype Attributes = {[key: string]: number | string | null | number[]};\n\nfunction getCellAttrs(dom: Node | string, extraAttrs: CellAttributes): undefined | Attributes {\n    if (!(dom instanceof HTMLElement)) {\n        return;\n    }\n\n    const widthAttr = dom.getAttribute('data-colwidth');\n    const widths = widthAttr && /^\\d+(,\\d+)*$/.test(widthAttr) ? widthAttr.split(',').map(s => Number(s)) : null;\n    const colspan = Number(dom.getAttribute('colspan') || 1);\n    const result: Attributes = {\n        colspan,\n        rowspan: Number(dom.getAttribute('rowspan') || 1),\n        colwidth: widths && widths.length == colspan ? widths : null,\n    };\n\n    for (const prop in extraAttrs) {\n        const getter = extraAttrs[prop].getFromDOM;\n        const value = getter && getter(dom);\n        if (value != null) result[prop] = value;\n    }\n\n    return result;\n}\n\nfunction setCellAttrs(node: ProsemirrorNode, extraAttrs: CellAttributes): undefined | Record<string, string> {\n    const attrs: Record<string, string> = {};\n    if (node.attrs.colspan != 1) attrs.colspan = node.attrs.colspan;\n    if (node.attrs.rowspan != 1) attrs.rowspan = node.attrs.rowspan;\n    if (node.attrs.colwidth) attrs['data-colwidth'] = node.attrs.colwidth.join(',');\n\n    for (const prop in extraAttrs) {\n        const setter = extraAttrs[prop].setDOMAttr;\n        if (setter) setter(node.attrs[prop], attrs);\n    }\n\n    return attrs;\n}\n\n/**\n * This function creates a set of [node\n * specs](http://prosemirror.net/docs/ref/#model.SchemaSpec.nodes) for\n * `table`, `table_row`, and `table_cell` nodes types.\n *\n * It is very directly inspired by prosemirror-table\n */\nexport function tableNodes(options: TableNodesOptions): TableNodes {\n    const extraAttrs = options.cellAttributes || {};\n    const cellAttrs: CellAttributes = {\n        colspan: {default: 1},\n        rowspan: {default: 1},\n        colwidth: {default: null},\n    };\n\n    for (const prop in extraAttrs) {\n        cellAttrs[prop] = {\n            default: extraAttrs[prop].default,\n        };\n    }\n\n    return {\n        table: {\n            attrs: {\n                class: {default: null},\n            },\n            content: 'table_row+',\n            tableRole: 'table',\n            isolating: true,\n            group: options.tableGroup,\n            parseDOM: [\n                {\n                    tag: 'table',\n                    getAttrs: (dom: Node | string): undefined | Attributes => {\n                        if (!(dom instanceof HTMLElement)) {\n                            return;\n                        }\n\n                        return {class: dom.className};\n                    },\n                },\n            ],\n            toDOM: node => {\n                const attrs: Record<string, string> = {};\n                if (node.attrs.class) {\n                    attrs.class = node.attrs.class;\n                }\n\n                return ['table', attrs, ['tbody', 0]];\n            },\n        },\n        table_row: {\n            content: '(table_cell | table_header)*',\n            tableRole: 'row',\n            parseDOM: [{tag: 'tr'}],\n            toDOM: () => {\n                return ['tr', 0];\n            },\n        },\n        table_cell: {\n            content: options.cellContent,\n            attrs: cellAttrs,\n            tableRole: 'cell',\n            isolating: true,\n            parseDOM: [{tag: 'td', getAttrs: dom => getCellAttrs(dom, extraAttrs)}],\n            toDOM: node => {\n                return ['td', setCellAttrs(node, extraAttrs), 0];\n            },\n        },\n        table_header: {\n            content: options.cellContent,\n            attrs: cellAttrs,\n            tableRole: 'header_cell',\n            isolating: true,\n            parseDOM: [{tag: 'th', getAttrs: dom => getCellAttrs(dom, extraAttrs)}],\n            toDOM: node => {\n                return ['th', setCellAttrs(node, extraAttrs), 0];\n            },\n        },\n    };\n}\n"]}
|
package/esm2020/public-api.mjs
CHANGED
|
@@ -3,6 +3,7 @@ import '@angular/localize/init';
|
|
|
3
3
|
/*
|
|
4
4
|
* Public API Surface of natural-editor
|
|
5
5
|
*/
|
|
6
|
+
export { NaturalCustomCssDirective } from './lib/custom-css/custom-css.directive';
|
|
6
7
|
export { NaturalEditorComponent } from './lib/editor/editor.component';
|
|
7
8
|
export { NaturalEditorModule } from './lib/editor.module';
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwtZWRpdG9yL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHdIQUF3SDtBQUN4SCxPQUFPLHdCQUF3QixDQUFDO0FBRWhDOztHQUVHO0FBRUgsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFDaEYsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0sK0JBQStCLENBQUM7QUFDckUsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0scUJBQXFCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBMb2FkIGAkbG9jYWxpemVgIG9udG8gdGhlIGdsb2JhbCBzY29wZSAtIHRvIGJlIGFibGUgdG8gdXNlIHRoYXQgZnVuY3Rpb24gdG8gdHJhbnNsYXRlIHN0cmluZ3MgaW4gY29tcG9uZW50cy9zZXJ2aWNlcy5cbmltcG9ydCAnQGFuZ3VsYXIvbG9jYWxpemUvaW5pdCc7XG5cbi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgbmF0dXJhbC1lZGl0b3JcbiAqL1xuXG5leHBvcnQge05hdHVyYWxDdXN0b21Dc3NEaXJlY3RpdmV9IGZyb20gJy4vbGliL2N1c3RvbS1jc3MvY3VzdG9tLWNzcy5kaXJlY3RpdmUnO1xuZXhwb3J0IHtOYXR1cmFsRWRpdG9yQ29tcG9uZW50fSBmcm9tICcuL2xpYi9lZGl0b3IvZWRpdG9yLmNvbXBvbmVudCc7XG5leHBvcnQge05hdHVyYWxFZGl0b3JNb2R1bGV9IGZyb20gJy4vbGliL2VkaXRvci5tb2R1bGUnO1xuIl19
|