summaryrefslogtreecommitdiff
path: root/scripts
diff options
context:
space:
mode:
authorHeber Leonard <heber.leonard2@gmail.com>2020-07-08 16:27:55 -0300
committerHeber Leonard <heber.leonard2@gmail.com>2020-07-08 16:27:55 -0300
commit585639efc16011885c5c071266d1f32dab957270 (patch)
treef07f6837065b43015a158bac21ce8d06b5caf162 /scripts
first commit
Diffstat (limited to 'scripts')
-rw-r--r--scripts/main.js155
1 files changed, 155 insertions, 0 deletions
diff --git a/scripts/main.js b/scripts/main.js
new file mode 100644
index 0000000..1ee3067
--- /dev/null
+++ b/scripts/main.js
@@ -0,0 +1,155 @@
+
+const app = document.querySelector("#app");
+const delay = ms => new Promise(res => setTimeout(res, ms));
+
+
+app.addEventListener("keypress", async function(event){
+ if(event.key === "Enter"){
+ await delay(150);
+ getInputValue();
+
+ removeInput();
+ await delay(150);
+ new_line();
+ }
+});
+
+app.addEventListener("click", function(event){
+ const input = document.querySelector("input");
+ input.focus();
+})
+
+
+async function open_terminal(){
+ createText("Welcome");
+ await delay(700);
+ createText("Starting the server...");
+ await delay(1500);
+ createText("You can run several commands:");
+
+ createCode("about me", "Who am i and what do i do.");
+ createCode("all", "See all commands.");
+ createCode("social -a", "All my social networks.");
+
+ await delay(500);
+ new_line();
+}
+
+
+function new_line(){
+
+ const p = document.createElement("p");
+ const span1 = document.createElement("span");
+ const span2 = document.createElement("span");
+ p.setAttribute("class", "path")
+ p.textContent = "# user";
+ span1.textContent = " in";
+ span2.textContent = " ~/heber-leonard";
+ p.appendChild(span1);
+ p.appendChild(span2);
+ app.appendChild(p);
+ const div = document.createElement("div");
+ div.setAttribute("class", "type")
+ const i = document.createElement("i");
+ i.setAttribute("class", "fas fa-angle-right icone")
+ const input = document.createElement("input");
+ div.appendChild(i);
+ div.appendChild(input);
+ app.appendChild(div);
+ input.focus();
+
+}
+
+function removeInput(){
+ const div = document.querySelector(".type");
+ app.removeChild(div);
+}
+
+async function getInputValue(){
+
+ const value = document.querySelector("input").value;
+ if(value === "all"){
+ trueValue(value);
+
+ createCode("projects", "My github page with my projects. Follow me there ;)");
+ createCode("about me", "Who am i and what do i do.");
+ createCode("social -a", "All my social networks.");
+ createCode("clear", "Clean the terminal.");
+
+ }
+ else if(value === "projects"){
+ trueValue(value);
+ createText("<a href='https://github.com/heberleonard2' target='_blank'><i class='fab fa-github white'></i> github.com/heberleonard2</a>")
+ }
+ else if(value === "about me"){
+ trueValue(value);
+ createText("Oi, meu nome é Héber ;)")
+ createText("Desenvolvedor atualmente focado em o todo ecossistema Javascript. Utilizando principalmente a stack <span class='blue'>Node, React e React Native </span>por permitir criar aplicações de forma descomplicada e produtiva.")
+ }
+ else if(value === "social -a"){
+ trueValue(value);
+ createText("<a href='https://github.com/heberleonard2' target='_blank'><i class='fab fa-github white'></i> github.com/heberleonard2</a>")
+ createText("<a href='https://www.linkedin.com/in/heber-leonard/' target='_blank'><i class='fab fa-linkedin-in white'></i> linkedin.com/in/heber-leonard</a>")
+ createText("<a href='https://www.instagram.com/heber_leonard/' target='_blank'><i class='fab fa-instagram white'></i> instagram.com/heber_leonard</a>")
+ }
+ else if(value === "social"){
+ trueValue(value);
+ createText("Didn't you mean: social -all?")
+ }
+
+ else if(value === "clear"){
+ document.querySelectorAll("p").forEach(e => e.parentNode.removeChild(e));
+ document.querySelectorAll("section").forEach(e => e.parentNode.removeChild(e));
+ }
+ else{
+ falseValue(value);
+ createText(`command not found: ${value}`)
+ }
+}
+
+function trueValue(value){
+
+ const div = document.createElement("section");
+ div.setAttribute("class", "type2")
+ const i = document.createElement("i");
+ i.setAttribute("class", "fas fa-angle-right icone")
+ const mensagem = document.createElement("h2");
+ mensagem.setAttribute("class", "sucess")
+ mensagem.textContent = `${value}`;
+ div.appendChild(i);
+ div.appendChild(mensagem);
+ app.appendChild(div);
+}
+
+function falseValue(value){
+
+ const div = document.createElement("section");
+ div.setAttribute("class", "type2")
+ const i = document.createElement("i");
+ i.setAttribute("class", "fas fa-angle-right icone error")
+ const mensagem = document.createElement("h2");
+ mensagem.setAttribute("class", "error")
+ mensagem.textContent = `${value}`;
+ div.appendChild(i);
+ div.appendChild(mensagem);
+ app.appendChild(div);
+}
+
+function createText(text, classname){
+ const p = document.createElement("p");
+
+ p.innerHTML =
+ text
+ ;
+ app.appendChild(p);
+}
+
+function createCode(code, text){
+ const p = document.createElement("p");
+ p.setAttribute("class", "code");
+ p.innerHTML =
+ `${code} <br/><span class='text'> ${text} </span>`;
+ app.appendChild(p);
+}
+
+open_terminal(); \ No newline at end of file