From cc59a91fea88f6a12510a5ff5af3f669a6410450 Mon Sep 17 00:00:00 2001 From: Filip Date: Fri, 27 Mar 2026 12:18:36 +0100 Subject: [PATCH] feat: init --- .gemini/commands/opsx/apply.toml | 149 + .gemini/commands/opsx/archive.toml | 154 + .gemini/commands/opsx/explore.toml | 170 + .gemini/commands/opsx/propose.toml | 103 + .gemini/skills/openspec-apply-change/SKILL.md | 156 + .../skills/openspec-archive-change/SKILL.md | 114 + .gemini/skills/openspec-explore/SKILL.md | 288 + .gemini/skills/openspec-propose/SKILL.md | 110 + .gitignore | 15 + backend/Dockerfile | 20 + backend/docker.js | 114 + backend/index.js | 49 + backend/package-lock.json | 1569 ++ backend/package.json | 19 + docker-compose.yml | 15 + frontend/.gitignore | 23 + frontend/Dockerfile | 35 + frontend/README.md | 70 + frontend/package-lock.json | 17790 ++++++++++++++++ frontend/package.json | 41 + frontend/public/favicon.ico | Bin 0 -> 3870 bytes frontend/public/index.html | 43 + frontend/public/logo192.png | Bin 0 -> 5347 bytes frontend/public/logo512.png | Bin 0 -> 9664 bytes frontend/public/manifest.json | 25 + frontend/public/robots.txt | 3 + frontend/src/App.css | 51 + frontend/src/App.js | 49 + frontend/src/App.test.js | 8 + frontend/src/api.js | 8 + frontend/src/components/ServiceCard.css | 46 + frontend/src/components/ServiceCard.js | 52 + frontend/src/index.css | 13 + frontend/src/index.js | 17 + frontend/src/logo.svg | 1 + frontend/src/reportWebVitals.js | 13 + frontend/src/setupTests.js | 5 + .../create-gitignore-file/.openspec.yaml | 2 + .../changes/create-gitignore-file/design.md | 35 + .../changes/create-gitignore-file/proposal.md | 21 + .../specs/git-ignore-management/spec.md | 39 + .../changes/create-gitignore-file/tasks.md | 19 + .../docker-service-display/.openspec.yaml | 2 + .../changes/docker-service-display/design.md | 30 + .../docker-service-display/proposal.md | 25 + .../specs/docker-service-discovery/spec.md | 26 + .../specs/service-display-frontend/spec.md | 26 + .../changes/docker-service-display/tasks.md | 34 + .../modernize-frontend-ui/.openspec.yaml | 2 + .../changes/modernize-frontend-ui/design.md | 48 + .../changes/modernize-frontend-ui/proposal.md | 27 + .../specs/docker-service-discovery/spec.md | 26 + .../specs/service-display-frontend/spec.md | 29 + .../changes/modernize-frontend-ui/tasks.md | 19 + openspec/config.yaml | 20 + 55 files changed, 21768 insertions(+) create mode 100644 .gemini/commands/opsx/apply.toml create mode 100644 .gemini/commands/opsx/archive.toml create mode 100644 .gemini/commands/opsx/explore.toml create mode 100644 .gemini/commands/opsx/propose.toml create mode 100644 .gemini/skills/openspec-apply-change/SKILL.md create mode 100644 .gemini/skills/openspec-archive-change/SKILL.md create mode 100644 .gemini/skills/openspec-explore/SKILL.md create mode 100644 .gemini/skills/openspec-propose/SKILL.md create mode 100644 .gitignore create mode 100644 backend/Dockerfile create mode 100644 backend/docker.js create mode 100644 backend/index.js create mode 100644 backend/package-lock.json create mode 100644 backend/package.json create mode 100644 docker-compose.yml create mode 100644 frontend/.gitignore create mode 100644 frontend/Dockerfile create mode 100644 frontend/README.md create mode 100644 frontend/package-lock.json create mode 100644 frontend/package.json create mode 100644 frontend/public/favicon.ico create mode 100644 frontend/public/index.html create mode 100644 frontend/public/logo192.png create mode 100644 frontend/public/logo512.png create mode 100644 frontend/public/manifest.json create mode 100644 frontend/public/robots.txt create mode 100644 frontend/src/App.css create mode 100644 frontend/src/App.js create mode 100644 frontend/src/App.test.js create mode 100644 frontend/src/api.js create mode 100644 frontend/src/components/ServiceCard.css create mode 100644 frontend/src/components/ServiceCard.js create mode 100644 frontend/src/index.css create mode 100644 frontend/src/index.js create mode 100644 frontend/src/logo.svg create mode 100644 frontend/src/reportWebVitals.js create mode 100644 frontend/src/setupTests.js create mode 100644 openspec/changes/create-gitignore-file/.openspec.yaml create mode 100644 openspec/changes/create-gitignore-file/design.md create mode 100644 openspec/changes/create-gitignore-file/proposal.md create mode 100644 openspec/changes/create-gitignore-file/specs/git-ignore-management/spec.md create mode 100644 openspec/changes/create-gitignore-file/tasks.md create mode 100644 openspec/changes/docker-service-display/.openspec.yaml create mode 100644 openspec/changes/docker-service-display/design.md create mode 100644 openspec/changes/docker-service-display/proposal.md create mode 100644 openspec/changes/docker-service-display/specs/docker-service-discovery/spec.md create mode 100644 openspec/changes/docker-service-display/specs/service-display-frontend/spec.md create mode 100644 openspec/changes/docker-service-display/tasks.md create mode 100644 openspec/changes/modernize-frontend-ui/.openspec.yaml create mode 100644 openspec/changes/modernize-frontend-ui/design.md create mode 100644 openspec/changes/modernize-frontend-ui/proposal.md create mode 100644 openspec/changes/modernize-frontend-ui/specs/docker-service-discovery/spec.md create mode 100644 openspec/changes/modernize-frontend-ui/specs/service-display-frontend/spec.md create mode 100644 openspec/changes/modernize-frontend-ui/tasks.md create mode 100644 openspec/config.yaml diff --git a/.gemini/commands/opsx/apply.toml b/.gemini/commands/opsx/apply.toml new file mode 100644 index 0000000..88a0dfe --- /dev/null +++ b/.gemini/commands/opsx/apply.toml @@ -0,0 +1,149 @@ +description = "Implement tasks from an OpenSpec change (Experimental)" + +prompt = """ +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: + - Context 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 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! 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.