Skip to content

Commit

Permalink
Merge pull request #938 from hasparus/components-lazy-typescript
Browse files Browse the repository at this point in the history
Move @theme-ui/components types to this repo
  • Loading branch information
hasparus authored May 19, 2020
2 parents 9637bcd + e76823f commit 413e49b
Show file tree
Hide file tree
Showing 6 changed files with 388 additions and 11 deletions.
366 changes: 366 additions & 0 deletions packages/components/index.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,366 @@
import * as React from 'react'
import { StyledComponent } from '@emotion/styled'
import { InterpolationWithTheme } from '@emotion/core'
import { SpaceProps, ColorProps, MarginProps } from 'styled-system'
import { ResponsiveStyleValue } from '@theme-ui/css'

type Omit<T, K> = Pick<T, Exclude<keyof T, K>>

type Assign<T, U> = {
[P in keyof (T & U)]: P extends keyof T
? T[P]
: P extends keyof U
? U[P]
: never
}

type ForwardRef<T, P> = React.ForwardRefExoticComponent<
React.PropsWithoutRef<P> & React.RefAttributes<T>
>

export interface BoxOwnProps extends SpaceProps, ColorProps {
as?: React.ElementType
variant?: string
css?: InterpolationWithTheme<any>
}
export interface BoxProps
extends Assign<React.ComponentProps<'div'>, BoxOwnProps> {}
/**
* Use the Box component as a layout primitive to add margin, padding, and colors to content.
* @see https://theme-ui.com/components/box
*/
export const Box: StyledComponent<React.ComponentProps<'div'>, BoxOwnProps, {}>

export type FlexStyleProps = BoxOwnProps
export type FlexProps = BoxProps
/**
* Use the Flex component to create flexbox layouts.
* @see https://theme-ui.com/components/flex
*/
export const Flex: StyledComponent<
React.ComponentProps<'div'>,
FlexStyleProps,
{}
>

export interface GridProps extends BoxProps {
/**
* Minimum width of child elements
*/
width?: ResponsiveStyleValue<string | number>
/**
* Number of columns to use for the layout (cannot be used in conjunction with the width prop)
*/
columns?: ResponsiveStyleValue<string | number>
/**
* Space between child elements
*/
gap?: ResponsiveStyleValue<string | number>
}
/**
* CSS grid layout component to arrange direct child elements in a tiled grid layout.
* @see https://theme-ui.com/components/grid
*/
export const Grid: ForwardRef<HTMLDivElement, GridProps>

export interface ButtonProps
extends Assign<React.ComponentPropsWithRef<'button'>, BoxOwnProps> {}
/**
* Primitive button component with variants
* @see https://theme-ui.com/components/button
*/
export const Button: ForwardRef<HTMLButtonElement, ButtonProps>

export interface LinkProps
extends Assign<React.ComponentPropsWithRef<'a'>, BoxOwnProps> {}
/**
* Link variants can be defined in the `theme.links` object.
* By default the Link component will use styles defined in `theme.styles.a`.
* @see https://theme-ui.com/components/link
*/
export const Link: ForwardRef<HTMLAnchorElement, LinkProps>

export type TextProps = BoxProps
/**
* Primitive typographic component.
*
* Text style variants can be defined in the theme.text object.
* @see https://theme-ui.com/components/text
*/
export const Text: ForwardRef<HTMLDivElement, BoxProps>

export interface HeadingProps
extends Assign<React.ComponentPropsWithRef<'h2'>, BoxOwnProps> {}
/**
* Primitive heading component, defaults to <h2>.
*
* Text style variants can be defined in the theme.text object.
* The Heading component uses theme.text.heading as its default variant style.
* @see https://theme-ui.com/components/heading
*/
export const Heading: ForwardRef<HTMLHeadingElement, HeadingProps>

export interface ImageProps
extends Assign<React.ComponentProps<'img'>, BoxOwnProps> {}
/**
* Image style variants can be defined in the theme.images object.
* @see https://theme-ui.com/components/image/
*/
export const Image: ForwardRef<HTMLImageElement, ImageProps>

export type CardProps = BoxProps
/**
* Card style variants can be defined in the `theme.cards` object.
* By default the Card component uses the `theme.cards.primary` variant.
* @see https://theme-ui.com/components/card
*/
export const Card: ForwardRef<HTMLDivElement, CardProps>

