@coze-arch/cli 0.0.1-alpha.f74941 → 0.0.1-alpha.ff64d9

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 (167) 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/.cozeproj/scripts/server_dev_run.sh +45 -0
  7. package/lib/__templates__/expo/README.md +66 -7
  8. package/lib/__templates__/expo/_gitignore +1 -1
  9. package/lib/__templates__/expo/_npmrc +3 -5
  10. package/lib/__templates__/expo/client/app/_layout.tsx +14 -14
  11. package/lib/__templates__/expo/client/app/demo.tsx +1 -0
  12. package/lib/__templates__/expo/client/app/index.tsx +1 -0
  13. package/lib/__templates__/expo/client/app.config.ts +75 -0
  14. package/lib/__templates__/expo/client/components/ThemedText.tsx +33 -0
  15. package/lib/__templates__/expo/client/components/ThemedView.tsx +38 -0
  16. package/lib/__templates__/expo/client/constants/theme.ts +786 -50
  17. package/lib/__templates__/expo/client/contexts/AuthContext.tsx +14 -107
  18. package/lib/__templates__/expo/client/declarations.d.ts +5 -0
  19. package/lib/__templates__/expo/client/hooks/useColorScheme.ts +34 -1
  20. package/lib/__templates__/expo/client/hooks/useTheme.ts +1 -1
  21. package/lib/__templates__/expo/client/metro.config.js +121 -0
  22. package/lib/__templates__/expo/client/package.json +93 -0
  23. package/lib/__templates__/expo/client/screens/demo/index.tsx +25 -0
  24. package/lib/__templates__/expo/client/screens/demo/styles.ts +28 -0
  25. package/lib/__templates__/expo/client/scripts/install-missing-deps.js +36 -12
  26. package/lib/__templates__/expo/client/tsconfig.json +24 -0
  27. package/lib/__templates__/expo/client/utils/index.ts +1 -2
  28. package/lib/__templates__/expo/package.json +13 -92
  29. package/lib/__templates__/expo/pnpm-lock.yaml +675 -678
  30. package/lib/__templates__/expo/pnpm-workspace.yaml +3 -0
  31. package/lib/__templates__/expo/server/package.json +32 -0
  32. package/lib/__templates__/expo/{src → server/src}/index.ts +8 -2
  33. package/lib/__templates__/expo/server/tsconfig.json +24 -0
  34. package/lib/__templates__/expo/template.config.js +2 -1
  35. package/lib/__templates__/expo/tsconfig.json +1 -24
  36. package/lib/__templates__/nextjs/.coze +4 -3
  37. package/lib/__templates__/nextjs/README.md +341 -19
  38. package/lib/__templates__/nextjs/_npmrc +2 -1
  39. package/lib/__templates__/nextjs/components.json +21 -0
  40. package/lib/__templates__/nextjs/next.config.ts +12 -0
  41. package/lib/__templates__/nextjs/package.json +56 -2
  42. package/lib/__templates__/nextjs/pnpm-lock.yaml +7951 -1519
  43. package/lib/__templates__/nextjs/scripts/dev.sh +9 -27
  44. package/lib/__templates__/{react-rsbuild/scripts/build.sh → nextjs/scripts/prepare.sh} +0 -5
  45. package/lib/__templates__/nextjs/src/app/globals.css +124 -13
  46. package/lib/__templates__/nextjs/src/app/layout.tsx +19 -30
  47. package/lib/__templates__/nextjs/src/app/page.tsx +35 -23
  48. package/lib/__templates__/nextjs/src/components/ui/accordion.tsx +66 -0
  49. package/lib/__templates__/nextjs/src/components/ui/alert-dialog.tsx +157 -0
  50. package/lib/__templates__/nextjs/src/components/ui/alert.tsx +66 -0
  51. package/lib/__templates__/nextjs/src/components/ui/aspect-ratio.tsx +11 -0
  52. package/lib/__templates__/nextjs/src/components/ui/avatar.tsx +53 -0
  53. package/lib/__templates__/nextjs/src/components/ui/badge.tsx +46 -0
  54. package/lib/__templates__/nextjs/src/components/ui/breadcrumb.tsx +109 -0
  55. package/lib/__templates__/nextjs/src/components/ui/button-group.tsx +83 -0
  56. package/lib/__templates__/nextjs/src/components/ui/button.tsx +62 -0
  57. package/lib/__templates__/nextjs/src/components/ui/calendar.tsx +220 -0
  58. package/lib/__templates__/nextjs/src/components/ui/card.tsx +92 -0
  59. package/lib/__templates__/nextjs/src/components/ui/carousel.tsx +241 -0
  60. package/lib/__templates__/nextjs/src/components/ui/chart.tsx +357 -0
  61. package/lib/__templates__/nextjs/src/components/ui/checkbox.tsx +32 -0
  62. package/lib/__templates__/nextjs/src/components/ui/collapsible.tsx +33 -0
  63. package/lib/__templates__/nextjs/src/components/ui/command.tsx +184 -0
  64. package/lib/__templates__/nextjs/src/components/ui/context-menu.tsx +252 -0
  65. package/lib/__templates__/nextjs/src/components/ui/dialog.tsx +143 -0
  66. package/lib/__templates__/nextjs/src/components/ui/drawer.tsx +135 -0
  67. package/lib/__templates__/nextjs/src/components/ui/dropdown-menu.tsx +257 -0
  68. package/lib/__templates__/nextjs/src/components/ui/empty.tsx +104 -0
  69. package/lib/__templates__/nextjs/src/components/ui/field.tsx +248 -0
  70. package/lib/__templates__/nextjs/src/components/ui/form.tsx +167 -0
  71. package/lib/__templates__/nextjs/src/components/ui/hover-card.tsx +44 -0
  72. package/lib/__templates__/nextjs/src/components/ui/input-group.tsx +170 -0
  73. package/lib/__templates__/nextjs/src/components/ui/input-otp.tsx +77 -0
  74. package/lib/__templates__/nextjs/src/components/ui/input.tsx +21 -0
  75. package/lib/__templates__/nextjs/src/components/ui/item.tsx +193 -0
  76. package/lib/__templates__/nextjs/src/components/ui/kbd.tsx +28 -0
  77. package/lib/__templates__/nextjs/src/components/ui/label.tsx +24 -0
  78. package/lib/__templates__/nextjs/src/components/ui/menubar.tsx +276 -0
  79. package/lib/__templates__/nextjs/src/components/ui/navigation-menu.tsx +168 -0
  80. package/lib/__templates__/nextjs/src/components/ui/pagination.tsx +127 -0
  81. package/lib/__templates__/nextjs/src/components/ui/popover.tsx +48 -0
  82. package/lib/__templates__/nextjs/src/components/ui/progress.tsx +31 -0
  83. package/lib/__templates__/nextjs/src/components/ui/radio-group.tsx +45 -0
  84. package/lib/__templates__/nextjs/src/components/ui/resizable.tsx +63 -0
  85. package/lib/__templates__/nextjs/src/components/ui/scroll-area.tsx +58 -0
  86. package/lib/__templates__/nextjs/src/components/ui/select.tsx +190 -0
  87. package/lib/__templates__/nextjs/src/components/ui/separator.tsx +28 -0
  88. package/lib/__templates__/nextjs/src/components/ui/sheet.tsx +139 -0
  89. package/lib/__templates__/nextjs/src/components/ui/sidebar.tsx +724 -0
  90. package/lib/__templates__/nextjs/src/components/ui/skeleton.tsx +13 -0
  91. package/lib/__templates__/nextjs/src/components/ui/slider.tsx +63 -0
  92. package/lib/__templates__/nextjs/src/components/ui/sonner.tsx +40 -0
  93. package/lib/__templates__/nextjs/src/components/ui/spinner.tsx +16 -0
  94. package/lib/__templates__/nextjs/src/components/ui/switch.tsx +31 -0
  95. package/lib/__templates__/nextjs/src/components/ui/table.tsx +116 -0
  96. package/lib/__templates__/nextjs/src/components/ui/tabs.tsx +66 -0
  97. package/lib/__templates__/nextjs/src/components/ui/textarea.tsx +18 -0
  98. package/lib/__templates__/nextjs/src/components/ui/toggle-group.tsx +83 -0
  99. package/lib/__templates__/nextjs/src/components/ui/toggle.tsx +47 -0
  100. package/lib/__templates__/nextjs/src/components/ui/tooltip.tsx +61 -0
  101. package/lib/__templates__/nextjs/src/hooks/use-mobile.ts +19 -0
  102. package/lib/__templates__/nextjs/src/lib/utils.ts +6 -0
  103. package/lib/__templates__/nextjs/template.config.js +32 -2
  104. package/lib/__templates__/templates.json +61 -74
  105. package/lib/__templates__/vite/.coze +4 -3
  106. package/lib/__templates__/vite/README.md +204 -26
  107. package/lib/__templates__/vite/_npmrc +2 -1
  108. package/lib/__templates__/vite/eslint.config.mjs +9 -0
  109. package/lib/__templates__/vite/package.json +6 -2
  110. package/lib/__templates__/vite/pnpm-lock.yaml +3486 -19
  111. package/lib/__templates__/vite/scripts/dev.sh +7 -26
  112. package/lib/__templates__/{rsbuild/scripts/build.sh → vite/scripts/prepare.sh} +0 -5
  113. package/lib/__templates__/vite/src/main.ts +1 -2
  114. package/lib/__templates__/vite/template.config.js +39 -6
  115. package/lib/__templates__/vite/vite.config.ts +3 -3
  116. package/lib/cli.js +634 -313
  117. package/package.json +11 -4
  118. package/lib/__templates__/expo/.cozeproj/scripts/deploy_build.sh +0 -109
  119. package/lib/__templates__/expo/.cozeproj/scripts/deploy_run.sh +0 -257
  120. package/lib/__templates__/expo/app.json +0 -63
  121. package/lib/__templates__/expo/babel.config.js +0 -9
  122. package/lib/__templates__/expo/client/app/(tabs)/_layout.tsx +0 -43
  123. package/lib/__templates__/expo/client/app/(tabs)/home.tsx +0 -1
  124. package/lib/__templates__/expo/client/app/(tabs)/index.tsx +0 -7
  125. package/lib/__templates__/expo/client/app/+not-found.tsx +0 -79
  126. package/lib/__templates__/expo/client/index.js +0 -11
  127. package/lib/__templates__/expo/client/screens/home/index.tsx +0 -54
  128. package/lib/__templates__/expo/client/screens/home/styles.ts +0 -332
  129. package/lib/__templates__/expo/metro.config.js +0 -53
  130. package/lib/__templates__/nextjs/.vscode/settings.json +0 -121
  131. package/lib/__templates__/react-rsbuild/.coze +0 -11
  132. package/lib/__templates__/react-rsbuild/.vscode/settings.json +0 -121
  133. package/lib/__templates__/react-rsbuild/README.md +0 -61
  134. package/lib/__templates__/react-rsbuild/_gitignore +0 -97
  135. package/lib/__templates__/react-rsbuild/_npmrc +0 -22
  136. package/lib/__templates__/react-rsbuild/package.json +0 -31
  137. package/lib/__templates__/react-rsbuild/pnpm-lock.yaml +0 -997
  138. package/lib/__templates__/react-rsbuild/rsbuild.config.ts +0 -13
  139. package/lib/__templates__/react-rsbuild/scripts/dev.sh +0 -51
  140. package/lib/__templates__/react-rsbuild/scripts/start.sh +0 -15
  141. package/lib/__templates__/react-rsbuild/src/App.tsx +0 -60
  142. package/lib/__templates__/react-rsbuild/src/index.css +0 -21
  143. package/lib/__templates__/react-rsbuild/src/index.html +0 -12
  144. package/lib/__templates__/react-rsbuild/src/index.tsx +0 -16
  145. package/lib/__templates__/react-rsbuild/tailwind.config.js +0 -9
  146. package/lib/__templates__/react-rsbuild/template.config.js +0 -54
  147. package/lib/__templates__/react-rsbuild/tsconfig.json +0 -17
  148. package/lib/__templates__/rsbuild/.coze +0 -11
  149. package/lib/__templates__/rsbuild/.vscode/settings.json +0 -7
  150. package/lib/__templates__/rsbuild/README.md +0 -61
  151. package/lib/__templates__/rsbuild/_gitignore +0 -97
  152. package/lib/__templates__/rsbuild/_npmrc +0 -22
  153. package/lib/__templates__/rsbuild/package.json +0 -24
  154. package/lib/__templates__/rsbuild/pnpm-lock.yaml +0 -888
  155. package/lib/__templates__/rsbuild/rsbuild.config.ts +0 -12
  156. package/lib/__templates__/rsbuild/scripts/dev.sh +0 -51
  157. package/lib/__templates__/rsbuild/scripts/start.sh +0 -15
  158. package/lib/__templates__/rsbuild/src/index.css +0 -21
  159. package/lib/__templates__/rsbuild/src/index.html +0 -12
  160. package/lib/__templates__/rsbuild/src/index.ts +0 -5
  161. package/lib/__templates__/rsbuild/src/main.ts +0 -65
  162. package/lib/__templates__/rsbuild/tailwind.config.js +0 -9
  163. package/lib/__templates__/rsbuild/template.config.js +0 -56
  164. package/lib/__templates__/rsbuild/tsconfig.json +0 -16
  165. package/lib/__templates__/vite/.vscode/settings.json +0 -7
  166. /package/lib/__templates__/expo/{eslint-formatter-simple.mjs → client/eslint-formatter-simple.mjs} +0 -0
  167. /package/lib/__templates__/expo/{eslint.config.mjs → client/eslint.config.mjs} +0 -0
