import { format, parseISO } from 'date-fns' import { TiEdit } from 'react-icons/ti' import { defineField, defineType } from 'sanity' import authorType from './author' export default defineType({ name: 'gallery', title: 'Gallery', icon: TiEdit, type: 'document', fields: [ defineField({ name: 'title', title: 'Title', description: 'Judul Gallery', type: 'string', //validation: (rule) => rule.required(), }), defineField({ name: 'slug', title: 'Slug', type: 'slug', options: { source: 'title', maxLength: 96, isUnique: (value, context) => context.defaultIsUnique(value, context), }, }), defineField({ name: 'content', title: 'Content', description: 'Deskripsi', type: 'text', }), defineField({ title: 'Pixieset URL', name: 'pixiesetURL', type: 'url', description: 'Alamat album di Pixieset', }), defineField({ name: 'date', title: 'Event Date', type: 'datetime', initialValue: () => new Date().toISOString(), }), defineField({ name: 'coverImage', title: 'Cover Image', type: 'image', options: { hotspot: true, }, }), { name: 'images', type: 'array', title: 'Images', of: [ { name: 'image', type: 'image', title: 'Image', options: { hotspot: true, }, fields: [ { name: 'alt', type: 'string', title: 'Alternative text', }, ], }, ], options: { layout: 'grid', }, }, defineField({ name: 'author', title: 'Author', type: 'reference', to: [{ type: authorType.name }], }), ], // orderings: [ // { // title: "Data", // name: "releaseDateDesc", // by: [{ field: "datetime", direction: "desc" }], // }, // ], preview: { select: { title: 'title', author: 'author.name', date: 'date', media: 'coverImage', }, prepare({ title, media, author, date }) { const subtitles = [ author && `by ${author}`, date && `on ${format(parseISO(date), 'LLL d, yyyy')}`, ].filter(Boolean) return { title, media, subtitle: subtitles.join(' ') } }, }, })