3 Star 11 Fork 2

BLumia / BLumiaOJ

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
contestlist.php 2.51 KB
一键复制 编辑 原始数据 按行查看 历史
BLumia 提交于 2017-06-14 16:20 . contest ranklist improved
<?php
session_start();
//Vars
require_once('./include/setting_oj.inc.php');
require_once('./include/contest_functions.inc.php');
//Prepare
$p=isset($_GET['p']) ? $_GET['p'] : 1;
if($p<1){$p=1;}
$front=intval(($p-1)*$PAGE_ITEMS);
$privateFliter = isset($_GET['private']) ? intval($_GET['private']) : 2; // Default(2):All 0:Public 1: Private&Password
switch($privateFliter) {
case 0:// Public
$privateFliterSQL = " AND contest.`private`=0 "; break;
case 1:// Private&Password
$privateFliterSQL = " AND contest.`private`=1 "; break;
default:// All
$privateFliterSQL = ""; break;
}
$sql=$pdo->prepare("select * from contest left join (
select * from privilege where rightstr like 'm%'
) p on concat('m',contest_id)=rightstr
where contest.`defunct`='N' {$privateFliterSQL} order by contest_id desc limit $front,$PAGE_ITEMS ");
$sql->execute();
$contestList=$sql->fetchAll(PDO::FETCH_ASSOC);
$contestCount=count($contestList);
//var_dump($contestList);
$sql=$pdo->prepare("select count(*) as count from contest where `defunct`='N' {$privateFliterSQL}");
$sql->execute();
$totalCount=$sql->fetch(PDO::FETCH_ASSOC);
$totalCount=intval($totalCount['count']);
//var_dump($totalCount);
$pageCnt = ceil((double)$totalCount / $PAGE_ITEMS);
foreach ($contestList as &$row){
$start_time = strtotime($row["start_time"]);
$end_time = strtotime($row["end_time"]);
$now = time();
$length = $end_time-$start_time;
$left = $end_time-$now;
// past
if ($now>$end_time) {
$row['content_status'] = "<span class='label label-success'>".L_Ended."</span>&nbsp;<span class='label label-success'>".$row["end_time"]."</span>";
// pending
} else if ($now<$start_time) {
$row['content_status'] = "<span class='label label-primary'>".L_Start."</span>&nbsp;<span class='label label-info'>".$row["start_time"]."</span>&nbsp;";
$row['content_status'].= "<span class='label label-success'>".L_TOTAL.formatTimeLength($length)."</span>";
// running
} else {
$row['content_status'] = "<span class='label label-danger'>".L_Running."</span>&nbsp;";
$row['content_status'].= "<span class='label label-success'>".L_LeftTime.":".formatTimeLength($left)." </span>";
}
$private=intval($row["private"]);
if ($private==0)
$row['private'] = "<span class='label label-primary'>".L_Public."</span>";
else
$row['private'] = "<span class='label label-danger'>".L_Private."</span>";
}
unset($row); // avoid last row overwritten.
//Page Includes
require("./pages/contestlist.php");
?>
PHP
1
https://gitee.com/blumia/BLumiaOJ.git
git@gitee.com:blumia/BLumiaOJ.git
blumia
BLumiaOJ
BLumiaOJ
master

搜索帮助