@zodiac-ui/editor
Version:
A rich text editor for Angular based on `@atlaskit/editor-core`.
82 lines • 12.1 kB
JavaScript
import { Schema } from "prosemirror-model";
import { docNode } from "../../plugins/doc/doc.node";
import { paragraphNode } from "../../plugins/paragraph/paragraph.node";
import { alignment } from "../../plugins/alignment/alignment.mark";
import { sanitizeNodes } from "./sanitize";
import { textNode } from "../../plugins/text/text.node";
const nodesInOrder = [
{ name: 'doc', spec: docNode },
{ name: 'paragraph', spec: paragraphNode },
{ name: 'text', spec: textNode },
];
const marksInOrder = [
{ name: 'alignment', spec: alignment },
];
const markGroupDeclarations = [
// groupDeclaration(COLOR),
// groupDeclaration(FONT_STYLE),
// groupDeclaration(SEARCH_QUERY),
// groupDeclaration(LINK),
];
const ɵ0 = groupMark => groupMark.name;
const markGroupDeclarationsNames = markGroupDeclarations.map(ɵ0);
function addItems(builtInItems, config, customSpecs = {}) {
if (!config) {
return {};
}
/**
* Add built-in Node / Mark specs
*/
const items = builtInItems.reduce((items, { name, spec }) => {
if (config.indexOf(name) !== -1) {
items[name] = customSpecs[name] || spec;
}
return items;
}, {});
/**
* Add Custom Node / Mark specs
*/
return Object.keys(customSpecs).reduce((items, name) => {
if (items[name]) {
return items;
}
items[name] = customSpecs[name];
return items;
}, items);
}
export function sortByRank(a, b) {
return a.rank - b.rank;
}
function sortByOrder(item) {
// return function(a: { name: string }, b: { name: string }): number {
// return Ranks[item].indexOf(a.name) - Ranks[item].indexOf(b.name);
// };
return () => 0;
}
export function fixExcludes(marks) {
const markKeys = Object.keys(marks);
const markGroups = new Set(markKeys.map(mark => marks[mark].group));
markKeys.map(markKey => {
const mark = marks[markKey];
if (mark.excludes) {
mark.excludes = mark.excludes
.split(' ')
.filter(group => markGroups.has(group))
.join(' ');
}
});
return marks;
}
export function createSchema(editorConfig) {
const marks = fixExcludes(editorConfig.marks.sort(sortByOrder('marks')).reduce((acc, mark) => {
acc[mark.name] = mark.mark;
return acc;
}, {}));
const nodes = sanitizeNodes(editorConfig.nodes.sort(sortByOrder('nodes')).reduce((acc, node) => {
acc[node.name] = node.node;
return acc;
}, {}), marks);
return new Schema({ nodes, marks });
}
export { ɵ0 };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-schema.js","sourceRoot":"ng://@zodiac-ui/editor/","sources":["lib/utils/create-schema.ts"],"names":[],"mappings":"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","sourcesContent":["import { MarkSpec, NodeSpec, Schema } from \"prosemirror-model\"\r\nimport { docNode } from \"../../plugins/doc/doc.node\"\r\nimport { paragraphNode } from \"../../plugins/paragraph/paragraph.node\"\r\nimport { alignment } from \"../../plugins/alignment/alignment.mark\"\r\nimport { sanitizeNodes } from \"./sanitize\"\r\nimport { EditorConfig } from \"../interfaces/editor-config\"\r\nimport { textNode } from \"../../plugins/text/text.node\"\r\n\r\nexport interface SchemaConfig {\r\n    nodes: string[];\r\n    customNodeSpecs?: SchemaCustomNodeSpecs;\r\n    marks?: string[];\r\n    customMarkSpecs?: SchemaCustomMarkSpecs;\r\n}\r\n\r\nexport interface SchemaBuiltInItem {\r\n    name: string;\r\n    spec: NodeSpec | MarkSpec;\r\n}\r\n\r\nexport interface SchemaCustomNodeSpecs {\r\n    [name: string]: NodeSpec;\r\n}\r\n\r\nexport interface SchemaCustomMarkSpecs {\r\n    [name: string]: MarkSpec;\r\n}\r\n\r\nconst nodesInOrder: SchemaBuiltInItem[] = [\r\n    { name: 'doc', spec: docNode },\r\n    { name: 'paragraph', spec: paragraphNode },\r\n    { name: 'text', spec: textNode },\r\n];\r\n\r\nconst marksInOrder: SchemaBuiltInItem[] = [\r\n    { name: 'alignment', spec: alignment },\r\n];\r\n\r\nconst markGroupDeclarations = [\r\n    // groupDeclaration(COLOR),\r\n    // groupDeclaration(FONT_STYLE),\r\n    // groupDeclaration(SEARCH_QUERY),\r\n    // groupDeclaration(LINK),\r\n];\r\n\r\nconst markGroupDeclarationsNames = markGroupDeclarations.map(\r\n    groupMark => groupMark.name,\r\n);\r\n\r\nfunction addItems(\r\n    builtInItems: SchemaBuiltInItem[],\r\n    config: string[],\r\n    customSpecs: SchemaCustomNodeSpecs | SchemaCustomMarkSpecs = {},\r\n) {\r\n    if (!config) {\r\n        return {};\r\n    }\r\n\r\n    /**\r\n     * Add built-in Node / Mark specs\r\n     */\r\n    const items = builtInItems.reduce<Record<string, NodeSpec | MarkSpec>>(\r\n        (items, { name, spec }) => {\r\n            if (config.indexOf(name) !== -1) {\r\n                items[name] = customSpecs[name] || spec;\r\n            }\r\n\r\n            return items;\r\n        },\r\n        {},\r\n    );\r\n\r\n    /**\r\n     * Add Custom Node / Mark specs\r\n     */\r\n    return Object.keys(customSpecs).reduce((items, name) => {\r\n        if (items[name]) {\r\n            return items;\r\n        }\r\n\r\n        items[name] = customSpecs[name];\r\n\r\n        return items;\r\n    }, items);\r\n}\r\n\r\nexport function sortByRank(a: { rank: number }, b: { rank: number }): number {\r\n    return a.rank - b.rank;\r\n}\r\n\r\nfunction sortByOrder(item: 'plugins' | 'nodes' | 'marks') {\r\n    // return function(a: { name: string }, b: { name: string }): number {\r\n    //     return Ranks[item].indexOf(a.name) - Ranks[item].indexOf(b.name);\r\n    // };\r\n\r\n    return () => 0\r\n}\r\n\r\nexport function fixExcludes(marks: {\r\n    [key: string]: MarkSpec;\r\n}): { [key: string]: MarkSpec } {\r\n    const markKeys = Object.keys(marks);\r\n    const markGroups = new Set(markKeys.map(mark => marks[mark].group));\r\n\r\n    markKeys.map(markKey => {\r\n        const mark = marks[markKey];\r\n        if (mark.excludes) {\r\n            mark.excludes = mark.excludes\r\n                .split(' ')\r\n                .filter(group => markGroups.has(group))\r\n                .join(' ');\r\n        }\r\n    });\r\n    return marks;\r\n}\r\n\r\nexport function createSchema(editorConfig: EditorConfig) {\r\n    const marks = fixExcludes(\r\n        editorConfig.marks.sort(sortByOrder('marks')).reduce(\r\n            (acc, mark) => {\r\n                acc[mark.name] = mark.mark;\r\n                return acc;\r\n            },\r\n            {} as { [nodeName: string]: MarkSpec },\r\n        ),\r\n    );\r\n    const nodes = sanitizeNodes(\r\n        editorConfig.nodes.sort(sortByOrder('nodes')).reduce(\r\n            (acc, node) => {\r\n                acc[node.name] = node.node;\r\n                return acc;\r\n            },\r\n            {} as { [nodeName: string]: NodeSpec },\r\n        ),\r\n        marks,\r\n    );\r\n\r\n    return new Schema({ nodes, marks });\r\n}\r\n"]}