### What? Makes it possible to filter join documents using a `where` added directly in the config. ### Why? It makes the join field more powerful for adding contextual meaning to the documents being returned. For example, maybe you have a `requiresAction` field that you set and you can have a join that automatically filters the documents to those that need attention. ### How? In the database adapter, we merge the requested `where` to the `where` defined on the field. On the frontend the results are filtered using the `filterOptions` property in the component. Fixes https://github.com/payloadcms/payload/discussions/8936 https://github.com/payloadcms/payload/discussions/8937 --------- Co-authored-by: Sasha <64744993+r1tsuu@users.noreply.github.com>
104 lines
2.2 KiB
TypeScript
104 lines
2.2 KiB
TypeScript
import type { CollectionConfig } from 'payload'
|
|
|
|
import { categoriesSlug, postsSlug } from '../shared.js'
|
|
import { singularSlug } from './Singular.js'
|
|
|
|
export const Categories: CollectionConfig = {
|
|
slug: categoriesSlug,
|
|
admin: {
|
|
useAsTitle: 'name',
|
|
},
|
|
fields: [
|
|
{
|
|
name: 'name',
|
|
type: 'text',
|
|
},
|
|
// Alternative tabs usage
|
|
// {
|
|
// type: 'tabs',
|
|
// tabs: [
|
|
// {
|
|
// label: 'Unnamed tab',
|
|
// fields: [
|
|
// {
|
|
// name: 'relatedPosts',
|
|
// label: 'Related Posts',
|
|
// type: 'join',
|
|
// collection: postsSlug,
|
|
// on: 'category',
|
|
// },
|
|
// ],
|
|
// },
|
|
// {
|
|
// name: 'group',
|
|
// fields: [
|
|
// {
|
|
// name: 'relatedPosts',
|
|
// label: 'Related Posts (Group)',
|
|
// type: 'join',
|
|
// collection: postsSlug,
|
|
// on: 'group.category',
|
|
// },
|
|
// ],
|
|
// },
|
|
// ],
|
|
// },
|
|
{
|
|
name: 'relatedPosts',
|
|
label: 'Related Posts',
|
|
type: 'join',
|
|
collection: postsSlug,
|
|
defaultSort: '-title',
|
|
defaultLimit: 5,
|
|
on: 'category',
|
|
maxDepth: 1,
|
|
},
|
|
{
|
|
name: 'hasManyPosts',
|
|
type: 'join',
|
|
collection: postsSlug,
|
|
on: 'categories',
|
|
},
|
|
{
|
|
name: 'hasManyPostsLocalized',
|
|
type: 'join',
|
|
collection: postsSlug,
|
|
on: 'categoriesLocalized',
|
|
},
|
|
{
|
|
name: 'group',
|
|
type: 'group',
|
|
fields: [
|
|
{
|
|
name: 'relatedPosts',
|
|
label: 'Related Posts (Group)',
|
|
type: 'join',
|
|
collection: postsSlug,
|
|
on: 'group.category',
|
|
},
|
|
{
|
|
name: 'camelCasePosts',
|
|
type: 'join',
|
|
collection: postsSlug,
|
|
on: 'group.camelCaseCategory',
|
|
},
|
|
],
|
|
},
|
|
{
|
|
name: 'singulars',
|
|
type: 'join',
|
|
collection: singularSlug,
|
|
on: 'category',
|
|
},
|
|
{
|
|
name: 'filtered',
|
|
type: 'join',
|
|
collection: postsSlug,
|
|
on: 'category',
|
|
where: {
|
|
isFiltered: { not_equals: true },
|
|
},
|
|
},
|
|
],
|
|
}
|