summaryrefslogtreecommitdiffstats
path: root/kutils/kmultitabbar.h
diff options
context:
space:
mode:
Diffstat (limited to 'kutils/kmultitabbar.h')
-rw-r--r--kutils/kmultitabbar.h316
1 files changed, 0 insertions, 316 deletions
diff --git a/kutils/kmultitabbar.h b/kutils/kmultitabbar.h
deleted file mode 100644
index ffc3fca5f..000000000
--- a/kutils/kmultitabbar.h
+++ /dev/null
@@ -1,316 +0,0 @@
-/***************************************************************************
- kmultitabbar.h - description
- -------------------
- begin : 2001
- copyright : (C) 2001,2002,2003 by Joseph Wenninger <jowenn@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) 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 _KMultitabbar_h_
-#define _KMultitabbar_h_
-
-#include <tqscrollview.h>
-#include <tqvbox.h>
-#include <tqhbox.h>
-#include <tqlayout.h>
-#include <tqstring.h>
-#include <tqptrlist.h>
-#include <tqpushbutton.h>
-
-#include <tdelibs_export.h>
-
-class TQPixmap;
-class TQPainter;
-class TQFrame;
-
-class KMultiTabBarPrivate;
-class KMultiTabBarTabPrivate;
-class KMultiTabBarButtonPrivate;
-class KMultiTabBarInternal;
-
-/**
- * @ingroup main
- * @ingroup multitabbar
- * A Widget for horizontal and vertical tabs.
- * It is possible to add normal buttons to the top/left
- * The handling if only one tab at a time or multiple tabs
- * should be raisable is left to the "user".
- *@author Joseph Wenninger
- */
-class KUTILS_EXPORT KMultiTabBar: public TQWidget
-{
- Q_OBJECT
-public:
- /**
- * The tab bar's orientation. Also constraints the bar's position.
- */
- enum KMultiTabBarMode {
- Horizontal, ///< Horizontal orientation (i.e. on top or bottom)
- Vertical ///< Vertical orientation (i.e. on the left or right hand side)
- };
-
- /**
- * The tab bar's position
- */
- enum KMultiTabBarPosition {
- Left, ///< Left hand side
- Right, ///< Right hand side
- Top, ///< On top
- Bottom ///< On bottom
- };
-
- /**
- * The list of available styles for KMultiTabBar
- */
- enum KMultiTabBarStyle {
- VSNET=0, ///< Visual Studio .Net like (only show the text of active tabs)
- KDEV3=1, ///< KDevelop 3 like (always show the text)
- KONQSBC=2, ///< Konqueror's classic sidebar style (unthemed) (currently disabled)
- KDEV3ICON=3, ///< KDevelop 3 like with icons
- STYLELAST=0xffff ///< Last style
- };
-
- /**
- * Constructor.
- * @param bm The tab bar's orientation
- * @param parent The parent widget
- * @param name The widget's name
- */
- KMultiTabBar(KMultiTabBarMode bm,TQWidget *parent=0,const char *name=0);
-
- /**
- * Destructor.
- */
- virtual ~KMultiTabBar();
-
- /**
- * append a new button to the button area. The button can later on be accessed with button(ID)
- * eg for connecting signals to it
- * @param pic a pixmap for the button
- * @param id an arbitraty ID value. It will be emitted in the clicked signal for identifying the button
- * if more than one button is connected to a signals.
- * @param popup A popup menu which should be displayed if the button is clicked
- * @param not_used_yet will be used for a popup text in the future
- */
- int appendButton(const TQPixmap &pic,int id=-1,TQPopupMenu* popup=0,const TQString& not_used_yet=TQString::null);
- /**
- * remove a button with the given ID
- */
- void removeButton(int id);
- /**
- * append a new tab to the tab area. It can be accessed lateron with tabb(id);
- * @param pic a bitmap for the tab
- * @param id an arbitrary ID which can be used later on to identify the tab
- * @param text if a mode with text is used it will be the tab text, otherwise a mouse over hint
- * @return Always zero. Can be safely ignored.
- */
- int appendTab(const TQPixmap &pic,int id=-1,const TQString& text=TQString::null);
- /**
- * remove a tab with a given ID
- * @param id The ID of the tab to remove
- */
- void removeTab(int id);
- /**
- * set a tab to "raised"
- * @param id The ID of the tab to manipulate
- * @param state true == activated/raised, false == not active
- */
- void setTab(int id ,bool state);
- /**
- * return the state of a tab, identified by it's ID
- * @param id The ID of the tab to raise
- */
- bool isTabRaised(int id) const;
- /**
- * get a pointer to a button within the button area identified by its ID
- * @param id The id of the tab
- */
- class KMultiTabBarButton *button(int id) const;
-
- /**
- * get a pointer to a tab within the tab area, identified by its ID
- */
- class KMultiTabBarTab *tab(int id) const;
- /**
- * set the real position of the widget.
- * @param pos if the mode is horizontal, only use top, bottom, if it is vertical use left or right
- */
- void setPosition(KMultiTabBarPosition pos);
- /**
- * get the tabbar position.
- * @return The tab bar's position
- */
- KMultiTabBarPosition position() const;
- /**
- * set the display style of the tabs
- * @param style The new display style
- */
- void setStyle(KMultiTabBarStyle style);
- /**
- * get the display style of the tabs
- * @return display style
- */
- KMultiTabBarStyle tabStyle() const;
- /**
- * Returns the list of pointers to the tabs of type KMultiTabBarTab.
- * @return The list of tabs.
- * @warning be careful, don't delete tabs yourself and don't delete the list itself
- */
- TQPtrList<KMultiTabBarTab>* tabs();
- /**
- * Returns the list of pointers to the tab buttons of type KMultiTabBarButton.
- * @return The list of tab buttons.
- * @warning be careful, don't delete buttons yourself and don't delete the list itself
- */
- TQPtrList<KMultiTabBarButton>* buttons();
-
- /**
- * might vanish, not sure yet
- */
- void showActiveTabTexts(bool show=true);
-protected:
- friend class KMultiTabBarButton;
- virtual void fontChange( const TQFont& );
- void updateSeparator();
-private:
- class KMultiTabBarInternal *m_internal;
- TQBoxLayout *m_l;
- TQFrame *m_btnTabSep;
- TQPtrList<KMultiTabBarButton> m_buttons;
- KMultiTabBarPosition m_position;
- KMultiTabBarPrivate *d;
-};
-
-/**
- * @ingroup multitabbar
- * This class represents a tab bar button in a KMultiTabBarWidget.
- * This class should never be created except with the appendButton call of KMultiTabBar
- */
-class KUTILS_EXPORT KMultiTabBarButton: public TQPushButton
-{
- Q_OBJECT
-public:
- /** @internal */
- KMultiTabBarButton(const TQPixmap& pic,const TQString&, TQPopupMenu *popup,
- int id,TQWidget *parent, KMultiTabBar::KMultiTabBarPosition pos, KMultiTabBar::KMultiTabBarStyle style);
- /** @internal */
- KMultiTabBarButton(const TQString&, TQPopupMenu *popup,
- int id,TQWidget *parent, KMultiTabBar::KMultiTabBarPosition pos, KMultiTabBar::KMultiTabBarStyle style);
- /**
- * Destructor
- */
- virtual ~KMultiTabBarButton();
- /**
- * Returns the tab's ID
- * @return The tab's ID
- */
- int id() const;
-
-public slots:
- /**
- * this is used internaly, but can be used by the user, if (s)he wants to
- * It the according call of KMultiTabBar is invoked though this modifications will be overwritten
- */
- void setPosition(KMultiTabBar::KMultiTabBarPosition);
- /**
- * this is used internaly, but can be used by the user, if (s)he wants to
- * It the according call of KMultiTabBar is invoked though this modifications will be overwritten
- */
- void setStyle(KMultiTabBar::KMultiTabBarStyle);
-
- /**
- * modify the text of the button
- */
- void setText(const TQString &);
-
- TQSize sizeHint() const;
-
-protected:
- KMultiTabBar::KMultiTabBarPosition m_position;
- KMultiTabBar::KMultiTabBarStyle m_style;
- TQString m_text;
- virtual void hideEvent( class TQHideEvent*);
- virtual void showEvent( class TQShowEvent*);
-private:
- int m_id;
- KMultiTabBarButtonPrivate *d;
-signals:
- /**
- * this is emitted if the button is clicked
- * @param id the ID identifying the button
- */
- void clicked(int id);
-protected slots:
- virtual void slotClicked();
-};
-
-/**
- * @ingroup multitabbar
- * This class represents a tab bar's tab in a KMultiTabBarWidget.
- * This class should never be created except with the appendTab call of KMultiTabBar
- */
-class KUTILS_EXPORT KMultiTabBarTab: public KMultiTabBarButton
-{
- Q_OBJECT
-public:
- /** @internal */
- KMultiTabBarTab(const TQPixmap& pic,const TQString&,int id,TQWidget *parent,
- KMultiTabBar::KMultiTabBarPosition pos,KMultiTabBar::KMultiTabBarStyle style);
- /**
- * Destructor.
- */
- virtual ~KMultiTabBarTab();
- /**
- * set the active state of the tab
- * @param state @c true if the tab should become active, @c false otherwise
- */
- void setState(bool state);
- /**
- * choose if the text should always be displayed
- * this is only used in classic mode if at all
- * @param show Whether or not to show the text
- */
- void showActiveTabText(bool show);
- /**
- * Resized the tab to the needed size.
- */
- void resize(){ setSize( neededSize() ); }
-private:
- bool m_showActiveTabText;
- int m_expandedSize;
- KMultiTabBarTabPrivate *d;
-protected:
- friend class KMultiTabBarInternal;
- void setSize(int);
- int neededSize();
- void updateState();
- virtual void drawButton(TQPainter *);
- virtual void drawButtonLabel(TQPainter *);
- void drawButtonStyled(TQPainter *);
- void drawButtonClassic(TQPainter *);
-protected slots:
- virtual void slotClicked();
- void setTabsPosition(KMultiTabBar::KMultiTabBarPosition);
-
-public slots:
- virtual void setIcon(const TQString&);
- virtual void setIcon(const TQPixmap&);
-};
-
-#endif