0.0.6 • Published 12 months ago
payload-plugin-slug v0.0.6
Payload Plugin Slug
A convenient drop-in field for Payload CMS to quickly add a slug field to a collection with sensible defaults.
Background
Payload CMS does not provide a default slug field, and implementing one for quick projects requires building a custom component. This repo is here to help.
The implementation is mainly based on PaylodCMS' own Website Template.
How to use
- Add this to your collection config.
- Done!
This is not a plugin in payload's stricter terms. Do not add this to your payload.config() in the Plugin array.
import { slugField } from 'payload-plugin-slug'
export default buildConfig({
  collections: [
    {
      slug: 'users',
      auth: true,
      fields: [],
    },
    {
      slug: 'pages',
      admin: {
        useAsTitle: 'title',
      },
      fields: [
        {
          name: 'title',
          type: 'text',
        },
        {
          name: 'content',
          type: 'richText',
        },
        ...slugField(), // add the field like so.
      ],
    },
  ],
  
})Change defaults
You can change the field by which standard slugs are generated from, as well as change config defaults.
...slugField("field-to-use-", {
  TextField: {
    required: false,
  },
  CheckboxField: {
    //...
  }
})If you want to extend the field, you can simply copy & paste it to your own field library.