バージョン選択

フォーラム

メニュー

オンライン状況

69 人のユーザが現在オンラインです。 (62 人のユーザが フォーラム を参照しています。)
登録ユーザ: 0
ゲスト: 69
もっと...

サイト内検索

質問 > フロント機能 > パンくずリスト ver2.11用 教えてください。

フロント機能

新規スレッドを追加する

スレッド表示 | 古いものから 前のトピック | 次のトピック | 下へ
投稿者 スレッド
it-plus
投稿日時: 2011/10/7 18:13
対応状況: −−−
常連
登録日: 2011/9/23
居住地:
投稿: 31
Re: パンくずリスト ver2.11用 教えてください。
すみません、私が設置したパンくずリストでも下記のような現象が起こっております。


・1
  2
   3
とすると、

TopPage > 3 2 > 1

リストの表示順序が逆になります。

ご教授の程、宜しくお願い申し上げます。

naganaga
投稿日時: 2011/9/24 14:24
対応状況: −−−
半人前
登録日: 2009/3/12
居住地:
投稿: 18
Re: パンくずリスト ver2.11用 教えてください。
解決方法のご教授ありがとうございます。

114行目の末尾に全角スペースが悪さしているとは思っても見ませんでした。
全角スペース追加した記憶がないので、全く特定できませんでした。
無事に動いたのでホッとしております。

飼い猫がスペースキーを踏んだから?

何はともあれ動いて良かったです。
fukap
投稿日時: 2011/9/22 14:47
対応状況: −−−
仙人
登録日: 2009/7/7
居住地: 滋賀県
投稿: 907
Re: パンくずリスト ver2.11用 教えてください。
114行目の末尾に全角スペースがいくつか入っているのが原因ですね。
本カスタマイズとは関係ないと思われます。
naganaga
投稿日時: 2011/9/22 14:21
対応状況: −−−
半人前
登録日: 2009/3/12
居住地:
投稿: 18
Re: パンくずリスト ver2.11用 教えてください。
ご指摘された117行を調べてみましたところ、画面に表示するサブタイトルの設定行となっております。{}は使用しておらず、行末には;が入っておりますので、あくまで素人目ですが、問題ないように思えます。

一応、エラーメッセージで指摘された117行を記述します。


$this->tpl_subtitle = $this->lfGetPageTitle($this->mode, $this->arrSearchData['category_id']);


こちらで、パンくずリストの表示コードの貼付け位置も分かった方が良いと思いますので、LC_Page_Products_List.phpの全文も合わせて記述します。


<?php
/*
 * This file is part of EC-CUBE
 *
 * Copyright(c) 2000-2011 LOCKON CO.,LTD. All Rights Reserved.
 *
 * http://www.lockon.co.jp/
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; either version 2
 * of the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
 */

// {{{ requires
require_once CLASS_EX_REALDIR . 'page_extends/LC_Page_Ex.php';

/**
 * 商品一覧 のページクラス.
 *
 * @package Page
 * @author LOCKON CO.,LTD.
 * @version $Id: LC_Page_Products_List.php 21139 2011-08-05 18:08:16Z Seasoft $
 */
class LC_Page_Products_List extends LC_Page_Ex {

    // {{{ properties

    /** テンプレートクラス名1 */
    var $tpl_class_name1 = array();

    /** テンプレートクラス名2 */
    var $tpl_class_name2 = array();

    /** JavaScript テンプレート */
    var $tpl_javascript;

    var $orderby;

    var $mode;

    /** 検索条件(内部データ) */
    var $arrSearchData = array();

    /** 検索条件(表示用) */
    var $arrSearch = array();

    var $tpl_subtitle = '';

    /** ランダム文字列 **/
    var $tpl_rnd = '';

    // }}}
    // {{{ functions

