frontend-hamroun 1.1.31 → 1.1.33
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/package.json +1 -1
- package/templates/basic-app/build.js +22 -0
- package/templates/basic-app/dev.js +27 -0
- package/templates/basic-app/package.json +5 -12
- package/templates/ssr-template/build.js +44 -0
- package/templates/ssr-template/dev.js +24 -0
- package/templates/ssr-template/package.json +4 -6
- package/templates/ssr-template/src/client.tsx +8 -1
- package/templates/ssr-template/src/server.ts +24 -5
- package/templates/ssr-template/vite.config.ts +13 -1
package/package.json
CHANGED
@@ -0,0 +1,22 @@
|
|
1
|
+
import * as esbuild from 'esbuild';
|
2
|
+
|
3
|
+
await esbuild.build({
|
4
|
+
entryPoints: ['src/main.tsx'],
|
5
|
+
bundle: true,
|
6
|
+
outfile: 'dist/bundle.js',
|
7
|
+
format: 'esm',
|
8
|
+
platform: 'browser',
|
9
|
+
minify: true,
|
10
|
+
sourcemap: true,
|
11
|
+
loader: {
|
12
|
+
'.tsx': 'tsx',
|
13
|
+
'.ts': 'tsx',
|
14
|
+
},
|
15
|
+
jsxFactory: '_jsx',
|
16
|
+
jsxFragment: '_Fragment',
|
17
|
+
banner: {
|
18
|
+
js: `import { jsx as _jsx, Fragment as _Fragment } from 'frontend-hamroun';`,
|
19
|
+
},
|
20
|
+
});
|
21
|
+
|
22
|
+
console.log('Build complete');
|
@@ -0,0 +1,27 @@
|
|
1
|
+
import * as esbuild from 'esbuild';
|
2
|
+
|
3
|
+
const ctx = await esbuild.context({
|
4
|
+
entryPoints: ['src/main.tsx'],
|
5
|
+
bundle: true,
|
6
|
+
outfile: 'dist/bundle.js',
|
7
|
+
format: 'esm',
|
8
|
+
platform: 'browser',
|
9
|
+
sourcemap: true,
|
10
|
+
loader: {
|
11
|
+
'.tsx': 'tsx',
|
12
|
+
'.ts': 'tsx',
|
13
|
+
},
|
14
|
+
jsxFactory: '_jsx',
|
15
|
+
jsxFragment: '_Fragment',
|
16
|
+
banner: {
|
17
|
+
js: `import { jsx as _jsx, Fragment as _Fragment } from 'frontend-hamroun';`,
|
18
|
+
},
|
19
|
+
});
|
20
|
+
|
21
|
+
await ctx.watch();
|
22
|
+
await ctx.serve({
|
23
|
+
servedir: '.',
|
24
|
+
port: 3000,
|
25
|
+
});
|
26
|
+
|
27
|
+
console.log('Development server running on http://localhost:3000');
|
@@ -4,22 +4,15 @@
|
|
4
4
|
"version": "0.0.0",
|
5
5
|
"type": "module",
|
6
6
|
"scripts": {
|
7
|
-
"dev": "
|
8
|
-
"build": "
|
9
|
-
"
|
10
|
-
"lint": "eslint src --ext ts,tsx --report-unused-disable-directives --max-warnings 0",
|
11
|
-
"lint:fix": "eslint src --ext ts,tsx --fix"
|
7
|
+
"dev": "node dev.js",
|
8
|
+
"build": "node build.js",
|
9
|
+
"serve": "esbuild --serve=3000 --servedir=."
|
12
10
|
},
|
13
11
|
"dependencies": {
|
14
12
|
"frontend-hamroun": "latest"
|
15
13
|
},
|
16
14
|
"devDependencies": {
|
17
|
-
"
|
18
|
-
"
|
19
|
-
"@typescript-eslint/eslint-plugin": "^6.0.0",
|
20
|
-
"@typescript-eslint/parser": "^6.0.0",
|
21
|
-
"eslint": "^8.45.0",
|
22
|
-
"eslint-plugin-react-hooks": "^4.6.0",
|
23
|
-
"eslint-plugin-react-refresh": "^0.4.3"
|
15
|
+
"esbuild": "^0.19.0",
|
16
|
+
"typescript": "^5.0.0"
|
24
17
|
}
|
25
18
|
}
|
@@ -0,0 +1,44 @@
|
|
1
|
+
import * as esbuild from 'esbuild';
|
2
|
+
|
3
|
+
// Build client
|
4
|
+
await esbuild.build({
|
5
|
+
entryPoints: ['src/client.tsx'],
|
6
|
+
bundle: true,
|
7
|
+
outfile: 'dist/client.js',
|
8
|
+
format: 'esm',
|
9
|
+
platform: 'browser',
|
10
|
+
minify: true,
|
11
|
+
sourcemap: true,
|
12
|
+
loader: {
|
13
|
+
'.tsx': 'tsx',
|
14
|
+
'.ts': 'tsx',
|
15
|
+
},
|
16
|
+
jsxFactory: '_jsx',
|
17
|
+
jsxFragment: '_Fragment',
|
18
|
+
banner: {
|
19
|
+
js: `import { jsx as _jsx, Fragment as _Fragment } from 'frontend-hamroun';`,
|
20
|
+
},
|
21
|
+
});
|
22
|
+
|
23
|
+
// Build server
|
24
|
+
await esbuild.build({
|
25
|
+
entryPoints: ['src/server.ts'],
|
26
|
+
bundle: true,
|
27
|
+
outfile: 'dist/server.js',
|
28
|
+
format: 'esm',
|
29
|
+
platform: 'node',
|
30
|
+
minify: true,
|
31
|
+
sourcemap: true,
|
32
|
+
loader: {
|
33
|
+
'.tsx': 'tsx',
|
34
|
+
'.ts': 'tsx',
|
35
|
+
},
|
36
|
+
jsxFactory: '_jsx',
|
37
|
+
jsxFragment: '_Fragment',
|
38
|
+
banner: {
|
39
|
+
js: `import { jsx as _jsx, Fragment as _Fragment } from 'frontend-hamroun';`,
|
40
|
+
},
|
41
|
+
external: ['express', 'frontend-hamroun'],
|
42
|
+
});
|
43
|
+
|
44
|
+
console.log('Build complete');
|
@@ -0,0 +1,24 @@
|
|
1
|
+
import * as esbuild from 'esbuild';
|
2
|
+
|
3
|
+
const ctx = await esbuild.context({
|
4
|
+
entryPoints: ['src/client.tsx', 'src/server.ts'],
|
5
|
+
bundle: true,
|
6
|
+
outdir: 'dist',
|
7
|
+
format: 'esm',
|
8
|
+
platform: 'node',
|
9
|
+
sourcemap: true,
|
10
|
+
loader: {
|
11
|
+
'.tsx': 'tsx',
|
12
|
+
'.ts': 'tsx',
|
13
|
+
},
|
14
|
+
jsxFactory: '_jsx',
|
15
|
+
jsxFragment: '_Fragment',
|
16
|
+
banner: {
|
17
|
+
js: `import { jsx as _jsx, Fragment as _Fragment } from 'frontend-hamroun';`,
|
18
|
+
},
|
19
|
+
external: ['express', 'frontend-hamroun'],
|
20
|
+
});
|
21
|
+
|
22
|
+
await ctx.watch();
|
23
|
+
|
24
|
+
console.log('Watching for changes...');
|
@@ -4,10 +4,8 @@
|
|
4
4
|
"version": "0.0.0",
|
5
5
|
"type": "module",
|
6
6
|
"scripts": {
|
7
|
-
"dev": "
|
8
|
-
"build": "
|
9
|
-
"build:server": "tsc -p tsconfig.server.json",
|
10
|
-
"build:ssr": "npm run build && npm run build:server",
|
7
|
+
"dev": "node dev.js",
|
8
|
+
"build": "node build.js",
|
11
9
|
"start": "node dist/server.js"
|
12
10
|
},
|
13
11
|
"dependencies": {
|
@@ -15,9 +13,9 @@
|
|
15
13
|
"frontend-hamroun": "latest"
|
16
14
|
},
|
17
15
|
"devDependencies": {
|
16
|
+
"esbuild": "^0.19.0",
|
18
17
|
"@types/express": "^4.17.17",
|
19
18
|
"@types/node": "^20.5.0",
|
20
|
-
"typescript": "^5.0.0"
|
21
|
-
"vite": "^4.4.9"
|
19
|
+
"typescript": "^5.0.0"
|
22
20
|
}
|
23
21
|
}
|
@@ -1,4 +1,11 @@
|
|
1
1
|
import { hydrate } from 'frontend-hamroun';
|
2
2
|
import { App } from './App';
|
3
3
|
|
4
|
-
|
4
|
+
|
5
|
+
|
6
|
+
document.addEventListener('DOMContentLoaded', () => {
|
7
|
+
hydrate(
|
8
|
+
<App />,
|
9
|
+
document.getElementById('root')!
|
10
|
+
);
|
11
|
+
});
|
@@ -1,12 +1,31 @@
|
|
1
1
|
import express from 'express';
|
2
|
-
import
|
3
|
-
import {
|
2
|
+
import path from 'path';
|
3
|
+
import { fileURLToPath } from 'url';
|
4
|
+
import { renderToString, jsx } from 'frontend-hamroun';
|
5
|
+
import { App } from './App.js';
|
6
|
+
import fs from 'fs';
|
4
7
|
|
8
|
+
const __dirname = path.dirname(fileURLToPath(import.meta.url));
|
5
9
|
const app = express();
|
6
10
|
const port = 3000;
|
7
11
|
|
8
|
-
|
9
|
-
|
12
|
+
// Find the client entry file
|
13
|
+
const getClientEntry = () => {
|
14
|
+
const assetsDir = path.join(__dirname, './');
|
15
|
+
const files = fs.readdirSync(assetsDir);
|
16
|
+
return files.find(file => file.startsWith("client")&& file.endsWith('.js'));
|
17
|
+
};
|
18
|
+
|
19
|
+
// Serve static files from dist/assets
|
20
|
+
app.use('/assets', express.static(path.join(__dirname, './')));
|
21
|
+
|
22
|
+
// Serve static files from dist
|
23
|
+
app.use(express.static(path.join(__dirname, 'dist')));
|
24
|
+
|
25
|
+
app.get('/', async (_req: any, res: { send: (arg0: string) => void; }) => {
|
26
|
+
const clientEntry = getClientEntry();
|
27
|
+
const html = await renderToString(jsx(App, null
|
28
|
+
));
|
10
29
|
|
11
30
|
res.send(`
|
12
31
|
<!DOCTYPE html>
|
@@ -16,7 +35,7 @@ app.get('/', async (req: any, res: { send: (arg0: string) => void; }) => {
|
|
16
35
|
</head>
|
17
36
|
<body>
|
18
37
|
<div id="root">${html}</div>
|
19
|
-
<script type="module" src="/
|
38
|
+
<script type="module" src="/assets/${clientEntry}"></script>
|
20
39
|
</body>
|
21
40
|
</html>
|
22
41
|
`);
|
@@ -1,12 +1,24 @@
|
|
1
1
|
import { defineConfig } from 'vite';
|
2
|
+
import path from 'path';
|
2
3
|
|
3
4
|
export default defineConfig({
|
5
|
+
resolve: {
|
6
|
+
alias: {
|
7
|
+
'frontend-hamroun': path.resolve(__dirname, 'node_modules/frontend-hamroun')
|
8
|
+
}
|
9
|
+
},
|
4
10
|
build: {
|
5
|
-
|
11
|
+
outDir: 'dist',
|
12
|
+
ssr: 'src/server.ts',
|
6
13
|
rollupOptions: {
|
7
14
|
input: {
|
8
15
|
client: './src/client.tsx',
|
9
16
|
server: './src/server.ts'
|
17
|
+
},
|
18
|
+
output: {
|
19
|
+
entryFileNames: '[name].js',
|
20
|
+
chunkFileNames: 'assets/[name]-[hash].js',
|
21
|
+
assetFileNames: 'assets/[name]-[hash].[ext]'
|
10
22
|
}
|
11
23
|
}
|
12
24
|
},
|