aboutsummaryrefslogtreecommitdiff
path: root/src/client/views/nodes/DataVizBox/DocCreatorMenu.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'src/client/views/nodes/DataVizBox/DocCreatorMenu.tsx')
-rw-r--r--src/client/views/nodes/DataVizBox/DocCreatorMenu.tsx119
1 files changed, 100 insertions, 19 deletions
diff --git a/src/client/views/nodes/DataVizBox/DocCreatorMenu.tsx b/src/client/views/nodes/DataVizBox/DocCreatorMenu.tsx
index d5c2bc227..dbd385047 100644
--- a/src/client/views/nodes/DataVizBox/DocCreatorMenu.tsx
+++ b/src/client/views/nodes/DataVizBox/DocCreatorMenu.tsx
@@ -1,16 +1,25 @@
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
-import { action, computed, IReactionDisposer, makeObservable, observable } from 'mobx';
+import { action, computed, IReactionDisposer, makeObservable, observable, runInAction } from 'mobx';
import { observer } from 'mobx-react';
import * as React from 'react';
import { SnappingManager } from '../../../util/SnappingManager';
import './DocCreatorMenu.scss';
import { ObservableReactComponent } from '../../ObservableReactComponent';
+import { IconButton, Size } from 'browndash-components';
+import { returnFalse, setupMoveUpEvents } from '../../../../ClientUtils';
+import { emptyFunction } from '../../../../Utils';
+import { undoable } from '../../../util/UndoManager';
+import { DragManager } from '../../../util/DragManager';
+import { DocumentView } from '../DocumentView';
+import { dropActionType } from '../../../util/DropActionTypes';
@observer
export class DocCreatorMenu extends ObservableReactComponent<{}> {
static Instance: DocCreatorMenu;
+ private _ref: HTMLDivElement | null = null;
+
private _reactionDisposer?: IReactionDisposer;
@observable _pageX: number = 0;
@@ -22,8 +31,12 @@ export class DocCreatorMenu extends ObservableReactComponent<{}> {
@observable _mouseX: number = -1;
@observable _mouseY: number = -1;
+ @observable _startPos: {x: number, y: number} | undefined = undefined;
@observable _shouldDisplay: boolean = false;
+ @observable _menuContent: 'templates' | 'options' = 'templates';
+ @observable _dragging: boolean = false;
+
constructor(props: any) {
super(props);
makeObservable(this);
@@ -35,6 +48,7 @@ export class DocCreatorMenu extends ObservableReactComponent<{}> {
this._mouseX = e.clientX;
this._mouseY = e.clientY;
};
+
@action
onPointerUp = (e: PointerEvent) => {
if (e.button !== 2 && !e.ctrlKey) return;
@@ -43,10 +57,6 @@ export class DocCreatorMenu extends ObservableReactComponent<{}> {
if (Math.abs(this._mouseX - curX) > 1 || Math.abs(this._mouseY - curY) > 1) {
this._shouldDisplay = false;
}
-
- if (this._shouldDisplay) {
- this._display = true;
- }
};
componentDidMount() {
@@ -67,18 +77,18 @@ export class DocCreatorMenu extends ObservableReactComponent<{}> {
return this._pageX + DocCreatorMenu.width > window.innerWidth - DocCreatorMenu.buffer ? window.innerWidth - DocCreatorMenu.buffer - DocCreatorMenu.width : Math.max(0, this._pageX);
}
- get pageY() {
- return this._pageY + DocCreatorMenu.height > window.innerHeight - DocCreatorMenu.buffer ? window.innerHeight - DocCreatorMenu.buffer - DocCreatorMenu.height : Math.max(0, this._pageY);
- }
-
@action
- displayMenu = (x: number, y: number) => {
+ toggleDisplay = (x: number, y: number) => {
// maxX and maxY will change if the UI/font size changes, but will work for any amount
// of items added to the menu
-
- this._pageX = x;
- this._pageY = y;
- this._shouldDisplay = true;
+ if (this._shouldDisplay) {
+ this._shouldDisplay = false;
+ } else {
+ this._pageX = x;
+ console.log(y);
+ this._pageY = y;
+ this._shouldDisplay = true;
+ }
};
@action
@@ -89,21 +99,92 @@ export class DocCreatorMenu extends ObservableReactComponent<{}> {
return wasOpen;
};
+ @action
+ onPointerMove = (e: any) => {
+ if (this._dragging){
+ this._pageX = e.pageX - (this._startPos?.x ?? 0);
+ this._pageY = e.pageY - (this._startPos?.y ?? 0);
+ }
+ }
+
+ setDragStart = () => {
+
+ }
+
render() {
return (
<div
className="docCreatorMenu-cont"
+ ref={r => this._ref = r}
style={{
display: '',
- left: this.pageX,
- ...(this._yRelativeToTop ? { top: Math.max(0, this.pageY) } : { bottom: this.pageY }),
+ left: this._pageX,
+ top: this._pageY,
+ width: this._shouldDisplay ? 300 : 0,
+ height: this._shouldDisplay ? 400 : 0,
background: SnappingManager.userBackgroundColor,
color: SnappingManager.userColor,
}}>
{!this._shouldDisplay ? undefined :
- <div>hi hi</div>
-
-
+ <>
+ <div
+ className='docCreatorMenu-menu'
+ onPointerDown={e =>
+ setupMoveUpEvents(
+ this,
+ e,
+ (e) => {
+ this._dragging = true;
+ this._startPos = {x: 0, y: 0};
+ this._startPos.x = e.pageX - (this._ref?.getBoundingClientRect().left ?? 0);
+ this._startPos.y = e.pageY - (this._ref?.getBoundingClientRect().top ?? 0);
+ return true;
+ },
+ emptyFunction,
+ undoable(clickEv => {
+ clickEv.stopPropagation();
+ }, 'open actions menu')
+ )
+
+ }
+ onPointerMove={e => this.onPointerMove(e)}
+ onPointerUp={() => this._dragging = false}
+ >
+ <button
+ className='docCreatorMenu-menu-button'
+ onPointerDown={e =>
+ setupMoveUpEvents(
+ this,
+ e,
+ returnFalse,
+ emptyFunction,
+ undoable(clickEv => {
+ clickEv.stopPropagation();
+ runInAction(() => this._menuContent = this._menuContent === 'templates' ? 'options' : 'templates');
+ }, 'open actions menu')
+ )
+ }
+ >
+ <FontAwesomeIcon icon={this._menuContent === 'templates' ? 'table-cells' : 'window-maximize'}/>
+ </button>
+ <button className='docCreatorMenu-menu-button close-menu'>
+ <FontAwesomeIcon icon={'minus'}/>
+ </button>
+ <button className='docCreatorMenu-menu-button right'>
+ <FontAwesomeIcon icon={'plus'}/>
+ </button>
+ </div>
+ <hr className='docCreatorMenu-menu-hr'/>
+ <div className='docCreatorMenu-content'>
+ {this._menuContent === 'templates' ?
+ <div>
+ </div>
+ :
+ <div>
+ </div>
+ }
+ </div>
+ </>
}
</div>
)