OSDN Git Service

初回コミット(v2.6.17.1)
[magic3/magic3.git] / widgets / m / blog_list / include / container / m_blog_listWidgetContainer.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    Magic3 Framework
10  * @author     平田直毅(Naoki Hirata) <naoki@aplo.co.jp>
11  * @copyright  Copyright 2006-2010 Magic3 Project.
12  * @license    http://www.gnu.org/copyleft/gpl.html  GPL License
13  * @version    SVN: $Id: m_blog_listWidgetContainer.php 3740 2010-10-27 01:22:39Z fishbone $
14  * @link       http://www.magic3.org
15  */
16 require_once($gEnvManager->getContainerPath() . '/baseWidgetContainer.php');
17 require_once($gEnvManager->getCurrentWidgetDbPath() . '/blog_listDb.php');
18
19 class m_blog_listWidgetContainer extends BaseWidgetContainer
20 {
21         private $db;                    // DB接続オブジェクト
22         private $langId;                // 言語
23         const TARGET_WIDGET = 'blog_main';              // 呼び出しウィジェットID
24         const DEFAULT_TITLE = 'ブログリスト';             // デフォルトのウィジェットタイトル名
25                 
26         /**
27          * コンストラクタ
28          */
29         function __construct()
30         {
31                 // 親クラスを呼び出す
32                 parent::__construct();
33                 
34                 // DBオブジェクト作成
35                 $this->db = new blog_listDb();
36         }
37         /**
38          * テンプレートファイルを設定
39          *
40          * _assign()でデータを埋め込むテンプレートファイルのファイル名を返す。
41          * 読み込むディレクトリは、「自ウィジェットディレクトリ/include/template」に固定。
42          *
43          * @param RequestManager $request               HTTPリクエスト処理クラス
44          * @param object         $param                 任意使用パラメータ。そのまま_assign()に渡る
45          * @return string                                               テンプレートファイル名。テンプレートライブラリを使用しない場合は空文字列「''」を返す。
46          */
47         function _setTemplate($request, &$param)
48         {
49                 return 'main.tmpl.html';
50         }
51         /**
52          * テンプレートにデータ埋め込む
53          *
54          * _setTemplate()で指定したテンプレートファイルにデータを埋め込む。
55          *
56          * @param RequestManager $request               HTTPリクエスト処理クラス
57          * @param object         $param                 任意使用パラメータ。_setTemplate()と共有。
58          * @param                                                               なし
59          */
60         function _assign($request, &$param)
61         {
62                 $this->langId   = $this->gEnv->getCurrentLanguage();            // 表示言語を取得
63                 
64                 // ブログリストを作成
65                 $this->db->getAllBlog(array($this, 'blogListLoop'));
66         }
67         /**
68          * ウィジェットのタイトルを設定
69          *
70          * @param RequestManager $request               HTTPリクエスト処理クラス
71          * @param object         $param                 任意使用パラメータ。そのまま_assign()に渡る
72          * @return string                                               ウィジェットのタイトル名
73          */
74         function _setTitle($request, &$param)
75         {
76                 return self::DEFAULT_TITLE;
77         }
78         /**
79          * 取得したデータをテンプレートに設定する
80          *
81          * @param int $index                    行番号(0~)
82          * @param array $fetchedRow             フェッチ取得した行
83          * @param object $param                 未使用
84          * @return bool                                 true=処理続行の場合、false=処理終了の場合
85          */
86         function blogListLoop($index, $fetchedRow, $param)
87         {
88                 // リンク先の作成
89                 $name = $fetchedRow['bl_name'];
90                 $linkUrl = $this->gEnv->getDefaultUrl() . '?' . M3_REQUEST_PARAM_BLOG_ID . '=' . $fetchedRow['bl_id'];
91                 $row = array(
92                         'link_url' => $this->convertUrlToHtmlEntity($this->getUrl($linkUrl, true/*リンク用*/)),             // リンク
93                         'name' => $this->convertToDispString($name)                     // タイトル
94                 );
95                 $this->tmpl->addVars('itemlist', $row);
96                 $this->tmpl->parseTemplate('itemlist', 'a');
97                 return true;
98         }
99 }
100 ?>