@@ -3,44 +3,26 @@ set -Eeuo pipefail
3
3
 
4
4
  PORT=<%= port %>
5
5
  COZE_WORKSPACE_PATH="${COZE_WORKSPACE_PATH:-$(pwd)}"
6
+ NODE_ENV=development
7
+ DEPLOY_RUN_PORT=<%= port %>
6
8
 
7
9
  cd "${COZE_WORKSPACE_PATH}"
8
10
 
9
11
  kill_port_if_listening() {
10
12
  local pids
11
-
12
- # Check if lsof is available (macOS/BSD) or ss (Linux)
13
- if command -v lsof >/dev/null 2>&1; then
14
- # macOS/BSD using lsof
15
- pids=$(lsof -ti:${PORT} 2>/dev/null || true)
16
- elif command -v ss >/dev/null 2>&1; then
17
- # Linux using ss
18
- pids=$(ss -H -lntp 2>/dev/null | awk -v port="${PORT}" '$4 ~ ":"port"$"' | grep -o 'pid=[0-9]*' | cut -d= -f2 | paste -sd' ' - || true)
19
- else
20
- echo "Warning: neither lsof nor ss found, cannot check port ${PORT}"
21
- return
22
- fi
23
-
13
+ pids=$(ss -H -lntp 2>/dev/null | awk -v port="${DEPLOY_RUN_PORT}" '$4 ~ ":"port"$"' | grep -o 'pid=[0-9]*' | cut -d= -f2 | paste -sd' ' - || true)
24
14
  if [[ -z "${pids}" ]]; then
25
- echo "Port ${PORT} is free."
15
+ echo "Port ${DEPLOY_RUN_PORT} is free."
26
16
  return
27
17
  fi
28
-
29
- echo "Port ${PORT} in use by PIDs: ${pids} (SIGKILL)"
18
+ echo "Port ${DEPLOY_RUN_PORT} in use by PIDs: ${pids} (SIGKILL)"
30
19
  echo "${pids}" | xargs -I {} kill -9 {}
31
20
  sleep 1
32
-
33
- # Verify port is cleared
34
- if command -v lsof >/dev/null 2>&1; then
35
- pids=$(lsof -ti:${PORT} 2>/dev/null || true)
36
- elif command -v ss >/dev/null 2>&1; then
37
- pids=$(ss -H -lntp 2>/dev/null | awk -v port="${PORT}" '$4 ~ ":"port"$"' | grep -o 'pid=[0-9]*' | cut -d= -f2 | paste -sd' ' - || true)
38
- fi
39
-
21
+ pids=$(ss -H -lntp 2>/dev/null | awk -v port="${DEPLOY_RUN_PORT}" '$4 ~ ":"port"$"' | grep -o 'pid=[0-9]*' | cut -d= -f2 | paste -sd' ' - || true)
40
22
  if [[ -n "${pids}" ]]; then
41
- echo "Warning: port ${PORT} still busy after SIGKILL, PIDs: ${pids}"
23
+ echo "Warning: port ${DEPLOY_RUN_PORT} still busy after SIGKILL, PIDs: ${pids}"
42
24
  else
43
- echo "Port ${PORT} cleared."
25
+ echo "Port ${DEPLOY_RUN_PORT} cleared."
44
26
  fi
45
27
  }
