diff --git a/src/www/js/wc.js b/src/www/js/wc.js
index 612f52276..c292c99b4 100644
--- a/src/www/js/wc.js
+++ b/src/www/js/wc.js
@@ -8,7 +8,12 @@ wc.o=element("output")
wc.e=element("extra")
wc.i=element("grammarinfo")
wc.p=element("pick")
-wc.os=[] // output segment list
+wc.os=[] /* output segment list
+ [{input,text:String; from,to::Lang;
+ target:Node;
+ rs::[TranslationResults];
+ current_pick::Int // index into rs or -1
+ }] */
wc.cache={} // output segment cache, indexed by source text
wc.local=appLocalStorage("gf.wc.")
wc.translating=""
@@ -122,8 +127,9 @@ wc.translate=function() {
}
function word(w) {
var ps=w.split("_")
- return ps.length==2 && elem(ps[1],gftranslate.documented_classes)
- ? inflect(w,ps[1]) : text(w)
+ var n=ps.length
+ return ps.length>1 && elem(ps[n-1],gftranslate.documented_classes)
+ ? inflect(w,ps[n-1]) : text(w)
}
return tree.split(/([ ()]+)/).map(word)
}
@@ -132,7 +138,14 @@ wc.translate=function() {
var r=so.rs[so.current_pick]
var prob=r.prob<=0 ? "" : r.prob || ""
if(e) {
- e.innerHTML=prob+"
"
+ clear(e)
+ var speak_from=speech_buttons(so.from,"",so.input)
+ var speak_to=speech_buttons(so.to,"",so.text)
+ speak_to.className=speak_from.className="speech_buttons"
+ e.appendChild(wrap("div",[speak_from,
+ text(so.input+" → "+so.text),
+ speak_to]))
+ e.appendChild(wrap("div",text(prob)))
if(r.tree) {
wc.e2=node("div",{id:"tree-container","class":"e2"})
e.appendChild(wrap("span",treetext(r.tree)))
diff --git a/src/www/wc.html b/src/www/wc.html
index 06a86a973..3251b0925 100644
--- a/src/www/wc.html
+++ b/src/www/wc.html
@@ -32,6 +32,10 @@ span.inflect { color: blue; }
.node rect { fill: #fff; stroke: black; stroke-width: 1.5px; }
.node text { font-size: 10px; font-family: serif; }
.link { fill: none; stroke: #ccc; stroke-width: 1.5px; }
+.speech_buttons > * { display: none; }
+.speech_buttons > *:nth-child(1) { display: inline; }
+.speech_buttons > *:nth-child(2) { display: inline; }
+/* .speech_buttons:hover > * { display: inline; } */
@@ -103,7 +107,7 @@ span.inflect { color: blue; }