@common-stack/generate-plugin 8.1.1-alpha.0 → 8.1.1-alpha.10
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.
- package/CHANGELOG.md +40 -0
- package/lib/generators/add-backend/files/package.json +1 -1
- package/lib/generators/add-frontend/frameworks/tailwindui/src/entry.client.tsx.template +11 -15
- package/lib/generators/add-frontend/frameworks/tailwindui/src/entry.server.tsx.template +9 -10
- package/lib/generators/add-frontend/frameworks/tailwindui/src/root.tsx.template +68 -42
- package/lib/generators/add-frontend/frameworks/tailwindui/tailwind.config.ts.template +288 -9
- package/lib/generators/add-frontend/templates/package.json +3 -7
- package/lib/generators/add-frontend/templates/server.js +11 -10
- package/lib/generators/add-frontend/templates/src/routes.ts.template +38 -0
- package/lib/generators/add-frontend/templates/vite.config.ts.template +91 -48
- package/lib/generators/add-fullstack/files/package.json +3 -3
- package/lib/generators/add-moleculer/files/package.json +5 -5
- package/lib/generators/add-package/files/browser/package.json +1 -1
- package/lib/generators/add-package/files/server/package.json +3 -3
- package/package.json +3 -3
- package/src/generators/add-backend/files/package.json +1 -1
- package/src/generators/add-frontend/frameworks/tailwindui/src/entry.client.tsx.template +11 -15
- package/src/generators/add-frontend/frameworks/tailwindui/src/entry.server.tsx.template +9 -10
- package/src/generators/add-frontend/frameworks/tailwindui/src/root.tsx.template +68 -42
- package/src/generators/add-frontend/frameworks/tailwindui/tailwind.config.ts.template +288 -9
- package/src/generators/add-frontend/templates/package.json +3 -7
- package/src/generators/add-frontend/templates/server.js +11 -10
- package/src/generators/add-frontend/templates/src/routes.ts.template +38 -0
- package/src/generators/add-frontend/templates/vite.config.ts.template +91 -48
- package/src/generators/add-fullstack/files/package.json +3 -3
- package/src/generators/add-moleculer/files/package.json +5 -5
- package/src/generators/add-package/files/browser/package.json +1 -1
- package/src/generators/add-package/files/server/package.json +3 -3
|
@@ -17,7 +17,7 @@
|
|
|
17
17
|
"main": "index.js",
|
|
18
18
|
"scripts": {
|
|
19
19
|
"prebuild": "yarn build:clean && yarn genconfig",
|
|
20
|
-
"build": "cross-env SSR=true NODE_OPTIONS='--max_old_space_size=
|
|
20
|
+
"build": "cross-env SSR=true NODE_OPTIONS='--max_old_space_size=6096' NODE_ENV=production remix vite:build",
|
|
21
21
|
"build:SSR": "cross-env SSR=true NODE_ENV=production remix vite:build",
|
|
22
22
|
"build:clean": "rimraf dist build node_modules/.vite",
|
|
23
23
|
"build:debug": "cross-env DEBUGGING=true NODE_ENV=production remix vite:build",
|
|
@@ -56,16 +56,12 @@
|
|
|
56
56
|
"common": "link:./common"
|
|
57
57
|
},
|
|
58
58
|
"dependencies": {
|
|
59
|
-
"@common-stack/frontend-stack-react": "
|
|
59
|
+
"@common-stack/frontend-stack-react": "8.1.1-alpha.4",
|
|
60
60
|
"@react-icons/all-files": "^4.1.0",
|
|
61
61
|
"classnames": "^2.2.6",
|
|
62
|
-
"compression": "^1.7.4",
|
|
63
62
|
"glob-all": "^3.3.1",
|
|
64
63
|
"immutability-helper": "^3.0.1",
|
|
65
64
|
"is-plain-obj": "^3.0.0",
|
|
66
|
-
"isomorphic-fetch": "^2.2.1",
|
|
67
|
-
"lodash": "^4.17.15",
|
|
68
|
-
"lodash-es": "^4.17.21",
|
|
69
65
|
"moment": "2.29.1",
|
|
70
66
|
"ramda": "^0.30.1",
|
|
71
67
|
"react-ga4": "^2.1.0",
|
|
@@ -81,7 +77,7 @@
|
|
|
81
77
|
},
|
|
82
78
|
"devDependencies": {
|
|
83
79
|
"@cdmbase/vite-plugin-i18next-loader": "^2.0.12",
|
|
84
|
-
"@common-stack/rollup-vite-utils": "
|
|
80
|
+
"@common-stack/rollup-vite-utils": "8.1.1-alpha.9",
|
|
85
81
|
"@remix-run/dev": "~2.15.3",
|
|
86
82
|
"@remix-run/serve": "~2.15.3",
|
|
87
83
|
"cross-env": "^7.0.3",
|
|
@@ -1,14 +1,9 @@
|
|
|
1
1
|
import express from 'express';
|
|
2
2
|
import compression from 'compression';
|
|
3
3
|
import { createRequestHandler } from '@remix-run/express';
|
|
4
|
-
import { installGlobals } from '@remix-run/node';
|
|
5
4
|
import './env.js';
|
|
6
|
-
import {
|
|
7
|
-
|
|
8
|
-
} from '@common-stack/rollup-vite-utils/lib/preStartup/configLoader/configLoader.js';
|
|
9
|
-
import config from './app/cde-webconfig.json' assert { type: 'json' };
|
|
10
|
-
|
|
11
|
-
installGlobals();
|
|
5
|
+
import { performCopyOperations } from '@common-stack/rollup-vite-utils/lib/preStartup/configLoader/configLoader.js';
|
|
6
|
+
import config from './app/cde-webconfig.json' with { type: 'json' };
|
|
12
7
|
|
|
13
8
|
Object.keys(config.buildConfig).forEach((key) => {
|
|
14
9
|
global[key] = config.buildConfig[key];
|
|
@@ -17,9 +12,15 @@ Object.keys(config.buildConfig).forEach((key) => {
|
|
|
17
12
|
const startServer = async () => {
|
|
18
13
|
await performCopyOperations(config);
|
|
19
14
|
|
|
20
|
-
const { corsMiddleware } = await import(
|
|
21
|
-
|
|
22
|
-
|
|
15
|
+
const { corsMiddleware } = await import(
|
|
16
|
+
`./${config.commonPaths.appPath}/${config.commonPaths.frontendStackPath}/backend/middlewares/cors.js`
|
|
17
|
+
);
|
|
18
|
+
const { containerMiddleware } = await import(
|
|
19
|
+
`./${config.commonPaths.appPath}/${config.commonPaths.frontendStackPath}/backend/middlewares/container.js`
|
|
20
|
+
);
|
|
21
|
+
const { loadContext } = await import(
|
|
22
|
+
`./${config.commonPaths.appPath}/${config.commonPaths.frontendStackPath}/load-context.server.js`
|
|
23
|
+
);
|
|
23
24
|
|
|
24
25
|
const viteDevServer =
|
|
25
26
|
process.env.NODE_ENV === 'production'
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
// import { flatRoutes } from "@remix-run/fs-routes";
|
|
2
|
+
import { type RouteConfig } from '@remix-run/route-config';
|
|
3
|
+
import { remixRoutesOptionAdapter } from '@remix-run/routes-option-adapter';
|
|
4
|
+
import { dirname, resolve } from 'path';
|
|
5
|
+
import { fileURLToPath } from 'url';
|
|
6
|
+
import { defineRoutesConfig } from '@common-stack/rollup-vite-utils/lib/vite-wrappers/json-wrappers.js';
|
|
7
|
+
import { performCopyOperations } from '@common-stack/rollup-vite-utils/lib/preStartup/configLoader/configLoader.js';
|
|
8
|
+
import config from '../app/cde-webconfig.json' with { type: 'json' };
|
|
9
|
+
|
|
10
|
+
const directoryName = dirname(fileURLToPath(import.meta.url));
|
|
11
|
+
|
|
12
|
+
export default remixRoutesOptionAdapter(async (defineRoutes) => {
|
|
13
|
+
if (process.env.NODE_ENV === 'production') {
|
|
14
|
+
await performCopyOperations(config);
|
|
15
|
+
}
|
|
16
|
+
let metaJson = null;
|
|
17
|
+
try {
|
|
18
|
+
metaJson = await import('../app/sync-meta.json');
|
|
19
|
+
} catch {
|
|
20
|
+
console.warn('No sync-meta.json found, continuing without metadata.');
|
|
21
|
+
}
|
|
22
|
+
return defineRoutes((routeFn) => {
|
|
23
|
+
defineRoutesConfig(
|
|
24
|
+
routeFn,
|
|
25
|
+
{
|
|
26
|
+
routesFileName: 'routes.json',
|
|
27
|
+
packages: config.modules,
|
|
28
|
+
paths: config.paths,
|
|
29
|
+
iconsRepository: config?.iconsRepository,
|
|
30
|
+
rootPath: resolve(directoryName, '../../..'),
|
|
31
|
+
settings: {
|
|
32
|
+
_useFutureCommonPackage: true,
|
|
33
|
+
},
|
|
34
|
+
},
|
|
35
|
+
metaJson,
|
|
36
|
+
);
|
|
37
|
+
});
|
|
38
|
+
}) satisfies RouteConfig;
|
|
@@ -1,23 +1,26 @@
|
|
|
1
|
-
import { defineConfig } from 'vite';
|
|
1
|
+
import { defineConfig, ConfigEnv, UserConfig } from 'vite';
|
|
2
2
|
import { vitePlugin as remix } from '@remix-run/dev';
|
|
3
3
|
import { dirname, resolve } from 'path';
|
|
4
|
-
import { installGlobals } from '@remix-run/node';
|
|
5
4
|
import { fileURLToPath } from 'url';
|
|
6
|
-
import {
|
|
5
|
+
// import { remixDevTools } from 'remix-development-tools';
|
|
7
6
|
import tsconfigPaths from 'vite-tsconfig-paths';
|
|
8
7
|
import { i18nInternationalizationPlugin } from '@common-stack/rollup-vite-utils/lib/vite-plugins/i18n-internationalization-plugin.js';
|
|
9
|
-
import {
|
|
8
|
+
// import { visualizer } from 'rollup-plugin-visualizer';
|
|
10
9
|
import { loadEnvConfig } from '@common-stack/rollup-vite-utils/lib/preStartup/configLoader/envLoader.js';
|
|
11
10
|
import { cjsInterop } from 'vite-plugin-cjs-interop';
|
|
12
11
|
import { mergeWith } from 'lodash-es';
|
|
13
|
-
import config from './app/cde-webconfig.json'
|
|
12
|
+
import config from './app/cde-webconfig.json' with { type: 'json' };
|
|
14
13
|
|
|
15
|
-
|
|
16
|
-
|
|
14
|
+
declare module '@remix-run/node' {
|
|
15
|
+
// or cloudflare, deno, etc.
|
|
16
|
+
interface Future {
|
|
17
|
+
v3_singleFetch: true;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
17
20
|
|
|
18
21
|
const directoryName = dirname(fileURLToPath(import.meta.url));
|
|
19
22
|
|
|
20
|
-
export default defineConfig(async ({ isSsrBuild }) => {
|
|
23
|
+
export default defineConfig(async ({ isSsrBuild }: ConfigEnv): Promise<UserConfig> => {
|
|
21
24
|
console.log('--- IS SSR BUILD:', isSsrBuild);
|
|
22
25
|
|
|
23
26
|
// Load environment variables from dotenv or other config
|
|
@@ -32,69 +35,105 @@ export default defineConfig(async ({ isSsrBuild }) => {
|
|
|
32
35
|
Object.entries(config.buildConfig).map(([key, value]) => [
|
|
33
36
|
key,
|
|
34
37
|
typeof value === 'string' ? `"${value.replace(/\\/g, '\\\\')}"` : value,
|
|
35
|
-
])
|
|
38
|
+
]),
|
|
36
39
|
),
|
|
37
40
|
};
|
|
38
41
|
|
|
39
|
-
// Define routes configuration
|
|
40
|
-
const routesConfig = async (defineRoutes) => {
|
|
41
|
-
// In production, perform required file copy operations
|
|
42
|
-
if (process.env.NODE_ENV === 'production') {
|
|
43
|
-
await performCopyOperations(config);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
// Load metadata for routes
|
|
47
|
-
let metaJson = null;
|
|
48
|
-
try {
|
|
49
|
-
metaJson = await import('./app/sync-meta.json');
|
|
50
|
-
} catch {
|
|
51
|
-
console.warn('No sync-meta.json found, continuing without metadata.');
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
// Return routes definition
|
|
55
|
-
return defineRoutes((routeFn) =>
|
|
56
|
-
defineRoutesConfig(
|
|
57
|
-
routeFn,
|
|
58
|
-
{
|
|
59
|
-
routesFileName: 'routes.json',
|
|
60
|
-
packages: config.modules,
|
|
61
|
-
paths: config.paths,
|
|
62
|
-
iconsRepository: config?.iconsRepository,
|
|
63
|
-
rootPath: resolve(directoryName, '../..'),
|
|
64
|
-
settings: {
|
|
65
|
-
_useFutureCommonPackage: true,
|
|
66
|
-
},
|
|
67
|
-
},
|
|
68
|
-
metaJson
|
|
69
|
-
)
|
|
70
|
-
);
|
|
71
|
-
};
|
|
72
|
-
|
|
73
42
|
// Vite configuration
|
|
74
43
|
const viteConfig = {
|
|
75
44
|
define: envVariables,
|
|
45
|
+
ssr: {
|
|
46
|
+
// Keep small client-only libraries bundled, including all @radix-ui packages
|
|
47
|
+
// to ensure proper CommonJS to ESM interop handled by cjsInterop plugin
|
|
48
|
+
noExternal: [
|
|
49
|
+
'react-datepicker',
|
|
50
|
+
/^@radix-ui\//,
|
|
51
|
+
'@radix-ui/react-slot',
|
|
52
|
+
'@radix-ui/react-primitive',
|
|
53
|
+
'@radix-ui/react-compose-refs',
|
|
54
|
+
'@radix-ui/react-context',
|
|
55
|
+
'@radix-ui/react-collection',
|
|
56
|
+
'@radix-ui/react-separator',
|
|
57
|
+
],
|
|
58
|
+
},
|
|
76
59
|
plugins: [
|
|
60
|
+
// remixDevTools({
|
|
61
|
+
// server: {
|
|
62
|
+
// logs: {
|
|
63
|
+
// cookies: true,
|
|
64
|
+
// defer: true,
|
|
65
|
+
// actions: true,
|
|
66
|
+
// loaders: true,
|
|
67
|
+
// cache: true,
|
|
68
|
+
// siteClear: true,
|
|
69
|
+
// },
|
|
70
|
+
// },
|
|
71
|
+
// }),
|
|
77
72
|
i18nInternationalizationPlugin({
|
|
78
73
|
folderName: 'cdm-locales',
|
|
79
74
|
packages: [...config.modules, ...config.i18n.packages],
|
|
80
|
-
namespaceResolution: 'basename',
|
|
75
|
+
namespaceResolution: 'basename' as any,
|
|
81
76
|
}),
|
|
77
|
+
// visualizer({
|
|
78
|
+
// open: true,
|
|
79
|
+
// filename: 'bundle-analysis.html',
|
|
80
|
+
// }),
|
|
81
|
+
// cjsInterop({
|
|
82
|
+
// dependencies: ['@apollo/client', '@ant-design/pro-utils', '@rjsf/**',],
|
|
83
|
+
// }),
|
|
82
84
|
cjsInterop({
|
|
83
|
-
dependencies: [
|
|
85
|
+
dependencies: [
|
|
86
|
+
'@rjsf/**',
|
|
87
|
+
'react-timer-hook',
|
|
88
|
+
'rc-util/lib/hooks/useMergedState.js',
|
|
89
|
+
'@ant-design/icons',
|
|
90
|
+
'rc-picker',
|
|
91
|
+
'@monaco-editor/loader',
|
|
92
|
+
'react-google-calendar-api',
|
|
93
|
+
'@apollo/client',
|
|
94
|
+
],
|
|
84
95
|
}),
|
|
85
96
|
remix({
|
|
86
97
|
appDirectory: 'src',
|
|
87
|
-
routes: routesConfig,
|
|
98
|
+
// routes: routesConfig,
|
|
99
|
+
future: {
|
|
100
|
+
unstable_optimizeDeps: true,
|
|
101
|
+
v3_fetcherPersist: true,
|
|
102
|
+
v3_relativeSplatPath: true,
|
|
103
|
+
v3_throwAbortReason: true,
|
|
104
|
+
v3_lazyRouteDiscovery: true,
|
|
105
|
+
v3_singleFetch: true,
|
|
106
|
+
v3_routeConfig: true,
|
|
107
|
+
},
|
|
88
108
|
}),
|
|
89
109
|
tsconfigPaths({ ignoreConfigErrors: true }),
|
|
90
110
|
],
|
|
91
111
|
optimizeDeps: {
|
|
112
|
+
include: [
|
|
113
|
+
'@radix-ui/react-slot',
|
|
114
|
+
'@radix-ui/react-compose-refs',
|
|
115
|
+
'@radix-ui/react-primitive',
|
|
116
|
+
'@radix-ui/react-collection',
|
|
117
|
+
'@radix-ui/react-dialog',
|
|
118
|
+
'@radix-ui/react-select',
|
|
119
|
+
'@radix-ui/react-alert-dialog',
|
|
120
|
+
'@radix-ui/react-popover',
|
|
121
|
+
'@radix-ui/react-tooltip',
|
|
122
|
+
'@radix-ui/react-context-menu',
|
|
123
|
+
],
|
|
92
124
|
esbuildOptions: {
|
|
93
125
|
target: 'esnext',
|
|
94
126
|
},
|
|
127
|
+
force: true, // Force dependency optimization on every build
|
|
95
128
|
},
|
|
96
129
|
build: {
|
|
97
130
|
target: 'esnext',
|
|
131
|
+
rollupOptions: {
|
|
132
|
+
output: {
|
|
133
|
+
// Ensure that worker files are properly bundled
|
|
134
|
+
format: 'es',
|
|
135
|
+
},
|
|
136
|
+
},
|
|
98
137
|
},
|
|
99
138
|
resolve: {
|
|
100
139
|
alias: {
|
|
@@ -102,14 +141,18 @@ export default defineConfig(async ({ isSsrBuild }) => {
|
|
|
102
141
|
'@src': resolve(directoryName, 'src'),
|
|
103
142
|
},
|
|
104
143
|
},
|
|
144
|
+
worker: {
|
|
145
|
+
format: 'es', // Use ES modules format for workers
|
|
146
|
+
plugins: () => [], // Return an empty array of plugins
|
|
147
|
+
},
|
|
105
148
|
};
|
|
106
149
|
|
|
107
150
|
// Deep merge custom Vite config from config.json
|
|
108
|
-
// to merge Arrays properly need to concat.
|
|
151
|
+
// to merge Arrays properly need to concat.
|
|
109
152
|
const result = mergeWith(config.viteConfig, viteConfig, (objValue, srcValue) => {
|
|
110
153
|
if (Array.isArray(objValue)) {
|
|
111
154
|
return objValue.concat(srcValue);
|
|
112
155
|
}
|
|
113
156
|
});
|
|
114
|
-
return result;
|
|
157
|
+
return result as UserConfig;
|
|
115
158
|
});
|
|
@@ -136,9 +136,9 @@
|
|
|
136
136
|
"@babel/preset-typescript": "^7.18.6",
|
|
137
137
|
"@babel/register": "^7.18.9",
|
|
138
138
|
"@babel/runtime": "^7.20.1",
|
|
139
|
-
"@common-stack/env-list-loader": "
|
|
140
|
-
"@common-stack/generate-plugin": "
|
|
141
|
-
"@common-stack/rollup-vite-utils": "
|
|
139
|
+
"@common-stack/env-list-loader": "8.1.1-alpha.2",
|
|
140
|
+
"@common-stack/generate-plugin": "8.1.1-alpha.9",
|
|
141
|
+
"@common-stack/rollup-vite-utils": "8.1.1-alpha.9",
|
|
142
142
|
"@emotion/babel-plugin": "^11.11.0",
|
|
143
143
|
"@graphql-codegen/add": "^5.0.3",
|
|
144
144
|
"@graphql-codegen/cli": "^5.0.4",
|
|
@@ -29,11 +29,11 @@
|
|
|
29
29
|
"common": "link:./common"
|
|
30
30
|
},
|
|
31
31
|
"dependencies": {
|
|
32
|
-
"@common-stack/client-core": "
|
|
33
|
-
"@common-stack/core": "
|
|
34
|
-
"@common-stack/server-core": "
|
|
35
|
-
"@common-stack/server-stack": "
|
|
36
|
-
"@common-stack/store-mongo": "
|
|
32
|
+
"@common-stack/client-core": "8.1.1-alpha.4",
|
|
33
|
+
"@common-stack/core": "8.1.1-alpha.4",
|
|
34
|
+
"@common-stack/server-core": "8.1.1-alpha.4",
|
|
35
|
+
"@common-stack/server-stack": "8.1.1-alpha.5",
|
|
36
|
+
"@common-stack/store-mongo": "8.1.1-alpha.4",
|
|
37
37
|
"@container-stack/mailing-api": "5.2.1-alpha.1",
|
|
38
38
|
"helmet": "^3.21.2",
|
|
39
39
|
"react": "18.2.0",
|
|
@@ -62,9 +62,9 @@
|
|
|
62
62
|
"peerDependencies": {
|
|
63
63
|
"@apollo/client": ">=3.0.0",
|
|
64
64
|
"@cdm-logger/server": ">=9.0.3",
|
|
65
|
-
"@common-stack/core": "
|
|
66
|
-
"@common-stack/server-core": "
|
|
67
|
-
"@common-stack/store-mongo": "
|
|
65
|
+
"@common-stack/core": "8.1.1-alpha.4",
|
|
66
|
+
"@common-stack/server-core": "8.1.1-alpha.4",
|
|
67
|
+
"@common-stack/store-mongo": "8.1.1-alpha.4",
|
|
68
68
|
"@container-stack/mailing-api": ">=0.0.35-alpha.1",
|
|
69
69
|
"@vscode-alt/monaco-editor": "^0.21.4",
|
|
70
70
|
"inversify": "^5.0.1",
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@common-stack/generate-plugin",
|
|
3
|
-
"version": "8.1.1-alpha.
|
|
3
|
+
"version": "8.1.1-alpha.10",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"main": "./lib/index.mjs",
|
|
6
6
|
"typings": "./lib/index.d.ts",
|
|
@@ -18,7 +18,7 @@
|
|
|
18
18
|
"watch": "yarn build:lib:watch"
|
|
19
19
|
},
|
|
20
20
|
"dependencies": {
|
|
21
|
-
"@common-stack/rollup-vite-utils": "8.1.1-alpha.
|
|
21
|
+
"@common-stack/rollup-vite-utils": "8.1.1-alpha.10",
|
|
22
22
|
"tslib": "^2.3.0"
|
|
23
23
|
},
|
|
24
24
|
"publishConfig": {
|
|
@@ -26,5 +26,5 @@
|
|
|
26
26
|
},
|
|
27
27
|
"executors": "./executors.json",
|
|
28
28
|
"generators": "./generators.json",
|
|
29
|
-
"gitHead": "
|
|
29
|
+
"gitHead": "ea4d6450f95dc8cdba4be5888b794b562bb72e4c"
|
|
30
30
|
}
|
|
@@ -64,7 +64,7 @@
|
|
|
64
64
|
"dependencies": {
|
|
65
65
|
"@apollo/client": "^3.9.0",
|
|
66
66
|
"@babel/runtime": "^7.20.1",
|
|
67
|
-
"@common-stack/server-stack": "
|
|
67
|
+
"@common-stack/server-stack": "8.1.1-alpha.5",
|
|
68
68
|
"@remix-run/node": "~2.15.3",
|
|
69
69
|
"lodash": "^4.17.15",
|
|
70
70
|
"react": "18.2.0"
|
|
@@ -55,21 +55,17 @@ async function hydrate() {
|
|
|
55
55
|
startTransition(() => {
|
|
56
56
|
hydrateRoot(
|
|
57
57
|
document,
|
|
58
|
-
|
|
59
|
-
<
|
|
60
|
-
<
|
|
61
|
-
<
|
|
62
|
-
<
|
|
63
|
-
<
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
</ReduxProvider>
|
|
70
|
-
</StrictMode>
|
|
71
|
-
</I18nextProvider>
|
|
72
|
-
) as any,
|
|
58
|
+
<I18nextProvider i18n={i18next}>
|
|
59
|
+
<ReduxProvider store={store}>
|
|
60
|
+
<SlotFillProvider>
|
|
61
|
+
<InversifyProvider container={container} modules={clientModules}>
|
|
62
|
+
<ApolloProvider client={client}>
|
|
63
|
+
<RemixBrowser />
|
|
64
|
+
</ApolloProvider>
|
|
65
|
+
</InversifyProvider>
|
|
66
|
+
</SlotFillProvider>
|
|
67
|
+
</ReduxProvider>
|
|
68
|
+
</I18nextProvider>,
|
|
73
69
|
);
|
|
74
70
|
});
|
|
75
71
|
}
|
|
@@ -4,6 +4,7 @@
|
|
|
4
4
|
* For more information, see https://remix.run/file-conventions/entry.server
|
|
5
5
|
*/
|
|
6
6
|
import * as React from 'react';
|
|
7
|
+
import 'reflect-metadata';
|
|
7
8
|
(global as any).__CLIENT__ = false;
|
|
8
9
|
(global as any).__SERVER__ = true;
|
|
9
10
|
import { PassThrough, Transform } from 'node:stream';
|
|
@@ -28,7 +29,8 @@ import config from '@app/cde-webconfig.json';
|
|
|
28
29
|
// @ts-ignore
|
|
29
30
|
import type { IAppLoadContext } from '@common-stack/client-core';
|
|
30
31
|
|
|
31
|
-
|
|
32
|
+
// Reject/cancel all pending promises after 5 seconds
|
|
33
|
+
export const streamTimeout = 5000;
|
|
32
34
|
|
|
33
35
|
class ConstantsTransform extends Transform {
|
|
34
36
|
_fills: string[];
|
|
@@ -120,7 +122,7 @@ function handleBotRequest(
|
|
|
120
122
|
let shellRendered = false;
|
|
121
123
|
const { pipe, abort } = renderToPipeableStream(
|
|
122
124
|
<I18nextProvider i18n={i18nInstance}>
|
|
123
|
-
<RemixServer context={remixContext} url={request.url}
|
|
125
|
+
<RemixServer context={remixContext} url={request.url} />
|
|
124
126
|
</I18nextProvider>,
|
|
125
127
|
{
|
|
126
128
|
onAllReady() {
|
|
@@ -154,7 +156,7 @@ function handleBotRequest(
|
|
|
154
156
|
},
|
|
155
157
|
);
|
|
156
158
|
|
|
157
|
-
setTimeout(abort,
|
|
159
|
+
setTimeout(abort, streamTimeout + 1000);
|
|
158
160
|
});
|
|
159
161
|
}
|
|
160
162
|
|
|
@@ -184,11 +186,7 @@ function handleBrowserRequest(
|
|
|
184
186
|
<SlotFillProvider context={slotFillContext}>
|
|
185
187
|
<InversifyProvider container={container} modules={clientModules as any}>
|
|
186
188
|
<ApolloProvider client={client}>
|
|
187
|
-
<RemixServer
|
|
188
|
-
context={remixContext}
|
|
189
|
-
url={request.url}
|
|
190
|
-
abortDelay={ABORT_DELAY}
|
|
191
|
-
/>
|
|
189
|
+
<RemixServer context={remixContext} url={request.url} />
|
|
192
190
|
</ApolloProvider>
|
|
193
191
|
</InversifyProvider>
|
|
194
192
|
</SlotFillProvider>
|
|
@@ -203,8 +201,9 @@ function handleBrowserRequest(
|
|
|
203
201
|
const apolloState = { ...client.extract() };
|
|
204
202
|
const reduxState = { ...store.getState() };
|
|
205
203
|
const fills = Object.keys(slotFillContext.fills);
|
|
204
|
+
const styleSheet = '';
|
|
206
205
|
|
|
207
|
-
const transform = new ConstantsTransform(fills, apolloState, reduxState,
|
|
206
|
+
const transform = new ConstantsTransform(fills, apolloState, reduxState, styleSheet);
|
|
208
207
|
|
|
209
208
|
responseHeaders.set('Content-Type', 'text/html');
|
|
210
209
|
|
|
@@ -233,6 +232,6 @@ function handleBrowserRequest(
|
|
|
233
232
|
},
|
|
234
233
|
);
|
|
235
234
|
|
|
236
|
-
setTimeout(abort,
|
|
235
|
+
setTimeout(abort, streamTimeout + 1000);
|
|
237
236
|
});
|
|
238
237
|
}
|