aboutsummaryrefslogtreecommitdiff
path: root/src/theme_builder/components/conditions/CompoundConditionEditor.cpp
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2022-03-29 22:55:29 +0800
committercrupest <crupest@outlook.com>2022-03-29 22:55:29 +0800
commit77e217af8bdbfb20b9147f6159d5bdfda439ea95 (patch)
tree46873c9dc28ad7d0f900a8f7610a1ea4b881f75e /src/theme_builder/components/conditions/CompoundConditionEditor.cpp
parent6c09f49d51a564ff4dd0a6d3fa9804dffc2b236c (diff)
downloadcru-77e217af8bdbfb20b9147f6159d5bdfda439ea95.tar.gz
cru-77e217af8bdbfb20b9147f6159d5bdfda439ea95.tar.bz2
cru-77e217af8bdbfb20b9147f6159d5bdfda439ea95.zip
...
Diffstat (limited to 'src/theme_builder/components/conditions/CompoundConditionEditor.cpp')
-rw-r--r--src/theme_builder/components/conditions/CompoundConditionEditor.cpp40
1 files changed, 7 insertions, 33 deletions
diff --git a/src/theme_builder/components/conditions/CompoundConditionEditor.cpp b/src/theme_builder/components/conditions/CompoundConditionEditor.cpp
index 1e149789..69b8ed02 100644
--- a/src/theme_builder/components/conditions/CompoundConditionEditor.cpp
+++ b/src/theme_builder/components/conditions/CompoundConditionEditor.cpp
@@ -12,28 +12,6 @@
#include "cru/ui/style/Condition.h"
namespace cru::theme_builder::components::conditions {
-CompoundConditionEditorChild::CompoundConditionEditorChild(
- std::unique_ptr<ConditionEditor>&& condition_editor)
- : condition_editor_(std::move(condition_editor)) {
- container_.SetFlexDirection(ui::controls::FlexDirection::Horizontal);
- container_.AddChild(&remove_button_);
-
- remove_button_.GetStyleRuleSet()->SetParent(
- ui::ThemeManager::GetInstance()->GetResourceStyleRuleSet(
- u"cru.theme_builder.icon-button.style"));
- remove_button_.SetIconWithSvgPathDataStringResourceKey(u"icon.close",
- {0, 0, 16, 16});
- remove_button_.SetPreferredSize({24, 24});
- remove_button_.SetPadding(ui::Thickness(2));
- remove_button_.SetIconFillColor(ui::colors::red);
-
- container_.AddChild(condition_editor_->GetRootControl());
-
- remove_button_.ClickEvent()->AddSpyOnlyHandler(
- [this] { this->remove_event_.Raise(nullptr); });
-}
-
-CompoundConditionEditorChild::~CompoundConditionEditorChild() {}
CompoundConditionEditor::CompoundConditionEditor() {
SetLabel(u"Compound Condition");
@@ -83,15 +61,13 @@ CompoundConditionEditor::CompoundConditionEditor() {
}
if (editor) {
ConnectChangeEvent(editor.get());
- auto child =
- std::make_unique<CompoundConditionEditorChild>(std::move(editor));
- child->RemoveEvent()->AddSpyOnlyHandler([this, c = child.get()] {
+ editor->RemoveEvent()->AddSpyOnlyHandler([this, c = editor.get()] {
auto index = this->children_container_.IndexOf(c->GetRootControl());
this->children_.erase(this->children_.begin() + index);
this->children_container_.RemoveChildAt(index);
RaiseChangeEvent();
});
- children_.push_back(std::move(child));
+ children_.push_back(std::move(editor));
children_container_.AddChild(children_.back()->GetRootControl());
RaiseChangeEvent();
}
@@ -104,7 +80,7 @@ std::vector<ClonablePtr<ui::style::Condition>>
CompoundConditionEditor::GetChildren() {
std::vector<ClonablePtr<ui::style::Condition>> children;
for (auto& child : children_) {
- children.push_back(child->GetConditionEditor()->GetCondition());
+ children.push_back(child->GetCondition());
}
return children;
}
@@ -115,17 +91,15 @@ void CompoundConditionEditor::SetChildren(
children_container_.ClearChildren();
children_.clear();
for (const auto& condition : children) {
- auto condition_editor = CreateConditionEditor(condition.get());
- ConnectChangeEvent(condition_editor.get());
- auto child = std::make_unique<CompoundConditionEditorChild>(
- std::move(condition_editor));
- child->RemoveEvent()->AddSpyOnlyHandler([this, c = child.get()] {
+ auto editor = CreateConditionEditor(condition.get());
+ ConnectChangeEvent(editor.get());
+ editor->RemoveEvent()->AddSpyOnlyHandler([this, c = editor.get()] {
auto index = this->children_container_.IndexOf(c->GetRootControl());
this->children_.erase(this->children_.begin() + index);
this->children_container_.RemoveChildAt(index);
RaiseChangeEvent();
});
- children_.push_back(std::move(child));
+ children_.push_back(std::move(editor));
children_container_.AddChild(children_.back()->GetRootControl());
}
if (trigger_change) {