storkit: merge 454_story_deduplicate_work_item_display_in_web_ui_story_panel
This commit is contained in:
@@ -17,6 +17,46 @@ import { api } from "../api/client";
|
||||
|
||||
const { useCallback, useEffect, useRef, useState } = React;
|
||||
|
||||
/**
|
||||
* Strip YAML front matter and the first H1 heading from story content before
|
||||
* rendering. The panel header already shows the story ID/title, so rendering
|
||||
* them again inside the markdown body creates duplicate information.
|
||||
*/
|
||||
function stripDisplayContent(content: string): string {
|
||||
let text = content;
|
||||
// Strip YAML front matter (--- ... ---)
|
||||
if (text.startsWith("---")) {
|
||||
const eol = text.indexOf("\n");
|
||||
if (eol !== -1) {
|
||||
const closeIdx = text.indexOf("\n---", eol);
|
||||
if (closeIdx !== -1) {
|
||||
text = text.slice(closeIdx + 4);
|
||||
}
|
||||
}
|
||||
}
|
||||
// Trim leading blank lines left by the front matter
|
||||
text = text.trimStart();
|
||||
// Strip the first H1 heading — it duplicates the panel header title
|
||||
if (text.startsWith("# ")) {
|
||||
const eol = text.indexOf("\n");
|
||||
text = eol !== -1 ? text.slice(eol + 1).trimStart() : "";
|
||||
}
|
||||
return text;
|
||||
}
|
||||
|
||||
/**
|
||||
* Format the story ID/title line shown in the panel header.
|
||||
* Produces e.g. "Story 454: My Story Name" or "Bug 12: Crash on startup".
|
||||
* Falls back to name or storyId when the pattern doesn't match.
|
||||
*/
|
||||
function formatStoryTitle(storyId: string, name: string | null): string {
|
||||
const match = storyId.match(/^(\d+)_([a-z]+)_/);
|
||||
if (!match || !name) return name ?? storyId;
|
||||
const [, number, type] = match;
|
||||
const typeLabel = type.charAt(0).toUpperCase() + type.slice(1);
|
||||
return `${typeLabel} ${number}: ${name}`;
|
||||
}
|
||||
|
||||
const STAGE_LABELS: Record<string, string> = {
|
||||
backlog: "Backlog",
|
||||
current: "Current",
|
||||
@@ -352,7 +392,7 @@ export function WorkItemDetailPanel({
|
||||
whiteSpace: "nowrap",
|
||||
}}
|
||||
>
|
||||
{name ?? storyId}
|
||||
{formatStoryTitle(storyId, name)}
|
||||
</div>
|
||||
{stage && (
|
||||
<div
|
||||
@@ -504,7 +544,7 @@ export function WorkItemDetailPanel({
|
||||
),
|
||||
}}
|
||||
>
|
||||
{content}
|
||||
{stripDisplayContent(content)}
|
||||
</Markdown>
|
||||
</div>
|
||||
)}
|
||||
|
||||
Reference in New Issue
Block a user