You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Hydro/packages/ui-default/utils/loadReactRedux.ts

35 lines
1012 B
TypeScript

import React from 'react';
import { createRoot } from 'react-dom/client';
import type { Action, AnyAction, Reducer } from 'redux';
export default async function loadReactRedux<S, A extends Action = AnyAction>(storeReducer: Reducer<S, A>) {
const [{ Provider }, { createStore, applyMiddleware }, { default: reduxThunk }, { default: reduxPromise }] = await Promise.all([
import('react-redux'),
import('redux'),
import('redux-thunk'),
import('redux-promise-middleware'),
]);
const reduxMiddlewares = [];
reduxMiddlewares.push(reduxThunk);
reduxMiddlewares.push(reduxPromise);
if (process.env.NODE_ENV !== 'production') {
const { createLogger } = await import('redux-logger');
reduxMiddlewares.push(createLogger({
collapsed: true,
duration: true,
}));
}
const store = createStore(storeReducer, applyMiddleware(...reduxMiddlewares));
return {
React,
createRoot,
Provider,
store,
};
}
window.Hydro.utils.loadReactRedux = loadReactRedux;