Skip to content

Commit

Permalink
chore(composable): move changes-logs data fetching logic #276
Browse files Browse the repository at this point in the history
  • Loading branch information
wazolab committed Dec 9, 2024
1 parent 43afaed commit 7b9b0c2
Show file tree
Hide file tree
Showing 2 changed files with 67 additions and 64 deletions.
65 changes: 65 additions & 0 deletions composables/useChangesLogs.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
import type { LoCha, Log, Project } from '~/libs/types'

interface ChangesLogsData {
project: Project
loChas: LoCha[]
logs: Log[]
fetchedAt: Date
}
export function useChangesLogs(projectSlug: string) {
const nuxtApp = useNuxtApp()
const config = useRuntimeConfig()

return useAsyncData<ChangesLogsData>(
`changes_logs-${projectSlug}`,
async () => {
try {
// Fetch project and change logs data concurrently
const [project, loChas] = await Promise.all([
$fetch<Project>(`${config.public.api}/projects/${projectSlug}`),
$fetch<LoCha[]>(`${config.public.api}/projects/${projectSlug}/changes_logs`),
])

return {
project,
loChas,
logs: loChas.map((loCha) => loCha.objects).flat(),
fetchedAt: new Date(),
}
}
catch (err) {
if (err instanceof Error) {
ElMessage.error({
duration: 0,
message: err.message,
})

throw new Error(err.message)
}
else {
throw new TypeError('Failed to fetch data')
}
}
},
{
getCachedData(key) {
const data = nuxtApp.payload.data[key] || nuxtApp.static.data[key]

if (!data) {
return null
}

// Check if the cached data has expired
const expirationDate = new Date(data.fetchedAt)
expirationDate.setTime(expirationDate.getTime() + 5 * 1000)
const isExpired = expirationDate.getTime() < Date.now()

if (isExpired) {
return null
}

return data
},
},
)
}
66 changes: 2 additions & 64 deletions pages/[project]/changes_logs.vue
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
<script setup lang="ts">
import type { Geometry } from 'geojson'
import type { LoCha, Project } from '~/libs/types'
import { uniq } from 'underscore'
//
Expand All @@ -17,71 +16,10 @@ definePageMeta({
//
const router = useRouter()
const route = useRoute()
const projectSlug = route.params.project.toString()
const config = useRuntimeConfig()
const user = useUser()
const nuxtApp = useNuxtApp()
//
// Data
//
const projectSlug = route.params.project as string
//
// Data Fetching
//
const { data, status, refresh } = useAsyncData(
`changes_logs-${projectSlug}`,
async () => {
try {
const [project, loChas] = await Promise.all([
$fetch<Project>(`${config.public.api}/projects/${projectSlug}`),
$fetch<LoCha[]>(`${config.public.api}/projects/${projectSlug}/changes_logs`),
])
return { project, loChas }
}
catch (err) {
if (err instanceof Error) {
ElMessage.error({
duration: 0,
message: err.message,
})
throw new Error(err.message)
}
else {
throw new TypeError('Failed to fetch data')
}
}
},
{
getCachedData(key) {
const data = nuxtApp.payload.data[key] || nuxtApp.static.data[key]
if (!data) {
return null
}
const expirationDate = new Date(data.fetchedAt)
expirationDate.setTime(expirationDate.getTime() + 30 * 1000)
const isExpired = expirationDate.getTime() < Date.now()
if (isExpired) {
return null
}
return data
},
transform: ({ project, loChas }) => {
return {
project,
loChas,
logs: loChas.map((loCha) => loCha.objects).flat(),
fetchedAt: new Date(),
}
},
},
)
const { data, status, refresh } = useChangesLogs(projectSlug)
//
// Computed
Expand Down

0 comments on commit 7b9b0c2

Please sign in to comment.