diff options
| author | bobzel <zzzman@gmail.com> | 2020-11-30 10:59:52 -0500 | 
|---|---|---|
| committer | bobzel <zzzman@gmail.com> | 2020-11-30 10:59:52 -0500 | 
| commit | 228ea98b69e848dddf835debb2acf77bbd7ddfbb (patch) | |
| tree | 62e2d3054ab565bc91997db7875d4022e1751564 /src/client/views/collections/collectionFreeForm/CollectionFreeFormLinkView.tsx | |
| parent | aae3fe10d4f996dfc811977ce457ae33d5fe3bcc (diff) | |
| parent | 5da87a5d161446308031dd4b221f1f7e3a127e72 (diff) | |
Merge branch 'master' into sally-changes
Diffstat (limited to 'src/client/views/collections/collectionFreeForm/CollectionFreeFormLinkView.tsx')
| -rw-r--r-- | src/client/views/collections/collectionFreeForm/CollectionFreeFormLinkView.tsx | 15 | 
1 files changed, 10 insertions, 5 deletions
| diff --git a/src/client/views/collections/collectionFreeForm/CollectionFreeFormLinkView.tsx b/src/client/views/collections/collectionFreeForm/CollectionFreeFormLinkView.tsx index 4cf257640..c81bd068c 100644 --- a/src/client/views/collections/collectionFreeForm/CollectionFreeFormLinkView.tsx +++ b/src/client/views/collections/collectionFreeForm/CollectionFreeFormLinkView.tsx @@ -40,6 +40,7 @@ export class CollectionFreeFormLinkView extends React.Component<CollectionFreeFo          if (SnappingManager.GetIsDragging() || !A.ContentDiv || !B.ContentDiv) return;          setTimeout(action(() => this._opacity = 1), 0); // since the render code depends on querying the Dom through getBoudndingClientRect, we need to delay triggering render()          setTimeout(action(() => (!LinkDocs.length || !linkDoc.linkDisplay) && (this._opacity = 0.05)), 750); // this will unhighlight the link line. +        if (!linkDoc.linkAutoMove) return;          const acont = A.props.Document.type === DocumentType.LINK ? A.ContentDiv.getElementsByClassName("linkAnchorBox-cont") : [];          const bcont = B.props.Document.type === DocumentType.LINK ? B.ContentDiv.getElementsByClassName("linkAnchorBox-cont") : [];          const adiv = (acont.length ? acont[0] : A.ContentDiv); @@ -60,6 +61,7 @@ export class CollectionFreeFormLinkView extends React.Component<CollectionFreeFo          const linkEles = Array.from(window.document.getElementsByClassName(linkDoc[Id]));          const targetAhyperlink = linkEles.find((ele: any) => ele.dataset.targetids?.includes((linkDoc[afield] as Doc)[Id]));          const targetBhyperlink = linkEles.find((ele: any) => ele.dataset.targetids?.includes((linkDoc[bfield] as Doc)[Id])); +        if ((!targetAhyperlink && !a.width) || (!targetBhyperlink && !b.width)) return;          if (!targetBhyperlink) {              A.rootDoc[afield + "_x"] = (apt.point.x - aleft) / awidth * 100;              A.rootDoc[afield + "_y"] = (apt.point.y - atop) / aheight * 100; @@ -101,8 +103,8 @@ export class CollectionFreeFormLinkView extends React.Component<CollectionFreeFo          const top = rect.top, height = rect.height;          var el = el.parentNode;          while (el && el !== document.body) { -            if (el.hasOwnProperty("getBoundingClientRect")) { -                rect = el.getBoundingClientRect(); +            rect = el?.getBoundingClientRect(); +            if (rect?.width) {                  if (top <= rect.bottom === false && getComputedStyle(el).overflow === "hidden") return rect.bottom;                  // Check if the element is out of view due to a container scrolling                  if ((top + height) <= rect.top && getComputedStyle(el).overflow === "hidden") return rect.top; @@ -117,8 +119,8 @@ export class CollectionFreeFormLinkView extends React.Component<CollectionFreeFo          const left = rect.left, width = rect.width;          var el = el.parentNode;          while (el && el !== document.body) { -            if (el.hasOwnProperty("getBoundingClientRect")) { -                rect = el.getBoundingClientRect(); +            rect = el?.getBoundingClientRect(); +            if (rect?.width) {                  if (left <= rect.right === false && getComputedStyle(el).overflow === "hidden") return rect.right;                  // Check if the element is out of view due to a container scrolling                  if ((left + width) <= rect.left && getComputedStyle(el).overflow === "hidden") return rect.left; @@ -138,11 +140,14 @@ export class CollectionFreeFormLinkView extends React.Component<CollectionFreeFo          const adiv = (acont.length ? acont[0] : A.ContentDiv);          const bdiv = (bcont.length ? bcont[0] : B.ContentDiv);          for (let apdiv = adiv; apdiv; apdiv = apdiv.parentElement as any) if ((apdiv as any).hidden) return; -        for (let apdiv = bdiv; apdiv; apdiv = apdiv.parentElement as any) if ((apdiv as any).hidden) return; +        for (let bpdiv = bdiv; bpdiv; bpdiv = bpdiv.parentElement as any) if ((bpdiv as any).hidden) return;          const a = adiv.getBoundingClientRect();          const b = bdiv.getBoundingClientRect();          const atop = this.visibleY(adiv);          const btop = this.visibleY(bdiv); +        if (!a.width || !b.width) return undefined; +        const atop2 = this.visibleY(adiv); +        const btop2 = this.visibleY(bdiv);          const aleft = this.visibleX(adiv);          const bleft = this.visibleX(bdiv);          const clipped = aleft !== a.left || atop !== a.top || bleft !== b.left || btop !== b.top; | 
