-rw-r--r-- | core/launcher/mediummountgui.cpp | 97 | ||||
-rw-r--r-- | core/launcher/mediummountgui.h | 4 |
2 files changed, 42 insertions, 59 deletions
diff --git a/core/launcher/mediummountgui.cpp b/core/launcher/mediummountgui.cpp index eb2308e..6d60ce4 100644 --- a/core/launcher/mediummountgui.cpp +++ b/core/launcher/mediummountgui.cpp @@ -1,234 +1,217 @@ #include "mediummountgui.h" -#include <qvariant.h> #include <qcheckbox.h> #include <qgroupbox.h> #include <qlabel.h> #include <qlineedit.h> #include <qpushbutton.h> #include <qlayout.h> -#include <qtooltip.h> -#include <qwhatsthis.h> #include <qimage.h> #include <qpixmap.h> +#include <qvbox.h> +#include <qhbox.h> #include <qpe/resource.h> #include <qpe/config.h> -#include <qpe/config.h> - - -#include <qapplication.h> - MediumMountGui::MediumMountGui( Config *cfg, const QString &path ,QWidget* parent, const char* name, bool , WFlags ) : QDialog( parent, name, true ) { m_cfg = cfg; - QWidget *d = QApplication::desktop(); - int w=d->width(); - int h=d->height(); - resize( w , h ); setCaption( tr( "Medium inserted" ) ); mediumPath = path; readConfig(); startGui(); + showMaximized(); } void MediumMountGui::readConfig(){ //OConfig cfg (mediumPath +"/.opiestorage.cf"); m_cfg->setGroup("main"); checkagain = m_cfg->readBoolEntry("check", false); m_cfg->setGroup("mimetypes"); checkmimeaudio = m_cfg->readBoolEntry("audio", true ); checkmimeimage = m_cfg->readBoolEntry("image", true ); checkmimetext = m_cfg->readBoolEntry("text" , true ); checkmimevideo = m_cfg->readBoolEntry("video", true ); checkmimeall = m_cfg->readBoolEntry("all" , false); m_cfg->setGroup("dirs"); limittodirs = m_cfg->readEntry("dirs", ""); } bool MediumMountGui::check() { return !checkagain; } QStringList MediumMountGui::dirs() { - QStringList list = QStringList::split(",", limittodirs ); - return list; + return QStringList::split( ",", limittodirs ); } void MediumMountGui::writeConfig(bool autocheck) { //OConfig cfg (mediumPath +"/.opiestorage.cf"); m_cfg->setGroup("main"); m_cfg->writeEntry("check", AskBox->isChecked() ); m_cfg->writeEntry("autocheck", autocheck ); m_cfg->setGroup("mimetypes"); m_cfg->writeEntry("audio", CheckBoxAudio->isChecked() ); m_cfg->writeEntry("image",CheckBoxImage->isChecked() ); m_cfg->writeEntry("text",CheckBoxImage->isChecked() ); m_cfg->writeEntry("video",CheckBoxVideo->isChecked() ); m_cfg->writeEntry("all",CheckBoxAll->isChecked() ); m_cfg->setGroup("dirs"); m_cfg->writeEntry("dirs", ""); - // if all is checked then add only "QString::null" to the list. if (checkmimeall) { mimeTypeList.clear(); mimeTypeList += QString::null; } else { if (checkmimeaudio) { mimeTypeList += ("audio/*"); } if (checkmimetext) { mimeTypeList += ("text/*"); } if (checkmimevideo) { mimeTypeList += ("video/*"); } if (checkmimeimage) { mimeTypeList += ("image/*"); } } m_cfg->write(); // not really needed here but just to be sure } void MediumMountGui::startGui() { - QPixmap image = Resource::loadPixmap( "HelpBrowser"); + QVBoxLayout* mainLayout = new QVBoxLayout( this ); + QHBoxLayout * titelBox = new QHBoxLayout( mainLayout ); Text_2 = new QLabel( this ); - Text_2->setGeometry( QRect( 10, 15, 40, 40 ) ); - Text_2->setPixmap( image ); + // FIXME needs an image + Text_2->setPixmap( Resource::loadPixmap( "mediummount/mediummount" ) ); Text = new QLabel( this, "Text" ); - Text->setGeometry( QRect( 55, 11, this->width()-50, 50 ) ); Text->setText( tr( "A <b>storage medium</b> was inserted. Should it be scanned for media files?" ) ); + titelBox->addWidget( Text_2 ); + titelBox->setStretchFactor( Text_2, 2 ); + titelBox->addWidget( Text ); + titelBox->setStretchFactor( Text, 8 ); // media box GroupBox1 = new QGroupBox( this, "GroupBox1" ); - GroupBox1->setGeometry( QRect( 10, 80, (this->width())-25, 80 ) ); GroupBox1->setTitle( tr( "Which media files" ) ); + QGridLayout *mimeLayout = new QGridLayout( GroupBox1, 3, 2, 10 ); + CheckBoxAudio = new QCheckBox( GroupBox1, "CheckBoxAudio" ); - CheckBoxAudio->setGeometry( QRect( 10, 15, (GroupBox1->width()/2)-15 , 15 ) ); CheckBoxAudio->setText( tr( "Audio" ) ); CheckBoxImage = new QCheckBox( GroupBox1, "CheckBoxImage" ); - CheckBoxImage->setGeometry( QRect( 10, 35,(GroupBox1->width()/2)-15, 15 ) ); CheckBoxImage->setText( tr( "Image" ) ); CheckBoxText = new QCheckBox( GroupBox1, "CheckBoxText" ); - CheckBoxText->setGeometry( QRect((GroupBox1->width()/2) , 15, (GroupBox1->width()/2)-15, 15 ) ); CheckBoxText->setText( tr( "Text" ) ); CheckBoxVideo = new QCheckBox( GroupBox1, "CheckBoxVideo" ); - CheckBoxVideo->setGeometry( QRect( (GroupBox1->width()/2), 35, (GroupBox1->width()/2)-15, 15 ) ); CheckBoxVideo->setText( tr( "Video" ) ); CheckBoxAll = new QCheckBox ( GroupBox1); - CheckBoxAll->setGeometry( QRect( 10, 55, (GroupBox1->width()/2)-15, 15 ) ); CheckBoxAll->setText( tr( "All" ) ); - QObject::connect( (QObject*)CheckBoxAll, SIGNAL( clicked() ), this, SLOT( deactivateOthers()) ); - - CheckBoxLink = new QCheckBox ( GroupBox1); - CheckBoxLink->setGeometry( QRect( (GroupBox1->width()/2), 55, (GroupBox1->width()/2)-15, 15 ) ); CheckBoxLink->setText( tr( "Link apps" ) ); // as long as the feature is not supported CheckBoxLink->setEnabled(false); + mimeLayout->addWidget( CheckBoxAudio, 0, 0 ); + mimeLayout->addWidget( CheckBoxImage, 0, 1 ); + mimeLayout->addWidget( CheckBoxText , 1, 0 ); + mimeLayout->addWidget( CheckBoxVideo, 1, 1 ); + mimeLayout->addWidget( CheckBoxAll, 2, 0 ); + mimeLayout->addWidget( CheckBoxLink, 2, 1 ); - // select dirs + connect( CheckBoxAll, SIGNAL( clicked() ), this, SLOT( deactivateOthers() ) ); - DirSelectText = new QLabel( this, "DirSelectText" ); - DirSelectText->setGeometry( QRect( 10, 160,this->width() , 20 ) ); - DirSelectText->setText( tr( "Limit search to dir: (not used yet)" ) ); + QVBox* dirBox = new QVBox( this ); + dirBox->setMargin( 4 ); - LineEdit1 = new QLineEdit( this ); - LineEdit1->setGeometry( QRect( 10, 180, (this->width())-60, 20 ) ); + // select dirs + DirSelectText = new QLabel( dirBox, "DirSelectText" ); + DirSelectText->setText( tr( "Limit search to dir: (not used yet)" ) ); - PushButton3 = new QPushButton( this ); - PushButton3->setGeometry( QRect( (this->width())-40, 180, 30, 20 ) ); + QHBox* dirLineBox = new QHBox( dirBox ); + LineEdit1 = new QLineEdit( dirLineBox ); + PushButton3 = new QPushButton( dirLineBox ); PushButton3->setText( tr( "Add" ) ); - // decision - DirSelectText_2 = new QLabel( this ); - DirSelectText_2->setGeometry( QRect( 10,240,this->width(), 15 ) ); + DirSelectText_2 = new QLabel( dirBox ); DirSelectText_2->setText( tr( "Your decision will be stored on the medium." ) ); // ask again - AskBox = new QCheckBox( this ); - AskBox->setGeometry( QRect( 10, 215, (this->width())-15 , 15 ) ); + AskBox = new QCheckBox( dirBox ); AskBox->setText( tr( "Do not ask again for this medium" ) ); - AskBox->setChecked(checkagain); CheckBoxAudio->setChecked(checkmimeaudio); CheckBoxImage->setChecked(checkmimeimage); CheckBoxText->setChecked(checkmimetext); CheckBoxVideo->setChecked(checkmimevideo); CheckBoxAll->setChecked( checkmimeall ); deactivateOthers(); + + QHBox* buttonBox = new QHBox( this ); // buttons - quit = new QPushButton( this ); - quit->setGeometry( QRect( (this->width()/2)- 90 , 260, 80, 22 ) ); + quit = new QPushButton( buttonBox ); quit->setFocus(); quit->setText( tr( "Yes" ) ); - - quit_2 = new QPushButton( this ); - quit_2->setGeometry( QRect((this->width()/2) , 260, 80, 22 ) ); + quit_2 = new QPushButton( buttonBox ); quit_2->setText( tr( "No" ) ); - QObject::connect( (QObject*)quit, SIGNAL( clicked() ), this, SLOT(yesPressed() ) ); - QObject::connect( (QObject*)quit_2, SIGNAL( clicked() ), this, SLOT(noPressed() ) ); - + mainLayout->addWidget( GroupBox1 ); + mainLayout->addWidget( dirBox ); + mainLayout->addWidget( buttonBox ); + connect( quit, SIGNAL( clicked() ), this, SLOT( yesPressed() ) ); + connect( quit_2, SIGNAL( clicked() ), this, SLOT( noPressed() ) ); } void MediumMountGui::deactivateOthers() { bool mod = !(CheckBoxAll->isChecked()); - - //if (!CheckBoxVideo->isChecked()){ - // mod = false; - //} else { - // mod = true; - //} CheckBoxVideo->setEnabled(mod); CheckBoxAudio->setEnabled(mod); CheckBoxText->setEnabled(mod); CheckBoxImage->setEnabled(mod); } void MediumMountGui::yesPressed() { writeConfig(true); // and do something accept(); } QStringList MediumMountGui::mimeTypes(){ return mimeTypeList; } void MediumMountGui::noPressed() { writeConfig(false); reject(); } MediumMountGui::~MediumMountGui(){ } diff --git a/core/launcher/mediummountgui.h b/core/launcher/mediummountgui.h index 8292c3a..39f9a52 100644 --- a/core/launcher/mediummountgui.h +++ b/core/launcher/mediummountgui.h @@ -1,71 +1,71 @@ #ifndef MEDIUMMOUNTGUI_H #define MEDIUMMOUNTGUI_H #include <qvariant.h> #include <qdialog.h> + class QVBoxLayout; class QHBoxLayout; class QGridLayout; class QCheckBox; class QGroupBox; class QLabel; class QLineEdit; class QPushButton; class Config; -class MediumMountGui : public QDialog -{ +class MediumMountGui : public QDialog { Q_OBJECT public: MediumMountGui( Config *cfg, const QString &path = "tmp/", QWidget* parent = 0, const char* name = 0, bool modal = FALSE ,WFlags fl = 0 ); ~MediumMountGui(); protected: QPushButton* quit; QPushButton* quit_2; QLabel* DirSelectText_2; QLineEdit* LineEdit1; QPushButton* PushButton3; QLabel* DirSelectText; QLabel* Text_2; QLabel* Text; QGroupBox* GroupBox1; QCheckBox* CheckBoxAudio; QCheckBox* CheckBoxImage; QCheckBox* CheckBoxText; QCheckBox* CheckBoxVideo; QCheckBox* CheckBoxAll; QCheckBox* CheckBoxLink; QCheckBox* AskBox; public: bool check(); QStringList mimeTypes(); QStringList dirs(); private: void startGui(); void readConfig(); void writeConfig(bool checkagain); private slots: void yesPressed(); void noPressed(); void deactivateOthers(); private: QString mediumPath; bool checkagain:1; bool checkmimeaudio:1; bool checkmimeimage:1; bool checkmimetext:1; bool checkmimevideo:1; bool checkmimeall:1; QString limittodirs; QStringList mimeTypeList; Config *m_cfg; }; #endif |