-/***************************************************************************
- * Copyright (C) 2009-2010 by Peter Penz <peter.penz19@gmail.com> *
- * *
- * This program is free software; you can redistribute it and/or modify *
- * it under the terms of the GNU General Public License as published by *
- * the Free Software Foundation; either version 2 of the License, or *
- * (at your option) any later version. *
- * *
- * This program is distributed in the hope that it will be useful, *
- * but WITHOUT ANY WARRANTY; without even the implied warranty of *
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
- * GNU General Public License for more details. *
- * *
- * You should have received a copy of the GNU General Public License *
- * along with this program; if not, write to the *
- * Free Software Foundation, Inc., *
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *
- ***************************************************************************/
+/*
+ * SPDX-FileCopyrightText: 2009-2010 Peter Penz <peter.penz19@gmail.com>
+ *
+ * SPDX-License-Identifier: GPL-2.0-or-later
+ */
#ifndef INFORMATIONPANELCONTENT_H
#define INFORMATIONPANELCONTENT_H
+#include "config-dolphin.h"
#include <KFileItem>
-#include <config-baloo.h>
#include <QPointer>
#include <QUrl>
#include <QWidget>
class KFileItemList;
-class PhononWidget;
+class MediaWidget;
class PixmapViewer;
-class PlacesItemModel;
class QPixmap;
+class QDialogButtonBox;
class QString;
class QLabel;
class QScrollArea;
+class QGestureEvent;
-namespace KIO {
- class PreviewJob;
+namespace KIO
+{
+class PreviewJob;
}
-#ifndef HAVE_BALOO
-class KFileMetaDataWidget;
-#else
-namespace Baloo {
- class FileMetaDataWidget;
+namespace Baloo
+{
+class FileMetaDataWidget;
}
-#endif
/**
* @brief Manages the widgets that display the meta information
Q_OBJECT
public:
- explicit InformationPanelContent(QWidget* parent = nullptr);
+ explicit InformationPanelContent(QWidget *parent = nullptr);
~InformationPanelContent() override;
/**
* The preview of the item is generated asynchronously,
* the other meta information are fetched synchronously.
*/
- void showItem(const KFileItem& item);
+ void showItem(const KFileItem &item);
+
+ /**
+ * Shows the meta information for the items \p items and its preview
+ */
+ void showItems(const KFileItemList &items);
+
+ KFileItemList items();
/**
- * Shows the meta information for the items \p items.
+ * Refreshes the preview display, hiding it if needed
*/
- void showItems(const KFileItemList& items);
+ void refreshPreview();
/**
- * Opens a menu which allows to configure which meta information
- * should be shown.
- *
- * TODO: Move this code to the class InformationPanel
+ * Switch the metadatawidget into configuration mode
*/
- void configureSettings(const QList<QAction*>& customContextMenuActions);
+ void configureShownProperties();
-signals:
- void urlActivated( const QUrl& url );
+ /*
+ * Set the auto play media mode for the file previewed
+ * Eventually starting media playback when turning it on
+ * But not stopping it when turning it off
+ */
+ void setPreviewAutoPlay(bool autoPlay);
+
+Q_SIGNALS:
+ void urlActivated(const QUrl &url);
+ void configurationFinished();
+ void contextMenuRequested(const QPoint &pos);
+
+public Q_SLOTS:
+ /**
+ * Is invoked after the file meta data configuration dialog has been
+ * closed and refreshes the displayed meta data by the panel.
+ */
+ void refreshMetaData();
protected:
/** @see QObject::eventFilter() */
- bool eventFilter(QObject* obj, QEvent* event) override;
+ bool eventFilter(QObject *obj, QEvent *event) override;
+
+ bool event(QEvent *event) override;
-private slots:
+private Q_SLOTS:
/**
* Is invoked if no preview is available for the item. In this
* case the icon will be shown.
*/
- void showIcon(const KFileItem& item);
+ void showIcon(const KFileItem &item);
/**
* Is invoked if a preview is available for the item. The preview
* \a pixmap is shown inside the info page.
*/
- void showPreview(const KFileItem& item, const QPixmap& pixmap);
+ void showPreview(const KFileItem &item, const QPixmap &pixmap);
/**
* Marks the currently shown preview as outdated
void slotHasVideoChanged(bool hasVideo);
- /**
- * Is invoked after the file meta data configuration dialog has been
- * closed and refreshes the visibility of the meta data.
- */
- void refreshMetaData();
-
private:
/**
* Sets the text for the label \a m_nameLabel and assures that the
* label width (QLabel::setWordWrap() does not work if the
* text represents one extremely long word).
*/
- void setNameLabelText(const QString& text);
+ void setNameLabelText(const QString &text);
/**
* Adjusts the sizes of the widgets dependent on the available
*/
void adjustWidgetSizes(int width);
+ /**
+ * Refreshes the image in the PixmapViewer
+ */
+ void refreshPixmapView();
+
+ bool gestureEvent(QGestureEvent *event);
+
private:
KFileItem m_item;
QPointer<KIO::PreviewJob> m_previewJob;
- QTimer* m_outdatedPreviewTimer;
-
- PixmapViewer* m_preview;
- PhononWidget* m_phononWidget;
- QLabel* m_nameLabel;
-#ifndef HAVE_BALOO
- KFileMetaDataWidget* m_metaDataWidget;
-#else
- Baloo::FileMetaDataWidget* m_metaDataWidget;
-#endif
- QScrollArea* m_metaDataArea;
-
- PlacesItemModel* m_placesItemModel;
+ QTimer *m_outdatedPreviewTimer;
+
+ PixmapViewer *m_preview;
+ MediaWidget *m_mediaWidget;
+ QLabel *m_nameLabel;
+ Baloo::FileMetaDataWidget *m_metaDataWidget;
+ QScrollArea *m_metaDataArea;
+ QLabel *m_configureLabel;
+ QDialogButtonBox *m_configureButtons;
+
+ bool m_isVideo;
};
#endif // INFORMATIONPANELCONTENT_H