mirror of
https://github.com/withastro/astro.git
synced 2025-01-13 22:11:20 -05:00
83 lines
1.6 KiB
TypeScript
83 lines
1.6 KiB
TypeScript
|
import astroDb, { defineReadableTable, column } from '@astrojs/db';
|
||
|
import { defineConfig } from 'astro/config';
|
||
|
|
||
|
const Recipe = defineReadableTable({
|
||
|
columns: {
|
||
|
id: column.number({ primaryKey: true }),
|
||
|
title: column.text(),
|
||
|
description: column.text(),
|
||
|
},
|
||
|
});
|
||
|
|
||
|
const Ingredient = defineReadableTable({
|
||
|
columns: {
|
||
|
id: column.number({ primaryKey: true }),
|
||
|
name: column.text(),
|
||
|
quantity: column.number(),
|
||
|
recipeId: column.number(),
|
||
|
},
|
||
|
indexes: {
|
||
|
recipeIdx: { on: 'recipeId' },
|
||
|
},
|
||
|
foreignKeys: [{ columns: 'recipeId', references: () => [Recipe.columns.id] }],
|
||
|
});
|
||
|
|
||
|
export default defineConfig({
|
||
|
integrations: [astroDb()],
|
||
|
db: {
|
||
|
tables: { Recipe, Ingredient },
|
||
|
async data({ seed, seedReturning }) {
|
||
|
const pancakes = await seedReturning(Recipe, {
|
||
|
title: 'Pancakes',
|
||
|
description: 'A delicious breakfast',
|
||
|
});
|
||
|
|
||
|
await seed(Ingredient, [
|
||
|
{
|
||
|
name: 'Flour',
|
||
|
quantity: 1,
|
||
|
recipeId: pancakes.id,
|
||
|
},
|
||
|
{
|
||
|
name: 'Eggs',
|
||
|
quantity: 2,
|
||
|
recipeId: pancakes.id,
|
||
|
},
|
||
|
{
|
||
|
name: 'Milk',
|
||
|
quantity: 1,
|
||
|
recipeId: pancakes.id,
|
||
|
},
|
||
|
]);
|
||
|
|
||
|
const pizza = await seedReturning(Recipe, {
|
||
|
title: 'Pizza',
|
||
|
description: 'A delicious dinner',
|
||
|
});
|
||
|
|
||
|
await seed(Ingredient, [
|
||
|
{
|
||
|
name: 'Flour',
|
||
|
quantity: 1,
|
||
|
recipeId: pizza.id,
|
||
|
},
|
||
|
{
|
||
|
name: 'Eggs',
|
||
|
quantity: 2,
|
||
|
recipeId: pizza.id,
|
||
|
},
|
||
|
{
|
||
|
name: 'Milk',
|
||
|
quantity: 1,
|
||
|
recipeId: pizza.id,
|
||
|
},
|
||
|
{
|
||
|
name: 'Tomato Sauce',
|
||
|
quantity: 1,
|
||
|
recipeId: pizza.id,
|
||
|
},
|
||
|
]);
|
||
|
},
|
||
|
},
|
||
|
});
|