X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~yarrgweb/git?p=ypp-sc-tools.web-live.git;a=blobdiff_plain;f=yarrg%2Fweb%2Fquery_offers;h=76f45c0da52f143bb39fd7de472c5a1118539cdf;hp=b9befe2c60ce3ed0016a6a37683737686a6e4d19;hb=aa69f9268584bedbdbdf5d0d51e2ce78b9ecd330;hpb=d343fff49b802614be47d21b569f43b7d42d4511 diff --git a/yarrg/web/query_offers b/yarrg/web/query_offers index b9befe2..76f45c0 100644 --- a/yarrg/web/query_offers +++ b/yarrg/web/query_offers @@ -88,14 +88,15 @@ return unless defined $cmid and @islandids; foreach my $wf (@warningfs) { $wf->(); } +if ($qa->{'debug'}) {
-NOT YET IMPLEMENTED
 bs= <% $qa->{BuySell} %>
 cmdid= <% $cmid %>
 islandids= <% join ',', map { defined($_) ? $_ : 'U' } @islandids %>
 
<%perl> +} my $locdesc; if (@islandids>1) { @@ -109,6 +110,8 @@ if (@islandids>1) { $locdesc= ' in '.$archipelagoes[0]; } +my $now= time; + my @conds; my @condvals; push @condvals, $cmid; @@ -124,13 +127,18 @@ foreach my $ix (0..$#islandids) { } } foreach my $bs (split /_/, $qa->{BuySell}) { + my %da_ages; + my %ts_sortkeys; + die unless grep { $bs eq $_ } qw(buy sell); my $ascdesc= $bs eq 'buy' ? 'DESC' : 'ASC';

Offers to <% uc $bs |h %> <% $commodname |h %> <% $locdesc %>

<%perl> my $stmt= " - SELECT archipelago, islandname, stallname, price, qty, timestamp + SELECT archipelago, islandname, + stallname, price, qty, timestamp, + offers.stallid FROM $bs AS offers JOIN islands ON offers.islandid==islands.islandid JOIN uploads ON offers.islandid==uploads.islandid @@ -151,11 +159,65 @@ foreach my $bs (split /_/, $qa->{BuySell}) { <%perl> } + my $row; my $sth= $dbh->prepare($stmt); $sth->execute(@condvals); + my $rowix= 0; - <& dumptable, sth => $sth &> +% while ($row= $sth->fetchrow_arrayref) { +% if (!$rowix) { + ++++ + +% } +% my $rowid= ${bs}.$row->[6]; +% my $tscellid= "c$rowid"; +% my $age= $now - $row->[5]; +% $da_ages{$rowid}= $age; +% $row->[5]= + class="<% 'datarow'.($rowix & 1) %>" > +% foreach my $ci (0..4) { +% my $val= $row->[$ci]; +% $ts_sortkeys{$ci}{$rowid}= $val; + +% $rowix++; +% } +% if ($rowix) { +
Archipelago +Island +Stall or Shoppe +Price +Quantity +Data age +
= 3 ? 'align=right' : '' %> ><% $val |h %> +% } +<% prettyprint_age($age) %> +
+ +<&| tabsort, table => "${bs}_table", rowclass => 'datarow', cols => [ + {}, {}, {}, + { Numeric => 1, DoReverse => 1 }, + { Numeric => 1, DoReverse => 1 }, + { Numeric => 1, DoReverse => 1, SortKey => "${bs}_ages[rowid]" }], + sortkeys => "${bs}_sortkeys" + &> + <%$bs%>_sortkeys= <% to_json_protecttags(\%ts_sortkeys) %>; + <%$bs%>_ages= <% to_json_protecttags(\%da_ages) %>; + +% } else { +No offers. +% } + <%perl> } - + +

+(Please don't use these pages to scrape data out of the YARRG +database. This will be a pain for you to program, slow to run, and +pointlessly overload our server. Instead, see our +information for developers +to find out how to get testing data or a real-time feed.)