2023-05-04 09:20:30 -04:00
|
|
|
import { z } from 'zod'
|
|
|
|
import { ItemType } from '../../items/enums'
|
|
|
|
import { itemBaseSchema } from '../../items/baseSchemas'
|
|
|
|
import { optionBaseSchema, blockBaseSchema } from '../baseSchemas'
|
|
|
|
import { defaultButtonLabel } from './constants'
|
|
|
|
import { InputBlockType } from './enums'
|
2023-06-05 17:33:43 +02:00
|
|
|
import { conditionSchema } from '../logic/condition'
|
2023-05-04 09:20:30 -04:00
|
|
|
|
|
|
|
export const pictureChoiceOptionsSchema = optionBaseSchema.merge(
|
|
|
|
z.object({
|
|
|
|
isMultipleChoice: z.boolean().optional(),
|
|
|
|
isSearchable: z.boolean().optional(),
|
|
|
|
buttonLabel: z.string(),
|
|
|
|
searchInputPlaceholder: z.string(),
|
|
|
|
dynamicItems: z
|
|
|
|
.object({
|
|
|
|
isEnabled: z.boolean().optional(),
|
|
|
|
titlesVariableId: z.string().optional(),
|
|
|
|
descriptionsVariableId: z.string().optional(),
|
|
|
|
pictureSrcsVariableId: z.string().optional(),
|
|
|
|
})
|
|
|
|
.optional(),
|
|
|
|
})
|
|
|
|
)
|
|
|
|
|
|
|
|
export const pictureChoiceItemSchema = itemBaseSchema.merge(
|
|
|
|
z.object({
|
|
|
|
type: z.literal(ItemType.PICTURE_CHOICE),
|
|
|
|
pictureSrc: z.string().optional(),
|
|
|
|
title: z.string().optional(),
|
|
|
|
description: z.string().optional(),
|
2023-06-05 17:33:43 +02:00
|
|
|
displayCondition: z
|
|
|
|
.object({
|
|
|
|
isEnabled: z.boolean().optional(),
|
|
|
|
condition: conditionSchema.optional(),
|
|
|
|
})
|
|
|
|
.optional(),
|
2023-05-04 09:20:30 -04:00
|
|
|
})
|
|
|
|
)
|
|
|
|
|
|
|
|
export const pictureChoiceBlockSchema = blockBaseSchema.merge(
|
|
|
|
z.object({
|
|
|
|
type: z.enum([InputBlockType.PICTURE_CHOICE]),
|
|
|
|
items: z.array(pictureChoiceItemSchema),
|
|
|
|
options: pictureChoiceOptionsSchema,
|
|
|
|
})
|
|
|
|
)
|
|
|
|
|
|
|
|
export type PictureChoiceItem = z.infer<typeof pictureChoiceItemSchema>
|
|
|
|
export type PictureChoiceBlock = z.infer<typeof pictureChoiceBlockSchema>
|
|
|
|
|
|
|
|
export const defaultPictureChoiceOptions: PictureChoiceBlock['options'] = {
|
|
|
|
buttonLabel: defaultButtonLabel,
|
|
|
|
searchInputPlaceholder: 'Filter the options...',
|
|
|
|
}
|