mirror of https://github.com/procxx/kepka.git
Added ability to open folders with shortcuts.
This commit is contained in:
parent
49e286b04c
commit
09bc3eefdb
|
@ -295,6 +295,8 @@ bool Manager::readCustomFile() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void Manager::fillDefaults() {
|
void Manager::fillDefaults() {
|
||||||
|
const auto ctrl = Platform::IsMac() ? qsl("meta") : qsl("ctrl");
|
||||||
|
|
||||||
set(qsl("ctrl+w"), Command::Close);
|
set(qsl("ctrl+w"), Command::Close);
|
||||||
set(qsl("ctrl+f4"), Command::Close);
|
set(qsl("ctrl+f4"), Command::Close);
|
||||||
set(qsl("ctrl+l"), Command::Lock);
|
set(qsl("ctrl+l"), Command::Lock);
|
||||||
|
@ -316,15 +318,11 @@ void Manager::fillDefaults() {
|
||||||
set(qsl("alt+down"), Command::ChatNext);
|
set(qsl("alt+down"), Command::ChatNext);
|
||||||
set(qsl("ctrl+pgup"), Command::ChatPrevious);
|
set(qsl("ctrl+pgup"), Command::ChatPrevious);
|
||||||
set(qsl("alt+up"), Command::ChatPrevious);
|
set(qsl("alt+up"), Command::ChatPrevious);
|
||||||
if (Platform::IsMac()) {
|
|
||||||
set(qsl("meta+tab"), Command::ChatNext);
|
set(qsl("%1+tab").arg(ctrl), Command::ChatNext);
|
||||||
set(qsl("meta+shift+tab"), Command::ChatPrevious);
|
set(qsl("%1+shift+tab").arg(ctrl), Command::ChatPrevious);
|
||||||
set(qsl("meta+backtab"), Command::ChatPrevious);
|
set(qsl("%1+backtab").arg(ctrl), Command::ChatPrevious);
|
||||||
} else {
|
|
||||||
set(qsl("ctrl+tab"), Command::ChatNext);
|
|
||||||
set(qsl("ctrl+shift+tab"), Command::ChatPrevious);
|
|
||||||
set(qsl("ctrl+backtab"), Command::ChatPrevious);
|
|
||||||
}
|
|
||||||
set(qsl("ctrl+alt+home"), Command::ChatFirst);
|
set(qsl("ctrl+alt+home"), Command::ChatFirst);
|
||||||
set(qsl("ctrl+alt+end"), Command::ChatLast);
|
set(qsl("ctrl+alt+end"), Command::ChatLast);
|
||||||
|
|
||||||
|
@ -340,6 +338,14 @@ void Manager::fillDefaults() {
|
||||||
set(qsl("ctrl+4"), Command::ChatPinned4);
|
set(qsl("ctrl+4"), Command::ChatPinned4);
|
||||||
set(qsl("ctrl+5"), Command::ChatPinned5);
|
set(qsl("ctrl+5"), Command::ChatPinned5);
|
||||||
|
|
||||||
|
auto &&folders = ranges::view::zip(
|
||||||
|
kShowFolder,
|
||||||
|
ranges::view::ints(1, ranges::unreachable));
|
||||||
|
|
||||||
|
for (const auto [command, index] : folders) {
|
||||||
|
set(qsl("%1+shift+%2").arg(ctrl).arg(index > 9 ? 0 : index), command);
|
||||||
|
}
|
||||||
|
|
||||||
set(qsl("ctrl+0"), Command::ChatSelf);
|
set(qsl("ctrl+0"), Command::ChatSelf);
|
||||||
|
|
||||||
set(qsl("ctrl+9"), Command::ShowArchive);
|
set(qsl("ctrl+9"), Command::ShowArchive);
|
||||||
|
|
|
@ -35,6 +35,17 @@ enum class Command {
|
||||||
ChatPinned4,
|
ChatPinned4,
|
||||||
ChatPinned5,
|
ChatPinned5,
|
||||||
|
|
||||||
|
ShowFolder1,
|
||||||
|
ShowFolder2,
|
||||||
|
ShowFolder3,
|
||||||
|
ShowFolder4,
|
||||||
|
ShowFolder5,
|
||||||
|
ShowFolder6,
|
||||||
|
ShowFolder7,
|
||||||
|
ShowFolder8,
|
||||||
|
ShowFolder9,
|
||||||
|
ShowFolder10,
|
||||||
|
|
||||||
ShowArchive,
|
ShowArchive,
|
||||||
|
|
||||||
JustSendMessage,
|
JustSendMessage,
|
||||||
|
@ -48,6 +59,19 @@ enum class Command {
|
||||||
SupportHistoryForward,
|
SupportHistoryForward,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
constexpr auto kShowFolder = {
|
||||||
|
Command::ShowFolder1,
|
||||||
|
Command::ShowFolder2,
|
||||||
|
Command::ShowFolder3,
|
||||||
|
Command::ShowFolder4,
|
||||||
|
Command::ShowFolder5,
|
||||||
|
Command::ShowFolder6,
|
||||||
|
Command::ShowFolder7,
|
||||||
|
Command::ShowFolder8,
|
||||||
|
Command::ShowFolder9,
|
||||||
|
Command::ShowFolder10,
|
||||||
|
};
|
||||||
|
|
||||||
[[nodiscard]] FnMut<bool()> RequestHandler(Command command);
|
[[nodiscard]] FnMut<bool()> RequestHandler(Command command);
|
||||||
|
|
||||||
class Request {
|
class Request {
|
||||||
|
|
|
@ -3034,6 +3034,25 @@ void InnerWidget::setupShortcuts() {
|
||||||
return jumpToDialogRow({ row->key(), FullMsgId() });
|
return jumpToDialogRow({ row->key(), FullMsgId() });
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
auto &&folders = ranges::view::zip(
|
||||||
|
Shortcuts::kShowFolder,
|
||||||
|
ranges::view::ints(0, ranges::unreachable));
|
||||||
|
|
||||||
|
for (const auto [command, index] : folders) {
|
||||||
|
request->check(command) && request->handle([=, index = index] {
|
||||||
|
const auto list = &session().data().chatsFilters().list();
|
||||||
|
if (index >= list->size()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
const auto filterId = list->at(index).id();
|
||||||
|
_controller->setActiveChatsFilter((filterId == _filterId)
|
||||||
|
? 0
|
||||||
|
: filterId);
|
||||||
|
return true;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
if (session().supportMode() && row.key.history()) {
|
if (session().supportMode() && row.key.history()) {
|
||||||
request->check(
|
request->check(
|
||||||
Command::SupportScrollToCurrent
|
Command::SupportScrollToCurrent
|
||||||
|
|
Loading…
Reference in New Issue