aboutsummaryrefslogtreecommitdiff
path: root/src/theme_builder/components/conditions
diff options
context:
space:
mode:
Diffstat (limited to 'src/theme_builder/components/conditions')
-rw-r--r--src/theme_builder/components/conditions/ClickStateConditionEditor.cpp68
-rw-r--r--src/theme_builder/components/conditions/ClickStateConditionEditor.h30
2 files changed, 98 insertions, 0 deletions
diff --git a/src/theme_builder/components/conditions/ClickStateConditionEditor.cpp b/src/theme_builder/components/conditions/ClickStateConditionEditor.cpp
new file mode 100644
index 00000000..a9170cc5
--- /dev/null
+++ b/src/theme_builder/components/conditions/ClickStateConditionEditor.cpp
@@ -0,0 +1,68 @@
+#include "ClickStateConditionEditor.h"
+#include "cru/common/ClonablePtr.h"
+#include "cru/ui/helper/ClickDetector.h"
+#include "cru/ui/style/Condition.h"
+
+namespace cru::theme_builder::components::conditions {
+using ui::helper::ClickState;
+namespace {
+const std::vector<String> kClickStates{
+ u"None",
+ u"Hover",
+ u"Press",
+ u"PressInactive",
+};
+
+Index ConvertClickStateToIndex(ClickState click_state) {
+ switch (click_state) {
+ case ClickState::None:
+ return 0;
+ case ClickState::Hover:
+ return 1;
+ case ClickState::Press:
+ return 2;
+ case ClickState::PressInactive:
+ return 3;
+ }
+ return -1;
+}
+
+ClickState ConvertIndexToClickState(Index index) {
+ switch (index) {
+ case 0:
+ return ClickState::None;
+ case 1:
+ return ClickState::Hover;
+ case 2:
+ return ClickState::Press;
+ case 3:
+ return ClickState::PressInactive;
+ }
+ return ClickState::None;
+}
+} // namespace
+
+ClickStateConditionEditor::ClickStateConditionEditor() {
+ GetContainer()->AddChild(click_state_select_.GetRootControl());
+
+ click_state_select_.SetItems(kClickStates);
+ click_state_select_.SetSelectedIndex(0, false);
+
+ click_state_select_.ChangeEvent()->AddSpyOnlyHandler(
+ [this] { change_event_.Raise(nullptr); });
+}
+
+ClickStateConditionEditor::~ClickStateConditionEditor() {}
+
+ClonablePtr<ui::style::ClickStateCondition>
+ClickStateConditionEditor::GetValue() const {
+ return ui::style::ClickStateCondition::Create(
+ ConvertIndexToClickState(click_state_select_.GetSelectedIndex()));
+}
+
+void ClickStateConditionEditor::SetValue(
+ ClonablePtr<ui::style::ClickStateCondition> value, bool trigger_change) {
+ click_state_select_.SetSelectedIndex(
+ ConvertClickStateToIndex(value->GetClickState()), trigger_change);
+}
+} // namespace cru::theme_builder::components::conditions
diff --git a/src/theme_builder/components/conditions/ClickStateConditionEditor.h b/src/theme_builder/components/conditions/ClickStateConditionEditor.h
new file mode 100644
index 00000000..f172f029
--- /dev/null
+++ b/src/theme_builder/components/conditions/ClickStateConditionEditor.h
@@ -0,0 +1,30 @@
+#pragma once
+#include "../properties/SelectPropertyEditor.h"
+#include "ConditionEditor.h"
+#include "cru/common/ClonablePtr.h"
+#include "cru/common/Event.h"
+#include "cru/ui/style/Condition.h"
+
+namespace cru::theme_builder::components::conditions {
+class ClickStateConditionEditor : public ConditionEditor {
+ public:
+ ClickStateConditionEditor();
+ ~ClickStateConditionEditor();
+
+ public:
+ ClonablePtr<ui::style::ClickStateCondition> GetValue() const;
+ void SetValue(ClonablePtr<ui::style::ClickStateCondition> value,
+ bool trigger_change = true);
+
+ ClonablePtr<ui::style::Condition> GetCondition() override {
+ return GetValue();
+ }
+
+ IEvent<std::nullptr_t>* ChangeEvent() { return &change_event_; }
+
+ private:
+ properties::SelectPropertyEditor click_state_select_;
+
+ Event<std::nullptr_t> change_event_;
+};
+} // namespace cru::theme_builder::components::conditions