diff options
Diffstat (limited to 'src/client/views/collections/CollectionView.tsx')
| -rw-r--r-- | src/client/views/collections/CollectionView.tsx | 59 | 
1 files changed, 33 insertions, 26 deletions
| diff --git a/src/client/views/collections/CollectionView.tsx b/src/client/views/collections/CollectionView.tsx index e65ebf075..38e027fb3 100644 --- a/src/client/views/collections/CollectionView.tsx +++ b/src/client/views/collections/CollectionView.tsx @@ -24,7 +24,7 @@ import { CollectionCarouselView } from './CollectionCarouselView';  import { CollectionDockingView } from "./CollectionDockingView";  import { CollectionFreeFormView } from './collectionFreeForm/CollectionFreeFormView';  import { CollectionGridView } from './collectionGrid/CollectionGridView'; -import { CollectionLinearView } from './CollectionLinearView'; +import { CollectionLinearView } from './collectionLinear';  import CollectionMapView from './CollectionMapView';  import { CollectionMulticolumnView } from './collectionMulticolumn/CollectionMulticolumnView';  import { CollectionMultirowView } from './collectionMulticolumn/CollectionMultirowView'; @@ -36,6 +36,8 @@ import { CollectionTimeView } from './CollectionTimeView';  import { CollectionTreeView } from "./CollectionTreeView";  import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';  import './CollectionView.scss'; +import { returnEmptyString } from '../../../Utils'; +import { InkTool } from '../../../fields/InkField';  export const COLLECTION_BORDER_WIDTH = 2;  const path = require('path'); @@ -62,14 +64,16 @@ export enum CollectionViewType {  export interface CollectionViewProps extends FieldViewProps {      isAnnotationOverlay?: boolean;  // is the collection an annotation overlay (eg an overlay on an image/video/etc)      layoutEngine?: () => string; -    setPreviewCursor?: (func: (x: number, y: number, drag: boolean) => void) => void; +    setPreviewCursor?: (func: (x: number, y: number, drag: boolean, hide: boolean) => void) => void;      // property overrides for child documents      children?: never | (() => JSX.Element[]) | React.ReactNode;      childDocuments?: Doc[]; // used to override the documents shown by the sub collection to an explicit list (see LinkBox)      childDocumentsActive?: () => boolean;// whether child documents can be dragged if collection can be dragged (eg., in a when a Pile document is in startburst mode)      childFitWidth?: () => boolean; +    childShowTitle?: () => string;      childOpacity?: () => number; +    childContextMenuItems?: () => { script: ScriptField, label: string }[];      childHideTitle?: () => boolean; // whether to hide the documentdecorations title for children      childHideDecorationTitle?: () => boolean;      childLayoutTemplate?: () => (Doc | undefined);// specify a layout Doc template to use for children of the collection @@ -83,7 +87,7 @@ export interface CollectionViewProps extends FieldViewProps {  type CollectionDocument = makeInterface<[typeof documentSchema]>;  const CollectionDocument = makeInterface(documentSchema);  @observer -export class CollectionView extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProps & CollectionViewProps, CollectionDocument>(CollectionDocument, "") { +export class CollectionView extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProps & CollectionViewProps, CollectionDocument>(CollectionDocument) {      public static LayoutString(fieldStr: string) { return FieldView.LayoutString(CollectionView, fieldStr); }      @observable private static _safeMode = false; @@ -91,6 +95,11 @@ export class CollectionView extends ViewBoxAnnotatableComponent<ViewBoxAnnotatab      protected _multiTouchDisposer?: InteractionUtils.MultiTouchEventDisposer; +    constructor(props: any) { +        super(props); +        runInAction(() => this._annotationKeySuffix = returnEmptyString); +    } +      get collectionViewType(): CollectionViewType | undefined {          const viewField = StrCast(this.layoutDoc._viewType);          if (CollectionView._safeMode) { @@ -112,7 +121,7 @@ export class CollectionView extends ViewBoxAnnotatableComponent<ViewBoxAnnotatab          // const imageProtos = children.filter(doc => Cast(doc.data, ImageField)).map(Doc.GetProto);          // const allTagged = imageProtos.length > 0 && imageProtos.every(image => image.googlePhotosTags);          // return !allTagged ? (null) : <img id={"google-tags"} src={"/assets/google_tags.png"} />; -        this.isContentActive(); +        //this.isContentActive();      }      screenToLocalTransform = () => this.props.renderDepth ? this.props.ScreenToLocalTransform() : this.props.ScreenToLocalTransform().scale(this.props.PanelWidth() / this.bodyPanelWidth()); @@ -157,7 +166,7 @@ export class CollectionView extends ViewBoxAnnotatableComponent<ViewBoxAnnotatab          !Doc.UserDoc().noviceMode && subItems.push({ description: "Map", event: () => func(CollectionViewType.Map), icon: "globe-americas" });          subItems.push({ description: "Grid", event: () => func(CollectionViewType.Grid), icon: "th-list" }); -        if (!Doc.IsSystem(this.rootDoc) && !this.rootDoc.annotationOn) { +        if (!Doc.IsSystem(this.rootDoc) && !this.rootDoc.isGroup && !this.rootDoc.annotationOn) {              const existingVm = ContextMenu.Instance.findByDescription(category);              const catItems = existingVm && "subitems" in existingVm ? existingVm.subitems : [];              catItems.push({ description: "Add a Perspective...", addDivider: true, noexpand: true, subitems: subItems, icon: "eye" }); @@ -186,15 +195,20 @@ export class CollectionView extends ViewBoxAnnotatableComponent<ViewBoxAnnotatab              }              !Doc.UserDoc().noviceMode && optionItems.push({ description: `${this.rootDoc.isInPlaceContainer ? "Unset" : "Set"} inPlace Container`, event: () => this.rootDoc.isInPlaceContainer = !this.rootDoc.isInPlaceContainer, icon: "project-diagram" }); -            optionItems.push({ -                description: "Create Branch", event: async () => this.props.addDocTab(await BranchCreate(this.rootDoc), "add:right"), icon: "project-diagram" -            }); -            optionItems.push({ -                description: "Pull Master", event: () => BranchTask(this.rootDoc, "pull"), icon: "project-diagram" -            }); -            optionItems.push({ -                description: "Merge Branches", event: () => BranchTask(this.rootDoc, "merge"), icon: "project-diagram" -            }); +            if (!Doc.UserDoc().noviceMode) { +                optionItems.push({ +                    description: "Create Branch", event: async () => this.props.addDocTab(await BranchCreate(this.rootDoc), "add:right"), icon: "project-diagram" +                }); +                optionItems.push({ +                    description: "Pull Master", event: () => BranchTask(this.rootDoc, "pull"), icon: "project-diagram" +                }); +                optionItems.push({ +                    description: "Merge Branches", event: () => BranchTask(this.rootDoc, "merge"), icon: "project-diagram" +                }); +            } +            if (this.Document._viewType === CollectionViewType.Docking) { +                optionItems.push({ description: "Create Dashboard", event: () => CurrentUserUtils.createNewDashboard(Doc.UserDoc()), icon: "project-diagram" }); +            }              !options && cm.addItem({ description: "Options...", subitems: optionItems, icon: "hand-point-right" }); @@ -232,15 +246,12 @@ export class CollectionView extends ViewBoxAnnotatableComponent<ViewBoxAnnotatab      childLayoutTemplate = () => this.props.childLayoutTemplate?.() || Cast(this.rootDoc.childLayoutTemplate, Doc, null);      @computed get childLayoutString() { return StrCast(this.rootDoc.childLayoutString); } -    /** -    * Shows the filter icon if it's a user-created collection which isn't a dashboard and has some docFilters applied on it or on the current dashboard. -    */ -    @computed get showFilterIcon() { -        return this.props.Document.viewType !== CollectionViewType.Docking && !Doc.IsSystem(this.props.Document) && this._subView?.IsFiltered(); -    }      @observable _subView: any = undefined; +    isContentActive = (outsideReaction?: boolean) => { +        return this.props.isContentActive() ? true : false; +    }      render() {          TraceMobx();          const props: SubCollectionViewProps = { @@ -250,6 +261,8 @@ export class CollectionView extends ViewBoxAnnotatableComponent<ViewBoxAnnotatab              moveDocument: this.moveDocument,              removeDocument: this.removeDocument,              isContentActive: this.isContentActive, +            isAnyChildContentActive: this.isAnyChildContentActive, +            whenChildContentsActiveChanged: this.whenChildContentsActiveChanged,              PanelWidth: this.bodyPanelWidth,              PanelHeight: this.props.PanelHeight,              ScreenToLocalTransform: this.screenToLocalTransform, @@ -261,12 +274,6 @@ export class CollectionView extends ViewBoxAnnotatableComponent<ViewBoxAnnotatab              style={{ pointerEvents: this.props.layerProvider?.(this.rootDoc) === false ? "none" : undefined }}>              {this.showIsTagged()}              {this.collectionViewType !== undefined ? this.SubView(this.collectionViewType, props) : (null)} -            {this.showFilterIcon ? -                <FontAwesomeIcon icon={"filter"} size="lg" -                    style={{ position: 'absolute', top: '1%', right: '1%', cursor: "pointer", padding: 1, color: this.showFilterIcon === "hasFilter" ? '#18c718bd' : "orange", zIndex: 1 }} -                    onPointerDown={action(e => { this.props.select(false); CurrentUserUtils.propertiesWidth = 250; e.stopPropagation(); })} -                /> -                : (null)}          </div>);      }  } | 
