create-catalyst-app-internal 0.0.3-canary.4 → 0.0.3-canary.40

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (35) hide show
  1. package/package.json +1 -1
  2. package/scripts/cli.cjs +108 -8
  3. package/templates/common/config/config.json +10 -1
  4. package/templates/common/src/js/containers/Home/Home.js +6 -1
  5. package/templates/common/webpackConfig.js +1 -0
  6. package/templates/mcp-root/mcp/context.md +674 -0
  7. package/templates/mcp-root/mcp/mcp.js +36 -0
  8. package/templates/none-js/package.json +9 -3
  9. package/templates/none-ts/client/index.js +23 -0
  10. package/templates/none-ts/package.json +40 -0
  11. package/templates/none-ts/src/js/containers/App/index.js +16 -0
  12. package/templates/none-ts/src/js/routes/utils.js +42 -0
  13. package/templates/none-ts/tsconfig.json +13 -0
  14. package/templates/none-ts/types.d.ts +4 -0
  15. package/templates/redux-js/package.json +9 -3
  16. package/templates/redux-ts/client/index.js +28 -0
  17. package/templates/redux-ts/package.json +43 -0
  18. package/templates/redux-ts/src/js/containers/App/actions.js +17 -0
  19. package/templates/redux-ts/src/js/containers/App/index.js +16 -0
  20. package/templates/redux-ts/src/js/containers/App/reducer.js +19 -0
  21. package/templates/redux-ts/src/js/routes/utils.js +42 -0
  22. package/templates/redux-ts/src/js/store/index.js +28 -0
  23. package/templates/redux-ts/tsconfig.json +13 -0
  24. package/templates/redux-ts/types.d.ts +4 -0
  25. package/templates/rtk-js/package.json +9 -3
  26. package/templates/rtk-ts/client/index.js +28 -0
  27. package/templates/rtk-ts/package.json +43 -0
  28. package/templates/rtk-ts/src/js/containers/App/index.js +16 -0
  29. package/templates/rtk-ts/src/js/containers/App/reducer.js +18 -0
  30. package/templates/rtk-ts/src/js/routes/utils.js +42 -0
  31. package/templates/rtk-ts/src/js/store/index.js +28 -0
  32. package/templates/rtk-ts/tsconfig.json +13 -0
  33. package/templates/rtk-ts/types.d.ts +4 -0
  34. package/templates/tailwind/postcss.config.js +5 -0
  35. package/templates/tailwind/src/static/css/base/index.scss +2 -0
@@ -7,7 +7,13 @@
7
7
  "serve": "catalyst serve",
8
8
  "lint": "eslint .",
9
9
  "devBuild": "catalyst devBuild",
10
- "devServe": "catalyst devServe"
10
+ "devServe": "catalyst devServe",
11
+ "buildApp": "catalyst buildApp",
12
+ "buildApp:ios": "catalyst buildApp:ios",
13
+ "buildApp:android": "catalyst buildApp:android",
14
+ "setupEmulator": "catalyst setupEmulator",
15
+ "setupEmulator:ios": "catalyst setupEmulator:ios",
16
+ "setupEmulator:android": "catalyst setupEmulator:android"
11
17
  },
12
18
  "_moduleAliases": {
13
19
  "@api": "api.js",
@@ -19,8 +25,8 @@
19
25
  },
20
26
  "dependencies": {
21
27
  "@loadable/component": "^5.16.3",
22
- "@tata1mg/router": "^0.0.1-beta.6",
23
- "catalyst-core-internal": "0.0.3-canary.0"
28
+ "@tata1mg/router": "0.0.1-beta.7",
29
+ "catalyst-core-internal": "0.0.3-canary.40"
24
30
  },
