@coze-arch/cli 0.0.1-alpha.704fa1 → 0.0.1-alpha.763697

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 (67) hide show
  1. package/lib/__templates__/expo/.coze +1 -1
  2. package/lib/__templates__/expo/.cozeproj/scripts/dev_build.sh +19 -82
  3. package/lib/__templates__/expo/.cozeproj/scripts/dev_run.sh +62 -81
  4. package/lib/__templates__/expo/README.md +66 -7
  5. package/lib/__templates__/expo/client/{src/app → app}/_layout.tsx +1 -1
  6. package/lib/__templates__/expo/client/app/index.tsx +1 -0
  7. package/lib/__templates__/expo/client/app.config.ts +75 -0
  8. package/lib/__templates__/expo/client/components/ThemedText.tsx +33 -0
  9. package/lib/__templates__/expo/client/components/ThemedView.tsx +38 -0
  10. package/lib/__templates__/expo/client/constants/theme.ts +854 -0
  11. package/lib/__templates__/expo/client/hooks/useColorScheme.ts +34 -0
  12. package/lib/__templates__/expo/client/metro.config.js +75 -5
  13. package/lib/__templates__/expo/client/package.json +3 -2
  14. package/lib/__templates__/expo/client/screens/home/index.tsx +25 -0
  15. package/lib/__templates__/expo/client/screens/home/styles.ts +28 -0
  16. package/lib/__templates__/expo/client/tsconfig.json +1 -1
  17. package/lib/__templates__/expo/package.json +4 -98
  18. package/lib/__templates__/expo/pnpm-lock.yaml +376 -577
  19. package/lib/__templates__/expo/server/package.json +17 -2
  20. package/lib/__templates__/expo/server/src/index.ts +8 -2
  21. package/lib/__templates__/expo/server/tsconfig.json +24 -0
  22. package/lib/__templates__/expo/template.config.js +1 -0
  23. package/lib/__templates__/nextjs/.coze +1 -0
  24. package/lib/__templates__/nextjs/_npmrc +1 -0
  25. package/lib/__templates__/nextjs/next.config.ts +12 -0
  26. package/lib/__templates__/nextjs/package.json +3 -2
  27. package/lib/__templates__/nextjs/pnpm-lock.yaml +13 -5
  28. package/lib/__templates__/nextjs/scripts/prepare.sh +9 -0
  29. package/lib/__templates__/nextjs/src/app/globals.css +10 -2
  30. package/lib/__templates__/nextjs/src/app/layout.tsx +1 -12
  31. package/lib/__templates__/nextjs/src/app/page.tsx +33 -21
  32. package/lib/__templates__/nextjs/src/components/ui/resizable.tsx +29 -22
  33. package/lib/__templates__/nextjs/src/components/ui/sidebar.tsx +228 -230
  34. package/lib/__templates__/nextjs/template.config.js +30 -0
  35. package/lib/__templates__/templates.json +61 -43
  36. package/lib/__templates__/vite/.coze +1 -0
  37. package/lib/__templates__/vite/_npmrc +1 -0
  38. package/lib/__templates__/vite/eslint.config.mjs +9 -0
  39. package/lib/__templates__/vite/package.json +5 -1
  40. package/lib/__templates__/vite/pnpm-lock.yaml +3481 -14
  41. package/lib/__templates__/vite/scripts/prepare.sh +9 -0
  42. package/lib/__templates__/vite/template.config.js +28 -4
  43. package/lib/cli.js +189 -52
  44. package/package.json +6 -2
  45. package/lib/__templates__/expo/client/app.json +0 -63
  46. package/lib/__templates__/expo/client/src/constants/theme.ts +0 -128
  47. package/lib/__templates__/expo/client/src/hooks/useColorScheme.ts +0 -1
  48. package/lib/__templates__/expo/client/src/screens/home/index.tsx +0 -50
  49. package/lib/__templates__/expo/client/src/screens/home/styles.ts +0 -60
  50. package/lib/__templates__/nextjs/.vscode/settings.json +0 -121
  51. package/lib/__templates__/vite/.vscode/settings.json +0 -7
  52. /package/lib/__templates__/expo/client/{src/app/index.ts → app/home.tsx} +0 -0
  53. /package/lib/__templates__/expo/client/{src/assets → assets}/fonts/SpaceMono-Regular.ttf +0 -0
  54. /package/lib/__templates__/expo/client/{src/assets → assets}/images/adaptive-icon.png +0 -0
  55. /package/lib/__templates__/expo/client/{src/assets → assets}/images/default-avatar.png +0 -0
  56. /package/lib/__templates__/expo/client/{src/assets → assets}/images/favicon.png +0 -0
  57. /package/lib/__templates__/expo/client/{src/assets → assets}/images/icon.png +0 -0
  58. /package/lib/__templates__/expo/client/{src/assets → assets}/images/partial-react-logo.png +0 -0
  59. /package/lib/__templates__/expo/client/{src/assets → assets}/images/react-logo.png +0 -0
  60. /package/lib/__templates__/expo/client/{src/assets → assets}/images/react-logo@2x.png +0 -0
  61. /package/lib/__templates__/expo/client/{src/assets → assets}/images/react-logo@3x.png +0 -0
  62. /package/lib/__templates__/expo/client/{src/assets → assets}/images/splash-icon.png +0 -0
  63. /package/lib/__templates__/expo/client/{src/components → components}/Screen.tsx +0 -0
  64. /package/lib/__templates__/expo/client/{src/components → components}/SmartDateInput.tsx +0 -0
  65. /package/lib/__templates__/expo/client/{src/contexts → contexts}/AuthContext.tsx +0 -0
  66. /package/lib/__templates__/expo/client/{src/hooks → hooks}/useTheme.ts +0 -0
  67. /package/lib/__templates__/expo/client/{src/utils → utils}/index.ts +0 -0
