File indexing completed on 2024-09-15 12:00:41
0001 /* 0002 This file is part of the KDE libraries 0003 SPDX-FileCopyrightText: 2016 Kai Uwe Broulik <kde@privat.broulik.de> 0004 0005 SPDX-License-Identifier: LGPL-2.0-or-later 0006 */ 0007 0008 #ifndef OPENFILEMANAGERWINDOWJOB_H 0009 #define OPENFILEMANAGERWINDOWJOB_H 0010 0011 #include "kiowidgets_export.h" 0012 0013 #include <KJob> 0014 0015 #include <QList> 0016 #include <QUrl> 0017 0018 #include <memory> 0019 0020 namespace KIO 0021 { 0022 class OpenFileManagerWindowJobPrivate; 0023 0024 /** 0025 * @class KIO::OpenFileManagerWindowJob openfilemanagerwindowjob.h <KIO/OpenFileManagerWindowJob> 0026 * 0027 * @brief Open a File Manager Window 0028 * 0029 * Using this job you can open a file manager window and highlight specific 0030 * files within a folder. This can be useful if you downloaded a file and want 0031 * to present it to the user without the user having to manually search the 0032 * file in its parent folder. This can also be used for a "Show in Parent Folder" 0033 * functionality. 0034 * 0035 * On Linux, this job will use the org.freedesktop.FileManager1 interface to highlight 0036 * the files and/or folders. If this fails, the parent directory of the first URL 0037 * will be opened in the default file manager instead. 0038 * 0039 * Note that this job is really only about highlighting certain items 0040 * which means if you, for example, pass it just a URL to a folder it will 0041 * not open this particular folder but instead highlight it within its parent folder. 0042 * 0043 * If you just want to open a folder, use OpenUrlJob instead. 0044 * 0045 * @since 5.24 0046 */ 0047 class KIOWIDGETS_EXPORT OpenFileManagerWindowJob : public KJob 0048 { 0049 Q_OBJECT 0050 0051 public: 0052 /** 0053 * Creates an OpenFileManagerWindowJob 0054 */ 0055 explicit OpenFileManagerWindowJob(QObject *parent = nullptr); 0056 0057 /** 0058 * Destroys the OpenFileManagerWindowJob 0059 */ 0060 ~OpenFileManagerWindowJob() override; 0061 0062 /** 0063 * Errors the job may emit 0064 */ 0065 enum Errors { 0066 NoValidUrlsError = KJob::UserDefinedError, ///< No valid URLs to highlight have been specified 0067 LaunchFailedError, ///< Failed to launch the file manager 0068 }; 0069 0070 /** 0071 * The files and/or folders to highlight 0072 */ 0073 QList<QUrl> highlightUrls() const; 0074 0075 /** 0076 * Set the files and/or folders to highlight 0077 */ 0078 void setHighlightUrls(const QList<QUrl> &highlightUrls); 0079 0080 /** 0081 * The Startup ID 0082 */ 0083 QByteArray startupId() const; 0084 0085 /** 0086 * Sets the platform-specific startup id of the file manager launch. 0087 * @param startupId startup id, if any (otherwise ""). 0088 * For X11, this would be the id for the Startup Notification protocol. 0089 * For Wayland, this would be the token for the XDG Activation protocol. 0090 */ 0091 void setStartupId(const QByteArray &startupId); 0092 0093 /** 0094 * Starts the job 0095 */ 0096 void start() override; 0097 0098 private: 0099 friend class AbstractOpenFileManagerWindowStrategy; 0100 friend class OpenFileManagerWindowDBusStrategy; 0101 friend class OpenFileManagerWindowKRunStrategy; 0102 0103 std::unique_ptr<OpenFileManagerWindowJobPrivate> const d; 0104 }; 0105 0106 /** 0107 * Convenience method for creating a job to highlight a certain file or folder. 0108 * 0109 * It will create a job for a given URL(s) and automatically start it. 0110 * 0111 * @since 5.24 0112 */ 0113 KIOWIDGETS_EXPORT OpenFileManagerWindowJob *highlightInFileManager(const QList<QUrl> &urls, const QByteArray &asn = QByteArray()); 0114 0115 } // namespace KIO 0116 0117 #endif // OPENFILEMANAGERWINDOWJOB_H