diff options
Diffstat (limited to 'src/client/views/nodes/DocumentLinksButton.tsx')
| -rw-r--r-- | src/client/views/nodes/DocumentLinksButton.tsx | 142 | 
1 files changed, 74 insertions, 68 deletions
| diff --git a/src/client/views/nodes/DocumentLinksButton.tsx b/src/client/views/nodes/DocumentLinksButton.tsx index aa3f10188..b63174e54 100644 --- a/src/client/views/nodes/DocumentLinksButton.tsx +++ b/src/client/views/nodes/DocumentLinksButton.tsx @@ -20,6 +20,7 @@ import './DocumentLinksButton.scss';  import { DocServer } from "../../DocServer";  import { LightboxView } from "../LightboxView";  import { cat } from "shelljs"; +import { Colors } from "../global/globalEnums";  const higflyout = require("@hig/flyout");  export const { anchorPoints } = higflyout; @@ -67,6 +68,40 @@ export class DocumentLinksButton extends React.Component<DocumentLinksButtonProp          return false;      } +    onLinkMenuOpen = (e: React.PointerEvent): void => { +        setupMoveUpEvents(this, e, this.onLinkButtonMoved, emptyFunction, action((e, doubleTap) => { +            if (doubleTap) { +                const rootDoc = this.props.View.rootDoc; +                const docid = Doc.CurrentUserEmail + Doc.GetProto(rootDoc)[Id] + "-pivotish"; +                DocServer.GetRefField(docid).then(async docx => { +                    const rootAlias = () => { +                        const rootAlias = Doc.MakeAlias(rootDoc); +                        rootAlias.x = rootAlias.y = 0; +                        return rootAlias; +                    }; +                    let wid = rootDoc[WidthSym](); +                    const target = ((docx instanceof Doc) && docx) || Docs.Create.FreeformDocument([rootAlias()], { title: this.props.View.Document.title + "-pivot", _width: 500, _height: 500, }, docid); +                    const docs = await DocListCastAsync(Doc.GetProto(target).data); +                    if (!target.pivotFocusish) (Doc.GetProto(target).pivotFocusish = target); +                    DocListCast(rootDoc.links).forEach(link => { +                        const other = LinkManager.getOppositeAnchor(link, rootDoc); +                        const otherdoc = !other ? undefined : other.annotationOn ? Cast(other.annotationOn, Doc, null) : other; +                        if (otherdoc && !docs?.some(d => Doc.AreProtosEqual(d, otherdoc))) { +                            const alias = Doc.MakeAlias(otherdoc); +                            alias.x = wid; +                            alias.y = 0; +                            alias._lockedPosition = false; +                            wid += otherdoc[WidthSym](); +                            Doc.AddDocToList(Doc.GetProto(target), "data", alias); +                        } +                    }); +                    LightboxView.SetLightboxDoc(target); +                }); +            } +            else DocumentLinksButton.LinkEditorDocView = this.props.View; +        })); +    } +      @undoBatch      onLinkButtonDown = (e: React.PointerEvent): void => {          setupMoveUpEvents(this, e, this.onLinkButtonMoved, emptyFunction, action((e, doubleTap) => { @@ -79,37 +114,7 @@ export class DocumentLinksButton extends React.Component<DocumentLinksButtonProp                      DocumentLinksButton.StartLink = this.props.View.props.Document;                      DocumentLinksButton.StartLinkView = this.props.View;                  } -            } else if (!this.props.InMenu) { -                if (doubleTap) { -                    const rootDoc = this.props.View.rootDoc; -                    const docid = Doc.CurrentUserEmail + Doc.GetProto(rootDoc)[Id] + "-pivotish"; -                    DocServer.GetRefField(docid).then(async docx => { -                        const rootAlias = () => { -                            const rootAlias = Doc.MakeAlias(rootDoc); -                            rootAlias.x = rootAlias.y = 0; -                            return rootAlias; -                        }; -                        let wid = rootDoc[WidthSym](); -                        const target = ((docx instanceof Doc) && docx) || Docs.Create.FreeformDocument([rootAlias()], { title: this.props.View.Document.title + "-pivot", _width: 500, _height: 500, }, docid); -                        const docs = await DocListCastAsync(Doc.GetProto(target).data); -                        if (!target.pivotFocusish) (Doc.GetProto(target).pivotFocusish = target); -                        DocListCast(rootDoc.links).forEach(link => { -                            const other = LinkManager.getOppositeAnchor(link, rootDoc); -                            const otherdoc = !other ? undefined : other.annotationOn ? Cast(other.annotationOn, Doc, null) : other; -                            if (otherdoc && !docs?.some(d => Doc.AreProtosEqual(d, otherdoc))) { -                                const alias = Doc.MakeAlias(otherdoc); -                                alias.x = wid; -                                alias.y = 0; -                                alias._lockedPosition = false; -                                wid += otherdoc[WidthSym](); -                                Doc.AddDocToList(Doc.GetProto(target), "data", alias); -                            } -                        }); -                        LightboxView.SetLightboxDoc(target); -                    }); -                } -                else DocumentLinksButton.LinkEditorDocView = this.props.View; -            } +            };          }));      } @@ -125,7 +130,6 @@ export class DocumentLinksButton extends React.Component<DocumentLinksButtonProp                  DocumentLinksButton.StartLink = this.props.View.props.Document;                  DocumentLinksButton.StartLinkView = this.props.View;              } -              //action(() => Doc.BrushDoc(this.props.View.Document));          } else if (!this.props.InMenu) {              DocumentLinksButton.LinkEditorDocView = this.props.View; @@ -246,46 +250,48 @@ export class DocumentLinksButton extends React.Component<DocumentLinksButtonProp      /**       * gets the JSX of the link button (btn used to start/complete links) OR the link-view button (btn on bottom left of each linked node) +     *  +     * todo:glr / anh seperate functionality such as onClick onPointerDown of link menu button       */      @computed get linkButtonInner() { -        const btnDim = this.props.InMenu ? "20px" : "30px"; +        const btnDim = "30px";          const link = <img style={{ width: "22px", height: "16px" }} src={`/assets/${"link.png"}`} />; - -        return <div className="documentLinksButton-cont" ref={this._linkButton} -            style={{ left: this.props.Offset?.[0], top: this.props.Offset?.[1], right: this.props.Offset?.[2], bottom: this.props.Offset?.[3] }} -        > -            <div className={"documentLinksButton"} -                onPointerDown={this.onLinkButtonDown} onClick={this.onLinkClick} -                style={{ -                    backgroundColor: this.props.InMenu ? "" : '#BDDDF5', -                    color: this.props.InMenu ? "white" : "black", -                    width: btnDim, -                    height: btnDim, -                }} > -                {this.props.InMenu ? -                    this.props.StartLink ? -                        <FontAwesomeIcon className="documentdecorations-icon" icon="link" size="sm" /> -                        : link -                    : Array.from(this.filteredLinks).length} -            </div> -            {this.props.InMenu && !this.props.StartLink && DocumentLinksButton.StartLink !== this.props.View.props.Document ? //if the origin node is not this node -                <div className={"documentLinksButton-endLink"} +        const isActive = (DocumentLinksButton.StartLink === this.props.View.props.Document) && this.props.StartLink; +        return (!this.props.InMenu ? +            <div className="documentLinksButton-cont" +                style={{ left: this.props.Offset?.[0], top: this.props.Offset?.[1], right: this.props.Offset?.[2], bottom: this.props.Offset?.[3] }} +            > +                <div className={"documentLinksButton"} +                    onPointerDown={this.onLinkMenuOpen} onClick={this.onLinkClick}                      style={{ -                        width: btnDim, height: btnDim, -                        backgroundColor: DocumentLinksButton.StartLink ? "" : "grey", -                        opacity: DocumentLinksButton.StartLink ? "" : "50%", -                        border: DocumentLinksButton.StartLink ? "" : "none", -                        cursor: DocumentLinksButton.StartLink ? "pointer" : "default" -                    }} -                    onPointerDown={DocumentLinksButton.StartLink && this.completeLink} -                    onClick={e => DocumentLinksButton.StartLink && DocumentLinksButton.finishLinkClick(e.clientX, e.clientY, DocumentLinksButton.StartLink, this.props.View.props.Document, true, this.props.View)} /> -                : (null) -            } -            {DocumentLinksButton.StartLink === this.props.View.props.Document && this.props.InMenu && this.props.StartLink ? //if link has been started from current node, then set behavior of link button to deactivate linking when clicked again -                <div className={"documentLinksButton-startLink"} onPointerDown={this.clearLinks} onClick={this.clearLinks} style={{ width: btnDim, height: btnDim }} /> -                : (null) -            } -        </div >; +                        backgroundColor: Colors.LIGHT_BLUE, +                        color: Colors.BLACK, +                        width: btnDim, +                        height: btnDim, +                    }}> +                    {Array.from(this.filteredLinks).length} +                </div> +            </div> +            : +            <div className="documentLinksButton-menu" ref={this._linkButton}> +                {this.props.InMenu && !this.props.StartLink && DocumentLinksButton.StartLink !== this.props.View.props.Document ? //if the origin node is not this node +                    <div className={"documentLinksButton-endLink"} +                        onPointerDown={DocumentLinksButton.StartLink && this.completeLink} +                        onClick={e => DocumentLinksButton.StartLink && DocumentLinksButton.finishLinkClick(e.clientX, e.clientY, DocumentLinksButton.StartLink, this.props.View.props.Document, true, this.props.View)}> +                        <FontAwesomeIcon className="documentdecorations-icon" icon="link" /> +                    </div> +                    : (null) +                } +                { +                    this.props.InMenu && this.props.StartLink ? //if link has been started from current node, then set behavior of link button to deactivate linking when clicked again +                        <div className={`documentLinksButton ${isActive ? `startLink` : ``}`} onPointerDown={isActive ? undefined : this.onLinkButtonDown} onClick={isActive ? this.clearLinks : this.onLinkClick}> +                            <FontAwesomeIcon className="documentdecorations-icon" icon="link" /> +                        </div> +                        : +                        (null) +                } +            </div> +        )      }      render() { | 
