minibar: remember the selected set of target langauges

This commit is contained in:
hallgren
2013-04-02 13:49:50 +00:00
parent da862e20b4
commit 40bc49245a
2 changed files with 84 additions and 27 deletions

View File

@@ -231,11 +231,13 @@ Some implementation details:
<li>[Added 2013-04-02] Abstract syntax tree visualizations: click once to <li>[Added 2013-04-02] Abstract syntax tree visualizations: click once to
show abstract syntax trees without category names. Click again to add show abstract syntax trees without category names. Click again to add
category names. category names.
<li>[Added 2013-04-02] Minibar now remembers from one visit to the next
the selected set of target languages for each grammar.
</ul> </ul>
<hr> <hr>
<div class=modtime><small> <div class=modtime><small>
<!-- hhmts start -->Last modified: Tue Apr 2 13:55:59 CEST 2013 <!-- hhmts end --> <!-- hhmts start -->Last modified: Tue Apr 2 15:49:32 CEST 2013 <!-- hhmts end -->
</small></div> </small></div>
<address> <address>
<a href="http://www.cse.chalmers.se/~hallgren/">TH</a> <a href="http://www.cse.chalmers.se/~hallgren/">TH</a>

View File

@@ -27,7 +27,7 @@ function Translations(server,opts) {
var tom=this.to_menu=node("select",{id:"to_menu",multiple:"",size:5},[]); var tom=this.to_menu=node("select",{id:"to_menu",multiple:"",size:5},[]);
appendChildren(this.menus,[text(" To: "), this.to_menu]) appendChildren(this.menus,[text(" To: "), this.to_menu])
tom.onchange=bind(this.get_translations,this); tom.onchange=bind(this.change_language,this);
/* // This seems triggers weird scrolling behavior in Firefox and Chrome: /* // This seems triggers weird scrolling behavior in Firefox and Chrome:
tom.onmouseover=function() { var n=tom.options.length; tom.onmouseover=function() { var n=tom.options.length;
tom.size=n<12 ? n : 12; } tom.size=n<12 ? n : 12; }
@@ -37,17 +37,45 @@ function Translations(server,opts) {
} }
Translations.prototype.change_grammar=function(grammar) { Translations.prototype.change_grammar=function(grammar) {
this.grammar=grammar; var t=this
t.grammar=grammar;
update_language_menu(this.to_menu,grammar); t.local=mt_local(t.server.current_grammar_url)
insertFirst(this.to_menu,option("All","All")); update_language_menu(t.to_menu,grammar);
this.to_menu.value="All"; insertFirst(t.to_menu,option("All","All"));
t.to_menu.value="All";
var toLangs=t.local.get("toLangs")
if(toLangs) {
t.toLangs=toLangs
t.toSet=toSet(toLangs)
var os=to_menu.options
for(var i=0;i<os.length;i++)
os[i].selected=t.toSet[os[i].value] || false
}
else {
t.toLangs=["All"]
t.toSet={"All":true}
}
} }
Translations.prototype.clear=function() { Translations.prototype.clear=function() {
this.main.innerHTML=""; this.main.innerHTML="";
} }
Translations.prototype.change_language=function() {
var toLangs=[]
var os=to_menu.options;
for(var i=0;i<os.length;i++)
if(os[i].selected) {
toLangs.push(os[i].value)
toSet[os[i].value]=true;
}
this.toLangs=toLangs
this.toSet=toSet(toLangs)
this.local.put("toLangs",toLangs)
this.get_translations();
}
Translations.prototype.translateFrom=function(current,startcat,lin_action) { Translations.prototype.translateFrom=function(current,startcat,lin_action) {
this.current=current; this.current=current;
this.startcat=startcat; this.startcat=startcat;
@@ -115,14 +143,8 @@ Translations.prototype.show_translations=function(translationResults) {
var trans=main; var trans=main;
//var to=target_lang(); // wrong //var to=target_lang(); // wrong
var to=to_menu.value; var to=to_menu.value;
var toLangs=[] var toLangs=self.toLangs
var toSet={} var toSet=self.toSet
var os=to_menu.options;
for(var i=0;i<os.length;i++)
if(os[i].selected) {
toLangs.push(os[i].value)
toSet[os[i].value]=true;
}
var cnt=translationResults.length; // cnt==1 usually var cnt=translationResults.length; // cnt==1 usually
//trans.translations=translations; //trans.translations=translations;
trans.single_translation=[]; trans.single_translation=[];
@@ -212,19 +234,6 @@ Translations.prototype.show_groupedtranslations=function(translationsResult) {
} }
} }
function tree_button(img_url,opt) {
var imgs=[tree_icon,img_url+(opt||"&nofun=true"),img_url]
var current=0;
function cycle() {
current++;
if(current>=imgs.length) current=0;
i.src=imgs[current]
}
var i=button_img(tree_icon,cycle);
return i
}
Translations.prototype.abstree_button=function(abs) { Translations.prototype.abstree_button=function(abs) {
var f=this.options.tree_img_format; var f=this.options.tree_img_format;
var img=this.server.current_grammar_url+"?command=abstrtree&format="+f+"&tree="+encodeURIComponent(abs) var img=this.server.current_grammar_url+"?command=abstrtree&format="+f+"&tree="+encodeURIComponent(abs)
@@ -252,6 +261,20 @@ Translations.prototype.parsetree_button=function(abs,lang) {
return btn; return btn;
} }
/* --- Auxiliary functions -------------------------------------------------- */
function tree_button(img_url,opt) {
var imgs=[tree_icon,img_url+(opt||"&nofun=true"),img_url]
var current=0;
function cycle() {
current++;
if(current>=imgs.length) current=0;
i.src=imgs[current]
}
var i=button_img(tree_icon,cycle);
return i
}
function draw_brackets(b) { function draw_brackets(b) {
return b.token return b.token
? span_class("token",text(b.token)) ? span_class("token",text(b.token))
@@ -259,3 +282,35 @@ function draw_brackets(b) {
title:(b.fun||"_")+":"+b.cat+" "+b.fid+":"+b.index}, title:(b.fun||"_")+":"+b.cat+" "+b.fid+":"+b.index},
b.children.map(draw_brackets)) b.children.map(draw_brackets))
} }
// Access to localStorage, if available
function mt_local(grammar_url) {
function dummy() {
return {
get: function(name,def) { return def },
put: function(name,value) { }
}
}
function real() {
var prefix="gf.minibar_translations."+grammar_url+"."
return {
get: function (name,def) {
var id=prefix+name
return localStorage[id] ? JSON.parse(localStorage[id]) : def;
},
put: function (name,value) {
var id=prefix+name;
localStorage[id]=JSON.stringify(value);
}
}
}
return window.localStorage ? real() : dummy()
}
// Convert an array of strings to a set (for quick & easy membership tests)
function toSet(a) {
var set={}
for(var i=0;i<a.length;i++) set[a[i]]=true
return set
}