types(reactivity): handle primitive + object intersection types in UnwrapRef (#614)
This commit is contained in:
parent
2f6ec45d10
commit
2b4d0d6501
@ -85,6 +85,11 @@ function toProxyRef<T extends object, K extends keyof T>(
|
||||
|
||||
type UnwrapArray<T> = { [P in keyof T]: UnwrapRef<T[P]> }
|
||||
|
||||
// corner case when use narrows type
|
||||
// Ex. type RelativePath = string & { __brand: unknown }
|
||||
// RelativePath extends object -> true
|
||||
type BaseTypes = string | number | boolean
|
||||
|
||||
// Recursively unwraps nested value bindings.
|
||||
export type UnwrapRef<T> = {
|
||||
cRef: T extends ComputedRef<infer V> ? UnwrapRef<V> : T
|
||||
@ -97,6 +102,6 @@ export type UnwrapRef<T> = {
|
||||
? 'ref'
|
||||
: T extends Array<any>
|
||||
? 'array'
|
||||
: T extends Function | CollectionTypes
|
||||
: T extends Function | CollectionTypes | BaseTypes
|
||||
? 'ref' // bail out on types that shouldn't be unwrapped
|
||||
: T extends object ? 'object' : 'ref']
|
||||
|
@ -12,6 +12,8 @@ describe('with object props', () => {
|
||||
ddd: string[]
|
||||
}
|
||||
|
||||
type GT = string & { __brand: unknown }
|
||||
|
||||
const MyComponent = defineComponent({
|
||||
props: {
|
||||
a: Number,
|
||||
@ -57,6 +59,9 @@ describe('with object props', () => {
|
||||
c: ref(1),
|
||||
d: {
|
||||
e: ref('hi')
|
||||
},
|
||||
f: {
|
||||
g: ref('hello' as GT)
|
||||
}
|
||||
}
|
||||
},
|
||||
@ -88,6 +93,7 @@ describe('with object props', () => {
|
||||
// assert setup context unwrapping
|
||||
expectType<number>(this.c)
|
||||
expectType<string>(this.d.e)
|
||||
expectType<GT>(this.f.g)
|
||||
|
||||
// setup context properties should be mutable
|
||||
this.c = 2
|
||||
|
Loading…
Reference in New Issue
Block a user