diff options
| author | Sam Nystrom <sam@samnystrom.dev> | 2024-03-12 14:52:25 +0000 |
|---|---|---|
| committer | Sam Nystrom <sam@samnystrom.dev> | 2024-03-12 17:34:56 -0400 |
| commit | a9aa246f58dcb2664c4e7a1bd98e69c19e7d7000 (patch) | |
| tree | 2795ec23ec748024dd863215a9735cb8c3825579 /src/pages/ProjectsList.tsx | |
| parent | 367fe51e7e1c55e39299e2e667ca4f399a474019 (diff) | |
Add rudimentary backend and auth
Diffstat (limited to 'src/pages/ProjectsList.tsx')
| -rw-r--r-- | src/pages/ProjectsList.tsx | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/src/pages/ProjectsList.tsx b/src/pages/ProjectsList.tsx new file mode 100644 index 0000000..b30c73e --- /dev/null +++ b/src/pages/ProjectsList.tsx @@ -0,0 +1,49 @@ +import { useContext, useEffect } from 'preact/hooks'; +import { useSignal } from '@preact/signals'; +import { route } from 'preact-router'; +import { Pb } from '../pb.ts'; + +export const ProjectsList = ({ user }) => { + console.log(user); + const pb = useContext(Pb); + const projects = useSignal(null); + const projectName = useSignal(''); + + useEffect(() => { + pb.collection('projects') + .getList(1, 20, { sort: '-mtime' }) + .then(p => projects.value = p); + }, []); + + const onCreateProject = async (event: FormEvent) => { + event.preventDefault(); + const project = await pb.collection('projects').create({ + name: projectName.value, + owner: pb.authStore.model.id, + }); + route(`/${user}/${project.name}`); + }; + + if (projects.value === null) { + return ( + <p>Loading...</p> + ); + } + return ( + <main> + <h1>{user}</h1> + <form onSubmit={onCreateProject}> + <label> + Name: + <input type="text" value={projectName} onInput={e => projectName.value = e.target.value} /> + </label> + <button>Create roject</button> + </form> + <ul> + {projects.value.items.map(p => ( + <li><a href={`/${user}/${p.name}`}>{p.name}</a></li> + ))} + </ul> + </main> + ); +};
\ No newline at end of file |
