feat: translate 'Action' to 'Tindakan' and update validation messages

This commit is contained in:
Ardeman 2025-03-25 09:37:03 +08:00
parent 57e23adf3c
commit dce745f53d
15 changed files with 46 additions and 46 deletions

View File

@ -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>

View File

@ -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>

View File

@ -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, {

View File

@ -56,7 +56,7 @@ export const AdvertisementsPage = () => {
data: 'clicked', data: 'clicked',
}, },
{ {
title: 'Action', title: 'Tindakan',
data: 'id', data: 'id',
}, },
] ]

View File

@ -51,7 +51,7 @@ export const CategoriesPage = () => {
data: 'description', data: 'description',
}, },
{ {
title: 'Action', title: 'Tindakan',
data: 'id', data: 'id',
}, },
] ]

View File

@ -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',
}, },
] ]

View File

@ -61,7 +61,7 @@ export const SubscribePlanPage = () => {
data: 'status', data: 'status',
}, },
{ {
title: 'Action', title: 'Tindakan',
data: 'id', data: 'id',
}, },
] ]

View File

@ -46,7 +46,7 @@ export const TagsPage = () => {
data: 'code', data: 'code',
}, },
{ {
title: 'Action', title: 'Tindakan',
data: 'id', data: 'id',
}, },
] ]

View File

@ -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">

View File

@ -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">

View File

@ -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' }}

View File

@ -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">

View File

@ -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">

View File

@ -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>

View File

@ -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>