Full Code of Batterii/PagingRecycler for AI

master 5e281eeb0ae0 cached
20 files
23.5 KB
6.6k tokens
47 symbols
1 requests
Download .txt
Repository: Batterii/PagingRecycler
Branch: master
Commit: 5e281eeb0ae0
Files: 20
Total size: 23.5 KB

Directory structure:
gitextract_s3c1ibv1/

├── .gitignore
├── README.md
├── build.gradle
├── gradle/
│   └── wrapper/
│       ├── gradle-wrapper.jar
│       └── gradle-wrapper.properties
├── gradle.properties
├── gradlew
├── gradlew.bat
├── library/
│   ├── .gitignore
│   ├── build.gradle
│   ├── proguard-rules.pro
│   └── src/
│       ├── androidTest/
│       │   └── java/
│       │       └── com/
│       │           └── akiniyalocts/
│       │               └── pagingrecycler/
│       │                   └── ApplicationTest.java
│       ├── main/
│       │   ├── AndroidManifest.xml
│       │   ├── java/
│       │   │   └── com/
│       │   │       └── akiniyalocts/
│       │   │           └── pagingrecycler/
│       │   │               ├── PagingAdapter.java
│       │   │               └── PagingDelegate.java
│       │   └── res/
│       │       └── values/
│       │           ├── colors.xml
│       │           ├── strings.xml
│       │           └── styles.xml
│       └── test/
│           └── java/
│               └── com/
│                   └── akiniyalocts/
│                       └── pagingrecycler/
│                           └── ExampleUnitTest.java
└── settings.gradle

================================================
FILE CONTENTS
================================================

================================================
FILE: .gitignore
================================================
target/
.classpath
.project
.settings/
gen/
bin/
local.properties
.metadata/
*.class
*.apk
*.res
*.dex
*.iml
ButtercupMobile/out
.idea
.gradle/
ButtercupMobile/obj
.gradle
local.properties
.DS_Store
build/
*.iml
.idea/
*.swp
com_crashlytics_export_strings.xml
crashlytics-build.properties
ajcore.*
.navgation/

================================================
FILE: README.md
================================================
# PagingRecycler [![](https://jitpack.io/v/Batterii/PagingRecycler.svg)](https://jitpack.io/#Batterii/PagingRecycler)

A quick way to implement a paging pattern for a RecyclerView. PagingRecycler will show a "loading" view at the bottom of your RecyclerView while you are waiting for a page of results from your api call, then remove it when you are finished.
### Gradle
```gradle

  allprojects {
		repositories {
			...
			maven { url "https://jitpack.io" }
		}
	}

		dependencies {
	        compile 'com.github.Batterii:PagingRecycler:v1.1.1'
	}
```
## Usage
### Adapter
```java

public class MyAdapter extends PagingAdapter{

  private List<Item> myItems;

  public MyAdapter(){
    myItems = new ArrayList<>();
  }

  @Override
    public int getPagingLayout() {
        return R.layout.paging_item;
  }

  @Override
  public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
    // Do your normal view creation

    // End with this
    return super.onCreateViewHolder(parent, viewType);

  }  

  @Override
  public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {
    // Call super!
    super.onBindViewHolder(holder, position);

    // Do your normal binding

  }

  @Override
  public int getItemCount() {
    // just return super here
    return super.getItemCount();
  }

  @Override
  public int getPagingItemCount() {
    // return your actual item size here
    return myItems.size();
  }

}
```

### Your Activity/Fragment etc.
```java

public class MyActivity extends AppCompatActivity implements PagingDelegate.OnPageListener{

 @Override
  public void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);

      MyAdapter adapter = new MyAdapter();

      RecyclerView mRecycler = (RecyclerView)findViewById(R.id.my_recycler);

      PagingDelegate pagingDelegate = new PagingDelegate.Builder(adapter)
                .attachTo(mRecycler)
                .listenWith(this)
                .build();

      mRecycler.setAdapter(adapter);
  }

   @Override
    public void onPage(int offset) {
        // Perform your paging request
    }

    @Override
    public void onDonePaging() {

    }

  }
```

License
--------

    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.


================================================
FILE: build.gradle
================================================
// Top-level build file where you can add configuration options common to all sub-projects/modules.

buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:1.5.0'

        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        jcenter()
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}


