# HG changeset patch # User Olaf Wintermann # Date 1736804217 -3600 # Node ID dc762a79e72dd4a3dabbfc9e0c46c019550050ba # Parent 752bd110375eaeddc103ec841a5420f86ef17e16 add ui_customwidget_create function (GTK) diff -r 752bd110375e -r dc762a79e72d ui/gtk/container.c --- a/ui/gtk/container.c Wed Jan 08 20:35:24 2025 +0100 +++ b/ui/gtk/container.c Mon Jan 13 22:36:57 2025 +0100 @@ -52,6 +52,17 @@ return 1; } +UIEXPORT UIWIDGET ui_customwidget_create(UiObject *obj, ui_createwidget_func create_widget, void *userdata, UiWidgetArgs args) { + UiObject* current = uic_current_obj(obj); + + UIWIDGET widget = create_widget(obj, args, userdata); + + UI_APPLY_LAYOUT1(current, args); + current->container->add(current->container, widget, FALSE); + + return widget; +} + GtkWidget* ui_gtk_vbox_new(int spacing) { #if GTK_MAJOR_VERSION >= 3 return gtk_box_new(GTK_ORIENTATION_VERTICAL, spacing); diff -r 752bd110375e -r dc762a79e72d ui/ui/container.h --- a/ui/ui/container.h Wed Jan 08 20:35:24 2025 +0100 +++ b/ui/ui/container.h Mon Jan 13 22:36:57 2025 +0100 @@ -57,6 +57,18 @@ UI_HEADERBAR_ALTERNATIVE_BOX } UiHeaderbarAlternative; +typedef struct UiWidgetArgs { + UiTri fill; + UiBool hexpand; + UiBool vexpand; + UiBool hfill; + UiBool vfill; + int colspan; + int rowspan; + const char *name; + const char *style_class; +} UiWidgetArgs; + typedef struct UiContainerArgs { UiTri fill; UiBool hexpand; @@ -277,6 +289,12 @@ UIEXPORT UiObject* ui_document_tab(UiTabbedPane *view); +typedef UIWIDGET (*ui_createwidget_func)(UiObject *obj, UiWidgetArgs args, void *userdata); +UIEXPORT UIWIDGET ui_customwidget_create(UiObject *obj, ui_createwidget_func create_widget, void *userdata, UiWidgetArgs args); + +#define ui_customwidget(obj, create_widget, userdata, ...) ui_customwidget_create(obj, create_widget, userdata, (UiWidgetArgs) { __VA_ARGS__ }) + + /* used for macro */ UIEXPORT void ui_container_begin_close(UiObject *obj); UIEXPORT int ui_container_finish(UiObject *obj);