1
0
mirror of https://github.com/vichan-devel/vichan.git synced 2024-12-11 07:16:10 +01:00
vichan/templates/themes/catalog/theme.php

103 lines
3.4 KiB
PHP
Raw Normal View History

2013-07-18 17:30:00 +02:00
<?php
require 'info.php';
function catalog_build($action, $settings, $board) {
global $config;
2013-07-18 17:30:00 +02:00
// Possible values for $action:
// - all (rebuild everything, initialization)
// - news (news has been updated)
// - boards (board list changed)
// - post (a reply has been made)
// - post-thread (a thread has been made)
2013-07-18 17:30:00 +02:00
2014-04-05 23:04:46 +02:00
if ($settings['all']) {
2014-04-23 23:59:41 +02:00
$boards = listBoards(TRUE);
2014-04-05 23:04:46 +02:00
} else {
$boards = explode(' ', $settings['boards']);
}
if ($action == 'all') {
2013-07-18 17:30:00 +02:00
foreach ($boards as $board) {
$b = new Catalog();
$b->build($settings, $board);
2013-07-18 17:30:00 +02:00
}
2014-04-05 23:04:46 +02:00
} elseif ($action == 'post-thread' || ($settings['update_on_posts'] && $action == 'post') || ($settings['update_on_posts'] && $action == 'post-delete') && (in_array($board, $boards) | $settings['all'])) {
$b = new Catalog();
$b->build($settings, $board);
2013-07-18 17:30:00 +02:00
}
}
// Wrap functions in a class so they don't interfere with normal Tinyboard operations
class Catalog {
public function build($settings, $board_name) {
2013-07-18 17:30:00 +02:00
global $config, $board;
openBoard($board_name);
2013-07-18 17:30:00 +02:00
$recent_images = array();
$recent_posts = array();
$stats = array();
$query = query(sprintf("SELECT *, `id` AS `thread_id`,
2014-08-08 22:48:38 +02:00
(SELECT COUNT(`id`) FROM ``posts_%s`` WHERE `thread` = `thread_id`) AS `reply_count`,
(SELECT SUM(`num_files`) FROM ``posts_%s`` WHERE `thread` = `thread_id` AND `num_files` IS NOT NULL) AS `image_count`,
'%s' AS `board` FROM ``posts_%s`` WHERE `thread` IS NULL ORDER BY `bump` DESC",
$board_name, $board_name, $board_name, $board_name, $board_name)) or error(db_error());
2013-07-18 17:30:00 +02:00
2013-08-01 02:51:43 +02:00
while ($post = $query->fetch(PDO::FETCH_ASSOC)) {
2013-07-18 17:30:00 +02:00
$post['link'] = $config['root'] . $board['dir'] . $config['dir']['res'] . sprintf($config['file_page'], ($post['thread'] ? $post['thread'] : $post['id']));
$post['board_name'] = $board['name'];
if ($post['embed'] && preg_match('/^https?:\/\/(\w+\.)?(?:youtube\.com\/watch\?v=|youtu\.be\/)([a-zA-Z0-9\-_]{10,11})(&.+)?$/i', $post['embed'], $matches)) {
$post['youtube'] = $matches[2];
}
2014-08-08 22:48:38 +02:00
if (isset($post['files'])) {
2014-04-27 15:48:47 +02:00
$files = json_decode($post['files']);
if ($files[0]->file == 'deleted') {
if (count($files) > 1) {
foreach ($files as $file) {
if (($file == $files[0]) || ($file->file == 'deleted')) continue;
$post['file'] = $config['uri_thumb'] . $file->thumb;
}
if (empty($post['file'])) $post['file'] = $config['image_deleted'];
}
else {
$post['file'] = $config['image_deleted'];
}
}
else if($files[0]->thumb == 'spoiler') {
$post['file'] = '/' . $config['spoiler_image'];
}
else {
2014-04-27 15:48:47 +02:00
$post['file'] = $config['uri_thumb'] . $files[0]->thumb;
2014-08-08 22:48:38 +02:00
}
}
if (empty($post['image_count'])) $post['image_count'] = 0;
2013-07-18 17:30:00 +02:00
$recent_posts[] = $post;
}
2014-08-08 22:48:38 +02:00
$required_scripts = array('js/jquery.min.js', 'js/jquery.mixitup.min.js', 'js/catalog.js');
2014-06-12 19:26:21 +02:00
foreach($required_scripts as $i => $s) {
if (!in_array($s, $config['additional_javascript']))
$config['additional_javascript'][] = $s;
}
file_write($config['dir']['home'] . $board_name . '/catalog.html', Element('themes/catalog/catalog.html', Array(
2013-07-18 17:30:00 +02:00
'settings' => $settings,
'config' => $config,
'boardlist' => createBoardlist(),
'recent_images' => $recent_images,
'recent_posts' => $recent_posts,
'stats' => $stats,
'board' => $board_name,
'link' => $config['root'] . $board['dir']
)));
2013-07-18 17:30:00 +02:00
}
};