Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/Malinskiy/SuperRecyclerView

Pumped up RecyclerView
https://github.com/Malinskiy/SuperRecyclerView

Last synced: 3 months ago
JSON representation

Pumped up RecyclerView

Awesome Lists containing this project

README

        

[![Maven Central](https://maven-badges.herokuapp.com/maven-central/com.malinskiy/superrecyclerview/badge.svg?style=flat)](https://maven-badges.herokuapp.com/maven-central/com.malinskiy/superrecyclerview) [![Build Status](https://travis-ci.org/Malinskiy/SuperRecyclerView.svg?branch=master)](https://travis-ci.org/Malinskiy/SuperRecyclerView) [![Android Arsenal](https://img.shields.io/badge/Android%20Arsenal-SuperRecyclerView-brightgreen.svg?style=flat)](https://android-arsenal.com/details/1/1239)
==============

##Description

This is an attempt to make RecyclerView easier to use.

Features built in:
- ProgressBar while adapter hasn't been set
- EmptyView if adapter is empty
- SwipeRefreshLayout (Google's one)
- Infinite scrolling, when you reach the X last item, load more of them.
- Swipe To Dismiss or Swipe To Remove
- Sticky headers (via [Eowise][eowise-sticky-headers], see sample)

##Integration

Just add it to you dependencies

```
compile 'com.malinskiy:superrecyclerview:$version'
```

##Usage

- Use directly SuperRecyclerView:

```xml

```

- Current Attributes supported:
```xml















```

##SuperRecyclerView Java Usage

```java
recycler.setRefreshListener(new SwipeRefreshLayout.OnRefreshListener {
@Override
public void onRefresh() {
// Do your refresh
});

// when there is only 10 items to see in the recycler, this is triggered
recycler.setupMoreListener(new OnMoreListener() {
@Override
public void onMoreAsked(int numberOfItems, int numberBeforeMore, int currentItemPos) {
// Fetch more from Api or DB
}}, 10);

recycler.setupSwipeToDismiss(new SwipeDismissListViewTouchListener.DismissCallbacks() {
@Override
public boolean canDismiss(int position) {
return true
}

@Override
public void onDismiss(RecyclerView recyclerView, int[] reverseSortedPositions) {
// Do your stuff like call an Api or update your db
}});

```

##Scrollbars
RecyclerView currently doesn't support setting scrollbars from code that's why I can't parse custom attributes.
You have to use appropriate `mainLayoutId` attribute to have scrollbars visible.

### Vertical scrollbars
```xml

```

### Horizontal scrollbars
```xml

```

##Swipe layout
1. You should always assign ```android:id``` to ```@id/recyclerview_swipe```. Note that it's a reference to an already defined id, so don't use ```@+id```

2. The `SwipeLayout` can only have 2 children that are instances of [`ViewGroup`](http://developer.android.com/reference/android/view/ViewGroup.html), e.g. `LinearLayout`, `RelativeLayout`, `GridLayout`

3. The first child is the bottom view, the second child is the top view

4. Your adapter should extend `BaseSwipeAdapter` class

5. Do not setup swipe to dismiss and use swipe layout at the same time. If you do - a kitten will cry somewhere.

Item example:

```xml

```

Custom attributes supported:
```xml












```

####[Sample java][sample java]

## Proguard

```
-dontwarn com.malinskiy.superrecyclerview.SwipeDismissRecyclerViewTouchListener*
```

##Thanks
[Jake Warthon][jake-swipe-to-dismiss] for implementation of SwipeToDismiss via NineOldAndroids

[Eowise][eowise-sticky-headers] for implementation of sticky headers

[Quentin Dommerc][superlistview] for inspiration

[代码家][swipelayout] for swipe layout implementation

##License

Copyright (c) 2016 Anton Malinskiy

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
Come on, don't tell me you read that.

[sample java]:https://github.com/Malinskiy/SuperRecyclerView/blob/master/SuperRecyclerView-sample/src/main/java/com/malinskiy/superrecyclerview/sample/BaseActivity.java
[jake-swipe-to-dismiss]:https://github.com/JakeWharton/SwipeToDismissNOA
[eowise-sticky-headers]:https://github.com/eowise/recyclerview-stickyheaders
[superlistview]:https://github.com/dommerq/SuperListview
[swipelayout]:https://github.com/daimajia/AndroidSwipeLayout