Просмотр файла lib/includes/articles/view.php

Размер файла: 6.82Kb
  1. <?php
  2.  
  3. $error = array();
  4. if (!$id) {
  5. $error[] = 'Ошибка входящих данных'; // =)
  6. } else {
  7. Core::get(array('page.class', 'text.class', 'cache.class'), 'classes');
  8.  
  9. $strs = !empty($_REQUEST['strings']) ? abs(intval($_REQUEST['strings'])) : 500;
  10. $total = mb_strlen($sql->query("SELECT `text` FROM `mod_lib` WHERE `id` = " . $id ." AND `type` = 'arc'")->result());
  11. if (isset($_GET['page']))
  12. {
  13. if ($_GET['page'] == 'end')
  14. $_GET['page'] = ceil($total / $strs);
  15. if ($_GET['page'] > 1)
  16. $start = $_GET['page'] * $strs - $strs;
  17. }
  18. $start = isset($start) == 0 ? 1 : $start;
  19.  
  20. $arc = $sql->query(
  21. "SELECT `refid`, `name`, SUBSTRING(`text` FROM " . $start . " FOR " . $strs
  22. . ") as `content`, `announce`, `tags`, `time`, " .
  23. "`author_id`, `author_name`, `comm_count`, " .
  24. "`views`, `uni_views`, `rate_plus`, `rate_minus`, " .
  25. "`edit_name`, `edit_id`, `edit_time`" .
  26. " FROM `mod_lib` WHERE `id` = " . $id .
  27. " AND `type` = 'arc'" . ($moder ? "" : " AND `mod` = '0'")
  28. )->fetch();
  29. if ($arc !== FALSE) {
  30.  
  31. /* Получаем имя родительского каталога */
  32.  
  33. if ($arc['refid'] != 0) {
  34. $cat = $sql->query("SELECT `name` FROM `mod_lib` WHERE `id` = " . $arc['refid'])->fetch();
  35. if ($cat != FALSE) {
  36. $cat = htmlentities($cat['name'], ENT_QUOTES, 'UTF-8');
  37. }
  38. }
  39. $page = new page($total, $strs);
  40. /* Счетчик просмотров */
  41. $libView = isset($_SESSION['lib_view']) ? $_SESSION['lib_view'] : 0;
  42. if ($libView != $id) {
  43. $sql->query("UPDATE `mod_lib` SET `views` = '" . ($arc['views'] + 1) . "' WHERE `id` = " . $id);
  44. $_SESSION['lib_view'] = $id;
  45. }
  46. /* Счетчик уникальных просмотров */
  47. //$user_id = $user_id ? $user_id : md5(core::$ip . core::$ip_via_proxy . core::$user_agent);
  48. $unic = $sql->query("SELECT COUNT(*) FROM `mod_lib_counters` WHERE `uid` = '" . $user_id ."' AND `aid` = '" . $id . "' AND `type` = 0")->result();
  49. if (!$unic) {
  50. $sql->query("UPDATE `mod_lib` SET `uni_views` = '" . ($arc['uni_views'] + 1) . "' WHERE `id` = '" . $id . "'");
  51. $sql->query("INSERT INTO `mod_lib_counters` SET `aid` = '" . $id . "', `uid` = '" . $user_id . "'");
  52. }
  53.  
  54. $text = text::output($arc['content']);
  55.  
  56. $set['title'] = htmlspecialchars($arc['name']);
  57. /* Устанавливаем мета теги */
  58. $meta['keywords'] = htmlspecialchars($arc['tags']);
  59. $meta['description'] = htmlspecialchars($arc['announce']);
  60.  
  61. require H . 'engine/includes/head.php';
  62. $cache = new cache(H . 'engine/files/tmp/lib[arc='.$id.';strs='.$strs.';start='.$start.'].swc');
  63. if (!$cache->life())
  64. {
  65. ob_start();
  66. $author_arc = Core::get_user($arc['author_id']);
  67. echo '<div class="fmenu">' . 'Библиотека' . ' | ' . (!empty($cat) ? $cat . ' | ' : '') . $set['title'] . '</div>';
  68. if ($total > $start)
  69. $page->display('?act=articles&amp;mod=view&amp;id=' . $id . '&amp;strings=' . $strs . '&amp;', $strs);
  70. echo '<div class="post"><b>' . htmlentities($arc['name'], ENT_QUOTES, 'UTF-8');
  71. echo '</b><br />'. $text . '</div>';
  72. if ($total > $start)
  73. $page->display('?act=articles&amp;mod=view&amp;id=' . $id . '&amp;strings=' . $strs . '&amp;', $strs);
  74. echo '<div class="post">' .
  75. (!empty($arc['tags']) ? '<b>Метки:</b>&#160;' . tagsToLinks($arc['tags']) . '<br />' : '') .
  76. '<b>Автор:</b>&#160;'.$author_arc['nick'].' ('.Core::time($arc['time']).')<br />',
  77. (!empty($arc['edit_time']) ? '<b>Изменено:</b>&#160;'.Core::time($arc['edit_time']).'<br />' : '').
  78. '<b>Просмотры:</b>&#160;' . $arc['views'] . '<br />' .
  79. '<b>Уникальных просмотров:</b>&#160;' . $arc['uni_views'] . '<br />' .
  80. '<b>Комментарии:</b>&#160;<a href="?act=comments&amp;id=' . $id . '">' . $sql->query('SELECT count(*) from `mod_lib_comments` where `sub_id` = '.$id)->result() . '</a><br />' .
  81. '<b>Рейтинг</b>:&#160;' .
  82. '<a href="?act=articles&amp;mod=vote&amp;id=' . $id . '&amp;do=1"><img src="' . ICONSDIR . 'minus.png" alt="-" /></a>&#160;' .
  83. ($arc['rate_plus'] - $arc['rate_minus']) .
  84. '&#160;<a href="?act=articles&amp;mod=vote&amp;id=' . $id . '&amp;do=2"><img src="' . ICONSDIR . 'plus.png" alt="+" /></a>&#160;' .
  85. '(За: ' . $arc['rate_plus'] . ' | Против: ' . $arc['rate_minus'] . ')</div>';
  86. /* Прикрепленные файлы */
  87. $ftotal = $sql->query("SELECT COUNT(*) FROM `mod_lib_files` WHERE `aid` = '" . $id . "'")->result();
  88. if ($ftotal != 0) {
  89. echo '<div class="msg"><b>Прикрепленные&#160; файлы:</b><br />';
  90. $sql->query("SELECT `name` FROM `mod_lib_files` WHERE `aid` = " . $id);
  91. while($fdata = $sql->fetch()) {
  92. $fname = htmlentities($fdata['name'], ENT_QUOTES, 'UTF-8');
  93. echo '<a href="/lib/files/attach/' . $fname . '">' . $fname . '</a><br />';
  94. }
  95. echo '</div>';
  96. }
  97. echo '<div class="menu"><b>Символов на страницу:</b><br />' .
  98. '<form action="?act=articles&amp;mod=view&amp;id=' . $id . '" method="post">' .
  99. '<select name="strings">';
  100. $strings = range(500, 3000, 500);
  101. foreach ($strings as $val) {
  102. echo '<option value="' . $val . '"' . ($val == $strs ? ' selected="selected"' : '') . '>' . $val . '</option>';
  103. }
  104. echo '</select><input type="submit" name="submit" value="Сохранить" /></form></div><div class="menu">';
  105. $cache->write();
  106. }
  107. echo $cache->read();
  108.  
  109. /* Добавление статьи в закладки / Удаление статьи из закладок */
  110. $bookmark = $sql->query(
  111. "SELECT COUNT(*) FROM `mod_lib_counters` " .
  112. "WHERE `aid` = '" . $id .
  113. "' AND `uid` = '" . $user_id .
  114. "' AND `type` = '2'"
  115. )->result();
  116. $bmLink = $bookmark
  117. ? '<a href="?act=bookmarks&amp;mod=remove&amp;id=' . $id . '">Удалить из закладок</a>'
  118. : '<a href="?act=bookmarks&amp;mod=add&amp;id=' . $id . '">Добавить в закладки</a>';
  119. echo '<a href="?act=' .
  120. (isset($_GET['panel']) ? 'panel&amp;mod=view&amp;id=' . $arc['refid'] : 'category&amp;mod=view&amp;id=' . $arc['refid'])
  121. . '">Назад</a><br /><a href="index.php">В библиотеку</a><br />' .
  122. '<a href="?act=articles&amp;mod=download&amp;id=' . $id . '">Загрузить</a><br />' . $bmLink;
  123. if ($admin) {
  124. echo '<br /><a href="?act=articles&amp;mod=move&amp;id=' . $id . '">Переместить</a>' .
  125. '<br /><a href="?act=articles&amp;mod=form&amp;id=' . $id . '&amp;do=edit">Редактировать</a>' .
  126. '<br /><a href="?act=articles&amp;mod=remove&amp;id=' . $id . '">Удалить</a>';
  127. }
  128. echo '</div>';
  129. } else {
  130. $error[] = 'Статья не найдена';
  131. }
  132. }
  133. if (!empty($error)) {
  134. $set['title'] = 'Библиотека';
  135. require H . 'engine/includes/head.php';
  136. }