aboutsummaryrefslogtreecommitdiff
path: root/src/client/views/nodes/Timeline.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'src/client/views/nodes/Timeline.tsx')
-rw-r--r--src/client/views/nodes/Timeline.tsx27
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>