ccjk 14.2.2 → 15.0.0
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/LICENSE +1 -1
- package/README.md +58 -341
- package/dist/cli.js +59 -0
- package/dist/cli.js.map +1 -0
- package/dist/commands/detect.js +15 -0
- package/dist/commands/detect.js.map +1 -0
- package/dist/commands/doctor.js +68 -0
- package/dist/commands/doctor.js.map +1 -0
- package/dist/commands/git-install.js +50 -0
- package/dist/commands/git-install.js.map +1 -0
- package/dist/commands/init.js +102 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/mcp.js +66 -0
- package/dist/commands/mcp.js.map +1 -0
- package/dist/commands/menu.js +33 -0
- package/dist/commands/menu.js.map +1 -0
- package/dist/core/detect.js +24 -0
- package/dist/core/detect.js.map +1 -0
- package/dist/core/lint.js +49 -0
- package/dist/core/lint.js.map +1 -0
- package/dist/core/mcp.js +41 -0
- package/dist/core/mcp.js.map +1 -0
- package/dist/core/paths.js +9 -0
- package/dist/core/paths.js.map +1 -0
- package/dist/core/providers.js +53 -0
- package/dist/core/providers.js.map +1 -0
- package/dist/core/settings.js +31 -0
- package/dist/core/settings.js.map +1 -0
- package/dist/core/slash-templates.js +56 -0
- package/dist/core/slash-templates.js.map +1 -0
- package/dist/core/tools.js +27 -0
- package/dist/core/tools.js.map +1 -0
- package/package.json +43 -164
- package/README.HONEST.md +0 -176
- package/README.en.md +0 -67
- package/README.ja.md +0 -67
- package/README.ko.md +0 -67
- package/README.zh-CN.md +0 -86
- package/bin/ccjk.mjs +0 -5
- package/bin/ccjk.ts +0 -222
- package/dist/chunks/agent-teams.mjs +0 -145
- package/dist/chunks/agent.mjs +0 -1439
- package/dist/chunks/agents.mjs +0 -3783
- package/dist/chunks/api-cli.mjs +0 -135
- package/dist/chunks/api-config-selector.mjs +0 -159
- package/dist/chunks/api-providers.mjs +0 -144
- package/dist/chunks/api.mjs +0 -115
- package/dist/chunks/auto-bootstrap.mjs +0 -358
- package/dist/chunks/auto-fixer.mjs +0 -95
- package/dist/chunks/auto-updater.mjs +0 -507
- package/dist/chunks/banner.mjs +0 -173
- package/dist/chunks/bash.mjs +0 -187
- package/dist/chunks/boost.mjs +0 -474
- package/dist/chunks/brain-config.mjs +0 -75
- package/dist/chunks/brain-status.mjs +0 -89
- package/dist/chunks/ccjk-agents.mjs +0 -416
- package/dist/chunks/ccjk-all.mjs +0 -1046
- package/dist/chunks/ccjk-config.mjs +0 -445
- package/dist/chunks/ccjk-hooks.mjs +0 -1074
- package/dist/chunks/ccjk-mcp.mjs +0 -763
- package/dist/chunks/ccjk-setup.mjs +0 -765
- package/dist/chunks/ccjk-skills.mjs +0 -518
- package/dist/chunks/ccr.mjs +0 -109
- package/dist/chunks/ccu.mjs +0 -40
- package/dist/chunks/check-updates.mjs +0 -117
- package/dist/chunks/claude-code-incremental-manager.mjs +0 -761
- package/dist/chunks/claude-config.mjs +0 -606
- package/dist/chunks/claude-config2.mjs +0 -62
- package/dist/chunks/claude-wrapper.mjs +0 -85
- package/dist/chunks/clavue-config.mjs +0 -1454
- package/dist/chunks/cleanup-migration.mjs +0 -20
- package/dist/chunks/cli-hook.mjs +0 -4096
- package/dist/chunks/cloud-sync.mjs +0 -29
- package/dist/chunks/code-type-resolver.mjs +0 -880
- package/dist/chunks/codex-config-switch.mjs +0 -452
- package/dist/chunks/codex-provider-manager.mjs +0 -238
- package/dist/chunks/codex-uninstaller.mjs +0 -404
- package/dist/chunks/codex.mjs +0 -2141
- package/dist/chunks/commands.mjs +0 -108
- package/dist/chunks/commands2.mjs +0 -421
- package/dist/chunks/commit.mjs +0 -140
- package/dist/chunks/completion.mjs +0 -517
- package/dist/chunks/config-consolidator.mjs +0 -172
- package/dist/chunks/config-switch.mjs +0 -334
- package/dist/chunks/config.mjs +0 -558
- package/dist/chunks/config2.mjs +0 -484
- package/dist/chunks/config3.mjs +0 -486
- package/dist/chunks/constants.mjs +0 -323
- package/dist/chunks/context-opt.mjs +0 -444
- package/dist/chunks/context.mjs +0 -974
- package/dist/chunks/dashboard.mjs +0 -481
- package/dist/chunks/doctor.mjs +0 -1301
- package/dist/chunks/eval.mjs +0 -502
- package/dist/chunks/evolution.mjs +0 -322
- package/dist/chunks/features.mjs +0 -715
- package/dist/chunks/fish.mjs +0 -181
- package/dist/chunks/fs-operations.mjs +0 -180
- package/dist/chunks/health-alerts.mjs +0 -830
- package/dist/chunks/help.mjs +0 -341
- package/dist/chunks/hook-installer.mjs +0 -48
- package/dist/chunks/impact.mjs +0 -651
- package/dist/chunks/index.mjs +0 -23
- package/dist/chunks/index10.mjs +0 -19
- package/dist/chunks/index11.mjs +0 -1171
- package/dist/chunks/index12.mjs +0 -218
- package/dist/chunks/index13.mjs +0 -679
- package/dist/chunks/index14.mjs +0 -1009
- package/dist/chunks/index15.mjs +0 -194
- package/dist/chunks/index2.mjs +0 -7637
- package/dist/chunks/index3.mjs +0 -171
- package/dist/chunks/index4.mjs +0 -26
- package/dist/chunks/index5.mjs +0 -19
- package/dist/chunks/index6.mjs +0 -19092
- package/dist/chunks/index7.mjs +0 -616
- package/dist/chunks/index8.mjs +0 -1602
- package/dist/chunks/index9.mjs +0 -5384
- package/dist/chunks/init.mjs +0 -1911
- package/dist/chunks/installer.mjs +0 -757
- package/dist/chunks/installer2.mjs +0 -103
- package/dist/chunks/interview.mjs +0 -2927
- package/dist/chunks/json-config.mjs +0 -60
- package/dist/chunks/linux.mjs +0 -3863
- package/dist/chunks/macos.mjs +0 -69
- package/dist/chunks/main.mjs +0 -635
- package/dist/chunks/manager.mjs +0 -1048
- package/dist/chunks/marketplace.mjs +0 -265
- package/dist/chunks/mcp-cli.mjs +0 -205
- package/dist/chunks/mcp-performance.mjs +0 -187
- package/dist/chunks/mcp.mjs +0 -667
- package/dist/chunks/memory-check.mjs +0 -2973
- package/dist/chunks/memory-paths.mjs +0 -259
- package/dist/chunks/memory-sync.mjs +0 -209
- package/dist/chunks/memory.mjs +0 -354
- package/dist/chunks/metrics-display.mjs +0 -153
- package/dist/chunks/monitor.mjs +0 -1856
- package/dist/chunks/notification.mjs +0 -1864
- package/dist/chunks/onboarding.mjs +0 -386
- package/dist/chunks/package.mjs +0 -3
- package/dist/chunks/paradigm.mjs +0 -74
- package/dist/chunks/permission-manager.mjs +0 -250
- package/dist/chunks/permissions.mjs +0 -265
- package/dist/chunks/persistence-manager.mjs +0 -801
- package/dist/chunks/persistence.mjs +0 -707
- package/dist/chunks/platform.mjs +0 -395
- package/dist/chunks/plugin.mjs +0 -1936
- package/dist/chunks/powershell.mjs +0 -213
- package/dist/chunks/prompts.mjs +0 -244
- package/dist/chunks/providers.mjs +0 -263
- package/dist/chunks/quick-actions.mjs +0 -335
- package/dist/chunks/quick-provider.mjs +0 -755
- package/dist/chunks/quick-setup.mjs +0 -421
- package/dist/chunks/remote.mjs +0 -497
- package/dist/chunks/research.mjs +0 -1904
- package/dist/chunks/rollback.mjs +0 -38
- package/dist/chunks/session-manager.mjs +0 -1371
- package/dist/chunks/session.mjs +0 -878
- package/dist/chunks/sessions.mjs +0 -106
- package/dist/chunks/silent-updater.mjs +0 -396
- package/dist/chunks/simple-config.mjs +0 -122
- package/dist/chunks/skill.mjs +0 -117
- package/dist/chunks/skill2.mjs +0 -9052
- package/dist/chunks/skills-sync.mjs +0 -1343
- package/dist/chunks/skills.mjs +0 -577
- package/dist/chunks/slash-commands.mjs +0 -208
- package/dist/chunks/smart-guide.mjs +0 -247
- package/dist/chunks/snapshot.mjs +0 -58
- package/dist/chunks/startup.mjs +0 -487
- package/dist/chunks/stats.mjs +0 -191
- package/dist/chunks/status.mjs +0 -471
- package/dist/chunks/team.mjs +0 -63
- package/dist/chunks/thinking.mjs +0 -626
- package/dist/chunks/trace.mjs +0 -57
- package/dist/chunks/uninstall.mjs +0 -852
- package/dist/chunks/update.mjs +0 -174
- package/dist/chunks/upgrade-manager.mjs +0 -204
- package/dist/chunks/upgrade.mjs +0 -133
- package/dist/chunks/version-checker.mjs +0 -891
- package/dist/chunks/vim.mjs +0 -903
- package/dist/chunks/windows.mjs +0 -14
- package/dist/chunks/workflows.mjs +0 -633
- package/dist/chunks/wsl.mjs +0 -129
- package/dist/chunks/zero-config.mjs +0 -871
- package/dist/chunks/zsh.mjs +0 -182
- package/dist/cli.d.mts +0 -1
- package/dist/cli.d.ts +0 -1
- package/dist/cli.mjs +0 -2684
- package/dist/i18n/locales/en/agent-teams.json +0 -18
- package/dist/i18n/locales/en/agentBrowser.json +0 -80
- package/dist/i18n/locales/en/agents.json +0 -135
- package/dist/i18n/locales/en/api.json +0 -63
- package/dist/i18n/locales/en/ccjk-agents.json +0 -33
- package/dist/i18n/locales/en/ccjk-all.json +0 -23
- package/dist/i18n/locales/en/ccjk-skills.json +0 -22
- package/dist/i18n/locales/en/ccjk.json +0 -276
- package/dist/i18n/locales/en/ccr.json +0 -65
- package/dist/i18n/locales/en/claude-md.json +0 -73
- package/dist/i18n/locales/en/cli.json +0 -148
- package/dist/i18n/locales/en/cloud-setup.json +0 -31
- package/dist/i18n/locales/en/cloud-sync.json +0 -147
- package/dist/i18n/locales/en/cloud.json +0 -40
- package/dist/i18n/locales/en/cloudPlugins.json +0 -118
- package/dist/i18n/locales/en/codex.json +0 -184
- package/dist/i18n/locales/en/cometix.json +0 -29
- package/dist/i18n/locales/en/common.json +0 -68
- package/dist/i18n/locales/en/config.json +0 -108
- package/dist/i18n/locales/en/configuration.json +0 -236
- package/dist/i18n/locales/en/context.json +0 -85
- package/dist/i18n/locales/en/dashboard.json +0 -78
- package/dist/i18n/locales/en/errors.json +0 -26
- package/dist/i18n/locales/en/evolution.json +0 -54
- package/dist/i18n/locales/en/hooks.json +0 -74
- package/dist/i18n/locales/en/hooksSync.json +0 -133
- package/dist/i18n/locales/en/installation.json +0 -83
- package/dist/i18n/locales/en/interview.json +0 -104
- package/dist/i18n/locales/en/language.json +0 -19
- package/dist/i18n/locales/en/lsp.json +0 -78
- package/dist/i18n/locales/en/marketplace.json +0 -116
- package/dist/i18n/locales/en/mcp.json +0 -180
- package/dist/i18n/locales/en/memory.json +0 -23
- package/dist/i18n/locales/en/menu.json +0 -299
- package/dist/i18n/locales/en/multi-config.json +0 -79
- package/dist/i18n/locales/en/notification.json +0 -307
- package/dist/i18n/locales/en/permissions.json +0 -95
- package/dist/i18n/locales/en/persistence.json +0 -127
- package/dist/i18n/locales/en/plugins.json +0 -146
- package/dist/i18n/locales/en/quick-actions.json +0 -78
- package/dist/i18n/locales/en/registry.json +0 -54
- package/dist/i18n/locales/en/remote.json +0 -93
- package/dist/i18n/locales/en/sandbox.json +0 -44
- package/dist/i18n/locales/en/setup.json +0 -44
- package/dist/i18n/locales/en/shencha.json +0 -14
- package/dist/i18n/locales/en/skills.json +0 -100
- package/dist/i18n/locales/en/skillsSync.json +0 -74
- package/dist/i18n/locales/en/smartGuide.json +0 -49
- package/dist/i18n/locales/en/stats.json +0 -20
- package/dist/i18n/locales/en/subagent.json +0 -69
- package/dist/i18n/locales/en/superpowers.json +0 -117
- package/dist/i18n/locales/en/team.json +0 -7
- package/dist/i18n/locales/en/thinking.json +0 -65
- package/dist/i18n/locales/en/tools.json +0 -42
- package/dist/i18n/locales/en/uninstall.json +0 -56
- package/dist/i18n/locales/en/updater.json +0 -29
- package/dist/i18n/locales/en/vim.json +0 -169
- package/dist/i18n/locales/en/workflow.json +0 -55
- package/dist/i18n/locales/en/workspace.json +0 -108
- package/dist/i18n/locales/zh-CN/agent-teams.json +0 -18
- package/dist/i18n/locales/zh-CN/agentBrowser.json +0 -80
- package/dist/i18n/locales/zh-CN/agents.json +0 -135
- package/dist/i18n/locales/zh-CN/api.json +0 -63
- package/dist/i18n/locales/zh-CN/ccjk-agents.json +0 -33
- package/dist/i18n/locales/zh-CN/ccjk-all.json +0 -23
- package/dist/i18n/locales/zh-CN/ccjk-skills.json +0 -22
- package/dist/i18n/locales/zh-CN/ccjk.json +0 -276
- package/dist/i18n/locales/zh-CN/ccr.json +0 -65
- package/dist/i18n/locales/zh-CN/claude-md.json +0 -73
- package/dist/i18n/locales/zh-CN/cli.json +0 -148
- package/dist/i18n/locales/zh-CN/cloud-setup.json +0 -31
- package/dist/i18n/locales/zh-CN/cloud-sync.json +0 -147
- package/dist/i18n/locales/zh-CN/cloud.json +0 -40
- package/dist/i18n/locales/zh-CN/cloudPlugins.json +0 -118
- package/dist/i18n/locales/zh-CN/codex.json +0 -184
- package/dist/i18n/locales/zh-CN/cometix.json +0 -29
- package/dist/i18n/locales/zh-CN/common.json +0 -68
- package/dist/i18n/locales/zh-CN/config.json +0 -108
- package/dist/i18n/locales/zh-CN/configuration.json +0 -234
- package/dist/i18n/locales/zh-CN/context.json +0 -85
- package/dist/i18n/locales/zh-CN/dashboard.json +0 -78
- package/dist/i18n/locales/zh-CN/errors.json +0 -26
- package/dist/i18n/locales/zh-CN/evolution.json +0 -54
- package/dist/i18n/locales/zh-CN/hooks.json +0 -74
- package/dist/i18n/locales/zh-CN/hooksSync.json +0 -133
- package/dist/i18n/locales/zh-CN/installation.json +0 -83
- package/dist/i18n/locales/zh-CN/interview.json +0 -104
- package/dist/i18n/locales/zh-CN/language.json +0 -19
- package/dist/i18n/locales/zh-CN/lsp.json +0 -78
- package/dist/i18n/locales/zh-CN/marketplace.json +0 -116
- package/dist/i18n/locales/zh-CN/mcp.json +0 -180
- package/dist/i18n/locales/zh-CN/memory.json +0 -23
- package/dist/i18n/locales/zh-CN/menu.json +0 -299
- package/dist/i18n/locales/zh-CN/multi-config.json +0 -79
- package/dist/i18n/locales/zh-CN/notification.json +0 -307
- package/dist/i18n/locales/zh-CN/permissions.json +0 -95
- package/dist/i18n/locales/zh-CN/persistence.json +0 -127
- package/dist/i18n/locales/zh-CN/plugins.json +0 -146
- package/dist/i18n/locales/zh-CN/quick-actions.json +0 -78
- package/dist/i18n/locales/zh-CN/registry.json +0 -54
- package/dist/i18n/locales/zh-CN/remote.json +0 -93
- package/dist/i18n/locales/zh-CN/sandbox.json +0 -44
- package/dist/i18n/locales/zh-CN/setup.json +0 -44
- package/dist/i18n/locales/zh-CN/shencha.json +0 -14
- package/dist/i18n/locales/zh-CN/skills.json +0 -100
- package/dist/i18n/locales/zh-CN/skillsSync.json +0 -74
- package/dist/i18n/locales/zh-CN/smartGuide.json +0 -49
- package/dist/i18n/locales/zh-CN/stats.json +0 -20
- package/dist/i18n/locales/zh-CN/subagent.json +0 -69
- package/dist/i18n/locales/zh-CN/superpowers.json +0 -117
- package/dist/i18n/locales/zh-CN/team.json +0 -7
- package/dist/i18n/locales/zh-CN/thinking.json +0 -65
- package/dist/i18n/locales/zh-CN/tools.json +0 -42
- package/dist/i18n/locales/zh-CN/uninstall.json +0 -56
- package/dist/i18n/locales/zh-CN/updater.json +0 -29
- package/dist/i18n/locales/zh-CN/vim.json +0 -169
- package/dist/i18n/locales/zh-CN/workflow.json +0 -55
- package/dist/i18n/locales/zh-CN/workspace.json +0 -108
- package/dist/index.d.mts +0 -5658
- package/dist/index.d.ts +0 -5658
- package/dist/index.mjs +0 -3732
- package/dist/shared/ccjk.5bEolFrk.mjs +0 -254
- package/dist/shared/ccjk.8oaxX4iR.mjs +0 -90
- package/dist/shared/ccjk.B2U7DsPy.mjs +0 -31
- package/dist/shared/ccjk.B2f-cwUP.mjs +0 -468
- package/dist/shared/ccjk.BAGoDD49.mjs +0 -36
- package/dist/shared/ccjk.BBtCGd_g.mjs +0 -899
- package/dist/shared/ccjk.BFQ7yr5S.mjs +0 -16
- package/dist/shared/ccjk.BLsIiTqO.mjs +0 -449
- package/dist/shared/ccjk.BXv8aYs1.mjs +0 -170
- package/dist/shared/ccjk.BnsY5WxD.mjs +0 -171
- package/dist/shared/ccjk.BoApaI4j.mjs +0 -28
- package/dist/shared/ccjk.Bq8TqZG_.mjs +0 -189
- package/dist/shared/ccjk.BtrioX1Z.mjs +0 -25
- package/dist/shared/ccjk.Bx_rmYfN.mjs +0 -69
- package/dist/shared/ccjk.BzPbSEP2.mjs +0 -115
- package/dist/shared/ccjk.C0WLUnFV.mjs +0 -293
- package/dist/shared/ccjk.C1hANZTu.mjs +0 -19
- package/dist/shared/ccjk.C2jHOZVP.mjs +0 -52
- package/dist/shared/ccjk.CNhnT6uQ.mjs +0 -636
- package/dist/shared/ccjk.COweQ1RR.mjs +0 -5
- package/dist/shared/ccjk.CfKKcvWy.mjs +0 -126
- package/dist/shared/ccjk.Cjgrln_h.mjs +0 -297
- package/dist/shared/ccjk.CoCHVXl3.mjs +0 -3951
- package/dist/shared/ccjk.CwGZSTAK.mjs +0 -319
- package/dist/shared/ccjk.CxpGa6MC.mjs +0 -2724
- package/dist/shared/ccjk.D-magaEx.mjs +0 -763
- package/dist/shared/ccjk.D0g2ABGg.mjs +0 -171
- package/dist/shared/ccjk.D6ycHbak.mjs +0 -270
- package/dist/shared/ccjk.D75wivnp.mjs +0 -142
- package/dist/shared/ccjk.DDL-4C-k.mjs +0 -100
- package/dist/shared/ccjk.DFRPtmK_.mjs +0 -75
- package/dist/shared/ccjk.DMV3x5Sd.mjs +0 -299
- package/dist/shared/ccjk.DZ2LLOa-.mjs +0 -2195
- package/dist/shared/ccjk.DbigonEQ.mjs +0 -698
- package/dist/shared/ccjk.DcMvE7lf.mjs +0 -618
- package/dist/shared/ccjk.DeWpAShp.mjs +0 -1828
- package/dist/shared/ccjk.DhJ1kyDR.mjs +0 -30
- package/dist/shared/ccjk.DlTXS9rP.mjs +0 -224
- package/dist/shared/ccjk.DopKzo3z.mjs +0 -305
- package/dist/shared/ccjk.DsZsc4LR.mjs +0 -1280
- package/dist/shared/ccjk.DuzJZlgj.mjs +0 -418
- package/dist/shared/ccjk.Dxgd2vjc.mjs +0 -444
- package/dist/shared/ccjk.J8YiPsOw.mjs +0 -259
- package/dist/shared/ccjk.KfSWcGlE.mjs +0 -38
- package/dist/shared/ccjk.L7yC58_i.mjs +0 -225
- package/dist/shared/ccjk.MwtjAULc.mjs +0 -1447
- package/dist/shared/ccjk.OJKHVSOb.mjs +0 -2005
- package/dist/shared/ccjk.OTnevPNE.mjs +0 -225
- package/dist/shared/ccjk.RyizuzOI.mjs +0 -21
- package/dist/shared/ccjk.T_cX87dY.mjs +0 -15
- package/dist/shared/ccjk.bQ7Dh1g4.mjs +0 -249
- package/dist/shared/ccjk.gDEDGD_t.mjs +0 -38
- package/dist/shared/ccjk.hoqrwWdN.mjs +0 -333
- package/dist/shared/ccjk.i_vn-9C3.mjs +0 -317
- package/dist/shared/ccjk.lG3ccFjm.mjs +0 -885
- package/dist/shared/ccjk.wLJHO0Af.mjs +0 -244
- package/dist/shared/ccjk.y-a_1vK4.mjs +0 -5127
- package/dist/templates/agents/README.md +0 -78
- package/dist/templates/agents/fullstack-developer.json +0 -70
- package/dist/templates/agents/go-expert.json +0 -69
- package/dist/templates/agents/index.json +0 -64
- package/dist/templates/agents/python-expert.json +0 -69
- package/dist/templates/agents/react-specialist.json +0 -69
- package/dist/templates/agents/testing-automation-expert.json +0 -70
- package/dist/templates/agents/typescript-architect.json +0 -69
- package/dist/templates/claude-code/common/settings.json +0 -109
- package/dist/templates/common/error-prevention.md +0 -267
- package/dist/templates/common/karpathy-baseline.md +0 -83
- package/dist/templates/common/output-styles/zh-CN/carmack-mode.md +0 -381
- package/dist/templates/common/output-styles/zh-CN/codex-rigor-mode.md +0 -114
- package/dist/templates/common/output-styles/zh-CN/dhh-mode.md +0 -265
- package/dist/templates/common/output-styles/zh-CN/evan-you-mode.md +0 -539
- package/dist/templates/common/output-styles/zh-CN/jobs-mode.md +0 -369
- package/dist/templates/common/output-styles/zh-CN/linus-mode.md +0 -135
- package/dist/templates/common/output-styles/zh-CN/uncle-bob-mode.md +0 -221
- package/dist/templates/common/workflow/continuousDelivery/en/continuous-delivery.md +0 -628
- package/dist/templates/common/workflow/continuousDelivery/zh-CN/continuous-delivery.md +0 -628
- package/dist/templates/common/workflow/essential/en/agents/ccjk-config-agent.md +0 -187
- package/dist/templates/common/workflow/essential/en/agents/ccjk-mcp-agent.md +0 -191
- package/dist/templates/common/workflow/essential/en/agents/ccjk-skill-agent.md +0 -249
- package/dist/templates/common/workflow/essential/en/agents/ccjk-workflow-agent.md +0 -277
- package/dist/templates/common/workflow/essential/en/agents/get-current-datetime.md +0 -29
- package/dist/templates/common/workflow/essential/en/agents/init-architect.md +0 -115
- package/dist/templates/common/workflow/essential/en/agents/ui-ux-designer.md +0 -91
- package/dist/templates/common/workflow/essential/en/feat.md +0 -92
- package/dist/templates/common/workflow/essential/en/goal.md +0 -147
- package/dist/templates/common/workflow/essential/en/init-project.md +0 -53
- package/dist/templates/common/workflow/essential/zh-CN/agents/get-current-datetime.md +0 -29
- package/dist/templates/common/workflow/essential/zh-CN/agents/init-architect.md +0 -115
- package/dist/templates/common/workflow/essential/zh-CN/agents/ui-ux-designer.md +0 -91
- package/dist/templates/common/workflow/essential/zh-CN/feat.md +0 -315
- package/dist/templates/common/workflow/essential/zh-CN/goal.md +0 -146
- package/dist/templates/common/workflow/essential/zh-CN/init-project.md +0 -53
- package/dist/templates/common/workflow/git/en/git-cleanBranches.md +0 -102
- package/dist/templates/common/workflow/git/en/git-commit.md +0 -205
- package/dist/templates/common/workflow/git/en/git-rollback.md +0 -90
- package/dist/templates/common/workflow/git/en/git-worktree.md +0 -276
- package/dist/templates/common/workflow/git/zh-CN/git-cleanBranches.md +0 -102
- package/dist/templates/common/workflow/git/zh-CN/git-commit.md +0 -205
- package/dist/templates/common/workflow/git/zh-CN/git-rollback.md +0 -90
- package/dist/templates/common/workflow/git/zh-CN/git-worktree.md +0 -276
- package/dist/templates/common/workflow/interview/en/interview.md +0 -67
- package/dist/templates/common/workflow/interview/zh-CN/interview.md +0 -67
- package/dist/templates/common/workflow/linearMethod/en/linear-method.md +0 -651
- package/dist/templates/common/workflow/linearMethod/zh-CN/linear-method.md +0 -752
- package/dist/templates/common/workflow/refactoringMaster/en/refactoring-master.md +0 -516
- package/dist/templates/common/workflow/refactoringMaster/zh-CN/refactoring-master.md +0 -812
- package/dist/templates/common/workflow/sixStep/en/workflow.md +0 -83
- package/dist/templates/common/workflow/sixStep/zh-CN/workflow.md +0 -359
- package/dist/templates/common/workflow/specFirstTDD/en/spec-first-tdd.md +0 -364
- package/dist/templates/common/workflow/specFirstTDD/zh-CN/spec-first-tdd.md +0 -366
- package/dist/templates/hooks/README.md +0 -212
- package/dist/templates/hooks/git-workflow-hooks.md +0 -551
- package/dist/templates/hooks/post-test/coverage.json +0 -21
- package/dist/templates/hooks/post-test/summary.json +0 -21
- package/dist/templates/hooks/post-test-coverage.md +0 -434
- package/dist/templates/hooks/pre-commit/eslint.json +0 -22
- package/dist/templates/hooks/pre-commit/prettier.json +0 -22
- package/dist/templates/hooks/pre-commit-black.md +0 -274
- package/dist/templates/hooks/pre-commit-eslint.md +0 -153
- package/dist/templates/hooks/pre-commit-gofmt.md +0 -284
- package/dist/templates/hooks/pre-commit-prettier.md +0 -212
- package/dist/templates/hooks/pre-commit-type-check.md +0 -377
- package/dist/templates/skills/ccjk-init.md +0 -154
- package/dist/templates/skills/ccjk-mcp-setup.md +0 -205
- package/dist/templates/skills/ccjk-troubleshoot.md +0 -228
- package/dist/templates/skills/django-patterns.md +0 -1016
- package/dist/templates/skills/git-workflow.md +0 -748
- package/dist/templates/skills/go-idioms.md +0 -963
- package/dist/templates/skills/index.json +0 -132
- package/dist/templates/skills/nextjs-optimization.md +0 -694
- package/dist/templates/skills/python-pep8.md +0 -852
- package/dist/templates/skills/react-patterns.md +0 -686
- package/dist/templates/skills/rust-patterns.md +0 -1057
- package/dist/templates/skills/security-best-practices.md +0 -1413
- package/dist/templates/skills/testing-best-practices.md +0 -1315
- package/dist/templates/skills/ts-best-practices.md +0 -354
- package/templates/agents/README.md +0 -78
- package/templates/agents/fullstack-developer.json +0 -70
- package/templates/agents/go-expert.json +0 -69
- package/templates/agents/index.json +0 -64
- package/templates/agents/python-expert.json +0 -69
- package/templates/agents/react-specialist.json +0 -69
- package/templates/agents/testing-automation-expert.json +0 -70
- package/templates/agents/typescript-architect.json +0 -69
- package/templates/claude-code/common/settings.json +0 -109
- package/templates/common/error-prevention.md +0 -267
- package/templates/common/karpathy-baseline.md +0 -83
- package/templates/common/output-styles/zh-CN/carmack-mode.md +0 -381
- package/templates/common/output-styles/zh-CN/codex-rigor-mode.md +0 -114
- package/templates/common/output-styles/zh-CN/dhh-mode.md +0 -265
- package/templates/common/output-styles/zh-CN/evan-you-mode.md +0 -539
- package/templates/common/output-styles/zh-CN/jobs-mode.md +0 -369
- package/templates/common/output-styles/zh-CN/linus-mode.md +0 -135
- package/templates/common/output-styles/zh-CN/uncle-bob-mode.md +0 -221
- package/templates/common/workflow/continuousDelivery/en/continuous-delivery.md +0 -628
- package/templates/common/workflow/continuousDelivery/zh-CN/continuous-delivery.md +0 -628
- package/templates/common/workflow/essential/en/agents/ccjk-config-agent.md +0 -187
- package/templates/common/workflow/essential/en/agents/ccjk-mcp-agent.md +0 -191
- package/templates/common/workflow/essential/en/agents/ccjk-skill-agent.md +0 -249
- package/templates/common/workflow/essential/en/agents/ccjk-workflow-agent.md +0 -277
- package/templates/common/workflow/essential/en/agents/get-current-datetime.md +0 -29
- package/templates/common/workflow/essential/en/agents/init-architect.md +0 -115
- package/templates/common/workflow/essential/en/agents/ui-ux-designer.md +0 -91
- package/templates/common/workflow/essential/en/feat.md +0 -92
- package/templates/common/workflow/essential/en/goal.md +0 -147
- package/templates/common/workflow/essential/en/init-project.md +0 -53
- package/templates/common/workflow/essential/zh-CN/agents/get-current-datetime.md +0 -29
- package/templates/common/workflow/essential/zh-CN/agents/init-architect.md +0 -115
- package/templates/common/workflow/essential/zh-CN/agents/ui-ux-designer.md +0 -91
- package/templates/common/workflow/essential/zh-CN/feat.md +0 -315
- package/templates/common/workflow/essential/zh-CN/goal.md +0 -146
- package/templates/common/workflow/essential/zh-CN/init-project.md +0 -53
- package/templates/common/workflow/git/en/git-cleanBranches.md +0 -102
- package/templates/common/workflow/git/en/git-commit.md +0 -205
- package/templates/common/workflow/git/en/git-rollback.md +0 -90
- package/templates/common/workflow/git/en/git-worktree.md +0 -276
- package/templates/common/workflow/git/zh-CN/git-cleanBranches.md +0 -102
- package/templates/common/workflow/git/zh-CN/git-commit.md +0 -205
- package/templates/common/workflow/git/zh-CN/git-rollback.md +0 -90
- package/templates/common/workflow/git/zh-CN/git-worktree.md +0 -276
- package/templates/common/workflow/interview/en/interview.md +0 -67
- package/templates/common/workflow/interview/zh-CN/interview.md +0 -67
- package/templates/common/workflow/linearMethod/en/linear-method.md +0 -651
- package/templates/common/workflow/linearMethod/zh-CN/linear-method.md +0 -752
- package/templates/common/workflow/refactoringMaster/en/refactoring-master.md +0 -516
- package/templates/common/workflow/refactoringMaster/zh-CN/refactoring-master.md +0 -812
- package/templates/common/workflow/sixStep/en/workflow.md +0 -83
- package/templates/common/workflow/sixStep/zh-CN/workflow.md +0 -359
- package/templates/common/workflow/specFirstTDD/en/spec-first-tdd.md +0 -364
- package/templates/common/workflow/specFirstTDD/zh-CN/spec-first-tdd.md +0 -366
- package/templates/hooks/README.md +0 -212
- package/templates/hooks/git-workflow-hooks.md +0 -551
- package/templates/hooks/post-test/coverage.json +0 -21
- package/templates/hooks/post-test/summary.json +0 -21
- package/templates/hooks/post-test-coverage.md +0 -434
- package/templates/hooks/pre-commit/eslint.json +0 -22
- package/templates/hooks/pre-commit/prettier.json +0 -22
- package/templates/hooks/pre-commit-black.md +0 -274
- package/templates/hooks/pre-commit-eslint.md +0 -153
- package/templates/hooks/pre-commit-gofmt.md +0 -284
- package/templates/hooks/pre-commit-prettier.md +0 -212
- package/templates/hooks/pre-commit-type-check.md +0 -377
- package/templates/skills/basic.hbs +0 -72
- package/templates/skills/ccjk-init.md +0 -154
- package/templates/skills/ccjk-mcp-setup.md +0 -205
- package/templates/skills/ccjk-troubleshoot.md +0 -228
- package/templates/skills/code-refactor.hbs +0 -133
- package/templates/skills/code-review.hbs +0 -141
- package/templates/skills/django-patterns.md +0 -1016
- package/templates/skills/git-workflow.md +0 -748
- package/templates/skills/go-idioms.md +0 -963
- package/templates/skills/index.json +0 -132
- package/templates/skills/nextjs-optimization.md +0 -694
- package/templates/skills/python-pep8.md +0 -852
- package/templates/skills/react-patterns.md +0 -686
- package/templates/skills/rust-patterns.md +0 -1057
- package/templates/skills/security-best-practices.md +0 -1413
- package/templates/skills/testing-best-practices.md +0 -1315
- package/templates/skills/ts-best-practices.md +0 -354
- package/templates/skills/type-fix.hbs +0 -132
|
@@ -1,694 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: nextjs-optimization
|
|
3
|
-
description: Next.js App Router patterns, server components, and performance optimization
|
|
4
|
-
description_zh: Next.js App Router 模式、服务器组件和性能优化
|
|
5
|
-
version: 1.0.0
|
|
6
|
-
category: frontend
|
|
7
|
-
triggers: ['/nextjs-optimization', '/nextjs', '/app-router', '/server-components']
|
|
8
|
-
use_when:
|
|
9
|
-
- Building Next.js 13+ applications with App Router
|
|
10
|
-
- Implementing server components and data fetching strategies
|
|
11
|
-
- Optimizing Next.js performance and SEO
|
|
12
|
-
- Code review for Next.js applications
|
|
13
|
-
use_when_zh:
|
|
14
|
-
- 使用 App Router 构建 Next.js 13+ 应用程序
|
|
15
|
-
- 实现服务器组件和数据获取策略
|
|
16
|
-
- 优化 Next.js 性能和 SEO
|
|
17
|
-
- Next.js 应用程序代码审查
|
|
18
|
-
auto_activate: true
|
|
19
|
-
priority: 8
|
|
20
|
-
agents: [nextjs-expert, fullstack-architect]
|
|
21
|
-
tags: [nextjs, app-router, server-components, performance, seo]
|
|
22
|
-
---
|
|
23
|
-
|
|
24
|
-
# Next.js Optimization | Next.js 优化
|
|
25
|
-
|
|
26
|
-
## Context | 上下文
|
|
27
|
-
|
|
28
|
-
Use this skill when developing Next.js 13+ applications with App Router that require optimal performance, SEO, and modern React patterns. Essential for production-ready Next.js applications.
|
|
29
|
-
|
|
30
|
-
在开发需要最佳性能、SEO 和现代 React 模式的 Next.js 13+ App Router 应用程序时使用此技能。对于生产就绪的 Next.js 应用程序至关重要。
|
|
31
|
-
|
|
32
|
-
## App Router Patterns | App Router 模式
|
|
33
|
-
|
|
34
|
-
### 1. File-based Routing Structure | 基于文件的路由结构
|
|
35
|
-
|
|
36
|
-
```
|
|
37
|
-
app/
|
|
38
|
-
├── layout.tsx # Root layout
|
|
39
|
-
├── page.tsx # Home page
|
|
40
|
-
├── loading.tsx # Loading UI
|
|
41
|
-
├── error.tsx # Error UI
|
|
42
|
-
├── not-found.tsx # 404 page
|
|
43
|
-
├── global-error.tsx # Global error boundary
|
|
44
|
-
├── (auth)/ # Route groups
|
|
45
|
-
│ ├── login/
|
|
46
|
-
│ │ └── page.tsx
|
|
47
|
-
│ └── register/
|
|
48
|
-
│ └── page.tsx
|
|
49
|
-
├── dashboard/
|
|
50
|
-
│ ├── layout.tsx # Nested layout
|
|
51
|
-
│ ├── page.tsx
|
|
52
|
-
│ ├── settings/
|
|
53
|
-
│ │ └── page.tsx
|
|
54
|
-
│ └── [userId]/ # Dynamic routes
|
|
55
|
-
│ ├── page.tsx
|
|
56
|
-
│ └── edit/
|
|
57
|
-
│ └── page.tsx
|
|
58
|
-
└── api/ # API routes
|
|
59
|
-
├── auth/
|
|
60
|
-
│ └── route.ts
|
|
61
|
-
└── users/
|
|
62
|
-
└── route.ts
|
|
63
|
-
```
|
|
64
|
-
|
|
65
|
-
### 2. Server Components Best Practices | 服务器组件最佳实践
|
|
66
|
-
|
|
67
|
-
```tsx
|
|
68
|
-
// ✅ Good: Server component with data fetching
|
|
69
|
-
import { Suspense } from 'react';
|
|
70
|
-
import { getUserPosts, getUser } from '@/lib/api';
|
|
71
|
-
|
|
72
|
-
// Server component - runs on server
|
|
73
|
-
async function UserProfile({ userId }: { userId: string }) {
|
|
74
|
-
// Fetch data directly in server component
|
|
75
|
-
const user = await getUser(userId);
|
|
76
|
-
|
|
77
|
-
if (!user) {
|
|
78
|
-
return <div>User not found</div>;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
return (
|
|
82
|
-
<div>
|
|
83
|
-
<h1>{user.name}</h1>
|
|
84
|
-
<p>{user.email}</p>
|
|
85
|
-
<Suspense fallback={<div>Loading posts...</div>}>
|
|
86
|
-
<UserPosts userId={userId} />
|
|
87
|
-
</Suspense>
|
|
88
|
-
</div>
|
|
89
|
-
);
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
// Separate server component for posts
|
|
93
|
-
async function UserPosts({ userId }: { userId: string }) {
|
|
94
|
-
const posts = await getUserPosts(userId);
|
|
95
|
-
|
|
96
|
-
return (
|
|
97
|
-
<div>
|
|
98
|
-
{posts.map(post => (
|
|
99
|
-
<article key={post.id}>
|
|
100
|
-
<h2>{post.title}</h2>
|
|
101
|
-
<p>{post.excerpt}</p>
|
|
102
|
-
</article>
|
|
103
|
-
))}
|
|
104
|
-
</div>
|
|
105
|
-
);
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
// Page component
|
|
109
|
-
export default function UserPage({ params }: { params: { userId: string } }) {
|
|
110
|
-
return (
|
|
111
|
-
<main>
|
|
112
|
-
<Suspense fallback={<div>Loading user...</div>}>
|
|
113
|
-
<UserProfile userId={params.userId} />
|
|
114
|
-
</Suspense>
|
|
115
|
-
</main>
|
|
116
|
-
);
|
|
117
|
-
}
|
|
118
|
-
```
|
|
119
|
-
|
|
120
|
-
### 3. Client Components Pattern | 客户端组件模式
|
|
121
|
-
|
|
122
|
-
```tsx
|
|
123
|
-
'use client'; // Mark as client component
|
|
124
|
-
|
|
125
|
-
import { useState, useEffect } from 'react';
|
|
126
|
-
import { useRouter } from 'next/navigation';
|
|
127
|
-
|
|
128
|
-
// ✅ Good: Client component for interactivity
|
|
129
|
-
export function InteractiveCounter({ initialCount = 0 }: { initialCount?: number }) {
|
|
130
|
-
const [count, setCount] = useState(initialCount);
|
|
131
|
-
const router = useRouter();
|
|
132
|
-
|
|
133
|
-
useEffect(() => {
|
|
134
|
-
// Client-side only code
|
|
135
|
-
const interval = setInterval(() => {
|
|
136
|
-
setCount(c => c + 1);
|
|
137
|
-
}, 1000);
|
|
138
|
-
|
|
139
|
-
return () => clearInterval(interval);
|
|
140
|
-
}, []);
|
|
141
|
-
|
|
142
|
-
const handleReset = () => {
|
|
143
|
-
setCount(0);
|
|
144
|
-
// Client-side navigation
|
|
145
|
-
router.refresh();
|
|
146
|
-
};
|
|
147
|
-
|
|
148
|
-
return (
|
|
149
|
-
<div>
|
|
150
|
-
<p>Count: {count}</p>
|
|
151
|
-
<button onClick={() => setCount(c => c + 1)}>
|
|
152
|
-
Increment
|
|
153
|
-
</button>
|
|
154
|
-
<button onClick={handleReset}>
|
|
155
|
-
Reset
|
|
156
|
-
</button>
|
|
157
|
-
</div>
|
|
158
|
-
);
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
// ✅ Good: Hybrid approach - server component wrapping client component
|
|
162
|
-
import { InteractiveCounter } from './InteractiveCounter';
|
|
163
|
-
|
|
164
|
-
async function CounterPage() {
|
|
165
|
-
// Server-side data fetching
|
|
166
|
-
const initialData = await fetch('https://api.example.com/counter').then(r => r.json());
|
|
167
|
-
|
|
168
|
-
return (
|
|
169
|
-
<div>
|
|
170
|
-
<h1>Counter Page</h1>
|
|
171
|
-
<InteractiveCounter initialCount={initialData.count} />
|
|
172
|
-
</div>
|
|
173
|
-
);
|
|
174
|
-
}
|
|
175
|
-
```
|
|
176
|
-
|
|
177
|
-
## Data Fetching Strategies | 数据获取策略
|
|
178
|
-
|
|
179
|
-
### 1. Server-Side Data Fetching | 服务器端数据获取
|
|
180
|
-
|
|
181
|
-
```tsx
|
|
182
|
-
// ✅ Good: Parallel data fetching
|
|
183
|
-
async function ProductPage({ params }: { params: { id: string } }) {
|
|
184
|
-
// Fetch data in parallel
|
|
185
|
-
const [product, reviews, relatedProducts] = await Promise.all([
|
|
186
|
-
getProduct(params.id),
|
|
187
|
-
getProductReviews(params.id),
|
|
188
|
-
getRelatedProducts(params.id)
|
|
189
|
-
]);
|
|
190
|
-
|
|
191
|
-
return (
|
|
192
|
-
<div>
|
|
193
|
-
<ProductDetails product={product} />
|
|
194
|
-
<ProductReviews reviews={reviews} />
|
|
195
|
-
<RelatedProducts products={relatedProducts} />
|
|
196
|
-
</div>
|
|
197
|
-
);
|
|
198
|
-
}
|
|
199
|
-
|
|
200
|
-
// ✅ Good: Streaming with Suspense
|
|
201
|
-
function ProductPageWithStreaming({ params }: { params: { id: string } }) {
|
|
202
|
-
return (
|
|
203
|
-
<div>
|
|
204
|
-
<Suspense fallback={<ProductSkeleton />}>
|
|
205
|
-
<ProductDetails productId={params.id} />
|
|
206
|
-
</Suspense>
|
|
207
|
-
|
|
208
|
-
<Suspense fallback={<ReviewsSkeleton />}>
|
|
209
|
-
<ProductReviews productId={params.id} />
|
|
210
|
-
</Suspense>
|
|
211
|
-
|
|
212
|
-
<Suspense fallback={<RelatedSkeleton />}>
|
|
213
|
-
<RelatedProducts productId={params.id} />
|
|
214
|
-
</Suspense>
|
|
215
|
-
</div>
|
|
216
|
-
);
|
|
217
|
-
}
|
|
218
|
-
|
|
219
|
-
async function ProductDetails({ productId }: { productId: string }) {
|
|
220
|
-
const product = await getProduct(productId);
|
|
221
|
-
return <div>{/* Product details */}</div>;
|
|
222
|
-
}
|
|
223
|
-
```
|
|
224
|
-
|
|
225
|
-
### 2. Client-Side Data Fetching | 客户端数据获取
|
|
226
|
-
|
|
227
|
-
```tsx
|
|
228
|
-
'use client';
|
|
229
|
-
|
|
230
|
-
import { useState, useEffect } from 'react';
|
|
231
|
-
import useSWR from 'swr';
|
|
232
|
-
|
|
233
|
-
// ✅ Good: SWR for client-side data fetching
|
|
234
|
-
function UserDashboard() {
|
|
235
|
-
const { data: user, error, isLoading } = useSWR('/api/user', fetcher);
|
|
236
|
-
const { data: notifications } = useSWR('/api/notifications', fetcher, {
|
|
237
|
-
refreshInterval: 30000 // Refresh every 30 seconds
|
|
238
|
-
});
|
|
239
|
-
|
|
240
|
-
if (error) return <div>Failed to load user data</div>;
|
|
241
|
-
if (isLoading) return <div>Loading...</div>;
|
|
242
|
-
|
|
243
|
-
return (
|
|
244
|
-
<div>
|
|
245
|
-
<h1>Welcome, {user.name}</h1>
|
|
246
|
-
<NotificationList notifications={notifications} />
|
|
247
|
-
</div>
|
|
248
|
-
);
|
|
249
|
-
}
|
|
250
|
-
|
|
251
|
-
// ✅ Good: Custom hook for data fetching
|
|
252
|
-
function useApi<T>(url: string) {
|
|
253
|
-
const [data, setData] = useState<T | null>(null);
|
|
254
|
-
const [loading, setLoading] = useState(true);
|
|
255
|
-
const [error, setError] = useState<Error | null>(null);
|
|
256
|
-
|
|
257
|
-
useEffect(() => {
|
|
258
|
-
async function fetchData() {
|
|
259
|
-
try {
|
|
260
|
-
setLoading(true);
|
|
261
|
-
const response = await fetch(url);
|
|
262
|
-
if (!response.ok) throw new Error('Failed to fetch');
|
|
263
|
-
const result = await response.json();
|
|
264
|
-
setData(result);
|
|
265
|
-
} catch (err) {
|
|
266
|
-
setError(err instanceof Error ? err : new Error('Unknown error'));
|
|
267
|
-
} finally {
|
|
268
|
-
setLoading(false);
|
|
269
|
-
}
|
|
270
|
-
}
|
|
271
|
-
|
|
272
|
-
fetchData();
|
|
273
|
-
}, [url]);
|
|
274
|
-
|
|
275
|
-
return { data, loading, error };
|
|
276
|
-
}
|
|
277
|
-
```
|
|
278
|
-
|
|
279
|
-
### 3. Caching and Revalidation | 缓存和重新验证
|
|
280
|
-
|
|
281
|
-
```tsx
|
|
282
|
-
// ✅ Good: Static generation with revalidation
|
|
283
|
-
export const revalidate = 3600; // Revalidate every hour
|
|
284
|
-
|
|
285
|
-
async function BlogPost({ params }: { params: { slug: string } }) {
|
|
286
|
-
const post = await getBlogPost(params.slug);
|
|
287
|
-
|
|
288
|
-
return (
|
|
289
|
-
<article>
|
|
290
|
-
<h1>{post.title}</h1>
|
|
291
|
-
<div dangerouslySetInnerHTML={{ __html: post.content }} />
|
|
292
|
-
</article>
|
|
293
|
-
);
|
|
294
|
-
}
|
|
295
|
-
|
|
296
|
-
// ✅ Good: Dynamic with custom cache
|
|
297
|
-
async function getProductWithCache(id: string) {
|
|
298
|
-
const response = await fetch(`https://api.example.com/products/${id}`, {
|
|
299
|
-
next: {
|
|
300
|
-
revalidate: 300, // Cache for 5 minutes
|
|
301
|
-
tags: [`product-${id}`] // For on-demand revalidation
|
|
302
|
-
}
|
|
303
|
-
});
|
|
304
|
-
|
|
305
|
-
if (!response.ok) {
|
|
306
|
-
throw new Error('Failed to fetch product');
|
|
307
|
-
}
|
|
308
|
-
|
|
309
|
-
return response.json();
|
|
310
|
-
}
|
|
311
|
-
|
|
312
|
-
// API route for cache revalidation
|
|
313
|
-
// app/api/revalidate/route.ts
|
|
314
|
-
import { revalidateTag } from 'next/cache';
|
|
315
|
-
import { NextRequest } from 'next/server';
|
|
316
|
-
|
|
317
|
-
export async function POST(request: NextRequest) {
|
|
318
|
-
const { tag } = await request.json();
|
|
319
|
-
|
|
320
|
-
revalidateTag(tag);
|
|
321
|
-
|
|
322
|
-
return Response.json({ revalidated: true });
|
|
323
|
-
}
|
|
324
|
-
```
|
|
325
|
-
|
|
326
|
-
## Performance Optimization | 性能优化
|
|
327
|
-
|
|
328
|
-
### 1. Image Optimization | 图像优化
|
|
329
|
-
|
|
330
|
-
```tsx
|
|
331
|
-
import Image from 'next/image';
|
|
332
|
-
|
|
333
|
-
// ✅ Good: Optimized images with Next.js Image component
|
|
334
|
-
function ProductGallery({ product }: { product: Product }) {
|
|
335
|
-
return (
|
|
336
|
-
<div className="grid grid-cols-2 gap-4">
|
|
337
|
-
{/* Hero image with priority loading */}
|
|
338
|
-
<Image
|
|
339
|
-
src={product.images[0]}
|
|
340
|
-
alt={product.name}
|
|
341
|
-
width={800}
|
|
342
|
-
height={600}
|
|
343
|
-
priority
|
|
344
|
-
className="rounded-lg"
|
|
345
|
-
placeholder="blur"
|
|
346
|
-
blurDataURL="data:image/jpeg;base64,/9j/4AAQSkZJRgABAQAAAQABAAD/2wBDAAYEBQYFBAYGBQYHBwYIChAKCgkJChQODwwQFxQYGBcUFhYaHSUfGhsjHBYWICwgIyYnKSopGR8tMC0oMCUoKSj/2wBDAQcHBwoIChMKChMoGhYaKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCj/wAARCAABAAEDASIAAhEBAxEB/8QAFQABAQAAAAAAAAAAAAAAAAAAAAv/xAAUEAEAAAAAAAAAAAAAAAAAAAAA/8QAFQEBAQAAAAAAAAAAAAAAAAAAAAX/xAAUEQEAAAAAAAAAAAAAAAAAAAAA/9oADAMBAAIRAxEAPwCdABmX/9k="
|
|
347
|
-
/>
|
|
348
|
-
|
|
349
|
-
{/* Lazy loaded images */}
|
|
350
|
-
{product.images.slice(1).map((image, index) => (
|
|
351
|
-
<Image
|
|
352
|
-
key={index}
|
|
353
|
-
src={image}
|
|
354
|
-
alt={`${product.name} ${index + 2}`}
|
|
355
|
-
width={400}
|
|
356
|
-
height={300}
|
|
357
|
-
className="rounded-lg"
|
|
358
|
-
loading="lazy"
|
|
359
|
-
/>
|
|
360
|
-
))}
|
|
361
|
-
</div>
|
|
362
|
-
);
|
|
363
|
-
}
|
|
364
|
-
|
|
365
|
-
// ✅ Good: Responsive images
|
|
366
|
-
function ResponsiveHero({ image }: { image: string }) {
|
|
367
|
-
return (
|
|
368
|
-
<Image
|
|
369
|
-
src={image}
|
|
370
|
-
alt="Hero image"
|
|
371
|
-
fill
|
|
372
|
-
className="object-cover"
|
|
373
|
-
sizes="(max-width: 768px) 100vw, (max-width: 1200px) 50vw, 33vw"
|
|
374
|
-
priority
|
|
375
|
-
/>
|
|
376
|
-
);
|
|
377
|
-
}
|
|
378
|
-
```
|
|
379
|
-
|
|
380
|
-
### 2. Bundle Optimization | 包优化
|
|
381
|
-
|
|
382
|
-
```tsx
|
|
383
|
-
// ✅ Good: Dynamic imports for code splitting
|
|
384
|
-
import dynamic from 'next/dynamic';
|
|
385
|
-
|
|
386
|
-
// Lazy load heavy components
|
|
387
|
-
const Chart = dynamic(() => import('./Chart'), {
|
|
388
|
-
loading: () => <div>Loading chart...</div>,
|
|
389
|
-
ssr: false // Disable SSR for client-only components
|
|
390
|
-
});
|
|
391
|
-
|
|
392
|
-
const Modal = dynamic(() => import('./Modal'), {
|
|
393
|
-
loading: () => <div>Loading...</div>
|
|
394
|
-
});
|
|
395
|
-
|
|
396
|
-
function Dashboard() {
|
|
397
|
-
const [showChart, setShowChart] = useState(false);
|
|
398
|
-
const [showModal, setShowModal] = useState(false);
|
|
399
|
-
|
|
400
|
-
return (
|
|
401
|
-
<div>
|
|
402
|
-
<button onClick={() => setShowChart(true)}>
|
|
403
|
-
Show Chart
|
|
404
|
-
</button>
|
|
405
|
-
|
|
406
|
-
{showChart && <Chart />}
|
|
407
|
-
{showModal && <Modal onClose={() => setShowModal(false)} />}
|
|
408
|
-
</div>
|
|
409
|
-
);
|
|
410
|
-
}
|
|
411
|
-
|
|
412
|
-
// ✅ Good: Tree shaking with named imports
|
|
413
|
-
import { debounce } from 'lodash-es'; // Better than import _ from 'lodash'
|
|
414
|
-
import { format } from 'date-fns'; // Better than import * as dateFns
|
|
415
|
-
```
|
|
416
|
-
|
|
417
|
-
### 3. Streaming and Suspense | 流式传输和 Suspense
|
|
418
|
-
|
|
419
|
-
```tsx
|
|
420
|
-
import { Suspense } from 'react';
|
|
421
|
-
|
|
422
|
-
// ✅ Good: Streaming layout
|
|
423
|
-
export default function Layout({ children }: { children: React.ReactNode }) {
|
|
424
|
-
return (
|
|
425
|
-
<html>
|
|
426
|
-
<body>
|
|
427
|
-
<header>
|
|
428
|
-
<Suspense fallback={<div>Loading navigation...</div>}>
|
|
429
|
-
<Navigation />
|
|
430
|
-
</Suspense>
|
|
431
|
-
</header>
|
|
432
|
-
|
|
433
|
-
<main>
|
|
434
|
-
<Suspense fallback={<div>Loading content...</div>}>
|
|
435
|
-
{children}
|
|
436
|
-
</Suspense>
|
|
437
|
-
</main>
|
|
438
|
-
|
|
439
|
-
<footer>
|
|
440
|
-
<Suspense fallback={<div>Loading footer...</div>}>
|
|
441
|
-
<Footer />
|
|
442
|
-
</Suspense>
|
|
443
|
-
</footer>
|
|
444
|
-
</body>
|
|
445
|
-
</html>
|
|
446
|
-
);
|
|
447
|
-
}
|
|
448
|
-
|
|
449
|
-
// ✅ Good: Progressive enhancement
|
|
450
|
-
function ProductPage({ params }: { params: { id: string } }) {
|
|
451
|
-
return (
|
|
452
|
-
<div>
|
|
453
|
-
{/* Critical content loads first */}
|
|
454
|
-
<Suspense fallback={<ProductSkeleton />}>
|
|
455
|
-
<ProductInfo productId={params.id} />
|
|
456
|
-
</Suspense>
|
|
457
|
-
|
|
458
|
-
{/* Non-critical content streams in later */}
|
|
459
|
-
<Suspense fallback={<div>Loading reviews...</div>}>
|
|
460
|
-
<ProductReviews productId={params.id} />
|
|
461
|
-
</Suspense>
|
|
462
|
-
|
|
463
|
-
<Suspense fallback={<div>Loading recommendations...</div>}>
|
|
464
|
-
<ProductRecommendations productId={params.id} />
|
|
465
|
-
</Suspense>
|
|
466
|
-
</div>
|
|
467
|
-
);
|
|
468
|
-
}
|
|
469
|
-
```
|
|
470
|
-
|
|
471
|
-
## SEO and Metadata | SEO 和元数据
|
|
472
|
-
|
|
473
|
-
### 1. Metadata API | 元数据 API
|
|
474
|
-
|
|
475
|
-
```tsx
|
|
476
|
-
import type { Metadata } from 'next';
|
|
477
|
-
|
|
478
|
-
// ✅ Good: Static metadata
|
|
479
|
-
export const metadata: Metadata = {
|
|
480
|
-
title: 'My App',
|
|
481
|
-
description: 'The best app ever built',
|
|
482
|
-
keywords: ['nextjs', 'react', 'typescript'],
|
|
483
|
-
authors: [{ name: 'John Doe' }],
|
|
484
|
-
openGraph: {
|
|
485
|
-
title: 'My App',
|
|
486
|
-
description: 'The best app ever built',
|
|
487
|
-
url: 'https://myapp.com',
|
|
488
|
-
siteName: 'My App',
|
|
489
|
-
images: [
|
|
490
|
-
{
|
|
491
|
-
url: 'https://myapp.com/og-image.jpg',
|
|
492
|
-
width: 1200,
|
|
493
|
-
height: 630,
|
|
494
|
-
},
|
|
495
|
-
],
|
|
496
|
-
locale: 'en_US',
|
|
497
|
-
type: 'website',
|
|
498
|
-
},
|
|
499
|
-
twitter: {
|
|
500
|
-
card: 'summary_large_image',
|
|
501
|
-
title: 'My App',
|
|
502
|
-
description: 'The best app ever built',
|
|
503
|
-
images: ['https://myapp.com/twitter-image.jpg'],
|
|
504
|
-
},
|
|
505
|
-
};
|
|
506
|
-
|
|
507
|
-
// ✅ Good: Dynamic metadata
|
|
508
|
-
export async function generateMetadata(
|
|
509
|
-
{ params }: { params: { id: string } }
|
|
510
|
-
): Promise<Metadata> {
|
|
511
|
-
const product = await getProduct(params.id);
|
|
512
|
-
|
|
513
|
-
return {
|
|
514
|
-
title: product.name,
|
|
515
|
-
description: product.description,
|
|
516
|
-
openGraph: {
|
|
517
|
-
title: product.name,
|
|
518
|
-
description: product.description,
|
|
519
|
-
images: [product.image],
|
|
520
|
-
},
|
|
521
|
-
};
|
|
522
|
-
}
|
|
523
|
-
```
|
|
524
|
-
|
|
525
|
-
### 2. Structured Data | 结构化数据
|
|
526
|
-
|
|
527
|
-
```tsx
|
|
528
|
-
// ✅ Good: JSON-LD structured data
|
|
529
|
-
function ProductPage({ product }: { product: Product }) {
|
|
530
|
-
const jsonLd = {
|
|
531
|
-
'@context': 'https://schema.org',
|
|
532
|
-
'@type': 'Product',
|
|
533
|
-
name: product.name,
|
|
534
|
-
description: product.description,
|
|
535
|
-
image: product.images,
|
|
536
|
-
offers: {
|
|
537
|
-
'@type': 'Offer',
|
|
538
|
-
price: product.price,
|
|
539
|
-
priceCurrency: 'USD',
|
|
540
|
-
availability: 'https://schema.org/InStock',
|
|
541
|
-
},
|
|
542
|
-
aggregateRating: {
|
|
543
|
-
'@type': 'AggregateRating',
|
|
544
|
-
ratingValue: product.rating,
|
|
545
|
-
reviewCount: product.reviewCount,
|
|
546
|
-
},
|
|
547
|
-
};
|
|
548
|
-
|
|
549
|
-
return (
|
|
550
|
-
<>
|
|
551
|
-
<script
|
|
552
|
-
type="application/ld+json"
|
|
553
|
-
dangerouslySetInnerHTML={{ __html: JSON.stringify(jsonLd) }}
|
|
554
|
-
/>
|
|
555
|
-
<div>
|
|
556
|
-
{/* Product content */}
|
|
557
|
-
</div>
|
|
558
|
-
</>
|
|
559
|
-
);
|
|
560
|
-
}
|
|
561
|
-
```
|
|
562
|
-
|
|
563
|
-
## Anti-Patterns | 反模式
|
|
564
|
-
|
|
565
|
-
### 1. Avoid Client Components for Static Content | 避免在静态内容中使用客户端组件
|
|
566
|
-
|
|
567
|
-
```tsx
|
|
568
|
-
// ❌ Bad: Unnecessary client component
|
|
569
|
-
'use client';
|
|
570
|
-
|
|
571
|
-
function BlogPost({ post }: { post: Post }) {
|
|
572
|
-
return (
|
|
573
|
-
<article>
|
|
574
|
-
<h1>{post.title}</h1>
|
|
575
|
-
<p>{post.content}</p>
|
|
576
|
-
</article>
|
|
577
|
-
);
|
|
578
|
-
}
|
|
579
|
-
|
|
580
|
-
// ✅ Good: Server component for static content
|
|
581
|
-
function BlogPost({ post }: { post: Post }) {
|
|
582
|
-
return (
|
|
583
|
-
<article>
|
|
584
|
-
<h1>{post.title}</h1>
|
|
585
|
-
<p>{post.content}</p>
|
|
586
|
-
</article>
|
|
587
|
-
);
|
|
588
|
-
}
|
|
589
|
-
```
|
|
590
|
-
|
|
591
|
-
### 2. Avoid Blocking Data Fetching | 避免阻塞数据获取
|
|
592
|
-
|
|
593
|
-
```tsx
|
|
594
|
-
// ❌ Bad: Sequential data fetching
|
|
595
|
-
async function BadProductPage({ params }: { params: { id: string } }) {
|
|
596
|
-
const product = await getProduct(params.id);
|
|
597
|
-
const reviews = await getProductReviews(params.id); // Waits for product
|
|
598
|
-
const related = await getRelatedProducts(params.id); // Waits for reviews
|
|
599
|
-
|
|
600
|
-
return (
|
|
601
|
-
<div>
|
|
602
|
-
<ProductDetails product={product} />
|
|
603
|
-
<ProductReviews reviews={reviews} />
|
|
604
|
-
<RelatedProducts products={related} />
|
|
605
|
-
</div>
|
|
606
|
-
);
|
|
607
|
-
}
|
|
608
|
-
|
|
609
|
-
// ✅ Good: Parallel data fetching
|
|
610
|
-
async function GoodProductPage({ params }: { params: { id: string } }) {
|
|
611
|
-
const [product, reviews, related] = await Promise.all([
|
|
612
|
-
getProduct(params.id),
|
|
613
|
-
getProductReviews(params.id),
|
|
614
|
-
getRelatedProducts(params.id)
|
|
615
|
-
]);
|
|
616
|
-
|
|
617
|
-
return (
|
|
618
|
-
<div>
|
|
619
|
-
<ProductDetails product={product} />
|
|
620
|
-
<ProductReviews reviews={reviews} />
|
|
621
|
-
<RelatedProducts products={related} />
|
|
622
|
-
</div>
|
|
623
|
-
);
|
|
624
|
-
}
|
|
625
|
-
```
|
|
626
|
-
|
|
627
|
-
### 3. Avoid Overusing Client Components | 避免过度使用客户端组件
|
|
628
|
-
|
|
629
|
-
```tsx
|
|
630
|
-
// ❌ Bad: Everything as client component
|
|
631
|
-
'use client';
|
|
632
|
-
|
|
633
|
-
function Layout({ children }: { children: React.ReactNode }) {
|
|
634
|
-
return (
|
|
635
|
-
<div>
|
|
636
|
-
<Header />
|
|
637
|
-
<main>{children}</main>
|
|
638
|
-
<Footer />
|
|
639
|
-
</div>
|
|
640
|
-
);
|
|
641
|
-
}
|
|
642
|
-
|
|
643
|
-
// ✅ Good: Mix server and client components
|
|
644
|
-
function Layout({ children }: { children: React.ReactNode }) {
|
|
645
|
-
return (
|
|
646
|
-
<div>
|
|
647
|
-
<Header /> {/* Server component */}
|
|
648
|
-
<main>{children}</main>
|
|
649
|
-
<Footer /> {/* Server component */}
|
|
650
|
-
</div>
|
|
651
|
-
);
|
|
652
|
-
}
|
|
653
|
-
|
|
654
|
-
// Only interactive parts are client components
|
|
655
|
-
'use client';
|
|
656
|
-
function InteractiveHeader() {
|
|
657
|
-
const [isOpen, setIsOpen] = useState(false);
|
|
658
|
-
|
|
659
|
-
return (
|
|
660
|
-
<nav>
|
|
661
|
-
<button onClick={() => setIsOpen(!isOpen)}>
|
|
662
|
-
Menu
|
|
663
|
-
</button>
|
|
664
|
-
{isOpen && <MobileMenu />}
|
|
665
|
-
</nav>
|
|
666
|
-
);
|
|
667
|
-
}
|
|
668
|
-
```
|
|
669
|
-
|
|
670
|
-
## Performance Checklist | 性能检查清单
|
|
671
|
-
|
|
672
|
-
- [ ] Server components are used for static content
|
|
673
|
-
- [ ] Client components are minimal and focused
|
|
674
|
-
- [ ] Data fetching is parallelized where possible
|
|
675
|
-
- [ ] Images use Next.js Image component with optimization
|
|
676
|
-
- [ ] Code splitting is implemented for large components
|
|
677
|
-
- [ ] Metadata is properly configured for SEO
|
|
678
|
-
- [ ] Caching strategies are implemented
|
|
679
|
-
- [ ] Bundle size is monitored and optimized
|
|
680
|
-
- [ ] Streaming and Suspense are used for better UX
|
|
681
|
-
- [ ] Core Web Vitals are measured and optimized
|
|
682
|
-
|
|
683
|
-
## 性能检查清单
|
|
684
|
-
|
|
685
|
-
- [ ] 静态内容使用服务器组件
|
|
686
|
-
- [ ] 客户端组件最小化且专注
|
|
687
|
-
- [ ] 在可能的地方并行化数据获取
|
|
688
|
-
- [ ] 图像使用 Next.js Image 组件进行优化
|
|
689
|
-
- [ ] 为大型组件实现代码分割
|
|
690
|
-
- [ ] 为 SEO 正确配置元数据
|
|
691
|
-
- [ ] 实现缓存策略
|
|
692
|
-
- [ ] 监控和优化包大小
|
|
693
|
-
- [ ] 使用流式传输和 Suspense 改善用户体验
|
|
694
|
-
- [ ] 测量和优化核心 Web 指标
|