/*
This file is part of the KDE project
- SPDX-FileCopyrightText: 2020 Felix Ernst <fe.a.ernst@gmail.com>
+ SPDX-FileCopyrightText: 2020 Felix Ernst <felixernst@kde.org>
SPDX-License-Identifier: LGPL-2.1-only OR LGPL-3.0-only OR LicenseRef-KDE-Accepted-LGPL
*/
#ifndef DOLPHINURLNAVIGATOR_H
#define DOLPHINURLNAVIGATOR_H
-#include <KCompletion>
#include <KUrlNavigator>
-#include <forward_list>
-
-class KToggleAction;
-
/**
- * @brief Extends KUrlNavigator in a Dolphin-specific way
+ * @brief Extends KUrlNavigator in a Dolphin-specific way.
*
- * Makes sure that Dolphin preferences, settings and settings changes are
+ * Makes sure that Dolphin preferences and settings are
* applied to all constructed DolphinUrlNavigators.
- *
* @see KUrlNavigator
+ *
+ * To apply changes to all instances of this class @see DolphinUrlNavigatorsController.
*/
class DolphinUrlNavigator : public KUrlNavigator
{
*/
DolphinUrlNavigator(const QUrl &url, QWidget *parent = nullptr);
- virtual ~DolphinUrlNavigator();
+ ~DolphinUrlNavigator() override;
- /**
- * This method is needed so the DolphinNavigatorWidgetAction knows when there is not enough
- * space to neatly align the UrlNavigator with the ViewContainers. Unfortunately KUrlNavigator
- * does not have a useful sizeHint() currently. It would make more sense to change
- * KUrlNavigator instead.
- */
+ // TODO: Fix KUrlNavigator::sizeHint() instead.
QSize sizeHint() const override;
/**
/**
* Retrieve the visual state of this DolphinUrlNavigator.
* If two DolphinUrlNavigators have the same visual state they should look identical.
+ *
+ * @return a copy of the visualState of this object. Ownership of this copy is transferred
+ * to the caller via std::unique_ptr.
*/
std::unique_ptr<VisualState> visualState() const;
/**
*/
void setVisualState(const VisualState &visualState);
-public slots:
/**
- * Refreshes all DolphinUrlNavigators to get synchronized with the
- * Dolphin settings if they were changed.
+ * Clears the text in the text field
*/
- static void slotReadSettings();
+ void clearText() const;
/**
- * Switches to "breadcrumb" mode if the editable mode is not set to be
- * preferred in the Dolphin settings.
+ * Displays placeholder text in the URL navigator
*/
- void slotReturnPressed();
+ void setPlaceholderText(const QString &text);
- static void slotPlacesPanelVisibilityChanged(bool visible);
+ /**
+ * Sets the visibility of the read-only badge at the end of the breadcrumb.
+ */
+ void setReadOnlyBadgeVisible(bool visible);
-protected:
/**
- * Constructor-helper function
+ * Returns the visibility of the read-only badge at the end of the breadcrumb.
*/
- void init();
+ bool readOnlyBadgeVisible() const;
-protected slots:
+public Q_SLOTS:
/**
- * Sets the completion mode for all DolphinUrlNavigators
- * and saves it in settings.
+ * Switches to "breadcrumb" mode if the editable mode is not set to be
+ * preferred in the Dolphin settings.
*/
- static void setCompletionMode(const KCompletion::CompletionMode completionMode);
+ void slotReturnPressed();
-protected:
- /** Contains all currently constructed DolphinUrlNavigators */
- static std::forward_list<DolphinUrlNavigator *> s_instances;
+Q_SIGNALS:
+ /**
+ * Escape was pressed, and the focus should return to the view.
+ */
+ void requestToLoseFocus();
- /** Caches the (negated) places panel visibility */
- static bool s_placesSelectorVisible;
+protected:
+ /**
+ * Return focus back to the view when pressing Escape and this would have no other effect (e.g. deselecting or changing edit mode).
+ */
+ void keyPressEvent(QKeyEvent *keyEvent) override;
};
#endif // DOLPHINURLNAVIGATOR_H