@coze-arch/cli 0.0.1-alpha.912cd5 → 0.0.1-alpha.9c5406

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 (74) hide show
  1. package/lib/__templates__/expo/.coze +7 -2
  2. package/lib/__templates__/expo/.cozeproj/scripts/dev_build.sh +46 -0
  3. package/lib/__templates__/expo/.cozeproj/scripts/dev_run.sh +220 -0
  4. package/lib/__templates__/expo/.cozeproj/scripts/prod_build.sh +47 -0
  5. package/lib/__templates__/expo/.cozeproj/scripts/prod_run.sh +34 -0
  6. package/lib/__templates__/expo/README.md +66 -7
  7. package/lib/__templates__/expo/_gitignore +1 -1
  8. package/lib/__templates__/expo/_npmrc +3 -5
  9. package/lib/__templates__/expo/client/app/_layout.tsx +1 -1
  10. package/lib/__templates__/expo/client/app/home.tsx +1 -0
  11. package/lib/__templates__/expo/client/app/index.tsx +1 -0
  12. package/lib/__templates__/expo/client/app.config.ts +75 -0
  13. package/lib/__templates__/expo/client/components/ThemedText.tsx +33 -0
  14. package/lib/__templates__/expo/client/components/ThemedView.tsx +38 -0
  15. package/lib/__templates__/expo/client/constants/theme.ts +786 -50
  16. package/lib/__templates__/expo/client/contexts/AuthContext.tsx +14 -107
  17. package/lib/__templates__/expo/client/hooks/useColorScheme.ts +34 -1
  18. package/lib/__templates__/expo/client/hooks/useTheme.ts +1 -1
  19. package/lib/__templates__/expo/client/metro.config.js +121 -0
  20. package/lib/__templates__/expo/client/package.json +93 -0
  21. package/lib/__templates__/expo/client/screens/home/index.tsx +13 -42
  22. package/lib/__templates__/expo/client/screens/home/styles.ts +19 -323
  23. package/lib/__templates__/expo/client/tsconfig.json +24 -0
  24. package/lib/__templates__/expo/client/utils/index.ts +1 -2
  25. package/lib/__templates__/expo/package.json +13 -101
  26. package/lib/__templates__/expo/pnpm-lock.yaml +527 -861
  27. package/lib/__templates__/expo/pnpm-workspace.yaml +3 -0
  28. package/lib/__templates__/expo/server/package.json +32 -0
  29. package/lib/__templates__/expo/{src → server/src}/index.ts +8 -2
  30. package/lib/__templates__/expo/server/tsconfig.json +24 -0
  31. package/lib/__templates__/expo/template.config.js +2 -1
  32. package/lib/__templates__/expo/tsconfig.json +1 -24
  33. package/lib/__templates__/nextjs/.coze +4 -3
  34. package/lib/__templates__/nextjs/_npmrc +2 -1
  35. package/lib/__templates__/nextjs/next.config.ts +12 -0
  36. package/lib/__templates__/nextjs/package.json +11 -4
  37. package/lib/__templates__/nextjs/pnpm-lock.yaml +2505 -1116
  38. package/lib/__templates__/nextjs/scripts/dev.sh +8 -27
  39. package/lib/__templates__/nextjs/scripts/prepare.sh +9 -0
  40. package/lib/__templates__/nextjs/src/app/globals.css +109 -89
  41. package/lib/__templates__/nextjs/src/app/layout.tsx +19 -34
  42. package/lib/__templates__/nextjs/src/app/page.tsx +33 -21
  43. package/lib/__templates__/nextjs/src/components/ui/resizable.tsx +29 -22
  44. package/lib/__templates__/nextjs/src/components/ui/sidebar.tsx +228 -230
  45. package/lib/__templates__/nextjs/template.config.js +31 -1
  46. package/lib/__templates__/templates.json +61 -36
  47. package/lib/__templates__/vite/.coze +4 -3
  48. package/lib/__templates__/vite/README.md +204 -26
  49. package/lib/__templates__/vite/_npmrc +2 -1
  50. package/lib/__templates__/vite/eslint.config.mjs +9 -0
  51. package/lib/__templates__/vite/package.json +6 -2
  52. package/lib/__templates__/vite/pnpm-lock.yaml +3486 -19
  53. package/lib/__templates__/vite/scripts/dev.sh +7 -26
  54. package/lib/__templates__/vite/scripts/prepare.sh +9 -0
  55. package/lib/__templates__/vite/template.config.js +38 -5
  56. package/lib/__templates__/vite/vite.config.ts +3 -3
  57. package/lib/cli.js +611 -314
  58. package/package.json +10 -4
  59. package/lib/__templates__/expo/.cozeproj/scripts/deploy_build.sh +0 -109
  60. package/lib/__templates__/expo/.cozeproj/scripts/deploy_run.sh +0 -257
  61. package/lib/__templates__/expo/app.json +0 -63
  62. package/lib/__templates__/expo/babel.config.js +0 -9
  63. package/lib/__templates__/expo/client/app/(tabs)/_layout.tsx +0 -43
  64. package/lib/__templates__/expo/client/app/(tabs)/home.tsx +0 -1
  65. package/lib/__templates__/expo/client/app/(tabs)/index.tsx +0 -7
  66. package/lib/__templates__/expo/client/app/+not-found.tsx +0 -79
  67. package/lib/__templates__/expo/client/index.js +0 -12
  68. package/lib/__templates__/expo/metro.config.js +0 -53
  69. package/lib/__templates__/nextjs/.babelrc +0 -15
  70. package/lib/__templates__/nextjs/.vscode/settings.json +0 -121
  71. package/lib/__templates__/nextjs/server.mjs +0 -50
  72. package/lib/__templates__/vite/.vscode/settings.json +0 -7
  73. /package/lib/__templates__/expo/{eslint-formatter-simple.mjs → client/eslint-formatter-simple.mjs} +0 -0
  74. /package/lib/__templates__/expo/{eslint.config.mjs → client/eslint.config.mjs} +0 -0
