Page
[ class tree: Page ] [ index: Page ] [ all elements ]

Source for file LC_Page_Admin_Contents_Recommend.php

Documentation is available at LC_Page_Admin_Contents_Recommend.php

  1. <?php
  2. /*
  3.  * This file is part of EC-CUBE
  4.  *
  5.  * Copyright(c) 2000-2010 LOCKON CO.,LTD. All Rights Reserved.
  6.  *
  7.  * http://www.lockon.co.jp/
  8.  *
  9.  * This program is free software; you can redistribute it and/or
  10.  * modify it under the terms of the GNU General Public License
  11.  * as published by the Free Software Foundation; either version 2
  12.  * of the License, or (at your option) any later version.
  13.  *
  14.  * This program is distributed in the hope that it will be useful,
  15.  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  16.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  17.  * GNU General Public License for more details.
  18.  *
  19.  * You should have received a copy of the GNU General Public License
  20.  * along with this program; if not, write to the Free Software
  21.  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
  22.  */
  23.  
  24. // {{{ requires
  25. require_once(CLASS_PATH "pages/LC_Page.php");
  26.  
  27. /**
  28.  * おすすめ管理 のページクラス.
  29.  *
  30.  * @package Page
  31.  * @author LOCKON CO.,LTD.
  32.  * @version $Id$
  33.  */
  34.  
  35.     // }}}
  36.     // {{{ functions
  37.  
  38.     /**
  39.      * Page を初期化する.
  40.      *
  41.      * @return void 
  42.      */
  43.     function init({
  44.         parent::init();
  45.         $this->tpl_mainpage = 'contents/recomend.tpl';
  46.         $this->tpl_mainno = 'contents';
  47.         $this->tpl_subnavi 'contents/subnavi.tpl';
  48.         $this->tpl_subno "recommend";
  49.         $this->tpl_subtitle 'オススメ管理';
  50.     }
  51.  
  52.     /**
  53.      * Page のプロセス.
  54.      *
  55.      * @return void 
  56.      */
  57.     function process({
  58.         $conn new SC_DBConn();
  59.         $objView new SC_AdminView();
  60.         $objSess new SC_Session();
  61.  
  62.         $arrRegistColumn array(
  63.                                  array(  "column" => "product_id""convert" => "n" ),
  64.                                  array(  "column" => "category_id""convert" => "n" ),
  65.                                  array(  "column" => "rank""convert" => "n" ),
  66.                                  array(  "column" => "title""convert" => "aKV" ),
  67.                                  array(  "column" => "comment""convert" => "aKV" ),
  68.                                  );
  69.  
  70.         // 認証可否の判定
  71.         SC_Utils_Ex::sfIsSuccess($objSess);
  72.  
  73.         //最大登録数の表示
  74.         $this->tpl_disp_max RECOMMEND_NUM;
  75.  
  76.         if (!isset($_POST['mode'])) $_POST['mode'"";
  77.         if (!isset($_POST['category_id'])) $_POST['category_id'"";
  78.  
  79.         // 登録時
  80.         if $_POST['mode'== 'regist' ){
  81.  
  82.             // 入力文字の強制変換
  83.             $this->arrForm $_POST;
  84.             $this->arrForm $this->lfConvertParam($this->arrForm$arrRegistColumn);
  85.             // エラーチェック
  86.             $this->arrErr[$this->arrForm['rank']] $this->lfErrorCheck();
  87.             if $this->arrErr[$this->arrForm['rank']]{
  88.                 // 古いのを消す
  89.                 $sql "DELETE FROM dtb_best_products WHERE category_id = ? AND rank = ?";
  90.                 $conn->query($sqlarray($this->arrForm['category_id',$this->arrForm['rank']));
  91.  
  92.                 // DB登録
  93.                 $this->arrForm['creator_id'$_SESSION['member_id'];
  94.                 $this->arrForm['update_date'"NOW()";
  95.                 $this->arrForm['create_date'"NOW()";
  96.  
  97.                 $objQuery new SC_Query();
  98.                 $objQuery->insert("dtb_best_products"$this->arrForm );
  99.                 //        $conn->autoExecute("dtb_best_products", $this->arrForm );
  100.             }
  101.  
  102.         elseif $_POST['mode'== 'delete' ){
  103.             // 削除時
  104.  
  105.             $sql "DELETE FROM dtb_best_products WHERE category_id = ? AND rank = ?";
  106.             $conn->query($sqlarray($_POST['category_id',$_POST['rank']));
  107.  
  108.         }
  109.  
  110.         // カテゴリID取得 無いときはトップページ
  111.         if SC_Utils_Ex::sfCheckNumLength($_POST['category_id']) ){
  112.             $this->category_id $_POST['category_id'];
  113.         else {
  114.             $this->category_id 0;
  115.         }
  116.  
  117.         // 既に登録されている内容を取得する
  118.         $sql "SELECT B.name, B.main_list_image, A.* FROM dtb_best_products as A INNER JOIN dtb_products as B USING (product_id)
  119.          WHERE A.del_flg = 0 ORDER BY rank";
  120.         $arrItems $conn->getAll($sql);
  121.         foreach$arrItems as $data ){
  122.             $this->arrItems[$data['rank']] $data;
  123.         }
  124.  
  125.         // 商品変更時は、選択された商品に一時的に置き換える
  126.         if $_POST['mode'== 'set_item'){
  127.             $sql "SELECT product_id, name, main_list_image FROM dtb_products WHERE product_id = ? AND del_flg = 0";
  128.             $result $conn->getAll($sqlarray($_POST['product_id']));
  129.             if $result ){
  130.                 $data $result[0];
  131.                 foreach$data as $key=>$val){
  132.                     $this->arrItems[$_POST['rank']][$key$val;
  133.                 }
  134.                 $this->arrItems[$_POST['rank']]['rank'$_POST['rank'];
  135.             }
  136.             $this->checkRank $_POST['rank'];
  137.         }
  138.  
  139.         //各ページ共通
  140.         $this->cnt_question 6;
  141.         $this->arrActive = isset($arrActive$arrActive "";;
  142.         $this->arrQuestion = isset($arrQuestion$arrQuestion "";
  143.  
  144.         // カテゴリ取得
  145.         $objDb new SC_Helper_DB_Ex();
  146.         $this->arrCatList $objDb->sfGetCategoryList("level = 1");
  147.  
  148.         //---- ページ表示
  149.         $objView->assignobj($this);
  150.         $objView->display(MAIN_FRAME);
  151.     }
  152.  
  153.     /**
  154.      * デストラクタ.
  155.      *
  156.      * @return void 
  157.      */
  158.     function destroy({
  159.         parent::destroy();
  160.     }
  161.  
  162.     //---- 取得文字列の変換
  163.     function lfConvertParam($array$arrRegistColumn{
  164.  
  165.         // カラム名とコンバート情報
  166.         foreach ($arrRegistColumn as $data{
  167.             $arrConvList$data["column"] ] $data["convert"];
  168.         }
  169.         // 文字変換
  170.         $new_array array();
  171.         foreach ($arrConvList as $key => $val{
  172.             $new_array[$key= isset($array[$key]$array[$key"";
  173.             ifstrlen($val0{
  174.                 $new_array[$keymb_convert_kana($new_array[$key,$val);
  175.             }
  176.         }
  177.         return $new_array;
  178.  
  179.     }
  180.  
  181.     /* 入力エラーチェック */
  182.     function lfErrorCheck({
  183.         $objQuery new SC_Query;
  184.         $objErr new SC_CheckError();
  185.  
  186.         $objErr->doFunc(array("見出しコメント""title"STEXT_LEN)array("MAX_LENGTH_CHECK"));
  187.         $objErr->doFunc(array("オススメコメント""comment"LTEXT_LEN)array("EXIST_CHECK","MAX_LENGTH_CHECK"));
  188.  
  189.         return $objErr->arrErr;
  190.     }
  191.  
  192. }
  193. ?>

Documentation generated on Fri, 24 Feb 2012 13:58:36 +0900 by Seasoft