Skip to content

Instantly share code, notes, and snippets.

@KaeruCT
Last active December 16, 2015 21:29
Show Gist options
  • Save KaeruCT/5500114 to your computer and use it in GitHub Desktop.
Save KaeruCT/5500114 to your computer and use it in GitHub Desktop.
choose your own adventure (really tightly coupled to board software)
<?php
// By Kaeru~
require('lib/common.php');
$sql = new mysql;
if(!@$sql->connect($sqlhost,$sqluser,$sqlpass))
{
mysqlerror();
}
if(!@$sql->selectdb('nwwebde1_myoa'))
{
mysqlerror();
}
/*if($_GET['lol']=='yes')
{
$sql->query('TRUNCATE TABLE g_opts');
$sql->query('TRUNCATE TABLE g_stages');
$sql->query('TRUNCATE TABLE g_rep');
$sql->query('INSERT INTO g_stages SET text = "You are standing in an open field west of a white house, with a boarded front door.
There is a small mailbox here.
What will you do?"');
$sql->query('INSERT INTO g_opts SET stage = 1, text = "Enter house"');
$sql->query('INSERT INTO g_opts SET stage = 1, text = "Open mailbox"');
$sql->query('INSERT INTO g_opts SET stage = 1, text = "Walk away"');
print 'queries done';
}*/
function branch($stage)
{
global $sql;
$tree = array();
$opts = $sql->query('SELECT * FROM g_opts WHERE stage = '.$stage);
$stage = $sql->fetchq('SELECT * FROM g_stages WHERE id = '.$stage);
$tree['text'] = $stage['text'];
$tree['opts'] = array();
while($opt = $sql->fetch($opts))
{
$tree['opts'][$opt['id']] = array('opt' => $opt['text'], 'branch' => branch($opt['to']));
}
return $tree;
}
function loosends($stage, &$num)
{
global $sql, $visited;
if (!$visited) $visited = array();
if (in_array($stage, $visited)) {
return '';
}
$visited[] = $stage;
$out = '';
$opts = $sql->query('SELECT * FROM g_opts WHERE stage = '.$stage);
while($opt = $sql->fetch($opts))
{
if(!$opt['to'])
{
$num++;
$out .= '<li><a href="game.php?option='.$opt['id'].'">'.$opt['text'].'</a></li>';
}
else
$out .= loosends($opt['to'], $num);
}
return $out;
}
function branchp($arr)
{
$out = '<div class="tree" style="display: none;">';
$out .= '<p>'.($arr['text']?nl2br(htmlval($arr['text'])):'This part of the story isn\'t done yet!').'</p>';
foreach($arr['opts'] as $k => $v)
{
if(is_array($v))
{
$out .= '<div class="tog" onclick="$(this).next().slideToggle();">'.$v['opt'].'</div>';
$out .= branchp($v['branch']);
}
}
$out .= '</div>';
return $out;
}
$links = '<a href="game.php?loose">Loose ends</a>&nbsp;|&nbsp;<a href="game.php">Beginning</a>';
$option = isset($_GET['option'])?intval($_GET['option']):0;
$from = isset($_GET['from'])?intval($_GET['from']):0;
$action = isset($_POST['action'])?$_POST['action']:'';
$rep = isset($_GET['report'])?intval($_GET['report']):0;
$msg = $link = $title = '';
if($rep)
{
if($sql->resultq('SELECT COUNT(*) FROM g_stages WHERE id = "'.$rep.'"')>0)
{
$option = $sql->resultq('SELECT id FROM g_opts WHERE `to` = "'.$rep.'"');
if($sql->resultq('SELECT COUNT(*) FROM g_rep WHERE stage = "'.$rep.'" AND user = "'.$loguser['id'].'"')>0)
{
$msg = 'You already reported this setting!';
}
else
{
$sql->query('REPLACE INTO g_rep SET stage = "'.$rep.'", user = "'.$loguser['id'].'"');
$msg = 'This setting has been reported!';
}
$msg .= '<br /><a href="game.php?option='.$option.'">Go back</a>';
}
else
$msg = 'This setting doesn\'t even exist!<br /><a href="game.php">Go back</a>';
}
elseif($option!=0)
{
$option = $sql->fetchq('SELECT * FROM g_opts WHERE id = "'.$option.'"');
$link = '<a href="game.php">Go back to start</a>';
}
else
$option = array('id' => 0, 'to' => 1, 'stage' => 0, 'text' => 'The Beginning');
if(isset($_GET['branch']))
{
$title = 'Branch';
$tree = branch(1);
$msg = '<div class="tog" onclick="$(this).next().slideDown();">Start!</div>'.branchp($tree);
}
elseif(isset($_GET['loose']))
{
$num = 0;
$msg = '<ol>'.loosends(1, $num).'</ol>';
$title = 'Loose ends ('.$num.')';
}
elseif($action)
{
switch($action)
{
case 'newsetting':
$num = isset($_POST['numopts'])?intval($_POST['numopts']):2;
$optid = isset($_POST['optid'])?intval($_POST['optid']):0;
if($num>4) $num = 4;
if($num<1) $num = 1;
if($optid)
{
$opt = $sql->fetchq('SELECT * FROM g_opts WHERE id = "'.$_POST['optid'].'"');
$msg = '
<form method="post" action="game.php"><input type="hidden" name="optid" value="'.$_POST['optid'].'"><input type="hidden" name="numopts" value="'.$num.'"><input type="hidden" name="action" value="submitsetting"><table>
<tr><th colspan="2">Setting for "'.$opt['text'].'" option</th></tr>
<tr><td width="150px"><label for="setting">Setting:</label></td><td><textarea id="setting" name="setting" cols="80" rows="5"></textarea></td></tr>';
for($i=1;$i<=$num;$i++)
$msg.= '<tr><td><label for="opt'.$i.'">Option '.$i.':</label></td><td><input type="text" id="opt'.$i.'" name="opt'.$i.'"></td></tr>
';
$msg .= '<tr><td>&nbsp;</td><td><input type="submit" value="Submit"></td></tr>
</table></form>';
}
else
$msg = 'No option ID was specified.';
break;
case 'submitsetting':
$num = isset($_POST['numopts'])?intval($_POST['numopts']):2;
if($num>=4) $num = 4;
if($num<1) $num = 1;
$text = isset($_POST['setting'])?trim($_POST['setting']):'';
$optid = isset($_POST['optid'])?intval($_POST['optid']):0;
$err = array();
if(!$text)
{
$err[] = 'You didn\'t fill the "setting" field.';
}
if(!$optid)
{
$err[] = 'No option ID was specified.';
}
if($sql->resultq('SELECT COUNT(id) FROM g_opts WHERE id = "'.$optid.'"') == 0)
{
$err[] = 'No option with that ID exists.';
}
else
{
$opt = $sql->fetchq('SELECT * FROM g_opts WHERE id = "'.$optid.'"');
if($opt['to']!=0)
$err[] = 'Someone submitted the option before you did!';
}
for($i=1;$i<=$num;$i++)
{
if(!trim($_POST['opt'.$i]))
{
$err[] = 'You didn\'t fill all the options.';
break;
}
}
if(!$err[0])
{
$sql->query('INSERT INTO g_stages SET text = "'.$text.'", user = "'.$loguser['id'].'"');
$stageid = mysql_insert_id();
$sql->query('UPDATE g_opts SET `to` = "'.$stageid.'" WHERE id = "'.$optid.'"');
for($i=1;$i<=$num;$i++)
$sql->query('INSERT INTO g_opts SET stage = '.$stageid.', text = "'.$_POST['opt'.$i].'"');
sendirc('New option submitted by '.$loguser['name'].'! {boardurl}game.php?option='.$optid);
$msg = 'Option submitted succesfully!<br /><a href="game.php?option='.$optid.'">Go back where you ended!</a>';
}
else
{
$msg = 'The following error'.(sizeof($err)==1?'':'s').' occured:<ul><li>'.implode('</li><li>', $err).'</li></ul>';
}
break;
case 'ending':
$text = isset($_POST['ending'])?trim($_POST['ending']):'';
$optid = isset($_POST['optid'])?intval($_POST['optid']):0;
if(!$text)
{
$err[] = 'You didn\'t fill the "ending" field.';
}
if(!$optid)
{
$err[] = 'No option ID was specified.';
}
if($sql->resultq('SELECT COUNT(id) FROM g_opts WHERE id = "'.$optid.'"') == 0)
{
$err[] = 'No option with that ID exists.';
}
if(!$err[0])
{
$sql->query('INSERT INTO g_stages SET text = "'.$text.'", user = "'.$loguser['id'].'"');
$stageid = mysql_insert_id();
$sql->query('UPDATE g_opts SET `to` = "'.$stageid.'" WHERE id = "'.$optid.'"');
sendirc('An ending was submitted by '.$loguser['name'].'! {boardurl}game.php?option='.$optid);
$msg = 'Ending submitted succesfully!<br /><a href="game.php?option='.$optid.'">Go back where you ended!</a>';
}
else
{
$msg = 'The following error'.(sizeof($err)==1?'':'s').' occured:<ul><li>'.implode('</li><li>', $err).'</li></ul>';
}
break;
case 'link':
$setid = isset($_POST['settingid'])?intval($_POST['settingid']):0;
$optid = isset($_POST['optid'])?intval($_POST['optid']):0;
if(!$setid)
{
$err[] = 'You didn\'t fill the "setting ID" field.';
}
if(!$optid)
{
$err[] = 'No option ID was specified.';
}
if($sql->resultq('SELECT COUNT(id) FROM g_opts WHERE id = "'.$optid.'"') == 0)
{
$err[] = 'No option with that ID exists.';
}
if($sql->resultq('SELECT COUNT(id) FROM g_stages WHERE id = "'.$setid.'"') == 0)
{
$err[] = 'No setting with that ID exists.';
}
if(!$err[0])
{
$sql->query('UPDATE g_opts SET `to` = "'.$setid.'" WHERE id = "'.$optid.'"');
sendirc('New option submitted by '.$loguser['name'].'! {boardurl}game.php?option='.$optid);
$msg = 'Link to existing setting submitted succesfully!<br /><a href="game.php?option='.$optid.'">Go back where you ended!</a>';
}
else
{
$msg = 'The following error'.(sizeof($err)==1?'':'s').' occured:<ul><li>'.implode('</li><li>', $err).'</li></ul>';
}
break;
}
}
elseif(!$msg)
{
$settingid = '';
if(!$option)
{
$msg = 'This option doesn\'t even exist!';
}
elseif(!$option['to'])
{
$title = $option['text'];
$msg = '<p>This part of the story isn\'t done yet. You can either continue the story, or end it here.</p>
<div>
<a href="#" onclick="$(\'#end\').slideUp(); $(\'#link\').slideUp(); $(\'#continue\').slideDown(); return false;">Continue</a> |
<a href="#" onclick="$(\'#end\').slideUp(); $(\'#continue\').slideUp(); $(\'#link\').slideDown(); return false;">Link to an existing setting</a> |
<a href="#" onclick="$(\'#continue\').slideUp(); $(\'#link\').slideUp(); $(\'#end\').slideDown(); return false;">End</a></div>
<div id="continue" style="display: none;"><form method="post" action="game.php"><input type="hidden" name="optid" value="'.$option['id'].'"><input type="hidden" name="action" value="newsetting"><table>
<tr><th colspan="2">Continue the story</th></tr>
<tr><td width="150px"><label for="numopts">Number of options:<br>(max: 4)</label></td><td><input type="text" id="numopts" name="numopts" size="2" maxlength="1"></td></tr>
<tr><td>&nbsp;</td><td><input type="submit" value="Submit"></td></tr>
</table></form></div>
<div id="end" style="display: none;"><form method="post" action="game.php"><input type="hidden" name="optid" value="'.$option['id'].'"><input type="hidden" name="action" value="ending"><table>
<tr><th colspan="2">End it here</th></tr>
<tr><td width="150px"><label for="ending">Ending text:</label></td><td><textarea id="ending" name="ending" cols="80" rows="5"></textarea></td></tr>
<tr><td>&nbsp;</td><td><input type="submit" value="Submit"></td></tr>
</table></form></div>
<div id="link" style="display: none;"><form method="post" action="game.php"><input type="hidden" name="optid" value="'.$option['id'].'"><input type="hidden" name="action" value="link"><table>
<tr><th colspan="2">Link to an existing setting</th></tr>
<tr><td colspan="2">*The setting ID appears at the bottom of each setting.</td></tr>
<tr>
<td width="150px"><label for="settingid">Setting ID:</label></td>
<td><input type="text" name="settingid" id="settingid" size="4" maxlength="4"></td
</tr>
<tr><td>&nbsp;</td><td><input type="submit" value="Submit"></td></tr>
</table></form></div>';
}
else
{
$setting = $sql->fetchq('SELECT * FROM g_stages WHERE id = "'.$option['to'].'"');
$opts = $sql->query('SELECT * FROM g_opts WHERE stage = "'.$option['to'].'"');
$title = $option['text'];
$l = array();
while($opt = $sql->fetch($opts))
{
$msg .= '<li><a href="game.php?option='.$opt['id'].'&amp;from='.$setting['id'].'">'.htmlentities($opt['text']).'</a></li>';
}
if(!$msg)
{
$msg = '<h2>THE END</h2><a href="game.php">Go back to the beginning</a>.';
}
else $msg = '<ul>'.$msg.'</ul>';
}
if($setting['text'] != ''){
$settingid = '<small>This setting\'s ID is: <b>'.$setting['id'].'</b></small>';
}
$msg = '<div><div id="setting">'.nl2br(htmlval($setting['text'])).'</div><div id="opts">'.$msg.'</div>'.$settingid.'</div>';
if($option['stage'])
{
if(!$from)
{
$option = $sql->resultq('SELECT id FROM g_opts WHERE `to` = "'.$option['stage'].'" ORDER BY id ASC LIMIT 1');
}else{
$option = $from;
}
$l[] = '<a href="game.php'.($option?'?option='.$option:'').'">Go back to previous setting</a>';
}
if($setting['user'])
{
$user = $sql->fetchq('SELECT name,sex,power,color,id FROM users WHERE id = '.$setting['user']);
}
/*if($log)
$l[] = '<a href="game.php?report='.$setting['id'].'">Report</a>';*/
if($l[0])
$links .= '&nbsp;|&nbsp;'.implode('&nbsp;|&nbsp;', $l);
}
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title><?=$title?></title>
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<meta name="Author" content="Kaeru" />
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3/jquery.min.js"></script>
<style type="text/css">
body{color: #444; font-family: "Droid Sans", Tahoma, sans-serif; background: #fff url(%3D%3D)}
#wrap {max-width: 800px; margin: 0 auto;}
div#main{background: #eee; box-shadow: #000 1px 1px 3px; border-radius: 2px; padding: 16px;}
div.t {background: #444; border: #666 1px solid; padding: 10px; color: #eee;}
div.t > div {padding: 10px;}
p.sm{font-size: .8em}
div.tree{padding: 4px; border: #aaa 1px solid; background: url('theme/fragment/tdbg3.png')}
div.tog{font-weight: bold; cursor: pointer; margin: 4px;}
a:link{color:#333; font-weight: bold; text-decoration: none;}
a:visited{color:#333; font-weight: bold; text-decoration: none;}
a:active{color:#222; text-decoration: none;}
a:hover{color:#111;text-decoration: underline;}
form{display: inline;}
table{width: 100%; margin: 20px 0;}
textarea,input[type=text] {border: #888 1px solid; padding: 4px;}
</style>
</head>
<body>
<div id="wrap">
<h1><?=$title?></h1>
<p class="sm"><?=$links?></p>
<div id="main">
<?=$msg?>
</div>
</div>
<!--<div><small>By Kaeru~<br /><?=pagestats();?></small></div>-->
</body>
</html>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment