'use client'
import { ControlDetail } from '../control-library/components/ControlDetail'
import { ControlListView } from '../control-library/components/ControlListView'
import { useControlLibraryState } from '../control-library/components/useControlLibraryState'
import { BACKEND_URL } from '../control-library/components/helpers'
/**
* Master Controls page — reuses the Control Library UI exactly,
* but shows Master Controls (13.5K grouped controls) instead of
* individual atomic controls (272K).
*
* The MC API route (/api/sdk/v1/master-controls) returns data in
* the same format as the canonical controls endpoint.
*/
export default function MasterControlsPage() {
// Reuse the exact same state hook — it fetches from BACKEND_URL
// We override BACKEND_URL via a wrapper, but for now we reuse as-is
// since both endpoints speak the same format.
const state = useControlLibraryState('/api/sdk/v1/master-controls')
if (state.loading && state.controls.length === 0) {
return (
)
}
if (state.error) {
return (
)
}
// DETAIL mode — add fallback fields that ControlDetail expects
if (state.mode === 'detail' && state.selectedControl) {
const safeCtrl = {
...state.selectedControl,
scope: state.selectedControl.scope || { platforms: [], components: [], data_classes: [] },
target_audience: state.selectedControl.target_audience || [],
requirements: state.selectedControl.requirements || [],
test_procedure: state.selectedControl.test_procedure || [],
evidence: state.selectedControl.evidence || [],
open_anchors: state.selectedControl.open_anchors || [],
risk_score: state.selectedControl.risk_score || null,
implementation_effort: state.selectedControl.implementation_effort || null,
}
return (
{ state.setMode('list'); state.setSelectedControl(null) }}
onEdit={() => {}}
onDelete={async () => {}}
onReview={async () => {}}
onRefresh={state.fullReload}
onCompare={() => {}}
onNavigateToControl={async (controlId: string) => {
try {
const res = await fetch(`${BACKEND_URL}?endpoint=control&id=${controlId}`)
if (res.ok) { state.setSelectedControl(await res.json()); state.setMode('detail') }
} catch { /* ignore */ }
}}
/>
)
}
// LIST mode — exact same UI as Control Library
return (
{}}
setCurrentPage={state.setCurrentPage}
onSelectControl={(ctrl) => { state.setSelectedControl(ctrl); state.setMode('detail') }}
onCreateMode={() => {}}
onEnterReview={() => {}}
onBulkReject={async () => {}}
onRefresh={() => { state.loadControls(); state.loadMeta() }}
onLoadStats={state.loadProcessedStats}
onFullReload={state.fullReload}
/>
)
}