aboutsummaryrefslogtreecommitdiff
path: root/include/cru/ui/controls/FlexLayout.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/cru/ui/controls/FlexLayout.h')
-rw-r--r--include/cru/ui/controls/FlexLayout.h40
1 files changed, 40 insertions, 0 deletions
diff --git a/include/cru/ui/controls/FlexLayout.h b/include/cru/ui/controls/FlexLayout.h
new file mode 100644
index 00000000..1255b119
--- /dev/null
+++ b/include/cru/ui/controls/FlexLayout.h
@@ -0,0 +1,40 @@
+#pragma once
+#include "LayoutControl.h"
+
+namespace cru::ui::controls {
+class CRU_UI_API FlexLayout : public LayoutControl {
+ public:
+ static constexpr StringView control_type = u"FlexLayout";
+
+ static FlexLayout* Create() { return new FlexLayout(); }
+
+ protected:
+ FlexLayout();
+
+ public:
+ FlexLayout(const FlexLayout& other) = delete;
+ FlexLayout(FlexLayout&& other) = delete;
+ FlexLayout& operator=(const FlexLayout& other) = delete;
+ FlexLayout& operator=(FlexLayout&& other) = delete;
+ ~FlexLayout() override;
+
+ String GetControlType() const final { return control_type.ToString(); }
+
+ render::RenderObject* GetRenderObject() const override;
+
+ FlexMainAlignment GetContentMainAlign() const;
+ void SetContentMainAlign(FlexMainAlignment value);
+
+ FlexDirection GetFlexDirection() const;
+ void SetFlexDirection(FlexDirection direction);
+
+ FlexCrossAlignment GetItemCrossAlign() const;
+ void SetItemCrossAlign(FlexCrossAlignment alignment);
+
+ FlexChildLayoutData GetChildLayoutData(Control* control);
+ void SetChildLayoutData(Control* control, FlexChildLayoutData data);
+
+ private:
+ std::shared_ptr<render::FlexLayoutRenderObject> render_object_;
+};
+} // namespace cru::ui::controls