aboutsummaryrefslogtreecommitdiff
path: root/src/client/views/nodes/Track.tsx
diff options
context:
space:
mode:
authorandrewdkim <adkim414@gmail.com>2019-06-28 16:40:33 -0400
committerandrewdkim <adkim414@gmail.com>2019-06-28 16:40:33 -0400
commit3c735287ec92664e368649fea63ccd85210b5fc5 (patch)
tree817a3c10f4babc3d72978761e153e4e47ceebf5b /src/client/views/nodes/Track.tsx
parent5c4f8dbe2a2506b998f80a0cf17e1044d0af7405 (diff)
flyout
Diffstat (limited to 'src/client/views/nodes/Track.tsx')
-rw-r--r--src/client/views/nodes/Track.tsx257
1 files changed, 112 insertions, 145 deletions
diff --git a/src/client/views/nodes/Track.tsx b/src/client/views/nodes/Track.tsx
index c7154fbb3..957128040 100644
--- a/src/client/views/nodes/Track.tsx
+++ b/src/client/views/nodes/Track.tsx
@@ -1,50 +1,17 @@
import * as React from "react";
-import * as ReactDOM from "react-dom";
import { observer } from "mobx-react";
import { observable, reaction, action, IReactionDisposer, observe, IObservableArray, computed, toJS, IObservableObject } from "mobx";
import "./Track.scss";
-import { CollectionViewProps } from "../collections/CollectionBaseView";
-import { CollectionSubView, SubCollectionViewProps } from "../collections/CollectionSubView";
-import { DocumentViewProps, DocumentView } from "./DocumentView";
-import { CollectionFreeFormView } from "../collections/collectionFreeForm/CollectionFreeFormView";
import { Doc, DocListCastAsync, DocListCast } from "../../../new_fields/Doc";
import { Document, listSpec, createSchema, makeInterface, defaultSpec } from "../../../new_fields/Schema";
import { FieldValue, Cast, NumCast, BoolCast } from "../../../new_fields/Types";
-import { emptyStatement, thisExpression, react } from "babel-types";
-import { DocumentManager } from "../../util/DocumentManager";
-import { SelectionManager } from "../../util/SelectionManager";
import { List } from "../../../new_fields/List";
-import { Self } from "../../../new_fields/FieldSymbols";
-import { list } from "serializr";
-import { arrays, Dictionary } from "typescript-collections";
-import { forEach } from "typescript-collections/dist/lib/arrays";
-import { CompileScript } from "../../util/Scripting";
-import { FieldView } from "./FieldView";
-import { promises } from "fs";
-import { Tapable } from "tapable";
-import { Keyframe, KeyframeData } from "./Keyframe";
-import { timingSafeEqual } from "crypto";
-import { node } from "prop-types";
-
-const PositionSchema = createSchema({
- x: defaultSpec("number", 0),
- y: defaultSpec("number", 0)
-});
-
-type Position = makeInterface<[typeof PositionSchema]>;
-const Position = makeInterface(PositionSchema);
-const TimeAndPositionSchema = createSchema({
- time: defaultSpec("number", 0),
- position: Doc
-});
-
-type TimeAndPosition = makeInterface<[typeof TimeAndPositionSchema]>;
-const TimeAndPosition = makeInterface(TimeAndPositionSchema);
-
-
-interface IProp{
- node: Doc;
- currentBarX: number;
+import { Keyframe, RegionData } from "./Keyframe";
+
+interface IProp {
+ node: Doc;
+ currentBarX: number;
+ // setPosition: (position: number) => any;
}
@observer
@@ -57,54 +24,88 @@ export class Track extends React.Component<IProp> {
@observable private _keys = ["x", "y", "width", "height", "panX", "panY", "scale"];
- @computed
- private get keyframes(){
- return Cast(this.props.node.keyframes, listSpec(Doc)) as List<Doc> ;
+ componentWillMount() {
+ this.props.node.regions = new List<Doc>();
+ console.log((Cast(this.props.node.regions, listSpec(Doc)) as List<Doc>).length);
}
+ @action
+ componentDidMount() {
+ this.props.node.hidden = true;
+ this.props.node.opacity = 0;
+ reaction(() => this.props.currentBarX, () => {
+ let region: (Doc | undefined) = this.findRegion(this.props.currentBarX);
+ if (region !== undefined) {
+ this.props.node.hidden = false;
+ this.timeChange(this.props.currentBarX);
+ } else {
+ this.props.node.hidden = true;
+ }
+ });
+
+ // reaction(() => {
+ // let keys = Doc.allKeys(this.props.node);
+ // let x = keys.indexOf("keyframes");
+ // let afterX = keys.slice(x + 1);
+ // let beforeX = keys.slice(0, x);
+ // keys = beforeX.concat(afterX);
+ // return keys.map(key => FieldValue(this.props.node[key]));
+ // }, data => {
+ // if (this.keyframes.length !== 0){
+ // let kf:(Doc | undefined) = this.findKeyframe(this.props.currentBarX);
+ // }
+ // });
+ }
+ /**
+ * removes reaction when the component is removed from the timeline
+ */
+ componentWillUnmount() {
+ this._reactionDisposers.forEach(disp => disp());
+ this._reactionDisposers = [];
+ }
@action
timeChange = async (time: number) => {
- let singlekfd = this.findKeyframe(time);
- let leftkf: (Doc | undefined) = this.calcMinLeft(singlekfd!);
- let rightkf: (Doc | undefined) = this.calcMinRight(singlekfd!);
-
- if (leftkf && rightkf){
- this.interpolate(leftkf, rightkf);
- } else if(leftkf){
- console.log("left exists");
+ let region = this.findRegion(time);
+ let leftkf: (Doc | undefined) = this.calcMinLeft(region!);
+ let rightkf: (Doc | undefined) = this.calcMinRight(region!);
+
+ if (leftkf && rightkf) {
+ this.interpolate(leftkf, rightkf);
+ } else if (leftkf) {
+ console.log("left exists");
this._keys.forEach(k => {
- let data = leftkf!.key as Doc;
- this.props.node[k] = data[k];
- });
- } else if (rightkf){
- console.log("right exists");
+ let data = leftkf!.key as Doc;
+ this.props.node[k] = data[k];
+ });
+ } else if (rightkf) {
+ console.log("right exists");
this._keys.forEach(k => {
- let data = rightkf!.key as Doc;
- this.props.node[k] = data[k];
- });
+ let data = rightkf!.key as Doc;
+ this.props.node[k] = data[k];
+ });
}
}
-
+
/**
* calculates the closest left keyframe, if there is one
* @param kfList: keyframe list
* @param time
*/
@action
- calcMinLeft = (singlekfd: Doc): (Doc|undefined) => { //returns the time of the closet keyframe to the left
- let leftKf:Doc = new Doc();
- leftKf.time = Infinity;
- (singlekfd.kfs! as List<Doc>).forEach((kf) => {
+ calcMinLeft = (region: Doc): (Doc | undefined) => { //returns the time of the closet keyframe to the left
+ let leftKf: Doc = new Doc();
+ leftKf.time = Infinity;
+ (region.keyframes! as List<Doc>).forEach((kf) => {
kf = kf as Doc;
if (NumCast(kf.time) < this.props.currentBarX && NumCast(leftKf.time) > NumCast(kf.time)) {
- leftKf = kf;
+ leftKf = kf;
}
});
- if (NumCast(leftKf.time) === Infinity){
- return undefined;
+ if (NumCast(leftKf.time) === Infinity) {
+ return undefined;
}
return leftKf;
}
@@ -115,36 +116,36 @@ export class Track extends React.Component<IProp> {
* @param time: time
*/
@action
- calcMinRight = (singlekfd: Doc): (Doc|undefined) => { //returns the time of the closest keyframe to the right
- let rightKf:Doc = new Doc();
- rightKf.time = Infinity;
- (singlekfd.kfs! as List<Doc>).forEach((kf) => {
+ calcMinRight = (region: Doc): (Doc | undefined) => { //returns the time of the closest keyframe to the right
+ let rightKf: Doc = new Doc();
+ rightKf.time = Infinity;
+ (region.keyframes! as List<Doc>).forEach((kf) => {
kf = kf as Doc;
if (NumCast(kf.time) > this.props.currentBarX && NumCast(rightKf.time) > NumCast(kf.time)) {
- rightKf = kf;
+ rightKf = kf;
}
});
- if (NumCast(rightKf.time) === Infinity){
- return undefined;
+ if (NumCast(rightKf.time) === Infinity) {
+ return undefined;
}
return rightKf;
}
- /**
- * Linearly interpolates a document from time1 to time2
- * @param Doc that needs to be modified
- * @param kf1 timeandposition of the first yellow bar
- * @param kf2 timeandposition of the second yellow bar
- * @param time time that you want to interpolate
- */
+ /**
+ * Linearly interpolates a document from time1 to time2
+ * @param Doc that needs to be modified
+ * @param kf1 timeandposition of the first yellow bar
+ * @param kf2 timeandposition of the second yellow bar
+ * @param time time that you want to interpolate
+ */
@action
interpolate = async (kf1: Doc, kf2: Doc) => {
- let node1 = kf1.key as Doc;
- let node2 = kf2.key as Doc;
- console.log(toJS(node1));
- console.log(toJS(node2));
+ let node1 = kf1.key as Doc;
+ let node2 = kf2.key as Doc;
+ console.log(toJS(node1));
+ console.log(toJS(node2));
const dif_time = NumCast(kf2.time) - NumCast(kf1.time);
const ratio = (this.props.currentBarX - NumCast(kf1.time)) / dif_time; //linear
@@ -155,74 +156,38 @@ export class Track extends React.Component<IProp> {
});
}
- @action
- componentDidMount() {
- this.props.node.hidden = true;
- this.props.node.opacity = 0;
- this.props.node.keyframes = new List<Doc>();
- reaction (() => this.props.currentBarX, () => {
- this.keyframes.forEach((kfd) => {
- kfd = KeyframeData(kfd as Doc);
- if (kfd.length !== 0){
- let singlekfd:(Doc | undefined) = this.findKeyframe(this.props.currentBarX);
- if (singlekfd !== undefined){
- this.props.node.hidden = false;
- this.timeChange(this.props.currentBarX);
- } else {
- this.props.node.hidden = true;
- }
- }
- });
- });
-
- // reaction(() => {
- // let keys = Doc.allKeys(this.props.node);
- // let x = keys.indexOf("keyframes");
- // let afterX = keys.slice(x + 1);
- // let beforeX = keys.slice(0, x);
- // keys = beforeX.concat(afterX);
- // return keys.map(key => FieldValue(this.props.node[key]));
- // }, data => {
- // if (this.keyframes.length !== 0){
- // let kf:(Doc | undefined) = this.findKeyframe(this.props.currentBarX);
- // }
- // });
- }
- @action
- findKeyframe(time:number): (Doc | undefined){
- let foundKeyframe = undefined;
- this.keyframes.map(kfd => {
- kfd = KeyframeData(kfd as Doc);
- if (time >= NumCast(kfd.position) && time <= (NumCast(kfd.position) + NumCast(kfd.duration))){
- foundKeyframe = kfd;
- }
- });
- return foundKeyframe;
- }
- /**
- * removes reaction when the component is removed from the timeline
- */
- componentWillUnmount() {
- this._reactionDisposers.forEach(disp => disp());
- this._reactionDisposers = [];
+ @action
+ findRegion(time: number): (Doc | undefined) {
+ let foundRegion = undefined;
+ this.regions.map(region => {
+ region = RegionData(region as Doc);
+ if (time >= NumCast(region.position) && time <= (NumCast(region.position) + NumCast(region.duration))) {
+ foundRegion = region;
+ }
+ });
+ return foundRegion;
}
- @observable private _keyframes: JSX.Element[] = [];
-
- @action
+ @action
onInnerDoubleClick = (e: React.MouseEvent) => {
- let inner = this._inner.current!;
+ let inner = this._inner.current!;
let left = inner.getBoundingClientRect().left;
let offsetX = Math.round(e.clientX - left);
- let keyframedata:Doc = new Doc();
- keyframedata.duration = 200;
- keyframedata.position = offsetX;
- keyframedata.kfs = new List<Doc>();
- this.keyframes.push(keyframedata);
- this._keyframes.push(<Keyframe node={this.props.node} keyframedata={keyframedata}/>);
+ let regiondata: Doc = new Doc(); //creating regiond ata
+ regiondata.duration = 200;
+ regiondata.position = offsetX;
+ regiondata.keyframes = new List<Doc>();
+ this.regions.push(regiondata);
+ }
+
+
+ @computed
+ private get regions() {
+ console.log((Cast(this.props.node.regions, listSpec(Doc)) as List<Doc>).length + "from get");
+ return Cast(this.props.node.regions, listSpec(Doc)) as List<Doc>;
}
render() {
@@ -230,7 +195,9 @@ export class Track extends React.Component<IProp> {
<div className="track-container">
<div className="track">
<div className="inner" ref={this._inner} onDoubleClick={this.onInnerDoubleClick}>
- {this._keyframes.map((element)=> element)}
+ {this.regions.map((region) => {
+ return <Keyframe node={this.props.node} RegionData={region as Doc}/>;
+ })}
</div>
</div>
</div>