// This file must be executed as early as possible to ensure the preloads are triggered ASAP import "./preload-route-chunks"; 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 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 { Toast } from "design-system"; import "./assets/styles/index.css"; import "./polyfills"; import GlobalStyles from "globalStyles"; // enable autofreeze only in development import { setAutoFreeze } from "immer"; import AppErrorBoundary from "./AppErrorBoundry"; import log from "loglevel"; import { getAppsmithConfigs } from "@appsmith/configs"; const shouldAutoFreeze = process.env.NODE_ENV === "development"; const { newRelic } = getAppsmithConfigs(); setAutoFreeze(shouldAutoFreeze); runSagaMiddleware(); appInitializer(); const { enableNewRelic } = newRelic; enableNewRelic && (async () => { try { await import( /* webpackChunkName: "otlpTelemetry" */ "./UITelemetry/auto-otel-web.js" ); } catch (e) { log.error("Error loading telemetry script", e); } })(); 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; }