/* This file is part of the KDE libraries Copyright (C) 1999,2000 Kurt Granroth <granroth@kde.org> Copyright (C) 2001,2002 Ellis Whitehead <ellis@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 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 KSTDACTION_H #define KSTDACTION_H class TQObject; class TQWidget; class TDEAction; class TDEActionCollection; class TDERecentFilesAction; class TDEToggleAction; class TDEToggleToolBarAction; class TDEToggleFullScreenAction; #include <tqstringlist.h> #include <tdelibs_export.h> /** * Convenience methods to access all standard KDE actions. * * These actions should be used instead of hardcoding menubar and * toolbar items. Using these actions helps your application easily * conform to the KDE UI Style Guide * @see http://developer.kde.org/documentation/standards/kde/style/basics/index.html . * * All of the documentation for TDEAction holds for KStdAction * also. When in doubt on how things work, check the TDEAction * documention first. * * <b>Simple Example:</b>\n * * In general, using standard actions should be a drop in replacement * for regular actions. For example, if you previously had: * * \code * TDEAction *newAct = new TDEAction(i18n("&New"), TQIconSet(BarIcon("document-new")), * TDEStdAccel::shortcut(TDEStdAccel::New), this, * TQT_SLOT(fileNew()), actionCollection()); * \endcode * * You could drop that and replace it with: * * \code * TDEAction *newAct = KStdAction::openNew(this, TQT_SLOT(fileNew()), * actionCollection()); * \endcode * * <b>Non-standard Usages</b>\n * * It is possible to use the standard actions in various * non-recommended ways. Say, for instance, you wanted to have a * standard action (with the associated correct text and icon and * accelerator, etc) but you didn't want it to go in the standard * place (this is not recommended, by the way). One way to do this is * to simply not use the XML UI framework and plug it into wherever * you want. If you do want to use the XML UI framework (good!), then * it is still possible. * * Basically, the XML building code matches names in the XML code with * the internal names of the actions. You can find out the internal * names of each of the standard actions by using the stdName * action like so: KStdAction::stdName(KStdAction::Cut) would return * 'edit_cut'. The XML building code will match 'edit_cut' to the * attribute in the global XML file and place your action there. * * However, you can change the internal name. In this example, just * do something like: * * \code * (void)KStdAction::cut(this, TQT_SLOT(editCut()), actionCollection(), "my_cut"); * \endcode * * Now, in your local XML resource file (e.g., yourappui.rc), simply * put 'my_cut' where you want it to go. * * Another non-standard usage concerns getting a pointer to an * existing action if, say, you want to enable or disable the action. * You could do it the recommended way and just grab a pointer when * you instantiate it as in the the 'openNew' example above... or you * could do it the hard way: * * \code * TDEAction *cut = actionCollection()->action(KStdAction::stdName(KStdAction::Cut)); * \endcode * * Another non-standard usage concerns instantiating the action in the * first place. Usually, you would use the member functions as * shown above (e.g., KStdAction::cut(this, SLOT, parent)). You * may, however, do this using the enums provided. This author can't * think of a reason why you would want to, but, hey, if you do, * here's how: * * \code * (void)KStdAction::action(KStdAction::New, this, TQT_SLOT(fileNew()), actionCollection()); * (void)KStdAction::action(KStdAction::Cut, this, TQT_SLOT(editCut()), actionCollection()); * \endcode * * @author Kurt Granroth <granroth@kde.org> */ namespace KStdAction { /** * The standard menubar and toolbar actions. */ enum StdAction { ActionNone, // File Menu New, Open, OpenRecent, Save, SaveAs, Revert, Close, Print, PrintPreview, Mail, Quit, // Edit Menu Undo, Redo, Cut, Copy, Paste, SelectAll, Deselect, Find, FindNext, FindPrev, Replace, // View Menu ActualSize, FitToPage, FitToWidth, FitToHeight, ZoomIn, ZoomOut, Zoom, Redisplay, // Go Menu Up, Back, Forward, Home, Prior, Next, Goto, GotoPage, GotoLine, FirstPage, LastPage, // Bookmarks Menu AddBookmark, EditBookmarks, // Tools Menu Spelling, // Settings Menu ShowMenubar, ShowToolbar, ShowStatusbar, SaveOptions, KeyBindings, Preferences, ConfigureToolbars, // Help Menu Help, HelpContents, WhatsThis, ReportBug, AboutApp, AboutKDE, TipofDay, ///< @since 3.1 // Another settings menu item ConfigureNotifications, FullScreen, ///< @since 3.2 Clear, ///< @since 3.2 PasteText, ///< @since 3.2 SwitchApplicationLanguage ///< @since 3.5.8 }; /** * Creates an action corresponding to the * KStdAction::StdAction enum. */ TDEUI_EXPORT TDEAction* create( StdAction id, const char *name, const TQObject *recvr, const char *slot, TDEActionCollection* parent ); inline TDEAction* create( StdAction id, const TQObject *recvr, const char *slot, TDEActionCollection* parent ) { return KStdAction::create( id, 0, recvr, slot, parent ); } /** * @obsolete. Creates an action corresponding to the * KStdAction::StdAction enum. */ inline TDEAction *action(StdAction act_enum, const TQObject *recvr, const char *slot, TDEActionCollection *parent, const char *name = 0L ) { return KStdAction::create( act_enum, name, recvr, slot, parent ); } /** * This will return the internal name of a given standard action. */ TDEUI_EXPORT const char* name( StdAction id ); /// @obsolete. Use name() inline const char* stdName(StdAction act_enum) { return name( act_enum ); } /** * Returns a list of all standard names. Used by TDEAccelManager * to give those heigher weight. * @since 3.1 */ TDEUI_EXPORT TQStringList stdNames(); /** * Create a new document or window. */ TDEUI_EXPORT TDEAction *openNew(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Open an existing file. */ TDEUI_EXPORT TDEAction *open(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Open a recently used document. The signature of the slot being called * is of the form slotURLSelected( const KURL & ). * @param recvr object to receive slot * @param slot The TQT_SLOT to invoke when a URL is selected. The slot's * signature is slotURLSelected( const KURL & ). * @param parent parent widget * @param name name of widget */ TDEUI_EXPORT TDERecentFilesAction *openRecent(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Save the current document. */ TDEUI_EXPORT TDEAction *save(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Save the current document under a different name. */ TDEUI_EXPORT TDEAction *saveAs(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Revert the current document to the last saved version * (essentially will undo all changes). */ TDEUI_EXPORT TDEAction *revert(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Close the current document. */ TDEUI_EXPORT TDEAction *close(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Print the current document. */ TDEUI_EXPORT TDEAction *print(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Show a print preview of the current document. */ TDEUI_EXPORT TDEAction *printPreview(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Mail this document. */ TDEUI_EXPORT TDEAction *mail(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Quit the program. */ TDEUI_EXPORT TDEAction *quit(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Undo the last operation. */ TDEUI_EXPORT TDEAction *undo(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Redo the last operation. */ TDEUI_EXPORT TDEAction *redo(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Cut selected area and store it in the clipboard. */ TDEUI_EXPORT TDEAction *cut(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Copy the selected area into the clipboard. */ TDEUI_EXPORT TDEAction *copy(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Paste the contents of clipboard at the current mouse or cursor * position. */ TDEUI_EXPORT TDEAction *paste(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Paste the contents of clipboard at the current mouse or cursor * position. Provide a button on the toolbar with the clipboard history * menu if Klipper is running. * @since 3.2 */ TDEUI_EXPORT TDEAction *pasteText(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Clear the content of the focus widget * @since 3.2 */ TDEUI_EXPORT TDEAction *clear(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Select all elements in the current document. */ TDEUI_EXPORT TDEAction *selectAll(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Deselect any selected elements in the current document. */ TDEUI_EXPORT TDEAction *deselect(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Initiate a 'find' request in the current document. */ TDEUI_EXPORT TDEAction *find(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Find the next instance of a stored 'find'. */ TDEUI_EXPORT TDEAction *findNext(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Find a previous instance of a stored 'find'. */ TDEUI_EXPORT TDEAction *findPrev(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Find and replace matches. */ TDEUI_EXPORT TDEAction *replace(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * View the document at its actual size. */ TDEUI_EXPORT TDEAction *actualSize(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Fit the document view to the size of the current window. */ TDEUI_EXPORT TDEAction *fitToPage(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Fit the document view to the width of the current window. */ TDEUI_EXPORT TDEAction *fitToWidth(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Fit the document view to the height of the current window. */ TDEUI_EXPORT TDEAction *fitToHeight(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Zoom in. */ TDEUI_EXPORT TDEAction *zoomIn(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Zoom out. */ TDEUI_EXPORT TDEAction *zoomOut(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Popup a zoom dialog. */ TDEUI_EXPORT TDEAction *zoom(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Redisplay or redraw the document. */ TDEUI_EXPORT TDEAction *redisplay(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Move up (web style menu). */ TDEUI_EXPORT TDEAction *up(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Move back (web style menu). */ TDEUI_EXPORT TDEAction *back(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Move forward (web style menu). */ TDEUI_EXPORT TDEAction *forward(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Go to the "Home" position or document. */ TDEUI_EXPORT TDEAction *home(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Scroll up one page. */ TDEUI_EXPORT TDEAction *prior(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Scroll down one page. */ TDEUI_EXPORT TDEAction *next(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Go to somewhere in general. */ TDEUI_EXPORT TDEAction *goTo(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Go to a specific page (dialog). */ TDEUI_EXPORT TDEAction *gotoPage(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Go to a specific line (dialog). */ TDEUI_EXPORT TDEAction *gotoLine(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Jump to the first page. */ TDEUI_EXPORT TDEAction *firstPage(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Jump to the last page. */ TDEUI_EXPORT TDEAction *lastPage(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Add the current page to the bookmarks tree. */ TDEUI_EXPORT TDEAction *addBookmark(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Edit the application bookmarks. */ TDEUI_EXPORT TDEAction *editBookmarks(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Pop up the spell checker. */ TDEUI_EXPORT TDEAction *spelling(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Show/Hide the menubar. */ TDEUI_EXPORT TDEToggleAction *showMenubar(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * @obsolete. toolbar actions are created automatically now in the * Settings menu. Don't use this anymore. * See: TDEMainWindow::createStandardStatusBarAction() * Show/Hide the primary toolbar. * @since 3.1 */ TDEUI_EXPORT TDEToggleAction *showToolbar(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ) KDE_DEPRECATED; /** * @obsolete. toolbar actions are created automatically now in the * Settings menu. Don't use this anymore. * See: TDEMainWindow::setStandardToolBarMenuEnabled(bool); * Show/Hide the primary toolbar. */ TDEUI_EXPORT TDEToggleToolBarAction *showToolbar(const char* toolBarName, TDEActionCollection* parent, const char *name = 0 ) KDE_DEPRECATED; /** * Show/Hide the statusbar. */ TDEUI_EXPORT TDEToggleAction *showStatusbar(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Switch to/from full screen mode * @since 3.2 */ TDEUI_EXPORT TDEToggleFullScreenAction *fullScreen(const TQObject *recvr, const char *slot, TDEActionCollection* parent, TQWidget* window, const char *name = 0 ); /** * Display the save options dialog. */ TDEUI_EXPORT TDEAction *saveOptions(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Display the configure key bindings dialog. * * Note that you might be able to use the pre-built KXMLGUIFactory's fuction: * KStdAction::keyBindings(guiFactory(), TQT_SLOT(configureShortcuts()), actionCollection()); */ TDEUI_EXPORT TDEAction *keyBindings(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Display the preferences/options dialog. */ TDEUI_EXPORT TDEAction *preferences(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * The Customize Toolbar dialog. */ TDEUI_EXPORT TDEAction *configureToolbars(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * The Configure Notifications dialog. * @since 3.1 */ TDEUI_EXPORT TDEAction *configureNotifications(const TQObject *recvr, const char *slot, TDEActionCollection *parent, const char *name = 0); /** * Display the help. */ TDEUI_EXPORT TDEAction *help(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Display the help contents. */ TDEUI_EXPORT TDEAction *helpContents(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Trigger the What's This cursor. */ TDEUI_EXPORT TDEAction *whatsThis(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Display "Tip of the Day" * @since 3.1 */ TDEUI_EXPORT TDEAction *tipOfDay(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Open up the Report Bug dialog. */ TDEUI_EXPORT TDEAction *reportBug(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Display the application's About box. */ TDEUI_EXPORT TDEAction *aboutApp(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Display the About KDE dialog. */ TDEUI_EXPORT TDEAction *aboutKDE(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); /** * Display "Switch application language" dialog. * @since 3.5.8 */ TDEUI_EXPORT TDEAction *switchApplicationLanguage(const TQObject *recvr, const char *slot, TDEActionCollection* parent, const char *name = 0 ); } #endif // KSTDACTION_H