chiark / gitweb /
Much tidying; preserve query type etc. in query_commod
[ypp-sc-tools.web-live.git] / yarrg / web / query_route
index 4344e1d017d69b1c5113bf70b446e82e78befbad..8f6d99c49d29ed353f5f2fcdf6d88dc55180afac 100644 (file)
@@ -1,73 +1,64 @@
+<%doc>
+
+ This is part of the YARRG website.  YARRG is a tool and website
+ for assisting players of Yohoho Puzzle Pirates.
+
+ Copyright (C) 2009 Ian Jackson <ijackson@chiark.greenend.org.uk>
+ Copyright (C) 2009 Clare Boothby
+
+  YARRG's client code etc. is covered by the ordinary GNU GPL (v3 or later).
+  The YARRG website is covered by the GNU Affero GPL v3 or later, which
+   basically means that every installation of the website will let you
+   download the source.
+
+ This program is free software: you can redistribute it and/or modify
+ it under the terms of the GNU Affero General Public License as
+ published by the Free Software Foundation, either version 3 of the
+ License, or (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ GNU Affero General Public License for more details.
+
+ You should have received a copy of the GNU Affero General Public License
+ along with this program.  If not, see <http://www.gnu.org/licenses/>.
+
+ Yohoho and Puzzle Pirates are probably trademarks of Three Rings and
+ are used without permission.  This program is not endorsed or
+ sponsored by Three Rings.
+
+
+ This Mason component generates the core of the `trade route' query.
+
+
+</%doc>
 <%args>
 $quri
-$a
 $routestring => '';
 </%args>
 <%perl>
-#my $routestring= $queryqf{'routestring'};
-#
-# for output:
+
 my @archipelagoes;
 my @islandids;
 my %islandid2;
 
+my $qa= \%ARGS;
 </%perl>
 
-<h1>Specify route</h1>
-<form action="<% $quri->() |h %>" method="get">
-
 %#---------- textbox, user enters route as string ----------
-% if (!$a->{Dropdowns}) {
+% if (!$qa->{Dropdowns}) {
+
+<h1>Specify route</h1>
 
 Enter route (islands, or archipelagoes, separated by |s or commas;
  abbreviations are OK):<br>
 
-<&| script &>
-tr_uri= "routetextstring?format=json&type=text/xml"
-               + "&ocean=<% uri_escape($a->{Ocean}) %>";
-
-tr_timeout=false;
-tr_request=false;
-tr_done='';
-tr_needed='';
-function tr_Later(){
-  window.clearTimeout(tr_timeout);
-  tr_timeout = window.setTimeout(tr_Needed, 500);
-}
-function tr_Needed(){
-  window.clearTimeout(tr_timeout);
-  tr_element= document.getElementById('routestring');
-  tr_needed= tr_element.value;
-  tr_Request();
-}
-function tr_Request(){
-  if (tr_request || tr_needed==tr_done) return;
-  tr_done= tr_needed;
-  tr_request= new XMLHttpRequest();
-  uri= tr_uri+'&string='+encodeURIComponent(tr_needed);
-  tr_request.open('GET', uri);
-  tr_request.onreadystatechange= tr_Ready;
-  tr_request.send(null);
-}
-function tr_Ready() {
-  if (tr_request.readyState != 4) return;
-  if (tr_request.status == 200) {
-    response= tr_request.responseText;
-    eval('results='+response);
-    toedit= document.getElementById('routeresults');
-    toedit.innerHTML= results.show;
-  }
-  tr_request= false;
-  tr_Request();
-}
-window.onload= tr_Needed;
-</&script>
+<form action="<% $quri->() |h %>" method="get">
 
-<input type="text" id="routestring" name="routestring" size=80
- value="<% $routestring |h %>"
- onchange="tr_Needed();"
- onkeyup="tr_Later();"><br>
-<div id="routeresults">&nbsp;</div><br>
+<&| qtextstring, qa => $qa, thingstring => 'routestring' &>
+ size=80
+</&>
 
 % } else { #---------- dropdowns, user selects from menus ----------
 
@@ -90,7 +81,7 @@ my $optionlistmap= sub {
        return $out;
 };
 
-my $dbh= dbw_connect($a->{Ocean});
+my $dbh= dbw_connect($qa->{Ocean});
 
 $sth= $dbh->prepare("SELECT DISTINCT archipelago FROM islands
                            ORDER BY archipelago;");
@@ -120,9 +111,9 @@ foreach my $arch (keys %islandlistdata) {
                $optionlistmap->($islandlistdata{$arch}, '');
 }
 
-</%perl>
+$dbh->rollback();
 
-<input type=hidden name=dropdowns value="<% $a->{Dropdowns} |h %>">
+</%perl>
 
 <&| script &>
 ms_lists= <% to_json_protecttags(\%resetislandlistdata) %>;
@@ -141,7 +132,7 @@ function ms_Setarch(dd) {
 <table style="table-layout:fixed; width:90%;">
 
 <tr>
-%      for my $dd (0..$a->{Dropdowns}-1) {
+%      for my $dd (0..$qa->{Dropdowns}-1) {
 <td>
 <select name="archipelago<% $dd %>" onchange="ms_Setarch(<% $dd %>)">
 <option value="none">Whole ocean</option>
@@ -150,7 +141,7 @@ function ms_Setarch(dd) {
 </tr>
 
 <tr>
-%      for my $dd (0..$a->{Dropdowns}-1) {
+%      for my $dd (0..$qa->{Dropdowns}-1) {
 %              my $arch= $ARGS{"archipelago$dd"};
 %              $arch= 'none' if !defined $arch;
 <td>
@@ -165,6 +156,8 @@ function ms_Setarch(dd) {
 % } #---------- end of dropdowns, now common middle of page code ----------
 
 <input type=submit name=submit value="Go">
+% my $ours= sub { $_[0] =~ m/^island|^archipelago|^routestring/; };
+<& "lookup:formhidden", ours => $ours &>
 </form>
 
 <%perl>
@@ -177,21 +170,22 @@ $results_head= sub {
 };
 
 #---------- result computation - textstring ----------
-if (!$a->{Dropdowns}) {
+if (!$qa->{Dropdowns}) {
   if (length $routestring) {
        $results_head->();
-       my $rsr= $m->comp('routetextstring',
-               ocean => $a->{Ocean},
+       my ($emsg,$canonstring,$results)= $m->comp('qtextstringcheck',
+               what => 'routestring',
+               ocean => $qa->{Ocean},
                string => $routestring,
                format => 'return'
        );
-       if (length $rsr->{Error}) {
-               print encode_entities($rsr->{Error});
+       if (length $emsg) {
+               print encode_entities($emsg);
        } else {
-               foreach my $entry (@{ $rsr->{Results} }) {
-                       push @archipelagoes,
-                               defined $entry->[1] ? undef : $entry->[0];
+               foreach my $entry (@$results) {
                        push @islandids, $entry->[1];
+                       push @archipelagoes,
+                               defined $entry->[1] ? undef : $entry->[2];
                } 
        }
   }
@@ -205,7 +199,7 @@ my $argorundef= sub {
        return $thing;
 };
 
-for my $dd (0..$a->{Dropdowns}-1) {
+for my $dd (0..$qa->{Dropdowns}-1) {
        my $arch= $argorundef->($dd,'archipelago');
        my $island= $argorundef->($dd,'islandid');
        next unless defined $arch or defined $island;