diff options
| author | bobzel <zzzman@gmail.com> | 2021-09-02 12:41:27 -0400 | 
|---|---|---|
| committer | bobzel <zzzman@gmail.com> | 2021-09-02 12:41:27 -0400 | 
| commit | 04920f5deac0449524693a738cea45394be3d0fa (patch) | |
| tree | 4d95843d2f0e445f1379e001203edcc1b0bc1d6f | |
| parent | 8cb650d9fb542465525c198c1f93f6aba7256e0b (diff) | |
fixes for making overlay ink stroke in doc decorations align with selected stroke.
| -rw-r--r-- | src/client/views/DocumentDecorations.scss | 5 | ||||
| -rw-r--r-- | src/client/views/DocumentDecorations.tsx | 22 | 
2 files changed, 21 insertions, 6 deletions
| diff --git a/src/client/views/DocumentDecorations.scss b/src/client/views/DocumentDecorations.scss index 316f63240..9479fd365 100644 --- a/src/client/views/DocumentDecorations.scss +++ b/src/client/views/DocumentDecorations.scss @@ -6,7 +6,12 @@ $linkGap : 3px;      position: absolute;      z-index: 2000;  } +.documentDecorations-inkstroke { +  svg:not(:root) { +    overflow: visible !important; +  } +}  .documentDecorations-container {      z-index: $docDecorations-zindex;      position: absolute; diff --git a/src/client/views/DocumentDecorations.tsx b/src/client/views/DocumentDecorations.tsx index 244d14f3a..db3ec79a1 100644 --- a/src/client/views/DocumentDecorations.tsx +++ b/src/client/views/DocumentDecorations.tsx @@ -393,10 +393,10 @@ export class DocumentDecorations extends React.Component<{ PanelWidth: number, P          this._inkDragDocs.map(oldbds => ({ oldbds, inkPts: Cast(oldbds.doc.data, InkField)?.inkData || [] }))              .forEach(({ oldbds: { doc, x, y, width, height }, inkPts }) => {                  Doc.GetProto(doc).data = new InkField(inkPts.map(ipt =>  // (new x — oldx) + newWidth * (oldxpoint /oldWidth) -                ({ -                    X: (NumCast(doc.x) - x) + NumCast(doc.width) * ipt.X / width, -                    Y: (NumCast(doc.y) - y) + NumCast(doc.height) * ipt.Y / height -                }))); +                    ({ +                        X: (NumCast(doc.x) - x) + NumCast(doc.width) * ipt.X / width, +                        Y: (NumCast(doc.y) - y) + NumCast(doc.height) * ipt.Y / height +                    })));                  Doc.SetNativeWidth(doc, undefined);                  Doc.SetNativeHeight(doc, undefined);              }); @@ -480,7 +480,7 @@ export class DocumentDecorations extends React.Component<{ PanelWidth: number, P              const scaleX = width === strokeWidth ? 1 : (this.props.PanelWidth - strokeWidth) / (width - strokeWidth);              const scaleY = height === strokeWidth ? 1 : (this.props.PanelHeight - strokeWidth) / (height - strokeWidth); -            selectedLine = InteractionUtils.CreatePolyline(inkData, left, top, Colors.MEDIUM_BLUE, 4, 4, StrCast(inkDoc.strokeBezier), StrCast(inkDoc.fillColor, "none"), +            selectedLine = InteractionUtils.CreatePolyline(inkData, left, top, Colors.MEDIUM_BLUE, strokeWidth, strokeWidth, StrCast(inkDoc.strokeBezier), StrCast(inkDoc.fillColor, "none"),                  StrCast(inkDoc.strokeStartMarker), StrCast(inkDoc.strokeEndMarker), StrCast(inkDoc.strokeDash), 1, 1, "", "none", 1.0, false);          } @@ -502,7 +502,6 @@ export class DocumentDecorations extends React.Component<{ PanelWidth: number, P                  }}>                      {!canDelete ? <div /> : topBtn("close", "times", undefined, this.onCloseClick, "Close")}                      {seldoc.props.hideDecorationTitle || seldoc.props.Document.type === DocumentType.EQUATION ? (null) : titleArea} -                    {selectedLine}                      {seldoc.props.hideResizeHandles || seldoc.props.Document.type === DocumentType.EQUATION ? (null) :                          <>                              {SelectionManager.Views().length !== 1 || seldoc.Document.type === DocumentType.INK ? (null) : @@ -525,6 +524,17 @@ export class DocumentDecorations extends React.Component<{ PanelWidth: number, P                          </>                      }                  </div > +                <div className="documentDecorations-inkstroke" style={{ +                    position: "absolute", +                    width: (bounds.r - bounds.x + this._resizeBorderWidth) + "px", +                    height: (bounds.b - bounds.y + this._resizeBorderWidth) + "px", +                    left: bounds.x, +                    top: bounds.y, +                    overflow: "visible", +                    pointerEvents: "none", +                }} > +                    {selectedLine} +                </div>                  {seldoc?.Document.type === DocumentType.FONTICON ? (null) : <div className="link-button-container" key="links" style={{ left: bounds.x - this._resizeBorderWidth / 2 + 10, top: bounds.b + this._resizeBorderWidth / 2 }}>                      <DocumentButtonBar views={SelectionManager.Views} />                  </div>} | 
