revite/ui/ui.tsx

89 lines
3 KiB
TypeScript
Raw Normal View History

2021-07-24 19:39:41 +01:00
import styled from "styled-components";
2021-06-18 15:35:35 +01:00
2021-07-24 19:39:41 +01:00
import "../src/styles/index.scss";
import { render } from "preact";
import { useState } from "preact/hooks";
import Theme from "../src/context/Theme";
import Banner from "../src/components/ui/Banner";
import Button from "../src/components/ui/Button";
import Checkbox from "../src/components/ui/Checkbox";
import ColourSwatches from "../src/components/ui/ColourSwatches";
import ComboBox from "../src/components/ui/ComboBox";
import InputBox from "../src/components/ui/InputBox";
import Overline from "../src/components/ui/Overline";
import Radio from "../src/components/ui/Radio";
import Tip from "../src/components/ui/Tip";
2021-06-18 15:35:35 +01:00
export const UIDemo = styled.div`
2021-07-24 19:39:41 +01:00
gap: 12px;
padding: 12px;
display: flex;
flex-direction: column;
align-items: flex-start;
2021-06-18 15:35:35 +01:00
`;
export function UI() {
2021-07-24 19:39:41 +01:00
let [checked, setChecked] = useState(false);
let [colour, setColour] = useState("#FD6671");
let [selected, setSelected] = useState<"a" | "b" | "c">("a");
2021-06-18 15:35:35 +01:00
return (
<>
<Button>Button (normal)</Button>
<Button contrast>Button (contrast)</Button>
<Button error>Button (error)</Button>
2021-07-24 19:39:41 +01:00
<Button contrast error>
Button (contrast + error)
</Button>
2021-06-18 15:35:35 +01:00
<Banner>I am a banner!</Banner>
2021-07-24 19:39:41 +01:00
<Checkbox
checked={checked}
onChange={setChecked}
description="ok gamer">
Do you want thing??
</Checkbox>
2021-06-18 15:35:35 +01:00
<ComboBox>
<option>Select an option.</option>
<option>1</option>
<option>2</option>
<option>3</option>
</ComboBox>
<InputBox placeholder="Normal input box..." />
<InputBox placeholder="Contrast input box..." contrast />
<InputBox value="Input box with value" />
<InputBox value="Contrast with value" contrast />
2021-07-24 19:39:41 +01:00
<ColourSwatches value={colour} onChange={(v) => setColour(v)} />
<Tip hideSeparator>I am a tip! I provide valuable information.</Tip>
<Radio checked={selected === "a"} onSelect={() => setSelected("a")}>
First option
</Radio>
<Radio checked={selected === "b"} onSelect={() => setSelected("b")}>
Second option
</Radio>
<Radio checked={selected === "c"} onSelect={() => setSelected("c")}>
Last option
</Radio>
2021-06-18 15:35:35 +01:00
<Overline>Normal overline</Overline>
<Overline type="subtle">Subtle overline</Overline>
<Overline type="error">Error overline</Overline>
<Overline error="with error">Normal overline</Overline>
2021-07-24 19:39:41 +01:00
<Overline type="subtle" error="with error">
Subtle overline
</Overline>
2021-06-18 15:35:35 +01:00
</>
2021-07-24 19:39:41 +01:00
);
2021-06-18 15:35:35 +01:00
}
2021-07-24 19:39:41 +01:00
render(
<>
<Theme>
<UIDemo>
<UI />
</UIDemo>
</Theme>
</>,
document.getElementById("app")!,
);