update insights

This commit is contained in:
2025-11-25 16:00:08 -03:00
parent 0278fca9f2
commit 93d330c8df
11 changed files with 65 additions and 15 deletions

View File

@@ -71,7 +71,7 @@ export default function Route({ loaderData }: Route.ComponentProps) {
<SidebarInset className="relative flex flex-col flex-1 min-w-0"> <SidebarInset className="relative flex flex-col flex-1 min-w-0">
<header <header
className="bg-background/15 backdrop-blur-sm className="bg-background/15 backdrop-blur-sm
px-4 py-2 lg:py-4 sticky top-0 z-5" px-4 py-2 lg:py-4 sticky top-0 z-10"
> >
<div className="container mx-auto flex items-center max-w-7xl"> <div className="container mx-auto flex items-center max-w-7xl">
<SidebarTrigger className="md:hidden" /> <SidebarTrigger className="md:hidden" />

View File

@@ -27,12 +27,14 @@ export const columns: ColumnDef<Enrollment>[] = [
{ {
id: 'select', id: 'select',
header: DataTableColumnHeaderSelect, header: DataTableColumnHeaderSelect,
cell: DataTableColumnHeaderSelect cell: DataTableColumnHeaderSelect,
meta: { className: 'w-8' }
}, },
...columns_, ...columns_,
{ {
id: 'actions', id: 'action',
cell: ActionMenu cell: ActionMenu,
meta: { className: 'w-12' }
} }
] ]

View File

