@zodiac-ui/editor
Version:
A rich text editor for Angular based on `@atlaskit/editor-core`.
108 lines • 17.8 kB
JavaScript
import { toggleMark } from "prosemirror-commands";
export const deepEqual = (obj1, obj2) => {
for (const key in obj1) {
if (obj1[key] !== obj2[key]) {
return false;
}
}
return true;
};
export const hasCode = (state, pos) => {
const { code } = state.schema.marks;
const node = pos >= 0 && state.doc.nodeAt(pos);
if (node) {
return !!node.marks.filter(mark => mark.type === code).length;
}
return false;
};
export const isMarkTypeActive = (state, markType) => {
const { $from, from, to, empty } = state.selection;
if (empty) {
return !!markType.isInSet(state.storedMarks || $from.marks());
}
return state.doc.rangeHasMark(from, to, markType);
};
/**
* Determine if a mark (with specific attribute values) exists anywhere in the selection.
*/
export const isMarkActive = (state, mark) => {
const { from, to, empty } = state.selection;
// When the selection is empty, only the active marks apply.
if (empty) {
return !!mark.isInSet(state.tr.storedMarks || state.selection.$from.marks());
}
// For a non-collapsed selection, the marks on the nodes matter.
let found = false;
state.doc.nodesBetween(from, to, node => {
found = found || mark.isInSet(node.marks);
});
return found;
};
export const getTextFormattingState = (editorState) => {
const { em, code, strike, strong, subsup, underline } = editorState.schema.marks;
const state = {};
if (code) {
state.codeActive = isMarkActive(editorState, code.create());
state.codeDisabled = !toggleMark(code)(editorState);
}
if (em) {
state.emActive = isMarkTypeActive(editorState, em);
state.emDisabled = state.codeActive ? true : !toggleMark(em)(editorState);
}
if (strike) {
state.strikeActive = isMarkTypeActive(editorState, strike);
state.strikeDisabled = state.codeActive ? true : !toggleMark(strike)(editorState);
}
if (strong) {
state.strongActive = isMarkTypeActive(editorState, strong);
state.strongDisabled = state.codeActive ? true : !toggleMark(strong)(editorState);
}
if (subsup) {
const subMark = subsup.create({ type: "sub" });
const supMark = subsup.create({ type: "sup" });
state.subscriptActive = isMarkActive(editorState, subMark);
state.subscriptDisabled = state.codeActive
? true
: !toggleMark(subsup, { type: "sub" })(editorState);
state.superscriptActive = isMarkActive(editorState, supMark);
state.superscriptDisabled = state.codeActive
? true
: !toggleMark(subsup, { type: "sup" })(editorState);
}
if (underline) {
state.underlineActive = isMarkTypeActive(editorState, underline);
state.underlineDisabled = state.codeActive ? true : !toggleMark(underline)(editorState);
}
return state;
};
const applyCodeBlock = (from, to, tr) => {
const { schema } = tr.doc.type;
if (schema.marks.code) {
const codeMark = schema.marks.code.create();
tr.addMark(tr.mapping.map(from), tr.mapping.map(to), codeMark).setStoredMarks([codeMark]);
}
};
const ɵ0 = applyCodeBlock;
export function transformToCodeAction(from, to, tr) {
// transformSmartCharsMentionsAndEmojis(from, to, tr);
applyCodeBlock(from, to, tr);
return tr;
}
export const createInlineCodeFromTextInput = (from, to, text) => {
return (state, dispatch) => {
if (state.selection.empty) {
const { nodeBefore: before } = state.doc.resolve(from);
const { nodeAfter: after } = state.doc.resolve(to);
const hasTickBefore = before && before.text && before.text.endsWith("`");
const hasTickAfter = after && after.text && after.text.startsWith("`");
const tr = state.tr.replaceRangeWith(from - 1, to + 1, state.schema.text(text));
if (dispatch) {
dispatch(transformToCodeAction(tr.mapping.map(from - 1), tr.mapping.map(to + 1), tr));
}
return true;
}
return false;
};
};
export { ɵ0 };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"ng://@zodiac-ui/editor/","sources":["plugins/text-formatting/utils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Determine if a mark of a specific type exists anywhere in the selection.\r\n */\r\nimport { Mark, MarkType } from \"prosemirror-model\"\r\nimport { EditorState, Transaction } from \"prosemirror-state\"\r\nimport { TextFormattingState } from \"./interfaces\"\r\nimport { toggleMark } from \"prosemirror-commands\"\r\nimport { Command } from \"../../lib/interfaces/command\"\r\n\r\nexport const deepEqual = (obj1, obj2) => {\r\n    for (const key in obj1) {\r\n        if (obj1[key] !== obj2[key]) {\r\n            return false;\r\n        }\r\n    }\r\n    return true;\r\n};\r\n\r\nexport const hasCode = (state: EditorState, pos: number): boolean => {\r\n    const { code } = state.schema.marks;\r\n    const node = pos >= 0 && state.doc.nodeAt(pos);\r\n    if (node) {\r\n        return !!node.marks.filter(mark => mark.type === code).length;\r\n    }\r\n\r\n    return false;\r\n};\r\n\r\n\r\nexport const isMarkTypeActive = (state: EditorState, markType: MarkType): boolean => {\r\n    const { $from, from, to, empty } = state.selection\r\n    if (empty) {\r\n        return !!markType.isInSet(state.storedMarks || $from.marks())\r\n    }\r\n    return state.doc.rangeHasMark(from, to, markType)\r\n}\r\n\r\n/**\r\n * Determine if a mark (with specific attribute values) exists anywhere in the selection.\r\n */\r\nexport const isMarkActive = (state: EditorState, mark: Mark): boolean => {\r\n    const { from, to, empty } = state.selection\r\n    // When the selection is empty, only the active marks apply.\r\n    if (empty) {\r\n        return !!mark.isInSet(state.tr.storedMarks || state.selection.$from.marks())\r\n    }\r\n    // For a non-collapsed selection, the marks on the nodes matter.\r\n    let found = false\r\n    state.doc.nodesBetween(from, to, node => {\r\n        found = found || mark.isInSet(node.marks)\r\n    })\r\n    return found\r\n}\r\n\r\nexport const getTextFormattingState = (editorState: EditorState): TextFormattingState => {\r\n    const { em, code, strike, strong, subsup, underline } = editorState.schema.marks\r\n    const state: TextFormattingState = {}\r\n\r\n    if (code) {\r\n        state.codeActive = isMarkActive(editorState, code.create())\r\n        state.codeDisabled = !toggleMark(code)(editorState)\r\n    }\r\n    if (em) {\r\n        state.emActive = isMarkTypeActive(editorState, em)\r\n        state.emDisabled = state.codeActive ? true : !toggleMark(em)(editorState)\r\n    }\r\n    if (strike) {\r\n        state.strikeActive = isMarkTypeActive(editorState, strike)\r\n        state.strikeDisabled = state.codeActive ? true : !toggleMark(strike)(editorState)\r\n    }\r\n    if (strong) {\r\n        state.strongActive = isMarkTypeActive(editorState, strong)\r\n        state.strongDisabled = state.codeActive ? true : !toggleMark(strong)(editorState)\r\n    }\r\n    if (subsup) {\r\n        const subMark = subsup.create({ type: \"sub\" })\r\n        const supMark = subsup.create({ type: \"sup\" })\r\n        state.subscriptActive = isMarkActive(editorState, subMark)\r\n        state.subscriptDisabled = state.codeActive\r\n            ? true\r\n            : !toggleMark(subsup, { type: \"sub\" })(editorState)\r\n        state.superscriptActive = isMarkActive(editorState, supMark)\r\n        state.superscriptDisabled = state.codeActive\r\n            ? true\r\n            : !toggleMark(subsup, { type: \"sup\" })(editorState)\r\n    }\r\n    if (underline) {\r\n        state.underlineActive = isMarkTypeActive(editorState, underline)\r\n        state.underlineDisabled = state.codeActive ? true : !toggleMark(underline)(editorState)\r\n    }\r\n    return state\r\n}\r\n\r\nconst applyCodeBlock = (from: number, to: number, tr: Transaction): void => {\r\n    const { schema } = tr.doc.type\r\n\r\n    if (schema.marks.code) {\r\n        const codeMark = schema.marks.code.create()\r\n        tr.addMark(tr.mapping.map(from), tr.mapping.map(to), codeMark).setStoredMarks([codeMark])\r\n    }\r\n}\r\n\r\nexport function transformToCodeAction(from: number, to: number, tr: Transaction): Transaction {\r\n    // transformSmartCharsMentionsAndEmojis(from, to, tr);\r\n\r\n    applyCodeBlock(from, to, tr)\r\n\r\n    return tr\r\n}\r\n\r\nexport const createInlineCodeFromTextInput = (from: number, to: number, text: string): Command => {\r\n    return (state, dispatch) => {\r\n        if (state.selection.empty) {\r\n            const { nodeBefore: before } = state.doc.resolve(from)\r\n            const { nodeAfter: after } = state.doc.resolve(to)\r\n\r\n            const hasTickBefore = before && before.text && before.text.endsWith(\"`\")\r\n            const hasTickAfter = after && after.text && after.text.startsWith(\"`\")\r\n            const tr = state.tr.replaceRangeWith(from - 1, to + 1, state.schema.text(text))\r\n\r\n            if (dispatch) {\r\n                dispatch(\r\n                    transformToCodeAction(tr.mapping.map(from - 1), tr.mapping.map(to + 1), tr),\r\n                )\r\n            }\r\n            return true\r\n        }\r\n        return false\r\n    }\r\n}\r\n"]}