Skip to content

Commit fbd90e0

Browse files
authored
Merge pull request #16 from aahill/feb-additions
adding Bing Spell Check and Autosuggest samples
2 parents 738ca24 + f738c3f commit fbd90e0

File tree

12 files changed

+698
-7
lines changed

12 files changed

+698
-7
lines changed

Tutorials/BingAutosuggestApp.html

Lines changed: 149 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,149 @@
1+
<!DOCTYPE html>
2+
<html>
3+
<head>
4+
<meta charset="UTF-8">
5+
<title>Bing Autosuggest</title>
6+
7+
<style type="text/css">
8+
html, body, div, p, h1, h2 {font-family: Verdana, "Lucida Sans", sans-serif;}
9+
10+
html, body, div, p {font-weight: normal;}
11+
h1, h2 {font-weight: bold;}
12+
sup {font-weight: normal;}
13+
14+
html, body, div, p {font-size: 12px;}
15+
h1 {font-size: 20px;}
16+
h2 {font-size: 16px;}
17+
h1, h2 {clear: left;}
18+
19+
img#logo {float: right;}
20+
</style>
21+
22+
<script type="text/javascript">
23+
24+
getSubscriptionKey = function() {
25+
26+
var COOKIE = "bing-autosuggest-api-key"; // name used to store API key in key/value storage
27+
28+
function findCookie(name) {
29+
var cookies = document.cookie.split(";");
30+
for (var i = 0; i < cookies.length; i++) {
31+
var keyvalue = cookies[i].split("=");
32+
if (keyvalue[0].trim() === name) {
33+
return keyvalue[1];
34+
}
35+
}
36+
return "";
37+
}
38+
39+
function getSubscriptionKeyCookie() {
40+
var key = findCookie(COOKIE);
41+
while (key.length !== 32) {
42+
key = prompt("Enter Bing Autosuggest API subscription key:", "").trim();
43+
var expiry = new Date();
44+
expiry.setFullYear(expiry.getFullYear() + 2);
45+
document.cookie = COOKIE + "=" + key.trim() + "; expires=" + expiry.toUTCString();
46+
}
47+
return key;
48+
}
49+
50+
function getSubscriptionKeyLocalStorage() {
51+
var key = localStorage.getItem(COOKIE) || "";
52+
while (key.length !== 32)
53+
key = prompt("Enter Bing Autosuggest API subscription key:", "").trim();
54+
localStorage.setItem(COOKIE, key)
55+
return key;
56+
}
57+
58+
function getSubscriptionKey(invalidate) {
59+
if (invalidate) {
60+
try {
61+
localStorage.removeItem(COOKIE);
62+
} catch (e) {
63+
document.cookie = COOKIE + "=";
64+
}
65+
} else {
66+
try {
67+
return getSubscriptionKeyLocalStorage();
68+
} catch (e) {
69+
return getSubscriptionKeyCookie();
70+
}
71+
}
72+
}
73+
74+
return getSubscriptionKey;
75+
76+
}();
77+
78+
function pre(text) {
79+
return "<pre>" + text.replace(/&/g, "&amp;").replace(/</g, "&lt;") + "</pre>"
80+
}
81+
82+
function renderSearchResults(results) {
83+
document.getElementById("results").innerHTML = pre(JSON.stringify(results, null, 2));
84+
}
85+
86+
function renderErrorMessage(message, code) {
87+
if (code)
88+
document.getElementById("results").innerHTML = "<pre>Status " + code + ": " + message + "</pre>";
89+
else
90+
document.getElementById("results").innerHTML = "<pre>" + message + "</pre>";
91+
}
92+
93+
function bingAutosuggest(query, key) {
94+
var endpoint = "https://api.cognitive.microsoft.com/bing/v7.0/Suggestions";
95+
96+
var request = new XMLHttpRequest();
97+
98+
try {
99+
request.open("GET", endpoint + "?q=" + encodeURIComponent(query));
100+
}
101+
catch (e) {
102+
renderErrorMessage("Bad request");
103+
return false;
104+
}
105+
106+
request.setRequestHeader("Ocp-Apim-Subscription-Key", key);
107+
108+
request.addEventListener("load", function() {
109+
if (this.status === 200) {
110+
renderSearchResults(JSON.parse(this.responseText));
111+
}
112+
else {
113+
if (this.status === 401) getSubscriptionKey(true);
114+
renderErrorMessage(this.statusText, this.status);
115+
}
116+
});
117+
118+
request.addEventListener("error", function() {
119+
renderErrorMessage("Network error");
120+
});
121+
122+
request.addEventListener("abort", function() {
123+
renderErrorMessage("Request aborted");
124+
});
125+
126+
request.send();
127+
return false;
128+
}
129+
// --></script>
130+
131+
</head>
132+
133+
<body onload="document.forms.bing.query.focus(); getSubscriptionKey();">
134+
135+
<img id="logo" align=base src="">
136+
137+
<form name="bing" oninput="return bingAutosuggest(this.query.value, getSubscriptionKey())">
138+
<h2>Autosuggest</h2>
139+
<input type="text" name="query" size="80" placeholder="Autosuggest" autocomplete=off>
140+
</form>
141+
142+
<h2>Results</h2>
143+
<div id="results">
144+
<p>None yet.</p>
145+
146+
</div>
147+
148+
</body>
149+
</html>

0 commit comments

Comments
 (0)