From 0057876cb39f395d59989316994ecfc253759ecc Mon Sep 17 00:00:00 2001 From: Dylan Vann Date: Sat, 16 May 2020 13:52:43 -0400 Subject: [PATCH 1/2] Use Redux Toolkit instead of plain Redux --- aiortc/package.json | 4 +-- aiortc/src/index.ts | 32 ++++++++++++-------- aiortc/src/redux/reducers/index.ts | 21 ------------- app/lib/index.jsx | 48 ++++++++++++++---------------- app/lib/redux/reducers/index.js | 23 -------------- app/package.json | 4 +-- 6 files changed, 43 insertions(+), 89 deletions(-) delete mode 100644 aiortc/src/redux/reducers/index.ts delete mode 100644 app/lib/redux/reducers/index.js diff --git a/aiortc/package.json b/aiortc/package.json index f993dc237..2bf7b6a8b 100644 --- a/aiortc/package.json +++ b/aiortc/package.json @@ -21,13 +21,11 @@ "dev": "cross-env DEBUG=\"${DEBUG:='*'}\" PYTHON_LOG_TO_STDOUT=true ROOM_ID=devel node ./lib/index.js" }, "dependencies": { + "@reduxjs/toolkit": "^1.3.6", "debug": "^4.1.1", "fake-mediastreamtrack": "^1.1.3", "mediasoup-client-aiortc": "github:versatica/mediasoup-client-aiortc#v3", "protoo-client": "^4.0.3", - "redux": "^4.0.5", - "redux-logger": "^3.0.6", - "redux-thunk": "^2.3.0", "repl": "^0.1.3", "tsc-watch": "^4.1.0", "typescript": "^3.6.5", diff --git a/aiortc/src/index.ts b/aiortc/src/index.ts index e40b5f491..c6873efa6 100644 --- a/aiortc/src/index.ts +++ b/aiortc/src/index.ts @@ -1,22 +1,28 @@ import * as repl from 'repl'; -import { - applyMiddleware as applyReduxMiddleware, - createStore as createReduxStore -} from 'redux'; -import thunk from 'redux-thunk'; +import { configureStore } from '@reduxjs/toolkit'; import { Logger } from './Logger'; import { RoomClient } from './RoomClient'; -import reducers from './redux/reducers'; - -const reduxMiddlewares = [ thunk ]; +import room from './redux/reducers/room'; +import me from './redux/reducers/me'; +import producers from './redux/reducers/producers'; +import dataProducers from './redux/reducers/dataProducers'; +import peers from './redux/reducers/peers'; +import consumers from './redux/reducers/consumers'; +import dataConsumers from './redux/reducers/dataConsumers'; const logger = new Logger(); -const store = createReduxStore( - reducers, - undefined, - applyReduxMiddleware(...reduxMiddlewares) -); +const store = configureStore({ + reducer: { + room, + me, + producers, + dataProducers, + peers, + consumers, + dataConsumers + } +}); RoomClient.init({ store }); diff --git a/aiortc/src/redux/reducers/index.ts b/aiortc/src/redux/reducers/index.ts deleted file mode 100644 index ac16241d7..000000000 --- a/aiortc/src/redux/reducers/index.ts +++ /dev/null @@ -1,21 +0,0 @@ -import { combineReducers } from 'redux'; -import room from './room'; -import me from './me'; -import producers from './producers'; -import dataProducers from './dataProducers'; -import peers from './peers'; -import consumers from './consumers'; -import dataConsumers from './dataConsumers'; - -const reducers = combineReducers( - { - room, - me, - producers, - dataProducers, - peers, - consumers, - dataConsumers - }); - -export default reducers; diff --git a/app/lib/index.jsx b/app/lib/index.jsx index 4da07c162..9ffca1026 100644 --- a/app/lib/index.jsx +++ b/app/lib/index.jsx @@ -3,14 +3,9 @@ import UrlParse from 'url-parse'; import React from 'react'; import { render } from 'react-dom'; import { Provider } from 'react-redux'; -import { - applyMiddleware as applyReduxMiddleware, - createStore as createReduxStore -} from 'redux'; -import thunk from 'redux-thunk'; -// import { createLogger as createReduxLogger } from 'redux-logger'; import randomString from 'random-string'; import * as faceapi from 'face-api.js'; +import { configureStore } from '@reduxjs/toolkit'; import Logger from './Logger'; import * as utils from './utils'; import randomName from './randomName'; @@ -19,31 +14,32 @@ import RoomClient from './RoomClient'; import RoomContext from './RoomContext'; import * as cookiesManager from './cookiesManager'; import * as stateActions from './redux/stateActions'; -import reducers from './redux/reducers'; +import room from './redux/reducers/room'; +import me from './redux/reducers/me'; +import producers from './redux/reducers/producers'; +import dataProducers from './redux/reducers/dataProducers'; +import peers from './redux/reducers/peers'; +import consumers from './redux/reducers/consumers'; +import dataConsumers from './redux/reducers/dataConsumers'; +import notifications from './redux/reducers/notifications'; import Room from './components/Room'; const logger = new Logger(); -const reduxMiddlewares = [ thunk ]; - -// if (process.env.NODE_ENV === 'development') -// { -// const reduxLogger = createReduxLogger( -// { -// duration : true, -// timestamp : false, -// level : 'log', -// logErrors : true -// }); - -// reduxMiddlewares.push(reduxLogger); -// } let roomClient; -const store = createReduxStore( - reducers, - undefined, - applyReduxMiddleware(...reduxMiddlewares) -); + +const store = configureStore({ + reducer : { + room, + me, + producers, + dataProducers, + peers, + consumers, + dataConsumers, + notifications + } +}); window.STORE = store; diff --git a/app/lib/redux/reducers/index.js b/app/lib/redux/reducers/index.js deleted file mode 100644 index 7fcfbe73f..000000000 --- a/app/lib/redux/reducers/index.js +++ /dev/null @@ -1,23 +0,0 @@ -import { combineReducers } from 'redux'; -import room from './room'; -import me from './me'; -import producers from './producers'; -import dataProducers from './dataProducers'; -import peers from './peers'; -import consumers from './consumers'; -import dataConsumers from './dataConsumers'; -import notifications from './notifications'; - -const reducers = combineReducers( - { - room, - me, - producers, - dataProducers, - peers, - consumers, - dataConsumers, - notifications - }); - -export default reducers; diff --git a/app/package.json b/app/package.json index d9b2d42e6..5339f403c 100644 --- a/app/package.json +++ b/app/package.json @@ -12,6 +12,7 @@ }, "dependencies": { "@babel/runtime": "^7.8.4", + "@reduxjs/toolkit": "^1.3.6", "bowser": "^2.9.0", "classnames": "^2.2.6", "clipboard-copy": "^3.1.0", @@ -33,9 +34,6 @@ "react-spinner": "^0.2.7", "react-tooltip": "^3.11.1", "react-transition-group": "^4.3.0", - "redux": "^4.0.5", - "redux-logger": "^3.0.6", - "redux-thunk": "^2.3.0", "riek": "^1.1.0", "url-parse": "^1.4.7" }, From 025bcc64ebff4ca534820757a62df42d972aeafc Mon Sep 17 00:00:00 2001 From: Dylan Vann Date: Sat, 16 May 2020 14:27:52 -0400 Subject: [PATCH 2/2] disable serializableCheck --- aiortc/src/index.ts | 7 +++++-- app/lib/index.jsx | 7 +++++-- 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/aiortc/src/index.ts b/aiortc/src/index.ts index c6873efa6..83400bbb7 100644 --- a/aiortc/src/index.ts +++ b/aiortc/src/index.ts @@ -1,5 +1,5 @@ import * as repl from 'repl'; -import { configureStore } from '@reduxjs/toolkit'; +import { configureStore, getDefaultMiddleware } from '@reduxjs/toolkit'; import { Logger } from './Logger'; import { RoomClient } from './RoomClient'; import room from './redux/reducers/room'; @@ -21,7 +21,10 @@ const store = configureStore({ peers, consumers, dataConsumers - } + }, + middleware : getDefaultMiddleware({ + serializableCheck : false + }) }); RoomClient.init({ store }); diff --git a/app/lib/index.jsx b/app/lib/index.jsx index 9ffca1026..602fd7e93 100644 --- a/app/lib/index.jsx +++ b/app/lib/index.jsx @@ -5,7 +5,7 @@ import { render } from 'react-dom'; import { Provider } from 'react-redux'; import randomString from 'random-string'; import * as faceapi from 'face-api.js'; -import { configureStore } from '@reduxjs/toolkit'; +import { configureStore, getDefaultMiddleware } from '@reduxjs/toolkit'; import Logger from './Logger'; import * as utils from './utils'; import randomName from './randomName'; @@ -38,7 +38,10 @@ const store = configureStore({ consumers, dataConsumers, notifications - } + }, + middleware : getDefaultMiddleware({ + serializableCheck : false + }) }); window.STORE = store;