update insights
This commit is contained in:
@@ -71,7 +71,7 @@ export default function Route({ loaderData }: Route.ComponentProps) {
|
||||
<SidebarInset className="relative flex flex-col flex-1 min-w-0">
|
||||
<header
|
||||
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">
|
||||
<SidebarTrigger className="md:hidden" />
|
||||
|
||||
@@ -27,12 +27,14 @@ export const columns: ColumnDef<Enrollment>[] = [
|
||||
{
|
||||
id: 'select',
|
||||
header: DataTableColumnHeaderSelect,
|
||||
cell: DataTableColumnHeaderSelect
|
||||
cell: DataTableColumnHeaderSelect,
|
||||
meta: { className: 'w-8' }
|
||||
},
|
||||
...columns_,
|
||||
{
|
||||
id: 'actions',
|
||||
cell: ActionMenu
|
||||
id: 'action',
|
||||
cell: ActionMenu,
|
||||
meta: { className: 'w-12' }
|
||||
}
|
||||
]
|
||||
|
||||
|
||||
@@ -77,6 +77,7 @@ export default function Route({ loaderData: { data } }: Route.ComponentProps) {
|
||||
{({ hits, page, hitsPerPage, totalHits }) => (
|
||||
<DataTable
|
||||
sort={[{ id: 'created_at', desc: true }]}
|
||||
columnPinning={{ left: ['select'], right: ['action'] }}
|
||||
columns={columns}
|
||||
data={hits as Enrollment[]}
|
||||
pageIndex={page - 1}
|
||||
|
||||
@@ -1,7 +1,6 @@
|
||||
'use client'
|
||||
|
||||
import { type ColumnDef } from '@tanstack/react-table'
|
||||
|
||||
import { EllipsisVerticalIcon } from 'lucide-react'
|
||||
|
||||
import { Button } from '@repo/ui/components/ui/button'
|
||||
@@ -29,7 +28,8 @@ export const columns: ColumnDef<Org>[] = [
|
||||
{
|
||||
id: 'select',
|
||||
header: DataTableColumnHeaderSelect,
|
||||
cell: DataTableColumnSelect
|
||||
cell: DataTableColumnSelect,
|
||||
meta: { className: 'w-8' }
|
||||
},
|
||||
{
|
||||
header: 'Empresa',
|
||||
@@ -65,8 +65,9 @@ export const columns: ColumnDef<Org>[] = [
|
||||
cell: DataTableColumnDatetime
|
||||
},
|
||||
{
|
||||
id: 'actions',
|
||||
cell: ActionMenu
|
||||
id: 'action',
|
||||
cell: ActionMenu,
|
||||
meta: { className: 'w-12' }
|
||||
}
|
||||
]
|
||||
|
||||
|
||||
@@ -48,6 +48,7 @@ export default function Route({ loaderData: { data } }: Route.ComponentProps) {
|
||||
return (
|
||||
<DataTable
|
||||
sort={[{ id: 'created_at', desc: true }]}
|
||||
columnPinning={{ left: ['select'], right: ['action'] }}
|
||||
columns={columns}
|
||||
data={hits as Org[]}
|
||||
pageIndex={page - 1}
|
||||
|
||||
@@ -1,8 +1,15 @@
|
||||
'use client'
|
||||
|
||||
import { type ColumnDef } from '@tanstack/react-table'
|
||||
import { EllipsisVerticalIcon } from 'lucide-react'
|
||||
|
||||
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 { initials } from '@repo/ui/lib/utils'
|
||||
import {
|
||||
@@ -12,13 +19,16 @@ import {
|
||||
} from '@repo/ui/components/data-table'
|
||||
import { columns as columns_, type Order } from '@repo/ui/routes/orders/columns'
|
||||
|
||||
import { CopyToClipboardItem } from '../_app.users._index/columns'
|
||||
|
||||
export type { Order }
|
||||
|
||||
export const columns: ColumnDef<Order>[] = [
|
||||
{
|
||||
id: 'select',
|
||||
header: DataTableColumnHeaderSelect,
|
||||
cell: DataTableColumnSelect
|
||||
cell: DataTableColumnSelect,
|
||||
meta: { className: 'w-8' }
|
||||
},
|
||||
{
|
||||
header: 'Comprador',
|
||||
@@ -28,7 +38,7 @@ export const columns: ColumnDef<Order>[] = [
|
||||
return (
|
||||
<div className="flex gap-2.5 items-center">
|
||||
<Avatar className="size-10 hidden lg:block">
|
||||
<AvatarFallback>{initials(name)}</AvatarFallback>
|
||||
<AvatarFallback className="border">{initials(name)}</AvatarFallback>
|
||||
</Avatar>
|
||||
|
||||
<ul>
|
||||
@@ -50,5 +60,32 @@ export const columns: ColumnDef<Order>[] = [
|
||||
accessorFn: ({ cpf, cnpj }) => cpf ?? cnpj,
|
||||
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>
|
||||
)
|
||||
}
|
||||
|
||||
@@ -42,6 +42,7 @@ export default function Route({ loaderData: { data } }: Route.ComponentProps) {
|
||||
return (
|
||||
<DataTable
|
||||
sort={[{ id: 'created_at', desc: true }]}
|
||||
columnPinning={{ left: ['select'], right: ['action'] }}
|
||||
columns={columns}
|
||||
data={hits as Order[]}
|
||||
pageIndex={page - 1}
|
||||
|
||||
@@ -25,12 +25,14 @@ export const columns: ColumnDef<User>[] = [
|
||||
{
|
||||
id: 'select',
|
||||
header: DataTableColumnHeaderSelect,
|
||||
cell: DataTableColumnSelect
|
||||
cell: DataTableColumnSelect,
|
||||
meta: { className: 'w-8' }
|
||||
},
|
||||
...columns_,
|
||||
{
|
||||
id: 'actions',
|
||||
cell: ActionMenu
|
||||
id: 'action',
|
||||
cell: ActionMenu,
|
||||
meta: { className: 'w-12' }
|
||||
}
|
||||
]
|
||||
|
||||
|
||||
@@ -52,6 +52,7 @@ export default function Route({ loaderData: { data } }) {
|
||||
return (
|
||||
<DataTable
|
||||
sort={[{ id: 'created_at', desc: true }]}
|
||||
columnPinning={{ left: ['select'], right: ['action'] }}
|
||||
columns={columns}
|
||||
data={hits as User[]}
|
||||
pageIndex={page - 1}
|
||||
|
||||
@@ -244,7 +244,7 @@ export function DataTable<TData, TValue>({
|
||||
isPinned === 'right' && 'right-0',
|
||||
'p-2.5',
|
||||
// Override the shadcn class
|
||||
'[&:has([role=checkbox])]:pr-2.5',
|
||||
'[&:has([role=checkbox])]:px-1.5',
|
||||
// @ts-ignore
|
||||
header.column.columnDef.meta?.className
|
||||
)}
|
||||
@@ -285,6 +285,8 @@ export function DataTable<TData, TValue>({
|
||||
isPinned && isSelected && 'bg-muted',
|
||||
isPinned === 'left' && 'left-0',
|
||||
isPinned === 'right' && 'right-0',
|
||||
// Override the shadcn class
|
||||
'[&:has([role=checkbox])]:px-1.5',
|
||||
'p-2.5',
|
||||
// @ts-ignore
|
||||
cell.column.columnDef.meta?.className
|
||||
|
||||
@@ -8,6 +8,8 @@
|
||||
"module": "ES2022",
|
||||
"moduleResolution": "bundler",
|
||||
"jsx": "react-jsx",
|
||||
"sourceMap": true,
|
||||
"inlineSources": true,
|
||||
"baseUrl": ".",
|
||||
"paths": {
|
||||
"@/*": ["./src/*"]
|
||||
|
||||
Reference in New Issue
Block a user