Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/im-beast/deno_tui

πŸ¦• Deno module for creating Terminal User Interfaces
https://github.com/im-beast/deno_tui

console deno deno-module terminal terminal-user-interface text-user-interface ts tui typescript

Last synced: 2 days ago
JSON representation

πŸ¦• Deno module for creating Terminal User Interfaces

Awesome Lists containing this project

README

        

# ⌨️ Tui

Deno mascot made as ASCII art

[![Deno](https://github.com/Im-Beast/deno_tui/actions/workflows/deno.yml/badge.svg)](https://github.com/Im-Beast/deno_tui/actions/workflows/deno.yml)
[![Deno doc](https://doc.deno.land/badge.svg)](https://doc.deno.land/https://deno.land/x/tui/mod.ts)

Simple [Deno](https://github.com/denoland/deno/) module that allows easy creation of
[Terminal User Interfaces](https://en.wikipedia.org/wiki/Text-based_user_interface).

### πŸ”© Features

- πŸ”° Ease of use
- πŸ‘οΈβ€πŸ—¨οΈ Reactivity
- πŸ–‡οΈ No dependencies
- πŸ“„ Decent documentation
- [πŸ“¦ Multiple ready-to-use components](./src/components/)
- 🎨 Styling framework agnostic
- This means you can use whatever terminal styling module you want
- [πŸ–οΈ Crayon](https://github.com/crayon-js/crayon) is recommended _but not imposed_ as it greatly integrates with Tui
- πŸͺΆ Relatively lightweight

## πŸ–₯️ OS Support

| Operating system | Linux | macOS | WindowsΒΉ | WSL |
| -------------------- | ----- | ----- | -------- | ---- |
| Base | βœ”οΈ | βœ”οΈ | βœ”οΈ | βœ”οΈ |
| Keyboard support | βœ”οΈ | βœ”οΈ | βœ”οΈ | βœ”οΈ |
| Mouse support | βœ”οΈ | βœ”οΈ | βœ”οΈ | βœ”οΈ |
| Required permissions | none | none | none | none |

ΒΉ - If unicode characters are displayed incorrectly type `chcp 65001` into the console to change active console code
page to use UTF-8 encoding.

## πŸŽ“ Get started

#### Replace {version} with relevant module versions

1. Create Tui instance

```ts
import { crayon } from "https://deno.land/x/crayon@$MODULE_VERSION/mod.ts";
import { Canvas, Tui } from "https://deno.land/x/tui@$MODULE_VERSION/mod.ts";

const tui = new Tui({
style: crayon.bgBlack, // Make background black
refreshRate: 1000 / 60, // Run in 60FPS
});

tui.dispatch(); // Close Tui on CTRL+C
```

2. Enable interaction using keyboard and mouse

```ts
import { handleInput, handleKeyboardControls, handleMouseControls } from "https://deno.land/x/tui@$MODULE_VERSION/mod.ts";
...

handleInput(tui);
handleMouseControls(tui);
handleKeyboardControls(tui);
```

3. Add some components

```ts
import { Button } from "https://deno.land/x/tui@$MODULE_VERSION/src/components/mod.ts";
import { Signal, Computed } from "https://deno.land/x/tui@$MODULE_VERSION/mod.ts";

...

// Create signal to make number automatically reactive
const number = new Signal(0);

const button = new Button({
parent: tui,
zIndex: 0,
label: {
text: new Computed(() => number.value.toString()), // cast number to string
},
theme: {
base: crayon.bgRed,
focused: crayon.bgLightRed,
active: crayon.bgYellow,
},
rectangle: {
column: 1,
row: 1,
height: 5,
width: 10,
},
});

// If button is active (pressed) make number bigger by one
button.state.when("active", (state) => {
++number.value;
});

// Listen to mousePress event
button.on("mousePress", ({ drag, movementX, movementY }) => {
if (!drag) return;

// Use peek() to get signal's value when it happens outside of Signal/Computed/Effect
const rectangle = button.rectangle.peek();
// Move button by how much mouse has moved while dragging it
rectangle.column += movementX;
rectangle.row += movementY;
});
```

4. Run Tui

```ts
...

tui.run();
```

## 🀝 Contributing

**Tui** is open for any contributions.

If you feel like you can enhance this project - please open an issue and/or pull request.

Code should be well document and easy to follow what's going on.

This project follows [conventional commits](https://www.conventionalcommits.org/en/v1.0.0/) spec.

If your pull request's code can be hard to understand, please add comments to it.

## πŸ“ Licensing

This project is available under **MIT** License conditions.