import { action, computed, observable, runInAction } from "mobx"; import { observer } from "mobx-react"; import { HeightSym, Opt, WidthSym } from "../../../new_fields/Doc"; import { ScriptField } from "../../../new_fields/ScriptField"; import { BoolCast, NumCast, StrCast } from "../../../new_fields/Types"; import { ContextMenu } from "../ContextMenu"; import { ContextMenuProps } from "../ContextMenuItem"; import { CollectionFreeFormView } from "./collectionFreeForm/CollectionFreeFormView"; import { CollectionSubView } from "./CollectionSubView"; import "./CollectionPileView.scss"; import React = require("react"); import { setupMoveUpEvents, emptyFunction, returnFalse } from "../../../Utils"; import { SelectionManager } from "../../util/SelectionManager"; @observer export class CollectionPileView extends CollectionSubView(doc => doc) { _lastTap = 0; _doubleTap: boolean | undefined = false; _originalChrome: string = ""; @observable _contentsActive = true; @observable _layoutEngine = "pass"; @observable _collapsed: boolean = false; @observable _childClickedScript: Opt; componentDidMount() { this._originalChrome = StrCast(this.layoutDoc._chromeStatus); this.layoutDoc._chromeStatus = "disabled"; this.layoutDoc.hideFilterView = true; } componentWillUnmount() { this.layoutDoc.hideFilterView = false; this.layoutDoc._chromeStatus = this._originalChrome; } layoutEngine = () => this._layoutEngine; @computed get contents() { return
; } specificMenu = (e: React.MouseEvent) => { const layoutItems: ContextMenuProps[] = []; const doc = this.props.Document; ContextMenu.Instance.addItem({ description: "Options...", subitems: layoutItems, icon: "eye" }); } toggleStarburst = action(() => { if (this._layoutEngine === 'starburst') { const defaultSize = 110; this.layoutDoc.overflow = undefined; this.rootDoc.x = NumCast(this.rootDoc.x) + this.layoutDoc[WidthSym]() / 2 - NumCast(this.layoutDoc._starburstPileWidth, defaultSize) / 2; this.rootDoc.y = NumCast(this.rootDoc.y) + this.layoutDoc[HeightSym]() / 2 - NumCast(this.layoutDoc._starburstPileHeight, defaultSize) / 2; this.layoutDoc._width = NumCast(this.layoutDoc._starburstPileWidth, defaultSize); this.layoutDoc._height = NumCast(this.layoutDoc._starburstPileHeight, defaultSize); this._layoutEngine = 'pass'; } else { const defaultSize = 25; this.layoutDoc.overflow = 'visible'; !this.layoutDoc._starburstRadius && (this.layoutDoc._starburstRadius = 500); !this.layoutDoc._starburstDocScale && (this.layoutDoc._starburstDocScale = 2.5); if (this._layoutEngine === 'pass') { this.rootDoc.x = NumCast(this.rootDoc.x) + this.layoutDoc[WidthSym]() / 2 - defaultSize / 2; this.rootDoc.y = NumCast(this.rootDoc.y) + this.layoutDoc[HeightSym]() / 2 - defaultSize / 2; this.layoutDoc._starburstPileWidth = this.layoutDoc[WidthSym](); this.layoutDoc._starburstPileHeight = this.layoutDoc[HeightSym](); } this.layoutDoc._width = this.layoutDoc._height = defaultSize; this._layoutEngine = 'starburst'; } }); pointerDown = (e: React.PointerEvent) => { // this._lastTap should be set to 0, and this._doubleTap should be set to false in the class header setupMoveUpEvents(this, e, returnFalse, emptyFunction, emptyFunction, false, false); // this sets _doubleTap } onClick = (e: React.MouseEvent) => { if (e.button === 0 && (this._doubleTap || this.layoutEngine() === "starburst")) { SelectionManager.DeselectAll(); this.toggleStarburst(); e.stopPropagation(); } else if (this.layoutEngine() === "pass") { runInAction(() => this._contentsActive = false); setTimeout(action(() => this._contentsActive = true), 300); } } render() { return
{this.contents}
; } }