Diffstat (limited to 'core/pim/today/todayconfig.cpp') (more/less context) (show whitespace changes)
-rw-r--r-- | core/pim/today/todayconfig.cpp | 117 |
1 files changed, 68 insertions, 49 deletions
diff --git a/core/pim/today/todayconfig.cpp b/core/pim/today/todayconfig.cpp index 4f0877c..c9823d4 100644 --- a/core/pim/today/todayconfig.cpp +++ b/core/pim/today/todayconfig.cpp @@ -17,5 +17,8 @@ #include "todayconfig.h" -#include <qpe/config.h> +#include <opie2/oconfig.h> +#include <opie2/opluginloader.h> +#include <opie2/todayplugininterface.h> + #include <qpe/resource.h> #include <qpe/qcopenvelope_qws.h> @@ -32,4 +35,9 @@ using namespace Opie::Ui; +using Opie::Core::OConfig; +using Opie::Core::OPluginManager; +using Opie::Core::OPluginLoader; +using Opie::Core::OPluginItem; + class ToolButton : public QToolButton { @@ -69,5 +77,6 @@ TodayConfig::TodayConfig( QWidget* parent, const char* name, bool modal ) m_appletListView->header()->hide(); m_appletListView->setSorting( -1 ); - QWhatsThis::add( m_appletListView, tr( "Check a checkbox to activate/deactivate a plugin or use the arrow buttons on the right to change the appearance order" ) ); + QWhatsThis::add + ( m_appletListView, tr( "Check a checkbox to activate/deactivate a plugin or use the arrow buttons on the right to change the appearance order" ) ); QVBox *vbox1 = new QVBox( hbox1 ); new ToolButton( vbox1, tr( "Move Up" ), "up", this , SLOT( moveSelectedUp() ) ); @@ -85,8 +94,6 @@ TodayConfig::TodayConfig( QWidget* parent, const char* name, bool modal ) TabWidget3->addTab( tab_3, "SettingsIcon", tr( "Misc" ) ); - m_applets_changed = false; - connect ( m_appletListView , SIGNAL( clicked(QListViewItem*) ), this, SLOT( appletChanged() ) ); - + previousItem = 0l; readConfig(); QPEApplication::showDialog( this ); @@ -94,4 +101,32 @@ TodayConfig::TodayConfig( QWidget* parent, const char* name, bool modal ) +void TodayConfig::setUpPlugins( OPluginManager * plugManager, OPluginLoader *plugLoader ) { + + + m_pluginManager = plugManager; + m_pluginLoader = plugLoader; + + OPluginItem::List inLst = m_pluginLoader->allAvailable( true ); + + OPluginItem::List lst; + for ( OPluginItem::List::Iterator it = inLst.begin(); it != inLst.end(); ++it ) { + lst.prepend((*it)); + + TodayPluginInterface* iface = m_pluginLoader->load<TodayPluginInterface>( *it, IID_TodayPluginInterface ); + + if ( iface->guiPart()->configWidget(this) != 0l ) { + TodayConfigWidget* widget = iface->guiPart()->configWidget( TabWidget3 ); + TabWidget3->addTab( widget, iface->guiPart()->pixmapNameConfig() + , iface->guiPart()->appName() ); + } + } + + for ( OPluginItem::List::Iterator it = lst.begin(); it != lst.end(); ++it ) { + pluginManagement( (*it) ); + } + + TabWidget3->setCurrentTab( tab_2 ); +} + /** * Autostart, uses the new (opie only) autostart method in the launcher code. @@ -99,5 +134,5 @@ TodayConfig::TodayConfig( QWidget* parent, const char* name, bool modal ) */ void TodayConfig::setAutoStart() { - Config cfg( "today" ); + OConfig cfg( "today" ); cfg.setGroup( "Autostart" ); if ( m_autoStart ) { @@ -117,5 +152,5 @@ void TodayConfig::setAutoStart() { */ void TodayConfig::readConfig() { - Config cfg( "today" ); + OConfig cfg( "today" ); cfg.setGroup( "Autostart" ); m_autoStart = cfg.readNumEntry( "autostart", 1 ); @@ -129,8 +164,4 @@ void TodayConfig::readConfig() { m_guiMisc->SpinRefresh->setValue( cfg.readNumEntry( "checkinterval", 15000 ) / 1000 ); m_guiMisc->CheckBoxHide->setChecked( cfg.readNumEntry( "HideBanner", 0 ) ); - - - cfg.setGroup( "Plugins" ); - m_excludeApplets = cfg.readListEntry( "ExcludeApplets", ',' ); } @@ -139,31 +170,22 @@ void TodayConfig::readConfig() { */ void TodayConfig::writeConfig() { - Config cfg( "today" ); - cfg.setGroup( "Plugins" ); - if ( m_applets_changed ) { - QStringList exclude; - QStringList include; - QStringList all_applets; + OConfig cfg( "today" ); - QListViewItemIterator list_it( m_appletListView ); + int position = m_appletListView->childCount(); + QListViewItemIterator list_it( m_appletListView ); + // // this makes sure the names get saved in the order selected for ( ; list_it.current(); ++list_it ) { - QMap <QString, QCheckListItem *>::Iterator it; - for ( it = m_applets.begin(); it != m_applets. end (); ++it ) { - if ( list_it.current() == (*it) && !(*it)-> isOn () ) { - exclude << it.key(); - } else if ( list_it.current() == (*it) && (*it)-> isOn () ){ - include << it.key(); - } - if ( list_it.current() == (*it) ) { - all_applets << it.key(); + OPluginItem::List lst = m_pluginLoader->allAvailable( true ); + for ( OPluginItem::List::Iterator it = lst.begin(); it != lst.end(); ++it ) { + if ( QString::compare( (*it).name() , list_it.current()->text(0) ) == 0 ) { + (*it).setPosition(position--); + m_pluginManager->setEnabled( (*it),((QCheckListItem*)list_it.current())->isOn() ); } } } - cfg.writeEntry( "ExcludeApplets", exclude, ',' ); - cfg.writeEntry( "IncludeApplets", include, ',' ); - cfg.writeEntry( "AllApplets", all_applets, ',' ); - } + + m_pluginManager->save(); cfg.setGroup( "Autostart" ); @@ -181,4 +203,12 @@ void TodayConfig::writeConfig() { // set autostart settings setAutoStart(); + + OPluginItem::List lst = m_pluginManager->managedPlugins(); + for ( OPluginItem::List::Iterator it = lst.begin(); it != lst.end(); ++it ) { + TodayPluginInterface* iface = m_pluginLoader->load<TodayPluginInterface>( *it, IID_TodayPluginInterface ); + if ( iface->guiPart()->configWidget(this) != 0l ) { + iface->guiPart()->configWidget(this)->writeConfig(); + } + } } @@ -203,29 +233,18 @@ void TodayConfig::moveSelectedDown() { * Set up the icons in the order/active tab */ -void TodayConfig::pluginManagement( QString libName, QString name, QPixmap icon ) { +void TodayConfig::pluginManagement( OPluginItem plugItem ) { - QCheckListItem *item; - item = new QCheckListItem( m_appletListView, name, QCheckListItem::CheckBox ); + QCheckListItem *item = new QCheckListItem( m_appletListView, plugItem.name(), QCheckListItem::CheckBox ); + TodayPluginInterface* iface = m_pluginLoader->load<TodayPluginInterface>( plugItem, IID_TodayPluginInterface ); + QPixmap icon = Resource::loadPixmap( iface->guiPart()->pixmapNameWidget() ); if ( !icon.isNull() ) { item->setPixmap( 0, icon ); } - - if ( m_excludeApplets.find( libName ) == m_excludeApplets.end() ) { - item->setOn( TRUE ); + item->setOn( plugItem.isEnabled() ); + previousItem = item; } - m_applets[libName] = item; - - // kind of hack to get the first tab as default. - TabWidget3->setCurrentTab( tab_2 ); -} -void TodayConfig::appletChanged() { - m_applets_changed = true; -} - - -TodayConfig::~TodayConfig() { -} +TodayConfig::~TodayConfig() {} |