55 lines
1.8 KiB
TypeScript
55 lines
1.8 KiB
TypeScript
// import { TRANSLATION_ITEMS } from '../i18n.config'
|
|
// common.json 파일을 직접 import
|
|
// @ts-ignore
|
|
import commonData from '../../layers/assets/data/common.json'
|
|
|
|
export default defineI18nLocale(async (locale: string) => {
|
|
const runtimeConfig = useRuntimeConfig()
|
|
const baseType = runtimeConfig.public.baseType
|
|
const translationItems = runtimeConfig.public.translationItems
|
|
const translationItemsArr = translationItems.split(',')
|
|
const staticUrl = runtimeConfig.public.staticUrl
|
|
const translationApi = translationItemsArr.map((item: string): string => {
|
|
return `${staticUrl}/${baseType}/tmp/${item}.json`
|
|
})
|
|
|
|
// API 데이터 가져오기
|
|
const fetchDataPromises = translationApi.map(apiUrl => {
|
|
return useFetch(apiUrl, {
|
|
method: 'GET',
|
|
headers: {
|
|
'Content-Type': 'application/json;charset=UTF-8',
|
|
},
|
|
})
|
|
})
|
|
|
|
try {
|
|
const fetchResults = await Promise.all(fetchDataPromises)
|
|
|
|
// 각 결과에서 locale에 맞는 데이터를 추출
|
|
const apiData = fetchResults.map(result => {
|
|
return result.data.value?.[locale] || {} // locale에 맞는 데이터가 없으면 빈 객체 반환
|
|
})
|
|
|
|
// apiData를 이용해 자동으로 병합
|
|
const mergedResult = apiData.reduce((acc, data) => {
|
|
return { ...acc, ...data }
|
|
}, {})
|
|
|
|
// common.json에서 해당 locale의 데이터를 가져와서 병합
|
|
const commonLocaleData = commonData[locale] || {}
|
|
|
|
// API 데이터와 common.json 데이터를 병합 (common.json이 우선순위)
|
|
const finalResult = { ...mergedResult, ...commonLocaleData }
|
|
|
|
// 병합된 결과 출력
|
|
// console.log('finalResult:', finalResult)
|
|
|
|
return finalResult
|
|
} catch (error) {
|
|
console.error('Error fetching translation data:', error)
|
|
// 에러 발생 시 common.json 데이터라도 반환
|
|
return commonData[locale] || {}
|
|
}
|
|
})
|