// import { BookIcon } from '@sanity/icons' import { format, parseISO } from 'date-fns' import { TiCalendarOutline } from 'react-icons/ti' import { defineField, defineType } from 'sanity' import authorType from '../author' export default defineType({ name: 'weddingpost', title: 'Wedding Main Page', icon: TiCalendarOutline, type: 'document', fields: [ defineField({ name: 'title', title: 'Title', 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), }, //validation: (rule) => rule.required(), }), defineField({ name: 'coverImage', title: 'Thumbnail', type: 'reference', to: [{ type: 'gallery' }], fields: [ { type: 'string', title: 'Alternative text', name: 'alt', }, ], }), defineField({ name: 'posterImage', title: 'Poster', type: 'image', options: { hotspot: true, }, }), defineField({ name: 'galeryImage', title: 'Galery Fotos', description: 'Tambahkan galery foto untuk halaman', type: 'array', of: [{ type: 'image' }], options: { layout: 'grid' }, }), defineField({ name: 'content', title: 'Content Wedding', type: 'array', of: [{ type: 'block' }], }), defineField({ name: 'date', title: 'Date', type: 'datetime', initialValue: () => new Date().toISOString(), }), defineField({ name: 'author', title: 'Author', type: 'reference', to: [{ type: authorType.name }], }), ], 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(' ') } }, }, })