Jump24 - Laravel Developers that Click into Place. Never outsourced. Never offshored. Always exceptional.

Laravel Cookie Consent

Laravel Cookie Consent stats

Downloads
834
Stars
95
Open Issues
0
Forks
4

View on GitHub →

A GDPR-compliant cookie consent solution for Laravel applications with fully customizable cookie banners, granular consent control, and enterprise-grade compliance features.

Laravel Cookie Consent

A GDPR-compliant solution offering enterprise-grade compliance with fully customizable cookie banners for Laravel applications. Simplifies regulatory requirements while maintaining excellent user experience and complete customization capabilities.

Features

  • πŸ”₯ One-Click Implementation – Simple installation via Composer with auto-loaded assets
  • ⚑ Zero Performance Impact – Lightweight with lazy-loaded components
  • 🌍 RTL & i18n Support – Full right-to-left compatibility + multilingual translations
  • πŸŒ™ Dark Mode Support – Auto dark/light mode matching system preferences
  • πŸ›‘ Granular Consent Control – Category-level cookie management (necessary/analytics/marketing)
  • πŸ“¦ Complete Customization – Override every color, text, and layout via config
  • πŸ“± Responsive Design – Perfectly adapts to all devices (mobile/tablet/desktop)
  • 🧩 No Frontend Dependencies – No jQuery, Bootstrap, or Tailwind required β€” works everywhere effortlessly

Installation

To get started with Cookie Consent, follow these simple steps:

  1. Install the package via Composer:
composer require devrabiul/laravel-cookie-consent
  1. Publish the package resources by running: (Normal publish)
php artisan vendor:publish --provider="Devrabiul\CookieConsent\CookieConsentServiceProvider"

Basic Usage

Include these components in your Blade templates:

  1. Add styles in the <head> section:
{!! CookieConsent::styles() !!}
  1. Add scripts before closing </body>:
{!! CookieConsent::scripts() !!}

Complete Example

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Your Page</title>
{!! CookieConsent::styles() !!}
</head>
<body>
 
<!-- Your content -->
 
{!! CookieConsent::scripts() !!}
</body>
</html>

Advanced Configuration

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Your Page</title>
{!! CookieConsent::styles() !!}
</head>
<body>
 
<!-- Your content -->
 
{!! CookieConsent::scripts(options: [
'cookie_lifetime' => config('laravel-cookie-consent.cookie_lifetime', 7),
'reject_lifetime' => config('laravel-cookie-consent.reject_lifetime', 1),
'disable_page_interaction' => config('laravel-cookie-consent.disable_page_interaction', true),
'preferences_modal_enabled' => config('laravel-cookie-consent.preferences_modal_enabled', true),
'consent_modal_layout' => config('laravel-cookie-consent.consent_modal_layout', 'bar-inline'),
'flip_button' => config('laravel-cookie-consent.flip_button', true),
'theme' => config('laravel-cookie-consent.theme', 'default'),
'cookie_prefix' => config('laravel-cookie-consent.cookie_prefix', 'Laravel_App'),
'policy_links' => config('laravel-cookie-consent.policy_links', [
['text' => CookieConsent::translate('Privacy Policy'), 'link' => url('privacy-policy')],
['text' => CookieConsent::translate('Terms & Conditions'), 'link' => url('terms-and-conditions')],
]),
'cookie_categories' => config('laravel-cookie-consent.cookie_categories', [
'necessary' => [
'enabled' => true,
'locked' => true,
'js_action' => 'loadGoogleAnalytics',
'title' => CookieConsent::translate('Essential Cookies'),
'description' => CookieConsent::translate('These cookies are essential for the website to function properly.'),
],
'analytics' => [
'enabled' => env('COOKIE_CONSENT_ANALYTICS', false),
'locked' => false,
'title' => CookieConsent::translate('Analytics Cookies'),
'description' => CookieConsent::translate('These cookies help us understand how visitors interact with our website.'),
],
'marketing' => [
'enabled' => env('COOKIE_CONSENT_MARKETING', false),
'locked' => false,
'js_action' => 'loadFacebookPixel',
'title' => CookieConsent::translate('Marketing Cookies'),
'description' => CookieConsent::translate('These cookies are used for advertising and tracking purposes.'),
],
'preferences' => [
'enabled' => env('COOKIE_CONSENT_PREFERENCES', false),
'locked' => false,
'js_action' => 'loadPreferencesFunc',
'title' => CookieConsent::translate('Preferences Cookies'),
'description' => CookieConsent::translate('These cookies allow the website to remember user preferences.'),
],
]),
'cookie_title' => CookieConsent::translate('Cookie Disclaimer'),
'cookie_description' => CookieConsent::translate('This website uses cookies to enhance your browsing experience, analyze site traffic, and personalize content. By continuing to use this site, you consent to our use of cookies.'),
'cookie_modal_title' => CookieConsent::translate('Cookie Preferences'),
'cookie_modal_intro' => CookieConsent::translate('You can customize your cookie preferences below.'),
'cookie_accept_btn_text' => CookieConsent::translate('Accept All'),
'cookie_reject_btn_text' => CookieConsent::translate('Reject All'),
'cookie_preferences_btn_text' => CookieConsent::translate('Manage Preferences'),
'cookie_preferences_save_text' => CookieConsent::translate('Save Preferences'),
]) !!}
 