@@ -1,332 +1,28 @@
1
- import { StyleSheet, Platform } from 'react-native';
1
+ import { Spacing } from '@/constants/theme';
2
+ import { StyleSheet } from 'react-native';
2
3
 
3
- const styles = StyleSheet.create({
4
- loadingContainer: {
5
- flex: 1,
6
- justifyContent: 'center',
7
- alignItems: 'center',
8
- },
9
- loadingText: {
10
- marginTop: 12,
11
- fontSize: 14,
12
- color: '#64748B',
13
- },
14
- errorContainer: {
15
- flex: 1,
16
- justifyContent: 'center',
17
- alignItems: 'center',
18
- paddingHorizontal: 24,
19
- },
20
- errorText: {
21
- marginTop: 16,
22
- fontSize: 16,
23
- color: '#64748B',
24
- },
25
- retryButton: {
26
- marginTop: 20,
27
- paddingHorizontal: 24,
28
- paddingVertical: 12,
29
- backgroundColor: '#2563EB',
30
- borderRadius: 8,
31
- },
32
- retryButtonText: {
33
- color: '#FFFFFF',
34
- fontSize: 14,
35
- fontWeight: '600',
36
- },
37
- header: {
38
- flexDirection: 'row',
39
- justifyContent: 'space-between',
40
- alignItems: 'center',
41
- paddingHorizontal: 16,
42
- // paddingBottom: 16,
43
- backgroundColor: '#FFFFFF',
44
- // borderBottomWidth: 1,
45
- borderBottomColor: '#E2E8F0',
46
- },
47
- headerLeft: {
48
- flexDirection: 'row',
49
- alignItems: 'center',
50
- gap: 10,
51
- },
52
- logoContainer: {
53
- width: 32,
54
- height: 32,
55
- backgroundColor: '#2563EB',
56
- borderRadius: 8,
57
- justifyContent: 'center',
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',
58
13
  alignItems: 'center',
59
- ...Platform.select({
60
- ios: {
61
- shadowColor: '#000',
62
- shadowOffset: { width: 0, height: 1 },
63
- shadowOpacity: 0.1,
64
- shadowRadius: 2,
65
- },
66
- android: {
67
- elevation: 2,
68
- },
69
- }),
70
- },
71
- logoText: {
72
- fontSize: 18,
73
- fontWeight: '700',
74
- color: '#1E293B',
75
- letterSpacing: -0.5,
76
- },
77
- userMenuContainer: {
78
- flexDirection: 'row',
79
- alignItems: 'center',
80
- gap: 10,
81
- paddingLeft: 16,
82
- borderLeftWidth: 1,
83
- borderLeftColor: '#E2E8F0',
84
- },
85
- userInfo: {
86
- alignItems: 'flex-end',
87
- },
88
- userName: {
89
- fontSize: 14,
90
- fontWeight: '500',
91
- color: '#1E293B',
92
- },
93
- userRole: {
94
- fontSize: 12,
95
- color: '#64748B',
96
- },
97
- avatar: {
98
- width: 36,
99
- height: 36,
100
- borderRadius: 18,
101
- borderWidth: 2,
102
- borderColor: '#FFFFFF',
103
- ...Platform.select({
104
- ios: {
105
- shadowColor: '#000',
106
- shadowOffset: { width: 0, height: 1 },
107
- shadowOpacity: 0.1,
108
- shadowRadius: 2,
109
- },
110
- android: {
111
- elevation: 2,
112
- },
113
- }),
114
- },
115
- avatarPlaceholder: {
116
- width: 36,
117
- height: 36,
118
- borderRadius: 18,
119
- justifyContent: 'center',
120
- alignItems: 'center',
121
- borderWidth: 2,
122
- borderColor: '#FFFFFF',
123
- backgroundColor: '#3B82F6',
124
- ...Platform.select({
125
- ios: {
126
- shadowColor: '#000',
127
- shadowOffset: { width: 0, height: 1 },
128
- shadowOpacity: 0.1,
129
- shadowRadius: 2,
130
- },
131
- android: {
132
- elevation: 2,
133
- },
134
- }),
135
- },
136
- avatarInitial: {
137
- fontSize: 14,
138
- fontWeight: '700',
139
- color: '#FFFFFF',
140
- },
141
- content: {
142
- paddingHorizontal: 16,
143
- paddingTop: 24,
144
- },
145
- welcomeSection: {
146
- marginBottom: 24,
147
- },
148
- welcomeTitle: {
149
- fontSize: 22,
150
- fontWeight: '700',
151
- color: '#1E293B',
152
- marginBottom: 4,
153
- },
154
- welcomeSubtitle: {
155
- fontSize: 14,
156
- color: '#64748B',
157
- },
158
- statsGrid: {
159
- flexDirection: 'row',
160
- gap: 12,
161
- marginBottom: 24,
162
- },
163
- statCard: {
164
- flex: 1,
165
- backgroundColor: '#FFFFFF',
166
- borderRadius: 12,
167
- padding: 16,
168
- ...Platform.select({
169
- ios: {
170
- shadowColor: '#000',
171
- shadowOffset: { width: 0, height: 1 },
172
- shadowOpacity: 0.05,
173
- shadowRadius: 3,
174
- },
175
- android: {
176
- elevation: 2,
177
- },
178
- }),
179
- },
180
- statCardHeader: {
181
- flexDirection: 'row',
182
- justifyContent: 'space-between',
183
- alignItems: 'flex-start',
184
- marginBottom: 12,
185
- },
186
- statIconContainer: {
187
- width: 40,
188
- height: 40,
189
- borderRadius: 10,
190
14
  justifyContent: 'center',
191
- alignItems: 'center',
192
- },
193
- statIconBlue: {
194
- backgroundColor: '#EFF6FF',
195
- },
196
- statIconRed: {
197
- backgroundColor: '#FEF2F2',
198
- },
199
- statIconGreen: {
200
- backgroundColor: '#ECFDF5',
201
- },
202
- attentionBadge: {
203
- backgroundColor: '#FEF2F2',
204
- paddingHorizontal: 6,
205
- paddingVertical: 2,
206
- borderRadius: 10,
207
- },
208
- attentionBadgeText: {
209
- fontSize: 10,
210
- fontWeight: '500',
211
- color: '#EF4444',
212
- },
213
- rateBadge: {
214
- backgroundColor: '#ECFDF5',
215
- paddingHorizontal: 6,
216
- paddingVertical: 2,
217
- borderRadius: 10,
218
- },
219
- rateBadgeText: {
220
- fontSize: 10,
221
- fontWeight: '500',
222
- color: '#10B981',
223
- },
224
- statValue: {
225
- fontSize: 28,
226
- fontWeight: '700',
227
- color: '#1E293B',
228
- marginBottom: 2,
229
- },
230
- statLabel: {
231
- fontSize: 13,
232
- color: '#64748B',
233
- },
234
- shortcutsSection: {
235
- gap: 12,
236
- marginBottom: 24,
237
- },
238
- shortcutCard: {
239
- flexDirection: 'row',
240
- justifyContent: 'space-between',
241
- alignItems: 'center',
242
- backgroundColor: '#FFFFFF',
243
- borderRadius: 12,
244
- padding: 16,
245
- ...Platform.select({
246
- ios: {
247
- shadowColor: '#000',
248
- shadowOffset: { width: 0, height: 1 },
249
- shadowOpacity: 0.05,
250
- shadowRadius: 3,
251
- },
252
- android: {
253
- elevation: 2,
254
- },
255
- }),
256
15
  },
257
- shortcutContent: {
258
- flex: 1,
259
- marginRight: 16,
16
+ logo: {
17
+ width: 130,
18
+ height: 109,
260
19
  },
261
- shortcutTitle: {
20
+ title: {
262
21
  fontSize: 16,
263
- fontWeight: '600',
264
- color: '#1E293B',
265
- marginBottom: 6,
22
+ fontWeight: 'bold',
266
23
  },
267
- shortcutDescription: {
268
- fontSize: 13,
269
- color: '#64748B',
270
- marginBottom: 10,
271
- lineHeight: 18,
272
- },
273
- shortcutAction: {
274
- flexDirection: 'row',
275
- alignItems: 'center',
276
- gap: 6,
277
- },
278
- shortcutActionText: {
279
- fontSize: 13,
280
- fontWeight: '500',
281
- color: '#2563EB',
282
- },
283
- shortcutIconContainer: {
284
- width: 56,
285
- height: 56,
286
- borderRadius: 28,
287
- justifyContent: 'center',
288
- alignItems: 'center',
289
- },
290
- shortcutIconBlue: {
291
- backgroundColor: '#EFF6FF',
292
- },
293
- shortcutIconGreen: {
294
- backgroundColor: '#ECFDF5',
295
- },
296
- bannerContainer: {
297
- height: 160,
298
- borderRadius: 12,
299
- overflow: 'hidden',
300
- backgroundColor: '#1E3A8A',
301
- },
302
- bannerOverlay: {
303
- flex: 1,
304
- justifyContent: 'center',
305
- paddingHorizontal: 20,
306
- },
307
- bannerTitle: {
308
- fontSize: 18,
309
- fontWeight: '700',
310
- color: '#FFFFFF',
311
- marginBottom: 6,
312
- },
313
- bannerSubtitle: {
314
- fontSize: 13,
315
- color: '#BFDBFE',
316
- marginBottom: 16,
317
- },
318
- bannerButton: {
319
- alignSelf: 'flex-start',
320
- backgroundColor: '#FFFFFF',
321
- paddingHorizontal: 20,
322
- paddingVertical: 10,
323
- borderRadius: 8,
324
- },
325
- bannerButtonText: {
326
- fontSize: 13,
327
- fontWeight: '500',
328
- color: '#2563EB',
24
+ description: {
25
+ fontSize: 14,
26
+ marginTop: Spacing.sm,
329
27
  },
330
28
  });
331
-
332
- export default styles;
@@ -0,0 +1,24 @@
1
+ {
2
+ "extends": "expo/tsconfig.base",
3
+ "compilerOptions": {
4
+ "skipLibCheck": true,
5
+ "jsx": "react-jsx",
6
+ "baseUrl": ".",
7
+ "strict": true,
8
+ "noEmit": true,
9
+ "paths": {
10
+ "@/*": ["./*"]
11
+ }
12
+ },
13
+ "include": ["**/*.ts", "**/*.tsx", ".expo/types/**/*.ts", "expo-env.d.ts"],
14
+ "exclude": [
15
+ "node_modules",
16
+ "**/*.spec.ts",
17
+ "**/*.test.ts",
18
+ "**/*.spec.tsx",
19
+ "**/*.test.tsx",
20
+ "dist",
21
+ "build",
22
+ ".expo"
23
+ ]
24
+ }
@@ -1,4 +1,3 @@
1
- // import { OpenAPI } from '@api'; // 如果使用 openapi 客户端,请取消注释并确保安装
2
1
  import dayjs from 'dayjs';
3
2
  import utc from 'dayjs/plugin/utc';
4
3
  dayjs.extend(utc);
@@ -26,7 +25,7 @@ export const buildAssetUrl = (url?: string | null, w?: number, h?: number): stri
26
25
  // 3. 构造参数,保留原有 Query (如有)
27
26
  const separator = abs.includes('?') ? '&' : '?';
28
27
  const query = [
29
- w ? `w=${Math.floor(w)}` : '',
28
+ w ? `w=${Math.floor(w)}` : '',
30
29
  h ? `h=${Math.floor(h)}` : ''
31
30
  ].filter(Boolean).join('&');
32
31
  return `${abs}${separator}${query}`;
@@ -1,110 +1,22 @@
1
1
  {
2
- "name": "<%= appName %>",
3
- "version": "1.0.0",
2
+ "name": "expo-express-monorepo",
4
3
  "private": true,
5
- "main": "client/index.js",
4
+ "version": "0.0.0",
6
5
  "scripts": {
7
- "build": "bash .cozeproj/scripts/deploy_build.sh",
8
- "check-deps": "npx depcheck",
9
- "dev": "bash .cozeproj/scripts/deploy_run.sh",
10
- "preinstall": "npx only-allow pnpm",
11
- "postinstall": "node ./client/scripts/install-missing-deps.js",
12
- "install-missing": "node ./client/scripts/install-missing-deps.js",
13
- "lint": "expo lint",
14
- "server": "NODE_ENV=development tsx ./src/index.ts",
15
- "start": "expo start --web",
16
- "test": "jest --watchAll"
17
- },
18
- "jest": {
19
- "preset": "jest-expo"
20
- },
21
- "dependencies": {
22
- "@aws-sdk/client-s3": "^3.958.0",
23
- "@aws-sdk/lib-storage": "^3.958.0",
24
- "@expo/metro-runtime": "^6.1.2",
25
- "@expo/vector-icons": "^15.0.0",
26
- "@react-native-async-storage/async-storage": "^2.2.0",
27
- "@react-native-community/datetimepicker": "^8.5.0",
28
- "@react-native-community/slider": "^5.0.1",
29
- "@react-native-masked-view/masked-view": "^0.3.2",
30
- "@react-native-picker/picker": "^2.11.0",
31
- "@react-navigation/bottom-tabs": "^7.2.0",
32
- "@react-navigation/native": "^7.0.14",
33
- "ajv": "^8.17.1",
34
- "ajv-formats": "^3.0.1",
35
- "connect": "^3.7.0",
36
- "coze-coding-dev-sdk": "0.5.0",
37
- "dayjs": "^1.11.19",
38
- "drizzle-kit": "^0.31.8",
39
- "drizzle-orm": "^0.45.1",
40
- "drizzle-zod": "^0.8.3",
41
- "expo": "^54.0.7",
42
- "expo-auth-session": "^7.0.9",
43
- "expo-av": "~16.0.6",
44
- "expo-blur": "~15.0.6",
45
- "expo-camera": "~17.0.10",
46
- "expo-constants": "~18.0.8",
47
- "expo-crypto": "^15.0.7",
48
- "expo-font": "~14.0.7",
49
- "expo-haptics": "~15.0.6",
50
- "expo-image-picker": "~17.0.7",
51
- "expo-linear-gradient": "~15.0.6",
52
- "expo-linking": "~8.0.7",
53
- "expo-location": "~19.0.7",
54
- "expo-router": "~6.0.0",
55
- "expo-splash-screen": "~31.0.8",
56
- "expo-status-bar": "~3.0.7",
57
- "expo-symbols": "~1.0.6",
58
- "expo-system-ui": "~6.0.9",
59
- "expo-web-browser": "~15.0.10",
60
- "express": "^4.22.1",
61
- "pg": "^8.16.3",
62
- "react": "19.1.0",
63
- "react-dom": "19.1.0",
64
- "react-native": "0.81.5",
65
- "react-native-chart-kit": "^6.12.0",
66
- "react-native-gesture-handler": "~2.28.0",
67
- "react-native-keyboard-aware-scroll-view": "^0.9.5",
68
- "react-native-modal-datetime-picker": "18.0.0",
69
- "react-native-reanimated": "~4.1.0",
70
- "react-native-safe-area-context": "~5.6.0",
71
- "react-native-screens": "~4.16.0",
72
- "react-native-svg": "15.15.0",
73
- "react-native-toast-message": "^2.3.3",
74
- "react-native-web": "^0.21.2",
75
- "react-native-webview": "~13.15.0",
76
- "react-native-worklets": "0.5.1",
77
- "zod": "^4.2.1"
78
- },
79
- "devDependencies": {
80
- "@babel/core": "^7.25.2",
81
- "@eslint/js": "^9.27.0",
82
- "@types/express": "^5.0.6",
83
- "@types/jest": "^29.5.12",
84
- "@types/pg": "^8.16.0",
85
- "@types/react": "~19.1.0",
86
- "@types/react-test-renderer": "19.1.0",
87
- "babel-plugin-module-resolver": "^5.0.2",
88
- "babel-preset-expo": "^54.0.9",
89
- "chalk": "^4.1.2",
90
- "depcheck": "^1.4.7",
91
- "eslint": "^9.27.0",
92
- "eslint-formatter-compact": "^9.0.1",
93
- "eslint-import-resolver-typescript": "^4.4.4",
94
- "eslint-plugin-import": "^2.32.0",
95
- "eslint-plugin-react": "^7.37.5",
96
- "eslint-plugin-react-hooks": "^7.0.1",
97
- "eslint-plugin-regexp": "^2.10.0",
98
- "globals": "^16.1.0",
99
- "jest": "^29.2.1",
100
- "jest-expo": "~54.0.10",
101
- "react-test-renderer": "19.1.0",
102
- "tsx": "^4.21.0",
103
- "typescript": "^5.8.3",
104
- "typescript-eslint": "^8.32.1"
6
+ "dev": "bash .cozeproj/scripts/dev_run.sh",
7
+ "build": "bash .cozeproj/scripts/prod_build.sh",
8
+ "start": "bash .cozeproj/scripts/prod_run.sh",
9
+ "preinstall": "npx only-allow pnpm"
105
10
  },
11
+ "dependencies": {},
12
+ "devDependencies": {},
106
13
  "packageManager": "pnpm@9.0.0",
107
14
  "engines": {
108
15
  "pnpm": ">=9.0.0"
16
+ },
17
+ "pnpm": {
18
+ "overrides": {
19
+ "esbuild": "0.27.2"
20
+ }
109
21
  }
110
22
  }