mirror of
				https://github.com/commons-app/apps-android-commons.git
				synced 2025-10-26 20:33:53 +01:00 
			
		
		
		
	feedback: add the feedback as a new section at end of the page
Addresses feedback on #5542. For auto-archiving of section to work properly on our feedback page, the new sections need to be created at the end of the page rather than at the top. So, adjust the feedback addition logic to make it such that the feedback is appended to the bottom of the page.
This commit is contained in:
		
							parent
							
								
									8fdfb8e6dc
								
							
						
					
					
						commit
						88a0f0c58d
					
				
					 5 changed files with 98 additions and 50 deletions
				
			
		|  | @ -78,6 +78,28 @@ class PageEditClient( | |||
|     } | ||||
| 
 | ||||
| 
 | ||||
|     /** | ||||
|      * Appends a new section to the wiki page | ||||
|      * @param pageTitle   Title of the page to edit | ||||
|      * @param sectionTitle Title of the new section that needs to be created | ||||
|      * @param sectionText  The page content that is to be added to the section | ||||
|      * @param summary     Edit summary | ||||
|      * @return whether the edit was successful | ||||
|      */ | ||||
|     fun createNewSection(pageTitle: String, sectionTitle: String, sectionText: String, summary: String): Observable<Boolean> { | ||||
|         return try { | ||||
|             pageEditInterface.postNewSection(pageTitle, summary, sectionTitle, sectionText, csrfTokenClient.getTokenBlocking()) | ||||
|                 .map { editResponse -> editResponse.edit()!!.editSucceeded() } | ||||
|         } catch (throwable: Throwable) { | ||||
|             if (throwable is InvalidLoginTokenException) { | ||||
|                 throw throwable | ||||
|             } else { | ||||
|                 Observable.just(false) | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|     /** | ||||
|      * Set new labels to Wikibase server of commons | ||||
|      * @param summary   Edit summary | ||||
|  |  | |||
|  | @ -74,6 +74,16 @@ interface PageEditInterface { | |||
|         @Field("token") token: String | ||||
|     ): Observable<Edit> | ||||
| 
 | ||||
|     @FormUrlEncoded | ||||
|     @Headers("Cache-Control: no-cache") | ||||
|     @POST(MW_API_PREFIX + "action=edit§ion=new") | ||||
|     fun postNewSection( | ||||
|         @Field("title") title: String, | ||||
|         @Field("summary") summary: String, | ||||
|         @Field("sectiontitle") sectionTitle: String, | ||||
|         @Field("text") sectionText: String, | ||||
|         @Field("token") token: String | ||||
|     ): Observable<Edit> | ||||
| 
 | ||||
|     @FormUrlEncoded | ||||
|     @Headers("Cache-Control: no-cache") | ||||
|  |  | |||
|  | @ -12,7 +12,8 @@ import java.util.Locale; | |||
|  * from feedback information | ||||
|  */ | ||||
| public class FeedbackContentCreator { | ||||
|     private StringBuilder stringBuilder; | ||||
|     private StringBuilder sectionTextBuilder; | ||||
|     private StringBuilder sectionTitleBuilder; | ||||
|     private Feedback feedback; | ||||
|     private Context context; | ||||
| 
 | ||||
|  | @ -28,71 +29,80 @@ public class FeedbackContentCreator { | |||
|     public void init() { | ||||
|         // Localization is not needed here, because this ends up on a page where developers read the feedback, so English is the most convenient. | ||||
| 
 | ||||
|         stringBuilder = new StringBuilder(); | ||||
|         stringBuilder.append("== "); | ||||
|         stringBuilder.append("Feedback from  "); | ||||
|         stringBuilder.append(AccountUtil.getUserName(context)); | ||||
|         stringBuilder.append(" for version "); | ||||
|         stringBuilder.append(feedback.getVersion()); | ||||
|         stringBuilder.append(" =="); | ||||
|         stringBuilder.append("\n"); | ||||
|         stringBuilder.append(feedback.getTitle()); | ||||
|         stringBuilder.append("\n"); | ||||
|         stringBuilder.append("\n"); | ||||
|         /* | ||||
|          * Construct the feedback section title | ||||
|          */ | ||||
|         sectionTitleBuilder = new StringBuilder(); | ||||
|         sectionTitleBuilder.append("Feedback from  "); | ||||
|         sectionTitleBuilder.append(AccountUtil.getUserName(context)); | ||||
|         sectionTitleBuilder.append(" for version "); | ||||
|         sectionTitleBuilder.append(feedback.getVersion()); | ||||
| 
 | ||||
|         /* | ||||
|          * Construct the feedback section text | ||||
|          */ | ||||
|         sectionTextBuilder = new StringBuilder(); | ||||
|         sectionTextBuilder.append("\n"); | ||||
|         sectionTextBuilder.append(feedback.getTitle()); | ||||
|         sectionTextBuilder.append("\n"); | ||||
|         sectionTextBuilder.append("\n"); | ||||
|         if (feedback.getApiLevel() != null) { | ||||
|             stringBuilder.append("* "); | ||||
|             stringBuilder.append(LangCodeUtils.getLocalizedResources(context, | ||||
|             sectionTextBuilder.append("* "); | ||||
|             sectionTextBuilder.append(LangCodeUtils.getLocalizedResources(context, | ||||
|                 Locale.ENGLISH).getString(R.string.api_level)); | ||||
|             stringBuilder.append(": "); | ||||
|             stringBuilder.append(feedback.getApiLevel()); | ||||
|             stringBuilder.append("\n"); | ||||
|             sectionTextBuilder.append(": "); | ||||
|             sectionTextBuilder.append(feedback.getApiLevel()); | ||||
|             sectionTextBuilder.append("\n"); | ||||
|         } | ||||
|         if (feedback.getAndroidVersion() != null) { | ||||
|             stringBuilder.append("* "); | ||||
|             stringBuilder.append(LangCodeUtils.getLocalizedResources(context, | ||||
|             sectionTextBuilder.append("* "); | ||||
|             sectionTextBuilder.append(LangCodeUtils.getLocalizedResources(context, | ||||
|                 Locale.ENGLISH).getString(R.string.android_version)); | ||||
|             stringBuilder.append(": "); | ||||
|             stringBuilder.append(feedback.getAndroidVersion()); | ||||
|             stringBuilder.append("\n"); | ||||
|             sectionTextBuilder.append(": "); | ||||
|             sectionTextBuilder.append(feedback.getAndroidVersion()); | ||||
|             sectionTextBuilder.append("\n"); | ||||
|         } | ||||
|         if (feedback.getDeviceManufacturer() != null) { | ||||
|             stringBuilder.append("* "); | ||||
|             stringBuilder.append(LangCodeUtils.getLocalizedResources(context, | ||||
|             sectionTextBuilder.append("* "); | ||||
|             sectionTextBuilder.append(LangCodeUtils.getLocalizedResources(context, | ||||
|                 Locale.ENGLISH).getString(R.string.device_manufacturer)); | ||||
|             stringBuilder.append(": "); | ||||
|             stringBuilder.append(feedback.getDeviceManufacturer()); | ||||
|             stringBuilder.append("\n"); | ||||
|             sectionTextBuilder.append(": "); | ||||
|             sectionTextBuilder.append(feedback.getDeviceManufacturer()); | ||||
|             sectionTextBuilder.append("\n"); | ||||
|         } | ||||
|         if (feedback.getDeviceModel() != null) { | ||||
|             stringBuilder.append("* "); | ||||
|             stringBuilder.append(LangCodeUtils.getLocalizedResources(context, | ||||
|             sectionTextBuilder.append("* "); | ||||
|             sectionTextBuilder.append(LangCodeUtils.getLocalizedResources(context, | ||||
|                 Locale.ENGLISH).getString(R.string.device_model)); | ||||
|             stringBuilder.append(": "); | ||||
|             stringBuilder.append(feedback.getDeviceModel()); | ||||
|             stringBuilder.append("\n"); | ||||
|             sectionTextBuilder.append(": "); | ||||
|             sectionTextBuilder.append(feedback.getDeviceModel()); | ||||
|             sectionTextBuilder.append("\n"); | ||||
|         } | ||||
|         if (feedback.getDevice() != null) { | ||||
|             stringBuilder.append("* "); | ||||
|             stringBuilder.append(LangCodeUtils.getLocalizedResources(context, | ||||
|             sectionTextBuilder.append("* "); | ||||
|             sectionTextBuilder.append(LangCodeUtils.getLocalizedResources(context, | ||||
|                 Locale.ENGLISH).getString(R.string.device_name)); | ||||
|             stringBuilder.append(": "); | ||||
|             stringBuilder.append(feedback.getDevice()); | ||||
|             stringBuilder.append("\n"); | ||||
|             sectionTextBuilder.append(": "); | ||||
|             sectionTextBuilder.append(feedback.getDevice()); | ||||
|             sectionTextBuilder.append("\n"); | ||||
|         } | ||||
|         if (feedback.getNetworkType() != null) { | ||||
|             stringBuilder.append("* "); | ||||
|             stringBuilder.append(LangCodeUtils.getLocalizedResources(context, | ||||
|             sectionTextBuilder.append("* "); | ||||
|             sectionTextBuilder.append(LangCodeUtils.getLocalizedResources(context, | ||||
|                 Locale.ENGLISH).getString(R.string.network_type)); | ||||
|             stringBuilder.append(": "); | ||||
|             stringBuilder.append(feedback.getNetworkType()); | ||||
|             stringBuilder.append("\n"); | ||||
|             sectionTextBuilder.append(": "); | ||||
|             sectionTextBuilder.append(feedback.getNetworkType()); | ||||
|             sectionTextBuilder.append("\n"); | ||||
|         } | ||||
|         stringBuilder.append("~~~~"); | ||||
|         stringBuilder.append("\n"); | ||||
|         sectionTextBuilder.append("~~~~"); | ||||
|         sectionTextBuilder.append("\n"); | ||||
|     } | ||||
| 
 | ||||
|     @Override | ||||
|     public String toString() { | ||||
|         return stringBuilder.toString(); | ||||
|     public String getSectionText() { | ||||
|         return sectionTextBuilder.toString(); | ||||
|     } | ||||
| 
 | ||||
|     public String getSectionTitle() { | ||||
|         return sectionTitleBuilder.toString(); | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -153,8 +153,13 @@ public class MoreBottomSheetFragment extends BottomSheetDialogFragment { | |||
|     void uploadFeedback(final Feedback feedback) { | ||||
|         final FeedbackContentCreator feedbackContentCreator = new FeedbackContentCreator(getContext(), feedback); | ||||
| 
 | ||||
|         Single<Boolean> single = | ||||
|             pageEditClient.prependEdit("Commons:Mobile_app/Feedback", feedbackContentCreator.toString(), "Summary") | ||||
|         final Single<Boolean> single = | ||||
|             pageEditClient.createNewSection( | ||||
|                     "Commons:Mobile_app/Feedback", | ||||
|                     feedbackContentCreator.getSectionTitle(), | ||||
|                     feedbackContentCreator.getSectionText(), | ||||
|                     "Summary" | ||||
|                 ) | ||||
|                 .flatMapSingle(result -> Single.just(result)) | ||||
|                 .firstOrError(); | ||||
| 
 | ||||
|  |  | |||
|  | @ -34,7 +34,8 @@ class FeedbackContentCreatorUnitTests { | |||
|     fun testToString() { | ||||
|         feedback = Feedback("123", "apiLevel", "title", "androidVersion", "deviceModel", "mfg", "deviceName", "wifi") | ||||
|         creator = FeedbackContentCreator(context, feedback) | ||||
|         Assert.assertNotNull(creator.toString()) | ||||
|         Assert.assertNotNull(creator.getSectionText()) | ||||
|         Assert.assertNotNull(creator.getSectionTitle()) | ||||
|     } | ||||
| 
 | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Kaartic Sivaraam
						Kaartic Sivaraam