mirror of
https://github.com/danog/telegram-tt.git
synced 2025-01-21 21:01:29 +01:00
[Perf] Animated Sticker: Avoid redundant data change on first render (#1576)
This commit is contained in:
parent
261ea66d5e
commit
8086003321
@ -60,6 +60,7 @@ const AnimatedSticker: FC<OwnProps> = ({
|
|||||||
const container = useRef<HTMLDivElement>(null);
|
const container = useRef<HTMLDivElement>(null);
|
||||||
const wasPlaying = useRef(false);
|
const wasPlaying = useRef(false);
|
||||||
const isFrozen = useRef(false);
|
const isFrozen = useRef(false);
|
||||||
|
const isFirstRender = useRef(true);
|
||||||
|
|
||||||
const playRef = useRef();
|
const playRef = useRef();
|
||||||
playRef.current = play;
|
playRef.current = play;
|
||||||
@ -194,9 +195,13 @@ const AnimatedSticker: FC<OwnProps> = ({
|
|||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (animation) {
|
if (animation) {
|
||||||
|
if (isFirstRender.current) {
|
||||||
|
isFirstRender.current = false;
|
||||||
|
} else {
|
||||||
animation.changeData(animationData);
|
animation.changeData(animationData);
|
||||||
playAnimation();
|
playAnimation();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}, [playAnimation, animation, animationData]);
|
}, [playAnimation, animation, animationData]);
|
||||||
|
|
||||||
useHeavyAnimationCheck(freezeAnimation, unfreezeAnimation);
|
useHeavyAnimationCheck(freezeAnimation, unfreezeAnimation);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user