public
Description: web-based go app
Homepage: http://eidogo.com/
Clone URL: git://github.com/jkk/eidogo.git
eidogo / games.phtml
100644 66 lines (56 sloc) 2.228 kb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
<?php $title = "Game Archive"; include("header.phtml"); ?>
 
<div id="text-content">
    
<h2>Games</h2>
 
<div id="subnav">
    <ul>
        <li><a href="/tourney">Recent Tournament Games</a></li>
        <li class="active"><a href="/games">Game Archive</a></li>
    </ul>
</div>
 
<form id="games-search" action="games">
<p>
    Search:
    <input name="q" value="<?=htmlentities(stripslashes($_GET['q']))?>">
    <input type="submit" value="Go">
</p>
</form>
 
<?php
 
function show_results($query) {
    $query = preg_replace("/[^a-zA-Z0-9 -]/", "", $query);
    $db = sqlite3_open("kombilo/t1.db");
    $res = sqlite3_query($db, "select * from games
where pb like '%$query%' or pw like '%$query%' or ev like '%$query%' or date like '%$query%'
order by date desc
limit 300");
    $games = array();
    while ($game = sqlite3_fetch_array($res)) $games[] = $game;
    if (!count($games)) {
        echo "<p>No games found matching &quot;$query&quot;.</p>";
        return;
    }
    echo "<p>" . count($games) . " games found, newest listed first:</p>
<table id='tourney-games'>
<tr><th>Date</th><th>Event</th><th>White</th><th>Black</th><th>Result</th></tr>";
    $class = "";
    foreach ($games as $game) {
        $class = $class == "odd" ? "even" : "odd";
        $gn = str_replace(".sgf", "", $game['filename']);
        echo "<tr class='$class'>\n";
        echo join("", array_map(create_function('$s', 'return "<td><a href=\"./#' . $gn . '\">" . $s . "</a></td>\n";'),
            array($game['date'], $game['EV'], $game['PW'], $game['PB'], $game['RE'])));
        echo "</tr>";
    }
}
 
if ($_GET['q']) {
    show_results($_GET['q']);
} else {
    echo "<p>The game archive contains a representative sample of games from the last few hundred years.
Enter a query above to search by player name, event name, or date.</p>
<p>Many games come from GoGoD, with their permission. If you are interested in having a full
collection of well over 50,000 pro games along with other enriching materials, please purchase their
product (<a href='http://www.gogod.co.uk'>http://www.gogod.co.uk</a>).</p>";
}
 
?>
</table>
 
</div>
 
<?php include("footer.phtml"); ?>