@@ -0,0 +1,34 @@
1
+ import { useEffect, useState } from 'react';
2
+ import { ColorSchemeName, useColorScheme as useReactNativeColorScheme, Platform } from 'react-native';
3
+
4
+ export function useColorScheme() {
5
+ const systemColorScheme = useReactNativeColorScheme();
6
+ const [colorScheme, setColorScheme] = useState<ColorSchemeName>(systemColorScheme);
7
+
8
+ useEffect(() => {
9
+ setColorScheme(systemColorScheme);
10
+ }, [systemColorScheme])
11
+
12
+ useEffect(() => {
13
+ function handleMessage(e: MessageEvent<{ event: string; colorScheme: ColorSchemeName; } | undefined>) {
14
+ if (e.data?.event === 'coze.workbench.colorScheme') {
15
+ const cs = e.data.colorScheme;
16
+ if (typeof cs === 'string') {
17
+ setColorScheme(cs);
18
+ }
19
+ }
20
+ }
21
+
22
+ if (Platform.OS === 'web') {
23
+ window.addEventListener('message', handleMessage, false);
24
+ }
25
+
26
+ return () => {
27
+ if (Platform.OS === 'web') {
28
+ window.removeEventListener('message', handleMessage, false);
29
+ }
30
+ }
31
+ }, []);
32
+
33
+ return colorScheme;
34
+ }
@@ -28,24 +28,94 @@ config.resolver.blockList = [
28
28
  /.*\.git\/.*/, // 排除 Git 目录
29
29
  ];
30
30
 
31
+ const BACKEND_TARGET = 'http://localhost:9091';
32
+
31
33
  const apiProxy = createProxyMiddleware({
32
- target: 'http://localhost:9091',
34
+ target: BACKEND_TARGET,
35
+ changeOrigin: true,
33
36
  logLevel: 'debug',
37
+ proxyTimeout: 86400000,
38
+ onProxyReq: (proxyReq, req) => {
39
+ const accept = req.headers.accept || '';
40
+ if (accept.includes('text/event-stream')) {
41
+ proxyReq.setHeader('accept-encoding', 'identity');
42
+ }
43
+ },
44
+ onProxyRes: (proxyRes, req, res) => {
45
+ const contentType = proxyRes.headers['content-type'] || '';
46
+ if (contentType.includes('text/event-stream') || contentType.includes('application/stream')) {
47
+ res.setHeader('Cache-Control', 'no-cache');
48
+ res.setHeader('Connection', 'keep-alive');
49
+ res.setHeader('X-Accel-Buffering', 'no');
50
+ if (typeof res.flushHeaders === 'function') {
51
+ try { res.flushHeaders(); } catch {}
52
+ }
53
+ }
54
+ },
34
55
  });
