/* This file is part of the KDE project SPDX-FileCopyrightText: 2022 Felix Ernst SPDX-License-Identifier: LGPL-2.1-only OR LGPL-3.0-only OR LicenseRef-KDE-Accepted-LGPL */ #ifndef BOTTOMBAR_H #define BOTTOMBAR_H #include "animatedheightwidget.h" #include "global.h" #include #include class KActionCollection; class KFileItemList; class QPushButton; class QResizeEvent; class QUrl; namespace SelectionMode { class BottomBarContentsContainer; /** * @brief A bar used in selection mode that serves various purposes depending on what the user is currently trying to do. * * The Contents enum below gives a rough idea about the different states this bar might have. * The bar is notified of various changes that make changing or updating the content worthwhile. * * The visible contents of the bar are managed in BottomBarContentsContainer. This class serves as a wrapper around it. */ class BottomBar : public AnimatedHeightWidget { Q_OBJECT public: /** The different contents this bar can have. */ enum Contents { CopyContents, CopyLocationContents, CopyToOtherViewContents, CutContents, DeleteContents, DuplicateContents, GeneralContents, MoveToOtherViewContents, MoveToTrashContents, PasteContents, RenameContents }; /** * @param actionCollection the collection this bar retrieves its actions from * @param parent the parent widget. Typically a DolphinViewContainer */ explicit BottomBar(KActionCollection *actionCollection, QWidget *parent); /** * Plays a show or hide animation while changing visibility. * Therefore, if this method is used to hide this widget, the actual hiding will be postponed until the animation finished. * * This bar might also not show itself when setVisible(true), when context menu actions are supposed to be shown * for the selected items but no items have been selected yet. In that case it will only show itself once items were selected. * * This bar might also ignore a setVisible(false) call, if it has PasteContents because that bar is supposed to stay visible * even outside of selection mode. * * @param visible Whether this bar is supposed to be visible long term * @param animated Whether this should be animated. The animation is skipped if the users' settings are configured that way. * * @see AnimatedHeightWidget::setVisible() * @see QWidget::setVisible() */ void setVisible(bool visible, Animated animated); /** * Changes the contents of the bar to @p contents. */ void resetContents(Contents contents); Contents contents() const; public Q_SLOTS: /** Adapts the contents based on the selection in the related view. */ void slotSelectionChanged(const KFileItemList &selection, const QUrl &baseUrl); /** Used to notify the m_selectionModeBottomBar that there is no other ViewContainer in the tab. */ void slotSplitTabDisabled(); Q_SIGNALS: /** * Forwards the errors from the KFileItemAction::error() used for contextual actions. */ void error(const QString &errorMessage); void selectionModeLeavingRequested(); protected: /** Is installed on an internal widget to make sure that the height of the bar is adjusted to its contents. */ bool eventFilter(QObject *watched, QEvent *event) override; /** Adapts the way the contents of this bar are displayed based on the available width. */ void resizeEvent(QResizeEvent *resizeEvent) override; private: /** * Identical to SelectionModeBottomBar::setVisible() but doesn't change m_allowedToBeVisible. * @see SelectionModeBottomBar::setVisible() * @see m_allowedToBeVisible */ void setVisibleInternal(bool visible, Animated animated); /** @see AnimatedHeightWidget::preferredHeight() */ int preferredHeight() const override; private: /** The only direct grandchild of this bar. */ BottomBarContentsContainer *m_contentsContainer; /** Remembers if this bar was setVisible(true) or setVisible(false) the last time. * This is necessary because this bar might have been setVisible(true) but there is no reason to show the bar currently so it was kept hidden. * @see SelectionModeBottomBar::setVisible() */ bool m_allowedToBeVisible = false; }; } #endif // BOTTOMBAR_H