Skip to content

Latest commit

 

History

History
102 lines (91 loc) · 2.93 KB

README.md

File metadata and controls

102 lines (91 loc) · 2.93 KB

Note-Worthy Algorithm: Nested API Calls

In this project we use an axios call to generate Wikipedia entries, as well as an API call through the JService-Node npm package. Because the axios query term will not be generated until trivia question is generated, it is necessary to nest the axios call inside the API call. It is also important to know that these two calls return data in different formats (array for axios, json for api), their syntaxes will therefore be slightly different.

Javascript:

// Requiring middleware
const express = require("express")
const exphbs = require("express-handlebars")
const bodyParser = require("body-parser")
const axios = require("axios")
const js = require('jservice-node');

// Instantiate express
const app = express()

// Integrating middleware
app.engine('handlebars', exphbs({ defaultLayout: 'main' }));
app.set('view engine', 'handlebars');
app.use(bodyParser.urlencoded({
  extended: true
}))
app.use(bodyParser.json())

// HTTP Protocol: Get Homepage
app.get("/", (req, res) => {
  // Grab one random question from jservice-node
  js.random(1, function(error, response, json){
    if(!error && response.statusCode == 200){
        console.log(json[0].question);
        const question = json[0].question;
        const answer = json[0].answer;
        const category = json[0].category.title;
        let queryString = answer;
        let term = encodeURIComponent(queryString)
        let url = "http://en.wikipedia.org/w/api.php?action=opensearch&search="+term+"&limit=1&format=json"

        // Populate Wiki entry using axios
        axios.get(url)
        .then(response => {
          res.render("home", {
            fyiDecript: response.data[2],
            fyiLink: response.data[3],
            question: question,
            answer: answer,
            category: category
          })
        })
        .catch(error => {
          console.log(error);
        });
    } else {
        console.log(`Error: ${response.statusCode}`);
    }
  });

})

Handlebars (HTML Template)

<!-- Trivia Section -->
<div class="trivia-section">
  <div class="trivia-category">
    <h3>Category: </h3>
    <p>{{category}}</p>
  </div>
  <h3>Prompt:</h3>
  <div class="trivia-card">
    <div class="trivia-question">
      <p>{{question}}</p>
    </div>
    <div id="answer" class="trivia-answer">
      <p>{{answer}}</p>
    </div>
  </div>
</div>

<!-- "Did You Know?" Section -->
<div id="fyi" class="fyi-section">
  <h3>Did You Know?</h3>
  <div class="fyi-card">
    <p>{{fyiDecript}}</p>
    <p>
      Would you like to know more? - <a target="_blank" href={{fyiLink}}>{{fyiLink}}</a>
    </p>
  </div>
</div>

trivia-binge

Endless trivia game using Jeopardy's API. Website built in HTML/CSS/JS and Node/Express

Wikipedia Edge Cases:

  1. Words beginning with "the"
  2. Words that are italicize
  3. Words that redirect to "{{this}} could refer to: " (Ex: Rubik)