TEXT 'O' MATIC 6000 (Concept)

In this example below you will see how to do a TEXT 'O' MATIC 6000 (Concept) with some HTML / CSS and Javascript

This pen is a conceptual pen based around the idea of having small fun little games that run client-side, and rely only on Javascript and a bit of styling. This pen could be embedded into a loading screen for something bulkier, or just as a fun little characteristic for your webpage.

Thumbnail
This awesome code was written by 16-Bit-Bacon, you can see more from this user in the personal repository.
You can find the original code on Codepen.io
Copyright 16-Bit-Bacon ©

Technologies

  • HTML
  • CSS
  • JavaScript
<!DOCTYPE html>
<html lang="en" >

<head>
  <meta charset="UTF-8">
  <title>TEXT 'O' MATIC 6000 (Concept)</title>
  <meta name="viewport" content="width=device-width, initial-scale=2">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/normalize/5.0.0/normalize.min.css">

  <link rel='stylesheet prefetch' href='http://cdnjs.cloudflare.com/ajax/libs/animate.css/3.2.3/animate.min.css'>

      <style>
      /* NOTE: The styles were added inline because Prefixfree needs access to your styles and they must be inlined if they are on local disk! */
      @charset "UTF-8";
@import url(https://fonts.googleapis.com/css?family=VT323);
html {
  background-color: #000;
  font-family: Consolas, monaco, monospace;
  color: #fff;
  font-size: 22px;
  text-transform: uppercase;
  margin: 10px;
}

hr {
  opacity: 0.2;
}

img {
  width: 50px;
  height: 50px;
  padding: 5px;
  opacity: 0.5;
}

.popupimg {
  width: 17vw;
  height: 17vw;
  position: absolute;
  right: 10vw;
  bottom: 10hw;
  opacity: 0.8;
}
.popupimg img {
  width: 100%;
  height: 100%;
}
.popupimg .hide {
  display: none;
}

.console_stats {
  font-size: 26px;
}

progress {
  -webkit-appearance: progress-bar;
  appearance: progress-bar;
  width: 25vw;
  height: 16px;
  border: 0;
  height: 18px;
  border-radius: 8px;
}

.health {
  background: #666;
  color: #666;
  transition: background 2s ease-in-out;
  transition: color 2s ease-in-out;
}

.health-full {
  background: #008000;
  color: #008000;
}

.health-half {
  background: #f90;
  color: #f90;
}

.health-low {
  background: #f00;
  color: #f00;
}

.user_input {
  color: #000;
}
.user_input .user-input_type {
  animation-name: color_change;
  animation-duration: 5s;
  animation-iteration-count: infinite;
  animation-direction: alternate;
  color: #fff;
  border: 0;
  width: 100%;
  line-height: 2;
}

btn, button, input[type="reset"] {
  display: none;
}

#gameOutput {
  height: 25vh;
}

@keyframes color_change {
  from {
    background-color: rgba(237, 255, 0, 0.1);
  }
  to {
    background-color: rgba(149, 118, 0, 0.1);
  }
}
* {
  box-sizing: border-box;
}

body {
  background: #383838;
  color: #14fdce;
  font-family: "VT323";
  font-size: 24px;
  -webkit-font-smoothing: none;
  line-height: 1.2;
}

h1 {
  font-size: 4rem;
  margin-bottom: 1rem;
  text-transform: uppercase;
}

p {
  margin-bottom: 2rem;
}

a {
  border-bottom: 0.2rem solid #14fdce;
  color: #14fdce;
  text-decoration: none;
  border-bottom: 0.2rem solid #14fdce;
  color: #14fdce;
  text-decoration: none;
  background-color: #14fdce;
  color: #031e11;
}

.piece {
  display: block;
  height: 100%;
  left: 0;
  top: 0;
  width: 100%;
}

.noclick {
  pointer-events: none;
}

.frame {
  background-color: transparent;
  border-radius: 2rem;
  border: 1rem solid;
  border-bottom-color: #121212;
  border-left-color: #080808;
  border-right-color: #080808;
  border-top-color: #020202;
  box-shadow: inset 0 0 18rem black, inset 0 0 3rem black, 0 0 10rem black;
  height: 96%;
  position: absolute;
  top: 2%;
  left: 2%;
  width: 96%;
  pointer-events: none;
}

