ink
Version:
React for CLI
32 lines (31 loc) • 1.41 kB
TypeScript
import React, { type ReactNode } from 'react';
import { type Styles } from '../styles.js';
export type Props<T> = {
/**
* Array of items of any type to render using a function you pass as a component child.
*/
readonly items: T[];
/**
* Styles to apply to a container of child elements. See <Box> for supported properties.
*/
readonly style?: Styles;
/**
* Function that is called to render every item in `items` array.
* First argument is an item itself and second argument is index of that item in `items` array.
* Note that `key` must be assigned to the root component.
*/
readonly children: (item: T, index: number) => ReactNode;
};
/**
* `<Static>` component permanently renders its output above everything else.
* It's useful for displaying activity like completed tasks or logs - things that
* are not changing after they're rendered (hence the name "Static").
*
* It's preferred to use `<Static>` for use cases like these, when you can't know
* or control the amount of items that need to be rendered.
*
* For example, [Tap](https://github.com/tapjs/node-tap) uses `<Static>` to display
* a list of completed tests. [Gatsby](https://github.com/gatsbyjs/gatsby) uses it
* to display a list of generated pages, while still displaying a live progress bar.
*/
export default function Static<T>(props: Props<T>): React.JSX.Element;