46
28
 
@@ -48,4 +30,4 @@ echo "Clearing port ${PORT} before start."
48
30
  kill_port_if_listening
49
31
  echo "Starting HTTP service on port ${PORT} for dev..."
50
32
 
51
- npx next dev -p $PORT
33
+ npx next dev --webpack --port $PORT
@@ -7,8 +7,3 @@ cd "${COZE_WORKSPACE_PATH}"
7
7
 
8
8
  echo "Installing dependencies..."
9
9
  pnpm install --prefer-frozen-lockfile --prefer-offline --loglevel debug --reporter=append-only
10
-
11
- echo "Building the project..."
12
- npx rsbuild build
13
-
14
- echo "Build completed successfully!"
@@ -1,26 +1,137 @@
1
1
  @import 'tailwindcss';
2
+ @import 'tw-animate-css';
2
3
 
3
- :root {
4
- --background: #ffffff;
5
- --foreground: #171717;
6
- }
4
+ @custom-variant dark (&:is(.dark *));
7
5
 
8
6
  @theme inline {
9
7
  --color-background: var(--background);
10
8
  --color-foreground: var(--foreground);
11
- --font-sans: var(--font-geist-sans);
12
- --font-mono: var(--font-geist-mono);
9
+ --color-sidebar-ring: var(--sidebar-ring);
10
+ --color-sidebar-border: var(--sidebar-border);
11
+ --color-sidebar-accent-foreground: var(--sidebar-accent-foreground);
12
+ --color-sidebar-accent: var(--sidebar-accent);
13
+ --color-sidebar-primary-foreground: var(--sidebar-primary-foreground);
14
+ --color-sidebar-primary: var(--sidebar-primary);
15
+ --color-sidebar-foreground: var(--sidebar-foreground);
16
+ --color-sidebar: var(--sidebar);
17
+ --color-chart-5: var(--chart-5);
18
+ --color-chart-4: var(--chart-4);
19
+ --color-chart-3: var(--chart-3);
20
+ --color-chart-2: var(--chart-2);
21
+ --color-chart-1: var(--chart-1);
22
+ --color-ring: var(--ring);
23
+ --color-input: var(--input);
24
+ --color-border: var(--border);
25
+ --color-destructive: var(--destructive);
26
+ --color-accent-foreground: var(--accent-foreground);
27
+ --color-accent: var(--accent);
28
+ --color-muted-foreground: var(--muted-foreground);
29
+ --color-muted: var(--muted);
30
+ --color-secondary-foreground: var(--secondary-foreground);
31
+ --color-secondary: var(--secondary);
32
+ --color-primary-foreground: var(--primary-foreground);
33
+ --color-primary: var(--primary);
34
+ --color-popover-foreground: var(--popover-foreground);
35
+ --color-popover: var(--popover);
36
+ --color-card-foreground: var(--card-foreground);
37
+ --color-card: var(--card);
38
+ --radius-sm: calc(var(--radius) - 4px);
39
+ --radius-md: calc(var(--radius) - 2px);
40
+ --radius-lg: var(--radius);
41
+ --radius-xl: calc(var(--radius) + 4px);
42
+ --radius-2xl: calc(var(--radius) + 8px);
43
+ --radius-3xl: calc(var(--radius) + 12px);
44
+ --radius-4xl: calc(var(--radius) + 16px);
45
+ --font-sans:
46
+ 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', ui-sans-serif,
47
+ system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto,
48
+ 'Helvetica Neue', Arial, sans-serif;
49
+ --font-mono:
50
+ ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono',
51
+ 'Courier New', monospace;
52
+ --font-serif:
53
+ 'Noto Serif SC', 'Songti SC', 'SimSun', ui-serif, Georgia, Cambria,
54
+ 'Times New Roman', Times, serif;
55
+ }
56
+
57
+ :root {
58
+ --radius: 0.625rem;
59
+ --background: oklch(1 0 0);
60
+ --foreground: oklch(0.145 0 0);
61
+ --card: oklch(1 0 0);
62
+ --card-foreground: oklch(0.145 0 0);
63
+ --popover: oklch(1 0 0);
64
+ --popover-foreground: oklch(0.145 0 0);
65
+ --primary: oklch(0.205 0 0);
66
+ --primary-foreground: oklch(0.985 0 0);
67
+ --secondary: oklch(0.97 0 0);
68
+ --secondary-foreground: oklch(0.205 0 0);
69
+ --muted: oklch(0.97 0 0);
70
+ --muted-foreground: oklch(0.556 0 0);
71
+ --accent: oklch(0.97 0 0);
72
+ --accent-foreground: oklch(0.205 0 0);
73
+ --destructive: oklch(0.577 0.245 27.325);
74
+ --border: oklch(0.922 0 0);
75
+ --input: oklch(0.922 0 0);
76
+ --ring: oklch(0.708 0 0);
77
+ --chart-1: oklch(0.646 0.222 41.116);
78
+ --chart-2: oklch(0.6 0.118 184.704);
79
+ --chart-3: oklch(0.398 0.07 227.392);
80
+ --chart-4: oklch(0.828 0.189 84.429);
81
+ --chart-5: oklch(0.769 0.188 70.08);
82
+ --sidebar: oklch(0.985 0 0);
83
+ --sidebar-foreground: oklch(0.145 0 0);
84
+ --sidebar-primary: oklch(0.205 0 0);
85
+ --sidebar-primary-foreground: oklch(0.985 0 0);
86
+ --sidebar-accent: oklch(0.97 0 0);
87
+ --sidebar-accent-foreground: oklch(0.205 0 0);
88
+ --sidebar-border: oklch(0.922 0 0);
89
+ --sidebar-ring: oklch(0.708 0 0);
90
+ }
91
+
92
+ .dark {
93
+ --background: oklch(0.145 0 0);
94
+ --foreground: oklch(0.985 0 0);
95
+ --card: oklch(0.205 0 0);
96
+ --card-foreground: oklch(0.985 0 0);
97
+ --popover: oklch(0.205 0 0);
98
+ --popover-foreground: oklch(0.985 0 0);
99
+ --primary: oklch(0.922 0 0);
100
+ --primary-foreground: oklch(0.205 0 0);
101
+ --secondary: oklch(0.269 0 0);
102
+ --secondary-foreground: oklch(0.985 0 0);
103
+ --muted: oklch(0.269 0 0);
104
+ --muted-foreground: oklch(0.708 0 0);
105
+ --accent: oklch(0.269 0 0);
106
+ --accent-foreground: oklch(0.985 0 0);
107
+ --destructive: oklch(0.704 0.191 22.216);
108
+ --border: oklch(1 0 0 / 10%);
109
+ --input: oklch(1 0 0 / 15%);
110
+ --ring: oklch(0.556 0 0);
111
+ --chart-1: oklch(0.488 0.243 264.376);
112
+ --chart-2: oklch(0.696 0.17 162.48);
113
+ --chart-3: oklch(0.769 0.188 70.08);
114
+ --chart-4: oklch(0.627 0.265 303.9);
115
+ --chart-5: oklch(0.645 0.246 16.439);
116
+ --sidebar: oklch(0.205 0 0);
117
+ --sidebar-foreground: oklch(0.985 0 0);
118
+ --sidebar-primary: oklch(0.488 0.243 264.376);
119
+ --sidebar-primary-foreground: oklch(0.985 0 0);
120
+ --sidebar-accent: oklch(0.269 0 0);
121
+ --sidebar-accent-foreground: oklch(0.985 0 0);
122
+ --sidebar-border: oklch(1 0 0 / 10%);
123
+ --sidebar-ring: oklch(0.556 0 0);
13
124
  }
