kdelibs/kio/kio/kfileitemactions.h
Ivailo Monev 1988ee1c94 kio: indent switch cases in KIO::JobUiDelegate::askDeleteConfirmation()
Signed-off-by: Ivailo Monev <xakepa10@gmail.com>
2022-06-03 16:12:22 +03:00

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 */