diff options
author | bobzel <zzzman@gmail.com> | 2022-03-22 11:32:47 -0400 |
---|---|---|
committer | bobzel <zzzman@gmail.com> | 2022-03-22 11:32:47 -0400 |
commit | 810f86195188503b04d64f9d58ea4dfc3a639398 (patch) | |
tree | 2e0f252147dd65f36069426df4fe5369423427dc /src/fields/Types.ts | |
parent | 0885f2b6ea10bdc54f587040ea8e6dc90ef5b0f3 (diff) |
fixed temporal media merge that had reverted a lot of things.
Diffstat (limited to 'src/fields/Types.ts')
-rw-r--r-- | src/fields/Types.ts | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/src/fields/Types.ts b/src/fields/Types.ts index 3d784448d..c90f3b6b3 100644 --- a/src/fields/Types.ts +++ b/src/fields/Types.ts @@ -3,6 +3,7 @@ import { List } from "./List"; import { RefField } from "./RefField"; import { DateField } from "./DateField"; import { ScriptField } from "./ScriptField"; +import { URLField, WebField, ImageField } from "./URLField"; export type ToType<T extends InterfaceValue> = T extends "string" ? string : @@ -91,6 +92,12 @@ export function DateCast(field: FieldResult) { export function ScriptCast(field: FieldResult, defaultVal: ScriptField | null = null) { return Cast(field, ScriptField, defaultVal); } +export function WebCast(field: FieldResult, defaultVal: WebField | null = null) { + return Cast(field, WebField, defaultVal); +} +export function ImageCast(field: FieldResult, defaultVal: ImageField | null = null) { + return Cast(field, ImageField, defaultVal); +} type WithoutList<T extends Field> = T extends List<infer R> ? (R extends RefField ? (R | Promise<R>)[] : R[]) : T; @@ -104,5 +111,6 @@ export interface PromiseLike<T> { then(callback: (field: Opt<T>) => void): void; } export function PromiseValue<T extends Field>(field: FieldResult<T>): PromiseLike<Opt<T>> { - return field instanceof Promise ? field : { then(cb: ((field: Opt<T>) => void)) { return cb(field); } }; + if (field instanceof Promise) return field as Promise<Opt<T>>; + return { then(cb: ((field: Opt<T>) => void)) { return cb(field); } }; }
\ No newline at end of file |