Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/arcanis/terminosaurus

Agnostic terminal GUI library for TypeScript, distributed with a native React renderer
https://github.com/arcanis/terminosaurus

cli command-line flexbox gui interactive react typescript

Last synced: about 2 months ago
JSON representation

Agnostic terminal GUI library for TypeScript, distributed with a native React renderer

Awesome Lists containing this project

README

        

#

Terminosaurus is a DOM-like UI library for TypeScript that makes it easy to build powerful graphical interfaces for your terminal without having to deal with complex positioning or state updates.

## Features

- Framework-agnostic API
- React renderer
- Advanced layout positioning
- Event handlers
- Text wrapping
- CSS properties
- Fast rendering

## Getting Started

Framework Agnostic
React Syntax

```ts
import {
TermElement,
TermText,
run,
} from 'terminosaurus';

run({}, async screen => {
const text = new TermText();
text.appendTo(screen.rootNode);

let counter = 0;

const increaseCounter = () => {
counter += 1;
text.setText(`Counter: ${counter}`);
};

text.onClick.addEventListener(() => {
increaseCounter();
});

increaseCounter();
});
```

```tsx
import {
useState
} from 'react'
import {
render,
} from 'terminosaurus/react';

function App() {
const [counter, setCounter] = useState(0);

const increaseCounter = () => {
setCounter(counter + 1);
};

return (

Counter: {counter}

);
}

render({}, );
```