35
56
 
57
+ const streamProxy = createProxyMiddleware({
58
+ target: BACKEND_TARGET,
59
+ changeOrigin: true,
60
+ logLevel: 'debug',
61
+ ws: true,
62
+ proxyTimeout: 86400000,
63
+ onProxyReq: (proxyReq, req) => {
64
+ const upgrade = req.headers.upgrade;
65
+ const accept = req.headers.accept || '';
66
+ if (upgrade && upgrade.toLowerCase() === 'websocket') {
67
+ proxyReq.setHeader('Connection', 'upgrade');
68
+ proxyReq.setHeader('Upgrade', req.headers.upgrade);
69
+ } else if (accept.includes('text/event-stream')) {
70
+ proxyReq.setHeader('accept-encoding', 'identity');
71
+ proxyReq.setHeader('Connection', 'keep-alive');
72
+ }
73
+ },
74
+ onProxyRes: (proxyRes, req, res) => {
75
+ const contentType = proxyRes.headers['content-type'] || '';
76
+ if (contentType.includes('text/event-stream') || contentType.includes('application/stream')) {
77
+ res.setHeader('Cache-Control', 'no-cache');
78
+ res.setHeader('Connection', 'keep-alive');
79
+ res.setHeader('X-Accel-Buffering', 'no');
80
+ if (typeof res.flushHeaders === 'function') {
81
+ try { res.flushHeaders(); } catch {}
82
+ }
83
+ }
84
+ },
85
+ });
86
+
87
+ const shouldProxyToBackend = (url) => {
88
+ if (!url) return false;
89
+ if (/^\/api\/v\d+\//.test(url)) {
90
+ return true;
91
+ }
92
+ return false;
93
+ };
94
+
95
+ const isWebSocketRequest = (req) =>
96
+ !!(req.headers.upgrade && req.headers.upgrade.toLowerCase() === 'websocket');
97
+ const isSSERequest = (req) => {
98
+ const accept = req.headers.accept || '';
99
+ return accept.includes('text/event-stream');
100
+ };
101
+
36
102
  config.server = {
37
- ...config.server,
38
- enhanceMiddleware: (metroMiddleware, metroServer) => {
103
+ ...config.server,
104
+ enhanceMiddleware: (metroMiddleware, metroServer) => {
39
105
  return connect()
40
106
  .use((req, res, next) => {
41
- if (req.url && req.url.startsWith('/api/v')) {
107
+ if (shouldProxyToBackend(req.url)) {
42
108
  console.log(`[Metro Proxy] Forwarding ${req.method} ${req.url}`);
109
+
110
+ if (isWebSocketRequest(req) || isSSERequest(req)) {
111
+ return streamProxy(req, res, next);
112
+ }
43
113
  return apiProxy(req, res, next);
44
114
  }
45
115
  next();
46
116
  })
47
117
  .use(metroMiddleware);
48
118
  },
49
- }
119
+ };
50
120
 
51
121
  module.exports = config;
@@ -24,8 +24,6 @@
24
24
  "@react-native-picker/picker": "^2.11.0",
25
25
  "@react-navigation/bottom-tabs": "^7.2.0",
26
26
  "@react-navigation/native": "^7.0.14",
27
- "babel-plugin-module-resolver": "^5.0.2",
28
- "babel-preset-expo": "^54.0.9",
29
27
  "dayjs": "^1.11.19",
30
28
  "expo": "^54.0.7",
31
29
  "expo-auth-session": "^7.0.9",
@@ -40,6 +38,7 @@
40
38
  "expo-linear-gradient": "~15.0.6",
41
39
  "expo-linking": "~8.0.7",
42
40
  "expo-location": "~19.0.7",
41
+ "expo-image": "^3.0.11",
43
42
  "expo-router": "~6.0.0",
44
43
  "expo-splash-screen": "~31.0.8",
45
44
  "expo-status-bar": "~3.0.7",
@@ -65,6 +64,8 @@
65
64
  },
