mirror of
https://github.com/mifi/lossless-cut.git
synced 2024-11-25 11:43:17 +01:00
87 lines
2.5 KiB
JavaScript
87 lines
2.5 KiB
JavaScript
import React, { memo } from 'react';
|
|
import { motion, AnimatePresence } from 'framer-motion';
|
|
import { FaTrashAlt } from 'react-icons/fa';
|
|
|
|
import { mySpring } from './animations';
|
|
|
|
import { formatDuration } from './util';
|
|
|
|
|
|
const TimelineSeg = memo(({
|
|
duration, cutStart, cutEnd, isActive, segNum, name,
|
|
onSegClick, invertCutSegments, segBgColor, segActiveBgColor, segBorderColor,
|
|
}) => {
|
|
const cutSectionWidth = `${((cutEnd - cutStart) / duration) * 100}%`;
|
|
|
|
const startTimePos = `${(cutStart / duration) * 100}%`;
|
|
const markerBorder = `2px solid ${isActive ? segBorderColor : 'transparent'}`;
|
|
const backgroundColor = isActive ? segActiveBgColor : segBgColor;
|
|
const markerBorderRadius = 5;
|
|
|
|
const wrapperStyle = {
|
|
position: 'absolute',
|
|
top: 0,
|
|
bottom: 0,
|
|
left: startTimePos,
|
|
width: cutSectionWidth,
|
|
display: 'flex',
|
|
alignItems: 'center',
|
|
justifyContent: 'space-between',
|
|
background: backgroundColor,
|
|
originX: 0,
|
|
boxSizing: 'border-box',
|
|
|
|
borderLeft: markerBorder,
|
|
borderTopLeftRadius: markerBorderRadius,
|
|
borderBottomLeftRadius: markerBorderRadius,
|
|
|
|
borderRight: markerBorder,
|
|
borderTopRightRadius: markerBorderRadius,
|
|
borderBottomRightRadius: markerBorderRadius,
|
|
};
|
|
|
|
const onThisSegClick = () => onSegClick(segNum);
|
|
|
|
const durationStr = cutEnd > cutStart ? `${formatDuration({ seconds: cutEnd - cutStart })} ` : '';
|
|
const title = `${durationStr}${name}`;
|
|
|
|
return (
|
|
<motion.div
|
|
style={wrapperStyle}
|
|
layoutTransition={mySpring}
|
|
initial={{ opacity: 0, scaleX: 0 }}
|
|
animate={{ opacity: 1, scaleX: 1 }}
|
|
exit={{ opacity: 0, scaleX: 0 }}
|
|
role="button"
|
|
onClick={onThisSegClick}
|
|
title={title}
|
|
>
|
|
<div style={{ alignSelf: 'flex-start', flexShrink: 1, fontSize: 10, minWidth: 0, overflow: 'hidden' }}>{segNum + 1}</div>
|
|
|
|
<AnimatePresence>
|
|
{invertCutSegments && (
|
|
<motion.div
|
|
initial={{ scale: 0 }}
|
|
animate={{ scale: 1 }}
|
|
exit={{ scale: 0 }}
|
|
style={{ width: 16, height: 16, flexShrink: 1 }}
|
|
>
|
|
<FaTrashAlt
|
|
style={{ width: '100%', color: segBorderColor }}
|
|
size={16}
|
|
/>
|
|
</motion.div>
|
|
)}
|
|
</AnimatePresence>
|
|
|
|
{name && <div style={{ flexBasis: 4, flexShrink: 1 }} />}
|
|
|
|
{name && <div style={{ flexShrink: 1, fontSize: 11, minWidth: 0, overflow: 'hidden', whiteSpace: 'nowrap' }}>{name}</div>}
|
|
|
|
<div style={{ flexGrow: 1 }} />
|
|
</motion.div>
|
|
);
|
|
});
|
|
|
|
export default TimelineSeg;
|