export interface LabelProps
extends Assign<React.ComponentProps<'label'>, BoxOwnProps> {}
/**
* Label variants can be defined in `theme.forms`
* and the component uses the `theme.forms.label` variant by default.
* @see https://theme-ui.com/components/label/
*/
export const Label: ForwardRef<HTMLLabelElement, LabelProps>

export interface InputProps
extends Assign<React.ComponentProps<'input'>, BoxOwnProps> {}
/**
* Input variants can be defined in `theme.forms`
* and the component uses the `theme.forms.input` variant by default.
* @see https://theme-ui.com/components/input/
*/
export const Input: ForwardRef<HTMLInputElement, InputProps>

export interface SelectProps
extends Assign<React.ComponentProps<'select'>, BoxOwnProps> {}
/**
* Select variants can be defined in `theme.forms`
* and the component uses the `theme.forms.select` variant by default.
* @see https://theme-ui.com/components/select/
*/
export const Select: ForwardRef<HTMLSelectElement, SelectProps>

export interface TextareaProps
extends Assign<React.ComponentProps<'textarea'>, BoxOwnProps> {}
/**
* Form textarea component
*
* Textarea variants can be defined in `theme.forms`
* and the component uses the `theme.forms.textarea` variant by default.
* @see https://theme-ui.com/components/textarea/
*/
export const Textarea: ForwardRef<HTMLTextAreaElement, TextareaProps>

export interface RadioProps
extends Assign<React.ComponentProps<'input'>, BoxOwnProps> {}
/**
* Form radio input component
*
* Radio variants can be defined in `theme.forms` and the
* component uses the `theme.forms.radio variant` by default.
* @see https://theme-ui.com/components/radio/
*/
export const Radio: ForwardRef<HTMLInputElement, RadioProps>

export interface CheckboxProps
extends Assign<React.ComponentProps<'input'>, BoxOwnProps> {}
/**
* Form checkbox input component
*
* Checkbox variants can be defined in `theme.forms` and the
* component uses the `theme.forms.checkbox` variant by default.
* @see https://theme-ui.com/components/checkbox/
*/
export const Checkbox: ForwardRef<HTMLInputElement, CheckboxProps>

export interface SliderProps
extends Assign<React.ComponentProps<'input'>, BoxOwnProps> {}
/**
* Range input element
*
* Slider variants can be defined in the `theme.forms` object.
* The Slider component uses `theme.forms.slider` as its default variant style.
* @see https://theme-ui.com/components/slider/
*/
export const Slider: ForwardRef<HTMLInputElement, SliderProps>

export interface FieldOwnProps extends MarginProps {
/**
* Text for Label component
*/
label: string
/**
* Used for the for, id, and name attributes
*/
name: string
}
export type FieldProps<T extends React.ElementType> = FieldOwnProps &
Omit<React.ComponentProps<T>, 'as' | keyof FieldOwnProps> & {
/**
* form control to render, default Input
*/
as?: T
}

// `T` is far from unnecessary. We derive component props from it.
// tslint:disable-next-line no-unnecessary-generics
export function Field<
T extends React.ElementType = React.ElementType<InputProps>
>(props: FieldProps<T>): JSX.Element

export interface ProgressProps
extends Assign<React.ComponentProps<'progress'>, BoxOwnProps> {}
/**
* @see https://theme-ui.com/components/progress/
*/
export const Progress: ForwardRef<HTMLProgressElement, ProgressProps>

export interface DonutProps
extends Omit<
React.SVGProps<SVGSVGElement>,
'opacity' | 'color' | 'css' | 'sx' | 'max' | 'min'
>,
BoxOwnProps {
value: number
min?: number
max?: number
title?: string
size?: string | number
}
/**
* Single value SVG donut chart
* @see https://theme-ui.com/components/donut/
*/
export const Donut: ForwardRef<SVGSVGElement, DonutProps>

export interface SpinnerProps
extends Omit<
React.SVGProps<SVGSVGElement>,
'opacity' | 'color' | 'css' | 'sx'
>,
BoxOwnProps {
size?: number | string
}
export const Spinner: ForwardRef<SVGSVGElement, SpinnerProps>

export interface AvatarProps extends ImageProps {
size?: number | string
}
export const Avatar: ForwardRef<HTMLImageElement, AvatarProps>

export type BadgeProps = BoxProps
export const Badge: ForwardRef<HTMLDivElement, BadgeProps>

