merge fix
authorBartek Przybylski <bart.p.pl@gmail.com>
Sun, 13 May 2012 14:19:22 +0000 (16:19 +0200)
committerBartek Przybylski <bart.p.pl@gmail.com>
Sun, 13 May 2012 14:19:22 +0000 (16:19 +0200)
1  2 
src/eu/alefzero/owncloud/ui/activity/FileDisplayActivity.java

@@@ -23,17 -23,15 +23,17 @@@ import android.accounts.AccountManager
  import android.app.AlertDialog;\r
  import android.app.AlertDialog.Builder;\r
  import android.app.Dialog;\r
+ import android.content.BroadcastReceiver;\r
+ import android.content.ContentResolver;\r
  import android.content.Context;\r
  import android.content.DialogInterface;\r
  import android.content.DialogInterface.OnClickListener;\r
- import android.content.BroadcastReceiver;\r
- import android.content.ContentResolver;\r
  import android.content.Intent;\r
  import android.content.IntentFilter;\r
 +import android.database.Cursor;\r
  import android.net.Uri;\r
  import android.os.Bundle;\r
 +import android.provider.MediaStore;\r
  import android.util.Log;\r
  import android.view.View;\r
  import android.view.ViewGroup;\r
@@@ -71,13 -69,10 +71,13 @@@ public class FileDisplayActivity extend
        private ArrayAdapter<String> mDirectories;\r
        private DataStorageManager mStorageManager;\r
  \r
-       private BR  b;\r
+       private SyncBroadcastReceiver  syncBroadcastRevceiver;\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
                mDirectories.insert(path, 0);\r
