From 275fe302cd03adf59fff1a0e4a08f13c6cfcaf31 Mon Sep 17 00:00:00 2001 From: crupest Date: Sun, 23 Jan 2022 21:48:08 +0800 Subject: ... --- src/ui/mapper/style/BorderStylerMapper.cpp | 34 ++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) create mode 100644 src/ui/mapper/style/BorderStylerMapper.cpp (limited to 'src/ui/mapper') diff --git a/src/ui/mapper/style/BorderStylerMapper.cpp b/src/ui/mapper/style/BorderStylerMapper.cpp new file mode 100644 index 00000000..8a5df83d --- /dev/null +++ b/src/ui/mapper/style/BorderStylerMapper.cpp @@ -0,0 +1,34 @@ +#include "cru/ui/mapper/style/BorderStylerMapper.hpp" +#include "cru/common/ClonablePtr.hpp" +#include "cru/ui/mapper/MapperRegistry.hpp" +#include "cru/ui/style/ApplyBorderStyleInfo.hpp" +#include "cru/ui/style/Styler.hpp" +#include "cru/xml/XmlNode.hpp" + +namespace cru::ui::mapper::style { +using cru::ui::style::ApplyBorderStyleInfo; +using cru::ui::style::BorderStyler; + +bool BorderStylerMapper::XmlElementIsOfThisType(xml::XmlElementNode* node) { + return node->GetTag().CaseInsensitiveEqual(u"BorderStyler"); +} + +ClonablePtr BorderStylerMapper::DoMapFromXml( + xml::XmlElementNode* node) { + auto border_style_mapper = + MapperRegistry::GetInstance()->GetMapper(); + + ApplyBorderStyleInfo border_style; + + for (auto child : node->GetChildren()) { + if (child->GetType() == xml::XmlElementNode::Type::Element) { + auto child_element = child->AsElement(); + if (border_style_mapper->XmlElementIsOfThisType(child_element)) { + border_style = border_style_mapper->MapFromXml(child_element); + } + } + } + + return BorderStyler::Create(std::move(border_style)); +} +} // namespace cru::ui::mapper::style -- cgit v1.2.3