aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorEleanor Eng <eleanor_eng@brown.edu>2019-04-29 17:44:47 -0400
committerEleanor Eng <eleanor_eng@brown.edu>2019-04-29 17:44:47 -0400
commita92c169ffc92fd5aa21cc1b85286b77d529cac1b (patch)
tree1ac7e2f963f1aa93506f68bb21adab811faa794b /src
parent0ebf923349f5acb1d5518cce9d6bda5a66655a0e (diff)
more good stuff but doesn't work
Diffstat (limited to 'src')
-rw-r--r--src/client/views/nodes/DocumentView.tsx19
-rw-r--r--src/client/views/nodes/Timeline.tsx23
2 files changed, 28 insertions, 14 deletions
diff --git a/src/client/views/nodes/DocumentView.tsx b/src/client/views/nodes/DocumentView.tsx
index c47a56168..0691e8c30 100644
--- a/src/client/views/nodes/DocumentView.tsx
+++ b/src/client/views/nodes/DocumentView.tsx
@@ -188,8 +188,9 @@ export class DocumentView extends React.Component<DocumentViewProps> {
if (maxdoc instanceof Document) {
this.props.addDocument && this.props.addDocument(maxdoc, false);
this.toggleIcon();
- } else
+ } else {
SelectionManager.SelectDoc(this, e.ctrlKey);
+ }
});
}
}
@@ -222,7 +223,7 @@ export class DocumentView extends React.Component<DocumentViewProps> {
@action createIcon = (layoutString: string): Document => {
let iconDoc = Documents.IconDocument(layoutString);
- iconDoc.SetText(KeyStore.Title, "ICON" + this.props.Document.Title)
+ iconDoc.SetText(KeyStore.Title, "ICON" + this.props.Document.Title);
iconDoc.SetBoolean(KeyStore.IsMinimized, false);
iconDoc.SetNumber(KeyStore.NativeWidth, 0);
iconDoc.SetNumber(KeyStore.NativeHeight, 0);
@@ -286,23 +287,24 @@ export class DocumentView extends React.Component<DocumentViewProps> {
let maxw = await maximizedDoc.GetTAsync(KeyStore.Width, NumberField);
let maxh = await maximizedDoc.GetTAsync(KeyStore.Height, NumberField);
if (minx !== undefined && miny !== undefined && maxx !== undefined && maxy !== undefined &&
- maxw !== undefined && maxh !== undefined)
+ maxw !== undefined && maxh !== undefined) {
this.animateBetweenIcon(
[minx.Data, miny.Data], [maxx.Data, maxy.Data], maxw.Data, maxh.Data,
Date.now(), maximizedDoc, isMinimized);
+ }
}
}
- })
+ });
}
@action
public getIconDoc = async (): Promise<Document | undefined> => {
- return await this.props.Document.GetTAsync(KeyStore.MinimizedDoc, Document).then(async mindoc =>
+ return this.props.Document.GetTAsync(KeyStore.MinimizedDoc, Document).then(async mindoc =>
mindoc ? mindoc :
- await this.props.Document.GetTAsync(KeyStore.BackgroundLayout, TextField).then(async field =>
+ this.props.Document.GetTAsync(KeyStore.BackgroundLayout, TextField).then(async field =>
(field instanceof TextField) ? this.createIcon(field.Data) :
- await this.props.Document.GetTAsync(KeyStore.Layout, TextField).then(field =>
+ this.props.Document.GetTAsync(KeyStore.Layout, TextField).then(field =>
(field instanceof TextField) ? this.createIcon(field.Data) : undefined)));
}
@@ -380,8 +382,9 @@ export class DocumentView extends React.Component<DocumentViewProps> {
//ContextMenu.Instance.addItem({ description: "Docking", event: () => this.props.Document.SetNumber(KeyStore.ViewType, CollectionViewType.Docking) })
ContextMenu.Instance.addItem({ description: "Delete", event: this.deleteClicked });
ContextMenu.Instance.displayMenu(e.pageX - 15, e.pageY - 15);
- if (!SelectionManager.IsSelected(this))
+ if (!SelectionManager.IsSelected(this)) {
SelectionManager.SelectDoc(this, false);
+ }
}
isSelected = () => SelectionManager.IsSelected(this);
diff --git a/src/client/views/nodes/Timeline.tsx b/src/client/views/nodes/Timeline.tsx
index 4e6fe567c..a64e1a7a8 100644
--- a/src/client/views/nodes/Timeline.tsx
+++ b/src/client/views/nodes/Timeline.tsx
@@ -21,6 +21,7 @@ export class Timeline extends React.Component<SubCollectionViewProps> {
@observable private _newBar: any = null;
private _reactionDisposers: IReactionDisposer[] = [];
private _keyFrames: KeyFrame[] = [];
+ @observable private _onBar: Boolean = false;
@action
onRecord = (e: React.MouseEvent) => {
@@ -30,7 +31,7 @@ export class Timeline extends React.Component<SubCollectionViewProps> {
@action
onStop = (e: React.MouseEvent) => {
this._isRecording = false;
- if (this._inner.current) { //if you comment this section out it works as before...
+ if (this._inner.current) {
this._newBar = document.createElement("div");
this._newBar.style.height = "100%";
this._newBar.style.width = "5px";
@@ -64,26 +65,36 @@ export class Timeline extends React.Component<SubCollectionViewProps> {
this._currentBar.style.backgroundColor = "green";
this._currentBar.style.transform = `translate(${0}px)`;
this._currentBar.style.position = "absolute";
+ this._currentBar.onPointerDown(this.selectFrame);
this._inner.current.appendChild(this._currentBar);
}
+ }
+ selectFrame = (e: React.PointerEvent) => {
+ this._onBar = true; //where to set back to false?
+ //let frame = document.getSelectedElement(e)
}
componentDidMount() {
this.createBar(5);
let doc: Document = this.props.Document;
let childrenList = this.props.Document.GetList(this.props.fieldKey, [] as Document[]);
- let keyFrame = new KeyFrame();
- this._keyFrames.push(keyFrame);
+ // let keyFrame = new KeyFrame(); //should not be done here...
+ // this._keyFrames.push(keyFrame);
let keys = [KeyStore.X, KeyStore.Y];
const addReaction = (element: Document) => {
return reaction(() => {
return keys.map(key => element.GetNumber(key, 0));
}, data => {
+ let keyFrame = new KeyFrame();
+ if (this._onBar) { //need to set value of onBar somewhere... -> if already on key frame use this keyframe
+ // keyFrame = function that returns current keyFrame;
+ } else { //else create new keyframe
+ this._keyFrames.push(keyFrame);
+ }
keys.forEach((key, index) => {
- console.log("moved!"); //now need to store key frames -> create a way to do this (data structure??)
- this._keyFrames.push(); //change thisss
- //keyFrame.document().SetNumber(key, data[index]);
+ console.log("moved!"); //store key frames -> need to create a way to do this (data structure??)
+ keyFrame.document().SetNumber(key, data[index]); //Tyler working on better Doc.ts functions...(this is currently not comprehensive...)
});
});
};