calculate automatic timeout labels dynamically
This commit is contained in:
		
							parent
							
								
									de2f5e7a83
								
							
						
					
					
						commit
						89992f541c
					
				| @ -35,6 +35,7 @@ import eu.siacs.conversations.entities.Account; | |||||||
| import eu.siacs.conversations.services.ExportLogsService; | import eu.siacs.conversations.services.ExportLogsService; | ||||||
| import eu.siacs.conversations.services.MemorizingTrustManager; | import eu.siacs.conversations.services.MemorizingTrustManager; | ||||||
| import eu.siacs.conversations.ui.util.Color; | import eu.siacs.conversations.ui.util.Color; | ||||||
|  | import eu.siacs.conversations.utils.TimeframeUtils; | ||||||
| import eu.siacs.conversations.xmpp.XmppConnection; | import eu.siacs.conversations.xmpp.XmppConnection; | ||||||
| import eu.siacs.conversations.xmpp.jid.InvalidJidException; | import eu.siacs.conversations.xmpp.jid.InvalidJidException; | ||||||
| import eu.siacs.conversations.xmpp.jid.Jid; | import eu.siacs.conversations.xmpp.jid.Jid; | ||||||
| @ -109,6 +110,25 @@ public class SettingsActivity extends XmppActivity implements | |||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
|  | 		ListPreference automaticMessageDeletionList = (ListPreference) mSettingsFragment.findPreference(AUTOMATIC_MESSAGE_DELETION); | ||||||
|  | 		if (automaticMessageDeletionList != null) { | ||||||
|  | 			final int[] choices = getResources().getIntArray(R.array.automatic_message_deletion_values); | ||||||
|  | 			CharSequence[] entries = new CharSequence[choices.length]; | ||||||
|  | 			CharSequence[] entryValues = new CharSequence[choices.length]; | ||||||
|  | 			for (int i = 0; i < choices.length; ++i) { | ||||||
|  | 				Log.d(Config.LOGTAG,"resolving choice "+choices[i]); | ||||||
|  | 				entryValues[i] = String.valueOf(choices[i]); | ||||||
|  | 				if (choices[i] == 0) { | ||||||
|  | 					entries[i] = getString(R.string.never); | ||||||
|  | 				} else { | ||||||
|  | 					entries[i] = TimeframeUtils.resolve(this, 1000L * choices[i]); | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 			automaticMessageDeletionList.setEntries(entries); | ||||||
|  | 			automaticMessageDeletionList.setEntryValues(entryValues); | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| 		boolean removeLocation = new Intent("eu.siacs.conversations.location.request").resolveActivity(getPackageManager()) == null; | 		boolean removeLocation = new Intent("eu.siacs.conversations.location.request").resolveActivity(getPackageManager()) == null; | ||||||
| 		boolean removeVoice = new Intent(MediaStore.Audio.Media.RECORD_SOUND_ACTION).resolveActivity(getPackageManager()) == null; | 		boolean removeVoice = new Intent(MediaStore.Audio.Media.RECORD_SOUND_ACTION).resolveActivity(getPackageManager()) == null; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -0,0 +1,75 @@ | |||||||
|  | /* | ||||||
|  |  * Copyright (c) 2018, Daniel Gultsch All rights reserved. | ||||||
|  |  * | ||||||
|  |  * Redistribution and use in source and binary forms, with or without modification, | ||||||
|  |  * are permitted provided that the following conditions are met: | ||||||
|  |  * | ||||||
|  |  * 1. Redistributions of source code must retain the above copyright notice, this | ||||||
|  |  * list of conditions and the following disclaimer. | ||||||
|  |  * | ||||||
|  |  * 2. Redistributions in binary form must reproduce the above copyright notice, | ||||||
|  |  * this list of conditions and the following disclaimer in the documentation and/or | ||||||
|  |  * other materials provided with the distribution. | ||||||
|  |  * | ||||||
|  |  * 3. Neither the name of the copyright holder nor the names of its contributors | ||||||
|  |  * may be used to endorse or promote products derived from this software without | ||||||
|  |  * specific prior written permission. | ||||||
|  |  * | ||||||
|  |  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND | ||||||
|  |  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||||
|  |  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||||
|  |  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR | ||||||
|  |  * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||||
|  |  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||||
|  |  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON | ||||||
|  |  * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||||
|  |  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||||
|  |  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | package eu.siacs.conversations.utils; | ||||||
|  | 
 | ||||||
|  | import android.content.Context; | ||||||
|  | import android.support.annotation.PluralsRes; | ||||||
|  | 
 | ||||||
|  | import eu.siacs.conversations.R; | ||||||
|  | 
 | ||||||
|  | public class TimeframeUtils { | ||||||
|  | 
 | ||||||
|  | 	private static final Timeframe[] TIMEFRAMES; | ||||||
|  | 
 | ||||||
|  | 	static { | ||||||
|  | 		TIMEFRAMES = new Timeframe[]{ | ||||||
|  | 				new Timeframe(1000L, R.plurals.seconds), | ||||||
|  | 				new Timeframe(60L * 1000, R.plurals.minutes), | ||||||
|  | 				new Timeframe(60L * 60 * 1000, R.plurals.hours), | ||||||
|  | 				new Timeframe(24L * 60 * 60 * 1000, R.plurals.days), | ||||||
|  | 				new Timeframe(7L * 24 * 60 * 60 * 1000, R.plurals.weeks), | ||||||
|  | 				new Timeframe(30L * 24 * 60 * 60 * 1000, R.plurals.months), | ||||||
|  | 		}; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	public static String resolve(Context context, long timeframe) { | ||||||
|  | 		for(int i = TIMEFRAMES.length -1 ; i >= 0; --i) { | ||||||
|  | 			long duration = TIMEFRAMES[i].duration; | ||||||
|  | 			long threshold = i > 0 ? (TIMEFRAMES[i-1].duration / 2) : 0; | ||||||
|  | 			if (timeframe >= duration - threshold) { | ||||||
|  | 				int count = (int) (timeframe / duration + ((timeframe%duration)>(duration/2)?1:0)); | ||||||
|  | 				return context.getResources().getQuantityString(TIMEFRAMES[i].name,count,count); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 		return context.getResources().getQuantityString(TIMEFRAMES[0].name,0,0); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 	private static class Timeframe { | ||||||
|  | 		public final long duration; | ||||||
|  | 		public final int name; | ||||||
|  | 
 | ||||||
|  | 		private Timeframe(long duration, @PluralsRes int name) { | ||||||
|  | 			this.duration = duration; | ||||||
|  | 			this.name = name; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -98,18 +98,11 @@ | |||||||
| 		<item>610</item> | 		<item>610</item> | ||||||
| 		<item>2584</item> | 		<item>2584</item> | ||||||
| 	</string-array> | 	</string-array> | ||||||
| 	<string-array name="automatic_message_deletion_values"> | 	<integer-array name="automatic_message_deletion_values"> | ||||||
| 		<item>0</item> | 		<item>0</item> | ||||||
| 		<item>86400</item> | 		<item>86400</item> | ||||||
| 		<item>604800</item> | 		<item>604800</item> | ||||||
| 		<item>2592000</item> | 		<item>2592000</item> | ||||||
| 		<item>15811200</item> | 		<item>15811200</item> | ||||||
| 	</string-array> | 	</integer-array> | ||||||
| 	<string-array name="automatic_message_deletion"> |  | ||||||
| 		<item>@string/never</item> |  | ||||||
| 		<item>@string/timeout_24_hours</item> |  | ||||||
| 		<item>@string/timeout_7_days</item> |  | ||||||
| 		<item>@string/timeout_30_days</item> |  | ||||||
| 		<item>@string/timeout_6_months</item> |  | ||||||
| 	</string-array> |  | ||||||
| </resources> | </resources> | ||||||
|  | |||||||
| @ -658,10 +658,30 @@ | |||||||
| 	<string name="hide_inactive_devices">Hide inactive</string> | 	<string name="hide_inactive_devices">Hide inactive</string> | ||||||
| 	<string name="distrust_omemo_key">Distrust device</string> | 	<string name="distrust_omemo_key">Distrust device</string> | ||||||
| 	<string name="distrust_omemo_key_text">Are you sure you want to remove the verification for this device?\nThis device and messages coming from that device will be marked as untrusted.</string> | 	<string name="distrust_omemo_key_text">Are you sure you want to remove the verification for this device?\nThis device and messages coming from that device will be marked as untrusted.</string> | ||||||
| 	<string name="timeout_24_hours">24 hours</string> | 	<plurals name="seconds"> | ||||||
| 	<string name="timeout_7_days">7 days</string> | 		<item quantity="one">%d second</item> | ||||||
| 	<string name="timeout_30_days">30 days</string> | 		<item quantity="other">%d seconds</item> | ||||||
| 	<string name="timeout_6_months">6 months</string> | 	</plurals> | ||||||
|  | 	<plurals name="minutes"> | ||||||
|  | 		<item quantity="one">%d minute</item> | ||||||
|  | 		<item quantity="other">%d minutes</item> | ||||||
|  | 	</plurals> | ||||||
|  | 	<plurals name="hours"> | ||||||
|  | 		<item quantity="one">%d hour</item> | ||||||
|  | 		<item quantity="other">%d hours</item> | ||||||
|  | 	</plurals> | ||||||
|  | 	<plurals name="days"> | ||||||
|  | 		<item quantity="one">%d day</item> | ||||||
|  | 		<item quantity="other">%d days</item> | ||||||
|  | 	</plurals> | ||||||
|  | 	<plurals name="weeks"> | ||||||
|  | 		<item quantity="one">%d week</item> | ||||||
|  | 		<item quantity="other">%d weeks</item> | ||||||
|  | 	</plurals> | ||||||
|  | 	<plurals name="months"> | ||||||
|  | 		<item quantity="one">%d month</item> | ||||||
|  | 		<item quantity="other">%d months</item> | ||||||
|  | 	</plurals> | ||||||
| 	<string name="pref_automatically_delete_messages">Automatic message deletion</string> | 	<string name="pref_automatically_delete_messages">Automatic message deletion</string> | ||||||
| 	<string name="pref_automatically_delete_messages_description">Automatically delete messages from this device that are older than the configured time frame.</string> | 	<string name="pref_automatically_delete_messages_description">Automatically delete messages from this device that are older than the configured time frame.</string> | ||||||
| 	<string name="encrypting_message">Encrypting message</string> | 	<string name="encrypting_message">Encrypting message</string> | ||||||
|  | |||||||
| @ -192,9 +192,7 @@ | |||||||
|                     android:key="automatic_message_deletion" |                     android:key="automatic_message_deletion" | ||||||
|                     android:title="@string/pref_automatically_delete_messages" |                     android:title="@string/pref_automatically_delete_messages" | ||||||
|                     android:summary="@string/pref_automatically_delete_messages_description" |                     android:summary="@string/pref_automatically_delete_messages_description" | ||||||
|                     android:defaultValue="@integer/automatic_message_deletion" |                     android:defaultValue="@integer/automatic_message_deletion"/> | ||||||
|                     android:entries="@array/automatic_message_deletion" |  | ||||||
|                     android:entryValues="@array/automatic_message_deletion_values" /> |  | ||||||
|                 <CheckBoxPreference |                 <CheckBoxPreference | ||||||
|                     android:defaultValue="@bool/dont_trust_system_cas" |                     android:defaultValue="@bool/dont_trust_system_cas" | ||||||
|                     android:key="dont_trust_system_cas" |                     android:key="dont_trust_system_cas" | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Daniel Gultsch
						Daniel Gultsch