================================================
FILE: gradle/wrapper/gradle-wrapper.properties
================================================
#Mon Dec 28 10:00:20 PST 2015
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-2.10-all.zip


================================================
FILE: gradle.properties
================================================
# Project-wide Gradle settings.

# IDE (e.g. Android Studio) users:
# Gradle settings configured through the IDE *will override*
# any settings specified in this file.

# For more details on how to configure your build environment visit
# http://www.gradle.org/docs/current/userguide/build_environment.html

# Specifies the JVM arguments used for the daemon process.
# The setting is particularly useful for tweaking memory settings.
# Default value: -Xmx10248m -XX:MaxPermSize=256m
# org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8

# When configured, Gradle will run in incubating parallel mode.
# This option should only be used with decoupled projects. More details, visit
# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
# org.gradle.parallel=true

================================================
FILE: gradlew
================================================
#!/usr/bin/env bash

##############################################################################
##
##  Gradle start up script for UN*X
##
##############################################################################

# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
DEFAULT_JVM_OPTS=""

APP_NAME="Gradle"
APP_BASE_NAME=`basename "$0"`

# Use the maximum available, or set MAX_FD != -1 to use that value.
MAX_FD="maximum"

warn ( ) {
    echo "$*"
}

die ( ) {
    echo
    echo "$*"
    echo
    exit 1
}

# OS specific support (must be 'true' or 'false').
cygwin=false
msys=false
darwin=false
case "`uname`" in
  CYGWIN* )
    cygwin=true
    ;;
  Darwin* )
    darwin=true
    ;;
  MINGW* )
    msys=true
    ;;
esac

# Attempt to set APP_HOME
# Resolve links: $0 may be a link
PRG="$0"
# Need this for relative symlinks.
while [ -h "$PRG" ] ; do
    ls=`ls -ld "$PRG"`
    link=`expr "$ls" : '.*-> \(.*\)$'`
    if expr "$link" : '/.*' > /dev/null; then
        PRG="$link"
    else
        PRG=`dirname "$PRG"`"/$link"
    fi
done
SAVED="`pwd`"
cd "`dirname \"$PRG\"`/" >/dev/null
APP_HOME="`pwd -P`"
cd "$SAVED" >/dev/null

CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar

# Determine the Java command to use to start the JVM.
if [ -n "$JAVA_HOME" ] ; then
    if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
        # IBM's JDK on AIX uses strange locations for the executables
        JAVACMD="$JAVA_HOME/jre/sh/java"
    else
        JAVACMD="$JAVA_HOME/bin/java"
    fi
    if [ ! -x "$JAVACMD" ] ; then
        die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME

Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
    fi
else
    JAVACMD="java"
    which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.

Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
fi

# Increase the maximum file descriptors if we can.
if [ "$cygwin" = "false" -a "$darwin" = "false" ] ; then
    MAX_FD_LIMIT=`ulimit -H -n`
    if [ $? -eq 0 ] ; then
        if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
            MAX_FD="$MAX_FD_LIMIT"
        fi
        ulimit -n $MAX_FD
        if [ $? -ne 0 ] ; then
            warn "Could not set maximum file descriptor limit: $MAX_FD"
        fi
    else
        warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
    fi
fi

# For Darwin, add options to specify how the application appears in the dock
if $darwin; then
    GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
fi

# For Cygwin, switch paths to Windows format before running java
if $cygwin ; then
    APP_HOME=`cygpath --path --mixed "$APP_HOME"`
    CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
    JAVACMD=`cygpath --unix "$JAVACMD"`

    # We build the pattern for arguments to be converted via cygpath
    ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
    SEP=""
    for dir in $ROOTDIRSRAW ; do
        ROOTDIRS="$ROOTDIRS$SEP$dir"
        SEP="|"
    done
    OURCYGPATTERN="(^($ROOTDIRS))"
    # Add a user-defined pattern to the cygpath arguments
    if [ "$GRADLE_CYGPATTERN" != "" ] ; then
        OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
    fi
    # Now convert the arguments - kludge to limit ourselves to /bin/sh
    i=0
    for arg in "$@" ; do
        CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
        CHECK2=`echo "$arg"|egrep -c "^-"`                                 ### Determine if an option

        if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then                    ### Added a condition
            eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
        else
            eval `echo args$i`="\"$arg\""
        fi
        i=$((i+1))
    done
    case $i in
        (0) set -- ;;
        (1) set -- "$args0" ;;
        (2) set -- "$args0" "$args1" ;;
        (3) set -- "$args0" "$args1" "$args2" ;;
        (4) set -- "$args0" "$args1" "$args2" "$args3" ;;
        (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
        (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
        (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
        (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
        (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
    esac
fi

# Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules
function splitJvmOpts() {
    JVM_OPTS=("$@")
}
eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS
JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME"

exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@"


================================================
FILE: gradlew.bat
================================================
@if "%DEBUG%" == "" @echo off
@rem ##########################################################################
@rem
@rem  Gradle startup script for Windows
@rem
@rem ##########################################################################

@rem Set local scope for the variables with windows NT shell
if "%OS%"=="Windows_NT" setlocal

@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
set DEFAULT_JVM_OPTS=

set DIRNAME=%~dp0
if "%DIRNAME%" == "" set DIRNAME=.
set APP_BASE_NAME=%~n0
set APP_HOME=%DIRNAME%

@rem Find java.exe
if defined JAVA_HOME goto findJavaFromJavaHome

set JAVA_EXE=java.exe
%JAVA_EXE% -version >NUL 2>&1
if "%ERRORLEVEL%" == "0" goto init

echo.
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
echo.
echo Please set the JAVA_HOME variable in your environment to match the
echo location of your Java installation.

goto fail

:findJavaFromJavaHome
set JAVA_HOME=%JAVA_HOME:"=%
set JAVA_EXE=%JAVA_HOME%/bin/java.exe

if exist "%JAVA_EXE%" goto init

echo.
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
echo.
echo Please set the JAVA_HOME variable in your environment to match the
echo location of your Java installation.

goto fail

:init
@rem Get command-line arguments, handling Windowz variants

if not "%OS%" == "Windows_NT" goto win9xME_args
if "%@eval[2+2]" == "4" goto 4NT_args

:win9xME_args
@rem Slurp the command line arguments.
set CMD_LINE_ARGS=
set _SKIP=2

:win9xME_args_slurp
if "x%~1" == "x" goto execute

set CMD_LINE_ARGS=%*
goto execute

:4NT_args
@rem Get arguments from the 4NT Shell from JP Software
set CMD_LINE_ARGS=%$

:execute
@rem Setup the command line

set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar

@rem Execute Gradle
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%

:end
@rem End local scope for the variables with windows NT shell
if "%ERRORLEVEL%"=="0" goto mainEnd

:fail
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
rem the _cmd.exe /c_ return code!
if  not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
exit /b 1

:mainEnd
if "%OS%"=="Windows_NT" endlocal

:omega


================================================
FILE: library/.gitignore
================================================
target/
.classpath
.project
.settings/
gen/
bin/
local.properties
.metadata/
*.class
*.apk
*.res
*.dex
*.iml
ButtercupMobile/out
.idea
.gradle/
ButtercupMobile/obj
.gradle
local.properties
.DS_Store
build/
*.iml
.idea/
*.swp
com_crashlytics_export_strings.xml
crashlytics-build.properties
ajcore.*
.navgation/
/build

================================================
FILE: library/build.gradle
================================================
apply plugin: 'com.android.library'

android {
    compileSdkVersion 25
    buildToolsVersion "25.0.2"

    defaultConfig {
        minSdkVersion 15
        targetSdkVersion 25
        versionCode 1
        versionName "1.0"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    testCompile 'junit:junit:4.12'
    compile 'com.android.support:appcompat-v7:25.3.0'
    compile 'com.android.support:recyclerview-v7:25.3.0'
}


================================================
FILE: library/proguard-rules.pro
================================================
# Add project specific ProGuard rules here.
# By default, the flags in this file are appended to flags specified
# in /Users/anthonykiniyalocts/Library/Android/sdk/tools/proguard/proguard-android.txt
# You can edit the include path and order by changing the proguardFiles
# directive in build.gradle.
#
# For more details, see
#   http://developer.android.com/guide/developing/tools/proguard.html

# Add any project specific keep options here:

# If your project uses WebView with JS, uncomment the following
# and specify the fully qualified class name to the JavaScript interface
# class:
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
#   public *;
#}


================================================
FILE: library/src/androidTest/java/com/akiniyalocts/pagingrecycler/ApplicationTest.java
================================================
package com.akiniyalocts.pagingrecycler;

import android.app.Application;
import android.test.ApplicationTestCase;

/**
 * <a href="http://d.android.com/tools/testing/testing_android.html">Testing Fundamentals</a>
 */
public class ApplicationTest extends ApplicationTestCase<Application> {
    public ApplicationTest() {
        super(Application.class);
    }
}

================================================
FILE: library/src/main/AndroidManifest.xml
================================================
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.akiniyalocts.pagingrecycler">

    <application
        android:allowBackup="true"
        android:label="@string/app_name"
        android:theme="@style/AppTheme">

    </application>

</manifest>


================================================
FILE: library/src/main/java/com/akiniyalocts/pagingrecycler/PagingAdapter.java
================================================
package com.akiniyalocts.pagingrecycler;

import android.os.Handler;
import android.support.v7.widget.RecyclerView;
import android.support.v7.widget.StaggeredGridLayoutManager;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

/**
 * Created by AKiniyalocts on 3/21/16.
 *
 * An extension of @see android.support.v7.widget.RecyclerView.Adapter that simplifies the common
 * "paging" pattern we see in clients. @see PagingDelegate
 */
public abstract class PagingAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder>{

    // View tag for paging view
    public static int VIEW_TYPE_PAGING = -100;

    private final Handler postHandler;

    // Empty ViewHolder for paging view
    static class LoadingViewHolder extends RecyclerView.ViewHolder{
        public LoadingViewHolder(View itemView) {
            super(itemView);
        }
    }

    // Are we currently paging?
    protected boolean paging = false;

    /**
     * @see PagingDelegate
     */
    private PagingDelegate pagingDelegate;

    public PagingAdapter() {
        postHandler = new Handler();
    }

    /**
     * Provide the layout you wish to inflate when the adapter is loading
     * @return R.layout.your_loading_layout
     */
    public abstract int getPagingLayout();

    /**
     * Provide a count of items in your adapter. Use this instead of getItemCount();
     * @return itemCount
     */
    public abstract int getPagingItemCount();

    public void setPagingDelegate(PagingDelegate pagingDelegate) {
        this.pagingDelegate = pagingDelegate;
    }

    /**
     *  Notify the adapter that it is paging by inserting an new item at the index of
     *  @see android.support.v7.widget.RecyclerView.Adapter getItemCount() + 1
     */
    public void setPaging(){
        if(!paging) {
            paging = true;

            final Runnable r = new Runnable() {
                public void run() {
                    PagingAdapter.this.notifyItemInserted(getItemCount() + 1);
                }
            };

            postHandler.post(r);
        }
    }

    /**
     * If the adapter is paging, return the original item size + 1 to account for the new paging view
     * in the RecyclerView. Otherwise, return item amount.
     * @return int currentItemCount
     */
    @Override
    public int getItemCount() {
        return paging ? getPagingItemCount() + 1: getPagingItemCount();
    }

    /**
     *  Notify the adapter that it is done paging by removing the previously added item
     *  at the index of @see android.support.v7.widget.RecyclerView.Adapter getItemCount() + 1
     */
    public void donePaging(){
        paging = false;

        notifyItemRemoved(getItemCount() + 1);
    }

    /**
     * Get the appropriate viewType for the recycler. If we are paging we return @see VIEW_TYPE_PAGING,
     * otherwise super it out.
     * @param position position in adapter
     * @return viewType
     */
    @Override
    public int getItemViewType(int position) {

        if(paging){
            return VIEW_TYPE_PAGING;
        }

        return super.getItemViewType(position);
    }

    /**
     * If there is a LoadingViewHolder in this position, inflate the view from getPagingLayout()
     * @param parent
     * @param viewType
     * @return LoadingViewHolder
     */
    @Override
    public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {

        if(viewType == VIEW_TYPE_PAGING){
            View itemView = LayoutInflater.from(parent.getContext()).inflate(getPagingLayout(), parent, false);

            return new PagingAdapter.LoadingViewHolder(itemView);
        }
        return null;
    }


    /**
     * If the PagingDelegate isFullSpanLoadingView(), then we should check to make sure its a StaggeredGrid, and then set
     * the span to full size.
     * @param holder
     * @param position
     */
    @Override
    public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {
        if(getItemViewType(position) == VIEW_TYPE_PAGING){

            if(pagingDelegate != null) {
                if(pagingDelegate.isFullspanLoadingView()) {
                    if (pagingDelegate.getRecyclerView().getLayoutManager() instanceof StaggeredGridLayoutManager) {
                        StaggeredGridLayoutManager.LayoutParams layoutParams = (StaggeredGridLayoutManager.LayoutParams) holder.itemView.getLayoutParams();

                        layoutParams.setFullSpan(true);
                    }
                }
            }
        }
    }
}


================================================
FILE: library/src/main/java/com/akiniyalocts/pagingrecycler/PagingDelegate.java
================================================
package com.akiniyalocts.pagingrecycler;

import android.support.v7.widget.RecyclerView;

/**
 * Intermediates between your @see PagingAdapter and your Activity.
 *
 * Create a new PagingDelegate with @see PagingDelegate.Builder();
 */
public class PagingDelegate extends RecyclerView.OnScrollListener{

    // Callbacks for when to page
    private OnPageListener onPageListener;

    // RecyclerView adapter attached
    private PagingAdapter pagingAdapter;


    private RecyclerView recyclerView;

    // Should the paging view span the entire list?
    private boolean fullspanLoadingView;

    // Automatically show the paging view
    private boolean autoPage;

    // Automatically hide the paging view
    private boolean autoCancel;

    private PagingDelegate() {}

    public void attach(RecyclerView recyclerView, PagingAdapter pagingAdapter){
        recyclerView.addOnScrollListener(this);
        this.pagingAdapter = pagingAdapter;
    }

    @Override
    public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
        super.onScrolled(recyclerView, dx, dy);

        if(!recyclerView.canScrollVertically(1)){
            onPageListener.onPage(pagingAdapter.getItemCount());
        }
    }

    public void setPaging(){
        pagingAdapter.setPaging();
    }

    public void donePaging(){
        pagingAdapter.donePaging();
    }


    private void setOnPageListener(OnPageListener onPageListener) {
        this.onPageListener = onPageListener;
    }

    private void setPagingAdapter(PagingAdapter pagingAdapter) {
        this.pagingAdapter = pagingAdapter;
    }

    private void setRecyclerView(RecyclerView recyclerView) {
        this.recyclerView = recyclerView;
        recyclerView.addOnScrollListener(this);
    }

    private void setAutoPage(boolean autoPage) {
        this.autoPage = autoPage;
    }

    private void setAutoCancel(boolean autoCancel) {
        this.autoCancel = autoCancel;
    }

    private void setFullspanLoadingView(boolean fullspanLoadingView) {
        this.fullspanLoadingView = fullspanLoadingView;
    }

    public boolean isFullspanLoadingView() {
        return fullspanLoadingView;
    }

    public RecyclerView getRecyclerView() {
        return recyclerView;
    }

    public interface OnPageListener{
        void onPage(int offset);

        void onDonePaging();
    }

    public static class Builder{


        private OnPageListener onPageListener;
        private PagingAdapter pagingAdapter;
        private RecyclerView recyclerView;

        private boolean autoPage = false;
        private boolean autoCancel = false;
        private boolean fullspanLoadingView = false;

        public Builder(PagingAdapter pagingAdapter){
            this.setPagingAdapter(pagingAdapter);
        }

        public Builder listenWith(OnPageListener listener){
            this.setOnPageListener(listener);
            return this;
        }

        public Builder attachTo(RecyclerView recyclerView){
            this.setRecyclerView(recyclerView);
            return this;
        }

        public Builder spanLoadingView(boolean fullspanLoadingView){
            this.fullspanLoadingView = fullspanLoadingView;
            return this;
        }

        public Builder autoPage(boolean autoPage){
            this.setAutoPage(autoPage);
            return this;
        }

        public Builder autoStop(boolean autoStop){
            this.setAutoCancel(autoStop);
            return this;
        }

        public PagingDelegate build(){
            PagingDelegate  pagingDelegate= new PagingDelegate();

            pagingDelegate.setOnPageListener(this.onPageListener);
            pagingDelegate.setRecyclerView(this.recyclerView);
            pagingDelegate.setPagingAdapter(this.pagingAdapter);
            pagingDelegate.setAutoCancel(this.autoCancel);
            pagingDelegate.setAutoPage(this.autoPage);
            pagingDelegate.setFullspanLoadingView(this.fullspanLoadingView);

            return pagingDelegate;
        }


        private void setOnPageListener(OnPageListener onPageListener) {
            this.onPageListener = onPageListener;
        }

        private void setPagingAdapter(PagingAdapter pagingAdapter) {
            this.pagingAdapter = pagingAdapter;
        }

        private void setRecyclerView(RecyclerView recyclerView) {
            this.recyclerView = recyclerView;
        }

        private void setAutoPage(boolean autoPage) {
            this.autoPage = autoPage;
        }

        private void setAutoCancel(boolean autoCancel) {
            this.autoCancel = autoCancel;
        }

    }
}


================================================
FILE: library/src/main/res/values/colors.xml
================================================
<?xml version="1.0" encoding="utf-8"?>
<resources>

</resources>


================================================
FILE: library/src/main/res/values/strings.xml
================================================
<resources>
    <string name="app_name">PagingRecycler</string>
</resources>


================================================
FILE: library/src/main/res/values/styles.xml
================================================
<resources>

<style name="AppTheme" parent="Theme.AppCompat.DayNight.NoActionBar">

</style>

</resources>


================================================
FILE: library/src/test/java/com/akiniyalocts/pagingrecycler/ExampleUnitTest.java
================================================
package com.akiniyalocts.pagingrecycler;

import org.junit.Test;

import static org.junit.Assert.*;

/**
 * To work on unit tests, switch the Test Artifact in the Build Variants view.
 */
public class ExampleUnitTest {
    @Test
    public void addition_isCorrect() throws Exception {
        assertEquals(4, 2 + 2);
    }
}

================================================
FILE: settings.gradle
================================================
include ':library'
Download .txt
gitextract_s3c1ibv1/

├── .gitignore
├── README.md
├── build.gradle
├── gradle/
│   └── wrapper/
│       ├── gradle-wrapper.jar
│       └── gradle-wrapper.properties
├── gradle.properties
├── gradlew
├── gradlew.bat
├── library/
│   ├── .gitignore
│   ├── build.gradle
│   ├── proguard-rules.pro
│   └── src/
│       ├── androidTest/
│       │   └── java/
│       │       └── com/
│       │           └── akiniyalocts/
│       │               └── pagingrecycler/
│       │                   └── ApplicationTest.java
│       ├── main/
│       │   ├── AndroidManifest.xml
│       │   ├── java/
│       │   │   └── com/
│       │   │       └── akiniyalocts/
│       │   │           └── pagingrecycler/
│       │   │               ├── PagingAdapter.java
│       │   │               └── PagingDelegate.java
│       │   └── res/
│       │       └── values/
│       │           ├── colors.xml
│       │           ├── strings.xml
│       │           └── styles.xml
│       └── test/
│           └── java/
│               └── com/
│                   └── akiniyalocts/
│                       └── pagingrecycler/
│                           └── ExampleUnitTest.java
└── settings.gradle
Download .txt
SYMBOL INDEX (47 symbols across 4 files)

FILE: library/src/androidTest/java/com/akiniyalocts/pagingrecycler/ApplicationTest.java
  class ApplicationTest (line 9) | public class ApplicationTest extends ApplicationTestCase<Application> {
    method ApplicationTest (line 10) | public ApplicationTest() {

FILE: library/src/main/java/com/akiniyalocts/pagingrecycler/PagingAdapter.java
  class PagingAdapter (line 16) | public abstract class PagingAdapter extends RecyclerView.Adapter<Recycle...
    class LoadingViewHolder (line 24) | static class LoadingViewHolder extends RecyclerView.ViewHolder{
      method LoadingViewHolder (line 25) | public LoadingViewHolder(View itemView) {
    method PagingAdapter (line 38) | public PagingAdapter() {
    method getPagingLayout (line 46) | public abstract int getPagingLayout();
    method getPagingItemCount (line 52) | public abstract int getPagingItemCount();
    method setPagingDelegate (line 54) | public void setPagingDelegate(PagingDelegate pagingDelegate) {
    method setPaging (line 62) | public void setPaging(){
    method getItemCount (line 81) | @Override
    method donePaging (line 90) | public void donePaging(){
    method getItemViewType (line 102) | @Override
    method onCreateViewHolder (line 118) | @Override
    method onBindViewHolder (line 136) | @Override

FILE: library/src/main/java/com/akiniyalocts/pagingrecycler/PagingDelegate.java
  class PagingDelegate (line 10) | public class PagingDelegate extends RecyclerView.OnScrollListener{
    method PagingDelegate (line 30) | private PagingDelegate() {}
    method attach (line 32) | public void attach(RecyclerView recyclerView, PagingAdapter pagingAdap...
    method onScrolled (line 37) | @Override
    method setPaging (line 46) | public void setPaging(){
    method donePaging (line 50) | public void donePaging(){
    method setOnPageListener (line 55) | private void setOnPageListener(OnPageListener onPageListener) {
    method setPagingAdapter (line 59) | private void setPagingAdapter(PagingAdapter pagingAdapter) {
    method setRecyclerView (line 63) | private void setRecyclerView(RecyclerView recyclerView) {
    method setAutoPage (line 68) | private void setAutoPage(boolean autoPage) {
    method setAutoCancel (line 72) | private void setAutoCancel(boolean autoCancel) {
    method setFullspanLoadingView (line 76) | private void setFullspanLoadingView(boolean fullspanLoadingView) {
    method isFullspanLoadingView (line 80) | public boolean isFullspanLoadingView() {
    method getRecyclerView (line 84) | public RecyclerView getRecyclerView() {
    type OnPageListener (line 88) | public interface OnPageListener{
      method onPage (line 89) | void onPage(int offset);
      method onDonePaging (line 91) | void onDonePaging();
    class Builder (line 94) | public static class Builder{
      method Builder (line 105) | public Builder(PagingAdapter pagingAdapter){
      method listenWith (line 109) | public Builder listenWith(OnPageListener listener){
      method attachTo (line 114) | public Builder attachTo(RecyclerView recyclerView){
      method spanLoadingView (line 119) | public Builder spanLoadingView(boolean fullspanLoadingView){
      method autoPage (line 124) | public Builder autoPage(boolean autoPage){
      method autoStop (line 129) | public Builder autoStop(boolean autoStop){
      method build (line 134) | public PagingDelegate build(){
      method setOnPageListener (line 148) | private void setOnPageListener(OnPageListener onPageListener) {
      method setPagingAdapter (line 152) | private void setPagingAdapter(PagingAdapter pagingAdapter) {
      method setRecyclerView (line 156) | private void setRecyclerView(RecyclerView recyclerView) {
      method setAutoPage (line 160) | private void setAutoPage(boolean autoPage) {
      method setAutoCancel (line 164) | private void setAutoCancel(boolean autoCancel) {

FILE: library/src/test/java/com/akiniyalocts/pagingrecycler/ExampleUnitTest.java
  class ExampleUnitTest (line 10) | public class ExampleUnitTest {
    method addition_isCorrect (line 11) | @Test
Condensed preview — 20 files, each showing path, character count, and a content snippet. Download the .json file or copy for the full structured content (27K chars).
[
  {
    "path": ".gitignore",
    "chars": 309,
    "preview": "target/\n.classpath\n.project\n.settings/\ngen/\nbin/\nlocal.properties\n.metadata/\n*.class\n*.apk\n*.res\n*.dex\n*.iml\nButtercupMo"
  },
  {
    "path": "README.md",
    "chars": 2773,
    "preview": "# PagingRecycler [![](https://jitpack.io/v/Batterii/PagingRecycler.svg)](https://jitpack.io/#Batterii/PagingRecycler)\n\nA"
  },
  {
    "path": "build.gradle",
    "chars": 498,
    "preview": "// Top-level build file where you can add configuration options common to all sub-projects/modules.\n\nbuildscript {\n    r"
  },
  {
    "path": "gradle/wrapper/gradle-wrapper.properties",
    "chars": 231,
    "preview": "#Mon Dec 28 10:00:20 PST 2015\ndistributionBase=GRADLE_USER_HOME\ndistributionPath=wrapper/dists\nzipStoreBase=GRADLE_USER_"
  },
  {
    "path": "gradle.properties",
    "chars": 855,
    "preview": "# Project-wide Gradle settings.\n\n# IDE (e.g. Android Studio) users:\n# Gradle settings configured through the IDE *will o"
  },
  {
    "path": "gradlew",
    "chars": 4971,
    "preview": "#!/usr/bin/env bash\n\n##############################################################################\n##\n##  Gradle start "
  },
  {
    "path": "gradlew.bat",
    "chars": 2404,
    "preview": "@if \"%DEBUG%\" == \"\" @echo off\r\n@rem ##########################################################################\r\n@rem\r\n@r"
  },
  {
    "path": "library/.gitignore",
    "chars": 316,
    "preview": "target/\n.classpath\n.project\n.settings/\ngen/\nbin/\nlocal.properties\n.metadata/\n*.class\n*.apk\n*.res\n*.dex\n*.iml\nButtercupMo"
  },
  {
    "path": "library/build.gradle",
    "chars": 629,
    "preview": "apply plugin: 'com.android.library'\n\nandroid {\n    compileSdkVersion 25\n    buildToolsVersion \"25.0.2\"\n\n    defaultConfi"
  },
  {
    "path": "library/proguard-rules.pro",
    "chars": 676,
    "preview": "# Add project specific ProGuard rules here.\n# By default, the flags in this file are appended to flags specified\n# in /U"
  },
  {
    "path": "library/src/androidTest/java/com/akiniyalocts/pagingrecycler/ApplicationTest.java",
    "chars": 362,
    "preview": "package com.akiniyalocts.pagingrecycler;\n\nimport android.app.Application;\nimport android.test.ApplicationTestCase;\n\n/**\n"
  },
  {
    "path": "library/src/main/AndroidManifest.xml",
    "chars": 284,
    "preview": "<manifest xmlns:android=\"http://schemas.android.com/apk/res/android\"\n    package=\"com.akiniyalocts.pagingrecycler\">\n\n   "
  },
  {
    "path": "library/src/main/java/com/akiniyalocts/pagingrecycler/PagingAdapter.java",
    "chars": 4576,
    "preview": "package com.akiniyalocts.pagingrecycler;\n\nimport android.os.Handler;\nimport android.support.v7.widget.RecyclerView;\nimpo"
  },
  {
    "path": "library/src/main/java/com/akiniyalocts/pagingrecycler/PagingDelegate.java",
    "chars": 4637,
    "preview": "package com.akiniyalocts.pagingrecycler;\n\nimport android.support.v7.widget.RecyclerView;\n\n/**\n * Intermediates between y"
  },
  {
    "path": "library/src/main/res/values/colors.xml",
    "chars": 65,
    "preview": "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<resources>\n\n</resources>\n"
  },
  {
    "path": "library/src/main/res/values/strings.xml",
    "chars": 77,
    "preview": "<resources>\n    <string name=\"app_name\">PagingRecycler</string>\n</resources>\n"
  },
  {
    "path": "library/src/main/res/values/styles.xml",
    "chars": 107,
    "preview": "<resources>\n\n<style name=\"AppTheme\" parent=\"Theme.AppCompat.DayNight.NoActionBar\">\n\n</style>\n\n</resources>\n"
  },
  {
    "path": "library/src/test/java/com/akiniyalocts/pagingrecycler/ExampleUnitTest.java",
    "chars": 324,
    "preview": "package com.akiniyalocts.pagingrecycler;\n\nimport org.junit.Test;\n\nimport static org.junit.Assert.*;\n\n/**\n * To work on u"
  },
  {
    "path": "settings.gradle",
    "chars": 19,
    "preview": "include ':library'\n"
  }
]

// ... and 1 more files (download for full content)

About this extraction

This page contains the full source code of the Batterii/PagingRecycler GitHub repository, extracted and formatted as plain text for AI agents and large language models (LLMs). The extraction includes 20 files (23.5 KB), approximately 6.6k tokens, and a symbol index with 47 extracted functions, classes, methods, constants, and types. Use this with OpenClaw, Claude, ChatGPT, Cursor, Windsurf, or any other AI tool that accepts text input. You can copy the full output to your clipboard or download it as a .txt file.

Extracted by GitExtract — free GitHub repo to text converter for AI. Built by Nikandr Surkov.

Copied to clipboard!