1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
import { useEffect, useState } from 'react';
import { invoke } from '@tauri-apps/api/core';
export default function Root() {
const [existingAccounts, setExistingAccounts] = useState<any>([])
const [signedIn, setSignedIn] = useState<{serverDomain: string, username: string} | null>(null)
const [accountData, setAccountData] = useState('')
async function signIn() {
let [serverDomain, username] = await invoke('start_account_auth', {instanceDomain: 'social.tempest.dev'}) as string[]
setSignedIn({serverDomain, username})
}
async function getSelf() {
if (!signedIn) throw new Error("Not signed in")
const {serverDomain, username} = signedIn;
let result = await invoke('get_self', {serverDomain, username}) as string
setAccountData(JSON.parse(result))
}
useEffect(() => {
(async () => {
setExistingAccounts(await invoke('get_all_accounts'))
})()
}, [])
return (
<>
{!signedIn ? (
<>
<p>Existing accounts:</p>
{existingAccounts.map(({username, server_domain}: {username: string, server_domain: string}) => (
<>
<button key={username + server_domain} onClick={() => setSignedIn({serverDomain: server_domain, username})}>@{username}@{server_domain}</button>
<br/>
</>
))}
<button onClick={signIn}>Add another account</button>
</>
) : (!accountData ? (
<button onClick={getSelf}>Retrieve account data</button>
):(
<p>Result from rust: <pre style={{whiteSpace:'pre'}}>{JSON.stringify(accountData, null, 2)}</pre></p>
))}
</>
)
}
|