diff --git a/README.md b/README.md index 6fe3d0e..7e0e965 100644 --- a/README.md +++ b/README.md @@ -1,11 +1,29 @@ -# chat-bubble -### A super-simple, tiny script for creating chat bot interfaces +# 💬 chat-bubble +## A super-simple, tiny script for creating chat bot interfaces -![Screenshot](screenshot.jpg?raw=true) +![Screenshot](screenshot.gif?raw=true) -- Super-easy to use, even if you don't code much! Here's the [tutorial](https://htmlpreview.github.io/?https://github.com/dmitrizzle/chat-bubble/blob/master/component/start-here/hello.html). -- Insanely small footprint, 1.03KB GZipped. -- No dependencies. Written with ES5, vanilla JavaScript. +- Super-easy to install & use! Here's the [tutorial bot](https://htmlpreview.github.io/?https://github.com/dmitrizzle/chat-bubble/blob/master/component/examples/0-tutor.html). +- Insanely small footprint, 1KB GZipped. +- No dependencies. Written with ES5, vanilla JavaScript. Works with modern browsers. + +### Usage +```html +
+``` + +```javascript + + // set up the chatbot script + var givemeBubbles = new Bubbles( + document.getElementById('chat'), // attach chatbot to placeholder above ^^ + "givemeBubbles" // you need to pass the name of the constructor variable that evokes Bubble function here + ); + + // pass JSON to your function and you're done! + givemeBubbles.talk({ "ice": { "says": [ "Hi" ] } }); +``` +Please see examples and the [tutorial bot](https://htmlpreview.github.io/?https://github.com/dmitrizzle/chat-bubble/blob/master/component/examples/0-tutor.html) link to learn more on how to use this thing. This component comes with styles in CSS files. They are separated in to multiple files. You can turn them into styled components, SASS or whatever for your convenience. For now it's just vanilla CSS so that this tool can work anywhere, regardless of the environment. diff --git a/component/Bubbles.js b/component/Bubbles.js index 7b3a2e6..190580a 100644 --- a/component/Bubbles.js +++ b/component/Bubbles.js @@ -2,11 +2,11 @@ function Bubbles(container, self, options) { // options options = typeof options !== "undefined" ? options : {}; - animationTime = options.animationTime || 200; // how long it takes to animate chat bubble, also set in CSS - typeSpeed = options.typeSpeed || 5; // delay per character, to simulate the machine "typing" - widerBy = options.widerBy || 2; // add a little extra width to bubbles to make sure they don't break - sidePadding = options.sidePadding || 6; // padding on both sides of chat bubbles - inputCallbackFn = options.inputCallbackFn || (function(o){ return false }); // should we display an input field? + animationTime = options.animationTime || 200; // how long it takes to animate chat bubble, also set in CSS + typeSpeed = options.typeSpeed || 5; // delay per character, to simulate the machine "typing" + widerBy = options.widerBy || 2; // add a little extra width to bubbles to make sure they don't break + sidePadding = options.sidePadding || 6; // padding on both sides of chat bubbles + inputCallbackFn = options.inputCallbackFn || false; // should we display an input field? var standingAnswer = "ice"; // remember where to restart convo if interrupted @@ -43,6 +43,7 @@ function Bubbles(container, self, options) { }); container.appendChild(inputWrap); bubbleWrap.style.paddingBottom = "100px"; + inputText.focus(); } inputCallbackFn ? this.typeInput(inputCallbackFn) : false; diff --git a/component/example-help.html b/component/example-help.html deleted file mode 100644 index 8328e69..0000000 --- a/component/example-help.html +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - \ No newline at end of file diff --git a/component/examples/0-tutor.html b/component/examples/0-tutor.html new file mode 100644 index 0000000..4537722 --- /dev/null +++ b/component/examples/0-tutor.html @@ -0,0 +1,229 @@ + + ++ Note: This is a simple script that isn't connected to any Natural Language Cognition networks. Whatever you type on the keyboard will be matched against the possible options given (dark grey bubbles). This script can't correct your spelling, it can't infer from synonyms or slang etc. But it is forgiving in terms of punctuation, capitalization and amount of text you type. For example, if one of the accepted answers is "Do 👉 this," you can simply type "do" and it'll work. +
+