[
  {
    "path": ".gitignore",
    "content": "target/\n.classpath\n.project\n.settings/\ngen/\nbin/\nlocal.properties\n.metadata/\n*.class\n*.apk\n*.res\n*.dex\n*.iml\nButtercupMobile/out\n.idea\n.gradle/\nButtercupMobile/obj\n.gradle\nlocal.properties\n.DS_Store\nbuild/\n*.iml\n.idea/\n*.swp\ncom_crashlytics_export_strings.xml\ncrashlytics-build.properties\najcore.*\n.navgation/"
  },
  {
    "path": "README.md",
    "content": "# PagingRecycler [![](https://jitpack.io/v/Batterii/PagingRecycler.svg)](https://jitpack.io/#Batterii/PagingRecycler)\n\nA 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.\n### Gradle\n```gradle\n\n  allprojects {\n\t\trepositories {\n\t\t\t...\n\t\t\tmaven { url \"https://jitpack.io\" }\n\t\t}\n\t}\n\n\t\tdependencies {\n\t        compile 'com.github.Batterii:PagingRecycler:v1.1.1'\n\t}\n```\n## Usage\n### Adapter\n```java\n\npublic class MyAdapter extends PagingAdapter{\n\n  private List<Item> myItems;\n\n  public MyAdapter(){\n    myItems = new ArrayList<>();\n  }\n\n  @Override\n    public int getPagingLayout() {\n        return R.layout.paging_item;\n  }\n\n  @Override\n  public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {\n    // Do your normal view creation\n\n    // End with this\n    return super.onCreateViewHolder(parent, viewType);\n\n  }  \n\n  @Override\n  public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {\n    // Call super!\n    super.onBindViewHolder(holder, position);\n\n    // Do your normal binding\n\n  }\n\n  @Override\n  public int getItemCount() {\n    // just return super here\n    return super.getItemCount();\n  }\n\n  @Override\n  public int getPagingItemCount() {\n    // return your actual item size here\n    return myItems.size();\n  }\n\n}\n```\n\n### Your Activity/Fragment etc.\n```java\n\npublic class MyActivity extends AppCompatActivity implements PagingDelegate.OnPageListener{\n\n @Override\n  public void onCreate(Bundle savedInstanceState) {\n      super.onCreate(savedInstanceState);\n\n      MyAdapter adapter = new MyAdapter();\n\n      RecyclerView mRecycler = (RecyclerView)findViewById(R.id.my_recycler);\n\n      PagingDelegate pagingDelegate = new PagingDelegate.Builder(adapter)\n                .attachTo(mRecycler)\n                .listenWith(this)\n                .build();\n\n      mRecycler.setAdapter(adapter);\n  }\n\n   @Override\n    public void onPage(int offset) {\n        // Perform your paging request\n    }\n\n    @Override\n    public void onDonePaging() {\n\n    }\n\n  }\n```\n\nLicense\n--------\n\n    Licensed under the Apache License, Version 2.0 (the \"License\");\n    you may not use this file except in compliance with the License.\n    You may obtain a copy of the License at\n\n       http://www.apache.org/licenses/LICENSE-2.0\n\n    Unless required by applicable law or agreed to in writing, software\n    distributed under the License is distributed on an \"AS IS\" BASIS,\n    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n    See the License for the specific language governing permissions and\n    limitations under the License.\n"
  },
  {
    "path": "build.gradle",
    "content": "// Top-level build file where you can add configuration options common to all sub-projects/modules.\n\nbuildscript {\n    repositories {\n        jcenter()\n    }\n    dependencies {\n        classpath 'com.android.tools.build:gradle:1.5.0'\n\n        // NOTE: Do not place your application dependencies here; they belong\n        // in the individual module build.gradle files\n    }\n}\n\nallprojects {\n    repositories {\n        jcenter()\n    }\n}\n\ntask clean(type: Delete) {\n    delete rootProject.buildDir\n}\n"
  },
  {
    "path": "gradle/wrapper/gradle-wrapper.properties",
    "content": "#Mon Dec 28 10:00:20 PST 2015\ndistributionBase=GRADLE_USER_HOME\ndistributionPath=wrapper/dists\nzipStoreBase=GRADLE_USER_HOME\nzipStorePath=wrapper/dists\ndistributionUrl=https\\://services.gradle.org/distributions/gradle-2.10-all.zip\n"
  },
  {
    "path": "gradle.properties",
    "content": "# Project-wide Gradle settings.\n\n# IDE (e.g. Android Studio) users:\n# Gradle settings configured through the IDE *will override*\n# any settings specified in this file.\n\n# For more details on how to configure your build environment visit\n# http://www.gradle.org/docs/current/userguide/build_environment.html\n\n# Specifies the JVM arguments used for the daemon process.\n# The setting is particularly useful for tweaking memory settings.\n# Default value: -Xmx10248m -XX:MaxPermSize=256m\n# org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8\n\n# When configured, Gradle will run in incubating parallel mode.\n# This option should only be used with decoupled projects. More details, visit\n# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects\n# org.gradle.parallel=true"
  },
  {
    "path": "gradlew",
    "content": "#!/usr/bin/env bash\n\n##############################################################################\n##\n##  Gradle start up script for UN*X\n##\n##############################################################################\n\n# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.\nDEFAULT_JVM_OPTS=\"\"\n\nAPP_NAME=\"Gradle\"\nAPP_BASE_NAME=`basename \"$0\"`\n\n# Use the maximum available, or set MAX_FD != -1 to use that value.\nMAX_FD=\"maximum\"\n\nwarn ( ) {\n    echo \"$*\"\n}\n\ndie ( ) {\n    echo\n    echo \"$*\"\n    echo\n    exit 1\n}\n\n# OS specific support (must be 'true' or 'false').\ncygwin=false\nmsys=false\ndarwin=false\ncase \"`uname`\" in\n  CYGWIN* )\n    cygwin=true\n    ;;\n  Darwin* )\n    darwin=true\n    ;;\n  MINGW* )\n    msys=true\n    ;;\nesac\n\n# Attempt to set APP_HOME\n# Resolve links: $0 may be a link\nPRG=\"$0\"\n# Need this for relative symlinks.\nwhile [ -h \"$PRG\" ] ; do\n    ls=`ls -ld \"$PRG\"`\n    link=`expr \"$ls\" : '.*-> \\(.*\\)$'`\n    if expr \"$link\" : '/.*' > /dev/null; then\n        PRG=\"$link\"\n    else\n        PRG=`dirname \"$PRG\"`\"/$link\"\n    fi\ndone\nSAVED=\"`pwd`\"\ncd \"`dirname \\\"$PRG\\\"`/\" >/dev/null\nAPP_HOME=\"`pwd -P`\"\ncd \"$SAVED\" >/dev/null\n\nCLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar\n\n# Determine the Java command to use to start the JVM.\nif [ -n \"$JAVA_HOME\" ] ; then\n    if [ -x \"$JAVA_HOME/jre/sh/java\" ] ; then\n        # IBM's JDK on AIX uses strange locations for the executables\n        JAVACMD=\"$JAVA_HOME/jre/sh/java\"\n    else\n        JAVACMD=\"$JAVA_HOME/bin/java\"\n    fi\n    if [ ! -x \"$JAVACMD\" ] ; then\n        die \"ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME\n\nPlease set the JAVA_HOME variable in your environment to match the\nlocation of your Java installation.\"\n    fi\nelse\n    JAVACMD=\"java\"\n    which java >/dev/null 2>&1 || die \"ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.\n\nPlease set the JAVA_HOME variable in your environment to match the\nlocation of your Java installation.\"\nfi\n\n# Increase the maximum file descriptors if we can.\nif [ \"$cygwin\" = \"false\" -a \"$darwin\" = \"false\" ] ; then\n    MAX_FD_LIMIT=`ulimit -H -n`\n    if [ $? -eq 0 ] ; then\n        if [ \"$MAX_FD\" = \"maximum\" -o \"$MAX_FD\" = \"max\" ] ; then\n            MAX_FD=\"$MAX_FD_LIMIT\"\n        fi\n        ulimit -n $MAX_FD\n        if [ $? -ne 0 ] ; then\n            warn \"Could not set maximum file descriptor limit: $MAX_FD\"\n        fi\n    else\n        warn \"Could not query maximum file descriptor limit: $MAX_FD_LIMIT\"\n    fi\nfi\n\n# For Darwin, add options to specify how the application appears in the dock\nif $darwin; then\n    GRADLE_OPTS=\"$GRADLE_OPTS \\\"-Xdock:name=$APP_NAME\\\" \\\"-Xdock:icon=$APP_HOME/media/gradle.icns\\\"\"\nfi\n\n# For Cygwin, switch paths to Windows format before running java\nif $cygwin ; then\n    APP_HOME=`cygpath --path --mixed \"$APP_HOME\"`\n    CLASSPATH=`cygpath --path --mixed \"$CLASSPATH\"`\n    JAVACMD=`cygpath --unix \"$JAVACMD\"`\n\n    # We build the pattern for arguments to be converted via cygpath\n    ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`\n    SEP=\"\"\n    for dir in $ROOTDIRSRAW ; do\n        ROOTDIRS=\"$ROOTDIRS$SEP$dir\"\n        SEP=\"|\"\n    done\n    OURCYGPATTERN=\"(^($ROOTDIRS))\"\n    # Add a user-defined pattern to the cygpath arguments\n    if [ \"$GRADLE_CYGPATTERN\" != \"\" ] ; then\n        OURCYGPATTERN=\"$OURCYGPATTERN|($GRADLE_CYGPATTERN)\"\n    fi\n    # Now convert the arguments - kludge to limit ourselves to /bin/sh\n    i=0\n    for arg in \"$@\" ; do\n        CHECK=`echo \"$arg\"|egrep -c \"$OURCYGPATTERN\" -`\n        CHECK2=`echo \"$arg\"|egrep -c \"^-\"`                                 ### Determine if an option\n\n        if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then                    ### Added a condition\n            eval `echo args$i`=`cygpath --path --ignore --mixed \"$arg\"`\n        else\n            eval `echo args$i`=\"\\\"$arg\\\"\"\n        fi\n        i=$((i+1))\n    done\n    case $i in\n        (0) set -- ;;\n        (1) set -- \"$args0\" ;;\n        (2) set -- \"$args0\" \"$args1\" ;;\n        (3) set -- \"$args0\" \"$args1\" \"$args2\" ;;\n        (4) set -- \"$args0\" \"$args1\" \"$args2\" \"$args3\" ;;\n        (5) set -- \"$args0\" \"$args1\" \"$args2\" \"$args3\" \"$args4\" ;;\n        (6) set -- \"$args0\" \"$args1\" \"$args2\" \"$args3\" \"$args4\" \"$args5\" ;;\n        (7) set -- \"$args0\" \"$args1\" \"$args2\" \"$args3\" \"$args4\" \"$args5\" \"$args6\" ;;\n        (8) set -- \"$args0\" \"$args1\" \"$args2\" \"$args3\" \"$args4\" \"$args5\" \"$args6\" \"$args7\" ;;\n        (9) set -- \"$args0\" \"$args1\" \"$args2\" \"$args3\" \"$args4\" \"$args5\" \"$args6\" \"$args7\" \"$args8\" ;;\n    esac\nfi\n\n# Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules\nfunction splitJvmOpts() {\n    JVM_OPTS=(\"$@\")\n}\neval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS\nJVM_OPTS[${#JVM_OPTS[*]}]=\"-Dorg.gradle.appname=$APP_BASE_NAME\"\n\nexec \"$JAVACMD\" \"${JVM_OPTS[@]}\" -classpath \"$CLASSPATH\" org.gradle.wrapper.GradleWrapperMain \"$@\"\n"
  },
  {
    "path": "gradlew.bat",
    "content": "@if \"%DEBUG%\" == \"\" @echo off\r\n@rem ##########################################################################\r\n@rem\r\n@rem  Gradle startup script for Windows\r\n@rem\r\n@rem ##########################################################################\r\n\r\n@rem Set local scope for the variables with windows NT shell\r\nif \"%OS%\"==\"Windows_NT\" setlocal\r\n\r\n@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.\r\nset DEFAULT_JVM_OPTS=\r\n\r\nset DIRNAME=%~dp0\r\nif \"%DIRNAME%\" == \"\" set DIRNAME=.\r\nset APP_BASE_NAME=%~n0\r\nset APP_HOME=%DIRNAME%\r\n\r\n@rem Find java.exe\r\nif defined JAVA_HOME goto findJavaFromJavaHome\r\n\r\nset JAVA_EXE=java.exe\r\n%JAVA_EXE% -version >NUL 2>&1\r\nif \"%ERRORLEVEL%\" == \"0\" goto init\r\n\r\necho.\r\necho ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.\r\necho.\r\necho Please set the JAVA_HOME variable in your environment to match the\r\necho location of your Java installation.\r\n\r\ngoto fail\r\n\r\n:findJavaFromJavaHome\r\nset JAVA_HOME=%JAVA_HOME:\"=%\r\nset JAVA_EXE=%JAVA_HOME%/bin/java.exe\r\n\r\nif exist \"%JAVA_EXE%\" goto init\r\n\r\necho.\r\necho ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%\r\necho.\r\necho Please set the JAVA_HOME variable in your environment to match the\r\necho location of your Java installation.\r\n\r\ngoto fail\r\n\r\n:init\r\n@rem Get command-line arguments, handling Windowz variants\r\n\r\nif not \"%OS%\" == \"Windows_NT\" goto win9xME_args\r\nif \"%@eval[2+2]\" == \"4\" goto 4NT_args\r\n\r\n:win9xME_args\r\n@rem Slurp the command line arguments.\r\nset CMD_LINE_ARGS=\r\nset _SKIP=2\r\n\r\n:win9xME_args_slurp\r\nif \"x%~1\" == \"x\" goto execute\r\n\r\nset CMD_LINE_ARGS=%*\r\ngoto execute\r\n\r\n:4NT_args\r\n@rem Get arguments from the 4NT Shell from JP Software\r\nset CMD_LINE_ARGS=%$\r\n\r\n:execute\r\n@rem Setup the command line\r\n\r\nset CLASSPATH=%APP_HOME%\\gradle\\wrapper\\gradle-wrapper.jar\r\n\r\n@rem Execute Gradle\r\n\"%JAVA_EXE%\" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% \"-Dorg.gradle.appname=%APP_BASE_NAME%\" -classpath \"%CLASSPATH%\" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%\r\n\r\n:end\r\n@rem End local scope for the variables with windows NT shell\r\nif \"%ERRORLEVEL%\"==\"0\" goto mainEnd\r\n\r\n:fail\r\nrem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of\r\nrem the _cmd.exe /c_ return code!\r\nif  not \"\" == \"%GRADLE_EXIT_CONSOLE%\" exit 1\r\nexit /b 1\r\n\r\n:mainEnd\r\nif \"%OS%\"==\"Windows_NT\" endlocal\r\n\r\n:omega\r\n"
  },
  {
    "path": "library/.gitignore",
    "content": "target/\n.classpath\n.project\n.settings/\ngen/\nbin/\nlocal.properties\n.metadata/\n*.class\n*.apk\n*.res\n*.dex\n*.iml\nButtercupMobile/out\n.idea\n.gradle/\nButtercupMobile/obj\n.gradle\nlocal.properties\n.DS_Store\nbuild/\n*.iml\n.idea/\n*.swp\ncom_crashlytics_export_strings.xml\ncrashlytics-build.properties\najcore.*\n.navgation/\n/build"
  },
  {
    "path": "library/build.gradle",
    "content": "apply plugin: 'com.android.library'\n\nandroid {\n    compileSdkVersion 25\n    buildToolsVersion \"25.0.2\"\n\n    defaultConfig {\n        minSdkVersion 15\n        targetSdkVersion 25\n        versionCode 1\n        versionName \"1.0\"\n    }\n    buildTypes {\n        release {\n            minifyEnabled false\n            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'\n        }\n    }\n}\n\ndependencies {\n    compile fileTree(dir: 'libs', include: ['*.jar'])\n    testCompile 'junit:junit:4.12'\n    compile 'com.android.support:appcompat-v7:25.3.0'\n    compile 'com.android.support:recyclerview-v7:25.3.0'\n}\n"
  },
  {
    "path": "library/proguard-rules.pro",
    "content": "# Add project specific ProGuard rules here.\n# By default, the flags in this file are appended to flags specified\n# in /Users/anthonykiniyalocts/Library/Android/sdk/tools/proguard/proguard-android.txt\n# You can edit the include path and order by changing the proguardFiles\n# directive in build.gradle.\n#\n# For more details, see\n#   http://developer.android.com/guide/developing/tools/proguard.html\n\n# Add any project specific keep options here:\n\n# If your project uses WebView with JS, uncomment the following\n# and specify the fully qualified class name to the JavaScript interface\n# class:\n#-keepclassmembers class fqcn.of.javascript.interface.for.webview {\n#   public *;\n#}\n"
  },
  {
    "path": "library/src/androidTest/java/com/akiniyalocts/pagingrecycler/ApplicationTest.java",
    "content": "package com.akiniyalocts.pagingrecycler;\n\nimport android.app.Application;\nimport android.test.ApplicationTestCase;\n\n/**\n * <a href=\"http://d.android.com/tools/testing/testing_android.html\">Testing Fundamentals</a>\n */\npublic class ApplicationTest extends ApplicationTestCase<Application> {\n    public ApplicationTest() {\n        super(Application.class);\n    }\n}"
  },
  {
    "path": "library/src/main/AndroidManifest.xml",
    "content": "<manifest xmlns:android=\"http://schemas.android.com/apk/res/android\"\n    package=\"com.akiniyalocts.pagingrecycler\">\n\n    <application\n        android:allowBackup=\"true\"\n        android:label=\"@string/app_name\"\n        android:theme=\"@style/AppTheme\">\n\n    </application>\n\n</manifest>\n"
  },
  {
    "path": "library/src/main/java/com/akiniyalocts/pagingrecycler/PagingAdapter.java",
    "content": "package com.akiniyalocts.pagingrecycler;\n\nimport android.os.Handler;\nimport android.support.v7.widget.RecyclerView;\nimport android.support.v7.widget.StaggeredGridLayoutManager;\nimport android.view.LayoutInflater;\nimport android.view.View;\nimport android.view.ViewGroup;\n\n/**\n * Created by AKiniyalocts on 3/21/16.\n *\n * An extension of @see android.support.v7.widget.RecyclerView.Adapter that simplifies the common\n * \"paging\" pattern we see in clients. @see PagingDelegate\n */\npublic abstract class PagingAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder>{\n\n    // View tag for paging view\n    public static int VIEW_TYPE_PAGING = -100;\n\n    private final Handler postHandler;\n\n    // Empty ViewHolder for paging view\n    static class LoadingViewHolder extends RecyclerView.ViewHolder{\n        public LoadingViewHolder(View itemView) {\n            super(itemView);\n        }\n    }\n\n    // Are we currently paging?\n    protected boolean paging = false;\n\n    /**\n     * @see PagingDelegate\n     */\n    private PagingDelegate pagingDelegate;\n\n    public PagingAdapter() {\n        postHandler = new Handler();\n    }\n\n    /**\n     * Provide the layout you wish to inflate when the adapter is loading\n     * @return R.layout.your_loading_layout\n     */\n    public abstract int getPagingLayout();\n\n    /**\n     * Provide a count of items in your adapter. Use this instead of getItemCount();\n     * @return itemCount\n     */\n    public abstract int getPagingItemCount();\n\n    public void setPagingDelegate(PagingDelegate pagingDelegate) {\n        this.pagingDelegate = pagingDelegate;\n    }\n\n    /**\n     *  Notify the adapter that it is paging by inserting an new item at the index of\n     *  @see android.support.v7.widget.RecyclerView.Adapter getItemCount() + 1\n     */\n    public void setPaging(){\n        if(!paging) {\n            paging = true;\n\n            final Runnable r = new Runnable() {\n                public void run() {\n                    PagingAdapter.this.notifyItemInserted(getItemCount() + 1);\n                }\n            };\n\n            postHandler.post(r);\n        }\n    }\n\n    /**\n     * If the adapter is paging, return the original item size + 1 to account for the new paging view\n     * in the RecyclerView. Otherwise, return item amount.\n     * @return int currentItemCount\n     */\n    @Override\n    public int getItemCount() {\n        return paging ? getPagingItemCount() + 1: getPagingItemCount();\n    }\n\n    /**\n     *  Notify the adapter that it is done paging by removing the previously added item\n     *  at the index of @see android.support.v7.widget.RecyclerView.Adapter getItemCount() + 1\n     */\n    public void donePaging(){\n        paging = false;\n\n        notifyItemRemoved(getItemCount() + 1);\n    }\n\n    /**\n     * Get the appropriate viewType for the recycler. If we are paging we return @see VIEW_TYPE_PAGING,\n     * otherwise super it out.\n     * @param position position in adapter\n     * @return viewType\n     */\n    @Override\n    public int getItemViewType(int position) {\n\n        if(paging){\n            return VIEW_TYPE_PAGING;\n        }\n\n        return super.getItemViewType(position);\n    }\n\n    /**\n     * If there is a LoadingViewHolder in this position, inflate the view from getPagingLayout()\n     * @param parent\n     * @param viewType\n     * @return LoadingViewHolder\n     */\n    @Override\n    public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {\n\n        if(viewType == VIEW_TYPE_PAGING){\n            View itemView = LayoutInflater.from(parent.getContext()).inflate(getPagingLayout(), parent, false);\n\n            return new PagingAdapter.LoadingViewHolder(itemView);\n        }\n        return null;\n    }\n\n\n    /**\n     * If the PagingDelegate isFullSpanLoadingView(), then we should check to make sure its a StaggeredGrid, and then set\n     * the span to full size.\n     * @param holder\n     * @param position\n     */\n    @Override\n    public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {\n        if(getItemViewType(position) == VIEW_TYPE_PAGING){\n\n            if(pagingDelegate != null) {\n                if(pagingDelegate.isFullspanLoadingView()) {\n                    if (pagingDelegate.getRecyclerView().getLayoutManager() instanceof StaggeredGridLayoutManager) {\n                        StaggeredGridLayoutManager.LayoutParams layoutParams = (StaggeredGridLayoutManager.LayoutParams) holder.itemView.getLayoutParams();\n\n                        layoutParams.setFullSpan(true);\n                    }\n                }\n            }\n        }\n    }\n}\n"
  },
  {
    "path": "library/src/main/java/com/akiniyalocts/pagingrecycler/PagingDelegate.java",
    "content": "package com.akiniyalocts.pagingrecycler;\n\nimport android.support.v7.widget.RecyclerView;\n\n/**\n * Intermediates between your @see PagingAdapter and your Activity.\n *\n * Create a new PagingDelegate with @see PagingDelegate.Builder();\n */\npublic class PagingDelegate extends RecyclerView.OnScrollListener{\n\n    // Callbacks for when to page\n    private OnPageListener onPageListener;\n\n    // RecyclerView adapter attached\n    private PagingAdapter pagingAdapter;\n\n\n    private RecyclerView recyclerView;\n\n    // Should the paging view span the entire list?\n    private boolean fullspanLoadingView;\n\n    // Automatically show the paging view\n    private boolean autoPage;\n\n    // Automatically hide the paging view\n    private boolean autoCancel;\n\n    private PagingDelegate() {}\n\n    public void attach(RecyclerView recyclerView, PagingAdapter pagingAdapter){\n        recyclerView.addOnScrollListener(this);\n        this.pagingAdapter = pagingAdapter;\n    }\n\n    @Override\n    public void onScrolled(RecyclerView recyclerView, int dx, int dy) {\n        super.onScrolled(recyclerView, dx, dy);\n\n        if(!recyclerView.canScrollVertically(1)){\n            onPageListener.onPage(pagingAdapter.getItemCount());\n        }\n    }\n\n    public void setPaging(){\n        pagingAdapter.setPaging();\n    }\n\n    public void donePaging(){\n        pagingAdapter.donePaging();\n    }\n\n\n    private void setOnPageListener(OnPageListener onPageListener) {\n        this.onPageListener = onPageListener;\n    }\n\n    private void setPagingAdapter(PagingAdapter pagingAdapter) {\n        this.pagingAdapter = pagingAdapter;\n    }\n\n    private void setRecyclerView(RecyclerView recyclerView) {\n        this.recyclerView = recyclerView;\n        recyclerView.addOnScrollListener(this);\n    }\n\n    private void setAutoPage(boolean autoPage) {\n        this.autoPage = autoPage;\n    }\n\n    private void setAutoCancel(boolean autoCancel) {\n        this.autoCancel = autoCancel;\n    }\n\n    private void setFullspanLoadingView(boolean fullspanLoadingView) {\n        this.fullspanLoadingView = fullspanLoadingView;\n    }\n\n    public boolean isFullspanLoadingView() {\n        return fullspanLoadingView;\n    }\n\n    public RecyclerView getRecyclerView() {\n        return recyclerView;\n    }\n\n    public interface OnPageListener{\n        void onPage(int offset);\n\n        void onDonePaging();\n    }\n\n    public static class Builder{\n\n\n        private OnPageListener onPageListener;\n        private PagingAdapter pagingAdapter;\n        private RecyclerView recyclerView;\n\n        private boolean autoPage = false;\n        private boolean autoCancel = false;\n        private boolean fullspanLoadingView = false;\n\n        public Builder(PagingAdapter pagingAdapter){\n            this.setPagingAdapter(pagingAdapter);\n        }\n\n        public Builder listenWith(OnPageListener listener){\n            this.setOnPageListener(listener);\n            return this;\n        }\n\n        public Builder attachTo(RecyclerView recyclerView){\n            this.setRecyclerView(recyclerView);\n            return this;\n        }\n\n        public Builder spanLoadingView(boolean fullspanLoadingView){\n            this.fullspanLoadingView = fullspanLoadingView;\n            return this;\n        }\n\n        public Builder autoPage(boolean autoPage){\n            this.setAutoPage(autoPage);\n            return this;\n        }\n\n        public Builder autoStop(boolean autoStop){\n            this.setAutoCancel(autoStop);\n            return this;\n        }\n\n        public PagingDelegate build(){\n            PagingDelegate  pagingDelegate= new PagingDelegate();\n\n            pagingDelegate.setOnPageListener(this.onPageListener);\n            pagingDelegate.setRecyclerView(this.recyclerView);\n            pagingDelegate.setPagingAdapter(this.pagingAdapter);\n            pagingDelegate.setAutoCancel(this.autoCancel);\n            pagingDelegate.setAutoPage(this.autoPage);\n            pagingDelegate.setFullspanLoadingView(this.fullspanLoadingView);\n\n            return pagingDelegate;\n        }\n\n\n        private void setOnPageListener(OnPageListener onPageListener) {\n            this.onPageListener = onPageListener;\n        }\n\n        private void setPagingAdapter(PagingAdapter pagingAdapter) {\n            this.pagingAdapter = pagingAdapter;\n        }\n\n        private void setRecyclerView(RecyclerView recyclerView) {\n            this.recyclerView = recyclerView;\n        }\n\n        private void setAutoPage(boolean autoPage) {\n            this.autoPage = autoPage;\n        }\n\n        private void setAutoCancel(boolean autoCancel) {\n            this.autoCancel = autoCancel;\n        }\n\n    }\n}\n"
  },
  {
    "path": "library/src/main/res/values/colors.xml",
    "content": "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<resources>\n\n</resources>\n"
  },
  {
    "path": "library/src/main/res/values/strings.xml",
    "content": "<resources>\n    <string name=\"app_name\">PagingRecycler</string>\n</resources>\n"
  },
  {
    "path": "library/src/main/res/values/styles.xml",
    "content": "<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",
    "content": "package com.akiniyalocts.pagingrecycler;\n\nimport org.junit.Test;\n\nimport static org.junit.Assert.*;\n\n/**\n * To work on unit tests, switch the Test Artifact in the Build Variants view.\n */\npublic class ExampleUnitTest {\n    @Test\n    public void addition_isCorrect() throws Exception {\n        assertEquals(4, 2 + 2);\n    }\n}"
  },
  {
    "path": "settings.gradle",
    "content": "include ':library'\n"
  }
]