mirror of
https://github.com/withastro/astro.git
synced 2025-01-13 22:11:20 -05:00
fix: apply defaults for all config values
This commit is contained in:
parent
88e0b044d0
commit
4f55cbb22e
1 changed files with 61 additions and 40 deletions
|
@ -29,28 +29,41 @@ const baseFieldSchema = z.object({
|
|||
collection: z.string().optional(),
|
||||
});
|
||||
|
||||
const schemaDefaults = {
|
||||
optional: false,
|
||||
unique: false,
|
||||
default: undefined,
|
||||
label: undefined,
|
||||
};
|
||||
|
||||
const booleanFieldSchema = z.object({
|
||||
type: z.literal('boolean'),
|
||||
schema: baseFieldSchema.extend({
|
||||
schema: baseFieldSchema
|
||||
.extend({
|
||||
default: z.union([z.boolean(), sqlSchema]).optional(),
|
||||
}),
|
||||
})
|
||||
.transform((s) => ({ ...schemaDefaults, ...s })),
|
||||
});
|
||||
|
||||
const numberFieldBaseSchema = baseFieldSchema.omit({ optional: true }).and(
|
||||
z.union([
|
||||
z.object({
|
||||
z
|
||||
.object({
|
||||
primaryKey: z.literal(false).optional(),
|
||||
optional: z.boolean().optional(),
|
||||
default: z.union([z.number(), sqlSchema]).optional(),
|
||||
}),
|
||||
z.object({
|
||||
})
|
||||
.transform((s) => ({ ...schemaDefaults, primaryKey: false, s })),
|
||||
z
|
||||
.object({
|
||||
// `integer primary key` uses ROWID as the default value.
|
||||
// `optional` and `default` do not have an effect,
|
||||
// so disable these config options for primary keys.
|
||||
primaryKey: z.literal(true),
|
||||
optional: z.literal(false).optional(),
|
||||
default: z.literal(undefined).optional(),
|
||||
}),
|
||||
})
|
||||
.transform((s) => ({ ...schemaDefaults, ...s })),
|
||||
])
|
||||
);
|
||||
|
||||
|
@ -86,18 +99,22 @@ const textFieldBaseSchema = baseFieldSchema
|
|||
})
|
||||
.and(
|
||||
z.union([
|
||||
z.object({
|
||||
z
|
||||
.object({
|
||||
primaryKey: z.literal(false).optional(),
|
||||
optional: z.boolean().optional(),
|
||||
}),
|
||||
z.object({
|
||||
})
|
||||
.transform((s) => ({ ...schemaDefaults, primaryKey: false, ...s })),
|
||||
z
|
||||
.object({
|
||||
// text primary key allows NULL values.
|
||||
// NULL values bypass unique checks, which could
|
||||
// lead to duplicate URLs per record in Astro Studio.
|
||||
// disable `optional` for primary keys.
|
||||
primaryKey: z.literal(true),
|
||||
optional: z.literal(false).optional(),
|
||||
}),
|
||||
})
|
||||
.transform((s) => ({ ...schemaDefaults, ...s })),
|
||||
])
|
||||
);
|
||||
|
||||
|
@ -127,7 +144,8 @@ const textFieldSchema = z.object({
|
|||
|
||||
const dateFieldSchema = z.object({
|
||||
type: z.literal('date'),
|
||||
schema: baseFieldSchema.extend({
|
||||
schema: baseFieldSchema
|
||||
.extend({
|
||||
default: z
|
||||
.union([
|
||||
sqlSchema,
|
||||
|
@ -135,14 +153,17 @@ const dateFieldSchema = z.object({
|
|||
z.date().transform((d) => d.toISOString()),
|
||||
])
|
||||
.optional(),
|
||||
}),
|
||||
})
|
||||
.transform((s) => ({ ...schemaDefaults, ...s })),
|
||||
});
|
||||
|
||||
const jsonFieldSchema = z.object({
|
||||
type: z.literal('json'),
|
||||
schema: baseFieldSchema.extend({
|
||||
schema: baseFieldSchema
|
||||
.extend({
|
||||
default: z.unknown().optional(),
|
||||
}),
|
||||
})
|
||||
.transform((s) => ({ ...schemaDefaults, ...s })),
|
||||
});
|
||||
|
||||
const fieldSchema = z.union([
|
||||
|
|
Loading…
Add table
Reference in a new issue