fix(types/jsx): jsx-runtime types for global JSX namespace registration (#7978)

This commit is contained in:
Haoqun Jiang 2023-03-29 16:15:08 +08:00 committed by GitHub
parent 77686cf476
commit 0f73f394da
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 32 additions and 9 deletions

39
packages/vue/jsx.d.ts vendored
View File

@ -1,15 +1,36 @@
// global JSX namespace registration
import { JSX as JSXInternal } from './jsx-runtime'
// somehow we have to copy=pase the jsx-runtime types here to make TypeScript happy
import { VNode, VNodeRef } from '@vue/runtime-dom'
import { IntrinsicElementAttributes } from './jsx-runtime/dom'
export * from './jsx-runtime/dom'
export type ReservedProps = {
key?: string | number | symbol
ref?: VNodeRef
ref_for?: boolean
ref_key?: string
}
export type NativeElements = {
[K in keyof IntrinsicElementAttributes]: IntrinsicElementAttributes[K] &
ReservedProps
}
declare global {
namespace JSX {
interface Element extends JSXInternal.Element {}
interface ElementClass extends JSXInternal.ElementClass {}
interface ElementAttributesProperty
extends JSXInternal.ElementAttributesProperty {}
interface IntrinsicElements extends JSXInternal.IntrinsicElements {}
interface IntrinsicAttributes extends JSXInternal.IntrinsicAttributes {}
export interface Element extends VNode {}
export interface ElementClass {
$props: {}
}
export interface ElementAttributesProperty {
$props: {}
}
export interface IntrinsicElements extends NativeElements {
// allow arbitrary elements
// @ts-ignore suppress ts:2374 = Duplicate string index signature.
[name: string]: any
}
export interface IntrinsicAttributes extends ReservedProps {}
}
}
export {}

View File

@ -2,3 +2,5 @@
// imports the global JSX namespace registration for compat.
// TODO: remove in 3.4
import '../jsx'
export * from '../jsx-runtime/dom'