-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathdareangel.dashboard.ts
92 lines (83 loc) · 3.44 KB
/
dareangel.dashboard.ts
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
85
86
87
88
89
90
// TODO: generate those free keys on the web
const COMPUTERVISIONKEY = "";
const BINGSPEECHKEY = "";
window.browser = (function () {
return window.msBrowser ||
window.browser ||
window.chrome;
})();
module DareAngel {
export class Dashboard {
private _targetDiv: HTMLElement;
private _imagesList = [];
private _tabIndex = 2;
private _canUseWebAudio = false;
private _audioContext: AudioContext;
private _bingTTSclient: BingTTS.Client;
private _useBingTTS = false;
constructor(targetDiv: HTMLElement) {
this._targetDiv = targetDiv;
this._bingTTSclient = new BingTTS.Client(BINGSPEECHKEY);
var BingTTSChk = <HTMLInputElement>document.getElementById("useBingTTS");
BingTTSChk.addEventListener("change", () => {
this._useBingTTS = BingTTSChk.checked;
});
browser.tabs.query({ active: true, currentWindow: true }, (tabs) => {
browser.tabs.sendMessage(tabs[0].id, { command: "requestImages" }, (response) => {
this._imagesList = JSON.parse(response);
this._imagesList.forEach((element) => {
var newImageHTMLElement = document.createElement("img");
newImageHTMLElement.src = element.url;
newImageHTMLElement.alt = element.alt;
newImageHTMLElement.tabIndex = this._tabIndex;
this._tabIndex++;
newImageHTMLElement.addEventListener("focus", (event) => {
if (COMPUTERVISIONKEY !== "") {
this.analyzeThisImage((<HTMLImageElement>event.target).src);
}
else {
var warningMsg = document.createElement("div");
warningMsg.innerHTML = "<h2>Please generate a Computer Vision key in the other tab.</h2>";
this._targetDiv.insertBefore(warningMsg, this._targetDiv.firstChild);
browser.tabs.create({active: false, url: "https://www.microsoft.com/cognitive-services/en-US/sign-up?ReturnUrl=/cognitive-services/en-us/subscriptions?productId=%2fproducts%2f54d873dd5eefd00dc474a0f4"});
}
});
this._targetDiv.appendChild(newImageHTMLElement);
});
});
});
}
private analyzeThisImage(url: string) {
var xhr = new XMLHttpRequest();
xhr.onreadystatechange = () => {
if (xhr.readyState == 4 && xhr.status == 200) {
var response = document.querySelector('#response');
var reponse = JSON.parse(xhr.response);
var resultToSpeak = `With a confidence of ${Math.round(reponse.description.captions[0].confidence * 100)}%, I think it's ${reponse.description.captions[0].text}`;
console.log(resultToSpeak);
if (!this._useBingTTS || BINGSPEECHKEY === "") {
var synUtterance = new SpeechSynthesisUtterance();
synUtterance.text = resultToSpeak;
window.speechSynthesis.speak(synUtterance);
}
else {
this._bingTTSclient.synthesize(resultToSpeak);
}
}
}
xhr.onerror = (evt) => {
console.log(evt);
};
try {
xhr.open('POST', 'https://api.projectoxford.ai/vision/v1.0/describe');
xhr.setRequestHeader("Content-Type", "application/json");
xhr.setRequestHeader("Ocp-Apim-Subscription-Key", COMPUTERVISIONKEY);
var requestObject = { "url": url };
xhr.send(JSON.stringify(requestObject));
}
catch (ex) {
console.log(ex);
}
}
}
}