summaryrefslogtreecommitdiffstats
path: root/xbmc/addons/ContextMenuAddon.cpp
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--xbmc/addons/ContextMenuAddon.cpp108
1 files changed, 108 insertions, 0 deletions
diff --git a/xbmc/addons/ContextMenuAddon.cpp b/xbmc/addons/ContextMenuAddon.cpp
new file mode 100644
index 0000000..1717580
--- /dev/null
+++ b/xbmc/addons/ContextMenuAddon.cpp
@@ -0,0 +1,108 @@
+/*
+ * Copyright (C) 2013-2018 Team Kodi
+ * This file is part of Kodi - https://kodi.tv
+ *
+ * SPDX-License-Identifier: GPL-2.0-or-later
+ * See LICENSES/README.md for more information.
+ */
+
+#include "ContextMenuAddon.h"
+
+#include "ContextMenuItem.h"
+#include "ContextMenuManager.h"
+#include "addons/addoninfo/AddonType.h"
+#include "guilib/LocalizeStrings.h"
+#include "utils/StringUtils.h"
+#include "utils/URIUtils.h"
+
+#include <sstream>
+
+namespace ADDON
+{
+
+CContextMenuAddon::CContextMenuAddon(const AddonInfoPtr& addonInfo)
+ : CAddon(addonInfo, AddonType::CONTEXTMENU_ITEM)
+{
+ const CAddonExtensions* menu = Type(AddonType::CONTEXTMENU_ITEM)->GetElement("menu");
+ if (menu)
+ {
+ int tmp = 0;
+ ParseMenu(menu, "", tmp);
+ }
+ else
+ {
+ //backwards compatibility. add first item definition
+ const CAddonExtensions* elem = Type(AddonType::CONTEXTMENU_ITEM)->GetElement("item");
+ if (elem)
+ {
+ std::string visCondition = elem->GetValue("visible").asString();
+ if (visCondition.empty())
+ visCondition = "false";
+
+ std::string parent = elem->GetValue("parent").asString() == "kodi.core.manage"
+ ? CContextMenuManager::MANAGE.m_groupId : CContextMenuManager::MAIN.m_groupId;
+
+ auto label = elem->GetValue("label").asString();
+ if (StringUtils::IsNaturalNumber(label))
+ label = g_localizeStrings.GetAddonString(ID(), atoi(label.c_str()));
+
+ CContextMenuItem menuItem = CContextMenuItem::CreateItem(
+ label, parent,
+ URIUtils::AddFileToFolder(Path(), Type(AddonType::CONTEXTMENU_ITEM)->LibName()),
+ visCondition, ID());
+
+ m_items.push_back(menuItem);
+ }
+ }
+}
+
+CContextMenuAddon::~CContextMenuAddon() = default;
+
+void CContextMenuAddon::ParseMenu(
+ const CAddonExtensions* elem,
+ const std::string& parent,
+ int& anonGroupCount)
+{
+ auto menuId = elem->GetValue("@id").asString();
+ auto menuLabel = elem->GetValue("label").asString();
+ if (StringUtils::IsNaturalNumber(menuLabel))
+ menuLabel = g_localizeStrings.GetAddonString(ID(), std::stoi(menuLabel));
+
+ if (menuId.empty())
+ {
+ //anonymous group. create a new unique internal id.
+ std::stringstream ss;
+ ss << ID() << ++anonGroupCount;
+ menuId = ss.str();
+ }
+
+ m_items.push_back(CContextMenuItem::CreateGroup(menuLabel, parent, menuId, ID()));
+
+ for (const auto& subMenu : elem->GetElements("menu"))
+ ParseMenu(&subMenu.second, menuId, anonGroupCount);
+
+ for (const auto& element : elem->GetElements("item"))
+ {
+ std::string visCondition = element.second.GetValue("visible").asString();
+ std::string library = element.second.GetValue("@library").asString();
+ std::string label = element.second.GetValue("label").asString();
+ if (StringUtils::IsNaturalNumber(label))
+ label = g_localizeStrings.GetAddonString(ID(), atoi(label.c_str()));
+
+ std::vector<std::string> args;
+ args.push_back(ID());
+
+ std::string arg = element.second.GetValue("@args").asString();
+ if (!arg.empty())
+ args.push_back(arg);
+
+ if (!label.empty() && !library.empty() && !visCondition.empty())
+ {
+ auto menu = CContextMenuItem::CreateItem(label, menuId,
+ URIUtils::AddFileToFolder(Path(), library), visCondition, ID(), args);
+ m_items.push_back(menu);
+ }
+ }
+}
+
+}