frontend-hamroun 1.1.32 → 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 CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "frontend-hamroun",
3
- "version": "1.1.32",
3
+ "version": "1.1.33",
4
4
  "description": "A lightweight frontend framework with hooks and virtual DOM",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",
@@ -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": "vite",
8
- "build": "tsc && vite build",
9
- "preview": "vite preview",
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
- "typescript": "^5.0.0",
18
- "vite": "^4.4.9",
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...');
@@ -1,13 +1,11 @@
1
1
  {
2
- "name": "ssr-version",
2
+ "name": "ssr-app",
3
3
  "private": true,
4
4
  "version": "0.0.0",
5
5
  "type": "module",
6
6
  "scripts": {
7
- "dev": "vite",
8
- "build:client": "vite build",
9
- "build:server": "vite build --ssr",
10
- "build": "npm run build:client && 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,20 +1,26 @@
1
1
  import { useState } from 'frontend-hamroun';
2
2
 
3
-
4
3
  export function App() {
5
- const [count, setCount] = useState( 0);
6
-
7
- const increment = () => setCount(count + 1);
8
- const decrement = () => setCount(count - 1);
9
-
4
+ // Initialize with a default state that works on both server and client
5
+ const [count, setCount] = useState(0);
6
+
10
7
  return (
11
8
  <div>
12
9
  <h1>Server-Side Rendered App</h1>
13
10
  <div>
14
- <button onClick={decrement} data-action="decrement">-</button>
11
+ <button
12
+ onClick={() => setCount(count - 1)}
13
+ data-action="decrement"
14
+ >-</button>
15
15
  <span style={{ margin: '0 10px' }}>{count}</span>
16
- <button onClick={increment} data-action="increment">+</button>
16
+ <button
17
+ onClick={() => setCount(count + 1)}
18
+ data-action="increment"
19
+ >+</button>
17
20
  </div>
21
+ <script dangerouslySetInnerHTML={{
22
+ __html: `window.__INITIAL_STATE__ = ${JSON.stringify({ count: 0 })};`
23
+ }} />
18
24
  </div>
19
25
  );
20
26
  }
@@ -22,7 +22,7 @@ app.use('/assets', express.static(path.join(__dirname, './')));
22
22
  // Serve static files from dist
23
23
  app.use(express.static(path.join(__dirname, 'dist')));
24
24
 
25
- app.get('/', async (req, res) => {
25
+ app.get('/', async (_req: any, res: { send: (arg0: string) => void; }) => {
26
26
  const clientEntry = getClientEntry();
27
27
  const html = await renderToString(jsx(App, null
28
28
  ));