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.0import {
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>
)
}
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"
SnackbarProps={{ anchorOrigin: { vertical: 'top', horizontal: 'center' } }}
/>
<FloatingPreferencesButton
position="bottom-right"
offset={24}
icon={<CustomIcon />}
/>
@react-lgpd-consent/core - Núcleo sem dependências de UIreact-lgpd-consent - Pacote agregador (core + mui)MIT © Luciano Édipo