Toolkit for building a bash-like shell in the browser, including full readline support
Javascript Online SHell provides a toolkit for building bash-like command line consoles for web pages. It consists of the following components:
readline.js - full readline support for ctrl sequences, tab, history, etc.
  shell.js - visual presentation of the shell and command handling
  pathhandler.js - provide cd, ls, pwd and path completion toolkit
  history.js - localStorage backed command history
  killring.js - killring for kill & yank handling in readline
  help or hit TAB for a list of commands.
  ls,
    cd, pwd and bash filename tab-completion
  Josh.Input for binding to input elements.josh.js is licensed under the Apache 2.0 License
Until documentation is written, refer to index.html and
  the annotated version of
  example.js for a sample implementation of a shell with path completion.
josh is built from 5 components and can be used in part or in full.
readline.js has no dependencies on any outside libraries, although it requires either
  history.js and killring.js or objects implementing the same calls.
It implements key trapping to bring
  GNU Readline like line editing to the browser. It can be used by itself to bring readline support to custom data entry fields or in conjunction with
  shell.js to create a full console.
In the below C-x refers to the Ctrl-x keystroke, while
  M-x refers to the Meta-x keystroke which is mapped to Alt, ⌘ and
  Left Windows.
C-b or Left Arrow
  M-b or Right Arrow
  C-fM-fC-a or Home
  C-e or End
  BackspaceC-d or Delete
  C-kM-BackspaceM-dC-yM-yC-rC-p or Up Arrow
  C-n or Down Arrow
  Page UpPage DownC-lTabEsc in reverse search
  C-conCancel handlerC-d on empty line
  onCancel handlershell.js has external dependencies of jQuery,
  Underscore and internal dependencies of readline.js and
  history.js.
It provides a simple console UI, using a panel for the console viewport and an auto-scrolling view inside the panel. It uses Underscore templates for generating the view html, although any template generator can be substituted as long as it can be expressed in the form of a function that takes a JSON object of arguments and returns an html string.
It also implements command handling so that new commands can be added by name with execution and completion handlers. Out of the box,
  shell.js provides the following commands:
help - list all known commands (including user added)clear - clear the "screen" i.e. viewporthistory - show the command history captured by readline.js in history.js
  pathhandler.js is a mix in to easily add the cd, ls and
  pwd commands as well as path completion. It has
  Underscore as its dependency for templating, however since all
  templates it uses are exposed, they could easily be replaced with a different function that accepts an argument object returns html.
By implementing the functions getNode and
  getChildNodes, this library adds path traversal, discovery and completion just like a bash shell.
  history.js implements a localStorage back command history storage that persists over page changes and reloads. It is used by the
  shell.js history command to list all executed commands, and by
  readline.js for up/down arrow and reverse search capabilities.
  killing.js implements the kill and yank behavior as well as state tracking, i.e. multiple consecutive kills are combined as a single kill and killring rotation tracks the previous yank, so that the
  readline.js can remove the previous yank and replace it with the rotated text.