    /**
     * Page を初期化する.
     *
     * @return void
     */
    function init() {
        parent::init();

        $masterData                 = new SC_DB_MasterData_Ex();
        $this->arrSTATUS            = $masterData->getMasterData("mtb_status");
        $this->arrSTATUS_IMAGE      = $masterData->getMasterData("mtb_status_image");
        $this->arrDELIVERYDATE      = $masterData->getMasterData("mtb_delivery_date");
        $this->arrPRODUCTLISTMAX    = $masterData->getMasterData("mtb_product_list_max");
    }

    /**
     * Page のプロセス.
     *
     * @return void
     */
    function process() {
        parent::process();
        $this->action();
        $this->sendResponse();
    }

    /**
     * Page のAction.
     *
     * @return void
     */
    function action() {
        $objQuery   =& SC_Query_Ex::getSingletonInstance();
        $objProduct = new SC_Product_Ex();

        $this->arrForm = $_REQUEST;//時間が無いのでコレで勘弁してください。 tao_s
        //modeの取得
        $this->mode = $this->getMode();

        //表示条件の取得
        $this->arrSearchData = array(
            'category_id'   => $this->lfGetCategoryId(intval($this->arrForm['category_id'])),
            'maker_id'      => intval($this->arrForm['maker_id']),
            'name'          => $this->arrForm['name']
        );
        $this->orderby = $this->arrForm['orderby'];

        //ページング設定
        $this->tpl_pageno   = $this->arrForm['pageno'];
        $this->disp_number  = $this->lfGetDisplayNum($this->arrForm['disp_number']);       

        // 画面に表示するサブタイトルの設定
        $this->tpl_subtitle = $this->lfGetPageTitle($this->mode, $this->arrSearchData['category_id']);

        // 画面に表示する検索条件を設定
        $this->arrSearch    = $this->lfGetSearchConditionDisp($this->arrSearchData);

        // 商品一覧データの取得
        $arrSearchCondition = $this->lfGetSearchCondition($this->arrSearchData);
        $this->tpl_linemax  = $this->lfGetProductAllNum($arrSearchCondition);
        $urlParam           = "category_id={$this->arrSearchData['category_id']}&pageno=#page#";
        $this->objNavi      = new SC_PageNavi_Ex($this->tpl_pageno, $this->tpl_linemax, $this->disp_number, 'fnNaviPage', NAVI_PMAX, $urlParam, SC_Display_Ex::detectDevice() !== DEVICE_TYPE_MOBILE);
        $this->arrProducts  = $this->lfGetProductsList($arrSearchCondition, $this->disp_number, $this->objNavi->start_row, $this->tpl_linemax, $objProduct);

        switch($this->getMode()){

            case "json":
                   $this->arrProducts = $this->setStatusDataTo($this->arrProducts, $this->arrSTATUS, $this->arrSTATUS_IMAGE);
                   $this->arrProducts = $objProduct->setPriceTaxTo($this->arrProducts);
                   echo SC_Utils_Ex::jsonEncode($this->arrProducts);
                   exit;
               break;

            default:

                //商品一覧の表示処理
                $strnavi            = $this->objNavi->strnavi;
                // 表示文字列
                $this->tpl_strnavi  = empty($strnavi) ? "&nbsp;" : $strnavi;

                // 規格1クラス名
                $this->tpl_class_name1  = $objProduct->className1;

                // 規格2クラス名
                $this->tpl_class_name2  = $objProduct->className2;

                // 規格1
                $this->arrClassCat1     = $objProduct->classCats1;

                // 規格1が設定されている
                $this->tpl_classcat_find1 = $objProduct->classCat1_find;
                // 規格2が設定されている
                $this->tpl_classcat_find2 = $objProduct->classCat2_find;

                $this->tpl_stock_find       = $objProduct->stock_find;
                $this->tpl_product_class_id = $objProduct->product_class_id;
                $this->tpl_product_type     = $objProduct->product_type;

                // 商品ステータスを取得
                $this->productStatus = $this->arrProducts['productStatus'];
                unset($this->arrProducts['productStatus']);
                $this->tpl_javascript .= 'var productsClassCategories = ' . SC_Utils_Ex::jsonEncode($objProduct->classCategories) . ';';
                //onloadスクリプトを設定
                foreach ($this->arrProducts as $arrProduct) {
                    $js_fnOnLoad .= "fnSetClassCategories(document.product_form{$arrProduct['product_id']});";
                }

                //カート処理
                $target_product_id = intval($this->arrForm['product_id']);
                if ( $target_product_id > 0) {
                    // 商品IDの正当性チェック
                    if (!SC_Utils_Ex::sfIsInt($this->arrForm['product_id'])
                        || !SC_Helper_DB_Ex::sfIsRecord("dtb_products", "product_id", $this->arrForm['product_id'], "del_flg = 0 AND status = 1")) {
                        SC_Utils_Ex::sfDispSiteError(PRODUCT_NOT_FOUND);
                    }

                    // 入力内容のチェック
                    $arrErr = $this->lfCheckError($target_product_id, $this->arrForm, $this->tpl_classcat_find1, $this->tpl_classcat_find2);
                    if (empty($arrErr)) {
                        $this->lfAddCart($this->arrForm, $_SERVER['HTTP_REFERER']);
                        SC_Response_Ex::sendRedirect(CART_URLPATH);
                        exit;
                    }
                    $js_fnOnLoad .= $this->lfSetSelectedData($this->arrProducts, $this->arrForm, $arrErr, $target_product_id);
                } else {
                    // カート「戻るボタン」用に保持
                    $netURL = new Net_URL();
                    //該当メソッドが無いため、$_SESSIONに直接セット
                    $_SESSION['cart_referer_url'] = $netURL->getURL();
                }

                $this->tpl_javascript   .= 'function fnOnLoad(){' . $js_fnOnLoad . '}';
                $this->tpl_onload       .= 'fnOnLoad(); ';
                break;

            }

            $this->tpl_rnd          = SC_Utils_Ex::sfGetRandomString(3);

    //パンくずリストを取得
    $this->arrTopicPath = $this->lfTopicPath($this->mode, $this->arrForm['category_id'], $this->arrForm['name']);

    }

    /**
     * デストラクタ.
     *
     * @return void
     */
    function destroy() {
        parent::destroy();
    }

    /**
     * カテゴリIDの取得
     *
     * @return integer カテゴリID
     */
    function lfGetCategoryId($category_id) {

        // 指定なしの場合、0 を返す
        if (empty($category_id)) return 0;

        // 正当性チェック
        if (!SC_Utils_Ex::sfIsInt($category_id)
            || SC_Utils_Ex::sfIsZeroFilling($category_id)
            || !SC_Helper_DB_Ex::sfIsRecord('dtb_category', 'category_id', (array)$category_id, 'del_flg = 0')
            ) {
            SC_Utils_Ex::sfDispSiteError(CATEGORY_NOT_FOUND);
        }

        // 指定されたカテゴリIDを元に正しいカテゴリIDを取得する。
        $arrCategory_id = SC_Helper_DB_Ex::sfGetCategoryId('', $category_id);

        if (empty($arrCategory_id)) {
            SC_Utils_Ex::sfDispSiteError(CATEGORY_NOT_FOUND);
        }

        return $arrCategory_id[0];
    }

    /* 商品一覧の表示 */
    function lfGetProductsList($searchCondition, $disp_number, $startno, $linemax, &$objProduct) {

        $arrval_order = array();

        $objQuery =& SC_Query_Ex::getSingletonInstance();
        // 表示順序
        switch ($this->orderby) {
            // 販売価格が安い順
            case 'price':
                $objProduct->setProductsOrder('price02', 'dtb_products_class', 'ASC');
                break;

            // 新着順
            case 'date':
                $objProduct->setProductsOrder('create_date', 'dtb_products', 'DESC');
                break;

            default:
                if (strlen($searchCondition["where_category"]) >= 1) {
                    $dtb_product_categories = "(SELECT * FROM dtb_product_categories WHERE ".$searchCondition["where_category"].")";
                    $arrval_order           = array_merge($searchCondition['arrvalCategory'], $searchCondition['arrvalCategory']);
                } else {
                    $dtb_product_categories = 'dtb_product_categories';
                }
                $order = <<< __EOS__
                    (
                        SELECT
                             T3.rank
                        FROM
                            $dtb_product_categories T2
                            JOIN dtb_category T3
                                USING (category_id)
                        WHERE T2.product_id = alldtl.product_id
                        ORDER BY T3.rank DESC, T2.rank DESC
                        LIMIT 1
                    ) DESC
                    ,(
                        SELECT
                            T2.rank
                        FROM
                            $dtb_product_categories T2
                            JOIN dtb_category T3
                                USING (category_id)
                        WHERE T2.product_id = alldtl.product_id
                        ORDER BY T3.rank DESC, T2.rank DESC
                        LIMIT 1
                    ) DESC
                    ,product_id
__EOS__;
                    $objQuery->setOrder($order);
                break;
        }
        // 取得範囲の指定(開始行番号、行数のセット)
        $objQuery->setLimitOffset($disp_number, $startno);
        $objQuery->setWhere($searchCondition['where']);

         // 表示すべきIDとそのIDの並び順を一気に取得
        $arrProduct_id = $objProduct->findProductIdsOrder($objQuery, array_merge($searchCondition['arrval'], $arrval_order));

        // 取得した表示すべきIDだけを指定して情報を取得。
        $where = "";
        if (is_array($arrProduct_id) && !empty($arrProduct_id)) {
            $where = 'product_id IN (' . implode(',', $arrProduct_id) . ')';
        } else {
            // 一致させない
            $where = '0<>0';
        }

        $where .= ' AND del_flg = 0'; // 商品規格の削除フラグ
        $objQuery =& SC_Query_Ex::getSingletonInstance();
        $objQuery->setWhere($where);
        $arrProducts = $objProduct->lists($objQuery, $arrProduct_id);

        //取得している並び順で並び替え
        $arrProducts2 = array();
        foreach($arrProducts as $item) {
            $arrProducts2[ $item['product_id'] ] = $item;
        }
        $arrProducts = array();
        foreach($arrProduct_id as $product_id) {
            $arrProducts[] = $arrProducts2[$product_id];
        }

        // 規格を設定
        $objProduct->setProductsClassByProductIds($arrProduct_id);
        $arrProducts += array('productStatus' => $objProduct->getProductStatus($arrProduct_id));
        return $arrProducts;
    }

