Compare commits
9 Commits
master
...
project/bo
| Author | SHA1 | Date |
|---|---|---|
|
|
88af4f9791 | |
|
|
20166724c1 | |
|
|
141ed18bec | |
|
|
71c5587bad | |
|
|
87a473f73f | |
|
|
12de015db4 | |
|
|
48b8be39e6 | |
|
|
cf6200dc2d | |
|
|
be9c0a5e69 |
|
|
@ -11,8 +11,7 @@ android {
|
|||
}
|
||||
|
||||
defaultConfig {
|
||||
minSdkVersion 10
|
||||
targetSdkVersion 25
|
||||
minSdkVersion 16
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -35,12 +34,12 @@ dependencies {
|
|||
exclude(group: 'org.apache.httpcomponents', module: 'httpclient')
|
||||
}
|
||||
|
||||
provided 'com.facebook.fresco:fresco:1.3.0'
|
||||
provided 'com.facebook.fresco:fresco:1.4.0'
|
||||
provided 'com.bluelinelabs:logansquare:1.3.7'
|
||||
|
||||
provided 'com.scottyab:aes-crypto:0.0.4'
|
||||
|
||||
provided('io.socket:socket.io-client:0.8.3') {
|
||||
provided('io.socket:socket.io-client:1.0.0') {
|
||||
exclude group: 'org.json', module: 'json'
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -109,8 +109,13 @@ public final class DeviceUtils {
|
|||
*/
|
||||
@NonNull
|
||||
public static NetworkType getNetworkType(@NonNull final Context context) {
|
||||
final ConnectivityManager cm = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
|
||||
final NetworkInfo info = cm.getActiveNetworkInfo();
|
||||
final ConnectivityManager connectivityManager = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
|
||||
return getNetworkType(connectivityManager);
|
||||
}
|
||||
|
||||
@NonNull
|
||||
private static NetworkType getNetworkType(@NonNull final ConnectivityManager connectivityManager) {
|
||||
final NetworkInfo info = connectivityManager.getActiveNetworkInfo();
|
||||
if (info == null || !info.isConnected()) {
|
||||
return NetworkType.NONE;
|
||||
}
|
||||
|
|
@ -137,12 +142,14 @@ public final class DeviceUtils {
|
|||
case TelephonyManager.NETWORK_TYPE_HSPAP:
|
||||
return NetworkType.MOBILE_3G;
|
||||
case TelephonyManager.NETWORK_TYPE_LTE:
|
||||
case 19: // NETWORK_TYPE_LTE_CA is hide
|
||||
return NetworkType.MOBILE_LTE;
|
||||
case TelephonyManager.NETWORK_TYPE_UNKNOWN:
|
||||
default:
|
||||
return NetworkType.NONE;
|
||||
return NetworkType.UNKNOWN;
|
||||
}
|
||||
}
|
||||
return NetworkType.NONE;
|
||||
return NetworkType.UNKNOWN;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -155,7 +162,6 @@ public final class DeviceUtils {
|
|||
return getNetworkType(context) != NetworkType.NONE;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Returns observable to observe is device connected to Wi-Fi network.
|
||||
*
|
||||
|
|
@ -177,6 +183,27 @@ public final class DeviceUtils {
|
|||
}));
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns observable to observe is device connected to the internet.
|
||||
*
|
||||
* @param context Context to register BroadcastReceiver to check connection to the internet;
|
||||
* @return Observable of internet connection status.
|
||||
*/
|
||||
@NonNull
|
||||
public static Observable<Boolean> observeIsNetworkConnected(@NonNull final Context context) {
|
||||
return Observable.switchOnNext(Observable.fromCallable(() -> {
|
||||
final NetworkStateReceiver networkStateReceiver = new NetworkStateReceiver();
|
||||
return Observable
|
||||
.<Boolean>create(subscriber -> {
|
||||
subscriber.onNext(isNetworkConnected(context));
|
||||
networkStateReceiver.setSubscriber(subscriber);
|
||||
context.registerReceiver(networkStateReceiver, NetworkStateReceiver.INTENT_FILTER);
|
||||
})
|
||||
.doOnUnsubscribe(() -> context.unregisterReceiver(networkStateReceiver))
|
||||
.distinctUntilChanged();
|
||||
}));
|
||||
}
|
||||
|
||||
private DeviceUtils() {
|
||||
}
|
||||
|
||||
|
|
@ -200,6 +227,10 @@ public final class DeviceUtils {
|
|||
* Wi-Fi network.
|
||||
*/
|
||||
WI_FI("Wi-Fi"),
|
||||
/**
|
||||
* Unknown network type.
|
||||
*/
|
||||
UNKNOWN("unknown"),
|
||||
/**
|
||||
* No network.
|
||||
*/
|
||||
|
|
@ -243,4 +274,27 @@ public final class DeviceUtils {
|
|||
|
||||
}
|
||||
|
||||
private static class NetworkStateReceiver extends BroadcastReceiver {
|
||||
|
||||
private static final IntentFilter INTENT_FILTER = new IntentFilter(ConnectivityManager.CONNECTIVITY_ACTION);
|
||||
@Nullable
|
||||
private ConnectivityManager connectivityManager;
|
||||
|
||||
@Nullable
|
||||
private Subscriber<? super Boolean> subscriber;
|
||||
|
||||
public void setSubscriber(@Nullable final Subscriber<? super Boolean> subscriber) {
|
||||
this.subscriber = subscriber;
|
||||
}
|
||||
|
||||
public void onReceive(@NonNull final Context context, @NonNull final Intent intent) {
|
||||
if (connectivityManager == null) {
|
||||
connectivityManager = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
|
||||
}
|
||||
if (subscriber != null) {
|
||||
subscriber.onNext(isNetworkConnected(context));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
|
@ -29,7 +29,9 @@ import java.io.ByteArrayOutputStream;
|
|||
import java.io.IOException;
|
||||
import java.lang.reflect.Type;
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashSet;
|
||||
import java.util.List;
|
||||
import java.util.Set;
|
||||
|
||||
import ru.touchin.roboswag.components.utils.storables.PreferenceStore;
|
||||
import ru.touchin.roboswag.core.observables.storable.Converter;
|
||||
|
|
@ -83,6 +85,26 @@ public final class GoogleJsonPreferences {
|
|||
.build();
|
||||
}
|
||||
|
||||
@NonNull
|
||||
public static <T> Storable<String, Set<T>, String> jsonSetStorable(@NonNull final String name,
|
||||
@NonNull final Class<T> jsonItemClass,
|
||||
@NonNull final SharedPreferences preferences) {
|
||||
return new Storable.Builder<>(name, Set.class, String.class, new PreferenceStore<>(preferences), new JsonSetConverter<>(jsonItemClass))
|
||||
.setObserveStrategy(Storable.ObserveStrategy.CACHE_ACTUAL_VALUE)
|
||||
.build();
|
||||
}
|
||||
|
||||
@NonNull
|
||||
public static <T> NonNullStorable<String, Set<T>, String> jsonSetStorable(@NonNull final String name,
|
||||
@NonNull final Class<T> jsonItemClass,
|
||||
@NonNull final SharedPreferences preferences,
|
||||
@NonNull final Set<T> defaultValue) {
|
||||
return new Storable.Builder<>(name, Set.class, String.class, new PreferenceStore<>(preferences), new JsonSetConverter<>(jsonItemClass))
|
||||
.setObserveStrategy(Storable.ObserveStrategy.CACHE_ACTUAL_VALUE)
|
||||
.setDefaultValue(defaultValue)
|
||||
.build();
|
||||
}
|
||||
|
||||
private GoogleJsonPreferences() {
|
||||
}
|
||||
|
||||
|
|
@ -146,4 +168,29 @@ public final class GoogleJsonPreferences {
|
|||
|
||||
}
|
||||
|
||||
public static class JsonSetConverter<T> extends JsonConverter<Set<T>> {
|
||||
|
||||
@NonNull
|
||||
private final Class<T> itemClass;
|
||||
|
||||
public JsonSetConverter(@NonNull final Class<T> itemClass) {
|
||||
super();
|
||||
this.itemClass = itemClass;
|
||||
}
|
||||
|
||||
@Nullable
|
||||
@Override
|
||||
public Set<T> toObject(@NonNull final Type jsonObjectType, @NonNull final Type stringType, @Nullable final String storeValue) {
|
||||
if (storeValue == null) {
|
||||
return null;
|
||||
}
|
||||
try {
|
||||
return new HashSet<>(GoogleJsonModel.DEFAULT_JSON_FACTORY.createJsonParser(storeValue).parseArray(HashSet.class, itemClass));
|
||||
} catch (final IOException exception) {
|
||||
throw new ShouldNotHappenException(exception);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in New Issue