diff options
Diffstat (limited to 'src')
46 files changed, 41 insertions, 143 deletions
| diff --git a/src/client/documents/Documents.ts b/src/client/documents/Documents.ts index d9c2e0d8b..797a129c4 100644 --- a/src/client/documents/Documents.ts +++ b/src/client/documents/Documents.ts @@ -122,7 +122,6 @@ export class DocumentOptions {      _scrollTop?: number; // scroll location for pdfs      _noAutoscroll?: boolean;// whether collections autoscroll when this item is dragged      _chromeHidden?: boolean; // whether the editing chrome for a document is hidden -    _layerTags?: List<string>; // layer tags a document has (used for tab filtering "layers" in document tab)      _searchDoc?: boolean; // is this a search document (used to change UI for search results in schema view)      _forceActive?: boolean; // flag to handle pointer events when not selected (or otherwise active)      _stayInCollection?: boolean;// whether the document should remain in its collection when someone tries to drag and drop it elsewhere @@ -426,7 +425,7 @@ export namespace Docs {                      childDontRegisterViews: true, _isLinkButton: true, _height: 150, description: "", showCaption: "description",                      backgroundColor: "lightblue", // lightblue is default color for linking dot and link documents text comment area                      links: "@links(self)", -                    _removeDropProperties: new List(["_layerTags", "isLinkButton"]), +                    _removeDropProperties: new List(["isLinkButton"]),                  }              }],              [DocumentType.LINKDB, { diff --git a/src/client/views/DocComponent.tsx b/src/client/views/DocComponent.tsx index 79aaf2158..9c176a4fd 100644 --- a/src/client/views/DocComponent.tsx +++ b/src/client/views/DocComponent.tsx @@ -44,7 +44,6 @@ interface ViewBoxBaseProps {      ContainingCollectionDoc: Opt<Doc>;      DocumentView?: () => DocumentView;      fieldKey: string; -    layerProvider?: (doc: Doc, assign?: boolean) => boolean;      isSelected: (outsideReaction?: boolean) => boolean;      isContentActive: () => boolean | undefined;      renderDepth: number; @@ -85,7 +84,6 @@ export interface ViewBoxAnnotatableProps {      DataDoc?: Doc;      fieldKey: string;      filterAddDocument?: (doc: Doc[]) => boolean;  // allows a document that renders a Collection view to filter or modify any documents added to the collection (see PresBox for an example) -    layerProvider?: (doc: Doc, assign?: boolean) => boolean;      isContentActive: () => boolean | undefined;      select: (isCtrlPressed: boolean) => void;      whenChildContentsActiveChanged: (isActive: boolean) => void; @@ -209,13 +207,11 @@ export function ViewBoxAnnotatableComponent<P extends ViewBoxAnnotatableProps>()                              if ([AclAdmin, AclEdit].includes(GetEffectiveAcl(doc))) inheritParentAcls(CurrentUserUtils.ActiveDashboard, doc);                              doc.context = this.props.Document;                              if (annotationKey ?? this._annotationKeySuffix()) Doc.GetProto(doc).annotationOn = this.props.Document; -                            this.props.layerProvider?.(doc, true);                              Doc.AddDocToList(targetDataDoc, annotationKey ?? this.annotationKey, doc);                          });                      }                      else {                          added.filter(doc => [AclAdmin, AclEdit].includes(GetEffectiveAcl(doc))).map(doc => {  // only make a pushpin if we have acl's to edit the document -                            this.props.layerProvider?.(doc, true);                              //DocUtils.LeavePushpin(doc);                              doc._stayInCollection = undefined;                              doc.context = this.props.Document; diff --git a/src/client/views/GestureOverlay.tsx b/src/client/views/GestureOverlay.tsx index 50dca0a99..482b62479 100644 --- a/src/client/views/GestureOverlay.tsx +++ b/src/client/views/GestureOverlay.tsx @@ -881,7 +881,6 @@ export class GestureOverlay extends Touchable {                  isContentActive={returnFalse}                  renderDepth={0}                  styleProvider={returnEmptyString} -                layerProvider={undefined}                  docViewPath={returnEmptyDoclist}                  focus={DocUtils.DefaultFocus}                  whenChildContentsActiveChanged={emptyFunction} diff --git a/src/client/views/InkingStroke.tsx b/src/client/views/InkingStroke.tsx index 3d9c048e5..d0f01c363 100644 --- a/src/client/views/InkingStroke.tsx +++ b/src/client/views/InkingStroke.tsx @@ -332,7 +332,7 @@ export class InkingStroke extends ViewBoxBaseComponent<FieldViewProps>() {              inkStrokeWidth, inkStrokeWidth + (highlightIndex && closed && fillColor && (new Color(fillColor)).alpha() < 1 ? 6 : 15),              StrCast(this.layoutDoc.strokeLineJoin), StrCast(this.layoutDoc.strokeLineCap),              StrCast(this.layoutDoc.strokeBezier), !closed ? "none" : fillColor === "transparent" || suppressFill ? "none" : fillColor, startMarker, endMarker, -            markerScale, undefined, inkScaleX, inkScaleY, "", this.props.pointerEvents?.() ?? (this.props.layerProvider?.(this.props.Document) === false ? "none" : "visiblepainted"), 0.0, +            markerScale, undefined, inkScaleX, inkScaleY, "", this.props.pointerEvents?.() ?? (this.rootDoc._lockedPosition ? "none" : "visiblepainted"), 0.0,              false, downHdlr);          const fsize = +(StrCast(this.props.Document.fontSize, "12px").replace("px", ""));          // bootsrap 3 style sheet sets line height to be 20px for default 14 point font size.  diff --git a/src/client/views/LightboxView.tsx b/src/client/views/LightboxView.tsx index 59ed0dc92..9882693ee 100644 --- a/src/client/views/LightboxView.tsx +++ b/src/client/views/LightboxView.tsx @@ -246,7 +246,6 @@ export class LightboxView extends React.Component<LightboxViewProps> {                          docFilters={this.docFilters}                          removeDocument={undefined}                          styleProvider={DefaultStyleProvider} -                        layerProvider={returnTrue}                          ScreenToLocalTransform={this.lightboxScreenToLocal}                          PanelWidth={this.lightboxWidth}                          PanelHeight={this.lightboxHeight} diff --git a/src/client/views/MainView.tsx b/src/client/views/MainView.tsx index db51c54f8..2e1d10955 100644 --- a/src/client/views/MainView.tsx +++ b/src/client/views/MainView.tsx @@ -281,7 +281,6 @@ export class MainView extends React.Component {              addDocTab={this.addDocTabFunc}              pinToPres={emptyFunction}              docViewPath={returnEmptyDoclist} -            layerProvider={undefined}              styleProvider={undefined}              rootSelected={returnTrue}              isContentActive={returnTrue} @@ -361,7 +360,6 @@ export class MainView extends React.Component {                          addDocTab={this.addDocTabFunc}                          pinToPres={emptyFunction}                          docViewPath={returnEmptyDoclist} -                        layerProvider={undefined}                          styleProvider={this._sidebarContent.proto === Doc.UserDoc().myDashboards || this._sidebarContent.proto === Doc.UserDoc().myFilesystem ? DashboardStyleProvider : DefaultStyleProvider}                          rootSelected={returnTrue}                          removeDocument={returnFalse} @@ -402,7 +400,6 @@ export class MainView extends React.Component {                  docViewPath={returnEmptyDoclist}                  focus={DocUtils.DefaultFocus}                  styleProvider={DefaultStyleProvider} -                layerProvider={undefined}                  isContentActive={returnTrue}                  whenChildContentsActiveChanged={emptyFunction}                  bringToFront={emptyFunction} @@ -516,7 +513,6 @@ export class MainView extends React.Component {                      dropAction={"alias"}                      setHeight={returnFalse}                      styleProvider={DefaultStyleProvider} -                    layerProvider={undefined}                      rootSelected={returnTrue}                      bringToFront={emptyFunction}                      select={emptyFunction} @@ -591,7 +587,6 @@ export class MainView extends React.Component {                      ContainingCollectionDoc={undefined}                      Document={DocumentLinksButton.invisibleWebDoc}                      dropAction={"move"} -                    layerProvider={undefined}                      styleProvider={undefined}                      isSelected={returnFalse}                      select={returnFalse} @@ -673,7 +668,6 @@ export class MainView extends React.Component {                              rootSelected={returnFalse}                              renderDepth={0}                              setHeight={returnFalse} -                            layerProvider={undefined}                              styleProvider={undefined}                              addDocTab={returnFalse}                              pinToPres={returnFalse} diff --git a/src/client/views/OverlayView.tsx b/src/client/views/OverlayView.tsx index 0f51cf9b2..ebad2981d 100644 --- a/src/client/views/OverlayView.tsx +++ b/src/client/views/OverlayView.tsx @@ -195,7 +195,6 @@ export class OverlayView extends React.Component {                      whenChildContentsActiveChanged={emptyFunction}                      focus={DocUtils.DefaultFocus}                      styleProvider={DefaultStyleProvider} -                    layerProvider={undefined}                      docViewPath={returnEmptyDoclist}                      addDocTab={returnFalse}                      pinToPres={emptyFunction} diff --git a/src/client/views/Palette.tsx b/src/client/views/Palette.tsx index 529697f71..954529bc9 100644 --- a/src/client/views/Palette.tsx +++ b/src/client/views/Palette.tsx @@ -54,7 +54,6 @@ export default class Palette extends React.Component<PaletteProps> {                              focus={emptyFunction}                              docViewPath={returnEmptyDoclist}                              styleProvider={returnEmptyString} -                            layerProvider={undefined}                              whenChildContentsActiveChanged={emptyFunction}                              bringToFront={emptyFunction}                              docFilters={returnEmptyFilter} diff --git a/src/client/views/PropertiesView.tsx b/src/client/views/PropertiesView.tsx index 21c688421..bba2ac211 100644 --- a/src/client/views/PropertiesView.tsx +++ b/src/client/views/PropertiesView.tsx @@ -303,7 +303,6 @@ export class PropertiesView extends React.Component<PropertiesViewProps> {                      fitContentsToDoc={returnTrue}                      rootSelected={returnFalse}                      styleProvider={DefaultStyleProvider} -                    layerProvider={undefined}                      docViewPath={returnEmptyDoclist}                      freezeDimensions={true}                      dontCenter={"y"} @@ -1010,7 +1009,6 @@ export class PropertiesView extends React.Component<PropertiesViewProps> {                              createNewFilterDoc={this.createNewFilterDoc}                              updateFilterDoc={this.updateFilterDoc}                              docViewPath={returnEmptyDoclist} -                            layerProvider={undefined}                              dontCenter="y"                          />                      </div> diff --git a/src/client/views/StyleProvider.tsx b/src/client/views/StyleProvider.tsx index 5056dedaf..334415b38 100644 --- a/src/client/views/StyleProvider.tsx +++ b/src/client/views/StyleProvider.tsx @@ -26,10 +26,6 @@ import React = require("react");  import { InkingStroke } from './InkingStroke';  import { TreeSort } from './collections/TreeView'; -export enum StyleLayers { -    Background = "background" -} -  export enum StyleProp {      TreeViewIcon = "treeViewIcon",      TreeViewSortings = "treeViewSortings",// options for how to sort tree view items @@ -56,14 +52,9 @@ export enum StyleProp {  function darkScheme() { return CurrentUserUtils.ActiveDashboard?.colorScheme === ColorScheme.Dark; } -function toggleBackground(doc: Doc) { +function toggleLockedPosition(doc: Doc) {      UndoManager.RunInBatch(() => runInAction(() => { -        const layers = StrListCast(doc._layerTags); -        if (!layers.includes(StyleLayers.Background)) { -            if (!layers.length) doc._layerTags = new List<string>([StyleLayers.Background]); -            else layers.push(StyleLayers.Background); -        } -        else layers.splice(layers.indexOf(StyleLayers.Background), 1); +        doc._lockedPosition = !doc._lockedPosition;      }), "toggleBackground");  } @@ -86,7 +77,7 @@ export function DefaultStyleProvider(doc: Opt<Doc>, props: Opt<DocumentViewProps      const isOpen = property.includes(":open");      const fieldKey = props?.fieldKey ? props.fieldKey + "-" : isCaption ? "caption-" : "";      const comicStyle = () => doc && !Doc.IsSystem(doc) && Doc.UserDoc().renderStyle === "comic"; -    const isBackground = () => StrListCast(doc?._layerTags).includes(StyleLayers.Background); +    const isBackground = () => doc && BoolCast(doc._lockedPosition);      const backgroundCol = () => props?.styleProvider?.(doc, props, StyleProp.BackgroundColor);      const opacity = () => props?.styleProvider?.(doc, props, StyleProp.Opacity);      const showTitle = () => props?.styleProvider?.(doc, props, StyleProp.ShowTitle); @@ -177,7 +168,7 @@ export function DefaultStyleProvider(doc: Opt<Doc>, props: Opt<DocumentViewProps                  //if (doc._viewType !== CollectionViewType.Freeform && doc._viewType !== CollectionViewType.Time) return "rgb(62,62,62)";                  default: docColor = docColor || (darkScheme() ? Colors.DARK_GRAY : Colors.WHITE); break;              } -            if (docColor && (!doc || props?.layerProvider?.(doc) === false)) docColor = DashColor(docColor).fade(0.5).toString(); +            if (docColor && !doc) docColor = DashColor(docColor).fade(0.5).toString();              return docColor;          }          case StyleProp.BoxShadow: { @@ -205,17 +196,15 @@ export function DefaultStyleProvider(doc: Opt<Doc>, props: Opt<DocumentViewProps          case StyleProp.PointerEvents:              if (doc?.type === DocumentType.MARKER) return "none";              if (props?.pointerEvents?.() === "none") return "none"; -            const layer = doc && props?.layerProvider?.(doc);              const isInk = doc && StrCast(Doc.Layout(doc).layout).includes(InkingStroke.name); -            if (opacity() === 0 || (isInk && !docProps?.treeViewDoc) || doc?.isInkMask) return "none"; -            if (layer === false && !selected && !SnappingManager.GetIsDragging()) return "none"; -            if (!isInk && layer === true) return "all"; +            if (doc?._lockedPosition || opacity() === 0 || (isInk && !docProps?.treeViewDoc) || doc?.isInkMask) return "none"; +            if (!isInk) return "all";              return undefined;          case StyleProp.Decorations:              if (props?.ContainingCollectionDoc?._viewType === CollectionViewType.Freeform || doc?.x !== undefined || doc?.y !== undefined) {                  return doc && (isBackground() || selected) && (props?.renderDepth || 0) > 0 &&                      ((doc.type === DocumentType.COL && doc._viewType !== CollectionViewType.Pile) || [DocumentType.RTF, DocumentType.IMG, DocumentType.INK].includes(doc.type as DocumentType)) ? -                    <div className="styleProvider-lock" onClick={() => toggleBackground(doc)}> +                    <div className="styleProvider-lock" onClick={() => toggleLockedPosition(doc)}>                          <FontAwesomeIcon icon={isBackground() ? "lock" : "unlock"} style={{ color: isBackground() ? "red" : undefined }} size="lg" />                      </div>                      : (null); @@ -251,30 +240,3 @@ export function DashboardStyleProvider(doc: Opt<Doc>, props: Opt<FieldViewProps      }      return DefaultStyleProvider(doc, props, property);  } - -// -// a preliminary semantic-"layering/grouping" mechanism for determining interactive properties of documents -//  currently, the provider tests whether the docuemnt's layer field matches the activeLayer field of the tab. -//     if it matches, then the document gets pointer events, otherwise it does not. -// -export function DefaultLayerProvider(thisDoc: Doc) { -    return (doc: Doc, assign?: boolean) => { -        if (doc.z) return true; -        if (assign) { -            const activeLayer = StrCast(thisDoc?.activeLayer); -            if (activeLayer) { -                const layers = Cast(doc._layerTags, listSpec("string"), []); -                if (layers.length && !layers.includes(activeLayer)) layers.push(activeLayer); -                else if (!layers.length) doc._layerTags = new List<string>([activeLayer]); -                if (activeLayer === "red" || activeLayer === "green" || activeLayer === "blue") doc._backgroundColor = activeLayer; -            } -            return true; -        } else { -            if (Doc.AreProtosEqual(doc, thisDoc)) return true; -            const layers = StrListCast(doc._layerTags); -            if (!layers.length && !thisDoc?.activeLayer) return true; -            if (layers.includes(StrCast(thisDoc?.activeLayer))) return true; -            return false; -        } -    }; -}
\ No newline at end of file diff --git a/src/client/views/TemplateMenu.tsx b/src/client/views/TemplateMenu.tsx index b3a24e031..636f7042f 100644 --- a/src/client/views/TemplateMenu.tsx +++ b/src/client/views/TemplateMenu.tsx @@ -131,7 +131,6 @@ export class TemplateMenu extends React.Component<TemplateMenuProps> {                  ContainingCollectionDoc={undefined}                  ContainingCollectionView={undefined}                  styleProvider={DefaultStyleProvider} -                layerProvider={undefined}                  setHeight={returnFalse}                  docViewPath={returnEmptyDoclist}                  docFilters={returnEmptyFilter} diff --git a/src/client/views/collections/CollectionMenu.tsx b/src/client/views/collections/CollectionMenu.tsx index 364a2440e..b3fbd4ca4 100644 --- a/src/client/views/collections/CollectionMenu.tsx +++ b/src/client/views/collections/CollectionMenu.tsx @@ -108,7 +108,6 @@ export class CollectionMenu extends AntimodeMenu<CollectionMenuProps>{                  dropAction={"alias"}                  setHeight={returnFalse}                  styleProvider={DefaultStyleProvider} -                layerProvider={undefined}                  rootSelected={returnTrue}                  bringToFront={emptyFunction}                  select={emptyFunction} diff --git a/src/client/views/collections/CollectionStackedTimeline.tsx b/src/client/views/collections/CollectionStackedTimeline.tsx index de307416f..683b6d51d 100644 --- a/src/client/views/collections/CollectionStackedTimeline.tsx +++ b/src/client/views/collections/CollectionStackedTimeline.tsx @@ -392,7 +392,7 @@ export class CollectionStackedTimeline extends CollectionSubView<CollectionStack      // handles dragging and dropping markers in timeline      @action      internalDocDrop(e: Event, de: DragManager.DropEvent, docDragData: DragManager.DocumentDragData, xp: number) { -        if (!de.embedKey && this.props.layerProvider?.(this.props.Document) !== false && this.props.Document._isGroup) return false; +        if (!de.embedKey && this.props.Document._isGroup) return false;          if (!super.onInternalDrop(e, de)) return false;          // determine x coordinate of drop and assign it to the documents being dragged  --- see internalDocDrop of collectionFreeFormView.tsx for how it's done when dropping onto a 2D freeform view diff --git a/src/client/views/collections/CollectionStackingView.tsx b/src/client/views/collections/CollectionStackingView.tsx index 509005b45..4338dedcc 100644 --- a/src/client/views/collections/CollectionStackingView.tsx +++ b/src/client/views/collections/CollectionStackingView.tsx @@ -222,7 +222,6 @@ export class CollectionStackingView extends CollectionSubView<Partial<collection              PanelWidth={width}              PanelHeight={height}              styleProvider={this.styleProvider} -            layerProvider={this.props.layerProvider}              docViewPath={this.props.docViewPath}              fitWidth={this.props.childFitWidth}              isContentActive={emptyFunction} @@ -543,7 +542,6 @@ export class CollectionStackingView extends CollectionSubView<Partial<collection                      renderDepth={this.props.renderDepth}                      focus={emptyFunction}                      styleProvider={this.props.styleProvider} -                    layerProvider={this.props.layerProvider}                      docViewPath={returnEmptyDoclist}                      whenChildContentsActiveChanged={emptyFunction}                      bringToFront={emptyFunction} diff --git a/src/client/views/collections/CollectionTreeView.tsx b/src/client/views/collections/CollectionTreeView.tsx index 41970eb96..5e89016db 100644 --- a/src/client/views/collections/CollectionTreeView.tsx +++ b/src/client/views/collections/CollectionTreeView.tsx @@ -296,7 +296,6 @@ export class CollectionTreeView extends CollectionSubView<Partial<collectionTree                      renderDepth={this.props.renderDepth + 1}                      focus={emptyFunction}                      styleProvider={this.props.styleProvider} -                    layerProvider={this.props.layerProvider}                      docViewPath={returnEmptyDoclist}                      whenChildContentsActiveChanged={emptyFunction}                      bringToFront={emptyFunction} diff --git a/src/client/views/collections/CollectionView.tsx b/src/client/views/collections/CollectionView.tsx index ee2c28b5f..7c5f49b42 100644 --- a/src/client/views/collections/CollectionView.tsx +++ b/src/client/views/collections/CollectionView.tsx @@ -261,7 +261,7 @@ export class CollectionView extends ViewBoxAnnotatableComponent<ViewBoxAnnotatab              CollectionView: this,          };          return (<div className={"collectionView"} onContextMenu={this.onContextMenu} -            style={{ pointerEvents: this.props.layerProvider?.(this.rootDoc) === false ? "none" : undefined }}> +            style={{ pointerEvents: this.rootDoc._lockedPosition ? "none" : undefined }}>              {this.showIsTagged()}              {this.renderSubView(this.collectionViewType, props)}          </div>); diff --git a/src/client/views/collections/TabDocView.tsx b/src/client/views/collections/TabDocView.tsx index 8dfc7edc7..73e5a9178 100644 --- a/src/client/views/collections/TabDocView.tsx +++ b/src/client/views/collections/TabDocView.tsx @@ -26,7 +26,7 @@ import { Colors, Shadows } from '../global/globalEnums';  import { LightboxView } from '../LightboxView';  import { DocFocusOptions, DocumentView, DocumentViewProps } from "../nodes/DocumentView";  import { PinProps, PresBox, PresMovement } from '../nodes/trails'; -import { DefaultLayerProvider, DefaultStyleProvider, StyleLayers, StyleProp } from '../StyleProvider'; +import { DefaultStyleProvider, StyleProp } from '../StyleProvider';  import { CollectionDockingView } from './CollectionDockingView';  import { CollectionDockingViewMenu } from './CollectionDockingViewMenu';  import { CollectionFreeFormView } from './collectionFreeForm/CollectionFreeFormView'; @@ -94,20 +94,6 @@ export class TabDocView extends React.Component<TabDocViewProps> {              if (tab.element[0].children[1].children.length === 1) { -                const toggle = document.createElement("div"); -                toggle.style.width = "10px"; -                toggle.style.height = "calc(100% - 2px)"; -                toggle.style.left = "-2px"; -                toggle.style.bottom = "1px"; -                toggle.style.borderTopRightRadius = "7px"; -                toggle.style.position = "relative"; -                toggle.style.display = "inline-block"; -                toggle.style.background = "transparent"; -                toggle.onclick = (e: MouseEvent) => { -                    if (tab.contentItem === tab.header.parent.getActiveContentItem()) { -                        tab.DashDoc.activeLayer = tab.DashDoc.activeLayer ? undefined : StyleLayers.Background; -                    } -                };                  iconWrap.className = "lm_iconWrap";                  iconWrap.id = "lm_iconWrap";                  closeWrap.className = "lm_iconWrap"; @@ -357,7 +343,6 @@ export class TabDocView extends React.Component<TabDocViewProps> {      disableMinimap = () => !this._document || (this._document.layout !== CollectionView.LayoutString(Doc.LayoutFieldKey(this._document)) || this._document?._viewType !== CollectionViewType.Freeform);      hideMinimap = () => this.disableMinimap() || BoolCast(this._document?.hideMinimap); -    @computed get layerProvider() { return this._document && DefaultLayerProvider(this._document); }      @computed get docView() {          return !this._activated || !this._document || this._document._viewType === CollectionViewType.Docking ? (null) :              <><DocumentView key={this._document[Id]} ref={action((r: DocumentView) => this._view = r)} @@ -369,7 +354,6 @@ export class TabDocView extends React.Component<TabDocViewProps> {                  isContentActive={returnTrue}                  PanelWidth={this.PanelWidth}                  PanelHeight={this.PanelHeight} -                layerProvider={this.layerProvider}                  styleProvider={DefaultStyleProvider}                  docFilters={CollectionDockingView.Instance.childDocFilters}                  docRangeFilters={CollectionDockingView.Instance.childDocRangeFilters} @@ -520,7 +504,6 @@ export class TabMinimapView extends React.Component<TabMinimapViewProps> {                      whenChildContentsActiveChanged={emptyFunction}                      focus={DocUtils.DefaultFocus}                      styleProvider={TabMinimapView.miniStyleProvider} -                    layerProvider={undefined}                      addDocTab={this.props.addDocTab}                      pinToPres={TabDocView.PinDoc}                      docFilters={CollectionDockingView.Instance.childDocFilters} diff --git a/src/client/views/collections/TreeView.tsx b/src/client/views/collections/TreeView.tsx index 164021358..d608f800c 100644 --- a/src/client/views/collections/TreeView.tsx +++ b/src/client/views/collections/TreeView.tsx @@ -663,7 +663,6 @@ export class TreeView extends React.Component<TreeViewProps> {                  hideDecorationTitle={this.props.treeView.outlineMode}                  hideResizeHandles={this.props.treeView.outlineMode}                  styleProvider={this.titleStyleProvider} -                layerProvider={returnTrue}                  docViewPath={returnEmptyDoclist}                  treeViewDoc={this.props.treeView.props.Document}                  addDocument={undefined} @@ -760,7 +759,6 @@ export class TreeView extends React.Component<TreeViewProps> {              renderDepth={this.props.renderDepth + 1}              treeViewDoc={this.props.treeView?.props.Document}              rootSelected={returnTrue} -            layerProvider={returnTrue}              docViewPath={this.props.treeView.props.docViewPath}              docFilters={returnEmptyFilter}              docRangeFilters={returnEmptyFilter} diff --git a/src/client/views/collections/collectionFreeForm/CollectionFreeFormView.tsx b/src/client/views/collections/collectionFreeForm/CollectionFreeFormView.tsx index 4f79d19ad..322944d92 100644 --- a/src/client/views/collections/collectionFreeForm/CollectionFreeFormView.tsx +++ b/src/client/views/collections/collectionFreeForm/CollectionFreeFormView.tsx @@ -44,7 +44,7 @@ import { FormattedTextBox } from "../../nodes/formattedText/FormattedTextBox";  import { PresBox } from "../../nodes/trails/PresBox";  import { VideoBox } from "../../nodes/VideoBox";  import { CreateImage } from "../../nodes/WebBoxRenderer"; -import { StyleLayers, StyleProp } from "../../StyleProvider"; +import { StyleProp } from "../../StyleProvider";  import { CollectionDockingView } from "../CollectionDockingView";  import { CollectionSubView } from "../CollectionSubView";  import { CollectionViewType } from "../CollectionView"; @@ -122,8 +122,6 @@ export class CollectionFreeFormView extends CollectionSubView<Partial<collection      @observable ChildDrag: DocumentView | undefined; // child document view being dragged.  needed to update drop areas of groups when a group item is dragged.      @computed get views() { return this._layoutElements.filter(ele => ele.bounds && !ele.bounds.z).map(ele => ele.ele); } -    @computed get backgroundEvents() { return this.props.layerProvider?.(this.layoutDoc) === false && SnappingManager.GetIsDragging(); } -    @computed get backgroundActive() { return this.props.layerProvider?.(this.layoutDoc) === false && this.props.isContentActive(); }      @computed get fitToContentVals() {          return {              bounds: { ...this.contentBounds, cx: (this.contentBounds.x + this.contentBounds.r) / 2, cy: (this.contentBounds.y + this.contentBounds.b) / 2 }, @@ -222,8 +220,8 @@ export class CollectionFreeFormView extends CollectionSubView<Partial<collection      @action      internalDocDrop(e: Event, de: DragManager.DropEvent, docDragData: DragManager.DocumentDragData, xp: number, yp: number) { -        if (!de.embedKey && !this.ChildDrag && this.props.layerProvider?.(this.props.Document) !== false && this.props.Document._isGroup) return false; -        if (!super.onInternalDrop(e, de)) return false; +        if (!de.embedKey && !this.ChildDrag && this.rootDoc._isGroup) return false; +        if (this.rootDoc._lockedPosition || !super.onInternalDrop(e, de)) return false;          const refDoc = docDragData.droppedDocuments[0];          const [xpo, ypo] = this.getContainerTransform().transformPoint(de.x, de.y);          const z = NumCast(refDoc.z); @@ -251,7 +249,7 @@ export class CollectionFreeFormView extends CollectionSubView<Partial<collection              const nd = [Doc.NativeWidth(layoutDoc), Doc.NativeHeight(layoutDoc)];              layoutDoc._width = NumCast(layoutDoc._width, 300);              layoutDoc._height = NumCast(layoutDoc._height, nd[0] && nd[1] ? nd[1] / nd[0] * NumCast(layoutDoc._width) : 300); -            !StrListCast(d._layerTags).includes(StyleLayers.Background) && (d._raiseWhenDragged === undefined ? Doc.UserDoc()._raiseWhenDragged : d._raiseWhenDragged) && (d.zIndex = zsorted.length + 1 + i); // bringToFront +            (d._raiseWhenDragged === undefined ? Doc.UserDoc()._raiseWhenDragged : d._raiseWhenDragged) && (d.zIndex = zsorted.length + 1 + i); // bringToFront          }          (docDragData.droppedDocuments.length === 1 || de.shiftKey) && this.updateClusterDocs(docDragData.droppedDocuments); @@ -418,8 +416,7 @@ export class CollectionFreeFormView extends CollectionSubView<Partial<collection                  styleProp = colors[cluster % colors.length];                  const set = this._clusterSets[cluster]?.filter(s => s.backgroundColor);                  // override the cluster color with an explicitly set color on a non-background document.  then override that with an explicitly set color on a background document -                set?.filter(s => !StrListCast(s._layerTags).includes(StyleLayers.Background)).map(s => styleProp = StrCast(s.backgroundColor)); -                set?.filter(s => StrListCast(s._layerTags).includes(StyleLayers.Background)).map(s => styleProp = StrCast(s.backgroundColor)); +                set?.map(s => styleProp = StrCast(s.backgroundColor));              }          } //else if (doc && NumCast(doc.group, -1) !== -1) styleProp = "gray";          return styleProp; @@ -1017,7 +1014,7 @@ export class CollectionFreeFormView extends CollectionSubView<Partial<collection      @action      bringToFront = (doc: Doc, sendToBack?: boolean) => { -        if (sendToBack || StrListCast(doc._layerTags).includes(StyleLayers.Background)) { +        if (sendToBack) {              doc.zIndex = 0;          } else if (doc.isInkMask) {              doc.zIndex = 5000; @@ -1155,7 +1152,7 @@ export class CollectionFreeFormView extends CollectionSubView<Partial<collection      pointerEvents = () => {          const engine = this.props.layoutEngine?.() || StrCast(this.props.Document._layoutEngine); -        const pointerEvents = this.props.isContentActive() === false ? "none" : this.backgroundActive || this.props.childPointerEvents ? "all" : +        const pointerEvents = this.props.isContentActive() === false ? "none" : this.props.childPointerEvents ? "all" :              (this.props.viewDefDivClick || (engine === "pass" && !this.props.isSelected(true))) ? "none" : this.props.pointerEvents?.();          return pointerEvents;      } @@ -1195,7 +1192,6 @@ export class CollectionFreeFormView extends CollectionSubView<Partial<collection              whenChildContentsActiveChanged={this.props.whenChildContentsActiveChanged}              docViewPath={this.props.docViewPath}              styleProvider={this.getClusterColor} -            layerProvider={this.props.layerProvider}              dataProvider={this.childDataProvider}              sizeProvider={this.childSizeProvider}              freezeDimensions={BoolCast(this.props.Document.childFreezeDimensions, this.props.childFreezeDimensions)} @@ -1614,7 +1610,7 @@ export class CollectionFreeFormView extends CollectionSubView<Partial<collection          const isDocInView = (doc: Doc, rect: { left: number, top: number, width: number, height: number }) => intersectRect(docDims(doc), rect);          const otherBounds = { left: this.panX(), top: this.panY(), width: Math.abs(size[0]), height: Math.abs(size[1]) }; -        let snappableDocs = activeDocs.filter(doc => !StrListCast(doc._layerTags).includes(StyleLayers.Background) && doc.z === undefined && isDocInView(doc, selRect));  // first see if there are any foreground docs to snap to +        let snappableDocs = activeDocs.filter(doc => doc.z === undefined && isDocInView(doc, selRect));  // first see if there are any foreground docs to snap to          !snappableDocs.length && (snappableDocs = activeDocs.filter(doc => doc.z === undefined && isDocInView(doc, selRect))); // if not, see if there are background docs to snap to          !snappableDocs.length && (snappableDocs = activeDocs.filter(doc => doc.z !== undefined && isDocInView(doc, otherBounds))); // if not, then why not snap to floating docs @@ -1739,7 +1735,7 @@ export class CollectionFreeFormView extends CollectionSubView<Partial<collection              onContextMenu={this.onContextMenu}              style={{                  pointerEvents: this.props.Document.type === DocumentType.MARKER ? "none" :  // bcz: ugh.. this is here to prevent markers, which render as freeform views, from grabbing events -- need a better approach. -                    this.backgroundEvents ? "all" : this.props.pointerEvents?.() as any, +                    this.props.pointerEvents?.() as any,                  transform: `scale(${this.contentScaling || 1})`,                  width: `${100 / (this.contentScaling || 1)}%`,                  height: this.isAnnotationOverlay && this.Document.scrollHeight ? NumCast(this.Document.scrollHeight) : `${100 / (this.contentScaling || 1)}%`// : this.isAnnotationOverlay ? (this.Document.scrollHeight ? this.Document.scrollHeight : "100%") : this.props.PanelHeight() @@ -1767,7 +1763,7 @@ export class CollectionFreeFormView extends CollectionSubView<Partial<collection                      </svg>                  </div>} -            {this.props.Document._isGroup && SnappingManager.GetIsDragging() && (this.ChildDrag || this.props.layerProvider?.(this.props.Document) === false) ? +            {this.props.Document._isGroup && SnappingManager.GetIsDragging() && this.ChildDrag ?                  <div className="collectionFreeForm-groupDropper" ref={this.createGroupEventsTarget} style={{                      width: this.ChildDrag ? "10000" : "100%",                      height: this.ChildDrag ? "10000" : "100%", diff --git a/src/client/views/collections/collectionFreeForm/MarqueeView.tsx b/src/client/views/collections/collectionFreeForm/MarqueeView.tsx index 5f303b428..1c4d47d57 100644 --- a/src/client/views/collections/collectionFreeForm/MarqueeView.tsx +++ b/src/client/views/collections/collectionFreeForm/MarqueeView.tsx @@ -28,7 +28,6 @@ import { CollectionView } from "../CollectionView";  import { MarqueeOptionsMenu } from "./MarqueeOptionsMenu";  import "./MarqueeView.scss";  import React = require("react"); -import { StyleLayers } from "../../StyleProvider";  import { TreeView } from "../TreeView";  import { VideoBox } from "../../nodes/VideoBox";  import { ImageField, WebField } from "../../../../fields/URLField"; @@ -348,7 +347,7 @@ export class MarqueeView extends React.Component<SubCollectionViewProps & Marque          this.hideMarquee();      } -    getCollection = action((selected: Doc[], creator: Opt<(documents: Array<Doc>, options: DocumentOptions, id?: string) => Doc>, layers: string[], makeGroup: Opt<boolean>) => { +    getCollection = action((selected: Doc[], creator: Opt<(documents: Array<Doc>, options: DocumentOptions, id?: string) => Doc>, makeGroup: Opt<boolean>) => {          const newCollection = creator ? creator(selected, { title: "nested stack", }) : ((doc: Doc) => {              Doc.GetProto(doc).data = new List<Doc>(selected);              Doc.GetProto(doc).title = makeGroup ? "grouping" : "nested freeform"; @@ -357,7 +356,6 @@ export class MarqueeView extends React.Component<SubCollectionViewProps & Marque              return doc;          })(Doc.MakeCopy(Doc.UserDoc().emptyCollection as Doc, true));          newCollection.system = undefined; -        newCollection._layerTags = new List<string>(layers);          newCollection._width = this.Bounds.width;          newCollection._height = this.Bounds.height;          newCollection._isGroup = makeGroup; @@ -437,7 +435,7 @@ export class MarqueeView extends React.Component<SubCollectionViewProps & Marque              }));              this.props.removeDocument?.(selected);          } -        const newCollection = this.getCollection(selected, (e as KeyboardEvent)?.key === "t" ? Docs.Create.StackingDocument : undefined, [], group); +        const newCollection = this.getCollection(selected, (e as KeyboardEvent)?.key === "t" ? Docs.Create.StackingDocument : undefined, group);          this.props.addDocument?.(newCollection);          this.props.selectDocuments([newCollection]);          MarqueeOptionsMenu.Instance.fadeOut(true); @@ -531,7 +529,7 @@ export class MarqueeView extends React.Component<SubCollectionViewProps & Marque      @action      background = (e: KeyboardEvent | React.PointerEvent | undefined) => { -        const newCollection = this.getCollection([], undefined, [StyleLayers.Background], undefined); +        const newCollection = this.getCollection([], undefined, undefined);          this.props.addDocument?.(newCollection);          MarqueeOptionsMenu.Instance.fadeOut(true);          this.hideMarquee(); @@ -617,7 +615,7 @@ export class MarqueeView extends React.Component<SubCollectionViewProps & Marque                  (this.touchesLine(bounds) || this.boundingShape(bounds)) && selection.push(doc);              }          }; -        this.props.activeDocuments().filter(doc => this.props.layerProvider?.(doc) !== false && !doc.z).map(selectFunc); +        this.props.activeDocuments().filter(doc => !doc.z && !doc._lockedPosition).map(selectFunc);          if (!selection.length && selectBackgrounds) this.props.activeDocuments().filter(doc => doc.z === undefined).map(selectFunc);          if (!selection.length) this.props.activeDocuments().filter(doc => doc.z !== undefined).map(selectFunc);          return selection; diff --git a/src/client/views/collections/collectionLinear/CollectionLinearView.tsx b/src/client/views/collections/collectionLinear/CollectionLinearView.tsx index c615bfb8e..bec582dcd 100644 --- a/src/client/views/collections/collectionLinear/CollectionLinearView.tsx +++ b/src/client/views/collections/collectionLinear/CollectionLinearView.tsx @@ -155,7 +155,6 @@ export class CollectionLinearView extends CollectionSubView() {                  renderDepth={this.props.renderDepth + 1}                  focus={emptyFunction}                  styleProvider={this.props.styleProvider} -                layerProvider={this.props.layerProvider}                  docViewPath={returnEmptyDoclist}                  whenChildContentsActiveChanged={emptyFunction}                  bringToFront={emptyFunction} diff --git a/src/client/views/collections/collectionMulticolumn/CollectionMulticolumnView.tsx b/src/client/views/collections/collectionMulticolumn/CollectionMulticolumnView.tsx index 6929a1cd8..92f9b2f49 100644 --- a/src/client/views/collections/collectionMulticolumn/CollectionMulticolumnView.tsx +++ b/src/client/views/collections/collectionMulticolumn/CollectionMulticolumnView.tsx @@ -219,7 +219,6 @@ export class CollectionMulticolumnView extends CollectionSubView() {              Document={layout}              DataDoc={layout.resolvedDataDoc as Doc}              styleProvider={this.props.styleProvider} -            layerProvider={this.props.layerProvider}              docViewPath={this.props.docViewPath}              LayoutTemplate={this.props.childLayoutTemplate}              LayoutTemplateString={this.props.childLayoutString} diff --git a/src/client/views/collections/collectionMulticolumn/CollectionMultirowView.tsx b/src/client/views/collections/collectionMulticolumn/CollectionMultirowView.tsx index 7e2b83230..4c4054b09 100644 --- a/src/client/views/collections/collectionMulticolumn/CollectionMultirowView.tsx +++ b/src/client/views/collections/collectionMulticolumn/CollectionMultirowView.tsx @@ -218,7 +218,6 @@ export class CollectionMultirowView extends CollectionSubView() {              Document={layout}              DataDoc={layout.resolvedDataDoc as Doc}              styleProvider={this.props.styleProvider} -            layerProvider={this.props.layerProvider}              docViewPath={this.props.docViewPath}              LayoutTemplate={this.props.childLayoutTemplate}              LayoutTemplateString={this.props.childLayoutString} diff --git a/src/client/views/collections/collectionSchema/CollectionSchemaView.tsx b/src/client/views/collections/collectionSchema/CollectionSchemaView.tsx index a93762ea4..b731479a5 100644 --- a/src/client/views/collections/collectionSchema/CollectionSchemaView.tsx +++ b/src/client/views/collections/collectionSchema/CollectionSchemaView.tsx @@ -417,7 +417,6 @@ export class CollectionSchemaView extends CollectionSubView() {                      docRangeFilters={this.childDocRangeFilters}                      searchFilterDocs={this.searchFilterDocs}                      styleProvider={DefaultStyleProvider} -                    layerProvider={undefined}                      docViewPath={returnEmptyDoclist}                      ContainingCollectionDoc={this.props.CollectionView?.props.Document}                      ContainingCollectionView={this.props.CollectionView} diff --git a/src/client/views/collections/collectionSchema/SchemaTable.tsx b/src/client/views/collections/collectionSchema/SchemaTable.tsx index 605481ddf..bea5b3be6 100644 --- a/src/client/views/collections/collectionSchema/SchemaTable.tsx +++ b/src/client/views/collections/collectionSchema/SchemaTable.tsx @@ -573,7 +573,6 @@ export class SchemaTable extends React.Component<SchemaTableProps> {                          Document={this._showDoc}                          DataDoc={this._showDataDoc}                          styleProvider={DefaultStyleProvider} -                        layerProvider={undefined}                          docViewPath={returnEmptyDoclist}                          freezeDimensions={true}                          focus={DocUtils.DefaultFocus} diff --git a/src/client/views/linking/LinkPopup.tsx b/src/client/views/linking/LinkPopup.tsx index c8be9069c..4b33ef8ae 100644 --- a/src/client/views/linking/LinkPopup.tsx +++ b/src/client/views/linking/LinkPopup.tsx @@ -67,7 +67,7 @@ export class LinkPopup extends React.Component<LinkPopupProps> {                      <input defaultValue={""} autoComplete="off" type="text" placeholder="Search for Document..." id="search-input"                          className="linkPopup-searchBox searchBox-input" /> */} -                    <SearchBox  +                    <SearchBox                          Document={CurrentUserUtils.MySearchPanelDoc}                          DataDoc={CurrentUserUtils.MySearchPanelDoc}                          linkFrom={linkDoc} @@ -83,7 +83,6 @@ export class LinkPopup extends React.Component<LinkPopupProps> {                          pinToPres={emptyFunction}                          rootSelected={returnTrue}                          styleProvider={DefaultStyleProvider} -                        layerProvider={undefined}                          removeDocument={undefined}                          ScreenToLocalTransform={Transform.Identity}                          PanelWidth={this.getPWidth} diff --git a/src/client/views/nodes/AudioBox.tsx b/src/client/views/nodes/AudioBox.tsx index e28e5b453..d97cb6f84 100644 --- a/src/client/views/nodes/AudioBox.tsx +++ b/src/client/views/nodes/AudioBox.tsx @@ -654,7 +654,7 @@ export class AudioBox extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProp              className="audiobox-container"              onContextMenu={this.specificContextMenu}              onClick={!this.path && !this._recorder ? this.recordAudioAnnotation : undefined} -            style={{ pointerEvents: this.props.layerProvider?.(this.layoutDoc) === false ? "none" : undefined }} +            style={{ pointerEvents: this.layoutDoc._lockedPosition ? "none" : undefined }}          >              {!this.path ? this.recordingControls : this.playbackControls}          </div>; diff --git a/src/client/views/nodes/CollectionFreeFormDocumentView.tsx b/src/client/views/nodes/CollectionFreeFormDocumentView.tsx index edadd59c0..5a0ab9110 100644 --- a/src/client/views/nodes/CollectionFreeFormDocumentView.tsx +++ b/src/client/views/nodes/CollectionFreeFormDocumentView.tsx @@ -21,7 +21,6 @@ import React = require("react");  export interface CollectionFreeFormDocumentViewProps extends DocumentViewProps {      dataProvider?: (doc: Doc, replica: string) => { x: number, y: number, zIndex?: number, opacity?: number, highlight?: boolean, z: number, transition?: string } | undefined;      sizeProvider?: (doc: Doc, replica: string) => { width: number, height: number } | undefined; -    layerProvider: ((doc: Doc, assign?: boolean) => boolean) | undefined;      renderCutoffProvider: (doc: Doc) => boolean;      zIndex?: number;      highlight?: boolean; @@ -159,7 +158,6 @@ export class CollectionFreeFormDocumentView extends DocComponent<CollectionFreeF              ...this.props,              CollectionFreeFormDocumentView: this.returnThis,              styleProvider: this.styleProvider, -            layerProvider: this.props.layerProvider,              ScreenToLocalTransform: this.screenToLocalTransform,              PanelWidth: this.panelWidth,              PanelHeight: this.panelHeight, diff --git a/src/client/views/nodes/DocumentView.tsx b/src/client/views/nodes/DocumentView.tsx index f30d093a1..c999b3224 100644 --- a/src/client/views/nodes/DocumentView.tsx +++ b/src/client/views/nodes/DocumentView.tsx @@ -37,7 +37,7 @@ import { DocComponent } from "../DocComponent";  import { EditableView } from '../EditableView';  import { InkingStroke } from "../InkingStroke";  import { LightboxView } from "../LightboxView"; -import { StyleLayers, StyleProp } from "../StyleProvider"; +import { StyleProp } from "../StyleProvider";  import { CollectionFreeFormDocumentView } from "./CollectionFreeFormDocumentView";  import { DocumentContentsView } from "./DocumentContentsView";  import { DocumentLinksButton } from './DocumentLinksButton'; @@ -123,7 +123,6 @@ export interface DocumentViewSharedProps {      PanelHeight: () => number;      docViewPath: () => DocumentView[];      dataTransition?: string; // specifies animation transition - used by collectionPile and potentially other layout engines when changing the size of documents so that the change won't be abrupt -    layerProvider: undefined | ((doc: Doc, assign?: boolean) => boolean);      styleProvider: Opt<StyleProviderFunc>;      focus: DocFocusFunc;      fitWidth?: (doc: Doc) => boolean; @@ -474,7 +473,7 @@ export class DocumentViewInternal extends DocComponent<DocumentViewInternalProps              (Math.abs(e.clientX - this._downX) < Utils.DRAG_THRESHOLD && Math.abs(e.clientY - this._downY) < Utils.DRAG_THRESHOLD)) {              let stopPropagate = true;              let preventDefault = true; -            !StrListCast(this.props.Document._layerTags).includes(StyleLayers.Background) && (this.rootDoc._raiseWhenDragged === undefined ? Doc.UserDoc()._raiseWhenDragged : this.rootDoc._raiseWhenDragged) && this.props.bringToFront(this.rootDoc); +            (this.rootDoc._raiseWhenDragged === undefined ? Doc.UserDoc()._raiseWhenDragged : this.rootDoc._raiseWhenDragged) && this.props.bringToFront(this.rootDoc);              if (this._doubleTap && (this.props.Document.type !== DocumentType.FONTICON || this.onDoubleClickHandler)) {// && !this.onClickHandler?.script) { // disable double-click to show full screen for things that have an on click behavior since clicking them twice can be misinterpreted as a double click                  if (this._timeout) {                      clearTimeout(this._timeout); diff --git a/src/client/views/nodes/FilterBox.tsx b/src/client/views/nodes/FilterBox.tsx index 78adf63cb..a47e17dfc 100644 --- a/src/client/views/nodes/FilterBox.tsx +++ b/src/client/views/nodes/FilterBox.tsx @@ -423,7 +423,6 @@ export class FilterBox extends ViewBoxBaseComponent<FieldViewProps>() {                      treeViewHideHeaderFields={false}                      dontRegisterView={true}                      styleProvider={this.FilterStyleProvider} -                    layerProvider={this.props.layerProvider}                      docViewPath={this.props.docViewPath}                      scriptContext={this.props.scriptContext}                      moveDocument={returnFalse} diff --git a/src/client/views/nodes/ImageBox.tsx b/src/client/views/nodes/ImageBox.tsx index e7c43e5cd..3b04aa807 100644 --- a/src/client/views/nodes/ImageBox.tsx +++ b/src/client/views/nodes/ImageBox.tsx @@ -379,7 +379,7 @@ export class ImageBox extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProp              style={{                  width: this.props.PanelWidth() ? undefined : `100%`,                  height: this.props.PanelWidth() ? undefined : `100%`, -                pointerEvents: this.props.layerProvider?.(this.layoutDoc) === false ? "none" : undefined, +                pointerEvents: this.layoutDoc._lockedPosition ? "none" : undefined,                  borderRadius              }} >              <CollectionFreeFormView {...OmitKeys(this.props, ["NativeWidth", "NativeHeight", "setContentView"]).omit} diff --git a/src/client/views/nodes/KeyValuePair.tsx b/src/client/views/nodes/KeyValuePair.tsx index 881cbf2bb..80def3025 100644 --- a/src/client/views/nodes/KeyValuePair.tsx +++ b/src/client/views/nodes/KeyValuePair.tsx @@ -60,7 +60,6 @@ export class KeyValuePair extends React.Component<KeyValuePairProps> {              docRangeFilters: returnEmptyFilter,              searchFilterDocs: returnEmptyDoclist,              styleProvider: DefaultStyleProvider, -            layerProvider: undefined,              docViewPath: returnEmptyDoclist,              ContainingCollectionView: undefined,              ContainingCollectionDoc: undefined, diff --git a/src/client/views/nodes/LinkAnchorBox.tsx b/src/client/views/nodes/LinkAnchorBox.tsx index 437d29f39..7fd289a97 100644 --- a/src/client/views/nodes/LinkAnchorBox.tsx +++ b/src/client/views/nodes/LinkAnchorBox.tsx @@ -89,7 +89,6 @@ export class LinkAnchorBox extends ViewBoxBaseComponent<FieldViewProps>() {      openLinkTargetOnRight = (e: React.MouseEvent) => {          const alias = Doc.MakeAlias(Cast(this.layoutDoc[this.fieldKey], Doc, null));          alias._isLinkButton = undefined; -        alias._layerTags = undefined;          alias.layoutKey = "layout";          this.props.addDocTab(alias, "add:right");      } diff --git a/src/client/views/nodes/LinkDocPreview.tsx b/src/client/views/nodes/LinkDocPreview.tsx index 375434933..ba515fb89 100644 --- a/src/client/views/nodes/LinkDocPreview.tsx +++ b/src/client/views/nodes/LinkDocPreview.tsx @@ -179,7 +179,6 @@ export class LinkDocPreview extends React.Component<LinkDocPreviewProps> {                              moveDocument={returnFalse}                              rootSelected={returnFalse}                              styleProvider={this.props.docProps?.styleProvider} -                            layerProvider={this.props.docProps?.layerProvider}                              docViewPath={returnEmptyDoclist}                              ScreenToLocalTransform={Transform.Identity}                              isDocumentActive={returnFalse} diff --git a/src/client/views/nodes/VideoBox.tsx b/src/client/views/nodes/VideoBox.tsx index 3b4c94562..c350e3139 100644 --- a/src/client/views/nodes/VideoBox.tsx +++ b/src/client/views/nodes/VideoBox.tsx @@ -809,7 +809,7 @@ export class VideoBox extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProp          const borderRadius = borderRad?.includes("px") ? `${Number(borderRad.split("px")[0]) / this.scaling()}px` : borderRad;          return (<div className="videoBox" onContextMenu={this.specificContextMenu} ref={this._mainCont}              style={{ -                pointerEvents: this.props.layerProvider?.(this.layoutDoc) === false ? "none" : undefined, +                pointerEvents: this.layoutDoc._lockedPosition ? "none" : undefined,                  borderRadius,                  overflow: this.props.docViewPath?.().slice(-1)[0].fitWidth ? "auto" : undefined              }} onWheel={e => { e.stopPropagation(); e.preventDefault(); }}> diff --git a/src/client/views/nodes/WebBox.tsx b/src/client/views/nodes/WebBox.tsx index 20e01be05..445df8ddd 100644 --- a/src/client/views/nodes/WebBox.tsx +++ b/src/client/views/nodes/WebBox.tsx @@ -74,7 +74,7 @@ export class WebBox extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProps      @computed get allAnnotations() { return DocListCast(this.dataDoc[this.annotationKey]); }      @computed get inlineTextAnnotations() { return this.allAnnotations.filter(a => a.textInlineAnnotations); }      @computed get webField() { return Cast(this.dataDoc[this.props.fieldKey], WebField)?.url; } -    @computed get webThumb() { return this.props.thumbShown?.() && ImageCast(this.layoutDoc["thumb-frozen"], ImageCast(this.layoutDoc.thumbScrollTop === this.layoutDoc._scrollTop ? this.layoutDoc.thumb : undefined))?.url } +    @computed get webThumb() { return this.props.thumbShown?.() && ImageCast(this.layoutDoc["thumb-frozen"], ImageCast(this.layoutDoc.thumbScrollTop === this.layoutDoc._scrollTop ? this.layoutDoc.thumb : undefined))?.url; }      constructor(props: any) {          super(props); @@ -134,7 +134,7 @@ export class WebBox extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProps                          returnedfilename => setTimeout(action(() => {                              this.lockout = false;                              this.layoutDoc.thumb = new ImageField(returnedfilename); -                            this.layoutDoc.thumbScrollTop = scrollTop +                            this.layoutDoc.thumbScrollTop = scrollTop;                          }), 500));                  })                  .catch(function (error: any) { @@ -717,7 +717,7 @@ export class WebBox extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProps      pointerEvents = () => !this._draggingSidebar && this.props.isContentActive() && this.props.pointerEvents?.() !== "none" && !MarqueeOptionsMenu.Instance.isShown() ? "all" : SnappingManager.GetIsDragging() ? undefined : "none";      annotationPointerEvents = () => this._isAnnotating || SnappingManager.GetIsDragging() ? "all" : "none";      render() { -        const pointerEvents = this.props.layerProvider?.(this.layoutDoc) === false ? "none" : this.props.pointerEvents?.() as any; +        const pointerEvents = this.layoutDoc._lockedPosition ? "none" : this.props.pointerEvents?.() as any;          const previewScale = this._previewNativeWidth ? 1 - this.sidebarWidth() / this._previewNativeWidth : 1;          const scale = previewScale * (this.props.scaling?.() || 1);          const renderAnnotations = (docFilters?: () => string[]) => diff --git a/src/client/views/nodes/formattedText/DashDocView.tsx b/src/client/views/nodes/formattedText/DashDocView.tsx index 364be461f..1d8e3a2cf 100644 --- a/src/client/views/nodes/formattedText/DashDocView.tsx +++ b/src/client/views/nodes/formattedText/DashDocView.tsx @@ -182,7 +182,6 @@ export class DashDocViewInternal extends React.Component<IDashDocViewInternal> {                      removeDocument={this.removeDoc}                      isDocumentActive={returnFalse}                      isContentActive={this._textBox.props.isContentActive} -                    layerProvider={this._textBox.props.layerProvider}                      styleProvider={this._textBox.props.styleProvider}                      docViewPath={this._textBox.props.docViewPath}                      ScreenToLocalTransform={this.getDocTransform} diff --git a/src/client/views/nodes/formattedText/FormattedTextBox.tsx b/src/client/views/nodes/formattedText/FormattedTextBox.tsx index 29117794e..f2a222cee 100644 --- a/src/client/views/nodes/formattedText/FormattedTextBox.tsx +++ b/src/client/views/nodes/formattedText/FormattedTextBox.tsx @@ -1630,7 +1630,7 @@ export class FormattedTextBox extends ViewBoxAnnotatableComponent<(FieldViewProp          const active = this.props.isContentActive();          const scale = (this.props.scaling?.() || 1) * NumCast(this.layoutDoc._viewScale, 1);          const rounded = StrCast(this.layoutDoc.borderRounding) === "100%" ? "-rounded" : ""; -        const interactive = (CurrentUserUtils.SelectedTool === InkTool.None || SnappingManager.GetIsDragging()) && (this.layoutDoc.z || this.props.layerProvider?.(this.layoutDoc) !== false); +        const interactive = (CurrentUserUtils.SelectedTool === InkTool.None || SnappingManager.GetIsDragging()) && (this.layoutDoc.z || !this.layoutDoc._lockedPosition);          if (!selected && FormattedTextBoxComment.textBox === this) setTimeout(FormattedTextBoxComment.Hide);          const minimal = this.props.ignoreAutoHeight;          const paddingX = NumCast(this.layoutDoc._xMargin, this.props.xPadding || 0); diff --git a/src/client/views/nodes/trails/PresBox.tsx b/src/client/views/nodes/trails/PresBox.tsx index 820d7ef96..64f5a296f 100644 --- a/src/client/views/nodes/trails/PresBox.tsx +++ b/src/client/views/nodes/trails/PresBox.tsx @@ -700,7 +700,7 @@ export class PresBox extends ViewBoxBaseComponent<FieldViewProps>() {      removeDocument = (doc: Doc) => Doc.RemoveDocFromList(this.rootDoc, this.fieldKey, doc);      getTransform = () => this.props.ScreenToLocalTransform().translate(-5, -65);// listBox padding-left and pres-box-cont minHeight      panelHeight = () => this.props.PanelHeight() - 40; -    isContentActive = (outsideReaction?: boolean) => ((CurrentUserUtils.SelectedTool === InkTool.None && this.props.layerProvider?.(this.layoutDoc) !== false) && +    isContentActive = (outsideReaction?: boolean) => ((CurrentUserUtils.SelectedTool === InkTool.None && !this.layoutDoc._lockedPosition) &&          (this.layoutDoc.forceActive || this.props.isSelected(outsideReaction) || this._isChildActive || this.props.renderDepth === 0) ? true : false)      /** diff --git a/src/client/views/nodes/trails/PresElementBox.tsx b/src/client/views/nodes/trails/PresElementBox.tsx index f4dc9b615..ef918d991 100644 --- a/src/client/views/nodes/trails/PresElementBox.tsx +++ b/src/client/views/nodes/trails/PresElementBox.tsx @@ -80,7 +80,6 @@ export class PresElementBox extends ViewBoxBaseComponent<FieldViewProps>() {                      Document={this.targetDoc}                      DataDoc={this.targetDoc[DataSym] !== this.targetDoc && this.targetDoc[DataSym]}                      styleProvider={this.styleProvider} -                    layerProvider={this.props.layerProvider}                      docViewPath={returnEmptyDoclist}                      rootSelected={returnTrue}                      addDocument={returnFalse} diff --git a/src/client/views/pdf/Annotation.tsx b/src/client/views/pdf/Annotation.tsx index fb2e33e2a..5bdce273d 100644 --- a/src/client/views/pdf/Annotation.tsx +++ b/src/client/views/pdf/Annotation.tsx @@ -26,7 +26,7 @@ export              {DocListCast(this.props.anno.textInlineAnnotations).map(a =>                  <RegionAnnotation pointerEvents={this.props.pointerEvents} {...this.props} document={a} key={a[Id]} />              )} -        </div> +        </div>;      }  } diff --git a/src/client/views/search/SearchBox.tsx b/src/client/views/search/SearchBox.tsx index 2905e96d9..152b7bbcb 100644 --- a/src/client/views/search/SearchBox.tsx +++ b/src/client/views/search/SearchBox.tsx @@ -127,7 +127,7 @@ export class SearchBox extends ViewBoxBaseComponent<SearchBoxProps>() {      static foreachRecursiveDoc(docs: Doc[], func: (depth: number, doc: Doc) => void) {          let newarray: Doc[] = [];          var depth = 0; -        let visited: Doc[] = []; +        const visited: Doc[] = [];          while (docs.length > 0) {              newarray = [];              docs.filter(d => d && !visited.includes(d)).forEach(d => { diff --git a/src/fields/Doc.ts b/src/fields/Doc.ts index 9de8d0831..194b3ba27 100644 --- a/src/fields/Doc.ts +++ b/src/fields/Doc.ts @@ -1026,7 +1026,7 @@ export namespace Doc {          if (status === DocBrushStatus.unbrushed) {              const lastBrushed = Array.from(brushManager.BrushedDoc.keys()).lastElement();              if (lastBrushed) { -                for (var link of LinkManager.Instance.getAllDirectLinks(lastBrushed)) { +                for (const link of LinkManager.Instance.getAllDirectLinks(lastBrushed)) {                      const a1 = Cast(link.anchor1, Doc, null);                      const a2 = Cast(link.anchor2, Doc, null);                      if (Doc.AreProtosEqual(a1, doc) || Doc.AreProtosEqual(a2, doc) || diff --git a/src/mobile/AudioUpload.tsx b/src/mobile/AudioUpload.tsx index 88221732e..418464f0e 100644 --- a/src/mobile/AudioUpload.tsx +++ b/src/mobile/AudioUpload.tsx @@ -96,7 +96,6 @@ export class AudioUpload extends React.Component {                          isDocumentActive={returnTrue}                          isContentActive={emptyFunction}                          focus={emptyFunction} -                        layerProvider={undefined}                          styleProvider={() => "rgba(0,0,0,0)"}                          docViewPath={returnEmptyDoclist}                          whenChildContentsActiveChanged={emptyFunction} diff --git a/src/mobile/MobileInterface.tsx b/src/mobile/MobileInterface.tsx index cfcc48608..78ec706d7 100644 --- a/src/mobile/MobileInterface.tsx +++ b/src/mobile/MobileInterface.tsx @@ -214,7 +214,6 @@ export class MobileInterface extends React.Component {                      isContentActive={emptyFunction}                      focus={DocUtils.DefaultFocus}                      styleProvider={this.whitebackground} -                    layerProvider={undefined}                      docViewPath={returnEmptyDoclist}                      whenChildContentsActiveChanged={emptyFunction}                      bringToFront={emptyFunction} diff --git a/src/server/server_Initialization.ts b/src/server/server_Initialization.ts index bdea57cb2..fd000a83c 100644 --- a/src/server/server_Initialization.ts +++ b/src/server/server_Initialization.ts @@ -195,7 +195,7 @@ function proxyServe(req: any, requrl: string, response: any) {                  console.log("EROR?: ", e);              }          } else req.pipe(request(requrl)).pipe(response); -    } +    };      retrieveHTTPBody = () => {          req.headers.cookie = "";          req.pipe(request(requrl)) | 
