From 674e8af2e92074b71c77e656a54244ce2693460c Mon Sep 17 00:00:00 2001 From: crupest Date: Wed, 16 Feb 2022 17:00:33 +0800 Subject: ... --- .../conditions/ClickStateConditionEditor.cpp | 68 ++++++++++++++++++++++ .../conditions/ClickStateConditionEditor.h | 30 ++++++++++ 2 files changed, 98 insertions(+) create mode 100644 src/theme_builder/components/conditions/ClickStateConditionEditor.cpp create mode 100644 src/theme_builder/components/conditions/ClickStateConditionEditor.h (limited to 'src/theme_builder/components/conditions') 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 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 +ClickStateConditionEditor::GetValue() const { + return ui::style::ClickStateCondition::Create( + ConvertIndexToClickState(click_state_select_.GetSelectedIndex())); +} + +void ClickStateConditionEditor::SetValue( + ClonablePtr 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 GetValue() const; + void SetValue(ClonablePtr value, + bool trigger_change = true); + + ClonablePtr GetCondition() override { + return GetValue(); + } + + IEvent* ChangeEvent() { return &change_event_; } + + private: + properties::SelectPropertyEditor click_state_select_; + + Event change_event_; +}; +} // namespace cru::theme_builder::components::conditions -- cgit v1.2.3