@@ -77,6 +77,7 @@ export default function Route({ loaderData: { data } }: Route.ComponentProps) {
{({ hits, page, hitsPerPage, totalHits }) => ( {({ hits, page, hitsPerPage, totalHits }) => (
<DataTable <DataTable
sort={[{ id: 'created_at', desc: true }]} sort={[{ id: 'created_at', desc: true }]}
columnPinning={{ left: ['select'], right: ['action'] }}
columns={columns} columns={columns}
data={hits as Enrollment[]} data={hits as Enrollment[]}
pageIndex={page - 1} pageIndex={page - 1}

View File

@@ -1,7 +1,6 @@
'use client' 'use client'
import { type ColumnDef } from '@tanstack/react-table' import { type ColumnDef } from '@tanstack/react-table'
import { EllipsisVerticalIcon } from 'lucide-react' import { EllipsisVerticalIcon } from 'lucide-react'
import { Button } from '@repo/ui/components/ui/button' import { Button } from '@repo/ui/components/ui/button'
@@ -29,7 +28,8 @@ export const columns: ColumnDef<Org>[] = [
{ {
id: 'select', id: 'select',
header: DataTableColumnHeaderSelect, header: DataTableColumnHeaderSelect,
cell: DataTableColumnSelect cell: DataTableColumnSelect,
meta: { className: 'w-8' }
}, },
{ {
header: 'Empresa', header: 'Empresa',
@@ -65,8 +65,9 @@ export const columns: ColumnDef<Org>[] = [
cell: DataTableColumnDatetime cell: DataTableColumnDatetime
}, },
{ {
id: 'actions', id: 'action',
cell: ActionMenu cell: ActionMenu,
meta: { className: 'w-12' }
} }
] ]

View File

@@ -48,6 +48,7 @@ export default function Route({ loaderData: { data } }: Route.ComponentProps) {
return ( return (
<DataTable <DataTable
sort={[{ id: 'created_at', desc: true }]} sort={[{ id: 'created_at', desc: true }]}
columnPinning={{ left: ['select'], right: ['action'] }}
columns={columns} columns={columns}
data={hits as Org[]} data={hits as Org[]}
pageIndex={page - 1} pageIndex={page - 1}

View File

@@ -1,8 +1,15 @@
'use client' 'use client'
import { type ColumnDef } from '@tanstack/react-table' import { type ColumnDef } from '@tanstack/react-table'
import { EllipsisVerticalIcon } from 'lucide-react'
import { Abbr } from '@repo/ui/components/abbr' import { Abbr } from '@repo/ui/components/abbr'
import { Button } from '@repo/ui/components/ui/button'
import {
DropdownMenu,
DropdownMenuContent,
DropdownMenuTrigger
} from '@repo/ui/components/ui/dropdown-menu'
import { Avatar, AvatarFallback } from '@repo/ui/components/ui/avatar' import { Avatar, AvatarFallback } from '@repo/ui/components/ui/avatar'
import { initials } from '@repo/ui/lib/utils' import { initials } from '@repo/ui/lib/utils'
import { import {
@@ -12,13 +19,16 @@ import {
} from '@repo/ui/components/data-table' } from '@repo/ui/components/data-table'
import { columns as columns_, type Order } from '@repo/ui/routes/orders/columns' import { columns as columns_, type Order } from '@repo/ui/routes/orders/columns'
import { CopyToClipboardItem } from '../_app.users._index/columns'
export type { Order } export type { Order }
export const columns: ColumnDef<Order>[] = [ export const columns: ColumnDef<Order>[] = [
{ {
id: 'select', id: 'select',
header: DataTableColumnHeaderSelect, header: DataTableColumnHeaderSelect,
cell: DataTableColumnSelect cell: DataTableColumnSelect,
meta: { className: 'w-8' }
}, },
{ {
header: 'Comprador', header: 'Comprador',
@@ -28,7 +38,7 @@ export const columns: ColumnDef<Order>[] = [
return ( return (
<div className="flex gap-2.5 items-center"> <div className="flex gap-2.5 items-center">
<Avatar className="size-10 hidden lg:block"> <Avatar className="size-10 hidden lg:block">
<AvatarFallback>{initials(name)}</AvatarFallback> <AvatarFallback className="border">{initials(name)}</AvatarFallback>
</Avatar> </Avatar>
<ul> <ul>
@@ -50,5 +60,32 @@ export const columns: ColumnDef<Order>[] = [
accessorFn: ({ cpf, cnpj }) => cpf ?? cnpj, accessorFn: ({ cpf, cnpj }) => cpf ?? cnpj,
cell: DataTableColumnCpfCnpj cell: DataTableColumnCpfCnpj
}, },
...columns_ ...columns_,
{
id: 'action',
cell: ActionMenu,
meta: { className: 'w-12' }
}
] ]
function ActionMenu({ row }: { row: any }) {
return (
<div className="flex justify-end items-center">
<DropdownMenu>
<DropdownMenuTrigger asChild>
<Button
variant="ghost"
className="data-[state=open]:bg-muted text-muted-foreground cursor-pointer"
size="icon-sm"
>
<EllipsisVerticalIcon />
<span className="sr-only">Abrir menu</span>
</Button>
</DropdownMenuTrigger>
<DropdownMenuContent align="end" className="w-36 *:cursor-pointer">
<CopyToClipboardItem text={row.id} />
</DropdownMenuContent>
</DropdownMenu>
</div>
)
}

View File

@@ -42,6 +42,7 @@ export default function Route({ loaderData: { data } }: Route.ComponentProps) {
return ( return (
<DataTable <DataTable
sort={[{ id: 'created_at', desc: true }]} sort={[{ id: 'created_at', desc: true }]}
columnPinning={{ left: ['select'], right: ['action'] }}
columns={columns} columns={columns}
data={hits as Order[]} data={hits as Order[]}
pageIndex={page - 1} pageIndex={page - 1}

View File

@@ -25,12 +25,14 @@ export const columns: ColumnDef<User>[] = [
{ {
id: 'select', id: 'select',
header: DataTableColumnHeaderSelect, header: DataTableColumnHeaderSelect,
cell: DataTableColumnSelect cell: DataTableColumnSelect,
meta: { className: 'w-8' }
}, },
...columns_, ...columns_,
{ {
id: 'actions', id: 'action',
cell: ActionMenu cell: ActionMenu,
meta: { className: 'w-12' }
} }
] ]

View File

@@ -52,6 +52,7 @@ export default function Route({ loaderData: { data } }) {
return ( return (
<DataTable <DataTable
sort={[{ id: 'created_at', desc: true }]} sort={[{ id: 'created_at', desc: true }]}
columnPinning={{ left: ['select'], right: ['action'] }}
columns={columns} columns={columns}
data={hits as User[]} data={hits as User[]}
pageIndex={page - 1} pageIndex={page - 1}

View File

@@ -244,7 +244,7 @@ export function DataTable<TData, TValue>({
isPinned === 'right' && 'right-0', isPinned === 'right' && 'right-0',
'p-2.5', 'p-2.5',
// Override the shadcn class // Override the shadcn class
'[&:has([role=checkbox])]:pr-2.5', '[&:has([role=checkbox])]:px-1.5',
// @ts-ignore // @ts-ignore
header.column.columnDef.meta?.className header.column.columnDef.meta?.className
)} )}
@@ -285,6 +285,8 @@ export function DataTable<TData, TValue>({
isPinned && isSelected && 'bg-muted', isPinned && isSelected && 'bg-muted',
isPinned === 'left' && 'left-0', isPinned === 'left' && 'left-0',
isPinned === 'right' && 'right-0', isPinned === 'right' && 'right-0',
// Override the shadcn class
'[&:has([role=checkbox])]:px-1.5',
'p-2.5', 'p-2.5',
// @ts-ignore // @ts-ignore
cell.column.columnDef.meta?.className cell.column.columnDef.meta?.className

View File

@@ -8,6 +8,8 @@
"module": "ES2022", "module": "ES2022",
"moduleResolution": "bundler", "moduleResolution": "bundler",
"jsx": "react-jsx", "jsx": "react-jsx",
"sourceMap": true,
"inlineSources": true,
"baseUrl": ".", "baseUrl": ".",
"paths": { "paths": {
"@/*": ["./src/*"] "@/*": ["./src/*"]