-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Matt
committed
Jan 7, 2024
1 parent
38053a5
commit e04e653
Showing
1 changed file
with
114 additions
and
29 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,51 +1,136 @@ | ||
import { Flex, Text, Link } from '@radix-ui/themes'; | ||
import { json, redirect } from "@remix-run/node"; | ||
import { Flex, Card, Heading, Text, Button, Dialog, TextField, Strong, Link } from '@radix-ui/themes'; | ||
import { authorize } from "../sessions.server.js"; | ||
import env from "../environment.server.js"; | ||
import { json, redirect } from "@remix-run/node"; | ||
import CreateCommunityDialog from '../components/create-community-dialog.jsx'; | ||
import { me, createCommunity } from "../wikid.server.js"; | ||
import { useLoaderData } from "@remix-run/react"; | ||
import { MagnifyingGlassIcon } from '@radix-ui/react-icons'; | ||
|
||
import '../components/styles.get-started.css' | ||
|
||
export const meta = () => { | ||
return [ | ||
{ | ||
title: "Wikid app" | ||
}, | ||
{ | ||
property: "og:title", | ||
content: "Wikid app", | ||
}, | ||
{ | ||
name: "description", | ||
content: "Where communities meet", | ||
}, | ||
{ | ||
title: "Wikid | join a community" | ||
}, | ||
{ | ||
property: "og:title", | ||
content: "Wikid | join a community", | ||
}, | ||
{ | ||
name: "description", | ||
content: "Where communities meet", | ||
}, | ||
]; | ||
}; | ||
|
||
export const loader = async ({ request }) => { | ||
const jwt = await authorize(request); | ||
|
||
if (!!jwt) { | ||
const [data, errors] = await me(jwt); | ||
return json({ me: data, errors: errors }); | ||
} | ||
|
||
return json({ me: null, errors: null }) | ||
} | ||
|
||
export async function action({ request }) { | ||
const body = await request.formData(); | ||
|
||
// const jwt = await authorize(request); | ||
const jwt = await authorize(request); | ||
|
||
// if (!!jwt) { | ||
// return redirect('/c/get-started'); | ||
// } | ||
const type = body.get("__action"); | ||
|
||
// return json({ electron: env.electron }) | ||
if (type == "create_community") { | ||
|
||
return redirect('/c/get-started'); | ||
const name = body.get("name"); | ||
const handle = body.get("handle"); | ||
const _private = body.get("private") == "private"; | ||
|
||
const [_, errors, __] = await createCommunity(name, handle, _private, jwt); | ||
|
||
if (!!errors) { | ||
return json(errors); | ||
} | ||
|
||
throw redirect(`/c/${handle}`); | ||
} | ||
} | ||
|
||
export default function Index() { | ||
|
||
const data = useLoaderData(); | ||
|
||
const featuredCommunities = [ | ||
{ | ||
id: "wikid", | ||
name: "Wikid Beta Testers 💖", | ||
members: 100 | ||
} | ||
]; | ||
|
||
return ( | ||
<> | ||
{data.electron && <nav className='wk-heading'> | ||
<Text weight="bold"> </Text> | ||
</nav>} | ||
<Flex direction="column" align="center" justify="center" pt="9" gap="2"> | ||
<Text>👷🏼♂️ Under construction 👷🏻</Text> | ||
<Link href='/join-beta' >Join beta?</Link> | ||
<Link color='red' href='/login'>Login, daring adventurer 🦄</Link> | ||
<Flex direction="column" gap="0" className="wk-main-content"> | ||
<nav className='wk-heading-smol'> | ||
<Flex direction="row" align="center" justify="center" p="0" style={{ width: "100%" }}> | ||
<TextField.Root radius='full'> | ||
<TextField.Slot> | ||
<MagnifyingGlassIcon height="16" width="16" /> | ||
</TextField.Slot> | ||
<TextField.Input | ||
type='text' | ||
className='wk-find-community' | ||
size="2" | ||
defaultValue="" | ||
placeholder="Find your community" | ||
style={{ | ||
width: 400, | ||
}} | ||
/> | ||
</TextField.Root> | ||
</Flex> | ||
</nav> | ||
<Flex direction="row" pt="8" align="start" justify="center" wrap="wrap" gap="9" className='wk-under-content'> | ||
<Card style={{ | ||
maxWidth: 400, | ||
width: "100%" | ||
}} size="4"> | ||
<Flex direction="column" gap="4"> | ||
<Heading>Create your community</Heading> | ||
<Text>Start your own community and invite friends to join.</Text> | ||
{!!(data?.me) ? <Dialog.Root> | ||
<label> | ||
<Dialog.Trigger> | ||
<Button radius='full'>Create community</Button> | ||
</Dialog.Trigger> | ||
</label> | ||
<CreateCommunityDialog /> | ||
</Dialog.Root> : <Link href='/signup'> | ||
<Button radius='full'>Create community</Button> | ||
</Link>} | ||
</Flex> | ||
</Card> | ||
<Card style={{ maxWidth: 400, width: "100%" }} size="4"> | ||
<Flex direction="column" gap="4"> | ||
<Heading>Join a community</Heading> | ||
<Text>Search for a community to join.</Text> | ||
<Text weight="bold" size="2">Featured communities</Text> | ||
{featuredCommunities.map((c) => { | ||
return <Link key={`fcm-${c.id}`} href={`/c/${c.id}`}> | ||
<Button variant="ghost" style={{ width: "100%" }}> | ||
<Flex align="start" justify="start" direction="column" gap="1" style={{ | ||
width: "100%", | ||
}}> | ||
<Text size="3" style={{ color: "var(--gray-12)" }}><Strong>{c.name}</Strong></Text> | ||
<Text color='green' size="2">{`${c.members} members`}</Text> | ||
</Flex> | ||
</Button> | ||
</Link> | ||
})} | ||
</Flex> | ||
</Card> | ||
</Flex> | ||
</> | ||
</Flex> | ||
); | ||
} |