diff options
| author | bobzel <zzzman@gmail.com> | 2020-12-12 22:52:26 -0500 | 
|---|---|---|
| committer | bobzel <zzzman@gmail.com> | 2020-12-12 22:52:26 -0500 | 
| commit | 890dd1c3d8d6a00cf3111972c20f7b5b9cb09085 (patch) | |
| tree | e5a3b38b32771dd1d2162ca8cb30d82700423f9d /src/client | |
| parent | 9ca004669a7882123277eb46cad8e86b28305266 (diff) | |
made conentScaling a DocumentView-only prop
Diffstat (limited to 'src/client')
22 files changed, 53 insertions, 49 deletions
| diff --git a/src/client/views/MainView.tsx b/src/client/views/MainView.tsx index d55d43623..b8c7a1a73 100644 --- a/src/client/views/MainView.tsx +++ b/src/client/views/MainView.tsx @@ -465,7 +465,6 @@ export class MainView extends React.Component {                      removeDocument={this.remButtonDoc}                      onClick={undefined}                      ScreenToLocalTransform={this.buttonBarXf} -                    ContentScaling={returnOne}                      PanelWidth={this.flyoutWidthFunc}                      PanelHeight={this.getContentsHeight}                      renderDepth={0} @@ -529,7 +528,6 @@ export class MainView extends React.Component {                  styleProvider={DefaultStyleProvider}                  removeDocument={undefined}                  ScreenToLocalTransform={Transform.Identity} -                ContentScaling={returnOne}                  PanelWidth={this.getPWidth}                  PanelHeight={this.getPHeight}                  renderDepth={0} @@ -568,7 +566,6 @@ export class MainView extends React.Component {                      focus={returnFalse}                      PanelWidth={() => 500}                      PanelHeight={() => 800} -                    ContentScaling={returnOne}                      docFilters={returnEmptyFilter}                      docRangeFilters={returnEmptyFilter}                      searchFilterDocs={returnEmptyDoclist} @@ -634,7 +631,6 @@ export class MainView extends React.Component {                              focus={returnFalse}                              PanelWidth={() => 500}                              PanelHeight={() => 800} -                            ContentScaling={returnOne}                              docFilters={returnEmptyFilter}                              docRangeFilters={returnEmptyFilter}                              searchFilterDocs={returnEmptyDoclist} diff --git a/src/client/views/StyleProvider.tsx b/src/client/views/StyleProvider.tsx index 6a534a979..128c3cb96 100644 --- a/src/client/views/StyleProvider.tsx +++ b/src/client/views/StyleProvider.tsx @@ -16,6 +16,7 @@ import React = require("react");  import Color = require('color');  import { listSpec } from '../../fields/Schema';  import { MainView } from './MainView'; +import { FieldViewProps } from './nodes/FieldView';  export enum StyleLayers {      Background = "background" @@ -59,10 +60,17 @@ function toggleBackground(doc: Doc) {      }), "toggleBackground");  } +export function testDocProps(toBeDetermined: any): toBeDetermined is DocumentViewProps { +    if (toBeDetermined.ContentScaling) { +        return true; +    } +    return false; +} +  //  // a preliminary implementation of a dash style sheet for setting rendering properties of documents nested within a Tab  //  -export function DefaultStyleProvider(doc: Opt<Doc>, props: Opt<DocumentViewProps>, property: string): any { +export function DefaultStyleProvider(doc: Opt<Doc>, props: Opt<FieldViewProps | DocumentViewProps>, property: string): any {      switch (property.split(":")[0]) {          case StyleProp.DocContents: return undefined;          case StyleProp.WidgetColor: return darkScheme() ? "lightgrey" : "dimgrey"; @@ -121,7 +129,7 @@ export function DefaultStyleProvider(doc: Opt<Doc>, props: Opt<DocumentViewProps                      `${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 -                        backgroundHalo(doc) && doc.type !== DocumentType.INK ? (`${props?.styleProvider?.(doc, props, StyleProp.BackgroundColor)} ${StrCast(doc.boxShadow, `0vw 0vw ${(isBackground() ? 100 : 50) / (props?.ContentScaling() || 1)}px`)}`) :  // if it's just in a cluster, make the shadown roughly match the cluster border extent +                        backgroundHalo(doc) && doc.type !== DocumentType.INK ? (`${props?.styleProvider?.(doc, props, StyleProp.BackgroundColor)} ${StrCast(doc.boxShadow, `0vw 0vw ${(isBackground() ? 100 : 50) / ((testDocProps(props) && props?.ContentScaling()) || 1)}px`)}`) :  // if it's just in a cluster, make the shadown roughly match the cluster border extent                              isBackground() ? undefined :  // if it's a background & has a cluster color, make the shadow spread really big                                  StrCast(doc.boxShadow, "");              } diff --git a/src/client/views/TemplateMenu.tsx b/src/client/views/TemplateMenu.tsx index 203274681..ddba71dd2 100644 --- a/src/client/views/TemplateMenu.tsx +++ b/src/client/views/TemplateMenu.tsx @@ -139,7 +139,6 @@ export class TemplateMenu extends React.Component<TemplateMenuProps> {                  dropAction={undefined}                  active={returnTrue}                  parentActive={returnFalse} -                ContentScaling={returnOne}                  bringToFront={emptyFunction}                  focus={emptyFunction}                  whenActiveChanged={emptyFunction} diff --git a/src/client/views/collections/CollectionStackingView.tsx b/src/client/views/collections/CollectionStackingView.tsx index e8165f673..510e47b20 100644 --- a/src/client/views/collections/CollectionStackingView.tsx +++ b/src/client/views/collections/CollectionStackingView.tsx @@ -29,6 +29,7 @@ import { CollectionStackingViewFieldColumn } from "./CollectionStackingViewField  import { CollectionSubView } from "./CollectionSubView";  import { CollectionViewType } from "./CollectionView";  import { StyleProp } from "../StyleProvider"; +import { FieldViewProps } from "../nodes/FieldView";  const _global = (window /* browser */ || global /* node */) as any;  type StackingDocument = makeInterface<[typeof collectionSchema, typeof documentSchema]>; @@ -61,7 +62,7 @@ export class CollectionStackingView extends CollectionSubView<StackingDocument,      @computed get numGroupColumns() { return this.isStackingView ? Math.max(1, this.Sections.size + (this.showAddAGroup ? 1 : 0)) : 1; }      @computed get showAddAGroup() { return (this.pivotField && (this.chromeStatus !== 'view-mode' && this.chromeStatus !== 'disabled')); }      @computed get columnWidth() { -        return Math.min(this.props.PanelWidth() / this.props.ContentScaling() /* / NumCast(this.layoutDoc._viewScale, 1)*/ - 2 * this.xMargin, +        return Math.min(this.props.PanelWidth() /* / NumCast(this.layoutDoc._viewScale, 1)*/ - 2 * this.xMargin,              this.isStackingView ? Number.MAX_VALUE : this.layoutDoc._columnWidth === -1 ? this.props.PanelWidth() - 2 * this.xMargin : NumCast(this.layoutDoc._columnWidth, 250));      }      @computed get NodeWidth() { return this.props.PanelWidth() - this.gridGap; } @@ -189,7 +190,7 @@ export class CollectionStackingView extends CollectionSubView<StackingDocument,      getDisplayDoc(doc: Doc, dxf: () => Transform, width: () => number) {          const dataDoc = (!doc.isTemplateDoc && !doc.isTemplateForField && !doc.PARAMS) ? undefined : this.props.DataDoc;          const height = () => this.getDocHeight(doc); -        const styleProvider = (doc: Doc | undefined, props: Opt<DocumentViewProps>, property: string) => { +        const styleProvider = (doc: Doc | undefined, props: Opt<DocumentViewProps | FieldViewProps>, property: string) => {              if (property === StyleProp.Opacity && doc) {                  if (this.props.childOpacity) {                      return this.props.childOpacity(); diff --git a/src/client/views/collections/TabDocView.tsx b/src/client/views/collections/TabDocView.tsx index 8b5143013..fe929abc5 100644 --- a/src/client/views/collections/TabDocView.tsx +++ b/src/client/views/collections/TabDocView.tsx @@ -33,6 +33,7 @@ import { List } from '../../../fields/List';  import { DocumentType } from '../../documents/DocumentTypes';  import Color = require('color');  import { StyleProp, DefaultStyleProvider, DefaultLayerProvider, StyleLayers } from '../StyleProvider'; +import { FieldViewProps } from '../nodes/FieldView';  const _global = (window /* browser */ || global /* node */) as any;  interface TabDocViewProps { @@ -352,7 +353,6 @@ export class TabDocView extends React.Component<TabDocViewProps> {                      addDocument={returnFalse}                      moveDocument={returnFalse}                      removeDocument={returnFalse} -                    ContentScaling={returnOne}                      PanelWidth={this.returnMiniSize}                      PanelHeight={this.returnMiniSize}                      ScreenToLocalTransform={this.ScreenToLocalTransform} @@ -389,7 +389,7 @@ export class TabDocView extends React.Component<TabDocViewProps> {      active = () => this._isActive; -    public static miniStyleProvider = (doc: Opt<Doc>, props: Opt<DocumentViewProps>, property: string): any => { +    public static miniStyleProvider = (doc: Opt<Doc>, props: Opt<DocumentViewProps | FieldViewProps>, property: string): any => {          if (doc) {              switch (property.split(":")[0]) {                  default: return DefaultStyleProvider(doc, props, property); diff --git a/src/client/views/collections/TreeView.tsx b/src/client/views/collections/TreeView.tsx index 843bec6de..11ff4ca3b 100644 --- a/src/client/views/collections/TreeView.tsx +++ b/src/client/views/collections/TreeView.tsx @@ -29,7 +29,8 @@ import { CollectionTreeView } from './CollectionTreeView';  import { CollectionView, CollectionViewType } from './CollectionView';  import "./TreeView.scss";  import React = require("react"); -import { StyleProp } from '../StyleProvider'; +import { StyleProp, testDocProps } from '../StyleProvider'; +import { FieldViewProps } from '../nodes/FieldView';  export interface TreeViewProps {      document: Doc; @@ -497,13 +498,13 @@ export class TreeView extends React.Component<TreeViewProps> {              e.preventDefault();          }      } -    titleStyleProvider = (doc: (Doc | undefined), props: Opt<DocumentViewProps>, property: string): any => { +    titleStyleProvider = (doc: (Doc | undefined), props: Opt<DocumentViewProps | FieldViewProps>, property: string): any => {          if (!doc || doc !== this.doc) return this.props?.treeView?.props.styleProvider?.(doc, props, property); // properties are inherited from the CollectionTreeView, not the hierarchical parent in the treeView          switch (property.split(":")[0]) {              case StyleProp.Opacity: return this.outlineMode ? undefined : 1;              case StyleProp.BackgroundColor: return StrCast(doc._backgroundColor, StrCast(doc.backgroundColor)); -            case StyleProp.DocContents: return !props?.treeViewDoc ? (null) : +            case StyleProp.DocContents: return testDocProps(props) && !props?.treeViewDoc ? (null) :                  <div className="treeView-label" style={{    // just render a title for a tree view label (identified by treeViewDoc being set in 'props')                      maxWidth: props?.PanelWidth() || undefined,                      background: props?.styleProvider?.(doc, props, StyleProp.BackgroundColor), @@ -513,7 +514,7 @@ export class TreeView extends React.Component<TreeViewProps> {              case StyleProp.Decorations: return (null);          }      } -    embeddedStyleProvider = (doc: (Doc | undefined), props: Opt<DocumentViewProps>, property: string): any => { +    embeddedStyleProvider = (doc: (Doc | undefined), props: Opt<DocumentViewProps | FieldViewProps>, property: string): any => {          if (property.startsWith(StyleProp.Decorations)) return (null);          return this.props?.treeView?.props.styleProvider?.(doc, props, property); // properties are inherited from the CollectionTreeView, not the hierarchical parent in the treeView      } diff --git a/src/client/views/collections/collectionFreeForm/CollectionFreeFormView.tsx b/src/client/views/collections/collectionFreeForm/CollectionFreeFormView.tsx index b8576681d..3f7eb24f8 100644 --- a/src/client/views/collections/collectionFreeForm/CollectionFreeFormView.tsx +++ b/src/client/views/collections/collectionFreeForm/CollectionFreeFormView.tsx @@ -49,6 +49,7 @@ import React = require("react");  import { CurrentUserUtils } from "../../../util/CurrentUserUtils";  import { StyleProp, StyleLayers } from "../../StyleProvider";  import { DocumentDecorations } from "../../DocumentDecorations"; +import { FieldViewProps } from "../../nodes/FieldView";  export const panZoomSchema = createSchema({      _panX: "number", @@ -116,7 +117,7 @@ export class CollectionFreeFormView extends CollectionSubView<PanZoomDocument, P      @computed get backgroundActive() { return this.props.layerProvider?.(this.layoutDoc) === false && (this.props.ContainingCollectionView?.active() || this.props.active()); }      @computed get fitToContentScaling() { return this.fitToContent ? NumCast(this.layoutDoc.fitToContentScaling, 1) : 1; }      @computed get fitToContent() { return (this.props.fitToBox || this.Document._fitToBox) && !this.isAnnotationOverlay; } -    @computed get parentScaling() { return this.props.ContentScaling && this.fitToContent ? this.props.ContentScaling() : 1; } +    @computed get parentScaling() { return 1; }      @computed get contentBounds() { return aggregateBounds(this._layoutElements.filter(e => e.bounds && !e.bounds.z).map(e => e.bounds!), NumCast(this.layoutDoc._xPadding, 10), NumCast(this.layoutDoc._yPadding, 10)); }      @computed get nativeWidth() { return this.fitToContent ? 0 : returnVal(this.props.NativeWidth?.(), Doc.NativeWidth(this.Document)); }      @computed get nativeHeight() { return this.fitToContent ? 0 : returnVal(this.props.NativeHeight?.(), Doc.NativeHeight(this.Document)); } @@ -405,7 +406,7 @@ export class CollectionFreeFormView extends CollectionSubView<PanZoomDocument, P          }      } -    getClusterColor = (doc: Opt<Doc>, props: Opt<DocumentViewProps>, property: string) => { +    getClusterColor = (doc: Opt<Doc>, props: Opt<DocumentViewProps | FieldViewProps>, property: string) => {          let styleProp = this.props.styleProvider?.(doc, props, property);  // bcz: check 'props'  used to be renderDepth + 1          if (property !== StyleProp.BackgroundColor) return styleProp;          const cluster = NumCast(doc?.cluster); @@ -1277,7 +1278,7 @@ export class CollectionFreeFormView extends CollectionSubView<PanZoomDocument, P      @undoBatch      @action      toggleNativeDimensions = () => { -        Doc.toggleNativeDimensions(this.layoutDoc, this.props.ContentScaling(), this.props.NativeWidth?.() || 0, this.props.NativeHeight?.() || 0); +        Doc.toggleNativeDimensions(this.layoutDoc, 1, this.props.NativeWidth?.() || 0, this.props.NativeHeight?.() || 0);      }      @undoBatch diff --git a/src/client/views/nodes/AudioBox.tsx b/src/client/views/nodes/AudioBox.tsx index b495cdd1b..7b721786f 100644 --- a/src/client/views/nodes/AudioBox.tsx +++ b/src/client/views/nodes/AudioBox.tsx @@ -539,7 +539,7 @@ export class AudioBox extends ViewBoxAnnotatableComponent<FieldViewProps, AudioD      rangeScript = () => AudioBox.RangeScript;      labelScript = () => AudioBox.LabelScript; -    static audioStyleProvider = (doc: Doc | undefined, props: Opt<DocumentViewProps>, property: string) => { +    static audioStyleProvider = (doc: Doc | undefined, props: Opt<DocumentViewProps | FieldViewProps>, property: string) => {          if (property === StyleProp.BackgroundColor) return "transparent";          if (property === StyleProp.PointerEvents) return "none";      } @@ -554,6 +554,7 @@ export class AudioBox extends ViewBoxAnnotatableComponent<FieldViewProps, AudioD                  rootSelected={returnFalse}                  LayoutTemplate={undefined}                  ContainingCollectionDoc={this.props.Document} +                ContentScaling={returnOne}                  removeDocument={this.removeDocument}                  parentActive={returnTrue}                  onClick={this.layoutDoc.playOnClick ? script : undefined} diff --git a/src/client/views/nodes/CollectionFreeFormDocumentView.tsx b/src/client/views/nodes/CollectionFreeFormDocumentView.tsx index 1b47f4551..3f473460f 100644 --- a/src/client/views/nodes/CollectionFreeFormDocumentView.tsx +++ b/src/client/views/nodes/CollectionFreeFormDocumentView.tsx @@ -17,6 +17,7 @@ import { ContentFittingDocumentView } from "./ContentFittingDocumentView";  import { DocumentView, DocumentViewProps } from "./DocumentView";  import React = require("react");  import { StyleProp } from "../StyleProvider"; +import { FieldViewProps } from "./FieldView";  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; @@ -59,7 +60,7 @@ export class CollectionFreeFormDocumentView extends DocComponent<CollectionFreeF      @computed get nativeWidth() { return returnVal(this.props.NativeWidth?.(), Doc.NativeWidth(this.layoutDoc, undefined, this.freezeDimensions)); }      @computed get nativeHeight() { return returnVal(this.props.NativeHeight?.(), Doc.NativeHeight(this.layoutDoc, undefined, this.freezeDimensions)); } -    styleProvider = (doc: Doc | undefined, props: Opt<DocumentViewProps>, property: string) => { +    styleProvider = (doc: Doc | undefined, props: Opt<DocumentViewProps | FieldViewProps>, property: string) => {          if (property === StyleProp.Opacity && doc === this.layoutDoc) return this.Opacity; // only change the opacity for this specific document, not its children          return this.props.styleProvider?.(doc, props, property);      } diff --git a/src/client/views/nodes/ColorBox.tsx b/src/client/views/nodes/ColorBox.tsx index 4fb350b55..52236a648 100644 --- a/src/client/views/nodes/ColorBox.tsx +++ b/src/client/views/nodes/ColorBox.tsx @@ -57,7 +57,7 @@ export class ColorBox extends ViewBoxBaseComponent<FieldViewProps, ColorDocument          const selDoc = SelectionManager.SelectedDocuments()?.[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={{ transform: `scale(${this.props.ContentScaling()})`, width: `${100 / this.props.ContentScaling()}%`, height: `${100 / this.props.ContentScaling()}%` }} > +            style={{ width: `${100}%`, height: `${100}%` }} >              <SketchPicker onChange={ColorBox.switchColor} presetColors={['#D0021B', '#F5A623', '#F8E71C', '#8B572A', '#7ED321', '#417505', '#9013FE', '#4A90E2', '#50E3C2', '#B8E986', '#000000', '#4A4A4A', '#9B9B9B', '#FFFFFF', '#f1efeb', 'transparent']}                  color={StrCast(ActiveInkPen()?.backgroundColor, diff --git a/src/client/views/nodes/ContentFittingDocumentView.tsx b/src/client/views/nodes/ContentFittingDocumentView.tsx index 122231f47..f2540dfa7 100644 --- a/src/client/views/nodes/ContentFittingDocumentView.tsx +++ b/src/client/views/nodes/ContentFittingDocumentView.tsx @@ -1,13 +1,12 @@  import React = require("react"); -import { computed, observable, action } from "mobx"; +import { action, computed, observable } from "mobx";  import { observer } from "mobx-react"; -import { Doc, WidthSym, HeightSym } from "../../../fields/Doc"; +import { Doc } from "../../../fields/Doc";  import { TraceMobx } from "../../../fields/util"; -import { emptyFunction, OmitKeys, returnVal, returnOne } from "../../../Utils"; +import { emptyFunction, OmitKeys, returnOne, returnVal } from "../../../Utils";  import { DocumentView, DocumentViewProps } from "../nodes/DocumentView"; -import "./ContentFittingDocumentView.scss";  import { StyleProp } from "../StyleProvider"; -import { StrCast } from "../../../fields/Types"; +import "./ContentFittingDocumentView.scss";  interface ContentFittingDocumentViewProps {      dontCenter?: "x" | "y" | "xy"; diff --git a/src/client/views/nodes/DocumentView.tsx b/src/client/views/nodes/DocumentView.tsx index c1ba1c73a..10b406fd4 100644 --- a/src/client/views/nodes/DocumentView.tsx +++ b/src/client/views/nodes/DocumentView.tsx @@ -43,10 +43,11 @@ import { TaskCompletionBox } from './TaskCompletedBox';  import React = require("react");  import { CollectionFreeFormDocumentView } from "./CollectionFreeFormDocumentView";  import { StyleProp, StyleLayers } from "../StyleProvider"; +import { FieldViewProps } from "./FieldView";  export type DocAfterFocusFunc = (notFocused: boolean) => boolean;  export type DocFocusFunc = (doc: Doc, willZoom?: boolean, scale?: number, afterFocus?: DocAfterFocusFunc, dontCenter?: boolean, focused?: boolean) => void; -export type StyleProviderFunc = (doc: Opt<Doc>, props: Opt<DocumentViewProps>, property: string) => any; +export type StyleProviderFunc = (doc: Opt<Doc>, props: Opt<DocumentViewProps | FieldViewProps>, property: string) => any;  export interface DocumentViewSharedProps {      renderDepth: number;      Document: Doc; @@ -58,7 +59,6 @@ export interface DocumentViewSharedProps {      PanelHeight: () => number;      NativeWidth?: () => number;      NativeHeight?: () => number; -    ContentScaling: () => number; // scaling the DocumentView does to transform its contents into its panel & needed by ScreenToLocal      layerProvider?: (doc: Doc, assign?: boolean) => boolean;      styleProvider?: StyleProviderFunc;      focus: DocFocusFunc; @@ -93,6 +93,7 @@ export interface DocumentViewProps extends DocumentViewSharedProps {      dragDivName?: string;      contentPointerEvents?: string;      radialMenu?: String[]; +    ContentScaling: () => number; // scaling the DocumentView does to transform its contents into its panel & needed by ScreenToLocal      contentFittingScaling?: () => number;// scaling done outside the document view (eg in ContentFittingDocumentView) to fit contents into panel (needed for ScreenToLocal but not needed by DocumentView to scale its content)      LayoutTemplate?: () => Opt<Doc>;      contextMenuItems?: () => { script: ScriptField, label: string }[]; @@ -972,7 +973,7 @@ export class DocumentView extends DocComponent<DocumentViewProps, Document>(Docu      hideLinkAnchor = (doc: Doc | Doc[]) => (doc instanceof Doc ? [doc] : doc).reduce((flg: boolean, doc) => flg && (doc.hidden = true), true)      anchorPanelWidth = () => this.props.PanelWidth() || 1;      anchorPanelHeight = () => this.props.PanelHeight() || 1; -    anchorStyleProvider = (doc: Opt<Doc>, props: Opt<DocumentViewProps>, property: string): any => { +    anchorStyleProvider = (doc: Opt<Doc>, props: Opt<DocumentViewProps | FieldViewProps>, property: string): any => {          switch (property.split(":")[0]) {              case StyleProp.BackgroundColor: return "transparent";              case StyleProp.HideLinkButton: return true; diff --git a/src/client/views/nodes/ImageBox.tsx b/src/client/views/nodes/ImageBox.tsx index 44df00709..374f964e3 100644 --- a/src/client/views/nodes/ImageBox.tsx +++ b/src/client/views/nodes/ImageBox.tsx @@ -67,7 +67,7 @@ export class ImageBox extends ViewBoxAnnotatableComponent<FieldViewProps, ImageD      @observable static _showControls: boolean;      @observable uploadIcon = uploadIcons.idle; -    @computed get contentScaling() { return this.props.ContentScaling(); } +    @computed get contentScaling() { return 1; }      protected createDropTarget = (ele: HTMLDivElement) => {          this._dropDisposer?.(); diff --git a/src/client/views/nodes/KeyValuePair.tsx b/src/client/views/nodes/KeyValuePair.tsx index aaf544c50..3c10cc5fe 100644 --- a/src/client/views/nodes/KeyValuePair.tsx +++ b/src/client/views/nodes/KeyValuePair.tsx @@ -76,7 +76,6 @@ export class KeyValuePair extends React.Component<KeyValuePairProps> {              PanelHeight: this.props.PanelHeight,              addDocTab: returnFalse,              pinToPres: returnZero, -            ContentScaling: returnOne          };          const contents = <FieldView {...props} />;          // let fieldKey = Object.keys(props.Document).indexOf(props.fieldKey) !== -1 ? props.fieldKey : "(" + props.fieldKey + ")"; diff --git a/src/client/views/nodes/LinkAnchorBox.tsx b/src/client/views/nodes/LinkAnchorBox.tsx index abefc6561..d0048c67b 100644 --- a/src/client/views/nodes/LinkAnchorBox.tsx +++ b/src/client/views/nodes/LinkAnchorBox.tsx @@ -146,7 +146,7 @@ export class LinkAnchorBox extends ViewBoxBaseComponent<FieldViewProps, LinkAnch                  background,                  left: `calc(${x}% - ${small ? 2.5 : 7.5}px)`,                  top: `calc(${y}% - ${small ? 2.5 : 7.5}px)`, -                transform: `scale(${anchorScale / this.props.ContentScaling()})` +                transform: `scale(${anchorScale})`              }} >              {!this._editing && !this._forceOpen ? (null) :                  <Flyout anchorPoint={anchorPoints.LEFT_TOP} content={flyout} open={this._forceOpen ? true : undefined} onOpen={() => this._isOpen = true} onClose={action(() => this._isOpen = this._forceOpen = this._editing = false)}> diff --git a/src/client/views/nodes/PDFBox.tsx b/src/client/views/nodes/PDFBox.tsx index a2f3fb2d1..b34c7966b 100644 --- a/src/client/views/nodes/PDFBox.tsx +++ b/src/client/views/nodes/PDFBox.tsx @@ -183,7 +183,7 @@ export class PDFBox extends ViewBoxAnnotatableComponent<FieldViewProps, PdfDocum          ContextMenu.Instance.addItem({ description: "Options...", subitems: funcs, icon: "asterisk" });      } -    @computed get contentScaling() { return this.props.ContentScaling(); } +    @computed get contentScaling() { return 1; }      @computed get renderTitleBox() {          const classname = "pdfBox" + (this.active() ? "-interactive" : "");          return <div className={classname} > diff --git a/src/client/views/nodes/ScreenshotBox.tsx b/src/client/views/nodes/ScreenshotBox.tsx index 713511a94..456de7ede 100644 --- a/src/client/views/nodes/ScreenshotBox.tsx +++ b/src/client/views/nodes/ScreenshotBox.tsx @@ -167,7 +167,7 @@ export class ScreenshotBox extends ViewBoxBaseComponent<FieldViewProps, Screensh      contentFunc = () => [this.content];      render() {          return (<div className="videoBox" onContextMenu={this.specificContextMenu} -            style={{ transform: `scale(${this.props.ContentScaling()})`, width: `${100 / this.props.ContentScaling()}%`, height: `${100 / this.props.ContentScaling()}%` }} > +            style={{ width: `${100}%`, height: `${100}%` }} >              <div className="videoBox-viewer" >                  <CollectionFreeFormView {...OmitKeys(this.props, ["NativeWidth", "NativeHeight"]).omit}                      PanelHeight={this.props.PanelHeight} diff --git a/src/client/views/nodes/VideoBox.tsx b/src/client/views/nodes/VideoBox.tsx index 90a5dee23..893236857 100644 --- a/src/client/views/nodes/VideoBox.tsx +++ b/src/client/views/nodes/VideoBox.tsx @@ -413,7 +413,7 @@ export class VideoBox extends ViewBoxAnnotatableComponent<FieldViewProps, VideoD          return this.addDocument(doc);      } -    @computed get contentScaling() { return this.props.ContentScaling(); } +    @computed get contentScaling() { return 1; }      contentFunc = () => [this.youtubeVideoId ? this.youtubeContent : this.content];      render() {          return (<div className="videoBox" onContextMenu={this.specificContextMenu} diff --git a/src/client/views/nodes/WebBox.tsx b/src/client/views/nodes/WebBox.tsx index 47464d794..511e8f537 100644 --- a/src/client/views/nodes/WebBox.tsx +++ b/src/client/views/nodes/WebBox.tsx @@ -457,7 +457,7 @@ export class WebBox extends ViewBoxAnnotatableComponent<FieldViewProps, WebDocum          return (<>              <div className={"webBox-cont" + (this.props.isSelected() && Doc.GetSelectedTool() === InkTool.None && !DocumentDecorations.Instance?.Interacting ? "-interactive" : "")} -                style={{ width: NumCast(this.layoutDoc[this.fieldKey + "-contentWidth"]) || (Number.isFinite(this.props.ContentScaling()) ? `${Math.max(100, 100 / this.props.ContentScaling())}% ` : "100%") }} +                style={{ width: "100%" }}                  onWheel={this.onPostWheel} onPointerDown={this.onPostPointer} onPointerMove={this.onPostPointer} onPointerUp={this.onPostPointer}>                  {view}              </div> @@ -648,14 +648,12 @@ export class WebBox extends ViewBoxAnnotatableComponent<FieldViewProps, WebDocum      marqueeing = () => this._marqueeing;      scrollXf = () => this.props.ScreenToLocalTransform().translate(NumCast(this.layoutDoc._scrollLeft), NumCast(this.layoutDoc._scrollTop));      render() { -        const scaling = Number.isFinite(this.props.ContentScaling()) ? this.props.ContentScaling() || 1 : 1;          return (<div className="webBox" ref={this._mainCont} >              <div className={`webBox-container`}                  style={{                      position: undefined, -                    transform: `scale(${scaling})`, -                    width: `${100 / scaling}% `, -                    height: `${100 / scaling}% `, +                    width: `${100}% `, +                    height: `${100}% `,                      pointerEvents: this.props.layerProvider?.(this.layoutDoc) === false ? "none" : undefined                  }}                  onContextMenu={this.specificContextMenu}> @@ -663,7 +661,7 @@ export class WebBox extends ViewBoxAnnotatableComponent<FieldViewProps, WebDocum                  {this.content}                  <div className={"webBox-outerContent"} ref={this._outerRef}                      style={{ -                        width: `${Math.max(100, 100 / scaling)}% `, +                        width: `${100}% `,                          pointerEvents: this.layoutDoc.isAnnotating && this.props.layerProvider?.(this.layoutDoc) !== false ? "all" : "none"                      }}                      onWheel={e => { diff --git a/src/client/views/nodes/formattedText/FormattedTextBox.tsx b/src/client/views/nodes/formattedText/FormattedTextBox.tsx index 0beea2bcd..feb5e63b2 100644 --- a/src/client/views/nodes/formattedText/FormattedTextBox.tsx +++ b/src/client/views/nodes/formattedText/FormattedTextBox.tsx @@ -581,7 +581,7 @@ export class FormattedTextBox extends ViewBoxAnnotatableComponent<(FieldViewProp      @undoBatch      @action      toggleNativeDimensions = () => { -        Doc.toggleNativeDimensions(this.layoutDoc, this.props.ContentScaling(), this.props.NativeWidth?.() || 0, this.props.NativeHeight?.() || 0); +        Doc.toggleNativeDimensions(this.layoutDoc, 1, this.props.NativeWidth?.() || 0, this.props.NativeHeight?.() || 0);      }      public static get DefaultLayout(): Doc | string | undefined { @@ -1609,7 +1609,7 @@ export class FormattedTextBox extends ViewBoxAnnotatableComponent<(FieldViewProp              />;      } -    sidebarContentScaling = () => this.props.ContentScaling() * NumCast(this.layoutDoc._viewScale, 1); +    sidebarContentScaling = () => NumCast(this.layoutDoc._viewScale, 1);      @computed get sidebarCollection() {          const fitToBox = this.props.Document._fitToBox;          const collectionProps: SubCollectionViewProps & collectionFreeformViewProps = { @@ -1647,13 +1647,13 @@ export class FormattedTextBox extends ViewBoxAnnotatableComponent<(FieldViewProp      @computed get sidebarWidthPercent() { return StrCast(this.layoutDoc._sidebarWidthPercent, "0%"); }      sidebarWidth = () => Number(this.sidebarWidthPercent.substring(0, this.sidebarWidthPercent.length - 1)) / 100 * this.props.PanelWidth(); -    sidebarScreenToLocal = () => this.props.ScreenToLocalTransform().translate(-(this.props.PanelWidth() - this.sidebarWidth()) / this.props.ContentScaling(), 0).scale(1 / NumCast(this.layoutDoc._viewScale, 1)); +    sidebarScreenToLocal = () => this.props.ScreenToLocalTransform().translate(-(this.props.PanelWidth() - this.sidebarWidth()), 0).scale(1 / NumCast(this.layoutDoc._viewScale, 1));      @computed get sidebarColor() { return StrCast(this.layoutDoc.sidebarColor, StrCast(this.layoutDoc[this.props.fieldKey + "-backgroundColor"], "#e4e4e4")); }      render() {          TraceMobx();          const selected = this.props.isSelected();          const active = this.active(); -        const scale = this.props.hideOnLeave ? 1 : this.props.ContentScaling() * NumCast(this.layoutDoc._viewScale, 1); +        const scale = this.props.hideOnLeave ? 1 : NumCast(this.layoutDoc._viewScale, 1);          const rounded = StrCast(this.layoutDoc.borderRounding) === "100%" ? "-rounded" : "";          const interactive = (Doc.GetSelectedTool() === InkTool.None || SnappingManager.GetIsDragging()) && (this.layoutDoc.z || this.props.layerProvider?.(this.layoutDoc) !== false);          if (!selected && FormattedTextBoxComment.textBox === this) setTimeout(() => FormattedTextBoxComment.Hide()); diff --git a/src/client/views/pdf/PDFViewer.tsx b/src/client/views/pdf/PDFViewer.tsx index 6b7a93747..fc547c60f 100644 --- a/src/client/views/pdf/PDFViewer.tsx +++ b/src/client/views/pdf/PDFViewer.tsx @@ -370,7 +370,7 @@ export class PDFViewer extends ViewBoxAnnotatableComponent<IViewerProps, PdfDocu      @action      scrollToAnnotation = (scrollToAnnotation: Doc) => {          if (scrollToAnnotation) { -            const offset = (this.props.PanelHeight() / this.props.ContentScaling()) / 2; +            const offset = this.props.PanelHeight() / 2;              this._mainCont.current && smoothScroll(500, this._mainCont.current, NumCast(scrollToAnnotation.y) - offset);              Doc.linkFollowHighlight(scrollToAnnotation);          } @@ -737,7 +737,7 @@ export class PDFViewer extends ViewBoxAnnotatableComponent<IViewerProps, PdfDocu      @computed get pdfViewerDiv() {          return <div className={"pdfViewerDash-text" + ((this.props.isSelected() || this.props.isChildActive()) ? "-selected" : "")} ref={this._viewer} />;      } -    @computed get contentScaling() { return this.props.ContentScaling(); } +    @computed get contentScaling() { return 1; }      @computed get standinViews() {          return <>              {this._showCover ? this.getCoverImage() : (null)} @@ -758,7 +758,6 @@ export class PDFViewer extends ViewBoxAnnotatableComponent<IViewerProps, PdfDocu                  overflowX: this._zoomed !== 1 ? "scroll" : undefined,                  width: !this.props.Document._fitWidth && (window.screen.width > 600) ? Doc.NativeWidth(this.props.Document) : `${100 / this.contentScaling}%`,                  height: !this.props.Document._fitWidth && (window.screen.width > 600) ? Doc.NativeHeight(this.props.Document) : `${100 / this.contentScaling}%`, -                transform: `scale(${this.props.ContentScaling()})`              }}  >              {this.pdfViewerDiv}              {this.annotationLayer} diff --git a/src/client/views/presentationview/PresElementBox.tsx b/src/client/views/presentationview/PresElementBox.tsx index 3b6b0259d..8615ba81d 100644 --- a/src/client/views/presentationview/PresElementBox.tsx +++ b/src/client/views/presentationview/PresElementBox.tsx @@ -78,7 +78,7 @@ export class PresElementBox extends ViewBoxBaseComponent<FieldViewProps, PresDoc      // embedWidth = () => this.props.PanelWidth();      // embedHeight = () => Math.min(this.props.PanelWidth() - 20, this.props.PanelHeight() - this.collapsedHeight);      embedWidth = (): number => this.props.PanelWidth() - 35; -    styleProvider = (doc: (Doc | undefined), props: Opt<DocumentViewProps>, property: string): any => { +    styleProvider = (doc: (Doc | undefined), props: Opt<DocumentViewProps | FieldViewProps>, property: string): any => {          if (property === StyleProp.Opacity) return 1;          return this.props.styleProvider?.(doc, props, property);      } | 
