2 * ownCloud Android client application
4 * @author David A. Velasco
5 * Copyright (C) 2011 Bartek Przybylski
6 * Copyright (C) 2015 ownCloud Inc.
8 * This program is free software: you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License version 2,
10 * as published by the Free Software Foundation.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with this program. If not, see <http://www.gnu.org/licenses/>.
21 package com
.owncloud
.android
.ui
.adapter
;
24 import java
.util
.Arrays
;
25 import java
.util
.Comparator
;
27 import android
.content
.Context
;
28 import android
.graphics
.Bitmap
;
29 import android
.view
.LayoutInflater
;
30 import android
.view
.View
;
31 import android
.view
.ViewGroup
;
32 import android
.widget
.BaseAdapter
;
33 import android
.widget
.ImageView
;
34 import android
.widget
.ListAdapter
;
35 import android
.widget
.ListView
;
36 import android
.widget
.TextView
;
38 import com
.owncloud
.android
.R
;
39 import com
.owncloud
.android
.datamodel
.ThumbnailsCacheManager
;
40 import com
.owncloud
.android
.lib
.common
.utils
.Log_OC
;
41 import com
.owncloud
.android
.utils
.BitmapUtils
;
42 import com
.owncloud
.android
.utils
.DisplayUtils
;
43 import com
.owncloud
.android
.utils
.MimetypeIconUtil
;
46 * This Adapter populates a ListView with all files and directories contained
47 * in a local directory
49 public class LocalFileListAdapter
extends BaseAdapter
implements ListAdapter
{
51 private static final String TAG
= LocalFileListAdapter
.class.getSimpleName();
53 private Context mContext
;
54 private File mDirectory
;
55 private File
[] mFiles
= null
;
57 public LocalFileListAdapter(File directory
, Context context
) {
59 swapDirectory(directory
);
63 public boolean areAllItemsEnabled() {
68 public boolean isEnabled(int position
) {
73 public int getCount() {
74 return mFiles
!= null ? mFiles
.length
: 0;
78 public Object
getItem(int position
) {
79 if (mFiles
== null
|| mFiles
.length
<= position
)
81 return mFiles
[position
];
85 public long getItemId(int position
) {
86 return mFiles
!= null
&& mFiles
.length
<= position ? position
: -1;
90 public int getItemViewType(int position
) {
95 public View
getView(int position
, View convertView
, ViewGroup parent
) {
96 View view
= convertView
;
98 LayoutInflater inflator
= (LayoutInflater
) mContext
99 .getSystemService(Context
.LAYOUT_INFLATER_SERVICE
);
100 view
= inflator
.inflate(R
.layout
.list_item
, null
);
102 if (mFiles
!= null
&& mFiles
.length
> position
) {
103 File file
= mFiles
[position
];
105 TextView fileName
= (TextView
) view
.findViewById(R
.id
.Filename
);
106 String name
= file
.getName();
107 fileName
.setText(name
);
109 ImageView fileIcon
= (ImageView
) view
.findViewById(R
.id
.thumbnail
);
111 /** Cancellation needs do be checked and done before changing the drawable in fileIcon, or
112 * {@link ThumbnailsCacheManager#cancelPotentialWork} will NEVER cancel any task.
114 boolean allowedToCreateNewThumbnail
= (ThumbnailsCacheManager
.cancelPotentialWork(file
, fileIcon
));
116 if (!file
.isDirectory()) {
117 fileIcon
.setImageResource(R
.drawable
.file
);
119 fileIcon
.setImageResource(R
.drawable
.ic_menu_archive
);
121 fileIcon
.setTag(file
.hashCode());
123 TextView fileSizeV
= (TextView
) view
.findViewById(R
.id
.file_size
);
124 TextView lastModV
= (TextView
) view
.findViewById(R
.id
.last_mod
);
125 ImageView checkBoxV
= (ImageView
) view
.findViewById(R
.id
.custom_checkbox
);
126 if (!file
.isDirectory()) {
127 fileSizeV
.setVisibility(View
.VISIBLE
);
128 fileSizeV
.setText(DisplayUtils
.bytesToHumanReadable(file
.length()));
130 lastModV
.setVisibility(View
.VISIBLE
);
131 lastModV
.setText(DisplayUtils
.unixTimeToHumanReadable(file
.lastModified()));
132 ListView parentList
= (ListView
) parent
;
133 if (parentList
.getChoiceMode() == ListView
.CHOICE_MODE_NONE
) {
134 checkBoxV
.setVisibility(View
.GONE
);
136 if (parentList
.isItemChecked(position
)) {
137 checkBoxV
.setImageResource(android
.R
.drawable
.checkbox_on_background
);
139 checkBoxV
.setImageResource(android
.R
.drawable
.checkbox_off_background
);
141 checkBoxV
.setVisibility(View
.VISIBLE
);
144 // get Thumbnail if file is image
145 if (BitmapUtils
.isImage(file
)){
146 // Thumbnail in Cache?
147 Bitmap thumbnail
= ThumbnailsCacheManager
.getBitmapFromDiskCache(
148 String
.valueOf(file
.hashCode())
150 if (thumbnail
!= null
){
151 fileIcon
.setImageBitmap(thumbnail
);
154 // generate new Thumbnail
155 if (allowedToCreateNewThumbnail
) {
156 final ThumbnailsCacheManager
.ThumbnailGenerationTask task
=
157 new ThumbnailsCacheManager
.ThumbnailGenerationTask(fileIcon
);
158 if (thumbnail
== null
) {
159 thumbnail
= ThumbnailsCacheManager
.mDefaultImg
;
161 final ThumbnailsCacheManager
.AsyncDrawable asyncDrawable
=
162 new ThumbnailsCacheManager
.AsyncDrawable(
163 mContext
.getResources(),
167 fileIcon
.setImageDrawable(asyncDrawable
);
169 Log_OC
.v(TAG
, "Executing task to generate a new thumbnail");
171 } // else, already being generated, don't restart it
174 fileIcon
.setImageResource(MimetypeIconUtil
.getFileTypeIconId(null
, file
.getName()));
178 fileSizeV
.setVisibility(View
.GONE
);
179 lastModV
.setVisibility(View
.GONE
);
180 checkBoxV
.setVisibility(View
.GONE
);
183 // not GONE; the alignment changes; ugly way to keep it
184 view
.findViewById(R
.id
.localFileIndicator
).setVisibility(View
.INVISIBLE
);
185 view
.findViewById(R
.id
.favoriteIcon
).setVisibility(View
.GONE
);
187 view
.findViewById(R
.id
.sharedIcon
).setVisibility(View
.GONE
);
188 view
.findViewById(R
.id
.sharedWithMeIcon
).setVisibility(View
.GONE
);
195 public int getViewTypeCount() {
200 public boolean hasStableIds() {
205 public boolean isEmpty() {
206 return (mFiles
== null
|| mFiles
.length
== 0);
210 * Change the adapted directory for a new one
211 * @param directory New file to adapt. Can be NULL, meaning "no content to adapt".
213 public void swapDirectory(File directory
) {
214 mDirectory
= directory
;
215 mFiles
= (mDirectory
!= null ? mDirectory
.listFiles() : null
);
216 if (mFiles
!= null
) {
217 Arrays
.sort(mFiles
, new Comparator
<File
>() {
219 public int compare(File lhs
, File rhs
) {
220 if (lhs
.isDirectory() && !rhs
.isDirectory()) {
222 } else if (!lhs
.isDirectory() && rhs
.isDirectory()) {
225 return compareNames(lhs
, rhs
);
228 private int compareNames(File lhs
, File rhs
) {
229 return lhs
.getName().toLowerCase().compareTo(rhs
.getName().toLowerCase());
234 notifyDataSetChanged();