| author | Sebastian Brannstrom <sebastianb@symbian.org> | 
| Sun, 31 Oct 2010 13:41:59 +0000 | |
| branch | twolistboxes | 
| changeset 317 | 5afc95a6ad83 | 
| parent 316 | 841ccfa933ac | 
| child 318 | a231cc388498 | 
| 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> | |
| 309 
d9f6395a50ea
Search view title moved from navi pane to title bar, for consistencey
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
243diff
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"); | |
| 316 | 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 | ||
| 140 | 78 | AknIconUtils::CreateIconL(bitmap, | 
| 79 | mask, | |
| 80 | iEikonEnv->EikAppUi()->Application()->BitmapStoreName(), | |
| 81 | EMbmPodcastFeed, | |
| 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 | ||
| 313 
0f30a75610de
First implementation of two listboxes
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
312diff
changeset | 88 | iListContainer->SetListboxIcons(icons); | 
| 2 | 89 | CleanupStack::Pop(icons); // icons | 
| 90 | ||
| 91 | iListContainer->Listbox()->SetListBoxObserver(this); | |
| 92 | ||
| 93 | SetEmptyTextL(R_PODCAST_EMPTY_SEARCH); | |
| 94 | } | |
| 95 | ||
| 96 | CPodcastSearchView::~CPodcastSearchView() | |
| 97 |     {
 | |
| 309 
d9f6395a50ea
Search view title moved from navi pane to title bar, for consistencey
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
243diff
changeset | 98 | 	DP("CPodcastSearchView::~CPodcastSearchView BEGIN");
 | 
| 2 | 99 | iPodcastModel.FeedEngine().RemoveObserver(this); | 
| 309 
d9f6395a50ea
Search view title moved from navi pane to title bar, for consistencey
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
243diff
changeset | 100 | 	DP("CPodcastSearchView::~CPodcastSearchView END");
 | 
| 2 | 101 | } | 
| 102 | ||
| 313 
0f30a75610de
First implementation of two listboxes
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
312diff
changeset | 103 | void CPodcastSearchView::SizeChanged() | 
| 
0f30a75610de
First implementation of two listboxes
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
312diff
changeset | 104 | 	{
 | 
| 
0f30a75610de
First implementation of two listboxes
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
312diff
changeset | 105 | |
| 
0f30a75610de
First implementation of two listboxes
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
312diff
changeset | 106 | } | 
| 
0f30a75610de
First implementation of two listboxes
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
312diff
changeset | 107 | |
| 2 | 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); | |
| 309 
d9f6395a50ea
Search view title moved from navi pane to title bar, for consistencey
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
243diff
changeset | 119 | |
| 
d9f6395a50ea
Search view title moved from navi pane to title bar, for consistencey
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
243diff
changeset | 120 | HBufC* text = iEikonEnv->AllocReadResourceLC(R_SEARCH_RESULTS); | 
| 
d9f6395a50ea
Search view title moved from navi pane to title bar, for consistencey
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
243diff
changeset | 121 | |
| 
d9f6395a50ea
Search view title moved from navi pane to title bar, for consistencey
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
243diff
changeset | 122 | CAknTitlePane* titlePane = static_cast<CAknTitlePane*> | 
| 
d9f6395a50ea
Search view title moved from navi pane to title bar, for consistencey
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
243diff
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 | |
| 309 
d9f6395a50ea
Search view title moved from navi pane to title bar, for consistencey
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
243diff
changeset | 125 | titlePane->SetTextL(*text , ETrue ); | 
| 
d9f6395a50ea
Search view title moved from navi pane to title bar, for consistencey
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
243diff
changeset | 126 | CleanupStack::PopAndDestroy(text); | 
| 56 | 127 | UpdateListboxItemsL(); | 
| 2 | 128 | } | 
| 129 | ||
| 130 | void CPodcastSearchView::DoDeactivate() | |
| 131 | {
 | |
| 132 | CPodcastListView::DoDeactivate(); | |
| 309 
d9f6395a50ea
Search view title moved from navi pane to title bar, for consistencey
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
243diff
changeset | 133 | |
| 
d9f6395a50ea
Search view title moved from navi pane to title bar, for consistencey
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
243diff
changeset | 134 | CAknTitlePane* titlePane = static_cast<CAknTitlePane*> | 
| 
d9f6395a50ea
Search view title moved from navi pane to title bar, for consistencey
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
243diff
changeset | 135 | ( StatusPane()->ControlL( TUid::Uid( EEikStatusPaneUidTitle ) ) ); | 
| 
d9f6395a50ea
Search view title moved from navi pane to title bar, for consistencey
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
243diff
changeset | 136 | |
| 
d9f6395a50ea
Search view title moved from navi pane to title bar, for consistencey
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
243diff
changeset | 137 | titlePane->SetTextToDefaultL(); | 
| 2 | 138 | } | 
| 139 | ||
| 140 | ||
| 141 | void CPodcastSearchView::HandleListBoxEventL(CEikListBox* /* aListBox */, TListBoxEvent aEventType) | |
| 142 | {
 | |
| 143 | 	DP("CPodcastSearchView::HandleListBoxEventL BEGIN");
 | |
| 144 | switch(aEventType) | |
| 145 | 	{
 | |
| 146 | case EEventEnterKeyPressed: | |
| 137 
eefed4bda2e2
Minor fixes to comply with single tap technical solution description. By this I consider bug 2056 closed.
 teknolog parents: 
126diff
changeset | 147 | case EEventItemSingleClicked: | 
| 2 | 148 | case EEventItemDoubleClicked: | 
| 149 | case EEventItemActioned: | |
| 150 | 		{
 | |
| 151 | HandleCommandL(EPodcastAddSearchResult); | |
| 152 | } | |
| 153 | break; | |
| 154 | default: | |
| 155 | break; | |
| 156 | } | |
| 157 | 	DP("CPodcastSearchView::HandleListBoxEventL END");
 | |
| 158 | } | |
| 159 | ||
| 160 | void CPodcastSearchView::UpdateListboxItemsL() | |
| 161 | 	{
 | |
| 162 | 	DP("CPodcastSearchView::UpdateListboxItemsL BEGIN");
 | |
| 163 | 	if(!iListContainer->IsVisible()) {
 | |
| 164 | 		DP("CPodcastSearchView::UpdateListboxItemsL END (not visible)");
 | |
| 165 | return; | |
| 166 | } | |
| 167 | const RFeedInfoArray* searchItems = NULL; | |
| 168 | searchItems = &iPodcastModel.FeedEngine().GetSearchResults(); | |
| 169 | TInt len = searchItems->Count(); | |
| 170 | TListItemProperties itemProps; | |
| 171 | iListContainer->Listbox()->Reset(); | |
| 317 
5afc95a6ad83
Stability fixes
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
316diff
changeset | 172 | //iListContainer->Listbox()->ItemDrawer()->ClearAllPropertiesL(); | 
| 2 | 173 | iItemIdArray.Reset(); | 
| 174 | iItemArray->Reset(); | |
| 175 | ||
| 176 | if (len > 0) | |
| 177 | 		{
 | |
| 178 | for (int i=0;i<len;i++) | |
| 179 | 			{				
 | |
| 180 | CFeedInfo *fi = (*searchItems)[i]; | |
| 181 | iItemIdArray.Append(fi->Uid()); | |
| 182 | TInt iconIndex = 0; | |
| 183 | ||
| 184 | TBuf<512> descr; | |
| 185 | descr.Copy(fi->Description().Left(512)); | |
| 15 
93d9f66bf50b
Cleaning description better for second line in search results
 teknolog parents: 
14diff
changeset | 186 | PodcastUtils::RemoveAllFormatting(descr); | 
| 2 | 187 | iListboxFormatbuffer.Format(KSearchResultFormat(), iconIndex, &fi->Title(), &descr); | 
| 188 | iItemArray->AppendL(iListboxFormatbuffer); | |
| 317 
5afc95a6ad83
Stability fixes
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
316diff
changeset | 189 | iListboxFormatbufferShort.Format(KSearchResultFormatLandscape(), iconIndex, &fi->Title()); | 
| 316 | 190 | iItemArrayShort->AppendL(iListboxFormatbufferShort); | 
| 317 
5afc95a6ad83
Stability fixes
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
316diff
changeset | 191 | //iListContainer->Listbox()->ItemDrawer()->SetPropertiesL(i, itemProps); | 
| 2 | 192 | } | 
| 193 | } | |
| 194 | else | |
| 195 | 		{					
 | |
| 196 | TBuf<KMaxFeedNameLength> itemName; | |
| 197 | iEikonEnv->ReadResourceL(itemName, R_PODCAST_NO_SEARCH_RESULTS); | |
| 198 | iItemArray->Reset(); | |
| 316 | 199 | iItemArrayShort->Reset(); | 
| 2 | 200 | iItemIdArray.Reset(); | 
| 201 | ||
| 202 | TListItemProperties itemProps; | |
| 203 | itemProps.SetDimmed(ETrue); | |
| 204 | itemProps.SetHiddenSelection(ETrue); | |
| 317 
5afc95a6ad83
Stability fixes
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
316diff
changeset | 205 | //iListContainer->Listbox()->ItemDrawer()->SetPropertiesL(0, itemProps); | 
| 2 | 206 | } | 
| 207 | iListContainer->Listbox()->HandleItemAdditionL(); | |
| 208 | 	DP("CPodcastSearchView::UpdateListboxItemsL END");
 | |
| 209 | } | |
| 210 | ||
| 211 | /** | |
| 212 | * Command handling function intended for overriding by sub classes. | |
| 213 | * Default implementation is empty. | |
| 214 | * @param aCommand ID of the command to respond to. | |
| 215 | */ | |
| 216 | void CPodcastSearchView::HandleCommandL(TInt aCommand) | |
| 217 | 	{
 | |
| 218 | //CloseToolbarExtension(); | |
| 219 | switch(aCommand) | |
| 220 | 		{
 | |
| 221 | case EPodcastAddSearchResult: | |
| 222 | 			{
 | |
| 223 | TInt index = iListContainer->Listbox()->CurrentItemIndex(); | |
| 224 | ||
| 225 | if(index < iItemArray->MdcaCount() && index >= 0) | |
| 226 | 				{
 | |
| 227 | CFeedInfo *newInfo = iPodcastModel.FeedEngine().GetSearchResults()[index]; | |
| 228 | ||
| 229 | // ask if user wants to add the feed | |
| 230 | TBuf<KMaxMessageLength> templ; | |
| 231 | TBuf<KMaxMessageLength> message; | |
| 232 | ||
| 233 | iEikonEnv->ReadResourceL(templ, R_ADD_FEED_QUERY); | |
| 234 | 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 | 235 | 				if(ShowQueryMessageL(message)) {
 | 
| 2 | 236 | TBool added = iPodcastModel.FeedEngine().AddFeedL(*newInfo); | 
| 237 | ||
| 238 | if (added) | |
| 312 
2faae209e72b
More elegant view handling between search view and feeds view
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
309diff
changeset | 239 | 						{
 | 
| 
2faae209e72b
More elegant view handling between search view and feeds view
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
309diff
changeset | 240 | // this is a bit of a hack, first we activate the feeds view normally | 
| 
2faae209e72b
More elegant view handling between search view and feeds view
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
309diff
changeset | 241 | AppUi()->ActivateLocalViewL(KUidPodcastFeedViewID, TUid::Uid(0), KNullDesC8); | 
| 
2faae209e72b
More elegant view handling between search view and feeds view
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
309diff
changeset | 242 | // and then we send the UID of the recently added feed back to feed view for updating | 
| 
2faae209e72b
More elegant view handling between search view and feeds view
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
309diff
changeset | 243 | // this is needed so the update? query comes on top of feed view, not search view | 
| 
2faae209e72b
More elegant view handling between search view and feeds view
 Sebastian Brannstrom <sebastianb@symbian.org> parents: 
309diff
changeset | 244 | AppUi()->ActivateLocalViewL(KUidPodcastFeedViewID, TUid::Uid(newInfo->Uid()), KNullDesC8); | 
| 2 | 245 | } | 
| 246 | else | |
| 247 | 						{
 | |
| 248 | TBuf<KMaxMessageLength> message; | |
| 249 | 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 | 250 | ShowErrorMessageL(message); | 
| 2 | 251 | } | 
| 252 | } | |
| 253 | } | |
| 254 | } | |
| 255 | break; | |
| 256 | default: | |
| 257 | CPodcastListView::HandleCommandL(aCommand); | |
| 258 | break; | |
| 259 | } | |
| 260 | UpdateToolbar(); | |
| 261 | } | |
| 262 | ||
| 7 | 263 | void CPodcastSearchView::OpmlParsingComplete(TInt /*aError*/, TUint /*aNumFeedsImported*/) | 
| 2 | 264 | 	{
 | 
| 265 | 	DP("CPodcastSearchView::OpmlParsingComplete BEGIN");
 | |
| 56 | 266 | |
| 2 | 267 | 	DP("CPodcastSearchView::OpmlParsingComplete END");
 | 
| 268 | } |