Files
fn_registry/frontend/functions/ui/page_header.md
T
egutierrez 5f4f1f7508 docs: params/output semántico en 506 funciones para composabilidad
Añade campos params y output al frontmatter YAML de las 506 funciones del registry.
Cada parámetro tiene descripción semántica (qué representa, unidades, rango típico)
y cada función describe qué produce su output. Permite a agentes razonar sobre
cadenas de composición (ej: prices → log_return → sharpe_ratio) sin leer código.
2026-04-05 18:45:16 +02:00

64 lines
1.7 KiB
Markdown

---
name: page_header
kind: component
lang: ts
domain: ui
version: "1.0.0"
purity: impure
signature: "PageHeader(props: PageHeaderProps): JSX.Element"
description: "Cabecera de página con título, subtítulo, acciones, back button, tabs integrados, badge y modo sticky. Incluye SimplePageHeader."
tags: [header, page, layout, navigation, component, ui]
uses_functions: [cn_ts_core]
uses_types: []
returns: []
returns_optional: false
error_type: ""
imports: [react]
output: "Componente PageHeader que renderiza cabecera de página con título, acciones, tabs integrados y modo sticky"
tested: false
tests: []
test_file_path: ""
file_path: "frontend/functions/ui/page_header.tsx"
props:
- name: title
type: "string"
required: true
description: "Título principal"
- name: subtitle
type: "string"
required: false
description: "Subtítulo"
- name: actions
type: "ReactNode"
required: false
description: "Botones de acción"
- name: tabs
type: "TabItem[]"
required: false
description: "Tabs de navegación integrados"
- name: sticky
type: "boolean"
required: false
description: "Header fijo al scroll"
emits: [onBack, onTabChange]
has_state: false
framework: react
variant: [full, simple]
source_repo: "https://gitea-dgg044oo04woo4ggcsws4gk0.organic-machine.com/Bl4cksmith/Frontend_Library"
source_license: "MIT"
source_file: "frontend/src/components/ui/page-header.tsx"
---
## Ejemplo
```tsx
<PageHeader
title="Dashboard"
subtitle="Vista general"
actions={<Button>Export</Button>}
tabs={[{ label: "Overview", value: "overview" }, { label: "Analytics", value: "analytics" }]}
activeTab="overview"
onTabChange={setTab}
/>
```