clawfire 0.1.0 → 0.2.1

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/dist/dev.d.cts CHANGED
@@ -4,74 +4,65 @@ import './schema-BJsictSV.cjs';
4
4
  import 'zod';
5
5
 
6
6
  interface DevServerOptions {
7
- /** 프로젝트 루트 경로 */
7
+ /** Project root path */
8
8
  projectDir?: string;
9
- /** 서버 포트 (기본: 3456) */
9
+ /** Frontend server port (default: 3000) */
10
10
  port?: number;
11
- /** 라우터 옵션 */
11
+ /** API server port (default: 3456) */
12
+ apiPort?: number;
13
+ /** Router options */
12
14
  routerOptions?: Partial<RouterOptions>;
13
- /** 리로드 활성화 (기본: true) */
15
+ /** Hot reload enabled (default: true) */
14
16
  hotReload?: boolean;
15
- /** 변경 감지 디바운스 ms (기본: 150) */
17
+ /** Change detection debounce ms (default: 150) */
16
18
  debounceMs?: number;
17
- /** 라우트를 수동으로 등록하는 콜백 (파일 기반 대신) */
19
+ /** Callback to manually register routes (instead of file-based) */
18
20
  onSetupRoutes?: (router: ClawfireRouter) => void | Promise<void>;
19
21
  }
20
22
  declare class DevServer {
21
- private server;
23
+ private frontendServer;
24
+ private apiServer;
22
25
  private router;
23
26
  private watcher;
24
- private sseClients;
27
+ private frontendSseClients;
28
+ private apiSseClients;
25
29
  private sseIdCounter;
26
30
  private options;
27
31
  private routesDir;
28
32
  private schemasDir;
33
+ private publicDir;
34
+ private pagesDir;
35
+ private componentsDir;
29
36
  private playgroundHtml;
30
37
  private importCounter;
31
38
  private isReloading;
39
+ private pageCompiler;
32
40
  constructor(options?: DevServerOptions);
33
- /**
34
- * 개발 서버 시작
35
- */
36
41
  start(): Promise<void>;
37
- /**
38
- * 서버 종료
39
- */
40
42
  stop(): Promise<void>;
41
- /**
42
- * 라우트 파일 로딩 (또는 수동 콜백)
43
- */
44
43
  private loadRoutes;
45
- /**
46
- * 라우트 핫 리로드
47
- */
48
44
  private reloadRoutes;
45
+ private handleFrontendChange;
49
46
  private startWatcher;
50
47
  private handleSSE;
51
48
  private broadcastSSE;
52
49
  private regeneratePlayground;
53
- private handleHttpRequest;
50
+ /**
51
+ * Inject HMR and (optionally) client-side router scripts before </body>.
52
+ */
53
+ private injectScripts;
54
+ private serveStaticFile;
55
+ private proxyToApiServer;
56
+ private handleFrontendRequest;
57
+ private handleApiRequest;
54
58
  private printStartupBanner;
55
59
  }
56
60
  /**
57
- * 개발 서버 생성 시작 (원라인 헬퍼)
58
- *
59
- * @example
60
- * ```ts
61
- * import { startDevServer } from "clawfire/dev";
62
- *
63
- * startDevServer({
64
- * port: 3456,
65
- * onSetupRoutes: (router) => {
66
- * router.register("/health", healthRoute);
67
- * router.register("/products/list", listRoute);
68
- * }
69
- * });
70
- * ```
61
+ * Create and start dev server (one-line helper)
71
62
  */
72
63
  declare function startDevServer(options?: DevServerOptions): Promise<DevServer>;
73
64
 
