OSDN Git Service

初回コミット(v2.6.17.1)
[magic3/magic3.git] / widgets / chacha_main / include / container / chacha_mainReadWidgetContainer.php
1 <?php
2 /**
3  * index.php用コンテナクラス
4  *
5  * PHP versions 5
6  *
7  * LICENSE: This source file is licensed under the terms of the GNU General Public License.
8  *
9  * @package    マイクロブログ
10  * @author     株式会社 毎日メディアサービス
11  * @copyright  Copyright 2010 株式会社 毎日メディアサービス.
12  * @license    http://www.gnu.org/copyleft/gpl.html  GPL License
13  * @version    SVN: $Id: chacha_mainReadWidgetContainer.php 3362 2010-07-10 03:08:21Z fishbone $
14  * @link       http://www.m-media.co.jp
15  */
16 require_once($gEnvManager->getCurrentWidgetContainerPath() .    '/chacha_mainBaseWidgetContainer.php');
17
18 class chacha_mainReadWidgetContainer extends chacha_mainBaseWidgetContainer
19 {
20         private $messageCount;                  // メッセージ数
21         private $isExistsMessage;       // メッセージが存在するかどうか
22         private $isExistsNextPage;      // 次のページがあるかどうか
23         
24         /**
25          * コンストラクタ
26          */
27         function __construct()
28         {
29                 // 親クラスを呼び出す
30                 parent::__construct();
31         }
32         /**
33          * テンプレートファイルを設定
34          *
35          * _assign()でデータを埋め込むテンプレートファイルのファイル名を返す。
36          * 読み込むディレクトリは、「自ウィジェットディレクトリ/include/template」に固定。
37          *
38          * @param RequestManager $request               HTTPリクエスト処理クラス
39          * @param object         $param                 任意使用パラメータ。そのまま_assign()に渡る
40          * @return string                                               テンプレートファイル名。テンプレートライブラリを使用しない場合は空文字列「''」を返す。
41          */
42         function _setTemplate($request, &$param)
43         {
44                 return 'thread_read.tmpl.html';
45         }
46         /**
47          * テンプレートにデータ埋め込む
48          *
49          * _setTemplate()で指定したテンプレートファイルにデータを埋め込む。
50          *
51          * @param RequestManager $request               HTTPリクエスト処理クラス
52          * @param object         $param                 任意使用パラメータ。_setTemplate()と共有。
53          * @param                                                               なし
54          */
55         function _assign($request, &$param)
56         {
57                 $act = $request->trimValueOf('act');
58                 $pageNo = $request->trimIntValueOf(M3_REQUEST_PARAM_PAGE_NO, '1');                              // ページ番号
59                 if (empty($pageNo)) $pageNo = 1;
60                 
61                 // クライアントIDを取得
62                 $clientId = '';
63                 if ($this->gEnv->canUseCookie()){               // クッキー使用可能なとき
64                         $clientId = $this->gAccess->getClientId();
65                 }
66                 
67                 // 会員IDを取得
68                 $clientMemberId = '';                   // 現在の端末の会員ID
69                 $ret = $this->_db->getMemberInfoByDeviceId($clientId, $row);
70                 if ($ret) $clientMemberId = $row['mb_id'];
71                 
72                 // 表示メッセージ取得
73                 // 1つ多く呼び出し、次のページがあるか確認
74                 $this->messageCount = $this->_configArray[self::CF_MESSAGE_COUNT_MYPAGE];               // 最大項目数
75                 $this->_db->getThread($this->_boardId, $this->messageCount, $pageNo, array($this, 'itemsLoop'), true);
76         
77                 // 個別のスタイル設定
78                 $innerStyle = self::CSS_BLOG_INNER_STYLE;
79                 //$innerColor = $this->_configArray[self::CF_PROFILE_COLOR];            // プロフィール背景色
80                 if (empty($innerColor)) $innerColor = $this->_configArray[self::CF_INNER_BG_COLOR];             // デフォルトの内枠背景色
81                 if (!empty($innerColor)) $innerStyle .= 'background-color:' . $innerColor . ';';
82                 $this->tmpl->addVar("_widget", "inner_style", $innerStyle);
83                 
84                 // 登録用リンクを作成。会員として認識できないときはプロフィール画面へ、認識できる場合はマイページ画面へ遷移。
85                 $this->tmpl->setAttribute('top_link_area', 'visibility', 'visible');
86                 if (empty($clientMemberId)){
87                         $rigistLink = $this->convertUrlToHtmlEntity($this->getUrl($this->_currentPageUrl . '&task=' . self::TASK_PROFILE, true));
88                         $registName = 'ユーザ登録';
89                 } else {
90                         $rigistLink = $this->convertUrlToHtmlEntity($this->getUrl($this->_currentPageUrl . '&task=' . self::TASK_MYPAGE . '&' . self::URL_PARAM_MEMBER_ID . '=' . $clientMemberId, true));
91                         $registName = '投稿';
92                 }
93                 $this->tmpl->addVar("top_link_area", "regist_url", $rigistLink);
94                 $this->tmpl->addVar("top_link_area", "regist_name", $registName);
95                 
96                 // スレッドが存在しないときは一覧を非表示にする
97                 if (!$this->isExistsMessage){
98                         $this->setGuidanceMsg('メッセージが投稿されていません');
99                         
100                         $this->tmpl->setAttribute('message_list', 'visibility', 'hidden');
101                 }
102                 
103                 // ページ遷移用リンク
104                 $pageLink = '';
105                 if ($pageNo > 1){                       // 前のページがあるとき
106                         $foreLink = $this->convertUrlToHtmlEntity($this->getUrl($this->_currentPageUrl . '&task=' . self::TASK_READ . '&page=' . ($pageNo -1), true));
107                         $pageLink .= '<a href="' . $foreLink . '"><b>前へ</b></a>';
108                 }
109                 if ($this->isExistsNextPage){   // 次のページがあるとき
110                         if (!empty($pageLink)) $pageLink .= '&nbsp;&nbsp;';
111                         $nextLink = $this->convertUrlToHtmlEntity($this->getUrl($this->_currentPageUrl . '&task=' . self::TASK_READ . '&page=' . ($pageNo +1), true));
112                         $pageLink .= '<a href="' . $nextLink . '"><b>次へ</b></a>';
113                 }
114                 $this->tmpl->addVar("_widget", "page_link", $pageLink);
115         }
116         /**
117          * 取得したメッセージ項目をテンプレートに設定する
118          *
119          * @param int           $index                  行番号
120          * @param array         $fetchedRow             取得行
121          * @param object        $param                  任意使用パラメータ
122          * @return bool                                         trueを返すとループ続行。falseを返すとその時点で終了。
123          */
124         function itemsLoop($index, $fetchedRow)
125         {
126                 // 最大表示数を超えたときは終了
127                 if ($index >= $this->messageCount){
128                         $this->isExistsNextPage = true;                         // 次のページあり
129                         return false;
130                 }
131                 
132                 // メッセージ用のデータを取得
133                 $no = $fetchedRow['mt_update_no'];              // スレッド更新番号
134                 $memberId = $fetchedRow['mb_id'];               // 会員ID
135                 $memberName = $fetchedRow['mb_name'];   // 会員名
136                 $messageId = $fetchedRow['mm_thread_id'];
137                 $messageCount = $fetchedRow['mt_message_count'] -1;             // メッセージ数
138                 if ($messageCount <= 0) $messageCount = '';                             // 返信がないときはメッセージ数を表示しない
139                 $mypageLink = $this->convertUrlToHtmlEntity($this->getUrl($this->_currentPageUrl . '&' . self::URL_PARAM_MEMBER_ID . '=' . $memberId, true));
140                 $messageLink = $this->convertUrlToHtmlEntity($this->getUrl($this->_currentPageUrl . '&' . self::URL_PARAM_MESSAGE_ID . '=' . $messageId, true));
141                 
142                 // 名前作成
143                 $nameTag = '<a href="' . $mypageLink . '">' . $this->convertToDispString($memberName) . '</a>';
144                 
145                 // 日付作成
146                 $weekDay = array('日', '月', '火', '水', '木', '金', '土');
147                 $timestamp = strtotime($fetchedRow['mm_regist_dt']);
148                 $weekNo = intval(date('w', $timestamp));
149                 $date = date('Y/m/d(' . $weekDay[$weekNo] . ') H:i:s', $timestamp);
150                 
151                 // 投稿文
152                 $message = $this->convertToDispString($fetchedRow['mm_message']);// 文字エスケープ処理
153                 $message = $this->_convertToPreviewTextWithSpace($message);                     // 改行をスペースに変換
154                 $message = $this->convDispMessage($message, $fetchedRow['mm_thread_id']);// メッセージ内のリンクを作成
155                 
156                 // メッセージID
157                 $messageIdTag = '<a href="' . $messageLink  . '">#' . $messageId . '</a>';
158                 
159                 // 削除メッセージのとき
160                 /*if ($fetchedRow['mm_deleted']){
161                         $message = '参照できません。';
162                 }*/
163                 // アバター画像を設定
164                 $avatarImageUrl = $this->getAvatarUrl($memberId);
165                 $avatarTag = '<img src="' . $this->getUrl($avatarImageUrl) . '" width="' . self::AVATAR_SIZE . '" height="' . self::AVATAR_SIZE .'" />';
166                 $avatarTag = '<a href="' . $mypageLink . '">' . $avatarTag . '</a>';
167                         
168                 $row = array(
169                         'no'            => $no,                                 // 項目番号
170                         'id'            => $messageIdTag,               // メッセージID
171                         'message_count'         => $messageCount,               // メッセージ数
172                         'name'          => $nameTag,                    // 会員名
173                         'date'          => $date,                       // 投稿日付
174                         'message'       => $message,            // 投稿文
175                         'avatar'        => $avatarTag   // アバター画像
176                 );
177                 $this->tmpl->addVars('message_list', $row);
178                 $this->tmpl->parseTemplate('message_list', 'a');
179                 
180                 // メッセージが存在するかどうか
181                 $this->isExistsMessage = true;
182                 return true;
183         }
184 }
185 ?>