From da6f0bcfc6ec786cf14f67f100b4c50cf2325db4 Mon Sep 17 00:00:00 2001 From: crupest Date: Wed, 16 Feb 2022 17:30:49 +0800 Subject: ... --- .../conditions/ClickStateConditionEditor.cpp | 3 ++- .../conditions/ClickStateConditionEditor.h | 2 +- .../components/conditions/FocusConditionEditor.cpp | 23 +++++++++++++++++ .../components/conditions/FocusConditionEditor.h | 29 ++++++++++++++++++++++ 4 files changed, 55 insertions(+), 2 deletions(-) create mode 100644 src/theme_builder/components/conditions/FocusConditionEditor.cpp create mode 100644 src/theme_builder/components/conditions/FocusConditionEditor.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 index a9170cc5..80d221bd 100644 --- a/src/theme_builder/components/conditions/ClickStateConditionEditor.cpp +++ b/src/theme_builder/components/conditions/ClickStateConditionEditor.cpp @@ -61,7 +61,8 @@ ClickStateConditionEditor::GetValue() const { } void ClickStateConditionEditor::SetValue( - ClonablePtr value, bool trigger_change) { + const ClonablePtr& value, + bool trigger_change) { click_state_select_.SetSelectedIndex( ConvertClickStateToIndex(value->GetClickState()), trigger_change); } diff --git a/src/theme_builder/components/conditions/ClickStateConditionEditor.h b/src/theme_builder/components/conditions/ClickStateConditionEditor.h index f172f029..4e18c423 100644 --- a/src/theme_builder/components/conditions/ClickStateConditionEditor.h +++ b/src/theme_builder/components/conditions/ClickStateConditionEditor.h @@ -13,7 +13,7 @@ class ClickStateConditionEditor : public ConditionEditor { public: ClonablePtr GetValue() const; - void SetValue(ClonablePtr value, + void SetValue(const ClonablePtr& value, bool trigger_change = true); ClonablePtr GetCondition() override { diff --git a/src/theme_builder/components/conditions/FocusConditionEditor.cpp b/src/theme_builder/components/conditions/FocusConditionEditor.cpp new file mode 100644 index 00000000..d5d864e1 --- /dev/null +++ b/src/theme_builder/components/conditions/FocusConditionEditor.cpp @@ -0,0 +1,23 @@ +#include "FocusConditionEditor.h" +#include "cru/common/ClonablePtr.h" +#include "cru/ui/style/Condition.h" + +namespace cru::theme_builder::components::conditions { +FocusConditionEditor::FocusConditionEditor() { + GetContainer()->AddChild(focus_check_box_.GetRootControl()); + + focus_check_box_.ChangeEvent()->AddSpyOnlyHandler( + [this] { change_event_.Raise(nullptr); }); +} + +FocusConditionEditor::~FocusConditionEditor() {} + +ClonablePtr FocusConditionEditor::GetValue() const { + return ui::style::FocusCondition::Create(focus_check_box_.GetValue()); +} + +void FocusConditionEditor::SetValue( + const ClonablePtr &value, bool trigger_change) { + focus_check_box_.SetValue(value->IsHasFocus(), trigger_change); +} +} // namespace cru::theme_builder::components::conditions diff --git a/src/theme_builder/components/conditions/FocusConditionEditor.h b/src/theme_builder/components/conditions/FocusConditionEditor.h new file mode 100644 index 00000000..ab5d40c6 --- /dev/null +++ b/src/theme_builder/components/conditions/FocusConditionEditor.h @@ -0,0 +1,29 @@ +#pragma once +#include "../properties/CheckBoxPropertyEditor.h" +#include "ConditionEditor.h" +#include "cru/common/ClonablePtr.h" +#include "cru/ui/style/Condition.h" + +namespace cru::theme_builder::components::conditions { +class FocusConditionEditor : public ConditionEditor { + public: + FocusConditionEditor(); + ~FocusConditionEditor() override; + + public: + ClonablePtr GetValue() const; + void SetValue(const ClonablePtr& value, + bool trigger_change = true); + + ClonablePtr GetCondition() override { + return GetValue(); + } + + IEvent* ChangeEvent() { return &change_event_; } + + private: + properties::CheckBoxPropertyEditor focus_check_box_; + + Event change_event_; +}; +} // namespace cru::theme_builder::components::conditions -- cgit v1.2.3