diff options
Diffstat (limited to 'src/ui/mapper/style/BorderStylerMapper.cpp')
-rw-r--r-- | src/ui/mapper/style/BorderStylerMapper.cpp | 34 |
1 files changed, 34 insertions, 0 deletions
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<BorderStyler> BorderStylerMapper::DoMapFromXml( + xml::XmlElementNode* node) { + auto border_style_mapper = + MapperRegistry::GetInstance()->GetMapper<ApplyBorderStyleInfo>(); + + 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 |