data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt=""
Does anyone have a properly implemented example code for pagination ? I am thinking of using the cursorAfter and cursorBefore to lazily load the feed data but would be great to get some good examples on how to go about it.
data:image/s3,"s3://crabby-images/bdd71/bdd714b9dc7c3c77551add1af2a7fca7484903e3" alt=""
Hi, while I search for examples, gonna leave this here for reference: https://dev.to/appwrite/this-is-why-you-should-use-cursor-pagination-4nh5
data:image/s3,"s3://crabby-images/bdd71/bdd714b9dc7c3c77551add1af2a7fca7484903e3" alt=""
Example of cursor pagination loading all pages: https://github.com/Meldiron/almost-gist/blob/main/backend/functions/onGistChange/src/index.js#L116-L143
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt=""
I'll check it out. Thanks Jyoti
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt=""
@joeyouss Shouldn't this example return all the documents ?
return [
...response.documents,
...(await getAllPages(collectionId, queries, nextCursor))
]
}
The await function will keep executing till it finds all the documents. How would it be different than listing the entire collection at once ?
data:image/s3,"s3://crabby-images/8929a/8929ae5732ba08ddcab685591e64f879390543b2" alt=""
That's a recursive function that calls itself until it fetches all pages so there are multiple API calls to get all the data
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt=""
True but from what i understand, it will recursively call till it fetches all the documents from the collection right and finally returns an entire array of it ? This does not look not like it is being lazily loaded for infinitely scrolling a feed.
data:image/s3,"s3://crabby-images/8929a/8929ae5732ba08ddcab685591e64f879390543b2" alt=""
No it is not, but perhaps it shows you how to use the cursor
data:image/s3,"s3://crabby-images/8929a/8929ae5732ba08ddcab685591e64f879390543b2" alt=""
The rest depends on your front end. You would make another list documents API call when you're towards the end of your list
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt=""
thanks for clarifying, the api documentation covers the cursor usage well. I was just wondering how we would actually implement it in a flutter app. If i wanted to fetch all documents, i would just listDocuments the entire collection though.
data:image/s3,"s3://crabby-images/8929a/8929ae5732ba08ddcab685591e64f879390543b2" alt=""
Maybe this will help: https://pub.dev/packages/infinite_scroll_pagination
data:image/s3,"s3://crabby-images/8929a/8929ae5732ba08ddcab685591e64f879390543b2" alt=""
I'm pretty sure I've also seen tutorials online for how to implement infinite scrolling.
data:image/s3,"s3://crabby-images/8929a/8929ae5732ba08ddcab685591e64f879390543b2" alt=""
The general idea is all the same..once the user reaches the end or as they get close to the end, fetch more data
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt=""
This sounds interesting. I'll check it out, thanks !
Recommended threads
- OAuth2 Google and Apple throws 409 user ...
Hello everyone. I’m using the cloud appwrite to auth my users. Originally I have had a sign in work successfully and the flow worked well. Suddenly with zero ...
- Redirect URL for Flutter Web App with Go...
May I know is there anyone can help with this matter? I'm so lost for my web. The account info is created after login using google. However, it does not lead to...
- Access to appwrite pro from GitHub educa...
Is the offer to get free appwrite pro from GitHub education still available?
data:image/s3,"s3://crabby-images/88b4b/88b4b3aac34845c367ed1d6b399a22b7c8c8713b" alt=""