mirror of
https://github.com/GrammaticalFramework/gf-core.git
synced 2026-04-23 03:32:51 -06:00
Merge phrasebook.js into minibar.js
This commit is contained in:
@@ -59,9 +59,6 @@ Some implementation details:
|
|||||||
<li>[Added 2010-02-25] Next to each translation, there is now a little tree icon that
|
<li>[Added 2010-02-25] Next to each translation, there is now a little tree icon that
|
||||||
you can click on to see a drawing of an abstract syntax tree or a parse tree. If you click
|
you can click on to see a drawing of an abstract syntax tree or a parse tree. If you click
|
||||||
on a drawing it collapses back into a tree icon.
|
on a drawing it collapses back into a tree icon.
|
||||||
</ul>
|
|
||||||
Work in progress:
|
|
||||||
<ul>
|
|
||||||
<li>[Added 2010-04-09] Preparations to support different ways to access the grammar:
|
<li>[Added 2010-04-09] Preparations to support different ways to access the grammar:
|
||||||
currently we access a PGF server via JSONP, but I would also like to support AJAX,
|
currently we access a PGF server via JSONP, but I would also like to support AJAX,
|
||||||
and local/downloaded JavaScript grammars.
|
and local/downloaded JavaScript grammars.
|
||||||
@@ -77,12 +74,20 @@ Work in progress:
|
|||||||
<code>{show_abstract:true,show_trees:true}</code> to show the abstract syntax of parsed
|
<code>{show_abstract:true,show_trees:true}</code> to show the abstract syntax of parsed
|
||||||
sentences, and to show icons that expand to syntax/parse trees next each translation.
|
sentences, and to show icons that expand to syntax/parse trees next each translation.
|
||||||
These features can be turned off by setting the fields to <code>false</code>.
|
These features can be turned off by setting the fields to <code>false</code>.
|
||||||
|
<li>[Added 2010-04-30] Grammar menu is omitted if there is only one grammar in
|
||||||
|
the grammar list.
|
||||||
|
<li>[Added 2010-04-30] Fewer hardwired constants and new
|
||||||
|
<code>start_minibar</code> options (server, grammars_url, grammar_list,
|
||||||
|
show_grouped_translations, delete_button_text) to make
|
||||||
|
<code>minibar.js</code> more resuable.)
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<hr>
|
<hr>
|
||||||
|
<small class=modtime>
|
||||||
|
<!-- hhmts start --> Last modified: Fri Apr 30 16:47:43 CEST 2010 <!-- hhmts end -->
|
||||||
|
</small>
|
||||||
<address>
|
<address>
|
||||||
<a href="http://www.cs.chalmers.se/~hallgren/">TH</a>
|
<a href="http://www.cs.chalmers.se/~hallgren/">TH</a>
|
||||||
<img src="http://www.altocumulus.org/~hallgren/online.cgi?icon" alt=""></address>
|
<img src="http://www.altocumulus.org/~hallgren/online.cgi?icon" alt=""></address>
|
||||||
</address>
|
</address>
|
||||||
<!-- hhmts start --> Last modified: Mon Apr 19 18:43:48 CEST 2010 <!-- hhmts end -->
|
|
||||||
</body> </html>
|
</body> </html>
|
||||||
|
|||||||
@@ -4,9 +4,21 @@
|
|||||||
<link rel=stylesheet type="text/css" href="minibar.css">
|
<link rel=stylesheet type="text/css" href="minibar.css">
|
||||||
<script type="text/JavaScript" src="support.js"></script>
|
<script type="text/JavaScript" src="support.js"></script>
|
||||||
<script type="text/JavaScript" src="minibar.js"></script>
|
<script type="text/JavaScript" src="minibar.js"></script>
|
||||||
|
<script type="text/JavaScript">
|
||||||
|
|
||||||
|
var my_options= {
|
||||||
|
server: "http://www.grammaticalframework.org:41296",
|
||||||
|
//server: "http://tournesol.cs.chalmers.se:41296",
|
||||||
|
//server: "http://localhost:41296",
|
||||||
|
//grammar_list: ["Foods.pgf"],
|
||||||
|
show_abstract: false,
|
||||||
|
show_trees: true,
|
||||||
|
show_grouped_translations: false
|
||||||
|
}
|
||||||
|
</script>
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
<body onload="start_minibar({show_abstract:false, show_trees: false})">
|
<body onload="start_minibar(my_options)">
|
||||||
<h1>Minibar</h1>
|
<h1>Minibar</h1>
|
||||||
<div id=minibar>
|
<div id=minibar>
|
||||||
</div>
|
</div>
|
||||||
@@ -18,7 +30,7 @@
|
|||||||
& <a href="http://www.grammaticalframework.org:41296/translate/">Translator</a>]
|
& <a href="http://www.grammaticalframework.org:41296/translate/">Translator</a>]
|
||||||
</small>
|
</small>
|
||||||
<small class=modtime>
|
<small class=modtime>
|
||||||
HTML <!-- hhmts start --> Last modified: Mon Apr 19 18:16:40 CEST 2010 <!-- hhmts end -->
|
HTML <!-- hhmts start --> Last modified: Fri Apr 30 16:48:36 CEST 2010 <!-- hhmts end -->
|
||||||
</small>
|
</small>
|
||||||
<address>
|
<address>
|
||||||
<a href="http://www.cs.chalmers.se/~hallgren/">TH</a>
|
<a href="http://www.cs.chalmers.se/~hallgren/">TH</a>
|
||||||
|
|||||||
@@ -2,30 +2,33 @@
|
|||||||
|
|
||||||
/* --- Configuration -------------------------------------------------------- */
|
/* --- Configuration -------------------------------------------------------- */
|
||||||
|
|
||||||
var server="http://www.grammaticalframework.org:41296"
|
|
||||||
//var server="http://tournesol.cs.chalmers.se:41296";
|
|
||||||
//var server="http://localhost:41296";
|
|
||||||
var grammars_url=server+"/grammars/";
|
|
||||||
|
|
||||||
var tree_icon=server+"/translate/se.chalmers.cs.gf.gwt.TranslateApp/tree-btn.png";
|
var default_server="http://www.grammaticalframework.org:41296"
|
||||||
|
var tree_icon=default_server+"/translate/se.chalmers.cs.gf.gwt.TranslateApp/tree-btn.png";
|
||||||
|
|
||||||
|
// default values for options:
|
||||||
var options={
|
var options={
|
||||||
show_abstract: true,
|
server: default_server,
|
||||||
show_trees: true
|
grammars_url: null, // if left null, start_minibar() fills in server+"/grammars/"
|
||||||
|
grammar_list: null, // if left null, start_minibar() will fetch a list from the server
|
||||||
|
show_abstract: false,
|
||||||
|
show_trees: false,
|
||||||
|
show_grouped_translations: true,
|
||||||
|
delete_button_text: "⌫",
|
||||||
}
|
}
|
||||||
|
|
||||||
/* --- Grammar access object ------------------------------------------------ */
|
/* --- Grammar access object ------------------------------------------------ */
|
||||||
|
|
||||||
var server = {
|
var server = {
|
||||||
// State variables (private):
|
// State variables (private):
|
||||||
current_grammar_url: grammars_url+"Foods.pgf",
|
current_grammar_url: options.grammars_url+"Foods.pgf",
|
||||||
// Methods:
|
// Methods:
|
||||||
switch_grammar: function(grammar_name) {
|
switch_grammar: function(grammar_name) {
|
||||||
this.current_grammar_url=grammars_url+grammar_name;
|
this.current_grammar_url=options.grammars_url+grammar_name;
|
||||||
},
|
},
|
||||||
|
|
||||||
get_grammarlist: function(cont_name) {
|
get_grammarlist: function(cont_name) {
|
||||||
jsonp(grammars_url+"grammars.cgi",cont_name);
|
jsonp(options.grammars_url+"grammars.cgi",cont_name);
|
||||||
},
|
},
|
||||||
get_languages: function(cont_name) {
|
get_languages: function(cont_name) {
|
||||||
jsonp(this.current_grammar_url,cont_name);
|
jsonp(this.current_grammar_url,cont_name);
|
||||||
@@ -51,6 +54,13 @@ var server = {
|
|||||||
+"&from="+encodeURIComponent(from)
|
+"&from="+encodeURIComponent(from)
|
||||||
+"&input="+encodeURIComponent(input),
|
+"&input="+encodeURIComponent(input),
|
||||||
cont_name)
|
cont_name)
|
||||||
|
},
|
||||||
|
translategroup: function(from,input,cont_name) {
|
||||||
|
jsonp(this.current_grammar_url
|
||||||
|
+"?command=translategroup"
|
||||||
|
+"&from="+encodeURIComponent(from)
|
||||||
|
+"&input="+encodeURIComponent(input),
|
||||||
|
cont_name)
|
||||||
}
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
@@ -59,7 +69,6 @@ var server = {
|
|||||||
|
|
||||||
function start_minibar(opts) { // typically called when the HTML document is loaded
|
function start_minibar(opts) { // typically called when the HTML document is loaded
|
||||||
if(opts) for(var o in opts) options[o]=opts[o];
|
if(opts) for(var o in opts) options[o]=opts[o];
|
||||||
|
|
||||||
var surface=div_id("surface");
|
var surface=div_id("surface");
|
||||||
surface.setAttribute("onclick","surface_click(this)");
|
surface.setAttribute("onclick","surface_click(this)");
|
||||||
appendChildren(element("minibar"),
|
appendChildren(element("minibar"),
|
||||||
@@ -67,31 +76,36 @@ function start_minibar(opts) { // typically called when the HTML document is loa
|
|||||||
surface,
|
surface,
|
||||||
div_id("words"),
|
div_id("words"),
|
||||||
div_id("translations")]);
|
div_id("translations")]);
|
||||||
server.get_grammarlist("show_grammarlist");
|
if(!options.grammars_url) options.grammars_url=options.server+"/grammars/";
|
||||||
|
if(options.grammar_list) show_grammarlist(options.grammar_list)
|
||||||
|
else server.get_grammarlist("show_grammarlist");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* --- Functions ------------------------------------------------------------ */
|
/* --- Functions ------------------------------------------------------------ */
|
||||||
|
|
||||||
function show_grammarlist(grammars) {
|
function show_grammarlist(grammars) {
|
||||||
var menu=empty("select");
|
var menubar=element("menubar");
|
||||||
for(var i=0;i<grammars.length;i++) {
|
menubar.innerHTML="";
|
||||||
var opt=empty("option");
|
if(grammars.length>1) {
|
||||||
opt.setAttribute("value",grammars[i]);
|
var menu=empty("select");
|
||||||
opt.innerHTML=grammars[i];
|
for(var i=0;i<grammars.length;i++) {
|
||||||
menu.appendChild(opt);
|
var opt=empty("option");
|
||||||
}
|
opt.setAttribute("value",grammars[i]);
|
||||||
menu.setAttribute("onchange","new_grammar(this)");
|
opt.innerHTML=grammars[i];
|
||||||
var menubar=element("menubar");
|
menu.appendChild(opt);
|
||||||
menubar.innerHTML="Grammar: ";
|
}
|
||||||
appendChildren(menubar,
|
menu.setAttribute("onchange","new_grammar(this)");
|
||||||
[menu,
|
menubar.innerHTML="Grammar: ";
|
||||||
text(" From: "), empty_id("select","language_menu"),
|
menubar.appendChild(menu);
|
||||||
text(" To: "), empty_id("select","to_menu"),
|
}
|
||||||
button("Clear","clear_all()"),
|
appendChildren(menubar,
|
||||||
button("⌫","delete_last()"),
|
[text(" From: "), empty_id("select","language_menu"),
|
||||||
button("Random","generate_random()")]);
|
text(" To: "), empty_id("select","to_menu"),
|
||||||
select_grammar(grammars[0]);
|
button(options.delete_button_text,"delete_last()"),
|
||||||
|
button("Clear","clear_all()"),
|
||||||
|
button("Random","generate_random()")]);
|
||||||
|
select_grammar(grammars[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
function new_grammar(menu) {
|
function new_grammar(menu) {
|
||||||
@@ -104,7 +118,7 @@ function select_grammar(grammar_name) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function langpart(conc,abs) { // langpart("FoodsEng","Food") == "Eng"
|
function langpart(conc,abs) { // langpart("FoodsEng","Food") == "Eng"
|
||||||
return conc.indexOf(abs)==0 ? conc.substring(abs.length) : conc;
|
return hasPrefix(conc,abs) ? conc.substr(abs.length) : conc;
|
||||||
}
|
}
|
||||||
|
|
||||||
function show_languages(grammar) {
|
function show_languages(grammar) {
|
||||||
@@ -116,7 +130,7 @@ function show_languages(grammar) {
|
|||||||
menu.innerHTML="";
|
menu.innerHTML="";
|
||||||
|
|
||||||
for(var i=0; i<lang.length; i++)
|
for(var i=0; i<lang.length; i++)
|
||||||
if(lang[i].canParse)
|
if(lang[i].canParse && !hasPrefix(lang[i].name,"Disamb"))
|
||||||
menu.appendChild(option(langpart(lang[i].name,grammar.name),""+i));
|
menu.appendChild(option(langpart(lang[i].name,grammar.name),""+i));
|
||||||
|
|
||||||
var to=element("to_menu");
|
var to=element("to_menu");
|
||||||
@@ -125,7 +139,8 @@ function show_languages(grammar) {
|
|||||||
to.innerHMTL="";
|
to.innerHMTL="";
|
||||||
to.appendChild(option("All","-1"));
|
to.appendChild(option("All","-1"));
|
||||||
for(var i=0; i<lang.length; i++)
|
for(var i=0; i<lang.length; i++)
|
||||||
to.appendChild(option(langpart(lang[i].name,grammar.name),lang[i].name));
|
if(!hasPrefix(lang[i].name,"Disamb"))
|
||||||
|
to.appendChild(option(langpart(lang[i].name,grammar.name),lang[i].name));
|
||||||
new_language(menu);
|
new_language(menu);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -270,7 +285,11 @@ function show_completions(completions) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function get_translations(menu) {
|
function get_translations(menu) {
|
||||||
server.translate(menu.current.from,menu.current.input,"show_translations");
|
var c=menu.current;
|
||||||
|
if(options.show_grouped_translations)
|
||||||
|
server.translategroup(c.from,c.input,"show_groupedtranslations");
|
||||||
|
else
|
||||||
|
server.translate(c.from,c.input,"show_translations");
|
||||||
}
|
}
|
||||||
|
|
||||||
function tdt(tree_btn,txt) {
|
function tdt(tree_btn,txt) {
|
||||||
@@ -279,8 +298,7 @@ function tdt(tree_btn,txt) {
|
|||||||
|
|
||||||
function show_translations(translations) {
|
function show_translations(translations) {
|
||||||
var trans=element("translations");
|
var trans=element("translations");
|
||||||
var menu=element("language_menu");
|
var grammar=element("language_menu").grammar;
|
||||||
var grammar=menu.grammar;
|
|
||||||
var to_menu=element("to_menu");
|
var to_menu=element("to_menu");
|
||||||
var to=to_menu.options[to_menu.selectedIndex].value
|
var to=to_menu.options[to_menu.selectedIndex].value
|
||||||
var cnt=translations.length;
|
var cnt=translations.length;
|
||||||
@@ -304,6 +322,29 @@ function show_translations(translations) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function show_groupedtranslations(translations) {
|
||||||
|
var trans=element("translations");
|
||||||
|
var grammar=element("language_menu").grammar;
|
||||||
|
var to_menu=element("to_menu");
|
||||||
|
var to=langpart(to_menu.options[to_menu.selectedIndex].value,grammar.name);
|
||||||
|
var cnt=translations.length;
|
||||||
|
trans.innerHTML="";
|
||||||
|
for(p=0;p<cnt;p++) {
|
||||||
|
var t=translations[p];
|
||||||
|
if(to=="-1" || t.to==to) {
|
||||||
|
var lin=t.linearizations;
|
||||||
|
var tbody=empty("tbody");
|
||||||
|
/*if(to=="-1")*/
|
||||||
|
tbody.appendChild(tr([th(text(t.to+":"))]));
|
||||||
|
for(var i=0;i<lin.length;i++) {
|
||||||
|
tbody.appendChild(tr([(text(lin[i].text))]));
|
||||||
|
if (lin.length > 1) tbody.appendChild(tr([(text(lin[i].tree))]));
|
||||||
|
}
|
||||||
|
trans.appendChild(wrap("table",tbody));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function abstree_button(abs) {
|
function abstree_button(abs) {
|
||||||
var i=img(tree_icon);
|
var i=img(tree_icon);
|
||||||
i.setAttribute("onclick","toggle_img(this)");
|
i.setAttribute("onclick","toggle_img(this)");
|
||||||
|
|||||||
37
src/runtime/javascript/minibar/phrasebook.html
Normal file
37
src/runtime/javascript/minibar/phrasebook.html
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
|
||||||
|
<html> <head>
|
||||||
|
<title>Phrasebook</title>
|
||||||
|
<link rel=stylesheet type="text/css" href="minibar.css">
|
||||||
|
<script type="text/JavaScript" src="support.js"></script>
|
||||||
|
<script type="text/JavaScript" src="minibar.js"></script>
|
||||||
|
<script type="text/JavaScript">
|
||||||
|
var phrasebook_options={
|
||||||
|
server: "http://tournesol.cs.chalmers.se:41296",
|
||||||
|
grammar_list: ["Phrasebook.pgf"],
|
||||||
|
delete_button_text: "Del"
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body onload="start_minibar(phrasebook_options)">
|
||||||
|
|
||||||
|
<div id=minibar>
|
||||||
|
</div>
|
||||||
|
<hr>
|
||||||
|
|
||||||
|
<small>
|
||||||
|
|
||||||
|
Based on
|
||||||
|
<a href="http://www.cs.chalmers.se/~hallgren/minibar/minibar.html">minibar</a>,
|
||||||
|
powered by
|
||||||
|
<a href="http://www.grammaticalframework.org">GF</a>,
|
||||||
|
see
|
||||||
|
<a href="../phrasebook.html">doc</a>.
|
||||||
|
|
||||||
|
|
||||||
|
</body>
|
||||||
|
|
||||||
|
</html>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -117,7 +117,10 @@ function swap(a,i,j) { // Note: this doesn't work on strings.
|
|||||||
return a;
|
return a;
|
||||||
}
|
}
|
||||||
|
|
||||||
function sort(a) { // Note: this doesn't work on strings.
|
function sort(a) {
|
||||||
|
// https://developer.mozilla.org/en/Core_JavaScript_1.5_Reference/Global_Objects/Array/sort
|
||||||
|
return a.sort;
|
||||||
|
/* // Note: this doesn't work on strings.
|
||||||
for(var i=0;i<a.length-1;i++) {
|
for(var i=0;i<a.length-1;i++) {
|
||||||
var min=i;
|
var min=i;
|
||||||
for(var j=i+1;j<a.length;j++)
|
for(var j=i+1;j<a.length;j++)
|
||||||
@@ -125,6 +128,7 @@ function sort(a) { // Note: this doesn't work on strings.
|
|||||||
if(min!=i) swap(a,i,min);
|
if(min!=i) swap(a,i,min);
|
||||||
}
|
}
|
||||||
return a;
|
return a;
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
function filter(p,xs) {
|
function filter(p,xs) {
|
||||||
@@ -143,6 +147,9 @@ function implode(cs) { // array of strings to string
|
|||||||
*/
|
*/
|
||||||
return cs.join("");
|
return cs.join("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function hasPrefix(s,pre) { return s.substr(0,pre.length)==pre; }
|
||||||
|
|
||||||
/*
|
/*
|
||||||
function all(p,xs) {
|
function all(p,xs) {
|
||||||
for(var i=0;i<xs.length;i++)
|
for(var i=0;i<xs.length;i++)
|
||||||
|
|||||||
Reference in New Issue
Block a user