diff options
| author | mehekj <mehek.jethani@gmail.com> | 2022-06-06 11:06:28 -0400 | 
|---|---|---|
| committer | mehekj <mehek.jethani@gmail.com> | 2022-06-06 11:06:28 -0400 | 
| commit | 0da188cccf46dea9e039d2f80907d2ee32edbfdb (patch) | |
| tree | 6943902900274cc6d9ed954181cf935757a1e2ae /src/client/views/nodes/formattedText/ProsemirrorExampleTransfer.ts | |
| parent | 3b3695cfc5674a93c0ecee4d2af5d8ba8c8cfb70 (diff) | |
| parent | 9acba91baa0ee2ee43106d344392039a2cbd0e46 (diff) | |
Merge branch 'master' into temporalmedia-mehek
Diffstat (limited to 'src/client/views/nodes/formattedText/ProsemirrorExampleTransfer.ts')
| -rw-r--r-- | src/client/views/nodes/formattedText/ProsemirrorExampleTransfer.ts | 70 | 
1 files changed, 19 insertions, 51 deletions
| diff --git a/src/client/views/nodes/formattedText/ProsemirrorExampleTransfer.ts b/src/client/views/nodes/formattedText/ProsemirrorExampleTransfer.ts index c76eda859..fb49b0698 100644 --- a/src/client/views/nodes/formattedText/ProsemirrorExampleTransfer.ts +++ b/src/client/views/nodes/formattedText/ProsemirrorExampleTransfer.ts @@ -1,20 +1,15 @@ -import { chainCommands, exitCode, joinDown, joinUp, lift, deleteSelection, joinBackward, selectNodeBackward, setBlockType, splitBlockKeepMarks, toggleMark, wrapIn, newlineInCode } from "prosemirror-commands"; -import { liftTarget } from "prosemirror-transform"; +import { chainCommands, deleteSelection, exitCode, joinBackward, joinDown, joinUp, lift, newlineInCode, selectNodeBackward, setBlockType, splitBlockKeepMarks, toggleMark, wrapIn } from "prosemirror-commands";  import { redo, undo } from "prosemirror-history";  import { Schema } from "prosemirror-model"; -import { liftListItem, sinkListItem } from "./prosemirrorPatches.js"; -import { splitListItem, wrapInList, } from "prosemirror-schema-list"; -import { EditorState, Transaction, TextSelection } from "prosemirror-state"; -import { SelectionManager } from "../../../util/SelectionManager"; -import { NumCast, BoolCast, Cast, StrCast } from "../../../../fields/Types"; -import { Doc, DataSym, DocListCast, AclAugment, AclSelfEdit } from "../../../../fields/Doc"; -import { FormattedTextBox } from "./FormattedTextBox"; -import { Id } from "../../../../fields/FieldSymbols"; -import { Docs } from "../../../documents/Documents"; -import { Utils } from "../../../../Utils"; -import { listSpec } from "../../../../fields/Schema"; -import { List } from "../../../../fields/List"; +import { splitListItem, wrapInList } from "prosemirror-schema-list"; +import { EditorState, TextSelection, Transaction } from "prosemirror-state"; +import { liftTarget } from "prosemirror-transform"; +import { AclAugment, AclSelfEdit, Doc } from "../../../../fields/Doc";  import { GetEffectiveAcl } from "../../../../fields/util"; +import { Utils } from "../../../../Utils"; +import { Docs } from "../../../documents/Documents"; +import { SelectionManager } from "../../../util/SelectionManager"; +import { liftListItem, sinkListItem } from "./prosemirrorPatches.js";  const mac = typeof navigator !== "undefined" ? /Mac/.test(navigator.platform) : false; @@ -48,29 +43,6 @@ export function buildKeymap<S extends Schema<any>>(schema: S, props: any, mapKey          keys[key] = cmd;      } -    /// bcz; Argh!!  replace with an onEnter func that conditionally handles Enter  -    const addTextBox = (below: boolean, force?: boolean) => { -        if (props.Document.treeViewType === "outline") return true;  // bcz: Arghh .. need to determine if this is an treeViewOutlineBox in which case Enter's are ignored.. -        const layoutDoc = props.Document; -        const originalDoc = layoutDoc.rootDocument || layoutDoc; -        if (force || props.Document._singleLine) { -            const layoutKey = StrCast(originalDoc.layoutKey); -            const newDoc = Doc.MakeCopy(originalDoc, true); -            const dataField = originalDoc[Doc.LayoutFieldKey(newDoc)]; -            newDoc[DataSym][Doc.LayoutFieldKey(newDoc)] = dataField === undefined || Cast(dataField, listSpec(Doc), null)?.length !== undefined ? new List<Doc>([]) : undefined; -            if (below) newDoc.y = NumCast(originalDoc.y) + NumCast(originalDoc._height) + 10; -            else newDoc.x = NumCast(originalDoc.x) + NumCast(originalDoc._width) + 10; -            if (layoutKey !== "layout" && originalDoc[layoutKey] instanceof Doc) { -                newDoc[layoutKey] = originalDoc[layoutKey]; -            } -            Doc.GetProto(newDoc).text = undefined; -            FormattedTextBox.SelectOnLoad = newDoc[Id]; -            props.addDocument(newDoc); -            return true; -        } -        return false; -    }; -      const canEdit = (state: any) => {          switch (GetEffectiveAcl(props.Document)) {              case AclAugment: return false; @@ -108,12 +80,12 @@ export function buildKeymap<S extends Schema<any>>(schema: S, props: any, mapKey      //Commands for lists      bind("Ctrl-i", (state: EditorState<S>, dispatch: (tx: Transaction<S>) => void) => canEdit(state) && wrapInList(schema.nodes.ordered_list)(state as any, dispatch as any)); +    bind("Ctrl-Tab", () => props.onKey?.(event, props) ? true : true); +    bind("Alt-Tab", () => props.onKey?.(event, props) ? true : true); +    bind("Meta-Tab", () => props.onKey?.(event, props) ? true : true); +    bind("Meta-Enter", () => props.onKey?.(event, props) ? true : true);      bind("Tab", (state: EditorState<S>, dispatch: (tx: Transaction<S>) => void) => { -        /// bcz; Argh!!  replace layotuTEmpalteString with a onTab prop conditionally handles Tab); -        if (props.Document._singleLine) { -            if (!props.LayoutTemplateString) return addTextBox(false, true); -            return true; -        } +        if (props.onKey?.(event, props)) return true;          if (!canEdit(state)) return true;          const ref = state.selection;          const range = ref.$from.blockRange(ref.$to); @@ -138,8 +110,7 @@ export function buildKeymap<S extends Schema<any>>(schema: S, props: any, mapKey      });      bind("Shift-Tab", (state: EditorState<S>, dispatch: (tx: Transaction<S>) => void) => { -        /// bcz; Argh!!  replace with a onShiftTab prop conditionally handles Tab); -        if (props.Document._singleLine) return true; +        if (props.onKey?.(event, props)) return true;          if (!canEdit(state)) return true;          const marks = state.storedMarks || (state.selection.$to.parentOffset && state.selection.$from.marks()); @@ -187,14 +158,13 @@ export function buildKeymap<S extends Schema<any>>(schema: S, props: any, mapKey          return tx;      }; -    //Command to create a text document to the right of the selected textbox -    bind("Alt-Enter", () => addTextBox(false, true)); -    //Command to create a text document to the bottom of the selected textbox -    bind("Ctrl-Enter", () => addTextBox(true, true)); +    bind("Alt-Enter", () => props.onKey?.(event, props) ? true : true); +    bind("Ctrl-Enter", () => props.onKey?.(event, props) ? true : true);      // backspace = chainCommands(deleteSelection, joinBackward, selectNodeBackward);      bind("Backspace", (state: EditorState<S>, dispatch: (tx: Transaction<Schema<any, any>>) => void) => { +        if (props.onKey?.(event, props)) return true;          if (!canEdit(state)) return true;          if (!deleteSelection(state, (tx: Transaction<S>) => { @@ -216,8 +186,8 @@ export function buildKeymap<S extends Schema<any>>(schema: S, props: any, mapKey      //newlineInCode, createParagraphNear, liftEmptyBlock, splitBlock      //command to break line      bind("Enter", (state: EditorState<S>, dispatch: (tx: Transaction<Schema<any, any>>) => void) => { -        if (addTextBox(true, false)) return true; +        if (props.onKey?.(event, props)) return true;          if (!canEdit(state)) return true;          const trange = state.selection.$from.blockRange(state.selection.$to); @@ -276,8 +246,6 @@ export function buildKeymap<S extends Schema<any>>(schema: S, props: any, mapKey          return false;      }); -    // mac && bind("Ctrl-Enter", cmd); -    // bind("Mod-Enter", cmd);      bind("Shift-Enter", cmd);      return keys; | 
