35 lines
939 B
TypeScript
35 lines
939 B
TypeScript
// https://vike.dev/data
|
|
|
|
import { useConfig } from 'vike-vue/useConfig'
|
|
import type { Movie, MovieDetails } from '../types.js'
|
|
|
|
export type Data = Awaited<ReturnType<typeof data>>
|
|
|
|
export async function data() {
|
|
// https://vike.dev/useConfig
|
|
const config = useConfig()
|
|
|
|
const response = await fetch(
|
|
'https://brillout.github.io/star-wars/api/films.json',
|
|
)
|
|
const moviesData = (await response.json()) as MovieDetails[]
|
|
|
|
config({
|
|
// Set <title>
|
|
title: `${moviesData.length} Star Wars Movies`,
|
|
})
|
|
|
|
// We remove data we don't need because the data is passed to the client; we should
|
|
// minimize what is sent over the network.
|
|
const movies = minimize(moviesData)
|
|
|
|
return { movies }
|
|
}
|
|
|
|
function minimize(movies: MovieDetails[]): Movie[] {
|
|
return movies.map((movie) => {
|
|
const { title, release_date, id } = movie
|
|
return { title, release_date, id }
|
|
})
|
|
}
|