-
Notifications
You must be signed in to change notification settings - Fork 81
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Archive Block pagination doesn't work correctly for posts #40
Comments
I can confirm I'm seeing the duplicate posts when visiting URLs like the following, so it's coming from the backend rather than a frontend bug. http://localhost:3000/api/posts?depth=0&limit=3&page=1&sort=-publishedDate http://localhost:3000/api/posts?depth=0&limit=3&page=2&sort=-publishedDate The issue goes away when sorting by id instead. I confirmed that I don't have any duplicate publish dates that might cause different search results each time: payloadcms/payload#2409 and payloadcms/payload#3209 may be related |
The fundamental issue seems to be that a field called import type { MigrateDownArgs, MigrateUpArgs } from '@payloadcms/db-mongodb'
export async function up({ payload }: MigrateUpArgs): Promise<void> {
const postsCollection = await payload.find({ collection: 'posts', pagination: false })
for (const doc of postsCollection.docs) {
// eslint-disable-next-line @typescript-eslint/no-explicit-any
const oldDoc = doc as any
if (oldDoc.publishedOn) {
await payload.update({
id: doc.id,
collection: 'posts',
data: { publishedDate: oldDoc.publishedOn },
overrideAccess: true,
})
}
}
}
export async function down({ payload }: MigrateDownArgs): Promise<void> {
const postsCollection = await payload.find({ collection: 'posts', pagination: false })
for (const doc of postsCollection.docs) {
if (doc.publishedDate) {
await payload.update({
id: doc.id,
collection: 'posts',
// eslint-disable-next-line @typescript-eslint/no-explicit-any
data: { publishedDate: null, publishedOn: doc.publishedDate } as any,
overrideAccess: true,
})
}
}
} For the public-demo project, seems the easiest would be just to rename the field so it's consistent across collections, but maybe it was different for a reason. I'd be happy to make a PR if someone on the team confirms that you want them consistent. |
Seems to work fine for projects, interestingly.
I played with it a bit but haven't yet figured out exactly what's going on as I'm still learning payload (edit: I think I found the issue in #40 (comment)). If I find anything I'll share it here. I'm at least fairly certain that it's something on the server side rather than the client app.
Screen.Recording.2024-02-03.at.21.57.44.mov
The text was updated successfully, but these errors were encountered: