--- a/bluetoothengine/btui/btcpplugin/btcpuimainview.cpp Fri Aug 06 16:43:21 2010 +0300
+++ b/bluetoothengine/btui/btcpplugin/btcpuimainview.cpp Fri Sep 03 16:17:59 2010 +0300
@@ -11,7 +11,7 @@
*
* Contributors:
*
-* Description: BtCpUiMainView implementation
+* Description: BtcpuiMainView implementation
*
*/
@@ -35,261 +35,182 @@
#include <hbcombobox.h>
#include <hbgroupbox.h>
#include <hbdataform.h>
+#include <HbStyleLoader>
+#include <bluetoothuitrace.h>
+#include <HbMessageBox>
+#include <btabstractdelegate.h>
+#include "btqtconstants.h"
+#include "btcpuimaingridviewitem.h"
+#include "btuidevtypemap.h"
+#include "btcpuiviewmgr.h"
#include "btcpuisearchview.h"
#include "btcpuideviceview.h"
-#include <bluetoothuitrace.h>
-#include <btdelegatefactory.h>
-#include <btabstractdelegate.h>
-#include "btqtconstants.h"
-#include "btcpuimainlistviewitem.h"
-#include "btuidevtypemap.h"
// docml to load
const char* BTUI_MAINVIEW_DOCML = ":/docml/bt-main-view.docml";
/*!
Constructs a new BtUiMainView using HBDocumentLoader. Docml (basically xml) file
- has been generated using Application Designer.
-
+ has been generated using Application Designer.
*/
-BtCpUiMainView::BtCpUiMainView(
- BtSettingModel &settingModel,
- BtDeviceModel &deviceModel,
- QGraphicsItem *parent )
- : BtCpUiBaseView( settingModel, deviceModel, parent ),
- mAbstractDelegate(0), mMainFilterModel(0)
+BtcpuiMainView::BtcpuiMainView(QGraphicsItem *parent )
+ : BtcpuiBaseView(parent), mSearchView(0), mDeviceView(0)
{
- bool ret(false);
-
- mMainWindow = hbInstance->allMainWindows().first();
- mMainView = this;
-
- // Create view for the application.
- // Set the name for the view. The name should be same as the view's
- // name in docml.
- setObjectName("view");
-
- mLoader = new HbDocumentLoader();
- // Pass the view to documentloader. Document loader uses this view
- // when docml is parsed, instead of creating new view.
- QObjectList objectList;
- objectList.append(this);
- mLoader->setObjectTree(objectList);
-
- bool ok = false;
- mLoader->load( BTUI_MAINVIEW_DOCML, &ok );
- // Exit if the file format is invalid
- BTUI_ASSERT_X( ok, "bt-main-view", "Invalid docml file" );
-
- mOrientation = mMainWindow->orientation();
-
- if (mOrientation == Qt::Horizontal) {
- mLoader->load(BTUI_MAINVIEW_DOCML, "landscape", &ok);
- BTUI_ASSERT_X( ok, "bt-main-view", "Invalid docml file: landscape section problem" );
- }
- else {
- mLoader->load(BTUI_MAINVIEW_DOCML, "portrait", &ok);
- BTUI_ASSERT_X( ok, "bt-main-view", "Invalid docml file: landscape section problem" );
- }
-
- mDeviceNameEdit=0;
- mDeviceNameEdit = qobject_cast<HbLineEdit *>( mLoader->findWidget( "lineEdit" ) );
- BTUI_ASSERT_X( mDeviceNameEdit != 0, "bt-main-view", "Device Name not found" );
- ret = connect(mDeviceNameEdit, SIGNAL(editingFinished ()), this, SLOT(changeBtLocalName()));
-
- mPowerButton=0;
- mPowerButton = qobject_cast<HbPushButton *>( mLoader->findWidget( "pushButton" ) );
- BTUI_ASSERT_X( mPowerButton != 0, "bt-main-view", "power button not found" );
- ret = connect(mPowerButton, SIGNAL(clicked()), this, SLOT(changePowerState()));
- BTUI_ASSERT_X( ret, "BtCpUiMainView::BtCpUiMainView", "can't connect power button" );
-
- mVisibilityMode=0;
- mVisibilityMode = qobject_cast<HbComboBox *>( mLoader->findWidget( "combobox" ) );
- BTUI_ASSERT_X( mVisibilityMode != 0, "bt-main-view", "visibility combobox not found" );
- // add new item for temporary visibility
- // NOTE: translation (at least default english) gives string "(p)Visible for 5 min",
- // if setting 1 min --> "(s)Visible for 1 min", ie p=plural, s=singular, but these should
- // not be shown to the user!
- // ToDo: change this to use translation once it starts working
- QString tempVis(hbTrId("txt_bt_setlabel_visibility_val_visible_for_l1_min", 5));
- //QString tempVis(hbTrId("Visible for 5 min"));
- mVisibilityMode->addItem(tempVis, Qt::DisplayRole);
-
- mDeviceList=0;
- mDeviceList = qobject_cast<HbListView *>( mLoader->findWidget( "listView" ) );
- BTUI_ASSERT_X( mDeviceList != 0, "bt-main-view", "Device List (grid view) not found" );
-
- ret = connect(mDeviceList, SIGNAL(activated(QModelIndex)), this, SLOT(deviceSelected(QModelIndex)));
- BTUI_ASSERT_X( ret, "bt-search-view", "deviceSelected can't connect" );
-
- // listen for orientation changes
- ret = connect(mMainWindow, SIGNAL(orientationChanged(Qt::Orientation)),
- this, SLOT(changeOrientation(Qt::Orientation)));
- BTUI_ASSERT_X( ret, "BtCpUiMainView::BtCpUiMainView()", "connect orientationChanged() failed");
-
- // load tool bar actions
- HbAction *discoverAction = static_cast<HbAction*>( mLoader->findObject( "discoverAction" ) );
- BTUI_ASSERT_X( discoverAction, "bt-main-view", "discover action missing" );
- ret = connect(discoverAction, SIGNAL(triggered()), this, SLOT(goToDiscoveryView()));
- BTUI_ASSERT_X( ret, "bt-main-view", "discover action can't connect" );
-
- // load tool bar actions
- mAllAction = static_cast<HbAction*>( mLoader->findObject( "allAction" ) );
- BTUI_ASSERT_X( mAllAction, "bt-main-view", "All action missing" );
- ret = connect(mAllAction, SIGNAL(triggered()), this, SLOT(allActionTriggered()));
- BTUI_ASSERT_X( ret, "bt-main-view", "all action can't connect" );
-
- // load tool bar actions
- mPairAction = static_cast<HbAction*>( mLoader->findObject( "pairedAction" ) );
- BTUI_ASSERT_X( mPairAction, "bt-main-view", "Pair action missing" );
- ret = connect(mPairAction, SIGNAL(triggered()), this, SLOT(pairActionTriggered()));
- BTUI_ASSERT_X( ret, "bt-main-view", "pair action can't connect" );
-
- mDataForm = qobject_cast<HbDataForm *>( mLoader->findWidget( "dataForm" ) );
- BTUI_ASSERT_X( mDataForm != 0, "bt-main-view", "dataForm not found" );
-
-
- // load menu
- HbMenu *optionsMenu = qobject_cast<HbMenu *>(mLoader->findWidget("viewMenu"));
- BTUI_ASSERT_X( optionsMenu != 0, "bt-main-view", "Options menu not found" );
- this->setMenu(optionsMenu);
-
- HbMenu *menu = this->menu();
- mRemovePairedDevices = menu->addAction(hbTrId("txt_bt_opt_remove_paired_devices"));
-
- mSubMenu = new HbMenu(hbTrId("txt_bt_opt_remove"));
- mSubMenu->addAction(hbTrId("txt_bt_opt_remove_sub_all_devices"));
- mSubMenu->addAction(hbTrId("txt_bt_opt_remove_sub_paired_devices"));
- mSubMenu->addAction(hbTrId("txt_bt_opt_remove_sub_blocked_devices"));
-
- // update display when setting data changed
- ret = connect(mSettingModel, SIGNAL(dataChanged(QModelIndex,QModelIndex)),
- this, SLOT(updateSettingItems(QModelIndex,QModelIndex)));
- BTUI_ASSERT_X( ret, "BtCpUiMainView::BtCpUiMainView", "can't connect dataChanged" );
-
- QModelIndex top = mSettingModel->index( BtSettingModel::LocalBtNameRow, 0 );
- QModelIndex bottom = mSettingModel->index( BtSettingModel::AllowedInOfflineRow, 0 );
- // update name, power and visibility rows
- updateSettingItems( top, bottom );
-
- //Handle Visibility Change User Interaction
- ret = connect(mVisibilityMode, SIGNAL(currentIndexChanged (int)),
- this, SLOT(visibilityChanged (int)));
- // create other views
- createViews();
- mCurrentView = this;
- mCurrentViewId = MainView;
-
- mMainFilterModel = new BtuiModelSortFilter(this);
-
- mMainFilterModel->setSourceModel( mDeviceModel );
- mDeviceList->setModel(mMainFilterModel);
- updateDeviceListFilter(BtuiPaired);
- // List view item
- BtCpUiMainListViewItem *prototype = new BtCpUiMainListViewItem(mDeviceList);
- prototype->setModelSortFilter(mMainFilterModel);
- mDeviceList->setItemPrototype(prototype);
-
+ loadDocument();
+ setViewMgr(this);
}
/*!
- Destructs the BtCpUiMainView.
+ Constructs a new BtUiMainView using HBDocumentLoader. Docml (basically xml) file
+ has been generated using Application Designer.
*/
-BtCpUiMainView::~BtCpUiMainView()
+BtcpuiMainView::BtcpuiMainView(BtSettingModel &settingModel,
+ BtDeviceModel &deviceModel,
+ QGraphicsItem *parent )
+ : BtcpuiBaseView(settingModel, deviceModel, parent ), mSearchView(0), mDeviceView(0)
{
+ loadDocument();
+ setViewMgr(this);
+}
+
+/*!
+ Destructs the BtcpuiMainView.
+ */
+BtcpuiMainView::~BtcpuiMainView()
+{
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
+ delete mSearchView;
+ delete mDeviceView;
delete mLoader; // Also deletes all widgets that it constructed.
- mMainWindow->removeView(mSearchView);
- mMainWindow->removeView(mDeviceView);
- if (mAbstractDelegate) {
- delete mAbstractDelegate;
- }
-
+ HbStyleLoader::unregisterFilePath(":/docml/btcpuimaingridviewitem.widgetml");
+ HbStyleLoader::unregisterFilePath(":/docml/btcpuimaingridviewitem.css");
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
}
/*!
from base class, initialize the view
*/
-void BtCpUiMainView::activateView(const QVariant& value, bool fromBackButton )
+void BtcpuiMainView::activateView(const QVariant& value, bool backNavi)
{
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
Q_UNUSED(value);
- Q_UNUSED(fromBackButton);
-
- //Reset the device list when returning to the view, as it may have been invalidated by the device view
- mMainFilterModel->setSourceModel( mDeviceModel );
- mDeviceList->setModel(mMainFilterModel);
+ Q_UNUSED(backNavi);
+ QModelIndex top = mSettingModel->index( BtSettingModel::LocalBtNameRow, 0 );
+ QModelIndex bottom = mSettingModel->index( BtSettingModel::AllowedInOfflineRow, 0 );
+ // update name, power and visibility rows
+ updateSettingItems( top, bottom );
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
}
-/*!
+/*!
From base class. Handle resource before the current view is deactivated.
*/
-void BtCpUiMainView::deactivateView()
+void BtcpuiMainView::deactivateView()
{
-
-}
-
-void BtCpUiMainView::goToDiscoveryView()
-{
- changeView( SearchView, false );
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
}
-void BtCpUiMainView::goToDeviceView(const QModelIndex& modelIndex)
+void BtcpuiMainView::launchDeviceDiscovery()
{
- //the QModelIndex of the selected device should be given as parameter here
- QVariant params;
- params.setValue(modelIndex);
- changeView( DeviceView, false, params );
-}
-
-Qt::Orientation BtCpUiMainView::orientation()
-{
- return mOrientation;
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
+ // Construct the search view if it does not exist yet.
+ (void) searchView();
+ bool ok = createDelegate(BtDelegate::Inquiry,
+ this, SLOT(handleDelegateCompleted(int,BtAbstractDelegate*)));
+ if (ok) {
+ // Connect to the signal from BtDelegateInquiry for switching to
+ // search view when BT inquiry operation is really started.
+ ok = connect(mDelegate, SIGNAL(beginUiEditMode()), this, SLOT(goToSearchView()));
+ BTUI_ASSERT_X( ok, "BtcpuiMainView", "launchDeviceDiscovery() can't connect" );
+ }
+ if (ok) {
+ mDelegate->exec(QVariant());
+ }
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
}
-void BtCpUiMainView::changeBtLocalName()
+void BtcpuiMainView::goToSearchView()
{
- //Error handling has to be done.
- if (!mAbstractDelegate) {
- mAbstractDelegate = BtDelegateFactory::newDelegate(BtDelegate::DeviceName,
- mSettingModel, mDeviceModel);
- connect( mAbstractDelegate, SIGNAL(commandCompleted(int,QVariant)), this, SLOT(btNameDelegateCompleted(int,QVariant)) );
- mAbstractDelegate->exec(mDeviceNameEdit->text ());
- }
- else {
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
+ BtcpuiBaseView *search = searchView();
+ // For navigating back to this view
+ search->setPreviousView( this );
+ search->take(mDelegate);
+ mDelegate = 0;
+ switchView(this, search, QVariant(), false);
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
+}
+
+void BtcpuiMainView::changeBtLocalName()
+{
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
+ bool ok = createExecuteDelegate(BtDelegate::ChangeLocalName,
+ this, SLOT(btNameDelegateCompleted(int)), mDeviceNameEdit->text());
+ if (!ok) {
setPrevBtLocalName();
}
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
}
-void BtCpUiMainView::setPrevBtLocalName()
+void BtcpuiMainView::setPrevBtLocalName()
{
- //ToDo: Should we notify user this as Error...?
- //HbNotificationDialog::launchDialog(hbTrId("Error"));
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
QModelIndex index = mSettingModel->index( BtSettingModel::LocalBtNameRow,0 );
mDeviceNameEdit->setText( mSettingModel->data(
index,BtSettingModel::settingDisplayRole).toString() );
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
}
-
-void BtCpUiMainView::btNameDelegateCompleted(int status, QVariant param)
+void BtcpuiMainView::btNameDelegateCompleted(int status)
{
- if(KErrNone == status) {
- mDeviceNameEdit->setText(param.toString());
- }
- else {
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
+ if(KErrNone != status) {
setPrevBtLocalName();
}
- //Error handling has to be done.
- if (mAbstractDelegate)
- {
- disconnect(mAbstractDelegate);
- delete mAbstractDelegate;
- mAbstractDelegate = 0;
- }
-
+ handleDelegateCompleted(status, mDelegate);
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
}
-void BtCpUiMainView::visibilityChanged (int index)
+void BtcpuiMainView::removeRegistryDevices(BtDelegate::EditorType type)
{
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
+
+ if (type != BtDelegate::RemoveBlockedDevices) {
+ //Before removing devices from the list call disconnect delegate
+ //to disconnect all active connections, this is done if all/paired
+ //devices are removed.
+ QList<QVariant> list;
+ list.append(QVariant( AllOngoingConnections ));
+
+ (void) createExecuteDelegate(BtDelegate::DisconnectAllConnections,
+ this, SLOT(disconnectAllDelegateCompleted(int)), list);
+ }
+ else {
+ //In case of Blocked devices, just remove devices from list.
+ (void) createExecuteDelegate(type,
+ this, SLOT(handleDelegateCompleted(int,BtAbstractDelegate*)), type);
+ }
+
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
+}
+
+void BtcpuiMainView::disconnectAllDelegateCompleted(int status)
+{
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
+ handleDelegateCompleted(status, mDelegate);
+
+ //Remove Device list from registry after disconnect is done.
+ (void) createExecuteDelegate(mRemoveDevDelegateType,
+ this, SLOT(handleDelegateCompleted(int,BtAbstractDelegate*)), mRemoveDevDelegateType);
+
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
+}
+
+void BtcpuiMainView::changeVisibility(int index)
+{
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
QList<QVariant> list;
VisibilityMode mode = indexToVisibilityMode(index);
@@ -298,57 +219,240 @@
//Right now hardcoded to 5 Mins.
list.append(QVariant(5));
}
+ bool ok = createExecuteDelegate(BtDelegate::ChangeVisibility,
+ this, SLOT(visibilityDelegateCompleted(int)), list);
//Error handling has to be done.
- if ( !mAbstractDelegate ) {
- mAbstractDelegate = BtDelegateFactory::newDelegate(BtDelegate::Visibility,
- mSettingModel, mDeviceModel);
- connect( mAbstractDelegate, SIGNAL(commandCompleted(int)), this, SLOT(visibilityDelegateCompleted(int)) );
- mAbstractDelegate->exec(list);
- }
- else {
+ if ( !ok ) {
setPrevVisibilityMode();
}
-
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
}
-void BtCpUiMainView::setPrevVisibilityMode()
+void BtcpuiMainView::setPrevVisibilityMode()
{
-
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
QModelIndex index = mSettingModel->index( BtSettingModel::VisibilityRow, 0 );
mVisibilityMode->setCurrentIndex ( visibilityModeToIndex((VisibilityMode)
mSettingModel->data(index,BtSettingModel::SettingValueRole).toInt()) );
-
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
}
-void BtCpUiMainView::allActionTriggered()
+void BtcpuiMainView::allActionTriggered()
+{
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
+
+ updateDeviceListFilter(BtuiAll);
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
+}
+
+void BtcpuiMainView::pairActionTriggered()
+{
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
+
+ updateDeviceListFilter(BtuiPaired);
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
+}
+
+void BtcpuiMainView::aboutToShowOptionsMenu()
+{
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
+
+ updateOptionsMenu();
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
+}
+
+void BtcpuiMainView::updateOptionsMenu()
{
- HbMenu *menu = this->menu();
- menu->removeAction(mRemovePairedDevices);
- mRemoveDevices = menu->addMenu( mSubMenu );
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
+
+ if(mPairAction->isEnabled()) {
+ //All Toolbar Action is active
+ mRemovePairedDevices->setVisible(false);
+
+ int devCount = mDeviceModel->deviceCount(BtuiDevProperty::InRegistry);
+ bool visibility = false;
+
+ HbAction *subMenuAction = static_cast<HbAction*> (mLoader->findObject(
+ "showAction"));
- updateDeviceListFilter(BtuiAll);
+ if(!devCount) {
+ //No Registry devices then return.
+ mSubMenu->menuAction()->setVisible(false);
+ subMenuAction->setVisible(false);
+ return;
+ }
+
+ visibility = true;
+ mSubMenu->menuAction()->setVisible(visibility);
+ subMenuAction->setVisible(visibility);
+
+ subMenuAction = static_cast<HbAction*> (mLoader->findObject(
+ "removeAllAction"));
+ subMenuAction->setVisible(visibility);
+
+ devCount = mDeviceModel->deviceCount(BtuiDevProperty::Bonded);
+
+ visibility = false;
+ if(devCount) {
+ visibility = true;
+ }
+ subMenuAction = static_cast<HbAction*> (mLoader->findObject(
+ "removePairedAction"));
+ subMenuAction->setVisible(visibility);
+
+ devCount = mDeviceModel->deviceCount(BtuiDevProperty::Blocked);
+
+ visibility = false;
+ if(devCount) {
+ visibility = true;
+ }
+ subMenuAction = static_cast<HbAction*> (mLoader->findObject(
+ "removeBlockedAction"));
+ subMenuAction->setVisible(visibility);
+
+ }
+ else {
+ //Pair Toolbar Action is active
+ mSubMenu->menuAction()->setVisible(false);
+
+ int devCount = mDeviceModel->deviceCount(BtuiDevProperty::Bonded);
+ bool visibility = false;
+
+ HbAction *subMenuAction = static_cast<HbAction*> (mLoader->findObject(
+ "showAction"));
+
+ if(devCount) {
+ visibility = true;
+ }
+ mRemovePairedDevices->setVisible(visibility);
+ subMenuAction->setVisible(visibility);
+ }
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
}
-void BtCpUiMainView::pairActionTriggered()
+void BtcpuiMainView::menuActionTriggered(HbAction *action)
{
- HbMenu *menu = this->menu();
- menu->removeAction(mRemoveDevices);
- mRemovePairedDevices = menu->addAction(hbTrId("txt_bt_opt_remove_paired_devices"));
- updateDeviceListFilter(BtuiPaired);
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
+
+ if(!(action->text().compare(hbTrId("txt_bt_opt_advanced_settings")))) {
+ //Advance Settings is not implemented yet.
+ return;
+ }
+
+ if(!(action->text().compare(hbTrId("txt_bt_opt_show")))) {
+ viewByDeviceTypeDialog();
+ }
+ else {
+ QString dialogtext;
+
+ if(!(action->text().compare(hbTrId("txt_bt_opt_remove_sub_all_devices")))) {
+ mRemoveDevDelegateType = BtDelegate::RemoveAllRegistryDevices;
+ dialogtext = hbTrId("txt_bt_info_delete_all_devices_some_devices_may_b");
+ }
+ else if(!(action->text().compare(hbTrId("txt_bt_opt_remove_sub_blocked_devices")))) {
+ mRemoveDevDelegateType = BtDelegate::RemoveBlockedDevices;
+ dialogtext = hbTrId("txt_bt_info_delete_all_blocked_devices");
+ }
+ else {
+ mRemoveDevDelegateType = BtDelegate::RemovePairedDevices;
+ dialogtext = hbTrId("txt_bt_info_delete_all_paired_devices_some_device");
+ }
+
+ HbMessageBox* dialog = new HbMessageBox(HbMessageBox::MessageTypeQuestion);
+ dialog->setText(dialogtext);
+ dialog->setStandardButtons(HbMessageBox::Yes | HbMessageBox::No);
+ dialog->setAttribute(Qt::WA_DeleteOnClose);
+
+ dialog->open(this,SLOT(onRemoveQuestionDialogClosed(int)));
+
+ }
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
+}
+
+void BtcpuiMainView::onRemoveQuestionDialogClosed(int action)
+{
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
+
+ if (action == HbMessageBox::Yes) {
+ removeRegistryDevices(mRemoveDevDelegateType);
+ }
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
}
-void BtCpUiMainView::updateDeviceListFilter(BtCpUiMainView::filterType filter)
+/*!
+ Callback for HbSelectionDialog closing
+ ReImplemented Slot from Base class
+
+ */
+void BtcpuiMainView::viewByDialogClosed(HbAction* action)
+{
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
+
+ int devTypesWanted = 0;
+
+ devTypesWanted = selectedDeviceTypes(action);
+
+ if (devTypesWanted) {
+ mBtuiModelSortFilter->clearDeviceMajorFilters();
+ if(mAllAction->isEnabled()) {
+ mBtuiModelSortFilter->addDeviceMajorFilter(
+ BtuiDevProperty::InRegistry | BtuiDevProperty::Bonded,
+ BtuiModelSortFilter::AtLeastMatch);
+ }
+ else {
+ mBtuiModelSortFilter->addDeviceMajorFilter(
+ BtuiDevProperty::InRegistry,
+ BtuiModelSortFilter::AtLeastMatch);
+ }
+ mBtuiModelSortFilter->addDeviceMajorFilter(devTypesWanted,
+ BtuiModelSortFilter::RoughMatch); // device can be any one of selected ones
+ }
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
+}
+
+BtcpuiBaseView *BtcpuiMainView::searchView()
{
- mMainFilterModel->clearDeviceMajorFilters();
+ if (!mSearchView) {
+ mSearchView = new BtcpuiSearchView(*mSettingModel, *mDeviceModel);
+ mSearchView->setViewMgr(this);
+ mMainWindow->addView(mSearchView);
+ }
+ return mSearchView;
+}
+
+BtcpuiBaseView *BtcpuiMainView::deviceView()
+{
+ if (!mDeviceView) {
+ mDeviceView = new BtcpuiDeviceView(*mSettingModel, *mDeviceModel);
+ mDeviceView->setViewMgr(this);
+ mMainWindow->addView(mDeviceView);
+ }
+ return mDeviceView;
+}
+
+void BtcpuiMainView::switchView(
+ BtcpuiBaseView *from, BtcpuiBaseView *destination,
+ const QVariant &init, bool backNavi)
+{
+ BTUI_ASSERT_X( from && destination, "BtcpuiSettingItem::switchView", "null view" );
+ from->deactivateView();
+ mMainWindow->setCurrentView( destination );
+ destination->activateView( init, backNavi);
+}
+
+void BtcpuiMainView::updateDeviceListFilter(BtcpuiMainView::filterType filter)
+{
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
+ mBtuiModelSortFilter->clearDeviceMajorFilters();
switch (filter) {
case BtuiAll:
mDataForm->setHeading(hbTrId("txt_bt_subhead_bluetooth_all_devices"));
mPairAction->setEnabled(true);
mAllAction->setEnabled(false);
- mMainFilterModel->addDeviceMajorFilter(
+ mBtuiModelSortFilter->addDeviceMajorFilter(
BtuiDevProperty::InRegistry,
BtuiModelSortFilter::AtLeastMatch);
@@ -357,56 +461,62 @@
mDataForm->setHeading(hbTrId("txt_bt_subhead_bluetooth_paired_devices"));
mPairAction->setEnabled(false);
mAllAction->setEnabled(true);
- mMainFilterModel->addDeviceMajorFilter(
+ mBtuiModelSortFilter->addDeviceMajorFilter(
BtuiDevProperty::InRegistry | BtuiDevProperty::Bonded,
BtuiModelSortFilter::AtLeastMatch);
break;
}
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
}
-
-void BtCpUiMainView::visibilityDelegateCompleted(int status)
+void BtcpuiMainView::visibilityDelegateCompleted(int status)
{
-
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
//This should be mapped to Qt error
if(KErrNone != status) {
setPrevVisibilityMode();
}
-
- //Error handling has to be done.
- if (mAbstractDelegate)
- {
- disconnect(mAbstractDelegate);
- delete mAbstractDelegate;
- mAbstractDelegate = 0;
- }
-
+ handleDelegateCompleted(status, mDelegate);
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
}
// called due to real orientation change event coming from main window
-void BtCpUiMainView::changeOrientation( Qt::Orientation orientation )
+void BtcpuiMainView::changeOrientation( Qt::Orientation orientation )
{
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
bool ok = false;
mOrientation = orientation;
if( orientation == Qt::Vertical ) {
// load "portrait" section
mLoader->load( BTUI_MAINVIEW_DOCML, "portrait", &ok );
BTUI_ASSERT_X( ok, "bt-main-view", "Invalid docml file: portrait section problem" );
+
+ mDeviceList->setColumnCount(1);
+ mDeviceList->setRowCount(4);
+ mDeviceList->setScrollDirections(Qt::Vertical);
+ mDeviceList->setVerticalScrollBarPolicy(HbScrollArea::ScrollBarAsNeeded );
} else {
// load "landscape" section
mLoader->load( BTUI_MAINVIEW_DOCML, "landscape", &ok );
BTUI_ASSERT_X( ok, "bt-main-view", "Invalid docml file: landscape section problem" );
+
+ mDeviceList->setRowCount(1);
+ mDeviceList->setColumnCount(6);
+ mDeviceList->setScrollDirections(Qt::Horizontal);
+ mDeviceList->setHorizontalScrollBarPolicy(HbScrollArea::ScrollBarAsNeeded );
}
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
}
/*!
Slot for receiving notification of local setting changes from the model.
Identify the setting changed and update the corresponding UI item.
*/
-void BtCpUiMainView::updateSettingItems(const QModelIndex &topLeft, const QModelIndex &bottomRight)
+void BtcpuiMainView::updateSettingItems(const QModelIndex &topLeft, const QModelIndex &bottomRight)
{
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
bool val(false);
// update only the part of the view specified by the model's row(s)
@@ -436,19 +546,21 @@
mSettingModel->data(index,BtSettingModel::SettingValueRole).toInt()) );
break;
}
- }
+ }
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
}
/*!
Slot for receiving notification for user interaction on power state.
Manually update model data since HbPushButton is not linked to model directly.
*/
-void BtCpUiMainView::changePowerState()
+void BtcpuiMainView::changePowerState()
{
+ BOstraceFunctionEntry1( DUMMY_DEVLIST, this );
QModelIndex index = mSettingModel->index(BtSettingModel::PowerStateRow, 0);
PowerStateQtValue powerState = (PowerStateQtValue)mSettingModel->data(index, Qt::EditRole).toInt();
BTUI_ASSERT_X(((powerState == BtPowerOn) || (powerState == BtPowerOff)),
- "BtCpUiMainView::changePowerState()", "incorrect qt power state");
+ "BtcpuiMainView::changePowerState()", "incorrect qt power state");
if (powerState == BtPowerOff) {
powerState = BtPowerOn;
@@ -456,34 +568,167 @@
else {
powerState = BtPowerOff;
}
-
- if (!mAbstractDelegate)//if there is no other delegate running
- {
- mAbstractDelegate = BtDelegateFactory::newDelegate(BtDelegate::ManagePower,
- mSettingModel, mDeviceModel );
- connect( mAbstractDelegate, SIGNAL(commandCompleted(int)), this, SLOT(powerDelegateCompleted(int)) );
- mAbstractDelegate->exec(QVariant((int)powerState));
- }
-
+ (void) createExecuteDelegate(BtDelegate::ManagePower,
+ this, SLOT(handleDelegateCompleted(int,BtAbstractDelegate*)),
+ QVariant((int)powerState));
+ BOstraceFunctionExit0(DUMMY_DEVLIST);
}
-void BtCpUiMainView::powerDelegateCompleted(int status)
+void BtcpuiMainView::loadDocument()
{
- Q_UNUSED(status);
- //ToDo: Error handling here
- if (mAbstractDelegate)
- {
- disconnect(mAbstractDelegate);
- delete mAbstractDelegate;
- mAbstractDelegate = 0;
+ bool ret(false);
+ // Create view for the application.
+ // Set the name for the view. The name should be same as the view's
+ // name in docml.
+ setObjectName("bt_main_view");
+
+ mLoader = new HbDocumentLoader();
+ // Pass the view to documentloader. Document loader uses this view
+ // when docml is parsed, instead of creating new view.
+ QObjectList objectList;
+ objectList.append(this);
+ mLoader->setObjectTree(objectList);
+
+ bool ok = false;
+ mLoader->load( BTUI_MAINVIEW_DOCML, &ok );
+ // Exit if the file format is invalid
+ BTUI_ASSERT_X( ok, "bt-main-view", "Invalid docml file" );
+
+ mDeviceList=0;
+ mDeviceList = qobject_cast<HbGridView *>( mLoader->findWidget( "deviceList" ) );
+ BTUI_ASSERT_X( mDeviceList != 0, "bt-main-view", "Device List (grid view) not found" );
+
+ ret = connect(mDeviceList, SIGNAL(activated(QModelIndex)), this, SLOT(deviceSelected(QModelIndex)));
+ BTUI_ASSERT_X( ret, "bt-main-view", "deviceSelected can't connect" );
+
+ ret = connect(mDeviceList,
+ SIGNAL(longPressed(HbAbstractViewItem*, QPointF)), this,
+ SLOT(showContextMenu(HbAbstractViewItem*, QPointF)));
+ BTUI_ASSERT_X( ret, "bt-main-view", "deviceSelected can't connect" );
+
+ mOrientation = mMainWindow->orientation();
+
+ mDeviceList->setSwapDimensionsOnOrientationChange(false);
+
+ if (mOrientation == Qt::Horizontal) {
+ mLoader->load(BTUI_MAINVIEW_DOCML, "landscape", &ok);
+ BTUI_ASSERT_X( ok, "bt-main-view", "Invalid docml file: landscape section problem" );
+ mDeviceList->setRowCount(1);
+ mDeviceList->setColumnCount(6);
+ mDeviceList->setScrollDirections(Qt::Horizontal);
+ mDeviceList->setHorizontalScrollBarPolicy(HbScrollArea::ScrollBarAsNeeded );
+ }
+ else {
+ mLoader->load(BTUI_MAINVIEW_DOCML, "portrait", &ok);
+ BTUI_ASSERT_X( ok, "bt-main-view", "Invalid docml file: landscape section problem" );
+ mDeviceList->setColumnCount(1);
+ mDeviceList->setRowCount(4);
+ mDeviceList->setScrollDirections(Qt::Vertical);
+ mDeviceList->setVerticalScrollBarPolicy(HbScrollArea::ScrollBarAsNeeded );
}
- //BTUI_ASSERT_X( status, "bt-main-view", "error in delegate complete" );
+
+ mDeviceNameEdit=0;
+ mDeviceNameEdit = qobject_cast<HbLineEdit *>( mLoader->findWidget( "deviceNameEdit" ) );
+ BTUI_ASSERT_X( mDeviceNameEdit != 0, "bt-main-view", "Device Name not found" );
+ ret = connect(mDeviceNameEdit, SIGNAL(editingFinished ()), this, SLOT(changeBtLocalName()));
+
+ mPowerButton=0;
+ mPowerButton = qobject_cast<HbPushButton *>( mLoader->findWidget( "toggleBluetoothPower" ) );
+ BTUI_ASSERT_X( mPowerButton != 0, "bt-main-view", "power button not found" );
+ ret = connect(mPowerButton, SIGNAL(clicked()), this, SLOT(changePowerState()));
+ BTUI_ASSERT_X( ret, "BtcpuiMainView::BtcpuiMainView", "can't connect power button" );
+
+ mVisibilityMode=0;
+ mVisibilityMode = qobject_cast<HbComboBox *>( mLoader->findWidget( "visibilityMode" ) );
+ BTUI_ASSERT_X( mVisibilityMode != 0, "bt-main-view", "visibility combobox not found" );
+ // add new item for temporary visibility
+ // NOTE: translation (at least default english) gives string "(p)Visible for 5 min",
+ // if setting 1 min --> "(s)Visible for 1 min", ie p=plural, s=singular, but these should
+ // not be shown to the user!
+ // ToDo: change this to use translation once it starts working
+ QString tempVis(hbTrId("txt_bt_setlabel_visibility_val_visible_for_l1_min", 5));
+ //QString tempVis(hbTrId("Visible for 5 min"));
+ mVisibilityMode->addItem(tempVis, Qt::DisplayRole);
+
+ // listen for orientation changes
+ ret = connect(mMainWindow, SIGNAL(orientationChanged(Qt::Orientation)),
+ this, SLOT(changeOrientation(Qt::Orientation)));
+ BTUI_ASSERT_X( ret, "BtcpuiMainView::BtcpuiMainView()", "connect orientationChanged() failed");
+
+ // load tool bar actions
+ HbAction *discoverAction = static_cast<HbAction*>( mLoader->findObject( "discoverAction" ) );
+ BTUI_ASSERT_X( discoverAction, "bt-main-view", "discover action missing" );
+ ret = connect(discoverAction, SIGNAL(triggered()), this, SLOT(launchDeviceDiscovery()));
+ BTUI_ASSERT_X( ret, "bt-main-view", "discover action can't connect" );
+
+ // load tool bar actions
+ mAllAction = static_cast<HbAction*>( mLoader->findObject( "allAction" ) );
+ BTUI_ASSERT_X( mAllAction, "bt-main-view", "All action missing" );
+ ret = connect(mAllAction, SIGNAL(triggered()), this, SLOT(allActionTriggered()));
+ BTUI_ASSERT_X( ret, "bt-main-view", "all action can't connect" );
+
+ // load tool bar actions
+ mPairAction = static_cast<HbAction*>( mLoader->findObject( "pairedAction" ) );
+ BTUI_ASSERT_X( mPairAction, "bt-main-view", "Pair action missing" );
+ ret = connect(mPairAction, SIGNAL(triggered()), this, SLOT(pairActionTriggered()));
+ BTUI_ASSERT_X( ret, "bt-main-view", "pair action can't connect" );
+
+ mDataForm = qobject_cast<HbDataForm *>( mLoader->findWidget( "bluetoothHeading" ) );
+ BTUI_ASSERT_X( mDataForm != 0, "bt-main-view", "dataForm not found" );
+
+
+ // load menu
+ HbMenu *optionsMenu = qobject_cast<HbMenu *>(mLoader->findWidget("viewMenu"));
+ BTUI_ASSERT_X( optionsMenu != 0, "bt-main-view", "Options menu not found" );
+ ret = connect(optionsMenu, SIGNAL(triggered(HbAction *)), this, SLOT(menuActionTriggered(HbAction *)));
+ BTUI_ASSERT_X( ret, "bt-main-view", "Menu can't connect" );
+
+ ret = connect(optionsMenu, SIGNAL(aboutToShow()), this, SLOT(aboutToShowOptionsMenu()));
+ BTUI_ASSERT_X( ret, "bt-main-view", "Menu aboutToShow() can't connect" );
+
+ mSubMenu = qobject_cast<HbMenu *>(mLoader->findWidget("removeSubMenu"));
+ BTUI_ASSERT_X( optionsMenu != 0, "bt-main-view", "Options Sub menu not found" );
+
+ mRemovePairedDevices = static_cast<HbAction*>( mLoader->findObject( "viewRemovePairedAction" ) );
+
+ // update display when setting data changed
+ ret = connect(mSettingModel, SIGNAL(dataChanged(QModelIndex,QModelIndex)),
+ this, SLOT(updateSettingItems(QModelIndex,QModelIndex)));
+ BTUI_ASSERT_X( ret, "BtcpuiMainView::BtcpuiMainView", "can't connect dataChanged" );
+
+ QModelIndex top = mSettingModel->index( BtSettingModel::LocalBtNameRow, 0 );
+ QModelIndex bottom = mSettingModel->index( BtSettingModel::AllowedInOfflineRow, 0 );
+ // update name, power and visibility rows
+ updateSettingItems( top, bottom );
+
+ //Handle Visibility Change User Interaction
+ ret = connect(mVisibilityMode, SIGNAL(currentIndexChanged (int)),
+ this, SLOT(changeVisibility(int)));
+
+ bool regStatus(false);
+ regStatus = HbStyleLoader::registerFilePath(":/docml/btcpuimaingridviewitem.widgetml");
+ BTUI_ASSERT_X( regStatus, "BtcpuiMainView::BtcpuiMainView", "registerFilePath Widgetml Failed" );
+ regStatus = HbStyleLoader::registerFilePath(":/docml/btcpuimaingridviewitem.css");
+ BTUI_ASSERT_X( regStatus, "BtcpuiMainView::BtcpuiMainView", "registerFilePath CSS Failed" );
+
+ mBtuiModelSortFilter = new BtuiModelSortFilter(this);
+
+ mBtuiModelSortFilter->setSourceModel( mDeviceModel );
+ mDeviceList->setModel(mBtuiModelSortFilter);
+ mDeviceList->setLayoutName("portrait");
+ updateDeviceListFilter(BtuiPaired);
+
+ mSubMenu->menuAction()->setVisible(false);
+ // Grid view item
+ BtCpUiMainGridViewItem *prototype = new BtCpUiMainGridViewItem(mDeviceList);
+ prototype->setModelSortFilter(mBtuiModelSortFilter);
+ mDeviceList->setItemPrototype(prototype);
}
/*!
* Mapping from visibility mode UI row to VisibilityMode
*/
-VisibilityMode BtCpUiMainView::indexToVisibilityMode(int index)
+VisibilityMode BtcpuiMainView::indexToVisibilityMode(int index)
{
VisibilityMode mode = BtVisibilityUnknown;
switch(index) {
@@ -497,7 +742,7 @@
mode = BtTemporary;
break;
default:
- BTUI_ASSERT_X(false, "BtCpUiMainView::indexToVisibilityMode", "invalid mode");
+ BTUI_ASSERT_X(false, "BtcpuiMainView::indexToVisibilityMode", "invalid mode");
}
return mode;
}
@@ -505,7 +750,7 @@
/*!
* Mapping from VisibilityMode to visibility mode UI row
*/
-int BtCpUiMainView::visibilityModeToIndex(VisibilityMode mode)
+int BtcpuiMainView::visibilityModeToIndex(VisibilityMode mode)
{
int uiRow = UiRowBtUnknown;
switch(mode) {
@@ -519,106 +764,17 @@
uiRow = UiRowBtTemporary;
break;
default:
- BTUI_ASSERT_X(false, "BtCpUiMainView::visibilityModeToIndex", "invalid mode");
+ BTUI_ASSERT_X(false, "BtcpuiMainView::visibilityModeToIndex", "invalid mode");
}
return uiRow;
}
-
-
-/*!
- Create views(main view, device view and search view).
- Add them to MainWindow. All views are long-lived and are deleted only when exiting the application
- (or when main view is deleted).
- */
-void BtCpUiMainView::createViews()
-{
- Qt::Orientation orientation = mMainWindow->orientation();
- // Create other views
- mSearchView = new BtCpUiSearchView( *mSettingModel, *mDeviceModel, this );
- mMainWindow->addView(mSearchView);
-
- mDeviceView = new BtCpUiDeviceView( *mSettingModel, *mDeviceModel, this );
- mMainWindow->addView(mDeviceView);
-
- mCurrentView = this;
- mCurrentViewId = MainView;
-
-
- // QList<int> stores the previous view ids for each view.
- for( int i=0; i < LastView; i++ ) {
- mPreviousViewIds.append( 0 );
- }
-}
-
-/*!
- Switch between the views.
- Parameter "value" is optional except for GadgetView,
- which needs the QModelIndex of device
- */
-void BtCpUiMainView::changeView(int targetViewId, bool fromBackButton,
- const QVariant& value )
-{
- mCurrentView->deactivateView();
-
- // update the previous view Id in QList<int>
- // If launching the target view from back softkey,
- // the previous viewId of target view should not be changed.
- // Otherwise, loop happens between two views.
- if(!fromBackButton) {
- // normal case: return to previous view
- mPreviousViewIds[ targetViewId ] = mCurrentViewId;
+void BtcpuiMainView::createContextMenuActions(int majorRole)
+{
+ if (majorRole & BtuiDevProperty::Connected) {
+ mContextMenu->addAction(hbTrId("txt_bt_menu_disconnect"));
}
-
- // set the new current view
- mCurrentView = idToView(targetViewId);
- mCurrentViewId = targetViewId;
- mMainWindow->setCurrentView( mCurrentView );
-
- // do preparation or some actions when new view is activated
- mCurrentView->activateView( value, fromBackButton );
-}
-
-
-void BtCpUiMainView::deviceSelected(const QModelIndex& modelIndex)
-{
- QModelIndex index = mMainFilterModel->mapToSource(modelIndex);
-
- QVariant params;
- params.setValue(index);
-
- changeView( DeviceView, false, params );
+ else {
+ mContextMenu->addAction(hbTrId("txt_bt_menu_connect"));
+ }
}
-
-BtCpUiBaseView * BtCpUiMainView::idToView(int targetViewId)
-{
- switch (targetViewId) {
- case MainView:
- return mMainView;
- case SearchView:
- return mSearchView;
- case DeviceView:
- return mDeviceView;
- default :
- BTUI_ASSERT_X(false, "BtCpUiMainView::idToView", "invalid view id");
- }
- return 0;
-}
-
-void BtCpUiMainView::setSoftkeyBack()
-{
- // not needed in main view
-}
-
-/*!
- Jump to previous view. This function is used when back button is pressed.
- semantics slightly different than in other views, since this is called by other
- views when a view switch is needed
- */
-void BtCpUiMainView::switchToPreviousView()
-{
- BTUI_ASSERT_X( (mCurrentViewId >= 0) && (mCurrentViewId < LastView),
- "BtCpUiMainView::switchToPreviousView", "invalid view id");
- changeView( mPreviousViewIds[mCurrentViewId], true );
-}
-