mirror of
https://bitbucket.org/smil3y/kdelibs.git
synced 2025-02-24 02:42:48 +00:00
156 lines
6.3 KiB
C++
156 lines
6.3 KiB
C++
/* This file is part of the KDE project
|
|
Copyright (C) 1998-2009 David Faure <faure@kde.org>
|
|
|
|
This library is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU Library General Public License as published
|
|
by the Free Software Foundation; either version 2 of the License or
|
|
( at your option ) version 3 or, at the discretion of KDE e.V.
|
|
( which shall act as a proxy as in section 14 of the GPLv3 ), any later version.
|
|
|
|
This library 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
|
|
Library General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Library General Public License
|
|
along with this library; see the file COPYING.LIB. If not, write to
|
|
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
Boston, MA 02110-1301, USA.
|
|
*/
|
|
|
|
#ifndef KFILEITEMACTIONS_H
|
|
#define KFILEITEMACTIONS_H
|
|
|
|
#include <kservice.h>
|
|
#include <kfileitem.h>
|
|
#include <kio/kio_export.h>
|
|
#include <QMenu>
|
|
|
|
class KFileItemListProperties;
|
|
class KAction;
|
|
class KFileItemActionsPrivate;
|
|
|
|
/**
|
|
* This class creates and handles the actions for a url (or urls) in a popupmenu.
|
|
*
|
|
* This includes:
|
|
* @li "open with <application>" actions, but also
|
|
* @li builtin services like mount/unmount for old-style device desktop files
|
|
* @li user-defined actions for a .desktop file, defined in the file itself (see the desktop entry standard)
|
|
* @li servicemenus actions, defined in .desktop files and selected based on the mimetype of the url
|
|
*
|
|
* @since 4.3
|
|
*/
|
|
class KIO_EXPORT KFileItemActions : public QObject
|
|
{
|
|
Q_OBJECT
|
|
public:
|
|
/**
|
|
* Creates a KFileItemActions instance.
|
|
* Note that this instance must stay alive for at least as long as the popupmenu;
|
|
* it has the slots for the actions created by addOpenWithActionsTo/addServiceActionsTo.
|
|
*/
|
|
KFileItemActions(QObject* parent = 0);
|
|
|
|
/**
|
|
* Destructor
|
|
*/
|
|
~KFileItemActions();
|
|
|
|
/**
|
|
* Sets all the data for the next instance of the popupmenu.
|
|
* @see KFileItemListProperties
|
|
*/
|
|
void setItemListProperties(const KFileItemListProperties& itemList);
|
|
|
|
/**
|
|
* Set the parent widget for any dialogs being shown.
|
|
*
|
|
* This should normally be your mainwindow, not a popup menu,
|
|
* so that it still exists even after the popup is closed
|
|
* (e.g. error message from KRun) and so that QAction::setStatusTip
|
|
* can find a statusbar, too.
|
|
*/
|
|
void setParentWidget(QWidget* widget);
|
|
|
|
/**
|
|
* Generate the "Open With <Application>" actions, and adds them to the @p menu.
|
|
* All actions are created as children of the menu.
|
|
* @param menu the QMenu where to add actions
|
|
* @param traderConstraint this constraint allows to exclude the current application
|
|
* from the "open with" list. Example: "DesktopEntryName != 'dolphin'".
|
|
* (Default value added in kdelibs-4.5, pass QString() explicitely for earlier versions).
|
|
*/
|
|
void addOpenWithActionsTo(QMenu* menu, const QString& traderConstraint = QString());
|
|
|
|
/**
|
|
* Returns an action for the preferred application only.
|
|
* @param traderConstraint this constraint allows to exclude the current application
|
|
* from the "open with" list. Example: "DesktopEntryName != 'dolphin'".
|
|
* @return the action - or 0 if no application was found.
|
|
*/
|
|
KAction* preferredOpenWithAction(const QString& traderConstraint);
|
|
|
|
/**
|
|
* Helper method used internally, can also be used for similar GUIs that
|
|
* show the list of associated applications.
|
|
*
|
|
* This is basically a KMimeTypeTrader::query, but it supports multiple mimetypes, and
|
|
* also cleans up "apparent" duplicates, such as the kde3 and kde4 applications with the same name.
|
|
*
|
|
* The list is sorted according to the user preferences for the given mimetype(s).
|
|
* In case multiple mimetypes appear in the url list, the logic is:
|
|
* applications that on average appear earlier on the associated applications
|
|
* list for the given mimetypes also appear earlier on the final applications list.
|
|
*
|
|
* Note that for a single mimetype there is no need to use this, you should use
|
|
* KMimeTypeTrader instead, e.g. query() or preferredService().
|
|
*
|
|
* Returns the applications associated with all the given mimetypes.
|
|
* @param mimeTypeList the mimetypes
|
|
* @param traderConstraint this optional constraint allows to exclude the current application
|
|
* from the "open with" list. Example: "DesktopEntryName != 'dolphin'".
|
|
* @return the sorted list of services.
|
|
* @since 4.4
|
|
*/
|
|
static KService::List associatedApplications(const QStringList& mimeTypeList, const QString& traderConstraint);
|
|
|
|
/**
|
|
* Generate the user-defined actions and submenus, and adds them to the @p menu.
|
|
* User-defined actions include:
|
|
* - builtin services like mount/unmount for old-style device desktop files
|
|
* - user-defined actions for a .desktop file, defined in the file itself (see the desktop entry standard)
|
|
* - servicemenus actions, defined in .desktop files and selected based on the mimetype of the url
|
|
*
|
|
* When KFileItemListProperties::supportsWriting() is false, actions that modify the files are not shown.
|
|
* This is controlled by Require=Write in the servicemenu desktop files.
|
|
*
|
|
* All actions are created as children of the menu.
|
|
* @return the number of actions added
|
|
*/
|
|
int addServiceActionsTo(QMenu* menu);
|
|
|
|
Q_SIGNALS:
|
|
/**
|
|
* Emitted before the "Open With" dialog is shown
|
|
* This is used e.g in folderview to close the folder peek popups on invoking the "Open With" menu action
|
|
* @since 4.8.2
|
|
*/
|
|
void openWithDialogAboutToBeShown();
|
|
|
|
public Q_SLOTS:
|
|
/**
|
|
* Slot used to execute a list of files in their respective preferred application.
|
|
* @param fileOpenList the list of KFileItems to open.
|
|
* @param traderConstraint this optional constraint allows to exclude the current application
|
|
* @since 4.5
|
|
*/
|
|
void runPreferredApplications(const KFileItemList& fileOpenList, const QString& traderConstraint);
|
|
|
|
private:
|
|
KFileItemActionsPrivate* const d;
|
|
friend class KFileItemActionsPrivate;
|
|
};
|
|
|
|
#endif /* KFILEITEMACTIONS_H */
|
|
|