-rw-r--r-- | core/settings/launcher/launcher.pro | 7 | ||||
-rw-r--r-- | core/settings/launcher/launchersettings.cpp | 2 | ||||
-rw-r--r-- | core/settings/launcher/tabconfig.h | 25 | ||||
-rw-r--r-- | core/settings/launcher/tabdialog.cpp | 381 | ||||
-rw-r--r-- | core/settings/launcher/tabdialog.h | 40 | ||||
-rw-r--r-- | core/settings/launcher/tabssettings.cpp | 170 | ||||
-rw-r--r-- | core/settings/launcher/tabssettings.h | 31 |
7 files changed, 571 insertions, 85 deletions
diff --git a/core/settings/launcher/launcher.pro b/core/settings/launcher/launcher.pro index a46a22f..484b159 100644 --- a/core/settings/launcher/launcher.pro +++ b/core/settings/launcher/launcher.pro @@ -1,17 +1,20 @@ TEMPLATE = app CONFIG += qt warn_on release DESTDIR = $(OPIEDIR)/bin HEADERS = launchersettings.h \ tabssettings.h \ - taskbarsettings.h + taskbarsettings.h \ + tabconfig.h \ + tabdialog.h SOURCES = main.cpp \ launchersettings.cpp \ tabssettings.cpp \ - taskbarsettings.cpp + taskbarsettings.cpp \ + tabdialog.cpp INCLUDEPATH += $(OPIEDIR)/include DEPENDPATH += $(OPIEDIR)/include LIBS += -lqpe -lopie TARGET = launchersettings diff --git a/core/settings/launcher/launchersettings.cpp b/core/settings/launcher/launchersettings.cpp index b794519..bcb9913 100644 --- a/core/settings/launcher/launchersettings.cpp +++ b/core/settings/launcher/launchersettings.cpp @@ -1,39 +1,41 @@ #include <qlayout.h> #include <opie/otabwidget.h> #include "launchersettings.h" #include "tabssettings.h" #include "taskbarsettings.h" LauncherSettings::LauncherSettings ( ) : QDialog ( 0, "LauncherSettings", false ) { setCaption ( tr( "Launcher Settings" )); QVBoxLayout *lay = new QVBoxLayout ( this, 4, 4 ); OTabWidget *tw = new OTabWidget ( this, "otab" ); lay-> addWidget ( tw ); m_tabs = new TabsSettings ( tw ); m_taskbar = new TaskbarSettings ( tw ); tw-> addTab ( m_taskbar, "appearance/styletabicon.png", tr( "Taskbar" )); tw-> addTab ( m_tabs, "appearance/styletabicon.png", tr( "Tabs" )); + + tw-> setCurrentTab ( m_taskbar ); } void LauncherSettings::accept ( ) { m_taskbar-> accept ( ); m_tabs-> accept ( ); QDialog::accept ( ); } void LauncherSettings::done ( int r ) { QDialog::done ( r ); close ( ); } diff --git a/core/settings/launcher/tabconfig.h b/core/settings/launcher/tabconfig.h new file mode 100644 index 0000000..52ae81f --- a/dev/null +++ b/core/settings/launcher/tabconfig.h @@ -0,0 +1,25 @@ +#ifndef __TABCONFIG_H__ +#define __TABCONFIG_H__ + +struct TabConfig { + enum ViewMode { + Icon, + List + }; + enum BackgroundType { + Ruled, + SolidColor, + Image + }; + + ViewMode m_view; + BackgroundType m_bg_type; + QString m_bg_image; + QString m_bg_color; + QString m_text_color; + QString m_font_family; + int m_font_size; + bool m_changed; +}; + +#endif diff --git a/core/settings/launcher/tabdialog.cpp b/core/settings/launcher/tabdialog.cpp new file mode 100644 index 0000000..7b01cc7 --- a/dev/null +++ b/core/settings/launcher/tabdialog.cpp @@ -0,0 +1,381 @@ + +#include <qpe/resource.h> +#include <qpe/config.h> + +#include <qlayout.h> +#include <qvbox.h> +#include <qtabbar.h> +#include <qiconview.h> +#include <qapplication.h> +#include <qlabel.h> +#include <qradiobutton.h> +#include <qbuttongroup.h> + +#include <opie/ofontselector.h> +#include <opie/otabwidget.h> +#include <opie/ocolorbutton.h> + +#include "tabdialog.h" + + +class SampleItem : public QIconViewItem { +public: + SampleItem ( QIconView *v, const QString &text, const QPixmap &pix ) : QIconViewItem ( v, text ) + { + m_large = pix; + m_small. convertFromImage ( pix. convertToImage ( ). smoothScale ( pix. width ( ) / 2, pix. height ( ) / 2 )); + } + + void sizeChange ( ) + { + calcRect ( ); + repaint ( ); + } + + QPixmap *pixmap ( ) const + { + if ( iconView ( )-> itemTextPos ( ) == QIconView::Right ) + return (QPixmap *) &m_small; + else + return (QPixmap *) &m_large; + } +private: + QPixmap m_large, m_small; +}; + +class SampleView : public QIconView { +public: + SampleView ( QWidget *parent = 0, const char *name = 0 ) : QIconView ( parent, name ) + { + setItemsMovable ( false ); + setAutoArrange ( true ); + setSorting ( true ); + setFrameStyle ( QFrame::NoFrame ); + setSpacing ( 4 ); + setMargin ( 0 ); + setSelectionMode ( QIconView::NoSelection ); + setBackgroundMode ( PaletteBase ); + setViewMode ( TabConfig::Icon ); + calculateGrid ( Bottom ); + + + new SampleItem ( this, tr( "Sample 1" ), Resource::loadPixmap ( "DateBook" )); + new SampleItem ( this, tr( "Sample 2" ), Resource::loadPixmap ( "Calibrate" )); + new SampleItem ( this, tr( "Sample 3" ), Resource::loadPixmap ( "UnknownDocument" )); + + setBackgroundType ( TabConfig::Ruled, QString::null ); + + setMaximumHeight ( firstItem ( )-> height ( ) + 16 ); + } + + void setViewMode ( TabConfig::ViewMode m ) + { + viewport ( )-> setUpdatesEnabled ( false ); + + switch ( m ) { + case TabConfig::List: + setItemTextPos( QIconView::Right ); + break; + case TabConfig::Icon: + setItemTextPos( QIconView::Bottom ); + break; + } +// hideOrShowItems ( false ); + + for ( QIconViewItem *it = firstItem ( ); it; it = it-> nextItem ( )) + ((SampleItem *) it )-> sizeChange ( ); + arrangeItemsInGrid ( true ); + viewport ( )-> setUpdatesEnabled ( true ); + update ( ); + } + + + void setBackgroundType( TabConfig::BackgroundType t, const QString &val ) + { + switch ( t ) { + case TabConfig::Ruled: { + QPixmap bg ( width ( ), 9 ); + QPainter painter ( &bg ); + for ( int i = 0; i < 3; i++ ) { + painter. setPen ( white ); + painter. drawLine ( 0, i*3, width()-1, i*3 ); + painter. drawLine ( 0, i*3+1, width()-1, i*3+1 ); + painter. setPen ( colorGroup().background().light(105) ); + painter. drawLine ( 0, i*3+2, width()-1, i*3+2 ); + } + painter.end ( ); + setBackgroundPixmap ( bg ); + break; + } + + case TabConfig::SolidColor: { + setBackgroundPixmap ( QPixmap ( )); + if ( val. isEmpty ( )) + setBackgroundColor ( colorGroup ( ). base ( )); + else + setBackgroundColor ( val ); + break; + } + + case TabConfig::Image: { + qDebug( "Loading image: %s", val.latin1() ); + QPixmap bg ( Resource::loadPixmap ( "wallpaper/" + val )); + if ( bg. isNull ( )) { + QImageIO imgio; + imgio. setFileName ( val ); + QSize ds = qApp-> desktop ( )-> size ( ); + QString param ( "Scale( %1, %2, ScaleMin )" ); // No tr + imgio. setParameters ( param. arg ( ds. width ( )). arg ( ds. height ( )). latin1 ( )); + imgio. read ( ); + bg = imgio. image ( ); + } + setBackgroundPixmap ( bg ); + break; + } + } + m_bgtype = t; + viewport ( )-> update ( ); + } + + void setTextColor ( const QColor &tc ) + { + m_textcolor = tc; + QColorGroup cg = colorGroup ( ); + cg. setColor ( QColorGroup::Text, tc ); + setPalette ( QPalette ( cg, cg, cg )); + viewport ( )-> update ( ); + } + + void setViewFont ( const QFont &f ) + { + setFont ( f ); + } + + void setItemTextPos ( ItemTextPos pos ) + { + calculateGrid ( pos ); + QIconView::setItemTextPos( pos ); + } + + void calculateGrid ( ItemTextPos pos ) + { + int dw = QApplication::desktop ( )-> width ( ); + int viewerWidth = dw - style ( ).scrollBarExtent ( ). width ( ); + if ( pos == Bottom ) { + int cols = 3; + if ( viewerWidth <= 200 ) + cols = 2; + else if ( viewerWidth >= 400 ) + cols = viewerWidth/96; + setSpacing ( 4 ); + setGridX (( viewerWidth - ( cols + 1 ) * spacing ( )) / cols ); + setGridY ( fontMetrics ( ). height ( ) * 2 + 24 ); + } + else { + int cols = 2; + if ( viewerWidth < 150 ) + cols = 1; + else if ( viewerWidth >= 400 ) + cols = viewerWidth / 150; + setSpacing ( 2 ); + setGridX (( viewerWidth - ( cols + 1 ) * spacing ( )) / cols ); + setGridY ( fontMetrics ( ). height ( ) + 2 ); + } + } + + void paletteChange( const QPalette &p ) + { + unsetPalette ( ); + QIconView::paletteChange ( p ); + if ( m_bgtype == TabConfig::Ruled ) + setBackgroundType ( TabConfig::Ruled, QString::null ); + QColorGroup cg = colorGroup ( ); + cg.setColor ( QColorGroup::Text, m_textcolor ); + setPalette ( QPalette ( cg, cg, cg )); + } + + void setBackgroundPixmap ( const QPixmap &pm ) + { + m_bgpix = pm; + } + + void setBackgroundColor ( const QColor &c ) + { + m_bgcolor = c; + } + + void drawBackground ( QPainter *p, const QRect &r ) + { + if ( !m_bgpix. isNull ( )) { + p-> drawTiledPixmap ( r, m_bgpix, QPoint (( r. x ( ) + contentsX ( )) % m_bgpix. width ( ), + ( r. y ( ) + contentsY ( )) % m_bgpix. height ( ))); + } + else + p-> fillRect ( r, m_bgcolor ); + } + +private: + QColor m_textcolor; + QColor m_bgcolor; + QPixmap m_bgpix; + TabConfig::BackgroundType m_bgtype; +}; + + + +TabDialog::TabDialog ( const QPixmap *tabicon, const QString &tabname, TabConfig &tc, QWidget *parent, const char *name, bool modal, WFlags fl ) + : QDialog ( parent, name, modal, fl ) +{ + setCaption ( tr( "Edit Tab" )); + + QVBoxLayout *lay = new QVBoxLayout ( this, 4, 4 ); + + OTabWidget *tw = new OTabWidget ( this, "tabwidget", OTabWidget::Global, OTabWidget::Bottom ); + QWidget *bgtab; + + tw-> addTab ( bgtab = createBgTab ( tw ), "appearance/backgroundtabicon.png", tr( "Background" )); + tw-> addTab ( createFontTab ( tw ), "appearance/fonttabicon.png", tr( "Font" )); + tw-> addTab ( createIconTab ( tw ), "appearance/colorstabicon.png", tr( "Icons" ) ); + + tw-> setCurrentTab ( bgtab ); + + QWidget *sample = new QVBox ( this ); + QTabBar *tb = new QTabBar ( sample ); + QString name ( tr( "Previewing %1" ). arg ( tabname )); + + tb-> addTab ( tabicon ? new QTab ( *tabicon, name ) : new QTab ( name )); + + m_sample = new SampleView ( sample ); + + lay-> addWidget ( tw, 10 ); + lay-> addWidget ( sample, 1 ); +} + + +TabDialog::~TabDialog ( ) +{ +} + +QWidget *TabDialog::createFontTab ( QWidget *parent ) +{ + Config config ( "qpe" ); + config. setGroup ( "Appearance" ); + + QString familyStr = config.readEntry( "FontFamily", "Helvetica" ); + QString styleStr = config.readEntry( "FontStyle", "Regular" ); + int size = config.readNumEntry( "FontSize", 10 ); + + m_fontselect = new OFontSelector ( parent, "FontTab" ); + m_fontselect-> setSelectedFont ( familyStr, styleStr, size ); + + connect( m_fontselect, SIGNAL( fontSelected ( const QFont & )), + this, SLOT( fontClicked ( const QFont & ))); + + return m_fontselect; +} + +QWidget *TabDialog::createBgTab ( QWidget *parent ) +{ + QWidget *tab = new QWidget( parent, "AdvancedTab" ); + QVBoxLayout *vertLayout = new QVBoxLayout( tab, 4, 4 ); + + QGridLayout* gridLayout = new QGridLayout ( vertLayout ); + gridLayout-> setColStretch ( 1, 10 ); + + QLabel* label = new QLabel( tr( "Type:" ), tab ); + gridLayout-> addWidget ( label, 0, 0 ); + m_bgtype = new QButtonGroup( tab, "buttongroup" ); + m_bgtype-> hide ( ); + m_bgtype-> setExclusive ( true ); + + QRadioButton *rb; + rb = new QRadioButton( tr( "Ruled" ), tab, "ruled" ); + m_bgtype-> insert ( rb, TabConfig::Ruled ); + gridLayout-> addWidget( rb, 0, 1 ); + + QHBoxLayout *hb = new QHBoxLayout ( ); + hb-> setSpacing ( 4 ); + + rb = new QRadioButton( tr( "Solid color" ), tab, "solid" ); + m_bgtype-> insert ( rb, TabConfig::SolidColor ); + hb-> addWidget ( rb ); + + m_solidcolor = new OColorButton ( tab ); + connect ( m_solidcolor, SIGNAL( colorSelected ( const QColor & )), this, SLOT( colorClicked ( const QColor & ))); + hb-> addWidget ( m_solidcolor ); + hb-> addStretch ( 10 ); + + gridLayout-> addLayout ( hb, 1, 1 ); + + rb = new QRadioButton( tr( "Image" ), tab, "image" ); + m_bgtype-> insert ( rb, TabConfig::Image ); + gridLayout-> addWidget( rb, 3, 1 ); + + QPushButton *p; + + connect ( m_bgtype, SIGNAL( clicked ( int )), this, SLOT( bgTypeClicked ( int ))); + + vertLayout-> addStretch ( 10 ); + + return tab; +} + +QWidget *TabDialog::createIconTab ( QWidget *parent ) +{ + QWidget *tab = new QWidget( parent, "AdvancedTab" ); + QVBoxLayout *vertLayout = new QVBoxLayout( tab, 4, 4 ); + + QGridLayout* gridLayout = new QGridLayout ( vertLayout ); + gridLayout-> setColStretch ( 1, 10 ); + + QLabel* label = new QLabel( tr( "Size:" ), tab ); + gridLayout-> addWidget ( label, 0, 0 ); + m_iconsize = new QButtonGroup( tab, "buttongroup" ); + m_iconsize-> hide ( ); + m_iconsize-> setExclusive ( true ); + + QRadioButton *rb; + rb = new QRadioButton( tr( "Small" ), tab, "iconsmall" ); + m_iconsize-> insert ( rb, TabConfig::List ); + gridLayout-> addWidget( rb, 0, 1 ); + + rb = new QRadioButton( tr( "Large" ), tab, "iconlarge" ); + m_iconsize-> insert ( rb, TabConfig::Icon ); + gridLayout-> addWidget( rb, 1, 1 ); + + connect ( m_iconsize, SIGNAL( clicked ( int )), this, SLOT( iconSizeClicked ( int ))); + + vertLayout-> addStretch ( 10 ); + + return tab; +} + + +void TabDialog::iconSizeClicked ( int s ) +{ + m_sample-> setViewMode ((TabConfig::ViewMode) s ); +} + +void TabDialog::fontClicked ( const QFont &f ) +{ + m_sample-> setViewFont ( f ); +} + +void TabDialog::bgTypeClicked ( int t ) +{ + QString s; + + m_solidcolor-> setEnabled ( t == TabConfig::SolidColor ); +// m_imagebrowse-> setEnabled ( t == TabConfig::Image ); +// m_imagedefault-> setEnabled ( t == TabConfig::Image ); + + if ( t == TabConfig::SolidColor ) + s = m_solidcolor-> color ( ). name ( ); + + m_sample-> setBackgroundType ((TabConfig::BackgroundType) t, s ); +} + +void TabDialog::colorClicked ( const QColor &col ) +{ + m_sample-> setBackgroundType ( TabConfig::SolidColor, col. name ( )); +} diff --git a/core/settings/launcher/tabdialog.h b/core/settings/launcher/tabdialog.h new file mode 100644 index 0000000..d602573 --- a/dev/null +++ b/core/settings/launcher/tabdialog.h @@ -0,0 +1,40 @@ +#ifndef __TABDIALOG_H__ +#define __TABDIALOG_H__ + +#include <qdialog.h> +#include "tabconfig.h" + +class QButtonGroup; +class OFontSelector; +class SampleView; +class OColorButton; + +class TabDialog : public QDialog { + Q_OBJECT +public: + TabDialog ( const QPixmap *tabicon, const QString &tabname, TabConfig &cfg, QWidget *parent = 0, const char *name = 0, bool modal = false, WFlags = 0 ); + virtual ~TabDialog ( ); + +protected slots: + void iconSizeClicked ( int ); + void fontClicked ( const QFont & ); + void bgTypeClicked ( int ); + void colorClicked ( const QColor & ); + +private: + QWidget *createBgTab ( QWidget *parent ); + QWidget *createFontTab ( QWidget *parent ); + QWidget *createIconTab ( QWidget *parent ); + + +private: + SampleView *m_sample; + QButtonGroup *m_iconsize; + OFontSelector *m_fontselect; + OColorButton *m_solidcolor; + + QButtonGroup *m_bgtype; +}; + + +#endif
\ No newline at end of file diff --git a/core/settings/launcher/tabssettings.cpp b/core/settings/launcher/tabssettings.cpp index 292c615..fc2d2c9 100644 --- a/core/settings/launcher/tabssettings.cpp +++ b/core/settings/launcher/tabssettings.cpp @@ -1,177 +1,225 @@ /********************************************************************** ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. ** ** This file is part of the Qtopia Environment. ** ** This file may be distributed and/or modified under the terms of the ** GNU General Public License version 2 as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL included in the ** packaging of this file. ** ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. ** ** See http://www.trolltech.com/gpl/ for GPL licensing information. ** ** Contact info@trolltech.com if any conditions of this licensing are ** not clear to you. ** **********************************************************************/ #include "tabssettings.h" #include <qpe/qpeapplication.h> #include <qpe/resource.h> #include <qpe/applnk.h> #include <qpe/mimetype.h> #include <qpe/qcopenvelope_qws.h> #include <qpe/config.h> -#include <qlistview.h> -#include <qheader.h> +#include <qlistbox.h> +#include <qpushbutton.h> #include <qlayout.h> #include <qlabel.h> #include <qwhatsthis.h> +#include "tabdialog.h" + #include <stdlib.h> +#include <qmessagebox.h> + + TabsSettings::TabsSettings ( QWidget *parent, const char *name ) : QWidget ( parent, name ) { - QBoxLayout *lay = new QVBoxLayout ( this, 4, 4 ); + QGridLayout *lay = new QGridLayout ( this, 0, 0, 4, 4 ); QLabel *l = new QLabel ( tr( "Launcher Tabs:" ), this ); - lay-> addWidget ( l ); + lay-> addMultiCellWidget ( l, 0, 0, 0, 1 ); - m_list = new QListView ( this ); - m_list-> addColumn ( "foobar" ); - m_list-> header ( )-> hide ( ); - - lay-> addWidget ( m_list ); + m_list = new QListBox ( this ); + lay-> addMultiCellWidget ( m_list, 1, 4, 0, 0 ); QWhatsThis::add ( m_list, tr( "foobar" )); + + QPushButton *p; + p = new QPushButton ( tr( "New" ), this ); + lay-> addWidget ( p, 1, 1 ); + connect ( p, SIGNAL( clicked ( )), this, SLOT( newClicked ( ))); + + p = new QPushButton ( tr( "Edit" ), this ); + lay-> addWidget ( p, 2, 1 ); + connect ( p, SIGNAL( clicked ( )), this, SLOT( editClicked ( ))); + + p = new QPushButton ( tr( "Delete" ), this ); + lay-> addWidget ( p, 3, 1 ); + connect ( p, SIGNAL( clicked ( )), this, SLOT( deleteClicked ( ))); + + lay-> setRowStretch ( 4, 10 ); init ( ); } void TabsSettings::init ( ) { - QListViewItem *lvi; - AppLnkSet rootFolder( MimeType::appsFolderName ( )); QStringList types = rootFolder. types ( ); + for ( QStringList::Iterator it = types. begin ( ); it != types. end ( ); ++it ) { - lvi = new QListViewItem ( m_list, rootFolder. typeName ( *it )); - lvi-> setPixmap ( 0, rootFolder. typePixmap ( *it )); + m_list-> insertItem ( rootFolder. typePixmap ( *it ), rootFolder. typeName ( *it )); m_ids << *it; } QImage img ( Resource::loadImage ( "DocsIcon" )); QPixmap pix; pix = img. smoothScale ( AppLnk::smallIconSize ( ), AppLnk::smallIconSize ( )); - lvi = new QListViewItem ( m_list, tr( "Documents" )); - lvi-> setPixmap ( 0, pix ); + m_list-> insertItem ( pix, tr( "Documents" )); m_ids += "Documents"; // No tr readTabSettings ( ); } void TabsSettings::readTabSettings ( ) { Config cfg ( "Launcher" ); QString grp ( "Tab %1" ); // No tr m_tabs. clear ( ); for ( QStringList::Iterator it = m_ids. begin ( ); it != m_ids. end ( ); ++it ) { - TabSettings ts; - ts. m_view = Icon; - ts. m_bg_type = Ruled; - ts. m_changed = false; + TabConfig tc; + tc. m_view = TabConfig::Icon; + tc. m_bg_type = TabConfig::Ruled; + tc. m_changed = false; cfg. setGroup ( grp. arg ( *it )); QString view = cfg. readEntry ( "View", "Icon" ); if ( view == "List" ) // No tr - ts. m_view = List; + tc. m_view = TabConfig::List; QString bgType = cfg. readEntry ( "BackgroundType", "Ruled" ); if ( bgType == "SolidColor" ) - ts. m_bg_type = SolidColor; + tc. m_bg_type = TabConfig::SolidColor; else if ( bgType == "Image" ) // No tr - ts. m_bg_type = Image; + tc. m_bg_type = TabConfig::Image; - ts. m_bg_image = cfg. readEntry ( "BackgroundImage", "wallpaper/opie" ); - ts. m_bg_color = cfg. readEntry ( "BackgroundColor" ); - ts. m_text_color = cfg. readEntry ( "TextColor" ); + tc. m_bg_image = cfg. readEntry ( "BackgroundImage", "wallpaper/opie" ); + tc. m_bg_color = cfg. readEntry ( "BackgroundColor" ); + tc. m_text_color = cfg. readEntry ( "TextColor" ); QStringList f = cfg. readListEntry ( "Font", ',' ); if ( f. count ( ) == 4 ) { - ts. m_font_family = f [0]; - ts. m_font_size = f [1]. toInt ( ); + tc. m_font_family = f [0]; + tc. m_font_size = f [1]. toInt ( ); } else { - ts. m_font_family = font ( ). family ( ); - ts. m_font_size = font ( ). pointSize ( ); + tc. m_font_family = font ( ). family ( ); + tc. m_font_size = font ( ). pointSize ( ); } - m_tabs [*it] = ts; + m_tabs [*it] = tc; } } void TabsSettings::accept ( ) { Config cfg ( "Launcher" ); // Launcher Tab QString grp ( "Tab %1" ); // No tr for ( QStringList::Iterator it = m_ids. begin ( ); it != m_ids. end ( ); ++it ) { - TabSettings &tab = m_tabs [*it]; + TabConfig &tc = m_tabs [*it]; cfg. setGroup ( grp. arg ( *it )); - if ( !tab. m_changed ) + if ( !tc. m_changed ) continue; - switch ( tab. m_view ) { - case Icon: - cfg.writeEntry ( "View", "Icon" ); - break; - case List: - cfg.writeEntry ( "View", "List" ); - break; + switch ( tc. m_view ) { + case TabConfig::Icon: + cfg.writeEntry ( "View", "Icon" ); + break; + case TabConfig::List: + cfg.writeEntry ( "View", "List" ); + break; } QCopEnvelope e ( "QPE/Launcher", "setTabView(QString,int)" ); - e << *it << tab. m_view; + e << *it << tc. m_view; - cfg. writeEntry ( "BackgroundImage", tab. m_bg_image ); - cfg. writeEntry ( "BackgroundColor", tab. m_bg_color ); - cfg. writeEntry ( "TextColor", tab. m_text_color ); + cfg. writeEntry ( "BackgroundImage", tc. m_bg_image ); + cfg. writeEntry ( "BackgroundColor", tc. m_bg_color ); + cfg. writeEntry ( "TextColor", tc. m_text_color ); - QString f = tab. m_font_family + "," + QString::number ( tab. m_font_size ) + ",50,0"; + QString f = tc. m_font_family + "," + QString::number ( tc. m_font_size ) + ",50,0"; cfg. writeEntry ( "Font", f ); QCopEnvelope be ( "QPE/Launcher", "setTabBackground(QString,int,QString)" ); - switch ( tab. m_bg_type ) { - case Ruled: - cfg.writeEntry( "BackgroundType", "Ruled" ); - be << *it << tab. m_bg_type << QString(""); - break; - case SolidColor: - cfg.writeEntry( "BackgroundType", "SolidColor" ); - be << *it << tab. m_bg_type << tab. m_bg_color; - break; - case Image: - cfg.writeEntry( "BackgroundType", "Image" ); - be << *it << tab. m_bg_type << tab. m_bg_image; - break; + switch ( tc. m_bg_type ) { + case TabConfig::Ruled: + cfg.writeEntry( "BackgroundType", "Ruled" ); + be << *it << tc. m_bg_type << QString(""); + break; + case TabConfig::SolidColor: + cfg.writeEntry( "BackgroundType", "SolidColor" ); + be << *it << tc. m_bg_type << tc. m_bg_color; + break; + case TabConfig::Image: + cfg.writeEntry( "BackgroundType", "Image" ); + be << *it << tc. m_bg_type << tc. m_bg_image; + break; } QCopEnvelope te( "QPE/Launcher", "setTextColor(QString,QString)" ); - te << *it << tab. m_text_color; + te << *it << tc. m_text_color; QCopEnvelope fe ( "QPE/Launcher", "setFont(QString,QString,int,int,int)" ); - fe << *it << tab. m_font_family; - fe << tab. m_font_size; + fe << *it << tc. m_font_family; + fe << tc. m_font_size; fe << 50 << 0; - tab. m_changed = false; + tc. m_changed = false; } } +void TabsSettings::newClicked ( ) +{ + QMessageBox::information ( this, tr( "Error" ), tr( "Not implemented yet" )); +} + +void TabsSettings::deleteClicked ( ) +{ + int ind = m_list-> currentItem ( ); + + if ( ind < 0 ) + return; + + QMessageBox::information ( this, tr( "Error" ), tr( "Not implemented yet" )); +} + +void TabsSettings::editClicked ( ) +{ + int ind = m_list-> currentItem ( ); + + if ( ind < 0 ) + return; + + TabConfig tc = m_tabs [m_ids [ind]]; + + TabDialog *d = new TabDialog ( m_list-> pixmap ( ind ), m_list-> text ( ind ), tc, this, "TabDialog", true ); + + d-> showMaximized ( ); + if ( d-> exec ( ) == QDialog::Accepted ) { + tc. m_changed = true; + m_tabs [m_ids [ind]] = tc; + } + + delete d; +} diff --git a/core/settings/launcher/tabssettings.h b/core/settings/launcher/tabssettings.h index 17b6e25..76cae68 100644 --- a/core/settings/launcher/tabssettings.h +++ b/core/settings/launcher/tabssettings.h @@ -1,52 +1,39 @@ #ifndef __TABS_SETTINGS_H__ #define __TABS_SETTINGS_H__ #include <qwidget.h> #include <qmap.h> -class QListView; +#include "tabconfig.h" + +class QListBox; class TabsSettings : public QWidget { Q_OBJECT public: TabsSettings ( QWidget *parent = 0, const char *name = 0 ); void accept ( ); - enum ViewMode { - Icon, - List - }; - enum BackgroundType { - Ruled, - SolidColor, - Image - }; - struct TabSettings { - ViewMode m_view; - BackgroundType m_bg_type; - QString m_bg_image; - QString m_bg_color; - QString m_text_color; - QString m_font_family; - int m_font_size; - bool m_changed; - }; +protected slots: + void newClicked ( ); + void deleteClicked ( ); + void editClicked ( ); protected: void init ( ); void readTabSettings ( ); private: - QListView *m_list; + QListBox *m_list; // QString currentTab; QStringList m_ids; - QMap <QString, TabSettings> m_tabs; + QMap <QString, TabConfig> m_tabs; }; #endif |