frontend-hamroun 1.1.33 → 1.1.35

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.33",
3
+ "version": "1.1.35",
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,28 @@
1
+ import * as esbuild from 'esbuild';
2
+
3
+ const isWatch = process.argv.includes('--watch');
4
+
5
+ const config = {
6
+ entryPoints: ['src/main.tsx'],
7
+ bundle: true,
8
+ outfile: 'dist/bundle.js',
9
+ loader: { '.tsx': 'tsx' },
10
+ jsxFactory: 'createElement',
11
+ jsxFragment: 'null',
12
+ platform: 'browser',
13
+ target: 'es2020',
14
+ minify: true,
15
+ inject: ['./src/jsx-shim.ts'],
16
+ define: {
17
+ 'Fragment': 'null'
18
+ }
19
+ };
20
+
21
+ if (isWatch) {
22
+ const ctx = await esbuild.context(config);
23
+ await ctx.watch();
24
+ console.log('Watching...');
25
+ } else {
26
+ await esbuild.build(config);
27
+ console.log('Build complete');
28
+ }
@@ -1,18 +1,24 @@
1
1
  {
2
- "name": "my-app",
2
+ "name": "esbuild",
3
3
  "private": true,
4
4
  "version": "0.0.0",
5
5
  "type": "module",
6
6
  "scripts": {
7
- "dev": "node dev.js",
8
- "build": "node build.js",
9
- "serve": "esbuild --serve=3000 --servedir=."
7
+ "dev": "node server.js",
8
+ "build": "node esbuild.config.js",
9
+ "lint": "eslint src --ext ts,tsx --report-unused-disable-directives --max-warnings 0",
10
+ "lint:fix": "eslint src --ext ts,tsx --fix"
10
11
  },
11
12
  "dependencies": {
12
13
  "frontend-hamroun": "latest"
13
14
  },
14
15
  "devDependencies": {
15
- "esbuild": "^0.19.0",
16
- "typescript": "^5.0.0"
16
+ "typescript": "^5.0.0",
17
+ "esbuild": "^0.19.2",
18
+ "@typescript-eslint/eslint-plugin": "^6.0.0",
19
+ "@typescript-eslint/parser": "^6.0.0",
20
+ "eslint": "^8.45.0",
21
+ "eslint-plugin-react-hooks": "^4.6.0",
22
+ "live-server": "^1.2.2"
17
23
  }
18
24
  }
@@ -0,0 +1,27 @@
1
+ import { spawn } from 'child_process';
2
+ import liveServer from 'live-server';
3
+
4
+ // Start esbuild in watch mode
5
+ const esbuild = spawn('node', ['esbuild.config.js', '--watch'], {
6
+ stdio: 'inherit'
7
+ });
8
+
9
+ // Start live-server
10
+ const params = {
11
+ port: 8080,
12
+ host: "0.0.0.0",
13
+ root: ".",
14
+ open: true,
15
+ wait: 1000,
16
+ logLevel: 2
17
+ };
18
+
19
+ liveServer.start(params);
20
+
21
+ // Handle process termination
22
+ // eslint-disable-next-line no-undef
23
+ process.on('SIGTERM', () => {
24
+ esbuild.kill();
25
+ // eslint-disable-next-line no-undef
26
+ process.exit();
27
+ });
@@ -1,11 +1,13 @@
1
1
  {
2
- "name": "ssr-app",
2
+ "name": "ssr-version",
3
3
  "private": true,
4
4
  "version": "0.0.0",
5
5
  "type": "module",
6
6
  "scripts": {
7
- "dev": "node dev.js",
8
- "build": "node build.js",
7
+ "dev": "vite",
8
+ "build:client": "vite build",
9
+ "build:server": "vite build --ssr",
10
+ "build": "npm run build:client && npm run build:server",
9
11
  "start": "node dist/server.js"
10
12
  },
11
13
  "dependencies": {
@@ -13,9 +15,9 @@
13
15
  "frontend-hamroun": "latest"
14
16
  },
15
17
  "devDependencies": {
16
- "esbuild": "^0.19.0",
17
18
  "@types/express": "^4.17.17",
18
19
  "@types/node": "^20.5.0",
19
- "typescript": "^5.0.0"
20
+ "typescript": "^5.0.0",
21
+ "vite": "^4.4.9"
20
22
  }
21
23
  }
@@ -1,22 +0,0 @@
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');
@@ -1,27 +0,0 @@
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');