chore: sync staging
This commit is contained in:
parent
c5ddd54a3e
commit
561b19cf66
610 changed files with 105285 additions and 1206 deletions
|
|
@ -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) => (
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue