pull/276/head
Mikael Finstad 6 years ago
parent 36ebb3f714
commit f47bb837fd

@ -336,6 +336,17 @@ const App = memo(() => {
setCutSegments(cloned);
};
const updateCurrentSegOrder = (newOrder) => {
const segAtNewIndex = cutSegments[newOrder];
const segAtOldIndex = cutSegments[currentSegIndexSafe];
const newSegments = [...cutSegments];
// Swap indexes:
newSegments[currentSegIndexSafe] = segAtNewIndex;
newSegments[newOrder] = segAtOldIndex;
setCutSegments(newSegments);
setCurrentSegIndex(newOrder);
};
const formatTimecode = useCallback((sec) => formatDuration({
seconds: sec, fps: timecodeShowFrames ? detectedFps : undefined,
}), [detectedFps, timecodeShowFrames]);
@ -553,6 +564,26 @@ const App = memo(() => {
setCutSegments(cutSegmentsNew);
}, [currentSegIndexSafe, cutSegments, setCutSegments]);
async function onReorderSegsPress() {
if (cutSegments.length < 2) return;
const { value } = await Swal.fire({
title: 'Change the order for the current segment',
text: `Please enter a number from 1 to ${cutSegments.length}`,
input: 'text',
inputValue: currentSegIndexSafe + 1,
showCancelButton: true,
inputValidator: (v) => {
const parsed = parseInt(v, 10);
return Number.isNaN(parsed) || parsed > cutSegments.length || parsed < 1 ? 'Invalid number entered' : undefined;
},
});
if (value) {
const newOrder = parseInt(value, 10);
updateCurrentSegOrder(newOrder - 1);
}
}
const jumpCutStart = () => seekAbs(currentApparentCutSeg.start);
const jumpCutEnd = () => seekAbs(currentApparentCutSeg.end);
@ -1738,6 +1769,8 @@ const App = memo(() => {
</div>
<div className="left-menu" style={{ position: 'absolute', left: 0, bottom: 0, padding: '.3em', display: 'flex', alignItems: 'center' }}>
{renderInvertCutButton()}
<FaPlus
size={30}
style={{ margin: '0 5px', color: 'white' }}
@ -1748,13 +1781,28 @@ const App = memo(() => {
<FaMinus
size={30}
style={{ margin: '0 5px', background: cutSegments.length < 2 ? undefined : currentSegBgColor, borderRadius: 3, color: 'white' }}
style={{ margin: '0 5px', background: cutSegments.length < 2 ? undefined : currentSegActiveBgColor, borderRadius: 3, color: 'white' }}
role="button"
title={`Delete current segment ${currentSegIndexSafe + 1}`}
onClick={removeCutSegment}
/>
{renderInvertCutButton()}
<div
style={{ width: 10, height: 10, padding: 4, margin: '0 5px', background: currentSegActiveBgColor, border: `2px solid ${currentSegBorderColor}`, borderRadius: 6, color: 'white', fontSize: 14, textAlign: 'center', lineHeight: '11px', fontWeight: 'bold' }}
role="button"
title="Change segment order"
onClick={onReorderSegsPress}
>
{currentSegIndexSafe + 1}
</div>
<FaTag
size={10}
title="Label segment"
role="button"
style={{ padding: 4, border: `2px solid ${currentSegBorderColor}`, background: currentSegActiveBgColor, borderRadius: 6 }}
onClick={onLabelSegmentPress}
/>
<select style={{ width: 80, margin: '0 10px' }} value={zoom.toString()} title="Zoom" onChange={withBlur(e => setZoom(parseInt(e.target.value, 10)))}>
{Array(10).fill().map((unused, z) => {
@ -1764,14 +1812,6 @@ const App = memo(() => {
);
})}
</select>
<FaTag
size={10}
title="Label segment"
role="button"
style={{ padding: 4, border: `2px solid ${currentSegBorderColor}`, background: currentSegActiveBgColor, borderRadius: 6 }}
onClick={onLabelSegmentPress}
/>
</div>
<div className="right-menu" style={{ position: 'absolute', right: 0, bottom: 0, padding: '.3em', display: 'flex', alignItems: 'center' }}>

Loading…
Cancel
Save