2018-02-02 19:09:23 +01:00
# :cookie: react-cookie-consent :cookie:
2018-02-01 16:54:00 +01:00
A small, simple and customizable cookie consent bar for use in React applications.
2018-02-02 19:09:23 +01:00
2018-05-01 15:32:00 +02:00
[![NPM ](https://nodei.co/npm/react-cookie-consent.png )](https://npmjs.org/package/react-cookie-consent)
2018-05-26 20:51:39 +02:00
Demo: https://mastermindzh.github.io/react-cookie-consent/
Example branch: https://github.com/Mastermindzh/react-cookie-consent/tree/example
2018-05-01 15:32:00 +02:00
## Default look
2018-02-02 19:15:40 +01:00
![default look ](https://raw.githubusercontent.com/Mastermindzh/react-cookie-consent/master/images/default.png )
2018-02-02 19:09:23 +01:00
2018-05-01 13:21:47 +02:00
2018-02-02 19:09:23 +01:00
## Installation
```
npm install react-cookie-consent
```
or use yarn:
```
yarn add react-cookie-consent
```
## Using it
You can import the cookie bar like this:
```js
import CookieConsent from "react-cookie-consent";
```
If you want to set/remove cookies yourself you can optionally import Cookie (straight from js-cookie) like this:
```js
2018-05-22 10:02:00 +02:00
import CookieConsent, { Cookies } from "react-cookie-consent";
2018-02-02 19:09:23 +01:00
```
Then you can use the component anywhere in your React app like so:
```js
< CookieConsent >
This website uses cookies to enhance the user experience.
< / CookieConsent >
```
You can optionally set some props like this (next chapter will show all props):
```js
< CookieConsent
location="bottom"
buttonText="Sure man!!"
cookieName="myAwesomeCookieName2"
style={{ background: "#2B373B" }}
buttonStyle={{ color: "#4e503b", fontSize: "13px" }}
>
This website uses cookies to enhance the user experience.{" "}
< span style = {{ fontSize: " 10px " } } >
This bit of text is smaller :O
< / span >
< / CookieConsent >
```
2018-05-22 10:07:41 +02:00
One of the props (onAccept) is a function, this function will be called after the user has clicked the accept button. You can provide a function like so:
2018-02-02 19:09:23 +01:00
```js
< CookieConsent
onAccept={() => {alert("yay!")}}
>
< / CookieConsent >
```
## Props
| Prop | Type | Default value | Description |
|---------------|:--------------------------------:|---------------|-------------------------------------------------------------------------------------------------------|
2018-05-31 19:51:48 +02:00
| location | string, either "top" or "bottom" | "bottom" | Syntactic sugar to easily enable you to place the bar at the top or the bottom of the browser window. |
| children | string or React component | | Content to appear inside the bar |
2018-05-30 14:06:00 +02:00
| disableStyles | boolean | false | If enabled the component will have no default style. (you can still supply style through props) |
2018-05-31 19:51:48 +02:00
| buttonText | string or React component | "I understand" | Text to appear on the button |
| cookieName | string | "CookieConsent" | Name of the cookie used to track whether the user has agreed. |
| onAccept | function | `() => {}` | Function to be called after the accept button has been clicked. |
| style | object | [look at source][style] | React styling object for the bar. |
| buttonStyle | object | [look at source][buttonStyle] | React styling object for the button. |
| contentStyle | object | [look at source][contentStyle] | React styling object for the content. |
| debug | boolean | undefined | Cookie is removed to debug styling. |
2018-02-02 19:09:23 +01:00
2018-05-22 10:07:41 +02:00
## Styling it
2018-02-02 19:09:23 +01:00
2018-05-30 14:10:47 +02:00
You can provide styling for the bar, the button and the content. Note that the bar has a `display: flex` property as default and is parent to its children "content" and "button".
2018-05-30 14:06:00 +02:00
2018-05-31 19:51:48 +02:00
The styling behaves kind of responsive. The minimum content width has been chosen to be "300px" as a default value. If the button does not fit into the same line it is wrapped around into the next line.
2018-05-30 14:10:47 +02:00
You can style each component by using the `style` , `buttonStyle` and `contentStyle` prop. These will append / replace the default styles of the components.
2018-02-02 19:09:23 +01:00
You can use `disableStyles={true}` to disable any built-in styling.
### Examples
#### changing the bar background to red
```js
< CookieConsent
style={{ background: "red" }}
>
< / CookieConsent >
```
#### changing the button font-weight to bold
```js
< CookieConsent
buttonStyle={{ fontWeight: "bold" }}
>
< / CookieConsent >
```
#### rainbows!
2018-02-02 19:15:40 +01:00
![rainbows! ](https://github.com/Mastermindzh/react-cookie-consent/blob/master/images/rainbow.png?raw=true )
2018-02-02 19:09:23 +01:00
If you're crazy enough you can even make a rainbow colored bar:
```js
< CookieConsent
buttonText="OMG DOUBLE RAINBOW"
cookieName="myAwesomeCookieName2"
style={{ background: "linear-gradient(to right, orange , yellow, green, cyan, blue, violet)", textShadow: "2px 2px black" }}
buttonStyle={{background: "linear-gradient(to left, orange , yellow, green, cyan, blue, violet)", color:"white", fontWeight: "bolder", textShadow: "2px 2px black"}}
>
This website uses cookies to enhance the user experience.{" "}
< span style = {{ fontSize: " 10px " } } >
This bit of text is smaller :O
< / span >
< / CookieConsent >
```
2018-05-22 10:07:41 +02:00
## Debugging it
2018-05-22 10:02:00 +02:00
2018-05-31 19:51:48 +02:00
Because the cookie consent bar will be hidden once accepted, you will have to set the prop `debug={true}` to evaluate styling changes:
2018-05-22 10:02:00 +02:00
```js
< CookieConsent
2018-05-31 19:51:48 +02:00
debug={true}
2018-05-22 10:02:00 +02:00
>
< / CookieConsent >
2018-05-26 20:51:39 +02:00
```
2018-05-30 14:06:00 +02:00
2018-05-31 19:51:48 +02:00
**Note:** Dont forget to remove the `debug` -property for production.
2018-05-30 14:06:00 +02:00
[style]: https://github.com/Mastermindzh/react-cookie-consent/blob/master/src/index.js#L17-L28
2018-06-01 09:32:51 +02:00
[buttonStyle]: https://github.com/Mastermindzh/react-cookie-consent/blob/master/src/index.js#L29-L38
[contentStyle]: https://github.com/Mastermindzh/react-cookie-consent/blob/master/src/index.js#L39-L42