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">
|
<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" />
|
||||||
|
|||||||
@@ -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' }
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|||||||
@@ -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}
|
||||||
|
|||||||
@@ -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' }
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|||||||
@@ -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}
|
||||||
|
|||||||
@@ -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>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|||||||
@@ -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}
|
||||||
|
|||||||
@@ -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' }
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|||||||
@@ -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}
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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/*"]
|
||||||
|
|||||||
Reference in New Issue
Block a user