diff --git a/src-tauri/migrations/20230427081017_clean_up_account.sql b/src-tauri/migrations/20230427081017_clean_up_account.sql new file mode 100644 index 00000000..5c5d8925 --- /dev/null +++ b/src-tauri/migrations/20230427081017_clean_up_account.sql @@ -0,0 +1,6 @@ +-- Add migration script here +ALTER TABLE accounts +DROP COLUMN channels; + +ALTER TABLE accounts +DROP COLUMN chats; \ No newline at end of file diff --git a/src-tauri/src/main.rs b/src-tauri/src/main.rs index b4c1185b..11da746a 100644 --- a/src-tauri/src/main.rs +++ b/src-tauri/src/main.rs @@ -87,6 +87,12 @@ fn main() { sql: include_str!("../migrations/20230425050745_add_blacklist_model.sql"), kind: MigrationKind::Up, }, + Migration { + version: 20230427081017, + description: "clean up account", + sql: include_str!("../migrations/20230427081017_clean_up_account.sql"), + kind: MigrationKind::Up, + }, ], ) .build(), diff --git a/src/onboarding/components/user.tsx b/src/onboarding/components/user.tsx new file mode 100644 index 00000000..c69370da --- /dev/null +++ b/src/onboarding/components/user.tsx @@ -0,0 +1,29 @@ +import { DEFAULT_AVATAR } from '@lume/stores/constants'; +import { useProfile } from '@lume/utils/hooks/useProfile'; +import { shortenKey } from '@lume/utils/shortenKey'; + +export default function User({ pubkey }: { pubkey: string }) { + const profile = useProfile(pubkey); + + return ( +
+
+ {pubkey} +
+
+ + {profile?.display_name || profile?.name} + + + {profile?.nip05?.toLowerCase() || shortenKey(pubkey)} + +
+
+ ); +} diff --git a/src/onboarding/pages/create/index.page.tsx b/src/onboarding/pages/create/index.page.tsx index 9c7d07dd..c15c7bd4 100644 --- a/src/onboarding/pages/create/index.page.tsx +++ b/src/onboarding/pages/create/index.page.tsx @@ -1,37 +1,21 @@ -import { RelayContext } from '@lume/shared/relaysProvider'; -import { WRITEONLY_RELAYS } from '@lume/stores/constants'; -import { createAccount } from '@lume/utils/storage'; +import { onboardingAtom } from '@lume/stores/onboarding'; import { EyeClose, EyeEmpty } from 'iconoir-react'; -import { generatePrivateKey, getEventHash, getPublicKey, nip19, signEvent } from 'nostr-tools'; -import { useCallback, useContext, useMemo, useState } from 'react'; +import { useSetAtom } from 'jotai'; +import { generatePrivateKey, getPublicKey, nip19 } from 'nostr-tools'; +import { useMemo, useState } from 'react'; import { navigate } from 'vite-plugin-ssr/client/router'; export function Page() { - const pool: any = useContext(RelayContext); - const [type, setType] = useState('password'); - const [loading, setLoading] = useState(false); - + const setOnboarding = useSetAtom(onboardingAtom); const privkey = useMemo(() => generatePrivateKey(), []); - const name = 'Pleb'; const pubkey = getPublicKey(privkey); const npub = nip19.npubEncode(pubkey); const nsec = nip19.nsecEncode(privkey); - // auto-generated profile metadata - const metadata: any = useMemo( - () => ({ - display_name: name, - name: name, - username: name.toLowerCase(), - picture: 'https://void.cat/d/KmypFh2fBdYCEvyJrPiN89.webp', - }), - [name] - ); - - // toggle privatek key + // toggle private key const showPrivateKey = () => { if (type === 'password') { setType('text'); @@ -40,119 +24,56 @@ export function Page() { } }; - // create account and broadcast to all relays - const submit = useCallback(async () => { - setLoading(true); - - // build event - const event: any = { - content: JSON.stringify(metadata), - created_at: Math.floor(Date.now() / 1000), - kind: 0, - pubkey: pubkey, - tags: [], - }; - event.id = getEventHash(event); - event.sig = signEvent(event, privkey); - // insert to database - createAccount(pubkey, privkey, metadata); - // broadcast - pool.publish(event, WRITEONLY_RELAYS); - // redirect to next step - navigate(`/onboarding/create/step-2?pubkey=${pubkey}&privkey=${privkey}`, { overwriteLastHistoryEntry: true }); - }, [pool, pubkey, privkey, metadata]); + const submit = () => { + setOnboarding((prev) => ({ ...prev, pubkey: pubkey, privkey: privkey })); + navigate('/onboarding/create/step-2'); + }; return ( -
-
-

- Create new account -

-
-
-
-
-
- -
- -
-
-
- -
- - -
-
-
- -
-
-
-
- default avatar -
-
-
-

{metadata.display_name}

-

@{metadata.username}

-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
+

Lume is auto-generated key for you

+
+
+
+ +
+
-
- {loading === true ? ( - - - - - ) : ( +
+ +
+ - )} +
+
diff --git a/src/onboarding/pages/create/step-2/index.page.tsx b/src/onboarding/pages/create/step-2/index.page.tsx index 1eb3f51c..becd24d0 100644 --- a/src/onboarding/pages/create/step-2/index.page.tsx +++ b/src/onboarding/pages/create/step-2/index.page.tsx @@ -1,185 +1,121 @@ -import { RelayContext } from '@lume/shared/relaysProvider'; -import { UserBase } from '@lume/shared/user/base'; -import { WRITEONLY_RELAYS } from '@lume/stores/constants'; -import { usePageContext } from '@lume/utils/hooks/usePageContext'; -import { fetchProfileMetadata } from '@lume/utils/hooks/useProfile'; -import { createPleb, updateAccount } from '@lume/utils/storage'; -import { arrayToNIP02 } from '@lume/utils/transform'; +import { AvatarUploader } from '@lume/shared/avatarUploader'; +import { DEFAULT_AVATAR } from '@lume/stores/constants'; +import { onboardingAtom } from '@lume/stores/onboarding'; -import { createClient } from '@supabase/supabase-js'; -import { CheckCircle } from 'iconoir-react'; -import { getEventHash, signEvent } from 'nostr-tools'; -import { Key, useCallback, useContext, useEffect, useState } from 'react'; +import { useAtom } from 'jotai'; +import { useEffect, useState } from 'react'; +import { useForm } from 'react-hook-form'; import { navigate } from 'vite-plugin-ssr/client/router'; -const supabase = createClient( - 'https://niwaazauwnrwiwmnocnn.supabase.co', - 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJzdXBhYmFzZSIsInJlZiI6Im5pd2FhemF1d25yd2l3bW5vY25uIiwicm9sZSI6ImFub24iLCJpYXQiOjE2NzYwMjAzMjAsImV4cCI6MTk5MTU5NjMyMH0.IbjrnE6rDgC6lhIAHBIMN4niM2bPjxkRLtvAy_gFgqw' -); - -const initialList = [ - { pubkey: '82341f882b6eabcd2ba7f1ef90aad961cf074af15b9ef44a09f9d2a8fbfbe6a2' }, - { pubkey: 'a341f45ff9758f570a21b000c17d4e53a3a497c8397f26c0e6d61e5acffc7a98' }, - { pubkey: '04c915daefee38317fa734444acee390a8269fe5810b2241e5e6dd343dfbecc9' }, - { pubkey: 'c4eabae1be3cf657bc1855ee05e69de9f059cb7a059227168b80b89761cbc4e0' }, - { pubkey: '6e468422dfb74a5738702a8823b9b28168abab8655faacb6853cd0ee15deee93' }, - { pubkey: 'e88a691e98d9987c964521dff60025f60700378a4879180dcbbb4a5027850411' }, - { pubkey: '3bf0c63fcb93463407af97a5e5ee64fa883d107ef9e558472c4eb9aaaefa459d' }, - { pubkey: 'c49d52a573366792b9a6e4851587c28042fb24fa5625c6d67b8c95c8751aca15' }, - { pubkey: 'e33fe65f1fde44c6dc17eeb38fdad0fceaf1cae8722084332ed1e32496291d42' }, - { pubkey: '84dee6e676e5bb67b4ad4e042cf70cbd8681155db535942fcc6a0533858a7240' }, - { pubkey: '703e26b4f8bc0fa57f99d815dbb75b086012acc24fc557befa310f5aa08d1898' }, - { pubkey: 'bf2376e17ba4ec269d10fcc996a4746b451152be9031fa48e74553dde5526bce' }, - { pubkey: '4523be58d395b1b196a9b8c82b038b6895cb02b683d0c253a955068dba1facd0' }, - { pubkey: 'c9b19ffcd43e6a5f23b3d27106ce19e4ad2df89ba1031dd4617f1b591e108965' }, - { pubkey: 'c7dccba4fe4426a7b1ea239a5637ba40fab9862c8c86b3330fe65e9f667435f6' }, - { pubkey: '6e1534f56fc9e937e06237c8ba4b5662bcacc4e1a3cfab9c16d89390bec4fca3' }, - { pubkey: '50d94fc2d8580c682b071a542f8b1e31a200b0508bab95a33bef0855df281d63' }, - { pubkey: '3d2e51508699f98f0f2bdbe7a45b673c687fe6420f466dc296d90b908d51d594' }, - { pubkey: '6e3f51664e19e082df5217fd4492bb96907405a0b27028671dd7f297b688608c' }, - { pubkey: '2edbcea694d164629854a52583458fd6d965b161e3c48b57d3aff01940558884' }, - { pubkey: '3f770d65d3a764a9c5cb503ae123e62ec7598ad035d836e2a810f3877a745b24' }, - { pubkey: 'eab0e756d32b80bcd464f3d844b8040303075a13eabc3599a762c9ac7ab91f4f' }, - { pubkey: 'be1d89794bf92de5dd64c1e60f6a2c70c140abac9932418fee30c5c637fe9479' }, - { pubkey: 'a5e93aef8e820cbc7ab7b6205f854b87aed4b48c5f6b30fbbeba5c99e40dcf3f' }, - { pubkey: '1989034e56b8f606c724f45a12ce84a11841621aaf7182a1f6564380b9c4276b' }, - { pubkey: 'c48b5cced5ada74db078df6b00fa53fc1139d73bf0ed16de325d52220211dbd5' }, - { pubkey: '460c25e682fda7832b52d1f22d3d22b3176d972f60dcdc3212ed8c92ef85065c' }, - { pubkey: '7f3b464b9ff3623630485060cbda3a7790131c5339a7803bde8feb79a5e1b06a' }, - { pubkey: 'b99dbca0184a32ce55904cb267b22e434823c97f418f36daf5d2dff0dd7b5c27' }, - { pubkey: 'e9e4276490374a0daf7759fd5f475deff6ffb9b0fc5fa98c902b5f4b2fe3bba2' }, - { pubkey: 'ea2e3c814d08a378f8a5b8faecb2884d05855975c5ca4b5c25e2d6f936286f14' }, - { pubkey: 'ff04a0e6cd80c141b0b55825fed127d4532a6eecdb7e743a38a3c28bf9f44609' }, -]; - export function Page() { - const pageContext = usePageContext(); - const searchParams: any = pageContext.urlParsed.search; - - const pubkey = searchParams.pubkey || ''; - const privkey = searchParams.privkey || ''; - - const pool: any = useContext(RelayContext); + const [image, setImage] = useState(DEFAULT_AVATAR); const [loading, setLoading] = useState(false); - const [list, setList]: any = useState(initialList); - const [follows, setFollows] = useState([]); + const [onboarding, setOnboarding] = useAtom(onboardingAtom); - // toggle follow state - const toggleFollow = (pubkey: string) => { - const arr = follows.includes(pubkey) ? follows.filter((i) => i !== pubkey) : [...follows, pubkey]; - setFollows(arr); + const { + register, + handleSubmit, + setValue, + formState: { isDirty, isValid }, + } = useForm({ + defaultValues: async () => { + if (onboarding.metadata) { + return onboarding.metadata; + } else { + return null; + } + }, + }); + + const onSubmit = (data: any) => { + setLoading(true); + setOnboarding((prev) => ({ ...prev, metadata: data })); + navigate('/onboarding/create/step-3'); }; - // save follows to database then broadcast - const submit = useCallback(async () => { - setLoading(true); - - const nip02 = arrayToNIP02(follows); - - // update account's folllows with NIP-02 tag list - updateAccount('follows', follows, pubkey); - - // create pleb - for (const tag of follows) { - fetchProfileMetadata(tag) - .then((res: any) => createPleb(tag, res.content)) - .catch(console.error); - } - - // build event - const event: any = { - content: '', - created_at: Math.floor(Date.now() / 1000), - kind: 3, - pubkey: pubkey, - tags: nip02, - }; - event.id = getEventHash(event); - event.sig = signEvent(event, privkey); - // broadcast - pool.publish(event, WRITEONLY_RELAYS); - // redirect to splashscreen - navigate('/'); - }, [pubkey, privkey, follows, pool]); - useEffect(() => { - let ignore = false; - - const fetchData = async () => { - const { data } = await supabase.from('random_users').select('pubkey').limit(28); - // update state - setList((list: any) => [...list, ...data]); - }; - - if (!ignore) { - fetchData().catch(console.error); - } - - return () => { - ignore = true; - }; - }, []); + setValue('picture', image); + }, [setValue, image]); return ( -
-
-
-

- Personalized your newsfeed -

-

- Follow at least{' '} - - {follows.length}/10 - {' '} - plebs -

+
+
+
+

Create your profile

-
-
-
- {list.map((item: { pubkey: string }, index: Key) => ( - - ))} +
+
+
+ +
+ +
+
+
+ +
+