66
65
  "devDependencies": {
67
66
  "@babel/core": "^7.25.2",
67
+ "babel-plugin-module-resolver": "^5.0.2",
68
+ "babel-preset-expo": "^54.0.9",
68
69
  "@eslint/js": "^9.27.0",
69
70
  "@types/jest": "^29.5.12",
70
71
  "@types/react": "~19.1.0",
@@ -0,0 +1,25 @@
1
+ import { View, Text } from 'react-native';
2
+ import { Image } from 'expo-image';
3
+
4
+ import { useTheme } from '@/hooks/useTheme';
5
+ import { Screen } from '@/components/Screen';
6
+ import { styles } from './styles';
7
+
8
+ export default function HomeScreen() {
9
+ const { theme, isDark } = useTheme();
10
+
11
+ return (
12
+ <Screen backgroundColor={theme.backgroundRoot} statusBarStyle={isDark ? 'light' : 'dark'}>
13
+ <View
14
+ style={styles.container}
15
+ >
16
+ <Image
17
+ style={styles.logo}
18
+ source="https://lf-coze-web-cdn.coze.cn/obj/eden-cn/lm-lgvj/ljhwZthlaukjlkulzlp/coze-coding/expo/coze-loading.gif"
19
+ ></Image>
20
+ <Text style={{...styles.title, color: theme.textPrimary}}>APP 开发中</Text>
21
+ <Text style={{...styles.description, color: theme.textSecondary}}>即将为您呈现应用界面</Text>
22
+ </View>
23
+ </Screen>
24
+ );
25
+ }
@@ -0,0 +1,28 @@
1
+ import { Spacing } from '@/constants/theme';
2
+ import { StyleSheet } from 'react-native';
3
+
4
+ export const styles = StyleSheet.create({
5
+ container: {
6
+ position: 'absolute',
7
+ top: 0,
8
+ left: 0,
9
+ width: '100%',
10
+ height: '100%',
11
+ display: 'flex',
12
+ flexDirection: 'column',
13
+ alignItems: 'center',
14
+ justifyContent: 'center',
15
+ },
16
+ logo: {
17
+ width: 130,
18
+ height: 109,
19
+ },
20
+ title: {
21
+ fontSize: 16,
22
+ fontWeight: 'bold',
23
+ },
24
+ description: {
25
+ fontSize: 14,
26
+ marginTop: Spacing.sm,
27
+ },
28
+ });
@@ -7,7 +7,7 @@
7
7
  "strict": true,
8
8
  "noEmit": true,
9
9
  "paths": {
10
- "@/*": ["./src/*"]
10
+ "@/*": ["./*"]
11
11
  }
12
12
  },
13
13
  "include": ["**/*.ts", "**/*.tsx", ".expo/types/**/*.ts", "expo-env.d.ts"],
