Added fronted newPostValidator and usePosts composables

main
TZGyn 3 years ago
parent 67d39b0478
commit 4526e9fae9
Signed by: TZGyn
GPG Key ID: 122EAF77AE81FD4A

@ -1,22 +1,41 @@
import { z } from 'zod'
const PostValidator = z.object({
sequence: z.number(),
id: z.string(),
title: z.string(),
description: z.string(),
created_at: z.string(),
updated_at: z.string(),
sequence: z.number(),
id: z.string(),
title: z.string(),
description: z.string(),
created_at: z.string(),
updated_at: z.string(),
})
const newPostValidator = z.object({
title: z.string(),
description: z.string(),
})
const parsePost = (data: unknown) => {
return PostValidator.parse(data)
return PostValidator.parse(data)
}
const PostsValidator = PostValidator.array()
const parsePosts = (data: unknown[]) => {
return PostsValidator.parse(data)
return PostsValidator.parse(data)
}
type Posts = z.infer<typeof PostsValidator>
const usePosts = () => useState<Posts>(() => [])
const createNewPost = async (data: unknown) => {
const parsedNewPost = newPostValidator.safeParse(data)
if (!parsedNewPost.success) return
const res = await request.post('/api/posts', parsedNewPost.data)
console.log(res)
}
export { parsePost, parsePosts, PostsValidator, PostValidator }
export { parsePost, parsePosts, PostValidator, createNewPost, usePosts }

@ -5,9 +5,7 @@ definePageMeta({
import { z } from 'zod'
type Posts = z.infer<typeof PostsValidator>
const posts = ref<Posts>([])
const posts = usePosts()
const lastPost = ref<Number>(0)
const responseValidator = z.object({

Loading…
Cancel
Save