mirror of
				https://github.com/commons-app/apps-android-commons.git
				synced 2025-10-26 20:33:53 +01:00 
			
		
		
		
	fix/handle-shared-files-and-error-handling (#6141)
This commit is contained in:
		
							parent
							
								
									ef032b0f93
								
							
						
					
					
						commit
						23e1f01783
					
				
					 1 changed files with 57 additions and 9 deletions
				
			
		|  | @ -684,17 +684,64 @@ class UploadActivity : BaseActivity(), UploadContract.View, UploadBaseFragment.C | ||||||
| 
 | 
 | ||||||
|     private fun receiveInternalSharedItems() { |     private fun receiveInternalSharedItems() { | ||||||
|         val intent = intent |         val intent = intent | ||||||
| 
 |         Timber.d("Intent has EXTRA_FILES: ${EXTRA_FILES}") | ||||||
|         Timber.d("Received intent %s with action %s", intent.toString(), intent.action) |         uploadableFiles = try { | ||||||
| 
 |             // Check if intent has the extra before trying to read it | ||||||
|         uploadableFiles = mutableListOf<UploadableFile>().apply { |             if (!intent.hasExtra(EXTRA_FILES)) { | ||||||
|             addAll(intent.getParcelableArrayListExtra(EXTRA_FILES) ?: emptyList()) |                 Timber.w("No EXTRA_FILES found in intent") | ||||||
|  |                 mutableListOf() | ||||||
|  |             } else { | ||||||
|  |                 // Try to get the files as Parcelable array | ||||||
|  |                 val files = if (VERSION.SDK_INT >= VERSION_CODES.TIRAMISU) { | ||||||
|  |                     intent.getParcelableArrayListExtra(EXTRA_FILES, UploadableFile::class.java) | ||||||
|  |                 } else { | ||||||
|  |                     @Suppress("DEPRECATION") | ||||||
|  |                     intent.getParcelableArrayListExtra<UploadableFile>(EXTRA_FILES) | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 // Convert to mutable list or return empty list if null | ||||||
|  |                 files?.toMutableList() ?: run { | ||||||
|  |                     Timber.w("Files array was null") | ||||||
|  |                     mutableListOf() | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } catch (e: Exception) { | ||||||
|  |             Timber.e(e, "Error reading files from intent") | ||||||
|  |             mutableListOf() | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // Log the result for debugging | ||||||
|  |         isMultipleFilesSelected = uploadableFiles.size > 1 | ||||||
|  |         Timber.i("Received files count: ${uploadableFiles.size}") | ||||||
|  |         uploadableFiles.forEachIndexed { index, file -> | ||||||
|  |             Timber.d("File $index path: ${file.getFilePath()}") | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // Handle other extras with null safety | ||||||
|  |         place = try { | ||||||
|  |             if (VERSION.SDK_INT >= VERSION_CODES.TIRAMISU) { | ||||||
|  |                 intent.getParcelableExtra(PLACE_OBJECT, Place::class.java) | ||||||
|  |             } else { | ||||||
|  |                 @Suppress("DEPRECATION") | ||||||
|  |                 intent.getParcelableExtra(PLACE_OBJECT) | ||||||
|  |             } | ||||||
|  |         } catch (e: Exception) { | ||||||
|  |             Timber.e(e, "Error reading place") | ||||||
|  |             null | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         prevLocation = try { | ||||||
|  |             if (VERSION.SDK_INT >= VERSION_CODES.TIRAMISU) { | ||||||
|  |                 intent.getParcelableExtra(LOCATION_BEFORE_IMAGE_CAPTURE, LatLng::class.java) | ||||||
|  |             } else { | ||||||
|  |                 @Suppress("DEPRECATION") | ||||||
|  |                 intent.getParcelableExtra(LOCATION_BEFORE_IMAGE_CAPTURE) | ||||||
|  |             } | ||||||
|  |         } catch (e: Exception) { | ||||||
|  |             Timber.e(e, "Error reading location") | ||||||
|  |             null | ||||||
|         } |         } | ||||||
|         isMultipleFilesSelected = uploadableFiles!!.size > 1 |  | ||||||
|         Timber.i("Received multiple upload %s", uploadableFiles!!.size) |  | ||||||
| 
 | 
 | ||||||
|         place = intent.getParcelableExtra<Place>(PLACE_OBJECT) |  | ||||||
|         prevLocation = intent.getParcelableExtra(LOCATION_BEFORE_IMAGE_CAPTURE) |  | ||||||
|         isInAppCameraUpload = intent.getBooleanExtra(IN_APP_CAMERA_UPLOAD, false) |         isInAppCameraUpload = intent.getBooleanExtra(IN_APP_CAMERA_UPLOAD, false) | ||||||
|         resetDirectPrefs() |         resetDirectPrefs() | ||||||
|     } |     } | ||||||
|  | @ -803,6 +850,7 @@ class UploadActivity : BaseActivity(), UploadContract.View, UploadBaseFragment.C | ||||||
|     /** |     /** | ||||||
|      * Overrides the back button to make sure the user is prepared to lose their progress |      * Overrides the back button to make sure the user is prepared to lose their progress | ||||||
|      */ |      */ | ||||||
|  |     @SuppressLint("MissingSuperCall") | ||||||
|     override fun onBackPressed() { |     override fun onBackPressed() { | ||||||
|         showAlertDialog( |         showAlertDialog( | ||||||
|             this, |             this, | ||||||
|  | @ -920,7 +968,7 @@ class UploadActivity : BaseActivity(), UploadContract.View, UploadBaseFragment.C | ||||||
| 
 | 
 | ||||||
|     companion object { |     companion object { | ||||||
|         private var uploadIsOfAPlace = false |         private var uploadIsOfAPlace = false | ||||||
|         const val EXTRA_FILES: String = "commons_image_exta" |         const val EXTRA_FILES: String = "commons_image_extra" | ||||||
|         const val LOCATION_BEFORE_IMAGE_CAPTURE: String = "user_location_before_image_capture" |         const val LOCATION_BEFORE_IMAGE_CAPTURE: String = "user_location_before_image_capture" | ||||||
|         const val IN_APP_CAMERA_UPLOAD: String = "in_app_camera_upload" |         const val IN_APP_CAMERA_UPLOAD: String = "in_app_camera_upload" | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Sujal
						Sujal