├── cubes.png ├── .github └── workflows │ └── npm-publish-workflow.yml ├── package.json ├── LICENSE ├── README.md ├── demo-bs4.html ├── demo-bs5.html ├── cookiealert.js └── cookiealert.css /cubes.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Wruczek/Bootstrap-Cookie-Alert/HEAD/cubes.png -------------------------------------------------------------------------------- /.github/workflows/npm-publish-workflow.yml: -------------------------------------------------------------------------------- 1 | on: push 2 | 3 | jobs: 4 | publish: 5 | runs-on: ubuntu-latest 6 | steps: 7 | - uses: actions/checkout@v1 8 | - uses: actions/setup-node@v1 9 | with: 10 | node-version: 10 11 | - run: npm install 12 | - run: npm test 13 | - uses: JS-DevTools/npm-publish@v1 14 | with: 15 | token: ${{ secrets.NPM_TOKEN }} 16 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "bootstrap-cookie-alert", 3 | "version": "1.2.2", 4 | "description": "A simple, good looking cookie alert built for Bootstrap 4. No dependencies required.", 5 | "repository": { 6 | "type": "git", 7 | "url": "https://github.com/Wruczek/Bootstrap-Cookie-Alert.git" 8 | }, 9 | "keywords": [ 10 | "bootstrap", 11 | "bootstrap4", 12 | "bootstrap-4", 13 | "cookie-alert" 14 | ], 15 | "style": "cookiealert.css", 16 | "module": "cookiealert.js", 17 | "author": "Wruczek ", 18 | "license": "MIT", 19 | "bugs": { 20 | "url": "https://github.com/Wruczek/Bootstrap-Cookie-Alert/issues" 21 | }, 22 | "homepage": "https://github.com/Wruczek/Bootstrap-Cookie-Alert#readme" 23 | } 24 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2017 Wruczek 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Bootstrap-Cookie-Alert 2 | A simple cookie alert for Bootstrap 5 and 4. No dependencies required.
3 | 4 | [**Demo with Bootstrap 5**](https://wruczek.github.io/Bootstrap-Cookie-Alert/demo-bs5) 5 | • 6 | [**Demo with Bootstrap 4**](https://wruczek.github.io/Bootstrap-Cookie-Alert/demo-bs4) 7 | 8 | I unfortunately don't remember the source of the cubes pattern :( 9 | If someone know, please email me or create an issue. I would love to credit the author. 10 | 11 | ## npm package 12 | `npm i bootstrap-cookie-alert` 13 | 14 | ## How to use 15 | #### 1. In the `head` of your document, include `cookiealert.css` **after Bootstrap**. 16 | ```html 17 | 18 | ``` 19 | 20 | #### 2. Add the html markup: 21 | ```html 22 | 23 | 30 | 31 | ``` 32 | 33 | #### 3. Include the JavaScript after the html markup 34 | ```html 35 | 36 | ``` 37 | 38 | ### Take a look at [`demo-bs5.html`](https://github.com/Wruczek/Bootstrap-Cookie-Alert/blob/gh-pages/demo-bs5.html) for a working example 39 | 40 | 41 | ### Accept event 42 | If you need to, you can listen for the `cookieAlertAccept` event to get notified when the user accepts the cookies. 43 | 44 | ```js 45 | window.addEventListener("cookieAlertAccept", function() { 46 | alert("cookies accepted") 47 | }) 48 | ``` 49 | -------------------------------------------------------------------------------- /demo-bs4.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | Bootstrap 4.6.2 cookie alert 9 | 10 | 11 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |
21 | 22 |
23 |
24 |
25 |
26 |
27 | 28 |
29 | 30 | 31 | 38 | 39 | 40 | 41 | 42 | 43 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | -------------------------------------------------------------------------------- /demo-bs5.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | Bootstrap 5.3.0 cookie alert 9 | 10 | 11 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |
21 | 22 |
23 |
24 |
25 |
26 |
27 | 28 |
29 | 30 | 31 | 38 | 39 | 40 | 41 | 42 | 43 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | -------------------------------------------------------------------------------- /cookiealert.js: -------------------------------------------------------------------------------- 1 | /* 2 | * Bootstrap Cookie Alert by Wruczek 3 | * https://github.com/Wruczek/Bootstrap-Cookie-Alert 4 | * Released under MIT license 5 | */ 6 | (function () { 7 | "use strict"; 8 | 9 | var cookieAlert = document.querySelector(".cookiealert"); 10 | var acceptCookies = document.querySelector(".acceptcookies"); 11 | 12 | if (!cookieAlert) { 13 | return; 14 | } 15 | 16 | cookieAlert.offsetHeight; // Force browser to trigger reflow (https://stackoverflow.com/a/39451131) 17 | 18 | // Show the alert if we cant find the "acceptCookies" cookie 19 | if (!getCookie("acceptCookies")) { 20 | cookieAlert.classList.add("show"); 21 | } 22 | 23 | // When clicking on the agree button, create a 1 year 24 | // cookie to remember user's choice and close the banner 25 | acceptCookies.addEventListener("click", function () { 26 | setCookie("acceptCookies", true, 365); 27 | cookieAlert.classList.remove("show"); 28 | 29 | // dispatch the accept event 30 | window.dispatchEvent(new Event("cookieAlertAccept")) 31 | }); 32 | 33 | // Cookie functions from w3schools 34 | function setCookie(cname, cvalue, exdays) { 35 | var d = new Date(); 36 | d.setTime(d.getTime() + (exdays * 24 * 60 * 60 * 1000)); 37 | var expires = "expires=" + d.toUTCString(); 38 | document.cookie = cname + "=" + cvalue + ";" + expires + ";path=/"; 39 | } 40 | 41 | function getCookie(cname) { 42 | var name = cname + "="; 43 | var decodedCookie = decodeURIComponent(document.cookie); 44 | var ca = decodedCookie.split(';'); 45 | for (var i = 0; i < ca.length; i++) { 46 | var c = ca[i]; 47 | while (c.charAt(0) === ' ') { 48 | c = c.substring(1); 49 | } 50 | if (c.indexOf(name) === 0) { 51 | return c.substring(name.length, c.length); 52 | } 53 | } 54 | return ""; 55 | } 56 | })(); 57 | -------------------------------------------------------------------------------- /cookiealert.css: -------------------------------------------------------------------------------- 1 | /* 2 | * Bootstrap Cookie Alert by Wruczek 3 | * https://github.com/Wruczek/Bootstrap-Cookie-Alert 4 | * Released under MIT license 5 | */ 6 | .cookiealert { 7 | position: fixed; 8 | bottom: 0; 9 | left: 0; 10 | width: 100%; 11 | margin: 0 !important; 12 | padding: 0.75rem 1.25rem; 13 | z-index: 999; 14 | opacity: 0; 15 | visibility: hidden; 16 | border-radius: 0; 17 | transform: translateY(100%); 18 | transition: all 500ms ease-out; 19 | color: #ecf0f1; 20 | background: #212327 url(''); 21 | } 22 | 23 | .cookiealert.show { 24 | opacity: 1; 25 | visibility: visible; 26 | transform: translateY(0%); 27 | transition-delay: 1000ms; 28 | } 29 | 30 | .cookiealert a { 31 | text-decoration: underline 32 | } 33 | 34 | .cookiealert .acceptcookies { 35 | margin-left: 10px; 36 | vertical-align: baseline; 37 | } 38 | --------------------------------------------------------------------------------