From ef66d79edfaced4a59b9685a7a6f5d81526b410c Mon Sep 17 00:00:00 2001 From: "Veit F." Date: Sun, 17 May 2026 14:31:48 +0200 Subject: [PATCH] first commit --- .gitignore | 23 + .npmrc | 1 + .opencode/commands/opsx-apply.md | 149 ++ .opencode/commands/opsx-archive.md | 154 ++ .opencode/commands/opsx-bulk-archive.md | 239 +++ .opencode/commands/opsx-continue.md | 111 ++ .opencode/commands/opsx-explore.md | 170 ++ .opencode/commands/opsx-ff.md | 94 ++ .opencode/commands/opsx-new.md | 66 + .opencode/commands/opsx-onboard.md | 547 +++++++ .opencode/commands/opsx-propose.md | 103 ++ .opencode/commands/opsx-sync.md | 131 ++ .opencode/commands/opsx-verify.md | 161 ++ .../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 ++ .opencode/skills/openspec-explore/SKILL.md | 288 ++++ .opencode/skills/openspec-ff-change/SKILL.md | 101 ++ .opencode/skills/openspec-new-change/SKILL.md | 74 + .opencode/skills/openspec-onboard/SKILL.md | 554 +++++++ .opencode/skills/openspec-propose/SKILL.md | 110 ++ .opencode/skills/openspec-sync-specs/SKILL.md | 138 ++ .../skills/openspec-verify-change/SKILL.md | 168 ++ .vscode/extensions.json | 3 + AGENTS.md | 37 + README.md | 30 + opencode.json | 4 + .../init-sveltekit-project/.openspec.yaml | 2 + .../changes/init-sveltekit-project/design.md | 46 + .../init-sveltekit-project/proposal.md | 23 + .../specs/git-repository/spec.md | 36 + .../specs/sveltekit-project/spec.md | 36 + .../changes/init-sveltekit-project/tasks.md | 26 + package-lock.json | 1385 +++++++++++++++++ package.json | 23 + src/app.d.ts | 13 + src/app.html | 12 + src/lib/assets/favicon.svg | 1 + src/lib/index.ts | 1 + src/routes/+layout.svelte | 11 + src/routes/+page.svelte | 2 + static/robots.txt | 3 + svelte.config.js | 17 + tsconfig.json | 20 + vite.config.ts | 6 + 46 files changed, 5753 insertions(+) create mode 100644 .gitignore create mode 100644 .npmrc create mode 100644 .opencode/commands/opsx-apply.md create mode 100644 .opencode/commands/opsx-archive.md create mode 100644 .opencode/commands/opsx-bulk-archive.md create mode 100644 .opencode/commands/opsx-continue.md create mode 100644 .opencode/commands/opsx-explore.md create mode 100644 .opencode/commands/opsx-ff.md create mode 100644 .opencode/commands/opsx-new.md create mode 100644 .opencode/commands/opsx-onboard.md create mode 100644 .opencode/commands/opsx-propose.md create mode 100644 .opencode/commands/opsx-sync.md create mode 100644 .opencode/commands/opsx-verify.md create mode 100644 .opencode/skills/openspec-apply-change/SKILL.md create mode 100644 .opencode/skills/openspec-archive-change/SKILL.md create mode 100644 .opencode/skills/openspec-bulk-archive-change/SKILL.md create mode 100644 .opencode/skills/openspec-continue-change/SKILL.md create mode 100644 .opencode/skills/openspec-explore/SKILL.md create mode 100644 .opencode/skills/openspec-ff-change/SKILL.md create mode 100644 .opencode/skills/openspec-new-change/SKILL.md create mode 100644 .opencode/skills/openspec-onboard/SKILL.md create mode 100644 .opencode/skills/openspec-propose/SKILL.md create mode 100644 .opencode/skills/openspec-sync-specs/SKILL.md create mode 100644 .opencode/skills/openspec-verify-change/SKILL.md create mode 100644 .vscode/extensions.json create mode 100644 AGENTS.md create mode 100644 README.md create mode 100644 opencode.json create mode 100644 openspec/changes/init-sveltekit-project/.openspec.yaml create mode 100644 openspec/changes/init-sveltekit-project/design.md create mode 100644 openspec/changes/init-sveltekit-project/proposal.md create mode 100644 openspec/changes/init-sveltekit-project/specs/git-repository/spec.md create mode 100644 openspec/changes/init-sveltekit-project/specs/sveltekit-project/spec.md create mode 100644 openspec/changes/init-sveltekit-project/tasks.md create mode 100644 package-lock.json create mode 100644 package.json create mode 100644 src/app.d.ts create mode 100644 src/app.html create mode 100644 src/lib/assets/favicon.svg create mode 100644 src/lib/index.ts create mode 100644 src/routes/+layout.svelte create mode 100644 src/routes/+page.svelte create mode 100644 static/robots.txt create mode 100644 svelte.config.js create mode 100644 tsconfig.json create mode 100644 vite.config.ts diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..3b462cb --- /dev/null +++ b/.gitignore @@ -0,0 +1,23 @@ +node_modules + +# Output +.output +.vercel +.netlify +.wrangler +/.svelte-kit +/build + +# OS +.DS_Store +Thumbs.db + +# Env +.env +.env.* +!.env.example +!.env.test + +# Vite +vite.config.js.timestamp-* +vite.config.ts.timestamp-* diff --git a/.npmrc b/.npmrc new file mode 100644 index 0000000..b6f27f1 --- /dev/null +++ b/.npmrc @@ -0,0 +1 @@ +engine-strict=true diff --git a/.opencode/commands/opsx-apply.md b/.opencode/commands/opsx-apply.md new file mode 100644 index 0000000..16d2ef3 --- /dev/null +++ b/.opencode/commands/opsx-apply.md @@ -0,0 +1,149 @@ +--- +description: Implement tasks from an OpenSpec change (Experimental) +--- + +Implement tasks from an OpenSpec change. + +**Input**: Optionally specify a change name (e.g., `/opsx-apply add-auth`). 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: + - `contextFiles`: artifact ID -> array of concrete file paths (varies by schema) + - 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 `/opsx-continue` + - If `state: "all_done"`: congratulate, suggest archive + - Otherwise: proceed to implementation + +4. **Read context files** + + Read every file path listed under `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! You can archive this change with `/opsx-archive`. +``` + +**Output On Pause (Issue Encountered)** + +``` +## Implementation Paused + +**Change:** +**Schema:** +**Progress:** 4/7 tasks complete + +### Issue Encountered + + +**Options:** +1.