@types/react-native-vector-icons
Version:
TypeScript definitions for react-native-vector-icons
48 lines (40 loc) • 1.38 kB
TypeScript
import { Component } from "react";
import { Icon, IconButtonProps, IconProps, ImageSource } from "./Icon";
export const FA5Style: {
regular: 0;
light: 1;
solid: 2;
brand: 3;
};
export type ValueOf<T> = T[keyof T];
// borrowed from
// https://www.typescriptlang.org/docs/handbook/release-notes/typescript-2-8.html
export type Omit<T, K> = Pick<T, Exclude<keyof T, K>>;
export type FontAwesome5IconVariants = keyof Omit<typeof FA5Style, "regular">;
export type FontAwesome5IconProps = { [K in FontAwesome5IconVariants]?: boolean } & IconProps;
export class FontAwesome5IconButton extends Component<
{ [K in FontAwesome5IconVariants]?: boolean } & IconButtonProps,
any
> {}
export default class FontAwesome5Icon extends Component<
FontAwesome5IconProps,
any
> {
static getImageSource(
name: string,
size?: number,
color?: string,
fa5Style?: ValueOf<typeof FA5Style>
): Promise<ImageSource>;
static getImageSourceSync(
name: string,
size?: number,
color?: string,
fa5Style?: ValueOf<typeof FA5Style>
): ImageSource;
static loadFont(file?: string): Promise<void>;
static hasIcon(name: string): boolean;
static TabBarItem: typeof Icon.TabBarItem;
static TabBarItemIOS: typeof Icon.TabBarItemIOS;
static Button: typeof FontAwesome5IconButton;
}