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);
}
}
}
}
|