From 847c0bded52739f5134a969ca4d99b0932926d1b Mon Sep 17 00:00:00 2001 From: Sara Gerretsen Date: Mon, 22 Sep 2025 13:35:02 +0200 Subject: [PATCH] feat: defined Toggle element --- src/elements.cpp | 49 ++++++++++++++++++++++++++++++++++++++++++++++-- src/elements.h | 5 +++-- src/style.h | 6 ++++++ 3 files changed, 56 insertions(+), 4 deletions(-) diff --git a/src/elements.cpp b/src/elements.cpp index 32a96f1..8d55a46 100644 --- a/src/elements.cpp +++ b/src/elements.cpp @@ -10,15 +10,60 @@ void TextButton(Clay_String text, Clay_Color color, OnHoveredFn onHovered, intpt .padding = style::buttonPadding, .childAlignment = { CLAY_ALIGN_X_CENTER, CLAY_ALIGN_Y_CENTER }, }, - .backgroundColor = Clay_Hovered() ? hovered : color, + .backgroundColor = Clay_Hovered() + ? hovered + : color, .cornerRadius = style::buttonRadii, .border = { style::ToHoveredColor(Clay_Hovered() ? hovered : color), CLAY_BORDER_ALL(1) }, }) { + Clay_OnHover(onHovered, onHoveredData); elements::Body(text, { .textColor = style::TextColors(0), .textAlignment = CLAY_TEXT_ALIGN_CENTER, }); - Clay_OnHover(onHovered, onHoveredData); + } +} + +void ToggleHovered(Clay_ElementId element, Clay_PointerData pointer, intptr_t data) { + bool *hovered{ (bool*)data }; + if (pointer.state == CLAY_POINTER_DATA_PRESSED_THIS_FRAME) { + *hovered = !(*hovered); + } +} + + +void Toggle(Clay_String label, Clay_Color selected, bool &state) { + CLAY_AUTO_ID({ + .layout = { + .sizing = { CLAY_SIZING_GROW(), CLAY_SIZING_GROW() }, + .childGap = 10, + .childAlignment = { CLAY_ALIGN_X_LEFT, CLAY_ALIGN_Y_CENTER }, + }, + }) { + Clay_Color color{Clay_Hovered() + ? style::ToHoveredColor(selected) + : selected + }; + Clay_OnHover(&ToggleHovered, (intptr_t)(&state)); + CLAY_AUTO_ID({ + .layout = { + .sizing = { + CLAY_SIZING_FIXED(20), CLAY_SIZING_FIXED(20) + } + }, + .backgroundColor = (state + ? selected + : style::color::transparent + ), + .cornerRadius = style::buttonRadii, + .border = { + color, + CLAY_BORDER_OUTSIDE(3) + }, + }) { } + Body(label, { + .textColor = style::TextColors(0) + }); } } diff --git a/src/elements.h b/src/elements.h index fb1c1e9..f3ac09c 100644 --- a/src/elements.h +++ b/src/elements.h @@ -7,8 +7,9 @@ namespace elements { typedef void(*OnHoveredFn)(Clay_ElementId element, Clay_PointerData pointer, intptr_t data); void TextButton(Clay_String text, Clay_Color color, OnHoveredFn onHovered, intptr_t onHoveredData = 0); -void Body(Clay_String string, Clay_TextElementConfig baseCfg); -void Header(Clay_String string, size_t header, Clay_TextElementConfig baseCfg); +void Toggle(Clay_String label, Clay_Color selected, bool &state); +void Body(Clay_String string, Clay_TextElementConfig baseCfg = {}); +void Header(Clay_String string, size_t header, Clay_TextElementConfig baseCfg = {}); } #endif // !ELEMENTS_H diff --git a/src/style.h b/src/style.h index b395821..45ea500 100644 --- a/src/style.h +++ b/src/style.h @@ -97,6 +97,12 @@ constexpr Clay_CornerRadius defaultRadiusAll = { defaultRadius, defaultRadius }; +namespace color { +constexpr Clay_Color transparent{ 255, 255, 255, 0 }; +constexpr Clay_Color black{ 0, 0, 0, 255 }; +constexpr Clay_Color white{ 255, 255, 255, 255 }; +} + Clay_Color PanelBackground(size_t idx); Clay_Color PanelBorder(size_t idx); Clay_Color TextColors(size_t idx);