CoastalCommitsPastes/client/components/new-post/password/index.tsx

51 lines
1.8 KiB
TypeScript
Raw Normal View History

2022-03-21 06:28:06 -04:00
import { Input, Modal, Note, Spacer } from "@geist-ui/core"
import { useState } from "react"
type Props = {
2022-03-21 21:51:19 -04:00
warning?: boolean
2022-03-21 06:28:06 -04:00
isOpen: boolean
onClose: () => void
onSubmit: (password: string) => void
}
2022-03-21 21:51:19 -04:00
const PasswordModal = ({ isOpen, onClose, onSubmit: onSubmitAfterVerify, warning }: Props) => {
2022-03-21 06:28:06 -04:00
const [password, setPassword] = useState<string>()
const [confirmPassword, setConfirmPassword] = useState<string>()
const [error, setError] = useState<string>()
const onSubmit = () => {
if (!password || !confirmPassword) {
setError('Please enter a password')
return
}
if (password !== confirmPassword) {
setError("Passwords do not match")
return
}
onSubmitAfterVerify(password)
}
return (<>
{<Modal visible={isOpen} >
<Modal.Title>Enter a password</Modal.Title>
<Modal.Content>
2022-03-21 21:51:19 -04:00
{!error && warning && <Note type="warning" label='Warning'>
2022-03-21 06:28:06 -04:00
This doesn&apos;t protect your post from the server administrator.
</Note>}
{error && <Note type="error" label='Error'>
{error}
</Note>}
<Spacer />
<Input width={"100%"} label="Password" marginBottom={1} htmlType="password" placeholder="Password" onChange={(e) => setPassword(e.target.value)} />
<Input width={"100%"} label="Confirm" htmlType="password" placeholder="Confirm Password" onChange={(e) => setConfirmPassword(e.target.value)} />
</Modal.Content>
<Modal.Action passive onClick={onClose}>Cancel</Modal.Action>
<Modal.Action onClick={onSubmit}>Submit</Modal.Action>
</Modal>}
</>)
}
export default PasswordModal