ここの情報は古いです。ご理解頂いた上でお取り扱いください。

source: OpenPNE/trunk/webapp/modules/pc/page/fh_comment_list.php @ 9465

Last change on this file since 9465 was 9465, checked in by ogawa, 11 years ago

#3184:pc_page_fh_comment_list内のSQLからdefaultを削除

File size: 2.8 KB
Line 
1<?php
2/**
3 * @copyright 2005-2008 OpenPNE Project
4 * @license   http://www.php.net/license/3_01.txt PHP License 3.01
5 */
6
7class pc_page_fh_comment_list extends OpenPNE_Action
8{
9    function execute($requests)
10    {
11        $u = $GLOBALS['AUTH']->uid();
12
13        // --- リクエスト変数
14        $target_c_member_id = $requests['target_c_member_id'];
15        $page = $requests['page'];
16        // ----------
17
18        if (empty($target_c_member_id)) {
19            $target_c_member_id = $u;
20        }
21
22        $target_c_member = db_member_c_member4c_member_id($target_c_member_id);
23        $this->set("target_member", $target_c_member);
24
25        if ($target_c_member_id == $u) {
26            $type = "h";
27        } else {
28            $type = "f";
29
30            $is_friend = db_friend_is_friend($u, $target_c_member_id);
31
32            // アクセスブロック
33            if (db_member_is_access_block($u, $target_c_member_id)) {
34                openpne_redirect('pc', 'page_h_access_block');
35            }
36        }
37        $this->set('inc_navi', fetch_inc_navi($type, $target_c_member_id));
38
39        //c_member_id から自分の日記についてるコメントIDリストを取得
40        $target_c_diary_comment_id = $this->_p_fh_diary_c_diary_comment_id_list4c_member_id($target_c_member_id, $is_friend, $type);
41
42        $page_size = 50;
43        list($c_diary_comment_list, $is_prev, $is_next, $total_num) =
44            db_diary_get_c_diary_comment_list4id_list($target_c_diary_comment_id, $page, $page_size, true);
45
46        //最近のコメント一覧用配列(50個まで)
47        $this->set("new_comment_list", $c_diary_comment_list);
48        $this->set("is_prev", $is_prev);
49        $this->set("is_next", $is_next);
50        $pager = array();
51        $pager['start'] = $page_size * ($page - 1) + 1;
52        if (($pager['end'] = $page_size * $page) > $total_num) {
53            $pager['end'] = $total_num;
54        }
55        $this->set('page', $page);
56        $this->set('pager', $pager);
57
58        return 'success';
59    }
60
61    // c_member_id から自分の日記についてるコメントID(複数)を取得
62    // 日記公開範囲を考慮
63    function _p_fh_diary_c_diary_comment_id_list4c_member_id($c_member_id, $is_friend, $type)
64    {
65        if ($type == 'h') {
66            return p_fh_diary_c_diary_comment_id_list4c_member_id($c_member_id);
67        }
68
69        $sql = "SELECT cdc.c_diary_comment_id FROM c_diary as cd,c_diary_comment as cdc" .
70            " WHERE cd.c_member_id = ?".
71            " AND cd.c_diary_id = cdc.c_diary_id";
72
73        if ($is_friend) {
74            $sql .= " AND cd.public_flag <> 'private'";
75        } else {
76            $sql .= " AND cd.public_flag = 'public'";
77        }
78
79        $params = array(intval($c_member_id));
80        return db_get_col($sql, $params);
81    }
82}
83
84?>
Note: See TracBrowser for help on using the repository browser.