summaryrefslogtreecommitdiffstats
path: root/kdeui/tests/kcomboboxtest.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'kdeui/tests/kcomboboxtest.cpp')
-rw-r--r--kdeui/tests/kcomboboxtest.cpp227
1 files changed, 227 insertions, 0 deletions
diff --git a/kdeui/tests/kcomboboxtest.cpp b/kdeui/tests/kcomboboxtest.cpp
new file mode 100644
index 000000000..2eb1f73e0
--- /dev/null
+++ b/kdeui/tests/kcomboboxtest.cpp
@@ -0,0 +1,227 @@
+#define protected public // for delegate()
+#include <kcombobox.h>
+#undef protected
+
+#include "kcomboboxtest.h"
+
+#include <assert.h>
+
+#include <kapplication.h>
+#include <kdebug.h>
+#include <kdialog.h>
+#include <klocale.h>
+#include <kiconloader.h>
+#include <ksimpleconfig.h>
+
+#include <qpushbutton.h>
+#include <qlayout.h>
+#include <qpixmap.h>
+#include <qlabel.h>
+#include <qhbox.h>
+#include <qtimer.h>
+
+
+KComboBoxTest::KComboBoxTest(QWidget* widget, const char* name )
+ :QWidget(widget, name)
+{
+ QVBoxLayout *vbox = new QVBoxLayout (this, KDialog::marginHint(), KDialog::spacingHint());
+
+ // Test for KCombo's KLineEdit destruction
+ KComboBox *testCombo = new KComboBox( true, this ); // rw, with KLineEdit
+ testCombo->setEditable( false ); // destroys our KLineEdit
+ assert( testCombo->delegate() == 0L );
+ delete testCombo; // not needed anymore
+
+ // Qt combobox
+ QHBox* hbox = new QHBox(this);
+ hbox->setSpacing (KDialog::spacingHint());
+ QLabel* lbl = new QLabel("&QCombobox:", hbox);
+ lbl->setSizePolicy (QSizePolicy::Maximum, QSizePolicy::Preferred);
+
+ m_qc = new QComboBox(hbox, "QtReadOnlyCombo" );
+ lbl->setBuddy (m_qc);
+ QObject::connect (m_qc, SIGNAL(activated(int)), SLOT(slotActivated(int)));
+ QObject::connect (m_qc, SIGNAL(activated(const QString&)), SLOT (slotActivated(const QString&)));
+ vbox->addWidget (hbox);
+
+ // Read-only combobox
+ hbox = new QHBox(this);
+ hbox->setSpacing (KDialog::spacingHint());
+ lbl = new QLabel("&Read-Only Combo:", hbox);
+ lbl->setSizePolicy (QSizePolicy::Maximum, QSizePolicy::Preferred);
+
+ m_ro = new KComboBox(hbox, "ReadOnlyCombo" );
+ lbl->setBuddy (m_ro);
+ m_ro->setCompletionMode( KGlobalSettings::CompletionAuto );
+ QObject::connect (m_ro, SIGNAL(activated(int)), SLOT(slotActivated(int)));
+ QObject::connect (m_ro, SIGNAL(activated(const QString&)), SLOT (slotActivated(const QString&)));
+ vbox->addWidget (hbox);
+
+ // Read-write combobox
+ hbox = new QHBox(this);
+ hbox->setSpacing (KDialog::spacingHint());
+ lbl = new QLabel("&Editable Combo:", hbox);
+ lbl->setSizePolicy (QSizePolicy::Maximum, QSizePolicy::Preferred);
+
+ m_rw = new KComboBox( true, hbox, "ReadWriteCombo" );
+ lbl->setBuddy (m_rw);
+ m_rw->setDuplicatesEnabled( true );
+ m_rw->setInsertionPolicy( QComboBox::NoInsertion );
+ m_rw->setTrapReturnKey( true );
+ QObject::connect (m_rw, SIGNAL(activated(int)), SLOT(slotActivated(int)));
+ QObject::connect (m_rw, SIGNAL(activated(const QString&)), SLOT(slotActivated(const QString&)));
+ QObject::connect (m_rw, SIGNAL(returnPressed()), SLOT(slotReturnPressed()));
+ QObject::connect (m_rw, SIGNAL(returnPressed(const QString&)), SLOT(slotReturnPressed(const QString&)));
+ vbox->addWidget (hbox);
+
+ // History combobox...
+ hbox = new QHBox(this);
+ hbox->setSpacing (KDialog::spacingHint());
+ lbl = new QLabel("&History Combo:", hbox);
+ lbl->setSizePolicy (QSizePolicy::Maximum, QSizePolicy::Preferred);
+
+ m_hc = new KHistoryCombo( true, hbox, "HistoryCombo" );
+ lbl->setBuddy (m_hc);
+ m_hc->setDuplicatesEnabled( true );
+ m_hc->setInsertionPolicy( QComboBox::NoInsertion );
+ QObject::connect (m_hc, SIGNAL(activated(int)), SLOT(slotActivated(int)));
+ QObject::connect (m_hc, SIGNAL(activated(const QString&)), SLOT(slotActivated(const QString&)));
+ QObject::connect (m_hc, SIGNAL(returnPressed()), SLOT(slotReturnPressed()));
+ vbox->addWidget (hbox);
+ m_hc->setTrapReturnKey(true);
+
+ // Read-write combobox that is a replica of code in konqueror...
+ hbox = new QHBox(this);
+ hbox->setSpacing (KDialog::spacingHint());
+ lbl = new QLabel( "&Konq's Combo:", hbox);
+ lbl->setSizePolicy (QSizePolicy::Maximum, QSizePolicy::Preferred);
+
+ m_konqc = new KComboBox( true, hbox, "KonqyCombo" );
+ lbl->setBuddy (m_konqc);
+ m_konqc->setMaxCount( 10 );
+ QObject::connect (m_konqc, SIGNAL(activated(int)), SLOT(slotActivated(int)));
+ QObject::connect (m_konqc, SIGNAL(activated(const QString&)), SLOT (slotActivated(const QString&)));
+ QObject::connect (m_konqc, SIGNAL(returnPressed()), SLOT(slotReturnPressed()));
+ vbox->addWidget (hbox);
+
+ // Create an exit button
+ hbox = new QHBox (this);
+ m_btnExit = new QPushButton( "E&xit", hbox );
+ QObject::connect( m_btnExit, SIGNAL(clicked()), SLOT(quitApp()) );
+
+ // Create a disable button...
+ m_btnEnable = new QPushButton( "Disa&ble", hbox );
+ QObject::connect (m_btnEnable, SIGNAL(clicked()), SLOT(slotDisable()));
+
+ vbox->addWidget (hbox);
+
+ // Popuplate the select-only list box
+ QStringList list;
+ list << "Stone" << "Tree" << "Peables" << "Ocean" << "Sand" << "Chips"
+ << "Computer" << "Mankind";
+ list.sort();
+
+ // Setup the qcombobox
+ m_qc->insertStringList (list);
+
+ // Setup read-only combo
+ m_ro->insertStringList( list );
+ m_ro->completionObject()->setItems( list );
+
+ // Setup read-write combo
+ m_rw->insertStringList( list );
+ m_rw->completionObject()->setItems( list );
+
+ // Setup read-write combo
+ m_hc->insertStringList( list );
+ m_hc->completionObject()->setItems( list );
+
+ // Setup konq's combobox
+ KSimpleConfig historyConfig( "konq_history" );
+ historyConfig.setGroup( "Location Bar" );
+ KCompletion * s_pCompletion = new KCompletion;
+ s_pCompletion->setOrder( KCompletion::Weighted );
+ s_pCompletion->setItems( historyConfig.readListEntry( "ComboContents" ) );
+ s_pCompletion->setCompletionMode( KGlobalSettings::completionMode() );
+ m_konqc->setCompletionObject( s_pCompletion );
+
+ QPixmap pix = SmallIcon("www");
+ m_konqc->insertItem( pix, "http://www.kde.org" );
+ m_konqc->setCurrentItem( m_konqc->count()-1 );
+
+ m_timer = new QTimer (this);
+ connect (m_timer, SIGNAL (timeout()), SLOT (slotTimeout()));
+}
+
+KComboBoxTest::~KComboBoxTest()
+{
+ if (m_timer)
+ {
+ delete m_timer;
+ m_timer = 0;
+ }
+}
+
+void KComboBoxTest::slotDisable ()
+{
+ if (m_timer->isActive())
+ return;
+
+ m_btnEnable->setEnabled (!m_btnEnable->isEnabled());
+
+ m_timer->start (5000, true);
+}
+
+void KComboBoxTest::slotTimeout ()
+{
+ bool enabled = m_ro->isEnabled();
+
+ if (enabled)
+ m_btnEnable->setText ("Ena&ble");
+ else
+ m_btnEnable->setText ("Disa&ble");
+
+ m_qc->setEnabled (!enabled);
+ m_ro->setEnabled (!enabled);
+ m_rw->setEnabled (!enabled);
+ m_hc->setEnabled (!enabled);
+ m_konqc->setEnabled (!enabled);
+
+ m_btnEnable->setEnabled (!m_btnEnable->isEnabled());
+}
+
+void KComboBoxTest::slotActivated( int index )
+{
+ kdDebug() << "Activated Combo: " << sender()->name() << ", index:" << index << endl;
+}
+
+void KComboBoxTest::slotActivated (const QString& item)
+{
+ kdDebug() << "Activated Combo: " << sender()->name() << ", item: " << item << endl;
+}
+
+void KComboBoxTest::slotReturnPressed ()
+{
+ kdDebug() << "Return Pressed: " << sender()->name() << endl;
+}
+
+void KComboBoxTest::slotReturnPressed(const QString& item)
+{
+ kdDebug() << "Return Pressed, value = " << item << endl;
+}
+
+void KComboBoxTest::quitApp()
+{
+ kapp->closeAllWindows();
+}
+
+int main ( int argc, char **argv)
+{
+ KApplication a(argc, argv, "kcomboboxtest");
+ KComboBoxTest* t= new KComboBoxTest;
+ a.setMainWidget (t);
+ t->show ();
+ return a.exec();
+}
+
+#include "kcomboboxtest.moc"