25
31
  "devDependencies": {
26
32
  "eslint": "^8.26.0",
@@ -0,0 +1,23 @@
1
+ import React from "react"
2
+ import "./styles"
3
+ import { hydrateRoot } from "react-dom/client"
4
+ import { loadableReady } from "@loadable/component"
5
+ import { RouterProvider } from "@tata1mg/router"
6
+ import clientRouter from "catalyst-core-internal/router/ClientRouter"
7
+
8
+ window.addEventListener("load", () => {
9
+ loadableReady(() => {
10
+ const { __ROUTER_INITIAL_DATA__: routerInitialData } = window
11
+
12
+ const router = clientRouter({ routerInitialState: routerInitialData })
13
+
14
+ const Application = (
15
+ <React.StrictMode>
16
+ <RouterProvider router={router} />
17
+ </React.StrictMode>
18
+ )
19
+
20
+ const container = document.getElementById("app")
21
+ hydrateRoot(container, Application)
22
+ })
23
+ })
@@ -0,0 +1,40 @@
1
+ {
2
+ "name": "create-catalyst-app-starter",
3
+ "version": "1.0.0",
4
+ "scripts": {
5
+ "start": "catalyst start",
6
+ "build": "npm run typecheck && catalyst build",
7
+ "serve": "catalyst serve",
8
+ "lint": "eslint .",
9
+ "devBuild": "catalyst devBuild",
10
+ "devServe": "catalyst devServe",
11
+ "buildApp": "catalyst buildApp",
12
+ "buildApp:ios": "catalyst buildApp:ios",
13
+ "buildApp:android": "catalyst buildApp:android",
14
+ "setupEmulator": "catalyst setupEmulator",
15
+ "setupEmulator:ios": "catalyst setupEmulator:ios",
16
+ "setupEmulator:android": "catalyst setupEmulator:android",
17
+ "typecheck": "tsc --noEmit"
18
+ },
19
+ "_moduleAliases": {
20
+ "@api": "api.js",
21
+ "@containers": "src/js/containers",
22
+ "@server": "server",
23
+ "@config": "config",
24
+ "@css": "src/static/css",
25
+ "@routes": "src/js/routes/"
26
+ },
27
+ "dependencies": {
28
+ "@loadable/component": "^5.16.3",
29
+ "@tata1mg/router": "0.0.1-beta.7",
30
+ "catalyst-core-internal": "0.0.3-canary.40"
31
+ },
32
+ "devDependencies": {
33
+ "eslint": "^8.26.0",
34
+ "typescript": "^5.8.3",
35
+ "@types/react": "^18.2.0",
36
+ "@types/react-dom": "^18.2.0",
37
+ "eslint-plugin-react": "^7.34.1",
38
+ "eslint-plugin-react-hooks": "^4.6.0"
39
+ }
40
+ }
@@ -0,0 +1,16 @@
1
+ import React from "react"
2
+ import { Outlet } from "@tata1mg/router"
3
+
4
+ const App = () => {
5
+ return (
6
+ <>
7
+ <Outlet />
8
+ </>
9
+ )
10
+ }
11
+
12
+ App.serverSideFunction = () => {
13
+ return new Promise((resolve) => resolve())
14
+ }
15
+
16
+ export default App
@@ -0,0 +1,42 @@
1
+ import React from "react"
2
+ import { RouterDataProvider, MetaTag } from "@tata1mg/router"
3
+ import App from "@containers/App"
4
+ import routes from "./index.js"
5
+
6
+ /**
7
+ * Making the routes array compatible with the format accepted by createBrowserRouter
8
+ * API on the client side
9
+ * https://reactrouter.com/en/main/routers/create-browser-router
10
+ */
11
+
12
+ export const preparedRoutes = ({ routerInitialState }) => {
13
+ const getPreparedRoutes = (routes) => {
14
+ return routes.map((route, index) => {
15
+ const Component = route.component
16
+ const routeToRender = {
17
+ ...route,
18
+ element: <Component key={index} />,
19
+ }
20
+ if (route.children) {
21
+ routeToRender.children = getPreparedRoutes(route.children)
22
+ }
23
+ return routeToRender
24
+ })
25
+ }
26
+
27
+ return [
28
+ {
29
+ element: (
30
+ <RouterDataProvider config={{}} initialState={routerInitialState}>
31
+ <MetaTag />
32
+ <App />
33
+ </RouterDataProvider>
34
+ ),
35
+ children: getPreparedRoutes(routes),
36
+ },
37
+ ]
38
+ }
39
+
40
+ export const getRoutes = () => {
41
+ return routes
42
+ }
@@ -0,0 +1,13 @@
1
+ {
2
+ "compilerOptions": {
3
+ "target": "ES2016",
4
+ "module": "CommonJS",
5
+ "esModuleInterop": true,
6
+ "strict": true,
7
+ "skipLibCheck": true,
8
+ "jsx": "react",
9
+ "noEmit": true
10
+ },
11
+ "include": ["src", "types.d.ts"],
12
+ "exclude": ["node_modules"]
13
+ }
@@ -0,0 +1,4 @@
1
+ declare module "*.scss" {
2
+ const classes: { [key: string]: string }
3
+ export default classes
4
+ }
@@ -7,7 +7,13 @@
7
7
  "serve": "catalyst serve",
8
8
  "lint": "eslint .",
9
9
  "devBuild": "catalyst devBuild",
10
- "devServe": "catalyst devServe"
10
+ "devServe": "catalyst devServe",
11
+ "buildApp": "catalyst buildApp",
12
+ "buildApp:ios": "catalyst buildApp:ios",
13
+ "buildApp:android": "catalyst buildApp:android",
14
+ "setupEmulator": "catalyst setupEmulator",
15
+ "setupEmulator:ios": "catalyst setupEmulator:ios",
16
+ "setupEmulator:android": "catalyst setupEmulator:android"
11
17
  },