@@ -1,109 +1,15 @@
1
1
  {
2
- "name": "<%= appName %>",
2
+ "name": "expo-express-monorepo",
3
3
  "private": true,
4
4
  "version": "0.0.0",
5
- "main": "expo-router/entry",
6
5
  "scripts": {
7
6
  "dev": "bash .cozeproj/scripts/dev_run.sh",
8
7
  "build": "bash .cozeproj/scripts/prod_build.sh",
9
8
  "start": "bash .cozeproj/scripts/prod_run.sh",
10
- "check-deps": "npx depcheck",
11
- "preinstall": "npx only-allow pnpm",
12
- "lint": "expo lint",
13
- "test": "jest --watchAll"
14
- },
15
- "jest": {
16
- "preset": "jest-expo"
17
- },
18
- "dependencies": {
19
- "@aws-sdk/client-s3": "^3.958.0",
20
- "@aws-sdk/lib-storage": "^3.958.0",
21
- "@expo/metro-runtime": "^6.1.2",
22
- "@expo/vector-icons": "^15.0.0",
23
- "@react-native-async-storage/async-storage": "^2.2.0",
24
- "@react-native-community/datetimepicker": "^8.5.0",
25
- "@react-native-community/slider": "^5.0.1",
26
- "@react-native-masked-view/masked-view": "^0.3.2",
27
- "@react-native-picker/picker": "^2.11.0",
28
- "@react-navigation/bottom-tabs": "^7.2.0",
29
- "@react-navigation/native": "^7.0.14",
30
- "ajv": "^8.17.1",
31
- "ajv-formats": "^3.0.1",
32
- "babel-plugin-module-resolver": "^5.0.2",
33
- "babel-preset-expo": "^54.0.9",
34
- "connect": "^3.7.0",
35
- "coze-coding-dev-sdk": "^0.5.5",
36
- "dayjs": "^1.11.19",
37
- "drizzle-kit": "^0.31.8",
38
- "drizzle-orm": "^0.45.1",
39
- "drizzle-zod": "^0.8.3",
40
- "expo": "^54.0.7",
41
- "expo-auth-session": "^7.0.9",
42
- "expo-av": "~16.0.6",
43
- "expo-blur": "~15.0.6",
44
- "expo-camera": "~17.0.10",
45
- "expo-constants": "~18.0.8",
46
- "expo-crypto": "^15.0.7",
47
- "expo-font": "~14.0.7",
48
- "expo-haptics": "~15.0.6",
49
- "expo-image-picker": "~17.0.7",
50
- "expo-linear-gradient": "~15.0.6",
51
- "expo-linking": "~8.0.7",
52
- "expo-location": "~19.0.7",
53
- "expo-router": "~6.0.0",
54
- "expo-splash-screen": "~31.0.8",
55
- "expo-status-bar": "~3.0.7",
56
- "expo-symbols": "~1.0.6",
57
- "expo-system-ui": "~6.0.9",
58
- "expo-web-browser": "~15.0.10",
59
- "express": "^4.22.1",
60
- "http-proxy-middleware": "^3.0.5",
61
- "multer": "^2.0.2",
62
- "pg": "^8.16.3",
63
- "react": "19.1.0",
64
- "react-dom": "19.1.0",
65
- "react-native": "0.81.5",
66
- "react-native-chart-kit": "^6.12.0",
67
- "react-native-gesture-handler": "~2.28.0",
68
- "react-native-keyboard-aware-scroll-view": "^0.9.5",
69
- "react-native-modal-datetime-picker": "18.0.0",
70
- "react-native-reanimated": "~4.1.0",
71
- "react-native-safe-area-context": "~5.6.0",
72
- "react-native-screens": "~4.16.0",
73
- "react-native-svg": "15.15.0",
74
- "react-native-toast-message": "^2.3.3",
75
- "react-native-web": "^0.21.2",
76
- "react-native-webview": "~13.15.0",
77
- "react-native-worklets": "0.5.1",
78
- "zod": "^4.2.1"
79
- },
80
- "devDependencies": {
81
- "@babel/core": "^7.25.2",
82
- "@eslint/js": "^9.27.0",
83
- "@types/express": "^5.0.6",
84
- "@types/jest": "^29.5.12",
85
- "@types/multer": "^2.0.0",
86
- "@types/pg": "^8.16.0",
87
- "@types/react": "~19.1.0",
88
- "@types/react-test-renderer": "19.1.0",
89
- "chalk": "^4.1.2",
90
- "depcheck": "^1.4.7",
91
- "esbuild": "0.27.2",
92
- "eslint": "^9.39.2",
93
- "eslint-formatter-compact": "^9.0.1",
94
- "eslint-import-resolver-typescript": "^4.4.4",
95
- "eslint-plugin-import": "^2.32.0",
96
- "eslint-plugin-react": "^7.37.5",
97
- "eslint-plugin-react-hooks": "^7.0.1",
98
- "eslint-plugin-regexp": "^2.10.0",
99
- "globals": "^16.1.0",
100
- "jest": "^29.2.1",
101
- "jest-expo": "~54.0.10",
102
- "react-test-renderer": "19.1.0",
103
- "tsx": "^4.21.0",
104
- "typescript": "^5.8.3",
105
- "typescript-eslint": "^8.32.1"
9
+ "preinstall": "npx only-allow pnpm"
106
10
  },
11
+ "dependencies": {},
12
+ "devDependencies": {},
107
13
  "packageManager": "pnpm@9.0.0",
108
14
  "engines": {
109
15
  "pnpm": ">=9.0.0"