Fixed side effect
[apps/osp/Gallery.git] / src / GlFileListPresentationModel.cpp
1 //
2 // Copyright (c) 2012 Samsung Electronics Co., Ltd.
3 //
4 // Licensed under the Flora License, Version 1.1 (the License);
5 // you may not use this file except in compliance with the License.
6 // You may obtain a copy of the License at
7 //
8 //     http://floralicense.org/license/
9 //
10 // Unless required by applicable law or agreed to in writing, software
11 // distributed under the License is distributed on an AS IS BASIS,
12 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 // See the License for the specific language governing permissions and
14 // limitations under the License.
15 //
16
17 /**
18  * @file                GlFileListPresentationModel.cpp
19  * @brief               This is the implementation file for FileListPresentationModel class.
20  */
21
22 #include <cstdlib>
23 #include <FMedia.h>
24 #include <FSystem.h>
25 #include "GlCommonUtil.h"
26 #include "GlFileListPresentationModel.h"
27 #include "GlContentUpdateEventListener.h"
28 #include "GlGalleryApp.h"
29 #include "GlThumbnailEvent.h"
30 #include "GlThumbnailEventArg.h"
31 #include "GlThumbnailProvider.h"
32 #include "GlTypes.h"
33
34 using namespace Tizen::App;
35 using namespace Tizen::Base;
36 using namespace Tizen::Base::Collection;
37 using namespace Tizen::Base::Runtime;
38 using namespace Tizen::Base::Utility;
39 using namespace Tizen::Content;
40 using namespace Tizen::Graphics;
41 using namespace Tizen::Io;
42 using namespace Tizen::Media;
43 using namespace Tizen::System;
44
45 static const String CONTENT_INFO_ORDER = L"ContentFileName";
46
47 static const int SIZE_PAGE_NO = 1;
48 static const int SIZE_CONUNT_PER_PAGE = 3000;
49 static const int SIZE_ICON_LIST_CACHE = 50;
50 static const int W_DURATION_TEXT = 44;
51 static const int H_DURATION_TEXT = 4;
52 static const int W_DURATION = 171;
53 static const int H_DURATION = 32;
54 static const int W_DEFAULT_THUMBNAIL = 171;
55 static const int H_DEFAULT_THUMBNAIL = 127;
56 static const int W_WIDE_THUMBNAIL = 171;
57 static const int H_WIDE_THUMBNAIL = 127;
58 static const int W_PLAY_FG = 64;
59 static const int H_PLAY_FG = 64;
60 static const int GAP_W_PLAY_FG = (W_DEFAULT_THUMBNAIL -W_PLAY_FG)/2;
61 static const int GAP_H_PLAY_FG = (H_DEFAULT_THUMBNAIL - H_PLAY_FG)/2;
62 static const int GAP_H_DURATION = H_DEFAULT_THUMBNAIL - H_DURATION;
63 static const int ALPHA_DURATION = 70;
64 static const int FONT_SIZE_DURATION = 24;
65 static const Dimension DIMENSION_REAL_ICON (171,127);
66 static const Rectangle RECTANGLE_THUMBNAIL_OFFSET_POSION (1, 1, 171, 127);
67 static const Rectangle RECTANGLE_VIDEO_THUMBNAIL_OFFSET_POSION (1, 1, 171, 127);
68 static const Color COLOR_DURATION_BG (Color::GetColor(COLOR_ID_BLACK));
69 static const Color COLOR_TEXT_OUTLINE (Color::GetColor(COLOR_ID_WHITE));
70
71 static const String RESERVED_CAMERA_PATH = Environment::GetMediaPath() + L"Camera";
72 static const String RESERVED_CAMERA_PATH_EXT = Environment::GetExternalStoragePath() + L"Camera";
73 static const String RESERVED_DOWNLOAD_PATH = Environment::GetMediaPath() + L"Downloads";
74
75 FileListPresentationModel* FileListPresentationModel::__pPresentationModelInstance = null;
76 ThumbnailProvider* FileListPresentationModel::__pThumbnailProvider = null;
77 ThumbnailEvent* FileListPresentationModel::__pThumbnailEvent = null;
78 ArrayList* FileListPresentationModel::__pPresentationModelListener = null;
79 ArrayList* FileListPresentationModel::__pContentEventListener = null;
80 ArrayList* FileListPresentationModel::__pIconListViewCache = null;
81 IList* FileListPresentationModel::__pDirectoryList = null;
82 IList* FileListPresentationModel::__pContentInfoList = null;
83
84 FileListPresentationModel::FileListPresentationModel(void)
85         : __pContentManager(null)
86         , __albumContentType(CONTENT_TYPE_ALL)
87         , __appControlMode(APPCONTROL_MODE_MAIN)
88         , __appControlMediaType(APPCONTROL_MEDIA_TYPE_IMAGE)
89         , __appControlSelectionMode(APPCONTROL_SELECTION_MODE_SINGLE)
90         , __pContentIdList(null)
91         , __updateProgressStatus(false)
92 {
93         AppLogDebug("ENTER");
94         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
95 }
96
97 FileListPresentationModel::~FileListPresentationModel(void)
98 {
99         AppLogDebug("ENTER");
100         DeviceManager::RemoveDeviceEventListener(DEVICE_TYPE_STORAGE_CARD, *this);
101         if (__pContentIdList)
102         {
103                 __pContentIdList->RemoveAll(true);
104                 delete __pContentIdList;
105                 __pContentIdList = null;
106         }
107         delete __pContentManager;
108         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
109 }
110
111 FileListPresentationModel*
112 FileListPresentationModel::GetInstance(void)
113 {
114         AppLogDebug("ENTER");
115         if (__pPresentationModelInstance == null)
116         {
117                 CreateInstance();
118         }
119         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
120
121         return __pPresentationModelInstance;
122 }
123
124 result
125 FileListPresentationModel::Construct(void)
126 {
127         AppLogDebug("ENTER");
128
129         IThumbnailEventListener* pThumbnailEventListener = static_cast<IThumbnailEventListener*>(this);
130         __pThumbnailEvent = new (std::nothrow) ThumbnailEvent();
131         __pThumbnailEvent->AddListener(*pThumbnailEventListener, true);
132
133         DeviceManager::AddDeviceEventListener(DEVICE_TYPE_STORAGE_CARD, *this);
134
135         ContentUpdateEventListener::GetInstance();
136         __pContentManager = new (std::nothrow) ContentManager();
137         __pContentManager->Construct();
138
139         if (__pIconListViewCache != null)
140         {
141                 __pIconListViewCache->RemoveAll(true);
142                 delete __pIconListViewCache;
143                 __pIconListViewCache = null;
144         }
145         __pIconListViewCache = new (std::nothrow) ArrayList(SingleObjectDeleter);
146         __pIconListViewCache->Construct(SIZE_ICON_LIST_CACHE);
147
148         if (__pDirectoryList != null)
149         {
150                 delete __pDirectoryList;
151         }
152         __pDirectoryList = new (std::nothrow) ArrayList(SingleObjectDeleter);
153
154         if (__pContentInfoList != null)
155         {
156                 delete __pContentInfoList;
157         }
158         __pContentInfoList = new (std::nothrow) ArrayList(SingleObjectDeleter);
159
160         __pPresentationModelListener = new (std::nothrow) ArrayList();
161         __pPresentationModelListener->Construct();
162
163         __pContentEventListener = new (std::nothrow) ArrayList();
164         __pContentEventListener->Construct();
165
166         __pThumbnailProvider = ThumbnailProvider::GetInstance();
167
168         GalleryApp* pApp = static_cast<GalleryApp*>(GalleryApp::GetInstance());
169         const IMap* pArguments = pApp->GetAppControlArguments();
170         String operationId = pApp->GetAppControlOperationId();
171
172         if (operationId.CompareTo(APPCONTROL_OPERATION_ID_MAIN) == 0)
173         {
174                 __appControlMode = APPCONTROL_MODE_MAIN;
175         }
176         else if (operationId.CompareTo(APPCONTROL_OPERATION_ID_PICK) == 0)
177         {
178                 __appControlMode = APPCONTROL_MODE_PICK;
179
180                 String mimeType = pApp->GetMimeType();
181                 if (mimeType.IsEmpty() != true)
182                 {
183                         if (mimeType.StartsWith(APPCONTROL_DATA_VIDEO, 0) == true)
184                         {
185                                 __appControlMediaType = APPCONTROL_MEDIA_TYPE_VIDEO;
186                         }
187                 }
188                 if (pArguments != null)
189                 {
190                         const String* selectionMode = static_cast<const String*>(pArguments->GetValue(String(APPCONTROL_KEY_SELECTION_MODE)));
191
192                         if (pApp->GetMimeType().StartsWith(APPCONTROL_DATA_VIDEO, 0) == true)
193                         {
194                                 __appControlMediaType = APPCONTROL_MEDIA_TYPE_VIDEO;
195                         }
196
197                         if (selectionMode != null && selectionMode->CompareTo(APPCONTROL_DATA_MULTIPLE) == 0)
198                         {
199                                 __appControlSelectionMode = APPCONTROL_SELECTION_MODE_MULTIPLE;
200                         }
201                 }
202         }
203         else if (operationId.CompareTo(APPCONTROL_OPERATION_ID_CONFIGURE) == 0)
204         {
205                 __appControlMode = APPCONTROL_MODE_SETTING;
206         }
207
208         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
209
210         return E_SUCCESS;
211 }
212
213 void
214 FileListPresentationModel::CreateInstance(void)
215 {
216         AppLogDebug("ENTER");
217         __pPresentationModelInstance = new (std::nothrow) FileListPresentationModel();
218         result r = __pPresentationModelInstance->Construct();
219         if (IsFailed(r) == true)
220         {
221                 delete __pPresentationModelInstance;
222                 __pPresentationModelInstance = null;
223                 AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
224
225                 return;
226         }
227
228         std::atexit(DestroyInstance);
229         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
230 }
231
232 void
233 FileListPresentationModel::DestroyInstance(void)
234 {
235         AppLogDebug("ENTER");
236
237         delete __pThumbnailEvent;
238
239         if (__pIconListViewCache != null)
240         {
241                 __pIconListViewCache->RemoveAll(true);
242                 delete __pIconListViewCache;
243                 __pIconListViewCache = null;
244         }
245
246         if (__pDirectoryList != null)
247         {
248                 delete __pDirectoryList;
249                 __pDirectoryList = null;
250         }
251
252         if (__pContentInfoList != null)
253         {
254                 delete __pContentInfoList;
255                 __pContentInfoList = null;
256         }
257
258         if (__pPresentationModelListener != null)
259         {
260                 delete __pPresentationModelListener;
261                 __pPresentationModelListener = null;
262         }
263
264         if (__pContentEventListener != null)
265         {
266                 delete __pContentEventListener;
267                 __pContentEventListener = null;
268         }
269
270         delete __pPresentationModelInstance;
271         __pPresentationModelInstance = null;
272
273         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
274 }
275
276 String
277 FileListPresentationModel::GetFileNameFromFullPath(const String& fullPath, const bool withExt) const
278 {
279         AppLogDebug("ENTER");
280         if (fullPath.CompareTo(EMPTY_SPACE) == 0)
281         {
282                 AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
283
284                 return EMPTY_SPACE;
285         }
286
287         String delim(DIRECTORY_SEPARATOR);
288         StringTokenizer st(fullPath,delim);
289         String token;
290         while (st.HasMoreTokens())
291         {
292                 st.GetNextToken(token);
293         }
294
295         if (withExt == true)
296         {
297                 AppLogDebug("EXIT 2(%s)", GetErrorMessage(GetLastResult()));
298
299                 return token;
300         }
301         else
302         {
303                 String subDelim(FILE_EXT_SEPARATOR);
304                 StringTokenizer subSt(token, subDelim);
305                 String subToken;
306                 subSt.GetNextToken(subToken);
307                 AppLogDebug("EXIT 3(%s)", GetErrorMessage(GetLastResult()));
308
309                 return subToken;
310         }
311 }
312
313 String
314 FileListPresentationModel::GetDirecotyNameFromFullPath(const String& fullPath)const
315 {
316         AppLogDebug("ENTER");
317         if (fullPath == null)
318         {
319                 AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
320
321                 return null;
322         }
323         String delim(DIRECTORY_SEPARATOR);
324         StringTokenizer st(fullPath,delim);
325         String token;
326         while (st.HasMoreTokens())
327         {
328                 st.GetNextToken(token);
329         }
330         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
331
332         return token;
333 }
334
335 bool
336 FileListPresentationModel::IsContainContentInDirectory(const String& directoryPath, ContentType contentType) const
337 {
338         AppLogDebug("ENTER");
339         IListT<ContentType>* pContentTypeList = new (std::nothrow) ArrayListT<ContentType>();
340         if (&directoryPath == null || pContentTypeList == null)
341         {
342                 AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
343
344                 return false;
345         }
346
347         if (contentType == CONTENT_TYPE_IMAGE || contentType == CONTENT_TYPE_ALL)
348         {
349                 pContentTypeList->Add(CONTENT_TYPE_IMAGE);
350         }
351         if (contentType == CONTENT_TYPE_VIDEO || contentType == CONTENT_TYPE_ALL)
352         {
353                 pContentTypeList->Add(CONTENT_TYPE_VIDEO);
354         }
355
356         ContentDirectory contentDirectory;
357         result r = contentDirectory.Construct(*pContentTypeList);
358         if (pContentTypeList != null)
359         {
360                 delete pContentTypeList;
361         }
362         TryReturn(r == E_SUCCESS, false, "[%s] Unable to construct ContentDirectory", GetErrorMessage(r));
363
364         bool returnValue = false;
365         int pageNo = SIZE_PAGE_NO;
366         int countPerPage = SIZE_CONUNT_PER_PAGE;
367
368         IList* pContentList = contentDirectory.GetContentDirectoryItemListN(directoryPath, pageNo, countPerPage,
369                         CONTENT_INFO_ORDER, SORT_ORDER_ASCENDING);
370
371         if (pContentList == null || pContentList->GetCount() <= 0)
372         {
373                 returnValue = false;
374         }
375         else
376         {
377                 returnValue = true;
378         }
379
380         if (pContentList != null)
381         {
382                 delete pContentList;
383         }
384         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
385
386         return returnValue;
387 }
388
389 result
390 FileListPresentationModel::GetThumbnailInSyncCacheN(const int index, String*& pName, Bitmap*& pThumbnail)
391 {
392         AppLogDebug("ENTER : index(%d)", index);
393         Bitmap* pOriginalBitmap = null;
394         Bitmap* pDestinationBitmap = null;
395         ContentInfo* pContentInfo = null;
396
397         if (__pContentInfoList != null && index < __pContentInfoList->GetCount())
398         {
399                 pContentInfo = static_cast<ContentInfo*>(__pContentInfoList->GetAt(index));
400                 if (pContentInfo == null)
401                 {
402                         AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
403
404                         return E_FAILURE;
405                 }
406         }
407         else
408         {
409                 AppLogDebug("EXIT 2 __pContentInfoList(%x) index(%d)", __pContentInfoList, index);
410                 return E_FAILURE;
411         }
412
413         ThumbnailInfo* pThumbnailInfo = GetThumbnailInfoFromInternalBufferN(pContentInfo->GetContentId());
414         if (pThumbnailInfo != null)
415         {
416                 pName = new (std::nothrow) String(pThumbnailInfo->GetFilePath());
417                 pOriginalBitmap = pThumbnailInfo->GetBitmapN();
418         }
419
420         if ((pThumbnailInfo != null)&&(pThumbnailInfo->GetContentType() == CONTENT_TYPE_VIDEO))
421         {
422                 if (pOriginalBitmap != null)
423                 {
424                         pDestinationBitmap = CoverVideoOverlayedImageOnThumbnailN(*pOriginalBitmap, *pThumbnailInfo);
425                         delete pOriginalBitmap;
426                 }
427         }
428         else
429         {
430                 pDestinationBitmap = pOriginalBitmap;
431         }
432
433         if (pDestinationBitmap != null)
434         {
435                 Bitmap* pThumbnailBgBitmap = ResourceManager::GetBitmapN(IDB_VIDEOTHUMBNAIL_BG);
436                 Rectangle thumbnailRect(RECTANGLE_THUMBNAIL_OFFSET_POSION);
437                 pDestinationBitmap->Scale(Dimension(RECTANGLE_THUMBNAIL_OFFSET_POSION.width - RECTANGLE_THUMBNAIL_OFFSET_POSION.x
438                                 , RECTANGLE_THUMBNAIL_OFFSET_POSION.height - RECTANGLE_THUMBNAIL_OFFSET_POSION.y));
439                 if (pThumbnailBgBitmap != null)
440                 {
441                         pThumbnailBgBitmap->Scale(DIMENSION_REAL_ICON);
442                         pThumbnail = GetShadedBackgroundBitmapN(*pThumbnailBgBitmap, *pDestinationBitmap, thumbnailRect);
443                         delete pThumbnailBgBitmap;
444                         delete pDestinationBitmap;
445                 }
446                 else
447                 {
448                         pThumbnail = pDestinationBitmap;
449                 }
450         }
451         else
452         {
453                 pThumbnail = null;
454         }
455
456         if (pThumbnailInfo != null)
457         {
458                 delete pThumbnailInfo;
459         }
460
461         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
462
463         return E_SUCCESS;
464 }
465
466 result
467 FileListPresentationModel::GetThumbnailVideoInSyncCacheN(const int index,
468                 String*& pName, Bitmap*& pThumbnail, String*& pDuration) const
469 {
470         AppLogDebug("ENTER : index(%d)", index);
471         ContentInfo* pContentInfo = null;
472         Bitmap* pOriginalBitmap = null;
473
474         if (__pContentInfoList != null && index < __pContentInfoList->GetCount())
475         {
476                 pContentInfo = static_cast<ContentInfo*>(__pContentInfoList->GetAt(index));
477                 if (pContentInfo == null)
478                 {
479                         AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
480                         return E_FAILURE;
481                 }
482         }
483         else
484         {
485                 AppLogDebug("EXIT 2 __pContentInfoList(%x) index(%d)", __pContentInfoList, index);
486                 return E_FAILURE;
487         }
488
489         ThumbnailInfo* pThumbnailInfo = GetThumbnailInfoFromInternalBufferN(pContentInfo->GetContentId());
490         if (pThumbnailInfo != null)
491         {
492                 pName = new (std::nothrow) String(pThumbnailInfo->GetFilePath());
493                 pOriginalBitmap = pThumbnailInfo->GetBitmapN();
494                 pDuration = new (std::nothrow) String(CommonUtil::DurationToTimeString(pThumbnailInfo->GetDuration()));
495         }
496         else
497         {
498                 pName = new (std::nothrow) String(EMPTY_SPACE);
499                 pDuration = new (std::nothrow) String(CommonUtil::DurationToTimeString(0));
500         }
501
502         if (pOriginalBitmap != null)
503         {
504                 Bitmap* pThumbnailBgBitmap = ResourceManager::GetBitmapN(IDB_VIDEOTHUMBNAIL_BG);
505                 Rectangle thumbnailRect(RECTANGLE_VIDEO_THUMBNAIL_OFFSET_POSION);
506                 pOriginalBitmap->Scale(Dimension(RECTANGLE_VIDEO_THUMBNAIL_OFFSET_POSION.width - RECTANGLE_VIDEO_THUMBNAIL_OFFSET_POSION.x
507                                 , RECTANGLE_VIDEO_THUMBNAIL_OFFSET_POSION.height - RECTANGLE_VIDEO_THUMBNAIL_OFFSET_POSION.y));
508                 if (pThumbnailBgBitmap != null)
509                 {
510                         pThumbnailBgBitmap->Scale(Dimension(W_WIDE_THUMBNAIL, H_WIDE_THUMBNAIL));
511                         pThumbnail = GetShadedBackgroundBitmapN(*pThumbnailBgBitmap, *pOriginalBitmap, thumbnailRect);
512                         delete pThumbnailBgBitmap;
513                 }
514                 delete pOriginalBitmap;
515         }
516         else
517         {
518                 pThumbnail = null;
519         }
520
521         if (pThumbnail != null)
522         {
523                 pThumbnail->Scale(Dimension(W_WIDE_THUMBNAIL, H_WIDE_THUMBNAIL));
524         }
525
526         if (pThumbnailInfo != null)
527         {
528                 delete pThumbnailInfo;
529         }
530         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
531
532         return E_SUCCESS;
533 }
534
535 void
536 FileListPresentationModel::RequestThumbnail(const int index)
537 {
538         AppLogDebug("ENTER : index(%d)", index);
539         ContentInfo* pContentInfo = null;
540
541         if (__pContentInfoList != null && index < __pContentInfoList->GetCount())
542         {
543                 pContentInfo = static_cast<ContentInfo*>(__pContentInfoList->GetAt(index));
544                 if (pContentInfo == null)
545                 {
546                         AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
547                         return;
548                 }
549         }
550         else
551         {
552                 AppLogDebug("EXIT 2 __pContentInfoList(%x) index(%d)", __pContentInfoList, index);
553
554                 return;
555         }
556
557         __pThumbnailProvider->RequestThumbnail(pContentInfo->GetContentId(), __pThumbnailEvent);
558         AppLogDebug("EXIT");
559 }
560
561 void
562 FileListPresentationModel::ClearThumbnailRequests(const bool appTerminating)
563 {
564         AppLogDebug("ENTER");
565
566         if (__pThumbnailProvider != null)
567         {
568                 __pThumbnailProvider->ClearThumbnailRequests(appTerminating);
569         }
570
571         AppLogDebug("EXIT");
572 }
573
574 void
575 FileListPresentationModel::OnThumbnailReceivedN(IEventArg& eventArg)
576 {
577         AppLogDebug("ENTER");
578
579         if (&eventArg != null)
580         {
581                 ThumbnailEventArg* pThumbnailEventArg = static_cast<ThumbnailEventArg*>(&eventArg);
582                 if (pThumbnailEventArg == null)
583                 {
584                         AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
585
586                         return;
587                 }               
588                 ThumbnailInfo* pThumbnailInfo = pThumbnailEventArg->GetThumbnailInfoN();
589                 if (pThumbnailInfo == null)
590                 {
591                         AppLogDebug("EXIT 2(%s)", GetErrorMessage(GetLastResult()));
592
593                         return;
594                 }
595
596                 bool isMatch = false;
597                 ContentId contentId = pThumbnailInfo->GetContentId();
598
599                 if (__pIconListViewCache != null)
600                 {
601                         IEnumerator* pEnum = __pIconListViewCache->GetEnumeratorN();
602                         Bitmap* pBitmap = null;
603                         while (pEnum->MoveNext() == E_SUCCESS)
604                         {
605                                 ThumbnailInfo* pTempThumbnailInfo = static_cast<ThumbnailInfo*>(pEnum->GetCurrent());
606
607                                 if (contentId == pTempThumbnailInfo->GetContentId())
608                                 {
609                                         AppLogDebug("[CHASEFIRE] PM receive (%ls)", pThumbnailInfo->GetFilePath().GetPointer());
610                                         pBitmap = pThumbnailInfo->GetBitmapN();
611                                         pTempThumbnailInfo->SetBitmap(*pBitmap);
612                                         delete pBitmap;
613
614                                         pTempThumbnailInfo->SetContentType(pThumbnailInfo->GetContentType());
615                                         pTempThumbnailInfo->SetDuration(pThumbnailInfo->GetDuration());
616                                         delete pThumbnailInfo;
617                                         isMatch = true;
618                                         break;
619                                 }
620                         }
621
622                         delete pEnum;
623
624                         if (isMatch == false)
625                         {
626                                 if (SIZE_ICON_LIST_CACHE <= __pIconListViewCache->GetCount())
627                                 {
628                                         __pIconListViewCache->RemoveAt(0, true);
629                                 }
630                                 AppLogDebug("[CHASEFIRE] (all:%d) Add Thumbail(%ls)", __pIconListViewCache->GetCount(),
631                                                 pThumbnailInfo->GetFilePath().GetPointer());
632                                 __pIconListViewCache->Add(pThumbnailInfo);
633                         }
634                 }
635
636                 int index = -1;
637                 int loopCount = __pContentInfoList->GetCount();
638                 for (int i = 0; i < loopCount; ++i)
639                 {
640                         if (contentId == (static_cast<ContentInfo*>(__pContentInfoList->GetAt(i)))->GetContentId())
641                         {
642                                 index = i;
643                                 break;
644                         }
645                 }
646
647                 IAlbumEventListener* pInterface = null;
648                 IEnumerator* pEventEnum = __pPresentationModelListener->GetEnumeratorN();
649                 while (pEventEnum->MoveNext() == E_SUCCESS)
650                 {
651                         pInterface = static_cast<IAlbumEventListener*>(pEventEnum->GetCurrent());
652                         pInterface->OnThumbnailDecoded(index);
653                 }
654                 delete pEventEnum;
655         }
656         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
657 }
658
659 void
660 FileListPresentationModel::OnContentCreated(void)
661 {
662         AppLogDebug("ENTER");
663         if (__updateProgressStatus == true)
664         {
665                 AppLogDebug("EXIT update in application");
666                 return;
667         }
668         IFormContentUpdateEventListener* pInterface = null;
669         if (__pContentEventListener == null)
670         {
671                 AppLogDebug("EXIT");
672                 return;
673         }
674         IEnumerator* pEventEnum = __pContentEventListener->GetEnumeratorN();
675         while (pEventEnum->MoveNext() == E_SUCCESS)
676         {
677                 pInterface = static_cast<IFormContentUpdateEventListener*>(pEventEnum->GetCurrent());
678                 if (pInterface != null)
679                 {
680                         pInterface->OnContentUpdated();
681                 }
682         }
683         delete pEventEnum;
684         AppLogDebug("EXIT");
685 }
686
687 void
688 FileListPresentationModel::OnContentUpdated(void)
689 {
690         AppLogDebug("ENTER");
691         if (__updateProgressStatus == true)
692         {
693                 AppLogDebug("EXIT update in application");
694                 return;
695         }
696         //Clear the ImageCaches when content is updated like rotate.
697         if (__pContentEventListener->GetCount())
698         {
699                 ClearImageCache();
700         }
701
702         IFormContentUpdateEventListener* pInterface = null;
703         if (__pContentEventListener == null)
704         {
705                 AppLogDebug("EXIT");
706                 return;
707         }
708         IEnumerator* pEventEnum = __pContentEventListener->GetEnumeratorN();
709         while (pEventEnum->MoveNext() == E_SUCCESS)
710         {
711                 pInterface = static_cast<IFormContentUpdateEventListener*>(pEventEnum->GetCurrent());
712                 pInterface->OnContentUpdated();
713         }
714         delete pEventEnum;
715         AppLogDebug("EXIT");
716 }
717
718 void
719 FileListPresentationModel::OnContentDeleted(void)
720 {
721
722
723
724         AppLogDebug("ENTER");
725         if (__updateProgressStatus == true)
726         {
727                 AppLogDebug("EXIT update in application");
728                 return;
729         }
730         IFormContentUpdateEventListener* pInterface = null;
731         if (__pContentEventListener == null)
732         {
733                 AppLogDebug("EXIT");
734                 return;
735         }
736         IEnumerator* pEventEnum = __pContentEventListener->GetEnumeratorN();
737         while (pEventEnum->MoveNext() == E_SUCCESS)
738         {
739                 ClearThumbnailRequests();
740                 pInterface = static_cast<IFormContentUpdateEventListener*>(pEventEnum->GetCurrent());
741                 pInterface->OnContentUpdated();
742         }
743         delete pEventEnum;
744         AppLogDebug("EXIT");
745 }
746
747 void
748 FileListPresentationModel::AddPresentationModelListener(const IAlbumEventListener* listener)
749 {
750         AppLogDebug("ENTER");
751         __pPresentationModelListener->Add((Object*)listener);
752         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
753 }
754
755 void
756 FileListPresentationModel::RemovePresentationModelListener(const IAlbumEventListener& listener)
757 {
758         AppLogDebug("ENTER");
759         __pPresentationModelListener->Remove(listener);
760         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
761 }
762
763 void
764 FileListPresentationModel::AddContentEventListener(const IFormContentUpdateEventListener* listener)
765 {
766         AppLogDebug("ENTER");
767         if (__pContentEventListener != null)
768         {
769                 __pContentEventListener->RemoveAll();
770                 __pContentEventListener->Add((Object*)listener);
771                 AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
772         }
773 }
774
775 void
776 FileListPresentationModel::RemoveContentEventListener(const IFormContentUpdateEventListener* listener)
777 {
778         AppLogDebug("ENTER");
779         __pContentEventListener->Remove(*listener);
780         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
781 }
782
783 ThumbnailInfo*
784 FileListPresentationModel::GetThumbnailInfoFromInternalBufferN(const ContentId& contentId) const
785 {
786         AppLogDebug("ENTER");
787         ThumbnailInfo* pThumbnailInfo = null;
788         ThumbnailInfo* pTempThumbnailInfo = null;
789         if (__pIconListViewCache != null)
790         {
791                 int loopCount = __pIconListViewCache->GetCount();
792                 for (int i = 0; i < loopCount; ++i)
793                 {
794                         pTempThumbnailInfo = static_cast<ThumbnailInfo*>(__pIconListViewCache->GetAt(i));
795                         if (contentId == pTempThumbnailInfo->GetContentId())
796                         {
797
798                                 pThumbnailInfo = new (std::nothrow) ThumbnailInfo();
799                                 Bitmap* pBitmap = pTempThumbnailInfo->GetBitmapN();
800                                 pThumbnailInfo->Construct(pTempThumbnailInfo->GetContentId(), pTempThumbnailInfo->GetFilePath(),
801                                                 *pBitmap, pTempThumbnailInfo->GetContentType(), pTempThumbnailInfo->GetDuration());
802                                 delete pBitmap;
803                                 break;
804                         }
805                 }
806         }
807         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
808
809         return pThumbnailInfo;
810 }
811
812 result
813 FileListPresentationModel::DeleteContentFileList(const IList& contentIndexList)
814 {
815         AppLogDebug("ENTER");
816         if (&contentIndexList == null || contentIndexList.GetCount() <= 0)
817         {
818                 AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
819
820                 return E_SUCCESS;
821         }
822
823         IList * pContentIdList = new (std::nothrow) ArrayList(SingleObjectDeleter);
824         int loopCount = contentIndexList.GetCount();
825         for (int i = 0; i < loopCount; ++i)
826         {
827                 const Integer* pIndex = static_cast<const Integer*>(contentIndexList.GetAt(i));
828
829                 if ((pIndex != null) && (pIndex->ToInt())>=0 && __pContentInfoList->GetCount() > pIndex->ToInt())
830                 {
831                         pContentIdList->Add(new (std::nothrow) ContentId((static_cast<ContentInfo*>
832                                         (__pContentInfoList->GetAt(pIndex->ToInt())))->GetContentId()));
833                 }
834         }
835
836         loopCount = pContentIdList->GetCount();
837         for (int i = 0; i < loopCount; ++i)
838         {
839                 ContentId* pContentId = static_cast<ContentId*>(pContentIdList->GetAt(i));
840                 if (pContentId != null)
841                 {
842                         DeleteContentFile(*pContentId);
843                 }
844         }
845         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
846
847         return E_SUCCESS;
848 }
849
850 IList*
851 FileListPresentationModel::GetCollisionIndexListN(const IList& contentIndexList, const String& destDirectory)
852 {
853         AppLogDebug("ENTER");
854         if (&contentIndexList == null || contentIndexList.GetCount() <= 0 || &destDirectory == null
855                         || destDirectory.IsEmpty() == true)
856         {
857                 AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
858
859                 return null;
860         }
861
862         if (File::IsFileExist(destDirectory) == false)
863         {
864                 AppLogDebug("EXIT 2(%s)", GetErrorMessage(GetLastResult()));
865
866                 return null;
867         }
868
869         IList * pCollisionInfoList = new (std::nothrow) ArrayList(SingleObjectDeleter);
870         ContentInfo* pContentInfo = null;
871         int loopCount = contentIndexList.GetCount();
872         for (int i = 0; i < loopCount; ++i)
873         {
874                 const Integer* pIndex = static_cast<const Integer*>(contentIndexList.GetAt(i));
875
876                 if ((pIndex != null) && (pIndex->ToInt()) >= 0 && __pContentInfoList->GetCount() > pIndex->ToInt())
877                 {
878                         pContentInfo = const_cast<ContentInfo*>(static_cast<const ContentInfo*>(__pContentInfoList->GetAt(pIndex->ToInt())));
879                         String filePath = pContentInfo->GetContentPath();
880                         String fileName = GetFileNameFromFullPath(filePath, true);
881
882                         String destPath;
883                         if (destDirectory.EndsWith(DIRECTORY_SEPARATOR) == true)
884                         {
885                                 destPath.Append(destDirectory);
886                                 destPath.Append(fileName);
887                         }
888                         else
889                         {
890                                 destPath.Append(destDirectory);
891                                 destPath.Append(DIRECTORY_SEPARATOR);
892                                 destPath.Append(fileName);
893                         }
894
895                         if (File::IsFileExist(destPath) == true)
896                         {
897                                 pCollisionInfoList->Add(*(new (std::nothrow) String(pIndex->ToString() + MULTI_ITEM_SEPARATOR + fileName)));
898                         }
899                 }
900         }
901         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
902
903         return pCollisionInfoList;
904 }
905
906 result
907 FileListPresentationModel::MoveToContentFileList(const IList& contentIndexList, const String& destDirectory)
908 {
909         AppLogDebug("ENTER");
910         result r = E_SUCCESS;
911         if (&contentIndexList == null || contentIndexList.GetCount() <= 0 || &destDirectory == null || destDirectory.IsEmpty() == true)
912         {
913                 AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
914
915                 return r;
916         }
917
918         if (File::IsFileExist(destDirectory) == false)
919         {
920                 Directory::Create(destDirectory, true);
921         }
922
923         delete __pContentIdList;
924         __pContentIdList = new (std::nothrow) ArrayList(SingleObjectDeleter);
925         int loopCount = contentIndexList.GetCount();
926         for (int i = 0; i < loopCount; ++i)
927         {
928                 const Integer* pIndex = static_cast<const Integer*>(contentIndexList.GetAt(i));
929
930                 if ((pIndex != null) && (pIndex->ToInt())>=0 && __pContentInfoList->GetCount() > pIndex->ToInt())
931                 {
932                         __pContentIdList->Add(new (std::nothrow) ContentId((static_cast<ContentInfo*>(__pContentInfoList->GetAt(pIndex->ToInt())))->GetContentId()));
933                 }
934         }
935
936
937         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
938
939         return E_SUCCESS;
940 }
941
942 result
943 FileListPresentationModel::DeleteContentFile(const ContentId& contentId)
944 {
945         AppLogDebug("ENTER");
946         if (&contentId == null)
947         {
948                 AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
949
950                 return E_SUCCESS;
951         }
952         result r = __pContentManager->DeleteContent(contentId);
953
954         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
955
956         return r;
957 }
958
959 result
960 FileListPresentationModel::MoveToContentFile(const ContentId& contentId, const String& destDirectory, const bool isCopyOperation)
961 {
962         AppLogDebug("ENTER");
963         if (contentId.ToString().IsEmpty() == true || destDirectory.IsEmpty() == true)
964         {
965                 AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
966                 return E_FAILURE;
967         }
968         result r = E_SUCCESS;
969         ContentInfo* pContentInfo = __pContentManager->GetContentInfoN(contentId);
970         if (pContentInfo == null)
971         {
972                 AppLogDebug("Santhosh %s", destDirectory.GetPointer());
973                 AppLogDebug("EXIT 2(%s)", GetErrorMessage(GetLastResult()));
974                 return E_FAILURE;
975         }
976
977         String filePath = pContentInfo->GetContentPath();
978         if (filePath.GetLength() < 4)
979         {
980                 AppLogDebug("EXIT 3(%s)", GetErrorMessage(GetLastResult()));
981                 return E_SUCCESS;
982         }
983
984         String destPath;
985         if (destDirectory.EndsWith(DIRECTORY_SEPARATOR) == true)
986         {
987                 destPath.Append(destDirectory);
988                 destPath.Append(GetFileNameFromFullPath(filePath, true));
989         }
990         else
991         {
992                 destPath.Append(destDirectory);
993                 destPath.Append(DIRECTORY_SEPARATOR);
994                 destPath.Append(GetFileNameFromFullPath(filePath, true));
995         }
996
997         if (destPath.CompareTo(filePath) == 0)
998         {
999                 AppLogDebug("EXIT 4(%s)", GetErrorMessage(GetLastResult()));
1000                 return E_SUCCESS;
1001         }
1002
1003         if (File::IsFileExist(destPath) == true)
1004         {
1005                 File::Remove(destPath);
1006         }
1007
1008         r = File::Copy(filePath, destPath, false);
1009
1010         if (r == E_STORAGE_FULL)
1011         {
1012                 File::Remove(destPath);
1013         }
1014         ContentManager::ScanFile(destPath);
1015
1016         if (r == E_SUCCESS)
1017         {
1018                 if (isCopyOperation == false)
1019                 {
1020                         File::Remove(filePath);               // if Move Op remove original file
1021                         ContentManager::ScanFile(filePath);
1022                 }
1023         }
1024
1025         delete pContentInfo;
1026
1027         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
1028
1029         return r;
1030 }
1031
1032 void
1033 FileListPresentationModel::ClearProviderId(void)
1034 {
1035         __providerId.Clear();
1036 }
1037
1038 result
1039 FileListPresentationModel::StartAppControl(const String& providerId, const String& operationId,
1040                 const String* pUriData, const Tizen::Base::String* pMimeType, const HashMap* pDataList,
1041                 IAppControlResponseListener* pListener)
1042 {
1043         AppLogDebug("ENTER");
1044         AppControl* pAc = AppManager::FindAppControlN(providerId, operationId);
1045
1046         ClearProviderId();
1047         __providerId.Append(providerId);
1048
1049         if (pAc == null)
1050         {
1051                 AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
1052                 return E_FAILURE;
1053         }
1054         result r = pAc->Start(pUriData, pMimeType, pDataList, pListener);
1055
1056         if (r == E_SUCCESS)
1057         {
1058                 GalleryApp* pGalleryApp = static_cast<GalleryApp*>(GalleryApp::GetInstance());
1059                 pGalleryApp->SetFrameEnabled(false);
1060         }
1061
1062         delete pAc;
1063
1064         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
1065
1066         return r;
1067 }
1068
1069 result
1070 FileListPresentationModel::SetCurrentAlbumInfo(const String& albumName, const IList& directoryList)
1071 {
1072         AppLogDebug("ENTER");
1073
1074         if (&directoryList != null)
1075         {
1076                 if (__pDirectoryList != null && __pDirectoryList->GetCount() > 0)
1077                 {
1078                         bool isMatched = false;
1079                         int outterLoopCount = __pDirectoryList->GetCount();
1080                         int innerLoopCount = 0;
1081                         for (int i = 0; i < outterLoopCount; ++i)
1082                         {
1083                                 isMatched = false;
1084                                 innerLoopCount = directoryList.GetCount();
1085                                 for (int j = 0; j < innerLoopCount; ++j)
1086                                 {
1087                                         if (static_cast<String*>(__pDirectoryList->GetAt(i))->CompareTo(
1088                                                         *(const_cast<String*>(static_cast<const String*>(directoryList.GetAt(j))))) == 0)
1089                                         {
1090                                                 isMatched = true;
1091                                                 break;
1092                                         }
1093                                 }
1094                         }
1095
1096                         outterLoopCount = directoryList.GetCount();
1097                         for (int i = 0; i < outterLoopCount; ++i)
1098                         {
1099                                 isMatched = false;
1100                                 innerLoopCount = __pDirectoryList->GetCount();
1101                                 for (int j = 0; j < innerLoopCount; ++j)
1102                                 {
1103                                         if (const_cast<String*>(static_cast<const String*>(directoryList.GetAt(i)))->CompareTo(
1104                                                         *(static_cast<String*>(__pDirectoryList->GetAt(j)))) == 0)
1105                                         {
1106                                                 isMatched = true;
1107                                                 break;
1108                                         }
1109                                 }
1110                         }
1111                 }
1112         }
1113
1114         __albumName = albumName;
1115         __providerId.Clear();
1116
1117         if (__pDirectoryList != null)
1118         {
1119                 delete __pDirectoryList;
1120         }
1121         __pDirectoryList = new (std::nothrow) ArrayList(SingleObjectDeleter);
1122
1123         int loopCount = directoryList.GetCount();
1124         for (int i = 0; i < loopCount; ++i)
1125         {
1126                 __pDirectoryList->Add(new (std::nothrow) String(*(const_cast<String*>
1127                         (static_cast<const String*>(directoryList.GetAt(i))))));
1128         }
1129
1130         if (__pContentInfoList != null)
1131         {
1132                 delete __pContentInfoList;
1133                 __pContentInfoList = null;
1134         }
1135
1136         if (GetAppControlMode() == APPCONTROL_MODE_PICK)
1137         {
1138                 AppControlMediaType appControlMediaType = GetAppControlMediaType();
1139                 if (appControlMediaType == APPCONTROL_MEDIA_TYPE_IMAGE)
1140                 {
1141                         __albumContentType = CONTENT_TYPE_IMAGE;
1142                 }
1143                 else if (appControlMediaType == APPCONTROL_MEDIA_TYPE_VIDEO)
1144                 {
1145                         __albumContentType = CONTENT_TYPE_VIDEO;
1146                 }
1147         }
1148         __pContentInfoList = GetContentInfoListInDirectoryListN(*__pDirectoryList, __albumContentType);
1149         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
1150
1151         return E_SUCCESS;
1152 }
1153
1154 result
1155 FileListPresentationModel::RefreshCurrentAlbumContentInfoList(const ContentType contentType)
1156 {
1157         AppLogDebug("ENTER");
1158         result r = RefreshContentInfoList(contentType);
1159         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
1160
1161         return r;
1162 }
1163
1164 void
1165 FileListPresentationModel::AddDirectoryIfNew(const String& dirName)
1166 {
1167
1168         bool isMatched = false;
1169         int dirCount = __pDirectoryList->GetCount();
1170         String fullDirName;
1171         fullDirName = Environment::GetMediaPath();
1172         fullDirName.Append(dirName);
1173
1174         if (__albumName != ResourceManager::GetString(L"IDS_MEDIABR_BODY_ALL_ALBUMS"))//we are not in All albums
1175         {
1176                 return;
1177         }
1178
1179         for (int i = 0; i < dirCount; ++i)
1180         {
1181                 if (static_cast<String*>(__pDirectoryList->GetAt(i))->CompareTo(fullDirName) == 0)
1182                 {
1183                         isMatched = true;
1184                         break;
1185                 }
1186         }
1187         
1188         if (!isMatched)
1189         {
1190                 __pDirectoryList->Add(new (std::nothrow) String(fullDirName));
1191         }
1192 }
1193
1194 result
1195 FileListPresentationModel::RefreshContentInfoList(const ContentType contentType)
1196 {
1197         AppLogDebug("ENTER");
1198         if ((contentType != CONTENT_TYPE_ALL) && (contentType != CONTENT_TYPE_IMAGE) && (contentType != CONTENT_TYPE_VIDEO))
1199         {
1200                 AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
1201
1202                 return E_FAILURE;
1203         }
1204
1205         if ((__pDirectoryList == null) || (__pDirectoryList->GetCount() <= 0))
1206         {
1207                 AppLogDebug("EXIT 2(%s)", GetErrorMessage(GetLastResult()));
1208
1209                 return E_SUCCESS;
1210         }
1211
1212         __albumContentType = contentType;
1213
1214         if (__pContentInfoList != null)
1215         {
1216                 delete __pContentInfoList;
1217                 __pContentInfoList = null;
1218         }
1219
1220         __pContentInfoList = GetContentInfoListInDirectoryListN(*__pDirectoryList, __albumContentType);
1221         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
1222
1223         return E_SUCCESS;
1224 }
1225
1226 String
1227 FileListPresentationModel::GetCurrentAlbumName(void) const
1228 {
1229         AppLogDebug("ENTER");
1230         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
1231
1232         return __albumName;
1233 }
1234
1235 void
1236 FileListPresentationModel::SetCurrentAlbumName(const String& albumName)
1237 {
1238         AppLogDebug("ENTER");
1239         if (&albumName == null)
1240         {
1241                 __albumName = EMPTY_SPACE;
1242         }
1243         else
1244         {
1245                 __albumName = albumName;
1246         }
1247         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
1248 }
1249
1250 ContentType
1251 FileListPresentationModel::GetCurrentAlbumContentType(void) const
1252 {
1253         AppLogDebug("ENTER");
1254         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
1255
1256         return __albumContentType;
1257 }
1258
1259 void
1260 FileListPresentationModel::SetCurrentAlbumContentType(const ContentType contentType)
1261 {
1262         AppLogDebug("ENTER");
1263         __albumContentType = contentType;
1264         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
1265 }
1266
1267 IList*
1268 FileListPresentationModel::GetAlbumDirectoryListN(void) const
1269 {
1270         AppLogDebug("ENTER");
1271         IList* pAlbumDirectoryList = new (std::nothrow) ArrayList(SingleObjectDeleter);
1272         if (__pDirectoryList == null)
1273         {
1274                 AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
1275
1276                 return pAlbumDirectoryList;
1277         }
1278
1279         String* pDirectory = null;
1280         int loopCount = __pDirectoryList->GetCount();
1281         for (int i = 0; i < loopCount; ++i)
1282         {
1283                 pDirectory = static_cast<String*>(__pDirectoryList->GetAt(i));
1284                 pAlbumDirectoryList->Add(new (std::nothrow) String(*pDirectory));
1285         }
1286         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
1287
1288         return pAlbumDirectoryList;
1289 }
1290
1291 IList*
1292 FileListPresentationModel::GetAlbumContentInfoList(void) const
1293 {
1294         AppLogDebug("ENTER");
1295         IList* pContentList = new (std::nothrow) ArrayList(SingleObjectDeleter);
1296         if (__pContentInfoList == null)
1297         {
1298                 AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
1299
1300                 return pContentList;
1301         }
1302
1303         ContentInfo* pContentInfo = null;
1304         int loopCount = __pContentInfoList->GetCount();
1305         for (int i = 0; i < loopCount; ++i)
1306         {
1307                 pContentInfo = static_cast<ContentInfo*>(__pContentInfoList->GetAt(i));
1308                 pContentList->Add(pContentInfo);
1309         }
1310         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
1311
1312         return pContentList;
1313 }
1314
1315 ContentInfo*
1316 FileListPresentationModel::GetContentInfo(const int index) const
1317 {
1318         AppLogDebug("ENTER");
1319         if (__pContentInfoList == null || __pContentInfoList->GetCount() == 0)
1320         {
1321                 AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
1322
1323                 return null;
1324         }
1325
1326         if (index < 0 || index >= __pContentInfoList->GetCount())
1327         {
1328                 AppLogDebug("EXIT 2(%s)", GetErrorMessage(GetLastResult()));
1329
1330                 return null;
1331         }
1332         ContentInfo* pContentInfo = static_cast<ContentInfo*>(__pContentInfoList->GetAt(index));
1333         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
1334
1335         return pContentInfo;
1336 }
1337
1338 IList* FileListPresentationModel::GetContentIdListAtIndexN(const IList& indexList) const
1339 {
1340         IList* pContentIdList = new (std::nothrow) ArrayList(SingleObjectDeleter);
1341         int loopCount = indexList.GetCount();
1342         for (int i = 0; i < loopCount; ++i)
1343         {
1344                 const Integer* pIndex = static_cast<const Integer*>(indexList.GetAt(i));
1345
1346                 if ((pIndex != null) && (pIndex->ToInt())>=0 && __pContentInfoList->GetCount() > pIndex->ToInt())
1347                 {
1348                         pContentIdList->Add(new (std::nothrow) ContentId((static_cast<ContentInfo*>(__pContentInfoList->GetAt(pIndex->ToInt())))->GetContentId()));
1349                 }
1350         }
1351
1352         return pContentIdList;
1353 }
1354
1355 int
1356 FileListPresentationModel::GetCurrentAlbumContentInfoCount(void) const
1357 {
1358         AppLogDebug("ENTER");
1359         if (__pContentInfoList == null)
1360         {
1361                 AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
1362
1363                 return 0;
1364         }
1365         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
1366
1367         return __pContentInfoList->GetCount();
1368 }
1369
1370 ContentId
1371 FileListPresentationModel::GetContentInfoIndex(const int index) const
1372 {
1373         AppLogDebug("ENTER");
1374         if (__pContentInfoList == null || __pContentInfoList->GetCount() == 0)
1375         {
1376                 AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
1377
1378                 return 0;
1379         }
1380
1381         if (index < 0 || index >= __pContentInfoList->GetCount())
1382         {
1383                 AppLogDebug("EXIT 2(%s)", GetErrorMessage(GetLastResult()));
1384
1385                 return 0;
1386         }
1387         ContentInfo* pContentInfo = static_cast<ContentInfo*>(__pContentInfoList->GetAt(index));
1388         ContentId contentId = pContentInfo->GetContentId();
1389         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
1390
1391         return contentId;
1392 }
1393
1394 String
1395 FileListPresentationModel::GetContentFilePath(const int index) const
1396 {
1397         AppLogDebug("ENTER index(%d)", index);
1398         if (__pContentInfoList == null || __pContentInfoList->GetCount() == 0)
1399         {
1400                 AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
1401
1402                 return EMPTY_SPACE;
1403         }
1404
1405         if (index < 0 || index >= __pContentInfoList->GetCount())
1406         {
1407                 AppLogDebug("EXIT 2(%s)", GetErrorMessage(GetLastResult()));
1408
1409                 return EMPTY_SPACE;
1410         }
1411
1412         ContentInfo* pContentInfo = static_cast<ContentInfo*>(__pContentInfoList->GetAt(index));
1413         String contentPath = pContentInfo->GetContentPath();
1414         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
1415
1416         return contentPath;
1417 }
1418
1419 Bitmap*
1420 FileListPresentationModel::CoverVideoOverlayedImageOnThumbnailN(Bitmap& thumbnail,
1421                 const ThumbnailInfo& thumbmailInfo)
1422 {
1423         AppLogDebug("ENTER");
1424         Bitmap* pOverlayedImage = null;
1425
1426         if (&thumbmailInfo != null)
1427         {
1428                 long duration = thumbmailInfo.GetDuration();
1429
1430                 Canvas mainCanvas;
1431                 if (&thumbnail != null)
1432                 {
1433                         BufferInfo bufferInfo;
1434                         thumbnail.Lock(bufferInfo, INFINITE);
1435                         thumbnail.Unlock();
1436                         mainCanvas.Construct(bufferInfo);
1437                 }
1438                 else
1439                 {
1440                         Rectangle mainRect(0, 0, W_DEFAULT_THUMBNAIL, H_DEFAULT_THUMBNAIL);
1441                         mainCanvas.Construct(mainRect);
1442                         mainCanvas.FillRectangle(Color::GetColor(COLOR_ID_BLACK), mainRect);
1443                 }
1444
1445                 Rectangle playRect(GAP_W_PLAY_FG, GAP_H_PLAY_FG, W_PLAY_FG, H_PLAY_FG);
1446                 Bitmap* playBitmap = ResourceManager::GetBitmapN(IDB_VIDEOTHUMBNAIL_PLAY);
1447                 if (playBitmap != null)
1448                 {
1449                         mainCanvas.DrawBitmap(playRect, *playBitmap);
1450                         delete playBitmap;
1451                 }
1452
1453                 Canvas durCanvas;
1454                 Rectangle durSize(0, 0, W_DURATION, H_DURATION);
1455                 Rectangle durRect(0, GAP_H_DURATION, W_DURATION, H_DURATION);
1456                 Color durColor(COLOR_DURATION_BG);
1457                 durColor.SetAlpha(ALPHA_DURATION);
1458                 durCanvas.Construct(durSize);
1459                 durCanvas.FillRectangle(durColor, durSize);
1460                 Font durFont;
1461                 durFont.Construct(FONT_STYLE_PLAIN, FONT_SIZE_DURATION);
1462                 durCanvas.SetFont(durFont);
1463                 durCanvas.DrawText(Point(W_DURATION_TEXT, H_DURATION_TEXT),
1464                                 CommonUtil::DurationToTimeString(duration), COLOR_TEXT_OUTLINE);
1465                 Bitmap durBitmap;
1466                 durBitmap.Construct(durCanvas, durCanvas.GetBounds());
1467                 mainCanvas.DrawBitmap(durRect, durBitmap);
1468
1469                 pOverlayedImage = new (std::nothrow) Bitmap();
1470                 pOverlayedImage->Construct(mainCanvas, mainCanvas.GetBounds());
1471         }
1472         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
1473
1474         return pOverlayedImage;
1475 }
1476
1477 Bitmap*
1478 FileListPresentationModel::GetShadedBackgroundBitmapN(Bitmap& bgBitmap,
1479                 const Bitmap& originalBitmap, const Rectangle& originalBitmapPosition) const
1480 {
1481         AppLogDebug("ENTER");
1482         if (&originalBitmap == null || &originalBitmap == null)
1483         {
1484                 AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
1485
1486                 return null;
1487         }
1488
1489         BufferInfo bufferInfo;
1490         bgBitmap.Lock(bufferInfo, INFINITE);
1491         bgBitmap.Unlock();
1492         Canvas mainCanvas;
1493         mainCanvas.Construct(bufferInfo);
1494         mainCanvas.Clear();
1495         mainCanvas.DrawBitmap(originalBitmapPosition, originalBitmap);
1496
1497         Bitmap* pMainImage = new (std::nothrow) Bitmap();
1498         pMainImage->Construct(mainCanvas,mainCanvas.GetBounds());
1499         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
1500
1501         return pMainImage;
1502 }
1503
1504 IList*
1505 FileListPresentationModel::GetContentInfoListInDirectoryListN(const IList& contentDirectoryList,
1506                 ContentType contentType)const
1507 {
1508         AppLogDebug("ENTER");
1509         IList* pContentList = new (std::nothrow) ArrayList(SingleObjectDeleter);
1510
1511         if ((&contentDirectoryList == null) || (contentDirectoryList.GetCount() == 0)
1512                         || ((contentType != CONTENT_TYPE_IMAGE) && (contentType != CONTENT_TYPE_VIDEO) && (contentType != CONTENT_TYPE_ALL)))
1513         {
1514                 AppLogDebug("EXIT 1(%s)", GetErrorMessage(GetLastResult()));
1515                 return pContentList;
1516         }
1517
1518         ContentDirectory contentDirectory;
1519         IListT<ContentType>* pContentTypeList = new (std::nothrow) ArrayListT<ContentType>();
1520         if (contentType == CONTENT_TYPE_IMAGE || contentType == CONTENT_TYPE_ALL)
1521         {
1522                 pContentTypeList->Add(CONTENT_TYPE_IMAGE);
1523         }
1524         if (contentType == CONTENT_TYPE_VIDEO || contentType == CONTENT_TYPE_ALL)
1525         {
1526                 pContentTypeList->Add(CONTENT_TYPE_VIDEO);
1527         }
1528         result r = contentDirectory.Construct(*pContentTypeList);
1529         delete pContentTypeList;
1530
1531         if (r == E_SUCCESS)
1532         {
1533                 int pageNo = SIZE_PAGE_NO;
1534                 int countPerPage = SIZE_CONUNT_PER_PAGE;
1535                 String* pContentDirectory = null;
1536
1537                 int loopCount = contentDirectoryList.GetCount();
1538                 for (int i = 0; i < loopCount; ++i)
1539                 {
1540                         IList* pIList = null;
1541                         pContentDirectory = const_cast<String*>(static_cast<const String*>(contentDirectoryList.GetAt(i)));
1542                         if (pContentDirectory != null)
1543                         {
1544                                 pIList = contentDirectory.GetContentDirectoryItemListN(*pContentDirectory, pageNo, countPerPage,
1545                                                 CONTENT_INFO_ORDER, SORT_ORDER_NONE);
1546
1547                                 if (pIList != null)
1548                                 {
1549                                         pContentList->AddItems(*pIList);
1550                                 }
1551                         }
1552                 }
1553         }
1554         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
1555
1556         return pContentList;
1557 }
1558
1559 String
1560 FileListPresentationModel::ConvertToAlbumName(const String& targetPath)const
1561 {
1562         AppLogDebug("ENTER");
1563         String albumName;
1564         if (&targetPath == null || targetPath.GetLength() == 0)
1565         {
1566                 return albumName;
1567         }
1568
1569         if (targetPath == RESERVED_CAMERA_PATH || targetPath == RESERVED_CAMERA_PATH_EXT)
1570         {
1571                 albumName = ResourceManager::GetString(L"IDS_MEDIABR_BODY_CAMERA_ROLL_ABB");
1572         }
1573         else if (targetPath == RESERVED_DOWNLOAD_PATH)
1574         {
1575                 albumName = ResourceManager::GetString(L"IDS_COM_BODY_DOWNLOADS");
1576         }
1577         else
1578         {
1579                 String directoryName = GetDirecotyNameFromFullPath(targetPath);
1580                 albumName = directoryName;
1581         }
1582
1583         return albumName;
1584 }
1585
1586 AppControlMode
1587 FileListPresentationModel::GetAppControlMode(void) const
1588 {
1589         AppLogDebug("Enter");
1590         AppLogDebug("Exit");
1591
1592         return __appControlMode;
1593 }
1594
1595 AppControlMediaType
1596 FileListPresentationModel::GetAppControlMediaType(void) const
1597 {
1598         AppLogDebug("Enter");
1599         AppLogDebug("Exit");
1600
1601         return __appControlMediaType;
1602 }
1603
1604 AppControlSelectionMode
1605 FileListPresentationModel::GetAppControlSelectionMode(void) const
1606 {
1607         AppLogDebug("Enter");
1608         AppLogDebug("Exit");
1609
1610         return __appControlSelectionMode;
1611 }
1612
1613 void
1614 FileListPresentationModel::SetUpdateProgressStatus(const bool status)
1615 {
1616         AppLogDebug("ENTER status = %d",status);
1617         __updateProgressStatus = status;
1618         AppLogDebug("EXIT");
1619 }
1620
1621 result
1622 FileListPresentationModel::RotateImage(int index, RotateMode rotateMode)
1623 {
1624         result r = E_SUCCESS;
1625         ImageBuffer rotateBuffer;
1626         ImageBuffer* pRotatedBuffer = null;
1627         ImageFormat imageFormat;
1628         Image img;
1629         String filePath = GetContentFilePath(index);
1630         ContentType contentType = ContentManagerUtil::CheckContentType(filePath);
1631         if (contentType == CONTENT_TYPE_VIDEO)
1632         {
1633                 return r;
1634         }
1635
1636         r = img.Construct();
1637
1638         if (r == E_SUCCESS)
1639         {
1640                 imageFormat = img.GetImageFormat(filePath);
1641
1642                 r = rotateBuffer.Construct(filePath);
1643                 if (r == E_SUCCESS)
1644                 {
1645                         if (rotateMode == ROTATE_MODE_RIGHT)
1646                         {
1647                                 pRotatedBuffer = rotateBuffer.RotateN(IMAGE_ROTATION_90);
1648                         }
1649                         else
1650                         {
1651                                 pRotatedBuffer = rotateBuffer.RotateN(IMAGE_ROTATION_270);
1652                         }
1653                 }
1654
1655                 if (pRotatedBuffer != null)
1656                 {
1657                         r = pRotatedBuffer->EncodeToFile(filePath, imageFormat, true, 100);
1658                         delete pRotatedBuffer;
1659                         ContentManager::ScanFile(filePath);
1660                 }
1661         }
1662
1663         return r;
1664 }
1665
1666 void
1667 FileListPresentationModel::ClearImageCache(void)
1668 {
1669         AppLogDebug("ENTER");
1670
1671         if(__pIconListViewCache != null)
1672         {
1673                 bool clearThumbnailReq = true;
1674                 while(__pIconListViewCache->GetCount() != 0)
1675                 {
1676                         //This is to Clear the Thumbnail Reuqests only Once
1677                         if(clearThumbnailReq == true)
1678                         {
1679                                 ClearThumbnailRequests();
1680                                 clearThumbnailReq = false;
1681                         }
1682                         __pIconListViewCache->RemoveAt(0, true);
1683                 }
1684         }
1685         AppLogDebug("EXIT");
1686 }
1687
1688 void
1689 FileListPresentationModel::OnDeviceStateChanged(DeviceType deviceType, const Tizen::Base::String& state)
1690 {
1691         AppLogDebug("ENTER");
1692         if (deviceType == DEVICE_TYPE_STORAGE_CARD && state == DEVICE_STORAGE_CARD_UNMOUNTED)
1693         {
1694                 IFormContentUpdateEventListener* pInterface = null;
1695                 IEnumerator* pEventEnum = __pContentEventListener->GetEnumeratorN();
1696                 while (pEventEnum->MoveNext() == E_SUCCESS)
1697                 {
1698                         pInterface = static_cast<IFormContentUpdateEventListener*>(pEventEnum->GetCurrent());
1699                         pInterface->OnContentUpdated();
1700                 }
1701                 delete pEventEnum;
1702         }
1703         AppLogDebug("EXIT(%s)", GetErrorMessage(GetLastResult()));
1704 }