- Easily allow extras in
OnItemBindClass
.
- Fixed package of DiffObservableList
- Changed package name to not conflict with 1.x
- Fixed potential synchronization issue in DiffObservableList
- Fixed crash when binding a ListView with headers and/or footers.
- Added DiffObservableList. This wraps DiffUtil allowing you to easily update your list with a new version and it will automatically find the change updates for animation.
This is a complete refactor to simplify and improve naming of components.
- Replaced
ItemView
,ItemViewSelector
, andItemViewArg
withItemBinding
andOnItemBind
. Everything is just anItemBinding
so 2 different classes don't have to be juggled. You can pass anOnItemBind
callback into anItemBinding
for dynamic selection. There is a convenience conversion so you can just provide anOnItemBind
toapp:itemBinding
in your layout. ItemView.BINDING_VARIABLE_NONE
is nowItemBinding.VAR_NONE
. Before, forgetting this would lead to subtle bugs.- An exception will be thrown if nothing is set on an itemBinding in
onItemBind
. - Knowledge of
itemTypeCount
is only present inBindingListViewAdapter
. You can pass it to the constructor or set it withapp:itemTypeCount="@{count}"
in your layout. setItemBinding()
is added to theBindingCollectionAdapter
instead of it being a required constructor arg.- Factories for custom adapters are removed, just pass in the instance directly to
app:adapter
. - Dynamically changing a bound adapter is supported. Note: this means that if it is not intended to change, you must provide the same instance each time.
- Constructing adapters from a class name is no longer supported.
selector = ItemViewClassSelector.builder()
.put(String.class, BR.name, R.layout.item_name)
.put(Footer.class, ItemView.BINDING_VARIABLE_NONE, R.layout.item_footer)
.build();
is now
itemBind = new OnItemBindClass<>()
.map(String.class, BR.name, R.layout.item_name)
.map(Footer.class, ItemBinding.VAR_NONE, R.layout.item_footer);
selector = new ItemViewModelSelector<Model>();
public class Model implements ItemViewModel {
@Override
public void itemView(ItemView itemView) {
itemView.set(BR.name, R.layout.item_name);
}
}
is now
itemBind = new OnItemBindModel<Model>();
public class Model implements ItemBindingModel {
@Override
public void onItemBind(ItemBinding itemBinding) {
itemBinding.set(BR.name, R.layout.item_name);
}
}
- Added way to construct your own custom view holder for a RecyclerView adapter.
- Updated databinding dependency to work around some of it's bugs.
- Added some utilities to help work with more complex item views and data sources.
- MergeObservableList: create a 'merged' view of multiple ObservableLists and single items. Any changes to a backing list will be reflected in the merge one. Useful for headers, footers, and concatenating data sources.
- ItemViewClassSelector: build an ItemViewSelector based on the classes of the items. Useful if you find yourself doing a bunch of instanceof checks in an ItemSelector.
- ItemViewModelSelector: a selector that selects item views using list items that implement the ItemViewModel interface.
- Fixed bug where BindingRecyclerViewAdapter would not register for list changes if the items are set on the adapter before the adapter is set on the recycler view.
- Items are now set on adapters before they are added to the collection view. This should make it more likely to restore state (ex: scroll position) if the items are already populated when bound.
- Better support for recyclerview item changes. This means better handling of layout changes and item animations. Source: https://realm.io/news/data-binding-android-boyar-mount/
- Disabled support for dynamic item views. This was causing unnecessary adapter replacement. It may be added back in a later version if it can be done correctly.
- Officially stable release! The won't be any backwards-incompatible changes without a major version bump.
- Changed group to
me.tatarka.bindingcolectionadapter
. - Added
getItemViewArg()
toBindingCollectionAdapter
so you can easily get the arg it was constructed with. - Added
ItemIsEnabled
toBindingListViewAdapter
to easily configure the behavior ofisEnabled(int)
. You can set withsetItemIsEnabled()
in code oritemIsEnabled
in your layout. - Support dynamically changing the
itemView
in a binding. This will replace the entire adapter.
- Updated to latest databinding, requites android plugin
1.5.0
- Use
requireAll = false
to vastly simplify binding adapters. - Fail with a more helpful error message when
itemView
is null. - Removed deprecated
ItemView
methods. - Invalid binding variable error can now show it's name even if the app's package and the BR package do not match.
- Deprecated
ItemView.getBindingVariable()
andItemView.getLayoutRes()
in favor ofItemView.bindingVariable()
andItemView.layoutRes()
. - Added public accessor methods to
ItemViewArg
to select and get item view info. - Removed unused constant in
BindingListViewAdapter
- Fixed
BindingViewPagerAdapter
possibly using the wrong binding variable inonBindBinding()
.
- Removed deprecated
BindingCollectionAdapter.setItems(Collection<T>)
. - Removed deprecated constructors on adapters.
- Removed deprecated methods on
ItemView
. - Removed some more deprecated items in
BindingCollectionAdapters
. - Removed ClassNameBindingCollectionAdapterFactories, though you can still use the class name in binding.
- Split out RecyclerView bindings into a separate dependency. If you are using RecyclerView, you
should also include
compile 'me.tatarka:bindingcollectionadpater-recyclerview:0.14'
.
- Update databinding to rc2.
- Simplified and re-ordered BindingAdapters
- Removed support for modifying an
ObservableList
off the main thread. It will now throw an exception. - Removed deprecated
BindingCollectionAdapter.getItems()
. - Removed a bunch of deprecated methods on
BindingCollectionAdapters
that should shouldn't be using anyway and deprecated some more. - Added
BindingCollectionAdapter.setItems(List<T>)
and deprecatedBindingCollectionAdapter.setItems(Collection<T>)
. Warning! This may cause a subtile change in behavior. The collection now always holds a reference to the collection you pass it instead of copying it into it's own. You must now be careful to only modify this collection on the main thread and callnotifyDataSetChanged()
or related if you are not using anObservableList
. - Added support for itemId on RecyclerView.
- Work around for
@BindingConversion
generics issue, fixes ItemViewSelector. - Added support for specifying adapters with factories instead of a class name.
- Change ListView BindingAdapters to AdapterView to directly support spinners.
- Fixed crash when
getViewTypeCount()
is not called beforegetItemViewType()
. - Unified ItemView and ItemViewSelector A new constructor that takes an ItemViewArg simplifies databinding since you don't need two seperate methods for ItemView and ItemViewSelector. a couple of BindingConversions keeps this backwards-compatible.
Note: If you are using a custom BindingCollectionAdapter, you should add a cosntructor to create it with an ItemViewArg (the common case would just be to call super). There is currently a fallback so that this change is backwards-compatible but it will be removed in a future update.
- Deprecated
itemView.setLayoutRes(DROP_DOWN_LAYOUT, int)
in favor ofapp:dropDownItemView
oradapter.setDropDownItemView(itemViw)
. Original functionality is completely removed but that shouldn't matter since you couldn't bind the adapter to the spinner anyway. - Added warning for changing list off the main thread. This future doesn't carry it's weight and will be removed from a future version.
- Deprecated
BindingCollectionAdapter.getItems()
and addedBindingCollectionAdapter.getAdapterItem(int)
. See javadoc for reasoning. - Show the binding variable name instead of int value when it fails to bind an item.
- Bumped data-binding dep to
1.0-rc1
.
- Reverted changes to
BindingRecyclerViewAdapter.getItemViewType()
because it actually causes it to work incorrectly.
- Fixed bug when creating a custom adapter with an
ItemViewSelector
- Changed
BindingRecyclerViewAdapter.getItemViewType()
to be safer to override.
- Changed the adapter subclass callback methods to
onCreateBinding()
andonBindBinding()
to give you more control over the superclass implementations.
-
You now need to subclass the adapters to access the views, this simpilifes things as you don't have to worry about setting the listener after it's been called. There is an additional binding 'adapter' that you can set to bind to your subclass.
-
Changed binding adapters to use multiple variables instead of tags, makes them easier to understand. If you copied the binding adapters yourself to get around apt plugin bug, you'll have to redo that.
- Minor refactoring in how the binding adapters are created.
- Fail fast when a variable cannot be bound to a layout.
- Add CollectionBindingListener which allows you to get access to item binding and manipulate it when it's created and when it's bound.
- Allow changes to the ObservableList to happen in a seperate thread.
- Initial Release.