An open-source JavaScript terminal emulator library, that works in your browser, Node.js and React.
This is a React Native wrapper around rohanchandra's extensible javascript-terminal
emulator. The goal of this library is to provide a consistent and easily-portable React Native interface to javascript-terminal
.
- In-memory file system, backed by Immutable.js
- Selected *NIX commands emulated (such as
ls
,cd
,head
,cat
,echo
,rm
) - Command parsing
- Support for environment variables
- Autocompletion of terminal commands
For more information, please check out the original repo. Whilst you're there, you should follow @rohanchandra.
Install with npm
or with yarn
.
npm install react-native-terminal-component --save
yarn add react-native-terminal-component
import React from 'react';
import { Alert } from 'react-native';
import Terminal from 'react-native-terminal-component';
export default class App extends React.Component {
render() {
return (
<Terminal
style={{
flex: 1,
}}
commandMapping={{
alert: {
function: (Terminal, opts) => {
Alert.alert(
opts
.join(' '),
);
}
optDef: {},
},
}}
/>
);
}
}
This library does not prescribe a method for displaying terminal output or the user interface, so I've provided examples in Node.js, pure JavaScript/HTML/CSS and with React/JavaScript/HTML/CSS:
- View the
/demo-cli
directory for an example of usage in Node.js - View the
/demo-web
directory for an example of usage in plain HTML and JavaScript - Visit the React Terminal Component website for usage with HTML, CSS, JavaScript and React
- View the
/demo-rn
directory for an example of usage in React Native.
First, make sure you have Node.js, Yarn and Git installed.
Now, fork and clone repo and install the dependencies.
git clone https://github.com/Cawfree/react-native-terminal-component
cd react-native-terminal-component/
yarn install
yarn build
- creates a development and production build of the library inlib
yarn build-rn
- generates the react-native wrapper interface stored indemo-rn/terminal.min.js
for the component (this must be re-ran for each modification made toreact-native.wrapper.js
)
yarn test
- run testsyarn test:min
- run tests with summary reportsyarn test:coverage
- shows test coverage statsyarn artifact:coverage-report
- creates HTML test coverage report in.nyc_output
yarn cli
- demo of using the emulator library in a Node.js command-line interface (this requires you have built the library withyarn build
)
Copyright 2018 Rohan Chandra
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.