diff options
Diffstat (limited to 'src/client/views/nodes/IconBox.tsx')
| -rw-r--r-- | src/client/views/nodes/IconBox.tsx | 30 | 
1 files changed, 22 insertions, 8 deletions
| diff --git a/src/client/views/nodes/IconBox.tsx b/src/client/views/nodes/IconBox.tsx index 3fab10df4..00021bc78 100644 --- a/src/client/views/nodes/IconBox.tsx +++ b/src/client/views/nodes/IconBox.tsx @@ -2,18 +2,16 @@ import React = require("react");  import { library } from '@fortawesome/fontawesome-svg-core';  import { faCaretUp, faFilePdf, faFilm, faImage, faObjectGroup, faStickyNote } from '@fortawesome/free-solid-svg-icons';  import { FontAwesomeIcon } from "@fortawesome/react-fontawesome"; -import { action, computed, observable, runInAction } from "mobx"; +import { computed, observable, runInAction } from "mobx";  import { observer } from "mobx-react"; -import { SelectionManager } from "../../util/SelectionManager";  import { FieldView, FieldViewProps } from './FieldView';  import "./IconBox.scss";  import { Cast, StrCast, BoolCast } from "../../../new_fields/Types"; -import { Doc, WidthSym, HeightSym } from "../../../new_fields/Doc"; +import { Doc, DocListCast } from "../../../new_fields/Doc";  import { IconField } from "../../../new_fields/IconField";  import { ContextMenu } from "../ContextMenu";  import Measure from "react-measure";  import { MINIMIZED_ICON_SIZE } from "../../views/globalCssVariables.scss"; -import { listSpec } from "../../../new_fields/Schema";  library.add(faCaretUp); @@ -42,24 +40,40 @@ export class IconBox extends React.Component<FieldViewProps> {      setLabelField = (e: React.MouseEvent): void => {          this.props.Document.hideLabel = !BoolCast(this.props.Document.hideLabel);      } +    setUseOwnTitleField = (e: React.MouseEvent): void => { +        this.props.Document.useOwnTitle = !BoolCast(this.props.Document.useTargetTitle); +    }      specificContextMenu = (e: React.MouseEvent): void => {          ContextMenu.Instance.addItem({ -            description: BoolCast(this.props.Document.hideLabel) ? "show label" : "hide label", +            description: BoolCast(this.props.Document.hideLabel) ? "Show label with icon" : "Remove label from icon",              event: this.setLabelField          }); +        let maxDocs = DocListCast(this.props.Document.maximizedDocs); +        if (maxDocs.length === 1 && !BoolCast(this.props.Document.hideLabel)) { +            ContextMenu.Instance.addItem({ +                description: BoolCast(this.props.Document.useOwnTitle) ? "Use target title for label" : "Use own title label", +                event: this.setUseOwnTitleField +            }); +        }      }      @observable _panelWidth: number = 0;      @observable _panelHeight: number = 0;      render() {          let labelField = StrCast(this.props.Document.labelField);          let hideLabel = BoolCast(this.props.Document.hideLabel); -        let maxDoc = Cast(this.props.Document.maximizedDocs, listSpec(Doc), []); -        let label = !hideLabel && maxDoc && labelField ? (maxDoc.length === 1 ? maxDoc[0][labelField] : this.props.Document[labelField]) : ""; +        let maxDocs = DocListCast(this.props.Document.maximizedDocs); +        let firstDoc = maxDocs.length ? maxDocs[0] : undefined; +        let label = hideLabel ? "" : (firstDoc && labelField && !BoolCast(this.props.Document.useOwnTitle, false) ? firstDoc[labelField] : this.props.Document.title);          return (              <div className="iconBox-container" onContextMenu={this.specificContextMenu}>                  {this.minimizedIcon} -                <Measure onResize={(r) => runInAction(() => { if (r.entry.width || BoolCast(this.props.Document.hideLabel)) this.props.Document.nativeWidth = this.props.Document.width = (r.entry.width + Number(MINIMIZED_ICON_SIZE)); })}> +                <Measure offset onResize={(r) => runInAction(() => { +                    if (r.offset!.width || BoolCast(this.props.Document.hideLabel)) { +                        this.props.Document.nativeWidth = (r.offset!.width + Number(MINIMIZED_ICON_SIZE)); +                        if (this.props.Document.height === Number(MINIMIZED_ICON_SIZE)) this.props.Document.width = this.props.Document.nativeWidth; +                    } +                })}>                      {({ measureRef }) =>                          <span ref={measureRef} className="iconBox-label">{label}</span>                      } | 
