From ce6110588f8b29a5d00377b33c7c62ca6d3d9ca0 Mon Sep 17 00:00:00 2001 From: zguiyang Date: Mon, 16 Mar 2026 15:32:40 +0800 Subject: [PATCH] feat(contact): add multilingual contact pages and dynamic configurations - Created `src/pages/contact.astro` and `src/pages/zh/contact.astro` to support multilingual contact functionality. - Introduced `contactIntents` and `contactMethods` dynamic configurations in `src/lib/data/contact.ts` for streamlined content management. - Designed responsive and localized layouts with enhanced UX for both languages. --- .agents/skills/openspec-apply-change/SKILL.md | 156 +++++ .../skills/openspec-archive-change/SKILL.md | 114 ++++ .../openspec-bulk-archive-change/SKILL.md | 246 ++++++++ .../skills/openspec-continue-change/SKILL.md | 118 ++++ .agents/skills/openspec-explore/SKILL.md | 288 +++++++++ .agents/skills/openspec-ff-change/SKILL.md | 101 ++++ .agents/skills/openspec-new-change/SKILL.md | 74 +++ .agents/skills/openspec-onboard/SKILL.md | 554 ++++++++++++++++++ .agents/skills/openspec-sync-specs/SKILL.md | 138 +++++ .../skills/openspec-verify-change/SKILL.md | 168 ++++++ src/components/Footer.tsx | 2 +- src/components/GlassHeader.tsx | 7 +- src/components/LanguageSwitcher.tsx | 45 +- src/i18n/translations.ts | 18 +- src/layouts/Layout.astro | 2 +- src/lib/data/contact.ts | 44 ++ src/lib/data/index.ts | 4 +- src/lib/data/personal-info.ts | 59 +- src/lib/data/projects.ts | 439 ++++++++------ src/lib/data/uses.ts | 39 ++ src/pages/about.astro | 268 ++------- src/pages/blog/index.astro | 6 +- src/pages/contact.astro | 62 ++ src/pages/hire.astro | 374 +----------- src/pages/index.astro | 302 +++------- src/pages/now.astro | 271 ++------- src/pages/projects.astro | 191 +++--- src/pages/services.mdx | 42 +- src/pages/uses.astro | 40 ++ src/pages/zh/about.astro | 268 ++------- src/pages/zh/blog/index.astro | 6 +- src/pages/zh/contact.astro | 62 ++ src/pages/zh/hire.astro | 332 +---------- src/pages/zh/index.astro | 345 +++-------- src/pages/zh/now.astro | 271 ++------- src/pages/zh/projects.astro | 191 +++--- src/pages/zh/services.mdx | 42 +- src/pages/zh/uses.astro | 40 ++ src/types/data.ts | 35 +- 优化.md | 257 ++++++++ 40 files changed, 3474 insertions(+), 2547 deletions(-) create mode 100644 .agents/skills/openspec-apply-change/SKILL.md create mode 100644 .agents/skills/openspec-archive-change/SKILL.md create mode 100644 .agents/skills/openspec-bulk-archive-change/SKILL.md create mode 100644 .agents/skills/openspec-continue-change/SKILL.md create mode 100644 .agents/skills/openspec-explore/SKILL.md create mode 100644 .agents/skills/openspec-ff-change/SKILL.md create mode 100644 .agents/skills/openspec-new-change/SKILL.md create mode 100644 .agents/skills/openspec-onboard/SKILL.md create mode 100644 .agents/skills/openspec-sync-specs/SKILL.md create mode 100644 .agents/skills/openspec-verify-change/SKILL.md create mode 100644 src/lib/data/contact.ts create mode 100644 src/lib/data/uses.ts create mode 100644 src/pages/contact.astro create mode 100644 src/pages/uses.astro create mode 100644 src/pages/zh/contact.astro create mode 100644 src/pages/zh/uses.astro create mode 100644 优化.md diff --git a/.agents/skills/openspec-apply-change/SKILL.md b/.agents/skills/openspec-apply-change/SKILL.md new file mode 100644 index 0000000..d474dc1 --- /dev/null +++ b/.agents/skills/openspec-apply-change/SKILL.md @@ -0,0 +1,156 @@ +--- +name: openspec-apply-change +description: Implement tasks from an OpenSpec change. Use when the user wants to start implementing, continue implementation, or work through tasks. +license: MIT +compatibility: Requires openspec CLI. +metadata: + author: openspec + version: "1.0" + generatedBy: "1.2.0" +--- + +Implement tasks from an OpenSpec change. + +**Input**: Optionally specify a change name. If omitted, check if it can be inferred from conversation context. If vague or ambiguous you MUST prompt for available changes. + +**Steps** + +1. **Select the change** + + If a name is provided, use it. Otherwise: + - Infer from conversation context if the user mentioned a change + - Auto-select if only one active change exists + - If ambiguous, run `openspec list --json` to get available changes and use the **AskUserQuestion tool** to let the user select + + Always announce: "Using change: " and how to override (e.g., `/opsx:apply `). + +2. **Check status to understand the schema** + ```bash + openspec status --change "" --json + ``` + Parse the JSON to understand: + - `schemaName`: The workflow being used (e.g., "spec-driven") + - Which artifact contains the tasks (typically "tasks" for spec-driven, check status for others) + +3. **Get apply instructions** + + ```bash + openspec instructions apply --change "" --json + ``` + + This returns: + - Context file paths (varies by schema - could be proposal/specs/design/tasks or spec/tests/implementation/docs) + - Progress (total, complete, remaining) + - Task list with status + - Dynamic instruction based on current state + + **Handle states:** + - If `state: "blocked"` (missing artifacts): show message, suggest using openspec-continue-change + - If `state: "all_done"`: congratulate, suggest archive + - Otherwise: proceed to implementation + +4. **Read context files** + + Read the files listed in `contextFiles` from the apply instructions output. + The files depend on the schema being used: + - **spec-driven**: proposal, specs, design, tasks + - Other schemas: follow the contextFiles from CLI output + +5. **Show current progress** + + Display: + - Schema being used + - Progress: "N/M tasks complete" + - Remaining tasks overview + - Dynamic instruction from CLI + +6. **Implement tasks (loop until done or blocked)** + + For each pending task: + - Show which task is being worked on + - Make the code changes required + - Keep changes minimal and focused + - Mark task complete in the tasks file: `- [ ]` → `- [x]` + - Continue to next task + + **Pause if:** + - Task is unclear → ask for clarification + - Implementation reveals a design issue → suggest updating artifacts + - Error or blocker encountered → report and wait for guidance + - User interrupts + +7. **On completion or pause, show status** + + Display: + - Tasks completed this session + - Overall progress: "N/M tasks complete" + - If all done: suggest archive + - If paused: explain why and wait for guidance + +**Output During Implementation** + +``` +## Implementing: (schema: ) + +Working on task 3/7: +[...implementation happening...] +✓ Task complete + +Working on task 4/7: +[...implementation happening...] +✓ Task complete +``` + +**Output On Completion** + +``` +## Implementation Complete + +**Change:** +**Schema:** +**Progress:** 7/7 tasks complete ✓ + +### Completed This Session +- [x] Task 1 +- [x] Task 2 +... + +All tasks complete! Ready to archive this change. +``` + +**Output On Pause (Issue Encountered)** + +``` +## Implementation Paused + +**Change:** +**Schema:** +**Progress:** 4/7 tasks complete + +### Issue Encountered + + +**Options:** +1.