.emblem {
  display: none;
  position: absolute;
  left: 50%;
  bottom: 0;
  font-size: 2rem;
  height: 3rem;
  width: 3rem;
  text-align: center;
  color: white;
  background: -webkit-linear-gradient(#ffffff, #555555);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 0.1rem 0rem rgba(0, 0, 0, 0.4), 0 0 2rem rgba(0, 0, 0, 0.8);
  -webkit-transform: translate(-50%);
  -ms-transform: translate(-50%);
  transform: translate(-50%);
}

.crtoutput {
  -webkit-animation: crt-output 10ms infinite;
  animation: crt-output 10ms infinite;
  background-color: #031e11;
  overflow: scroll;
  position: absolute;
  padding: 3rem 2rem;
  pointer-events: auto;
  text-shadow: 0rem 0.2rem 1rem #0c7b46;
  z-index: -1;
}

@-webkit-keyframes crt-output {
  0%;
  opacity: 0.9;
  50%;
  opacity: 1;
}
@keyframes crt-output {
  0%;
  opacity: 0.9;
  50%;
  opacity: 1;
}
.scanlines {
  background: -webkit-linear-gradient(top, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0) 50%, rgba(0, 0, 0, 0.2) 70%, rgba(0, 0, 0, 0.6));
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0) 50%, rgba(0, 0, 0, 0.2) 70%, rgba(0, 0, 0, 0.6));
  background-size: 100% 0.3rem;
  border-radius: 2rem;
  position: absolute;
}

