with one click
object-panel
// Work on Luxury Yacht object-panel details, YAML, actions, logs, shell/debug tabs, docked panels, related objects, and tests
// Work on Luxury Yacht object-panel details, YAML, actions, logs, shell/debug tabs, docked panels, related objects, and tests
Add support for a Kubernetes resource type by choosing the required catalog, refresh, detail, object-map, permission, frontend, docs, and test surfaces
Work on Luxury Yacht RBAC permission checks, capability descriptors, permission-denied diagnostics, object action availability, YAML/edit/delete/scale/restart gating, and capability tests
Work on Luxury Yacht canonical Kubernetes resource identity, status presentation, facts, ResourceLink relationships, DTO projection, table/detail/object-map parity, and shared resource model tests
Guide for safely modifying the refresh/streaming subsystem — covers the full domain lifecycle, registration points, and known fragility areas
Work on Luxury Yacht kubeconfig selection, multi-cluster client lifecycle, auth failure/recovery, selected/background clusters, cluster tabs, refresh subsystem rebuilds, and object catalog lifecycle
Work on logs, shell exec, debug containers, port-forward, node drain/maintenance, long-running operations, permissions, lifecycle, and cleanup tests
| name | object-panel |
| description | Work on Luxury Yacht object-panel details, YAML, actions, logs, shell/debug tabs, docked panels, related objects, and tests |
Use this when touching object detail panels, overview/detail tabs, YAML read/apply/edit flows, related objects, logs, shell/debug tabs, Helm content, object actions, panel docking, or object-panel tests.
Read:
AGENTS.mdbackend/AGENTS.md for backend detail/action changesfrontend/AGENTS.md for frontend panel changesdocs/frontend/dockable-panels.mddocs/frontend/yaml-editor.md for YAML editor surfacesdocs/architecture/shared-resource-model.md for identity, status, links,
facts, or lifecycledocs/architecture/data-access.md for frontend readsdocs/workflows/logs/overview.md,
docs/workflows/shell-debug.md, or docs/workflows/object-map.mdbackend/object_detail_provider.gobackend/resourcesbackend/resources/typesbackend/object_yaml*.gobackend/resources/pods/logs.gobackend/resources/nodes/logs.gobackend/resources/pods/debug.gobackend/shell_sessions.goBackend object-panel work must keep requests cluster-scoped and use complete
GVK/object identity. Rich detail and imperative operations belong in
backend/resources; list/table snapshot payloads belong in
backend/refresh/snapshot.
When adding a typed detail fetcher in backend/object_detail_provider.go, also
add exact-GVK capability metadata in objectDetailFetcherGVKs. That map
declares which concrete built-in GVK the typed fetcher can serve; it is not a
resource identity source and must not be used as a catalog replacement.
frontend/src/modules/object-panelfrontend/src/modules/object-panel/components/ObjectPanelfrontend/src/modules/object-panel/components/ObjectPanel/Logsfrontend/src/modules/object-panel/components/ObjectPanel/NodeLogsfrontend/src/modules/object-panel/hooksfrontend/src/shared/components/yaml for shared YAML editor mechanicsfrontend/src/ui/dockablefrontend/src/shared/components/modalsfrontend/wailsjs/go/models.ts when Go DTOs changeFrontend object-panel work must use backend-provided statusPresentation and
ResourceLink.ref where available. Do not reconstruct object identity from kind
and name when a full backend reference should be carried.
Log viewer presentation shared by container logs and node logs lives under
frontend/src/modules/object-panel/components/ObjectPanel/Logs. Keep
transport-specific wiring in the container or node shell, and put shared search,
CSV export, parsed JSON, ANSI rendering, scroll restoration, and terminal theme
behavior in the shared log viewer utilities/components.
YAML editor mechanics live in frontend/src/shared/components/yaml/YamlEditor.
Use that shared component for single-document YAML viewing/editing instead of
adding new CodeMirror/search/context-menu stacks inside object-panel tabs. Keep
workflow state such as refresh, object identity, permissions, save/cancel,
reload/merge, drift, managedFields policy, and post-save notices in the
object-panel wrapper.
clusterId, group, version, kind, and
namespace/name for concrete objects.YamlEditor for editor mechanics and keep workflow
state in the caller.mage qc:prerelease.Use focused checks while iterating:
go test ./backend ./backend/resources/...
npm run typecheck --prefix frontend
npm run test --prefix frontend -- object-panel
Then run mage qc:prerelease for non-documentation changes.