/* 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 KTOGGLETOOLBARACTION_H #define KTOGGLETOOLBARACTION_H #include class KToolBar; /** * An action that takes care of everything associated with * showing or hiding a toolbar by a menu action. It will * show or hide the toolbar with the given name when * activated, and check or uncheck itself if the toolbar * is manually shown or hidden. * * If you need to perfom some additional action when the * toolbar is shown or hidden, connect to the toggled(bool) * signal. It will be emitted after the toolbar's * visibility has changed, whenever it changes. */ class KDEUI_EXPORT KToggleToolBarAction : public KToggleAction { Q_OBJECT public: /** * Create a KToggleToolbarAction that manages the toolbar * named toolBarName. This can be either the name of a * toolbar in an xml ui file, or a toolbar programmatically * created with that name. * * @param The action's parent object. */ KToggleToolBarAction(const char* toolBarName, const QString& text, QObject *parent); /** * Create a KToggleToolbarAction that manages the @param toolBar. * This can be either the name of a toolbar in an xml ui file, * or a toolbar programmatically created with that name. * * @param toolBar the toolbar to be managed * @param parent The action's parent object. */ KToggleToolBarAction(KToolBar *toolBar, const QString &text, QObject *parent); /** * Destroys toggle toolbar action. */ virtual ~KToggleToolBarAction(); /** * Returns a pointer to the tool bar it manages. */ KToolBar *toolBar(); /** * Reimplemented from @see QObject. */ virtual bool eventFilter( QObject* watched, QEvent* event ); private Q_SLOTS: virtual void slotToggled( bool checked ); private: class Private; Private* const d; }; #endif