feat: translate 'Action' to 'Tindakan' and update validation messages
This commit is contained in:
parent
57e23adf3c
commit
dce745f53d
@ -18,10 +18,10 @@ import { useAdminContext } from '~/contexts/admin'
|
|||||||
import type { loader } from '~/routes/_admin.lg-admin'
|
import type { loader } from '~/routes/_admin.lg-admin'
|
||||||
|
|
||||||
export const profileSchema = z.object({
|
export const profileSchema = z.object({
|
||||||
name: z.string().min(1, 'Name is required'),
|
name: z.string().min(1, 'Wajib diisi'),
|
||||||
email: z.string().email('Email is invalid'),
|
email: z.string().email('Email tidak valid'),
|
||||||
profile_picture: z.string().url({
|
profile_picture: z.string().url({
|
||||||
message: 'Gambar profil must be valid',
|
message: 'URL tidak valid',
|
||||||
}),
|
}),
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -115,7 +115,7 @@ export const DialogProfile = () => {
|
|||||||
type="submit"
|
type="submit"
|
||||||
className="w-full rounded-md py-2"
|
className="w-full rounded-md py-2"
|
||||||
>
|
>
|
||||||
Save
|
Simpan
|
||||||
</Button>
|
</Button>
|
||||||
</fetcher.Form>
|
</fetcher.Form>
|
||||||
</RemixFormProvider>
|
</RemixFormProvider>
|
||||||
|
|||||||
@ -12,7 +12,7 @@ import { useNewsContext } from '~/contexts/news'
|
|||||||
|
|
||||||
export const loginSchema = z.object({
|
export const loginSchema = z.object({
|
||||||
email: z.string().email('Email tidak valid'),
|
email: z.string().email('Email tidak valid'),
|
||||||
password: z.string().min(6, 'Kata sandi minimal 6 karakter'),
|
password: z.string().min(6, 'Minimal 6 karakter'),
|
||||||
})
|
})
|
||||||
|
|
||||||
export type TLoginSchema = z.infer<typeof loginSchema>
|
export type TLoginSchema = z.infer<typeof loginSchema>
|
||||||
|
|||||||
@ -16,8 +16,8 @@ import type { loader } from '~/routes/_news'
|
|||||||
export const registerSchema = z
|
export const registerSchema = z
|
||||||
.object({
|
.object({
|
||||||
email: z.string().email('Email tidak valid'),
|
email: z.string().email('Email tidak valid'),
|
||||||
password: z.string().min(6, 'Kata sandi minimal 6 karakter'),
|
password: z.string().min(6, 'Minimal 6 karakter'),
|
||||||
rePassword: z.string().min(6, 'Kata sandi minimal 6 karakter'),
|
rePassword: z.string().min(6, 'Minimal 6 karakter'),
|
||||||
phone: z.string().min(10, 'No telepon tidak valid'),
|
phone: z.string().min(10, 'No telepon tidak valid'),
|
||||||
subscribe_plan: z
|
subscribe_plan: z
|
||||||
.object({
|
.object({
|
||||||
@ -28,7 +28,7 @@ export const registerSchema = z
|
|||||||
.optional()
|
.optional()
|
||||||
.nullable()
|
.nullable()
|
||||||
.refine((data) => !!data, {
|
.refine((data) => !!data, {
|
||||||
message: 'Silakan pilih paket berlangganan',
|
message: 'Pilih paket berlangganan',
|
||||||
}),
|
}),
|
||||||
})
|
})
|
||||||
.refine((field) => field.password === field.rePassword, {
|
.refine((field) => field.password === field.rePassword, {
|
||||||
|
|||||||
@ -56,7 +56,7 @@ export const AdvertisementsPage = () => {
|
|||||||
data: 'clicked',
|
data: 'clicked',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: 'Action',
|
title: 'Tindakan',
|
||||||
data: 'id',
|
data: 'id',
|
||||||
},
|
},
|
||||||
]
|
]
|
||||||
|
|||||||
@ -51,7 +51,7 @@ export const CategoriesPage = () => {
|
|||||||
data: 'description',
|
data: 'description',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: 'Action',
|
title: 'Tindakan',
|
||||||
data: 'id',
|
data: 'id',
|
||||||
},
|
},
|
||||||
]
|
]
|
||||||
|
|||||||
@ -55,15 +55,15 @@ export const ContentsPage = () => {
|
|||||||
},
|
},
|
||||||
{ title: 'Tag', data: 'tags' },
|
{ title: 'Tag', data: 'tags' },
|
||||||
{
|
{
|
||||||
title: 'Subscription',
|
title: 'Tipe Langganan',
|
||||||
data: 'is_premium',
|
data: 'is_premium',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: 'Jumlah Pembaca',
|
title: 'Jumlah Penayangan',
|
||||||
data: 'views',
|
data: 'views',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: 'Action',
|
title: 'Tindakan',
|
||||||
data: 'id',
|
data: 'id',
|
||||||
},
|
},
|
||||||
]
|
]
|
||||||
|
|||||||
@ -61,7 +61,7 @@ export const SubscribePlanPage = () => {
|
|||||||
data: 'status',
|
data: 'status',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: 'Action',
|
title: 'Tindakan',
|
||||||
data: 'id',
|
data: 'id',
|
||||||
},
|
},
|
||||||
]
|
]
|
||||||
|
|||||||
@ -46,7 +46,7 @@ export const TagsPage = () => {
|
|||||||
data: 'code',
|
data: 'code',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: 'Action',
|
title: 'Tindakan',
|
||||||
data: 'id',
|
data: 'id',
|
||||||
},
|
},
|
||||||
]
|
]
|
||||||
|
|||||||
@ -15,16 +15,16 @@ import { dateInput } from '~/utils/formatter'
|
|||||||
export const adsSchema = z.object({
|
export const adsSchema = z.object({
|
||||||
id: z.string().optional(),
|
id: z.string().optional(),
|
||||||
image: z.string().url({
|
image: z.string().url({
|
||||||
message: 'Gambar must be a valid URL',
|
message: 'URL tidak valid',
|
||||||
}),
|
}),
|
||||||
url: z.string().url({
|
url: z.string().url({
|
||||||
message: 'URL must be valid',
|
message: 'URL tidak valid',
|
||||||
}),
|
}),
|
||||||
start_date: z.string().min(1, {
|
start_date: z.string().min(1, {
|
||||||
message: 'Tanggal mulai is required',
|
message: 'Pilih tanggal',
|
||||||
}),
|
}),
|
||||||
end_date: z.string().min(1, {
|
end_date: z.string().min(1, {
|
||||||
message: 'Tanggal berakhir is required',
|
message: 'Pilih tanggal',
|
||||||
}),
|
}),
|
||||||
})
|
})
|
||||||
export type TAdsSchema = z.infer<typeof adsSchema>
|
export type TAdsSchema = z.infer<typeof adsSchema>
|
||||||
@ -101,7 +101,7 @@ export const FormAdvertisementsPage = (properties: TProperties) => {
|
|||||||
size="lg"
|
size="lg"
|
||||||
className="text-md h-[42px] rounded-md"
|
className="text-md h-[42px] rounded-md"
|
||||||
>
|
>
|
||||||
Save
|
Simpan
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
<div className="flex items-end justify-between gap-4">
|
<div className="flex items-end justify-between gap-4">
|
||||||
|
|||||||
@ -13,7 +13,7 @@ import { urlFriendlyCode } from '~/utils/formatter'
|
|||||||
|
|
||||||
export const categorySchema = z.object({
|
export const categorySchema = z.object({
|
||||||
id: z.string().optional(),
|
id: z.string().optional(),
|
||||||
name: z.string().min(3, 'Nama minimal 3 karakter'),
|
name: z.string().min(3, 'Minimal 3 karakter'),
|
||||||
code: z.string(),
|
code: z.string(),
|
||||||
sequence: z.preprocess(Number, z.number().optional()),
|
sequence: z.preprocess(Number, z.number().optional()),
|
||||||
description: z.string(),
|
description: z.string(),
|
||||||
@ -101,7 +101,7 @@ export const FormCategoryPage = (properties: TProperties) => {
|
|||||||
size="lg"
|
size="lg"
|
||||||
className="text-md h-[42px] rounded-md"
|
className="text-md h-[42px] rounded-md"
|
||||||
>
|
>
|
||||||
Save
|
Simpan
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
<div className="flex items-end justify-between gap-4">
|
<div className="flex items-end justify-between gap-4">
|
||||||
|
|||||||
@ -31,7 +31,7 @@ export const contentSchema = z.object({
|
|||||||
.nullable(),
|
.nullable(),
|
||||||
)
|
)
|
||||||
.refine((data) => data.length, {
|
.refine((data) => data.length, {
|
||||||
message: 'Please select a category',
|
message: 'Pilih kategori',
|
||||||
}),
|
}),
|
||||||
tags: z
|
tags: z
|
||||||
.array(
|
.array(
|
||||||
@ -46,17 +46,17 @@ export const contentSchema = z.object({
|
|||||||
)
|
)
|
||||||
.optional(),
|
.optional(),
|
||||||
title: z.string().min(1, {
|
title: z.string().min(1, {
|
||||||
message: 'Judul is required',
|
message: 'Wajib diisi',
|
||||||
}),
|
}),
|
||||||
content: z.string().min(1, {
|
content: z.string().min(1, {
|
||||||
message: 'Konten is required',
|
message: 'Wajib diisi',
|
||||||
}),
|
}),
|
||||||
featured_image: z.string().url({
|
featured_image: z.string().url({
|
||||||
message: 'Gambar Unggulan must be a valid URL',
|
message: 'URL tidak valid',
|
||||||
}),
|
}),
|
||||||
is_premium: z.boolean().optional(),
|
is_premium: z.boolean().optional(),
|
||||||
live_at: z.string().min(1, {
|
live_at: z.string().min(1, {
|
||||||
message: 'Tanggal mulai tayang is required',
|
message: 'Pilih tanggal',
|
||||||
}),
|
}),
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -144,7 +144,7 @@ export const FormContentsPage = (properties: TProperties) => {
|
|||||||
size="lg"
|
size="lg"
|
||||||
className="text-md h-[42px] rounded-md"
|
className="text-md h-[42px] rounded-md"
|
||||||
>
|
>
|
||||||
Save
|
Simpan
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
<div className="flex items-end justify-between gap-4">
|
<div className="flex items-end justify-between gap-4">
|
||||||
@ -154,7 +154,7 @@ export const FormContentsPage = (properties: TProperties) => {
|
|||||||
name="categories"
|
name="categories"
|
||||||
label="Kategori"
|
label="Kategori"
|
||||||
placeholder={
|
placeholder={
|
||||||
watchCategories
|
watchCategories?.length
|
||||||
? watchCategories.map((category) => category?.name).join(', ')
|
? watchCategories.map((category) => category?.name).join(', ')
|
||||||
: 'Pilih Kategori'
|
: 'Pilih Kategori'
|
||||||
}
|
}
|
||||||
@ -167,11 +167,11 @@ export const FormContentsPage = (properties: TProperties) => {
|
|||||||
multiple
|
multiple
|
||||||
id="tags"
|
id="tags"
|
||||||
name="tags"
|
name="tags"
|
||||||
label="Tags"
|
label="Tag"
|
||||||
placeholder={
|
placeholder={
|
||||||
watchTags
|
watchTags?.length
|
||||||
? watchTags.map((tag) => tag?.name).join(', ')
|
? watchTags.map((tag) => tag?.name).join(', ')
|
||||||
: 'Pilih Tags'
|
: 'Pilih Tag'
|
||||||
}
|
}
|
||||||
options={tags}
|
options={tags}
|
||||||
className="border-0 bg-white shadow focus:ring-1 focus:ring-[#2E2F7C] focus:outline-none"
|
className="border-0 bg-white shadow focus:ring-1 focus:ring-[#2E2F7C] focus:outline-none"
|
||||||
@ -180,7 +180,7 @@ export const FormContentsPage = (properties: TProperties) => {
|
|||||||
/>
|
/>
|
||||||
<Input
|
<Input
|
||||||
id="live_at"
|
id="live_at"
|
||||||
label="Tanggal Mulai Tayang"
|
label="Mulai Tayang"
|
||||||
placeholder="Pilih Tanggal"
|
placeholder="Pilih Tanggal"
|
||||||
name="live_at"
|
name="live_at"
|
||||||
type="date"
|
type="date"
|
||||||
@ -190,7 +190,7 @@ export const FormContentsPage = (properties: TProperties) => {
|
|||||||
<Switch
|
<Switch
|
||||||
id="is_premium"
|
id="is_premium"
|
||||||
name="is_premium"
|
name="is_premium"
|
||||||
label="Subscription"
|
label="Tipe Langganan"
|
||||||
labelClassName="text-sm font-medium text-[#363636]"
|
labelClassName="text-sm font-medium text-[#363636]"
|
||||||
className="h-[42px]"
|
className="h-[42px]"
|
||||||
options={{ true: 'Premium', false: 'Biasa' }}
|
options={{ true: 'Premium', false: 'Biasa' }}
|
||||||
|
|||||||
@ -15,14 +15,14 @@ export const staffSchema = z
|
|||||||
profile_picture: z
|
profile_picture: z
|
||||||
.string()
|
.string()
|
||||||
.url({
|
.url({
|
||||||
message: 'Gambar profil must be a valid URL',
|
message: 'URL tidak valid',
|
||||||
})
|
})
|
||||||
.or(z.literal('')),
|
.or(z.literal('')),
|
||||||
name: z.string().min(1, {
|
name: z.string().min(1, {
|
||||||
message: 'Nama staf is required',
|
message: 'Wajib diisi',
|
||||||
}),
|
}),
|
||||||
password: z.string().min(6, 'Kata sandi minimal 6 karakter'),
|
password: z.string().min(6, 'Minimal 6 karakter'),
|
||||||
rePassword: z.string().min(6, 'Kata sandi minimal 6 karakter'),
|
rePassword: z.string().min(6, 'Minimal 6 karakter'),
|
||||||
email: z.string().email('Email tidak valid'),
|
email: z.string().email('Email tidak valid'),
|
||||||
})
|
})
|
||||||
.refine((field) => field.password === field.rePassword, {
|
.refine((field) => field.password === field.rePassword, {
|
||||||
@ -91,7 +91,7 @@ export const FormStaffPage = () => {
|
|||||||
size="lg"
|
size="lg"
|
||||||
className="text-md h-[42px] rounded-md"
|
className="text-md h-[42px] rounded-md"
|
||||||
>
|
>
|
||||||
Save
|
Simpan
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
<div className="flex items-end justify-between gap-4">
|
<div className="flex items-end justify-between gap-4">
|
||||||
|
|||||||
@ -15,11 +15,11 @@ import { urlFriendlyCode } from '~/utils/formatter'
|
|||||||
|
|
||||||
export const subscribePlanSchema = z.object({
|
export const subscribePlanSchema = z.object({
|
||||||
id: z.string().optional(),
|
id: z.string().optional(),
|
||||||
name: z.string().min(3, 'Nama minimal 3 karakter'),
|
name: z.string().min(3, 'Minimal 3 karakter'),
|
||||||
code: z.string(),
|
code: z.string(),
|
||||||
length: z.preprocess(Number, z.number().min(1, 'Length minimal 1')),
|
length: z.preprocess(Number, z.number().min(1, 'Durasi minimal 1')),
|
||||||
price: z.preprocess(Number, z.number().min(1, 'Harga minimal 1')),
|
price: z.preprocess(Number, z.number().min(1, 'Harga minimal 1')),
|
||||||
status: z.string().min(1, 'Status is required'),
|
status: z.string().min(1, 'Pilih status'),
|
||||||
})
|
})
|
||||||
export type TSubscribePlanSchema = z.infer<typeof subscribePlanSchema>
|
export type TSubscribePlanSchema = z.infer<typeof subscribePlanSchema>
|
||||||
type TProperties = {
|
type TProperties = {
|
||||||
@ -106,7 +106,7 @@ export const FormSubscribePlanPage = (properties: TProperties) => {
|
|||||||
size="lg"
|
size="lg"
|
||||||
className="text-md h-[42px] rounded-md"
|
className="text-md h-[42px] rounded-md"
|
||||||
>
|
>
|
||||||
Save
|
Simpan
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
<div className="flex items-end justify-between gap-4">
|
<div className="flex items-end justify-between gap-4">
|
||||||
|
|||||||
@ -13,7 +13,7 @@ import { urlFriendlyCode } from '~/utils/formatter'
|
|||||||
|
|
||||||
export const tagSchema = z.object({
|
export const tagSchema = z.object({
|
||||||
id: z.string().optional(),
|
id: z.string().optional(),
|
||||||
name: z.string().min(3, 'Nama minimal 3 karakter'),
|
name: z.string().min(3, 'Minimal 3 karakter'),
|
||||||
code: z.string(),
|
code: z.string(),
|
||||||
})
|
})
|
||||||
export type TTagSchema = z.infer<typeof tagSchema>
|
export type TTagSchema = z.infer<typeof tagSchema>
|
||||||
@ -94,7 +94,7 @@ export const FormTagPage = (properties: TProperties) => {
|
|||||||
size="lg"
|
size="lg"
|
||||||
className="text-md h-[42px] rounded-md"
|
className="text-md h-[42px] rounded-md"
|
||||||
>
|
>
|
||||||
Save
|
Simpan
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
</fetcher.Form>
|
</fetcher.Form>
|
||||||
|
|||||||
@ -11,7 +11,7 @@ import { APP } from '~/configs/meta'
|
|||||||
|
|
||||||
export const loginSchema = z.object({
|
export const loginSchema = z.object({
|
||||||
email: z.string().email('Email tidak valid'),
|
email: z.string().email('Email tidak valid'),
|
||||||
password: z.string().min(6, 'Kata sandi minimal 6 karakter'),
|
password: z.string().min(6, 'Minimal 6 karakter'),
|
||||||
})
|
})
|
||||||
|
|
||||||
export type TLoginSchema = z.infer<typeof loginSchema>
|
export type TLoginSchema = z.infer<typeof loginSchema>
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user