introduced build flavor to build w/o emoji compat
This commit is contained in:
		
							parent
							
								
									4b3de32a4e
								
							
						
					
					
						commit
						9cc22ce992
					
				|  | @ -10,7 +10,7 @@ android: | ||||||
|   licenses: |   licenses: | ||||||
|     - '.+' |     - '.+' | ||||||
| script: | script: | ||||||
|     - ./gradlew assembleFreeRelease |     - ./gradlew assembleFreeSystemRelease | ||||||
| 
 | 
 | ||||||
| before_install: | before_install: | ||||||
|     - yes | sdkmanager "platforms;android-27" |     - yes | sdkmanager "platforms;android-27" | ||||||
|  |  | ||||||
|  | @ -368,7 +368,7 @@ Make sure to have ANDROID_HOME point to your Android SDK. Use the Android SDK Ma | ||||||
| 
 | 
 | ||||||
|     git clone https://github.com/siacs/Conversations.git |     git clone https://github.com/siacs/Conversations.git | ||||||
|     cd Conversations |     cd Conversations | ||||||
|     ./gradlew assembleFreeDebug |     ./gradlew assembleFreeSystemDebug | ||||||
| 
 | 
 | ||||||
| There are two build flavors available. *free* and *playstore*. Unless you know what you are doing you only need *free*. | There are two build flavors available. *free* and *playstore*. Unless you know what you are doing you only need *free*. | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
							
								
								
									
										17
									
								
								build.gradle
								
								
								
								
							
							
						
						
									
										17
									
								
								build.gradle
								
								
								
								
							|  | @ -6,7 +6,7 @@ buildscript { | ||||||
|         jcenter() |         jcenter() | ||||||
|     } |     } | ||||||
|     dependencies { |     dependencies { | ||||||
|         classpath 'com.android.tools.build:gradle:3.1.2' |         classpath 'com.android.tools.build:gradle:3.1.3' | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -23,7 +23,8 @@ repositories { | ||||||
| 
 | 
 | ||||||
| configurations { | configurations { | ||||||
|     playstoreImplementation |     playstoreImplementation | ||||||
|     freeImplementation |     compatImplementation | ||||||
|  |     freeCompatImplementation | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| ext { | ext { | ||||||
|  | @ -39,10 +40,10 @@ dependencies { | ||||||
|     implementation "com.android.support:support-v13:$supportLibVersion" |     implementation "com.android.support:support-v13:$supportLibVersion" | ||||||
|     implementation "com.android.support:appcompat-v7:$supportLibVersion" |     implementation "com.android.support:appcompat-v7:$supportLibVersion" | ||||||
|     implementation "com.android.support:cardview-v7:$supportLibVersion" |     implementation "com.android.support:cardview-v7:$supportLibVersion" | ||||||
|     implementation "com.android.support:support-emoji-appcompat:$supportLibVersion" |     compatImplementation "com.android.support:support-emoji-appcompat:$supportLibVersion" | ||||||
|     implementation "com.android.support:support-emoji:$supportLibVersion" |     implementation "com.android.support:support-emoji:$supportLibVersion" | ||||||
|     implementation "com.android.support:design:$supportLibVersion" |     implementation "com.android.support:design:$supportLibVersion" | ||||||
|     freeImplementation "com.android.support:support-emoji-bundled:$supportLibVersion" |     freeCompatImplementation "com.android.support:support-emoji-bundled:$supportLibVersion" | ||||||
|     implementation 'org.bouncycastle:bcmail-jdk15on:1.58' |     implementation 'org.bouncycastle:bcmail-jdk15on:1.58' | ||||||
|     implementation 'com.google.zxing:core:3.3.0' |     implementation 'com.google.zxing:core:3.3.0' | ||||||
|     implementation 'de.measite.minidns:minidns-hla:0.2.4' |     implementation 'de.measite.minidns:minidns-hla:0.2.4' | ||||||
|  | @ -89,7 +90,7 @@ android { | ||||||
|         targetCompatibility JavaVersion.VERSION_1_8 |         targetCompatibility JavaVersion.VERSION_1_8 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     flavorDimensions("distribution") |     flavorDimensions("distribution", "emoji") | ||||||
| 
 | 
 | ||||||
|     productFlavors { |     productFlavors { | ||||||
|         playstore { |         playstore { | ||||||
|  | @ -98,6 +99,12 @@ android { | ||||||
|         free { |         free { | ||||||
|             dimension "distribution" |             dimension "distribution" | ||||||
|         } |         } | ||||||
|  |         system { | ||||||
|  |             dimension "emoji" | ||||||
|  |         } | ||||||
|  |         compat { | ||||||
|  |             dimension "emoji" | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     buildTypes { |     buildTypes { | ||||||
|  |  | ||||||
|  | @ -0,0 +1,17 @@ | ||||||
|  | package eu.siacs.conversations.ui.widget; | ||||||
|  | 
 | ||||||
|  | import android.content.Context; | ||||||
|  | import android.support.text.emoji.widget.EmojiAppCompatEditText; | ||||||
|  | import android.util.AttributeSet; | ||||||
|  | 
 | ||||||
|  | public abstract class AbstractEditMessage extends EmojiAppCompatEditText { | ||||||
|  | 
 | ||||||
|  |     public AbstractEditMessage(Context context) { | ||||||
|  |         super(context); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public AbstractEditMessage(Context context, AttributeSet attrs) { | ||||||
|  |         super(context, attrs); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | @ -1,17 +0,0 @@ | ||||||
| package eu.siacs.conversations.ui.service; |  | ||||||
| 
 |  | ||||||
| import android.content.Context; |  | ||||||
| import android.support.text.emoji.EmojiCompat; |  | ||||||
| import android.support.text.emoji.bundled.BundledEmojiCompatConfig; |  | ||||||
| 
 |  | ||||||
| public class EmojiService extends AbstractEmojiService { |  | ||||||
| 
 |  | ||||||
| 	public EmojiService(Context context) { |  | ||||||
| 		super(context); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	@Override |  | ||||||
| 	protected EmojiCompat.Config buildConfig() { |  | ||||||
| 		return new BundledEmojiCompatConfig(context); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  | @ -0,0 +1,28 @@ | ||||||
|  | package eu.siacs.conversations.ui.service; | ||||||
|  | 
 | ||||||
|  | import android.content.Context; | ||||||
|  | import android.os.Build; | ||||||
|  | import android.support.text.emoji.EmojiCompat; | ||||||
|  | import android.support.text.emoji.FontRequestEmojiCompatConfig; | ||||||
|  | import android.support.text.emoji.bundled.BundledEmojiCompatConfig; | ||||||
|  | import android.support.v4.provider.FontRequest; | ||||||
|  | import android.util.Log; | ||||||
|  | 
 | ||||||
|  | import eu.siacs.conversations.Config; | ||||||
|  | import eu.siacs.conversations.R; | ||||||
|  | 
 | ||||||
|  | public class EmojiService { | ||||||
|  | 
 | ||||||
|  |     private final Context context; | ||||||
|  | 
 | ||||||
|  |     public EmojiService(Context context) { | ||||||
|  |         this.context = context; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void init() { | ||||||
|  |         BundledEmojiCompatConfig config = new BundledEmojiCompatConfig(context); | ||||||
|  |         config.setReplaceAll(true); | ||||||
|  |         EmojiCompat.init(config); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | @ -41,7 +41,6 @@ import android.content.Intent; | ||||||
| import android.content.pm.PackageManager; | import android.content.pm.PackageManager; | ||||||
| import android.databinding.DataBindingUtil; | import android.databinding.DataBindingUtil; | ||||||
| import android.net.Uri; | import android.net.Uri; | ||||||
| import android.os.Build; |  | ||||||
| import android.os.Bundle; | import android.os.Bundle; | ||||||
| import android.provider.Settings; | import android.provider.Settings; | ||||||
| import android.support.annotation.IdRes; | import android.support.annotation.IdRes; | ||||||
|  |  | ||||||
|  | @ -1,26 +0,0 @@ | ||||||
| package eu.siacs.conversations.ui.service; |  | ||||||
| 
 |  | ||||||
| import android.content.Context; |  | ||||||
| import android.os.Build; |  | ||||||
| import android.support.text.emoji.EmojiCompat; |  | ||||||
| 
 |  | ||||||
| public abstract class AbstractEmojiService { |  | ||||||
| 
 |  | ||||||
| 	protected final Context context; |  | ||||||
| 
 |  | ||||||
| 	public AbstractEmojiService(Context context) { |  | ||||||
| 		this.context = context; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	protected abstract EmojiCompat.Config buildConfig(); |  | ||||||
| 
 |  | ||||||
| 	public void init() { |  | ||||||
| 		final EmojiCompat.Config config = buildConfig(); |  | ||||||
| 		//On recent Androids we assume to have the latest emojis |  | ||||||
| 		//there are some annoying bugs with emoji compat that make it a safer choice not to use it when possible |  | ||||||
| 		// a) when using the ondemand emoji font (play store) flags don’t work |  | ||||||
| 		// b) the text preview has annoying glitches when the cut of text contains emojis (the emoji will be half visible) |  | ||||||
| 		config.setReplaceAll(Build.VERSION.SDK_INT < Build.VERSION_CODES.O); |  | ||||||
| 		EmojiCompat.init(config); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  | @ -2,7 +2,6 @@ package eu.siacs.conversations.ui.widget; | ||||||
| 
 | 
 | ||||||
| import android.content.SharedPreferences; | import android.content.SharedPreferences; | ||||||
| import android.preference.PreferenceManager; | import android.preference.PreferenceManager; | ||||||
| import android.support.text.emoji.widget.EmojiAppCompatEditText; |  | ||||||
| import android.support.v13.view.inputmethod.EditorInfoCompat; | import android.support.v13.view.inputmethod.EditorInfoCompat; | ||||||
| import android.support.v13.view.inputmethod.InputConnectionCompat; | import android.support.v13.view.inputmethod.InputConnectionCompat; | ||||||
| import android.support.v13.view.inputmethod.InputContentInfoCompat; | import android.support.v13.view.inputmethod.InputContentInfoCompat; | ||||||
|  | @ -23,7 +22,7 @@ import android.view.inputmethod.InputConnection; | ||||||
| import eu.siacs.conversations.Config; | import eu.siacs.conversations.Config; | ||||||
| import eu.siacs.conversations.R; | import eu.siacs.conversations.R; | ||||||
| 
 | 
 | ||||||
| public class EditMessage extends EmojiAppCompatEditText { | public class EditMessage extends AbstractEditMessage { | ||||||
| 
 | 
 | ||||||
| 	private static final InputFilter SPAN_FILTER = (source, start, end, dest, dstart, dend) -> source instanceof Spanned ? source.toString() : source; | 	private static final InputFilter SPAN_FILTER = (source, start, end, dest, dstart, dend) -> source instanceof Spanned ? source.toString() : source; | ||||||
| 	protected Handler mTypingHandler = new Handler(); | 	protected Handler mTypingHandler = new Handler(); | ||||||
|  |  | ||||||
|  | @ -1,45 +0,0 @@ | ||||||
| package eu.siacs.conversations.ui.service; |  | ||||||
| 
 |  | ||||||
| import android.content.Context; |  | ||||||
| import android.support.text.emoji.EmojiCompat; |  | ||||||
| import android.support.text.emoji.FontRequestEmojiCompatConfig; |  | ||||||
| import android.support.v4.provider.FontRequest; |  | ||||||
| import android.util.Log; |  | ||||||
| 
 |  | ||||||
| import eu.siacs.conversations.Config; |  | ||||||
| import eu.siacs.conversations.R; |  | ||||||
| 
 |  | ||||||
| public class EmojiService extends AbstractEmojiService { |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 	private final EmojiCompat.InitCallback initCallback = new EmojiCompat.InitCallback() { |  | ||||||
| 		@Override |  | ||||||
| 		public void onInitialized() { |  | ||||||
| 			super.onInitialized(); |  | ||||||
| 			Log.d(Config.LOGTAG,"EmojiService succeeded in loading fonts"); |  | ||||||
| 
 |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		@Override |  | ||||||
| 		public void onFailed(Throwable throwable) { |  | ||||||
| 			super.onFailed(throwable); |  | ||||||
| 			Log.d(Config.LOGTAG,"EmojiService failed to load fonts",throwable); |  | ||||||
| 		} |  | ||||||
| 	}; |  | ||||||
| 
 |  | ||||||
| 	public EmojiService(Context context) { |  | ||||||
| 		super(context); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	@Override |  | ||||||
| 	protected EmojiCompat.Config buildConfig() { |  | ||||||
| 		final FontRequest fontRequest = new FontRequest( |  | ||||||
| 				"com.google.android.gms.fonts", |  | ||||||
| 				"com.google.android.gms", |  | ||||||
| 				"Noto Color Emoji Compat", |  | ||||||
| 				R.array.font_certs); |  | ||||||
| 		FontRequestEmojiCompatConfig fontRequestEmojiCompatConfig = new FontRequestEmojiCompatConfig(context, fontRequest); |  | ||||||
| 		fontRequestEmojiCompatConfig.registerInitCallback(initCallback); |  | ||||||
| 		return fontRequestEmojiCompatConfig; |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  | @ -0,0 +1,53 @@ | ||||||
|  | package eu.siacs.conversations.ui.service; | ||||||
|  | 
 | ||||||
|  | import android.content.Context; | ||||||
|  | import android.os.Build; | ||||||
|  | import android.support.text.emoji.EmojiCompat; | ||||||
|  | import android.support.text.emoji.FontRequestEmojiCompatConfig; | ||||||
|  | import android.support.v4.provider.FontRequest; | ||||||
|  | import android.util.Log; | ||||||
|  | 
 | ||||||
|  | import eu.siacs.conversations.Config; | ||||||
|  | import eu.siacs.conversations.R; | ||||||
|  | 
 | ||||||
|  | public class EmojiService { | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     private final EmojiCompat.InitCallback initCallback = new EmojiCompat.InitCallback() { | ||||||
|  |         @Override | ||||||
|  |         public void onInitialized() { | ||||||
|  |             super.onInitialized(); | ||||||
|  |             Log.d(Config.LOGTAG, "EmojiService succeeded in loading fonts"); | ||||||
|  | 
 | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         @Override | ||||||
|  |         public void onFailed(Throwable throwable) { | ||||||
|  |             super.onFailed(throwable); | ||||||
|  |             Log.d(Config.LOGTAG, "EmojiService failed to load fonts", throwable); | ||||||
|  |         } | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     private final Context context; | ||||||
|  | 
 | ||||||
|  |     public EmojiService(Context context) { | ||||||
|  |         this.context = context; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void init() { | ||||||
|  |         final FontRequest fontRequest = new FontRequest( | ||||||
|  |                 "com.google.android.gms.fonts", | ||||||
|  |                 "com.google.android.gms", | ||||||
|  |                 "Noto Color Emoji Compat", | ||||||
|  |                 R.array.font_certs); | ||||||
|  |         FontRequestEmojiCompatConfig fontRequestEmojiCompatConfig = new FontRequestEmojiCompatConfig(context, fontRequest); | ||||||
|  |         fontRequestEmojiCompatConfig.registerInitCallback(initCallback); | ||||||
|  |         //On recent Androids we assume to have the latest emojis | ||||||
|  |         //there are some annoying bugs with emoji compat that make it a safer choice not to use it when possible | ||||||
|  |         // a) when using the ondemand emoji font (play store) flags don’t work | ||||||
|  |         // b) the text preview has annoying glitches when the cut of text contains emojis (the emoji will be half visible) | ||||||
|  |         fontRequestEmojiCompatConfig.setReplaceAll(Build.VERSION.SDK_INT < Build.VERSION_CODES.O); | ||||||
|  |         EmojiCompat.init(fontRequestEmojiCompatConfig); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | @ -0,0 +1,14 @@ | ||||||
|  | package eu.siacs.conversations.ui.service; | ||||||
|  | 
 | ||||||
|  | import android.content.Context; | ||||||
|  | 
 | ||||||
|  | public class EmojiService { | ||||||
|  | 
 | ||||||
|  |     public EmojiService(Context context) { | ||||||
|  |         //nop | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void init() { | ||||||
|  |         //nop | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | @ -0,0 +1,16 @@ | ||||||
|  | package eu.siacs.conversations.ui.widget; | ||||||
|  | 
 | ||||||
|  | import android.content.Context; | ||||||
|  | import android.support.v7.widget.AppCompatEditText; | ||||||
|  | import android.util.AttributeSet; | ||||||
|  | 
 | ||||||
|  | public abstract class AbstractEditMessage extends AppCompatEditText { | ||||||
|  | 
 | ||||||
|  |     public AbstractEditMessage(Context context) { | ||||||
|  |         super(context); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public AbstractEditMessage(Context context, AttributeSet attrs) { | ||||||
|  |         super(context, attrs); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | @ -0,0 +1,47 @@ | ||||||
|  | /* | ||||||
|  |  * Copyright (c) 2017, 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.support.text.emoji.EmojiCompat; | ||||||
|  | 
 | ||||||
|  | public class EmojiWrapper { | ||||||
|  | 
 | ||||||
|  | 	public static CharSequence transform(CharSequence input) { | ||||||
|  | 		try { | ||||||
|  | 			if (EmojiCompat.get().getLoadState() == EmojiCompat.LOAD_STATE_SUCCEEDED) { | ||||||
|  | 				return EmojiCompat.get().process(input); | ||||||
|  | 			} else { | ||||||
|  | 				return input; | ||||||
|  | 			} | ||||||
|  | 		} catch (IllegalStateException e) { | ||||||
|  | 			return input; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
		Loading…
	
		Reference in New Issue
	
	 Daniel Gultsch
						Daniel Gultsch