diff options
author | Eleanor Eng <eleanor_eng@brown.edu> | 2019-06-10 11:38:11 -0400 |
---|---|---|
committer | Eleanor Eng <eleanor_eng@brown.edu> | 2019-06-10 11:38:11 -0400 |
commit | 23208f830ffcf3e5a43db2da69f645746d03852b (patch) | |
tree | a2aeb789a457736d2b6fea109c578fcfaa404cb4 /src | |
parent | 6fe6e5d19e7233e4d65e6a93e1bc8860ab314c5c (diff) | |
parent | de73c98f17e5ab5fb83cc3db8af5172c334c2dea (diff) |
IT WORKS NOW YAYAYYAYAY
Diffstat (limited to 'src')
-rw-r--r-- | src/client/views/nodes/Timeline.tsx | 27 |
1 files changed, 20 insertions, 7 deletions
diff --git a/src/client/views/nodes/Timeline.tsx b/src/client/views/nodes/Timeline.tsx index 9036b9d19..ca7ceb19f 100644 --- a/src/client/views/nodes/Timeline.tsx +++ b/src/client/views/nodes/Timeline.tsx @@ -55,6 +55,7 @@ export class Timeline extends CollectionSubView(Document) { @observable private _data: Doc[] = []; // 1D list of nodes @observable private _keyframes: Doc[][] = []; //2D list of infos @observable private TEMPNUM = 0; + @observable private _keyChanged = false; @action onRecord = (e: React.MouseEvent) => { @@ -331,17 +332,24 @@ export class Timeline extends CollectionSubView(Document) { @action displayKeyFrames = async (dv: DocumentView) => { - console.log("hi"); + if (this._keyChanged) { //this runs when keyframe has been changed, so it should not delete any bars. + this._keyChanged = false; + } else { + this.clearBars(); + } let doc: Doc = dv.props.Document; let inner: HTMLDivElement = (await this._inner.current)!; this._data.forEach((node) => { + console.log(node); + console.log(doc); if (node === doc) { - this.clearBars(); + console.log("hi"); const index = this._data.indexOf(node); - this._keyframes[index].forEach((time) => { - if (time !== undefined) { - let timeandpos = TimeAndPosition(time); - let bar: HTMLDivElement = this.createBar(5, this._currentBarX, "yellow"); + this._keyframes[index].forEach(async (timeandpos) => { + if (timeandpos !== undefined) { + timeandpos = TimeAndPosition(timeandpos); + let time = NumCast(await timeandpos.time); + let bar: HTMLDivElement = this.createBar(5, time, "yellow"); inner.appendChild(bar); } }); @@ -353,11 +361,14 @@ export class Timeline extends CollectionSubView(Document) { @action clearBars = async () => { let inner: HTMLDivElement = (await this._inner.current)!; + console.log(inner.children); inner.childNodes.forEach((bar) => { if (bar !== this._currentBar) { inner.removeChild(bar); } + }); + } @@ -371,10 +382,12 @@ export class Timeline extends CollectionSubView(Document) { SelectionManager.SelectedDocuments().map((dv) => { this.displayKeyFrames(dv); })} + + + </div> </div> <button onClick={this.onRecord}>Record</button> - {/* <button onClick={this.onInterpolate}>Inter</button> */} <input placeholder="Time" ref={this._timeInput} onKeyDown={this.onTimeEntered}></input> </div> </div> |