Scrum4Me/components/backlog/new-sprint-trigger.tsx
Madhura68 ec3d72577b feat(ST-1369): NewSprintTrigger achter isActiveProduct-gate (G6)
De "Nieuwe sprint"-knop rendert niet langer op een niet-actief product —
een sprint-draft starten daar was verwarrend. page.tsx geeft de bestaande
isActiveProduct-flag door.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-15 01:25:54 +02:00

53 lines
1.4 KiB
TypeScript

'use client'
import { useState } from 'react'
import { Button } from '@/components/ui/button'
import { DemoTooltip } from '@/components/shared/demo-tooltip'
import { useUserSettingsStore } from '@/stores/user-settings/store'
import { NewSprintMetadataDialog } from './new-sprint-metadata-dialog'
interface NewSprintTriggerProps {
productId: string
isDemo: boolean
isActiveProduct: boolean
}
/**
* PBI-79 / ST-1337: trigger-knop voor de nieuwe sprint-flow.
* Verbergt zichzelf wanneer er al een pendingSprintDraft loopt — dan
* staat de SprintDefinitionBanner zelf de afronding te regelen — en
* wanneer het product niet het actieve product is (ST-1369 / G6).
*/
export function NewSprintTrigger({
productId,
isDemo,
isActiveProduct,
}: NewSprintTriggerProps) {
const [open, setOpen] = useState(false)
const hasDraft = useUserSettingsStore(
(s) => !!s.entities.settings.workflow?.pendingSprintDraft?.[productId],
)
if (hasDraft) return null
if (!isActiveProduct) return null
return (
<>
<DemoTooltip show={isDemo}>
<Button
size="sm"
onClick={() => setOpen(true)}
disabled={isDemo}
data-debug-id="new-sprint-trigger"
>
Nieuwe sprint
</Button>
</DemoTooltip>
<NewSprintMetadataDialog
open={open}
productId={productId}
onOpenChange={setOpen}
/>
</>
)
}