Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/platypusrex/next-universal-cookies

Cookie helpers/utils for Next.js applications
https://github.com/platypusrex/next-universal-cookies

cookiejs cookies nextjs

Last synced: about 1 month ago
JSON representation

Cookie helpers/utils for Next.js applications

Awesome Lists containing this project

README

        

# 🍪 next-universal-cookies 🍪

[![npm Package](https://img.shields.io/npm/v/next-universal-cookies.svg)](https://www.npmjs.org/package/next-universal-cookies)
[![License](https://img.shields.io/npm/l/next-universal-cookies.svg)](https://github.com/platypusrex/next-universal-cookies/blob/master/LICENSE)
[![Coverage Status](https://coveralls.io/repos/github/platypusrex/next-universal-cookies/badge.svg?branch=master)](https://coveralls.io/github/platypusrex/next-universal-cookies?branch=master)
![CI](https://github.com/platypusrex/next-universal-cookies/workflows/CI/badge.svg)

A proper collection of cookie helpers for use on both the client and server in Next.js applications

### Installation
npm
```shell script
npm install --save next-universal-cookies
```

or yarn
```shell script
yarn add next-universal-cookies
```

### Usage

#### Server

Any of the set of helpers can be utilized in `getServerSideProps`, `getInitialProps`, API routes.
For either `getServerSideProps` | `getInitialProps`, just pass in the context object as the first argument.
If using the helpers in next API routes, pass `req` and `res` as an object in the first parameter:

```typescript
import { parseCookies } from 'next-universal-cookies';

const cookies = parseCookies({ req, res })
```

```typescript
// Parsing
import { getCookieValue, parseCookies } from 'next-universal-cookies';

// Parse all cookies
const cookies = parseCookies(ctx);

// Parse and get single cookie value by name
const cookieValue = getCookieValue(ctx, 'cookie'); // returns string

// Parse and get multple cookie values by name
const { cookie, cookie2 } = getCookieValue(ctx, ['cookie', 'cookie2']); // returns object of values
```

```typescript
// Setting
import { setCookie } from 'next-universal-cookies';

// Set single cookie
setCookie(ctx, {
name: 'cookie',
value: 'cookie-value',
options: {
path: '/my-path',
sameSite: 'strict'
}
});

// or Set multiple cookies
setCookie(ctx, [
{
name: 'cookie',
value: 'cookie-value',
options: {
path: '/my-path',
sameSite: 'strict',
},
},
{
name: 'cookie-too',
value: 'cookie-value-too',
},
]);
```

```typescript
// Destroying
import { destroyCookie } from 'next-universal-cookies';

// Destory cookie with name 'cookie'
destroyCookie(ctx, 'cookie');
```

#### Client

The cookie helpers can also be utilized on the client. The function's input signature
is slightly altered when used client side. The `context` object is no longer required as
an argument.

```typescript
// Parsing
import { getCookieValue, parseCookies } from 'next-universal-cookies';

// Parse all cookies
const cookies = parseCookies();

// Parse and get single cookie value
const cookieValue = getCookieValue('cookie'); // returns string

// Parse and get multple cookie values by name
const { cookie, cookie2 } = getCookieValue(['cookie', 'cookie2']); // returns object of values
```

```typescript
// Setting
import { setCookie } from 'next-universal-cookies';

// Set single cookie
setCookie({
name: 'cookie',
value: 'cookie-value',
options: {
path: '/my-path',
sameSite: 'strict'
}
});

// or Set multiple cookies
setCookie([
{
name: 'cookie',
value: 'cookie-value',
options: {
path: '/my-path',
sameSite: 'strict',
},
},
{
name: 'cookie-too',
value: 'cookie-value-too',
},
]);
```

```typescript
// Destroying
import { destroyCookie } from 'next-universal-cookies';

// Destory cookie with name 'cookie'
destroyCookie('cookie');
```

### Contributors
This project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome!

### LICENSE
MIT