Skip to content
This repository has been archived by the owner on Feb 17, 2021. It is now read-only.

Commit

Permalink
Merge pull request #53 from ft-interactive/random-guff
Browse files Browse the repository at this point in the history
Use query selectors for DOM manipulation
  • Loading branch information
Sumeet Adur committed Dec 15, 2015
2 parents 0fe261f + 5b36df1 commit cd65e53
Showing 1 changed file with 17 additions and 12 deletions.
29 changes: 17 additions & 12 deletions client/scripts/main.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,12 @@ document.addEventListener('DOMContentLoaded', () => {
attachFastClick(document.body);

if (page === 'main' && document.documentElement.className === 'enhanced') {
let xmlhttp = new XMLHttpRequest();
let xmlhttp;
if (window.XMLHttpRequest) {
xmlhttp = new XMLHttpRequest();
} else {
xmlhttp = new ActiveXObject('Microsoft.XMLHTTP');
}
xmlhttp.onreadystatechange = function () {
if (xmlhttp.readyState === 4 && xmlhttp.status === 200) {
words = JSON.parse(xmlhttp.responseText);
Expand All @@ -28,35 +33,35 @@ function newRandomGuff() {

let randomNumber = Math.floor(Math.random() * (wordArray.length - 1)) + 1;

while (words[wordArray[randomNumber]].slug === document.getElementsByClassName('latest-guff')[0].id) {
while (words[wordArray[randomNumber]].slug === document.querySelector('.latest-guff').id) {
randomNumber = Math.floor(Math.random() * (wordArray.length - 1)) + 1;
}

const randomWord = words[wordArray[randomNumber]];

const randomGuffElement = document.getElementsByClassName('random-guff')[0];
const randomGuffElement = document.querySelector('.random-guff');

let randomGuffClone = randomGuffElement.cloneNode(true);

randomGuffClone.setAttribute('style', 'visibility: visible;');

let refreshButton = randomGuffClone.getElementsByClassName('refresh')[0];
let refreshButton = randomGuffClone.querySelector('.refresh');

if (!refreshButton) {
refreshButton = document.createElement('span');
refreshButton.className = 'refresh';
randomGuffClone.getElementsByClassName('paraHeads')[0].appendChild(refreshButton);
randomGuffClone.querySelector('.paraHeads').appendChild(refreshButton);
}

refreshButton.addEventListener('click', () => {
newRandomGuff();
});

let word = randomGuffClone.getElementsByClassName('word')[0];
let details = randomGuffClone.getElementsByClassName('details')[0];
const definition = details.getElementsByClassName('detail definition')[0];
const usageExample = details.getElementsByClassName('detail usageexample')[0];
const relatedWordsElement = details.getElementsByClassName('detail relatedwords')[0];
let word = randomGuffClone.querySelector('.word');
let details = randomGuffClone.querySelector('.details');
const definition = details.querySelector('.detail.definition');
const usageExample = details.querySelector('.detail.usageexample');
const relatedWordsElement = details.querySelector('.detail.relatedwords');

word.href = randomWord.slug + '/';
word.innerHTML = randomWord.word + '»';
Expand Down Expand Up @@ -107,6 +112,6 @@ function newRandomGuff() {

details.appendChild(newRelatedWordsElement);
}
document.getElementsByTagName('main')[0].insertBefore(randomGuffClone, randomGuffElement);
document.getElementsByTagName('main')[0].removeChild(randomGuffElement);
document.querySelector('main').insertBefore(randomGuffClone, randomGuffElement);
document.querySelector('main').removeChild(randomGuffElement);
}

0 comments on commit cd65e53

Please sign in to comment.