/* This file is part of the KDE libraries Copyright (C) 1999 Reginald Stadlbauer (C) 1999 Simon Hausmann (C) 2000 Nicolas Hadacek (C) 2000 Kurt Granroth (C) 2000 Michael Koch (C) 2001 Holger Freyther (C) 2002 Ellis Whitehead (C) 2003 Andras Mantia (C) 2005-2006 Hamish Rodda This library is free software; you can redistribute it and/or modify it under the terms of the GNU Library General Public License version 2 as published by the Free Software Foundation. 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 KPASTETEXTACTION_H #define KPASTETEXTACTION_H #include class KPasteTextActionPrivate; /** * An action for pasting text from the clipboard. * It's useful for text handling applications as * when plugged into a toolbar it provides a menu * with the clipboard history if klipper is running. * If klipper is not running, the menu has only one * item: the current clipboard content. */ class KDEUI_EXPORT KPasteTextAction: public KAction { Q_OBJECT public: /** * Constructs an action with the specified parent. * * @param parent The parent of this action. */ explicit KPasteTextAction(QObject *parent); /** * Constructs an action with text; a shortcut may be specified by * the ampersand character (e.g. \"&Option\" creates a shortcut with key \e O ) * * This is the most common KAction used when you do not have a * corresponding icon (note that it won't appear in the current version * of the "Edit ToolBar" dialog, because an action needs an icon to be * plugged in a toolbar...). * * @param text The text that will be displayed. * @param parent The parent of this action. */ KPasteTextAction(const QString &text, QObject *parent); /** * Constructs an action with text and an icon; a shortcut may be specified by * the ampersand character (e.g. \"&Option\" creates a shortcut with key \e O ) * * This is the other common KAction used. Use it when you * \e do have a corresponding icon. * * @param icon The icon to display. * @param text The text that will be displayed. * @param parent The parent of this action. */ KPasteTextAction(const KIcon &icon, const QString &text, QObject *parent); virtual ~KPasteTextAction(); /** * Controls the behavior of the clipboard history menu popup. * * @param mode If false and the clipboard contains a non-text object * the popup menu with the clipboard history will appear * immediately as the user clicks the toolbar action; if * true, the action works like the standard paste action * even if the current clipboard object is not text. * Default value is true. */ void setMixedMode(bool mode); private: KPasteTextActionPrivate * const d; Q_PRIVATE_SLOT( d, void _k_menuAboutToShow() ) Q_PRIVATE_SLOT( d, void _k_slotTriggered(QAction*) ) }; #endif