diff options
| author | hallgren <hallgren@chalmers.se> | 2014-05-07 23:42:05 +0000 |
|---|---|---|
| committer | hallgren <hallgren@chalmers.se> | 2014-05-07 23:42:05 +0000 |
| commit | fc6d8f63623c166ed79d2d2e3c4a73cc1de0a9a7 (patch) | |
| tree | 765d804007e84a9c5b7823cedbf3b1486f5ac4dd /src/www/js | |
| parent | 70b192594e7d3057b6d7422e60e9e08011e4dc00 (diff) | |
Wide Coverage Demo App: show all Phrasebook translations
Also improve behaviour for languages that are missing in Phrasebook (Chinese).
Also update the initial set of languages in the menus to match Translate11.pgf.
Diffstat (limited to 'src/www/js')
| -rw-r--r-- | src/www/js/gftranslate.js | 21 | ||||
| -rw-r--r-- | src/www/js/wc.js | 80 |
2 files changed, 62 insertions, 39 deletions
diff --git a/src/www/js/gftranslate.js b/src/www/js/gftranslate.js index a232bde50..86cdc477a 100644 --- a/src/www/js/gftranslate.js +++ b/src/www/js/gftranslate.js @@ -85,20 +85,23 @@ function trans_text_quality(text) { } // find_to :: Lang -> [{to:Lang,...}] -> Int -find_to=function(to,lins) { +function find_to(to,lins) { for(var i=0;i<lins.length;i++) if(lins[i].to==to) return i - return 0 // Hmm.... + return -1 // Hmm.... } -trans_quality=function(r,to) { +function trans_quality(r,to) { var ix=to ? find_to(to,r.linearizations) : 0 - var text=r.linearizations[ix].text - if(r.prob==0) return {quality:"high_quality",text:text} + if(ix<0) return null else { - var t=trans_text_quality(text) - if(t.quality=="default_quality" && r.tree && r.tree[0]=="?") - t.quality="low_quality" - return t + var text=r.linearizations[ix].text + if(r.prob==0) return {quality:"high_quality",text:text} + else { + var t=trans_text_quality(text) + if(t.quality=="default_quality" && r.tree && r.tree[0]=="?") + t.quality="low_quality" + return t + } } } diff --git a/src/www/js/wc.js b/src/www/js/wc.js index 51fb97a23..7ce80b11a 100644 --- a/src/www/js/wc.js +++ b/src/www/js/wc.js @@ -57,9 +57,15 @@ wc.translate=function() { return s.split(/([.!?]+[ \t\n]+|\n\n+|[ \t\n]*[-•*+#]+[ \t\n]+)/) } + function find_pick(rs) { + for(var i=0;i<rs.length && !rs[i].t;i++) + ; + return i + } + function translate_segment(so) { // so = segment output so.rs=[] // list of alternative translations for this segment - so.current_pick=0 // index of currently selected alternative + so.current_pick= -1 // index of currently selected alternative function show_error(msg) { //if(e) e.innerHTML="<span class=low_quality>Translation problem: "+msg+"</span>" @@ -74,14 +80,16 @@ wc.translate=function() { function show_picks() { clear(p) for(var i=0;i<so.rs.length;i++) { - p.appendChild(text(" ")) - var pick=text(i+1) // +"⃝" - if(i!=so.current_pick) { - var pick=node("a",{href:"#"},[pick]) - pick.onclick=pick.onmouseover=show_pick(i) + if(so.rs[i].t) { + var pick=text(i+1) // +"⃝" + if(i!=so.current_pick) { + var pick=node("a",{href:"#"},[pick]) + pick.onclick=pick.onmouseover=show_pick(i) + } + var q=so.rs[i].t.quality + p.appendChild(text(" ")) + p.appendChild(span_class("pick "+q,pick)) } - var q=so.rs[i].t.quality - p.appendChild(span_class("pick "+q,pick)) } /* p.appendChild(wrap_class("small","pick", @@ -101,31 +109,37 @@ wc.translate=function() { function show_trans(i) { var r=so.rs[i] - replaceChildren(so.target,text(r.text)) - so.text=r.text - so.target.className=r.t.quality - so.current_pick=i - if(wc.selected==so) show_more() + if(!r.t) { + i=find_pick(so.rs) + r=so.rs[i] + } + if(r && r.t) { + replaceChildren(so.target,text(r.t.text)) + so.text=r.t.text + so.target.className=r.t.quality + so.current_pick=i + if(wc.selected==so) show_more() + } } function showit2(r,grammar) { r.grammar=grammar so.rs.push(r) var j=so.rs.length-1 - if(so.current_pick==j) show_trans(j) + if(so.current_pick<0 || so.current_pick==j) show_trans(j) else if(wc.selected==so) show_picks() //disable(false) } function showit(r,grammar) { r.t=trans_quality(r,grammar+f.to.value) - r.text=r.t.text showit2(r,grammar) } function show_words(r) { var g=gftranslate.grammar var ix=find_to(g+f.to.value,r.linearizations) - r.text=r.linearizations[ix].text - r.t={quality:"bad_quality",text:r.text} - showit2(r,g) + if(ix>=0) { + r.t={quality:"bad_quality",text:r.linearizations[ix].text} + showit2(r,g) + } } function word_for_word(text,cont) { @@ -174,9 +188,11 @@ wc.translate=function() { function step3cnl(results) { var trans=results[0].translations if(trans && trans.length>=1) { - var r=trans[0] - r.prob=0 - showit(r,wc.cnl) + for(var i=0;i<trans.length;i++) { + var r=trans[i] + r.prob=0 + showit(r,wc.cnl) + } } step2(text) } @@ -193,15 +209,19 @@ wc.translate=function() { function change_segment_to(so,to) { var rs=so.rs if(rs) { - for(var i=0;i<rs.length;i++) { - var r=rs[i] - r.t=trans_quality(r,r.grammar+to) - r.text=r.t.text - if(i==so.current_pick) { - so.text=r.text - replaceChildren(so.target,text(r.text)) - } + for(var i=0;i<rs.length;i++) + rs[i].t=trans_quality(rs[i],rs[i].grammar+to) + var i=so.current_pick + if(!rs[i].t) { + i=find_pick(rs) + so.current_pick=i + clear(p) + wc.selected=null } + var r=rs[i] + so.text=r.t.text + replaceChildren(so.target,text(r.t.text)) + so.target.className=r.t.quality } so.to=to } @@ -267,7 +287,7 @@ wc.colors=function() { wc.swap=function() { var f=wc.f - function txt(r) { return r.text } + function txt(r) { return r.t.text } f.input.value=wc.os.map(txt).join("").trimRight() var from=f.from.value f.from.value=f.to.value |
