wip: test + typing for value
This commit is contained in:
@@ -9,6 +9,62 @@ export interface Value<T> {
|
||||
value: T
|
||||
}
|
||||
|
||||
type UnwrapValue<T, U = T> = T extends Value<infer V> ? V : T extends {} ? U : T
|
||||
|
||||
// A utility type that recursively unwraps value bindings nested inside an
|
||||
// observable object. Unfortunately TS cannot do recursive types, but this
|
||||
// should be enough for practical use cases...
|
||||
export type UnwrapBindings<T> = {
|
||||
[key in keyof T]: UnwrapValue<
|
||||
T[key],
|
||||
{
|
||||
[k2 in keyof T[key]]: UnwrapValue<
|
||||
T[key][k2],
|
||||
{
|
||||
[k3 in keyof T[key][k2]]: UnwrapValue<
|
||||
T[key][k2][k3],
|
||||
{
|
||||
[k4 in keyof T[key][k2][k3]]: UnwrapValue<
|
||||
T[key][k2][k3][k4],
|
||||
{
|
||||
[k5 in keyof T[key][k2][k3][k4]]: UnwrapValue<
|
||||
T[key][k2][k3][k4][k5],
|
||||
{
|
||||
[k6 in keyof T[key][k2][k3][k4][k5]]: UnwrapValue<
|
||||
T[key][k2][k3][k4][k5][k6],
|
||||
{
|
||||
[k7 in keyof T[key][k2][k3][k4][k5][k6]]: UnwrapValue<
|
||||
T[key][k2][k3][k4][k5][k6][k7],
|
||||
{
|
||||
[k8 in keyof T[key][k2][k3][k4][k5][k6][k7]]: UnwrapValue<
|
||||
T[key][k2][k3][k4][k5][k6][k7][k8],
|
||||
{
|
||||
[k9 in keyof T[key][k2][k3][k4][k5][k6][k7][k8]]: UnwrapValue<
|
||||
T[key][k2][k3][k4][k5][k6][k7][k8][k9],
|
||||
{
|
||||
[k10 in keyof T[key][k2][k3][k4][k5][k6][k7][k8][k9]]: UnwrapValue<
|
||||
T[key][k2][k3][k4][k5][k6][k7][k8][k9][k10]
|
||||
>
|
||||
}
|
||||
>
|
||||
}
|
||||
>
|
||||
}
|
||||
>
|
||||
}
|
||||
>
|
||||
}
|
||||
>
|
||||
}
|
||||
>
|
||||
}
|
||||
>
|
||||
}
|
||||
>
|
||||
}
|
||||
>
|
||||
}
|
||||
|
||||
const convert = (val: any): any => (isObject(val) ? observable(val) : val)
|
||||
|
||||
export function value<T>(raw: T): Value<T> {
|
||||
|
||||
Reference in New Issue
Block a user