Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/robacarp/keimeno
A lightweight text user interface library in Crystal
https://github.com/robacarp/keimeno
crystal demo mud telnet tui
Last synced: 3 months ago
JSON representation
A lightweight text user interface library in Crystal
- Host: GitHub
- URL: https://github.com/robacarp/keimeno
- Owner: robacarp
- License: mit
- Created: 2018-09-15T17:33:56.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2020-04-04T04:12:50.000Z (almost 5 years ago)
- Last Synced: 2024-10-04T21:33:25.728Z (3 months ago)
- Topics: crystal, demo, mud, telnet, tui
- Language: Crystal
- Homepage:
- Size: 18.6 KB
- Stars: 14
- Watchers: 3
- Forks: 0
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-crystal - Keimeno - A lightweight text user interface library in Crystal (CLI Builders)
README
# κείμενο - "keímeno" - text
[![Crystal Version](https://img.shields.io/badge/crystal-0.33-blueviolet.svg?longCache=true&style=for-the-badge)](https://crystal-lang.org/)
[![GitHub](https://img.shields.io/github/license/robacarp/keimeno.svg?style=for-the-badge)](https://tldrlegal.com/license/mit-license)A lightweight and simple, native crystal library for text based interactive command line interfaces (TUI).
[FZF like demo](https://i.imgur.com/DiZ2QQz.gifv)
## Installation
Update your shard.yml to include keymeno
```diff
dependencies:
+ keimeno:
+ github: robacarp/keimeno
```## Usage
See [the demos](/demo).
A basic command line utility can probably be built using the primitives provided herein: menu, prompt, text input. But that wouldn't be any fun if you were limited to those only.
To build your own interactive utility, subclass `Keimeno::Base`:
```crystal
class CoolMenu < Keimeno::Base
# The following methods provide high level anchoring into the TUI engine:# Display methods are called each time the interface needs to be updated
def before_display
enddef display
end# cleanup method is called (by default) on exit, via ctrl-c or otherwise
def cleanup
end# return_value is used to emit a result from the interface
def return_value
end# respond to specific keypresses with methods like these
def key_ctrl_c
enddef key_alt_enter
end# or respond to general keypresses with methods like these
def key_pressed(keystroke)
enddef function_key(keystroke)
enddef character_key(keystroke)
end# When you're done and it's time to cleanup and exit cleanly, call `finish!`
def i_know_im_ready_to_exit
finish!
end
end
```Responding to keypresses can happen at a few different altitudes depending on your needs. If you just want to respond to a special key or two (enter and ESC) and character keys, you might do this:
```crystal
class CoolWidget < Keimeno::Base
def key_enter
enddef key_esc
enddef character_key(keystroke)
end
end
```For close-to-readline bindings on your user inputs, the `TextInput` or `Prompt` modules can be included and will render a text input at the cursor location which responds reasonably close to what might be expected from a readline interface.
```crystal
class MegaInputDevice < Keimeno::Base
include Keimeno::TextInputdef display
print "What is your favorite color? "
enddef key_enter
finish!
enddef return_value
input_text
end
end
```