From 7ffbc2f41b95cb37bb32b2b3f13668595ba78ea8 Mon Sep 17 00:00:00 2001 From: Dylan Vann Date: Mon, 11 May 2020 01:07:28 -0400 Subject: [PATCH] Use Redux Toolkit instead of plain Redux Also removes unused utils. --- aiortc/package.json | 4 +-- aiortc/src/index.ts | 32 ++++++++++-------- aiortc/src/redux/reducers/index.ts | 21 ------------ app/lib/index.jsx | 52 +++++++++++++----------------- app/lib/redux/reducers/index.js | 23 ------------- app/lib/utils.js | 20 ------------ app/package.json | 4 +-- 7 files changed, 43 insertions(+), 113 deletions(-) delete mode 100644 aiortc/src/redux/reducers/index.ts delete mode 100644 app/lib/redux/reducers/index.js delete mode 100644 app/lib/utils.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..7c084fd37 100644 --- a/app/lib/index.jsx +++ b/app/lib/index.jsx @@ -3,47 +3,42 @@ 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'; import deviceInfo from './deviceInfo'; 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; @@ -52,9 +47,6 @@ RoomClient.init({ store }); domready(async () => { logger.debug('DOM ready'); - - await utils.initialize(); - run(); }); 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/lib/utils.js b/app/lib/utils.js deleted file mode 100644 index ebc220d46..000000000 --- a/app/lib/utils.js +++ /dev/null @@ -1,20 +0,0 @@ -let mediaQueryDetectorElem; - -export function initialize() -{ - // Media query detector stuff. - mediaQueryDetectorElem = - document.getElementById('mediasoup-demo-app-media-query-detector'); - - return Promise.resolve(); -} - -export function isDesktop() -{ - return Boolean(mediaQueryDetectorElem.offsetParent); -} - -export function isMobile() -{ - return !mediaQueryDetectorElem.offsetParent; -} 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" },