116 lines
2.9 KiB
TypeScript
116 lines
2.9 KiB
TypeScript
/** @jsx jsx */
|
|
import { jsx, Box, Flex } from "theme-ui"
|
|
import {
|
|
Container,
|
|
Card,
|
|
CardContent,
|
|
Typography,
|
|
CardActions,
|
|
Button,
|
|
makeStyles,
|
|
AppBar,
|
|
Tabs,
|
|
Tab,
|
|
Input
|
|
} from "@material-ui/core"
|
|
import Dropzone from "../src/components/Dropzone"
|
|
import { useState } from "react"
|
|
import { TabPanel } from "../src/components/TabPanel"
|
|
import * as R from "ramda"
|
|
|
|
const Index = () => {
|
|
const [value, setValue] = useState(1)
|
|
const [linkfileUrl, setInput] = useState("")
|
|
|
|
const handleChange = (event, newValue) => {
|
|
setValue(newValue)
|
|
}
|
|
|
|
const directView = () => {
|
|
const removeHead = R.compose(R.tail, R.split("sia://"))
|
|
const hash = removeHead(linkfileUrl)[0]
|
|
if (window) {
|
|
var win = window.open(`/direct/${hash}`, "_blank")
|
|
win.focus()
|
|
}
|
|
}
|
|
return (
|
|
<>
|
|
<Box color="white">
|
|
<Container>
|
|
<Flex sx={{ alignItems: "center", height: 120 }}>
|
|
<Box>
|
|
<Typography sx={{ fontWeight: 700 }}>Sia Skynet</Typography>
|
|
</Box>
|
|
<Box sx={{ ml: "auto" }}>
|
|
<Button href="https://sia.tech/" target="_blank">
|
|
About Sia
|
|
</Button>
|
|
</Box>
|
|
</Flex>
|
|
</Container>
|
|
</Box>
|
|
<Box>
|
|
<Container>
|
|
<AppBar position="static">
|
|
<Tabs
|
|
value={value}
|
|
onChange={handleChange}
|
|
aria-label="simple tabs example"
|
|
>
|
|
<Tab label="Upload" />
|
|
<Tab label="Download" />
|
|
</Tabs>
|
|
</AppBar>
|
|
</Container>
|
|
</Box>
|
|
<Container>
|
|
<TabPanel value={value} index={0}>
|
|
<Card sx={{ width: "100%" }}>
|
|
<CardContent>
|
|
<Dropzone />
|
|
</CardContent>
|
|
</Card>
|
|
</TabPanel>
|
|
</Container>
|
|
<Container>
|
|
<TabPanel value={value} index={1}>
|
|
<Card sx={{ width: "100%" }}>
|
|
<CardContent>
|
|
<Flex
|
|
sx={{
|
|
height: 400,
|
|
justifyContent: "center",
|
|
alignItems: "center",
|
|
flexDirection: "column"
|
|
}}
|
|
>
|
|
<p>Download a file by pasting in a Sia linkfile below:</p>
|
|
<Box sx={{ width: "60%" }}>
|
|
<Input
|
|
placeholder="sia://"
|
|
value={linkfileUrl}
|
|
onChange={e => setInput(e.target.value)}
|
|
sx={{ width: "100%" }}
|
|
/>
|
|
</Box>
|
|
<Box sx={{ mt: 3 }}>
|
|
<Button
|
|
variant="contained"
|
|
color="primary"
|
|
onClick={directView}
|
|
>
|
|
Download
|
|
</Button>
|
|
</Box>
|
|
</Flex>
|
|
</CardContent>
|
|
</Card>
|
|
</TabPanel>
|
|
</Container>
|
|
</>
|
|
)
|
|
}
|
|
|
|
export default Index
|