Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/cancerberosgx/accursed

blessed contributions, extensions, typings and documentation
https://github.com/cancerberosgx/accursed

Last synced: about 2 months ago
JSON representation

blessed contributions, extensions, typings and documentation

Awesome Lists containing this project

README

        

**Accursed**

[blessed](https://github.com/chjj/blessed/) contributions, extensions, typings, documentation and apps of mine

Summary: I discovered blessed, an awesome library for developing command line UI, but unfortunately is a discontinued project a dn has poor documentation.

Instead of cloning the project, here I try to develope missing parts, learn, document, type and find issues, but on top of it.

So I'm learning, documenting prototyping and researching. The following is a summary of work done.

- [Demos](#demos)
* [Running demos](#running-demos)
- [JSX](#jsx)
* [Attributes](#attributes)
* [IntrinsicElements](#intrinsicelements)
* [Class Elements and Function elements](#class-elements-and-function-elements)
+ [Class Elements](#class-elements)
+ [Function Elements](#function-elements)
* [Event handlers (function attributes)](#event-handlers-function-attributes)
* [blessed events supported 100% as JSXAttribtues](#blessed-events-supported-100%25-as-jsxattribtues)
* [Hight level event handlers](#hight-level-event-handlers)
+ [**event.currentTarget**](#eventcurrenttarget)
+ [onClick Example](#onclick-example)
+ [onRender example](#onrender-example)
+ [onChange example](#onchange-example)
+ [onSelect (for list-like elements)](#onselect-for-list-like-elements)
* [JSX Expressions](#jsx-expressions)
+ [conditions with AND operator](#conditions-with-and-operator)
+ [array render with map()](#array-render-with-map)
+ [conditions with ternary condition](#conditions-with-ternary-condition)
* [Refs](#refs)
* [Virtual Elements](#virtual-elements)
* [JSX Text](#jsx-text)
* [blessed-contrib](#blessed-contrib)
* [Rendering Component own children](#rendering-component-own-children)
* [Fragments](#fragments)
* [Hooks into React.crateElement](#hooks-into-reactcrateelement)
- [specs](#specs)
- [My blessed contrib widgets, utilities and JSX Components:](#my-blessed-contrib-widgets-utilities-and-jsx-components)
* [General tools](#general-tools)
* [JSX components](#jsx-components)
- [Apps](#apps)
- [Typings:](#typings)
- [Documentation:](#documentation)
- [How-to bless documents](#how-to-bless-documents)
* [Extending blessed Elements with TypeScript and accursed](#extending-blessed-elements-with-typescript-and-accursed)
* [Browserify](#browserify)
- [TODO & ISSUES & Ideas](#todo--issues--ideas)

# Demos

* Gallery: [![asciicast](https://asciinema.org/a/KcOrsgaP3vwhNPAic776MY9yi.svg)](https://asciinema.org/a/KcOrsgaP3vwhNPAic776MY9yi)

## Running demos

```
npm run start-emojis-search
npm run start-gallery
npm run start-cli-fonts-gallery
```

# JSX

* JSX/TSX support for all blessed components plus some of mine

Simple, implementation of React.createElement to render JSX to blessed elements.

Small but well-tested logic based on previous acquired knowledge in project https://github.com/cancerberoSgx/jsx-alone

## Attributes

Tip for JSX newcomers, JSX attributes are typed. If a blessed option accept a number or a boolean then the attribute must be also. Example: the following two expressions are equivalent:

```jsx
const el = blessed.listbar({
parent: screen, mouse: true, width: '88%',
height: 3, style: { selected: { bg: 'magenta' }, }
})
```

```jsx
const el = React.render( {
render() {
return


Hello {this.props.name}, so this are the colors: {this.props.colors.map(c=>)}

}
}
```

### Function Elements

In the following example, we create a new Element that will print children text with bold and optionally color styles.

```jsx
interface Props = { children: string | string[]; color?: string }
function Strong(props: Props) {
return (

)
}
```

## Event handlers (function attributes)

* work 100%
* are bind() to the element reference

## blessed events supported 100% as JSXAttribtues

JSX syntax, in event-related methods like like on() or key(), etc are supported via attributes. There is no syntax mapping at all, just straight forward method call, for example:

```js
textarea.key('f', (ch, key) => { ... }]}
```

equivalent to

´´ç
```jsx
{ ... }]}
```

If you notice some differences here, is ony because typings are insufficient, but there is no mapping/wrapping in these.

## Hight level event handlers

Although these are typed are kind of ugly because must be arrays. this is why also there are supported nicer "artificial" event handlers:. JSX-HTML event handler syntax more practical in the markup:

`onClick, onChange, onRender, onKeyPressed` so attributes are easy to write (just a function).

### **event.currentTarget**

Like with HTML - React - the event object of these hight level handlers have `currentTarget` property that references the element that triggered the event. Is particularly useful for change events in input elements:

```jsx
toggleCollapsed(e.currentTarget.parent as any, true)}
```

### onClick Example

```jsx
this.installCollapsible(e.currentTarget, { collapsedHeight: 4 })}
```

### onRender example

```jsx
this.installCollapsible(e.currentTarget, { collapsedHeight: 4 })}
```

### onChange example

(currently only supported for Checkbox and subclasses) - WIP

```jsx
toggleCollapsed(e.currentTarget.parent as any, true)}
```

### onSelect (for list-like elements)

```tsx
export class Categories extends Component {
render() {
return

Choose a category, select and emoji and press [ENTER] for details.

this.selected(e)}
/>
...
```

## JSX Expressions

Any expression often used to declare conditions aor iterate inside JSX Expressions are supported .

**Falsy values won't be rendered so you can write expressions like the following**

### conditions with AND operator
```
{ condition && ()
// append some elements to the screen.has a ref iption and its value is the object we jsut cerwated.)
const app =
expect(!ref1.current).isNotDefined() // before render the variable will be undefined
// after rendering the screen, we will be able to access the button using the variable without manually searching g for it.
blessed.screen.render()
// ... when the button finish rendering
ref1.current!.content = "'changed3"
ref1.current!.screen.render()
...
ref1.press()
...
```

Also `React.createRef()` accepts a callback that provides the new element:

```tsx
class App extends Component {
protected container: Box
render(){
return this.container = current)}>
...

}
}
```

## Virtual Elements

* Unique feature - not even existent in React
* Let component authors declare element's children props that won't be rendered at all.
* Useful to define complex component API as markup and then render another thing that implements it.
* See [spec](spec/virtualElementRenderingSpec.tsx)
* See [guides/virtual-elements.md](guides/virtual-elements.md)
* Examples of components that heavily use virtual elements to define their APIs:
* (src/jsx-components/tabPanel.tsx)[TabPanel]
* (src/jsx-components/listTable.tsx)[ListTable]
* (src/jsx-components/listBar.tsx)[ListBar]

## JSX Text

By default, for each JSXText node found, a new `blessed.text` is created.

THis means that JSX like

```jsx
Hello here I'm writing think this is invalid some in the middle and a tail
```

will be actually rendered as something like this

```jsx

```

Think on the TREE of blessed elements that will be generated). Also buttons will end up with a text inside. Below are more details, Probably a second implementaiton using parent's content attribute will be implemented and both will be available thorough configuration.

## blessed-contrib

**blessed-contrib widgets should be very easy to suuport, but right now I?m focusing on the framework and my own widgets tools and documentation, and hadent much time. They will be in time, probably in a separate project project.

## Rendering Component own children

* In custom components with children must render them using an expression like ` `

## Fragments

Not supported yet :()

## Hooks into React.crateElement

* WIP : api to extend the rendering process
* React object oprovide with some addLikstener in interesting moments of the rendering tha tusers can use to modify the render process and even interrupt / modify the flow but right now only sketches... working on that...

# specs

* blessed has no specs - seems they (did) run them manually. I'm writing specs with my new feaytures. Some I use cli-driver to test the tire flow from the real command line automation, and other, I just render the widgets and assert against the screen content.

* testing blessing APIs alone , even create custom elements: spec/blessedSpec.tsx
* jsx related: spec/jsxSpec.tsx
* using cli-driver to spawn a program and automate it spec/jsxSpec.tsx

# My blessed contrib widgets, utilities and JSX Components:

## General tools

* focus manager
* collapsible element
* node operations (ascendants, descendants, siblings, etc)
* showInModal()
* layout renderer with html like semantics display: block, overflow: hidden
* TreeView
* Maximize/Restore
* BorderBox
* EditorWidget from Slapeditor project. I updated dependencies and documented EditorWidget which is great. Made easy to use API that automatically highlights and focus the editor.
* ` visibleOnAncestorFocus` Automatically shows/hides descendants when ancestors (or any of its descendants) are focused
* `screenLogger` simple logger visual logger API
* `rowColumnResize`: adds small controls to resize rows or columns, easy to use with the keyboard and non invasive since the¥ only appear when column/row or descendant have focus.

## JSX components

* `ListTable`
* `TabPanel`
* `` conditions with markup - not so useful but interesting....
* `Button2`
* `ShowIf`
* `Collapsible`
* `Select`
* `Columns`
* `Accordion`
* `Autocomplete`
* `OptionsProvider`
* `Maximize` - wrapping an element with it will show a "maximize/restore" buttons floating at top-left
* `` component to easy render editor-component from slap editor project.
* `` - listbar semantics with jsx markup
* `cicks` to listen for multiple clicks (double click)

# Apps

* apps/emojis-search : a unicode data table explorer. Test blessed performance by letting ht user interactively navigate/search, etc the FULL unicode charset .

* accursed gallery, spec/blessed/gallery/LayoutDemo.tsx I tried to use these tools to build a interactive playground with examples. WIP

* json-cat: CLI app that render json streams with a tree view. Supports async render when streams are loading, filtering by text or json JSONPath.

* editar: CLI text-editor, inspired on vscode, based on editor-widget (independent form slap-editor)

* https://github.com/cancerberoSgx/demos/tree/master/docs/typescript-ast-explorer - explore a TypeScript project AST , visualize together with sources code and even apply refactors.

# Typings:

Also I think I've enhanced a lot the blessed.d.ts (TypeScript type declarations). ALthough the work from Definetely Typed I started from was very good, I did some refactoring so option types doesn't get too restrictive, I added lots of jsdoc comments and snippts to classes and methods and **declared lots of internal methods**. I want this types to be used by users extending the library (class MyElement extends blessing.widget.Box {}) and they need visibility to important methods, no matter if those are not meant to be published. I marked those with @internal tab. Also included typings for blessed-contrib but those I didn't modify so much.

# Documentation:

the typings already existing in DefinitelyTypes had more or less all the descriptions in blessed README. I added a lot from program.js, snippets and make sure it all blessed/tests.js compile OK with the types (which didn't). Also using typedoc I'm truing to generate html and markdown output of this so I can share with others.

* [Blessed API](https://cancerberosgx.github.io/demos/accursed/api/blessed/modules/_blessed_d_.html)

# How-to bless documents

## Extending blessed Elements with TypeScript and accursed

[guides/blessed-extending-element-typescript.md](guides/blessed-extending-element-typescript.md) explain how to extend blessed Element class to create a new Widget type, using TypeScript, in a type checked experience.

## Browserify

[guides/browserify.md](guides/browserify.md) explain how to run blessed programs in the browser using browserify.

[How to create a new blessed Element extending blessed classes, with descent type documented type checking and TypeScript using accursed:](guides/blessed-extending-element-typescript.md)

# TODO & ISSUES & Ideas

[TODO.md](TODO.md)