/***************************************************************** KWin - the KDE window manager This file is part of the KDE project. Copyright (C) 1999, 2000 Matthias Ettrich Copyright (C) 2003 Lubos Lunak You can Freely distribute this program under the GNU General Public License. See the file "COPYING" for the exact licensing terms. ******************************************************************/ #ifndef KWIN_TABBOX_H #define KWIN_TABBOX_H #include #include #include "utils.h" class QLabel; namespace KWinInternal { class Workspace; class Client; class TabBox : public QFrame { Q_OBJECT public: TabBox( Workspace *ws ); ~TabBox(); Client* currentClient(); int currentDesktop(); // DesktopMode and WindowsMode are based on the order in which the desktop // or window were viewed. // DesktopListMode lists them in the order created. enum Mode { DesktopMode, DesktopListMode, WindowsMode }; void setMode( Mode mode ); Mode mode() const; void reset( bool partial_reset = false ); void nextPrev( bool next = true); void delayedShow(); void hide(); void handleMouseEvent( XEvent* ); Workspace* workspace() const; void reconfigure(); void updateKeyMapping(); protected: void showEvent( QShowEvent* ); void hideEvent( QHideEvent* ); void paintEvent( QPaintEvent* ); private: void createClientList(ClientList &list, int desktop /*-1 = all*/, Client *start, bool chain); private: Client* client; Mode m; Workspace* wspace; ClientList clients; int desk; int lineHeight; bool showMiniIcon; QTimer delayedShowTimer; QString no_tasks; bool options_traverse_all; }; /*! Returns the tab box' workspace */ inline Workspace* TabBox::workspace() const { return wspace; } /*! Returns the current mode, either DesktopListMode or WindowsMode \sa setMode() */ inline TabBox::Mode TabBox::mode() const { return m; } } // namespace #endif