summaryrefslogtreecommitdiffstats
path: root/tqtinterface/qt4/src/dialogs/tqtabdialog.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'tqtinterface/qt4/src/dialogs/tqtabdialog.cpp')
-rw-r--r--tqtinterface/qt4/src/dialogs/tqtabdialog.cpp1145
1 files changed, 0 insertions, 1145 deletions
diff --git a/tqtinterface/qt4/src/dialogs/tqtabdialog.cpp b/tqtinterface/qt4/src/dialogs/tqtabdialog.cpp
deleted file mode 100644
index fd91293..0000000
--- a/tqtinterface/qt4/src/dialogs/tqtabdialog.cpp
+++ /dev/null
@@ -1,1145 +0,0 @@
-/****************************************************************************
-**
-** Implementation of TQTabDialog class
-**
-** Created : 960825
-**
-** Copyright (C) 2010 Timothy Pearson and (C) 1992-2008 Trolltech ASA.
-**
-** This file is part of the dialogs module of the TQt GUI Toolkit.
-**
-** This file may be used under the terms of the GNU General
-** Public License versions 2.0 or 3.0 as published by the Free
-** Software Foundation and appearing in the files LICENSE.GPL2
-** and LICENSE.GPL3 included in the packaging of this file.
-** Alternatively you may (at your option) use any later version
-** of the GNU General Public License if such license has been
-** publicly approved by Trolltech ASA (or its successors, if any)
-** and the KDE Free TQt Foundation.
-**
-** Please review the following information to ensure GNU General
-** Public Licensing requirements will be met:
-** http://trolltech.com/products/qt/licenses/licensing/opensource/.
-** If you are unsure which license is appropriate for your use, please
-** review the following information:
-** http://trolltech.com/products/qt/licenses/licensing/licensingoverview
-** or contact the sales department at [email protected].
-**
-** This file may be used under the terms of the Q Public License as
-** defined by Trolltech ASA and appearing in the file LICENSE.TQPL
-** included in the packaging of this file. Licensees holding valid TQt
-** Commercial licenses may use this file in accordance with the TQt
-** Commercial License Agreement provided with the Software.
-**
-** This file is provided "AS IS" with NO WARRANTY OF ANY KIND,
-** INCLUDING THE WARRANTIES OF DESIGN, MERCHANTABILITY AND FITNESS FOR
-** A PARTICULAR PURPOSE. Trolltech reserves all rights not granted
-** herein.
-**
-**********************************************************************/
-
-#include "tqtabdialog.h"
-
-#ifndef TQT_NO_TABDIALOG
-
-#include "tqobjectlist.h"
-#include "tqtabbar.h"
-#include "tqtabwidget.h"
-#include "tqpushbutton.h"
-#include "tqpainter.h"
-#include "tqpixmap.h"
-#include "tqapplication.h"
-#include "tqtabwidget.h"
-#include "tqwidgetstack.h"
-#include "tqlayout.h"
-
-/*!
- \class TQTabDialog tqtabdialog.h
-
- \brief The TQTabDialog class provides a stack of tabbed widgets.
-
- \ingroup dialogs
- \mainclass
-
- A tabbed dialog is one in which several "tab pages" are available.
- By clicking on a tab page's tab or by pressing the indicated
- Alt+\e{letter} key combination, the user can select which tab page
- they want to use.
-
- TQTabDialog provides a tab bar consisting of single row of tabs at
- the top; each tab has an associated widget which is that tab's
- tab page. In addition, TQTabDialog provides an OK button and the
- following optional buttons: Apply, Cancel, Defaults and Help.
-
- The normal way to use TQTabDialog is to do the following in the
- constructor:
- \list 1
- \i Create a TQTabDialog.
- \i Create a TQWidget for each of the pages in the tab dialog, insert
- tqchildren into it, set up tqgeometry management for it, and use
- addTab() (or insertTab()) to set up a tab and keyboard accelerator
- for it.
- \i Set up the buttons for the tab dialog using setOkButton(),
- setApplyButton(), setDefaultsButton(), setCancelButton() and
- setHelpButton().
- \i Connect to the Q_SIGNALS and Q_SLOTS.
- \endlist
-
- If you don't call addTab() the page you have created will not be
- visible. Don't confuse the object name you supply to the
- TQWidget constructor and the tab label you supply to addTab();
- addTab() takes user-visible name that appears on the widget's tab
- and may identify an accelerator, whereas the widget name is used
- primarily for debugging.
-
- Almost all applications have to connect the applyButtonPressed()
- signal to something. applyButtonPressed() is emitted when either OK
- or Apply is clicked, and your slot must copy the dialog's state into
- the application.
-
- There are also several other Q_SIGNALS which may be useful:
- \list
- \i cancelButtonPressed() is emitted when the user clicks Cancel.
- \i defaultButtonPressed() is emitted when the user clicks Defaults;
- the slot it is connected to should reset the state of the dialog to
- the application defaults.
- \i helpButtonPressed() is emitted when the user clicks Help.
- \i aboutToShow() is emitted at the start of show(); if there is any
- chance that the state of the application may change between the
- creation of the tab dialog and the time show() is called, you must
- connect this signal to a slot that resets the state of the dialog.
- \i currentChanged() is emitted when the user selects a page.
- \endlist
-
- Each tab is either enabled or disabled at any given time (see
- setTabEnabled()). If a tab is enabled the tab text is drawn in
- black and the user can select that tab. If it is disabled the tab
- is drawn in a different way and the user cannot select that tab.
- Note that even if a tab is disabled, the page can still be visible;
- for example, if all of the tabs happen to be disabled.
-
- You can change a tab's label and iconset using changeTab(). A tab
- page can be removed with removePage() and shown with showPage(). The
- current page is given by currentPage().
-
- TQTabDialog does not support tabs on the sides or bottom, nor can
- you set or retrieve the visible page. If you need more functionality
- than TQTabDialog provides, consider creating a TQDialog and using a
- TQTabBar with TQTabWidgets.
-
- Most of the functionality in TQTabDialog is provided by a TQTabWidget.
-
- <img src=qtabdlg-m.png> <img src=qtabdlg-w.png>
-
- \sa TQDialog
-*/
-
-/*!
- \fn void TQTabDialog::selected( const TQString & );
- \obsolete
-
- This signal is emitted whenever a tab is selected (raised),
- including during the first show().
-
- \sa raise()
-*/
-
-/*! \fn void TQTabDialog::currentChanged( TQWidget* );
-
- This signal is emitted whenever the current page changes.
-
- \sa currentPage(), showPage(), tabLabel()
-*/
-
-
-// add comments about delete, ok and apply
-
-class TQTabDialogPrivate
-{
-public:
- TQTabDialogPrivate();
-
- TQTabWidget* tw;
-
- TQPushButton * ok;
- TQPushButton * cb;
- TQPushButton * db;
- TQPushButton * hb;
- TQPushButton * ab;
-
- TQBoxLayout * tll;
-};
-
-TQTabDialogPrivate::TQTabDialogPrivate()
- : tw(0),
- ok(0), cb(0), db(0), hb(0), ab(0),
- tll(0)
-{ }
-
-/*!
- Constructs a TQTabDialog with only an OK button.
- The \a parent, \a name, \a modal and widget flag, \a f, arguments
- are passed on to the TQDialog constructor.
-*/
-
-TQTabDialog::TQTabDialog( TQWidget *parent, const char *name, bool modal,
- WFlags f )
- : TQDialog( parent, name, modal, f )
-{
- d = new TQTabDialogPrivate;
- TQ_CHECK_PTR( d );
-
- d->tw = new TQTabWidget( this, "tab widget" );
- connect ( d->tw, TQT_SIGNAL ( selected(const TQString&) ), this, TQT_SIGNAL( selected(const TQString&) ) );
- connect ( d->tw, TQT_SIGNAL ( currentChanged(TQWidget*) ), this, TQT_SIGNAL( currentChanged(TQWidget*) ) );
-
- d->ok = new TQPushButton( this, "ok" );
- TQ_CHECK_PTR( d->ok );
- d->ok->setText( tr("OK") );
- d->ok->setDefault( TRUE );
- connect( d->ok, TQT_SIGNAL(clicked()),
- this, TQT_SIGNAL(applyButtonPressed()) );
- connect( d->ok, TQT_SIGNAL(clicked()),
- this, TQT_SLOT(accept()) );
-}
-
-
-/*!
- Destroys the tab dialog.
-*/
-
-TQTabDialog::~TQTabDialog()
-{
- delete d;
-}
-
-
-/*!
- Sets the font for the tabs to \a font.
-
- If the widget is visible, the display is updated with the new font
- immediately. There may be some tqgeometry changes, depending on the
- size of the old and new fonts.
-*/
-
-void TQTabDialog::setFont( const TQFont & font )
-{
- TQDialog::setFont( font );
- setSizes();
-}
-
-
-/*!
- \fn void TQTabDialog::applyButtonPressed();
-
- This signal is emitted when either the Apply or OK button is clicked.
-
- It should be connected to a slot (or several Q_SLOTS) that change the
- application's state according to the state of the dialog.
-
- \sa cancelButtonPressed() defaultButtonPressed() setApplyButton()
-*/
-
-
-/*!
- Returns TRUE if the tab dialog has a Defaults button; otherwise
- returns FALSE.
-
- \sa setDefaultButton() defaultButtonPressed() hasApplyButton()
- hasCancelButton()
-*/
-
-bool TQTabDialog::hasDefaultButton() const
-{
- return d->db != 0;
-}
-
-
-/*!
- Returns TRUE if the tab dialog has a Help button; otherwise returns
- FALSE.
-
- \sa setHelpButton() helpButtonPressed() hasApplyButton()
- hasCancelButton()
-*/
-
-bool TQTabDialog::hasHelpButton() const
-{
- return d->hb != 0;
-}
-
-
-/*!
- \fn void TQTabDialog::cancelButtonPressed();
-
- This signal is emitted when the Cancel button is clicked. It is
- automatically connected to TQDialog::reject(), which will hide the
- dialog.
-
- The Cancel button should not change the application's state at all,
- so you should generally not need to connect it to any slot.
-
- \sa applyButtonPressed() defaultButtonPressed() setCancelButton()
-*/
-
-
-/*!
- Returns TRUE if the tab dialog has a Cancel button; otherwise
- returns FALSE.
-
- \sa setCancelButton() cancelButtonPressed() hasApplyButton()
- hasDefaultButton()
-*/
-
-bool TQTabDialog::hasCancelButton() const
-{
- return d->cb != 0;
-}
-
-
-/*!
- \fn void TQTabDialog::defaultButtonPressed();
-
- This signal is emitted when the Defaults button is pressed. It
- should reset the dialog (but not the application) to the "factory
- defaults".
-
- The application's state should not be changed until the user clicks
- Apply or OK.
-
- \sa applyButtonPressed() cancelButtonPressed() setDefaultButton()
-*/
-
-
-/*!
- \fn void TQTabDialog::helpButtonPressed();
-
- This signal is emitted when the Help button is pressed. It
- could be used to present information about how to use the dialog.
-
- \sa applyButtonPressed() cancelButtonPressed() setHelpButton()
-*/
-
-
-/*!
- Returns TRUE if the tab dialog has an Apply button; otherwise
- returns FALSE.
-
- \sa setApplyButton() applyButtonPressed() hasCancelButton()
- hasDefaultButton()
-*/
-
-bool TQTabDialog::hasApplyButton() const
-{
- return d->ab != 0;
-}
-
-
-/*!
- Returns TRUE if the tab dialog has an OK button; otherwise returns
- FALSE.
-
- \sa setOkButton() hasApplyButton() hasCancelButton()
- hasDefaultButton()
-*/
-
-bool TQTabDialog::hasOkButton() const
-{
- return d->ok != 0;
-}
-
-
-/*!
- \fn void TQTabDialog::aboutToShow()
-
- This signal is emitted by show() when it is time to set the state of
- the dialog's contents. The dialog should reflect the current state
- of the application when it appears; if there is any possibility that
- the state of the application may change between the time you call
- TQTabDialog::TQTabDialog() and TQTabDialog::show(), you should set the
- dialog's state in a slot and connect this signal to it.
-
- This applies mainly to TQTabDialog objects that are kept around
- hidden, rather than being created, shown, and deleted afterwards.
-
- \sa applyButtonPressed(), show(), cancelButtonPressed()
-*/
-
-
-/*!\reimp
-*/
-void TQTabDialog::show()
-{
- // Reimplemented in order to delay show()'ing of every page
- // except the initially visible one, and in order to emit the
- // aboutToShow() signal.
- if ( tqtopLevelWidget() == this )
- d->tw->setFocus();
- emit aboutToShow();
- setSizes();
- setUpLayout();
- TQDialog::show();
-}
-
-
-/*!
- Ensures that tab page \a i is visible and appropriately sized.
-*/
-
-void TQTabDialog::showTab( int i )
-{
- d->tw->showTab( i );
-}
-
-
-/*!
- Adds another tab and page to the tab view.
-
- The new page is \a child; the tab's label is \a label.
- Note the difference between the widget name (which you supply to
- widget constructors and to setTabEnabled(), for example) and the tab
- label. The name is internal to the program and invariant, whereas
- the label is shown on-screen and may vary according to language and
- other factors.
-
- If the tab's \a label contains an ampersand, the letter following
- the ampersand is used as an accelerator for the tab, e.g. if the
- label is "Bro&wse" then Alt+W becomes an accelerator which will
- move the focus to this tab.
-
- If you call addTab() after show() the screen will flicker and the
- user may be confused.
-
- \sa insertTab()
-*/
-
-void TQTabDialog::addTab( TQWidget * child, const TQString &label )
-{
- d->tw->addTab( child, label );
-}
-
-
-
-/*! \overload
-
- This version of the function shows the \a iconset as well as the \a
- label on the tab of \a child.
-*/
-void TQTabDialog::addTab( TQWidget *child, const TQIconSet& iconset, const TQString &label)
-{
- d->tw->addTab( child, iconset, label );
-}
-
-/*!
- \overload
-
- This is a lower-level method for adding tabs, similar to the other
- addTab() method. It is useful if you are using setTabBar() to set a
- TQTabBar subclass with an overridden TQTabBar::paint() function for a
- subclass of TQTab.
-
- The \a child is the widget to be placed on the new tab page. The \a
- tab is the tab to display on the tab page -- normally this shows a
- label or an icon that identifies the tab page.
-
-*/
-void TQTabDialog::addTab( TQWidget * child, TQTab* tab )
-{
- d->tw->addTab( child, tab );
-}
-
-/*!
- Inserts another tab and page to the tab view.
-
- The new page is \a child; the tab's label is \a label.
- Note the difference between the widget name (which you supply to
- widget constructors and to setTabEnabled(), for example) and the tab
- label. The name is internal to the program and invariant, whereas
- the label is shown on-screen and may vary according to language and
- other factors.
-
- If the tab's \a label contains an ampersand, the letter following
- the ampersand is used as an accelerator for the tab, e.g. if the
- label is "Bro&wse" then Alt+W becomes an accelerator which will
- move the focus to this tab.
-
- If \a index is not specified, the tab is simply added. Otherwise
- it is inserted at the specified position.
-
- If you call insertTab() after show(), the screen will flicker and the
- user may be confused.
-
- \sa addTab()
-*/
-
-void TQTabDialog::insertTab( TQWidget * child, const TQString &label, int index )
-{
- d->tw->insertTab( child, label, index );
-}
-
-
-/*! \overload
-
- This version of the function shows the \a iconset as well as the \a
- label on the tab of \a child.
- */
-void TQTabDialog::insertTab( TQWidget *child, const TQIconSet& iconset, const TQString &label, int index)
-{
- d->tw->insertTab( child, iconset, label, index );
-}
-
-/*!
- \overload
-
- This is a lower-level method for inserting tabs, similar to the other
- insertTab() method. It is useful if you are using setTabBar() to set a
- TQTabBar subclass with an overridden TQTabBar::paint() function for a
- subclass of TQTab.
-
- The \a child is the widget to be placed on the new tab page. The \a
- tab is the tab to display on the tab page -- normally this shows a
- label or an icon that identifies the tab page. The \a index is the
- position where this tab page should be inserted.
-
-*/
-void TQTabDialog::insertTab( TQWidget * child, TQTab* tab, int index )
-{
- d->tw->insertTab( child, tab, index );
-}
-
-/*!
- Replaces the TQTabBar heading the dialog by the given tab bar, \a tb.
- Note that this must be called \e before any tabs have been added,
- or the behavior is undefined.
- \sa tabBar()
-*/
-void TQTabDialog::setTabBar( TQTabBar* tb )
-{
- d->tw->setTabBar( tb );
- setUpLayout();
-}
-
-/*!
- Returns the currently set TQTabBar.
- \sa setTabBar()
-*/
-TQTabBar* TQTabDialog::tabBar() const
-{
- return d->tw->tabBar();
-}
-
-/*! Ensures that widget \a w is shown. This is mainly useful for accelerators.
-
- \warning If used carelessly, this function can easily surprise or
- confuse the user.
-
- \sa TQTabBar::setCurrentTab()
-*/
-
-void TQTabDialog::showPage( TQWidget * w )
-{
- d->tw->showPage( w );
-}
-
-
-/*! \obsolete
- Returns TRUE if the page with object name \a name is enabled and
- FALSE if it is disabled.
-
- If \a name is 0 or not the name of any of the pages, isTabEnabled()
- returns FALSE.
-
- \sa setTabEnabled(), TQWidget::isEnabled()
-*/
-
-bool TQTabDialog::isTabEnabled( const char* name ) const
-{
- if ( !name )
- return FALSE;
- TQObjectList * l
- = ((TQTabDialog *)this)->queryList( "TQWidget", name, FALSE, TRUE );
- if ( l && l->first() ) {
- TQWidget * w;
- while( l->current() ) {
- while( l->current() && !l->current()->isWidgetType() )
- l->next();
- w = (TQWidget *)(l->current());
- if ( w ) {
- bool enabled = d->tw->isTabEnabled( w );
- delete l;
- return enabled;
- }
- }
- }
- delete l;
- return FALSE;
-}
-
-
-/*!\obsolete
-
- Finds the page with object name \a name, enables/disables it
- according to the value of \a enable and redraws the page's tab
- appropriately.
-
- TQTabDialog uses TQWidget::setEnabled() internally, rather than keeping a
- separate flag.
-
- Note that even a disabled tab/page may be visible. If the page is
- already visible TQTabDialog will not hide it; if all the pages
- are disabled TQTabDialog will show one of them.
-
- The object name is used (rather than the tab label) because the tab
- text may not be invariant in multi-language applications.
-
- \sa isTabEnabled(), TQWidget::setEnabled()
-*/
-
-void TQTabDialog::setTabEnabled( const char* name, bool enable )
-{
- if ( !name )
- return;
- TQObjectList * l
- = ((TQTabDialog *)this)->queryList( "TQWidget", name, FALSE, TRUE );
- if ( l && l->first() ) {
- TQObjectListIt it(*l);
- TQObject *o;
- while( (o = it.current()) ) {
- ++it;
- if( o->isWidgetType() )
- d->tw->setTabEnabled( (TQWidget*)o, enable );
- }
- }
- delete l;
-}
-
-
-/* ### SHOULD THIS BE HERE?
- Adds an Apply button to the dialog. The button's text is set to \e
- text (and defaults to "Apply").
-
- The Apply button should apply the current settings in the dialog box
- to the application, while keeping the dialog visible.
-
- When Apply is clicked, the applyButtonPressed() signal is emitted.
-
- If \a text is a
- \link TQString::operator!() null string\endlink,
- no button is shown.
-
- \sa setCancelButton() setDefaultButton() applyButtonPressed()
-*/
-
-
-/*!
- Returns TRUE if the page \a w is enabled; otherwise returns FALSE.
-
- \sa setTabEnabled(), TQWidget::isEnabled()
-*/
-
-bool TQTabDialog::isTabEnabled( TQWidget* w ) const
-{
- return d->tw->isTabEnabled( w );
-}
-
-/*!
- If \a enable is TRUE the page \a w is enabled; otherwise \a w is
- disabled. The page's tab is redrawn appropriately.
-
- TQTabWidget uses TQWidget::setEnabled() internally, rather than keeping a
- separate flag.
-
- Note that even a disabled tab and tab page may be visible. If the
- page is already visible TQTabWidget will not hide it; if all the
- pages are disabled TQTabWidget will show one of them.
-
- \sa isTabEnabled(), TQWidget::setEnabled()
-*/
-
-void TQTabDialog::setTabEnabled( TQWidget* w, bool enable)
-{
- d->tw->setTabEnabled( w, enable );
-}
-
-
-/*!
- Adds an Apply button to the dialog. The button's text is set to \a
- text.
-
- The Apply button should apply the current settings in the dialog box
- to the application while keeping the dialog visible.
-
- When Apply is clicked, the applyButtonPressed() signal is emitted.
-
- If \a text is a
- \link TQString::operator!() null string\endlink,
- no button is shown.
-
- \sa setCancelButton() setDefaultButton() applyButtonPressed()
-*/
-void TQTabDialog::setApplyButton( const TQString &text )
-{
- if ( !text && d->ab ) {
- delete d->ab;
- d->ab = 0;
- setSizes();
- } else {
- if ( !d->ab ) {
- d->ab = new TQPushButton( this, "apply settings" );
- connect( d->ab, TQT_SIGNAL(clicked()),
- this, TQT_SIGNAL(applyButtonPressed()) );
- setUpLayout();
- }
- d->ab->setText( text );
- setSizes();
- //d->ab->show();
- }
-}
-
-/*!
- \overload
-
- Adds an Apply button to the dialog. The button's text is set to
- a localizable "Apply".
- */
-void TQTabDialog::setApplyButton()
-{
- setApplyButton( tr("Apply") );
-}
-
-
-/*!
- Adds a Help button to the dialog. The button's text is set to \a
- text.
-
- When Help is clicked, the helpButtonPressed() signal is emitted.
-
- If \a text is a
- \link TQString::operator!() null string\endlink,
- no button is shown.
-
- \sa setApplyButton() setCancelButton() helpButtonPressed()
-*/
-
-void TQTabDialog::setHelpButton( const TQString &text )
-{
- if ( !text ) {
- delete d->hb;
- d->hb = 0;
- setSizes();
- } else {
- if ( !d->hb ) {
- d->hb = new TQPushButton( this, "give help" );
- connect( d->hb, TQT_SIGNAL(clicked()),
- this, TQT_SIGNAL(helpButtonPressed()) );
- setUpLayout();
- }
- d->hb->setText( text );
- setSizes();
- //d->hb->show();
- }
-}
-
-
-/*!
- \overload
-
- Adds a Help button to the dialog. The button's text is set to
- a localizable "Help".
- */
-void TQTabDialog::setHelpButton()
-{
- setHelpButton( tr("Help") );
-}
-
-/*!
- Adds a Defaults button to the dialog. The button's text is set to \a
- text.
-
- The Defaults button should set the dialog (but not the application)
- back to the application defaults.
-
- When Defaults is clicked, the defaultButtonPressed() signal is emitted.
-
- If \a text is a
- \link TQString::operator!() null string\endlink,
- no button is shown.
-
- \sa setApplyButton() setCancelButton() defaultButtonPressed()
-*/
-
-void TQTabDialog::setDefaultButton( const TQString &text )
-{
- if ( !text ) {
- delete d->db;
- d->db = 0;
- setSizes();
- } else {
- if ( !d->db ) {
- d->db = new TQPushButton( this, "back to default" );
- connect( d->db, TQT_SIGNAL(clicked()),
- this, TQT_SIGNAL(defaultButtonPressed()) );
- setUpLayout();
- }
- d->db->setText( text );
- setSizes();
- //d->db->show();
- }
-}
-
-
-/*!
- \overload
-
- Adds a Defaults button to the dialog. The button's text is set to
- a localizable "Defaults".
- */
-void TQTabDialog::setDefaultButton()
-{
- setDefaultButton( tr("Defaults") );
-}
-
-/*!
- Adds a Cancel button to the dialog. The button's text is set to \a
- text.
-
- The cancel button should always return the application to the state
- it was in before the tab view popped up, or if the user has clicked
- Apply, back to the state immediately after the last Apply.
-
- When Cancel is clicked, the cancelButtonPressed() signal is emitted.
- The dialog is closed at the same time.
-
- If \a text is a
- \link TQString::operator!() null string\endlink,
- no button is shown.
-
- \sa setApplyButton() setDefaultButton() cancelButtonPressed()
-*/
-
-void TQTabDialog::setCancelButton( const TQString &text )
-{
- if ( !text ) {
- delete d->cb;
- d->cb = 0;
- setSizes();
- } else {
- if ( !d->cb ) {
- d->cb = new TQPushButton( this, "cancel dialog" );
- connect( d->cb, TQT_SIGNAL(clicked()),
- this, TQT_SIGNAL(cancelButtonPressed()) );
- connect( d->cb, TQT_SIGNAL(clicked()),
- this, TQT_SLOT(reject()) );
- setUpLayout();
- }
- d->cb->setText( text );
- setSizes();
- //d->cb->show();
- }
-}
-
-
-/*!
- \overload
-
- Adds a Cancel button to the dialog. The button's text is set to
- a localizable "Cancel".
- */
-
-void TQTabDialog::setCancelButton()
-{
- setCancelButton( tr("Cancel") );
-}
-
-
-/*! Sets up the tqlayout manager for the tab dialog.
-
- \sa setSizes() setApplyButton() setCancelButton() setDefaultButton()
-*/
-
-void TQTabDialog::setUpLayout()
-{
- // the next four are probably the same, really?
- const int topMargin = 6;
- const int leftMargin = 6;
- const int rightMargin = 6;
- const int bottomMargin = 6;
- const int betweenButtonsMargin = 7;
- const int aboveButtonsMargin = 8;
-
- delete d->tll;
- d->tll = new TQBoxLayout( this, TQBoxLayout::Down );
-
- // top margin
- d->tll->addSpacing( topMargin );
-
- TQBoxLayout * tmp = new TQHBoxLayout();
- d->tll->addLayout( tmp, 1 );
- tmp->addSpacing( leftMargin );
- tmp->addWidget( d->tw, 1);
- tmp->addSpacing( rightMargin + 2 );
-
- d->tll->addSpacing( aboveButtonsMargin + 2 );
- TQBoxLayout * buttonRow = new TQBoxLayout(TQBoxLayout::RightToLeft);
- d->tll->addLayout( buttonRow, 0 );
- d->tll->addSpacing( bottomMargin );
-
- buttonRow->addSpacing( rightMargin );
- if ( d->cb ) {
- buttonRow->addWidget( d->cb, 0 );
- buttonRow->addSpacing( betweenButtonsMargin );
- d->cb->raise();
- }
-
- if ( d->ab ) {
- buttonRow->addWidget( d->ab, 0 );
- buttonRow->addSpacing( betweenButtonsMargin );
- d->ab->raise();
- }
-
- if ( d->db ) {
- buttonRow->addWidget( d->db, 0 );
- buttonRow->addSpacing( betweenButtonsMargin );
- d->db->raise();
- }
-
- if ( d->hb ) {
- buttonRow->addWidget( d->hb, 0 );
- buttonRow->addSpacing( betweenButtonsMargin );
- d->hb->raise();
- }
-
- if ( d->ok ) {
- buttonRow->addWidget( d->ok, 0 );
- buttonRow->addSpacing( betweenButtonsMargin );
- d->ok->raise();
- }
-
- // add one custom widget here
- buttonRow->addStretch( 1 );
- // add another custom widget here
-
- d->tll->activate();
-}
-
-
-/*! Sets up the minimum and maximum sizes for each child widget.
-
- \sa setUpLayout() setFont()
-*/
-
-void TQTabDialog::setSizes()
-{
- // compute largest button size
- TQSize s( 0, 0 );
- int bw = s.width();
- int bh = s.height();
-
- if ( d->ok ) {
- s = d->ok->tqsizeHint();
- if ( s.width() > bw )
- bw = s.width();
- if ( s.height() > bh )
- bh = s.height();
- }
-
- if ( d->ab ) {
- s = d->ab->tqsizeHint();
- if ( s.width() > bw )
- bw = s.width();
- if ( s.height() > bh )
- bh = s.height();
- }
-
- if ( d->db ) {
- s = d->db->tqsizeHint();
- if ( s.width() > bw )
- bw = s.width();
- if ( s.height() > bh )
- bh = s.height();
- }
-
- if ( d->hb ) {
- s = d->hb->tqsizeHint();
- if ( s.width() > bw )
- bw = s.width();
- if ( s.height() > bh )
- bh = s.height();
- }
-
- if ( d->cb ) {
- s = d->cb->tqsizeHint();
- if ( s.width() > bw )
- bw = s.width();
- if ( s.height() > bh )
- bh = s.height();
- }
-
- // and set all the buttons to that size
- if ( d->ok )
- d->ok->setFixedSize( bw, bh );
- if ( d->ab )
- d->ab->setFixedSize( bw, bh );
- if ( d->db )
- d->db->setFixedSize( bw, bh );
- if ( d->hb )
- d->hb->setFixedSize( bw, bh );
- if ( d->cb )
- d->cb->setFixedSize( bw, bh );
-
- // fiddle the tab chain so the buttons are in their natural order
- TQWidget * w = d->ok;
-
- if ( d->hb ) {
- if ( w )
- setTabOrder( w, d->hb );
- w = d->hb;
- }
- if ( d->db ) {
- if ( w )
- setTabOrder( w, d->db );
- w = d->db;
- }
- if ( d->ab ) {
- if ( w )
- setTabOrder( w, d->ab );
- w = d->ab;
- }
- if ( d->cb ) {
- if ( w )
- setTabOrder( w, d->cb );
- w = d->cb;
- }
- setTabOrder( w, d->tw );
-}
-
-/*!\reimp
-*/
-void TQTabDialog::resizeEvent( TQResizeEvent * e )
-{
- TQDialog::resizeEvent( e );
-}
-
-
-/*!\reimp
-*/
-void TQTabDialog::paintEvent( TQPaintEvent * )
-{
-}
-
-
-/*!
- Adds an OK button to the dialog and sets the button's text to \a text.
-
- When the OK button is clicked, the applyButtonPressed() signal is emitted,
- and the current settings in the dialog box should be applied to
- the application. The dialog then closes.
-
- If \a text is a
- \link TQString::operator!() null string\endlink,
- no button is shown.
-
- \sa setCancelButton() setDefaultButton() applyButtonPressed()
-*/
-
-void TQTabDialog::setOkButton( const TQString &text )
-{
- if ( !text ) {
- delete d->ok;
- d->ok = 0;
- setSizes();
- } else {
- if ( !d->ok ) {
- d->ok = new TQPushButton( this, "ok" );
- connect( d->ok, TQT_SIGNAL(clicked()),
- this, TQT_SIGNAL(applyButtonPressed()) );
- setUpLayout();
- }
- d->ok->setText( text );
- setSizes();
- //d->ok->show();
- }
-}
-/*!
- \overload
-
- Adds an OK button to the dialog. The button's text is set to
- a localizable "OK".
- */
-
-void TQTabDialog::setOkButton()
-{
- setOkButton( tr("OK") );
-}
-
-
-/*
- \overload
- Old version of setOkButton(), provided for backward compatibility.
-*/
-void TQTabDialog::setOKButton( const TQString &text )
-{
- // Ugly workaround for original "OK" default argument
- TQString newText( text );
- if ( text.isNull() )
- newText = TQString::tqfromLatin1( "OK" );
- setOkButton( newText );
-}
-
-
-/*! Returns the text in the tab for page \a w.
-*/
-
-TQString TQTabDialog::tabLabel( TQWidget * w )
-{
- return d->tw->tabLabel( w );
-}
-
-
-/*! \reimp
-*/
-void TQTabDialog::styleChange( QStyle& s )
-{
- TQDialog::styleChange( s );
- setSizes();
-}
-
-
-/*! Returns a pointer to the page currently being displayed by the
-tab dialog. The tab dialog does its best to make sure that this value
-is never 0 (but if you try hard enough, it can be).
-*/
-
-TQWidget * TQTabDialog::currentPage() const
-{
- return d->tw->currentPage();
-}
-
-/*!
- \overload
- Defines a new \a label for the tab of page \a w
- */
-void TQTabDialog::changeTab( TQWidget *w, const TQString &label)
-{
- d->tw->changeTab( w, label );
-}
-
-/*!
- Changes tab page \a w's iconset to \a iconset and label to \a label.
-
- */
-void TQTabDialog::changeTab( TQWidget *w, const TQIconSet& iconset, const TQString &label)
-{
- d->tw->changeTab( w, iconset, label );
-}
-
-/*! Removes page \a w from this stack of widgets. Does not
- delete \a w.
- \sa showPage(), TQTabWidget::removePage(), TQWidgetStack::removeWidget()
-*/
-void TQTabDialog::removePage( TQWidget * w )
-{
- d->tw->removePage( w );
-}
-
-#endif