.glow {
  -webkit-animation: crt-glow 60s infinite;
  animation: crt-glow 60s infinite;
  background: -webkit-radial-gradient(center, circle, #1bd459 0%, rgba(27, 212, 89, 0.88) 58%, rgba(21, 235, 92, 0.57) 80%, rgba(19, 94, 29, 0.27) 93%, rgba(10, 23, 12, 0) 100%);
  background: radial-gradient(circle at center, #1bd459 0%, rgba(27, 212, 89, 0.88) 58%, rgba(21, 235, 92, 0.57) 80%, rgba(19, 94, 29, 0.27) 93%, rgba(10, 23, 12, 0) 100%);
  opacity: 0.15;
  pointer-events: none;
  position: fixed;
}

@-webkit-keyframes crt-glow {
  0%;
  opacity: 0.1;
  50%;
  opacity: 0.2;
}
@keyframes crt-glow {
  0%;
  opacity: 0.1;
  50%;
  opacity: 0.2;
}
::-moz-selection, ::selection {
  background-color: #14fdce;
  color: #031e11;
}

@font-face {
  font-family: "uuxsl";
  src: url("https://i.icomoon.io/public/188ac2dd2d/VOX/uuxsl.eot");
}
@font-face {
  font-family: "uuxsl";
  src: url(data:application/x-font-ttf;charset=utf-8;base64,AAEAAAALAIAAAwAwT1MvMg8SA1AAAAC8AAAAYGNtYXAaL8yjAAABHAAAAExnYXNwAAAAEAAAAWgAAAAIZ2x5ZiGj2jMAAAFwAAAA7GhlYWQEpbQaAAACXAAAADZoaGVhB6kDxgAAApQAAAAkaG10eAYAABkAAAK4AAAAFGxvY2EAKACKAAACzAAAAAxtYXhwAA0AMgAAAtgAAAAgbmFtZeGQWB4AAAL4AAABM3Bvc3QAAwAAAAAELAAAACAAAwQAAZAABQAAApkCzAAAAI8CmQLMAAAB6wAzAQkAAAAAAAAAAAAAAAAAAAABEAAAAAAAAAAAAAAAAAAAAABAAADmJgPA/8AAQAPAAEAAAAABAAAAAAAAAAAAAAAgAAAAAAACAAAAAwAAABQAAwABAAAAFAAEADgAAAAKAAgAAgACAAEAIOYm//3//wAAAAAAIOYm//3//wAB/+MZ3gADAAEAAAAAAAAAAAAAAAEAAf//AA8AAQAAAAAAAAAAAAIAADc5AQAAAAABAAAAAAAAAAAAAgAANzkBAAAAAAEAAAAAAAAAAAACAAA3OQEAAAAABwAZ/8YD5wO1AAUADQAVABsAIQAnAC8AABMVFzcnNQMFERcnNzU3ARElBxcVFwcvARUHFzcDJwcVNxcHFzc1JwcBBycHJxUFJeFVb1UZ/uJwAslVAkL+4m5VygJYcFVvVs1TU1NTplNTU1MBclXKylUBHwEfAbdnMUExZwG9pf61QWh04zH+UQFLpUEx4nVoNEFoMUExAcAwMHwxMNAxMWkvMP67MXV1MXympwAAAAABAAAAAQAAwDym7F8PPPUACwQAAAAAANDPt9EAAAAA0M+30QAA/8YD5wO1AAAACAACAAAAAAAAAAEAAAPA/8AAAAQAAAAAAAPnAAEAAAAAAAAAAAAAAAAAAAAFAAAAAAAAAAAAAAAAAgAAAAQAABkAAAAAAAoAFAAeAHYAAQAAAAUAMAAHAAAAAAACAAAAAAAAAAAAAAAAAAAAAAAAAA4ArgABAAAAAAABAAoAAAABAAAAAAACAA4AOQABAAAAAAADAAoAIAABAAAAAAAEAAoARwABAAAAAAAFABYACgABAAAAAAAGAAUAKgABAAAAAAAKADQAUQADAAEECQABAAoAAAADAAEECQACAA4AOQADAAEECQADAAoAIAADAAEECQAEAAoARwADAAEECQAFABYACgADAAEECQAGAAoALwADAAEECQAKADQAUQB1AHUAeABzAGwAVgBlAHIAcwBpAG8AbgAgADEALgAwAHUAdQB4AHMAbHV1eHNsAHUAdQB4AHMAbABSAGUAZwB1AGwAYQByAHUAdQB4AHMAbABGAG8AbgB0ACAAZwBlAG4AZQByAGEAdABlAGQAIABiAHkAIABJAGMAbwBNAG8AbwBuAC4AAAMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=) format("truetype"), url(data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAAASYAAsAAAAABEwAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABPUy8yAAABCAAAAGAAAABgDxIDUGNtYXAAAAFoAAAATAAAAEwaL8yjZ2FzcAAAAbQAAAAIAAAACAAAABBnbHlmAAABvAAAAOwAAADsIaPaM2hlYWQAAAKoAAAANgAAADYEpbQaaGhlYQAAAuAAAAAkAAAAJAepA8ZobXR4AAADBAAAABQAAAAUBgAAGWxvY2EAAAMYAAAADAAAAAwAKACKbWF4cAAAAyQAAAAgAAAAIAANADJuYW1lAAADRAAAATMAAAEz4ZBYHnBvc3QAAAR4AAAAIAAAACAAAwAAAAMEAAGQAAUAAAKZAswAAACPApkCzAAAAesAMwEJAAAAAAAAAAAAAAAAAAAAARAAAAAAAAAAAAAAAAAAAAAAQAAA5iYDwP/AAEADwABAAAAAAQAAAAAAAAAAAAAAIAAAAAAAAgAAAAMAAAAUAAMAAQAAABQABAA4AAAACgAIAAIAAgABACDmJv/9//8AAAAAACDmJv/9//8AAf/jGd4AAwABAAAAAAAAAAAAAAABAAH//wAPAAEAAAAAAAAAAAACAAA3OQEAAAAAAQAAAAAAAAAAAAIAADc5AQAAAAABAAAAAAAAAAAAAgAANzkBAAAAAAcAGf/GA+cDtQAFAA0AFQAbACEAJwAvAAATFRc3JzUDBREXJzc1NwERJQcXFRcHLwEVBxc3AycHFTcXBxc3NScHAQcnBycVBSXhVW9VGf7icALJVQJC/uJuVcoCWHBVb1bNU1NTU6ZTU1NTAXJVyspVAR8BHwG3ZzFBMWcBvaX+tUFodOMx/lEBS6VBMeJ1aDRBaDFBMQHAMDB8MTDQMTFpLzD+uzF1dTF8pqcAAAAAAQAAAAEAAMA8puxfDzz1AAsEAAAAAADQz7fRAAAAANDPt9EAAP/GA+cDtQAAAAgAAgAAAAAAAAABAAADwP/AAAAEAAAAAAAD5wABAAAAAAAAAAAAAAAAAAAABQAAAAAAAAAAAAAAAAIAAAAEAAAZAAAAAAAKABQAHgB2AAEAAAAFADAABwAAAAAAAgAAAAAAAAAAAAAAAAAAAAAAAAAOAK4AAQAAAAAAAQAKAAAAAQAAAAAAAgAOADkAAQAAAAAAAwAKACAAAQAAAAAABAAKAEcAAQAAAAAABQAWAAoAAQAAAAAABgAFACoAAQAAAAAACgA0AFEAAwABBAkAAQAKAAAAAwABBAkAAgAOADkAAwABBAkAAwAKACAAAwABBAkABAAKAEcAAwABBAkABQAWAAoAAwABBAkABgAKAC8AAwABBAkACgA0AFEAdQB1AHgAcwBsAFYAZQByAHMAaQBvAG4AIAAxAC4AMAB1AHUAeABzAGx1dXhzbAB1AHUAeABzAGwAUgBlAGcAdQBsAGEAcgB1AHUAeABzAGwARgBvAG4AdAAgAGcAZQBuAGUAcgBhAHQAZQBkACAAYgB5ACAASQBjAG8ATQBvAG8AbgAuAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA) format("woff");
  font-weight: normal;
  font-style: normal;
}
::-moz-selection [class^="icon-"], [class*=" icon-"] {
  font-family: "uuxsl";
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

::selection [class^="icon-"], [class*=" icon-"] {
  font-family: "uuxsl";
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

::-moz-selection .icon-information:before, ::selection .icon-information:before {
  content: "";
}

::-moz-selection .noisy, ::selection .noisy {
  background-image: url();
}

    </style>

    <script src="https://cdnjs.cloudflare.com/ajax/libs/prefixfree/1.0.7/prefixfree.min.js"></script>

</head>

<body>

  
<body class="noisy"></body>
<div class="emblem"><span class="icon-information"></span></div>
<div class="frame">
  <div class="piece crtoutput">
    <h2>Text 'o' Matic 6000</h2>
    <div class="animated">
      <div class="console_stats">
        <div class="popupimg"><img class="hide" id="img1" src="http://placehold.it/350x350"/><img id="img2" src="http://placehold.it/350x350"/><img class="hide" id="img3" src="http://placehold.it/350x350"/><img class="hide" id="img4" src="http://placehold.it/350x350"/><img class="hide" id="img5" src="http://placehold.it/350x350"/></div>
        <div id="stats"><b>Stats:</b><br/><img src="http://placehold.it/350x350" width="40px"/><span class="label">HP: </span><span class="stat" data-stat="hp"></span>
          <progress class="health" value="100" min="0" max="100" data-stat="hp"></progress><br/><img src="http://placehold.it/350x350" width="40px"/><span class="label">Inventory: </span><span class="stat" data-stat="inv"></span><br/><img src="http://placehold.it/350x350" width="40px"/><span class="label">Speed: </span><span class="stat" data-stat="spd"></span><br/><img src="http://placehold.it/350x350" width="40px"/><span class="label">Intelligence: </span><span class="stat" data-stat="mgk"></span><br/><img src="http://placehold.it/350x350" width="40px"/><span class="label">Strength: </span><span class="stat" data-stat="str"></span><br/><img src="http://placehold.it/350x350" width="40px"/><span class="label">Kills: </span><span class="stat" data-stat="kc"></span><br/>
        </div>
        <hr/>
      </div>
      <div class="console_output">
        <div id="gameOutput">WHAT IS YOUR ADVENTURER'S NAME?</div><br/>
      </div>
      <div>
        <hr/>
        <form class="user_input" id="gameForm" name="inputForm" action="action.php">
          <input class="user-input_type" id="gameInput" type="text"/>
          <input class="user_input" type="submit" value="Submit"/>
        </form><br/>
      </div>
    </div>
  </div>
  <div class="piece scanlines noclick"></div>
  <div class="piece glow noclick"></div>
</div>
  <script src='http://cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js'></script>
<script src='http://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.11.2/jquery-ui.min.js'></script>

  

    <script  src="js/index.js"></script>




</body>

</html>

/*Downloaded from https://www.codeseek.co/16-Bit-Bacon/text-andaposoandapos-matic-6000-concept-EVmjrL */
@charset "UTF-8";
@import url(https://fonts.googleapis.com/css?family=VT323);
html {
  background-color: #000;
  font-family: Consolas, monaco, monospace;
  color: #fff;
  font-size: 22px;
  text-transform: uppercase;
  margin: 10px;
}

hr {
  opacity: 0.2;
}

img {
  width: 50px;
  height: 50px;
  padding: 5px;
  opacity: 0.5;
}

.popupimg {
  width: 17vw;
  height: 17vw;
  position: absolute;
  right: 10vw;
  bottom: 10hw;
  opacity: 0.8;
}
.popupimg img {
  width: 100%;
  height: 100%;
}
.popupimg .hide {
  display: none;
}

.console_stats {
  font-size: 26px;
}

progress {
  -webkit-appearance: progress-bar;
  appearance: progress-bar;
  width: 25vw;
  height: 16px;
  border: 0;
  height: 18px;
  border-radius: 8px;
}

.health {
  background: #666;
  color: #666;
  transition: background 2s ease-in-out;
  transition: color 2s ease-in-out;
}

.health-full {
  background: #008000;
  color: #008000;
}

.health-half {
  background: #f90;
  color: #f90;
}

.health-low {
  background: #f00;
  color: #f00;
}

.user_input {
  color: #000;
}
.user_input .user-input_type {
  animation-name: color_change;
  animation-duration: 5s;
  animation-iteration-count: infinite;
  animation-direction: alternate;
  color: #fff;
  border: 0;
  width: 100%;
  line-height: 2;
}

btn, button, input[type="reset"] {
  display: none;
}

#gameOutput {
  height: 25vh;
}

@keyframes color_change {
  from {
    background-color: rgba(237, 255, 0, 0.1);
  }
  to {
    background-color: rgba(149, 118, 0, 0.1);
  }
}
* {
  box-sizing: border-box;
}

body {
  background: #383838;
  color: #14fdce;
  font-family: "VT323";
  font-size: 24px;
  -webkit-font-smoothing: none;
  line-height: 1.2;
}

h1 {
  font-size: 4rem;
  margin-bottom: 1rem;
  text-transform: uppercase;
}

p {
  margin-bottom: 2rem;
}

a {
  border-bottom: 0.2rem solid #14fdce;
  color: #14fdce;
  text-decoration: none;
  border-bottom: 0.2rem solid #14fdce;
  color: #14fdce;
  text-decoration: none;
  background-color: #14fdce;
  color: #031e11;
}

.piece {
  display: block;
  height: 100%;
  left: 0;
  top: 0;
  width: 100%;
}

.noclick {
  pointer-events: none;
}

.frame {
  background-color: transparent;
  border-radius: 2rem;
  border: 1rem solid;
  border-bottom-color: #121212;
  border-left-color: #080808;
  border-right-color: #080808;
  border-top-color: #020202;
  box-shadow: inset 0 0 18rem black, inset 0 0 3rem black, 0 0 10rem black;
  height: 96%;
  position: absolute;
  top: 2%;
  left: 2%;
  width: 96%;
  pointer-events: none;
}

.emblem {
  display: none;
  position: absolute;
  left: 50%;
  bottom: 0;
  font-size: 2rem;
  height: 3rem;
  width: 3rem;
  text-align: center;
  color: white;
  background: -webkit-linear-gradient(#ffffff, #555555);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 0.1rem 0rem rgba(0, 0, 0, 0.4), 0 0 2rem rgba(0, 0, 0, 0.8);
  -webkit-transform: translate(-50%);
  -ms-transform: translate(-50%);
  transform: translate(-50%);
}

.crtoutput {
  -webkit-animation: crt-output 10ms infinite;
  animation: crt-output 10ms infinite;
  background-color: #031e11;
  overflow: scroll;
  position: absolute;
  padding: 3rem 2rem;
  pointer-events: auto;
  text-shadow: 0rem 0.2rem 1rem #0c7b46;
  z-index: -1;
}

@-webkit-keyframes crt-output {
  0%;
  opacity: 0.9;
  50%;
  opacity: 1;
}
@keyframes crt-output {
  0%;
  opacity: 0.9;
  50%;
  opacity: 1;
}
.scanlines {
  background: -webkit-linear-gradient(top, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0) 50%, rgba(0, 0, 0, 0.2) 70%, rgba(0, 0, 0, 0.6));
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0) 50%, rgba(0, 0, 0, 0.2) 70%, rgba(0, 0, 0, 0.6));
  background-size: 100% 0.3rem;
  border-radius: 2rem;
  position: absolute;
}

.glow {
  -webkit-animation: crt-glow 60s infinite;
  animation: crt-glow 60s infinite;
  background: -webkit-radial-gradient(center, circle, #1bd459 0%, rgba(27, 212, 89, 0.88) 58%, rgba(21, 235, 92, 0.57) 80%, rgba(19, 94, 29, 0.27) 93%, rgba(10, 23, 12, 0) 100%);
  background: radial-gradient(circle at center, #1bd459 0%, rgba(27, 212, 89, 0.88) 58%, rgba(21, 235, 92, 0.57) 80%, rgba(19, 94, 29, 0.27) 93%, rgba(10, 23, 12, 0) 100%);
  opacity: 0.15;
  pointer-events: none;
  position: fixed;
}

@-webkit-keyframes crt-glow {
  0%;
  opacity: 0.1;
  50%;
  opacity: 0.2;
}
@keyframes crt-glow {
  0%;
  opacity: 0.1;
  50%;
  opacity: 0.2;
}
::-moz-selection, ::selection {
  background-color: #14fdce;
  color: #031e11;
}

@font-face {
  font-family: "uuxsl";
  src: url("https://i.icomoon.io/public/188ac2dd2d/VOX/uuxsl.eot");
}
@font-face {
  font-family: "uuxsl";
  src: url(data:application/x-font-ttf;charset=utf-8;base64,AAEAAAALAIAAAwAwT1MvMg8SA1AAAAC8AAAAYGNtYXAaL8yjAAABHAAAAExnYXNwAAAAEAAAAWgAAAAIZ2x5ZiGj2jMAAAFwAAAA7GhlYWQEpbQaAAACXAAAADZoaGVhB6kDxgAAApQAAAAkaG10eAYAABkAAAK4AAAAFGxvY2EAKACKAAACzAAAAAxtYXhwAA0AMgAAAtgAAAAgbmFtZeGQWB4AAAL4AAABM3Bvc3QAAwAAAAAELAAAACAAAwQAAZAABQAAApkCzAAAAI8CmQLMAAAB6wAzAQkAAAAAAAAAAAAAAAAAAAABEAAAAAAAAAAAAAAAAAAAAABAAADmJgPA/8AAQAPAAEAAAAABAAAAAAAAAAAAAAAgAAAAAAACAAAAAwAAABQAAwABAAAAFAAEADgAAAAKAAgAAgACAAEAIOYm//3//wAAAAAAIOYm//3//wAB/+MZ3gADAAEAAAAAAAAAAAAAAAEAAf//AA8AAQAAAAAAAAAAAAIAADc5AQAAAAABAAAAAAAAAAAAAgAANzkBAAAAAAEAAAAAAAAAAAACAAA3OQEAAAAABwAZ/8YD5wO1AAUADQAVABsAIQAnAC8AABMVFzcnNQMFERcnNzU3ARElBxcVFwcvARUHFzcDJwcVNxcHFzc1JwcBBycHJxUFJeFVb1UZ/uJwAslVAkL+4m5VygJYcFVvVs1TU1NTplNTU1MBclXKylUBHwEfAbdnMUExZwG9pf61QWh04zH+UQFLpUEx4nVoNEFoMUExAcAwMHwxMNAxMWkvMP67MXV1MXympwAAAAABAAAAAQAAwDym7F8PPPUACwQAAAAAANDPt9EAAAAA0M+30QAA/8YD5wO1AAAACAACAAAAAAAAAAEAAAPA/8AAAAQAAAAAAAPnAAEAAAAAAAAAAAAAAAAAAAAFAAAAAAAAAAAAAAAAAgAAAAQAABkAAAAAAAoAFAAeAHYAAQAAAAUAMAAHAAAAAAACAAAAAAAAAAAAAAAAAAAAAAAAAA4ArgABAAAAAAABAAoAAAABAAAAAAACAA4AOQABAAAAAAADAAoAIAABAAAAAAAEAAoARwABAAAAAAAFABYACgABAAAAAAAGAAUAKgABAAAAAAAKADQAUQADAAEECQABAAoAAAADAAEECQACAA4AOQADAAEECQADAAoAIAADAAEECQAEAAoARwADAAEECQAFABYACgADAAEECQAGAAoALwADAAEECQAKADQAUQB1AHUAeABzAGwAVgBlAHIAcwBpAG8AbgAgADEALgAwAHUAdQB4AHMAbHV1eHNsAHUAdQB4AHMAbABSAGUAZwB1AGwAYQByAHUAdQB4AHMAbABGAG8AbgB0ACAAZwBlAG4AZQByAGEAdABlAGQAIABiAHkAIABJAGMAbwBNAG8AbwBuAC4AAAMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=) format("truetype"), url(data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAAASYAAsAAAAABEwAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABPUy8yAAABCAAAAGAAAABgDxIDUGNtYXAAAAFoAAAATAAAAEwaL8yjZ2FzcAAAAbQAAAAIAAAACAAAABBnbHlmAAABvAAAAOwAAADsIaPaM2hlYWQAAAKoAAAANgAAADYEpbQaaGhlYQAAAuAAAAAkAAAAJAepA8ZobXR4AAADBAAAABQAAAAUBgAAGWxvY2EAAAMYAAAADAAAAAwAKACKbWF4cAAAAyQAAAAgAAAAIAANADJuYW1lAAADRAAAATMAAAEz4ZBYHnBvc3QAAAR4AAAAIAAAACAAAwAAAAMEAAGQAAUAAAKZAswAAACPApkCzAAAAesAMwEJAAAAAAAAAAAAAAAAAAAAARAAAAAAAAAAAAAAAAAAAAAAQAAA5iYDwP/AAEADwABAAAAAAQAAAAAAAAAAAAAAIAAAAAAAAgAAAAMAAAAUAAMAAQAAABQABAA4AAAACgAIAAIAAgABACDmJv/9//8AAAAAACDmJv/9//8AAf/jGd4AAwABAAAAAAAAAAAAAAABAAH//wAPAAEAAAAAAAAAAAACAAA3OQEAAAAAAQAAAAAAAAAAAAIAADc5AQAAAAABAAAAAAAAAAAAAgAANzkBAAAAAAcAGf/GA+cDtQAFAA0AFQAbACEAJwAvAAATFRc3JzUDBREXJzc1NwERJQcXFRcHLwEVBxc3AycHFTcXBxc3NScHAQcnBycVBSXhVW9VGf7icALJVQJC/uJuVcoCWHBVb1bNU1NTU6ZTU1NTAXJVyspVAR8BHwG3ZzFBMWcBvaX+tUFodOMx/lEBS6VBMeJ1aDRBaDFBMQHAMDB8MTDQMTFpLzD+uzF1dTF8pqcAAAAAAQAAAAEAAMA8puxfDzz1AAsEAAAAAADQz7fRAAAAANDPt9EAAP/GA+cDtQAAAAgAAgAAAAAAAAABAAADwP/AAAAEAAAAAAAD5wABAAAAAAAAAAAAAAAAAAAABQAAAAAAAAAAAAAAAAIAAAAEAAAZAAAAAAAKABQAHgB2AAEAAAAFADAABwAAAAAAAgAAAAAAAAAAAAAAAAAAAAAAAAAOAK4AAQAAAAAAAQAKAAAAAQAAAAAAAgAOADkAAQAAAAAAAwAKACAAAQAAAAAABAAKAEcAAQAAAAAABQAWAAoAAQAAAAAABgAFACoAAQAAAAAACgA0AFEAAwABBAkAAQAKAAAAAwABBAkAAgAOADkAAwABBAkAAwAKACAAAwABBAkABAAKAEcAAwABBAkABQAWAAoAAwABBAkABgAKAC8AAwABBAkACgA0AFEAdQB1AHgAcwBsAFYAZQByAHMAaQBvAG4AIAAxAC4AMAB1AHUAeABzAGx1dXhzbAB1AHUAeABzAGwAUgBlAGcAdQBsAGEAcgB1AHUAeABzAGwARgBvAG4AdAAgAGcAZQBuAGUAcgBhAHQAZQBkACAAYgB5ACAASQBjAG8ATQBvAG8AbgAuAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA) format("woff");
  font-weight: normal;
  font-style: normal;
}
::-moz-selection [class^="icon-"], [class*=" icon-"] {
  font-family: "uuxsl";
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

::selection [class^="icon-"], [class*=" icon-"] {
  font-family: "uuxsl";
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

::-moz-selection .icon-information:before, ::selection .icon-information:before {
  content: "";
}

::-moz-selection .noisy, ::selection .noisy {
  background-image: url();
}


/*Downloaded from https://www.codeseek.co/16-Bit-Bacon/text-andaposoandapos-matic-6000-concept-EVmjrL */
var TextAdventure = function() {

    // PRIVATE VARIABLES

    // Initialize Starting Stat List \\
    var stats = {
            spd: 3,
            mgk: 3,
            str: 3,
            hp: 100,
            inv: [{
                name: "sword",
                type: "atk",
                damage: 5
            }, {
                name: "helmet",
                type: "def",
                armour: 3
            }],
            kc: 0,
            dmg: 10
        },

        // Initialize Other Variables \\
        userInput,
        currentChapter = 0,
        user = {},

        // PRIVATE FUNCTIONS

        // Refresh the stats \\
        update = function(data) {

            console.log(data);

            $.each(data, function(key, val) {
                if (key == 'name') {
                    user.name = val;
                    console.log('Name is: ' + val);
                } else if (stats.hasOwnProperty(key)) {
                    setStat(key, val);
                    showStat(key);
                    console.log('key: ' + key + ' & val: ' + val);
                }
            });
        },

        // Tool Functions \\

        clearConsole = function() {
            $('#output').html('');
        },

        gameOver = function() {
            alert('GAME OVER');
        },

        inventoryToStringvar = function(inv) {
            var outputString = '';
            $.each(inv, function(key, val) {
                outputString += key + ': ' + val + ', ';
            });

            return outputString;
        },

        incrementStat = function(stat, amount) {

            // Update data
            stats[stat] += amount;

            // Update DOM
            if (stat == 'hp') {

                var $health = $('#hitpoints');
                $health.val(hp);
                // NOTE: This feature is currently broken
                if (hp <= 0) {
                    hp = 0;
                    console.log("change to empty");
                    $health.removeClass("health-half health-full").addClass("health-low");
                    gameOver();
                } else if (hp <= 50) {
                    console.log("change to half");
                    $health.removeClass("health-low health-full").addClass("health-half");
                } else if (hp >= 100) {
                    hp = 100;
                    console.log("change to full");
                    $health.removeClass("health-half health-low").addClass("health-full");
                } else {
                    console.log("change to full");
                    $health.removeClass("health-half health-low").addClass("health-full");
                }
            }

            $('.stat[data-stat="' + stat + '"]').text(stats[stat]);
        },
        
        incrementStats = function(amount) {
            incrementStat("spd", amount),
            incrementStat("mgk", amount),
            incrementStat("str", amount);
        },

        getStat = function(stat) {
            return stats[stat];
        },

        setStat = function(stat, newValue) {
            stats[stat] = newValue;
            return getStat(stat);
        },

        showStat = function(stat) {

            var value = getStat(stat);

            $('[data-stat="' + stat + '"]').each(function() {
                var $el = $(this);

                if ($el.prop("tagName") == 'PROGRESS') {
                    $el.animate({
                        value: value
                    }, 1000);
                } else {
                    $el.text(value);
                }
            });
        },

        showStats = function() {

            $.each(stats, function(key, val) {
                showStat(key);
            });
        },

        setChapter = function(chapter) {
            currentChapter = chapter;
        },
    
        showSuccessMessage = function() {
            alert("Level up!");
        };

    // PUBLIC FUNCTIONS
    return {

        init: function() {
            showStats();
        },

        levelUp: function() {
            incrementStats(10);
            showSuccessMessage();
        },

        getChapter: function() {
            return currentChapter;
        },

        // Run Game \\
        update: function(data) {

            update(data);
            var newChapter = currentChapter + 1;
            setChapter(newChapter);
        }
    }
}();

$(function() {

    TextAdventure.init();

    var $gameForm = $('#gameForm'),
        $gameInput = $('#gameInput'),
        $output = $('#gameOutput'),
        $img1 = $('#img1'),
        $img2 = $('#img2'),
        $img3 = $('#img3'),
        $img4 = $('#img4'),
        $img5 = $('#img5');

    // EVENT HANDLERS
    $gameForm.on('submit', function() {

        var chapter = TextAdventure.getChapter(),
            data, // null
            userInput = $gameInput.val();

        if (chapter == 0) {
            TextAdventure.levelUp();
            $output.html('Welcome, ' + userInput + '. Input a number to changee all your stats...');
            $img2.addClass("hide");
            $img3.removeClass("hide");

            data = {
                name: userInput
            };
        } else if (chapter == 1) {
            $output.html('Input a number to change your kill count...');
            $img3.addClass("hide");
            $img4.removeClass("hide");

            data = {
                hp: userInput,
                spd: userInput,
                mgk: userInput,
                str: userInput
            };
        } else if (chapter == 2) {
            $output.html('Input a  number to modify your health...');
            $img4.addClass("hide");
            $img5.removeClass("hide");

            data = {
                kc: userInput
            };
        } else if (chapter == 3) {
            $output.html('STOP! Do not submit anything!');
            $img5.addClass("hide");
            $img1.removeClass("hide");

            data = {
                hp: userInput
            };
        } else {
            $output.html('Game over!');
            $img1.addClass("hide");
            $img2.removeClass("hide");

            data = {
                hp: 0
            };
        }
        
        TextAdventure.update(data);
    });
});

Comments