|
|
|
@ -1,6 +1,5 @@
|
|
|
|
import React, { memo, useRef, useMemo, useCallback, useEffect, useState } from 'react';
|
|
|
|
import React, { memo, useRef, useMemo, useCallback, useEffect, useState } from 'react';
|
|
|
|
import { motion, useMotionValue, useSpring } from 'framer-motion';
|
|
|
|
import { motion, useMotionValue, useSpring } from 'framer-motion';
|
|
|
|
import Hammer from 'react-hammerjs';
|
|
|
|
|
|
|
|
import debounce from 'lodash/debounce';
|
|
|
|
import debounce from 'lodash/debounce';
|
|
|
|
import { useTranslation } from 'react-i18next';
|
|
|
|
import { useTranslation } from 'react-i18next';
|
|
|
|
import { FaCaretDown, FaCaretUp } from 'react-icons/fa';
|
|
|
|
import { FaCaretDown, FaCaretUp } from 'react-icons/fa';
|
|
|
|
@ -17,8 +16,6 @@ import { getSegColor } from './util/colors';
|
|
|
|
|
|
|
|
|
|
|
|
const currentTimeWidth = 1;
|
|
|
|
const currentTimeWidth = 1;
|
|
|
|
|
|
|
|
|
|
|
|
const hammerOptions = { recognizers: {} };
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const Waveform = memo(({ waveform, calculateTimelinePercent, durationSafe }) => {
|
|
|
|
const Waveform = memo(({ waveform, calculateTimelinePercent, durationSafe }) => {
|
|
|
|
const [style, setStyle] = useState({ display: 'none' });
|
|
|
|
const [style, setStyle] = useState({ display: 'none' });
|
|
|
|
|
|
|
|
|
|
|
|
@ -193,14 +190,26 @@ const Timeline = memo(({
|
|
|
|
}, [durationSafe]);
|
|
|
|
}, [durationSafe]);
|
|
|
|
|
|
|
|
|
|
|
|
const handleTap = useCallback((e) => {
|
|
|
|
const handleTap = useCallback((e) => {
|
|
|
|
seekAbs((getMouseTimelinePos(e.srcEvent)));
|
|
|
|
if (e.nativeEvent.buttons === 1) { // primary button
|
|
|
|
|
|
|
|
seekAbs((getMouseTimelinePos(e.nativeEvent)));
|
|
|
|
|
|
|
|
}
|
|
|
|
}, [seekAbs, getMouseTimelinePos]);
|
|
|
|
}, [seekAbs, getMouseTimelinePos]);
|
|
|
|
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
useEffect(() => {
|
|
|
|
setHoveringTime();
|
|
|
|
setHoveringTime();
|
|
|
|
}, [playerTime, commandedTime]);
|
|
|
|
}, [playerTime, commandedTime]);
|
|
|
|
|
|
|
|
|
|
|
|
const onMouseMove = useCallback((e) => setHoveringTime(getMouseTimelinePos(e.nativeEvent)), [getMouseTimelinePos]);
|
|
|
|
const onMouseMove = useCallback((e) => {
|
|
|
|
|
|
|
|
// eslint-disable-next-line no-bitwise
|
|
|
|
|
|
|
|
// const isButtonPressed = (index) => ((e.nativeEvent.buttons >> index) & 1);
|
|
|
|
|
|
|
|
if (e.nativeEvent.buttons === 0) { // no button pressed
|
|
|
|
|
|
|
|
setHoveringTime(getMouseTimelinePos(e.nativeEvent));
|
|
|
|
|
|
|
|
e.preventDefault();
|
|
|
|
|
|
|
|
} else if (e.nativeEvent.buttons === 1) { // primary button
|
|
|
|
|
|
|
|
handleTap(e);
|
|
|
|
|
|
|
|
e.preventDefault();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}, [getMouseTimelinePos, handleTap]);
|
|
|
|
const onMouseOut = useCallback(() => setHoveringTime(), []);
|
|
|
|
const onMouseOut = useCallback(() => setHoveringTime(), []);
|
|
|
|
|
|
|
|
|
|
|
|
const contextMenuTemplate = useMemo(() => [
|
|
|
|
const contextMenuTemplate = useMemo(() => [
|
|
|
|
@ -210,15 +219,13 @@ const Timeline = memo(({
|
|
|
|
useContextMenu(timelineScrollerRef, contextMenuTemplate);
|
|
|
|
useContextMenu(timelineScrollerRef, contextMenuTemplate);
|
|
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
return (
|
|
|
|
// eslint-disable-next-line jsx-a11y/mouse-events-have-key-events
|
|
|
|
// eslint-disable-next-line jsx-a11y/no-static-element-interactions,jsx-a11y/mouse-events-have-key-events
|
|
|
|
<Hammer
|
|
|
|
<div
|
|
|
|
onTap={handleTap}
|
|
|
|
style={{ position: 'relative' }}
|
|
|
|
onPan={handleTap}
|
|
|
|
onMouseDown={handleTap}
|
|
|
|
onMouseMove={onMouseMove}
|
|
|
|
onMouseMove={onMouseMove}
|
|
|
|
onMouseOut={onMouseOut}
|
|
|
|
onMouseOut={onMouseOut}
|
|
|
|
options={hammerOptions}
|
|
|
|
|
|
|
|
>
|
|
|
|
>
|
|
|
|
<div style={{ position: 'relative' }}>
|
|
|
|
|
|
|
|
<div
|
|
|
|
<div
|
|
|
|
style={{ overflowX: 'scroll' }}
|
|
|
|
style={{ overflowX: 'scroll' }}
|
|
|
|
className="hide-scrollbar"
|
|
|
|
className="hide-scrollbar"
|
|
|
|
@ -314,7 +321,6 @@ const Timeline = memo(({
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</Hammer>
|
|
|
|
|
|
|
|
);
|
|
|
|
);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|