|
1 | 1 | import React, { useState } from "react";
|
2 | 2 | import styled from "styled-components";
|
3 | 3 |
|
4 |
| -import { Checkbox, Field } from "@kleros/ui-components-library"; |
| 4 | +import { RULING_MODE } from "consts"; |
5 | 5 |
|
6 |
| -import LightButton from "components/LightButton"; |
| 6 | +import { Button, Radio } from "@kleros/ui-components-library"; |
| 7 | + |
| 8 | +import LabeledInput from "components/LabeledInput"; |
| 9 | + |
| 10 | +import Header from "./Header"; |
7 | 11 |
|
8 | 12 | const Container = styled.div`
|
| 13 | + width: 100%; |
9 | 14 | display: flex;
|
10 |
| - flex-wrap: wrap; |
11 |
| - gap: 8px; |
12 |
| - margin: 16px 0; |
13 |
| - border: ${({ theme }) => theme.klerosUIComponentsPrimaryBlue} 1px solid; |
14 |
| - border-radius: 4px; |
15 |
| - padding: 16px; |
| 15 | + flex-direction: column; |
| 16 | + gap: 32px; |
16 | 17 | `;
|
17 |
| -const RulingSettings = styled.div` |
| 18 | + |
| 19 | +const SelectContainer = styled.div` |
| 20 | + width: 100%; |
18 | 21 | display: flex;
|
19 | 22 | flex-direction: column;
|
20 |
| - gap: 8px; |
21 |
| - margin: 16px 0; |
| 23 | + flex-wrap: wrap; |
| 24 | + gap: 16px; |
22 | 25 | `;
|
23 |
| -const FieldContainer = styled.div` |
| 26 | + |
| 27 | +const AutomaticPresetInputsContainer = styled.div` |
24 | 28 | display: flex;
|
25 |
| - align-items: center; |
26 |
| - width: fit-content; |
27 |
| - height: fit-content; |
28 |
| - padding-left: 8px; |
29 |
| - gap: 8px; |
30 |
| - font-size: 14px; |
31 |
| - border-radius: 4px; |
32 |
| - border: ${({ theme }) => theme.klerosUIComponentsStroke} 1px solid; |
33 |
| - color: ${({ theme }) => theme.klerosUIComponentsPrimaryText}; |
| 29 | + gap: 16px; |
| 30 | + justify-content: space-around; |
| 31 | + flex-wrap: wrap; |
34 | 32 | `;
|
35 | 33 |
|
36 | 34 | const RulingModes: React.FC = () => {
|
37 | 35 | const [tie, setTie] = useState<boolean>(false);
|
38 | 36 | const [overriden, setOverriden] = useState<boolean>(false);
|
| 37 | + const [ruling, setRuling] = useState<number>(); |
| 38 | + const [rulingMode, setRulingMode] = useState<RULING_MODE | null>(null); |
39 | 39 |
|
40 | 40 | return (
|
41 |
| - <div> |
42 |
| - <h3>Ruling Mode</h3> |
43 |
| - <Container> |
44 |
| - <RulingSettings> |
45 |
| - <LightButton text={"Rule Now Manually"} /> |
46 |
| - <FieldContainer> |
47 |
| - ruling <Field placeholder={"1"}></Field> |
48 |
| - </FieldContainer> |
49 |
| - </RulingSettings> |
50 |
| - |
51 |
| - <RulingSettings> |
52 |
| - <LightButton text={"Run Automatically with a Preset"} /> |
53 |
| - <FieldContainer> |
54 |
| - ruling <Field placeholder={"1"}></Field> |
55 |
| - </FieldContainer> |
56 |
| - <FieldContainer> |
57 |
| - <Checkbox label="" small checked={tie} onChange={() => setTie((old) => !old)} /> |
58 |
| - <Field placeholder={"tie"}></Field> |
59 |
| - </FieldContainer> |
60 |
| - <FieldContainer> |
61 |
| - <Checkbox label="" small checked={overriden} onChange={() => setOverriden((old) => !old)} /> |
62 |
| - <Field placeholder={"overriden"}></Field> |
63 |
| - </FieldContainer> |
64 |
| - </RulingSettings> |
| 41 | + <Container> |
| 42 | + <Header text="Ruling Mode" /> |
| 43 | + <SelectContainer> |
| 44 | + <Radio |
| 45 | + small |
| 46 | + label="Manual" |
| 47 | + checked={rulingMode === RULING_MODE.Manual} |
| 48 | + onChange={() => { |
| 49 | + setRulingMode(RULING_MODE.Manual); |
| 50 | + }} |
| 51 | + /> |
| 52 | + <Radio |
| 53 | + small |
| 54 | + label="Random Preset" |
| 55 | + checked={rulingMode === RULING_MODE.RandomPreset} |
| 56 | + onChange={() => { |
| 57 | + setRulingMode(RULING_MODE.RandomPreset); |
| 58 | + }} |
| 59 | + /> |
| 60 | + <Radio |
| 61 | + small |
| 62 | + label="Automatic Preset" |
| 63 | + checked={rulingMode === RULING_MODE.AutomaticPreset} |
| 64 | + onChange={() => { |
| 65 | + setRulingMode(RULING_MODE.AutomaticPreset); |
| 66 | + }} |
| 67 | + /> |
| 68 | + <AutomaticPresetInputsContainer> |
| 69 | + <LabeledInput |
| 70 | + label="Ruling" |
| 71 | + type="number" |
| 72 | + value={ruling} |
| 73 | + onChange={(e) => setRuling(Number(e.target.value))} |
| 74 | + /> |
| 75 | + <LabeledInput label="Tie" inputType="checkbox" checked={tie} onChange={() => setTie((prev) => !prev)} /> |
| 76 | + <LabeledInput |
| 77 | + label="Overidden" |
| 78 | + inputType="checkbox" |
| 79 | + checked={overriden} |
| 80 | + onChange={() => setOverriden((prev) => !prev)} |
| 81 | + /> |
| 82 | + </AutomaticPresetInputsContainer> |
| 83 | + </SelectContainer> |
65 | 84 |
|
66 |
| - <RulingSettings> |
67 |
| - <LightButton text={"Run Automatically Randomly"} /> |
68 |
| - </RulingSettings> |
69 |
| - </Container> |
70 |
| - </div> |
| 85 | + <Button text="Update" /> |
| 86 | + </Container> |
71 | 87 | );
|
72 | 88 | };
|
73 | 89 |
|
|
0 commit comments