@atlaskit/editor-core
Version:
A package contains Atlassian editor core functionality
142 lines (126 loc) • 6.16 kB
text/typescript
import { browser, EditorState, Transaction } from '../prosemirror';
export const toggleBold = makeKeyMapWithCommon('Bold', 'Mod-b');
export const toggleItalic = makeKeyMapWithCommon('Italic', 'Mod-i');
export const toggleUnderline = makeKeyMapWithCommon('Underline', 'Mod-u');
export const toggleStrikethrough = makeKeyMapWithCommon('Strikethrough', 'Mod-Shift-s');
export const toggleCode = makeKeyMapWithCommon('Code', 'Mod-Shift-m');
export const clearFormatting = makeKeyMapWithCommon('Clear formatting', 'Mod-\\');
export const setNormalText = makeKeymap('Normal text', '', 'Cmd-Alt-0');
export const toggleHeading1 = makeKeymap('Heading 1', '', 'Cmd-Alt-1');
export const toggleHeading2 = makeKeymap('Heading 2', '', 'Cmd-Alt-2');
export const toggleHeading3 = makeKeymap('Heading 3', '', 'Cmd-Alt-3');
export const toggleHeading4 = makeKeymap('Heading 4', '', 'Cmd-Alt-4');
export const toggleHeading5 = makeKeymap('Heading 5', '', 'Cmd-Alt-5');
export const toggleOrderedList = makeKeymap('Numbered list', '', 'Cmd-Alt-7');
export const toggleBulletList = makeKeymap('Bullet list', '', 'Cmd-Alt-8');
export const toggleBlockQuote = makeKeymap('Block quote', '', 'Cmd-Alt-9');
export const insertNewLine = makeKeyMapWithCommon('Insert new line', 'Shift-Enter');
export const shiftBackspace = makeKeyMapWithCommon('Shift Backspace', 'Shift-Backspace');
export const splitCodeBlock = makeKeyMapWithCommon('Split code block', 'Enter');
export const splitListItem = makeKeyMapWithCommon('Split list item', 'Enter');
export const insertRule = makeKeyMapWithCommon('Insert horizontal rule', 'Mod-Shift--');
export const undo = makeKeyMapWithCommon('Undo', 'Mod-z');
export const createCodeBlock = makeKeyMapWithCommon('Create code block', 'Enter');
export const moveUp = makeKeyMapWithCommon('Move up', 'ArrowUp');
export const moveDown = makeKeyMapWithCommon('Move down', 'ArrowDown');
export const moveLeft = makeKeyMapWithCommon('Move left', 'ArrowLeft');
export const moveRight = makeKeyMapWithCommon('Move right', 'ArrowRight');
export const indentList = makeKeyMapWithCommon('Indent List', 'Tab');
export const outdentList = makeKeyMapWithCommon('Outdent List', 'Shift-Tab');
export const redo = makeKeymap('Redo', 'Ctrl-y', 'Cmd-Shift-z');
export const redoBarred = makeKeymap('Redo Barred', 'Ctrl-Shift-z', 'Cmd-y');
export const addLink = makeKeyMapWithCommon('Insert link', 'Mod-k');
export const enter = makeKeyMapWithCommon('Enter', 'Enter');
export const tab = makeKeyMapWithCommon('Tab', 'Tab');
export const backspace = makeKeyMapWithCommon('Backspace', 'Backspace');
export const space = makeKeyMapWithCommon('Space', 'Space');
export const escape = makeKeyMapWithCommon('Escape', 'Escape');
export const nextCell = makeKeyMapWithCommon('Next cell', 'Tab');
export const previousCell = makeKeyMapWithCommon('Previous cell', 'Shift-Tab');
export const toggleTable = makeKeyMapWithCommon('Table', 'Shift-Alt-t');
export const cut = makeKeyMapWithCommon('Cut', 'Mod-x');
export const copy = makeKeyMapWithCommon('Copy', 'Mod-c');
export const paste = makeKeyMapWithCommon('Paste', 'Mod-v');
export function tooltip(keymap: Keymap | undefined): string | undefined {
if (keymap) {
let shortcut;
if (browser.mac) {
shortcut = keymap.mac
.replace(/Cmd/i, '⌘')
.replace(/Shift/i, '⇧')
.replace(/Ctrl/i, '^')
.replace(/Alt/i, '⌥');
} else {
shortcut = keymap.windows;
}
return `${keymap.description} (${shortcut})`;
}
}
export function findKeymapByDescription(description: string): Keymap | undefined {
const matches = ALL.filter((keymap) => (keymap.description.toUpperCase() === description.toUpperCase()));
return matches[0];
}
export function findShortcutByDescription(description: string): string | undefined {
const keymap = findKeymapByDescription(description);
if (keymap) {
return findShortcutByKeymap(keymap);
}
}
export function findShortcutByKeymap(keymap: Keymap): string | undefined {
if (browser.mac) {
return keymap.mac;
}
return keymap.windows;
}
const ALL = [toggleOrderedList, toggleBulletList, toggleBold, toggleItalic,
toggleUnderline, toggleStrikethrough, toggleCode,
setNormalText, toggleHeading1, toggleHeading2, toggleHeading3, toggleHeading4, toggleHeading5,
toggleBlockQuote, insertNewLine, insertRule,
splitCodeBlock, splitListItem, redo, undo];
function makeKeymap(description: string, windows: string, mac: string, common?: string): Keymap {
return {
description: description,
windows: windows,
mac: mac,
common: common
};
}
function makeKeyMapWithCommon(description: string, common: string): Keymap {
const windows = common.replace(/Mod/i, 'Ctrl');
const mac = common.replace(/Mod/i, 'Cmd');
return makeKeymap(description, windows, mac, common);
}
export interface Keymap {
description: string;
windows: string;
mac: string;
common?: string;
}
export function bindKeymapWithCommand(shortcut: string, cmd: (state: EditorState<any>, dispatch: (tr: Transaction) => void) => boolean, keymap: { [key: string]: Function }) {
const oldCmd = keymap[shortcut];
let newCmd = cmd;
if (keymap[shortcut]) {
newCmd = (state: EditorState<any>, dispatch: (tr: Transaction) => void): boolean => {
return oldCmd(state, dispatch) || cmd(state, dispatch);
};
}
keymap[shortcut] = newCmd;
}
export function findKeyMapForBrowser(kayMap: Keymap): string | undefined {
if (kayMap) {
if (browser.mac) {
return kayMap.mac;
}
return kayMap.windows;
}
}
export const keyCodes: { [key: string]: number } = {
'Enter': 13, 'Backspace': 8, 'Tab': 9, 'Shift': 16, 'Ctrl': 17, 'Alt': 18, 'Pause': 19, 'CapsLock': 20, 'Esc': 27, 'Space': 32,
'PageUp': 63276, 'PageDown': 63277, 'End': 63275, 'Home': 63273, 'Left': 63234, 'Up': 63232, 'Right': 63235, 'Down': 63233,
'PrintScrn': 44, 'Insert': 63302, 'Delete': 63272, ';': 186, '=': 187, 'Mod': 93, '*': 106, '-': 189, '.': 190, '/': 191, ',': 188,
'`': 192, '[': 219, '\\': 220, ']': 221, '\'': 222
};
export const LEFT = 37;
export const RIGHT = 39;
export const UP = 38;
export const DOWN = 40;