aboutsummaryrefslogtreecommitdiff
path: root/demo
diff options
context:
space:
mode:
authorValentin Popov <dev@valentineus.link>2016-09-21 05:40:03 +0300
committerValentin Popov <dev@valentineus.link>2016-09-21 05:40:03 +0300
commitb9628f189b0ca2f7c411bd79566da37c73cc8e8f (patch)
tree01122bdea534d9cad15a63a271f87f742092b31f /demo
parent288980ceb35d5ace51284cfdf176e9acb5f7bb39 (diff)
downloadiii-module-b9628f189b0ca2f7c411bd79566da37c73cc8e8f.tar.xz
iii-module-b9628f189b0ca2f7c411bd79566da37c73cc8e8f.zip
Demo in beta mode.
Diffstat (limited to 'demo')
-rw-r--r--demo/components/class-application.php106
-rw-r--r--demo/components/communication.php16
-rw-r--r--demo/components/footer.php9
-rw-r--r--demo/components/navbar.php24
-rw-r--r--demo/components/results.php12
-rw-r--r--demo/components/settings.php24
-rw-r--r--demo/index.php83
-rw-r--r--demo/style.css40
8 files changed, 314 insertions, 0 deletions
diff --git a/demo/components/class-application.php b/demo/components/class-application.php
new file mode 100644
index 0000000..bdd6419
--- /dev/null
+++ b/demo/components/class-application.php
@@ -0,0 +1,106 @@
+<?php
+/**
+* Function of saving the token in a cookie.
+* When you receive the new value clears all stored cookies.
+* @param $token - The values of the token.
+*/
+function NewToken($token) {
+ unset($_COOKIE); // Removes all
+ SetCookie("BOT_TOKEN", $token); // Save a new cookie
+}
+
+/**
+* Session initialization function.
+* Searches saved session, producing a new
+* init or returns zero on failure.
+* @param $token - The values of the token.
+* @param $bot - Initialized bot.
+*/
+function GetSession($token, $bot) {
+ // Search the old session
+ if (isset($_COOKIE['BOT_SESSION'])) {
+ $session = $bot->session($_COOKIE['BOT_SESSION']);
+ } else { // Open a new one
+ $session = $bot->session();
+ SetCookie("BOT_SESSION", $session);
+ }
+
+ // We issue results
+ if (isset($session)) {
+ return $session;
+ } else {
+ return 0;
+ }
+}
+
+/**
+* The function returns the current ID.
+* Returns zero if no ID is stored.
+*/
+function GetID() {
+ // Search current ID...
+ if (isset($_COOKIE['CURRENT_ID'])) {
+ $id = (int)$_COOKIE['CURRENT_ID'] + 1;
+ // ...or returns zero
+ } else {
+ $id = 0;
+ }
+ // We issue results
+ return $id;
+}
+
+/**
+* The function overrides the current ID to
+* the specified or the next. If any missing ID
+* returns the one.
+* @param $id - Current ID.
+*/
+function SetID($id) {
+ // Process the specified ID...
+ if (isset($id)) {
+ $id = $id + 1;
+ // ...Or are saved...
+ } elseif (isset($_COOKIE['CURRENT_ID'])) {
+ $id = (int)$_COOKIE['CURRENT_ID'] + 1;
+ // ...Or return one
+ } else {
+ $id = 1;
+ }
+ SetCookie('CURRENT_ID', $id, time()+300); // Save the result
+ // We issue results
+ return $id;
+}
+
+/**
+* The function maintains a history of conversations,
+* using a database of cookie files.
+* @param $currentid - Message ID.
+* @param $textarea - Message text.
+* @param $type - Who said (Man / Bot).
+*/
+function SavingStories($currentid, $textarea, $type) {
+ // We form an array with values
+ $cookie = array(
+ 'type' => $type,
+ 'textarea' => $textarea,
+ 'time' => time());
+ // Save by encoding in JSON-string
+ SetCookie("TALK".$currentid, json_encode($cookie), time()+60);
+}
+
+/**
+* Function line formation.
+* @param $id - Variable Message ID.
+*/
+function ShowRecord($id) {
+ for ($i=0; $i < $id; $i++) {
+ if (isset($_COOKIE['TALK'.$i])) {
+ $cookie = json_decode($_COOKIE['TALK'.$i], true);
+ echo("<tr>");
+ echo("<td>".$cookie['type']."</td>");
+ echo("<td>".$cookie['textarea']."</td>");
+ echo("<td>".date("H:i:s", $cookie['time'])."</td>");
+ echo("</tr>");
+ }
+ }
+} ?>
diff --git a/demo/components/communication.php b/demo/components/communication.php
new file mode 100644
index 0000000..e73be75
--- /dev/null
+++ b/demo/components/communication.php
@@ -0,0 +1,16 @@
+<!-- Home side panel -->
+<form class="form-horizontal" method="post">
+ <div class="row">
+ <!-- Text field -->
+ <div class="col-md-8">
+ <input class="form-control" type="text" name="textarea" value="">
+ </div>
+ <!-- Control buttons -->
+ <div class="col-md-4">
+ <button type="submit" class="btn btn-default">Submit</button>
+ <button type="button" class="btn btn-success" data-toggle="modal" data-target="#SettingsModal">Settings</button>
+ </div>
+ </div><!-- row -->
+</form>
+<br/>
+<!-- End side panel -->
diff --git a/demo/components/footer.php b/demo/components/footer.php
new file mode 100644
index 0000000..b1df881
--- /dev/null
+++ b/demo/components/footer.php
@@ -0,0 +1,9 @@
+<!-- Beginning footer -->
+<footer class="footer">
+ <div class="container">
+ <p class="text-muted">
+ <a href="mailto:dev@valentineus.link">dev@valentineus.link</a>
+ </p>
+ </div>
+</footer>
+<!-- End footer -->
diff --git a/demo/components/navbar.php b/demo/components/navbar.php
new file mode 100644
index 0000000..9fcb9ee
--- /dev/null
+++ b/demo/components/navbar.php
@@ -0,0 +1,24 @@
+<!-- Start navigation bar -->
+<nav class="navbar navbar-default navbar-fixed-top">
+ <a href="https://github.com/valentineus/Module-III-API">
+ <img class="github-fork">
+ </a>
+ <div class="container">
+ <div class="collapse navbar-collapse">
+ <!-- The right side of the navigation bar -->
+ <ul class="nav navbar-nav navbar-right">
+ <li>
+ <p class="navbar-text"><?php
+ // Check the ability to use Cookie
+ if (SetCookie("TestCookie", "Success")) { ?>
+ <span class="glyphicon glyphicon-ok" aria-hidden="true"></span>
+ <?php } else { ?>
+ <span class="glyphicon glyphicon-remove" aria-hidden="true"></span>
+ <?php }
+ ?> Cookie</p>
+ </li>
+ </ul><!-- navbar-right -->
+ </div>
+ </div><!-- container -->
+</nav>
+<!-- End navigation bar -->
diff --git a/demo/components/results.php b/demo/components/results.php
new file mode 100644
index 0000000..4ae9332
--- /dev/null
+++ b/demo/components/results.php
@@ -0,0 +1,12 @@
+<div class="row">
+ <div class="col-md-12">
+ <table class="table table-striped">
+ <tr>
+ <th>#</th>
+ <th>Text</th>
+ <th>Date</th>
+ </tr>
+ <?php ShowRecord(GetID()); ?>
+ </table>
+ </div>
+</div>
diff --git a/demo/components/settings.php b/demo/components/settings.php
new file mode 100644
index 0000000..fe8e5ff
--- /dev/null
+++ b/demo/components/settings.php
@@ -0,0 +1,24 @@
+<!-- Start pop-up window for the settings -->
+<div class="modal fade" id="SettingsModal" tabindex="-1" role="dialog" aria-labelledby="SettingsModal">
+ <div class="modal-dialog" role="document">
+ <div class="modal-content">
+ <form class="form-horizontal" method="post">
+ <div class="modal-body">
+ <!-- Elements of a modal window -->
+ <div class="form-group">
+ <label for="inputPassword" class="col-sm-2 control-label">ID:</label>
+ <div class="col-sm-10">
+ <input type="text" class="form-control" id="inputPassword" name="BOT_TOKEN" placeholder="109cd867-0ef3-4473-af71-7543a9b2fccd">
+ </div>
+ </div>
+ </div>
+ <!-- The window control buttons -->
+ <div class="modal-footer">
+ <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
+ <button type="submit" class="btn btn-success">Save changes</button>
+ </div>
+ </form>
+ </div><!-- modal-content -->
+ </div><!-- modal-dialog -->
+</div>
+<!-- End pop-up window for the settings -->
diff --git a/demo/index.php b/demo/index.php
new file mode 100644
index 0000000..29a3609
--- /dev/null
+++ b/demo/index.php
@@ -0,0 +1,83 @@
+<?php
+ini_set("display_errors","1");
+ini_set("display_startup_errors","1");
+ini_set('error_reporting', E_ALL);
+?>
+<!DOCTYPE html>
+<html>
+ <head>
+ <!-- Connecting library jQuery -->
+ <script src="https://code.jquery.com/jquery-3.1.0.slim.min.js" integrity="sha256-cRpWjoSOw5KcyIOaZNo4i6fZ9tKPhYYb6i5T9RSVJG8=" crossorigin="anonymous"></script>
+ <!-- Connecting library Bootstrap -->
+ <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
+ <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap-theme.min.css" integrity="sha384-rHyoN1iRsVXV4nD0JutlnGaslCJuC7uwjduW9SVrLvRYooPp2bWYgmgJQIXwl/Sp" crossorigin="anonymous">
+ <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script>
+ <!-- Custom styles -->
+ <link href="style.css" rel="stylesheet">
+ <!-- Meta -->
+ <meta charset="utf-8">
+ <meta name="robots" content="NONE">
+ <!-- Title -->
+ <title>Testing conversational bot</title>
+ </head>
+ <body>
+ <?php // Connect all of the dependencies
+ include("../src/bot.php"); // Class for working with AI
+ include("components/class-application.php"); // Class to work with application logic
+ include("components/navbar.php"); // Connect the navigation bar
+ include("components/settings.php"); // Connecting a modal window with the settings
+ ?>
+ <!-- Begin page content -->
+ <div class="container">
+ <div class="page-header">
+ <h1>Communication Panel</h1>
+ </div>
+ <?php
+ // Checking the token initialization
+ if (isset($_POST['BOT_TOKEN'])) {
+ $token = htmlspecialchars($_POST['BOT_TOKEN']);
+ NewToken($token);
+ // ...Finding saved token
+ } elseif (isset($_COOKIE['BOT_TOKEN'])) {
+ $token = $_COOKIE['BOT_TOKEN'];
+ }
+
+ // The next step - checking/initialize the session with the bot.
+ if (isset($token)) {
+ // Initialize the robot system
+ define('BOT_TOKEN', $token);
+ $bot = new Bot(BOT_TOKEN);
+ $session = GetSession($token, $bot); // Initialize the session
+ if (empty($session)) { // No session? Error! ?>
+ <!-- Error Notification -->
+ <div class="alert alert-danger alert-dismissible" role="alert">
+ <button type="button" class="close" data-dismiss="alert" aria-label="Close"><span aria-hidden="true">&times;</span></button>
+ <strong>Error!</strong> Failed to create a session!
+ </div>
+ <?php }
+ } else { // Nope token? A warning! ?>
+ <!-- Error Notification -->
+ <div class="alert alert-warning alert-dismissible" role="alert">
+ <button type="button" class="close" data-dismiss="alert" aria-label="Close"><span aria-hidden="true">&times;</span></button>
+ <strong>Attention!</strong> No token: Required to check the settings!
+ </div>
+ <?php }
+
+ // Processes the message
+ if (isset($_POST['textarea'])) {
+ $currentid = GetID(); // Get the current ID
+ $currenttext = htmlspecialchars($_POST['textarea']); // Transform text
+ SavingStories($currentid, $currenttext, 'user'); // Keeping your message
+ $currentid = SetID($currentid); // Get next ID
+ SavingStories($currentid, $bot->say($currenttext), 'bot'); // Save bot response
+ header("Location: ".$_SERVER["REQUEST_URI"]); // Reloading the page
+ }
+
+ // Connecting the system interface
+ include("components/communication.php"); // Settings panel
+ include("components/results.php"); // Output messages
+ ?>
+ </div>
+ <?php include("components/footer.php"); // Connect the bottom panel ?>
+ </body>
+</html>
diff --git a/demo/style.css b/demo/style.css
new file mode 100644
index 0000000..abb8316
--- /dev/null
+++ b/demo/style.css
@@ -0,0 +1,40 @@
+html {
+ position: relative;
+ min-height: 100%;
+}
+
+body {
+ margin-bottom: 60px;
+}
+
+body > .container {
+ padding: 60px 15px 0;
+}
+
+textarea.form-control {
+ resize: none;
+}
+
+.footer {
+ background-color: #f5f5f5;
+ position: absolute;
+ height: 60px;
+ width: 100%;
+ bottom: 0;
+}
+
+.container .text-muted {
+ margin: 20px 0;
+}
+
+/* Loaded one icon from GitHub */
+.github-fork {
+ background: url('');
+ background-size: cover;
+ position: absolute;
+ height: 149px;
+ width: 149px;
+ border: 0;
+ left: 0;
+ top: 0;
+}