chore: sync staging

This commit is contained in:
Esdras Renan 2025-11-10 01:57:45 -03:00
parent c5ddd54a3e
commit 561b19cf66
610 changed files with 105285 additions and 1206 deletions

View file

@ -2,27 +2,28 @@
import * as React from "react"
import {
LayoutDashboard,
LayoutTemplate,
LifeBuoy,
Ticket,
PlayCircle,
BarChart3,
TrendingUp,
PanelsTopLeft,
UserCog,
AlertTriangle,
Building,
Building2,
Waypoints,
Clock4,
Timer,
MonitorCog,
UserPlus,
ChevronDown,
ShieldCheck,
Users,
Layers3,
CalendarDays,
ChevronDown,
Clock4,
Gauge,
LayoutDashboard,
Layers3,
LayoutTemplate,
LifeBuoy,
MonitorCog,
PlayCircle,
ShieldAlert,
ShieldCheck,
Ticket,
Timer,
TrendingUp,
UserCog,
UserPlus,
Users,
Waypoints,
} from "lucide-react"
import { usePathname } from "next/navigation"
import Link from "next/link"
@ -77,11 +78,14 @@ const navigation: NavigationGroup[] = [
url: "/tickets",
icon: Ticket,
requiredRole: "staff",
children: [{ title: "Resolvidos", url: "/tickets/resolved", icon: ShieldCheck, requiredRole: "staff" }],
children: [
{ title: "Todos os tickets", url: "/tickets", requiredRole: "staff" },
{ title: "Resolvidos", url: "/tickets/resolved", icon: ShieldCheck, requiredRole: "staff" },
],
},
{ title: "Visualizações", url: "/views", icon: PanelsTopLeft, requiredRole: "staff" },
{ title: "Modo Play", url: "/play", icon: PlayCircle, requiredRole: "staff" },
{ title: "Agenda", url: "/agenda", icon: CalendarDays, requiredRole: "staff" },
{ title: "Dispositivos", url: "/admin/devices", icon: MonitorCog, requiredRole: "admin" },
],
},
{
@ -91,8 +95,8 @@ const navigation: NavigationGroup[] = [
{ title: "Painéis customizados", url: "/dashboards", icon: LayoutTemplate, requiredRole: "staff" },
{ title: "SLA & Produtividade", url: "/reports/sla", icon: TrendingUp, requiredRole: "staff" },
{ title: "Qualidade (CSAT)", url: "/reports/csat", icon: LifeBuoy, requiredRole: "staff" },
{ title: "Backlog", url: "/reports/backlog", icon: BarChart3, requiredRole: "staff" },
{ title: "Clientes atendidos", url: "/reports/company", icon: Building2, requiredRole: "staff" },
{ title: "Backlog", url: "/reports/backlog", icon: Gauge, requiredRole: "staff" },
{ title: "Clientes", url: "/reports/company", icon: Building2, requiredRole: "staff" },
{ title: "Categorias", url: "/reports/categories", icon: Layers3, requiredRole: "staff" },
{ title: "Horas", url: "/reports/hours", icon: Clock4, requiredRole: "staff" },
],
@ -102,26 +106,39 @@ const navigation: NavigationGroup[] = [
requiredRole: "admin",
items: [
{
title: "Administração",
title: "Cadastros",
url: "/admin",
icon: UserPlus,
requiredRole: "admin",
exact: true,
children: [
{ title: "Equipe", url: "/admin", icon: LayoutDashboard, requiredRole: "admin", exact: true },
{ title: "Empresas", url: "/admin/companies", icon: Building, requiredRole: "admin" },
{ title: "Usuários", url: "/admin/users", icon: Users, requiredRole: "admin" },
],
},
{ title: "Filas", url: "/admin/channels", icon: Waypoints, requiredRole: "admin" },
{ title: "Times & papéis", url: "/admin/teams", icon: UserCog, requiredRole: "admin", hidden: true },
{
title: "Empresas & clientes",
url: "/admin/companies",
icon: Building,
title: "Orquestração",
url: "/admin/channels",
icon: Layers3,
requiredRole: "admin",
children: [
{ title: "Filas", url: "/admin/channels", icon: Waypoints, requiredRole: "admin" },
{ title: "Times & papéis", url: "/admin/teams", icon: UserCog, requiredRole: "admin" },
],
},
{ title: "Usuários", url: "/admin/users", icon: Users, requiredRole: "admin" },
{ title: "Dispositivos", url: "/admin/devices", icon: MonitorCog, requiredRole: "admin" },
{ title: "SLAs", url: "/admin/slas", icon: Timer, requiredRole: "admin" },
{
title: "Integração & SLAs",
url: "/admin/devices",
icon: MonitorCog,
requiredRole: "admin",
children: [
{ title: "SLAs", url: "/admin/slas", icon: Timer, requiredRole: "admin" },
{ title: "Alertas", url: "/admin/alerts", icon: ShieldAlert, requiredRole: "admin" },
],
},
{ title: "Incidentes", url: "/incidentes", icon: AlertTriangle, requiredRole: "admin" },
],
},
// Removido grupo "Conta" (Configurações) para evitar redundância com o menu do usuário no rodapé
]
export function AppSidebar({ ...props }: React.ComponentProps<typeof Sidebar>) {
@ -245,32 +262,56 @@ export function AppSidebar({ ...props }: React.ComponentProps<typeof Sidebar>) {
const childItems = item.children.filter((child) => !child.hidden && canAccess(child.requiredRole))
const isExpanded = expanded.has(item.title)
const isChildActive = childItems.some((child) => isActive(child))
const parentActive = isActive(item) || isChildActive
const parentActive = item.title === "Tickets" ? isActive(item) || isChildActive : isChildActive
const isToggleOnly = item.title !== "Tickets"
return (
<React.Fragment key={item.title}>
<SidebarMenuItem>
<SidebarMenuButton asChild isActive={parentActive}>
<Link href={item.url} className={cn("gap-2", "relative pr-7") }>
{isToggleOnly ? (
<button
type="button"
className={cn(
"relative flex w-full cursor-pointer select-none items-center gap-2 rounded-lg border border-transparent px-2 py-1 text-left transition hover:bg-sidebar-accent/70",
isExpanded && "bg-sidebar-accent/60"
)}
onClick={() => toggleExpanded(item.title)}
>
{item.icon ? <item.icon className="size-4" /> : null}
<span className="flex-1">{item.title}</span>
<span className="flex-1 text-sm font-medium text-foreground">{item.title}</span>
<span
role="button"
aria-label={isExpanded ? "Recolher submenu" : "Expandir submenu"}
onClick={(event) => {
event.preventDefault()
event.stopPropagation()
toggleExpanded(item.title)
}}
aria-hidden="true"
className={cn(
"absolute right-1.5 top-1/2 inline-flex h-6 w-6 -translate-y-1/2 items-center justify-center rounded-md text-neutral-500 transition hover:bg-slate-200 hover:text-neutral-700",
"inline-flex h-6 w-6 items-center justify-center rounded-md text-neutral-500 transition",
isExpanded && "rotate-180"
)}
>
<ChevronDown className="size-3" />
</span>
</Link>
</SidebarMenuButton>
</button>
) : (
<SidebarMenuButton asChild isActive={parentActive}>
<Link href={item.url} className={cn("gap-2", "relative pr-7") }>
{item.icon ? <item.icon className="size-4" /> : null}
<span className="flex-1">{item.title}</span>
<span
role="button"
aria-label={isExpanded ? "Recolher submenu" : "Expandir submenu"}
onClick={(event) => {
event.preventDefault()
event.stopPropagation()
toggleExpanded(item.title)
}}
className={cn(
"absolute right-1.5 top-1/2 inline-flex h-6 w-6 -translate-y-1/2 items-center justify-center rounded-md text-neutral-500 transition hover:bg-slate-200 hover:text-neutral-700",
isExpanded && "rotate-180"
)}
>
<ChevronDown className="size-3" />
</span>
</Link>
</SidebarMenuButton>
)}
</SidebarMenuItem>
{isExpanded
? childItems.map((child) => (