--- fenglin/bbs/list.php 2025/04/27 04:18:22 1.7 +++ fenglin/bbs/list.php 2026/02/11 10:59:14 1.11 @@ -205,13 +205,13 @@ if ($_SESSION["BBS_uid"] > 0) { - $aid_list = "-1"; + $aid_list = array(-1); while ($row = mysqli_fetch_array($rs)) { if ((new DateTimeImmutable("-" . $BBS_new_article_period . " day")) < (new DateTimeImmutable($row["sub_dt"]))) { - $aid_list .= (", " . $row["AID"]); + array_push($aid_list, $row["AID"]); } else { @@ -221,9 +221,11 @@ mysqli_data_seek($rs, 0); - if ($aid_list != "-1") + if (count($aid_list) > 1) { - $sql = "SELECT AID FROM view_article_log WHERE AID IN ($aid_list) AND UID = " . $_SESSION["BBS_uid"]; + $sql = "SELECT AID FROM view_article_log WHERE AID IN (" . + implode(",", $aid_list) . + ") AND UID = " . $_SESSION["BBS_uid"]; $rs_view = mysqli_query($db_conn, $sql); if ($rs_view == false) @@ -248,10 +250,25 @@ while ($row = mysqli_fetch_array($rs)) { + // Rewrite title with "Re: Re: " prefix into "Re: ... " + $title = $row["title"]; + if ($row["TID"] != 0) + { + $j = 0; + while (substr_compare($row["title"], "Re: ", $j, strlen("Re: ")) == 0) + { + $j += strlen("Re: "); + } + if ($j >= strlen("Re: Re: ")) + { + $title = "Re: ... " . substr($row["title"], $j); + } + } + array_push($result_set["data"]["articles"], array( "aid" => $row["AID"], "tid" => $row["TID"], - "title" => $row["title"], + "title" => $title, "sub_dt" => (new DateTimeImmutable($row["sub_dt"]))->setTimezone($_SESSION["BBS_user_tz"]), "length" => $row["length"], "icon" => $row["icon"], @@ -269,7 +286,7 @@ "last_reply_uid" => $row["last_reply_UID"], "last_reply_username" => $row["last_reply_username"], "last_reply_nickname" => $row["last_reply_nickname"], - "visited" => (($_SESSION["BBS_uid"] > 0 && in_array($row["AID"], $visited_aid_list)) ? 1 : 0), + "visited" => (($_SESSION["BBS_uid"] > 0 && ($row["UID"] == $_SESSION["BBS_uid"] || in_array($row["AID"], $visited_aid_list))) ? 1 : 0), )); if (!isset($author_list[$row["UID"]])) @@ -280,19 +297,23 @@ { $author_list[$row["last_reply_UID"]] = true; } + + unset($title); } mysqli_free_result($rs); - $uid_list = "-1"; + $uid_list = array(-1); foreach ($author_list as $uid => $status) { - $uid_list .= (", " . $uid); + array_push($uid_list, $uid); } unset($author_list); $author_list = array(); - $sql = "SELECT UID FROM user_list WHERE UID IN ($uid_list) AND enable"; + $sql = "SELECT UID FROM user_list WHERE UID IN (" . + implode(",", $uid_list) . + ") AND enable"; $rs = mysqli_query($db_conn, $sql); if ($rs == false) @@ -343,4 +364,3 @@ exit(json_encode($result_set)); // Output data in Json } include $theme_view_file; -?>