summaryrefslogtreecommitdiff
path: root/libopie/big-screen/omodalhelper.cpp
authorzecke <zecke>2003-09-13 15:04:36 (UTC)
committer zecke <zecke>2003-09-13 15:04:36 (UTC)
commit6b4c7e5d9f5c21bf044afb260fcfa066e86c12a1 (patch) (side-by-side diff)
tree736f68df631447b88768cb8f080306e78ae3cd20 /libopie/big-screen/omodalhelper.cpp
parent14db240e82c6208277946c6a76fe1d41615d6804 (diff)
downloadopie-6b4c7e5d9f5c21bf044afb260fcfa066e86c12a1.zip
opie-6b4c7e5d9f5c21bf044afb260fcfa066e86c12a1.tar.gz
opie-6b4c7e5d9f5c21bf044afb260fcfa066e86c12a1.tar.bz2
The rest of the implementation.
Theoretically you could use it, now writing the example and then finally compile that sucker for the 1st time
Diffstat (limited to 'libopie/big-screen/omodalhelper.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r--libopie/big-screen/omodalhelper.cpp7
1 files changed, 6 insertions, 1 deletions
diff --git a/libopie/big-screen/omodalhelper.cpp b/libopie/big-screen/omodalhelper.cpp
index e3d1c70..c5a47b3 100644
--- a/libopie/big-screen/omodalhelper.cpp
+++ b/libopie/big-screen/omodalhelper.cpp
@@ -15,146 +15,151 @@
    =_        +     =;=|` 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., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA.
*/
#include <qpushbutton.h>
#include <qvbox.h>
#include <qlayout.h>
#include <qlabel.h>
#include "omodalhelper.h"
/* SIgnal handling */
OModalHelperSignal::OModalHelperSignal( OModalHelperBase* base, QObject* parent )
: QObject( parent, "OModal Helper Signal" ), m_base( base ) {
}
OModalHelperSignal::~OModalHelperSignal() {
/* special the ancestor deletes its creator */
delete m_base;
}
/* Helper Controler */
/*
* the dialogs signal will be slotted here
* and we will call into m_base
*/
OModalHelperControler::OModalHelperControler( OModalHelperBase* base, QObject* parent )
: QObject(parent, "OModal Helper Controler" ), m_base( base ), m_dia( 0 ), m_id( -1 )
{
}
TransactionID OModalHelperControler::transactionID()const {
return m_id;
}
void OModalHelperControler::setTransactionID( TransactionID id ) {
m_dia = 0;
m_id = id;
}
QDialog* OModalHelperControler::dialog()const {
return m_dia;
}
/*
* If we're in the New mode we will map the QDialog
* to the TransactionID
*/
void OModalHelperControler::done( int result ) {
if ( sender() && !sender()->isA("OModalQueuedDialog") )
m_dia = static_cast<QDialog*>( sender() );
- m_base->done( m_id );
+ m_base->done( result, m_id );
}
void OModalHelperControler::next() {
m_base->next( m_id );
}
void OModalHelperControler::prev() {
m_base->prev( m_id );
}
/* The Queued Dialog inclusive QueuedBar */
struct OModalQueueBar : public QHBox {
QPushButton* next;
QPushButton* prev;
QLabel * label;
OModalQueueBar( QWidget* parent );
void setText( const QString& str );
};
OModalQueueBar::OModalQueueBar( QWidget* parent )
: QWidget( parent, "OModal Queue Bar" ) {
prev = new QPushButton( this );
prev->setText( OModalQueuedDialog::tr("Prev") );
label = new QLabel(this);
next = new QPushButton( this );
next->setText( OModalQueuedDialog::tr("Next") );
}
void OModalQueueBar::setText( const QString& str ) {
label->setText( str );
}
OModalQueuedDialog::OModalQueuedDialog( QDialog* mainWidget )
: QDialog(0, "OModal Queued Dialog" )
{
QVBoxLayout *lay = new QVBoxLayout( this );
m_bar = new OModalQueueBar( this );
lay->addWidget( m_bar );
m_center = mainWidget;
m_center->reparent(this, 0, QPoint(0, 0) );
lay->addWidget( m_center );
connect(m_bar->next, SIGNAL(clicked() ), this,
SIGNAL(next() ) );
connect(m_bar->prev, SIGNAL(clicked() ), this,
SIGNAL(prev() ) );
}
OModalQueuedDialog::~OModalQueuedDialog() {
}
QDialog* OModalQueuedDialog::centerDialog()const {
return m_center;
}
void OModalQueuedDialog::setQueueBarEnabled( bool b) {
/* in Qt3 use setEnabled( bool ) */
if (b)
m_bar->show();
else
m_bar->hide();
}
void OModalQueuedDialog::setRecord( int record, int count ) {
if (!record && !count ) {
hide();
return;
}else
show();
+ if ( count > 1 )
+ m_bar->show();
+ else
+ m_bar->hide();
+
m_bar->setText( tr("Editing record %1 out of %2",
"Shows the current edited record out of an array of records").arg( record ). arg( count ) );
}