12
18
  "_moduleAliases": {
13
19
  "@api": "api.js",
@@ -20,8 +26,8 @@
20
26
  },
21
27
  "dependencies": {
22
28
  "@loadable/component": "^5.16.3",
23
- "@tata1mg/router": "^0.0.1-beta.6",
24
- "catalyst-core-internal": "0.0.3-canary.0",
29
+ "@tata1mg/router": "0.0.1-beta.7",
30
+ "catalyst-core-internal": "0.0.3-canary.40",
25
31
  "@reduxjs/toolkit": "1.9.3",
26
32
  "react-redux": "^8.1.3"
27
33
  },
@@ -0,0 +1,28 @@
1
+ import React from "react"
2
+ import "./styles"
3
+ import { hydrateRoot } from "react-dom/client"
4
+ import { loadableReady } from "@loadable/component"
5
+ import { Provider } from "react-redux"
6
+ import { RouterProvider } from "@tata1mg/router"
7
+ import clientRouter from "catalyst-core-internal/router/ClientRouter"
8
+ import configureStore from "@store"
9
+
10
+ window.addEventListener("load", () => {
11
+ loadableReady(() => {
12
+ const { __ROUTER_INITIAL_DATA__: routerInitialData, __INITIAL_STATE__ } = window
13
+ const store = configureStore(__INITIAL_STATE__ || {})
14
+
15
+ const router = clientRouter({ store, routerInitialState: routerInitialData })
16
+
17
+ const Application = (
18
+ <Provider store={store} serverState={__INITIAL_STATE__}>
19
+ <React.StrictMode>
20
+ <RouterProvider router={router} />
21
+ </React.StrictMode>
22
+ </Provider>
23
+ )
24
+
25
+ const container = document.getElementById("app")
26
+ hydrateRoot(container, Application)
27
+ })
28
+ })
@@ -0,0 +1,43 @@
1
+ {
2
+ "name": "create-catalyst-app-starter",
3
+ "version": "1.0.0",
4
+ "scripts": {
5
+ "start": "catalyst start",
6
+ "build": "npm run typecheck && catalyst build",
7
+ "serve": "catalyst serve",
8
+ "lint": "eslint .",
9
+ "devBuild": "catalyst devBuild",
10
+ "devServe": "catalyst devServe",
11
+ "buildApp": "catalyst buildApp",
12
+ "buildApp:ios": "catalyst buildApp:ios",
13
+ "buildApp:android": "catalyst buildApp:android",
14
+ "setupEmulator": "catalyst setupEmulator",
15
+ "setupEmulator:ios": "catalyst setupEmulator:ios",
16
+ "setupEmulator:android": "catalyst setupEmulator:android",
17
+ "typecheck": "tsc --noEmit"
18
+ },
19
+ "_moduleAliases": {
20
+ "@api": "api.js",
21
+ "@containers": "src/js/containers",
22
+ "@server": "server",
23
+ "@config": "config",
24
+ "@css": "src/static/css",
25
+ "@routes": "src/js/routes/",
26
+ "@store": "src/js/store/index.js"
27
+ },
28
+ "dependencies": {
29
+ "@loadable/component": "^5.16.3",
30
+ "@tata1mg/router": "0.0.1-beta.7",
31
+ "catalyst-core-internal": "0.0.3-canary.40",
32
+ "@reduxjs/toolkit": "1.9.3",
33
+ "react-redux": "^8.1.3"
34
+ },
35
+ "devDependencies": {
36
+ "eslint": "^8.26.0",
37
+ "typescript": "^5.8.3",
38
+ "@types/react": "^18.2.0",
39
+ "@types/react-dom": "^18.2.0",
40
+ "eslint-plugin-react": "^7.34.1",
41
+ "eslint-plugin-react-hooks": "^4.6.0"
42
+ }
43
+ }
@@ -0,0 +1,17 @@
1
+ const createActionTypes = (prefix, actionTypeList = []) => {
2
+ const actionTypesObject = {}
3
+ actionTypeList.forEach((item) => {
4
+ actionTypesObject[item] = `${prefix}/${item}`
5
+ })
6
+
7
+ return actionTypesObject
8
+ }
9
+
10
+ export default createActionTypes
11
+
12
+ export const ShellActions = createActionTypes("shellActions", ["REDUX_TEST"])
13
+ export const reduxTest = () => {
14
+ return {
15
+ type: ShellActions.REDUX_TEST,
16
+ }
17
+ }
@@ -0,0 +1,16 @@
1
+ import React from "react"
2
+ import { Outlet } from "@tata1mg/router"
3
+
4
+ const App = () => {
5
+ return (
6
+ <>
7
+ <Outlet />
8
+ </>
9
+ )
10
+ }
11
+
12
+ App.serverSideFunction = () => {
13
+ return new Promise((resolve) => resolve())
14
+ }
15
+
16
+ export default App
@@ -0,0 +1,19 @@
1
+ import { ShellActions } from "./actions"
2
+
3
+ export const defaultState = {
4
+ testActionDispatched: false,
5
+ }
6
+
7
+ export const shellReducer = (state = defaultState, action) => {
8
+ switch (action.type) {
9
+ case ShellActions.REDUX_TEST: {
10
+ return {
11
+ ...state,
12
+ testActionDispatched: true,
13
+ }
14
+ }
15
+
16
+ default:
17
+ return state
18
+ }
19
+ }
@@ -0,0 +1,42 @@
1
+ import React from "react"
2
+ import { RouterDataProvider, MetaTag } from "@tata1mg/router"
3
+ import App from "@containers/App"
4
+ import routes from "./index.js"
5
+
6
+ /**
7
+ * Making the routes array compatible with the format accepted by createBrowserRouter
8
+ * API on the client side
9
+ * https://reactrouter.com/en/main/routers/create-browser-router
10
+ */
11
+
12
+ export const preparedRoutes = ({ store, routerInitialState }) => {
13
+ const getPreparedRoutes = (routes) => {
14
+ return routes.map((route, index) => {
15
+ const Component = route.component
16
+ const routeToRender = {
17
+ ...route,
18
+ element: <Component key={index} />,
19
+ }
20
+ if (route.children) {
21
+ routeToRender.children = getPreparedRoutes(route.children)
22
+ }
23
+ return routeToRender
24
+ })
25
+ }
26
+
27
+ return [
28
+ {
29
+ element: (
30
+ <RouterDataProvider config={{}} initialState={routerInitialState} fetcherArgs={{ store }}>
31
+ <MetaTag />
32
+ <App />
33
+ </RouterDataProvider>
34
+ ),
35
+ children: getPreparedRoutes(routes),
36
+ },
37
+ ]
38
+ }
39
+
40
+ export const getRoutes = () => {
41
+ return routes
42
+ }
@@ -0,0 +1,28 @@
1
+ import { configureStore as createStore } from "@reduxjs/toolkit"
2
+ import { combineReducers } from "redux"
3
+ import { shellReducer } from "@containers/App/reducer.js"
4
+ import fetchInstance from "@api"
5
+
6
+ /**
7
+ * Function that initializes the store with the initialstate and adds middlewares that can be used during action dispatch
8
+ * @param {object} initialState Default state
9
+ * @param {object} request Request object that we recieve on server, this is only recieved when store is initialized on the server.
10
+ * @return {object} The store itself
11
+ */
12
+
13
+ const configureStore = (initialState) => {
14
+ const api = fetchInstance
15
+ const store = createStore({
16
+ reducer: combineReducers({ shellReducer }),
17
+ middleware: (getDefaultMiddleware) =>
18
+ getDefaultMiddleware({
19
+ thunk: {
20
+ extraArgument: { api },
21
+ },
22
+ }),
23
+ preloadedState: initialState,
24
+ })
25
+ return store
26
+ }
27
+
28
+ export default configureStore
@@ -0,0 +1,13 @@
1
+ {
2
+ "compilerOptions": {
3
+ "target": "ES2016",
4
+ "module": "CommonJS",
5
+ "esModuleInterop": true,
6
+ "strict": true,
7
+ "skipLibCheck": true,
8
+ "jsx": "react",
9
+ "noEmit": true
10
+ },
11
+ "include": ["src", "types.d.ts"],
12
+ "exclude": ["node_modules"]
13
+ }
@@ -0,0 +1,4 @@
1
+ declare module "*.scss" {
2
+ const classes: { [key: string]: string }
3
+ export default classes
4
+ }
@@ -7,7 +7,13 @@
7
7
  "serve": "catalyst serve",
