Componentes Material-UI para react-lgpd-consent - UI pronta para usar
O pacote @react-lgpd-consent/mui fornece componentes visuais prontos para uso baseados em Material-UI para a biblioteca react-lgpd-consent.
npm install @react-lgpd-consent/mui @mui/material @mui/icons-material
# ou
pnpm add @react-lgpd-consent/mui @mui/material @mui/icons-material
Peer Dependencies:
@mui/material@^7.0.0 || ^6.0.0 || ^5.15.0@mui/icons-material@^7.0.0 || ^6.0.0 || ^5.15.0 (opcional)react@^18.2.0 || ^19.0.0, react-dom@^18.2.0 || ^19.0.0@react-lgpd-consent/mui/ui: apenas UI (ConsentProvider MUI + componentes). Ideal para bundles menores e sem re-export do core.@react-lgpd-consent/mui: compatibilidade total (re-exporta o core); use headless ou ConsentProviderHeadless daqui se precisar da lógica.@react-lgpd-consent/core: headless puro, recomendado para hooks/utils na sua própria UI.import {
ConsentProvider,
CookieBanner,
FloatingPreferencesButton
} from '@react-lgpd-consent/mui'
function App() {
return (
<ConsentProvider categories={{ enabledCategories: ['analytics', 'marketing'] }}>
<CookieBanner policyLinkUrl="/privacy-policy" />
<FloatingPreferencesButton />
{/* O PreferencesModal é injetado automaticamente! */}
<YourApp />
</ConsentProvider>
)
}
✨ Nota: O
ConsentProviderdeste pacote automaticamente renderiza oPreferencesModal. Você não precisa incluí-lo manualmente!
import { ConsentProvider, PreferencesModal } from '@react-lgpd-consent/mui'
function App() {
return (
<ConsentProvider
categories={{ enabledCategories: ['analytics'] }}
PreferencesModalComponent={(props) => (
<PreferencesModal {...props} hideBranding={true} />
)}
>
<YourApp />
</ConsentProvider>
)
}
Monitore eventos para auditoria:
import { ConsentProvider } from '@react-lgpd-consent/mui'
<ConsentProvider
onConsentInit={(state) => console.log('Inicializado:', state)}
onConsentChange={(current, prev) => console.log('Mudou:', current)}
onAuditLog={(entry) => {
fetch('/api/audit', { method: 'POST', body: JSON.stringify(entry) })
}}
>
import { createAnpdCategoriesConfig } from '@react-lgpd-consent/mui'
const categories = createAnpdCategoriesConfig({
include: ['analytics', 'marketing']
})
<ConsentProvider categories={categories}>
📖 Documentação completa: API.md | TROUBLESHOOTING.md
Se você quiser controle total sobre a UI:
import { ConsentProviderHeadless, useConsent } from '@react-lgpd-consent/mui'
function App() {
return (
<ConsentProviderHeadless categories={{ enabledCategories: ['analytics'] }}>
<CustomUI />
</ConsentProviderHeadless>
)
}
function CustomUI() {
const { acceptAll, rejectAll } = useConsent()
return (
<div>
<button onClick={acceptAll}>Aceitar</button>
<button onClick={rejectAll}>Rejeitar</button>
</div>
)
}
CookieBanner - Banner de consentimento (modal ou snackbar)PreferencesModal - Modal de preferências detalhadasFloatingPreferencesButton - Botão flutuante para reabrir preferênciasBranding - Componente de marca/logo customizávelNota: Este pacote re-exporta todo o @react-lgpd-consent/core, então você tem acesso a todos os hooks, contextos, utilitários e tipos.
<CookieBanner
blocking={true}
policyLinkUrl="/privacy"
position="bottom"
anchor="center"
offset={64}
SnackbarProps={{ autoHideDuration: null }}
/>
<FloatingPreferencesButton
position="bottom-right"
offset={24}
icon={<CustomIcon />}
/>
Use as props position, anchor e offset para evitar colisões com footers fixos, chat widgets e outros elementos flutuantes:
<ConsentProvider
categories={{ enabledCategories: ['analytics'] }}
cookieBannerProps={{
position: 'bottom',
anchor: 'center',
offset: 72 // ajuste conforme necessário
}}
floatingPreferencesButtonProps={{
position: 'bottom-right',
offset: 96
}}
/>
Para bloquear navegação até a decisão, use blockingMode="hard" no provider:
<ConsentProvider
categories={{ enabledCategories: ['analytics'] }}
blocking
blockingMode="hard"
blockingStrategy="provider"
/>
@react-lgpd-consent/core - Núcleo sem dependências de UIreact-lgpd-consent - Pacote agregador (core + mui)MIT © Luciano Édipo