0a0fe8c997
From: sources/frontend_designs/Ads Analytics Dashboard _standalone_.html New components: - funnel_chart_ts_ui — visualización de funnel de conversión con barras degradadas y tasa entre etapas como Badge semántico. - heatmap_grid_ts_ui — matriz rows × cols con intensidad color-mix sobre el primary color. Genérica (day×hour, cohort, correlation...). Improvements: - alert_ts_ui v1.1.0 — añadidas variantes semánticas success, warning, info (antes: solo default y destructive). - data_table_ts_ui v1.1.0 — prop opcional density: compact | cozy | roomy. No rompe API existente (default 'cozy' = comportamiento previo). Barrel frontend/functions/ui/index.ts actualizado con los dos nuevos exports y el type DataTableDensity. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
3.2 KiB
3.2 KiB
name, kind, lang, domain, version, purity, signature, description, tags, uses_functions, uses_types, returns, returns_optional, error_type, imports, output, tested, tests, test_file_path, file_path, props, emits, has_state, framework, variant
| name | kind | lang | domain | version | purity | signature | description | tags | uses_functions | uses_types | returns | returns_optional | error_type | imports | output | tested | tests | test_file_path | file_path | props | emits | has_state | framework | variant | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| data_table | component | ts | ui | 1.1.0 | impure | DataTable(props: DataTableProps): JSX.Element | Tabla de datos con sticky header, overflow scroll, heatmap por columna, formato condicional (number/datetime/currency), hover rows y densidad configurable (compact/cozy/roomy). Auto-detecta columnas desde la primera fila si no se proveen. |
|
false |
|
Componente DataTable que renderiza tabla con sticky header, heatmap condicional y formato automático de datos | false | frontend/functions/ui/data_table.tsx |
|
false | react |
|
Ejemplo
// Tabla simple con auto-detección de columnas
<DataTable data={rows} />
// Con columnas definidas y heatmap
<DataTable
data={metrics}
columns={[
{ key: 'domain', label: 'Domain' },
{ key: 'count', label: 'Functions', format: ',' },
{ key: 'pure_pct', label: 'Pure %', format: '.1f' },
]}
heatmapColumns={['count', 'pure_pct']}
/>
// Con formato moneda y fecha
<DataTable
data={transactions}
columns={[
{ key: 'date', label: 'Date', format: 'datetime' },
{ key: 'amount', label: 'Amount', format: '$,.2f', align: 'right' },
{ key: 'description', label: 'Description' },
]}
/>
Formatos soportados (campo format en ColumnDef)
| format | Ejemplo input | Output |
|---|---|---|
',' |
1234567 |
1,234,567 |
',.2f' |
1234.5 |
1,234.50 |
'$,.2f' |
1234.5 |
$1,234.50 |
'.0f' |
42.7 |
43 |
'datetime' |
'2026-04-01T12:00:00Z' |
4/1/2026, 12:00:00 PM |
Notas
Extraido y generalizado desde apps/rapid_dashboards/frontend/src/components/widgets/TableWidget.tsx. El heatmap usa useMemo para calcular min/max por columna solo cuando cambian data o heatmapColumns. La alineación de celdas numéricas es automática (derecha) cuando el valor es typeof 'number'; se puede sobreescribir con el campo align en ColumnDef.