| author | Sebastian Brannstrom <sebastianb@symbian.org> | 
| Sun, 14 Nov 2010 13:06:35 +0000 | |
| branch | newlist | 
| changeset 348 | bd7f3de17443 | 
| parent 347 | b8d687bb7ca1 | 
| permissions | -rw-r--r-- | 
| 2 | 1 | /* | 
| 2 | * Copyright (c) 2007-2010 Sebastian Brannstrom, Lars Persson, EmbedDev AB | |
| 3 | * | |
| 4 | * All rights reserved. | |
| 5 | * This component and the accompanying materials are made available | |
| 6 | * under the terms of the License "Eclipse Public License v1.0" | |
| 7 | * which accompanies this distribution, and is available | |
| 8 | * at the URL "http://www.eclipse.org/legal/epl-v10.html". | |
| 9 | * | |
| 10 | * Initial Contributors: | |
| 11 | * EmbedDev AB - initial contribution. | |
| 12 | * | |
| 13 | * Contributors: | |
| 14 | * | |
| 15 | * Description: | |
| 16 | * | |
| 17 | */ | |
| 18 | ||
| 19 | #include "PodcastSearchView.h" | |
| 20 | #include "PodcastAppUi.h" | |
| 21 | #include "FeedEngine.h" | |
| 22 | #include "ShowEngine.h" | |
| 23 | #include "SettingsEngine.h" | |
| 24 | #include "PodcastApp.h" | |
| 25 | #include "PodcastUtils.h" | |
| 26 | #include <caknfileselectiondialog.h> | |
| 27 | #include <podcast.rsg> | |
| 28 | #include <podcast.mbg> | |
| 336 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 29 | #include <akntitle.h> | 
| 2 | 30 | #include <gulicon.h> | 
| 31 | #include <eikenv.h> | |
| 32 | #include <e32const.h> | |
| 33 | #include <eikdialg.h> | |
| 34 | #include <aknquerydialog.h> | |
| 35 | #include <caknmemoryselectiondialog.h> | |
| 36 | #include <caknfilenamepromptdialog.h> | |
| 37 | #include <BAUTILS.H> | |
| 38 | #include <pathinfo.h> | |
| 39 | #include <f32file.h> | |
| 40 | #include <akntoolbarextension.h> | |
| 41 | ||
| 42 | const TInt KMaxFeedNameLength = 100; | |
| 43 | #define KMaxMessageLength 200 | |
| 44 | #define KMaxTitleLength 100 | |
| 45 | _LIT(KSearchResultFormat, "%d\t%S\t%S"); | |
| 336 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 46 | _LIT(KSearchResultFormatLandscape, "%d\t%S"); | 
| 2 | 47 | |
| 48 | CPodcastSearchView* CPodcastSearchView::NewL(CPodcastModel& aPodcastModel) | |
| 49 |     {
 | |
| 50 | CPodcastSearchView* self = CPodcastSearchView::NewLC(aPodcastModel); | |
| 51 | CleanupStack::Pop( self ); | |
| 52 | return self; | |
| 53 | } | |
| 54 | ||
| 55 | CPodcastSearchView* CPodcastSearchView::NewLC(CPodcastModel& aPodcastModel) | |
| 56 |     {
 | |
| 57 | CPodcastSearchView* self = new ( ELeave ) CPodcastSearchView(aPodcastModel); | |
| 58 | CleanupStack::PushL( self ); | |
| 59 | self->ConstructL(); | |
| 60 | return self; | |
| 61 | } | |
| 62 | ||
| 63 | CPodcastSearchView::CPodcastSearchView(CPodcastModel& aPodcastModel):iPodcastModel(aPodcastModel) | |
| 64 | {
 | |
| 65 | } | |
| 66 | ||
| 67 | void CPodcastSearchView::ConstructL() | |
| 68 | {
 | |
| 69 | BaseConstructL(R_PODCAST_SEARCHVIEW); | |
| 70 | CPodcastListView::ConstructL(); | |
| 71 | iPodcastModel.FeedEngine().AddObserver(this); | |
| 72 | CArrayPtr< CGulIcon >* icons = new(ELeave) CArrayPtrFlat< CGulIcon >(1); | |
| 73 | CleanupStack::PushL( icons ); | |
| 74 | ||
| 75 | CFbsBitmap* bitmap = NULL; | |
| 76 | CFbsBitmap* mask = NULL;// | |
| 77 | ||
| 138 
6c8c5122867a
Removed the "Reset database" menu option; Updated help files
 teknolog parents: 
67diff
changeset | 78 | AknIconUtils::CreateIconL(bitmap, | 
| 
6c8c5122867a
Removed the "Reset database" menu option; Updated help files
 teknolog parents: 
67diff
changeset | 79 | mask, | 
| 
6c8c5122867a
Removed the "Reset database" menu option; Updated help files
 teknolog parents: 
67diff
changeset | 80 | iEikonEnv->EikAppUi()->Application()->BitmapStoreName(), | 
| 
6c8c5122867a
Removed the "Reset database" menu option; Updated help files
 teknolog parents: 
67diff
changeset | 81 | EMbmPodcastFeed, | 
| 
6c8c5122867a
Removed the "Reset database" menu option; Updated help files
 teknolog parents: 
67diff
changeset | 82 | EMbmPodcastFeed_mask); | 
| 2 | 83 | CleanupStack::PushL( bitmap ); | 
| 84 | CleanupStack::PushL( mask ); | |
| 85 | icons->AppendL( CGulIcon::NewL( bitmap, mask ) ); | |
| 86 | CleanupStack::Pop(2); // bitmap, mask | |
| 87 | ||
| 336 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 88 | iListContainer->SetListboxIcons(icons); | 
| 2 | 89 | CleanupStack::Pop(icons); // icons | 
| 90 | ||
| 91 | SetEmptyTextL(R_PODCAST_EMPTY_SEARCH); | |
| 92 | } | |
| 93 | ||
| 94 | CPodcastSearchView::~CPodcastSearchView() | |
| 95 |     {
 | |
| 348 | 96 | 	DP("CPodcastSearchView::~CPodcastSearchView BEGIN");
 | 
| 2 | 97 | iPodcastModel.FeedEngine().RemoveObserver(this); | 
| 98 | ||
| 99 | if(iLongTapDetector) | |
| 100 | delete iLongTapDetector, iLongTapDetector = NULL; | |
| 101 | ||
| 102 | if(iStylusPopupMenu) | |
| 103 | delete iStylusPopupMenu, iStylusPopupMenu = NULL; | |
| 104 | ||
| 348 | 105 | 	DP("CPodcastSearchView::~CPodcastSearchView END");
 | 
| 2 | 106 | } | 
| 107 | ||
| 108 | TUid CPodcastSearchView::Id() const | |
| 109 | {
 | |
| 110 | return KUidPodcastSearchViewID; | |
| 111 | } | |
| 112 | ||
| 113 | void CPodcastSearchView::DoActivateL(const TVwsViewId& aPrevViewId, | |
| 114 | TUid aCustomMessageId, | |
| 115 | const TDesC8& aCustomMessage) | |
| 116 | {
 | |
| 117 | CPodcastListView::DoActivateL(aPrevViewId, aCustomMessageId, aCustomMessage); | |
| 118 | iPreviousView = TVwsViewId(KUidPodcast, KUidPodcastFeedViewID); | |
| 336 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 119 | |
| 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 120 | HBufC* text = iEikonEnv->AllocReadResourceLC(R_SEARCH_RESULTS); | 
| 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 121 | |
| 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 122 | CAknTitlePane* titlePane = static_cast<CAknTitlePane*> | 
| 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 123 | ( StatusPane()->ControlL( TUid::Uid( EEikStatusPaneUidTitle ) ) ); | 
| 49 
43e204e6ae2e
Fix for accidental merge regressions. Text fixes for tool tip and settings.
 teknolog parents: 
24diff
changeset | 124 | |
| 336 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 125 | titlePane->SetTextL(*text , ETrue ); | 
| 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 126 | CleanupStack::PopAndDestroy(text); | 
| 56 | 127 | UpdateListboxItemsL(); | 
| 347 
b8d687bb7ca1
Experimenting with adding a new view to list all new shows
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
336diff
changeset | 128 | ((CPodcastAppUi*)AppUi())->SetTabsDimmed(ETrue); | 
| 2 | 129 | } | 
| 130 | ||
| 131 | void CPodcastSearchView::DoDeactivate() | |
| 132 | {
 | |
| 133 | CPodcastListView::DoDeactivate(); | |
| 336 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 134 | |
| 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 135 | CAknTitlePane* titlePane = static_cast<CAknTitlePane*> | 
| 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 136 | ( StatusPane()->ControlL( TUid::Uid( EEikStatusPaneUidTitle ) ) ); | 
| 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 137 | |
| 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 138 | titlePane->SetTextToDefaultL(); | 
| 347 
b8d687bb7ca1
Experimenting with adding a new view to list all new shows
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
336diff
changeset | 139 | ((CPodcastAppUi*)AppUi())->SetTabsDimmed(EFalse); | 
| 2 | 140 | } | 
| 141 | ||
| 142 | ||
| 143 | void CPodcastSearchView::HandleListBoxEventL(CEikListBox* /* aListBox */, TListBoxEvent aEventType) | |
| 144 | {
 | |
| 145 | 	DP("CPodcastSearchView::HandleListBoxEventL BEGIN");
 | |
| 146 | switch(aEventType) | |
| 147 | 	{
 | |
| 148 | case EEventEnterKeyPressed: | |
| 149 | case EEventItemDoubleClicked: | |
| 150 | case EEventItemActioned: | |
| 151 | 		{
 | |
| 152 | HandleCommandL(EPodcastAddSearchResult); | |
| 153 | } | |
| 154 | break; | |
| 155 | default: | |
| 156 | break; | |
| 157 | } | |
| 158 | 	DP("CPodcastSearchView::HandleListBoxEventL END");
 | |
| 159 | } | |
| 160 | ||
| 161 | void CPodcastSearchView::UpdateListboxItemsL() | |
| 162 | 	{
 | |
| 163 | 	DP("CPodcastSearchView::UpdateListboxItemsL BEGIN");
 | |
| 164 | 	if(!iListContainer->IsVisible()) {
 | |
| 165 | 		DP("CPodcastSearchView::UpdateListboxItemsL END (not visible)");
 | |
| 166 | return; | |
| 167 | } | |
| 168 | const RFeedInfoArray* searchItems = NULL; | |
| 169 | searchItems = &iPodcastModel.FeedEngine().GetSearchResults(); | |
| 170 | TInt len = searchItems->Count(); | |
| 171 | TListItemProperties itemProps; | |
| 172 | iListContainer->Listbox()->Reset(); | |
| 336 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 173 | //iListContainer->Listbox()->ItemDrawer()->ClearAllPropertiesL(); | 
| 2 | 174 | iItemIdArray.Reset(); | 
| 175 | iItemArray->Reset(); | |
| 176 | ||
| 177 | if (len > 0) | |
| 178 | 		{
 | |
| 179 | for (int i=0;i<len;i++) | |
| 180 | 			{				
 | |
| 181 | CFeedInfo *fi = (*searchItems)[i]; | |
| 182 | iItemIdArray.Append(fi->Uid()); | |
| 183 | TInt iconIndex = 0; | |
| 184 | ||
| 185 | TBuf<512> descr; | |
| 186 | descr.Copy(fi->Description().Left(512)); | |
| 15 
93d9f66bf50b
Cleaning description better for second line in search results
 teknolog parents: 
14diff
changeset | 187 | PodcastUtils::RemoveAllFormatting(descr); | 
| 2 | 188 | iListboxFormatbuffer.Format(KSearchResultFormat(), iconIndex, &fi->Title(), &descr); | 
| 189 | iItemArray->AppendL(iListboxFormatbuffer); | |
| 336 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 190 | iListboxFormatbufferShort.Format(KSearchResultFormatLandscape(), iconIndex, &fi->Title()); | 
| 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 191 | iItemArrayShort->AppendL(iListboxFormatbufferShort); | 
| 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 192 | //iListContainer->Listbox()->ItemDrawer()->SetPropertiesL(i, itemProps); | 
| 2 | 193 | } | 
| 194 | } | |
| 195 | else | |
| 196 | 		{					
 | |
| 197 | TBuf<KMaxFeedNameLength> itemName; | |
| 198 | iEikonEnv->ReadResourceL(itemName, R_PODCAST_NO_SEARCH_RESULTS); | |
| 199 | iItemArray->Reset(); | |
| 336 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 200 | iItemArrayShort->Reset(); | 
| 2 | 201 | iItemIdArray.Reset(); | 
| 202 | ||
| 203 | TListItemProperties itemProps; | |
| 204 | itemProps.SetDimmed(ETrue); | |
| 205 | itemProps.SetHiddenSelection(ETrue); | |
| 336 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 206 | //iListContainer->Listbox()->ItemDrawer()->SetPropertiesL(0, itemProps); | 
| 2 | 207 | } | 
| 208 | iListContainer->Listbox()->HandleItemAdditionL(); | |
| 209 | 	DP("CPodcastSearchView::UpdateListboxItemsL END");
 | |
| 210 | } | |
| 211 | ||
| 212 | /** | |
| 213 | * Command handling function intended for overriding by sub classes. | |
| 214 | * Default implementation is empty. | |
| 215 | * @param aCommand ID of the command to respond to. | |
| 216 | */ | |
| 217 | void CPodcastSearchView::HandleCommandL(TInt aCommand) | |
| 218 | 	{
 | |
| 219 | //CloseToolbarExtension(); | |
| 220 | switch(aCommand) | |
| 221 | 		{
 | |
| 222 | case EPodcastAddSearchResult: | |
| 223 | 			{
 | |
| 224 | TInt index = iListContainer->Listbox()->CurrentItemIndex(); | |
| 225 | ||
| 226 | if(index < iItemArray->MdcaCount() && index >= 0) | |
| 227 | 				{
 | |
| 228 | CFeedInfo *newInfo = iPodcastModel.FeedEngine().GetSearchResults()[index]; | |
| 229 | ||
| 230 | // ask if user wants to add the feed | |
| 231 | TBuf<KMaxMessageLength> templ; | |
| 232 | TBuf<KMaxMessageLength> message; | |
| 233 | ||
| 234 | iEikonEnv->ReadResourceL(templ, R_ADD_FEED_QUERY); | |
| 235 | message.Format(templ, &newInfo->Title()); | |
| 35 
66c5303f3610
A ton of CodeScanner fixes (high issues) - but not all
 Brendan Donegan <brendand@symbian.org> parents: 
24diff
changeset | 236 | 				if(ShowQueryMessageL(message)) {
 | 
| 2 | 237 | TBool added = iPodcastModel.FeedEngine().AddFeedL(*newInfo); | 
| 238 | ||
| 239 | if (added) | |
| 336 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 240 | 						{
 | 
| 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 241 | // this is a bit of a hack, first we activate the feeds view normally | 
| 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 242 | AppUi()->ActivateLocalViewL(KUidPodcastFeedViewID, TUid::Uid(0), KNullDesC8); | 
| 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 243 | // and then we send the UID of the recently added feed back to feed view for updating | 
| 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 244 | // this is needed so the update? query comes on top of feed view, not search view | 
| 
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
138diff
changeset | 245 | AppUi()->ActivateLocalViewL(KUidPodcastFeedViewID, TUid::Uid(newInfo->Uid()), KNullDesC8); | 
| 2 | 246 | } | 
| 247 | else | |
| 248 | 						{
 | |
| 249 | TBuf<KMaxMessageLength> message; | |
| 250 | iEikonEnv->ReadResourceL(message, R_ADD_FEED_EXISTS); | |
| 35 
66c5303f3610
A ton of CodeScanner fixes (high issues) - but not all
 Brendan Donegan <brendand@symbian.org> parents: 
24diff
changeset | 251 | ShowErrorMessageL(message); | 
| 2 | 252 | } | 
| 253 | } | |
| 254 | } | |
| 255 | } | |
| 256 | break; | |
| 257 | default: | |
| 258 | CPodcastListView::HandleCommandL(aCommand); | |
| 259 | break; | |
| 260 | } | |
| 261 | UpdateToolbar(); | |
| 262 | } | |
| 263 | ||
| 7 | 264 | void CPodcastSearchView::OpmlParsingComplete(TInt /*aError*/, TUint /*aNumFeedsImported*/) | 
| 2 | 265 | 	{
 | 
| 266 | 	DP("CPodcastSearchView::OpmlParsingComplete BEGIN");
 | |
| 56 | 267 | |
| 2 | 268 | 	DP("CPodcastSearchView::OpmlParsingComplete END");
 | 
| 269 | } |