Skip to content

Releases: vadimdemedes/ink

v5.1.0

25 Nov 09:21
Compare
Choose a tag to compare
  • Support space-evenly value for justifyContent attribute (#678) 1588397

v5.0.1...v5.1.0

v5.0.1

31 May 15:59
Compare
Choose a tag to compare

v5.0.0...v5.0.1

v5.0.0

11 May 17:36
Compare
Choose a tag to compare

Even though this release is major, it doesn't have any breaking changes. The reason it's 5.0.0 is because after #635, Ink requires Node.js 18.

Huge thanks to @sindresorhus for maintaining Ink πŸ’›

Highlights

v4.4.1...v5.0.0

v4.4.1

09 Sep 11:43
Compare
Choose a tag to compare

Highlights

v4.4.0...v4.4.1

v4.4.0

01 Sep 10:17
Compare
Choose a tag to compare

Highlights

  • Add index property to Transform (#619) 0ee8e89
  • Use readable event instead of data to read from stdin (#616) 814f33e

Credits

Thanks to @isaacs and @matteodepalo for contributing to this release!

v4.3.1...v4.4.0

v4.3.1

07 Aug 20:37
Compare
Choose a tag to compare

This release brings back compatibility with Node.js v14.x. See #617 for details. Thanks @newhouse and @AlCalzone for handling it!

v4.3.0...v4.3.1

v4.3.0

17 Jul 06:22
Compare
Choose a tag to compare

Highlights

Thank you

Huge shoutout goes to @AlCalzone for performance improvements in the generation of output, which speeds up rendering and significantly reduces CPU usage πŸ”₯

v4.2.0...v4.3.0

v4.2.0

24 Apr 07:14
Compare
Choose a tag to compare

New features

Custom border style

fb66872

With the addition of borderStyle prop to Box, you can define custom border style for rendering borders.

<Box
	borderStyle={{
		topLeft: 'β†˜',
		top: '↓',
		topRight: '↙',
		left: 'β†’',
		bottomLeft: 'β†—',
		bottom: '↑',
		bottomRight: 'β†–',
		right: '←'
	}}
>
	<Text>Content</Text>
</Box>

Individual colors for each border side

015202c

Box has supported borderColor prop for a while now to change the color of the border. In this release, there are new borderTopColor, borderBottomColor, borderLeftColor and borderRightColor props to change the color for each border side individually.

<Box
	borderStyle="single"
	borderTopColor="magenta"
	borderBottomColor="green"
	borderLeftColor="yellow"
	borderRightColor="cyan"
>
	<Text>So colorful</Text>
</Box>

Toggle visibility of individual border sides

3e0aeab

As you can see, this is a pretty border-themed release. Continuing with the trend, now you toggle visibility of any border side individually via borderTop, borderBottom, borderLeft and borderRight props.

For example, if you wanted to hide top and bottom borders, you'd pass false to borderTop and borderBottom props respectively.

<Box
	borderStyle="single"
	borderTop={false}
	borderBottom={false}
>
	<Text>Content</Text>
</Box>

Other changes

  • Rework parsing keyboard input in useInput (#576) 6f99ca3
  • Detect arrow keys when pressed together with meta key 8180c1c
  • Fix tab key incorrectly having ctrl equal to true 26b8364
  • Fix arrow and page up/down keys detected as meta keys (#573) 09261d5
  • Improve diffing of styles (#566) 690d48c

v4.1.0...v4.2.0

v4.1.0

26 Mar 13:32
Compare
Choose a tag to compare

Highlights

Support for gap in Box

4a67772

Box supports gap prop now to easily add space between columns and rows without manually assigning margins. Similar to CSS, gap is a shorthand for setting both columnGap and rowGap at the same time.

<Box gap={1}>
	<Text>A</Text>
	<Text>B</Text>
</Box>
// A B

Wrapping of flex items

7bdbde5

@jodevsa contributed support for wrapping of flex items in via flexWrap prop, similar to flex-wrap CSS property.

<Box width={2} flexWrap="wrap">
	<Text>A</Text>
	<Text>BC</Text>
</Box>
// A
// B C

Customizable overflow behavior in Box

6278b81

Box supports an overflow prop, which controls the visibility of an element's overflow. It can be set to "visible" (default) and "hidden", which hides any content that overflows element's boundaries. Like in CSS, overflow is a shorthand for setting both overflowX and overflowY.

<Box width={6} overflow="hidden">
    <Box width={16} flexShrink={0}>
    	<Text>Hello World</Text>
    </Box>
</Box>
// Hello

WASM build of Yoga

c97a2ee

Thanks to @amitdahan, Ink now uses a WASM build of Yoga provided by the yoga-wasm-web package. Starting with this release, Ink no longer uses yoga-layout-prebuilt package that is lagging behind Yoga releases.

Faster rendering

e635106

@AlCalzone contributed an impressive performance boost (~150%) to slice-ansi, which Ink heavily uses for generating output before writing it to the terminal. This release updates Ink to use a newer version of slice-ansi, so this should translate to faster rendering in Ink as well.

Other changes

v4.0.0...v4.1.0

v4.0.0

01 Mar 20:29
Compare
Choose a tag to compare

Breaking changes

  • This package is now pure ESM. Please read this.
  • Require Node.js 14.16 (#546) aaf45a1
  • Require React 18. (#546) aaf45a1
  • Delete support for hsl, hsv, hwb and ansi color formats in Text's color prop.
  • Move react-devtools-core to optional peer dependency (#498) 8c2378a

Thank you

Major shoutout goes to @pepicrft and @amitdahan for leading the migration of Ink to ESM πŸ’›

Thanks to @sindresorhus for support and helping reviewing these massive changes πŸ‘

v3.2.0...v4.0.0