diff options
| author | bobzel <zzzman@gmail.com> | 2021-02-25 18:54:45 -0500 | 
|---|---|---|
| committer | bobzel <zzzman@gmail.com> | 2021-02-25 18:54:45 -0500 | 
| commit | fd329ad25987122c8f2a31177a6c346c97f00457 (patch) | |
| tree | 86904c38d08388a5c4becf805f20f82b7a8b6c29 /src/client/util/DragManager.ts | |
| parent | 17ee7f6f1f61a079ec79b71aebc65abfd72ec32a (diff) | |
added 'proto' drag option for dropping proto of document.  auto add of non annotations to file system.  auto added delegates & aliases to a docuemnt's 'alias' field.
Diffstat (limited to 'src/client/util/DragManager.ts')
| -rw-r--r-- | src/client/util/DragManager.ts | 7 | 
1 files changed, 4 insertions, 3 deletions
| diff --git a/src/client/util/DragManager.ts b/src/client/util/DragManager.ts index 19f1f8d15..0a3928ff8 100644 --- a/src/client/util/DragManager.ts +++ b/src/client/util/DragManager.ts @@ -13,7 +13,7 @@ import * as globalCssVariables from "../views/globalCssVariables.scss";  import { UndoManager } from "./UndoManager";  import { SnappingManager } from "./SnappingManager"; -export type dropActionType = "alias" | "copy" | "move" | "same" | "none" | undefined; // undefined = move, "same" = move but don't call removeDropProperties +export type dropActionType = "alias" | "copy" | "move" | "same" | "proto" | "none" | undefined; // undefined = move, "same" = move but don't call removeDropProperties  export function SetupDrag(      _reference: React.RefObject<HTMLElement>,      docFunc: () => Doc | Promise<Doc> | undefined, @@ -221,8 +221,9 @@ export namespace DragManager {                  docDragData.droppedDocuments =                      dragData.draggedDocuments.map(d => !dragData.isSelectionMove && !dragData.userDropAction && ScriptCast(d.onDragStart) ? addAudioTag(ScriptCast(d.onDragStart).script.run({ this: d }).result) :                          docDragData.dropAction === "alias" ? Doc.MakeAlias(d) : -                            docDragData.dropAction === "copy" ? Doc.MakeClone(d) : d); -                docDragData.dropAction !== "same" && docDragData.droppedDocuments.forEach((drop: Doc, i: number) => { +                            docDragData.dropAction === "proto" ? Doc.GetProto(d) : +                                docDragData.dropAction === "copy" ? Doc.MakeClone(d) : d); +                !["same", "proto"].includes(docDragData.dropAction as any) && docDragData.droppedDocuments.forEach((drop: Doc, i: number) => {                      const dragProps = Cast(dragData.draggedDocuments[i].removeDropProperties, listSpec("string"), []);                      const remProps = (dragData?.removeDropProperties || []).concat(Array.from(dragProps));                      remProps.map(prop => drop[prop] = undefined); | 
