import React from "react"; import "./wdyr"; import ReactDOM from "react-dom"; import { Provider } from "react-redux"; import "./index.css"; import { ThemeProvider } from "styled-components"; import { appInitializer } from "utils/AppUtils"; import { Slide } from "react-toastify"; import store, { runSagaMiddleware } from "./store"; import { LayersContext, Layers } from "constants/Layers"; import AppRouter from "@appsmith/AppRouter"; import * as Sentry from "@sentry/react"; import { getCurrentThemeDetails } from "selectors/themeSelectors"; import { connect } from "react-redux"; import type { AppState } from "@appsmith/reducers"; import { StyledToastContainer } from "design-system-old"; import "./assets/styles/index.css"; import "./polyfills"; import GlobalStyles from "globalStyles"; // enable autofreeze only in development import { setAutoFreeze } from "immer"; import AppErrorBoundary from "./AppErrorBoundry"; const shouldAutoFreeze = process.env.NODE_ENV === "development"; setAutoFreeze(shouldAutoFreeze); runSagaMiddleware(); appInitializer(); function App() { return ( ); } class ThemedApp extends React.Component<{ currentTheme: any; }> { render() { return ( ); } } const mapStateToProps = (state: AppState) => ({ currentTheme: getCurrentThemeDetails(state), }); const ThemedAppWithProps = connect(mapStateToProps)(ThemedApp); ReactDOM.render(, document.getElementById("root")); // expose store when run in Cypress if ((window as any).Cypress) { (window as any).store = store; }