lainchan/templates/themes/recent/theme.php

125 lines
4.4 KiB
PHP
Raw Normal View History

2011-04-14 14:53:29 -04:00
<?php
require 'info.php';
function recentposts_build($action, $settings, $board) {
2011-04-14 14:53:29 -04:00
// Possible values for $action:
// - all (rebuild everything, initialization)
// - news (news has been updated)
// - boards (board list changed)
// - post (a post has been made)
// - post-thread (a thread has been made)
2011-04-14 14:53:29 -04:00
$b = new RecentPosts();
2011-04-16 11:28:25 -04:00
$b->build($action, $settings);
2011-04-14 14:53:29 -04:00
}
// Wrap functions in a class so they don't interfere with normal Tinyboard operations
class RecentPosts {
2011-04-16 11:28:25 -04:00
public function build($action, $settings) {
2011-04-14 14:53:29 -04:00
global $config, $_theme;
2012-05-05 11:33:10 -04:00
if ($action == 'all') {
copy('templates/themes/recent/' . $settings['basecss'], $config['dir']['home'] . $settings['css']);
2011-04-14 14:53:29 -04:00
}
2011-04-16 11:28:25 -04:00
$this->excluded = explode(' ', $settings['exclude']);
if ($action == 'all' || $action == 'post' || $action == 'post-thread')
file_write($config['dir']['home'] . $settings['html'], $this->homepage($settings));
2011-04-14 14:53:29 -04:00
}
// Build news page
2011-04-16 11:28:25 -04:00
public function homepage($settings) {
2011-04-14 14:53:29 -04:00
global $config, $board;
$recent_images = Array();
$recent_posts = Array();
$stats = Array();
2011-04-14 14:53:29 -04:00
$boards = listBoards();
$query = '';
2012-05-05 11:33:10 -04:00
foreach ($boards as &$_board) {
if (in_array($_board['uri'], $this->excluded))
continue;
$query .= sprintf("SELECT *, '%s' AS `board` FROM `posts_%s` WHERE `file` IS NOT NULL AND `file` != 'deleted' AND `thumb` != 'spoiler' UNION ALL ", $_board['uri'], $_board['uri']);
}
$query = preg_replace('/UNION ALL $/', 'ORDER BY `time` DESC LIMIT ' . (int)$settings['limit_images'], $query);
$query = query($query) or error(db_error());
2011-04-14 14:53:29 -04:00
2013-07-31 20:51:43 -04:00
while ($post = $query->fetch(PDO::FETCH_ASSOC)) {
openBoard($post['board']);
2011-04-14 14:53:29 -04:00
// board settings won't be available in the template file, so generate links now
$post['link'] = $config['root'] . $board['dir'] . $config['dir']['res'] . sprintf($config['file_page'], ($post['thread'] ? $post['thread'] : $post['id'])) . '#' . $post['id'];
$post['src'] = $config['uri_thumb'] . $post['thumb'];
2011-04-14 14:53:29 -04:00
$recent_images[] = $post;
}
2011-04-14 14:53:29 -04:00
$query = '';
2012-05-05 11:33:10 -04:00
foreach ($boards as &$_board) {
if (in_array($_board['uri'], $this->excluded))
continue;
$query .= sprintf("SELECT *, '%s' AS `board` FROM `posts_%s` UNION ALL ", $_board['uri'], $_board['uri']);
}
$query = preg_replace('/UNION ALL $/', 'ORDER BY `time` DESC LIMIT ' . (int)$settings['limit_posts'], $query);
$query = query($query) or error(db_error());
2011-04-14 14:53:29 -04:00
2013-07-31 20:51:43 -04:00
while ($post = $query->fetch(PDO::FETCH_ASSOC)) {
openBoard($post['board']);
2011-04-14 14:53:29 -04:00
$post['link'] = $config['root'] . $board['dir'] . $config['dir']['res'] . sprintf($config['file_page'], ($post['thread'] ? $post['thread'] : $post['id'])) . '#' . $post['id'];
$post['snippet'] = pm_snippet($post['body'], 30);
$post['board_name'] = $board['name'];
2011-04-14 14:53:29 -04:00
$recent_posts[] = $post;
}
2011-04-14 14:53:29 -04:00
// Total posts
2013-07-31 20:51:43 -04:00
$query = 'SELECT SUM(`top`) FROM (';
2012-05-05 11:33:10 -04:00
foreach ($boards as &$_board) {
if (in_array($_board['uri'], $this->excluded))
continue;
$query .= sprintf("SELECT MAX(`id`) AS `top` FROM `posts_%s` UNION ALL ", $_board['uri']);
}
$query = preg_replace('/UNION ALL $/', ') AS `posts_all`', $query);
$query = query($query) or error(db_error());
2013-07-31 20:51:43 -04:00
$stats['total_posts'] = number_format($query->fetchColumn());
// Unique IPs
2013-07-31 20:51:43 -04:00
$query = 'SELECT COUNT(DISTINCT(`ip`)) FROM (';
2012-05-05 11:33:10 -04:00
foreach ($boards as &$_board) {
if (in_array($_board['uri'], $this->excluded))
continue;
$query .= sprintf("SELECT `ip` FROM `posts_%s` UNION ALL ", $_board['uri']);
}
$query = preg_replace('/UNION ALL $/', ') AS `posts_all`', $query);
$query = query($query) or error(db_error());
2013-07-31 20:51:43 -04:00
$stats['unique_posters'] = number_format($query->fetchColumn());
// Active content
2013-07-31 20:51:43 -04:00
$query = 'SELECT SUM(`filesize`) FROM (';
2012-05-05 11:33:10 -04:00
foreach ($boards as &$_board) {
if (in_array($_board['uri'], $this->excluded))
continue;
$query .= sprintf("SELECT `filesize` FROM `posts_%s` UNION ALL ", $_board['uri']);
}
$query = preg_replace('/UNION ALL $/', ') AS `posts_all`', $query);
$query = query($query) or error(db_error());
2013-07-31 20:51:43 -04:00
$stats['active_content'] = $query->fetchColumn();
return Element('themes/recent/recent.html', Array(
'settings' => $settings,
'config' => $config,
'boardlist' => createBoardlist(),
'recent_images' => $recent_images,
'recent_posts' => $recent_posts,
'stats' => $stats
));
2011-04-14 14:53:29 -04:00
}
};
2011-06-11 03:09:51 -04:00
?>