</body>
</html>

πŸŒ™ Enable Dark Mode

Add theme="dark" to your <body> tag to automatically enable dark mode.

<body theme="dark">

🌐 Enable RTL Mode

Add dir="rtl" to your <body> tag to enable right-to-left layout for RTL languages.

<body dir="rtl">

Layout Options

Config Status Control

COOKIE_CONSENT_ENABLED=true
COOKIE_CONSENT_PREFERENCES_ENABLED=true
 
COOKIE_CONSENT_ANALYTICS=true
COOKIE_CONSENT_MARKETING=true
COOKIE_CONSENT_PREFERENCES=true

Consent Modal Styles

  • box - Compact floating dialog
  • box-inline - Inline positioned box
  • box-wide - Expanded floating dialog
  • cloud - Modern floating design
  • cloud-inline - Compact cloud variant
  • bar - Top/bottom banner
  • bar-inline - Compact banner

Default: box-wide

Preferences Modal Styles

  • bar - Full-width layout
  • box - Centered popup

Default: bar

Configuration

Edit config/cookie-consent.php to modify:

  • Cookie lifetimes
  • Visual styles
  • Text content
  • Category settings

Example service loader (replace with your actual implementation)

function loadGoogleAnalytics() {
// Please put your GA script in loadGoogleAnalytics()
// You can define function name from - {!! CookieConsent::scripts() !!}
 
window.dataLayer = window.dataLayer || [];
 
function gtag() {
dataLayer.push(arguments);
}
 
gtag('js', new Date());
gtag('config', 'YOUR_GA_ID');
 
// Load the GA script
const script = document.createElement('script');
script.src = 'https://www.googletagmanager.com/gtag/js?id=YOUR_GA_ID';
script.async = true;
document.head.appendChild(script);
}
 
function loadFacebookPixel() {
// Please put your marketing script in loadFacebookPixel()
// You can define function name from - {!! CookieConsent::scripts() !!}
 
!function (f, b, e, v, n, t, s) {
if (f.fbq) return;
n = f.fbq = function () {
n.callMethod ?
n.callMethod.apply(n, arguments) : n.queue.push(arguments)
};
if (!f._fbq) f._fbq = n;
n.push = n;
n.loaded = !0;
n.version = '2.0';
n.queue = [];
t = b.createElement(e);
t.async = !0;
t.src = v;
s = b.getElementsByTagName(e)[0];
s.parentNode.insertBefore(t, s)
}(window, document, 'script',
'https://connect.facebook.net/en_US/fbevents.js');
fbq('init', 'YOUR_PIXEL_ID');
fbq('track', 'PageView');
}

🎯 Get Started Today!

Experience the magic of CookieConsent and enhance your Laravel applications with Cookie Consent.

πŸ”— GitHub: Laravel Cookie Consent
πŸ”— **Packagist: ** https://packagist.org/packages/devrabiul/laravel-cookie-consent

Contributing

We welcome contributions to CookieConsent! If you would like to contribute, please fork the repository and submit a pull request. For any issues or feature requests, please open an issue on GitHub.

Please:

  1. Fork the repository
  2. Create your feature branch
  3. Submit a pull request

License

This package is open-sourced software licensed under the MIT license.

Contact

For support or inquiries, please reach out to us at Send Mail.

devrabiul photo

I am a passionate Software Engineer creating high-quality, error-free websites. I specialize in clean code, performance, security, and user-friendly experiences

Cube

Laravel Newsletter

Join 40k+ other developers and never miss out on new tips, tutorials, and more.


Devrabiul Laravel Cookie Consent Related Articles

Laravel Cookie Consent image

Laravel Cookie Consent

Read article
Shift logo

Shift

Running an old Laravel version? Instant, automated Laravel upgrades and code modernization to keep your applications fresh.

Shift
Kirschbaum logo

Kirschbaum

Providing innovation and stability to ensure your web application succeeds.

Kirschbaum
Harpoon: Next generation time tracking and invoicing logo

Harpoon: Next generation time tracking and invoicing

The next generation time-tracking and billing software that helps your agency plan and forecast a profitable future.

Harpoon: Next generation time tracking and invoicing
Tinkerwell logo

Tinkerwell

The must-have code runner for Laravel developers. Tinker with AI, autocompletion and instant feedback on local and production environments.

Tinkerwell
SaaSykit: Laravel SaaS Starter Kit logo

SaaSykit: Laravel SaaS Starter Kit

SaaSykit is a Multi-tenant Laravel SaaS Starter Kit that comes with all features required to run a modern SaaS. Payments, Beautiful Checkout, Admin Panel, User dashboard, Auth, Ready Components, Stats, Blog, Docs and more.

SaaSykit: Laravel SaaS Starter Kit
Acquaint Softtech logo

Acquaint Softtech

Acquaint Softtech offers AI-ready Laravel developers who onboard in 48 hours at $3000/Month with no lengthy sales process and a 100 percent money-back guarantee.

Acquaint Softtech