    /* 入力内容のチェック */
    function lfCheckError($product_id, &$arrForm, $tpl_classcat_find1, $tpl_classcat_find2) {

        // 入力データを渡す。
        $objErr = new SC_CheckError_Ex($arrForm);

        // 複数項目チェック
        if ($tpl_classcat_find1[$product_id]) {
            $objErr->doFunc(array("規格1", 'classcategory_id1', INT_LEN), array("EXIST_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));
        }
        if ($tpl_classcat_find2[$product_id]) {
            $objErr->doFunc(array("規格2", 'classcategory_id2', INT_LEN), array("EXIST_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));
        }

        $objErr->doFunc(array("商品規格ID", 'product_class_id', INT_LEN), array("EXIST_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));
        $objErr->doFunc(array("数量", 'quantity', INT_LEN), array("EXIST_CHECK", "ZERO_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));

        return $objErr->arrErr;
    }

    /**
     * パラメーターの読み込み
     *
     * @return void
     */
    function lfGetDisplayNum($display_number) {
        // 表示件数
        return (SC_Utils_Ex::sfIsInt($display_number))
            ? $display_number
            : current(array_keys($this->arrPRODUCTLISTMAX));
    }

    /**
     * ページタイトルの設定
     *
     * @return str
     */
    function lfGetPageTitle($mode, $category_id = 0){
        if ($mode == 'search') {
            return "検索結果";
        } elseif ($category_id == 0) {
            return "全商品";
        } else {
            $arrCat = SC_Helper_DB_Ex::sfGetCat($category_id);
            return $arrCat['name'];
        }
    }

    /**
     * 表示用検索条件の設定
     *
     * @return array
     */
    function lfGetSearchConditionDisp($arrSearchData){
        $objQuery   =& SC_Query_Ex::getSingletonInstance();
        $arrSearch  = array('category' => '指定なし', 'maker' => '指定なし', 'name' => '指定なし');
        // カテゴリー検索条件
        if ($arrSearchData['category_id'] > 0) {
            $arrSearch['category']  = $objQuery->get('category_name', 'dtb_category', 'category_id = ?', array($arrSearchData['category_id']));
        }

        // メーカー検索条件
        if (strlen($arrSearchData['maker_id']) > 0) {
            $arrSearch['maker']     = $objQuery->get('name', 'dtb_maker', 'maker_id = ?', array($arrSearchData['maker_id']));
        }

        // 商品名検索条件
        if (strlen($arrSearchData['name']) > 0) {
            $arrSearch['name']      = $arrSearchData['name'];
        }
        return $arrSearch;
    }

    /**
     * 該当件数の取得
     *
     * @return int
     */
    function lfGetProductAllNum($searchCondition){
        // 検索結果対象となる商品の数を取得
        $objQuery   =& SC_Query_Ex::getSingletonInstance();
        $objQuery->setWhere($searchCondition['where']);
        $objProduct = new SC_Product_Ex();
        return $objProduct->findProductCount($objQuery, $searchCondition['arrval']);
    }

    /**
     * 検索条件のwhere文とかを取得
     *
     * @return array
     */
    function lfGetSearchCondition($arrSearchData){
        $searchCondition = array(
            'where'             => "",
            'arrval'            => array(),
            "where_category"    => "",
            'arrvalCategory'    => array()
        );

        // カテゴリからのWHERE文字列取得
        if ($arrSearchData["category_id"] != 0) {
            list($searchCondition["where_category"], $searchCondition['arrvalCategory']) = SC_Helper_DB_Ex::sfGetCatWhere($arrSearchData["category_id"]);
        }
        // ▼対象商品IDの抽出
        // 商品検索条件の作成(未削除、表示)
        $searchCondition['where'] = "alldtl.del_flg = 0 AND alldtl.status = 1 ";

        // 在庫無し商品の非表示
        if (NOSTOCK_HIDDEN === true) {
            $searchCondition['where'] .= ' AND (stock >= 1 OR stock_unlimited = 1)';
        }

        if (strlen($searchCondition["where_category"]) >= 1) {
            $searchCondition['where'] .= " AND T2.".$searchCondition["where_category"];
            $searchCondition['arrval'] = array_merge($searchCondition['arrval'], $searchCondition['arrvalCategory']);
        }

        // 商品名をwhere文に
        $name = $arrSearchData['name'];
        $name = str_replace(",", "", $name);
        // 全角スペースを半角スペースに変換
        $name = str_replace(' ', ' ', $name);
        // スペースでキーワードを分割
        $names = preg_split("/ +/", $name);
        // 分割したキーワードを一つずつwhere文に追加
        foreach ($names as $val) {
            if ( strlen($val) > 0 ) {
                $searchCondition['where']    .= " AND ( alldtl.name ILIKE ? OR alldtl.comment3 ILIKE ?) ";
                $searchCondition['arrval'][]  = "%$val%";
                $searchCondition['arrval'][]  = "%$val%";
            }
        }

        // メーカーらのWHERE文字列取得
        if ($arrSearchData['maker_id']) {
            $searchCondition['where']   .= " AND alldtl.maker_id = ? ";
            $searchCondition['arrval'][] = $arrSearchData['maker_id'];
        }
        return $searchCondition;
    }

    /**
     * カートに入れる商品情報にエラーがあったら戻す
     *
     * @return str
     */
    function lfSetSelectedData(&$arrProducts, $arrForm, $arrErr, $product_id){
        $js_fnOnLoad = "";
        foreach (array_keys($arrProducts) as $key) {
            if ($arrProducts[$key]['product_id'] == $product_id) {

                $arrProducts[$key]['product_class_id']  = $arrForm['product_class_id'];
                $arrProducts[$key]['classcategory_id1'] = $arrForm['classcategory_id1'];
                $arrProducts[$key]['classcategory_id2'] = $arrForm['classcategory_id2'];
                $arrProducts[$key]['quantity']          = $arrForm['quantity'];
                $arrProducts[$key]['arrErr']            = $arrErr;
                $js_fnOnLoad .= "fnSetClassCategories(document.product_form{$arrProducts[$key]['product_id']}, '{$arrForm['classcategory_id2']}');";
            }
        }
        return $js_fnOnLoad;
    }

    /**
     * カートに商品を追加
     *
     * @return void
     */
    function lfAddCart($arrForm, $referer){
        $product_class_id = $arrForm['product_class_id'];
        $objCartSess = new SC_CartSession_Ex();
        $objCartSess->addProduct($product_class_id, $arrForm['quantity']);
    }

    /**
     * 商品情報配列にステータス情報を追加する
     *
     * @param Array $arrProducts 商品一覧情報
     * @param Array $arrStatus	ステータス配列
     * @param Array $arrStatusImage スタータス画像配列
     * @return Array $arrProducts 商品一覧情報
     */
    function setStatusDataTo($arrProducts, $arrStatus, $arrStatusImage){

        foreach ($arrProducts['productStatus'] as $product_id => $arrValues) {
            for ($i = 0; $i < count($arrValues); $i++){
                $product_status_id = $arrValues[$i];
                if (!empty($product_status_id)) {
                    $arrProductStatus = array('status_cd' => $product_status_id,
                                              'status_name' => $arrStatus[$product_status_id],
                                              'status_image' =>$arrStatusImage[$product_status_id]);
                    $arrProducts['productStatus'][$product_id][$i] = $arrProductStatus;
                }
            }
        }
        return $arrProducts;
    }

    /**
     * パンくずリストを設定
     *
     * @return array
     */
    function lfTopicPath($mode, $category_id, $category_name){
        if ($mode == 'search') {
          $arrRet = $category_name . " の検索結果";
        } elseif (empty($category_id)){
          $arrRet = "全商品";
        } else {
          $objDb = new SC_Helper_DB_Ex();
          $arrCatId = $objDb->sfGetParents("dtb_category", "parent_category_id", "category_id", $category_id);
          foreach($arrCatId as $key => $val){
            $arrCatName = $objDb->sfGetCat($val);
            if($val != $category_id){
              $arrRet[] = '<a href="./list.php?category_id=' .$val. '">'. $arrCatName['name'] . '</a> > ';
            } else {
              $arrRet[] = $arrCatName['name'];
            }
          }
        }
        return $arrRet;
    }
}
?>


分かる範囲でコードの挿入位置を変えてみたりしたのですが、相変わらず同じエラーメッセージが出続けております。ちなみに、パンぐすリストのコードが入っていない状態では、問題なく一覧ページは表示されます。

それでは、
よろしくお願い致します。

EC-Cube 2.11.2
MySQL 5.1.22-rc
fukap
投稿日時: 2011/9/21 12:09
対応状況: −−−
仙人
登録日: 2009/7/7
居住地: 滋賀県
投稿: 907
Re: パンくずリスト ver2.11用 教えてください。
エラーコードが示しているように、
data/class/pages/products/LC_Page_Products_List.php の 117行目に
文法エラーがあるのではないでしょうか。

末尾に ; (セミコロン)がついていないとか } (波括弧)がついていないとか。
naganaga
投稿日時: 2011/9/20 23:37
対応状況: −−−
半人前
登録日: 2009/3/12
居住地:
投稿: 18
Re: パンくずリスト ver2.11用 教えてください。
EC-Cube Ver.2.11.2でパンくずリストのコードを設置してみたところ、商品一覧で、
「Parse error: syntax error, unexpected T_VARIABLE in /virtual/incite/public_html/incite.jp/store/data/class/pages/products/LC_Page_Products_List.php on line 117」
というエラーが出てしまいページが表示されなくなりました。

LC_Page_Products_List.phpの、「$this->tpl_rnd = SC_Utils_Ex::sfGetRandomString(3);」の後に、//パンくずリストを取得のコードを挿入。
もう一つのコードをファイルの末尾に入れました。
LC_Page_Products_Detail.phpと同じ位置に入れておりまして、商品詳細ページのパンくずリストは問題なく表示しております。
当方の力不足で、エラー原因が特定できず困っております。
解決方法をご教授頂けると有難く思います。

EC-Cube 2.11.2
MySQL 5.1.22-rc
aska824
投稿日時: 2011/6/11 21:28
対応状況: −−−
長老
登録日: 2010/2/20
居住地: 静岡県
投稿: 185
Re: パンくずリスト ver2.11用 教えてください。
お〜〜〜さすがです><

僕のを元に変更してくださってありがとうございます^^

あまり必要ないかもしれないんですが、僕的にはトップページにも「TopPage」ってな感じで入れたいんで少し改良させてもらいました(ってもSmartyだけなんですけど^^;)

色々聞いてもらっちゃってありがとうございます


----------------
-----------情報-----------
自分の分かる範囲でお答えします。

Shop Mate

fukap
投稿日時: 2011/6/11 8:26
対応状況: −−−
仙人
登録日: 2009/7/7
居住地: 滋賀県
投稿: 907
Re: パンくずリスト ver2.11用 教えてください。
aska824様にインスパイアされて、ちょっとだけ手直しした第二弾を作ってみましたヨ。
コンセプトは、少しだけSmartyテンプレ側でHTMLを処理するようにしたのと、全ページにパンくずリストが出るようにしてみました。
ちょっとpatapata様風味も入れつつって感じです。

./data/class/pages/products/LC_Page_Products_List.php の action() 内の末尾に以下のコードを記述

    //パンくずリストを取得
    $this->arrTopicPath = $this->lfTopicPath($this->mode, $this->arrForm['category_id'], $this->arrForm['name']);

./data/class/pages/products/LC_Page_Products_List.php の LC_Page_Products_List クラス内の末尾に以下のコードを記述

    /**
     * パンくずリストを設定
     *
     * @return array
     */
    function lfTopicPath($mode, $category_id, $category_name){
        if ($mode == 'search') {
          $arrRet = $category_name . " の検索結果";
        } elseif (empty($category_id)){
          $arrRet = "全商品";
        } else {
          $objDb = new SC_Helper_DB_Ex();
          $arrCatId = $objDb->sfGetParents("dtb_category", "parent_category_id", "category_id", $category_id);
          foreach($arrCatId as $key => $val){
            $arrCatName = $objDb->sfGetCat($val);
            if($val != $category_id){
              $arrRet[] = '<a href="./list.php?category_id=' .$val. '">'. $arrCatName['name'] . '</a> > ';
            } else {
              $arrRet[] = $arrCatName['name'];
            }
          }
        }
        return $arrRet;
    }

./data/class/pages/products/LC_Page_Products_Detail.php の action() 内の末尾に以下のコードを記述

    // パンくずリストを取得
    $this->arrTopicPath = $this->lfTopicPath2($product_id);

./data/class/pages/products/LC_Page_Products_List.php の LC_Page_Products_Detail クラス内の末尾に以下のコードを記述

    /*
     * パンくずリストを設定
     * @return array
     */
    function lfTopicPath2($product_id){
        $objDb = new SC_Helper_DB_Ex();
        $arrCategory_id = $objDb->sfGetCategoryId($product_id);
        $arrCatId = $objDb->sfGetParents("dtb_category", "parent_category_id", "category_id", $arrCategory_id[0]);
        foreach($arrCatId as $key => $val){
          $arrCatName = $objDb->sfGetCat($val);
          $arrRet[] = '<a href="./list.php?category_id=' .$val. '">'. $arrCatName['name'] . '</a> > ';
        }
        $arrRet[] = $this->arrProduct['name'];
        return $arrRet;
    }

./data/Smarty/templates/default/site_main.tpl の適当な場所に以下のタグを記述

<!--{* ▼BREAD CRUMBS *}-->
<!--{if $smarty.server.PHP_SELF != '/index.php'}-->
  <p><a href="<!--{$smarty.const.HTTP_URL}-->">TopPage</a> >
  <!--{if $arrTopicPath}-->
    <!--{foreach from=$arrTopicPath item=Topic}-->
      <!--{$Topic}-->
    <!--{/foreach}-->
  <!--{else}--><!--{$tpl_title|h}-->
  <!--{/if}-->
  </p>
<!--{/if}-->
<!--{* ▲BREAD CRUMBS *}-->

追記:バグ発見したので 6/12 20:00 にコード変更しました。
aska824
投稿日時: 2011/6/10 22:44
対応状況: −−−
長老
登録日: 2010/2/20
居住地: 静岡県
投稿: 185
Re: パンくずリスト ver2.11用 教えてください。
できた所でもう一つ、自分でやってみました^^;

一覧ページと、詳細ページだけじゃ物足りないなって思い、
http://www28.atwiki.jp/lucier/pages/42.html
の「表示するテンプレート」を参考に簡単ですが、他のページに表示させるよう変更しました^^l

<!--{if $TopicPath != ""}--><!--{$TopicPath}--><!--{else}--><a href="/index.php">ホーム</a> > <!--{$tpl_title}--><!--{/if}-->

これで表示できるようにしています。
ただ、トップページでも「ホーム > 」と表示されてしまいますが・・・^^;

あと、2階層までになってます。
特に必要無いかな?って思いましたが、一応載せてみました^^


----------------
-----------情報-----------
自分の分かる範囲でお答えします。

Shop Mate

aska824
投稿日時: 2011/6/10 22:21
対応状況: −−−
長老
登録日: 2010/2/20
居住地: 静岡県
投稿: 185
Re: パンくずリスト ver2.11用 教えてください。
あれ?
何故かわかりませんが、もう一度組み入れたところ、うまく表示されるようになりました^^;

もしかしたら何か抜けてたのかもしれません・・・

お騒がせしてすみません・・・。


----------------
-----------情報-----------
自分の分かる範囲でお答えします。

Shop Mate

« 1 2 (3) 4 5 »
スレッド表示 | 古いものから 前のトピック | 次のトピック | トップ


 



ログイン


EC-CUBE公式 Amazon Payプラグイン

統計情報

総メンバー数は88,710名です
総投稿数は109,948件です

投稿数ランキング

1
seasoft
7367
2
468
3217
3
AMUAMU
2712
4
nanasess
2313
5
umebius
2085
6
yuh
1819
7
h_tanaka
1638
8
red
1570
9
mcontact
1285
10
tsuji
958
11
fukap
907
12
shutta
835
13
tao_s
799
14 ramrun 789
15 karin 689
16 sumida 641
17
homan
633
18 DELIGHT 572
19
patapata
502
20
flealog
485


ネットショップの壺

EC-CUBEインテグレートパートナー

Copyright© EC-CUBE CO.,LTD. All Rights Reserved.