diff options
Diffstat (limited to 'src/client/views')
25 files changed, 138 insertions, 128 deletions
| diff --git a/src/client/views/DocumentButtonBar.tsx b/src/client/views/DocumentButtonBar.tsx index dc6311696..96f5d78fd 100644 --- a/src/client/views/DocumentButtonBar.tsx +++ b/src/client/views/DocumentButtonBar.tsx @@ -187,7 +187,7 @@ export class DocumentButtonBar extends React.Component<{ views: () => (DocumentV      get pinButton() {          const targetDoc = this.view0?.props.Document;          const isPinned = targetDoc && Doc.isDocPinned(targetDoc); -        return !targetDoc ? (null) : <Tooltip title={<><div className="dash-tooltip">{SelectionManager.SelectedDocuments().length > 1 ? "Pin multiple documents to presentation" : "Pin to presentation"}</div></>}> +        return !targetDoc ? (null) : <Tooltip title={<><div className="dash-tooltip">{SelectionManager.Views().length > 1 ? "Pin multiple documents to presentation" : "Pin to presentation"}</div></>}>              <div className="documentButtonBar-linker"                  style={{ color: "white" }}                  onClick={undoBatch(e => this.props.views().map(view => view && TabDocView.PinDoc(view.props.Document, false)))}> @@ -336,7 +336,7 @@ export class DocumentButtonBar extends React.Component<{ views: () => (DocumentV      }      openContextMenu = (e: React.MouseEvent) => { -        let child = SelectionManager.SelectedDocuments()[0].ContentDiv!.children[0]; +        let child = SelectionManager.Views()[0].ContentDiv!.children[0];          while (child.children.length) {              const next = Array.from(child.children).find(c => typeof (c.className) === "string");              if (next?.className.includes(DocumentView.ROOT_DIV)) break; diff --git a/src/client/views/DocumentDecorations.tsx b/src/client/views/DocumentDecorations.tsx index 1d0c5dac0..eed77b398 100644 --- a/src/client/views/DocumentDecorations.tsx +++ b/src/client/views/DocumentDecorations.tsx @@ -57,12 +57,12 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b      constructor(props: any) {          super(props);          DocumentDecorations.Instance = this; -        reaction(() => SelectionManager.SelectedDocuments().slice(), docs => this.titleBlur(false)); +        reaction(() => SelectionManager.Views().slice(), docs => this.titleBlur(false));      }      @computed      get Bounds(): { x: number, y: number, b: number, r: number } { -        return SelectionManager.SelectedDocuments().map(dv => dv.getBounds()).reduce((bounds, rect) => +        return SelectionManager.Views().map(dv => dv.getBounds()).reduce((bounds, rect) =>              !rect ? bounds :                  {                      x: Math.min(rect.left, bounds.x), @@ -80,8 +80,8 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b                  this._titleControlString = this._accumulatedTitle;              } else if (this._titleControlString.startsWith("#")) {                  const selectionTitleFieldKey = this._titleControlString.substring(1); -                selectionTitleFieldKey === "title" && (SelectionManager.SelectedDocuments()[0].dataDoc["title-custom"] = !this._accumulatedTitle.startsWith("-")); -                UndoManager.RunInBatch(() => selectionTitleFieldKey && SelectionManager.SelectedDocuments().forEach(d => { +                selectionTitleFieldKey === "title" && (SelectionManager.Views()[0].dataDoc["title-custom"] = !this._accumulatedTitle.startsWith("-")); +                UndoManager.RunInBatch(() => selectionTitleFieldKey && SelectionManager.Views().forEach(d => {                      const value = typeof d.props.Document[selectionTitleFieldKey] === "number" ? +this._accumulatedTitle : this._accumulatedTitle;                      Doc.SetInPlace(d.props.Document, selectionTitleFieldKey, value, true);                  }), "title blur"); @@ -96,7 +96,7 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b              const text = e.target.value;              if (text.startsWith("::")) {                  this._accumulatedTitle = text.slice(2, text.length); -                const promoteDoc = SelectionManager.SelectedDocuments()[0]; +                const promoteDoc = SelectionManager.Views()[0];                  Doc.SetInPlace(promoteDoc.props.Document, "title", this._accumulatedTitle, true);                  DocUtils.Publish(promoteDoc.props.Document, this._accumulatedTitle, promoteDoc.props.addDocument, promoteDoc.props.removeDocument);              } @@ -118,8 +118,8 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b      @action      onBackgroundMove = (dragTitle: boolean, e: PointerEvent): boolean => { -        const dragDocView = SelectionManager.SelectedDocuments()[0]; -        const dragData = new DragManager.DocumentDragData(SelectionManager.SelectedDocuments().map(dv => dv.props.Document)); +        const dragDocView = SelectionManager.Views()[0]; +        const dragData = new DragManager.DocumentDragData(SelectionManager.Views().map(dv => dv.props.Document));          const { left, top } = dragDocView.getBounds() || { left: 0, top: 0 };          dragData.offset = dragDocView.props.ScreenToLocalTransform().scale(dragDocView.ContentScale()).transformDirection(e.x - left, e.y - top);          dragData.moveDocument = dragDocView.props.moveDocument; @@ -128,7 +128,7 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b          dragData.dropAction = dragDocView.props.dropAction;          this.Interacting = true;          this._hidden = true; -        DragManager.StartDocumentDrag(SelectionManager.SelectedDocuments().map(dv => dv.ContentDiv!), dragData, e.x, e.y, { +        DragManager.StartDocumentDrag(SelectionManager.Views().map(dv => dv.ContentDiv!), dragData, e.x, e.y, {              dragComplete: action(e => {                  dragData.canEmbed && SelectionManager.DeselectAll();                  this._hidden = this.Interacting = false; @@ -145,7 +145,7 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b      @action      onCloseClick = async (e: React.MouseEvent | undefined) => {          if (!e?.button) { -            const selected = SelectionManager.SelectedDocuments().slice(); +            const selected = SelectionManager.Views().slice();              SelectionManager.DeselectAll();              selected.map(dv => dv.props.removeDocument?.(dv.props.Document));          } @@ -158,7 +158,7 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b      @action      onMaximizeClick = (e: PointerEvent): void => {          if (e.button === 0) { -            const selectedDocs = SelectionManager.SelectedDocuments(); +            const selectedDocs = SelectionManager.Views();              if (selectedDocs.length) {                  if (e.ctrlKey) {    // open an alias in a new tab with Ctrl Key                      selectedDocs[0].props.Document._fullScreenView = Doc.MakeAlias(selectedDocs[0].props.Document); @@ -181,7 +181,7 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b      @action      onIconifyClick = (e: PointerEvent): void => {          if (e.button === 0) { -            SelectionManager.SelectedDocuments().forEach(dv => dv?.iconify()); +            SelectionManager.Views().forEach(dv => dv?.iconify());          }          SelectionManager.DeselectAll();      } @@ -189,7 +189,7 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b      @action      onSelectorUp = (e: React.PointerEvent): void => {          setupMoveUpEvents(this, e, returnFalse, emptyFunction, action((e) => { -            const selDoc = SelectionManager.SelectedDocuments()?.[0]; +            const selDoc = SelectionManager.Views()?.[0];              if (selDoc) {                  selDoc.props.ContainingCollectionView?.props.select(false);              } @@ -207,7 +207,7 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b      onRadiusMove = (e: PointerEvent, down: number[]): boolean => {          let dist = Math.sqrt((e.clientX - down[0]) * (e.clientX - down[0]) + (e.clientY - down[1]) * (e.clientY - down[1]));          dist = dist < 3 ? 0 : dist; -        SelectionManager.SelectedDocuments().map(dv => dv.props.Document).map(doc => doc.layout instanceof Doc ? doc.layout : doc.isTemplateForField ? doc : Doc.GetProto(doc)). +        SelectionManager.Views().map(dv => dv.props.Document).map(doc => doc.layout instanceof Doc ? doc.layout : doc.isTemplateForField ? doc : Doc.GetProto(doc)).              map(d => d.borderRounding = `${Math.max(0, dist)}px`);          return false;      } @@ -220,7 +220,7 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b          setupMoveUpEvents(this, e, this.onRotateMove, this.onRotateUp, (e) => { });          this._prevX = e.clientX;          this._prevY = e.clientY; -        SelectionManager.SelectedDocuments().forEach(action((element: DocumentView) => { +        SelectionManager.Views().forEach(action((element: DocumentView) => {              const doc = Document(element.rootDoc);              if (doc.type === DocumentType.INK && doc.x && doc.y && doc._width && doc._height && doc.data) {                  const ink = Cast(doc.data, InkField)?.inkData; @@ -257,7 +257,7 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b          this._prevX = e.clientX;          this._prevY = e.clientY;          var index = 0; -        SelectionManager.SelectedDocuments().forEach(action((element: DocumentView) => { +        SelectionManager.Views().forEach(action((element: DocumentView) => {              const doc = Document(element.rootDoc);              if (doc.type === DocumentType.INK && doc.x && doc.y && doc._width && doc._height && doc.data) {                  doc.rotation = Number(doc.rotation) + Number(angle); @@ -304,7 +304,7 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b      onPointerDown = (e: React.PointerEvent): void => {          this._inkDocs = []; -        SelectionManager.SelectedDocuments().forEach(action((element: DocumentView) => { +        SelectionManager.Views().forEach(action((element: DocumentView) => {              const doc = Document(element.rootDoc);              if (doc.type === DocumentType.INK && doc.x && doc.y && doc._width && doc._height) {                  this._inkDocs.push({ x: doc.x, y: doc.y, width: doc._width, height: doc._height }); @@ -327,18 +327,18 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b          this._snapX = e.pageX;          this._snapY = e.pageY;          this._initialAutoHeight = true; -        DragManager.docsBeingDragged = SelectionManager.SelectedDocuments().map(dv => dv.rootDoc); -        SelectionManager.SelectedDocuments().map(dv => { +        DragManager.docsBeingDragged = SelectionManager.Views().map(dv => dv.rootDoc); +        SelectionManager.Views().map(dv => {              this._dragHeights.set(dv.layoutDoc, NumCast(dv.layoutDoc._height));              dv.layoutDoc._delayAutoHeight = dv.layoutDoc._height;          });      }      onPointerMove = (e: PointerEvent, down: number[], move: number[]): boolean => { -        const first = SelectionManager.SelectedDocuments()[0]; +        const first = SelectionManager.Views()[0];          let thisPt = { thisX: e.clientX - this._offX, thisY: e.clientY - this._offY };          var fixedAspect = Doc.NativeAspect(first.layoutDoc); -        SelectionManager.SelectedDocuments().forEach(action((element: DocumentView) => { +        SelectionManager.Views().forEach(action((element: DocumentView) => {              const doc = Document(element.rootDoc);              if (doc.type === DocumentType.INK && doc._width && doc._height && InkStrokeProperties.Instance?._lock) {                  fixedAspect = Doc.NativeHeight(doc); @@ -371,7 +371,7 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b          let dragRight = false;          let dX = 0, dY = 0, dW = 0, dH = 0;          const unfreeze = () => -            SelectionManager.SelectedDocuments().forEach(action((element: DocumentView) => +            SelectionManager.Views().forEach(action((element: DocumentView) =>                  ((element.rootDoc.type === DocumentType.RTF ||                      element.rootDoc.type === DocumentType.COMPARISON ||                      (element.rootDoc.type === DocumentType.WEB && Doc.LayoutField(element.rootDoc) instanceof HtmlField)) @@ -420,7 +420,7 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b                  break;          } -        SelectionManager.SelectedDocuments().forEach(action((docView: DocumentView) => { +        SelectionManager.Views().forEach(action((docView: DocumentView) => {              if (e.ctrlKey && !Doc.NativeHeight(docView.props.Document)) docView.toggleNativeDimensions();              if (dX !== 0 || dY !== 0 || dW !== 0 || dH !== 0) {                  const doc = Document(docView.rootDoc); @@ -486,7 +486,7 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b      @action      onPointerUp = (e: PointerEvent): void => { -        SelectionManager.SelectedDocuments().map(dv => { +        SelectionManager.Views().map(dv => {              if (NumCast(dv.layoutDoc._delayAutoHeight) < this._dragHeights.get(dv.layoutDoc)!) {                  dv.nativeWidth > 0 && Doc.toggleNativeDimensions(dv.layoutDoc, dv.ContentScale(), dv.props.PanelWidth(), dv.props.PanelHeight());                  dv.layoutDoc._autoHeight = true; @@ -501,7 +501,7 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b          //need to change points for resize, or else rotation/control points will fail. -        SelectionManager.SelectedDocuments().forEach(action((element: DocumentView, index) => { +        SelectionManager.Views().forEach(action((element: DocumentView, index) => {              const doc = Document(element.rootDoc);              if (doc.type === DocumentType.INK && doc.x && doc.y && doc._height && doc._width) {                  const ink = Cast(doc.data, InkField)?.inkData; @@ -524,8 +524,8 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b      @computed      get selectionTitle(): string { -        if (SelectionManager.SelectedDocuments().length === 1) { -            const selected = SelectionManager.SelectedDocuments()[0]; +        if (SelectionManager.Views().length === 1) { +            const selected = SelectionManager.Views()[0];              if (this._titleControlString.startsWith("=")) {                  return ScriptField.MakeFunction(this._titleControlString.substring(1), { doc: Doc.name })!.script.run({ self: selected.rootDoc, this: selected.layoutDoc }, console.log).result?.toString() || "";              } @@ -533,7 +533,7 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b                  return Field.toString(selected.props.Document[this._titleControlString.substring(1)] as Field) || "-unset-";              }              return this._accumulatedTitle; -        } else if (SelectionManager.SelectedDocuments().length > 1) { +        } else if (SelectionManager.Views().length > 1) {              return "-multiple-";          }          return "-unset-"; @@ -558,16 +558,16 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b      render() {          const darkScheme = CurrentUserUtils.ActiveDashboard?.darkScheme ? "dimgray" : undefined;          const bounds = this.Bounds; -        const seldoc = SelectionManager.SelectedDocuments().length ? SelectionManager.SelectedDocuments()[0] : undefined; +        const seldoc = SelectionManager.Views().length ? SelectionManager.Views()[0] : undefined;          if (SnappingManager.GetIsDragging() || bounds.r - bounds.x < 1 || bounds.x === Number.MAX_VALUE || !seldoc || this._hidden || isNaN(bounds.r) || isNaN(bounds.b) || isNaN(bounds.x) || isNaN(bounds.y)) {              return (null);          } -        const canDelete = SelectionManager.SelectedDocuments().some(docView => { +        const canDelete = SelectionManager.Views().some(docView => {              const collectionAcl = docView.props.ContainingCollectionView ? GetEffectiveAcl(docView.props.ContainingCollectionDoc?.[DataSym]) : AclEdit;              const docAcl = GetEffectiveAcl(docView.props.Document);              return !docView.props.Document._stayInCollection && (collectionAcl === AclAdmin || collectionAcl === AclEdit || docAcl === AclAdmin);          }); -        const canOpen = SelectionManager.SelectedDocuments().some(docView => !docView.props.Document._stayInCollection); +        const canOpen = SelectionManager.Views().some(docView => !docView.props.Document._stayInCollection);          const closeIcon = !canDelete ? (null) : (              <Tooltip title={<div className="dash-tooltip">Close</div>} placement="top">                  <div className="documentDecorations-closeButton" onClick={this.onCloseClick}> @@ -575,7 +575,7 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b                  </div></Tooltip>);          const openIcon = !canOpen ? (null) : <Tooltip title={<div className="dash-tooltip">Open in Tab (ctrl: as alias, shift: in new collection)</div>} placement="top"><div className="documentDecorations-openInTab" onContextMenu={e => { e.preventDefault(); e.stopPropagation(); }} onPointerDown={this.onMaximizeDown}> -            {SelectionManager.SelectedDocuments().length === 1 ? <FontAwesomeIcon icon="external-link-alt" className="documentView-minimizedIcon" /> : "..."} +            {SelectionManager.Views().length === 1 ? <FontAwesomeIcon icon="external-link-alt" className="documentView-minimizedIcon" /> : "..."}          </div>          </Tooltip>; @@ -606,7 +606,7 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b                  left: bounds.x - this._resizeBorderWidth / 2,                  top: bounds.y - this._resizeBorderWidth / 2,                  pointerEvents: KeyManager.Instance.ShiftPressed || this.Interacting ? "none" : "all", -                zIndex: SelectionManager.SelectedDocuments().length > 1 ? 900 : 0, +                zIndex: SelectionManager.Views().length > 1 ? 900 : 0,              }} onPointerDown={this.onBackgroundDown} onContextMenu={e => { e.preventDefault(); e.stopPropagation(); }} >              </div>              {bounds.r - bounds.x < 15 && bounds.b - bounds.y < 15 ? (null) : <> @@ -618,7 +618,7 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b                  }}>                      {closeIcon}                      {bounds.r - bounds.x < 100 ? null : titleArea} -                    {SelectionManager.SelectedDocuments().length !== 1 || seldoc.Document.type === DocumentType.INK ? (null) : +                    {SelectionManager.Views().length !== 1 || seldoc.Document.type === DocumentType.INK ? (null) :                          <Tooltip title={<div className="dash-tooltip">{`${seldoc.finalLayoutKey.includes("icon") ? "De" : ""}Iconify Document`}</div>} placement="top">                              <div className="documentDecorations-iconifyButton" onPointerDown={this.onIconifyDown}>                                  <FontAwesomeIcon icon={seldoc.finalLayoutKey.includes("icon") ? "window-restore" : "window-minimize"} className="documentView-minimizedIcon" /> @@ -645,7 +645,7 @@ export class DocumentDecorations extends React.Component<{ boundsLeft: number, b                  </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.SelectedDocuments} /> +                    <DocumentButtonBar views={SelectionManager.Views} />                  </div>}              </>}          </div > diff --git a/src/client/views/GlobalKeyHandler.ts b/src/client/views/GlobalKeyHandler.ts index a391bb550..3311a4dcc 100644 --- a/src/client/views/GlobalKeyHandler.ts +++ b/src/client/views/GlobalKeyHandler.ts @@ -93,7 +93,7 @@ export class KeyManager {                      return { stopPropagation: false, preventDefault: false };                  } -                const ungroupings = SelectionManager.SelectedDocuments().slice(); +                const ungroupings = SelectionManager.Views().slice();                  UndoManager.RunInBatch(() => ungroupings.map(dv => dv.layoutDoc.group = undefined), "ungroup");                  SelectionManager.DeselectAll();                  break; @@ -102,7 +102,7 @@ export class KeyManager {                      return { stopPropagation: false, preventDefault: false };                  } -                const groupings = SelectionManager.SelectedDocuments().slice(); +                const groupings = SelectionManager.Views().slice();                  const randomGroup = random(0, 1000);                  UndoManager.RunInBatch(() => groupings.map(dv => dv.layoutDoc.group = randomGroup), "group");                  SelectionManager.DeselectAll(); @@ -139,14 +139,14 @@ export class KeyManager {                      return { stopPropagation: false, preventDefault: false };                  } -                const selected = SelectionManager.SelectedDocuments().slice(); +                const selected = SelectionManager.Views().slice();                  UndoManager.RunInBatch(() => selected.map(dv => !dv.props.Document._stayInCollection && dv.props.removeDocument?.(dv.props.Document)), "delete");                  SelectionManager.DeselectAll();                  break; -            case "arrowleft": UndoManager.RunInBatch(() => SelectionManager.SelectedDocuments().map(dv => dv.props.CollectionFreeFormDocumentView?.().nudge(-1, 0)), "nudge left"); break; -            case "arrowright": UndoManager.RunInBatch(() => SelectionManager.SelectedDocuments().map(dv => dv.props.CollectionFreeFormDocumentView?.().nudge?.(1, 0)), "nudge right"); break; -            case "arrowup": UndoManager.RunInBatch(() => SelectionManager.SelectedDocuments().map(dv => dv.props.CollectionFreeFormDocumentView?.().nudge?.(0, -1)), "nudge up"); break; -            case "arrowdown": UndoManager.RunInBatch(() => SelectionManager.SelectedDocuments().map(dv => dv.props.CollectionFreeFormDocumentView?.().nudge?.(0, 1)), "nudge down"); break; +            case "arrowleft": UndoManager.RunInBatch(() => SelectionManager.Views().map(dv => dv.props.CollectionFreeFormDocumentView?.().nudge(-1, 0)), "nudge left"); break; +            case "arrowright": UndoManager.RunInBatch(() => SelectionManager.Views().map(dv => dv.props.CollectionFreeFormDocumentView?.().nudge?.(1, 0)), "nudge right"); break; +            case "arrowup": UndoManager.RunInBatch(() => SelectionManager.Views().map(dv => dv.props.CollectionFreeFormDocumentView?.().nudge?.(0, -1)), "nudge up"); break; +            case "arrowdown": UndoManager.RunInBatch(() => SelectionManager.Views().map(dv => dv.props.CollectionFreeFormDocumentView?.().nudge?.(0, 1)), "nudge down"); break;          }          return { @@ -160,10 +160,10 @@ export class KeyManager {          const preventDefault = false;          switch (keyname) { -            case "arrowleft": UndoManager.RunInBatch(() => SelectionManager.SelectedDocuments().map(dv => dv.props.CollectionFreeFormDocumentView?.().nudge?.(-10, 0)), "nudge left"); break; -            case "arrowright": UndoManager.RunInBatch(() => SelectionManager.SelectedDocuments().map(dv => dv.props.CollectionFreeFormDocumentView?.().nudge?.(10, 0)), "nudge right"); break; -            case "arrowup": UndoManager.RunInBatch(() => SelectionManager.SelectedDocuments().map(dv => dv.props.CollectionFreeFormDocumentView?.().nudge?.(0, -10)), "nudge up"); break; -            case "arrowdown": UndoManager.RunInBatch(() => SelectionManager.SelectedDocuments().map(dv => dv.props.CollectionFreeFormDocumentView?.().nudge?.(0, 10)), "nudge down"); break; +            case "arrowleft": UndoManager.RunInBatch(() => SelectionManager.Views().map(dv => dv.props.CollectionFreeFormDocumentView?.().nudge?.(-10, 0)), "nudge left"); break; +            case "arrowright": UndoManager.RunInBatch(() => SelectionManager.Views().map(dv => dv.props.CollectionFreeFormDocumentView?.().nudge?.(10, 0)), "nudge right"); break; +            case "arrowup": UndoManager.RunInBatch(() => SelectionManager.Views().map(dv => dv.props.CollectionFreeFormDocumentView?.().nudge?.(0, -10)), "nudge up"); break; +            case "arrowdown": UndoManager.RunInBatch(() => SelectionManager.Views().map(dv => dv.props.CollectionFreeFormDocumentView?.().nudge?.(0, 10)), "nudge down"); break;          }          return { @@ -179,7 +179,7 @@ export class KeyManager {          switch (keyname) {              case "ƒ":              case "f": -                const dv = SelectionManager.SelectedDocuments()?.[0]; +                const dv = SelectionManager.Views()?.[0];                  UndoManager.RunInBatch(() => dv?.float(), "float");          } @@ -219,7 +219,7 @@ export class KeyManager {                  SearchBox.Instance.enter(undefined);                  break;              case "o": -                const target = SelectionManager.SelectedDocuments()[0]; +                const target = SelectionManager.Views()[0];                  target && CollectionDockingView.OpenFullScreen(target.props.Document);                  break;              case "r": @@ -246,11 +246,11 @@ export class KeyManager {                  preventDefault = false;                  break;              case "x": -                if (SelectionManager.SelectedDocuments().length) { +                if (SelectionManager.Views().length) {                      const bds = DocumentDecorations.Instance.Bounds; -                    const pt = SelectionManager.SelectedDocuments()[0].props.ScreenToLocalTransform().transformPoint(bds.x + (bds.r - bds.x) / 2, bds.y + (bds.b - bds.y) / 2); -                    const text = `__DashDocId(${pt?.[0] || 0},${pt?.[1] || 0}):` + SelectionManager.SelectedDocuments().map(dv => dv.Document[Id]).join(":"); -                    SelectionManager.SelectedDocuments().length && navigator.clipboard.writeText(text); +                    const pt = SelectionManager.Views()[0].props.ScreenToLocalTransform().transformPoint(bds.x + (bds.r - bds.x) / 2, bds.y + (bds.b - bds.y) / 2); +                    const text = `__DashDocId(${pt?.[0] || 0},${pt?.[1] || 0}):` + SelectionManager.Views().map(dv => dv.Document[Id]).join(":"); +                    SelectionManager.Views().length && navigator.clipboard.writeText(text);                      DocumentDecorations.Instance.onCloseClick(undefined);                      stopPropagation = false;                      preventDefault = false; @@ -259,9 +259,9 @@ export class KeyManager {              case "c":                  if (!PDFMenu.Instance.Active && DocumentDecorations.Instance.Bounds.r - DocumentDecorations.Instance.Bounds.x > 2) {                      const bds = DocumentDecorations.Instance.Bounds; -                    const pt = SelectionManager.SelectedDocuments()[0].props.ScreenToLocalTransform().transformPoint(bds.x + (bds.r - bds.x) / 2, bds.y + (bds.b - bds.y) / 2); -                    const text = `__DashCloneId(${pt?.[0] || 0},${pt?.[1] || 0}):` + SelectionManager.SelectedDocuments().map(dv => dv.Document[Id]).join(":"); -                    SelectionManager.SelectedDocuments().length && navigator.clipboard.writeText(text); +                    const pt = SelectionManager.Views()[0].props.ScreenToLocalTransform().transformPoint(bds.x + (bds.r - bds.x) / 2, bds.y + (bds.b - bds.y) / 2); +                    const text = `__DashCloneId(${pt?.[0] || 0},${pt?.[1] || 0}):` + SelectionManager.Views().map(dv => dv.Document[Id]).join(":"); +                    SelectionManager.Views().length && navigator.clipboard.writeText(text);                      stopPropagation = false;                  }                  preventDefault = false; @@ -278,7 +278,7 @@ export class KeyManager {          const plain = e.clipboardData?.getData("text/plain");          const clone = plain?.startsWith("__DashCloneId(");          if (plain && (plain.startsWith("__DashDocId(") || clone)) { -            const first = SelectionManager.SelectedDocuments().length ? SelectionManager.SelectedDocuments()[0] : undefined; +            const first = SelectionManager.Views().length ? SelectionManager.Views()[0] : undefined;              if (first?.props.Document.type === DocumentType.COL) {                  const docids = plain.split(":");                  let count = 1; diff --git a/src/client/views/InkStrokeProperties.ts b/src/client/views/InkStrokeProperties.ts index ad5c70fb1..2dac44bf8 100644 --- a/src/client/views/InkStrokeProperties.ts +++ b/src/client/views/InkStrokeProperties.ts @@ -25,7 +25,7 @@ export class InkStrokeProperties {      }      @computed get selectedInk() { -        const inks = SelectionManager.SelectedDocuments().filter(i => Document(i.rootDoc).type === DocumentType.INK); +        const inks = SelectionManager.Views().filter(i => Document(i.rootDoc).type === DocumentType.INK);          return inks.length ? inks : undefined;      }      @computed get unFilled() { return this.selectedInk?.reduce((p, i) => p && !i.rootDoc.fillColor ? true : false, true) || false; } @@ -150,7 +150,7 @@ export class InkStrokeProperties {      @action      rotate = (angle: number) => {          const _centerPoints: { X: number, Y: number }[] = []; -        SelectionManager.SelectedDocuments().forEach(action(inkView => { +        SelectionManager.Views().forEach(action(inkView => {              const doc = Document(inkView.rootDoc);              if (doc.type === DocumentType.INK && doc.x && doc.y && doc._width && doc._height && doc.data) {                  const ink = Cast(doc.data, InkField)?.inkData; @@ -167,7 +167,7 @@ export class InkStrokeProperties {          }));          var index = 0; -        SelectionManager.SelectedDocuments().forEach(action(inkView => { +        SelectionManager.Views().forEach(action(inkView => {              const doc = Document(inkView.rootDoc);              if (doc.type === DocumentType.INK && doc.x && doc.y && doc._width && doc._height && doc.data) {                  doc.rotation = Number(doc.rotation) + Number(angle); diff --git a/src/client/views/PropertiesButtons.tsx b/src/client/views/PropertiesButtons.tsx index 1731d715a..bc3be4076 100644 --- a/src/client/views/PropertiesButtons.tsx +++ b/src/client/views/PropertiesButtons.tsx @@ -55,8 +55,8 @@ export class PropertiesButtons extends React.Component<{}, {}> {      @computed get selectedDoc() { return SelectionManager.SelectedSchemaDoc() || this.selectedDocumentView?.rootDoc; }      @computed get selectedDocumentView() { -        if (SelectionManager.SelectedDocuments().length) { -            return SelectionManager.SelectedDocuments()[0]; +        if (SelectionManager.Views().length) { +            return SelectionManager.Views()[0];          } else return undefined;      } @@ -187,7 +187,7 @@ export class PropertiesButtons extends React.Component<{}, {}> {      @action @undoBatch      onLock = () => { -        SelectionManager.SelectedDocuments().forEach(dv => dv.docView?.toggleLockPosition()); +        SelectionManager.Views().forEach(dv => dv.docView?.toggleLockPosition());      }      @computed @@ -224,7 +224,7 @@ export class PropertiesButtons extends React.Component<{}, {}> {      @undoBatch      @action      setDictation = () => { -        SelectionManager.SelectedDocuments().forEach(dv => dv.rootDoc._showAudio = dv.rootDoc._showAudio === !dv.rootDoc._showAudio); +        SelectionManager.Views().forEach(dv => dv.rootDoc._showAudio = dv.rootDoc._showAudio === !dv.rootDoc._showAudio);      }      @computed @@ -244,7 +244,7 @@ export class PropertiesButtons extends React.Component<{}, {}> {      @undoBatch      @action      setTitle = () => { -        SelectionManager.SelectedDocuments().forEach(dv => dv.rootDoc._showTitle = dv.rootDoc._showTitle === undefined ? "title" : undefined); +        SelectionManager.Views().forEach(dv => dv.rootDoc._showTitle = dv.rootDoc._showTitle === undefined ? "title" : undefined);      }      @computed @@ -263,7 +263,7 @@ export class PropertiesButtons extends React.Component<{}, {}> {      @undoBatch      @action      setCaption = () => { -        SelectionManager.SelectedDocuments().forEach(dv => dv.rootDoc._showCaption = dv.rootDoc._showCaption === undefined ? "caption" : undefined); +        SelectionManager.Views().forEach(dv => dv.rootDoc._showCaption = dv.rootDoc._showCaption === undefined ? "caption" : undefined);      }      @computed @@ -282,7 +282,7 @@ export class PropertiesButtons extends React.Component<{}, {}> {      @undoBatch      @action      setChrome = () => { -        SelectionManager.SelectedDocuments().forEach(dv => dv.rootDoc._chromeStatus = dv.rootDoc._chromeStatus === "disabled" ? "enabled" : "disabled"); +        SelectionManager.Views().forEach(dv => dv.rootDoc._chromeStatus = dv.rootDoc._chromeStatus === "disabled" ? "enabled" : "disabled");      }      @computed @@ -325,7 +325,7 @@ export class PropertiesButtons extends React.Component<{}, {}> {          const value = e.target.value;          this.selectedDoc && (this.selectedDoc.onClickBehavior = e.target.value); -        SelectionManager.SelectedDocuments().forEach(dv => { +        SelectionManager.Views().forEach(dv => {              if (value === "nothing") {                  dv.docView?.noOnClick();              } else if (value === "enterPortal") { @@ -347,7 +347,7 @@ export class PropertiesButtons extends React.Component<{}, {}> {      @undoBatch @action      editOnClickScript = () => {          if (this.selectedDoc) { -            if (SelectionManager.SelectedDocuments().length) SelectionManager.SelectedDocuments().forEach(dv => DocUtils.makeCustomViewClicked(dv.rootDoc, undefined, "onClick")); +            if (SelectionManager.Views().length) SelectionManager.Views().forEach(dv => DocUtils.makeCustomViewClicked(dv.rootDoc, undefined, "onClick"));              else DocUtils.makeCustomViewClicked(this.selectedDoc, undefined, "onClick");          }      } @@ -432,7 +432,7 @@ export class PropertiesButtons extends React.Component<{}, {}> {      @action @undoBatch      changeFitToBox = () => {          if (this.selectedDoc) { -            if (SelectionManager.SelectedDocuments().length) SelectionManager.SelectedDocuments().forEach(dv => dv.rootDoc._fitToBox = !dv.rootDoc._fitToBox); +            if (SelectionManager.Views().length) SelectionManager.Views().forEach(dv => dv.rootDoc._fitToBox = !dv.rootDoc._fitToBox);              else this.selectedDoc._fitToBox = !this.selectedDoc._fitToBox;          }      } @@ -440,7 +440,7 @@ export class PropertiesButtons extends React.Component<{}, {}> {      @action @undoBatch      changeClusters = () => {          if (this.selectedDoc) { -            if (SelectionManager.SelectedDocuments().length) SelectionManager.SelectedDocuments().forEach(dv => dv.rootDoc._useClusters = !dv.rootDoc._useClusters); +            if (SelectionManager.Views().length) SelectionManager.Views().forEach(dv => dv.rootDoc._useClusters = !dv.rootDoc._useClusters);              else this.selectedDoc._useClusters = !this.selectedDoc._useClusters;          }      } diff --git a/src/client/views/PropertiesView.tsx b/src/client/views/PropertiesView.tsx index 1c14bc721..32342075c 100644 --- a/src/client/views/PropertiesView.tsx +++ b/src/client/views/PropertiesView.tsx @@ -48,7 +48,7 @@ export class PropertiesView extends React.Component<PropertiesViewProps> {      @computed get selectedDoc() { return SelectionManager.SelectedSchemaDoc() || this.selectedDocumentView?.rootDoc; }      @computed get selectedDocumentView() { -        if (SelectionManager.SelectedDocuments().length) return SelectionManager.SelectedDocuments()[0]; +        if (SelectionManager.Views().length) return SelectionManager.Views()[0];          if (PresBox.Instance?._selectedArray.size) return DocumentManager.Instance.getDocumentView(PresBox.Instance.rootDoc);          return undefined;      } @@ -118,8 +118,8 @@ export class PropertiesView extends React.Component<PropertiesViewProps> {      @computed get expandedField() {          if (this.dataDoc && this.selectedDoc) {              const ids: { [key: string]: string } = {}; -            const docs = SelectionManager.SelectedDocuments().length < 2 ? [this.layoutFields ? Doc.Layout(this.selectedDoc) : this.dataDoc] : -                SelectionManager.SelectedDocuments().map(dv => this.layoutFields ? Doc.Layout(dv.layoutDoc) : dv.dataDoc); +            const docs = SelectionManager.Views().length < 2 ? [this.layoutFields ? Doc.Layout(this.selectedDoc) : this.dataDoc] : +                SelectionManager.Views().map(dv => this.layoutFields ? Doc.Layout(dv.layoutDoc) : dv.dataDoc);              docs.forEach(doc => Object.keys(doc).forEach(key => !(key in ids) && doc[key] !== ComputedField.undefined && (ids[key] = key)));              const rows: JSX.Element[] = [];              for (const key of Object.keys(ids).slice().sort()) { @@ -162,7 +162,7 @@ export class PropertiesView extends React.Component<PropertiesViewProps> {      @computed get noviceFields() {          if (this.dataDoc) {              const ids: { [key: string]: string } = {}; -            const docs = SelectionManager.SelectedDocuments().length < 2 ? [this.dataDoc] : SelectionManager.SelectedDocuments().map(dv => dv.dataDoc); +            const docs = SelectionManager.Views().length < 2 ? [this.dataDoc] : SelectionManager.Views().map(dv => dv.dataDoc);              docs.forEach(doc => Object.keys(doc).forEach(key => !(key in ids) && doc[key] !== ComputedField.undefined && (ids[key] = key)));              const rows: JSX.Element[] = [];              const noviceReqFields = ["author", "creationDate", "tags"]; @@ -217,7 +217,7 @@ export class PropertiesView extends React.Component<PropertiesViewProps> {      @undoBatch      setKeyValue = (value: string) => { -        const docs = SelectionManager.SelectedDocuments().length < 2 && this.selectedDoc ? [this.layoutFields ? Doc.Layout(this.selectedDoc) : this.dataDoc] : SelectionManager.SelectedDocuments().map(dv => this.layoutFields ? dv.layoutDoc : dv.dataDoc); +        const docs = SelectionManager.Views().length < 2 && this.selectedDoc ? [this.layoutFields ? Doc.Layout(this.selectedDoc) : this.dataDoc] : SelectionManager.Views().map(dv => this.layoutFields ? dv.layoutDoc : dv.dataDoc);          docs.forEach(doc => {              if (value.indexOf(":") !== -1) {                  const newVal = value[0].toUpperCase() + value.substring(1, value.length); @@ -256,7 +256,7 @@ export class PropertiesView extends React.Component<PropertiesViewProps> {      }      @computed get layoutPreview() { -        if (SelectionManager.SelectedDocuments().length > 1) { +        if (SelectionManager.Views().length > 1) {              return "-- multiple selected --";          }          if (this.selectedDoc) { @@ -305,7 +305,7 @@ export class PropertiesView extends React.Component<PropertiesViewProps> {       */      @undoBatch      changePermissions = (e: any, user: string) => { -        const docs = SelectionManager.SelectedDocuments().length < 2 ? [this.selectedDoc!] : SelectionManager.SelectedDocuments().map(docView => docView.props.Document); +        const docs = SelectionManager.Views().length < 2 ? [this.selectedDoc!] : SelectionManager.Views().map(docView => docView.props.Document);          SharingManager.Instance.shareFromPropertiesSidebar(user, e.currentTarget.value as SharingPermissions, docs);      } @@ -385,9 +385,9 @@ export class PropertiesView extends React.Component<PropertiesViewProps> {          ]);          // all selected docs -        const docs = SelectionManager.SelectedDocuments().length < 2 ? +        const docs = SelectionManager.Views().length < 2 ?              [this.layoutDocAcls ? this.selectedDoc! : this.selectedDoc![DataSym]] -            : SelectionManager.SelectedDocuments().map(docView => this.layoutDocAcls ? docView.props.Document : docView.props.Document[DataSym]); +            : SelectionManager.Views().map(docView => this.layoutDocAcls ? docView.props.Document : docView.props.Document[DataSym]);          const target = docs[0]; @@ -438,7 +438,7 @@ export class PropertiesView extends React.Component<PropertiesViewProps> {      @computed get editableTitle() {          const titles = new Set<string>(); -        SelectionManager.SelectedDocuments().forEach(dv => titles.add(StrCast(dv.rootDoc.title))); +        SelectionManager.Views().forEach(dv => titles.add(StrCast(dv.rootDoc.title)));          const title = Array.from(titles.keys()).length > 1 ? "--multiple selected--" : StrCast(this.selectedDoc?.title);          return <div className="editable-title"><EditableView              key="editableView" @@ -452,8 +452,8 @@ export class PropertiesView extends React.Component<PropertiesViewProps> {      @undoBatch      @action      setTitle = (value: string) => { -        if (SelectionManager.SelectedDocuments().length > 1) { -            SelectionManager.SelectedDocuments().map(dv => Doc.SetInPlace(dv.rootDoc, "title", value, true)); +        if (SelectionManager.Views().length > 1) { +            SelectionManager.Views().map(dv => Doc.SetInPlace(dv.rootDoc, "title", value, true));              return true;          } else if (this.dataDoc) {              if (this.selectedDoc) Doc.SetInPlace(this.selectedDoc, "title", value, true); diff --git a/src/client/views/StyleProvider.tsx b/src/client/views/StyleProvider.tsx index d6571276a..83192164f 100644 --- a/src/client/views/StyleProvider.tsx +++ b/src/client/views/StyleProvider.tsx @@ -135,7 +135,7 @@ export function DefaultStyleProvider(doc: Opt<Doc>, props: Opt<FieldViewProps |              switch (doc?.type) {                  case DocumentType.COL:                      return StrCast(doc?.boxShadow, -                        isBackground() || doc?._isGroup ? undefined : // groups have no drop shadow -- they're supposed to be "invisible" +                        isBackground() || doc?._isGroup || docProps?.LayoutTemplateString ? undefined : // groups have no drop shadow -- they're supposed to be "invisible".  LayoutString's imply collection is being rendered as something else (e.g., title of a Slide)                              `${darkScheme() ? "rgb(30, 32, 31) " : "#9c9396 "} ${StrCast(doc.boxShadow, "0.2vw 0.2vw 0.8vw")}`);                  default:                      return doc.z ? `#9c9396  ${StrCast(doc?.boxShadow, "10px 10px 0.9vw")}` :  // if it's a floating doc, give it a big shadow diff --git a/src/client/views/collections/CollectionMenu.tsx b/src/client/views/collections/CollectionMenu.tsx index 20b4fa2d7..3839dff8b 100644 --- a/src/client/views/collections/CollectionMenu.tsx +++ b/src/client/views/collections/CollectionMenu.tsx @@ -52,7 +52,7 @@ export class CollectionMenu extends AntimodeMenu<AntimodeMenuProps> {      }      componentDidMount() { -        reaction(() => SelectionManager.SelectedDocuments().length && SelectionManager.SelectedDocuments()[0], +        reaction(() => SelectionManager.Views().length && SelectionManager.Views()[0],              (doc) => doc && this.SetSelection(doc));      } @@ -372,7 +372,7 @@ export class CollectionViewBaseChrome extends React.Component<CollectionMenuProp      }      @computed get selectedDocumentView() { -        return SelectionManager.SelectedDocuments().length ? SelectionManager.SelectedDocuments()[0] : undefined; +        return SelectionManager.Views().length ? SelectionManager.Views()[0] : undefined;      }      @computed get selectedDoc() { return this.selectedDocumentView?.rootDoc; }      @computed get notACollection() { @@ -554,7 +554,7 @@ export class CollectionFreeFormViewChrome extends React.Component<CollectionMenu      }      @computed get selectedDocumentView() { -        return SelectionManager.SelectedDocuments().length ? SelectionManager.SelectedDocuments()[0] : undefined; +        return SelectionManager.Views().length ? SelectionManager.Views()[0] : undefined;      }      @computed get selectedDoc() { return this.selectedDocumentView?.rootDoc; }      @computed get isText() { @@ -621,7 +621,7 @@ export class CollectionFreeFormViewChrome extends React.Component<CollectionMenu      @action      editProperties = (value: any, field: string) => { -        SelectionManager.SelectedDocuments().forEach(action((element: DocumentView) => { +        SelectionManager.Views().forEach(action((element: DocumentView) => {              const doc = Document(element.rootDoc);              if (doc.type === DocumentType.INK) {                  switch (field) { diff --git a/src/client/views/collections/CollectionSchemaView.tsx b/src/client/views/collections/CollectionSchemaView.tsx index f153f1cca..c39f8b255 100644 --- a/src/client/views/collections/CollectionSchemaView.tsx +++ b/src/client/views/collections/CollectionSchemaView.tsx @@ -352,7 +352,7 @@ export class CollectionSchemaView extends CollectionSubView(doc => doc) {      @action setFocused = (doc: Doc) => this._focusedTable = doc;      @action setPreviewDoc = (doc: Opt<Doc>) => { -        SelectionManager.SelectSchemaDoc(this, doc); +        SelectionManager.SelectSchemaView(this, doc);          this._previewDoc = doc;      } diff --git a/src/client/views/collections/CollectionSubView.tsx b/src/client/views/collections/CollectionSubView.tsx index 38e461e46..d7b9d9745 100644 --- a/src/client/views/collections/CollectionSubView.tsx +++ b/src/client/views/collections/CollectionSubView.tsx @@ -305,8 +305,8 @@ export function CollectionSubView<T, X>(schemaCtor: (doc: Doc) => T, moreProps?:                          } else {                              let srcUrl: string | undefined;                              let srcWeb: Doc | undefined; -                            if (SelectionManager.SelectedDocuments().length) { -                                srcWeb = SelectionManager.SelectedDocuments()[0].props.Document; +                            if (SelectionManager.Views().length) { +                                srcWeb = SelectionManager.Views()[0].props.Document;                                  srcUrl = (srcWeb.data as WebField).url?.href?.match(/http[s]?:\/\/[^/]*/)?.[0];                              }                              const reg = new RegExp(Utils.prepend(""), "g"); @@ -315,7 +315,7 @@ export function CollectionSubView<T, X>(schemaCtor: (doc: Doc) => T, moreProps?:                              Doc.GetProto(htmlDoc)["data-text"] = Doc.GetProto(htmlDoc).text = text;                              this.addDocument(htmlDoc);                              if (srcWeb) { -                                const iframe = SelectionManager.SelectedDocuments()[0].ContentDiv?.getElementsByTagName("iframe")?.[0]; +                                const iframe = SelectionManager.Views()[0].ContentDiv?.getElementsByTagName("iframe")?.[0];                                  const focusNode = (iframe?.contentDocument?.getSelection()?.focusNode as any);                                  if (focusNode) {                                      const rects = iframe?.contentWindow?.getSelection()?.getRangeAt(0).getClientRects(); diff --git a/src/client/views/collections/CollectionTreeView.scss b/src/client/views/collections/CollectionTreeView.scss index f774af74f..72ab51784 100644 --- a/src/client/views/collections/CollectionTreeView.scss +++ b/src/client/views/collections/CollectionTreeView.scss @@ -21,7 +21,7 @@      ul {          list-style: none; -        padding-left: 20px; +        padding-left: $TREE_BULLET_WIDTH;          margin-bottom: 1px; // otherwise vertical scrollbars may pop up for no apparent reason....          > .contentFittingDocumentView  {              width: unset; diff --git a/src/client/views/collections/CollectionTreeView.tsx b/src/client/views/collections/CollectionTreeView.tsx index a90edc2c9..344a6c103 100644 --- a/src/client/views/collections/CollectionTreeView.tsx +++ b/src/client/views/collections/CollectionTreeView.tsx @@ -189,6 +189,7 @@ export class CollectionTreeView extends CollectionSubView<Document, Partial<coll      onChildClick = () => this.props.onChildClick?.() || ScriptCast(this.doc.onChildClick);      whenActiveChanged = (isActive: boolean) => { this.props.whenActiveChanged(this._isChildActive = isActive); };      active = (outsideReaction: boolean | undefined) => this.props.active(outsideReaction) || this._isChildActive; +    panelWidth = () => this.props.PanelWidth() - 20; // bcz: 20 is the 10 + 10 for the left and right padding.      @computed get treeChildren() {          TraceMobx();          return this.props.childDocuments || this.childDocs; @@ -200,7 +201,7 @@ export class CollectionTreeView extends CollectionSubView<Document, Partial<coll          const moveDoc = (d: Doc | Doc[], target: Doc | undefined, addDoc: (doc: Doc | Doc[]) => boolean) => this.props.moveDocument?.(d, target, addDoc) || false;          return TreeView.GetChildElements(this.treeChildren, this, this.doc, this.props.DataDoc, this.props.fieldKey, this.props.ContainingCollectionDoc, undefined, addDoc, this.remove,              moveDoc, dropAction, this.props.addDocTab, this.props.pinToPres, this.props.styleProvider, this.props.ScreenToLocalTransform, -            this.outerXf, this.active, this.props.PanelWidth, this.props.renderDepth, () => this.props.treeViewHideHeaderFields || BoolCast(this.doc.treeViewHideHeaderFields), +            this.outerXf, this.active, this.panelWidth, this.props.renderDepth, () => this.props.treeViewHideHeaderFields || BoolCast(this.doc.treeViewHideHeaderFields),              BoolCast(this.doc.treeViewPreventOpen), [], this.props.onCheckedClick,              this.onChildClick, this.props.treeViewSkipFields, true, this.whenActiveChanged, this.props.dontRegisterView || Cast(this.props.Document.dontRegisterChildViews, "boolean", null));      } diff --git a/src/client/views/collections/TabDocView.tsx b/src/client/views/collections/TabDocView.tsx index a4ab201bc..0d03936dc 100644 --- a/src/client/views/collections/TabDocView.tsx +++ b/src/client/views/collections/TabDocView.tsx @@ -117,14 +117,14 @@ export class TabDocView extends React.Component<TabDocViewProps> {              // select the tab document when the tab is directly clicked and activate the tab whenver the tab document is selected              titleEle.onpointerdown = action((e: any) => {                  if (e.target.className !== "lm_close_tab") { -                    if (this.view) SelectionManager.SelectDoc(this.view, false); +                    if (this.view) SelectionManager.SelectView(this.view, false);                      else this._activated = true;                      if (Date.now() - titleEle.lastClick < 1000) titleEle.select();                      titleEle.lastClick = Date.now();                      (document.activeElement !== titleEle) && titleEle.focus();                  }              }); -            tab._disposers.selectionDisposer = reaction(() => SelectionManager.SelectedDocuments().some(v => v.topMost && v.props.Document === doc), +            tab._disposers.selectionDisposer = reaction(() => SelectionManager.Views().some(v => v.topMost && v.props.Document === doc),                  action((selected) => {                      if (selected) this._activated = true;                      const toggle = tab.element[0].children[1].children[0] as HTMLInputElement; @@ -222,7 +222,7 @@ export class TabDocView extends React.Component<TabDocViewProps> {      }      componentDidMount() { -        const selected = () => SelectionManager.SelectedDocuments().some(v => v.props.Document === this._document); +        const selected = () => SelectionManager.Views().some(v => v.props.Document === this._document);          new _global.ResizeObserver(action((entries: any) => {              for (const entry of entries) {                  this._panelWidth = entry.contentRect.width; diff --git a/src/client/views/collections/TreeView.scss b/src/client/views/collections/TreeView.scss index 8468e27df..7a654c7cf 100644 --- a/src/client/views/collections/TreeView.scss +++ b/src/client/views/collections/TreeView.scss @@ -37,7 +37,7 @@      }      .bullet {          position: relative; -        width: 20px; +        width: $TREE_BULLET_WIDTH;          color: $intermediate-color;          margin-top: 3px;          transform: scale(1.3, 1.3); diff --git a/src/client/views/collections/TreeView.tsx b/src/client/views/collections/TreeView.tsx index 31a1a2b99..f51c745bb 100644 --- a/src/client/views/collections/TreeView.tsx +++ b/src/client/views/collections/TreeView.tsx @@ -1,6 +1,7 @@  import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';  import { action, computed, observable } from "mobx";  import { observer } from "mobx-react"; +import { TREE_BULLET_WIDTH } from '../globalCssVariables.scss';  import { DataSym, Doc, DocListCast, DocListCastOrNull, Field, HeightSym, Opt, WidthSym } from '../../../fields/Doc';  import { Id } from '../../../fields/FieldSymbols';  import { List } from '../../../fields/List'; @@ -64,6 +65,8 @@ export interface TreeViewProps {      whenActiveChanged: (isActive: boolean) => void;  } +let treeBulletWidth = function () { return Number(TREE_BULLET_WIDTH.replace("px", "")); } +  @observer  /**   * Renders a treeView of a collection of documents @@ -83,6 +86,7 @@ export class TreeView extends React.Component<TreeViewProps> {      private _uniqueId = Utils.GenerateGuid();      private _editMaxWidth: number | string = 0; +      @observable _dref: DocumentView | undefined | null;      @computed get doc() { TraceMobx(); return this.props.document; }      get noviceMode() { return BoolCast(Doc.UserDoc().noviceMode, false); } @@ -284,9 +288,9 @@ export class TreeView extends React.Component<TreeViewProps> {      docWidth = () => {          const layoutDoc = this.layoutDoc;          const aspect = Doc.NativeAspect(layoutDoc); -        if (layoutDoc._fitWidth) return Math.min(this.props.panelWidth() - 20, layoutDoc[WidthSym]()); -        if (aspect) return Math.min(layoutDoc[WidthSym](), Math.min(this.MAX_EMBED_HEIGHT * aspect, this.props.panelWidth() - 20)); -        return Doc.NativeWidth(layoutDoc) ? Math.min(layoutDoc[WidthSym](), this.props.panelWidth() - 20) : Math.min(this.layoutDoc[WidthSym](), this.props.panelWidth() - 20); +        if (layoutDoc._fitWidth) return Math.min(this.props.panelWidth() - treeBulletWidth(), layoutDoc[WidthSym]()); +        if (aspect) return Math.min(layoutDoc[WidthSym](), Math.min(this.MAX_EMBED_HEIGHT * aspect, this.props.panelWidth() - treeBulletWidth())); +        return Math.min(this.props.panelWidth() - treeBulletWidth(), Doc.NativeWidth(layoutDoc) ? layoutDoc[WidthSym]() : this.layoutDoc[WidthSym]());      }      docHeight = () => {          const layoutDoc = this.layoutDoc; @@ -354,9 +358,9 @@ export class TreeView extends React.Component<TreeViewProps> {          return rows;      } -    rtfWidth = () => Math.min(this.layoutDoc?.[WidthSym](), this.props.panelWidth() - 20); +    rtfWidth = () => Math.min(this.layoutDoc?.[WidthSym](), this.props.panelWidth() - treeBulletWidth());      rtfHeight = () => this.rtfWidth() <= this.layoutDoc?.[WidthSym]() ? Math.min(this.layoutDoc?.[HeightSym](), this.MAX_EMBED_HEIGHT) : this.MAX_EMBED_HEIGHT; -    rtfOutlineHeight = () => Math.max(this.layoutDoc?.[HeightSym](), 20); +    rtfOutlineHeight = () => Math.max(this.layoutDoc?.[HeightSym](), treeBulletWidth());      expandPanelHeight = () => {          if (this.layoutDoc._fitWidth) return this.docHeight();          const aspect = this.layoutDoc[WidthSym]() / this.layoutDoc[HeightSym](); @@ -486,7 +490,7 @@ export class TreeView extends React.Component<TreeViewProps> {      showContextMenu = (e: React.MouseEvent) => simulateMouseClick(this._docRef.current?.ContentDiv, e.clientX, e.clientY + 30, e.screenX, e.screenY + 30);      contextMenuItems = () => Doc.IsSystem(this.doc) ? [] : [{ script: ScriptField.MakeFunction(`openOnRight(self)`)!, label: "Open" }, { script: ScriptField.MakeFunction(`DocFocus(self)`)!, label: "Focus" }]; -    truncateTitleWidth = () => NumCast(this.props.treeView.props.Document.treeViewTruncateTitleWidth, 0); +    truncateTitleWidth = () => NumCast(this.props.treeView.props.Document.treeViewTruncateTitleWidth, this.props.panelWidth());      onChildClick = () => this.props.onChildClick?.() ?? (this._editTitleScript?.() || ScriptCast(this.doc.treeChildClick));      onChildDoubleClick = () => (!this.outlineMode && this._openScript?.()) || ScriptCast(this.doc.treeChildDoubleClick); @@ -553,8 +557,10 @@ export class TreeView extends React.Component<TreeViewProps> {                  moveDocument={this.move}                  removeDocument={this.props.removeDoc}                  ScreenToLocalTransform={this.getTransform} +                NativeHeight={returnZero} +                NativeWidth={returnZero}                  PanelWidth={this.truncateTitleWidth} -                PanelHeight={returnZero} +                PanelHeight={() => 18}                  contextMenuItems={this.contextMenuItems}                  renderDepth={1}                  focus={returnTrue} @@ -746,7 +752,7 @@ export class TreeView extends React.Component<TreeViewProps> {          const docs = TreeView.sortDocs(childDocs, StrCast(containingCollection?.[key + "-sortCriteria"])); -        const rowWidth = () => panelWidth() - 20; +        const rowWidth = () => panelWidth() - treeBulletWidth();          return docs.filter(child => child instanceof Doc).map((child, i) => {              const pair = Doc.GetLayoutDataDocPair(containingCollection, dataDoc, child);              if (!pair.layout || pair.data instanceof Promise) { diff --git a/src/client/views/collections/collectionFreeForm/CollectionFreeFormView.tsx b/src/client/views/collections/collectionFreeForm/CollectionFreeFormView.tsx index 1add65c10..0fb1c0f9c 100644 --- a/src/client/views/collections/collectionFreeForm/CollectionFreeFormView.tsx +++ b/src/client/views/collections/collectionFreeForm/CollectionFreeFormView.tsx @@ -208,7 +208,7 @@ export class CollectionFreeFormView extends CollectionSubView<PanZoomDocument, P      private selectDocuments = (docs: Doc[]) => {          SelectionManager.DeselectAll(); -        docs.map(doc => DocumentManager.Instance.getDocumentView(doc, this.props.CollectionView)).map(dv => dv && SelectionManager.SelectDoc(dv, true)); +        docs.map(doc => DocumentManager.Instance.getDocumentView(doc, this.props.CollectionView)).map(dv => dv && SelectionManager.SelectView(dv, true));      }      public isCurrent(doc: Doc) { return (Math.abs(NumCast(doc.displayTimecode, -1) - NumCast(this.Document._currentTimecode, -1)) < 1.5 || NumCast(doc.displayTimecode, -1) === -1); } diff --git a/src/client/views/collections/collectionFreeForm/MarqueeView.tsx b/src/client/views/collections/collectionFreeForm/MarqueeView.tsx index 47ffc48fb..d20d1abfc 100644 --- a/src/client/views/collections/collectionFreeForm/MarqueeView.tsx +++ b/src/client/views/collections/collectionFreeForm/MarqueeView.tsx @@ -152,7 +152,7 @@ export class MarqueeView extends React.Component<SubCollectionViewProps & Marque                  this.props.addDocument?.(slide);                  //setTimeout(() => SelectionManager.SelectDoc(DocumentManager.Instance.getDocumentView(slide)!, false));                  e.stopPropagation(); -            } else if (!e.ctrlKey && !e.metaKey && SelectionManager.SelectedDocuments().length < 2) { +            } else if (!e.ctrlKey && !e.metaKey && SelectionManager.Views().length < 2) {                  FormattedTextBox.SelectOnLoadChar = FormattedTextBox.DefaultLayout && !this.props.childLayoutString ? e.key : "";                  FormattedTextBox.LiveTextUndo = UndoManager.StartBatch("live text batch");                  this.props.addLiveTextDocument(CurrentUserUtils.GetNewTextDoc("-typed text-", x, y, 200, 100, this.props.xMargin === 0)); diff --git a/src/client/views/globalCssVariables.scss b/src/client/views/globalCssVariables.scss index b2ea87c06..ccc9306c4 100644 --- a/src/client/views/globalCssVariables.scss +++ b/src/client/views/globalCssVariables.scss @@ -39,6 +39,7 @@ $MINIMIZED_ICON_SIZE:25;  $MAX_ROW_HEIGHT: 44px;  $DFLT_IMAGE_NATIVE_DIM: 900px;  $MENU_PANEL_WIDTH: 60px; +$TREE_BULLET_WIDTH: 20px;  :export {      contextMenuZindex: $contextMenu-zindex; @@ -51,4 +52,5 @@ $MENU_PANEL_WIDTH: 60px;      SEARCH_PANEL_HEIGHT: $searchpanel-height;      DFLT_IMAGE_NATIVE_DIM: $DFLT_IMAGE_NATIVE_DIM;      MENU_PANEL_WIDTH: $MENU_PANEL_WIDTH; +    TREE_BULLET_WIDTH: $TREE_BULLET_WIDTH;  }
\ No newline at end of file diff --git a/src/client/views/globalCssVariables.scss.d.ts b/src/client/views/globalCssVariables.scss.d.ts index c56b75d5e..11e62e1eb 100644 --- a/src/client/views/globalCssVariables.scss.d.ts +++ b/src/client/views/globalCssVariables.scss.d.ts @@ -10,6 +10,7 @@ interface IGlobalScss {      SEARCH_PANEL_HEIGHT: string;      DFLT_IMAGE_NATIVE_DIM: string;      MENU_PANEL_WIDTH: string; +    TREE_BULLET_WIDTH: string;  }  declare const globalCssVariables: IGlobalScss; diff --git a/src/client/views/nodes/AudioBox.tsx b/src/client/views/nodes/AudioBox.tsx index 4b3c328b0..67d25e525 100644 --- a/src/client/views/nodes/AudioBox.tsx +++ b/src/client/views/nodes/AudioBox.tsx @@ -135,7 +135,7 @@ export class AudioBox extends ViewBoxAnnotatableComponent<FieldViewProps, AudioD              }, { fireImmediately: true });          // for play when link is selected -        this._disposers.reaction = reaction(() => SelectionManager.SelectedDocuments(), +        this._disposers.reaction = reaction(() => SelectionManager.Views(),              selected => {                  const sel = selected.length ? selected[0].props.Document : undefined;                  let link; diff --git a/src/client/views/nodes/ColorBox.tsx b/src/client/views/nodes/ColorBox.tsx index 52236a648..d5b6a269e 100644 --- a/src/client/views/nodes/ColorBox.tsx +++ b/src/client/views/nodes/ColorBox.tsx @@ -31,7 +31,7 @@ export class ColorBox extends ViewBoxBaseComponent<FieldViewProps, ColorDocument          SetActiveInkColor(color.hex);          if (Doc.GetSelectedTool() === InkTool.None) { -            const selected = SelectionManager.SelectedDocuments(); +            const selected = SelectionManager.Views();              selected.map(view => {                  const targetDoc = view.props.Document.dragFactory instanceof Doc ? view.props.Document.dragFactory :                      view.props.Document.layout instanceof Doc ? view.props.Document.layout : @@ -54,7 +54,7 @@ export class ColorBox extends ViewBoxBaseComponent<FieldViewProps, ColorDocument          super(props);      }      render() { -        const selDoc = SelectionManager.SelectedDocuments()?.[0]?.rootDoc; +        const selDoc = SelectionManager.Views()?.[0]?.rootDoc;          return <div className={`colorBox-container${this.active() ? "-interactive" : ""}`}              onPointerDown={e => e.button === 0 && !e.ctrlKey && e.stopPropagation()} onClick={e => { (e.nativeEvent as any).stuff = true; e.stopPropagation(); }}              style={{ width: `${100}%`, height: `${100}%` }} > @@ -67,7 +67,7 @@ export class ColorBox extends ViewBoxBaseComponent<FieldViewProps, ColorDocument                  <div> {ActiveInkWidth() ?? 2}</div>                  <input type="range" defaultValue={ActiveInkWidth() ?? 2} min={1} max={100} onChange={(e: React.ChangeEvent<HTMLInputElement>) => {                      SetActiveInkWidth(e.target.value); -                    SelectionManager.SelectedDocuments().filter(i => StrCast(i.rootDoc.type) === DocumentType.INK).map(i => i.rootDoc.strokeWidth = Number(e.target.value)); +                    SelectionManager.Views().filter(i => StrCast(i.rootDoc.type) === DocumentType.INK).map(i => i.rootDoc.strokeWidth = Number(e.target.value));                  }} />                  {/* <div> {ActiveInkBezierApprox() ?? 2}</div>                  <input type="range" defaultValue={ActiveInkBezierApprox() ?? 2} min={0} max={300} onChange={(e: React.ChangeEvent<HTMLInputElement>) => { diff --git a/src/client/views/nodes/DocumentView.tsx b/src/client/views/nodes/DocumentView.tsx index 3c140a22a..56982bd89 100644 --- a/src/client/views/nodes/DocumentView.tsx +++ b/src/client/views/nodes/DocumentView.tsx @@ -409,7 +409,7 @@ export class DocumentViewInternal extends DocComponent<DocumentViewInternalProps                      self: this.rootDoc,                      scriptContext: this.props.scriptContext,                      thisContainer: this.props.ContainingCollectionDoc, -                    documentView: this, +                    documentView: this.props.DocumentView,                      shiftKey                  }, console.log);                  const clickFunc = () => { @@ -616,7 +616,7 @@ export class DocumentViewInternal extends DocComponent<DocumentViewInternalProps          if (e && this.rootDoc._hideContextMenu && Doc.UserDoc().noviceMode) {              e.preventDefault();              e.stopPropagation(); -            !this.props.isSelected(true) && SelectionManager.SelectDoc(this.props.DocumentView, false); +            !this.props.isSelected(true) && SelectionManager.SelectView(this.props.DocumentView, false);          }          // the touch onContextMenu is button 0, the pointer onContextMenu is button 2          if (e) { @@ -658,8 +658,8 @@ export class DocumentViewInternal extends DocComponent<DocumentViewInternalProps              const zorders = cm.findByDescription("ZOrder...");              const zorderItems: ContextMenuProps[] = zorders && "subitems" in zorders ? zorders.subitems : []; -            zorderItems.push({ description: "Bring to Front", event: () => SelectionManager.SelectedDocuments().forEach(dv => dv.props.bringToFront(dv.rootDoc, false)), icon: "expand-arrows-alt" }); -            zorderItems.push({ description: "Send to Back", event: () => SelectionManager.SelectedDocuments().forEach(dv => dv.props.bringToFront(dv.rootDoc, true)), icon: "expand-arrows-alt" }); +            zorderItems.push({ description: "Bring to Front", event: () => SelectionManager.Views().forEach(dv => dv.props.bringToFront(dv.rootDoc, false)), icon: "expand-arrows-alt" }); +            zorderItems.push({ description: "Send to Back", event: () => SelectionManager.Views().forEach(dv => dv.props.bringToFront(dv.rootDoc, true)), icon: "expand-arrows-alt" });              zorderItems.push({ description: this.rootDoc._raiseWhenDragged !== false ? "Keep ZIndex when dragged" : "Allow ZIndex to change when dragged", event: undoBatch(action(() => this.rootDoc._raiseWhenDragged = this.rootDoc._raiseWhenDragged === undefined ? false : undefined)), icon: "expand-arrows-alt" });              !zorders && cm.addItem({ description: "ZOrder...", subitems: zorderItems, icon: "compass" }); @@ -733,7 +733,7 @@ export class DocumentViewInternal extends DocComponent<DocumentViewInternalProps                  e?.stopPropagation(); // DocumentViews should stop propagation of this event              }              cm.displayMenu((e?.pageX || pageX || 0) - 15, (e?.pageY || pageY || 0) - 15); -            !this.props.isSelected(true) && setTimeout(() => SelectionManager.SelectDoc(this.props.DocumentView, false), 300); // on a mac, the context menu is triggered on mouse down, but a YouTube video becaomes interactive when selected which means that the context menu won't show up.  by delaying the selection until hopefully after the pointer up, the context menu will appear. +            !this.props.isSelected(true) && setTimeout(() => SelectionManager.SelectView(this.props.DocumentView, false), 300); // on a mac, the context menu is triggered on mouse down, but a YouTube video becaomes interactive when selected which means that the context menu won't show up.  by delaying the selection until hopefully after the pointer up, the context menu will appear.          });      } @@ -983,7 +983,7 @@ export class DocumentView extends React.Component<DocumentViewProps> {                  topDoc.x = fpt[0];                  topDoc.y = fpt[1];              } -            setTimeout(() => SelectionManager.SelectDoc(DocumentManager.Instance.getDocumentView(topDoc, container)!, false), 0); +            setTimeout(() => SelectionManager.SelectView(DocumentManager.Instance.getDocumentView(topDoc, container)!, false), 0);          }      } @@ -1061,7 +1061,7 @@ export class DocumentView extends React.Component<DocumentViewProps> {      });      isSelected = (outsideReaction?: boolean) => SelectionManager.IsSelected(this, outsideReaction); -    select = (ctrlPressed: boolean) => SelectionManager.SelectDoc(this, ctrlPressed); +    select = (ctrlPressed: boolean) => SelectionManager.SelectView(this, ctrlPressed);      NativeWidth = () => this.nativeWidth;      NativeHeight = () => this.nativeHeight;      PanelWidth = () => this.panelWidth; diff --git a/src/client/views/nodes/PresBox.tsx b/src/client/views/nodes/PresBox.tsx index da74edbe3..42462000b 100644 --- a/src/client/views/nodes/PresBox.tsx +++ b/src/client/views/nodes/PresBox.tsx @@ -160,7 +160,7 @@ export class PresBox extends ViewBoxBaseComponent<FieldViewProps, PresBoxSchema>          this.props.Document.presentationFieldKey = this.fieldKey; // provide info to the presElement script so that it can look up rendering information about the presBox      }      @computed get selectedDocumentView() { -        if (SelectionManager.SelectedDocuments().length) return SelectionManager.SelectedDocuments()[0]; +        if (SelectionManager.Views().length) return SelectionManager.Views()[0];          if (this._selectedArray.size) return DocumentManager.Instance.getDocumentView(this.rootDoc);      }      @computed get isPres(): boolean { @@ -195,7 +195,7 @@ export class PresBox extends ViewBoxBaseComponent<FieldViewProps, PresBoxSchema>          this.turnOffEdit(true);          DocListCastAsync((Doc.UserDoc().myPresentations as Doc).data).then(pres =>              !pres?.includes(this.rootDoc) && Doc.AddDocToList(Doc.UserDoc().myPresentations as Doc, "data", this.rootDoc)); -        this._disposers.selection = reaction(() => SelectionManager.SelectedDocuments(), +        this._disposers.selection = reaction(() => SelectionManager.Views(),              views => views.some(view => view.props.Document === this.rootDoc) && this.updateCurrentPresentation());      } @@ -404,7 +404,7 @@ export class PresBox extends ViewBoxBaseComponent<FieldViewProps, PresBoxSchema>          const self = this;          const resetSelection = action(() => {              const presDocView = DocumentManager.Instance.getDocumentView(self.rootDoc); -            if (presDocView) SelectionManager.SelectDoc(presDocView, false); +            if (presDocView) SelectionManager.SelectView(presDocView, false);              self.rootDoc.presStatus = presStatus;              self._selectedArray.clear();              selViewCache.forEach(doc => self._selectedArray.set(doc, undefined)); @@ -761,7 +761,7 @@ export class PresBox extends ViewBoxBaseComponent<FieldViewProps, PresBoxSchema>      @action      selectPres = () => {          const presDocView = DocumentManager.Instance.getDocumentView(this.rootDoc); -        presDocView && SelectionManager.SelectDoc(presDocView, false); +        presDocView && SelectionManager.SelectView(presDocView, false);      }      //Regular click diff --git a/src/client/views/nodes/formattedText/RichTextMenu.tsx b/src/client/views/nodes/formattedText/RichTextMenu.tsx index cf9b03308..07439825f 100644 --- a/src/client/views/nodes/formattedText/RichTextMenu.tsx +++ b/src/client/views/nodes/formattedText/RichTextMenu.tsx @@ -144,7 +144,7 @@ export class RichTextMenu extends AntimodeMenu<AntimodeMenuProps>   {      }      componentDidMount() { -        this._reaction = reaction(() => SelectionManager.SelectedDocuments(), +        this._reaction = reaction(() => SelectionManager.Views(),              () => this._delayHide && !(this._delayHide = false) && this.fadeOut(true));      }      componentWillUnmount() { @@ -836,7 +836,7 @@ export class RichTextMenu extends AntimodeMenu<AntimodeMenuProps>   {                          if (linkDoc instanceof Doc) {                              const anchor1 = await Cast(linkDoc.anchor1, Doc);                              const anchor2 = await Cast(linkDoc.anchor2, Doc); -                            const currentDoc = SelectionManager.SelectedDocuments().length && SelectionManager.SelectedDocuments()[0].props.Document; +                            const currentDoc = SelectionManager.Views().length && SelectionManager.Views()[0].props.Document;                              if (currentDoc && anchor1 && anchor2) {                                  if (Doc.AreProtosEqual(currentDoc, anchor1)) {                                      return StrCast(anchor2.title); @@ -987,11 +987,11 @@ export class RichTextMenu extends AntimodeMenu<AntimodeMenuProps>   {                  <div className="richTextMenu-divider" key="divider 3" />,                  {[this.createMarksDropdown(this.activeFontSize, this.fontSizeOptions, "font size", action((val: string) => {                      this.activeFontSize = val; -                    SelectionManager.SelectedDocuments().map(dv => dv.props.Document._fontSize = val); +                    SelectionManager.Views().map(dv => dv.props.Document._fontSize = val);                  })),                  this.createMarksDropdown(this.activeFontFamily, this.fontFamilyOptions, "font family", action((val: string) => {                      this.activeFontFamily = val; -                    SelectionManager.SelectedDocuments().map(dv => dv.props.Document._fontFamily = val); +                    SelectionManager.Views().map(dv => dv.props.Document._fontFamily = val);                  })),                  <div className="richTextMenu-divider" key="divider 4" />,                  this.createNodesDropdown(this.activeListType, this.listTypeOptions, "list type", () => ({})), diff --git a/src/client/views/pdf/PDFViewer.tsx b/src/client/views/pdf/PDFViewer.tsx index d6d500702..02f7ada96 100644 --- a/src/client/views/pdf/PDFViewer.tsx +++ b/src/client/views/pdf/PDFViewer.tsx @@ -150,7 +150,7 @@ export class PDFViewer extends ViewBoxAnnotatableComponent<IViewerProps, PdfDocu                      this._savedAnnotations.keys().forEach(k => this._savedAnnotations.setValue(k, []));                      PDFMenu.Instance.fadeOut(true);                  } -                (SelectionManager.SelectedDocuments().length === 1) && this.setupPdfJsViewer(); +                (SelectionManager.Views().length === 1) && this.setupPdfJsViewer();              },              { fireImmediately: true });          this._disposers.scrollY = reaction( | 
