@ecodev/natural-editor 41.2.0 → 42.0.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/{esm2015/ecodev-natural-editor.js → esm2020/ecodev-natural-editor.mjs} +0 -0
- package/esm2020/lib/editor/editor.component.mjs +213 -0
- package/{esm2015/lib/editor.module.js → esm2020/lib/editor.module.mjs} +4 -4
- package/{esm2015/lib/link-dialog/link-dialog.component.js → esm2020/lib/link-dialog/link-dialog.component.mjs} +5 -8
- package/esm2020/lib/utils/image.mjs +81 -0
- package/esm2020/lib/utils/inputrules.mjs +70 -0
- package/esm2020/lib/utils/item.mjs +39 -0
- package/esm2020/lib/utils/keymap.mjs +115 -0
- package/esm2020/lib/utils/menu.mjs +184 -0
- package/esm2020/lib/utils/paragraph-with-alignment.mjs +43 -0
- package/esm2020/lib/utils/schema.mjs +51 -0
- package/{esm2015/lib/utils/table.js → esm2020/lib/utils/table.mjs} +2 -2
- package/esm2020/lib/utils/text-align-item.mjs +81 -0
- package/{esm2015/public-api.js → esm2020/public-api.mjs} +0 -0
- package/fesm2015/ecodev-natural-editor.mjs +995 -0
- package/fesm2015/ecodev-natural-editor.mjs.map +1 -0
- package/fesm2020/ecodev-natural-editor.mjs +1001 -0
- package/fesm2020/ecodev-natural-editor.mjs.map +1 -0
- package/lib/editor/editor.component.d.ts +1 -0
- package/lib/utils/inputrules.d.ts +7 -0
- package/lib/utils/item.d.ts +30 -0
- package/lib/utils/keymap.d.ts +32 -0
- package/lib/utils/menu.d.ts +2 -31
- package/lib/utils/paragraph-with-alignment.d.ts +2 -0
- package/lib/utils/text-align-item.d.ts +6 -0
- package/package.json +31 -10
- package/src/lib/editor/_editor.theme.scss +1 -1
- package/theming/_natural-editor.theme.scss +1 -1
- package/bundles/ecodev-natural-editor.umd.js +0 -1026
- package/bundles/ecodev-natural-editor.umd.js.map +0 -1
- package/esm2015/lib/editor/editor.component.js +0 -200
- package/esm2015/lib/utils/image.js +0 -81
- package/esm2015/lib/utils/menu.js +0 -207
- package/esm2015/lib/utils/schema.js +0 -46
- package/fesm2015/ecodev-natural-editor.js +0 -673
- package/fesm2015/ecodev-natural-editor.js.map +0 -1
|
@@ -1,81 +0,0 @@
|
|
|
1
|
-
import { Decoration, DecorationSet } from 'prosemirror-view';
|
|
2
|
-
import { Plugin } from 'prosemirror-state';
|
|
3
|
-
import { Inject, Injectable } from '@angular/core';
|
|
4
|
-
import { DOCUMENT } from '@angular/common';
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
export class ImagePlugin {
|
|
7
|
-
constructor(document) {
|
|
8
|
-
this.document = document;
|
|
9
|
-
this.plugin = new Plugin({
|
|
10
|
-
state: {
|
|
11
|
-
init() {
|
|
12
|
-
return DecorationSet.empty;
|
|
13
|
-
},
|
|
14
|
-
apply(tr, set) {
|
|
15
|
-
// Adjust decoration positions to changes made by the transaction
|
|
16
|
-
set = set.map(tr.mapping, tr.doc);
|
|
17
|
-
// See if the transaction adds or removes any placeholders
|
|
18
|
-
const action = tr.getMeta(this);
|
|
19
|
-
if (action && action.add) {
|
|
20
|
-
const widget = document.createElement('placeholder');
|
|
21
|
-
const deco = Decoration.widget(action.add.pos, widget, { id: action.add.id });
|
|
22
|
-
set = set.add(tr.doc, [deco]);
|
|
23
|
-
}
|
|
24
|
-
else if (action && action.remove) {
|
|
25
|
-
set = set.remove(set.find(undefined, undefined, spec => spec.id === action.remove.id));
|
|
26
|
-
}
|
|
27
|
-
return set;
|
|
28
|
-
},
|
|
29
|
-
},
|
|
30
|
-
props: {
|
|
31
|
-
decorations(state) {
|
|
32
|
-
return this.getState(state);
|
|
33
|
-
},
|
|
34
|
-
},
|
|
35
|
-
});
|
|
36
|
-
}
|
|
37
|
-
findPlaceholder(state, id) {
|
|
38
|
-
const decorators = this.plugin.getState(state);
|
|
39
|
-
const found = decorators.find(undefined, undefined, spec => spec.id === id);
|
|
40
|
-
return found.length ? found[0].from : null;
|
|
41
|
-
}
|
|
42
|
-
startImageUpload(view, file, uploader, schema) {
|
|
43
|
-
// A fresh object to act as the ID for this upload
|
|
44
|
-
const id = {};
|
|
45
|
-
// Replace the selection with a placeholder
|
|
46
|
-
const tr = view.state.tr;
|
|
47
|
-
if (!tr.selection.empty) {
|
|
48
|
-
tr.deleteSelection();
|
|
49
|
-
}
|
|
50
|
-
tr.setMeta(this.plugin, { add: { id, pos: tr.selection.from } });
|
|
51
|
-
view.dispatch(tr);
|
|
52
|
-
uploader(file).subscribe({
|
|
53
|
-
next: url => {
|
|
54
|
-
const pos = this.findPlaceholder(view.state, id);
|
|
55
|
-
// If the content around the placeholder has been deleted, drop
|
|
56
|
-
// the image
|
|
57
|
-
if (pos === null) {
|
|
58
|
-
return;
|
|
59
|
-
}
|
|
60
|
-
// Otherwise, insert it at the placeholder's position, and remove
|
|
61
|
-
// the placeholder
|
|
62
|
-
view.dispatch(view.state.tr
|
|
63
|
-
.replaceWith(pos, pos, schema.nodes.image.create({ src: url }))
|
|
64
|
-
.setMeta(this.plugin, { remove: { id } }));
|
|
65
|
-
},
|
|
66
|
-
error: () => {
|
|
67
|
-
// On failure, just clean up the placeholder
|
|
68
|
-
view === null || view === void 0 ? void 0 : view.dispatch(tr.setMeta(this.plugin, { remove: { id } }));
|
|
69
|
-
},
|
|
70
|
-
});
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
ImagePlugin.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: ImagePlugin, deps: [{ token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
74
|
-
ImagePlugin.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: ImagePlugin });
|
|
75
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: ImagePlugin, decorators: [{
|
|
76
|
-
type: Injectable
|
|
77
|
-
}], ctorParameters: function () { return [{ type: Document, decorators: [{
|
|
78
|
-
type: Inject,
|
|
79
|
-
args: [DOCUMENT]
|
|
80
|
-
}] }]; } });
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.js","sourceRoot":"","sources":["../../../../../projects/natural-editor/src/lib/utils/image.ts"],"names":[],"mappings":"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","sourcesContent":["import {Decoration, DecorationSet, EditorView} from 'prosemirror-view';\nimport {EditorState, Plugin} from 'prosemirror-state';\nimport {Observable} from 'rxjs';\nimport {Schema} from 'prosemirror-model';\nimport {Inject, Injectable} from '@angular/core';\nimport {DOCUMENT} from '@angular/common';\n\nexport type ImageUploader = (file: File) => Observable<string>;\n\n@Injectable()\nexport class ImagePlugin {\n    public readonly plugin: Plugin<DecorationSet>;\n\n    constructor(@Inject(DOCUMENT) private readonly document: Document) {\n        this.plugin = new Plugin<DecorationSet>({\n            state: {\n                init(): DecorationSet {\n                    return DecorationSet.empty;\n                },\n                apply(tr, set): DecorationSet {\n                    // Adjust decoration positions to changes made by the transaction\n                    set = set.map(tr.mapping, tr.doc);\n\n                    // See if the transaction adds or removes any placeholders\n                    const action = tr.getMeta(this);\n                    if (action && action.add) {\n                        const widget = document.createElement('placeholder');\n                        const deco = Decoration.widget(action.add.pos, widget, {id: action.add.id});\n                        set = set.add(tr.doc, [deco]);\n                    } else if (action && action.remove) {\n                        set = set.remove(set.find(undefined, undefined, spec => spec.id === action.remove.id));\n                    }\n\n                    return set;\n                },\n            },\n            props: {\n                decorations(state): DecorationSet {\n                    return this.getState(state);\n                },\n            },\n        });\n    }\n\n    private findPlaceholder(state: EditorState, id: {}): number | null {\n        const decorators = this.plugin.getState(state);\n        const found = decorators.find(undefined, undefined, spec => spec.id === id);\n        return found.length ? found[0].from : null;\n    }\n\n    public startImageUpload(view: EditorView, file: File, uploader: ImageUploader, schema: Schema): void {\n        // A fresh object to act as the ID for this upload\n        const id = {};\n\n        // Replace the selection with a placeholder\n        const tr = view.state.tr;\n        if (!tr.selection.empty) {\n            tr.deleteSelection();\n        }\n\n        tr.setMeta(this.plugin, {add: {id, pos: tr.selection.from}});\n        view.dispatch(tr);\n\n        uploader(file).subscribe({\n            next: url => {\n                const pos = this.findPlaceholder(view.state, id);\n                // If the content around the placeholder has been deleted, drop\n                // the image\n                if (pos === null) {\n                    return;\n                }\n\n                // Otherwise, insert it at the placeholder's position, and remove\n                // the placeholder\n                view.dispatch(\n                    view.state.tr\n                        .replaceWith(pos, pos, schema.nodes.image.create({src: url}))\n                        .setMeta(this.plugin, {remove: {id}}),\n                );\n            },\n            error: () => {\n                // On failure, just clean up the placeholder\n                view?.dispatch(tr.setMeta(this.plugin, {remove: {id}}));\n            },\n        });\n    }\n}\n"]}
|
|
@@ -1,207 +0,0 @@
|
|
|
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
|
-
import { addColumnAfter, addColumnBefore, addRowAfter, addRowBefore, deleteColumn, deleteRow, deleteTable, mergeCells, splitCell, toggleHeaderCell, toggleHeaderColumn, toggleHeaderRow, } from 'prosemirror-tables';
|
|
6
|
-
import { addTable } from './table';
|
|
7
|
-
/**
|
|
8
|
-
* One item of the menu.
|
|
9
|
-
*
|
|
10
|
-
* This is the equivalent of `MenuItem` but without all the rendering logic since we use Angular
|
|
11
|
-
* templates for rendering. Also it caches the state of the item everytime the editor state changes,
|
|
12
|
-
* so Angular can query the state as often as needed without performance hit.
|
|
13
|
-
*/
|
|
14
|
-
export class Item {
|
|
15
|
-
constructor(spec) {
|
|
16
|
-
this.spec = spec;
|
|
17
|
-
/**
|
|
18
|
-
* Whether the item is 'active' (for example, the item for toggling the strong mark might be active when the cursor is in strong text).
|
|
19
|
-
*/
|
|
20
|
-
this.active = false;
|
|
21
|
-
/**
|
|
22
|
-
* Button is shown but disabled, because the item cannot be (un-)applied
|
|
23
|
-
*/
|
|
24
|
-
this.disabled = false;
|
|
25
|
-
/**
|
|
26
|
-
* Whether the item is shown at the moment
|
|
27
|
-
*/
|
|
28
|
-
this.show = true;
|
|
29
|
-
}
|
|
30
|
-
/**
|
|
31
|
-
* Update the item state according to the editor state
|
|
32
|
-
*/
|
|
33
|
-
update(view, state) {
|
|
34
|
-
if (this.spec.active) {
|
|
35
|
-
this.active = this.spec.active(state);
|
|
36
|
-
}
|
|
37
|
-
if (this.spec.enable) {
|
|
38
|
-
this.disabled = !this.spec.enable(state);
|
|
39
|
-
}
|
|
40
|
-
if (this.spec.select) {
|
|
41
|
-
this.show = this.spec.select(state);
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
/**
|
|
46
|
-
* Convert built-in `MenuItem` into our Angular specific `Item`
|
|
47
|
-
*/
|
|
48
|
-
function toItem(item) {
|
|
49
|
-
return new Item(item.spec);
|
|
50
|
-
}
|
|
51
|
-
function canInsert(state, nodeType) {
|
|
52
|
-
const $from = state.selection.$from;
|
|
53
|
-
for (let d = $from.depth; d >= 0; d--) {
|
|
54
|
-
const index = $from.index(d);
|
|
55
|
-
if ($from.node(d).canReplaceWith(index, index, nodeType)) {
|
|
56
|
-
return true;
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
return false;
|
|
60
|
-
}
|
|
61
|
-
function cmdItem(cmd, options = {}, useEnable = false) {
|
|
62
|
-
const passedOptions = Object.assign({ run: cmd }, options);
|
|
63
|
-
if ((!options.enable || useEnable) && !options.select) {
|
|
64
|
-
passedOptions[options.enable ? 'enable' : 'select'] = (state) => cmd(state);
|
|
65
|
-
}
|
|
66
|
-
return new Item(passedOptions);
|
|
67
|
-
}
|
|
68
|
-
function markActive(state, type) {
|
|
69
|
-
const { from, $from, to, empty } = state.selection;
|
|
70
|
-
if (empty) {
|
|
71
|
-
return !!type.isInSet(state.storedMarks || $from.marks());
|
|
72
|
-
}
|
|
73
|
-
else {
|
|
74
|
-
return state.doc.rangeHasMark(from, to, type);
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
function markItem(markType, options = {}) {
|
|
78
|
-
const passedOptions = Object.assign({ active(state) {
|
|
79
|
-
return markActive(state, markType);
|
|
80
|
-
} }, options);
|
|
81
|
-
return cmdItem(toggleMark(markType), passedOptions, true);
|
|
82
|
-
}
|
|
83
|
-
function linkItem(markType, dialog) {
|
|
84
|
-
return new Item({
|
|
85
|
-
active(state) {
|
|
86
|
-
return markActive(state, markType);
|
|
87
|
-
},
|
|
88
|
-
enable(state) {
|
|
89
|
-
return !state.selection.empty;
|
|
90
|
-
},
|
|
91
|
-
run(state, dispatch, view) {
|
|
92
|
-
if (markActive(state, markType)) {
|
|
93
|
-
toggleMark(markType)(state, dispatch);
|
|
94
|
-
return true;
|
|
95
|
-
}
|
|
96
|
-
dialog
|
|
97
|
-
.open(LinkDialogComponent, {
|
|
98
|
-
data: {
|
|
99
|
-
href: '',
|
|
100
|
-
title: '',
|
|
101
|
-
},
|
|
102
|
-
})
|
|
103
|
-
.afterClosed()
|
|
104
|
-
.subscribe(result => {
|
|
105
|
-
if (result) {
|
|
106
|
-
if (!result.title) {
|
|
107
|
-
delete result.title;
|
|
108
|
-
}
|
|
109
|
-
toggleMark(markType, result)(view.state, view.dispatch);
|
|
110
|
-
}
|
|
111
|
-
view.focus();
|
|
112
|
-
});
|
|
113
|
-
},
|
|
114
|
-
});
|
|
115
|
-
}
|
|
116
|
-
function wrapListItem(nodeType) {
|
|
117
|
-
return cmdItem(wrapInList(nodeType));
|
|
118
|
-
}
|
|
119
|
-
/**
|
|
120
|
-
* Given a schema, look for default mark and node types in it and
|
|
121
|
-
* return an object with relevant menu items relating to those marks:
|
|
122
|
-
*/
|
|
123
|
-
export function buildMenuItems(schema, dialog) {
|
|
124
|
-
const r = {
|
|
125
|
-
joinUp: toItem(joinUpItem),
|
|
126
|
-
lift: toItem(liftItem),
|
|
127
|
-
selectParentNode: toItem(selectParentNodeItem),
|
|
128
|
-
undo: toItem(undoItem),
|
|
129
|
-
redo: toItem(redoItem),
|
|
130
|
-
};
|
|
131
|
-
let type;
|
|
132
|
-
type = schema.marks.strong;
|
|
133
|
-
if (type) {
|
|
134
|
-
r.toggleStrong = markItem(type);
|
|
135
|
-
}
|
|
136
|
-
type = schema.marks.em;
|
|
137
|
-
if (type) {
|
|
138
|
-
r.toggleEm = markItem(type);
|
|
139
|
-
}
|
|
140
|
-
type = schema.marks.code;
|
|
141
|
-
if (type) {
|
|
142
|
-
r.toggleCode = markItem(type);
|
|
143
|
-
}
|
|
144
|
-
type = schema.marks.link;
|
|
145
|
-
if (type) {
|
|
146
|
-
r.toggleLink = linkItem(type, dialog);
|
|
147
|
-
}
|
|
148
|
-
type = schema.nodes.bullet_list;
|
|
149
|
-
if (type) {
|
|
150
|
-
r.wrapBulletList = wrapListItem(type);
|
|
151
|
-
}
|
|
152
|
-
type = schema.nodes.ordered_list;
|
|
153
|
-
if (type) {
|
|
154
|
-
r.wrapOrderedList = wrapListItem(type);
|
|
155
|
-
}
|
|
156
|
-
type = schema.nodes.blockquote;
|
|
157
|
-
if (type) {
|
|
158
|
-
r.wrapBlockQuote = toItem(wrapItem(type, {}));
|
|
159
|
-
}
|
|
160
|
-
type = schema.nodes.paragraph;
|
|
161
|
-
if (type) {
|
|
162
|
-
r.makeParagraph = toItem(blockTypeItem(type, {}));
|
|
163
|
-
}
|
|
164
|
-
type = schema.nodes.code_block;
|
|
165
|
-
if (type) {
|
|
166
|
-
r.makeCodeBlock = toItem(blockTypeItem(type, {}));
|
|
167
|
-
}
|
|
168
|
-
type = schema.nodes.heading;
|
|
169
|
-
if (type) {
|
|
170
|
-
r.makeHead1 = toItem(blockTypeItem(type, { attrs: { level: 1 } }));
|
|
171
|
-
r.makeHead2 = toItem(blockTypeItem(type, { attrs: { level: 2 } }));
|
|
172
|
-
r.makeHead3 = toItem(blockTypeItem(type, { attrs: { level: 3 } }));
|
|
173
|
-
r.makeHead4 = toItem(blockTypeItem(type, { attrs: { level: 4 } }));
|
|
174
|
-
r.makeHead5 = toItem(blockTypeItem(type, { attrs: { level: 5 } }));
|
|
175
|
-
r.makeHead6 = toItem(blockTypeItem(type, { attrs: { level: 6 } }));
|
|
176
|
-
}
|
|
177
|
-
type = schema.nodes.horizontal_rule;
|
|
178
|
-
if (type) {
|
|
179
|
-
const hr = type;
|
|
180
|
-
r.insertHorizontalRule = new Item({
|
|
181
|
-
enable(state) {
|
|
182
|
-
return canInsert(state, hr);
|
|
183
|
-
},
|
|
184
|
-
run(state, dispatch) {
|
|
185
|
-
dispatch(state.tr.replaceSelectionWith(hr.create()));
|
|
186
|
-
},
|
|
187
|
-
});
|
|
188
|
-
}
|
|
189
|
-
type = schema.nodes.table;
|
|
190
|
-
if (type) {
|
|
191
|
-
r.insertTable = new Item({ run: (e, tr) => addTable(e, tr) });
|
|
192
|
-
r.addColumnBefore = new Item({ run: addColumnBefore });
|
|
193
|
-
r.addColumnAfter = new Item({ run: addColumnAfter });
|
|
194
|
-
r.deleteColumn = new Item({ run: deleteColumn });
|
|
195
|
-
r.addRowBefore = new Item({ run: addRowBefore });
|
|
196
|
-
r.addRowAfter = new Item({ run: addRowAfter });
|
|
197
|
-
r.deleteRow = new Item({ run: deleteRow });
|
|
198
|
-
r.deleteTable = new Item({ run: deleteTable });
|
|
199
|
-
r.mergeCells = new Item({ run: mergeCells });
|
|
200
|
-
r.splitCell = new Item({ run: splitCell });
|
|
201
|
-
r.toggleHeaderColumn = new Item({ run: toggleHeaderColumn });
|
|
202
|
-
r.toggleHeaderRow = new Item({ run: toggleHeaderRow });
|
|
203
|
-
r.toggleHeaderCell = new Item({ run: toggleHeaderCell });
|
|
204
|
-
}
|
|
205
|
-
return r;
|
|
206
|
-
}
|
|
207
|
-
//# 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';\n\n/**\n * One item of the menu.\n *\n * This is the equivalent of `MenuItem` but without all the rendering logic since we use Angular\n * templates for rendering. Also it caches the state of the item everytime the editor state changes,\n * so Angular can query the state as often as needed without performance hit.\n */\nexport class Item {\n    /**\n     * Whether the item is 'active' (for example, the item for toggling the strong mark might be active when the cursor is in strong text).\n     */\n    public active = false;\n\n    /**\n     * Button is shown but disabled, because the item cannot be (un-)applied\n     */\n    public disabled = false;\n\n    /**\n     * Whether the item is shown at the moment\n     */\n    public show = true;\n\n    constructor(public readonly spec: MenuItemSpec) {}\n\n    /**\n     * Update the item state according to the editor state\n     */\n    public update(view: EditorView, state: EditorState): void {\n        if (this.spec.active) {\n            this.active = this.spec.active(state);\n        }\n\n        if (this.spec.enable) {\n            this.disabled = !this.spec.enable(state);\n        }\n\n        if (this.spec.select) {\n            this.show = this.spec.select(state);\n        }\n    }\n}\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    | '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\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"]}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import { marks, nodes } from 'prosemirror-schema-basic';
|
|
2
|
-
import { addListNodes } from 'prosemirror-schema-list';
|
|
3
|
-
import { Schema } from 'prosemirror-model';
|
|
4
|
-
import { tableNodes } from 'prosemirror-tables';
|
|
5
|
-
const basicNodes = {
|
|
6
|
-
heading: nodes.heading,
|
|
7
|
-
doc: nodes.doc,
|
|
8
|
-
paragraph: nodes.paragraph,
|
|
9
|
-
text: nodes.text,
|
|
10
|
-
hard_break: nodes.hard_break,
|
|
11
|
-
};
|
|
12
|
-
const basicMarks = {
|
|
13
|
-
link: marks.link,
|
|
14
|
-
em: marks.em,
|
|
15
|
-
strong: marks.strong,
|
|
16
|
-
};
|
|
17
|
-
const tmpSchema = new Schema({ nodes: basicNodes, marks: basicMarks });
|
|
18
|
-
export const basicSchema = new Schema({
|
|
19
|
-
nodes: addListNodes(tmpSchema.spec.nodes, 'paragraph block*', 'block'),
|
|
20
|
-
marks: tmpSchema.spec.marks,
|
|
21
|
-
});
|
|
22
|
-
const tmpSchema2 = new Schema({
|
|
23
|
-
nodes: Object.assign(Object.assign({}, nodes), tableNodes({
|
|
24
|
-
tableGroup: 'block',
|
|
25
|
-
cellContent: 'block+',
|
|
26
|
-
cellAttributes: {
|
|
27
|
-
background: {
|
|
28
|
-
default: null,
|
|
29
|
-
getFromDOM(dom) {
|
|
30
|
-
return dom.style.backgroundColor || null;
|
|
31
|
-
},
|
|
32
|
-
setDOMAttr(value, attrs) {
|
|
33
|
-
if (value) {
|
|
34
|
-
attrs.style = (attrs.style || '') + `background-color: ${value};`;
|
|
35
|
-
}
|
|
36
|
-
},
|
|
37
|
-
},
|
|
38
|
-
},
|
|
39
|
-
})),
|
|
40
|
-
marks: basicMarks,
|
|
41
|
-
});
|
|
42
|
-
export const advancedSchema = new Schema({
|
|
43
|
-
nodes: addListNodes(tmpSchema2.spec.nodes, 'paragraph block*', 'block'),
|
|
44
|
-
marks: basicMarks,
|
|
45
|
-
});
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC1lZGl0b3Ivc3JjL2xpYi91dGlscy9zY2hlbWEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLEtBQUssRUFBRSxLQUFLLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUN0RCxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDckQsT0FBTyxFQUFDLE1BQU0sRUFBQyxNQUFNLG1CQUFtQixDQUFDO0FBQ3pDLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxvQkFBb0IsQ0FBQztBQUk5QyxNQUFNLFVBQVUsR0FBZTtJQUMzQixPQUFPLEVBQUUsS0FBSyxDQUFDLE9BQU87SUFDdEIsR0FBRyxFQUFFLEtBQUssQ0FBQyxHQUFHO0lBQ2QsU0FBUyxFQUFFLEtBQUssQ0FBQyxTQUFTO0lBQzFCLElBQUksRUFBRSxLQUFLLENBQUMsSUFBSTtJQUNoQixVQUFVLEVBQUUsS0FBSyxDQUFDLFVBQVU7Q0FDL0IsQ0FBQztBQUdGLE1BQU0sVUFBVSxHQUFlO0lBQzNCLElBQUksRUFBRSxLQUFLLENBQUMsSUFBSTtJQUNoQixFQUFFLEVBQUUsS0FBSyxDQUFDLEVBQUU7SUFDWixNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU07Q0FDdkIsQ0FBQztBQUVGLE1BQU0sU0FBUyxHQUFHLElBQUksTUFBTSxDQUFDLEVBQUMsS0FBSyxFQUFFLFVBQVUsRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFDLENBQUMsQ0FBQztBQUVyRSxNQUFNLENBQUMsTUFBTSxXQUFXLEdBQUcsSUFBSSxNQUFNLENBQUM7SUFDbEMsS0FBSyxFQUFFLFlBQVksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxrQkFBa0IsRUFBRSxPQUFPLENBQUM7SUFDdEUsS0FBSyxFQUFFLFNBQVMsQ0FBQyxJQUFJLENBQUMsS0FBSztDQUM5QixDQUFDLENBQUM7QUFFSCxNQUFNLFVBQVUsR0FBRyxJQUFJLE1BQU0sQ0FBQztJQUMxQixLQUFLLGtDQUNFLEtBQUssR0FDTCxVQUFVLENBQUM7UUFDVixVQUFVLEVBQUUsT0FBTztRQUNuQixXQUFXLEVBQUUsUUFBUTtRQUNyQixjQUFjLEVBQUU7WUFDWixVQUFVLEVBQUU7Z0JBQ1IsT0FBTyxFQUFFLElBQUk7Z0JBQ2IsVUFBVSxDQUFDLEdBQVk7b0JBQ25CLE9BQVEsR0FBbUIsQ0FBQyxLQUFLLENBQUMsZUFBZSxJQUFJLElBQUksQ0FBQztnQkFDOUQsQ0FBQztnQkFDRCxVQUFVLENBQUMsS0FBVSxFQUFFLEtBQVU7b0JBQzdCLElBQUksS0FBSyxFQUFFO3dCQUNQLEtBQUssQ0FBQyxLQUFLLEdBQUcsQ0FBQyxLQUFLLENBQUMsS0FBSyxJQUFJLEVBQUUsQ0FBQyxHQUFHLHFCQUFxQixLQUFLLEdBQUcsQ0FBQztxQkFDckU7Z0JBQ0wsQ0FBQzthQUNKO1NBQ0o7S0FDSixDQUFDLENBQ0w7SUFDRCxLQUFLLEVBQUUsVUFBVTtDQUNwQixDQUFDLENBQUM7QUFFSCxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsSUFBSSxNQUFNLENBQUM7SUFDckMsS0FBSyxFQUFFLFlBQVksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxrQkFBa0IsRUFBRSxPQUFPLENBQUM7SUFDdkUsS0FBSyxFQUFFLFVBQVU7Q0FDcEIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHttYXJrcywgbm9kZXN9IGZyb20gJ3Byb3NlbWlycm9yLXNjaGVtYS1iYXNpYyc7XG5pbXBvcnQge2FkZExpc3ROb2Rlc30gZnJvbSAncHJvc2VtaXJyb3Itc2NoZW1hLWxpc3QnO1xuaW1wb3J0IHtTY2hlbWF9IGZyb20gJ3Byb3NlbWlycm9yLW1vZGVsJztcbmltcG9ydCB7dGFibGVOb2Rlc30gZnJvbSAncHJvc2VtaXJyb3ItdGFibGVzJztcblxuLy8gS2VlcCBvbmx5IGJhc2ljIGVsZW1lbnRzXG50eXBlIEJhc2ljTm9kZXMgPSBPbWl0PHR5cGVvZiBub2RlcywgJ2ltYWdlJyB8ICdjb2RlX2Jsb2NrJyB8ICdibG9ja3F1b3RlJyB8ICdob3Jpem9udGFsX3J1bGUnPjtcbmNvbnN0IGJhc2ljTm9kZXM6IEJhc2ljTm9kZXMgPSB7XG4gICAgaGVhZGluZzogbm9kZXMuaGVhZGluZyxcbiAgICBkb2M6IG5vZGVzLmRvYyxcbiAgICBwYXJhZ3JhcGg6IG5vZGVzLnBhcmFncmFwaCxcbiAgICB0ZXh0OiBub2Rlcy50ZXh0LFxuICAgIGhhcmRfYnJlYWs6IG5vZGVzLmhhcmRfYnJlYWssXG59O1xuXG50eXBlIEJhc2ljTWFya3MgPSBPbWl0PHR5cGVvZiBtYXJrcywgJ2NvZGUnPjtcbmNvbnN0IGJhc2ljTWFya3M6IEJhc2ljTWFya3MgPSB7XG4gICAgbGluazogbWFya3MubGluayxcbiAgICBlbTogbWFya3MuZW0sXG4gICAgc3Ryb25nOiBtYXJrcy5zdHJvbmcsXG59O1xuXG5jb25zdCB0bXBTY2hlbWEgPSBuZXcgU2NoZW1hKHtub2RlczogYmFzaWNOb2RlcywgbWFya3M6IGJhc2ljTWFya3N9KTtcblxuZXhwb3J0IGNvbnN0IGJhc2ljU2NoZW1hID0gbmV3IFNjaGVtYSh7XG4gICAgbm9kZXM6IGFkZExpc3ROb2Rlcyh0bXBTY2hlbWEuc3BlYy5ub2RlcywgJ3BhcmFncmFwaCBibG9jayonLCAnYmxvY2snKSxcbiAgICBtYXJrczogdG1wU2NoZW1hLnNwZWMubWFya3MsXG59KTtcblxuY29uc3QgdG1wU2NoZW1hMiA9IG5ldyBTY2hlbWEoe1xuICAgIG5vZGVzOiB7XG4gICAgICAgIC4uLm5vZGVzLFxuICAgICAgICAuLi50YWJsZU5vZGVzKHtcbiAgICAgICAgICAgIHRhYmxlR3JvdXA6ICdibG9jaycsXG4gICAgICAgICAgICBjZWxsQ29udGVudDogJ2Jsb2NrKycsXG4gICAgICAgICAgICBjZWxsQXR0cmlidXRlczoge1xuICAgICAgICAgICAgICAgIGJhY2tncm91bmQ6IHtcbiAgICAgICAgICAgICAgICAgICAgZGVmYXVsdDogbnVsbCxcbiAgICAgICAgICAgICAgICAgICAgZ2V0RnJvbURPTShkb206IEVsZW1lbnQpOiBzdHJpbmcgfCBudWxsIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiAoZG9tIGFzIEhUTUxFbGVtZW50KS5zdHlsZS5iYWNrZ3JvdW5kQ29sb3IgfHwgbnVsbDtcbiAgICAgICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICAgICAgc2V0RE9NQXR0cih2YWx1ZTogYW55LCBhdHRyczogYW55KTogdm9pZCB7XG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAodmFsdWUpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBhdHRycy5zdHlsZSA9IChhdHRycy5zdHlsZSB8fCAnJykgKyBgYmFja2dyb3VuZC1jb2xvcjogJHt2YWx1ZX07YDtcbiAgICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgfSxcbiAgICAgICAgfSksXG4gICAgfSxcbiAgICBtYXJrczogYmFzaWNNYXJrcyxcbn0pO1xuXG5leHBvcnQgY29uc3QgYWR2YW5jZWRTY2hlbWEgPSBuZXcgU2NoZW1hKHtcbiAgICBub2RlczogYWRkTGlzdE5vZGVzKHRtcFNjaGVtYTIuc3BlYy5ub2RlcywgJ3BhcmFncmFwaCBibG9jayonLCAnYmxvY2snKSxcbiAgICBtYXJrczogYmFzaWNNYXJrcyxcbn0pO1xuIl19
|