Compare commits

..

No commits in common. "cd90c92c6d66c525460010dd620a03cd0ceecf10" and "79e34039020f24a5832d176f60594ab07862c1d7" have entirely different histories.

4 changed files with 29 additions and 30 deletions

Binary file not shown.

View File

@ -51,9 +51,14 @@ export const columns: ColumnDef<StoryWithGenres>[] = [
} }
}, },
columnHelper.accessor("genres", { columnHelper.accessor("genres", {
// cell: props => {
// const genres = props.getValue()
// return <GenreBadges genres={genres} />
// },
cell: GenrePickerInputCell, cell: GenrePickerInputCell,
filterFn: "arrIncludes", filterFn: "arrIncludes",
meta: {} meta: {}
//TODO - write custom filter function, to account for an array of objects
}), }),
] ]

View File

@ -227,7 +227,7 @@ export function DataTable<TData, TValue>({
<TableBody> <TableBody>
{table.getRowModel().rows?.length ? ( {table.getRowModel().rows?.length ? (
table.getRowModel().rows.map((row) => ( table.getRowModel().rows.map((row) => (
<ContextMenu onOpenChange={open => setIsContextMenuOpen(open)} key={row.id + "contextMenu"}> <ContextMenu onOpenChange={open => setIsContextMenuOpen(open)}>
<ContextMenuTrigger asChild> <ContextMenuTrigger asChild>
<TableRow <TableRow
key={row.id} key={row.id}
@ -240,7 +240,6 @@ export function DataTable<TData, TValue>({
</TableCell> </TableCell>
))} ))}
<FormContextMenu <FormContextMenu
key={"formContextMenu" + row.id}
row={row} row={row}
table={table} table={table}
/> />

View File

@ -4,14 +4,13 @@ import { Popover, PopoverContent, PopoverTrigger } from "@/components/ui/popover
import { Button } from "@/components/ui/button" import { Button } from "@/components/ui/button"
import { Checkbox } from "@/components/ui/checkbox" import { Checkbox } from "@/components/ui/checkbox"
import { ComponentProps, useState } from "react" import { ComponentProps, useState } from "react"
import { EventType, useForm, UseFormReturn } from "react-hook-form" import { useForm, UseFormReturn } from "react-hook-form"
import { CellContext } from "@tanstack/react-table" import { CellContext } from "@tanstack/react-table"
import { z } from "zod" import { z } from "zod"
import { zodResolver } from "@hookform/resolvers/zod" import { zodResolver } from "@hookform/resolvers/zod"
import { toast } from "@/components/ui/use-toast" import { toast } from "@/components/ui/use-toast"
import GenreBadges from "app/ui/genreBadges" import GenreBadges from "app/ui/genreBadges"
import { updateField, updateGenres } from "app/lib/update" import { updateField, updateGenres } from "app/lib/update"
import { Genre } from "@prisma/client"
export default function GenrePickerInputCell(props: CellContext<any, any>) { export default function GenrePickerInputCell(props: CellContext<any, any>) {
@ -24,25 +23,23 @@ export default function GenrePickerInputCell(props: CellContext<any, any>) {
const genres = props.table.options.meta.genres const genres = props.table.options.meta.genres
const [isActive, setIsActive] = useState(false) const [isActive, setIsActive] = useState(false)
async function onSubmit({ genres }: { genres: number[] }, event: Event) { async function onSubmit({ genres }: { genres: number[] }) {
event.preventDefault()
const genresArray = genres.map((e) => { return { id: e } }) const genresArray = genres.map((e) => { return { id: e } })
console.log(`genres: ${genres}, genresArray: ${JSON.stringify(genresArray)}`) toast({
// toast({ title: "You submitted the following values:",
// title: "You submitted the following values:", description: (
// description: ( <pre className="mt-2 w-[340px] rounded-md bg-slate-950 p-4">
// <pre className="mt-2 w-[340px] rounded-md bg-slate-950 p-4"> <code className="text-white">{JSON.stringify(genresArray, null, 2)}</code>
// <code className="text-white">{JSON.stringify(genres)}</code> </pre>
// </pre> ),
// ), })
// }) const res = await updateGenres({
// const res = await updateGenres({ id,
// id, table,
// table, genres: genresArray,
// genres: genresArray, pathname
// pathname })
// }) setIsActive(false)
// setIsActive(false)
} }
function onErrors(errors) { function onErrors(errors) {
@ -57,7 +54,7 @@ export default function GenrePickerInputCell(props: CellContext<any, any>) {
console.log(JSON.stringify(errors)) console.log(JSON.stringify(errors))
} }
const formSchema = z.object({ const formSchema = z.object({
genres: z.array(z.coerce.number()) genres: z.array(z.number())
}) })
const form = useForm<z.infer<typeof formSchema>>({ const form = useForm<z.infer<typeof formSchema>>({
resolver: zodResolver(formSchema), resolver: zodResolver(formSchema),
@ -66,9 +63,9 @@ export default function GenrePickerInputCell(props: CellContext<any, any>) {
} }
}) })
return ( return (
<Form {...form}> <Form {...form}>
<form onSubmit={form.handleSubmit(onSubmit, onErrors)} id="editGenresForm"> <form onSubmit={form.handleSubmit(onSubmit, onErrors)} id="editGenresForm">
<Popover modal={true}> <Popover modal={true}>
<FormField <FormField
control={form.control} control={form.control}
@ -76,14 +73,14 @@ export default function GenrePickerInputCell(props: CellContext<any, any>) {
render={({ field }) => ( render={({ field }) => (
<FormItem className="flex flex-col"> <FormItem className="flex flex-col">
<PopoverTrigger> <PopoverTrigger>
{value.length > 0 ? <GenreBadges genres={value} /> : <p>Add genres</p> {value.length > 0 ? <GenreBadges genres={value} /> : <Button variant="ghost">Add genres</Button>
} }
</PopoverTrigger> </PopoverTrigger>
<PopoverContent align="start"> <PopoverContent align="start">
{genres.map((item: Genre) => ( {genres.map((item) => (
< FormField < FormField
key={item.id} key={item.id}
control={form.control} control={form.control}
@ -100,9 +97,7 @@ export default function GenrePickerInputCell(props: CellContext<any, any>) {
onCheckedChange={(checked) => { onCheckedChange={(checked) => {
console.log(field.value) console.log(field.value)
return checked return checked
? field.onChange( ? field.onChange([...field.value, item.id])
[...field.value, item.id]
)
: field.onChange( : field.onChange(
field.value?.filter( field.value?.filter(
(value) => value !== item.id (value) => value !== item.id
@ -127,9 +122,9 @@ export default function GenrePickerInputCell(props: CellContext<any, any>) {
)} )}
/> />
</Popover> </Popover>
</form> </form>
</Form> </Form>
) )
} }