Files
fn_registry/cpp/functions/core/button.md
T
egutierrez da6a8b5e59 feat(cpp/core): primitivas UI estilo Mantine
Anade 9 primitivas reutilizables al registry C++ que replican el comportamiento
de los componentes correspondientes de @fn_library / Mantine v9, todas
estilizadas con tokens_cpp_core (colores Mantine dark + indigo):

- button_cpp_core         (component, pure)  variantes primary/secondary/subtle/danger + sm/md/lg
- icon_button_cpp_core    (component, pure)  cuadrado 28x28 con glyph centrado + tooltip
- toolbar_cpp_core        (component, pure)  grupo horizontal de acciones con separadores
- modal_dialog_cpp_core   (component, pure)  popup modal centrada + close con Escape
- text_input_cpp_core     (component, impure) InputText con label muted + placeholder
- select_cpp_core         (component, impure) dropdown con label + opcion '(none)' opcional
- toast_cpp_core          (component, impure) notificaciones efimeras + inbox con badge
- tree_view_cpp_core      (component, impure) jerarquia low-level con tree_node_clicked helper
- process_runner_cpp_core (component, impure) tarea en std::thread + spinner inline

Cada primitiva tiene su .md con frontmatter completo (params/output) y se
indexa via fn index. Son la base del primitives_gallery y de cualquier
app fn_ui futura.
2026-04-25 21:25:39 +02:00

1.9 KiB

name, kind, lang, domain, version, purity, signature, description, tags, uses_functions, uses_types, returns, returns_optional, error_type, imports, tested, tests, test_file_path, file_path, framework, params, output
name kind lang domain version purity signature description tags uses_functions uses_types returns returns_optional error_type imports tested tests test_file_path file_path framework params output
button component cpp core 1.0.0 pure bool fn_ui::button(const char* label, fn_ui::ButtonVariant variant = Secondary, fn_ui::ButtonSize size = Md) Boton ImGui con variantes (primary/secondary/subtle/danger) y tamanos (sm/md/lg) usando fn_tokens. Replica Mantine Button / fn_library Button.
imgui
button
ui
form
tokens
tokens_cpp_core
false
imgui
false
cpp/functions/core/button.cpp imgui
name desc
label Texto visible del boton (tambien se usa como id ImGui; prefijar con ## para solo-id)
name desc
variant ButtonVariant: Primary (indigo), Secondary (surface+border, default), Subtle (transparente), Danger (rojo)
name desc
size ButtonSize: Sm (compacto), Md (default), Lg (grande, font x1.1)
true el frame en que se hace click, false en caso contrario

button

Boton con variantes semanticas y tamanos fijos. Usa tokens (primary, surface, error, border, text) y padding/radius consistentes — mismo estilo visual en cualquier app C++ que lo use.

Variantes

Variant Uso Colores
Primary Accion principal (Save, Submit) colors::primary + hover
Secondary Accion neutra (Cancel) surface + border
Subtle Accion discreta (ver mas) transparente + hover surface
Danger Accion destructiva (Delete) colors::error

Ejemplo

#include "core/button.h"
using fn_ui::button;
using V = fn_ui::ButtonVariant;

if (button("Reindex", V::Primary)) { ... }
if (button("Cancel",  V::Subtle))  { ... }
if (button("Delete",  V::Danger))  { ... }

Notas

  • No gestiona layout: usar ImGui::SameLine() o toolbar para alinear varios.
  • Para botones solo-icono sin texto, usar icon_button.