fix: Shortcuts applying to multiple views at once
This commit is contained in:
parent
e34e0e62f2
commit
313e59d7f9
@ -163,61 +163,24 @@ namespace hex {
|
|||||||
class Shortcut {
|
class Shortcut {
|
||||||
public:
|
public:
|
||||||
Shortcut() = default;
|
Shortcut() = default;
|
||||||
Shortcut(Keys key) : m_keys({ key }) { }
|
Shortcut(Keys key);
|
||||||
explicit Shortcut(std::set<Key> keys) : m_keys(std::move(keys)) { }
|
explicit Shortcut(std::set<Key> keys);
|
||||||
Shortcut(const Shortcut &other) = default;
|
Shortcut(const Shortcut &other) = default;
|
||||||
Shortcut(Shortcut &&) noexcept = default;
|
Shortcut(Shortcut &&) noexcept = default;
|
||||||
|
|
||||||
Shortcut& operator=(const Shortcut &other) = default;
|
|
||||||
|
|
||||||
Shortcut& operator=(Shortcut &&) noexcept = default;
|
|
||||||
|
|
||||||
constexpr static auto None = Keys(0);
|
constexpr static auto None = Keys(0);
|
||||||
|
|
||||||
Shortcut operator+(const Key &other) const {
|
Shortcut& operator=(const Shortcut &other) = default;
|
||||||
Shortcut result = *this;
|
Shortcut& operator=(Shortcut &&) noexcept = default;
|
||||||
result.m_keys.insert(other);
|
|
||||||
|
|
||||||
return result;
|
Shortcut operator+(const Key &other) const;
|
||||||
}
|
Shortcut &operator+=(const Key &other);
|
||||||
|
bool operator<(const Shortcut &other) const;
|
||||||
Shortcut &operator+=(const Key &other) {
|
bool operator==(const Shortcut &other) const;
|
||||||
m_keys.insert(other);
|
|
||||||
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool operator<(const Shortcut &other) const {
|
|
||||||
return m_keys < other.m_keys;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool operator==(const Shortcut &other) const {
|
|
||||||
return m_keys == other.m_keys;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool match(const Shortcut &other) const {
|
|
||||||
auto left = m_keys;
|
|
||||||
auto right = other.m_keys;
|
|
||||||
|
|
||||||
left.erase(AllowWhileTyping);
|
|
||||||
right.erase(AllowWhileTyping);
|
|
||||||
left.erase(CurrentView);
|
|
||||||
right.erase(CurrentView);
|
|
||||||
|
|
||||||
return left == right;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool isLocal() const {
|
|
||||||
return m_keys.contains(CurrentView);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool allowWhileTyping() const {
|
|
||||||
return m_keys.contains(AllowWhileTyping);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
bool isLocal() const;
|
||||||
std::string toString() const;
|
std::string toString() const;
|
||||||
|
const std::set<Key>& getKeys() const;
|
||||||
const std::set<Key>& getKeys() const { return m_keys; }
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
friend Shortcut operator+(const Key &lhs, const Key &rhs);
|
friend Shortcut operator+(const Key &lhs, const Key &rhs);
|
||||||
@ -225,12 +188,7 @@ namespace hex {
|
|||||||
std::set<Key> m_keys;
|
std::set<Key> m_keys;
|
||||||
};
|
};
|
||||||
|
|
||||||
inline Shortcut operator+(const Key &lhs, const Key &rhs) {
|
Shortcut operator+(const Key &lhs, const Key &rhs);
|
||||||
Shortcut result;
|
|
||||||
result.m_keys = { lhs, rhs };
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief The ShortcutManager handles global and view-specific shortcuts.
|
* @brief The ShortcutManager handles global and view-specific shortcuts.
|
||||||
@ -300,7 +258,7 @@ namespace hex {
|
|||||||
[[nodiscard]] static std::vector<ShortcutEntry> getGlobalShortcuts();
|
[[nodiscard]] static std::vector<ShortcutEntry> getGlobalShortcuts();
|
||||||
[[nodiscard]] static std::vector<ShortcutEntry> getViewShortcuts(const View *view);
|
[[nodiscard]] static std::vector<ShortcutEntry> getViewShortcuts(const View *view);
|
||||||
|
|
||||||
[[nodiscard]] static bool updateShortcut(const Shortcut &oldShortcut, const Shortcut &newShortcut, View *view = nullptr);
|
[[nodiscard]] static bool updateShortcut(Shortcut oldShortcut, Shortcut newShortcut, View *view = nullptr);
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
@ -15,6 +15,47 @@ namespace hex {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Shortcut operator+(const Key &lhs, const Key &rhs) {
|
||||||
|
Shortcut result;
|
||||||
|
result.m_keys = { lhs, rhs };
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
Shortcut::Shortcut(Keys key) : m_keys({ key }) {
|
||||||
|
|
||||||
|
}
|
||||||
|
Shortcut::Shortcut(std::set<Key> keys) : m_keys(std::move(keys)) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
Shortcut Shortcut::operator+(const Key &other) const {
|
||||||
|
Shortcut result = *this;
|
||||||
|
result.m_keys.insert(other);
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
Shortcut& Shortcut::operator+=(const Key &other) {
|
||||||
|
m_keys.insert(other);
|
||||||
|
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Shortcut::operator<(const Shortcut &other) const {
|
||||||
|
return m_keys < other.m_keys;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Shortcut::operator==(const Shortcut &other) const {
|
||||||
|
return m_keys == other.m_keys;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Shortcut::isLocal() const {
|
||||||
|
return m_keys.contains(CurrentView);
|
||||||
|
}
|
||||||
|
|
||||||
|
const std::set<Key>& Shortcut::getKeys() const { return m_keys; }
|
||||||
|
|
||||||
std::string Shortcut::toString() const {
|
std::string Shortcut::toString() const {
|
||||||
std::string result;
|
std::string result;
|
||||||
|
|
||||||
@ -169,11 +210,11 @@ namespace hex {
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
result += " + ";
|
result += Concatination;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (result.ends_with(" + "))
|
if (result.ends_with(Concatination))
|
||||||
result = result.substr(0, result.size() - 3);
|
result = result.substr(0, result.size() - strlen(Concatination));
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@ -216,6 +257,8 @@ namespace hex {
|
|||||||
pressedShortcut += SUPER;
|
pressedShortcut += SUPER;
|
||||||
if (focused)
|
if (focused)
|
||||||
pressedShortcut += CurrentView;
|
pressedShortcut += CurrentView;
|
||||||
|
if (ImGui::GetIO().WantTextInput)
|
||||||
|
pressedShortcut += AllowWhileTyping;
|
||||||
|
|
||||||
pressedShortcut += static_cast<Keys>(keyCode);
|
pressedShortcut += static_cast<Keys>(keyCode);
|
||||||
|
|
||||||
@ -228,13 +271,11 @@ namespace hex {
|
|||||||
if (ImGui::IsPopupOpen(ImGuiID(0), ImGuiPopupFlags_AnyPopupId))
|
if (ImGui::IsPopupOpen(ImGuiID(0), ImGuiPopupFlags_AnyPopupId))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
for (const auto &[potentialShortcut, entry] : shortcuts) {
|
if (auto it = shortcuts.find(shortcut); it != shortcuts.end()) {
|
||||||
if (potentialShortcut.match(shortcut)) {
|
const auto &[foundShortcut, entry] = *it;
|
||||||
if (!ImGui::GetIO().WantTextInput || potentialShortcut.allowWhileTyping())
|
|
||||||
entry.callback();
|
entry.callback();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void ShortcutManager::process(const View *currentView, bool ctrl, bool alt, bool shift, bool super, bool focused, u32 keyCode) {
|
void ShortcutManager::process(const View *currentView, bool ctrl, bool alt, bool shift, bool super, bool focused, u32 keyCode) {
|
||||||
const Shortcut pressedShortcut = getShortcut(ctrl, alt, shift, super, focused, keyCode);
|
const Shortcut pressedShortcut = getShortcut(ctrl, alt, shift, super, focused, keyCode);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user