diff options
Diffstat (limited to 'src/client/views')
3 files changed, 71 insertions, 9 deletions
| diff --git a/src/client/views/collections/TabDocView.tsx b/src/client/views/collections/TabDocView.tsx index 73e5a9178..1310a582c 100644 --- a/src/client/views/collections/TabDocView.tsx +++ b/src/client/views/collections/TabDocView.tsx @@ -83,6 +83,9 @@ export class TabDocView extends React.Component<TabDocViewProps> {              titleEle.size = StrCast(doc.title).length + 3;              titleEle.value = doc.title; +            titleEle.onkeydown = (e: KeyboardEvent) => { +                e.stopPropagation(); +            }              titleEle.onchange = undoBatch(action((e: any) => {                  titleEle.size = e.currentTarget.value.length + 3;                  Doc.GetProto(doc).title = e.currentTarget.value; diff --git a/src/client/views/collections/collectionMulticolumn/CollectionMulticolumnView.tsx b/src/client/views/collections/collectionMulticolumn/CollectionMulticolumnView.tsx index 92f9b2f49..3582718a3 100644 --- a/src/client/views/collections/collectionMulticolumn/CollectionMulticolumnView.tsx +++ b/src/client/views/collections/collectionMulticolumn/CollectionMulticolumnView.tsx @@ -1,10 +1,10 @@  import { action, computed } from 'mobx';  import { observer } from 'mobx-react';  import * as React from "react"; -import { Doc } from '../../../../fields/Doc'; +import { Doc, DocListCast } from '../../../../fields/Doc';  import { List } from '../../../../fields/List';  import { BoolCast, NumCast, ScriptCast, StrCast } from '../../../../fields/Types'; -import { emptyFunction, returnFalse } from '../../../../Utils'; +import { emptyFunction, returnFalse, returnTrue } from '../../../../Utils';  import { DragManager, dropActionType } from '../../../util/DragManager';  import { Transform } from '../../../util/Transform';  import { undoBatch } from '../../../util/UndoManager'; @@ -194,11 +194,38 @@ export class CollectionMulticolumnView extends CollectionSubView() {      @undoBatch      @action      onInternalDrop = (e: Event, de: DragManager.DropEvent) => { -        if (super.onInternalDrop(e, de)) { +        let dropInd = -1; +        if (de.complete.docDragData && this._mainCont) { +            let curInd = -1;              de.complete.docDragData?.droppedDocuments.forEach(action((d: Doc) => { -                d._dimUnit = "*"; -                d._dimMagnitude = 1; +                curInd = this.childDocs.indexOf(d);              })); +            Array.from(this._mainCont.children).forEach((child, index) => { +                const brect = child.getBoundingClientRect(); +                if (brect.x < de.x && brect.x + brect.width > de.x) { +                    if (curInd !== -1 && curInd === Math.floor(index / 2)) { +                        dropInd = curInd; +                    } +                    else if (child.className === "multiColumnResizer") { +                        dropInd = Math.floor(index / 2); +                    } else { +                        dropInd = Math.ceil(index / 2 + (de.x - brect.x > brect.width / 2 ? 0 : -1)); +                    } +                } +            }) +            if (super.onInternalDrop(e, de)) { +                de.complete.docDragData?.droppedDocuments.forEach(action((d: Doc) => { +                    d._dimUnit = "*"; +                    d._dimMagnitude = 1; +                    if (dropInd !== curInd || dropInd === -1) { +                        if (this.childDocs.includes(d)) { +                            if (dropInd > this.childDocs.indexOf(d)) dropInd--; +                        } +                        Doc.RemoveDocFromList(this.rootDoc, this.props.fieldKey, d); +                        Doc.AddDocToList(this.rootDoc, this.props.fieldKey, d, DocListCast(this.rootDoc[this.props.fieldKey])[dropInd], undefined, dropInd === -1); +                    } +                })); +            }          }          return false;      } @@ -214,6 +241,7 @@ export class CollectionMulticolumnView extends CollectionSubView() {          }          return this.props.addDocTab(doc, where);      } +    isContentActive = () => this.props.isSelected() || this.props.isContentActive();      getDisplayDoc = (layout: Doc, dxf: () => Transform, width: () => number, height: () => number) => {          return <DocumentView              Document={layout} @@ -232,6 +260,7 @@ export class CollectionMulticolumnView extends CollectionSubView() {              onClick={this.onChildClickHandler}              onDoubleClick={this.onChildDoubleClickHandler}              ScreenToLocalTransform={dxf} +            isDocumentActive={this.props.childDocumentsActive ? this.props.isDocumentActive : this.isContentActive}              focus={this.props.focus}              docFilters={this.childDocFilters}              docRangeFilters={this.childDocRangeFilters} diff --git a/src/client/views/collections/collectionMulticolumn/CollectionMultirowView.tsx b/src/client/views/collections/collectionMulticolumn/CollectionMultirowView.tsx index 4c4054b09..95456cf46 100644 --- a/src/client/views/collections/collectionMulticolumn/CollectionMultirowView.tsx +++ b/src/client/views/collections/collectionMulticolumn/CollectionMultirowView.tsx @@ -1,7 +1,7 @@  import { action, computed } from 'mobx';  import { observer } from 'mobx-react';  import * as React from "react"; -import { Doc } from '../../../../fields/Doc'; +import { Doc, DocListCast } from '../../../../fields/Doc';  import { List } from '../../../../fields/List';  import { BoolCast, NumCast, ScriptCast, StrCast } from '../../../../fields/Types';  import { emptyFunction, returnFalse } from '../../../../Utils'; @@ -190,14 +190,42 @@ export class CollectionMultirowView extends CollectionSubView() {          return Transform.Identity(); // type coersion, this case should never be hit      } +      @undoBatch      @action      onInternalDrop = (e: Event, de: DragManager.DropEvent) => { -        if (super.onInternalDrop(e, de)) { +        let dropInd = -1; +        if (de.complete.docDragData && this._mainCont) { +            let curInd = -1;              de.complete.docDragData?.droppedDocuments.forEach(action((d: Doc) => { -                d._dimUnit = "*"; -                d._dimMagnitude = 1; +                curInd = this.childDocs.indexOf(d);              })); +            Array.from(this._mainCont.children).forEach((child, index) => { +                const brect = child.getBoundingClientRect(); +                if (brect.y < de.y && brect.y + brect.height > de.y) { +                    if (curInd !== -1 && curInd === Math.floor(index / 2)) { +                        dropInd = curInd; +                    } +                    else if (child.className === "multiColumnResizer") { +                        dropInd = Math.floor(index / 2); +                    } else { +                        dropInd = Math.ceil(index / 2 + (de.y - brect.y > brect.height / 2 ? 0 : -1)); +                    } +                } +            }) +            if (super.onInternalDrop(e, de)) { +                de.complete.docDragData?.droppedDocuments.forEach(action((d: Doc) => { +                    d._dimUnit = "*"; +                    d._dimMagnitude = 1; +                    if (dropInd !== curInd || dropInd === -1) { +                        if (this.childDocs.includes(d)) { +                            if (dropInd > this.childDocs.indexOf(d)) dropInd--; +                        } +                        Doc.RemoveDocFromList(this.rootDoc, this.props.fieldKey, d); +                        Doc.AddDocToList(this.rootDoc, this.props.fieldKey, d, DocListCast(this.rootDoc[this.props.fieldKey])[dropInd], undefined, dropInd === -1); +                    } +                })); +            }          }          return false;      } @@ -213,6 +241,7 @@ export class CollectionMultirowView extends CollectionSubView() {          }          return this.props.addDocTab(doc, where);      } +    isContentActive = () => this.props.isSelected() || this.props.isContentActive();      getDisplayDoc(layout: Doc, dxf: () => Transform, width: () => number, height: () => number) {          return <DocumentView              Document={layout} @@ -230,6 +259,7 @@ export class CollectionMultirowView extends CollectionSubView() {              onClick={this.onChildClickHandler}              onDoubleClick={this.onChildDoubleClickHandler}              ScreenToLocalTransform={dxf} +            isDocumentActive={this.props.childDocumentsActive ? this.props.isDocumentActive : this.isContentActive}              focus={this.props.focus}              docFilters={this.childDocFilters}              isContentActive={emptyFunction} | 
