151 lines
5.3 KiB
C
151 lines
5.3 KiB
C
|
|
#ifndef UART_CLAY_COMMON_LAYOUT_H
|
||
|
|
#define UART_CLAY_COMMON_LAYOUT_H
|
||
|
|
|
||
|
|
#include "uart_func.c"
|
||
|
|
|
||
|
|
typedef enum { MAIN_FONT, SMALL_FONT } FONT_ID;
|
||
|
|
|
||
|
|
const Clay_Color COLOR_RED = {255, 45, 0, 255};
|
||
|
|
const Clay_Color COLOR_GREEN = {25, 255, 25, 255};
|
||
|
|
const Clay_Color COLOR_BLUE = {0, 120, 255, 255};
|
||
|
|
const Clay_Color COLOR_ORANGE = {225, 127, 0, 255};
|
||
|
|
const Clay_Color COLOR_LIGHT = {224, 215, 210, 255};
|
||
|
|
const Clay_Color COLOR_BLACK = {0, 0, 0, 255};
|
||
|
|
|
||
|
|
const Clay_Sizing EXPAND = { CLAY_SIZING_GROW(0), CLAY_SIZING_GROW(0) };
|
||
|
|
const Clay_ChildAlignment CENTER_X_Y = { .x = CLAY_ALIGN_X_CENTER, .y = CLAY_ALIGN_Y_CENTER };
|
||
|
|
|
||
|
|
const Clay_LayoutConfig BUTTON_CONFIG = {
|
||
|
|
.sizing = EXPAND,
|
||
|
|
.childAlignment = CENTER_X_Y
|
||
|
|
};
|
||
|
|
|
||
|
|
const Clay_TextElementConfig LARGE_TEXT = { .textColor = COLOR_BLACK, .fontId = MAIN_FONT, .fontSize = 30 };
|
||
|
|
|
||
|
|
Clay_String modal_message;
|
||
|
|
|
||
|
|
Clay_Color darken(const Clay_Color color, const int scale) {
|
||
|
|
return (Clay_Color){
|
||
|
|
color.r * (100 - scale) / 100,
|
||
|
|
color.g * (100 - scale) / 100,
|
||
|
|
color.b * (100 - scale) / 100,
|
||
|
|
color.a
|
||
|
|
};
|
||
|
|
}
|
||
|
|
|
||
|
|
void toggle_red(Clay_ElementId elementId, Clay_PointerData pointerInfo, intptr_t userData) {
|
||
|
|
const uart_data *data = (uart_data *)userData;
|
||
|
|
|
||
|
|
if (pointerInfo.state == CLAY_POINTER_DATA_PRESSED_THIS_FRAME) {
|
||
|
|
constexpr size_t response_length = 15;
|
||
|
|
handle_uart(data, 'r', response_length);
|
||
|
|
modal_message.length = response_length - 2;
|
||
|
|
UART_modal_show = true;
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
void toggle_green(Clay_ElementId elementId, Clay_PointerData pointerInfo, intptr_t userData) {
|
||
|
|
const uart_data *data = (uart_data *)userData;
|
||
|
|
|
||
|
|
if (pointerInfo.state == CLAY_POINTER_DATA_PRESSED_THIS_FRAME) {
|
||
|
|
constexpr size_t response_length = 17;
|
||
|
|
handle_uart(data, 'g', response_length);
|
||
|
|
modal_message.length = response_length - 2;
|
||
|
|
|
||
|
|
UART_modal_show = true;
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
void toggle_blue(Clay_ElementId elementId, Clay_PointerData pointerInfo, intptr_t userData) {
|
||
|
|
const uart_data *data = (uart_data *)userData;
|
||
|
|
|
||
|
|
if (pointerInfo.state == CLAY_POINTER_DATA_PRESSED_THIS_FRAME) {
|
||
|
|
constexpr size_t response_length = 16;
|
||
|
|
handle_uart(data, 'b', response_length);
|
||
|
|
modal_message.length = response_length - 2;
|
||
|
|
UART_modal_show = true;
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
void toggle_orange(Clay_ElementId elementId, Clay_PointerData pointerInfo, intptr_t userData) {
|
||
|
|
const uart_data *data = (uart_data *)userData;
|
||
|
|
|
||
|
|
if (pointerInfo.state == CLAY_POINTER_DATA_PRESSED_THIS_FRAME) {
|
||
|
|
constexpr size_t response_length = 18;
|
||
|
|
handle_uart(data, 'o', response_length);
|
||
|
|
modal_message.length = response_length - 2;
|
||
|
|
UART_modal_show = true;
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
void hide_modal(Clay_ElementId elementId, Clay_PointerData pointerInfo, intptr_t userData) {
|
||
|
|
if (pointerInfo.state == CLAY_POINTER_DATA_PRESSED_THIS_FRAME) {
|
||
|
|
UART_modal_show = false;
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
void Button(const Clay_String label, const Clay_Color color, void (*onHoverFunction)(Clay_ElementId elementId, Clay_PointerData pointerInfo, intptr_t userData), const intptr_t data) {
|
||
|
|
CLAY_AUTO_ID({
|
||
|
|
.layout = BUTTON_CONFIG, .backgroundColor = color, .cornerRadius = CLAY_CORNER_RADIUS(16)
|
||
|
|
}) {
|
||
|
|
Clay_OnHover(onHoverFunction, data);
|
||
|
|
CLAY_TEXT(label, (void *)&LARGE_TEXT);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
void Modal() {
|
||
|
|
CLAY_AUTO_ID({
|
||
|
|
.layout = {
|
||
|
|
.layoutDirection = CLAY_TOP_TO_BOTTOM,
|
||
|
|
.sizing = { .height = CLAY_SIZING_PERCENT(0.25f), .width = CLAY_SIZING_PERCENT(0.55f) },
|
||
|
|
.childAlignment = CENTER_X_Y,
|
||
|
|
.padding = CLAY_PADDING_ALL(16),
|
||
|
|
.childGap = 8,
|
||
|
|
},
|
||
|
|
.cornerRadius = CLAY_CORNER_RADIUS(16),
|
||
|
|
.floating = {
|
||
|
|
.attachTo = CLAY_ATTACH_TO_PARENT,
|
||
|
|
.attachPoints = { .element = CLAY_ATTACH_POINT_CENTER_CENTER, .parent = CLAY_ATTACH_POINT_CENTER_CENTER }
|
||
|
|
},
|
||
|
|
.backgroundColor = darken(COLOR_LIGHT, 10)
|
||
|
|
}) {
|
||
|
|
CLAY_TEXT(modal_message, (void *)&LARGE_TEXT);
|
||
|
|
CLAY_AUTO_ID({ .layout = { .sizing = EXPAND } });
|
||
|
|
CLAY_AUTO_ID({
|
||
|
|
.layout = {
|
||
|
|
.sizing = { .height = CLAY_SIZING_FIT(), .width = CLAY_SIZING_GROW() },
|
||
|
|
.childAlignment = CENTER_X_Y
|
||
|
|
}, .backgroundColor = COLOR_RED, .cornerRadius = CLAY_CORNER_RADIUS(16)
|
||
|
|
}) {
|
||
|
|
Clay_OnHover(hide_modal, 0);
|
||
|
|
CLAY_TEXT(CLAY_STRING("X"), (void *)&LARGE_TEXT);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
Clay_RenderCommandArray Clay_CreateLayout(uart_data *data) {
|
||
|
|
Clay_BeginLayout();
|
||
|
|
Clay__debugViewWidth = 700;
|
||
|
|
|
||
|
|
CLAY(CLAY_ID("Outer"),{
|
||
|
|
.layout = {
|
||
|
|
.layoutDirection = CLAY_TOP_TO_BOTTOM,
|
||
|
|
.sizing = EXPAND,
|
||
|
|
.padding = CLAY_PADDING_ALL(16),
|
||
|
|
.childGap = 16
|
||
|
|
},
|
||
|
|
.backgroundColor = COLOR_LIGHT,
|
||
|
|
}) {
|
||
|
|
if (UART_modal_show) {
|
||
|
|
Modal();
|
||
|
|
}
|
||
|
|
|
||
|
|
Button(CLAY_STRING("Red"), COLOR_RED, UART_modal_show ? nullptr : toggle_red, (intptr_t)data);
|
||
|
|
Button(CLAY_STRING("Green"), COLOR_GREEN, UART_modal_show ? nullptr : toggle_green, (intptr_t)data);
|
||
|
|
Button(CLAY_STRING("Blue"), COLOR_BLUE, UART_modal_show ? nullptr : toggle_blue, (intptr_t)data);
|
||
|
|
Button(CLAY_STRING("Orange"), COLOR_ORANGE, UART_modal_show ? nullptr : toggle_orange, (intptr_t)data);
|
||
|
|
}
|
||
|
|
return Clay_EndLayout();
|
||
|
|
}
|
||
|
|
|
||
|
|
#endif //UART_CLAY_COMMON_LAYOUT_H
|