14
125
 
15
- @media (prefers-color-scheme: dark) {
16
- :root {
17
- --background: #0a0a0a;
18
- --foreground: #ededed;
126
+ @layer base {
127
+ * {
128
+ @apply border-border outline-ring/50;
129
+ }
130
+ body {
131
+ @apply bg-background text-foreground;
19
132
  }
20
133
  }
21
134
 
22
135
  body {
23
- background: var(--background);
24
- color: var(--foreground);
25
- font-family: Arial, Helvetica, sans-serif;
136
+ @apply font-sans;
26
137
  }
@@ -1,17 +1,6 @@
1
1
  import type { Metadata } from 'next';
2
- import { Geist, Geist_Mono } from 'next/font/google';
3
2
  import './globals.css';
4
3
 
5
- const geistSans = Geist({
6
- variable: '--font-geist-sans',
7
- subsets: ['latin'],
8
- });
9
-
10
- const geistMono = Geist_Mono({
11
- variable: '--font-geist-mono',
12
- subsets: ['latin'],
13
- });
14
-
15
4
  export const metadata: Metadata = {
16
5
  title: {
17
6
  default: '新应用 | 扣子编程',
@@ -33,9 +22,9 @@ export const metadata: Metadata = {
33
22
  ],
34
23
  authors: [{ name: 'Coze Code Team', url: 'https://code.coze.cn' }],
35
24
  generator: 'Coze Code',
36
- icons: {
37
- icon: '',
38
- },
25
+ // icons: {
26
+ // icon: '',
27
+ // },
39
28
  openGraph: {
40
29
  title: '扣子编程 | 你的 AI 工程师已就位',
41
30
  description:
@@ -44,22 +33,22 @@ export const metadata: Metadata = {
44
33
  siteName: '扣子编程',
45
34
  locale: 'zh_CN',
46
35
  type: 'website',
47
- images: [
48
- {
49
- url: '',
50
- width: 1200,
51
- height: 630,
52
- alt: '扣子编程 - 你的 AI 工程师',
53
- },
54
- ],
55
- },
56
- twitter: {
57
- card: 'summary_large_image',
58
- title: 'Coze Code | Your AI Engineer is Here',
59
- description:
60
- 'Build and deploy full-stack applications through AI conversation. No env setup, just flow.',
61
- images: [''],
36
+ // images: [
37
+ // {
38
+ // url: '',
39
+ // width: 1200,
40
+ // height: 630,
41
+ // alt: '扣子编程 - 你的 AI 工程师',
42
+ // },
43
+ // ],
62
44
  },
45
+ // twitter: {
46
+ // card: 'summary_large_image',
47
+ // title: 'Coze Code | Your AI Engineer is Here',
48
+ // description:
49
+ // 'Build and deploy full-stack applications through AI conversation. No env setup, just flow.',
50
+ // // images: [''],
51
+ // },
63
52
  robots: {
64
53
  index: true,
65
54
  follow: true,
@@ -74,7 +63,7 @@ export default function RootLayout({
74
63
  return (
75
64
  <html lang="en">
76
65
  <body
77
- className={`${geistSans.variable} ${geistMono.variable} antialiased`}
66
+ className={`antialiased`}
78
67
  >
79
68
  {children}
80
69
  </body>
@@ -1,4 +1,6 @@
1
1
  import type { Metadata } from 'next';
2
+ import Image from 'next/image';
3
+ import { Button } from '@/components/ui/button';
2
4
 
3
5
  export const metadata: Metadata = {
4
6
  title: '扣子编程 - AI 开发伙伴',
@@ -7,31 +9,29 @@ export const metadata: Metadata = {
7
9
 
8
10
  export default function Home() {
9
11
  return (
10
- <div className="flex min-h-screen items-center justify-center bg-white text-black transition-colors duration-300 dark:bg-black dark:text-white">
12
+ <div className="flex min-h-screen items-center justify-center bg-background text-foreground transition-colors duration-300 dark:bg-background dark:text-foreground">
11
13
  {/* 主容器 */}
12
14
  <main className="flex min-h-screen w-full max-w-3xl flex-col items-center justify-between px-16 py-32 sm:items-start">
13
15
  {/* 头部:Logo 和 产品名称 */}
14
16
  <div className="flex items-center gap-3">
15
- {/* 注意:生产环境建议使用 next/image 并配置 remotePatterns */}
16
- <img
17
- className="dark:invert"
18
- src="https://lf3-static.bytednsdoc.com/obj/eden-cn/hkpzboz/coze_logo.png"
17
+ <Image
18
+ src="https://lf-coze-web-cdn.coze.cn/obj/eden-cn/lm-lgvj/ljhwZthlaukjlkulzlp/favicon.svg"
19
19
  alt="扣子编程 Logo"
20
20
  width={40}
21
21
  height={40}
22
- style={{ width: '40px', height: '40px', objectFit: 'contain' }}
22
+ unoptimized
23
23
  />
24
- <span className="text-xl font-bold tracking-tight text-black dark:text-zinc-50">
24
+ <span className="text-xl font-bold tracking-tight text-foreground dark:text-foreground">
25
25
  扣子编程
26
26
  </span>
27
27
  </div>
28
28
 
29
29
  {/* 中间内容区:主标题和副标题 */}
30
30
  <div className="flex flex-col items-center gap-6 text-center sm:items-start sm:text-left">
31
- <h1 className="max-w-xl text-4xl font-semibold leading-tight tracking-tight text-black dark:text-zinc-50">
31
+ <h1 className="max-w-xl text-4xl font-semibold leading-tight tracking-tight text-foreground dark:text-foreground">
32
32
  扣子编程,你的 AI 开发伙伴已就位
33
33
  </h1>
34
- <p className="max-w-2xl text-lg leading-8 text-zinc-600 dark:text-zinc-400">
34
+ <p className="max-w-2xl text-lg leading-8 text-muted-foreground dark:text-muted-foreground">
35
35
  当前是空白入口文件,项目正在开发中,请稍候...
36
36
  <br />
37
37
  开发完成后界面将自动更新。如未自动更新成功,可以手动点击右上角刷新或重启按钮查看效果。
@@ -41,24 +41,36 @@ export default function Home() {
41
41
  {/* 底部按钮区 */}
42
42
  <div className="flex w-full flex-col gap-4 text-base font-medium sm:w-auto sm:flex-row">
43
43
  {/* 按钮 1:前往首页 */}
44
- <a
45
- className="flex h-12 w-full min-w-[160px] items-center justify-center gap-2 rounded-full bg-black px-8 text-white transition-colors hover:bg-zinc-800 dark:bg-white dark:text-black dark:hover:bg-zinc-200 md:w-auto"
46
- href="https://code.coze.cn/"
47
- target="_blank"
48
- rel="noopener noreferrer"
44
+ <Button
45
+ asChild
46
+ variant="default"
47
+ size="lg"
48
+ className="h-12 min-w-[160px] rounded-full px-8"
49
49
  >
50
- 前往首页
51
- </a>
50
+ <a
51
+ href="https://code.coze.cn/"
52
+ target="_blank"
53
+ rel="noopener noreferrer"
54
+ >
55
+ 前往首页
56
+ </a>
57
+ </Button>
52
58
 
53
59
  {/* 按钮 2:查看文档 */}
54
- <a
55
- className="flex h-12 w-full min-w-[160px] items-center justify-center rounded-full border border-solid border-black/[.08] px-8 transition-colors hover:border-transparent hover:bg-black/[.04] dark:border-white/[.145] dark:hover:bg-[#1a1a1a] md:w-auto"
56
- href="https://docs.coze.cn/"
57
- target="_blank"
58
- rel="noopener noreferrer"
60
+ <Button
61
+ asChild
62
+ variant="outline"
63
+ size="lg"
64
+ className="h-12 min-w-[160px] rounded-full px-8"
59
65
  >
60
- 查看文档
61
- </a>
66
+ <a
67
+ href="https://docs.coze.cn/"
68
+ target="_blank"
69
+ rel="noopener noreferrer"
70
+ >
71
+ 查看文档
72
+ </a>
73
+ </Button>
62
74
  </div>
63
75
  </main>
64
76
  </div>
@@ -0,0 +1,66 @@
1
+ "use client"
2
+
3
+ import * as React from "react"
4
+ import * as AccordionPrimitive from "@radix-ui/react-accordion"
5
+ import { ChevronDownIcon } from "lucide-react"
6
+
7
+ import { cn } from "@/lib/utils"
8
+
9
+ function Accordion({
10
+ ...props
11
+ }: React.ComponentProps<typeof AccordionPrimitive.Root>) {
12
+ return <AccordionPrimitive.Root data-slot="accordion" {...props} />
13
+ }
14
+
15
+ function AccordionItem({
16
+ className,
17
+ ...props
18
+ }: React.ComponentProps<typeof AccordionPrimitive.Item>) {
19
+ return (
20
+ <AccordionPrimitive.Item
21
+ data-slot="accordion-item"
22
+ className={cn("border-b last:border-b-0", className)}
23
+ {...props}
24
+ />
25
+ )
26
+ }
27
+
28
+ function AccordionTrigger({
29
+ className,
30
+ children,
31
+ ...props
32
+ }: React.ComponentProps<typeof AccordionPrimitive.Trigger>) {
33
+ return (
34
+ <AccordionPrimitive.Header className="flex">
35
+ <AccordionPrimitive.Trigger
36
+ data-slot="accordion-trigger"
37
+ className={cn(
38
+ "focus-visible:border-ring focus-visible:ring-ring/50 flex flex-1 items-start justify-between gap-4 rounded-md py-4 text-left text-sm font-medium transition-all outline-none hover:underline focus-visible:ring-[3px] disabled:pointer-events-none disabled:opacity-50 [&[data-state=open]>svg]:rotate-180",
39
+ className
40
+ )}
41
+ {...props}
42
+ >
43
+ {children}
44
+ <ChevronDownIcon className="text-muted-foreground pointer-events-none size-4 shrink-0 translate-y-0.5 transition-transform duration-200" />
45
+ </AccordionPrimitive.Trigger>
46
+ </AccordionPrimitive.Header>
47
+ )
48
+ }
49
+
50
+ function AccordionContent({
51
+ className,
52
+ children,
53
+ ...props
54
+ }: React.ComponentProps<typeof AccordionPrimitive.Content>) {
55
+ return (
56
+ <AccordionPrimitive.Content
57
+ data-slot="accordion-content"
58
+ className="data-[state=closed]:animate-accordion-up data-[state=open]:animate-accordion-down overflow-hidden text-sm"
59
+ {...props}
60
+ >
61
+ <div className={cn("pt-0 pb-4", className)}>{children}</div>
62
+ </AccordionPrimitive.Content>
63
+ )
64
+ }
65
+
66
+ export { Accordion, AccordionItem, AccordionTrigger, AccordionContent }
@@ -0,0 +1,157 @@
1
+ "use client"
2
+
3
+ import * as React from "react"
4
+ import * as AlertDialogPrimitive from "@radix-ui/react-alert-dialog"
5
+
6
+ import { cn } from "@/lib/utils"
7
+ import { buttonVariants } from "@/components/ui/button"
8
+
9
+ function AlertDialog({
10
+ ...props
11
+ }: React.ComponentProps<typeof AlertDialogPrimitive.Root>) {
12
+ return <AlertDialogPrimitive.Root data-slot="alert-dialog" {...props} />
13
+ }
14
+
15
+ function AlertDialogTrigger({
16
+ ...props
17
+ }: React.ComponentProps<typeof AlertDialogPrimitive.Trigger>) {
18
+ return (
19
+ <AlertDialogPrimitive.Trigger data-slot="alert-dialog-trigger" {...props} />
20
+ )
21
+ }
22
+
23
+ function AlertDialogPortal({
24
+ ...props
25
+ }: React.ComponentProps<typeof AlertDialogPrimitive.Portal>) {
26
+ return (
27
+ <AlertDialogPrimitive.Portal data-slot="alert-dialog-portal" {...props} />
28
+ )
29
+ }
30
+
31
+ function AlertDialogOverlay({
32
+ className,
33
+ ...props
34
+ }: React.ComponentProps<typeof AlertDialogPrimitive.Overlay>) {
35
+ return (
36
+ <AlertDialogPrimitive.Overlay
37
+ data-slot="alert-dialog-overlay"
38
+ className={cn(
39
+ "data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 fixed inset-0 z-50 bg-black/50",
40
+ className
41
+ )}
42
+ {...props}
43
+ />
44
+ )
45
+ }
46
+
47
+ function AlertDialogContent({
48
+ className,
49
+ ...props
50
+ }: React.ComponentProps<typeof AlertDialogPrimitive.Content>) {
51
+ return (
52
+ <AlertDialogPortal>
53
+ <AlertDialogOverlay />
54
+ <AlertDialogPrimitive.Content
55
+ data-slot="alert-dialog-content"
56
+ className={cn(
57
+ "bg-background data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 fixed top-[50%] left-[50%] z-50 grid w-full max-w-[calc(100%-2rem)] translate-x-[-50%] translate-y-[-50%] gap-4 rounded-lg border p-6 shadow-lg duration-200 sm:max-w-lg",
58
+ className
59
+ )}
60
+ {...props}
61
+ />
62
+ </AlertDialogPortal>
63
+ )
64
+ }
65
+
66
+ function AlertDialogHeader({
67
+ className,
68
+ ...props
69
+ }: React.ComponentProps<"div">) {
70
+ return (
71
+ <div
72
+ data-slot="alert-dialog-header"
73
+ className={cn("flex flex-col gap-2 text-center sm:text-left", className)}
74
+ {...props}
75
+ />
76
+ )
77
+ }
78
+
79
+ function AlertDialogFooter({
80
+ className,
81
+ ...props
82
+ }: React.ComponentProps<"div">) {
83
+ return (
84
+ <div
85
+ data-slot="alert-dialog-footer"
86
+ className={cn(
87
+ "flex flex-col-reverse gap-2 sm:flex-row sm:justify-end",
88
+ className
89
+ )}
90
+ {...props}
91
+ />
92
+ )
93
+ }
94
+
95
+ function AlertDialogTitle({
96
+ className,
97
+ ...props
98
+ }: React.ComponentProps<typeof AlertDialogPrimitive.Title>) {
99
+ return (
100
+ <AlertDialogPrimitive.Title
101
+ data-slot="alert-dialog-title"
102
+ className={cn("text-lg font-semibold", className)}
103
+ {...props}
104
+ />
105
+ )
106
+ }
107
+
108
+ function AlertDialogDescription({
109
+ className,
110
+ ...props
111
+ }: React.ComponentProps<typeof AlertDialogPrimitive.Description>) {
112
+ return (
113
+ <AlertDialogPrimitive.Description
114
+ data-slot="alert-dialog-description"
115
+ className={cn("text-muted-foreground text-sm", className)}
116
+ {...props}
117
+ />
118
+ )
119
+ }
120
+
121
+ function AlertDialogAction({
122
+ className,
123
+ ...props
124
+ }: React.ComponentProps<typeof AlertDialogPrimitive.Action>) {
125
+ return (
126
+ <AlertDialogPrimitive.Action
127
+ className={cn(buttonVariants(), className)}
128
+ {...props}
129
+ />
130
+ )
131
+ }
132
+
133
+ function AlertDialogCancel({
134
+ className,
135
+ ...props
136
+ }: React.ComponentProps<typeof AlertDialogPrimitive.Cancel>) {
137
+ return (
138
+ <AlertDialogPrimitive.Cancel
139
+ className={cn(buttonVariants({ variant: "outline" }), className)}
140
+ {...props}
141
+ />
142
+ )
143
+ }
144
+
145
+ export {
146
+ AlertDialog,
147
+ AlertDialogPortal,
148
+ AlertDialogOverlay,
149
+ AlertDialogTrigger,
150
+ AlertDialogContent,
151
+ AlertDialogHeader,
152
+ AlertDialogFooter,
153
+ AlertDialogTitle,
154
+ AlertDialogDescription,
155
+ AlertDialogAction,
156
+ AlertDialogCancel,
157
+ }
@@ -0,0 +1,66 @@
1
+ import * as React from "react"
2
+ import { cva, type VariantProps } from "class-variance-authority"
3
+
4
+ import { cn } from "@/lib/utils"
5
+
6
+ const alertVariants = cva(
7
+ "relative w-full rounded-lg border px-4 py-3 text-sm grid has-[>svg]:grid-cols-[calc(var(--spacing)*4)_1fr] grid-cols-[0_1fr] has-[>svg]:gap-x-3 gap-y-0.5 items-start [&>svg]:size-4 [&>svg]:translate-y-0.5 [&>svg]:text-current",
8
+ {
9
+ variants: {
10
+ variant: {
11
+ default: "bg-card text-card-foreground",
12
+ destructive:
13
+ "text-destructive bg-card [&>svg]:text-current *:data-[slot=alert-description]:text-destructive/90",
14
+ },
15
+ },
16
+ defaultVariants: {
17
+ variant: "default",
18
+ },
19
+ }
20
+ )
21
+
22
+ function Alert({
23
+ className,
24
+ variant,
25
+ ...props
26
+ }: React.ComponentProps<"div"> & VariantProps<typeof alertVariants>) {
27
+ return (
28
+ <div
29
+ data-slot="alert"
30
+ role="alert"
31
+ className={cn(alertVariants({ variant }), className)}
32
+ {...props}
33
+ />
34
+ )
35
+ }
36
+
37
+ function AlertTitle({ className, ...props }: React.ComponentProps<"div">) {
38
+ return (
39
+ <div
40
+ data-slot="alert-title"
41
+ className={cn(
42
+ "col-start-2 line-clamp-1 min-h-4 font-medium tracking-tight",
43
+ className
44
+ )}
45
+ {...props}
46
+ />
47
+ )
48
+ }
49
+
50
+ function AlertDescription({
51
+ className,
52
+ ...props
53
+ }: React.ComponentProps<"div">) {
54
+ return (
55
+ <div
56
+ data-slot="alert-description"
57
+ className={cn(
58
+ "text-muted-foreground col-start-2 grid justify-items-start gap-1 text-sm [&_p]:leading-relaxed",
59
+ className
60
+ )}
61
+ {...props}
62
+ />
63
+ )
64
+ }
65
+
66
+ export { Alert, AlertTitle, AlertDescription }