2017-07-29 13:09:55 +02:00
|
|
|
package com.wireguard.android;
|
|
|
|
|
|
|
|
import android.databinding.BindingAdapter;
|
2017-08-08 02:46:19 +02:00
|
|
|
import android.databinding.ObservableArrayMap;
|
2017-07-29 13:09:55 +02:00
|
|
|
import android.databinding.ObservableList;
|
|
|
|
import android.widget.ListView;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Static methods for use by generated code in the Android data binding library.
|
|
|
|
*/
|
|
|
|
|
|
|
|
public final class BindingAdapters {
|
2017-08-08 02:46:19 +02:00
|
|
|
@BindingAdapter({"items", "layout"})
|
|
|
|
public static <K, V> void arrayMapBinding(ListView view, ObservableArrayMap<K, V> oldMap,
|
|
|
|
int oldLayoutId, ObservableArrayMap<K, V> newMap,
|
|
|
|
int newLayoutId) {
|
|
|
|
// Remove any existing binding when there is no new map.
|
|
|
|
if (newMap == null) {
|
|
|
|
view.setAdapter(null);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
// The ListAdapter interface is not generic, so this cannot be checked.
|
|
|
|
@SuppressWarnings("unchecked")
|
|
|
|
ObservableArrayMapAdapter<K, V> adapter =
|
|
|
|
(ObservableArrayMapAdapter<K, V>) view.getAdapter();
|
|
|
|
// If the layout changes, any existing adapter must be replaced.
|
|
|
|
if (newLayoutId != oldLayoutId)
|
|
|
|
adapter = null;
|
|
|
|
// Add a new binding if there was none, or if it must be replaced due to a layout change.
|
|
|
|
if (adapter == null) {
|
|
|
|
adapter = new ObservableArrayMapAdapter<>(view.getContext(), newLayoutId, newMap);
|
|
|
|
view.setAdapter(adapter);
|
|
|
|
} else if (newMap != oldMap) {
|
|
|
|
// Changing the list only requires modifying the existing adapter.
|
|
|
|
adapter.setMap(newMap);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-07-29 13:09:55 +02:00
|
|
|
@BindingAdapter({"items", "layout"})
|
|
|
|
public static <T> void listBinding(ListView view, ObservableList<T> oldList, int oldLayoutId,
|
|
|
|
ObservableList<T> newList, int newLayoutId) {
|
|
|
|
// Remove any existing binding when there is no new list.
|
|
|
|
if (newList == null) {
|
|
|
|
view.setAdapter(null);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
// The ListAdapter interface is not generic, so this cannot be checked.
|
|
|
|
@SuppressWarnings("unchecked")
|
|
|
|
ObservableListAdapter<T> adapter = (ObservableListAdapter<T>) view.getAdapter();
|
|
|
|
// If the layout changes, any existing adapter must be replaced.
|
|
|
|
if (newLayoutId != oldLayoutId)
|
|
|
|
adapter = null;
|
|
|
|
// Add a new binding if there was none, or if it must be replaced due to a layout change.
|
|
|
|
if (adapter == null) {
|
|
|
|
adapter = new ObservableListAdapter<>(view.getContext(), newLayoutId, newList);
|
|
|
|
view.setAdapter(adapter);
|
|
|
|
} else if (newList != oldList) {
|
|
|
|
// Changing the list only requires modifying the existing adapter.
|
|
|
|
adapter.setList(newList);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private BindingAdapters() {
|
|
|
|
}
|
|
|
|
}
|