74
- type WatchEventType = "route-change" | "schema-change" | "config-change" | "any-change";
65
+ type WatchEventType = "route-change" | "schema-change" | "config-change" | "frontend-change" | "css-change" | "page-change" | "component-change" | "any-change";
75
66
  interface WatchEvent {
76
67
  type: WatchEventType;
77
68
  filePath: string;
@@ -90,6 +81,14 @@ declare class FileWatcher extends EventEmitter {
90
81
  * 단일 파일 감시
91
82
  */
92
83
  watchFile(filePath: string, eventType: WatchEventType): this;
84
+ /**
85
+ * 프론트엔드 디렉터리 감시 (확장자별 이벤트 타입 자동 결정)
86
+ */
87
+ watchDirFrontend(dir: string): this;
88
+ /**
89
+ * Linux fallback: 프론트엔드 디렉터리 수동 재귀 감시
90
+ */
91
+ private watchDirFrontendRecursiveManual;
93
92
  /**
94
93
  * Linux fallback: 디렉터리 수동 재귀 감시
95
94
  */
package/dist/dev.d.ts CHANGED
@@ -4,74 +4,65 @@ import './schema-BJsictSV.js';
4
4
  import 'zod';
5
5
 
6
6
  interface DevServerOptions {
7
- /** 프로젝트 루트 경로 */
7
+ /** Project root path */
8
8
  projectDir?: string;
9
- /** 서버 포트 (기본: 3456) */
9
+ /** Frontend server port (default: 3000) */
10
10
  port?: number;
11
- /** 라우터 옵션 */
11
+ /** API server port (default: 3456) */
12
+ apiPort?: number;
13
+ /** Router options */
12
14
  routerOptions?: Partial<RouterOptions>;
13
- /** 리로드 활성화 (기본: true) */
15
+ /** Hot reload enabled (default: true) */
14
16
  hotReload?: boolean;
15
- /** 변경 감지 디바운스 ms (기본: 150) */
17
+ /** Change detection debounce ms (default: 150) */
16
18
  debounceMs?: number;
17
- /** 라우트를 수동으로 등록하는 콜백 (파일 기반 대신) */
19
+ /** Callback to manually register routes (instead of file-based) */
18
20
  onSetupRoutes?: (router: ClawfireRouter) => void | Promise<void>;
19
21
  }
20
22
  declare class DevServer {
21
- private server;
23
+ private frontendServer;
24
+ private apiServer;
22
25
  private router;
23
26
  private watcher;
24
- private sseClients;
27
+ private frontendSseClients;
28
+ private apiSseClients;
25
29
  private sseIdCounter;
26
30
  private options;
27
31
  private routesDir;
28
32
  private schemasDir;
33
+ private publicDir;
34
+ private pagesDir;
35
+ private componentsDir;
29
36
  private playgroundHtml;
30
37
  private importCounter;
31
38
  private isReloading;
39
+ private pageCompiler;
32
40
  constructor(options?: DevServerOptions);
33
- /**
34
- * 개발 서버 시작
35
- */
36
41
  start(): Promise<void>;
37
- /**
38
- * 서버 종료
39
- */
40
42
  stop(): Promise<void>;
41
- /**
42
- * 라우트 파일 로딩 (또는 수동 콜백)
43
- */
44
43
  private loadRoutes;
45
- /**
46
- * 라우트 핫 리로드
47
- */
48
44
  private reloadRoutes;
45
+ private handleFrontendChange;
49
46
  private startWatcher;
50
47
  private handleSSE;
51
48
  private broadcastSSE;
52
49
  private regeneratePlayground;
53
- private handleHttpRequest;
50
+ /**
51
+ * Inject HMR and (optionally) client-side router scripts before </body>.
52
+ */
53
+ private injectScripts;
54
+ private serveStaticFile;
55
+ private proxyToApiServer;
56
+ private handleFrontendRequest;
57
+ private handleApiRequest;
54
58
  private printStartupBanner;
55
59
  }
56
60
  /**
57
- * 개발 서버 생성 시작 (원라인 헬퍼)
58
- *
59
- * @example
60
- * ```ts
61
- * import { startDevServer } from "clawfire/dev";
62
- *
63
- * startDevServer({
64
- * port: 3456,
65
- * onSetupRoutes: (router) => {
66
- * router.register("/health", healthRoute);
67
- * router.register("/products/list", listRoute);
68
- * }
69
- * });
70
- * ```
61
+ * Create and start dev server (one-line helper)
71
62
  */
72
63
  declare function startDevServer(options?: DevServerOptions): Promise<DevServer>;
73
64
 
74
- type WatchEventType = "route-change" | "schema-change" | "config-change" | "any-change";
65
+ type WatchEventType = "route-change" | "schema-change" | "config-change" | "frontend-change" | "css-change" | "page-change" | "component-change" | "any-change";
75
66
  interface WatchEvent {
76
67
  type: WatchEventType;
77
68
  filePath: string;
@@ -90,6 +81,14 @@ declare class FileWatcher extends EventEmitter {
90
81
  * 단일 파일 감시
91
82
  */
92
83
  watchFile(filePath: string, eventType: WatchEventType): this;
84
+ /**
85
+ * 프론트엔드 디렉터리 감시 (확장자별 이벤트 타입 자동 결정)
86
+ */
87
+ watchDirFrontend(dir: string): this;
88
+ /**
89
+ * Linux fallback: 프론트엔드 디렉터리 수동 재귀 감시
90
+ */
91
+ private watchDirFrontendRecursiveManual;
93
92
  /**
94
93
  * Linux fallback: 디렉터리 수동 재귀 감시
95
94
  */