/[LeafOK_CVS]/lbbs/utils/bin/gen_section_menu.php
ViewVC logotype

Diff of /lbbs/utils/bin/gen_section_menu.php

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.7 by sysadm, Fri May 30 03:00:26 2025 UTC Revision 1.11 by sysadm, Mon Oct 13 00:18:28 2025 UTC
# Line 91  Line 91 
91          $buffer .= <<<MENU          $buffer .= <<<MENU
92  #---------------------------------------------------------------------  #---------------------------------------------------------------------
93  %menu M_EGROUP  %menu M_EGROUP
94  title       0, 0, "[Ŀб]"  title       0, 0, "[栏目列表]"
95  screen      2, 0, S_EGROUP  screen      2, 0, S_EGROUP
96    
97  MENU;  MENU;
# Line 102  MENU; Line 102  MENU;
102    
103                  $section_count = count($section_class["sections"]);                  $section_count = count($section_class["sections"]);
104    
105                  $title_f = str_repeat(" ", 5 - intval(log10($section_count))) . $section_count . "  " .                  $title_f = str_repeat(" ", 5 - intval(log10($section_count))) . $section_count . " +  " .
106                          $section_class['name'] . str_repeat(" ", 32 - strlen($section_class['name'])) .                          $section_class['name'] . str_repeat(" ", 32 - strlen($section_class['name'])) .
107                          "[" . addslashes($section_class['title']) . "]";                          "[" . addslashes($section_class['title']) . "]";
108    
# Line 136  MENU; Line 136  MENU;
136    
137                          $article_count = $section['udf_values']['article_count'];                          $article_count = $section['udf_values']['article_count'];
138    
139                          $title_f = str_repeat(" ", 5 - intval(log10($article_count))) . $article_count . "  " .                          $title_f = str_repeat(" ", 5 - intval(log10($article_count))) . $article_count . " +  " .
140                                  $section['name'] . str_repeat(" ", 20 - strlen($section['name'])) .                                  $section['name'] . str_repeat(" ", 20 - strlen($section['name'])) .
141                                  $class_title_f . addslashes($section['title']) . str_repeat(" ", 22 - str_length($section['title'])) .                                  $class_title_f . addslashes($section['title']) . str_repeat(" ", 22 - str_length($section['title'])) .
142                                  $section['udf_values']['section_master'];                                  ($section['udf_values']['section_master'] == "" ? "诚征版主中" : $section['udf_values']['section_master']);
143    
144                          $buffer .= <<<MENU                          $buffer .= <<<MENU
145                          @LIST_SECTION   {$display_row}, 4, 1, {$section['read_user_level']},   "{$section['name']}",    "{$title_f}"                          @LIST_SECTION   {$display_row}, 4, 1, {$section['read_user_level']},   "{$section['name']}",    "{$title_f}"
# Line 154  MENU; Line 154  MENU;
154    
155          }          }
156    
157            // Load excerptional section list
158            $ex_section_hierachy = array();
159    
160            $ret = load_section_list($ex_section_hierachy,
161                    function (array $section, array $filter_param) : bool
162                    {
163                            $db_conn = $filter_param["db"];
164    
165                            // Query excerptional article count
166                            $sql = "SELECT AID AS ex_article_count FROM bbs WHERE SID = " .
167                                            $section["SID"] . " AND visible AND gen_ex LIMIT 1";
168                            
169                            $rs = mysqli_query($db_conn, $sql);
170                            if ($rs == false)
171                            {
172                                    echo mysqli_error($db_conn);
173                                    return false;
174                            }
175    
176                            $have_ex_article = (mysqli_num_rows($rs) > 0);
177                            mysqli_free_result($rs);
178    
179                            return $have_ex_article;
180                    },
181                    function (array $section, array $filter_param) : mixed
182                    {
183                            $db_conn = $filter_param["db"];
184                            $result = array(
185                                    "ex_menu_tm" => 0,
186                                    "ex_article_count" => 0,
187                            );
188    
189                            // Query ex_menu_tm
190                            $sql = "SELECT ex_menu_tm FROM section_config WHERE SID = " . $section["SID"];
191                            $rs = mysqli_query($db_conn, $sql);
192                            if ($rs == false)
193                            {
194                                    echo mysqli_error($db_conn);
195                                    return $result;
196                            }
197    
198                            if ($row = mysqli_fetch_array($rs))
199                            {
200                                    $result["ex_menu_tm"] = $row["ex_menu_tm"];
201                            }
202                            mysqli_free_result($rs);
203    
204                            // Query excerptional article count
205                            $sql = "SELECT COUNT(*) AS ex_article_count FROM bbs WHERE SID = " .
206                                            $section["SID"] . " AND visible AND gen_ex";
207                            
208                            $rs = mysqli_query($db_conn, $sql);
209                            if ($rs == false)
210                            {
211                                    echo mysqli_error($db_conn);
212                                    return $result;
213                            }
214    
215                            if ($row = mysqli_fetch_array($rs))
216                            {
217                                    $result["ex_article_count"] = $row["ex_article_count"];
218                            }
219                            mysqli_free_result($rs);
220    
221                            return $result;
222                    },
223                    $db_conn,
224                    array(
225                            "db" => $db_conn
226                    )
227            );
228    
229            if ($ret == false)
230            {
231                    echo "Query excerptional section list error: " . mysqli_error($db_conn);
232                    exit();
233            }
234    
235            // Generate menu of excerptional section class
236            $buffer .= <<<MENU
237    #---------------------------------------------------------------------
238    %menu M_ANNOUNCE
239    title       0, 0, "精华公布栏"
240    screen      2, 0, S_EGROUP
241    
242    MENU;
243    
244            foreach ($ex_section_hierachy as $c_index => $section_class)
245            {
246                    $display_row = ($c_index == 0 ? 4 : 0);
247    
248                    $section_count = count($section_class["sections"]);
249    
250                    $title_f = str_repeat(" ", 5 - intval(log10($section_count))) . $section_count . " +  " .
251                            $section_class['name'] . str_repeat(" ", 32 - strlen($section_class['name'])) .
252                            "[" . addslashes($section_class['title']) . "]";
253    
254                    $buffer .= <<<MENU
255                    !M_EX_{$section_class['name']}   {$display_row}, 4, 1, 0,   "{$section_class['name']}",    "{$title_f}"
256    
257                    MENU;
258            }
259    
260            $buffer .= <<<MENU
261    %
262    
263    MENU;
264    
265            foreach ($ex_section_hierachy as $c_index => $section_class)
266            {
267                    // Generate menu of excerptional sections in section_class[$c_index]
268                    $buffer .= <<<MENU
269    #---------------------------------------------------------------------
270    %menu M_EX_{$section_class["name"]}
271    title       0, 0, "精华区 > {$section_class["title"]}"
272    screen      2, 0, S_EX_DIR
273    
274    MENU;
275    
276                    $display_row = 4;
277                    $class_title_f = "[" . addslashes($section_class['title']) . "]" . str_repeat(" ", 10 - str_length($section_class['title']));
278                    
279                    foreach ($section_class["sections"] as $s_index => $section)
280                    {
281                            $article_count = $section['udf_values']['ex_article_count'];
282                            if ($article_count == 0)
283                            {
284                                    continue;
285                            }
286    
287                            $title_f = str_repeat(" ", 5 - intval(log10($article_count))) . $article_count . " +  " .
288                                    $section['name'] . str_repeat(" ", 20 - strlen($section['name'])) .
289                                    $class_title_f . addslashes($section['title']) . str_repeat(" ", 22 - str_length($section['title'])) .
290                                    (new DateTimeImmutable($section['udf_values']['ex_menu_tm']))->format("Y.m.d");
291    
292                            $buffer .= <<<MENU
293                            @LIST_EX_SECTION   {$display_row}, 4, 1, 0,   "{$section['name']}",    "{$title_f}"
294    
295                            MENU;
296    
297                            $display_row = 0;
298                    }
299    
300                    $buffer .= <<<MENU
301    %
302    
303    MENU;
304    
305            }
306    
307          // Generate menu of all sections          // Generate menu of all sections
308          $buffer .= <<<MENU          $buffer .= <<<MENU
309  #---------------------------------------------------------------------  #---------------------------------------------------------------------
310  %menu M_BOARD  %menu M_BOARD
311  title       0, 0, "[б]"  title       0, 0, "[版块列表]"
312  screen      2, 0, S_BOARD  screen      2, 0, S_BOARD
313  page        4, 1, 20  page        4, 1, 20
314    
# Line 174  MENU; Line 324  MENU;
324                  {                  {
325                          $article_count = $section['udf_values']['article_count'];                          $article_count = $section['udf_values']['article_count'];
326    
327                          $title_f = str_repeat(" ", 5 - intval(log10($article_count))) . $article_count . "  " .                          $title_f = str_repeat(" ", 5 - intval(log10($article_count))) . $article_count . " +  " .
328                                  $section['name'] . str_repeat(" ", 20 - strlen($section['name'])) .                                  $section['name'] . str_repeat(" ", 20 - strlen($section['name'])) .
329                                  $class_title_f . addslashes($section['title']) . str_repeat(" ", 22 - str_length($section['title'])) .                                  $class_title_f . addslashes($section['title']) . str_repeat(" ", 22 - str_length($section['title'])) .
330                                  $section['udf_values']['section_master'];                                  ($section['udf_values']['section_master'] == "" ? "诚征版主中" : $section['udf_values']['section_master']);
331    
332                          $buffer .= <<<MENU                          $buffer .= <<<MENU
333                          @LIST_SECTION   {$display_row}, 4, 1, {$section['read_user_level']},   "{$section['name']}",    "{$title_f}"                          @LIST_SECTION   {$display_row}, 4, 1, {$section['read_user_level']},   "{$section['name']}",    "{$title_f}"
# Line 193  MENU; Line 343  MENU;
343    
344  MENU;  MENU;
345    
346          // Generate menu of favourite sections          // Generate menu of favorite sections
347          $buffer .= <<<MENU          $buffer .= <<<MENU
348  #---------------------------------------------------------------------  #---------------------------------------------------------------------
349  %menu M_FAVOUR  %menu M_FAVOUR
350  title       0, 0, "[ղ]"  title       0, 0, "[版块收藏]"
351  screen      2, 0, S_BOARD  screen      2, 0, S_BOARD
352  use_filter  use_filter
353  page        4, 1, 20  page        4, 1, 20
# Line 214  MENU; Line 364  MENU;
364                  {                  {
365                          $article_count = $section['udf_values']['article_count'];                          $article_count = $section['udf_values']['article_count'];
366    
367                          $title_f = str_repeat(" ", 5 - intval(log10($article_count))) . $article_count . "  " .                          $title_f = str_repeat(" ", 5 - intval(log10($article_count))) . $article_count . " +  " .
368                                  $section['name'] . str_repeat(" ", 20 - strlen($section['name'])) .                                  $section['name'] . str_repeat(" ", 20 - strlen($section['name'])) .
369                                  $class_title_f . addslashes($section['title']) . str_repeat(" ", 22 - str_length($section['title'])) .                                  $class_title_f . addslashes($section['title']) . str_repeat(" ", 22 - str_length($section['title'])) .
370                                  $section['udf_values']['section_master'];                                  ($section['udf_values']['section_master'] == "" ? "诚征版主中" : $section['udf_values']['section_master']);
371    
372                          $buffer .= <<<MENU                          $buffer .= <<<MENU
373                          @LIST_SECTION   {$display_row}, 4, {$section['sid']}, {$section['read_user_level']},   "{$section['name']}",    "{$title_f}"                          @LIST_SECTION   {$display_row}, 4, {$section['sid']}, {$section['read_user_level']},   "{$section['name']}",    "{$title_f}"


Legend:
Removed lines/characters  
Changed lines/characters
  Added lines/characters

webmaster@leafok.com
ViewVC Help
Powered by ViewVC 1.3.0-beta1