From 43dbeb02b85e5cd75c89a780409c46008cae9ba4 Mon Sep 17 00:00:00 2001 From: David Capello Date: Tue, 9 Sep 2014 23:42:47 -0300 Subject: [PATCH] Some fixes to the FileSelector * Enter pad should behave like the regular Enter key * Added navigation with Ctrl (or Cmd) + arrow keys --- src/app/ui/file_list.cpp | 16 +++++++-- src/app/ui/file_selector.cpp | 70 +++++++++++++++++++++++------------- src/app/ui/file_selector.h | 4 +++ 3 files changed, 62 insertions(+), 28 deletions(-) diff --git a/src/app/ui/file_list.cpp b/src/app/ui/file_list.cpp index 047f23ee0..4f0882fad 100644 --- a/src/app/ui/file_list.cpp +++ b/src/app/ui/file_list.cpp @@ -175,24 +175,29 @@ bool FileList::onProcessMessage(Message* msg) int bottom = m_list.size(); switch (scancode) { + case kKeyUp: if (select >= 0) select--; else select = 0; break; + case kKeyDown: if (select >= 0) select++; else select = 0; break; + case kKeyHome: select = 0; break; + case kKeyEnd: select = bottom-1; break; + case kKeyPageUp: case kKeyPageDown: { int sgn = (scancode == kKeyPageUp) ? -1: 1; @@ -202,6 +207,7 @@ bool FileList::onProcessMessage(Message* msg) select += sgn * vp.h / (getTextHeight()+4*jguiscale()); break; } + case kKeyLeft: case kKeyRight: if (select >= 0) { @@ -212,14 +218,16 @@ bool FileList::onProcessMessage(Message* msg) view->setViewScroll(scroll); } break; + case kKeyEnter: + case kKeyEnterPad: if (m_selected) { if (m_selected->isBrowsable()) { setCurrentFolder(m_selected); return true; } if (m_selected->isFolder()) { - // Do nothing (is a folder but not browseable. + // Do nothing (is a folder but not browseable). return true; } else { @@ -230,15 +238,17 @@ bool FileList::onProcessMessage(Message* msg) } else return Widget::onProcessMessage(msg); + case kKeyBackspace: goUp(); return true; + default: if (unicodeChar == ' ' || (utolower(unicodeChar) >= 'a' && utolower(unicodeChar) <= 'z') || - (utolower(unicodeChar) >= '0' && - utolower(unicodeChar) <= '9')) { + (unicodeChar >= '0' && + unicodeChar <= '9')) { if (ui::clock() - m_isearchClock > ISEARCH_KEYPRESS_INTERVAL_MSECS) m_isearch.clear(); diff --git a/src/app/ui/file_selector.cpp b/src/app/ui/file_selector.cpp index 592465f5d..35374632f 100644 --- a/src/app/ui/file_selector.cpp +++ b/src/app/ui/file_selector.cpp @@ -115,12 +115,6 @@ protected: virtual bool onProcessMessage(Message* msg) override { if (msg->type() == kKeyUpMessage && static_cast(msg)->unicodeChar() >= 32) { - // Check if all keys are released - for (int c=0; cgetFileList(); - for (FileItemList::const_iterator - it=children.begin(); it!=children.end(); ++it) { - IFileItem* child = *it; + for (IFileItem* child : children) { std::string child_name = child->getDisplayName(); - std::string::iterator it1, it2; for (it1 = child_name.begin(), it2 = left_part.begin(); - it1!=child_name.end() && it2!=left_part.end(); + it1 != child_name.end() && it2 != left_part.end(); ++it1, ++it2) { if (std::tolower(*it1) != std::tolower(*it2)) break; @@ -146,7 +137,6 @@ protected: if (it2 == left_part.end()) { setText(left_part + child_name.substr(left_part.size())); selectText(child_name.size(), left_part.size()); - clear_keybuf(); return true; } } @@ -259,6 +249,13 @@ FileSelector::FileSelector() m_fileList->FileSelected.connect(Bind(&FileSelector::onFileListFileSelected, this)); m_fileList->FileAccepted.connect(Bind(&FileSelector::onFileListFileAccepted, this)); m_fileList->CurrentFolderChanged.connect(Bind(&FileSelector::onFileListCurrentFolderChanged, this)); + + getManager()->addMessageFilter(kKeyDownMessage, this); +} + +FileSelector::~FileSelector() +{ + getManager()->removeMessageFilter(kKeyDownMessage, this); } std::string FileSelector::show(const std::string& title, @@ -367,7 +364,7 @@ again: std::string fn = m_fileName->getText(); std::string buf; - IFileItem* enter_folder = NULL; + IFileItem* enter_folder = m_fileList->getSelectedFileItem(); // up a level? if (fn == "..") { @@ -375,7 +372,12 @@ again: if (!enter_folder) enter_folder = folder; } - else if (!fn.empty()) { + else if (fn.empty()) { + // show the window again + setVisible(true); + goto again; + } + else { // check if the user specified in "fn" a item of "fileview" const FileItemList& children = m_fileList->getFileList(); @@ -384,16 +386,14 @@ again: fn2 = base::string_to_lower(fn2); #endif - for (FileItemList::const_iterator - it=children.begin(); it!=children.end(); ++it) { - IFileItem* child = *it; + for (IFileItem* child : children) { std::string child_name = child->getDisplayName(); #ifdef WIN32 child_name = base::string_to_lower(child_name); #endif if (child_name == fn2) { - enter_folder = *it; + enter_folder = child; buf = enter_folder->getFileName(); break; } @@ -437,11 +437,6 @@ again: enter_folder = fs->getFileItemFromPath(buf); } } - else { - // show the window again - setVisible(true); - goto again; - } // did we find a folder to enter? if (enter_folder && @@ -478,6 +473,31 @@ again: return result; } +bool FileSelector::onProcessMessage(ui::Message* msg) +{ + switch (msg->type()) { + case kKeyDownMessage: + if (msg->ctrlPressed() || msg->cmdPressed()) { + KeyMessage* keyMsg = static_cast(msg); + KeyScancode scancode = keyMsg->scancode(); + switch (scancode) { + case kKeyUp: onGoUp(); return true; + case kKeyLeft: onGoBack(); return true; + case kKeyRight: onGoForward(); return true; + case kKeyDown: + if (m_fileList->getSelectedFileItem() && + m_fileList->getSelectedFileItem()->isBrowsable()) { + m_fileList->setCurrentFolder( + m_fileList->getSelectedFileItem()); + } + return true; + } + } + break; + } + return Window::onProcessMessage(msg); +} + // Updates the content of the combo-box that shows the current // location in the file-system. void FileSelector::updateLocation() @@ -701,7 +721,7 @@ void FileSelector::onFileTypeChange() if (!currentExtension.empty()) { m_fileName->setText((fileName.substr(0, fileName.size()-currentExtension.size())+newExtension).c_str()); - m_fileName->selectText(0, -1); + m_fileName->selectAllText(); } } @@ -713,7 +733,7 @@ void FileSelector::onFileListFileSelected() std::string filename = base::get_file_name(fileitem->getFileName()); m_fileName->setText(filename.c_str()); - m_fileName->selectText(0, -1); + m_fileName->selectAllText(); selectFileTypeFromFileName(); } } diff --git a/src/app/ui/file_selector.h b/src/app/ui/file_selector.h index 6bed1a2d9..27e264584 100644 --- a/src/app/ui/file_selector.h +++ b/src/app/ui/file_selector.h @@ -39,12 +39,16 @@ namespace app { class FileSelector : public ui::Window { public: FileSelector(); + ~FileSelector(); // Shows the dialog to select a file in the program. std::string show(const std::string& title, const std::string& initialPath, const std::string& showExtensions); + protected: + bool onProcessMessage(ui::Message* msg) override; + private: void updateLocation(); void updateNavigationButtons();