2021-06-06 22:18:40 +00:00
|
|
|
/* Imports */
|
|
|
|
import { Slider, Rail, Handles, Tracks, Ticks } from "react-compound-slider";
|
|
|
|
import React, { useState } from 'react';
|
|
|
|
// https://sghall.github.io/react-compound-slider/#/getting-started/tutorial
|
|
|
|
|
|
|
|
/* Definitions */
|
|
|
|
|
|
|
|
const sliderStyle = { // Give the slider some width
|
|
|
|
position: 'relative',
|
|
|
|
width: '40em',
|
|
|
|
height: 40,
|
|
|
|
border: '5em',
|
|
|
|
}
|
|
|
|
|
|
|
|
const railStyle = {
|
|
|
|
position: 'absolute',
|
|
|
|
width: '100%',
|
|
|
|
height: 15,
|
2021-10-06 08:54:40 +00:00
|
|
|
marginTop: 32.5,
|
2021-06-06 22:18:40 +00:00
|
|
|
borderRadius: 5,
|
|
|
|
backgroundColor: 'lightgrey',
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Support functions */
|
|
|
|
function Handle({
|
|
|
|
handle: { id, value, percent },
|
|
|
|
getHandleProps,
|
|
|
|
displayFunction,
|
|
|
|
handleWidth
|
|
|
|
}) {
|
|
|
|
|
|
|
|
return (
|
|
|
|
<>
|
|
|
|
<div className="justify-center text-center text-gray-600 text-xs">
|
|
|
|
{displayFunction(value)}
|
|
|
|
</div>
|
|
|
|
<div
|
|
|
|
style={{
|
|
|
|
left: `${percent}%`,
|
|
|
|
position: 'absolute',
|
|
|
|
marginLeft: -10,
|
2021-10-06 08:51:27 +00:00
|
|
|
marginTop: 2.5,
|
2021-06-06 22:18:40 +00:00
|
|
|
zIndex: 2,
|
|
|
|
width: 30,
|
|
|
|
height: 30,
|
|
|
|
cursor: 'pointer',
|
2021-10-06 08:51:27 +00:00
|
|
|
borderRadius: '0%',
|
2021-06-06 22:18:40 +00:00
|
|
|
backgroundColor: '#374151',
|
|
|
|
color: '#374151',
|
|
|
|
}}
|
|
|
|
{...getHandleProps(id)}
|
|
|
|
>
|
|
|
|
</div>
|
|
|
|
</>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
function Track({ source, target, getTrackProps }) {
|
|
|
|
return (
|
|
|
|
<div
|
|
|
|
style={{
|
|
|
|
position: 'absolute',
|
2021-10-06 08:54:40 +00:00
|
|
|
height: 17.5,
|
2021-06-06 22:18:40 +00:00
|
|
|
zIndex: 1,
|
2021-10-06 08:54:40 +00:00
|
|
|
marginTop: 8.25,
|
2021-06-06 22:18:40 +00:00
|
|
|
backgroundColor: ' #3B82F6',
|
|
|
|
borderRadius: 5,
|
|
|
|
cursor: 'pointer',
|
|
|
|
left: `${source.percent}%`,
|
|
|
|
width: `${target.percent - source.percent}%`,
|
|
|
|
}}
|
|
|
|
{...getTrackProps() /* this will set up events if you want it to be clickeable (optional) */}
|
|
|
|
/>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Body */
|
|
|
|
// Two functions, essentially identical.
|
2021-10-06 11:00:09 +00:00
|
|
|
export function SliderElement({ onChange, value, displayFunction, domain }) {
|
2021-11-25 00:50:28 +00:00
|
|
|
let toLogDomain = (arr) => [Math.log(arr[0]) / Math.log(10), Math.log(arr[1]) / Math.log(10)]
|
2021-06-06 22:18:40 +00:00
|
|
|
return (
|
|
|
|
<Slider
|
|
|
|
rootStyle={sliderStyle /* inline styles for the outer div. Can also use className prop. */}
|
2021-11-25 00:50:28 +00:00
|
|
|
domain={toLogDomain([1 / domain, domain])}
|
2021-06-06 22:18:40 +00:00
|
|
|
values={[value]}
|
2021-09-22 19:45:18 +00:00
|
|
|
step={0.0001}
|
2021-06-06 22:18:40 +00:00
|
|
|
onChange={onChange}
|
2021-06-07 17:09:30 +00:00
|
|
|
reversed={true}
|
2021-06-06 22:18:40 +00:00
|
|
|
>
|
|
|
|
<Rail>
|
|
|
|
{({ getRailProps }) => (
|
|
|
|
<div style={railStyle} {...getRailProps()} />
|
|
|
|
)}
|
|
|
|
</Rail>
|
|
|
|
<Handles>
|
|
|
|
{({ handles, getHandleProps }) => (
|
|
|
|
<div className="slider-handles">
|
|
|
|
{handles.map(handle => (
|
|
|
|
<Handle
|
|
|
|
key={handle.id}
|
|
|
|
handle={handle}
|
|
|
|
getHandleProps={getHandleProps}
|
|
|
|
displayFunction={displayFunction}
|
|
|
|
handleWidth={"15em"}
|
|
|
|
/>
|
|
|
|
))}
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
</Handles>
|
|
|
|
<Tracks right={false}>
|
|
|
|
{({ tracks, getTrackProps }) => (
|
|
|
|
<div className="slider-tracks">
|
|
|
|
{tracks.map(({ id, source, target }) => (
|
|
|
|
<Track
|
|
|
|
key={id}
|
|
|
|
source={source}
|
|
|
|
target={target}
|
|
|
|
getTrackProps={getTrackProps}
|
|
|
|
/>
|
|
|
|
))}
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
</Tracks>
|
|
|
|
</Slider>
|
|
|
|
)
|
|
|
|
}
|
2021-06-12 14:13:13 +00:00
|
|
|
|
2021-11-25 00:50:28 +00:00
|
|
|
export function SubmitSliderButton({ posList, binaryComparisons, sliderValue, toComparePair, nextStepSlider }) {
|
2021-06-12 14:13:13 +00:00
|
|
|
// This element didn't necessarily have to exist, but it made it easier for debugging purposes
|
|
|
|
let onClick = (event) => {
|
|
|
|
//event.preventDefault();
|
2021-11-25 00:50:28 +00:00
|
|
|
let obj = { posList, binaryComparisons, sliderValue, element1: toComparePair[1], element2: toComparePair[0] }
|
2021-06-12 14:13:13 +00:00
|
|
|
//
|
|
|
|
console.log("input@SubmitSliderButton")
|
|
|
|
console.log(obj)
|
2021-11-25 00:50:28 +00:00
|
|
|
if (!!Number(sliderValue) && sliderValue >= 0) {
|
2021-11-25 00:42:34 +00:00
|
|
|
nextStepSlider(obj)
|
2021-11-25 00:50:28 +00:00
|
|
|
} else if (!!Number(sliderValue) && sliderValue < 0) {
|
2021-11-25 00:42:34 +00:00
|
|
|
alert("Negative numbers not yet allowed")
|
2021-11-25 00:50:28 +00:00
|
|
|
} else {
|
|
|
|
alert("Your input is not a number")
|
2021-11-25 00:42:34 +00:00
|
|
|
}
|
2021-06-12 14:13:13 +00:00
|
|
|
}
|
|
|
|
|
2021-11-25 00:50:28 +00:00
|
|
|
return (<button
|
2021-06-12 14:13:13 +00:00
|
|
|
className="bg-transparent hover:bg-blue-500 text-blue-700 font-semibold hover:text-white py-2 px-4 border border-blue-500 hover:border-transparent rounded mt-5"
|
|
|
|
onClick={onClick}>
|
2021-11-25 00:50:28 +00:00
|
|
|
Submit
|
2021-06-12 14:13:13 +00:00
|
|
|
</button>)
|
|
|
|
|
|
|
|
}
|