1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 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);
}
}
}
}
|