create-fluxstack 1.0.13 → 1.0.14

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 (214) hide show
  1. package/.env.example +29 -29
  2. package/app/client/README.md +69 -69
  3. package/app/client/index.html +14 -13
  4. package/app/client/src/App.tsx +157 -524
  5. package/app/client/src/components/ErrorBoundary.tsx +107 -0
  6. package/app/client/src/components/ErrorDisplay.css +365 -0
  7. package/app/client/src/components/ErrorDisplay.tsx +258 -0
  8. package/app/client/src/components/FluxStackConfig.tsx +1321 -0
  9. package/app/client/src/components/HybridLiveCounter.tsx +140 -0
  10. package/app/client/src/components/LiveClock.tsx +286 -0
  11. package/app/client/src/components/MainLayout.tsx +390 -0
  12. package/app/client/src/components/SidebarNavigation.tsx +391 -0
  13. package/app/client/src/components/StateDemo.tsx +178 -0
  14. package/app/client/src/components/SystemMonitor.tsx +1038 -0
  15. package/app/client/src/components/Teste.tsx +104 -0
  16. package/app/client/src/components/UserProfile.tsx +809 -0
  17. package/app/client/src/hooks/useAuth.ts +39 -0
  18. package/app/client/src/hooks/useNotifications.ts +56 -0
  19. package/app/client/src/lib/eden-api.ts +189 -53
  20. package/app/client/src/lib/errors.ts +340 -0
  21. package/app/client/src/lib/hooks/useErrorHandler.ts +258 -0
  22. package/app/client/src/lib/index.ts +45 -0
  23. package/app/client/src/main.tsx +3 -2
  24. package/app/client/src/pages/ApiDocs.tsx +182 -0
  25. package/app/client/src/pages/Demo.tsx +174 -0
  26. package/app/client/src/pages/HybridLive.tsx +263 -0
  27. package/app/client/src/pages/Overview.tsx +155 -0
  28. package/app/client/src/store/README.md +43 -0
  29. package/app/client/src/store/index.ts +16 -0
  30. package/app/client/src/store/slices/uiSlice.ts +151 -0
  31. package/app/client/src/store/slices/userSlice.ts +161 -0
  32. package/app/client/src/test/README.md +257 -0
  33. package/app/client/src/test/setup.ts +70 -0
  34. package/app/client/src/test/types.ts +12 -0
  35. package/app/client/src/vite-env.d.ts +1 -1
  36. package/app/client/tsconfig.app.json +44 -43
  37. package/app/client/tsconfig.json +7 -7
  38. package/app/client/tsconfig.node.json +25 -25
  39. package/app/client/zustand-setup.md +65 -0
  40. package/app/server/controllers/users.controller.ts +68 -68
  41. package/app/server/index.ts +9 -1
  42. package/app/server/live/CounterComponent.ts +191 -0
  43. package/app/server/live/FluxStackConfig.ts +529 -0
  44. package/app/server/live/LiveClockComponent.ts +214 -0
  45. package/app/server/live/SidebarNavigation.ts +156 -0
  46. package/app/server/live/SystemMonitor.ts +594 -0
  47. package/app/server/live/SystemMonitorIntegration.ts +151 -0
  48. package/app/server/live/TesteComponent.ts +87 -0
  49. package/app/server/live/UserProfileComponent.ts +135 -0
  50. package/app/server/live/register-components.ts +28 -0
  51. package/app/server/middleware/auth.ts +136 -0
  52. package/app/server/middleware/errorHandling.ts +250 -0
  53. package/app/server/middleware/index.ts +10 -0
  54. package/app/server/middleware/rateLimit.ts +193 -0
  55. package/app/server/middleware/requestLogging.ts +215 -0
  56. package/app/server/middleware/validation.ts +270 -0
  57. package/app/server/routes/index.ts +14 -2
  58. package/app/server/routes/upload.ts +92 -0
  59. package/app/server/routes/users.routes.ts +2 -9
  60. package/app/server/services/NotificationService.ts +302 -0
  61. package/app/server/services/UserService.ts +222 -0
  62. package/app/server/services/index.ts +46 -0
  63. package/core/cli/commands/plugin-deps.ts +263 -0
  64. package/core/cli/generators/README.md +339 -0
  65. package/core/cli/generators/component.ts +770 -0
  66. package/core/cli/generators/controller.ts +299 -0
  67. package/core/cli/generators/index.ts +144 -0
  68. package/core/cli/generators/interactive.ts +228 -0
  69. package/core/cli/generators/prompts.ts +83 -0
  70. package/core/cli/generators/route.ts +513 -0
  71. package/core/cli/generators/service.ts +465 -0
  72. package/core/cli/generators/template-engine.ts +154 -0
  73. package/core/cli/generators/types.ts +71 -0
  74. package/core/cli/generators/utils.ts +192 -0
  75. package/core/cli/index.ts +69 -0
  76. package/core/cli/plugin-discovery.ts +16 -85
  77. package/core/client/fluxstack.ts +17 -0
  78. package/core/client/hooks/index.ts +7 -0
  79. package/core/client/hooks/state-validator.ts +130 -0
  80. package/core/client/hooks/useAuth.ts +49 -0
  81. package/core/client/hooks/useChunkedUpload.ts +258 -0
  82. package/core/client/hooks/useHybridLiveComponent.ts +967 -0
  83. package/core/client/hooks/useWebSocket.ts +373 -0
  84. package/core/client/index.ts +47 -0
  85. package/core/client/state/createStore.ts +193 -0
  86. package/core/client/state/index.ts +15 -0
  87. package/core/config/env-dynamic.ts +1 -1
  88. package/core/config/env.ts +2 -1
  89. package/core/config/runtime-config.ts +3 -3
  90. package/core/config/schema.ts +84 -49
  91. package/core/framework/server.ts +30 -0
  92. package/core/index.ts +25 -0
  93. package/core/live/ComponentRegistry.ts +399 -0
  94. package/core/live/types.ts +164 -0
  95. package/core/plugins/built-in/live-components/commands/create-live-component.ts +1201 -0
  96. package/core/plugins/built-in/live-components/index.ts +27 -0
  97. package/core/plugins/built-in/logger/index.ts +1 -1
  98. package/core/plugins/built-in/monitoring/index.ts +1 -1
  99. package/core/plugins/built-in/static/index.ts +1 -1
  100. package/core/plugins/built-in/swagger/index.ts +1 -1
  101. package/core/plugins/built-in/vite/index.ts +1 -1
  102. package/core/plugins/dependency-manager.ts +384 -0
  103. package/core/plugins/index.ts +5 -1
  104. package/core/plugins/manager.ts +7 -3
  105. package/core/plugins/registry.ts +88 -10
  106. package/core/plugins/types.ts +11 -11
  107. package/core/server/framework.ts +43 -0
  108. package/core/server/index.ts +11 -1
  109. package/core/server/live/ComponentRegistry.ts +1017 -0
  110. package/core/server/live/FileUploadManager.ts +272 -0
  111. package/core/server/live/LiveComponentPerformanceMonitor.ts +930 -0
  112. package/core/server/live/SingleConnectionManager.ts +0 -0
  113. package/core/server/live/StateSignature.ts +644 -0
  114. package/core/server/live/WebSocketConnectionManager.ts +688 -0
  115. package/core/server/live/websocket-plugin.ts +435 -0
  116. package/core/server/middleware/errorHandling.ts +141 -0
  117. package/core/server/middleware/index.ts +16 -0
  118. package/core/server/plugins/static-files-plugin.ts +232 -0
  119. package/core/server/services/BaseService.ts +95 -0
  120. package/core/server/services/ServiceContainer.ts +144 -0
  121. package/core/server/services/index.ts +9 -0
  122. package/core/templates/create-project.ts +46 -2
  123. package/core/testing/index.ts +10 -0
  124. package/core/testing/setup.ts +74 -0
  125. package/core/types/build.ts +38 -14
  126. package/core/types/types.ts +319 -0
  127. package/core/utils/env-runtime.ts +7 -0
  128. package/core/utils/errors/handlers.ts +264 -39
  129. package/core/utils/errors/index.ts +528 -18
  130. package/core/utils/errors/middleware.ts +114 -0
  131. package/core/utils/logger/formatters.ts +222 -0
  132. package/core/utils/logger/index.ts +167 -48
  133. package/core/utils/logger/middleware.ts +253 -0
  134. package/core/utils/logger/performance.ts +384 -0
  135. package/core/utils/logger/transports.ts +365 -0
  136. package/create-fluxstack.ts +296 -296
  137. package/fluxstack.config.ts +17 -1
  138. package/package-template.json +66 -66
  139. package/package.json +31 -6
  140. package/public/README.md +16 -0
  141. package/vite.config.ts +29 -14
  142. package/.claude/settings.local.json +0 -74
  143. package/.github/workflows/ci-build-tests.yml +0 -480
  144. package/.github/workflows/dependency-management.yml +0 -324
  145. package/.github/workflows/release-validation.yml +0 -355
  146. package/.kiro/specs/fluxstack-architecture-optimization/design.md +0 -700
  147. package/.kiro/specs/fluxstack-architecture-optimization/requirements.md +0 -127
  148. package/.kiro/specs/fluxstack-architecture-optimization/tasks.md +0 -330
  149. package/CLAUDE.md +0 -200
  150. package/Dockerfile +0 -58
  151. package/Dockerfile.backend +0 -52
  152. package/Dockerfile.frontend +0 -54
  153. package/README-Docker.md +0 -85
  154. package/ai-context/00-QUICK-START.md +0 -86
  155. package/ai-context/README.md +0 -88
  156. package/ai-context/development/eden-treaty-guide.md +0 -362
  157. package/ai-context/development/patterns.md +0 -382
  158. package/ai-context/development/plugins-guide.md +0 -572
  159. package/ai-context/examples/crud-complete.md +0 -626
  160. package/ai-context/project/architecture.md +0 -399
  161. package/ai-context/project/overview.md +0 -213
  162. package/ai-context/recent-changes/eden-treaty-refactor.md +0 -281
  163. package/ai-context/recent-changes/type-inference-fix.md +0 -223
  164. package/ai-context/reference/environment-vars.md +0 -384
  165. package/ai-context/reference/troubleshooting.md +0 -407
  166. package/app/client/src/components/TestPage.tsx +0 -453
  167. package/bun.lock +0 -1063
  168. package/bunfig.toml +0 -16
  169. package/core/__tests__/integration.test.ts +0 -227
  170. package/core/build/index.ts +0 -186
  171. package/core/config/__tests__/config-loader.test.ts +0 -554
  172. package/core/config/__tests__/config-merger.test.ts +0 -657
  173. package/core/config/__tests__/env-converter.test.ts +0 -372
  174. package/core/config/__tests__/env-processor.test.ts +0 -431
  175. package/core/config/__tests__/env.test.ts +0 -452
  176. package/core/config/__tests__/integration.test.ts +0 -418
  177. package/core/config/__tests__/loader.test.ts +0 -331
  178. package/core/config/__tests__/schema.test.ts +0 -129
  179. package/core/config/__tests__/validator.test.ts +0 -318
  180. package/core/framework/__tests__/server.test.ts +0 -233
  181. package/core/plugins/__tests__/built-in.test.ts.disabled +0 -366
  182. package/core/plugins/__tests__/manager.test.ts +0 -398
  183. package/core/plugins/__tests__/monitoring.test.ts +0 -401
  184. package/core/plugins/__tests__/registry.test.ts +0 -335
  185. package/core/utils/__tests__/errors.test.ts +0 -139
  186. package/core/utils/__tests__/helpers.test.ts +0 -297
  187. package/core/utils/__tests__/logger.test.ts +0 -141
  188. package/create-test-app.ts +0 -156
  189. package/docker-compose.microservices.yml +0 -75
  190. package/docker-compose.simple.yml +0 -57
  191. package/docker-compose.yml +0 -71
  192. package/eslint.config.js +0 -23
  193. package/flux-cli.ts +0 -214
  194. package/nginx-lb.conf +0 -37
  195. package/publish.sh +0 -63
  196. package/run-clean.ts +0 -26
  197. package/run-env-tests.ts +0 -313
  198. package/tailwind.config.js +0 -34
  199. package/tests/__mocks__/api.ts +0 -56
  200. package/tests/fixtures/users.ts +0 -69
  201. package/tests/integration/api/users.routes.test.ts +0 -221
  202. package/tests/setup.ts +0 -29
  203. package/tests/unit/app/client/App-simple.test.tsx +0 -56
  204. package/tests/unit/app/client/App.test.tsx.skip +0 -237
  205. package/tests/unit/app/client/eden-api.test.ts +0 -186
  206. package/tests/unit/app/client/simple.test.tsx +0 -23
  207. package/tests/unit/app/controllers/users.controller.test.ts +0 -150
  208. package/tests/unit/core/create-project.test.ts.skip +0 -95
  209. package/tests/unit/core/framework.test.ts +0 -144
  210. package/tests/unit/core/plugins/logger.test.ts.skip +0 -268
  211. package/tests/unit/core/plugins/vite.test.ts.disabled +0 -188
  212. package/tests/utils/test-helpers.ts +0 -61
  213. package/vitest.config.ts +0 -50
  214. package/workspace.json +0 -6
