frontend-hamroun 1.2.79 → 1.2.82

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 (259) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +129 -1513
  3. package/bin/cli.js +506 -145
  4. package/dist/index.cjs +2 -0
  5. package/dist/index.cjs.map +1 -0
  6. package/dist/index.client.cjs +2 -0
  7. package/dist/index.client.cjs.map +1 -0
  8. package/dist/index.client.js +26 -0
  9. package/dist/index.client.js.map +1 -0
  10. package/dist/index.js +299 -1
  11. package/dist/index.js.map +1 -0
  12. package/dist/jsx-runtime.cjs +2 -0
  13. package/dist/jsx-runtime.cjs.map +1 -0
  14. package/dist/jsx-runtime.js +93 -1
  15. package/dist/jsx-runtime.js.map +1 -0
  16. package/dist/renderer-Bo9zkUZ_.js +52 -0
  17. package/dist/renderer-Bo9zkUZ_.js.map +1 -0
  18. package/dist/renderer-Din1y3YM.cjs +2 -0
  19. package/dist/renderer-Din1y3YM.cjs.map +1 -0
  20. package/dist/server-renderer-CqIpQ-od.cjs +2 -0
  21. package/dist/server-renderer-CqIpQ-od.cjs.map +1 -0
  22. package/dist/server-renderer-QHt45Ip2.js +255 -0
  23. package/dist/server-renderer-QHt45Ip2.js.map +1 -0
  24. package/dist/server-renderer.cjs +2 -0
  25. package/dist/server-renderer.cjs.map +1 -0
  26. package/dist/server-renderer.js +5 -1
  27. package/dist/server-renderer.js.map +1 -0
  28. package/package.json +77 -120
  29. package/templates/basic-app/build.js +22 -0
  30. package/templates/basic-app/dev.js +27 -0
  31. package/templates/basic-app/esbuild.config.js +28 -0
  32. package/templates/basic-app/index.html +1 -1
  33. package/templates/basic-app/package.json +29 -28
  34. package/templates/basic-app/server.js +24 -0
  35. package/templates/basic-app/src/App.jsx +16 -0
  36. package/templates/basic-app/src/App.tsx +26 -0
  37. package/templates/basic-app/src/client.jsx +5 -0
  38. package/templates/basic-app/src/client.tsx +11 -0
  39. package/templates/basic-app/src/components/Counter.jsx +13 -0
  40. package/templates/basic-app/src/components/Counter.tsx +18 -0
  41. package/templates/basic-app/src/jsx-shim.js +3 -0
  42. package/templates/basic-app/src/jsx-shim.ts +11 -0
  43. package/templates/basic-app/src/main.jsx +98 -0
  44. package/templates/basic-app/src/main.tsx +0 -1
  45. package/templates/basic-app/src/server.js +47 -0
  46. package/templates/basic-app/src/server.ts +52 -0
  47. package/templates/basic-app/tsconfig.server.json +11 -0
  48. package/templates/complete-app/lib/frontend-hamroun.js +182 -0
  49. package/templates/complete-app/package.json +2 -1
  50. package/templates/complete-app/pages/about.jsx +0 -0
  51. package/templates/complete-app/pages/index.jsx +0 -0
  52. package/templates/complete-app/pages/wasm-demo.jsx +0 -0
  53. package/templates/complete-app/public/client.js +58 -49
  54. package/templates/complete-app/public/index.html +88 -17
  55. package/templates/complete-app/public/styles.css +30 -533
  56. package/templates/complete-app/server.js +31 -222
  57. package/templates/complete-app/wasm/build.bat +0 -0
  58. package/templates/complete-app/wasm/build.sh +0 -0
  59. package/templates/complete-app/wasm/example.go +0 -0
  60. package/templates/fullstack-app/build/main.js +130 -101
  61. package/templates/fullstack-app/build/main.js.map +4 -4
  62. package/templates/fullstack-app/package-lock.json +1773 -566
  63. package/templates/ssr-template/esbuild.config.js +33 -0
  64. package/templates/ssr-template/jsx-shim.js +1 -0
  65. package/templates/ssr-template/package.json +22 -16
  66. package/templates/ssr-template/src/App.tsx +12 -52
  67. package/templates/ssr-template/src/client.tsx +3 -17
  68. package/templates/ssr-template/src/server.ts +21 -204
  69. package/templates/ssr-template/tsconfig.json +10 -13
  70. package/templates/ssr-template/tsconfig.server.json +6 -14
  71. package/templates/wasm/build-wasm.js +228 -0
  72. package/templates/wasm/esbuild.config.js +63 -0
  73. package/templates/wasm/go/main.go +256 -0
  74. package/templates/wasm/go/wasm_exec.js +0 -0
  75. package/templates/wasm/index.html +97 -0
  76. package/templates/wasm/jsx-shim.js +9 -0
  77. package/templates/{go-wasm-app → wasm}/package-lock.json +5307 -3732
  78. package/templates/wasm/package.json +42 -0
  79. package/templates/wasm/public/example.wasm +0 -0
  80. package/templates/wasm/src/App.tsx +564 -0
  81. package/templates/wasm/src/client.tsx +220 -0
  82. package/templates/wasm/src/index.tsx +21 -0
  83. package/templates/wasm/src/server.ts +145 -0
  84. package/templates/wasm/tsconfig.json +21 -0
  85. package/templates/wasm/tsconfig.node.json +13 -0
  86. package/templates/wasm/tsconfig.server.json +23 -0
  87. package/templates/wasm/vite.config.ts +56 -0
  88. package/templates/wasm/wasm-loader.js +103 -0
  89. package/dist/batch/package.json +0 -16
  90. package/dist/client-router/package.json +0 -16
  91. package/dist/component/package.json +0 -16
  92. package/dist/context/package.json +0 -16
  93. package/dist/event-bus/package.json +0 -16
  94. package/dist/forms/package.json +0 -16
  95. package/dist/hooks/package.json +0 -16
  96. package/dist/hooks-0728361a.cjs +0 -1
  97. package/dist/hooks-b58f947c.js +0 -133
  98. package/dist/hooks.js +0 -1
  99. package/dist/hooks.mjs +0 -13
  100. package/dist/index.mjs +0 -137
  101. package/dist/jsx-runtime/package.json +0 -16
  102. package/dist/jsx-runtime.mjs +0 -64
  103. package/dist/lifecycle-events/package.json +0 -16
  104. package/dist/package.json +0 -71
  105. package/dist/render-component/package.json +0 -16
  106. package/dist/renderer/package.json +0 -16
  107. package/dist/renderer.js +0 -1
  108. package/dist/renderer.mjs +0 -27
  109. package/dist/router/package.json +0 -16
  110. package/dist/server/package.json +0 -17
  111. package/dist/server/src/batch.d.ts +0 -3
  112. package/dist/server/src/batch.js +0 -23
  113. package/dist/server/src/batch.js.map +0 -1
  114. package/dist/server/src/client-router.d.ts +0 -60
  115. package/dist/server/src/client-router.js +0 -210
  116. package/dist/server/src/client-router.js.map +0 -1
  117. package/dist/server/src/component.d.ts +0 -14
  118. package/dist/server/src/component.js +0 -106
  119. package/dist/server/src/component.js.map +0 -1
  120. package/dist/server/src/context.d.ts +0 -13
  121. package/dist/server/src/context.js +0 -21
  122. package/dist/server/src/context.js.map +0 -1
  123. package/dist/server/src/event-bus.d.ts +0 -23
  124. package/dist/server/src/event-bus.js +0 -75
  125. package/dist/server/src/event-bus.js.map +0 -1
  126. package/dist/server/src/forms.d.ts +0 -40
  127. package/dist/server/src/forms.js +0 -148
  128. package/dist/server/src/forms.js.map +0 -1
  129. package/dist/server/src/hooks.d.ts +0 -12
  130. package/dist/server/src/hooks.js +0 -170
  131. package/dist/server/src/hooks.js.map +0 -1
  132. package/dist/server/src/index.client.d.ts +0 -12
  133. package/dist/server/src/index.client.js +0 -14
  134. package/dist/server/src/index.client.js.map +0 -1
  135. package/dist/server/src/index.d.ts +0 -88
  136. package/dist/server/src/index.js +0 -79
  137. package/dist/server/src/index.js.map +0 -1
  138. package/dist/server/src/jsx-runtime/jsx-dev-runtime.d.ts +0 -1
  139. package/dist/server/src/jsx-runtime/jsx-dev-runtime.js +0 -2
  140. package/dist/server/src/jsx-runtime/jsx-dev-runtime.js.map +0 -1
  141. package/dist/server/src/jsx-runtime/jsx-runtime.d.ts +0 -4
  142. package/dist/server/src/jsx-runtime/jsx-runtime.js +0 -41
  143. package/dist/server/src/jsx-runtime/jsx-runtime.js.map +0 -1
  144. package/dist/server/src/jsx-runtime.d.ts +0 -20
  145. package/dist/server/src/jsx-runtime.js +0 -105
  146. package/dist/server/src/jsx-runtime.js.map +0 -1
  147. package/dist/server/src/lifecycle-events.d.ts +0 -108
  148. package/dist/server/src/lifecycle-events.js +0 -177
  149. package/dist/server/src/lifecycle-events.js.map +0 -1
  150. package/dist/server/src/renderComponent.d.ts +0 -13
  151. package/dist/server/src/renderComponent.js +0 -30
  152. package/dist/server/src/renderComponent.js.map +0 -1
  153. package/dist/server/src/renderer.d.ts +0 -2
  154. package/dist/server/src/renderer.js +0 -31
  155. package/dist/server/src/renderer.js.map +0 -1
  156. package/dist/server/src/router.d.ts +0 -55
  157. package/dist/server/src/router.js +0 -166
  158. package/dist/server/src/router.js.map +0 -1
  159. package/dist/server/src/server/api-router.d.ts +0 -15
  160. package/dist/server/src/server/api-router.js +0 -111
  161. package/dist/server/src/server/api-router.js.map +0 -1
  162. package/dist/server/src/server/auth.d.ts +0 -32
  163. package/dist/server/src/server/auth.js +0 -80
  164. package/dist/server/src/server/auth.js.map +0 -1
  165. package/dist/server/src/server/database.d.ts +0 -24
  166. package/dist/server/src/server/database.js +0 -135
  167. package/dist/server/src/server/database.js.map +0 -1
  168. package/dist/server/src/server/index.d.ts +0 -116
  169. package/dist/server/src/server/index.js +0 -508
  170. package/dist/server/src/server/index.js.map +0 -1
  171. package/dist/server/src/server/middleware.d.ts +0 -11
  172. package/dist/server/src/server/middleware.js +0 -46
  173. package/dist/server/src/server/middleware.js.map +0 -1
  174. package/dist/server/src/server/server.d.ts +0 -9
  175. package/dist/server/src/server/server.js +0 -87
  176. package/dist/server/src/server/server.js.map +0 -1
  177. package/dist/server/src/server/templates.d.ts +0 -30
  178. package/dist/server/src/server/templates.js +0 -208
  179. package/dist/server/src/server/templates.js.map +0 -1
  180. package/dist/server/src/server/types.d.ts +0 -38
  181. package/dist/server/src/server/types.js +0 -4
  182. package/dist/server/src/server/types.js.map +0 -1
  183. package/dist/server/src/server/utils.d.ts +0 -70
  184. package/dist/server/src/server/utils.js +0 -156
  185. package/dist/server/src/server/utils.js.map +0 -1
  186. package/dist/server/src/server/wasm.d.ts +0 -9
  187. package/dist/server/src/server/wasm.js +0 -117
  188. package/dist/server/src/server/wasm.js.map +0 -1
  189. package/dist/server/src/server-renderer.d.ts +0 -5
  190. package/dist/server/src/server-renderer.js +0 -106
  191. package/dist/server/src/server-renderer.js.map +0 -1
  192. package/dist/server/src/server-types.d.ts +0 -42
  193. package/dist/server/src/server-types.js +0 -6
  194. package/dist/server/src/server-types.js.map +0 -1
  195. package/dist/server/src/store.d.ts +0 -41
  196. package/dist/server/src/store.js +0 -99
  197. package/dist/server/src/store.js.map +0 -1
  198. package/dist/server/src/types.d.ts +0 -19
  199. package/dist/server/src/types.js +0 -2
  200. package/dist/server/src/types.js.map +0 -1
  201. package/dist/server/src/utils.d.ts +0 -46
  202. package/dist/server/src/utils.js +0 -144
  203. package/dist/server/src/utils.js.map +0 -1
  204. package/dist/server/src/vdom.d.ts +0 -8
  205. package/dist/server/src/vdom.js +0 -22
  206. package/dist/server/src/vdom.js.map +0 -1
  207. package/dist/server/src/wasm.d.ts +0 -36
  208. package/dist/server/src/wasm.js +0 -159
  209. package/dist/server/src/wasm.js.map +0 -1
  210. package/dist/server/tsconfig.server.tsbuildinfo +0 -1
  211. package/dist/server-renderer/package.json +0 -16
  212. package/dist/server-renderer.mjs +0 -64
  213. package/dist/store/package.json +0 -16
  214. package/dist/types/package.json +0 -16
  215. package/dist/utils/package.json +0 -16
  216. package/dist/vdom/package.json +0 -16
  217. package/dist/wasm/package.json +0 -16
  218. package/dist/wasm.js +0 -1
  219. package/dist/wasm.mjs +0 -103
  220. package/templates/basic-app/docs/rapport_pfe.aux +0 -27
  221. package/templates/basic-app/docs/rapport_pfe.log +0 -399
  222. package/templates/basic-app/docs/rapport_pfe.out +0 -10
  223. package/templates/basic-app/docs/rapport_pfe.pdf +0 -0
  224. package/templates/basic-app/docs/rapport_pfe.tex +0 -68
  225. package/templates/basic-app/docs/rapport_pfe.toc +0 -14
  226. package/templates/complete-app/package-lock.json +0 -2536
  227. package/templates/go-wasm-app/README.md +0 -38
  228. package/templates/go-wasm-app/babel.config.js +0 -21
  229. package/templates/go-wasm-app/build-client.js +0 -49
  230. package/templates/go-wasm-app/build-wasm.js +0 -237
  231. package/templates/go-wasm-app/build.config.js +0 -62
  232. package/templates/go-wasm-app/build.js +0 -218
  233. package/templates/go-wasm-app/package.json +0 -32
  234. package/templates/go-wasm-app/public/index.html +0 -128
  235. package/templates/go-wasm-app/public/styles.css +0 -197
  236. package/templates/go-wasm-app/public/wasm/example.wasm +0 -0
  237. package/templates/go-wasm-app/public/wasm/wasm_exec_node.js +0 -39
  238. package/templates/go-wasm-app/server.js +0 -70
  239. package/templates/go-wasm-app/src/App.jsx +0 -38
  240. package/templates/go-wasm-app/src/app.js +0 -173
  241. package/templates/go-wasm-app/src/client.js +0 -57
  242. package/templates/go-wasm-app/src/components/Footer.jsx +0 -13
  243. package/templates/go-wasm-app/src/components/Header.jsx +0 -19
  244. package/templates/go-wasm-app/src/components/WasmDemo.jsx +0 -120
  245. package/templates/go-wasm-app/src/main.jsx +0 -12
  246. package/templates/go-wasm-app/src/wasm/example.go +0 -75
  247. package/templates/go-wasm-app/tsconfig.server.json +0 -18
  248. package/templates/go-wasm-app/vite.config.js +0 -45
  249. package/templates/ssr-template/client.js +0 -58
  250. package/templates/ssr-template/package-lock.json +0 -2478
  251. package/templates/ssr-template/public/index.html +0 -47
  252. package/templates/ssr-template/readme.md +0 -188
  253. package/templates/ssr-template/server.js +0 -369
  254. package/templates/ssr-template/server.ts +0 -275
  255. package/templates/ssr-template/src/client.ts +0 -61
  256. package/templates/ssr-template/src/pages/index.tsx +0 -51
  257. package/templates/ssr-template/vite.config.js +0 -57
  258. /package/{dist/Counter.d.ts → templates/complete-app/api/hello.js} +0 -0
  259. /package/templates/{go-wasm-app/public/wasm → wasm/public}/wasm_exec.js +0 -0
