OSDN Git Service

初回コミット(v2.6.17.1)
[magic3/magic3.git] / widgets / blog_category_menu / include / container / blog_category_menuWidgetContainer.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-2009 Magic3 Project.
12  * @license    http://www.gnu.org/copyleft/gpl.html  GPL License
13  * @version    SVN: $Id: blog_category_menuWidgetContainer.php 3829 2010-11-16 12:24:10Z fishbone $
14  * @link       http://www.magic3.org
15  */
16 require_once($gEnvManager->getContainerPath() . '/baseWidgetContainer.php');
17 require_once($gEnvManager->getCurrentWidgetDbPath() . '/blog_category_menuDb.php');
18
19 class blog_category_menuWidgetContainer 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_category_menuDb();
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 'menu.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->getAllCategory(array($this, 'categoryListLoop'), $this->langId);// デフォルト言語で取得
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 categoryListLoop($index, $fetchedRow, $param)
87         {
88                 // リンク先の作成
89                 $name = $fetchedRow['bc_name'];
90                 $linkUrl = $this->createCmdUrlToWidget(self::TARGET_WIDGET, 'act=view&' . M3_REQUEST_PARAM_CATEGORY_ID . '=' . $fetchedRow['bc_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 ?>