-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfact.js
84 lines (66 loc) · 2.47 KB
/
fact.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
function getImageInfo(searchUrl, callback, errorCallback) {
var x = new XMLHttpRequest();
x.open('GET', searchUrl);
x.onreadystatechange=function()
{
if (x.readyState==4 && x.status==200)
{
var response = x.responseText;
var right_content = $($(response).filter('div#page.container').html()).filter('div#right_content').html();
var fishSources = [];
$(right_content).each(function(){
if ($($(this).find('img')).length !== 0){
var fish_name = $(this).find('img').filter('img').prop('alt');
var img_Url = $(this).find('img').filter('img').prop('src');
var fish = {"fishName" : fish_name, "imageUrl" : img_Url};
fishSources.push(fish);
}
});
var fishInfo = $(right_content).filter('p').html();
callback(fishSources[0]["imageUrl"], fishSources[0]["fishName"], fishInfo);
}
};
x.onerror = function() {
errorCallback('Network error.');
};
x.send();
}
function loadJQuery(){
var t=document;
var o=t.createElement('script');
o=t.createElement('script');
o.setAttribute('type','text/javascript');
o.setAttribute('src','https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js');
t.lastChild.firstChild.appendChild(o);
}
function renderStatus(statusText) {
document.getElementById('status').textContent = statusText;
}
document.addEventListener('DOMContentLoaded', function() {
loadJQuery();
var fishArray = [
'bigmouthbuffalo',
'yellowperch',
'whitesucker',
'trout/index',
'sauger',
'salmon/index',
'longnosegar',
'freshwaterdrum',
'catfish/index',
'burbot',
'bowfin',
'bass/index'
];
var randomNumber = Math.floor(Math.random()*fishArray.length);
var searchUrl = 'http://www.dnr.state.mn.us/fish/' + fishArray[randomNumber]+ '.html';
getImageInfo(searchUrl, function(imageSrc, fishName, fishInfo) {
var imageResult = document.getElementById('image-result');
imageResult.src = imageSrc;
imageResult.hidden = false;
$("#description").prepend($('<p>' + fishInfo + '</p>').fadeIn('slow'));
$("#fishName").prepend($('<h4>' + fishName + '</h4>').fadeIn('slow'));
}, function(errorMessage) {
renderStatus('Cannot display image. ' + errorMessage);
});
});