@modusoperandi/licit 1.4.3 → 1.4.6
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/BlockquoteInsertNewLineCommand.js.flow +70 -70
- package/BlockquoteNodeSpec.js.flow +29 -29
- package/BlockquoteToggleCommand.js.flow +56 -56
- package/BookmarkNodeSpec.js.flow +39 -39
- package/BulletListNodeSpec.js.flow +61 -61
- package/CZIProseMirror.js.flow +90 -90
- package/CodeBlockCommand.js.flow +65 -65
- package/CodeBlockNodeSpec.js.flow +24 -24
- package/CodeMarkSpec.js.flow +14 -14
- package/ContentPlaceholderPlugin.js.flow +183 -183
- package/CursorPlaceholderPlugin.js.flow +113 -113
- package/DocLayoutCommand.js.flow +97 -97
- package/DocNodeSpec.js.flow +62 -62
- package/EMMarkSpec.js.flow +39 -39
- package/EditorCommands.js.flow +124 -124
- package/EditorKeyMap.js.flow +173 -173
- package/EditorMarks.js +4 -2
- package/EditorMarks.js.flow +77 -74
- package/EditorNodes.js.flow +55 -55
- package/EditorPageLayoutPlugin.js.flow +67 -67
- package/EditorPlugins.js.flow +8 -8
- package/EditorSchema.js.flow +12 -12
- package/EditorState.js.flow +7 -7
- package/FontSizeMarkSpec.js.flow +54 -54
- package/FontTypeMarkSpec.js.flow +89 -89
- package/HTMLMutator.js.flow +58 -58
- package/HangingIndentMarkSpec.js +34 -0
- package/HangingIndentMarkSpec.js.flow +30 -0
- package/HardBreakNodeSpec.js.flow +15 -15
- package/HeadingNodeSpec.js.flow +42 -42
- package/HistoryRedoCommand.js.flow +41 -41
- package/HistoryUndoCommand.js.flow +41 -41
- package/HorizontalRuleCommand.js.flow +71 -71
- package/HorizontalRuleNodeSpec.js.flow +39 -39
- package/ImageUploadPlaceholderPlugin.js.flow +187 -187
- package/LICENSE +22 -22
- package/LinkMarkSpec.js +4 -2
- package/LinkMarkSpec.js.flow +38 -37
- package/LinkSetURLCommand.js.flow +129 -129
- package/LinkTooltipPlugin.js +31 -37
- package/LinkTooltipPlugin.js.flow +204 -217
- package/ListItemInsertNewLineCommand.js.flow +76 -76
- package/ListItemMergeCommand.js.flow +197 -197
- package/ListItemNodeSpec.js.flow +52 -52
- package/ListSplitCommand.js.flow +54 -54
- package/ListToggleCommand.js.flow +99 -99
- package/MarkNames.js +2 -1
- package/MarkNames.js.flow +20 -19
- package/MarksClearCommand.js.flow +66 -66
- package/NodeNames.js.flow +23 -23
- package/OrderedListNodeSpec.js.flow +131 -131
- package/OverrideMarkSpec.js.flow +49 -49
- package/ParagraphNodeSpec.js +21 -2
- package/ParagraphNodeSpec.js.flow +233 -215
- package/ParagraphSpacingCommand.js.flow +139 -139
- package/PrintCommand.js.flow +53 -53
- package/SelectionPlaceholderPlugin.js.flow +129 -129
- package/SpacerMarkSpec.js.flow +47 -47
- package/StrikeMarkSpec.js.flow +24 -24
- package/StrongMarkSpec.js.flow +39 -39
- package/StyleView.js.flow +18 -18
- package/TableBackgroundColorCommand.js.flow +79 -79
- package/TableBorderColorCommand.js +5 -3
- package/TableBorderColorCommand.js.flow +108 -106
- package/TableCellColorCommand.js.flow +73 -73
- package/TableCellMenuPlugin.js.flow +129 -129
- package/TableInsertCommand.js.flow +117 -117
- package/TableMergeCellsCommand.js.flow +113 -113
- package/TableNodesSpecs.js.flow +144 -144
- package/TablePlugins.js.flow +14 -14
- package/TableResizePlugin.js.flow +636 -636
- package/TextColorMarkSpec.js.flow +40 -40
- package/TextHighlightMarkSpec.js.flow +47 -47
- package/TextInsertTabSpaceCommand.js +0 -3
- package/TextInsertTabSpaceCommand.js.flow +103 -106
- package/TextNoWrapMarkSpec.js.flow +14 -14
- package/TextNodeSpec.js.flow +7 -7
- package/TextSelectionMarkSpec.js.flow +24 -24
- package/TextSubMarkSpec.js.flow +28 -28
- package/TextSuperMarkSpec.js.flow +28 -28
- package/TextUnderlineMarkSpec.js.flow +24 -24
- package/Types.js.flow +77 -77
- package/WebFontLoader.js.flow +22 -22
- package/blockQuoteInputRule.js.flow +36 -36
- package/bom.xml +8573 -8650
- package/browser.js.flow +7 -7
- package/buildEditorPlugins.js.flow +48 -48
- package/buildInputRules.js.flow +85 -85
- package/client/CollabConnector.js.flow +90 -90
- package/client/EditorConnection.js.flow +324 -324
- package/client/Licit.js +39 -39
- package/client/Licit.js.flow +649 -649
- package/client/Licit.test.js.flow +104 -104
- package/client/Reporter.js.flow +35 -35
- package/client/SimpleConnector.js.flow +61 -61
- package/client/http.js.flow +60 -60
- package/client/licit.css +12 -12
- package/client/throttle.js.flow +27 -27
- package/convertFromDOMElement.js.flow +33 -33
- package/convertFromHTML.js.flow +15 -15
- package/convertFromJSON.js.flow +53 -53
- package/convertToCSSPTValue.js.flow +19 -19
- package/convertToJSON.js.flow +7 -7
- package/createCommand.js.flow +62 -62
- package/createEditorKeyMap.js.flow +87 -87
- package/createEmptyEditorState.js.flow +29 -29
- package/createTableResizingPlugin.js.flow +86 -86
- package/findActionableCell.js.flow +74 -74
- package/findActiveMark.js.flow +32 -32
- package/hyphenize.js.flow +17 -17
- package/index.d.ts +167 -167
- package/index.js.flow +10 -10
- package/insertTable.js.flow +54 -54
- package/isEditorStateEmpty.js.flow +32 -32
- package/isTableNode.js.flow +15 -15
- package/joinDown.js.flow +25 -25
- package/joinListNode.js.flow +55 -55
- package/joinUp.js.flow +37 -37
- package/keymaps.js.flow +175 -175
- package/lookUpElement.js.flow +14 -14
- package/nodeAt.js.flow +12 -12
- package/normalizeHTML.js.flow +80 -80
- package/package.json +152 -152
- package/patchAnchorElements.js.flow +38 -38
- package/patchBreakElements.js.flow +22 -22
- package/patchElementInlineStyles.js.flow +92 -92
- package/patchListElements.js.flow +275 -275
- package/patchMathElements.js.flow +58 -58
- package/patchParagraphElements.js.flow +20 -20
- package/patchStyleElements.js.flow +197 -197
- package/patchTableElements.js.flow +88 -88
- package/rebaseDocWithSteps.js.flow +42 -42
- package/sanitizeURL.js.flow +13 -13
- package/splitListItem.js.flow +191 -191
- package/styles.css +46 -46
- package/toClosestFontPtSize.js.flow +22 -22
- package/toSafeHTMLDocument.js.flow +9 -9
- package/toggleBlockquote.js.flow +101 -101
- package/toggleCodeBlock.js.flow +102 -102
- package/ui/AlertInfo.js.flow +63 -63
- package/ui/BookmarkNodeView.js.flow +64 -64
- package/ui/CommandButton.js.flow +68 -68
- package/ui/CommandMenu.js.flow +74 -74
- package/ui/CommandMenuButton.js.flow +128 -128
- package/ui/CustomEditorView.js.flow +29 -29
- package/ui/CustomMenu.js.flow +14 -14
- package/ui/CustomMenuItem.js.flow +35 -35
- package/ui/CustomNodeView.js.flow +207 -207
- package/ui/CustomRadioButton.js.flow +63 -63
- package/ui/DocLayoutEditor.js.flow +130 -130
- package/ui/Editor.js.flow +281 -281
- package/ui/EditorFrameset.js.flow +79 -79
- package/ui/EditorToolbar.js.flow +197 -197
- package/ui/EditorToolbarConfig.js.flow +162 -162
- package/ui/FontSizeCommandMenuButton.js.flow +66 -66
- package/ui/FontTypeCommandMenuButton.js.flow +60 -60
- package/ui/Frag.js.flow +11 -11
- package/ui/Icon.js.flow +82 -82
- package/ui/ImageInlineEditor.js.flow +66 -66
- package/ui/KeyCodes.js.flow +12 -12
- package/ui/LinkTooltip.js.flow +51 -51
- package/ui/LinkURLEditor.js.flow +227 -227
- package/ui/ListItemNodeView.js.flow +101 -101
- package/ui/ListTypeButton.js.flow +121 -121
- package/ui/ListTypeCommandButton.js.flow +85 -85
- package/ui/ListTypeMenu.js.flow +78 -78
- package/ui/LoadingIndicator.js.flow +19 -19
- package/ui/PasteMenu.js.flow +52 -52
- package/ui/ResizeObserver.js.flow +105 -105
- package/ui/RichTextEditor.js.flow +133 -133
- package/ui/SelectionObserver.js.flow +134 -134
- package/ui/TableCellMenu.js.flow +49 -49
- package/ui/TableGridSizeEditor.js.flow +185 -185
- package/ui/TableNodeView.js.flow +36 -36
- package/ui/bindScrollHandler.js.flow +46 -46
- package/ui/canUseCSSFont.js.flow +42 -42
- package/ui/czi-body-layout-editor.css +16 -16
- package/ui/czi-bookmark-view.css +10 -10
- package/ui/czi-cursor-placeholder.css +36 -36
- package/ui/czi-custom-menu-button.css +18 -18
- package/ui/czi-custom-menu-item.css +30 -30
- package/ui/czi-custom-menu.css +8 -8
- package/ui/czi-custom-radio-button.css +80 -80
- package/ui/czi-custom-scrollbar.css +21 -21
- package/ui/czi-editor-frameset.css +81 -81
- package/ui/czi-editor-toolbar.css +122 -122
- package/ui/czi-editor.css +239 -216
- package/ui/czi-form.css +201 -201
- package/ui/czi-frag.css +3 -3
- package/ui/czi-heading.css +40 -40
- package/ui/czi-icon.css +72 -72
- package/ui/czi-image-resize-box.css +165 -165
- package/ui/czi-image-upload-editor.css +57 -57
- package/ui/czi-image-upload-placeholder.css +50 -50
- package/ui/czi-image-url-editor.css +38 -38
- package/ui/czi-image-view.css +121 -121
- package/ui/czi-indent.css +137 -137
- package/ui/czi-inline-editor.css +20 -20
- package/ui/czi-link-tooltip.css +112 -112
- package/ui/czi-list.css +406 -406
- package/ui/czi-loading-indicator.css +66 -66
- package/ui/czi-math-view.css +62 -62
- package/ui/czi-selection-placeholder.css +24 -24
- package/ui/czi-table-cell-menu.css +16 -16
- package/ui/czi-table-grid-size-editor.css +37 -37
- package/ui/czi-table.css +89 -89
- package/ui/czi-vars.css +47 -45
- package/ui/findActiveFontSize.js.flow +55 -55
- package/ui/findActiveFontType.js.flow +35 -35
- package/ui/fonts.css +460 -460
- package/ui/handleEditorDrop.js.flow +28 -28
- package/ui/handleEditorKeyDown.js.flow +39 -39
- package/ui/handleEditorPaste.js.flow +33 -33
- package/ui/htmlElementToRect.js.flow +18 -18
- package/ui/icon-font.css +9 -9
- package/ui/injectStyleSheet.js.flow +40 -40
- package/ui/isElementFullyVisible.js.flow +14 -14
- package/ui/isOffline.js.flow +8 -8
- package/ui/isReactClass.js.flow +12 -12
- package/ui/listType.css +21 -21
- package/ui/resolveImage.js.flow +121 -121
- package/ui/toCSSColor.js.flow +51 -51
- package/ui/toCSSLineSpacing.js.flow +53 -53
- package/ui/toHexColor.js.flow +26 -26
- package/ui/uuid.js.flow +9 -9
- package/uuid.js.flow +9 -9
package/joinListNode.js.flow
CHANGED
|
@@ -1,55 +1,55 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import { Schema } from 'prosemirror-model';
|
|
4
|
-
import { TextSelection } from 'prosemirror-state';
|
|
5
|
-
import { Transform } from 'prosemirror-transform';
|
|
6
|
-
|
|
7
|
-
import { isListNode } from '@modusoperandi/licit-ui-commands';
|
|
8
|
-
import joinDown from './joinDown';
|
|
9
|
-
import joinUp from './joinUp';
|
|
10
|
-
|
|
11
|
-
export default function joinListNode(
|
|
12
|
-
tr: Transform,
|
|
13
|
-
schema: Schema,
|
|
14
|
-
listNodePos: number
|
|
15
|
-
): Transform {
|
|
16
|
-
if (!tr.doc || !tr.selection) {
|
|
17
|
-
return tr;
|
|
18
|
-
}
|
|
19
|
-
const node = tr.doc.nodeAt(listNodePos);
|
|
20
|
-
if (!isListNode(node)) {
|
|
21
|
-
return tr;
|
|
22
|
-
}
|
|
23
|
-
const initialSelection = tr.selection;
|
|
24
|
-
const listFromPos = listNodePos;
|
|
25
|
-
const listToPos = listFromPos + node.nodeSize;
|
|
26
|
-
const $fromPos = tr.doc.resolve(listFromPos);
|
|
27
|
-
const $toPos = tr.doc.resolve(listToPos);
|
|
28
|
-
|
|
29
|
-
let selectionOffset = 0;
|
|
30
|
-
if (
|
|
31
|
-
$toPos.nodeAfter &&
|
|
32
|
-
$toPos.nodeAfter.type === node.type &&
|
|
33
|
-
$toPos.nodeAfter.attrs.level === node.attrs.level
|
|
34
|
-
) {
|
|
35
|
-
tr = joinDown(tr);
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
if (
|
|
39
|
-
$fromPos.nodeBefore &&
|
|
40
|
-
$fromPos.nodeBefore.type === node.type &&
|
|
41
|
-
$fromPos.nodeBefore.attrs.level === node.attrs.level
|
|
42
|
-
) {
|
|
43
|
-
selectionOffset -= 2;
|
|
44
|
-
tr = joinUp(tr);
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
const selection = TextSelection.create(
|
|
48
|
-
tr.doc,
|
|
49
|
-
initialSelection.from + selectionOffset,
|
|
50
|
-
initialSelection.to + selectionOffset
|
|
51
|
-
);
|
|
52
|
-
|
|
53
|
-
tr = tr.setSelection(selection);
|
|
54
|
-
return tr;
|
|
55
|
-
}
|
|
1
|
+
// @flow
|
|
2
|
+
|
|
3
|
+
import { Schema } from 'prosemirror-model';
|
|
4
|
+
import { TextSelection } from 'prosemirror-state';
|
|
5
|
+
import { Transform } from 'prosemirror-transform';
|
|
6
|
+
|
|
7
|
+
import { isListNode } from '@modusoperandi/licit-ui-commands';
|
|
8
|
+
import joinDown from './joinDown';
|
|
9
|
+
import joinUp from './joinUp';
|
|
10
|
+
|
|
11
|
+
export default function joinListNode(
|
|
12
|
+
tr: Transform,
|
|
13
|
+
schema: Schema,
|
|
14
|
+
listNodePos: number
|
|
15
|
+
): Transform {
|
|
16
|
+
if (!tr.doc || !tr.selection) {
|
|
17
|
+
return tr;
|
|
18
|
+
}
|
|
19
|
+
const node = tr.doc.nodeAt(listNodePos);
|
|
20
|
+
if (!isListNode(node)) {
|
|
21
|
+
return tr;
|
|
22
|
+
}
|
|
23
|
+
const initialSelection = tr.selection;
|
|
24
|
+
const listFromPos = listNodePos;
|
|
25
|
+
const listToPos = listFromPos + node.nodeSize;
|
|
26
|
+
const $fromPos = tr.doc.resolve(listFromPos);
|
|
27
|
+
const $toPos = tr.doc.resolve(listToPos);
|
|
28
|
+
|
|
29
|
+
let selectionOffset = 0;
|
|
30
|
+
if (
|
|
31
|
+
$toPos.nodeAfter &&
|
|
32
|
+
$toPos.nodeAfter.type === node.type &&
|
|
33
|
+
$toPos.nodeAfter.attrs.level === node.attrs.level
|
|
34
|
+
) {
|
|
35
|
+
tr = joinDown(tr);
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
if (
|
|
39
|
+
$fromPos.nodeBefore &&
|
|
40
|
+
$fromPos.nodeBefore.type === node.type &&
|
|
41
|
+
$fromPos.nodeBefore.attrs.level === node.attrs.level
|
|
42
|
+
) {
|
|
43
|
+
selectionOffset -= 2;
|
|
44
|
+
tr = joinUp(tr);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
const selection = TextSelection.create(
|
|
48
|
+
tr.doc,
|
|
49
|
+
initialSelection.from + selectionOffset,
|
|
50
|
+
initialSelection.to + selectionOffset
|
|
51
|
+
);
|
|
52
|
+
|
|
53
|
+
tr = tr.setSelection(selection);
|
|
54
|
+
return tr;
|
|
55
|
+
}
|
package/joinUp.js.flow
CHANGED
|
@@ -1,37 +1,37 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
// https://github.com/ProseMirror/prosemirror-commands/blob/master/src/commands.js
|
|
3
|
-
|
|
4
|
-
import { NodeSelection } from 'prosemirror-state';
|
|
5
|
-
import { Transform, canJoin, joinPoint } from 'prosemirror-transform';
|
|
6
|
-
|
|
7
|
-
// Join the selected block or, if there is a text selection, the
|
|
8
|
-
// closest ancestor block of the selection that can be joined, with
|
|
9
|
-
// the sibling above it.
|
|
10
|
-
export default function joinUp(tr: Transform): Transform {
|
|
11
|
-
const sel = tr.selection;
|
|
12
|
-
const nodeSel = sel instanceof NodeSelection;
|
|
13
|
-
let point;
|
|
14
|
-
if (nodeSel) {
|
|
15
|
-
if (sel.node.isTextblock || !canJoin(tr.doc, sel.from)) {
|
|
16
|
-
return tr;
|
|
17
|
-
}
|
|
18
|
-
point = sel.from;
|
|
19
|
-
} else {
|
|
20
|
-
point = joinPoint(tr.doc, sel.from, -1);
|
|
21
|
-
if (point === null || point === undefined) {
|
|
22
|
-
return tr;
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
tr = tr.join(point);
|
|
27
|
-
if (nodeSel) {
|
|
28
|
-
tr = tr.setSelection(
|
|
29
|
-
NodeSelection.create(
|
|
30
|
-
tr.doc,
|
|
31
|
-
point - tr.doc.resolve(point).nodeBefore.nodeSize
|
|
32
|
-
)
|
|
33
|
-
);
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
return tr;
|
|
37
|
-
}
|
|
1
|
+
// @flow
|
|
2
|
+
// https://github.com/ProseMirror/prosemirror-commands/blob/master/src/commands.js
|
|
3
|
+
|
|
4
|
+
import { NodeSelection } from 'prosemirror-state';
|
|
5
|
+
import { Transform, canJoin, joinPoint } from 'prosemirror-transform';
|
|
6
|
+
|
|
7
|
+
// Join the selected block or, if there is a text selection, the
|
|
8
|
+
// closest ancestor block of the selection that can be joined, with
|
|
9
|
+
// the sibling above it.
|
|
10
|
+
export default function joinUp(tr: Transform): Transform {
|
|
11
|
+
const sel = tr.selection;
|
|
12
|
+
const nodeSel = sel instanceof NodeSelection;
|
|
13
|
+
let point;
|
|
14
|
+
if (nodeSel) {
|
|
15
|
+
if (sel.node.isTextblock || !canJoin(tr.doc, sel.from)) {
|
|
16
|
+
return tr;
|
|
17
|
+
}
|
|
18
|
+
point = sel.from;
|
|
19
|
+
} else {
|
|
20
|
+
point = joinPoint(tr.doc, sel.from, -1);
|
|
21
|
+
if (point === null || point === undefined) {
|
|
22
|
+
return tr;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
tr = tr.join(point);
|
|
27
|
+
if (nodeSel) {
|
|
28
|
+
tr = tr.setSelection(
|
|
29
|
+
NodeSelection.create(
|
|
30
|
+
tr.doc,
|
|
31
|
+
point - tr.doc.resolve(point).nodeBefore.nodeSize
|
|
32
|
+
)
|
|
33
|
+
);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
return tr;
|
|
37
|
+
}
|
package/keymaps.js.flow
CHANGED
|
@@ -1,175 +1,175 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import Keymap from 'browserkeymap';
|
|
4
|
-
|
|
5
|
-
import browser from './browser';
|
|
6
|
-
|
|
7
|
-
import {
|
|
8
|
-
makeKeyMap,
|
|
9
|
-
makeKeyMapWithCommon,
|
|
10
|
-
} from '@modusoperandi/licit-doc-attrs-step';
|
|
11
|
-
|
|
12
|
-
// https://tinyurl.com/ybwf3wex
|
|
13
|
-
|
|
14
|
-
export function tooltip(keymap: ?Keymap): ?string {
|
|
15
|
-
if (keymap) {
|
|
16
|
-
let shortcut;
|
|
17
|
-
if (browser.isMac()) {
|
|
18
|
-
shortcut = keymap.mac
|
|
19
|
-
.replace(/Cmd/i, '⌘')
|
|
20
|
-
.replace(/Shift/i, '⇧')
|
|
21
|
-
.replace(/Ctrl/i, '^')
|
|
22
|
-
.replace(/Alt/i, '⌥');
|
|
23
|
-
} else {
|
|
24
|
-
shortcut = keymap.windows;
|
|
25
|
-
}
|
|
26
|
-
return `${keymap.description} (${shortcut})`;
|
|
27
|
-
}
|
|
28
|
-
return null;
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
export const KEY_BACK_DELETE = makeKeyMapWithCommon('', 'Backspace');
|
|
32
|
-
export const KEY_FORWARD_DELETE = makeKeyMapWithCommon('', 'Delete');
|
|
33
|
-
export const KEY_INSERT_HORIZONTAL_RULE = makeKeyMapWithCommon(
|
|
34
|
-
'Insert horizontal rule',
|
|
35
|
-
'Mod-Shift--'
|
|
36
|
-
);
|
|
37
|
-
export const KEY_INSERT_NEW_LINE_IN_BLOCKQUOTE = makeKeyMapWithCommon(
|
|
38
|
-
'Insert new line in blockquote',
|
|
39
|
-
'Shift-Enter'
|
|
40
|
-
);
|
|
41
|
-
export const KEY_REDO = makeKeyMapWithCommon('Redo', 'Mod-Shift-z');
|
|
42
|
-
export const KEY_SET_NORMAL_TEXT = makeKeyMap(
|
|
43
|
-
'Normal text',
|
|
44
|
-
'Ctrl-0',
|
|
45
|
-
'Cmd-Alt-0'
|
|
46
|
-
);
|
|
47
|
-
export const KEY_SHIFT_BACKSPACE = makeKeyMapWithCommon(
|
|
48
|
-
'Shift Backspace',
|
|
49
|
-
'Shift-Backspace'
|
|
50
|
-
);
|
|
51
|
-
export const KEY_SPLIT_CODEBLOCK = makeKeyMapWithCommon(
|
|
52
|
-
'Split code block',
|
|
53
|
-
'Enter'
|
|
54
|
-
);
|
|
55
|
-
export const KEY_SPLIT_LIST_ITEM = makeKeyMapWithCommon(
|
|
56
|
-
'Split list item',
|
|
57
|
-
'Enter'
|
|
58
|
-
);
|
|
59
|
-
export const KEY_TAB = makeKeyMapWithCommon('', 'Tab');
|
|
60
|
-
export const KEY_TAB_SHIFT = makeKeyMapWithCommon('', 'Shift-Tab');
|
|
61
|
-
export const KEY_TOGGLE_BLOCK_QUOTE = makeKeyMap(
|
|
62
|
-
'Block quote',
|
|
63
|
-
'Ctrl-7',
|
|
64
|
-
'Cmd-Alt-7'
|
|
65
|
-
);
|
|
66
|
-
export const KEY_TOGGLE_BOLD = makeKeyMapWithCommon('Toggle bold', 'Mod-b');
|
|
67
|
-
export const KEY_TOGGLE_BULLET_LIST = makeKeyMapWithCommon(
|
|
68
|
-
'Toggle bullet list',
|
|
69
|
-
'Mod-Shift-b'
|
|
70
|
-
);
|
|
71
|
-
export const KEY_TOGGLE_CODE_BLOCK = makeKeyMap(
|
|
72
|
-
'Code block',
|
|
73
|
-
'Ctrl-8',
|
|
74
|
-
'Cmd-Alt-8'
|
|
75
|
-
);
|
|
76
|
-
export const KEY_TOGGLE_HEADING_1 = makeKeyMap(
|
|
77
|
-
'Heading 1',
|
|
78
|
-
'Ctrl-1',
|
|
79
|
-
'Cmd-Alt-1'
|
|
80
|
-
);
|
|
81
|
-
export const KEY_TOGGLE_HEADING_2 = makeKeyMap(
|
|
82
|
-
'Heading 2',
|
|
83
|
-
'Ctrl-2',
|
|
84
|
-
'Cmd-Alt-2'
|
|
85
|
-
);
|
|
86
|
-
export const KEY_TOGGLE_HEADING_3 = makeKeyMap(
|
|
87
|
-
'Heading 3',
|
|
88
|
-
'Ctrl-3',
|
|
89
|
-
'Cmd-Alt-3'
|
|
90
|
-
);
|
|
91
|
-
export const KEY_TOGGLE_HEADING_4 = makeKeyMap(
|
|
92
|
-
'Heading 4',
|
|
93
|
-
'Ctrl-4',
|
|
94
|
-
'Cmd-Alt-4'
|
|
95
|
-
);
|
|
96
|
-
export const KEY_TOGGLE_HEADING_5 = makeKeyMap(
|
|
97
|
-
'Heading 5',
|
|
98
|
-
'Ctrl-5',
|
|
99
|
-
'Cmd-Alt-5'
|
|
100
|
-
);
|
|
101
|
-
export const KEY_TOGGLE_HEADING_6 = makeKeyMap(
|
|
102
|
-
'Heading 5',
|
|
103
|
-
'Ctrl-6',
|
|
104
|
-
'Cmd-Alt-6'
|
|
105
|
-
);
|
|
106
|
-
export const KEY_TOGGLE_ITALIC = makeKeyMapWithCommon('Toggle italic', 'Mod-i');
|
|
107
|
-
export const KEY_TOGGLE_MONOSPACE = makeKeyMapWithCommon(
|
|
108
|
-
'Toggle monospace',
|
|
109
|
-
'Mod-Shift-m'
|
|
110
|
-
);
|
|
111
|
-
export const KEY_TOGGLE_ORDERED_LIST = makeKeyMapWithCommon(
|
|
112
|
-
'Toggle ordered list',
|
|
113
|
-
'Mod-Shift-l'
|
|
114
|
-
);
|
|
115
|
-
export const KEY_TOGGLE_STRIKETHROUGH = makeKeyMapWithCommon(
|
|
116
|
-
'Toggle strikethrough',
|
|
117
|
-
'Mod-Shift-s'
|
|
118
|
-
);
|
|
119
|
-
export const KEY_TOGGLE_UNDERLINE = makeKeyMapWithCommon(
|
|
120
|
-
'Toggle underline',
|
|
121
|
-
'Mod-u'
|
|
122
|
-
);
|
|
123
|
-
export const KEY_UNDO = makeKeyMapWithCommon('Undo', 'Mod-z');
|
|
124
|
-
|
|
125
|
-
export const ALL_KEYS = [
|
|
126
|
-
KEY_BACK_DELETE,
|
|
127
|
-
KEY_FORWARD_DELETE,
|
|
128
|
-
KEY_INSERT_HORIZONTAL_RULE,
|
|
129
|
-
KEY_INSERT_NEW_LINE_IN_BLOCKQUOTE,
|
|
130
|
-
KEY_SET_NORMAL_TEXT,
|
|
131
|
-
KEY_SHIFT_BACKSPACE,
|
|
132
|
-
KEY_SPLIT_LIST_ITEM,
|
|
133
|
-
KEY_TAB_SHIFT,
|
|
134
|
-
KEY_TAB,
|
|
135
|
-
KEY_TOGGLE_BLOCK_QUOTE,
|
|
136
|
-
KEY_TOGGLE_BOLD,
|
|
137
|
-
KEY_TOGGLE_BULLET_LIST,
|
|
138
|
-
KEY_TOGGLE_BULLET_LIST,
|
|
139
|
-
KEY_TOGGLE_CODE_BLOCK,
|
|
140
|
-
KEY_TOGGLE_HEADING_1,
|
|
141
|
-
KEY_TOGGLE_HEADING_2,
|
|
142
|
-
KEY_TOGGLE_HEADING_3,
|
|
143
|
-
KEY_TOGGLE_HEADING_4,
|
|
144
|
-
KEY_TOGGLE_HEADING_5,
|
|
145
|
-
KEY_TOGGLE_HEADING_6,
|
|
146
|
-
KEY_TOGGLE_ITALIC,
|
|
147
|
-
KEY_TOGGLE_MONOSPACE,
|
|
148
|
-
KEY_TOGGLE_ORDERED_LIST,
|
|
149
|
-
KEY_TOGGLE_STRIKETHROUGH,
|
|
150
|
-
KEY_TOGGLE_UNDERLINE,
|
|
151
|
-
KEY_UNDO,
|
|
152
|
-
];
|
|
153
|
-
|
|
154
|
-
export function findKeymapByDescription(description: string): ?Keymap {
|
|
155
|
-
const matches = ALL_KEYS.filter((keymap) => {
|
|
156
|
-
return keymap.description.toUpperCase() === description.toUpperCase();
|
|
157
|
-
});
|
|
158
|
-
return matches[0];
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
export function findShortcutByDescription(description: string): ?string {
|
|
162
|
-
const keymap = findKeymapByDescription(description);
|
|
163
|
-
if (keymap) {
|
|
164
|
-
return findShortcutByKeymap(keymap);
|
|
165
|
-
}
|
|
166
|
-
return null;
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
export function findShortcutByKeymap(keymap: Keymap): ?string {
|
|
170
|
-
if (browser.isMac()) {
|
|
171
|
-
return keymap.mac;
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
return keymap.windows;
|
|
175
|
-
}
|
|
1
|
+
// @flow
|
|
2
|
+
|
|
3
|
+
import Keymap from 'browserkeymap';
|
|
4
|
+
|
|
5
|
+
import browser from './browser';
|
|
6
|
+
|
|
7
|
+
import {
|
|
8
|
+
makeKeyMap,
|
|
9
|
+
makeKeyMapWithCommon,
|
|
10
|
+
} from '@modusoperandi/licit-doc-attrs-step';
|
|
11
|
+
|
|
12
|
+
// https://tinyurl.com/ybwf3wex
|
|
13
|
+
|
|
14
|
+
export function tooltip(keymap: ?Keymap): ?string {
|
|
15
|
+
if (keymap) {
|
|
16
|
+
let shortcut;
|
|
17
|
+
if (browser.isMac()) {
|
|
18
|
+
shortcut = keymap.mac
|
|
19
|
+
.replace(/Cmd/i, '⌘')
|
|
20
|
+
.replace(/Shift/i, '⇧')
|
|
21
|
+
.replace(/Ctrl/i, '^')
|
|
22
|
+
.replace(/Alt/i, '⌥');
|
|
23
|
+
} else {
|
|
24
|
+
shortcut = keymap.windows;
|
|
25
|
+
}
|
|
26
|
+
return `${keymap.description} (${shortcut})`;
|
|
27
|
+
}
|
|
28
|
+
return null;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
export const KEY_BACK_DELETE = makeKeyMapWithCommon('', 'Backspace');
|
|
32
|
+
export const KEY_FORWARD_DELETE = makeKeyMapWithCommon('', 'Delete');
|
|
33
|
+
export const KEY_INSERT_HORIZONTAL_RULE = makeKeyMapWithCommon(
|
|
34
|
+
'Insert horizontal rule',
|
|
35
|
+
'Mod-Shift--'
|
|
36
|
+
);
|
|
37
|
+
export const KEY_INSERT_NEW_LINE_IN_BLOCKQUOTE = makeKeyMapWithCommon(
|
|
38
|
+
'Insert new line in blockquote',
|
|
39
|
+
'Shift-Enter'
|
|
40
|
+
);
|
|
41
|
+
export const KEY_REDO = makeKeyMapWithCommon('Redo', 'Mod-Shift-z');
|
|
42
|
+
export const KEY_SET_NORMAL_TEXT = makeKeyMap(
|
|
43
|
+
'Normal text',
|
|
44
|
+
'Ctrl-0',
|
|
45
|
+
'Cmd-Alt-0'
|
|
46
|
+
);
|
|
47
|
+
export const KEY_SHIFT_BACKSPACE = makeKeyMapWithCommon(
|
|
48
|
+
'Shift Backspace',
|
|
49
|
+
'Shift-Backspace'
|
|
50
|
+
);
|
|
51
|
+
export const KEY_SPLIT_CODEBLOCK = makeKeyMapWithCommon(
|
|
52
|
+
'Split code block',
|
|
53
|
+
'Enter'
|
|
54
|
+
);
|
|
55
|
+
export const KEY_SPLIT_LIST_ITEM = makeKeyMapWithCommon(
|
|
56
|
+
'Split list item',
|
|
57
|
+
'Enter'
|
|
58
|
+
);
|
|
59
|
+
export const KEY_TAB = makeKeyMapWithCommon('', 'Tab');
|
|
60
|
+
export const KEY_TAB_SHIFT = makeKeyMapWithCommon('', 'Shift-Tab');
|
|
61
|
+
export const KEY_TOGGLE_BLOCK_QUOTE = makeKeyMap(
|
|
62
|
+
'Block quote',
|
|
63
|
+
'Ctrl-7',
|
|
64
|
+
'Cmd-Alt-7'
|
|
65
|
+
);
|
|
66
|
+
export const KEY_TOGGLE_BOLD = makeKeyMapWithCommon('Toggle bold', 'Mod-b');
|
|
67
|
+
export const KEY_TOGGLE_BULLET_LIST = makeKeyMapWithCommon(
|
|
68
|
+
'Toggle bullet list',
|
|
69
|
+
'Mod-Shift-b'
|
|
70
|
+
);
|
|
71
|
+
export const KEY_TOGGLE_CODE_BLOCK = makeKeyMap(
|
|
72
|
+
'Code block',
|
|
73
|
+
'Ctrl-8',
|
|
74
|
+
'Cmd-Alt-8'
|
|
75
|
+
);
|
|
76
|
+
export const KEY_TOGGLE_HEADING_1 = makeKeyMap(
|
|
77
|
+
'Heading 1',
|
|
78
|
+
'Ctrl-1',
|
|
79
|
+
'Cmd-Alt-1'
|
|
80
|
+
);
|
|
81
|
+
export const KEY_TOGGLE_HEADING_2 = makeKeyMap(
|
|
82
|
+
'Heading 2',
|
|
83
|
+
'Ctrl-2',
|
|
84
|
+
'Cmd-Alt-2'
|
|
85
|
+
);
|
|
86
|
+
export const KEY_TOGGLE_HEADING_3 = makeKeyMap(
|
|
87
|
+
'Heading 3',
|
|
88
|
+
'Ctrl-3',
|
|
89
|
+
'Cmd-Alt-3'
|
|
90
|
+
);
|
|
91
|
+
export const KEY_TOGGLE_HEADING_4 = makeKeyMap(
|
|
92
|
+
'Heading 4',
|
|
93
|
+
'Ctrl-4',
|
|
94
|
+
'Cmd-Alt-4'
|
|
95
|
+
);
|
|
96
|
+
export const KEY_TOGGLE_HEADING_5 = makeKeyMap(
|
|
97
|
+
'Heading 5',
|
|
98
|
+
'Ctrl-5',
|
|
99
|
+
'Cmd-Alt-5'
|
|
100
|
+
);
|
|
101
|
+
export const KEY_TOGGLE_HEADING_6 = makeKeyMap(
|
|
102
|
+
'Heading 5',
|
|
103
|
+
'Ctrl-6',
|
|
104
|
+
'Cmd-Alt-6'
|
|
105
|
+
);
|
|
106
|
+
export const KEY_TOGGLE_ITALIC = makeKeyMapWithCommon('Toggle italic', 'Mod-i');
|
|
107
|
+
export const KEY_TOGGLE_MONOSPACE = makeKeyMapWithCommon(
|
|
108
|
+
'Toggle monospace',
|
|
109
|
+
'Mod-Shift-m'
|
|
110
|
+
);
|
|
111
|
+
export const KEY_TOGGLE_ORDERED_LIST = makeKeyMapWithCommon(
|
|
112
|
+
'Toggle ordered list',
|
|
113
|
+
'Mod-Shift-l'
|
|
114
|
+
);
|
|
115
|
+
export const KEY_TOGGLE_STRIKETHROUGH = makeKeyMapWithCommon(
|
|
116
|
+
'Toggle strikethrough',
|
|
117
|
+
'Mod-Shift-s'
|
|
118
|
+
);
|
|
119
|
+
export const KEY_TOGGLE_UNDERLINE = makeKeyMapWithCommon(
|
|
120
|
+
'Toggle underline',
|
|
121
|
+
'Mod-u'
|
|
122
|
+
);
|
|
123
|
+
export const KEY_UNDO = makeKeyMapWithCommon('Undo', 'Mod-z');
|
|
124
|
+
|
|
125
|
+
export const ALL_KEYS = [
|
|
126
|
+
KEY_BACK_DELETE,
|
|
127
|
+
KEY_FORWARD_DELETE,
|
|
128
|
+
KEY_INSERT_HORIZONTAL_RULE,
|
|
129
|
+
KEY_INSERT_NEW_LINE_IN_BLOCKQUOTE,
|
|
130
|
+
KEY_SET_NORMAL_TEXT,
|
|
131
|
+
KEY_SHIFT_BACKSPACE,
|
|
132
|
+
KEY_SPLIT_LIST_ITEM,
|
|
133
|
+
KEY_TAB_SHIFT,
|
|
134
|
+
KEY_TAB,
|
|
135
|
+
KEY_TOGGLE_BLOCK_QUOTE,
|
|
136
|
+
KEY_TOGGLE_BOLD,
|
|
137
|
+
KEY_TOGGLE_BULLET_LIST,
|
|
138
|
+
KEY_TOGGLE_BULLET_LIST,
|
|
139
|
+
KEY_TOGGLE_CODE_BLOCK,
|
|
140
|
+
KEY_TOGGLE_HEADING_1,
|
|
141
|
+
KEY_TOGGLE_HEADING_2,
|
|
142
|
+
KEY_TOGGLE_HEADING_3,
|
|
143
|
+
KEY_TOGGLE_HEADING_4,
|
|
144
|
+
KEY_TOGGLE_HEADING_5,
|
|
145
|
+
KEY_TOGGLE_HEADING_6,
|
|
146
|
+
KEY_TOGGLE_ITALIC,
|
|
147
|
+
KEY_TOGGLE_MONOSPACE,
|
|
148
|
+
KEY_TOGGLE_ORDERED_LIST,
|
|
149
|
+
KEY_TOGGLE_STRIKETHROUGH,
|
|
150
|
+
KEY_TOGGLE_UNDERLINE,
|
|
151
|
+
KEY_UNDO,
|
|
152
|
+
];
|
|
153
|
+
|
|
154
|
+
export function findKeymapByDescription(description: string): ?Keymap {
|
|
155
|
+
const matches = ALL_KEYS.filter((keymap) => {
|
|
156
|
+
return keymap.description.toUpperCase() === description.toUpperCase();
|
|
157
|
+
});
|
|
158
|
+
return matches[0];
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
export function findShortcutByDescription(description: string): ?string {
|
|
162
|
+
const keymap = findKeymapByDescription(description);
|
|
163
|
+
if (keymap) {
|
|
164
|
+
return findShortcutByKeymap(keymap);
|
|
165
|
+
}
|
|
166
|
+
return null;
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
export function findShortcutByKeymap(keymap: Keymap): ?string {
|
|
170
|
+
if (browser.isMac()) {
|
|
171
|
+
return keymap.mac;
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
return keymap.windows;
|
|
175
|
+
}
|
package/lookUpElement.js.flow
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
export default function lookUpElement(
|
|
4
|
-
el: ?Element,
|
|
5
|
-
predict: (el: Element) => boolean
|
|
6
|
-
): ?Element {
|
|
7
|
-
while (el?.nodeName) {
|
|
8
|
-
if (predict(el)) {
|
|
9
|
-
return el;
|
|
10
|
-
}
|
|
11
|
-
el = el.parentElement;
|
|
12
|
-
}
|
|
13
|
-
return null;
|
|
14
|
-
}
|
|
1
|
+
// @flow
|
|
2
|
+
|
|
3
|
+
export default function lookUpElement(
|
|
4
|
+
el: ?Element,
|
|
5
|
+
predict: (el: Element) => boolean
|
|
6
|
+
): ?Element {
|
|
7
|
+
while (el?.nodeName) {
|
|
8
|
+
if (predict(el)) {
|
|
9
|
+
return el;
|
|
10
|
+
}
|
|
11
|
+
el = el.parentElement;
|
|
12
|
+
}
|
|
13
|
+
return null;
|
|
14
|
+
}
|
package/nodeAt.js.flow
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import { Node } from 'prosemirror-model';
|
|
4
|
-
|
|
5
|
-
export default function nodeAt(doc: Node, pos: number): ?Node {
|
|
6
|
-
if (pos < 0 || pos > doc.content.size) {
|
|
7
|
-
// Exit here or error will be thrown:
|
|
8
|
-
// e.g. RangeError: Position outside of fragment.
|
|
9
|
-
return null;
|
|
10
|
-
}
|
|
11
|
-
return doc.nodeAt(pos);
|
|
12
|
-
}
|
|
1
|
+
// @flow
|
|
2
|
+
|
|
3
|
+
import { Node } from 'prosemirror-model';
|
|
4
|
+
|
|
5
|
+
export default function nodeAt(doc: Node, pos: number): ?Node {
|
|
6
|
+
if (pos < 0 || pos > doc.content.size) {
|
|
7
|
+
// Exit here or error will be thrown:
|
|
8
|
+
// e.g. RangeError: Position outside of fragment.
|
|
9
|
+
return null;
|
|
10
|
+
}
|
|
11
|
+
return doc.nodeAt(pos);
|
|
12
|
+
}
|