interface CloseProps extends Omit<IconButtonProps, 'children'> {}
/**
* Button with close (×) icon.
*
* The Close component renders as a <button> element by default.
* Pass any button attributes as props to the component.
*
* Close component variants can be defined in the theme.buttons object.
* The Close component uses theme.buttons.close as its default variant style.
*/
export const Close: ForwardRef<HTMLButtonElement, CloseProps>

export type AlertProps = BoxProps
/**
* Component for displaying messages, notifications, or other application state.
*
* Alert variants can be defined in `theme.alerts`.
* The Alert component uses `theme.alerts.primary` as its default variant.
*/
export const Alert: ForwardRef<HTMLDivElement, AlertProps>

export type DividerProps = BoxProps
/**
* The Divider component reuses styles from `theme.styles.hr` as its default variant.
*/
export const Divider: ForwardRef<HTMLDivElement, DividerProps>

export interface EmbedProps extends BoxProps {
ratio?: number
src?: React.IframeHTMLAttributes<any>['src']
frameBorder?: React.IframeHTMLAttributes<any>['frameBorder']
allowFullScreen?: React.IframeHTMLAttributes<any>['allowFullScreen']
allow?: React.IframeHTMLAttributes<any>['allow']
}
/**
* Responsive iframe for video embeds.
*
* Embed variants can be defined anywhere in the theme object.
*
* @see https://theme-ui.com/components/embed
*/
export const Embed: ForwardRef<HTMLIFrameElement, EmbedProps>

export interface AspectRatioProps extends BoxProps {
ratio?: number
}
/**
* Component for maintaining a fluid-width aspect ratio
* @see https://theme-ui.com/components/aspect-ratio
*/
export const AspectRatio: ForwardRef<HTMLDivElement, AspectRatioProps>

export interface AspectImageProps extends ImageProps {
ratio?: number
}
/**
* Image component constrained by as aspect ratio.
* @see https://theme-ui.com/components/aspect-image
*/
export const AspectImage: ForwardRef<HTMLImageElement, AspectImageProps>

export type ContainerProps = BoxProps
/**
* Centered, max-width layout component
*
* Container variants can be defined in the `theme.layout` object.
* The Container component uses `theme.layout.container` as its default variant style.
* @see https://theme-ui.com/components/container
*/
export const Container: ForwardRef<HTMLDivElement, ContainerProps>

export type NavLinkProps = LinkProps
/**
* Link component for use in navigation
*
* NavLink variants can be defined in the `theme.links` object.
* By default the NavLink component will use styles defined in `theme.links.nav`.
* @see https://theme-ui.com/components/nav-link
*/
export const NavLink: ForwardRef<HTMLAnchorElement, NavLinkProps>

export type MessageProps = BoxProps
/**
* Styled Box component for callouts and inline messages
*
* Message variants can be defined in the theme.messages object.
* @see https://theme-ui.com/components/message
*/
export const Message: ForwardRef<HTMLDivElement, MessageProps>

export interface IconButtonProps
extends Assign<React.ComponentPropsWithRef<'button'>, BoxOwnProps> {}
/**
* Transparent button for SVG icons
*
* IconButton variants can be defined in the `theme.buttons` object.
* By default the IconButton component will use styles defined in `theme.buttons.icon`.
*
* @see https://theme-ui.com/components/icon-button
*/
export const IconButton: ForwardRef<HTMLButtonElement, IconButtonProps>

export type MenuButtonProps = IconButtonProps
/**
* MenuButton variants can be defined in the `theme.buttons` object.
* By default the MenuButton component will use styles defined in `theme.buttons.menu`.
*
* @see https://theme-ui.com/components/menu-button
*/
export const MenuButton: ForwardRef<HTMLButtonElement, MenuButtonProps>
4 changes: 3 additions & 1 deletion packages/components/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,12 @@
"version": "0.4.0-alpha.1",
"main": "dist/index.js",
"module": "dist/index.esm.js",
"types": "index.d.ts",
"sideEffects": false,
"scripts": {
"prepare": "microbundle --no-compress --jsx React.createElement",
"watch": "microbundle watch --no-compress --jsx React.createElement"
"watch": "microbundle watch --no-compress --jsx React.createElement",
"typecheck": "tsc --noEmit"
},
"dependencies": {
"@emotion/core": "^10.0.0",
Expand Down
4 changes: 4 additions & 0 deletions packages/components/tsconfig.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
{
"extends": "../../tsconfig.json",
"include": ["src/**/*.ts", "src/**/*.tsx", "index.d.ts"]
}
Loading

0 comments on commit 413e49b

Please sign in to comment.