Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nitin42/terminal-in-react
๐จโ๐ป A component that renders a terminal
https://github.com/nitin42/terminal-in-react
css design javascript react svg terminal webapp webpack
Last synced: 5 days ago
JSON representation
๐จโ๐ป A component that renders a terminal
- Host: GitHub
- URL: https://github.com/nitin42/terminal-in-react
- Owner: nitin42
- License: mit
- Created: 2017-07-07T09:49:19.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2023-08-03T09:14:06.000Z (over 1 year ago)
- Last Synced: 2024-10-29T15:33:01.590Z (3 months ago)
- Topics: css, design, javascript, react, svg, terminal, webapp, webpack
- Language: JavaScript
- Homepage: http://terminal-in-react.surge.sh/
- Size: 495 KB
- Stars: 2,131
- Watchers: 21
- Forks: 151
- Open Issues: 40
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-list - terminal-in-react
README
# Terminal in React
[![Downloads][npm-dm]][package-url]
[![Downloads][npm-dt]][package-url]
[![NPM Version][npm-v]][package-url]
[![Dependencies][deps]][package-url]
[![Dev Dependencies][dev-deps]][package-url]
[![License][license]][package-url]
![size](https://img.shields.io/badge/size-31.4%20KB-brightgreen.svg)
![size](https://img.shields.io/badge/gzip-8.63%20KB-brightgreen.svg)
> A component that renders a terminal
## Table of contents
* [Install](#install)
* [Usage](#usage)
* [Working](#working)
* [Plugins](#using-plugins-)
* [Features](#more-features)
* [Customization](#customization)
* [API reference](#api)
* [Built-in commands](#built-in-commands)
* [Where to use ?](#where-to-use-)
* [Add a feature](#you-want-a-x-feature)
* [Contributing](#contributing)
* [Troubleshooting](#troubleshooting)
* [Detailed reference](https://github.com/nitin42/terminal-in-react/wiki)
## Install
```
npm install terminal-in-react --save
```
or if you use `yarn````
yarn add terminal-in-react
```This package also depends on `react` so make sure you've already installed it.
## Usage
```jsx
import React, { Component } from 'react';
import Terminal from 'terminal-in-react';class App extends Component {
showMsg = () => 'Hello World'render() {
return (
window.open('https://www.google.com/', '_blank'),
showmsg: this.showMsg,
popup: () => alert('Terminal in React')
}}
descriptions={{
'open-google': 'opens google.com',
showmsg: 'shows a message',
alert: 'alert', popup: 'alert'
}}
msg='You can write anything here. Example - Hello! My name is Foo and I like Bar.'
/>
);
}
}
```> Be careful when copying this example because it uses `window` object (`'open-google': () => window.open("https://www.google.com/", "_blank"),`) which is only available on the client-side and it will give you an error if you're doing server side rendering.
## Working
### Adding commands โ๏ธ
To add your own command, use prop `commands` which accepts an object. This objects then maps `command name -> command function`.
Let's take an example. You want to open a website with a command `open-google`
```jsx
window.open("https://www.google.com/", "_blank")}} />
```### Adding description of your command ๐๐ผโโ๏ธ
Add a description of your command using prop `description`.
```jsx
```
### Console logging
You can have the terminal watch console.log/info function and print out.
It does so by default.```jsx
```
### Command passthrough
You can have the terminal pass out the cmd that was input
```jsx
`-PassedThrough:${cmd}: command not found`} />
```### Async handling of commands ๐
you can also handle the result with a callback
```jsx
{
// do something async
print(`-PassedThrough:${cmd}: command not found`);
}}
/>
```### Minimise, maximise and close the window
```jsx
```
### Hide the default options
```jsx
```
This will hide the option color, show and clear.
### Advanced commands ๐จโ๐ป
You can give your commands options and get them back parsed to the method.
Using this method will also give your command a build in help output.
With the option `-h` or `--help`.```jsx
{
print(`The color is ${args._[0] || args.color}`);
},
options: [
{
name: 'color',
description: 'The color the output should be',
defaultValue: 'white',
},
],
},
}}
/>
```
The command API has three parameters `arguments`, `print`, and `runCommand`.
- `arguments` will be an array of the input split on spaces or and object with
parameters meeting the options given as well as a `_` option with any strings given
after the options.
- `print` is a method to write a new line to the terminals output. Any string returned
as a result of a command will also be printed.
- `runCommand` is a method to call other commands it takes a string and will
attempt to run the command givenLet's take an another example -
```jsx
{
const text = args.slice(1).join(' ');
print('');
for (let i = 0; i < text.length; i += 1) {
setTimeout(() => {
runCommand(`edit-line ${text.slice(0, i + 1)}`);
}, 100 * i);
}
}
}}
/>```
## Using plugins ๐ฅ
[Plugin Documentation](PLUGINS.md).
We have also developed a plugin system for the `` component which helps you develop custom plugins. Here is one example of plugin which creates a fake file system called [terminal-in-react-pseudo-file-system-plugin](https://github.com/jcgertig/terminal-in-react-pseudo-file-system-plugin).
### Instantiating the plugin
```jsx
import pseudoFileSystem from 'terminal-in-react-pseudo-file-system-plugin';
const FileSystemPlugin = pseudoFileSystem();```
or if the plugin requires config
```jsx
import NodeEvalPlugin from 'terminal-in-react-node-eval-plugin';
import pseudoFileSystemPlugin from 'terminal-in-react-pseudo-file-system-plugin';
const FileSystemPlugin = pseudoFileSystemPlugin();...
...
```
Awesome! Right? Let us know if you make something interesting ๐
## Plugin List
- [terminal-in-react-pseudo-file-system-plugin](https://github.com/jcgertig/terminal-in-react-pseudo-file-system-plugin) : A client-side only filesystem
- [terminal-in-react-node-eval-plugin](https://github.com/jcgertig/terminal-in-react-node-eval-plugin) : used with a filesystem to evaluate js code
- [terminal-in-react-vi-plugin](https://github.com/jcgertig/terminal-in-react-vi-plugin) : used with a filesystem to edit the contents of files more easily## More features
### Tab autocomplete
### Multiline input ๐คน๐ผโโ๏ธ
via `shift + enter`
### Check history of your commands ๐ฑ๏ธ
using arrow down and up keys
### Keyboard shortcuts โจ
You can define keyboard shortcuts. They have to be grouped by os. The three available are
`win`, `darwin`, and `linux`. You can group multiple os by a `,` for example if the
shortcut was for all platforms `win,darwin,linux` would be fine as a key```jsx
```
But you might want to specific
```jsx
```
You can mix and match
```jsx
```
The value of the shortcut should be a command to run.
## Override the top bar buttons actionHandlers
Use the prop `actionHandlers`.
The object allows for 3 methods `handleClose`, `handleMaximise`, `handleMinimise`;
Each one is a function and will pass in the default method as the first param.
Any method not passed in will use the default.```jsx
{
// do something on close
toggleClose();
},
handleMaximise: (toggleMaximise) => {
// do something on maximise
toggleMaximise();
}
}}
/>
```## Customization
Use
* prop `color` to change the color of the text.
* prop `outputColor` to change the color of the output text defaults to color prop.
* prop `backgroundColor` to change the background.
* prop `barColor` to change the color of bar.
* prop `prompt` to change the prompt (`>`) color.
* prop `showActions` to change if the three circles are shown.
* prop `hideTopBar` to hide the top bar altogether.
* prop `allowTabs` to allow multiple tabs.## API
**component props**
| Props | Type | Default |
| ------------- |:-------------:| -----:|
| **color** | string | 'green' |
| **outputColor** | string | props.color |
| **backgroundColor** | string | 'black' |
| **prompt** | string | 'green' |
| **barColor** | string | 'black' |
| **description** | object | {} |
| **commands** | object | { clear, help, show, } |
| **msg** | string | - |
| **closedTitle** | string | OOPS! You closed the window. |
| **closedMessage** | string | Click on the icon to reopen. |
| **watchConsoleLogging** | bool | false |
| **commandPassThrough** | function | null |
| **promptSymbol** | string | > |
| **plugins** | array | [ { name: '', load: new Plugin(), commands: {} descriptions: {} } ] |
| **startState** | string ['open', 'maximised', 'minimised', 'closed'] | 'open' |
| **showActions** | bool | true |
| **hideTopBar** | bool | false |
| **allowTabs** | bool | true |
| **actionHandlers** | object | - |## Built-in commands
* `clear` - Clears the screen
* `help` - List all the commands
* `show` - Shows a msg if any
* `echo` - Display the input message
* `edit-line` - Edits the last line or a given line using the `-l` argument## Where to use ?
* Embed it as a toy on your website
* For showcasing
* Explain any of your projects using this terminal component
* or just play with it## You want a X feature
Sure! Check our [todolist](./todo.md) or create an issue.
## Contributing
[Contributing Guide](./CONTRIBUTING.md)
## Troubleshooting
**Build errors when using with `create-react-app`**
Eject from `create-react-app` and use a custom webpack configuration with [`babili-webpack-plugin`](https://github.com/webpack-contrib/babili-webpack-plugin). Read more about this [here](https://github.com/facebookincubator/create-react-app/issues/984).
**Style issues when maximizing**
Set the style to `height: 100vh` on parent element.
[npm-dm]: https://img.shields.io/npm/dm/terminal-in-react.svg
[npm-dt]: https://img.shields.io/npm/dt/terminal-in-react.svg
[npm-v]: https://img.shields.io/npm/v/terminal-in-react.svg
[deps]: https://img.shields.io/david/nitin42/terminal-in-react.svg
[dev-deps]: https://img.shields.io/david/dev/nitin42/terminal-in-react.svg
[license]: https://img.shields.io/npm/l/terminal-in-react.svg
[package-url]: https://npmjs.com/package/terminal-in-react