aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/client/views/nodes/Timeline.tsx148
1 files changed, 98 insertions, 50 deletions
diff --git a/src/client/views/nodes/Timeline.tsx b/src/client/views/nodes/Timeline.tsx
index aba1a6065..cdd355fb3 100644
--- a/src/client/views/nodes/Timeline.tsx
+++ b/src/client/views/nodes/Timeline.tsx
@@ -32,6 +32,8 @@ export class Timeline extends CollectionSubView(Document) {
private _currentBarX: number = 0;
@observable private _onBar: Boolean = false;
+ @observable private _keys = ["x", "y"];
+ @observable private _frames: Doc[] = [];
@action
@@ -42,71 +44,117 @@ export class Timeline extends CollectionSubView(Document) {
return;
}
let childrenList = (children[Self] as any).__fields;
- let keys = ["x", "y"];
+ // let keys = ["x", "y"]; //maybe make this an instance var?
const addReaction = (element: Doc) => {
element = (element as any).value();
return reaction(() => {
- return keys.map(key => FieldValue(element[key]));
- }, data => {
+ return this._keys.map(key => FieldValue(element[key]));
+ }, data => { //where is the data index actually being set?
if (this._inner.current) {
let keyFrame: KeyFrame; //keyframe reference
- let exists:boolean = false;
- let time:number = this._currentBarX; //time that indicates what frame you are in. Whole numbers.
- let frames:List<Doc>;
+ //is KeyFrame just a wrapper for a doc? cause then could just be of type doc...
+ let exists: boolean = false;
+ let time: number = this._currentBarX; //time that indicates what frame you are in. Whole numbers.
+ // let frames: List<Doc>; //don't know if this should be an instance...
this._keyFrames.forEach(kf => { //checks if there is a keyframe that is tracking htis document.
if (kf.doc.document === element) {
- keyFrame = kf;
- frames = Cast(keyFrame.doc.frames, listSpec(Doc))!;
- exists = true;
+ keyFrame = kf;
+ this._frames = Cast(keyFrame.doc.frames, listSpec(Doc))!;
+ exists = true;
}
- });
+ });
- if (!exists){
- keyFrame = new KeyFrame();
- let bar:HTMLDivElement = this.createBar(5, time, "yellow");
- this._inner.current.appendChild(bar);
- keyFrame.doc.bar = bar;
+ if (!exists) {
+ keyFrame = new KeyFrame();
+ let bar: HTMLDivElement = this.createBar(5, time, "yellow");
+ this._inner.current.appendChild(bar);
+ // keyFrame.doc.bar = bar;
keyFrame.doc.frames = new List<Doc>();
-
- this._keyFrames.push(keyFrame);
+
+ this._keyFrames.push(keyFrame);
}
-
- keys.forEach((key, index) => {
- console.log(data[index]);
- if (keyFrame.doc.frames !== undefined){
- frames.forEach(frame => {
- if (frame.time === this._currentBarX){
- frame.key = data[index];
+
+ this._keys.forEach((key, index) => {
+ console.log(data[index]);
+ if (keyFrame.doc.frames !== undefined) {
+ this._frames.forEach(frame => {
+ if (frame.time === this._currentBarX) {
+ frame[key] = data[index];
}
- });
+ });
}
-
+
//keyFrame.document[key] = data[index];
});
}
});
};
-
-
+
+
observe(childrenList as IObservableArray<Doc>, change => {
-
- if (change.type === "update") {
+
+ if (change.type === "update") {
this._reactionDisposers[change.index]();
this._reactionDisposers[change.index] = addReaction(change.newValue);
} else {
let removed = this._reactionDisposers.splice(change.index, change.removedCount, ...change.added.map(addReaction));
removed.forEach(disp => disp());
}
- }, true);
-
+ }, true);
+
}
- @action
+ //maybe to be called in innerPointerDown
+ //this is the only method that should have access to time changes
+ //should run every time the time has been changed
+ //should look through the array of times and positions and set docs to the positions associated with the specific time
+ //if there is not an entry in the array associated with the time (for now) choose the next existing lower/higher time entry, etc.
+ //eventually there will be interpolation between these existing times
+ //will be similar to last block of code in the onRecord reaction, but kind of doing the opposite...
+
+
+ @action
+ timeChange = async (time: number) => { //x position of mouse relative to inner box can be passed in?
+ let element = (Doc as any).value();
+ //data is list of docs
+ //this.props.document
+ //GOOD EXAMPLES: collection subview has childdox getter : gets the data part (field key)
+ //to get keyframes out of document can also use similar code
+ let keyFrame: KeyFrame; //keyframe reference
+ //potentially correct looping??
+ const docs = await DocListCastAsync(this.props.Document[this.props.fieldKey]);
+ for (let i in docs) {
+ let oneDoc = docs[i];
+ let kfs = this._keyFrames[i]; //what is this doing (is this where child getter comes in?)
+ }
+ //end of potentially correct looping
+ this._keyFrames.forEach(kf => { //checks if there is a keyframe that is tracking this document
+ if (kf.doc.document === element) {
+ keyFrame = kf;
+ this._frames = Cast(keyFrame.doc.frames, listSpec(Doc))!;
+ }
+ },
+ this._keys.forEach((key) => { //for each key
+ if (keyFrame.doc.frames !== undefined) {
+ this._frames.forEach(frame => {
+ if (frame.time === time) {
+ keyFrame.doc[key] = frame[key]; //set the doc's position to the frames' stored values
+ }
+ });
+ }
+ }
+ }
+
+ get keyFrames() {
+ return Cast(this.props.Document[this.props.fieldKey], listSpec(Doc), []).filter(doc => KeyFrame);
+ }
+
+ @action
displayKeyFrames = (dv: DocumentView) => {
- console.log(dv);
- dv.props.Document;
-
+ console.log(dv);
+ dv.props.Document;
+
}
@@ -139,32 +187,32 @@ export class Timeline extends CollectionSubView(Document) {
e.stopPropagation();
let offsetX = Math.round(e.offsetX);
this._currentBarX = offsetX;
- this._currentBar.style.transform = `translate(${offsetX}px)`;
+ this._currentBar.style.transform = `translate(${offsetX}px)`; //styling should not have to be done this way...maybe done through react??
console.log(offsetX);
console.log(this._currentBarX);
}
- createBar = (width: number, pos:number = 0, color:string = "green"): HTMLDivElement => {
+ createBar = (width: number, pos: number = 0, color: string = "green"): HTMLDivElement => {
let bar = document.createElement("div");
bar.style.height = "100%";
bar.style.width = `${width}px`;
bar.style.backgroundColor = color;
- bar.style.transform = `translate(${pos}px)`;
+ bar.style.transform = `translate(${pos}px)`; //repeated code from previous method
bar.style.position = "absolute";
bar.style.pointerEvents = "none";
return bar;
}
- onTimeEntered = (e:React.KeyboardEvent) => {
- if (this._timeInput.current){
- if (e.keyCode === 13){
- let input = parseInt(this._timeInput.current.value) || 0;
+ onTimeEntered = (e: React.KeyboardEvent) => {
+ if (this._timeInput.current) {
+ if (e.keyCode === 13) {
+ let input = parseInt(this._timeInput.current.value) || 0;
this._currentBar.style.transform = `translate(${input}px)`;
- this._currentBarX = input;
+ this._currentBarX = input;
}
}
}
-
+
componentDidMount() {
if (this._inner.current && this._currentBar === null) {
this._currentBar = this.createBar(5);
@@ -187,11 +235,11 @@ export class Timeline extends CollectionSubView(Document) {
<div className="timeline-container">
<div className="timeline">
<div className="inner" ref={this._inner} onPointerDown={this.onInnerPointerDown} onPointerUp={this.onInnerPointerUp}>
- {
- SelectionManager.SelectedDocuments().map((dv) => {
- this.displayKeyFrames(dv);
- })
- }
+ {
+ SelectionManager.SelectedDocuments().map((dv) => {
+ this.displayKeyFrames(dv);
+ })
+ }
</div>
</div>
<button onClick={this.onRecord}>Record</button>