slim-bot

Module for adding command features to an input field

Usage no npm install needed!

<script type="module">
  import slimBot from 'https://cdn.skypack.dev/slim-bot';
</script>

README

Slim-bot

Module for adding command features to an input field

Attaches an event listener to the provided input element. When prefix is entered, input gets .console-mode class and starts listening for commands

Installation

npm install slim-bot

Usage

HTML

<!-- Element to listen to -->
<input type="text" id="input-element" />

CSS

/* Class that gets applied when input enters console-mode */
.console-mode {
    background-color: lightred;
}

JS

// Import Tokenize from slim-bot
const Tokenize = require('slim-bot');

// Define HTMLInputElement
const inputElement = document.getElementById('input-element');

// Define commands
const myCommands = {
  'open': {
      params: ['Enter a URL or path'],
      operation: function(path) {
          window.open(path);
      }
  },
  'backgroundColor': {
      params: ['Enter a hex code'],
      operation: function(color) {
          document.body.style.backgroundColor = color;
      }
  },
  'big': {
      params: [],
      operation: function() {
          input.blur();
          input.classList.add('big');
          setTimeout(function() {
            input.classList.remove('big');
            input.focus();
          }, 1000);
      }
   }
};

// Instantiate Tokenize
const slimBot = new Tokenize({
    commands: myCommands,
    element: inputElement,
    prefix: '/'
});

Demo

Play around with the demo git clone https://github.com/daviddiefenderfer/slim-bot.git && cd slim-bot/demo && npm start

App served at localhost:8080