@@@ -98,8 -93,8 +98,8 @@@
        builder.setTitle(R.string.main_tit_accsetup);\r
        builder.setMessage(R.string.main_wrn_accsetup);\r
        builder.setCancelable(false);\r
 -      builder.setPositiveButton(R.string.common_ok, this);\r
 -      builder.setNegativeButton(R.string.common_cancel, this);\r
 +      builder.setPositiveButton(android.R.string.ok, this);\r
 +      builder.setNegativeButton(android.R.string.cancel, this);\r
        dialog = builder.create();\r
        break;\r
      case DIALOG_CREATE_DIR:\r
        final Account a = AccountUtils.getCurrentOwnCloudAccount(this);\r
        builder.setView(dirName);\r
        builder.setTitle(R.string.uploader_info_dirname);\r
 -      dirName.setTextColor(R.color.setup_text_typed);\r
 +      int typed_color = getResources().getColor(R.color.setup_text_typed);\r
 +      dirName.setTextColor(typed_color);\r
  \r
 -      builder.setPositiveButton(R.string.common_ok, new OnClickListener() {\r
 +      builder.setPositiveButton(android.R.string.ok, new OnClickListener() {\r
          public void onClick(DialogInterface dialog, int which) {\r
            String s = dirName.getText().toString();\r
 -          if (s.trim().isEmpty()) {\r
 +          if (s.trim().length() == 0) {\r
              dialog.cancel();\r
              return;\r
            }\r
                dialog.cancel();\r
              }\r
            });\r
 +      dialog = builder.create();\r
 +      break;\r
      }\r
      default: \r
        dialog = null;\r
        @Override\r
        public void onCreate(Bundle savedInstanceState) {\r
                super.onCreate(savedInstanceState);\r
 +\r
                if(!accountsAreSetup()){\r
        showDialog(DIALOG_SETUP_ACCOUNT);\r
        return;\r
      }\r
 -\r
 -              requestWindowFeature(Window.FEATURE_INDETERMINATE_PROGRESS);  \r
 -\r
 -              mDirectories = new CustomArrayAdapter<String>(this,\r
 -                              R.layout.sherlock_spinner_dropdown_item);\r
 -              mDirectories.add("/");\r
 -              setContentView(R.layout.files);\r
 -              mStorageManager = new FileDataStorageManager(AccountUtils.getCurrentOwnCloudAccount(this), getContentResolver());\r
 -              ActionBar action_bar = getSupportActionBar();\r
 -              action_bar.setNavigationMode(ActionBar.NAVIGATION_MODE_LIST);\r
 -              action_bar.setDisplayShowTitleEnabled(false);\r
 -              action_bar.setListNavigationCallbacks(mDirectories, this);\r
 -              action_bar.setDisplayHomeAsUpEnabled(true);\r
 +              \r
 +              requestWindowFeature(Window.FEATURE_INDETERMINATE_PROGRESS);\r
 +    setProgressBarIndeterminateVisibility(false);\r
        }\r
  \r
        @Override\r
        public boolean onOptionsItemSelected(MenuItem item) {\r
 +        boolean retval = true;\r
                switch (item.getItemId()) {\r
                case R.id.settingsItem: {\r
                        Intent i = new Intent(this, Preferences.class);\r
                      bundle);\r
        break;\r
                }\r
 +              case R.id.action_upload: {\r
 +                Intent action = new Intent(Intent.ACTION_GET_CONTENT);  \r
 +                action = action.setType("*/*").addCategory(Intent.CATEGORY_OPENABLE);  \r
 +                startActivityForResult(Intent.createChooser(action, "Upload file from..."), ACTION_SELECT_FILE);\r
 +                break;\r
 +              }\r
 +                \r
                case android.R.id.home: {\r
 -                      onBackPressed();\r
 +                Intent i = new Intent(this, AccountSelectActivity.class);\r
 +                startActivity(i);\r
 +                finish();\r
                        break;\r
                }\r
 -                      \r
 +                      default:\r
 +                        retval = false;\r
                }\r
 -              return true;\r
 +              return retval;\r
        }\r
        \r
        @Override\r
              showDialog(DIALOG_SETUP_ACCOUNT);\r
            }\r
          }\r
 -       \r
 -       @Override\r
 -        protected void onStart() {\r
 -          super.onStart();\r
 -          // Check, if there are ownCloud accounts\r
 -          if(!accountsAreSetup()){\r
 -            showDialog(DIALOG_SETUP_ACCOUNT);\r
 -          }\r
 -       }\r
 +\r
            \r
         @Override\r
        protected void onResume() {\r
        showDialog(DIALOG_SETUP_ACCOUNT);\r
        return;\r
      }\r
 -         IntentFilter syncMessageIntentFilter = new IntentFilter(FileSyncService.SYNC_MESSAGE);\r
 -         syncBroadcastRevceiver = new  SyncBroadcastReceiver();\r
 -         registerReceiver(syncBroadcastRevceiver, syncMessageIntentFilter);\r
 -         setProgressBarIndeterminateVisibility(false);\r
 +        \r
 +         IntentFilter f = new IntentFilter(FileSyncService.SYNC_MESSAGE);\r
 +         b = new  BR();\r
 +         registerReceiver(b, f);\r
 +         if (getSupportFragmentManager().findFragmentById(R.id.fileList) == null)\r
 +           setContentView(R.layout.files);\r
 +         \r
 +         mDirectories = new CustomArrayAdapter<String>(this,\r
 +              R.layout.sherlock_spinner_dropdown_item);\r
 +          mDirectories.add("/");\r
 +          \r
 +          mStorageManager = new FileDataStorageManager(AccountUtils.getCurrentOwnCloudAccount(this), getContentResolver());\r
 +          ActionBar action_bar = getSupportActionBar();\r
 +          action_bar.setNavigationMode(ActionBar.NAVIGATION_MODE_LIST);\r
 +          action_bar.setDisplayShowTitleEnabled(false);\r
 +          action_bar.setListNavigationCallbacks(mDirectories, this);\r
 +          action_bar.setDisplayHomeAsUpEnabled(true);\r
        }\r
            \r
 +       public void onActivityResult(int requestCode, int resultCode, Intent data) {\r
 +     if (resultCode == RESULT_OK) {\r
 +         if (requestCode == ACTION_SELECT_FILE) {\r
 +             Uri selectedImageUri = data.getData();\r
 +\r
 +             String filemanagerstring = selectedImageUri.getPath();\r
 +\r
 +             String selectedImagePath = getPath(selectedImageUri);\r
 +\r
 +             //DEBUG PURPOSE - you can delete this if you want\r
 +             if(selectedImagePath!=null)\r
 +                 System.out.println(selectedImagePath);\r
 +             else System.out.println("selectedImagePath is null");\r
 +             if(filemanagerstring!=null)\r
 +                 System.out.println(filemanagerstring);\r
 +             else System.out.println("filemanagerstring is null");\r
 +\r
 +             //NOW WE HAVE OUR WANTED STRING\r
 +             if(selectedImagePath!=null)\r
 +                 System.out.println("selectedImagePath is the right one for you!");\r
 +             else\r
 +                 System.out.println("filemanagerstring is the right one for you!");\r
 +         }\r
 +     }\r
 +       }\r
 +       \r
 +     public String getPath(Uri uri) {\r
 +       String[] projection = { MediaStore.Images.Media.DATA };\r
 +       Cursor cursor = managedQuery(uri, projection, null, null, null);\r
 +       if(cursor!=null)\r
 +       {\r
 +           //HERE YOU WILL GET A NULLPOINTER IF CURSOR IS NULL\r
 +           //THIS CAN BE, IF YOU USED OI FILE MANAGER FOR PICKING THE MEDIA\r
 +           int column_index = cursor\r
 +           .getColumnIndexOrThrow(MediaStore.Images.Media.DATA);\r
 +           cursor.moveToFirst();\r
 +           return cursor.getString(column_index);\r
 +       }\r
 +       else return null;\r
 +   }\r
 +     \r
         @Override\r
        protected void onPause() {\r
          super.onPause();\r
 -        if(syncBroadcastRevceiver != null){\r
 -                unregisterReceiver(syncBroadcastRevceiver);  \r
 +        if (b != null) {\r
 +          unregisterReceiver(b);\r
 +          b = null;\r
          }\r
 +        \r
        }\r
         \r
        @Override\r
  \r
                \r
        }\r
 -\r
 +      \r
         public void onClick(DialogInterface dialog, int which) {\r
            // In any case - we won't need it anymore\r
            dialog.dismiss();\r
      return accounts.length > 0;\r
    }\r
    \r
