Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/danielr18/connected-next-router
A Redux binding for Next.js Router compatible with Next.js.
https://github.com/danielr18/connected-next-router
Last synced: 3 days ago
JSON representation
A Redux binding for Next.js Router compatible with Next.js.
- Host: GitHub
- URL: https://github.com/danielr18/connected-next-router
- Owner: danielr18
- License: mit
- Created: 2018-07-09T04:30:18.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2025-01-11T07:14:56.000Z (22 days ago)
- Last Synced: 2025-01-23T02:06:39.273Z (10 days ago)
- Language: TypeScript
- Homepage:
- Size: 1.55 MB
- Stars: 110
- Watchers: 6
- Forks: 29
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[![Coverage Status](https://coveralls.io/repos/github/danielr18/connected-next-router/badge.svg?branch=test-github-action)](https://coveralls.io/github/danielr18/connected-next-router?branch=test-github-action)
> v5.0.0 requires Next.js 10 or newer, React Redux 7.1.0 or newer, and React 16.8.0 or newer. If you are using Next.js 9, check out [v3 branch](https://github.com/danielr18/connected-next-router/tree/v3). If you are using Next.js 7-8, check out [v0 branch](https://github.com/danielr18/connected-next-router/tree/v0).
# Connected Next Router
A Redux binding for Next.js Router compatible with Next.js.
## Main features
:sparkles: Keep Router state in sync with your Redux store.
:tada: Dispatch Router methods (`push`, `replace`, `go`, `goBack`, `goForward`, `prefetch`) using Redux actions.
:clock9: Support time traveling in Redux DevTools.
:gem: Ease migration to [next.js](https://github.com/zeit/next.js) framework from codebases using [connected-react-router](https://github.com/supasate/connected-react-router) or [react-router-redux](https://github.com/ReactTraining/react-router/tree/master/packages/react-router-redux) (see [migration guide](/MIGRATION.md)).
## Installation
Using [npm](https://www.npmjs.com/):
$ npm install --save connected-next-router
Or [yarn](https://yarnpkg.com/):
$ yarn add connected-next-router
## Usage
### Step 1
- Add `routerReducer` to your root reducer.
- Use `createRouterMiddleware` if you want to dispatch Router actions (ex. to change URL with `push('/home')`).
- Use `initialRouterState(url)` to populate router state in the server side.```js
// store/configure-store.js
import { createStore, applyMiddleware, combineReducers } from 'redux'
import { createRouterMiddleware, initialRouterState, routerReducer } from 'connected-next-router'
import { HYDRATE, createWrapper } from 'next-redux-wrapper'
import Router from 'next/router'const rootReducer = combineReducers({
// Add other reducers
router: routerReducer
});const routerMiddleware = createRouterMiddleware();
// Using next-redux-wrapper's initStore
const reducer = (state, action) => {
if (action.type === HYDRATE) {
const nextState = {
...state, // use previous state
...action.payload, // apply delta from hydration
}
if (typeof window !== 'undefined' && state?.router) {
// preserve router value on client side navigation
nextState.router = state.router
}
return nextState
} else {
return rootReducer(state, action)
}
}export const initStore = (context) => {
const routerMiddleware = createRouterMiddleware()
const { asPath } = context.ctx || Router.router || {}
let initialState
if (asPath) {
initialState = {
router: initialRouterState(asPath)
}
}
return createStore(reducer, initialState, applyMiddleware(routerMiddleware))
}export const wrapper = createWrapper(initStore)
```### Step 2
- Place `ConnectedRouter` as children of `react-redux`'s `Provider`.
```js
// pages/_app.js
import App from 'next/app'
import { ConnectedRouter } from 'connected-next-router'
import { wrapper } from '../store/configure-store'class ExampleApp extends App {
render() {
const { Component, pageProps } = this.props
return (
)
}
}// wrapper.withRedux wraps the App with react-redux's Provider
export default wrapper.withRedux(ExampleApp)
```## Examples
- [examples/basic](/examples/basic) - basic reference implementation
- [examples/typescript](/examples/typescript) - typescript reference implementation
- [without next-redux-wrapper](https://github.com/danielr18/connected-next-router/issues/49)## Acknowledgements
[Acknowledge](/ACKNOWLEDGE.md)
## License
[MIT License](/LICENSE)