@@ -0,0 +1,220 @@
1
+ import { jsx, render } from 'frontend-hamroun';
2
+ import { loadGoWasm } from '../wasm-loader.js';
3
+
4
+ // WASM Demo Component
5
+ function WasmDemo() {
6
+ const [wasmReady, setWasmReady] = useState(false);
7
+ const [result, setResult] = useState('');
8
+ const [input1, setInput1] = useState('5');
9
+ const [input2, setInput2] = useState('3');
10
+ const [fibInput, setFibInput] = useState('10');
11
+
12
+ useEffect(() => {
13
+ loadWasm();
14
+ }, []);
15
+
16
+ const loadWasm = async () => {
17
+ try {
18
+ await loadGoWasm('/example.wasm');
19
+ setWasmReady(true);
20
+ setResult('✅ Go WASM module loaded successfully!');
21
+ } catch (error) {
22
+ setResult(`❌ Failed to load WASM: ${error.message}`);
23
+ }
24
+ };
25
+
26
+ const testAdd = () => {
27
+ if (!wasmReady) return;
28
+ try {
29
+ const num1 = parseFloat(input1);
30
+ const num2 = parseFloat(input2);
31
+ const result = (window as any).add(num1, num2);
32
+ setResult(`Add result: ${num1} + ${num2} = ${result}`);
33
+ } catch (error) {
34
+ setResult(`Error: ${error.message}`);
35
+ }
36
+ };
37
+
38
+ const testFibonacci = () => {
39
+ if (!wasmReady) return;
40
+ try {
41
+ const n = parseInt(fibInput);
42
+ const result = (window as any).fibonacci(n);
43
+ setResult(`Fibonacci(${n}) = ${result}`);
44
+ } catch (error) {
45
+ setResult(`Error: ${error.message}`);
46
+ }
47
+ };
48
+
49
+ const testProcessArray = () => {
50
+ if (!wasmReady) return;
51
+ try {
52
+ const testArray = [1, 2, 3, 4, 5];
53
+ const result = (window as any).processArray(testArray);
54
+ const resultArray = Array.from(result);
55
+ setResult(`Process array [${testArray.join(', ')}] = [${resultArray.join(', ')}]`);
56
+ } catch (error) {
57
+ setResult(`Error: ${error.message}`);
58
+ }
59
+ };
60
+
61
+ const testFormatMessage = () => {
62
+ if (!wasmReady) return;
63
+ try {
64
+ const message = 'Hello from JavaScript!';
65
+ const result = (window as any).formatMessage(message);
66
+ setResult(`Formatted: ${result}`);
67
+ } catch (error) {
68
+ setResult(`Error: ${error.message}`);
69
+ }
70
+ };
71
+
72
+ const testPerformance = () => {
73
+ if (!wasmReady) return;
74
+ try {
75
+ const iterations = 100000;
76
+ const startTime = performance.now();
77
+ const result = (window as any).performanceBenchmark(iterations);
78
+ const endTime = performance.now();
79
+
80
+ setResult(
81
+ `Performance test: ${result.message}\n` +
82
+ `Result: ${result.result}\n` +
83
+ `Time: ${(endTime - startTime).toFixed(2)}ms`
84
+ );
85
+ } catch (error) {
86
+ setResult(`Error: ${error.message}`);
87
+ }
88
+ };
89
+
90
+ const testTypeDemo = () => {
91
+ if (!wasmReady) return;
92
+ try {
93
+ const result = (window as any).typeDemo();
94
+ setResult(
95
+ `Type demo results:\n` +
96
+ `String: ${result.string}\n` +
97
+ `Number: ${result.number}\n` +
98
+ `Boolean: ${result.boolean}\n` +
99
+ `Array: [${Array.from(result.array).join(', ')}]`
100
+ );
101
+ } catch (error) {
102
+ setResult(`Error: ${error.message}`);
103
+ }
104
+ };
105
+
106
+ return jsx('div', {
107
+ className: 'wasm-demo',
108
+ children: [
109
+ jsx('h1', { children: '🚀 Frontend Hamroun + Go WASM Demo' }),
110
+
111
+ jsx('div', {
112
+ className: 'status',
113
+ children: jsx('p', {
114
+ className: wasmReady ? 'ready' : 'loading',
115
+ children: wasmReady ? '✅ WASM Ready' : '⏳ Loading WASM...'
116
+ })
117
+ }),
118
+
119
+ jsx('div', {
120
+ className: 'controls',
121
+ children: [
122
+ jsx('h2', { children: '🧮 Arithmetic Operations' }),
123
+ jsx('div', {
124
+ className: 'input-group',
125
+ children: [
126
+ jsx('input', {
127
+ type: 'number',
128
+ value: input1,
129
+ onChange: (e: any) => setInput1(e.target.value),
130
+ placeholder: 'First number'
131
+ }),
132
+ jsx('span', { children: ' + ' }),
133
+ jsx('input', {
134
+ type: 'number',
135
+ value: input2,
136
+ onChange: (e: any) => setInput2(e.target.value),
137
+ placeholder: 'Second number'
138
+ }),
139
+ jsx('button', {
140
+ onClick: testAdd,
141
+ disabled: !wasmReady,
142
+ children: 'Calculate'
143
+ })
144
+ ]
145
+ }),
146
+
147
+ jsx('h2', { children: '🔢 Fibonacci Sequence' }),
148
+ jsx('div', {
149
+ className: 'input-group',
150
+ children: [
151
+ jsx('input', {
152
+ type: 'number',
153
+ value: fibInput,
154
+ onChange: (e: any) => setFibInput(e.target.value),
155
+ placeholder: 'Fibonacci number'
156
+ }),
157
+ jsx('button', {
158
+ onClick: testFibonacci,
159
+ disabled: !wasmReady,
160
+ children: 'Calculate Fibonacci'
161
+ })
162
+ ]
163
+ }),
164
+
165
+ jsx('h2', { children: '🔧 Advanced Functions' }),
166
+ jsx('div', {
167
+ className: 'button-group',
168
+ children: [
169
+ jsx('button', {
170
+ onClick: testProcessArray,
171
+ disabled: !wasmReady,
172
+ children: 'Process Array'
173
+ }),
174
+ jsx('button', {
175
+ onClick: testFormatMessage,
176
+ disabled: !wasmReady,
177
+ children: 'Format Message'
178
+ }),
179
+ jsx('button', {
180
+ onClick: testPerformance,
181
+ disabled: !wasmReady,
182
+ children: 'Performance Test'
183
+ }),
184
+ jsx('button', {
185
+ onClick: testTypeDemo,
186
+ disabled: !wasmReady,
187
+ children: 'Type Demo'
188
+ })
189
+ ]
190
+ })
191
+ ]
192
+ }),
193
+
194
+ jsx('div', {
195
+ className: 'result',
196
+ children: [
197
+ jsx('h3', { children: '📋 Result:' }),
198
+ jsx('pre', { children: result })
199
+ ]
200
+ })
201
+ ]
202
+ });
203
+ }
204
+
205
+ // App Component
206
+ function App() {
207
+ return jsx('div', {
208
+ className: 'app',
209
+ children: jsx(WasmDemo, {})
210
+ });
211
+ }
212
+
213
+ // Render the app
214
+ const appElement = document.getElementById('app');
215
+ if (appElement) {
216
+ render(jsx(App, {}), appElement);
217
+ }
218
+
219
+ // Import statements for hooks
220
+ import { useState, useEffect } from 'frontend-hamroun';
@@ -0,0 +1,21 @@
1
+ import { jsx, render } from 'frontend-hamroun';
2
+ import App from './App.tsx';
3
+
4
+ // Simple render without infinite loops
5
+ function startApp() {
6
+ const appElement = jsx(App, {});
7
+ const rootElement = document.getElementById('app');
8
+
9
+ if (rootElement) {
10
+ render(appElement, rootElement);
11
+ } else {
12
+ console.error('Root element not found');
13
+ }
14
+ }
15
+
16
+ // Start when DOM is ready
17
+ if (document.readyState === 'loading') {
18
+ document.addEventListener('DOMContentLoaded', startApp);
19
+ } else {
20
+ startApp();
21
+ }
@@ -0,0 +1,145 @@
1
+ import { createServer } from 'frontend-hamroun';
2
+ import { loadGoWasmFromFile } from 'frontend-hamroun';
3
+ import path from 'path';
4
+ import { fileURLToPath } from 'url';
5
+
6
+ const __filename = fileURLToPath(import.meta.url);
7
+ const __dirname = path.dirname(__filename);
8
+
9
+ // Create server instance
10
+ const server = createServer({
11
+ port: 3000,
12
+ staticDir: './public',
13
+ pagesDir: './src/pages',
14
+ apiDir: './src/api'
15
+ });
16
+
17
+ // Server-side WASM integration example
18
+ async function initServerWasm() {
19
+ try {
20
+ console.log('🔄 Initializing server-side Go WASM...');
21
+
22
+ const wasmPath = path.join(__dirname, '..', 'public', 'example.wasm');
23
+ const wasmInstance = await loadGoWasmFromFile(wasmPath, {
24
+ debug: true,
25
+ onLoad: (instance) => {
26
+ console.log('✅ Go WASM loaded on server side');
27
+
28
+ // Test server-side WASM functions
29
+ try {
30
+ if (instance.functions.add) {
31
+ const result = instance.functions.add(5, 3);
32
+ console.log('Server WASM test - add(5, 3):', result);
33
+ }
34
+
35
+ if (instance.functions.fibonacci) {
36
+ const fibResult = instance.functions.fibonacci(10);
37
+ console.log('Server WASM test - fibonacci(10):', fibResult);
38
+ }
39
+ } catch (error) {
40
+ console.log('Server WASM test functions not available:', error.message);
41
+ }
42
+ }
43
+ });
44
+
45
+ // Make WASM instance available to API routes
46
+ server.getExpressApp().locals.wasm = wasmInstance;
47
+
48
+ } catch (error) {
49
+ console.error('❌ Failed to initialize server-side WASM:', error);
50
+ }
51
+ }
52
+
53
+ // API route example using server-side WASM
54
+ server.getExpressApp().get('/api/wasm/compute', async (req, res) => {
55
+ try {
56
+ const { operation, a, b } = req.query;
57
+ const wasmInstance = req.app.locals.wasm;
58
+
59
+ if (!wasmInstance) {
60
+ return res.status(500).json({ error: 'WASM not initialized' });
61
+ }
62
+
63
+ let result;
64
+ switch (operation) {
65
+ case 'add':
66
+ if (wasmInstance.functions.add) {
67
+ result = wasmInstance.functions.add(Number(a), Number(b));
68
+ } else {
69
+ throw new Error('Add function not available');
70
+ }
71
+ break;
72
+ case 'fibonacci':
73
+ if (wasmInstance.functions.fibonacci) {
74
+ result = wasmInstance.functions.fibonacci(Number(a));
75
+ } else {
76
+ throw new Error('Fibonacci function not available');
77
+ }
78
+ break;
79
+ default:
80
+ throw new Error('Unknown operation');
81
+ }
82
+
83
+ res.json({
84
+ success: true,
85
+ operation,
86
+ result,
87
+ serverTime: new Date().toISOString()
88
+ });
89
+ } catch (error) {
90
+ res.status(400).json({
91
+ success: false,
92
+ error: error.message
93
+ });
94
+ }
95
+ });
96
+
97
+ // Health check endpoint
98
+ server.getExpressApp().get('/api/health', (req, res) => {
99
+ res.json({
100
+ status: 'healthy',
101
+ wasm: !!req.app.locals.wasm,
102
+ timestamp: new Date().toISOString()
103
+ });
104
+ });
105
+
106
+ // Start server
107
+ async function startServer() {
108
+ try {
109
+ // Initialize WASM first
110
+ await initServerWasm();
111
+
112
+ // Start the server
113
+ await server.start();
114
+
115
+ console.log('🚀 Server started successfully!');
116
+ console.log('📋 Available endpoints:');
117
+ console.log(' • http://localhost:3000 - Main app');
118
+ console.log(' • http://localhost:3000/api/health - Health check');
119
+ console.log(' • http://localhost:3000/api/wasm/compute - WASM compute API');
120
+ console.log('');
121
+ console.log('💡 Example API calls:');
122
+ console.log(' • /api/wasm/compute?operation=add&a=5&b=3');
123
+ console.log(' • /api/wasm/compute?operation=fibonacci&a=10');
124
+
125
+ } catch (error) {
126
+ console.error('❌ Failed to start server:', error);
127
+ process.exit(1);
128
+ }
129
+ }
130
+
131
+ // Graceful shutdown
132
+ process.on('SIGTERM', async () => {
133
+ console.log('🛑 Received SIGTERM, shutting down gracefully...');
134
+ await server.stop();
135
+ process.exit(0);
136
+ });
137
+
138
+ process.on('SIGINT', async () => {
139
+ console.log('🛑 Received SIGINT, shutting down gracefully...');
140
+ await server.stop();
141
+ process.exit(0);
142
+ });
143
+
144
+ // Start the server
145
+ startServer();
@@ -0,0 +1,21 @@
1
+ {
2
+ "compilerOptions": {
3
+ "target": "ES2020",
4
+ "lib": ["ES2020", "DOM", "DOM.Iterable"],
5
+ "module": "ESNext",
6
+ "skipLibCheck": true,
7
+ "moduleResolution": "bundler",
8
+ "allowImportingTsExtensions": true,
9
+ "resolveJsonModule": true,
10
+ "isolatedModules": true,
11
+ "noEmit": true,
12
+ "jsx": "preserve",
13
+ "jsxImportSource": "frontend-hamroun",
14
+ "strict": true,
15
+ "noUnusedLocals": true,
16
+ "noUnusedParameters": true,
17
+ "noFallthroughCasesInSwitch": true
18
+ },
19
+ "include": ["src"],
20
+ "references": [{ "path": "./tsconfig.node.json" }]
21
+ }
@@ -0,0 +1,13 @@
1
+ {
2
+ "compilerOptions": {
3
+ "composite": true,
4
+ "skipLibCheck": true,
5
+ "module": "ESNext",
6
+ "moduleResolution": "bundler",
7
+ "allowSyntheticDefaultImports": true,
8
+ "strict": true,
9
+ "noEmit": true,
10
+ "types": ["node"]
11
+ },
12
+ "include": ["vite.config.*", "vitest.config.*", "build-wasm.js", "esbuild.config.js"]
13
+ }
@@ -0,0 +1,23 @@
1
+ {
2
+ "extends": "./tsconfig.json",
3
+ "compilerOptions": {
4
+ "module": "ESNext",
5
+ "outDir": "dist",
6
+ "noEmit": false,
7
+ "jsx": "preserve",
8
+ "moduleResolution": "bundler",
9
+ "composite": true,
10
+ "skipLibCheck": true,
11
+ "allowSyntheticDefaultImports": true,
12
+ "strict": true,
13
+ "target": "ES2020",
14
+ "lib": ["ES2020"],
15
+ "types": ["node"],
16
+ "esModuleInterop": true,
17
+ "allowImportingTsExtensions": true,
18
+ "resolveJsonModule": true,
19
+ "isolatedModules": true
20
+ },
21
+ "include": ["src/server.ts", "**/*.ts", "**/*.js"],
22
+ "exclude": ["node_modules", "dist"]
23
+ }
@@ -0,0 +1,56 @@
1
+ import { defineConfig } from 'vite';
2
+ import path from 'path';
3
+
4
+ export default defineConfig({
5
+ resolve: {
6
+ alias: {
7
+ 'frontend-hamroun': path.resolve(__dirname, 'node_modules/frontend-hamroun')
8
+ }
9
+ },
10
+ build: {
11
+ outDir: 'dist',
12
+ ssr: 'src/server.ts',
13
+ rollupOptions: {
14
+ input: {
15
+ client: './src/client.tsx',
16
+ server: './src/server.ts'
17
+ },
18
+ output: {
19
+ entryFileNames: '[name].js',
20
+ chunkFileNames: 'assets/[name]-[hash].js',
21
+ assetFileNames: 'assets/[name]-[hash].[ext]'
22
+ },
23
+ // Exclude WASM build script from hot reload and external dependencies
24
+ external: ['./build-wasm.js']
25
+ },
26
+ target: 'esnext'
27
+ },
28
+ esbuild: {
29
+ jsxFactory: '_jsx',
30
+ jsxFragment: '_Fragment',
31
+ jsxInject: `import { jsx as _jsx, Fragment as _Fragment } from 'frontend-hamroun'`
32
+ },
33
+ server: {
34
+ fs: {
35
+ allow: ['..']
36
+ },
37
+ headers: {
38
+ 'Cross-Origin-Opener-Policy': 'same-origin',
39
+ 'Cross-Origin-Embedder-Policy': 'require-corp'
40
+ },
41
+ watch: {
42
+ // Prevent watching go directory and wasm files to avoid infinite loops
43
+ ignored: [
44
+ '**/go/**',
45
+ '**/*.wasm',
46
+ '**/build-wasm.js',
47
+ '**/wasm_exec.js'
48
+ ]
49
+ }
50
+ },
51
+ optimizeDeps: {
52
+ exclude: ['frontend-hamroun']
53
+ },
54
+ // Prevent Vite from processing WASM files
55
+ assetsInclude: ['**/*.wasm']
56
+ });
@@ -0,0 +1,103 @@
1
+ /**
2
+ * WASM Loader for Frontend Hamroun Go WASM integration
3
+ */
4
+
5
+ let wasmInstance = null;
6
+ let wasmReady = false;
7
+
8
+ export async function loadGoWasm(wasmPath, options = {}) {
9
+ if (wasmReady) {
10
+ return wasmInstance;
11
+ }
12
+
13
+ try {
14
+ console.log('🔄 Loading Go WASM module from:', wasmPath);
15
+
16
+ // Load the Go WASM runtime
17
+ if (!window.Go) {
18
+ await loadWasmExecJs();
19
+ }
20
+
21
+ // Create Go instance
22
+ const go = new window.Go();
23
+
24
+ // Fetch and instantiate WASM
25
+ const wasmModule = await WebAssembly.instantiateStreaming(
26
+ fetch(wasmPath),
27
+ go.importObject
28
+ );
29
+
30
+ // Run the Go program
31
+ go.run(wasmModule.instance);
32
+
33
+ wasmInstance = {
34
+ instance: wasmModule.instance,
35
+ module: wasmModule.module,
36
+ go: go
37
+ };
38
+
39
+ wasmReady = true;
40
+
41
+ console.log('✅ Go WASM module loaded successfully!');
42
+
43
+ if (options.onLoad) {
44
+ options.onLoad(wasmInstance);
45
+ }
46
+
47
+ return wasmInstance;
48
+
49
+ } catch (error) {
50
+ console.error('❌ Failed to load Go WASM module:', error);
51
+ throw error;
52
+ }
53
+ }
54
+
55
+ async function loadWasmExecJs() {
56
+ return new Promise((resolve, reject) => {
57
+ const script = document.createElement('script');
58
+ script.src = '/wasm_exec.js';
59
+ script.onload = resolve;
60
+ script.onerror = () => reject(new Error('Failed to load wasm_exec.js'));
61
+ document.head.appendChild(script);
62
+ });
63
+ }
64
+
65
+ export function isWasmReady() {
66
+ return wasmReady;
67
+ }
68
+
69
+ export function getWasmInstance() {
70
+ return wasmInstance;
71
+ }
72
+
73
+ // Utility functions for calling Go functions safely
74
+ export function callGoFunction(functionName, ...args) {
75
+ if (!wasmReady) {
76
+ throw new Error('WASM module not ready');
77
+ }
78
+
79
+ if (typeof window[functionName] !== 'function') {
80
+ throw new Error(`Go function '${functionName}' not found`);
81
+ }
82
+
83
+ return window[functionName](...args);
84
+ }
85
+
86
+ export async function waitForWasm(timeout = 10000) {
87
+ if (wasmReady) return wasmInstance;
88
+
89
+ return new Promise((resolve, reject) => {
90
+ const checkInterval = setInterval(() => {
91
+ if (wasmReady) {
92
+ clearInterval(checkInterval);
93
+ clearTimeout(timeoutId);
94
+ resolve(wasmInstance);
95
+ }
96
+ }, 100);
97
+
98
+ const timeoutId = setTimeout(() => {
99
+ clearInterval(checkInterval);
100
+ reject(new Error('WASM loading timeout'));
101
+ }, timeout);
102
+ });
103
+ }
@@ -1,16 +0,0 @@
1
- {
2
- "name": "frontend-hamroun/batch",
3
- "version": "1.2.79",
4
- "type": "module",
5
- "main": "./index.js",
6
- "module": "./index.mjs",
7
- "types": "./index.d.ts",
8
- "exports": {
9
- ".": {
10
- "import": "./index.mjs",
11
- "require": "./index.js",
12
- "types": "./index.d.ts"
13
- }
14
- },
15
- "sideEffects": false
16
- }
@@ -1,16 +0,0 @@
1
- {
2
- "name": "frontend-hamroun/client-router",
3
- "version": "1.2.79",
4
- "type": "module",
5
- "main": "./index.js",
6
- "module": "./index.mjs",
7
- "types": "./index.d.ts",
8
- "exports": {
9
- ".": {
10
- "import": "./index.mjs",
11
- "require": "./index.js",
12
- "types": "./index.d.ts"
13
- }
14
- },
15
- "sideEffects": false
16
- }
@@ -1,16 +0,0 @@
1
- {
2
- "name": "frontend-hamroun/component",
3
- "version": "1.2.79",
4
- "type": "module",
5
- "main": "./index.js",
6
- "module": "./index.mjs",
7
- "types": "./index.d.ts",
8
- "exports": {
9
- ".": {
10
- "import": "./index.mjs",
11
- "require": "./index.js",
12
- "types": "./index.d.ts"
13
- }
14
- },
15
- "sideEffects": false
16
- }
@@ -1,16 +0,0 @@
1
- {
2
- "name": "frontend-hamroun/context",
3
- "version": "1.2.79",
4
- "type": "module",
5
- "main": "./index.js",
6
- "module": "./index.mjs",
7
- "types": "./index.d.ts",
8
- "exports": {
9
- ".": {
10
- "import": "./index.mjs",
11
- "require": "./index.js",
12
- "types": "./index.d.ts"
13
- }
14
- },
15
- "sideEffects": false
16
- }
@@ -1,16 +0,0 @@
1
- {
2
- "name": "frontend-hamroun/event-bus",
3
- "version": "1.2.79",
4
- "type": "module",
5
- "main": "./index.js",
6
- "module": "./index.mjs",
7
- "types": "./index.d.ts",
8
- "exports": {
9
- ".": {
10
- "import": "./index.mjs",
11
- "require": "./index.js",
12
- "types": "./index.d.ts"
13
- }
14
- },
15
- "sideEffects": false
16
- }