Summary:
Applied suggested changes to [[ https://phabricator.kde.org/D9662 | D9662 ]]
- Enum instead of bool
- Use QStringLiteral
Test Plan: Visual inspection
Reviewers: ngraham, elvisangelaccio, #dolphin
Reviewed By: ngraham, #dolphin
Subscribers: #dolphin
Tags: #dolphin, #kde_applications
Differential Revision: https://phabricator.kde.org/D9911
void FoldersPanel::reloadTree()
{
if (m_controller) {
void FoldersPanel::reloadTree()
{
if (m_controller) {
+ loadTree(url(), AllowJumpHome);
anim->setDuration(200);
}
anim->setDuration(200);
}
-void FoldersPanel::loadTree(const QUrl& url, bool allowJumpHome)
+void FoldersPanel::loadTree(const QUrl& url, FoldersPanel::NavigationBehaviour navigationBehaviour)
{
Q_ASSERT(m_controller);
{
Q_ASSERT(m_controller);
if (!url.isLocalFile()) {
// Clear the path for non-local URLs and use it as base
baseUrl = url;
if (!url.isLocalFile()) {
// Clear the path for non-local URLs and use it as base
baseUrl = url;
- baseUrl.setPath(QString('/'));
+ baseUrl.setPath(QStringLiteral("/"));
} else if (Dolphin::homeUrl().isParentOf(url) || (Dolphin::homeUrl() == url)) {
if (FoldersPanelSettings::limitFoldersPanelToHome() ) {
baseUrl = Dolphin::homeUrl();
} else if (Dolphin::homeUrl().isParentOf(url) || (Dolphin::homeUrl() == url)) {
if (FoldersPanelSettings::limitFoldersPanelToHome() ) {
baseUrl = Dolphin::homeUrl();
// Use the root directory as base for local URLs (#150941)
baseUrl = QUrl::fromLocalFile(QDir::rootPath());
}
// Use the root directory as base for local URLs (#150941)
baseUrl = QUrl::fromLocalFile(QDir::rootPath());
}
- } else if (FoldersPanelSettings::limitFoldersPanelToHome() && allowJumpHome) {
+ } else if (FoldersPanelSettings::limitFoldersPanelToHome() && navigationBehaviour == AllowJumpHome) {
baseUrl = Dolphin::homeUrl();
jumpHome = true;
} else {
baseUrl = Dolphin::homeUrl();
jumpHome = true;
} else {
}
const int index = m_model->index(url);
}
const int index = m_model->index(url);
- if (jumpHome == true) {
emit folderActivated(baseUrl);
} else if (index >= 0) {
updateCurrentItem(index);
emit folderActivated(baseUrl);
} else if (index >= 0) {
updateCurrentItem(index);
+ /**
+ * Indicate if it is allowed to leave current location.
+ */
+ enum NavigationBehaviour {
+ StayWhereYouAre, ///< Don't leave current location.
+ AllowJumpHome ///< Go Home only when context menu option got checked.
+ };
/**
* Initializes the base URL of the tree and expands all
* directories until \a url.
* @param url URL of the leaf directory that should get expanded.
/**
* Initializes the base URL of the tree and expands all
* directories until \a url.
* @param url URL of the leaf directory that should get expanded.
- * @param allowJumpHome indicate context menu got checked.
+ * @param navigationBehaviour Navigation behaviour \see NavigationBehaviour
- void loadTree(const QUrl& url, bool allowJumpHome = false);
+ void loadTree(const QUrl& url, NavigationBehaviour navigationBehaviour = StayWhereYouAre);