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'
export const profileSchema = z.object({
name: z.string().min(1, 'Name is required'),
email: z.string().email('Email is invalid'),
name: z.string().min(1, 'Wajib diisi'),
email: z.string().email('Email tidak valid'),
profile_picture: z.string().url({
message: 'Gambar profil must be valid',
message: 'URL tidak valid',
}),
})
@ -115,7 +115,7 @@ export const DialogProfile = () => {
type="submit"
className="w-full rounded-md py-2"
>
Save
Simpan
</Button>
</fetcher.Form>
</RemixFormProvider>

View File

@ -12,7 +12,7 @@ import { useNewsContext } from '~/contexts/news'
export const loginSchema = z.object({
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>

View File

@ -16,8 +16,8 @@ import type { loader } from '~/routes/_news'
export const registerSchema = z
.object({
email: z.string().email('Email tidak valid'),
password: z.string().min(6, 'Kata sandi minimal 6 karakter'),
rePassword: z.string().min(6, 'Kata sandi minimal 6 karakter'),
password: z.string().min(6, 'Minimal 6 karakter'),
rePassword: z.string().min(6, 'Minimal 6 karakter'),
phone: z.string().min(10, 'No telepon tidak valid'),
subscribe_plan: z
.object({
@ -28,7 +28,7 @@ export const registerSchema = z
.optional()
.nullable()
.refine((data) => !!data, {
message: 'Silakan pilih paket berlangganan',
message: 'Pilih paket berlangganan',
}),
})
.refine((field) => field.password === field.rePassword, {

View File

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

View File

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

View File

@ -55,15 +55,15 @@ export const ContentsPage = () => {
},
{ title: 'Tag', data: 'tags' },
{
title: 'Subscription',
title: 'Tipe Langganan',
data: 'is_premium',
},
{
title: 'Jumlah Pembaca',
title: 'Jumlah Penayangan',
data: 'views',
},
{
title: 'Action',
title: 'Tindakan',
data: 'id',
},
]

View File

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

View File

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

View File

@ -15,16 +15,16 @@ import { dateInput } from '~/utils/formatter'
export const adsSchema = z.object({
id: z.string().optional(),
image: z.string().url({
message: 'Gambar must be a valid URL',
message: 'URL tidak valid',
}),
url: z.string().url({
message: 'URL must be valid',
message: 'URL tidak valid',
}),
start_date: z.string().min(1, {
message: 'Tanggal mulai is required',
message: 'Pilih tanggal',
}),
end_date: z.string().min(1, {
message: 'Tanggal berakhir is required',
message: 'Pilih tanggal',
}),
})
export type TAdsSchema = z.infer<typeof adsSchema>
@ -101,7 +101,7 @@ export const FormAdvertisementsPage = (properties: TProperties) => {
size="lg"
className="text-md h-[42px] rounded-md"
>
Save
Simpan
</Button>
</div>
<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({
id: z.string().optional(),
name: z.string().min(3, 'Nama minimal 3 karakter'),
name: z.string().min(3, 'Minimal 3 karakter'),
code: z.string(),
sequence: z.preprocess(Number, z.number().optional()),
description: z.string(),
@ -101,7 +101,7 @@ export const FormCategoryPage = (properties: TProperties) => {
size="lg"
className="text-md h-[42px] rounded-md"
>
Save
Simpan
</Button>
</div>
<div className="flex items-end justify-between gap-4">

View File

@ -31,7 +31,7 @@ export const contentSchema = z.object({
.nullable(),
)
.refine((data) => data.length, {
message: 'Please select a category',
message: 'Pilih kategori',
}),
tags: z
.array(
@ -46,17 +46,17 @@ export const contentSchema = z.object({
)
.optional(),
title: z.string().min(1, {
message: 'Judul is required',
message: 'Wajib diisi',
}),
content: z.string().min(1, {
message: 'Konten is required',
message: 'Wajib diisi',
}),
featured_image: z.string().url({
message: 'Gambar Unggulan must be a valid URL',
message: 'URL tidak valid',
}),
is_premium: z.boolean().optional(),
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"
className="text-md h-[42px] rounded-md"
>
Save
Simpan
</Button>
</div>
<div className="flex items-end justify-between gap-4">
@ -154,7 +154,7 @@ export const FormContentsPage = (properties: TProperties) => {
name="categories"
label="Kategori"
placeholder={
watchCategories
watchCategories?.length
? watchCategories.map((category) => category?.name).join(', ')
: 'Pilih Kategori'
}
@ -167,11 +167,11 @@ export const FormContentsPage = (properties: TProperties) => {
multiple
id="tags"
name="tags"
label="Tags"
label="Tag"
placeholder={
watchTags
watchTags?.length
? watchTags.map((tag) => tag?.name).join(', ')
: 'Pilih Tags'
: 'Pilih Tag'
}
options={tags}
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
id="live_at"
label="Tanggal Mulai Tayang"
label="Mulai Tayang"
placeholder="Pilih Tanggal"
name="live_at"
type="date"
@ -190,7 +190,7 @@ export const FormContentsPage = (properties: TProperties) => {
<Switch
id="is_premium"
name="is_premium"
label="Subscription"
label="Tipe Langganan"
labelClassName="text-sm font-medium text-[#363636]"
className="h-[42px]"
options={{ true: 'Premium', false: 'Biasa' }}

View File

@ -15,14 +15,14 @@ export const staffSchema = z
profile_picture: z
.string()
.url({
message: 'Gambar profil must be a valid URL',
message: 'URL tidak valid',
})
.or(z.literal('')),
name: z.string().min(1, {
message: 'Nama staf is required',
message: 'Wajib diisi',
}),
password: z.string().min(6, 'Kata sandi minimal 6 karakter'),
rePassword: z.string().min(6, 'Kata sandi minimal 6 karakter'),
password: z.string().min(6, 'Minimal 6 karakter'),
rePassword: z.string().min(6, 'Minimal 6 karakter'),
email: z.string().email('Email tidak valid'),
})
.refine((field) => field.password === field.rePassword, {
@ -91,7 +91,7 @@ export const FormStaffPage = () => {
size="lg"
className="text-md h-[42px] rounded-md"
>
Save
Simpan
</Button>
</div>
<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({
id: z.string().optional(),
name: z.string().min(3, 'Nama minimal 3 karakter'),
name: z.string().min(3, 'Minimal 3 karakter'),
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')),
status: z.string().min(1, 'Status is required'),
status: z.string().min(1, 'Pilih status'),
})
export type TSubscribePlanSchema = z.infer<typeof subscribePlanSchema>
type TProperties = {
@ -106,7 +106,7 @@ export const FormSubscribePlanPage = (properties: TProperties) => {
size="lg"
className="text-md h-[42px] rounded-md"
>
Save
Simpan
</Button>
</div>
<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({
id: z.string().optional(),
name: z.string().min(3, 'Nama minimal 3 karakter'),
name: z.string().min(3, 'Minimal 3 karakter'),
code: z.string(),
})
export type TTagSchema = z.infer<typeof tagSchema>
@ -94,7 +94,7 @@ export const FormTagPage = (properties: TProperties) => {
size="lg"
className="text-md h-[42px] rounded-md"
>
Save
Simpan
</Button>
</div>
</fetcher.Form>

View File

@ -11,7 +11,7 @@ import { APP } from '~/configs/meta'
export const loginSchema = z.object({
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>