\r
import java.io.File;\r
import java.net.URLDecoder;\r
-import java.net.URLEncoder;\r
-\r
import android.accounts.Account;\r
import android.accounts.AccountManager;\r
import android.app.AlertDialog;\r
import eu.alefzero.owncloud.files.services.FileUploader;\r
import eu.alefzero.owncloud.syncadapter.FileSyncService;\r
import eu.alefzero.owncloud.ui.fragment.FileListFragment;\r
-import eu.alefzero.owncloud.utils.OwnCloudVersion;\r
import eu.alefzero.webdav.WebdavClient;\r
\r
/**\r
\r
private static final int DIALOG_SETUP_ACCOUNT = 0;\r
private static final int DIALOG_CREATE_DIR = 1;\r
-\r
- private static final int REQUEST_ACCOUNT_SETUP = 0;\r
private static final int ACTION_SELECT_FILE = 1;\r
\r
public void pushPath(String path) {\r
\r
requestWindowFeature(Window.FEATURE_INDETERMINATE_PROGRESS);\r
setProgressBarIndeterminateVisibility(false);\r
- // if (getSupportFragmentManager().findFragmentById(R.id.fileList) ==\r
- // null)\r
+ \r
setContentView(R.layout.files);\r
\r
}\r
mDirectories.insert(s, 0);\r
FileListFragment fileListFramgent = (FileListFragment) getSupportFragmentManager()\r
.findFragmentById(R.id.fileList);\r
- if (fileListFramgent != null) fileListFramgent.populateFileList();\r
+ if (fileListFramgent != null) fileListFramgent.listDirectory();\r
}\r
\r
mStorageManager = new FileDataStorageManager(\r
}\r
\r
public void onActivityResult(int requestCode, int resultCode, Intent data) {\r
- Log.e("ASD", requestCode + " " + resultCode);\r
if (resultCode == RESULT_OK) {\r
if (requestCode == ACTION_SELECT_FILE) {\r
Uri selectedImageUri = data.getData();\r
AccountUtils.getCurrentOwnCloudAccount(this));\r
String remotepath = new String();\r
for (int j = mDirectories.getCount() - 2; j >= 0; --j) {\r
- remotepath += "/" + URLDecoder.decode(mDirectories.getItem(j));\r
+ remotepath += "/" + URLEncoder.encode(mDirectories.getItem(j));\r
}\r
if (!remotepath.endsWith("/"))\r
remotepath += "/";\r
- remotepath += new File(filepath).getName();\r
+ remotepath += URLEncoder.encode(new File(filepath).getName());\r
Log.e("ASD", remotepath + "");\r
\r
i.putExtra(FileUploader.KEY_LOCAL_FILE, filepath);\r
i.putExtra(FileUploader.KEY_REMOTE_FILE, remotepath);\r
- i.putExtra(FileUploader.KEY_UPLOAD_TYPE,\r
- FileUploader.UPLOAD_SINGLE_FILE);\r
+ i.putExtra(FileUploader.KEY_UPLOAD_TYPE, FileUploader.UPLOAD_SINGLE_FILE);\r
startService(i);\r
}\r
}\r
FileListFragment fileListFramgent = (FileListFragment) getSupportFragmentManager()\r
.findFragmentById(R.id.fileList);\r
if (fileListFramgent != null)\r
- fileListFramgent.populateFileList();\r
+ fileListFramgent.listDirectory();\r
}\r
}\r
\r
* \r
*/\r
public class FileListFragment extends FragmentListView {\r
+ private static final String TAG = "FileListFragment";\r
private Account mAccount;\r
private Stack<String> mDirNames;\r
private Vector<OCFile> mFiles;\r
private DataStorageManager mStorageManager;\r
+ private OCFile mFile;\r
private boolean mIsLargeDevice = false;\r
\r
public FileListFragment() {\r
super.onCreate(savedInstanceState);\r
\r
mAccount = AccountUtils.getCurrentOwnCloudAccount(getActivity());\r
+ mStorageManager = new FileDataStorageManager(mAccount, getActivity().getContentResolver());\r
getListView().setDivider(getResources().getDrawable(R.drawable.uploader_list_separator));\r
getListView().setDividerHeight(1);\r
\r
- populateFileList();\r
+ Intent intent = getActivity().getIntent();\r
+ OCFile directory = intent.getParcelableExtra(FileDetailFragment.EXTRA_FILE);\r
+ mFile = directory;\r
+ \r
+ listDirectory(directory);\r
}\r
\r
@Override\r
public void onStart() {\r
- \r
// Create a placeholder upon launch\r
View fragmentContainer = getActivity().findViewById(R.id.file_details_container);\r
if (fragmentContainer != null) {\r
throw new IndexOutOfBoundsException("Incorrect item selected");\r
}\r
OCFile file = mFiles.get(position);\r
-\r
+ mFile = file;\r
+ \r
// Update ActionBarPath\r
if (file.getMimetype().equals("DIR")) {\r
String dirname = file.getFileName();\r
\r
mDirNames.push(dirname);\r
((FileDisplayActivity) getActivity()).pushPath(dirname);\r
-\r
- populateFileList();\r
+ \r
+ listDirectory(file);\r
resetFileFragment();\r
\r
return;\r
}\r
\r
Intent showDetailsIntent = new Intent(getActivity(), FileDetailActivity.class);\r
- showDetailsIntent.putExtra(FileDetailFragment.FILE, file);\r
+ showDetailsIntent.putExtra(FileDetailFragment.EXTRA_FILE, file);\r
showDetailsIntent.putExtra(FileDownloader.EXTRA_ACCOUNT, mAccount);\r
\r
// If we are on a large device -> update fragment\r
}\r
}\r
\r
- @Override\r
- public boolean onItemLongClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) {\r
- ClipData.Item item = new ClipData.Item("ASD");\r
- ClipDescription cd = new ClipDescription("ASD", new String[] { ClipDescription.MIMETYPE_TEXT_PLAIN });\r
- ClipData dragData = new ClipData(cd, item);\r
- arg1.startDrag(dragData, new View.DragShadowBuilder(arg0.getChildAt(arg2)), null, 0);\r
- return true;\r
- }\r
- \r
/**\r
* Call this, when the user presses the up button\r
*/\r
public void onNavigateUp() {\r
mDirNames.pop();\r
- populateFileList();\r
+ OCFile parentDir = null;\r
+ \r
+ if(mFile != null){\r
+ parentDir = mStorageManager.getFileById(mFile.getParentId());\r
+ mFile = parentDir;\r
+ }\r
+ \r
+ listDirectory(parentDir);\r
resetFileFragment();\r
}\r
\r
/**\r
- * Lists the directory\r
+ * Calls {@link FileListFragment#listDirectory(OCFile)} with a null parameter\r
*/\r
- public void populateFileList() {\r
- String s = "/";\r
- for (String a : mDirNames)\r
- s += a + "/";\r
- Log.e("ASD", s);\r
-\r
- mStorageManager = new FileDataStorageManager(mAccount, getActivity().getContentResolver());\r
- OCFile file = mStorageManager.getFileByPath(s);\r
- mFiles = mStorageManager.getDirectoryContent(file);\r
+ public void listDirectory(){\r
+ listDirectory(null);\r
+ }\r
+ \r
+ /**\r
+ * Lists the given directory on the view. When the input parameter is null,\r
+ * it will either refresh the last known directory, or list the root\r
+ * if there never was a directory.\r
+ * \r
+ * @param directory File to be listed\r
+ */\r
+ public void listDirectory(OCFile directory) {\r
+ \r
+ // Check input parameters for null\r
+ if(directory == null){\r
+ if(mFile != null){\r
+ directory = mFile;\r
+ } else {\r
+ directory = mStorageManager.getFileByPath("/");\r
+ }\r
+ }\r
+ \r
+ // If that's not a directory -> List its parent\r
+ if(!directory.isDirectory()){\r
+ Log.w(TAG, "You see, that is not a directory -> " + directory.toString());\r
+ directory = mStorageManager.getFileById(directory.getParentId());\r
+ }\r
+ \r
+ mFiles = mStorageManager.getDirectoryContent(directory);\r
if (mFiles == null || mFiles.size() == 0) {\r
Toast.makeText(getActivity(), "There are no files here", Toast.LENGTH_LONG).show();\r
}\r
- setListAdapter(new FileListListAdapter(file, mStorageManager, getActivity()));\r
+ setListAdapter(new FileListListAdapter(directory, mStorageManager, getActivity()));\r
}\r
\r
@Override\r
super.onSaveInstanceState(outState);\r
outState.putParcelable("ACCOUNT", mAccount);\r
}\r
- \r
- // TODO: Delete this testing stuff.\r
- /*\r
- * private void addContact(Account account, String name, String username) {\r
- * Log.i("ASD", "Adding contact: " + name);\r
- * ArrayList<ContentProviderOperation> operationList = new\r
- * ArrayList<ContentProviderOperation>();\r
- * \r
- * //Create our RawContact ContentProviderOperation.Builder builder =\r
- * ContentProviderOperation.newInsert(RawContacts.CONTENT_URI);\r
- * builder.withValue(RawContacts.ACCOUNT_NAME, account.name);\r
- * builder.withValue(RawContacts.ACCOUNT_TYPE, account.type);\r
- * builder.withValue(RawContacts.SYNC1, username);\r
- * operationList.add(builder.build());\r
- * \r
- * //Create a Data record of common type 'StructuredName' for our RawContact\r
- * builder =\r
- * ContentProviderOperation.newInsert(ContactsContract.Data.CONTENT_URI);\r
- * builder\r
- * .withValueBackReference(ContactsContract.CommonDataKinds.StructuredName\r
- * .RAW_CONTACT_ID, 0); builder.withValue(ContactsContract.Data.MIMETYPE,\r
- * ContactsContract.CommonDataKinds.StructuredName.CONTENT_ITEM_TYPE);\r
- * builder\r
- * .withValue(ContactsContract.CommonDataKinds.StructuredName.DISPLAY_NAME,\r
- * name); operationList.add(builder.build());\r
- * \r
- * //Create a Data record of custom type\r
- * "vnd.android.cursor.item/vnd.fm.last.android.profile" to display a link\r
- * to the Last.fm profile builder =\r
- * ContentProviderOperation.newInsert(ContactsContract.Data.CONTENT_URI);\r
- * builder.withValueBackReference(ContactsContract.Data.RAW_CONTACT_ID, 0);\r
- * builder.withValue(ContactsContract.Data.MIMETYPE,\r
- * "vnd.android.cursor.item/vnd.owncloud.contact.profile");\r
- * builder.withValue(ContactsContract.Data.DATA1, username);\r
- * builder.withValue(ContactsContract.Data.DATA2, "Last.fm Profile");\r
- * builder.withValue(ContactsContract.Data.DATA3, "View profile");\r
- * operationList.add(builder.build());\r
- * \r
- * try {\r
- * getActivity().getContentResolver().applyBatch(ContactsContract.AUTHORITY,\r
- * operationList); } catch (Exception e) { Log.e("ASD",\r
- * "Something went wrong during creation! " + e); e.printStackTrace(); } }\r
- */\r
\r
}\r