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