diff options
| -rw-r--r-- | src/client/views/DocumentButtonBar.tsx | 2 | ||||
| -rw-r--r-- | src/client/views/collections/CollectionStackingView.tsx | 17 | ||||
| -rw-r--r-- | src/client/views/collections/TabDocView.tsx | 24 | ||||
| -rw-r--r-- | src/client/views/collections/TreeView.tsx | 10 | ||||
| -rw-r--r-- | src/client/views/collections/collectionFreeForm/CollectionFreeFormView.tsx | 3 | ||||
| -rw-r--r-- | src/client/views/nodes/CollectionFreeFormDocumentView.tsx | 24 | ||||
| -rw-r--r-- | src/client/views/nodes/DocumentView.scss | 3 | ||||
| -rw-r--r-- | src/client/views/nodes/DocumentView.tsx | 30 | ||||
| -rw-r--r-- | src/client/views/nodes/LabelBox.tsx | 2 | ||||
| -rw-r--r-- | src/client/views/nodes/SliderBox.tsx | 2 | ||||
| -rw-r--r-- | src/client/views/presentationview/PresElementBox.tsx | 8 | 
11 files changed, 76 insertions, 49 deletions
| diff --git a/src/client/views/DocumentButtonBar.tsx b/src/client/views/DocumentButtonBar.tsx index fa0b9a238..dc6311696 100644 --- a/src/client/views/DocumentButtonBar.tsx +++ b/src/client/views/DocumentButtonBar.tsx @@ -339,7 +339,7 @@ export class DocumentButtonBar extends React.Component<{ views: () => (DocumentV          let child = SelectionManager.SelectedDocuments()[0].ContentDiv!.children[0];          while (child.children.length) {              const next = Array.from(child.children).find(c => typeof (c.className) === "string"); -            if (next?.className.includes("documentView-node")) break; +            if (next?.className.includes(DocumentView.ROOT_DIV)) break;              if (next?.className.includes("dashFieldView")) break;              if (next) child = next;              else break; diff --git a/src/client/views/collections/CollectionStackingView.tsx b/src/client/views/collections/CollectionStackingView.tsx index b1c5dec84..408a8d969 100644 --- a/src/client/views/collections/CollectionStackingView.tsx +++ b/src/client/views/collections/CollectionStackingView.tsx @@ -22,7 +22,7 @@ import { ContextMenuProps } from "../ContextMenuItem";  import { EditableView } from "../EditableView";  import { CollectionFreeFormDocumentView } from "../nodes/CollectionFreeFormDocumentView";  import { ContentFittingDocumentView } from "../nodes/ContentFittingDocumentView"; -import { DocAfterFocusFunc } from "../nodes/DocumentView"; +import { DocAfterFocusFunc, DocumentViewProps } from "../nodes/DocumentView";  import { CollectionMasonryViewFieldRow } from "./CollectionMasonryViewFieldRow";  import "./CollectionStackingView.scss";  import { CollectionStackingViewFieldColumn } from "./CollectionStackingViewFieldColumn"; @@ -187,14 +187,24 @@ 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 opacity = () => this.Document._currentFrame === undefined ? this.props.childOpacity?.() : CollectionFreeFormDocumentView.getValues(doc, NumCast(this.Document._currentFrame))?.opacity; +        const styleProvider = (doc: Doc | undefined, props: DocumentViewProps, property: string) => { +            if (property === "opacity" && doc) { +                if (this.props.childOpacity) { +                    return this.props.childOpacity(); +                } +                if (this.Document._currentFrame !== undefined) { +                    return CollectionFreeFormDocumentView.getValues(doc, NumCast(this.Document._currentFrame))?.opacity; +                } +            } +            return this.props.styleProvider?.(doc, props, property); +        };          return <ContentFittingDocumentView              Document={doc}              DataDoc={dataDoc || (!Doc.AreProtosEqual(doc[DataSym], doc) && doc[DataSym])}              renderDepth={this.props.renderDepth + 1}              PanelWidth={width}              PanelHeight={height} -            styleProvider={this.props.styleProvider} +            styleProvider={styleProvider}              LayoutTemplate={this.props.childLayoutTemplate}              LayoutTemplateString={this.props.childLayoutString}              freezeDimensions={this.props.childFreezeDimensions} @@ -208,7 +218,6 @@ export class CollectionStackingView extends CollectionSubView<StackingDocument,              onClick={this.onChildClickHandler}              onDoubleClick={this.onChildDoubleClickHandler}              ScreenToLocalTransform={dxf} -            opacity={opacity}              focus={this.focusDocument}              docFilters={this.docFilters}              docRangeFilters={this.docRangeFilters} diff --git a/src/client/views/collections/TabDocView.tsx b/src/client/views/collections/TabDocView.tsx index 5c815c1f6..5b5d8ee4a 100644 --- a/src/client/views/collections/TabDocView.tsx +++ b/src/client/views/collections/TabDocView.tsx @@ -432,11 +432,16 @@ export class TabDocView extends React.Component<TabDocViewProps> {      //      // a preliminary implementation of a dash style sheet for setting rendering properties of documents nested within a Tab      //  -    public static styleProvider = (doc: Opt<Doc>, props: DocumentViewProps | undefined, property: string): any => { +    public static styleProvider = (doc: Opt<Doc>, props: DocumentViewProps, property: string): any => {          switch (property) { +            case "docContents": return undefined; +            case "widgetColor": return TabDocView.darkScheme ? "lightgrey" : "dimgrey"; +            case "opacity": return Cast(doc?._opacity, "number", Cast(doc?.opacity, "number", null)); +            case "hidden": return BoolCast(doc?._hidden, BoolCast(doc?.hidden)); +            case "borderRounding": return !doc ? undefined : StrCast(doc._borderRounding, StrCast(doc.borderRounding));              case "backgroundColor": {                  if (Doc.UserDoc().renderStyle === "comic") return undefined; -                let docColor = StrCast(doc?._backgroundColor, StrCast(doc?.backgroundColor)); +                let docColor: Opt<string> = StrCast(doc?._backgroundColor, StrCast(doc?.backgroundColor));                  if (!docColor) {                      switch (doc?.type) {                          case DocumentType.PRESELEMENT: docColor = TabDocView.darkScheme ? "" : ""; break; @@ -457,20 +462,23 @@ export class TabDocView extends React.Component<TabDocViewProps> {                  if (docColor && (!doc || props?.layerProvider?.(doc) === false)) docColor = Color(docColor).fade(0.5).toString();                  return docColor;              } -            case "widgetColor": return TabDocView.darkScheme ? "lightgrey" : "dimgrey"; -            case "hidden": return (BoolCast(doc?.hidden) /* || props?.layerProvider?.(doc) === false*/);              case "boxShadow": { +                if (!doc || props.styleProvider?.(doc, props, "opacity") === 0) return undefined;  // if it's not visible, then no shadow) +                const isBackground = StrListCast(doc.layers).includes("background");                  switch (doc?.type) { -                    case DocumentType.COL: return StrListCast(doc.layers).includes("background") ? undefined : +                    case DocumentType.COL: return isBackground ? undefined :                          `${TabDocView.darkScheme ? "rgb(30, 32, 31) " : "#9c9396 "} ${StrCast(doc.boxShadow, "0.2vw 0.2vw 0.8vw")}`; -                    default: return undefined; +                    default: +                        return doc.z ? `#9c9396  ${StrCast(doc?.boxShadow, "10px 10px 0.9vw")}` :  // if it's a floating doc, give it a big shadow +                            props.backgroundHalo?.(doc) && doc.type !== DocumentType.INK ? (`${props.styleProvider?.(doc, props, "backgroundColor")} ${StrCast(doc.boxShadow, `0vw 0vw ${(isBackground ? 100 : 50) / props.ContentScaling()}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, "")                  }              } -            case "docContents": return undefined;              default:                  if (property.startsWith("pointerEvents")) {                      const layer = doc && props?.layerProvider?.(doc); -                    if (doc?.Opacity === 0 || doc?.type === DocumentType.INK || doc?.isInkMask) return "none"; +                    if (props.styleProvider?.(doc, props, "opacity") === 0 || doc?.type === DocumentType.INK || doc?.isInkMask) return "none";                      if (layer === false && !property.includes(":selected") && !SnappingManager.GetIsDragging()) return "none";                      if (doc?.type !== DocumentType.INK && layer === true) return "all";                      return undefined; diff --git a/src/client/views/collections/TreeView.tsx b/src/client/views/collections/TreeView.tsx index be8a27ab0..24dd905a9 100644 --- a/src/client/views/collections/TreeView.tsx +++ b/src/client/views/collections/TreeView.tsx @@ -441,7 +441,7 @@ export class TreeView extends React.Component<TreeViewProps> {          return <div className={`bullet${this.outlineMode ? "-outline" : ""}`} key={"bullet"}              title={this.childDocs?.length ? `click to see ${this.childDocs?.length} items` : "view fields"}              onClick={this.bulletClick} -            style={this.outlineMode ? { opacity: NumCast(this.doc.opacity, 1) } : { +            style={this.outlineMode ? { opacity: this.styleProvider?.(this.doc, this.props.treeView.props, "opacity") } : {                  color: StrCast(this.doc.color, checked === "unchecked" ? "white" : "inherit"),                  opacity: checked === "unchecked" ? undefined : 0.4              }}> @@ -496,6 +496,12 @@ export class TreeView extends React.Component<TreeViewProps> {              e.preventDefault();          }      } +    styleProvider = (doc: (Doc | undefined), props: DocumentViewProps, property: string): any => { +        // override opacity and backgroundColor just for this treeView document: opacity = 1, and backgroundColor = undefined unless it is explicitly set on the document +        if (property === "opacity" && doc === this.props.document) return this.outlineMode ? undefined : 1; +        if (property === "backgroundColor" && doc === this.props.document) return StrCast(doc._backgroundColor, StrCast(doc.backgroundColor)); +        return this.props.treeView.props.styleProvider?.(doc, props, property); +    }      onKeyDown = (e: React.KeyboardEvent) => {          if (this.doc.treeViewHideHeader || this.outlineMode) {              e.stopPropagation(); @@ -520,6 +526,7 @@ export class TreeView extends React.Component<TreeViewProps> {                  ref={this._docRef}                  Document={this.doc}                  DataDoc={undefined} +                styleProvider={this.styleProvider}                  treeViewDoc={this.props.treeView.props.Document}                  addDocument={undefined}                  addDocTab={this.props.addDocTab} @@ -535,7 +542,6 @@ export class TreeView extends React.Component<TreeViewProps> {                  PanelWidth={this.truncateTitleWidth}                  PanelHeight={returnZero}                  contextMenuItems={this.contextMenuItems} -                opacity={this.outlineMode ? undefined : returnOne}                  renderDepth={1}                  focus={returnTrue}                  parentActive={returnTrue} diff --git a/src/client/views/collections/collectionFreeForm/CollectionFreeFormView.tsx b/src/client/views/collections/collectionFreeForm/CollectionFreeFormView.tsx index 94de40bc8..a8e24ebbe 100644 --- a/src/client/views/collections/collectionFreeForm/CollectionFreeFormView.tsx +++ b/src/client/views/collections/collectionFreeForm/CollectionFreeFormView.tsx @@ -1049,7 +1049,8 @@ export class CollectionFreeFormView extends CollectionSubView<PanZoomDocument, P      });      getCalculatedPositions(params: { pair: { layout: Doc, data?: Doc }, index: number, collection: Doc, docs: Doc[], state: any }): PoolData {          const layoutDoc = Doc.Layout(params.pair.layout); -        const { x, y, opacity } = this.Document._currentFrame === undefined ? params.pair.layout : +        const { x, y, opacity } = this.Document._currentFrame === undefined ? +            { x: params.pair.layout.x, y: params.pair.layout.y, opacity: this.props.styleProvider?.(params.pair.layout, this.props, "opacity") } :              CollectionFreeFormDocumentView.getValues(params.pair.layout, this.Document._currentFrame || 0);          const { z, color, zIndex } = params.pair.layout;          return { diff --git a/src/client/views/nodes/CollectionFreeFormDocumentView.tsx b/src/client/views/nodes/CollectionFreeFormDocumentView.tsx index ff37847df..60d33468a 100644 --- a/src/client/views/nodes/CollectionFreeFormDocumentView.tsx +++ b/src/client/views/nodes/CollectionFreeFormDocumentView.tsx @@ -44,8 +44,8 @@ export class CollectionFreeFormDocumentView extends DocComponent<CollectionFreeF      get transform() { return `scale(${this.props.ContentScaling()}) translate(${this.X - this.maskCentering}px, ${this.Y - this.maskCentering}px) rotate(${this.random(-1, 1) * this.props.jitterRotation}deg)`; }      get X() { return this.dataProvider ? this.dataProvider.x : (this.Document.x || 0); }      get Y() { return this.dataProvider ? this.dataProvider.y : (this.Document.y || 0); } -    get Opacity() { return this.dataProvider ? this.dataProvider.opacity : Cast(this.layoutDoc.opacity, "number", null); }      get ZInd() { return this.dataProvider ? this.dataProvider.zIndex : (this.Document.zIndex || 0); } +    get Opacity() { return this.dataProvider ? this.dataProvider.opacity : undefined; }      get Highlight() { return this.dataProvider?.highlight; }      get width() { return this.props.sizeProvider && this.sizeProvider ? this.sizeProvider.width : this.layoutDoc[WidthSym](); }      get height() { @@ -58,6 +58,11 @@ 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: DocumentViewProps, property: string) => { +        if (property === "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); +    } +      static animFields = ["_height", "_width", "x", "y", "_scrollTop", "opacity"];      public static getValues(doc: Doc, time: number) {          return CollectionFreeFormDocumentView.animFields.reduce((p, val) => { @@ -137,7 +142,6 @@ export class CollectionFreeFormDocumentView extends DocComponent<CollectionFreeF      panelHeight = () => (this.sizeProvider?.height || this.props.PanelHeight?.());      getTransform = (): Transform => this.props.ScreenToLocalTransform().translate(-this.X, -this.Y).scale(1 / this.contentScaling());      focusDoc = (doc: Doc) => this.props.focus(doc, false); -    opacity = () => this.Opacity;      NativeWidth = () => this.nativeWidth;      NativeHeight = () => this.nativeHeight;      returnThis = () => this; @@ -148,13 +152,13 @@ export class CollectionFreeFormDocumentView extends DocComponent<CollectionFreeF      render() {          TraceMobx();          const backgroundColor = this.props.styleProvider?.(this.Document, this.props, "backgroundColor"); -        const borderRounding = StrCast(Doc.Layout(this.layoutDoc).borderRounding) || StrCast(this.layoutDoc.borderRounding) || StrCast(this.Document.borderRounding) || undefined; - +        const borderRadius = this.props.styleProvider?.(this.Document, this.props, "borderRounding"); +        const boxShadow = this.props.styleProvider?.(this.Document, this.props, "boxShadow");          const divProps: DocumentViewProps = {              ...this.props,              CollectionFreeFormDocumentView: this.returnThis,              dragDivName: "collectionFreeFormDocumentView-container", -            opacity: this.opacity, +            styleProvider: this.styleProvider,              ScreenToLocalTransform: this.getTransform,              NativeHeight: this.NativeHeight,              NativeWidth: this.NativeWidth, @@ -163,13 +167,8 @@ export class CollectionFreeFormDocumentView extends DocComponent<CollectionFreeF          };          return <div className="collectionFreeFormDocumentView-container"              style={{ -                boxShadow: -                    this.Opacity === 0 ? undefined :  // if it's not visible, then no shadow -                        this.layoutDoc.z ? `#9c9396  ${StrCast(this.layoutDoc.boxShadow, "10px 10px 0.9vw")}` :  // if it's a floating doc, give it a big shadow -                            this.props.backgroundHalo?.(this.props.Document) && this.props.Document.type !== DocumentType.INK ? (`${this.props.styleProvider?.(this.props.Document, this.props, "backgroundColor")} ${StrCast(this.layoutDoc.boxShadow, `0vw 0vw ${(Cast(this.layoutDoc.layers, listSpec("string"), []).includes("background") ? 100 : 50) / this.props.ContentScaling()}px`)}`) :  // if it's just in a cluster, make the shadown roughly match the cluster border extent -                                Cast(this.layoutDoc.layers, listSpec("string"), []).includes('background') ? undefined :  // if it's a background & has a cluster color, make the shadow spread really big -                                    StrCast(this.layoutDoc.boxShadow, ""), -                borderRadius: borderRounding, +                boxShadow, +                borderRadius,                  outline: this.Highlight ? "orange solid 2px" : "",                  transform: this.transform,                  transition: this.props.dataTransition ? this.props.dataTransition : this.dataProvider ? this.dataProvider.transition : StrCast(this.layoutDoc.dataTransition), @@ -178,7 +177,6 @@ export class CollectionFreeFormDocumentView extends DocComponent<CollectionFreeF                  zIndex: this.ZInd,                  mixBlendMode: StrCast(this.layoutDoc.mixBlendMode) as any,                  display: this.ZInd === -99 ? "none" : undefined, -                // @ts-ignore                  pointerEvents: this.pointerEvents              }} > diff --git a/src/client/views/nodes/DocumentView.scss b/src/client/views/nodes/DocumentView.scss index ad72250b6..d25d7af05 100644 --- a/src/client/views/nodes/DocumentView.scss +++ b/src/client/views/nodes/DocumentView.scss @@ -1,5 +1,8 @@  @import "../globalCssVariables"; +.documentView-effectsWrapper { +    border-radius: inherit; +}  .documentView-node,  .documentView-node-topmost {      position: inherit; diff --git a/src/client/views/nodes/DocumentView.tsx b/src/client/views/nodes/DocumentView.tsx index 591859737..ed3fa6918 100644 --- a/src/client/views/nodes/DocumentView.tsx +++ b/src/client/views/nodes/DocumentView.tsx @@ -103,11 +103,11 @@ export interface DocumentViewProps extends DocumentViewSharedProps {      onPointerUp?: () => ScriptField;      setupDragLines?: (snapToDraggedDoc: boolean) => void;      forceHideLinkButton?: () => boolean; -    opacity?: () => number | undefined;  }  @observer  export class DocumentView extends DocComponent<DocumentViewProps, Document>(Document) { +    public static ROOT_DIV = "documentView-effectsWrapper";      @observable _animateScalingTo = 0;      private _downX: number = 0;      private _downY: number = 0; @@ -1090,24 +1090,22 @@ export class DocumentView extends DocComponent<DocumentViewProps, Document>(Docu          if (!(this.props.Document instanceof Doc)) return (null);          if (GetEffectiveAcl(this.props.Document[DataSym]) === AclPrivate) return (null);          if (this.props.styleProvider?.(this.layoutDoc, this.props, "hidden")) return null; -        const backgroundColor = this.props.styleProvider?.(this.layoutDoc, this.props, "backgroundColor"); -        const opacity = Cast(this.layoutDoc._opacity, "number", Cast(this.layoutDoc.opacity, "number", Cast(this.Document.opacity, "number", null))); -        const finalOpacity = this.props.opacity ? this.props.opacity() : opacity; -        const finalColor = this.layoutDoc.type === DocumentType.FONTICON || this.layoutDoc._viewType === CollectionViewType.Linear ? undefined : backgroundColor; -        const fullDegree = this.props.LayoutTemplateString ? (Doc.IsHighlighted(this.props.Document) ? 6 : 0) : Doc.isBrushedHighlightedDegree(this.props.Document); // bcz: Argh!! need to identify a tree view doc better than a LayoutTemlatString -        const borderRounding = this.layoutDoc.borderRounding; -        const localScale = fullDegree; +        const background = this.props.styleProvider?.(this.layoutDoc, this.props, "backgroundColor"); +        const borderRounding = this.props.styleProvider?.(this.layoutDoc, this.props, "borderRounding"); +        const opacity = this.props.styleProvider?.(this.layoutDoc, this.props, "opacity"); +        const highlightIndex = this.props.LayoutTemplateString ? (Doc.IsHighlighted(this.props.Document) ? 6 : 0) : Doc.isBrushedHighlightedDegree(this.props.Document); // bcz: Argh!! need to identify a tree view doc better than a LayoutTemlatString          const highlightColors = CurrentUserUtils.ActiveDashboard?.darkScheme ?              ["transparent", "#65350c", "#65350c", "yellow", "magenta", "cyan", "orange"] :              ["transparent", "maroon", "maroon", "yellow", "magenta", "cyan", "orange"];          const highlightStyles = ["solid", "dashed", "solid", "solid", "solid", "solid", "solid"]; -        let highlighting = fullDegree && this.layoutDoc.type !== DocumentType.FONTICON && this.layoutDoc._viewType !== CollectionViewType.Linear && this.props.Document.type !== DocumentType.INK; +        let highlighting = highlightIndex && ![DocumentType.FONTICON, DocumentType.INK].includes(this.layoutDoc.type as any) && this.layoutDoc._viewType !== CollectionViewType.Linear;          highlighting = highlighting && this.props.focus !== emptyFunction && this.layoutDoc.title !== "[pres element template]";  // bcz: hack to turn off highlighting onsidebar panel documents.  need to flag a document as not highlightable in a more direct way          const topmost = this.topMost ? "-topmost" : "";          return this.props.styleProvider?.(this.rootDoc, this.props, "docContents") ?? <div className={`documentView-node${topmost}`}              id={this.props.Document[Id]}              onKeyDown={this.onKeyDown} -            onContextMenu={this.onContextMenu} onPointerDown={this.onPointerDown} onClick={this.onClick} +            onPointerDown={this.onPointerDown} +            onClick={this.onClick}              onPointerEnter={action(e => !SnappingManager.GetIsDragging() && Doc.BrushDoc(this.props.Document))}              onPointerLeave={action(e => {                  let entered = false; @@ -1122,15 +1120,15 @@ export class DocumentView extends DocComponent<DocumentViewProps, Document>(Docu                  transition: !this._animateScalingTo ? StrCast(this.Document.dataTransition) : `transform 0.5s ease-${this._animateScalingTo < 1 ? "in" : "out"}`,                  pointerEvents: this.pointerEvents,                  color: StrCast(this.layoutDoc.color, "inherit"), -                outline: highlighting && !borderRounding ? `${highlightColors[fullDegree]} ${highlightStyles[fullDegree]} ${localScale}px` : "solid 0px", -                border: highlighting && borderRounding && highlightStyles[fullDegree] === "dashed" ? `${highlightStyles[fullDegree]} ${highlightColors[fullDegree]} ${localScale}px` : undefined, -                boxShadow: highlighting && borderRounding && highlightStyles[fullDegree] !== "dashed" ? `0 0 0 ${localScale}px ${highlightColors[fullDegree]}` : +                outline: highlighting && !borderRounding ? `${highlightColors[highlightIndex]} ${highlightStyles[highlightIndex]} ${highlightIndex}px` : "solid 0px", +                border: highlighting && borderRounding && highlightStyles[highlightIndex] === "dashed" ? `${highlightStyles[highlightIndex]} ${highlightColors[highlightIndex]} ${highlightIndex}px` : undefined, +                boxShadow: highlighting && borderRounding && highlightStyles[highlightIndex] !== "dashed" ? `0 0 0 ${highlightIndex}px ${highlightColors[highlightIndex]}` :                      this.Document.isLinkButton && !this.props.dontRegisterView && !this.props.forceHideLinkButton?.() ?                          StrCast(this.layoutDoc._linkButtonShadow, "lightblue 0em 0em 1em") :                          this.props.Document.isTemplateForField ? "black 0.2vw 0.2vw 0.8vw" :                              undefined, -                background: finalColor, -                opacity: finalOpacity, +                background, +                opacity,                  fontFamily: StrCast(this.Document._fontFamily, "inherit"),                  fontSize: !this.props.treeViewDoc ? Cast(this.Document._fontSize, "string", null) : undefined,              }}> @@ -1140,7 +1138,7 @@ export class DocumentView extends DocComponent<DocumentViewProps, Document>(Docu          </div>;      }      render() { -        return <div className="documentView-effectsWrapper" ref={this._mainCont} > +        return <div className={DocumentView.ROOT_DIV} onContextMenu={this.onContextMenu} ref={this._mainCont} >              {PresBox.EffectsProvider(this.layoutDoc, this.renderDoc) || this.renderDoc}          </div>;      } diff --git a/src/client/views/nodes/LabelBox.tsx b/src/client/views/nodes/LabelBox.tsx index 826ccd340..dd751b802 100644 --- a/src/client/views/nodes/LabelBox.tsx +++ b/src/client/views/nodes/LabelBox.tsx @@ -72,7 +72,7 @@ export class LabelBox extends ViewBoxBaseComponent<FieldViewProps, LabelDocument                  onMouseLeave={action(() => this._mouseOver = false)}                  onMouseOver={action(() => this._mouseOver = true)}                  ref={this.createDropTarget} onContextMenu={this.specificContextMenu} -                style={{ boxShadow: this.layoutDoc.opacity ? StrCast(this.layoutDoc.boxShadow) : "" }}> +                style={{ boxShadow: this.props.styleProvider?.(this.layoutDoc, this.props, "boxShadow") }}>                  <div className="labelBox-mainButton" style={{                      background: StrCast(this.layoutDoc.backgroundColor),                      backgroundColor: this.backColor, diff --git a/src/client/views/nodes/SliderBox.tsx b/src/client/views/nodes/SliderBox.tsx index d13680046..bcaf04da6 100644 --- a/src/client/views/nodes/SliderBox.tsx +++ b/src/client/views/nodes/SliderBox.tsx @@ -48,7 +48,7 @@ export class SliderBox extends ViewBoxBaseComponent<FieldViewProps, SliderDocume          const defaultValues = [NumCast(this.dataDoc[this.minThumbKey]), NumCast(this.dataDoc[this.maxThumbKey])];          return domain[1] <= domain[0] ? (null) : (              <div className="sliderBox-outerDiv" onContextMenu={this.specificContextMenu} onPointerDown={e => e.stopPropagation()} -                style={{ boxShadow: this.layoutDoc.opacity === 0 ? undefined : StrCast(this.layoutDoc.boxShadow, "") }}> +                style={{ boxShadow: this.props.styleProvider?.(this.layoutDoc, this.props, "boxShadow") }}>                  <div className="sliderBox-mainButton" onContextMenu={this.specificContextMenu} style={{                      background: StrCast(this.layoutDoc.backgroundColor), color: StrCast(this.layoutDoc.color, "black"),                      fontSize: StrCast(this.layoutDoc._fontSize), letterSpacing: StrCast(this.layoutDoc.letterSpacing) diff --git a/src/client/views/presentationview/PresElementBox.tsx b/src/client/views/presentationview/PresElementBox.tsx index 37752d6ee..7eda04930 100644 --- a/src/client/views/presentationview/PresElementBox.tsx +++ b/src/client/views/presentationview/PresElementBox.tsx @@ -21,6 +21,7 @@ import { CurrentUserUtils } from "../../util/CurrentUserUtils";  import { undoBatch } from "../../util/UndoManager";  import { EditableView } from "../EditableView";  import { DocumentManager } from "../../util/DocumentManager"; +import { DocumentViewProps } from "../nodes/DocumentView";  export const presSchema = createSchema({      presentationTargetDoc: Doc, @@ -76,6 +77,10 @@ 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: DocumentViewProps, property: string): any => { +        if (property === "opacity") return 1; +        return this.props.styleProvider?.(doc, props, property); +    }      /**       * The function that is responsible for rendering a preview or not for this       * presentation element. @@ -87,7 +92,7 @@ export class PresElementBox extends ViewBoxBaseComponent<FieldViewProps, PresDoc                      Document={this.targetDoc}                      DataDoc={this.targetDoc[DataSym] !== this.targetDoc && this.targetDoc[DataSym]}                      fitToBox={true} -                    styleProvider={this.props.styleProvider} +                    styleProvider={this.styleProvider}                      rootSelected={returnTrue}                      addDocument={returnFalse}                      removeDocument={returnFalse} @@ -102,7 +107,6 @@ export class PresElementBox extends ViewBoxBaseComponent<FieldViewProps, PresDoc                      focus={emptyFunction}                      whenActiveChanged={returnFalse}                      bringToFront={returnFalse} -                    opacity={returnOne}                      docFilters={this.props.docFilters}                      docRangeFilters={this.props.docRangeFilters}                      searchFilterDocs={this.props.searchFilterDocs} | 