@@ -0,0 +1,258 @@
1
+ import { useState, useCallback, useRef } from 'react'
2
+ import type {
3
+ FileUploadStartMessage,
4
+ FileUploadChunkMessage,
5
+ FileUploadCompleteMessage,
6
+ FileUploadProgressResponse,
7
+ FileUploadCompleteResponse
8
+ } from '../../types/types'
9
+
10
+ export interface ChunkedUploadOptions {
11
+ chunkSize?: number // Default 64KB
12
+ maxFileSize?: number // Default 50MB
13
+ allowedTypes?: string[]
14
+ sendMessageAndWait?: (message: any, timeout?: number) => Promise<any> // WebSocket send function
15
+ onProgress?: (progress: number, bytesUploaded: number, totalBytes: number) => void
16
+ onComplete?: (response: FileUploadCompleteResponse) => void
17
+ onError?: (error: string) => void
18
+ }
19
+
20
+ export interface ChunkedUploadState {
21
+ uploading: boolean
22
+ progress: number
23
+ error: string | null
24
+ uploadId: string | null
25
+ bytesUploaded: number
26
+ totalBytes: number
27
+ }
28
+
29
+ export function useChunkedUpload(componentId: string, options: ChunkedUploadOptions = {}) {
30
+
31
+ const [state, setState] = useState<ChunkedUploadState>({
32
+ uploading: false,
33
+ progress: 0,
34
+ error: null,
35
+ uploadId: null,
36
+ bytesUploaded: 0,
37
+ totalBytes: 0
38
+ })
39
+
40
+ const {
41
+ chunkSize = 64 * 1024, // 64KB default
42
+ maxFileSize = 50 * 1024 * 1024, // 50MB default
43
+ allowedTypes = ['image/jpeg', 'image/jpg', 'image/png', 'image/webp', 'image/gif'],
44
+ sendMessageAndWait,
45
+ onProgress,
46
+ onComplete,
47
+ onError
48
+ } = options
49
+
50
+ const abortControllerRef = useRef<AbortController | null>(null)
51
+
52
+ // Convert file to base64 chunks
53
+ const fileToChunks = useCallback(async (file: File): Promise<string[]> => {
54
+ return new Promise((resolve, reject) => {
55
+ const reader = new FileReader()
56
+
57
+ reader.onload = () => {
58
+ const arrayBuffer = reader.result as ArrayBuffer
59
+ const uint8Array = new Uint8Array(arrayBuffer)
60
+
61
+ // Split binary data into chunks first, then convert each chunk to base64
62
+ const chunks: string[] = []
63
+ for (let i = 0; i < uint8Array.length; i += chunkSize) {
64
+ const chunkEnd = Math.min(i + chunkSize, uint8Array.length)
65
+ const chunkBytes = uint8Array.slice(i, chunkEnd)
66
+
67
+ // Convert chunk to base64
68
+ let binary = ''
69
+ for (let j = 0; j < chunkBytes.length; j++) {
70
+ binary += String.fromCharCode(chunkBytes[j])
71
+ }
72
+ const base64Chunk = btoa(binary)
73
+ chunks.push(base64Chunk)
74
+ }
75
+
76
+ resolve(chunks)
77
+ }
78
+
79
+ reader.onerror = () => reject(new Error('Failed to read file'))
80
+ reader.readAsArrayBuffer(file)
81
+ })
82
+ }, [chunkSize])
83
+
84
+ // Start chunked upload
85
+ const uploadFile = useCallback(async (file: File) => {
86
+ if (!sendMessageAndWait) {
87
+ const error = 'No sendMessageAndWait function provided'
88
+ setState(prev => ({ ...prev, error }))
89
+ onError?.(error)
90
+ return
91
+ }
92
+
93
+ // Validate file
94
+ if (!allowedTypes.includes(file.type)) {
95
+ const error = `Invalid file type: ${file.type}. Allowed: ${allowedTypes.join(', ')}`
96
+ setState(prev => ({ ...prev, error }))
97
+ onError?.(error)
98
+ return
99
+ }
100
+
101
+ if (file.size > maxFileSize) {
102
+ const error = `File too large: ${file.size} bytes. Max: ${maxFileSize} bytes`
103
+ setState(prev => ({ ...prev, error }))
104
+ onError?.(error)
105
+ return
106
+ }
107
+
108
+ try {
109
+ const uploadId = `upload-${Date.now()}-${Math.random().toString(36).substring(2, 8)}`
110
+
111
+ // Create abort controller for this upload
112
+ abortControllerRef.current = new AbortController()
113
+
114
+ setState({
115
+ uploading: true,
116
+ progress: 0,
117
+ error: null,
118
+ uploadId,
119
+ bytesUploaded: 0,
120
+ totalBytes: file.size
121
+ })
122
+
123
+ console.log('🚀 Starting chunked upload:', { uploadId, filename: file.name, size: file.size })
124
+
125
+ // Convert file to chunks
126
+ const chunks = await fileToChunks(file)
127
+ const totalChunks = chunks.length
128
+
129
+ console.log(`📦 File split into ${totalChunks} chunks of ~${chunkSize} bytes each`)
130
+
131
+ // Start upload
132
+ const startMessage: FileUploadStartMessage = {
133
+ type: 'FILE_UPLOAD_START',
134
+ componentId,
135
+ uploadId,
136
+ filename: file.name,
137
+ fileType: file.type,
138
+ fileSize: file.size,
139
+ chunkSize,
140
+ requestId: `start-${uploadId}`
141
+ }
142
+
143
+ const startResponse = await sendMessageAndWait(startMessage, 10000)
144
+ if (!startResponse?.success) {
145
+ throw new Error(startResponse?.error || 'Failed to start upload')
146
+ }
147
+
148
+ console.log('✅ Upload started successfully')
149
+
150
+ // Send chunks sequentially
151
+ for (let i = 0; i < chunks.length; i++) {
152
+ if (abortControllerRef.current?.signal.aborted) {
153
+ throw new Error('Upload cancelled')
154
+ }
155
+
156
+ const chunkMessage: FileUploadChunkMessage = {
157
+ type: 'FILE_UPLOAD_CHUNK',
158
+ componentId,
159
+ uploadId,
160
+ chunkIndex: i,
161
+ totalChunks,
162
+ data: chunks[i],
163
+ requestId: `chunk-${uploadId}-${i}`
164
+ }
165
+
166
+ console.log(`📤 Sending chunk ${i + 1}/${totalChunks}`)
167
+
168
+ // Send chunk and wait for progress response
169
+ const progressResponse = await sendMessageAndWait(chunkMessage, 10000) as FileUploadProgressResponse
170
+
171
+ if (progressResponse) {
172
+ const { progress, bytesUploaded } = progressResponse
173
+ setState(prev => ({ ...prev, progress, bytesUploaded }))
174
+ onProgress?.(progress, bytesUploaded, file.size)
175
+ }
176
+
177
+ // Small delay to prevent overwhelming the server
178
+ await new Promise(resolve => setTimeout(resolve, 10))
179
+ }
180
+
181
+ // Complete upload
182
+ const completeMessage: FileUploadCompleteMessage = {
183
+ type: 'FILE_UPLOAD_COMPLETE',
184
+ componentId,
185
+ uploadId,
186
+ requestId: `complete-${uploadId}`
187
+ }
188
+
189
+ console.log('🏁 Completing upload...')
190
+
191
+ const completeResponse = await sendMessageAndWait(completeMessage, 10000) as FileUploadCompleteResponse
192
+
193
+ if (completeResponse?.success) {
194
+ setState(prev => ({
195
+ ...prev,
196
+ uploading: false,
197
+ progress: 100,
198
+ bytesUploaded: file.size
199
+ }))
200
+
201
+ console.log('🎉 Upload completed successfully:', completeResponse.fileUrl)
202
+ onComplete?.(completeResponse)
203
+ } else {
204
+ throw new Error(completeResponse?.error || 'Upload completion failed')
205
+ }
206
+
207
+ } catch (error: any) {
208
+ console.error('❌ Chunked upload failed:', error.message)
209
+ setState(prev => ({
210
+ ...prev,
211
+ uploading: false,
212
+ error: error.message
213
+ }))
214
+ onError?.(error.message)
215
+ }
216
+ }, [
217
+ componentId,
218
+ allowedTypes,
219
+ maxFileSize,
220
+ chunkSize,
221
+ sendMessageAndWait,
222
+ fileToChunks,
223
+ onProgress,
224
+ onComplete,
225
+ onError
226
+ ])
227
+
228
+ // Cancel upload
229
+ const cancelUpload = useCallback(() => {
230
+ if (abortControllerRef.current) {
231
+ abortControllerRef.current.abort()
232
+ setState(prev => ({
233
+ ...prev,
234
+ uploading: false,
235
+ error: 'Upload cancelled'
236
+ }))
237
+ }
238
+ }, [])
239
+
240
+ // Reset state
241
+ const reset = useCallback(() => {
242
+ setState({
243
+ uploading: false,
244
+ progress: 0,
245
+ error: null,
246
+ uploadId: null,
247
+ bytesUploaded: 0,
248
+ totalBytes: 0
249
+ })
250
+ }, [])
251
+
252
+ return {
253
+ ...state,
254
+ uploadFile,
255
+ cancelUpload,
256
+ reset
257
+ }
258
+ }