// frontend/src/components/layout/Sidebar.jsx // Primary navigation sidebar — 224px wide, fixed, full height. import { useState } from 'react' import { NavLink, useLocation } from 'react-router-dom' import { useAuth } from '@/hooks/useAuth' import logoDark from '@/assets/logos/bell_systems_horizontal_darkMode.png' // ─── SVG file icons (vite-plugin-svgr v4 — ?react query) ───────────────────── import IcoDevices from '@/assets/side-menu-icons/devices.svg?react' import IcoDeviceOverview from '@/assets/side-menu-icons/device-overview.svg?react' import IcoFleet from '@/assets/side-menu-icons/fleet.svg?react' import IcoBlackbox from '@/assets/side-menu-icons/blackbox.svg?react' import IcoMelodies from '@/assets/side-menu-icons/melodies.svg?react' import IcoMelodiesEditor from '@/assets/side-menu-icons/melodies-editor.svg?react' import IcoComposer from '@/assets/side-menu-icons/composer.svg?react' import IcoArchetypes from '@/assets/side-menu-icons/archetypes.svg?react' import IcoMelodySettings from '@/assets/side-menu-icons/melody-settings.svg?react' import IcoCommunications from '@/assets/side-menu-icons/communications.svg?react' import IcoWhatsapp from '@/assets/side-menu-icons/whatsapp.svg?react' import IcoSms from '@/assets/side-menu-icons/sms.svg?react' import IcoHelpdesk from '@/assets/side-menu-icons/helpdesk.svg?react' import IcoCommsLog from '@/assets/side-menu-icons/communications-log.svg?react' import IcoCustomers from '@/assets/side-menu-icons/customers.svg?react' import IcoCustomerOverview from '@/assets/side-menu-icons/customer-overview.svg?react' import IcoOrders from '@/assets/side-menu-icons/orders.svg?react' import IcoProducts from '@/assets/side-menu-icons/products.svg?react' import IcoCatalog from '@/assets/side-menu-icons/product-catalog.svg?react' import IcoSnManager from '@/assets/side-menu-icons/sn-manager.svg?react' import IcoManufacturing from '@/assets/side-menu-icons/manufacturing.svg?react' import IcoInventory from '@/assets/side-menu-icons/inventory.svg?react' import IcoProvisioning from '@/assets/side-menu-icons/provision.svg?react' import IcoFirmware from '@/assets/side-menu-icons/firmware.svg?react' import IcoApi from '@/assets/side-menu-icons/api.svg?react' // ─── Inline-only icons (no SVG file equivalent) ─────────────────────────────── const S = ({ children, ...p }) => ( ) // Wrapper to normalise imported SVG file components to 16×16 function SvgIcon({ Component }) { return (