2 * Copyright 2012 Samsung Electronics Co., Ltd
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
8 * http://floralicense.org/license
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.
17 var gMediaSource, gMediaFolders, gMediaItems, gItemId, gFolderId,
18 gMediaType = "ALL", gStorageType, gFlagInit, gSpan = $('<span/>');
20 $(document).delegate("#main", "pageinit", function() {
21 var highlightStoragetype = function (storageType) {
22 $("#folder-list li").each(function(){
23 $(this).removeClass("storagetypeHighlight");
25 if (storageType == "ALL") $("#folder-type-all").addClass("storagetypeHighlight");
26 else if (storageType == "INTERNAL") $("#folder-type-internal").addClass("storagetypeHighlight");
27 else if (storageType == "EXTERNAL") $("#folder-type-external").addClass("storagetypeHighlight");
32 gStorageType = gMediaType;
34 $("#folder-type-all").bind("click", function() {
35 showFolderList("ALL");
36 highlightStoragetype("ALL");
39 $("#folder-type-internal").bind("click", function() {
40 showFolderList("INTERNAL");
41 highlightStoragetype("INTERNAL");
44 $("#folder-type-external").bind("click", function() {
45 showFolderList("EXTERNAL");
46 highlightStoragetype("EXTERNAL");
52 $(document).delegate("#items", "pageinit", function() {
53 $("#items").bind("pageshow", showItemList);
55 $("#items-list input").bind("change", function() {
56 if ($(this).prop("checked") == true) {
57 gMediaType = $(this).attr("value");
58 getFolderItems(gFolderId, gMediaType);
62 $("#items-list").delegate("li", "click", function() {
63 var id = $(this).data("id");
66 $.mobile.changePage("#detail");
72 $(document).delegate("#detail", "pageinit", function() {
73 $("#detail").bind("pagebeforeshow", showMediaDetail);
76 $(window).on('tizenhwkey', function (e) {
77 if (e.originalEvent.keyName === "back") {
78 if ($.mobile.activePage.attr('id') === 'main') {
79 tizen.application.getCurrentApplication().exit();
86 function setLastStorage(storageType) {
87 gStorageType = storageType;
90 function makeListItem(id, mainText, subText) {
91 return '<li class="ui-li-has-multiline ui-li-text-ellipsis"'
92 + (id == null ? '' : ' data-id="'+ id +'"')
95 + '<span class="ui-li-text-sub">'
100 function stripTags(str) {
101 return gSpan.text(str).html();
104 function getFolders (storageType) {
106 gMediaSource = tizen.content;
107 gMediaSource.getDirectories(onGetFoldersSuccess, onGetFoldersError);
109 alert("getLocalMediaSource exc:" + exc.message);
112 function onGetFoldersSuccess(folders) {
113 $("#file-list").delegate("li", "vclick", function() {
114 var id = $(this).data("id");
116 getFolderItems(Number(id), gMediaType);
122 gMediaFolders = folders;
123 showFolderList(storageType);
125 * refresh view when looking at external items
126 * while external storage is detaching
128 if($.mobile.activePage.attr("id") == "items") {
133 function onGetFoldersError(err) {
134 alert("GetFolders failed:" + err.message);
140 function onContentChange() {
141 tizen.systeminfo.addPropertyValueChangeListener('STORAGE', function() {
142 getFolders(gStorageType);
146 function showFolderList(storageType) {
147 setLastStorage(storageType);
148 if(gFlagInit == false){
149 getFolders(storageType);
153 gMF = gMediaFolders.length,
155 for ( i = 0; i < gMF; i++) {
156 if (storageType == "ALL" || storageType == gMediaFolders[i].storageType) {
157 str += makeListItem(i, gMediaFolders[i].title, gMediaFolders[i].directoryURI);
160 $("#file-list").empty().hide().append(str).listview("refresh").show();
165 function showItemList() {
166 var str = '', title, i, gMediaLen;
168 title = gMediaFolders[gFolderId].title;
169 $("#items-title").text(gFolderId == null ? "All" : title.toString());
171 gMediaLen = gMediaItems.length;
172 for (i = 0; i < gMediaLen; i += 1) {
173 str += makeListItem(i, gMediaItems[i].title,
174 gMediaItems[i].type + " Rating: " + gMediaItems[i].rating);
176 $("#items-list > li[data-id]").remove();
177 $("#items-list").append(str).trigger("create").listview("refresh");
179 gMediaType = gStorageType = "ALL";
180 getFolders(gStorageType);
181 $("#folder-list li").removeClass("storagetypeHighlight");
182 $("#folder-type-all").addClass("storagetypeHighlight");
183 $.mobile.changePage("#main");
187 function getFolderItems(folderId, mediaType) {
188 function onFindItemsSuccess(items) {
190 gFolderId = folderId;
191 gMediaType = mediaType;
193 if($.mobile.activePage.attr("id") == "items") {
196 $.mobile.changePage("#items");
200 function onFindItemsError(err) {
201 alert("getFolderItems findItems failed: " + err.message);
205 gMediaSource.find(onFindItemsSuccess, onFindItemsError,
206 folderId == null ? null : gMediaFolders[folderId].id,
207 mediaType == "ALL" ? null : new tizen.AttributeFilter("type", "EXACTLY", mediaType),
208 new tizen.SortMode("title", "ASC"));
210 //alert("findItems exc:" + exc.message);
214 function makeCommonPropertiesListItems(item) {
215 return makeListItem(null, "Title", item.title)
216 + makeListItem(null, "Size", item.size + " Bytes")
217 + makeListItem(null, "Type", item.type)
218 + makeListItem(null, "Identifier", item.id)
219 + makeListItem(null, "Item URI", item.contentURI)
220 + makeListItem(null, "MIME type", item.mimeType)
221 + makeListItem(null, "Modified date", item.modifiedDate.toLocaleString())
222 + makeListItem(null, "Description", item.description)
223 + makeListItem(null, "Rating", item.rating);
226 function showMediaDetail() {
227 var str, item = gMediaItems[gItemId];
228 if (item.type == "IMAGE") {
229 str = makeCommonPropertiesListItems(item)
230 + makeListItem(null, "Width", item.width)
231 + makeListItem(null, "Height", item.height);
232 if (item.geolocation) {
233 str += makeListItem(null, "Latitude", item.geolocation.latitude)
234 + makeListItem(null, "Longitude", item.geolocation.longitude);
236 } else if (item.type == "VIDEO") {
237 str = makeCommonPropertiesListItems(item)
238 + makeListItem(null, "Width", item.width)
239 + makeListItem(null, "Height", item.height)
240 + makeListItem(null, "Album", item.album)
241 + makeListItem(null, "Artist", item.artists[0])
242 + makeListItem(null, "Duration", item.duration + " Milliseconds");
243 } else if (item.type == "AUDIO") {
244 str = makeCommonPropertiesListItems(item)
245 + makeListItem(null, "Album", item.album)
246 + makeListItem(null, "Artist", item.artists[0])
247 + makeListItem(null, "Composer", item.composers[0])
248 + makeListItem(null, "Genre", item.genres[0])
249 + makeListItem(null, "Copyright", item.copyright)
250 + makeListItem(null, "Bitrate", item.bitrate + " Bps")
251 + makeListItem(null, "Track number", item.trackNumber)
252 + makeListItem(null, "Duration", item.duration + " Milliseconds");
254 str = makeCommonPropertiesListItems(item);
257 $("#media-details").html(str).trigger("create").listview("refresh");