element-plus/packages/utils/types.ts

54 lines
1.2 KiB
TypeScript
Raw Normal View History

import type { CSSProperties, Plugin } from 'vue'
2020-08-04 10:49:49 +08:00
type OptionalKeys<T extends Record<string, unknown>> = {
[K in keyof T]: T extends Record<K, T[K]> ? never : K
2020-08-02 18:27:46 +08:00
}[keyof T]
type RequiredKeys<T extends Record<string, unknown>> = Exclude<
keyof T,
OptionalKeys<T>
>
2020-08-02 18:27:46 +08:00
type MonoArgEmitter<T, Keys extends keyof T> = <K extends Keys>(
evt: K,
arg?: T[K]
) => void
2020-08-02 18:27:46 +08:00
type BiArgEmitter<T, Keys extends keyof T> = <K extends Keys>(
evt: K,
arg: T[K]
) => void
2020-08-02 18:27:46 +08:00
export type EventEmitter<T extends Record<string, unknown>> = MonoArgEmitter<
T,
OptionalKeys<T>
> &
BiArgEmitter<T, RequiredKeys<T>>
export type AnyFunction<T> = (...args: any[]) => T
2020-09-03 21:19:12 +08:00
export type PartialReturnType<T extends (...args: unknown[]) => unknown> =
Partial<ReturnType<T>>
export type SFCWithInstall<T> = T & Plugin
export type Nullable<T> = T | null
2021-11-11 22:27:21 +08:00
export type RefElement = Nullable<HTMLElement>
export type CustomizedHTMLElement<T> = HTMLElement & T
export type Indexable<T> = {
[key: string]: T
}
export type Hash<T> = Indexable<T>
export type TimeoutHandle = number
refactor(style): adjust component size to large/default/small (#4491) * refactor(style): adjust component size to large/default/small * refactor(components): avatar size & use flex instead of block * refactor(components): adjust check button size * refactor(components): adjust tag size * refactor(components): adjust size doc * fix(components): datetime-picker demo style width * refactor(components): color-picker size & block to flex * refactor(components): adjust slider input size * refactor(components): adjust radio input size for demo * refactor(components): adjust select size & docs * refactor(components): adjust form radio size & docs * refactor(components): add windicss for docs * refactor(components): adjust skeleton avatar size to css var * refactor(components): simplify typography size demo * refactor(components): adjust dropdown size & demo * refactor(components): adjust descriptions size * fix(components): datetime-picker showcase class pollute global button * chore(ci): upgrade docs dependencies to fix ci * fix(ci): add highlight because vitepress not export it * fix(ci): disable line for no-console * fix(ci): remove mini to fix test * fix(style): code font size * fix(style): button span flex style * fix(style): button padding horizontal default 15px * refactor(components): adjust tag padding size & demo * refactor(components): adjust form line-height for input * refactor(components): adjust dropdown menu size & button padding * fix(style): picker separator block to flex center * fix: dropdown button span items-center * style: adjust input-with-icon & size demo & fix input vitepress load * chore: upgrade dependencies * chore: upgrade dependencies * ci: fix website build * ci: regenerate pnpm-lock.yaml * ci: use dev pnpm-lock * ci: update pnpm-lock.yaml
2021-12-12 17:54:21 +08:00
export type ComponentSize = 'large' | 'default' | 'small'
export type StyleValue = string | CSSProperties | Array<StyleValue>
export type Mutable<T> = { -readonly [P in keyof T]: T[P] }