Verfahrensablauf side semantics: WE always on left (Client Side / Court / Opponent Side) — drop Proaktiv/Reaktiv framing #88
Open
opened 2026-05-25 12:24:07 +00:00 by mAi
·
1 comment
No Branch/Tag Specified
main
mai/planck/coder-b5-b6-train-share
mai/archimedes/fixer-port-engine
mai/maxwell/coder-b4-akte-mode
mai/lorenz/coder-b3-event-triggered
mai/euler/fixer-builder-add
mai/brunel/fixer-prod-500s-after-b1
mai/galileo/coder-b1-b2-mvp-train
mai/pasteur/fixer-pkg-litigationplann
mai/newton/coder-b0-scenario-db
mai/edison/inventor-prd-columnar
mai/knuth/coder-workflow-tracker
mai/atlas/inventor-extend-tools
mai/cronus/inventor-unified
mai/atlas/inventor-deadline-system
mai/atlas/inventor-followup-rules
mai/athena/consultant-deadline
mai/brunel/fixer-dark-mode-support
mai/knuth/coder-cronus-fristenrechn
mai/ritchie/coder-mig-153-proceeding
mai/atlas/inventor-proceeding
mai/cronus/inventor-fristenrechner
mai/curie/coder-mig152-clone-dedupe
mai/darwin/researcher-lexy-draft
mai/knuth/coder-dedupe-null
mai/cronus/coder-composer-slice-f
mai/cronus/coder-composer-slice-e
mai/cronus/coder-composer-slice-d
mai/curie/coder-slice-b6-url-rename
mai/curie/coder-slice-b5-go-rename
mai/cronus/coder-composer-slice-c
mai/curie/coder-slice-b4-destructive-drop
mai/cronus/coder-composer-slice-b
mai/cronus/coder-composer-slice-a
mai/cronus/inventor-prd-for
mai/knuth/coder-verfahrensablauf
mai/ritchie/coder-make-backup
mai/diesel/fixer-dark-mode-css
mai/curie/coder-slice-b3-read-cutover
mai/diesel/fixer-verfahrensablauf
mai/curie/coder-slice-b2-dual-write
mai/cronus/coder-slice-d-scenarios
mai/knuth/coder-backfill-applies
mai/hermes/gitster-verfahrensablauf
mai/cronus/coder-berufung-labels-refactor
mai/diesel/hotfix-2-mig-134-missing
mai/curie/coder-slice-b1-procedural-events
mai/cronus/coder-slice-c-upc-snapshot
mai/brunel/hotfix-rename-upc-apl
mai/cronus/coder-slice-b3-primary-party
mai/cronus/coder-slice-b2-catalog-query
mai/cronus/inventor-litigation-slice-b
mai/curie/researcher-slice-b-zero
mai/cronus/inventor-litigation
mai/artemis/gitster-remove-admin
mai/ritchie/coder-sort-post-trigger
mai/knuth/coder-conditional-label
mai/hermes/coder-verfahrensablauf
mai/brunel/rebase-121-conditional
mai/knuth/coder-conditional-rule
mai/hermes/gitster-dark-mode-fix
mai/ritchie/coder-submission-form
mai/artemis/gitster-re-surface
mai/brunel/fixer-views-any-filters
mai/cronus/coder-cicd-slice-a
mai/knuth/coder-wave-1-tier-1-rule
mai/ritchie/coder-upc-damages-add
mai/cronus/inventor-ci-cd-pre
mai/brunel/rebase-108-language
mai/hermes/gitster-admin-rules-list
mai/artemis/gitster-submission
mai/icarus/gitster-verfahrensablauf
mai/orpheus/gitster-search-input
mai/atlas/coder-event-card-choices-slice-ab
mai/hermes/gitster-date-range
mai/demeter/gitster-submission
mai/knuth/coder-hl-patents-style
mai/hermes/gitster-draft-editor
mai/atlas/inventor-per-event-card
mai/knuth/coder-deadline-rule-tier
mai/cronus/coder-procedural-events-slice-a
mai/hermes/gitster-deadline-form
mai/artemis/gitster-add-missing-i18n
mai/demeter/gitster-paliadin-chat
mai/brunel/wave0-tier0-deadline-fixes
mai/artemis/coder-docker-compose-yml
mai/icarus/coder-inbox-overhaul-slice-a
mai/atlas/coder-date-range-picker-slice-a
mai/brunel/fixer-de-inf-lg-cfi
mai/cronus/inventor-procedural
mai/hermes/gitster-event-type-modal
mai/cronus/coder-backup-mode
mai/curie/researcher-bulletproof
mai/hermes/gitster-draft-editor-focus-jump
mai/cronus/inventor-backup-mode
mai/hermes/gitster-submissions
mai/artemis/gitster-deadline-form
mai/brunel/fixer-submission-preview
mai/brunel/fixer-test-data-reset
mai/artemis/gitster-approval-withdraw
mai/demeter/gitster-events
mai/hermes/gitster-sidebar-loses
mai/hermes/gitster-browse-a
mai/brunel/fixer-submissions-demo
mai/icarus/inventor-inbox-overhaul
mai/atlas/inventor-symmetric-date
mai/artemis/gitster-demote-daten
mai/hermes/gitster-team-view-mailto
mai/knuth/coder-global-schriftsatze
mai/knuth/coder-schriftsatze
mai/ritchie/coder-author-demo-docx
mai/knuth/coder-add-schriftsatze
mai/knuth/coder-add-checklist
mai/knuth/coder-anchor-lookup-must
mai/tesla/dashboard-resize-clamp
mai/knuth/coder-demote-projekt
mai/knuth/coder-paliadin-chat
mai/knuth/coder-print-views
mai/knuth/coder-add-proceeding
mai/knuth/coder-submission
mai/ritchie/coder-extend-team-email
mai/knuth/coder-changelog-catch-up
mai/tesla/dashboard-overlap
mai/pasteur/fixercoder-dashboard
mai/newton/inventor-configurable
mai/dirac/inventorcoder-user
mai/gauss/inventorcoder-team-admin
mai/kepler/inventorcoder-project
mai/darwin/roadmap-ccr-en
mai/euler/coder-small-ux-polish
mai/darwin/fristenrechner-cleanup
mai/darwin/fixercoder-priority-bug
mai/leibniz/inventor-caldav-multi
mai/hertz/inventor-unified-modal
mai/archimedes/inventor-excel-data
mai/boltzmann/inventor-gap-tolerant
mai/copernicus/submission-slice-1
mai/fermi/interactive-session
mai/hertz/inventor-suggest-changes
mai/copernicus/inventor-submission
mai/mendel/test-strategy-slice-1
mai/mendel/inventor-test-strategy
mai/ampere/custom-views-improvements
mai/joule/mig-097-apply-huygens-s
mai/ohm/workstream-b-rename
mai/huygens/workstream-a-backfill
mai/kelvin/t-204-phase-2-proceeding
mai/bohr/ingest-t-paliad-203-rule
mai/curie/fristenrechner-gap
mai/maxwell/inbox-grey-out
mai/rutherford/slice-9-follow-up-b-re
mai/dirac/slice-9-follow-up-a
mai/bose/determinator-cascade-slice-3
mai/bose/determinator-cascade-slice-2
mai/bose/determinator-row-cascade
mai/lorenz/fristen-phase-3-slice-9
mai/curie/fristen-phase-3-slice-12
mai/planck/aichat-phase-b-paliad
mai/young/fristen-phase-3-slice-11b
mai/lorenz/fristen-phase-3-slice-11a
mai/lorenz/fristen-phase-3-slice-10
mai/lorenz/fristen-phase-3-slice-8
mai/lorenz/fristen-phase-3-slice-7
mai/lorenz/fristen-phase-3-slice-6
mai/lorenz/fristen-phase-3-slice-5
mai/lorenz/fristen-phase-3-slice-4
mai/lorenz/fristen-phase-3-slice-3
mai/lorenz/fristen-phase-3-slice-2
mai/lorenz/fristen-phase-3-slice-1
mai/pauli/fristen-phase2-design
mai/tesla/project-timeline-chart
mai/pauli/fristen-logic-audit
mai/pauli/determinator-b1-row-by
mai/noether/tools-cleanup-slice-1
mai/kelvin/inventor-tools-surface
mai/planck/paliadin-per-user-rls
mai/maxwell/bug-bundle-filterbar
mai/faraday/project-timeline-chart
mai/schroedinger/smarttimeline-slice-4
mai/bohr/smarttimeline-slice-3
mai/gauss/smarttimeline-slice-2
mai/riemann/filterbar-phase-2-slice
mai/lagrange/smarttimeline-design-the
mai/curie/researcher-determinator
mai/noether/collapse-regel-typ-on
mai/riemann/inventor-universal
mai/minkowski/project-level-our-side
mai/dirac/inventor-inline-paliadin
mai/feynman/fristenrechner
mai/minkowski/navbar-dashboard-reorg
mai/shannon/approval-rework
mai/einstein/consultant-deadline-data
mai/curie/researcher-upc-rop-audit
mai/noether/paliadin-real-claude
mai/noether/inventor-paliadin
mai/hilbert/inventor-approval-policy
mai/shannon/bug-frist-due-date
mai/fritz/bug-fristen-termine
mai/godel/inventor-projects-page
mai/fritz/bug-paliadin-chat
mai/kepler/inventor-profession-vs
mai/noether/inventor-paliadin-in-app
mai/fritz/bulk-team-email-send-to
mai/noether/inventor-local-chat-for
mai/noether/inventor-data-display
mai/fritz/bug-derived-team-members
mai/fritz/bug-sidebar-visibly
mai/noether/inventor-project
mai/shannon/bug-project-team-add
mai/cronus/inventor-dual-control
mai/fritz/bug-edit-mode-on
mai/cronus/inventor-holidays-per
mai/ritchie/phase-h-ai-deadline
No results found.
No Label
Milestone
No items
No Milestone
Projects
Clear projects
No project
Notifications
Due Date
No due date set.
Dependencies
No dependencies set.
Reference: m/paliad#88
Reference in New Issue
Block a user
Blocking a user prevents them from interacting with repositories, such as opening or commenting on pull requests or issues. Learn more about blocking a user.
No description provided.
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
m's report (2026-05-25 14:22)
Context — what shipped
t-paliad-250 / m/paliad#81 (commit
02255c4on main) added side+appellant selectors to Verfahrensablauf and kept the existing Proaktiv / Court / Reaktiv column labels. m's report says the Proaktiv/Reaktiv axis is the wrong frame entirely — Klägerseite is sometimes proactive (filing) and sometimes reactive (responding), so the static label-pair lies.What m wants instead — user-perspective axis
Client Side/COURT/Opponent Side(DE primary:Unsere Seite/Gericht/Gegnerseite).sidefrom the project'sour_sidefield (already onpaliad.projects, per t-paliad-217 ish). Read-only display with override toggle.What to do
Part 1 — Column relabel + semantics flip
frontend/src/client/views/verfahrensablauf-core.ts(and the renderColumnsBody hermes touched in t-paliad-250) — rename column headers fromProaktiv/ReaktivtoUnsere Seite/Gegnerseite(EN:Client Side/Opponent Side).our_sidevalue.Part 2 — Appellant selector stays
Keep the appellant selector hermes added for appeal-type proceedings. Its role: when an Appeal is selected and the project doesn't pin which party appealed, the user picks. Without this pick, "both parties" appeal-rules still need to render somewhere — fall back to showing in BOTH columns until pinned.
Part 3 — Project default
paliad.projects.our_side(if it exists) drives the initial side selection. If the project has a proceeding chosen +our_sideset, the selectors are auto-filled and shown read-only with a small "override" affordance.If the
our_sidecolumn does NOT exist yet (verify), this issue's scope expands to add it as a migration. Flag in completion report. Likely DB shape:paliad.projects.our_side text CHECK (our_side IN ('claimant','defendant','patentee','opponent', etc.)).Part 4 — i18n
Rename existing keys (or add new keys + deprecate old):
proaktiv→our_side("Unsere Seite" / "Client Side")reaktiv→opponent_side("Gegnerseite" / "Opponent Side")Files most likely touched
frontend/src/client/views/verfahrensablauf-core.ts(column placement logic + headers)frontend/src/client/views/verfahrensablauf-core.test.ts(update test expectations)frontend/src/client/verfahrensablauf.ts(selector wiring)frontend/src/verfahrensablauf.tsxfrontend/src/client/i18n.ts+frontend/src/i18n-keys.tsinternal/models/models.go+ a migration forpaliad.projects.our_sideif it doesn't existinternal/services/projection_service.goif the column placement is computed server-sideHard rules
go build ./... && go test ./internal/... && cd frontend && bun run buildclean.mai/<worker>/side-semantics-our-perspective.Out of scope
Reporting
mai report completedwith branch + SHAs + UX path: open any case project withour_sideset → see Unsere Seite + Gegnerseite columns with all rules placed correctly → flip side toggle → columns swap, every rule re-resolves to the right column → confirm UPC Appeal still respects the separate appellant selector.Verfahrensablauf side semantics — done
Branch:
mai/hermes/gitster-verfahrensablauf→ a9a9adbWhat changed
The
Proaktiv | Gericht | Reaktivtriplet is gone. Columns are nowUnsere Seite | Gericht | Gegnerseite(EN:Client Side | Court | Opponent Side). The side toggle drives row PLACEMENT into theours/opponentbuckets — labels stay truthful regardless of which physical party (claimant vs defendant) occupies them.Old framing lied half the time: Klägerseite is sometimes proactive (filing a claim), sometimes reactive (responding to a CCR). The new framing is purely positional with semantic labels.
Files touched
frontend/src/client/views/verfahrensablauf-core.tsColumnsRow.proactive/reactive→ours/opponentrenderColumnsBodypicks staticdeadlines.col.ours/deadlines.col.opponentlabels — no more variant-by-side keysbucketDeadlinesIntoColumns: routes user's party intoourswhenopts.side === "defendant". Default (side === null) keeps the legacy "we are claimant" fallback so the claimant-on-left default survivesfrontend/src/client/views/verfahrensablauf-core.test.ts— rewritten expectations on new fields. Added two new tests pinning the WE-on-left semantics and the side+appellant interaction (side=defendant + appellant=claimant→"both"collapses into opponent column)frontend/src/client/fristenrechner.ts— wirescurrentPerspectiveintorenderColumnsBodyasside. Without this, a defendant-perspective user would see claimant filings under theUnsere Seiteheader. The old code didn't need the wire-up because the labels weren't perspective-awarefrontend/src/client/i18n.ts— DE:Unsere Seite/Gegnerseite. EN:Client Side/Opponent Side. Drops the now-redundant*.proactive.defendant/*.reactive.claimantvariant keysfrontend/src/i18n-keys.ts— regenerated unionfrontend/src/styles/global.css—.fr-col-proactive/.fr-col-reactive→.fr-col-ours/.fr-col-opponentHard-rule checks
?side=+?appellant=continue to drive perspective + appellant axis. Only the labels and field names changed; the URL contract is identical to t-paliad-250bun testpasses 112/112 (was 110, +2 new tests for WE-on-left + side×appellant interaction)Unsere Seite/Gegnerseitein DE,Client Side/Opponent Sidein ENbun run build(2794 i18n keys, no scan warnings) +go build ./...+go test ./internal/...all greenour_sidecolumn already exists onpaliad.projects(verified viainformation_schema.columns) — no migration needed for Part 3Part 3 (project default) — out of scope as written, no work needed
The issue's "derive
sidefrom project'sour_sidefield" applies to surfaces with project context./tools/verfahrensablaufis the abstract-browse tool — it has no project picker, so there's nothing to predefine. The fristenrechner side (/tools/fristenrechner) already does this viaapplyOurSidePredefine()→ourSideToPerspective()(t-paliad-164/180), and that wire is now coherent with the new column labels via theside: currentPerspectivepass-through I added.If m wants
/tools/verfahrensablaufto accept a project context in the URL (e.g.?project=<uuid>and predefine side from there), that's a separate feature — flag it and I'll file a follow-up.Appellant axis
Kept as-is. The appellant selector still pins which party initiated an Appeal/Counterclaim, and it's still independent of the side toggle:
side=defendant, appellant=defendant→ "both" rows collapse intoours(we appealed)side=defendant, appellant=claimant→ "both" rows collapse intoopponent(they appealed)appellant=null→ "both" rows mirror into both columns (legacy behaviour)The new test
side=defendant + appellant=claimant routes 'both' into opponentpins exactly this scenario.UX path to verify
/tools/verfahrensablauf→ pickUPC VerletzungsverfahrenUnsere Seite | Gericht | Gegnerseite. Default side is unset (Beide) → claimant filings on the left, defendant on the rightBeklagtenseite→ columns swap: defendant filings now on the left underUnsere Seite, claimant filings on the right underGegnerseite. Court column unchangedUPC Berufung(appellant-axis proceeding). Appellant row appears. SetBerufung durch: Klägerseitewhileside=Beklagtenseite→ allbothrows collapse into the right column (opponent appealed)Berufung durchtoBeklagtenseite(we appealed) →bothrows collapse into the left column (Unsere Seite)Out of scope (untouched)
party_rolesemantics in the DB — re-projected, not re-tagged—for consistency with the appellant row, that's a one-line tweak — flag it and I'll do a follow-up