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

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

Last change on this file since 6775 was 6775, checked in by ogawa, 12 years ago

#2309:ページャのリクエストからdirecを削除(php)

File size: 3.1 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
62    //c_member_id から自分の日記についてるコメントID(複数)を取得
63    //日記公開範囲を考慮
64    function _p_fh_diary_c_diary_comment_id_list4c_member_id($c_member_id, $is_friend, $type)
65    {
66        if ($type == 'h') {
67            return p_fh_diary_c_diary_comment_id_list4c_member_id($c_member_id);
68        }
69
70        $sql = "SELECT cdc.c_diary_comment_id FROM c_diary as cd,c_diary_comment as cdc, c_member as cm" .
71            " WHERE cd.c_member_id = ?".
72            " AND cd.c_diary_id = cdc.c_diary_id".
73            " AND cd.c_member_id = cm.c_member_id";
74
75        if ($is_friend) {
76            $sql .= ' AND ((cd.public_flag = \'public\') OR (cd.public_flag = \'default\' AND cm.public_flag_diary = \'public\') OR (cd.public_flag = \'friend\') OR (cd.public_flag = \'default\' AND cm.public_flag_diary = \'friend\'))';
77        } else {
78            $sql .= ' AND ((cd.public_flag = \'public\') OR (cd.public_flag = \'default\' AND cm.public_flag_diary = \'public\'))';
79        }
80
81        $params = array(intval($c_member_id));
82        return db_get_col($sql, $params);
83    }
84
85
86}
87
88?>
Note: See TracBrowser for help on using the repository browser.