-   private class BR extends BroadcastReceiver {\r
+   private class SyncBroadcastReceiver extends BroadcastReceiver {\r
+         /**\r
+          * {@link BroadcastReceiver} to enable syncing feedback in UI\r
+          */\r
      @Override\r
      public void onReceive(Context context, Intent intent) {\r
-       boolean in_progress = intent.getBooleanExtra(FileSyncService.IN_PROGRESS, false);\r
+       boolean inProgress = intent.getBooleanExtra(FileSyncService.IN_PROGRESS, false);\r
        String account_name = intent.getStringExtra(FileSyncService.ACCOUNT_NAME);\r
-       Log.d("FileDisplay", "sync of account " + account_name + " is in_progress: " + in_progress);\r
-       setProgressBarIndeterminateVisibility(in_progress);\r
-       if (!in_progress) {\r
-         FileListFragment f = (FileListFragment) getSupportFragmentManager().findFragmentById(R.id.fileList);\r
-         if (f != null)\r
-           f.populateFileList();\r
+       Log.d("FileDisplay", "sync of account " + account_name + " is in_progress: " + inProgress);\r
+       setProgressBarIndeterminateVisibility(inProgress);\r
+       if (!inProgress) {\r
+         FileListFragment fileListFramgent = (FileListFragment) getSupportFragmentManager().findFragmentById(R.id.fileList);\r
+         if (fileListFramgent != null)\r
+           fileListFramgent.populateFileList();\r
        }\r
      }\r
      \r