8
8
  "lint": "eslint .",
9
9
  "devBuild": "catalyst devBuild",
10
- "devServe": "catalyst devServe"
10
+ "devServe": "catalyst devServe",
11
+ "buildApp": "catalyst buildApp",
12
+ "buildApp:ios": "catalyst buildApp:ios",
13
+ "buildApp:android": "catalyst buildApp:android",
14
+ "setupEmulator": "catalyst setupEmulator",
15
+ "setupEmulator:ios": "catalyst setupEmulator:ios",
16
+ "setupEmulator:android": "catalyst setupEmulator:android"
11
17
  },
12
18
  "_moduleAliases": {
13
19
  "@api": "api.js",
@@ -20,8 +26,8 @@
20
26
  },
21
27
  "dependencies": {
22
28
  "@loadable/component": "^5.16.3",
23
- "@tata1mg/router": "^0.0.1-beta.6",
24
- "catalyst-core-internal": "0.0.3-canary.0",
29
+ "@tata1mg/router": "0.0.1-beta.7",
30
+ "catalyst-core-internal": "0.0.3-canary.40",
25
31
  "@reduxjs/toolkit": "1.9.3",
26
32
  "react-redux": "^8.1.3"
27
33
  },
@@ -0,0 +1,28 @@
1
+ import React from "react"
2
+ import "./styles"
3
+ import { hydrateRoot } from "react-dom/client"
4
+ import { loadableReady } from "@loadable/component"
5
+ import { Provider } from "react-redux"
6
+ import { RouterProvider } from "@tata1mg/router"
7
+ import clientRouter from "catalyst-core-internal/router/ClientRouter"
8
+ import configureStore from "@store"
9
+
10
+ window.addEventListener("load", () => {
11
+ loadableReady(() => {
12
+ const { __ROUTER_INITIAL_DATA__: routerInitialData, __INITIAL_STATE__ } = window
13
+ const store = configureStore(__INITIAL_STATE__ || {})
14
+
15
+ const router = clientRouter({ store, routerInitialState: routerInitialData })
16
+
17
+ const Application = (
18
+ <Provider store={store} serverState={__INITIAL_STATE__}>
19
+ <React.StrictMode>
20
+ <RouterProvider router={router} />
21
+ </React.StrictMode>
22
+ </Provider>
23
+ )
24
+
25
+ const container = document.getElementById("app")
26
+ hydrateRoot(container, Application)
27
+ })
28
+ })
@@ -0,0 +1,43 @@
1
+ {
2
+ "name": "create-catalyst-app-starter",
3
+ "version": "1.0.0",
4
+ "scripts": {
5
+ "start": "catalyst start",
6
+ "build": "npm run typecheck && catalyst build",
7
+ "serve": "catalyst serve",
8
+ "lint": "eslint .",
9
+ "devBuild": "catalyst devBuild",
10
+ "devServe": "catalyst devServe",
11
+ "buildApp": "catalyst buildApp",
12
+ "buildApp:ios": "catalyst buildApp:ios",
13
+ "buildApp:android": "catalyst buildApp:android",
14
+ "setupEmulator": "catalyst setupEmulator",
15
+ "setupEmulator:ios": "catalyst setupEmulator:ios",
16
+ "setupEmulator:android": "catalyst setupEmulator:android",
17
+ "typecheck": "tsc --noEmit"
18
+ },
19
+ "_moduleAliases": {
20
+ "@api": "api.js",
21
+ "@containers": "src/js/containers",
22
+ "@server": "server",
23
+ "@config": "config",
24
+ "@css": "src/static/css",
25
+ "@routes": "src/js/routes/",
26
+ "@store": "src/js/store/index.js"
27
+ },
28
+ "dependencies": {
29
+ "@loadable/component": "^5.16.3",
30
+ "@tata1mg/router": "0.0.1-beta.7",
31
+ "catalyst-core-internal": "0.0.3-canary.40",
32
+ "@reduxjs/toolkit": "1.9.3",
33
+ "react-redux": "^8.1.3"
34
+ },
35
+ "devDependencies": {
36
+ "eslint": "^8.26.0",
37
+ "typescript": "^5.8.3",
38
+ "@types/react": "^18.2.0",
39
+ "@types/react-dom": "^18.2.0",
40
+ "eslint-plugin-react": "^7.34.1",
41
+ "eslint-plugin-react-hooks": "^4.6.0"
42
+ }
43
+ }
@@ -0,0 +1,16 @@
1
+ import React from "react"
2
+ import { Outlet } from "@tata1mg/router"
3
+
4
+ const App = () => {
5
+ return (
6
+ <>
7
+ <Outlet />
8
+ </>
9
+ )
10
+ }
11
+
12
+ App.serverSideFunction = () => {
13
+ return new Promise((resolve) => resolve())
14
+ }
15
+
16
+ export default App
@@ -0,0 +1,18 @@
1
+ import { createSlice } from "@reduxjs/toolkit"
2
+
3
+ const initialState = {
4
+ testActionDispatched: false,
5
+ }
6
+
7
+ export const appSlice = createSlice({
8
+ name: "shellReducer",
9
+ initialState: initialState,
10
+ reducers: {
11
+ reduxTest: (state) => {
12
+ state.testActionDispatched = true
13
+ },
14
+ },
15
+ })
16
+
17
+ export const { reduxTest } = appSlice.actions
18
+ export const shellReducer = appSlice.reducer
@@ -0,0 +1,42 @@
1
+ import React from "react"
2
+ import { RouterDataProvider, MetaTag } from "@tata1mg/router"
3
+ import App from "@containers/App"
4
+ import routes from "./index.js"
5
+
6
+ /**
7
+ * Making the routes array compatible with the format accepted by createBrowserRouter
8
+ * API on the client side
9
+ * https://reactrouter.com/en/main/routers/create-browser-router
10
+ */
11
+
12
+ export const preparedRoutes = ({ store, routerInitialState }) => {
13
+ const getPreparedRoutes = (routes) => {
14
+ return routes.map((route, index) => {
15
+ const Component = route.component
16
+ const routeToRender = {
17
+ ...route,
18
+ element: <Component key={index} />,
19
+ }
20
+ if (route.children) {
21
+ routeToRender.children = getPreparedRoutes(route.children)
22
+ }
23
+ return routeToRender
24
+ })
25
+ }
26
+
27
+ return [
28
+ {
29
+ element: (
30
+ <RouterDataProvider config={{}} initialState={routerInitialState} fetcherArgs={{ store }}>
31
+ <MetaTag />
32
+ <App />
33
+ </RouterDataProvider>
34
+ ),
35
+ children: getPreparedRoutes(routes),
36
+ },
37
+ ]
38
+ }
39
+
40
+ export const getRoutes = () => {
41
+ return routes
42
+ }
@@ -0,0 +1,28 @@
1
+ import { configureStore as createStore } from "@reduxjs/toolkit"
2
+ import { combineReducers } from "redux"
3
+ import { shellReducer } from "@containers/App/reducer.js"
4
+ import fetchInstance from "@api"
5
+
6
+ /**
7
+ * Function that initializes the store with the initialstate and adds middlewares that can be used during action dispatch
8
+ * @param {object} initialState Default state
9
+ * @param {object} request Request object that we recieve on server, this is only recieved when store is initialized on the server.
10
+ * @return {object} The store itself
11
+ */
12
+
13
+ const configureStore = (initialState) => {
14
+ const api = fetchInstance
15
+ const store = createStore({
16
+ reducer: combineReducers({ shellReducer }),
17
+ middleware: (getDefaultMiddleware) =>
18
+ getDefaultMiddleware({
19
+ thunk: {
20
+ extraArgument: { api },
21
+ },
22
+ }),
23
+ preloadedState: initialState,
24
+ })
25
+ return store
26
+ }
27
+
28
+ export default configureStore
@@ -0,0 +1,13 @@
1
+ {
2
+ "compilerOptions": {
3
+ "target": "ES2016",
4
+ "module": "CommonJS",
5
+ "esModuleInterop": true,
6
+ "strict": true,
7
+ "skipLibCheck": true,
8
+ "jsx": "react",
9
+ "noEmit": true
10
+ },
11
+ "include": ["src", "types.d.ts"],
12
+ "exclude": ["node_modules"]
13
+ }
@@ -0,0 +1,4 @@
1
+ declare module "*.scss" {
2
+ const classes: { [key: string]: string }
3
+ export default classes
4
+ }
@@ -0,0 +1,5 @@
1
+ module.exports = {
2
+ plugins: {
3
+ "@tailwindcss/postcss": {},
4
+ },
5
+ }
@@ -0,0 +1,2 @@
1
+ @import "styles";
2
+ @import "tailwindcss";