From 3e2c1d432d73823e66e19d0081b498ace467b231 Mon Sep 17 00:00:00 2001 From: Jules Laplace Date: Thu, 2 Jul 2020 00:35:06 +0200 Subject: display the form --- animism-align/frontend/views/align/align.util.js | 28 ++++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 animism-align/frontend/views/align/align.util.js (limited to 'animism-align/frontend/views/align/align.util.js') diff --git a/animism-align/frontend/views/align/align.util.js b/animism-align/frontend/views/align/align.util.js new file mode 100644 index 0000000..32cbc35 --- /dev/null +++ b/animism-align/frontend/views/align/align.util.js @@ -0,0 +1,28 @@ +import { ZOOM_STEPS } from './constants' +import { clamp } from '../../util' + +export const positionToTime = (y, { start_ts, zoom, duration }) => { + const secondsPerPixel = ZOOM_STEPS[zoom] * 0.1 + const widthTimeDuration = window.innerHeight * secondsPerPixel + const timeMin = start_ts + const timeMax = Math.min(start_ts + widthTimeDuration, duration) + const timeWidth = timeMax - timeMin + return clamp(y * secondsPerPixel + start_ts, 0, timeMax) +} + +export const timeToPosition = (ts, { start_ts, zoom, duration }) => { + const height = window.innerHeight + const secondsPerPixel = ZOOM_STEPS[zoom] * 0.1 + const widthTimeDuration = height * secondsPerPixel + const timeMin = start_ts + const timeMax = Math.min(start_ts + widthTimeDuration, duration) + const timeWidth = timeMax - timeMin + const timeHalfHeight = height * secondsPerPixel / 2 + if (ts < timeMin - timeHalfHeight) { + return -9999 + } + if (ts > timeMax) { + return -9999 + } + return (ts - timeMin) / timeWidth * height +} -- cgit v1.2.3-70-g09d2