e03cc01109
#171 #171 #171 #171 #171 #171 #171 Co-authored-by: miteruzo <miteruzo@naver.com> Reviewed-on: #345
71 lines
2.1 KiB
TypeScript
71 lines
2.1 KiB
TypeScript
import { useState } from 'react'
|
|
|
|
import { useDialogue } from '@/components/dialogues/DialogueProvider'
|
|
import { Button } from '@/components/ui/button'
|
|
import { Dialog,
|
|
DialogContent,
|
|
DialogDescription,
|
|
DialogHeader,
|
|
DialogTitle } from '@/components/ui/dialog'
|
|
import { Input } from '@/components/ui/input'
|
|
import { toast } from '@/components/ui/use-toast'
|
|
import { apiPost } from '@/lib/api'
|
|
|
|
import type { User } from '@/types'
|
|
|
|
type Props = { visible: boolean
|
|
onVisibleChange: (visible: boolean) => void
|
|
setUser: (user: User) => void }
|
|
|
|
|
|
export default ({ visible, onVisibleChange, setUser }: Props) => {
|
|
const dialogue = useDialogue ()
|
|
|
|
const [inputCode, setInputCode] = useState ('')
|
|
|
|
const handleTransfer = async () => {
|
|
if (!(await dialogue.confirm ({
|
|
title: '引継ぎを行ってもよろしいですか?',
|
|
description: '現在のアカウントからはログアウトされます.',
|
|
confirmText: '引継ぐ',
|
|
variant: 'danger' })))
|
|
return
|
|
|
|
try
|
|
{
|
|
const data = await apiPost<{ valid: boolean; user: User }> (
|
|
'/users/verify', { code: inputCode })
|
|
if (data.valid)
|
|
{
|
|
localStorage.setItem ('user_code', inputCode)
|
|
setUser (data.user)
|
|
toast ({ title: '引継ぎ成功!' })
|
|
onVisibleChange (false)
|
|
}
|
|
else
|
|
toast ({ title: '認証失敗', description: 'そのコードは使へません.' })
|
|
}
|
|
catch
|
|
{
|
|
toast ({ title: '通信エラー', description: 'またあとで試してね.' })
|
|
}
|
|
}
|
|
|
|
return (
|
|
<Dialog open={visible} onOpenChange={onVisibleChange}>
|
|
<DialogContent className="px-6 pp-6 pt-7">
|
|
<DialogHeader className="pl-8">
|
|
<DialogTitle>ほかのブラウザから引継ぐ</DialogTitle>
|
|
<DialogDescription asChild>
|
|
<div className="flex gap-2">
|
|
<Input placeholder="引継ぎコードを入力"
|
|
value={inputCode}
|
|
onChange={ev => setInputCode (ev.target.value)}/>
|
|
<Button onClick={handleTransfer}>引継ぐ</Button>
|
|
</div>
|
|
</DialogDescription>
|
|
</DialogHeader>
|
|
</DialogContent>
|
|
</Dialog>)
|
|
}
|