diff options
-rw-r--r-- | src/client/views/nodes/Keyframe.tsx | 29 | ||||
-rw-r--r-- | src/client/views/nodes/Track.tsx | 186 |
2 files changed, 98 insertions, 117 deletions
diff --git a/src/client/views/nodes/Keyframe.tsx b/src/client/views/nodes/Keyframe.tsx index dee226c64..e90c6e436 100644 --- a/src/client/views/nodes/Keyframe.tsx +++ b/src/client/views/nodes/Keyframe.tsx @@ -8,11 +8,7 @@ import { Doc, DocListCast, DocListCastAsync } from "../../../new_fields/Doc"; import { Cast, FieldValue, StrCast, NumCast } from "../../../new_fields/Types"; import { List } from "../../../new_fields/List"; import { createSchema, defaultSpec, makeInterface, listSpec } from "../../../new_fields/Schema"; -import { any } from "bluebird"; import { FlyoutProps } from "./Timeline"; -import { number } from "prop-types"; -import { CollectionSchemaView, CollectionSchemaPreview } from "../collections/CollectionSchemaView"; -import { faDiceOne, faFirstAid } from "@fortawesome/free-solid-svg-icons"; import { Transform } from "../../util/Transform"; export namespace KeyframeFunc { @@ -125,11 +121,14 @@ export class Keyframe extends React.Component<IProps> { @action - async componentDidMount() { - let fadeIn = await this.makeKeyData(this.regiondata.position + this.regiondata.fadeIn, KeyframeFunc.KeyframeType.fade)!; - let fadeOut = await this.makeKeyData(this.regiondata.position + this.regiondata.duration - this.regiondata.fadeOut, KeyframeFunc.KeyframeType.fade)!; - let start = await this.makeKeyData(this.regiondata.position, KeyframeFunc.KeyframeType.fade)!; - let finish = await this.makeKeyData(this.regiondata.position + this.regiondata.duration, KeyframeFunc.KeyframeType.fade)!; + componentDidMount() { + + console.log(toJS(this.props.node)); + console.log("hi"); + let fadeIn = this.makeKeyData(this.regiondata.position + this.regiondata.fadeIn, KeyframeFunc.KeyframeType.fade)!; + let fadeOut = this.makeKeyData(this.regiondata.position + this.regiondata.duration - this.regiondata.fadeOut, KeyframeFunc.KeyframeType.fade)!; + let start = this.makeKeyData(this.regiondata.position, KeyframeFunc.KeyframeType.fade)!; + let finish = this.makeKeyData(this.regiondata.position + this.regiondata.duration, KeyframeFunc.KeyframeType.fade)!; (fadeIn.key! as Doc).opacity = 1; (fadeOut.key! as Doc).opacity = 1; (start.key! as Doc).opacity = 0.1; @@ -158,8 +157,8 @@ export class Keyframe extends React.Component<IProps> { @action - makeKeyData = async (kfpos: number, type: KeyframeFunc.KeyframeType = KeyframeFunc.KeyframeType.default) => { //Kfpos is mouse offsetX, representing time - let doclist = await DocListCastAsync(this.regiondata.keyframes!); + makeKeyData = (kfpos: number, type: KeyframeFunc.KeyframeType = KeyframeFunc.KeyframeType.default) => { //Kfpos is mouse offsetX, representing time + let doclist = DocListCast(this.regiondata.keyframes!); let existingkf: (Doc | undefined) = undefined; if (doclist) { doclist.forEach(TK => { //TK is TimeAndKey @@ -244,8 +243,7 @@ export class Keyframe extends React.Component<IProps> { e.preventDefault(); e.stopPropagation(); let bar = this._bar.current!; - let barX = bar.getBoundingClientRect().left; - let offset = e.clientX - barX; + let offset = Math.round((e.clientX - bar.getBoundingClientRect().left) * this.props.transform.Scale); let leftRegion = KeyframeFunc.findAdjacentRegion(KeyframeFunc.Direction.left, this.regiondata, this.regions); let firstkf: (Doc | undefined) = this.firstKeyframe; if (firstkf && this.regiondata.position + this.regiondata.fadeIn + offset >= NumCast(firstkf!.time)) { @@ -272,8 +270,7 @@ export class Keyframe extends React.Component<IProps> { e.preventDefault(); e.stopPropagation(); let bar = this._bar.current!; - let barX = bar.getBoundingClientRect().right; - let offset = e.clientX - barX; + let offset = Math.round((e.clientX - bar.getBoundingClientRect().right) * this.props.transform.Scale); let rightRegion = KeyframeFunc.findAdjacentRegion(KeyframeFunc.Direction.right, this.regiondata, this.regions); if (this.lastKeyframe! && this.regiondata.position + this.regiondata.duration - this.regiondata.fadeOut + offset <= NumCast((this.lastKeyframe! as Doc).time)) { let dif = this.regiondata.position + this.regiondata.duration - this.regiondata.fadeOut - NumCast((this.lastKeyframe! as Doc).time); @@ -306,9 +303,11 @@ export class Keyframe extends React.Component<IProps> { if (offset > this.regiondata.fadeIn && offset < this.regiondata.duration - this.regiondata.fadeOut) { //make sure keyframe is not created inbetween fades and ends let position = NumCast(this.regiondata.position); this.makeKeyData(Math.round(position + offset)); + console.log(this.regiondata.keyframes!.length); this.props.changeCurrentBarX(NumCast(Math.round(position + offset))); //first move the keyframe to the correct location and make a copy so the correct file gets coppied } } + @action moveKeyframe = (e: React.MouseEvent, kf: Doc) => { diff --git a/src/client/views/nodes/Track.tsx b/src/client/views/nodes/Track.tsx index 2fcb4f0e4..ee8bee56f 100644 --- a/src/client/views/nodes/Track.tsx +++ b/src/client/views/nodes/Track.tsx @@ -4,12 +4,12 @@ import { observable, reaction, action, IReactionDisposer, observe, IObservableAr import "./Track.scss"; import { Doc, DocListCastAsync, DocListCast } from "../../../new_fields/Doc"; import {listSpec} from "../../../new_fields/Schema"; -import { FieldValue, Cast, NumCast, BoolCast } from "../../../new_fields/Types"; +import { FieldValue, Cast, NumCast, BoolCast, StrCast } from "../../../new_fields/Types"; import { List } from "../../../new_fields/List"; import { Keyframe, KeyframeFunc, RegionData } from "./Keyframe"; import { FlyoutProps } from "./Timeline"; -import { CollectionView } from "../collections/CollectionView"; import { Transform } from "../../util/Transform"; +import { AddComparisonParameters } from "../../northstar/model/idea/idea"; interface IProps { node: Doc; @@ -36,20 +36,20 @@ export class Track extends React.Component<IProps> { this.props.node.regions = new List<Doc>(); } this.props.node.opacity = 1; - this.props.node.hidden = true; } componentDidMount() { runInAction(() => { - this._keyReaction = this.keyReaction(); + this.createRegion(this.props.currentBarX); + this.props.node.hidden = false; this._currentBarXReaction = this.currentBarXReaction(); }); } componentWillUnmount() { runInAction(() => { - this._keyReaction(); - this._currentBarXReaction(); + if (this._keyReaction) this._keyReaction(); + if (this._currentBarXReaction) this._currentBarXReaction(); }); } @@ -63,25 +63,23 @@ export class Track extends React.Component<IProps> { let regiondata = this.findRegion(this.props.currentBarX); if (regiondata){ DocListCast(regiondata.keyframes!).forEach((kf) => { - if(NumCast(kf.time!) === this.props.currentBarX){ - if (kf.type === KeyframeFunc.KeyframeType.default){ - kf.key = Doc.MakeCopy(this.props.node, true); - let leftkf: (Doc | undefined) = this.calcMinLeft(regiondata!, kf); // lef keyframe, if it exists - let rightkf: (Doc | undefined) = this.calcMinRight(regiondata!, kf); //right keyframe, if it exists - if (leftkf!.type === KeyframeFunc.KeyframeType.fade){ - let edge = this.calcMinLeft(regiondata!, leftkf!); - edge!.key = Doc.MakeCopy(kf.key as Doc, true); - leftkf!.key = Doc.MakeCopy(kf.key as Doc, true) ; - (Cast(edge!.key, Doc)! as Doc).opacity = 0.1; - (Cast(leftkf!.key, Doc)! as Doc).opacity = 1; - } - if (rightkf!.type === KeyframeFunc.KeyframeType.fade){ - let edge = this.calcMinRight(regiondata!, rightkf!); - edge!.key = Doc.MakeCopy(kf.key as Doc, true); - rightkf!.key = Doc.MakeCopy(kf.key as Doc, true); - (Cast(edge!.key, Doc)! as Doc).opacity = 0.1; - (Cast(rightkf!.key, Doc)! as Doc).opacity = 1; - } + if (kf.type === KeyframeFunc.KeyframeType.default){ + kf.key = Doc.MakeCopy(this.props.node, true); + let leftkf: (Doc | undefined) = this.calcMinLeft(regiondata!, kf); // lef keyframe, if it exists + let rightkf: (Doc | undefined) = this.calcMinRight(regiondata!, kf); //right keyframe, if it exists + if (leftkf!.type === KeyframeFunc.KeyframeType.fade){ //replicating this keyframe to fades + let edge = this.calcMinLeft(regiondata!, leftkf!); + edge!.key = Doc.MakeCopy(kf.key as Doc, true); + leftkf!.key = Doc.MakeCopy(kf.key as Doc, true) ; + (Cast(edge!.key, Doc)! as Doc).opacity = 0.1; + (Cast(leftkf!.key, Doc)! as Doc).opacity = 1; + } + if (rightkf!.type === KeyframeFunc.KeyframeType.fade){ + let edge = this.calcMinRight(regiondata!, rightkf!); + edge!.key = Doc.MakeCopy(kf.key as Doc, true); + rightkf!.key = Doc.MakeCopy(kf.key as Doc, true); + (Cast(edge!.key, Doc)! as Doc).opacity = 0.1; + (Cast(rightkf!.key, Doc)! as Doc).opacity = 1; } } }); @@ -91,18 +89,19 @@ export class Track extends React.Component<IProps> { @action currentBarXReaction = () => { - return reaction(() => this.props.currentBarX, () => { + return reaction(() => this.props.currentBarX, () => { + console.log("currentbar changed"); + if (this._keyReaction) this._keyReaction(); //dispose previous reaction first let regiondata: (Doc | undefined) = this.findRegion(this.props.currentBarX); - this._keyReaction(); if (regiondata) { - this.props.node.hidden = false; + this.props.node.hidden = false; + this.timeChange(this.props.currentBarX); DocListCast(regiondata.keyframes).forEach((kf) => { - if (kf.time === this.props.currentBarX){ - this._keyReaction = this.keyReaction(); + if (kf.time === this.props.currentBarX && kf.type === KeyframeFunc.KeyframeType.default){ + console.log("HI!"); + this._keyReaction = this.keyReaction(); //reactivates reaction. } }); - this.timeChange(this.props.currentBarX); - } else { this.props.node.hidden = true; } @@ -111,55 +110,37 @@ export class Track extends React.Component<IProps> { @action - timeChange = async (time: number) => { - let region = this.findRegion(Math.round(time)); //finds a region that the scrubber is on - let leftkf: (Doc | undefined) = this.calcMinLeft(region!); // lef keyframe, if it exists - let rightkf: (Doc | undefined) = this.calcMinRight(region!); //right keyframe, if it exists - let currentkf: (Doc | undefined) = this.calcCurrent(region!); //if the scrubber is on top of the keyframe - if (currentkf){ - this.applyKeys(currentkf.key as Doc); - } else { - this.interpolate(leftkf!, rightkf!); - } + timeChange = (time: number) => { + let regiondata = this.findRegion(Math.round(time)); //finds a region that the scrubber is on + if (regiondata) { + let leftkf: (Doc | undefined) = this.calcMinLeft(regiondata!); // lef keyframe, if it exists + let rightkf: (Doc | undefined) = this.calcMinRight(regiondata!); //right keyframe, if it exists + if(leftkf && rightkf) { + this.interpolate(leftkf, rightkf); + } + let currentkf: (Doc | undefined) = this.calcCurrent(regiondata!); //if the scrubber is on top of the keyframe + + if (currentkf){ + console.log(toJS(currentkf)); + this.applyKeys(Cast(currentkf.key, Doc) as Doc); + } + } + } @action private applyKeys = (kf: Doc) => { - let kf_length = Doc.allKeys(kf).length; - let node_length = Doc.allKeys(this.props.node).length; - if (kf_length > node_length) { - this.filterKeys(Doc.allKeys(kf)).forEach((key) => { - if (key === "title") { - console.log("TITLE APPLIED"); - Doc.SetOnPrototype(this.props.node, "title", kf[key] as string); - } else if (key === "documentText"){ - Doc.SetOnPrototype(this.props.node, "documentText", kf[key] as string); - } else { - this.props.node[key] = kf[key]; - } - }); - } else { - this.filterKeys(Doc.allKeys(this.props.node)).forEach((key) => { - if (kf[key] === undefined) { - this.props.node[key] = undefined; - } else if (key === "title") { - console.log("TITLE APPLIED"); - Doc.SetOnPrototype(this.props.node, "title", kf[key] as string); - } else if (key === "documentText"){ - Doc.SetOnPrototype(this.props.node, "documentText", kf[key] as string); - } else { - this.props.node[key] = kf[key]; - } - }); - } + this.filterKeys(Doc.allKeys(kf)).forEach(key => { + if (key === "title" || key === "documentText") Doc.SetOnPrototype(this.props.node, key, StrCast(kf[key])); + this.props.node[key] = kf[key]; + }); } + @action private filterKeys = (keys:string[]):string[] => { return keys.reduce((acc:string[], key:string) => { - if ( key !== "regions" && key !== "data" && key !== "creationDate" && key !== "cursors" && key !== "hidden"){ - acc.push(key); - } + if ( key !== "regions" && key !== "data" && key !== "creationDate" && key !== "cursors" && key !== "hidden") acc.push(key); return acc; }, []) as string[]; } @@ -168,9 +149,7 @@ export class Track extends React.Component<IProps> { calcCurrent = (region:Doc):(Doc|undefined) => { let currentkf:(Doc|undefined) = undefined; DocListCast(region.keyframes!).forEach((kf) => { - if (NumCast(kf.time) === Math.round(this.props.currentBarX)){ - currentkf = kf; - } + if (NumCast(kf.time) === Math.round(this.props.currentBarX)) currentkf = kf; }); return currentkf; } @@ -185,7 +164,7 @@ export class Track extends React.Component<IProps> { if (ref){ compTime = NumCast(ref.time); } - if (NumCast(kf.time) < compTime && NumCast(kf.time) > NumCast(time)) { + if (NumCast(kf.time) < compTime && NumCast(kf.time) >= time) { leftKf = kf; time = NumCast(kf.time); } @@ -203,7 +182,7 @@ export class Track extends React.Component<IProps> { if (ref){ compTime = NumCast(ref.time); } - if (NumCast(kf.time) > compTime && NumCast(kf.time) < NumCast(time)) { + if (NumCast(kf.time) > compTime && NumCast(kf.time) <= NumCast(time)) { rightKf = kf; time = NumCast(kf.time); } @@ -212,33 +191,31 @@ export class Track extends React.Component<IProps> { } @action - interpolate = async (kf1: Doc, kf2: Doc) => { - let node1 = kf1.key as Doc; - let node2 = kf2.key as Doc; - let mainNode = new Doc(); - const dif_time = NumCast(kf2.time) - NumCast(kf1.time); - const ratio = (this.props.currentBarX - NumCast(kf1.time)) / dif_time; //linear - let keys = []; - if (this.filterKeys(Doc.allKeys(node1)).length === Math.max(this.filterKeys(Doc.allKeys(node1)).length, this.filterKeys(Doc.allKeys(node2)).length )){ - keys = this.filterKeys(Doc.allKeys(node1)); - mainNode = node1; - } else { - keys = this.filterKeys(Doc.allKeys(node2)); - mainNode = node2; - } - - keys.forEach(key => { - if (node1[key] && node2[key] && typeof(node1[key]) === "number" && typeof(node2[key]) === "number"){ - const diff = NumCast(node2[key]) - NumCast(node1[key]); + interpolate = (left: Doc, right: Doc) => { + console.log("interpolating"); + let leftNode = left.key as Doc; + let rightNode = right.key as Doc; + + console.log(toJS(leftNode)); + console.log(toJS(rightNode)); + + const dif_time = NumCast(right.time) - NumCast(left.time); + const ratio = (this.props.currentBarX - NumCast(left.time)) / dif_time; //linear + + + this.filterKeys(Doc.allKeys(leftNode)).forEach(key => { + console.log(key); + if (leftNode[key] && rightNode[key] && typeof(leftNode[key]) === "number" && typeof(rightNode[key]) === "number"){ //if it is number, interpolate + const diff = NumCast(rightNode[key]) - NumCast(leftNode[key]); const adjusted = diff * ratio; - this.props.node[key] = NumCast(node1[key]) + adjusted; - } - else if (key === "title") { - Doc.SetOnPrototype(this.props.node, "title", mainNode[key] as string); - } else if (key === "documentText"){ - Doc.SetOnPrototype(this.props.node, "documentText", mainNode[key] as string); + this.props.node[key] = NumCast(leftNode[key]) + adjusted; + } else if (key === "title" || key === "documentText") { + Doc.SetOnPrototype(this.props.node, key, StrCast(leftNode[key])); + this.props.node[key] = leftNode[key]; } + console.log(this.props.node[key]); }); + console.log("done"); } @action @@ -257,8 +234,12 @@ export class Track extends React.Component<IProps> { onInnerDoubleClick = (e: React.MouseEvent) => { let inner = this._inner.current!; let offsetX = Math.round((e.clientX - inner.getBoundingClientRect().left) * this.props.transform.Scale); + this.createRegion(offsetX); + } + + createRegion = (position: number) => { let regiondata = KeyframeFunc.defaultKeyframe(); - regiondata.position = offsetX; + regiondata.position = position; let leftRegion = KeyframeFunc.findAdjacentRegion(KeyframeFunc.Direction.left, regiondata, this.regions); let rightRegion = KeyframeFunc.findAdjacentRegion(KeyframeFunc.Direction.right, regiondata, this.regions); if ((rightRegion && leftRegion && rightRegion.position - (leftRegion.position + leftRegion.duration) < NumCast(regiondata.fadeIn) + NumCast(regiondata.fadeOut)) || (rightRegion && rightRegion.position - regiondata.position < NumCast(regiondata.fadeIn) + NumCast(regiondata.fadeOut))){ @@ -267,6 +248,7 @@ export class Track extends React.Component<IProps> { regiondata.duration = rightRegion.position - regiondata.position; } this.regions.push(regiondata); + return regiondata; } |