diff -r e0aa398e6810 -r 3ab5c078b490 hsappkeyhandler/src/hsappkeyplugin.cpp --- a/hsappkeyhandler/src/hsappkeyplugin.cpp Wed Aug 18 10:05:49 2010 +0300 +++ b/hsappkeyhandler/src/hsappkeyplugin.cpp Thu Sep 02 20:45:03 2010 +0300 @@ -89,9 +89,8 @@ // // --------------------------------------------------------------------------- // -TKeyResponse CHsAppKeyPlugin::HandleKeyEventL( const TKeyEvent& aKeyEvent , - TEventCode /*aType*/ - ) +TKeyResponse CHsAppKeyPlugin::HandleKeyEventL(const TKeyEvent &aKeyEvent, + TEventCode /*aType*/) { TKeyResponse retVal(EKeyWasNotConsumed); if (aKeyEvent.iCode == EKeyApplication0) { @@ -102,7 +101,7 @@ HandleShortPressL(); retVal = EKeyWasConsumed; } - iSecondEvent =!iSecondEvent; + iSecondEvent = !iSecondEvent; } return retVal; } @@ -136,23 +135,39 @@ // void CHsAppKeyPlugin::HandleShortPressL() { - RApaLsSession apaLsSession; - CleanupClosePushL(apaLsSession); - User::LeaveIfError(apaLsSession.Connect()); - CAfActivityLauncher *activityEnabler = - CAfActivityLauncher::NewLC(apaLsSession, - iEikEnv->WsSession()); - TInt state(0); - RProperty::Get(KHsCategoryUid, KHsCategoryStateKey, state); - if (state == EHomeScreenIdleState) { - activityEnabler->launchActivityL(KAppLibActivactionUri); + TInt value(0); + RProperty::Get(TsProperty::KCategory, TsProperty::KVisibilityKey, value); + if (value) { + // when Task Switcher dialog is visible, Appkey is used to dismiss it + + // @todo: remove notification through property when SharedDialog flag + // is implemented in Orbit. + if (!mDialog) { + // dismiss dialog launched from HomeScreen + User::LeaveIfError(RProperty::Set(TsProperty::KCategory, TsProperty::KDismissRequestKey, 1)); + } else { + // dismiss dialog launched by this plugin + delete mDialog; + mDialog = 0; + } } else { - activityEnabler->launchActivityL(KHsActivactionUri); - } - CleanupStack::PopAndDestroy(activityEnabler); - CleanupStack::PopAndDestroy(&apaLsSession); - delete mDialog; - mDialog =0; + // when there is no Task Switcher dialog, Appkey is used to switch between Applib and HomeScreen + RApaLsSession apaLsSession; + CleanupClosePushL(apaLsSession); + User::LeaveIfError(apaLsSession.Connect()); + CAfActivityLauncher *activityEnabler = + CAfActivityLauncher::NewLC(apaLsSession, + iEikEnv->WsSession()); + TInt state(0); + RProperty::Get(KHsCategoryUid, KHsCategoryStateKey, state); + if (state == EHomeScreenIdleState) { + activityEnabler->launchActivityL(KAppLibActivactionUri); + } else { + activityEnabler->launchActivityL(KHsActivactionUri); + } + CleanupStack::PopAndDestroy(activityEnabler); + CleanupStack::PopAndDestroy(&apaLsSession); + } } // --------------------------------------------------------------------------- @@ -166,15 +181,14 @@ RProperty::Get( TsProperty::KCategory, TsProperty::KVisibilityKey, value ); - if(!value){ - mDialog = CHbDeviceDialogSymbian::NewL(); - + if(!value) { + mDialog = CHbDeviceDialogSymbian::NewL(); CHbSymbianVariantMap* params = CHbSymbianVariantMap::NewL(); - if(KErrNone != mDialog->Show(KTsPluginName,*params,this)) { - delete mDialog; - mDialog = 0; + if(KErrNone != mDialog->Show(KTsPluginName,*params,this)) { + delete mDialog; + mDialog = 0; } - delete params; + delete params; } } }