バージョン選択

フォーラム

メニュー

オンライン状況

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

サイト内検索

 > フロント機能 > カテゴリ毎のトップコンテンツ表示

フロント機能

新規スレッドを追加する

スレッド表示 | 新しいものから 前のトピック | 次のトピック | 下へ
投稿者 スレッド
homan
投稿日時: 2008/3/13 11:55
対応状況: −−−
仙人
登録日: 2007/7/2
居住地: 宮崎県宮崎市
投稿: 633
Re: カテゴリ毎のトップコンテンツ表示
引用:
二つ目「info_flg」のDB設定はphpMyAdminで見ると下記のようになっています。
・フィールドタイプ ⇒ smallint
・照合順序 ⇒ 空欄
・表示する ⇒ 空欄
・空の値(NULL) ⇒ いいえ
・基本値 ⇒ 0


info_flg の 空の値(NULL)を、「いいえ」から「はい」に変更してみてください。phpMyAdminでみるときは、空の値のところが、おそらく「NOT NULL」かなにかになっているとおもうので、「NULL」に変更します。

info_flgが空の値を許していないのに、NULL値がセットされてしまっているからだと思います。


----------------
このコミュニティでの投稿はボランティアの範囲に留めさせていただいています。個別の相談やカスタマイズは有償にて承っておりますのでご相談下さい。

[url=http://www.eccube-school.jp/]EC-CUBE

ゲスト
投稿日時: 2008/3/13 11:55
対応状況: −−−
Re: カテゴリ毎のトップコンテンツ表示
普通に新規ページ作ってカテゴリごとの商品を呼び出して
TOPページからは静的リンクを貼るって事じゃないの?

標準で付いてるカテゴリページは、検索ページでその
カテゴリを引っ張ってるだけだから
そのカテゴリごとのコメントを新規に追加して
カテゴリの呼び出しのときに表示してるだけだけど
普通は特集ページのようなスタイルでカテゴリトップの
必要性のほうが高いと思うんだけどな
icom352
投稿日時: 2008/3/13 12:06
対応状況: −−−
半人前
登録日: 2007/6/4
居住地:
投稿: 11
Re: カテゴリ毎のトップコンテンツ表示
引用:

homanさんは書きました:
info_flg の 空の値(NULL)を、「いいえ」から「はい」に変更してみてください。phpMyAdminでみるときは、空の値のところが、おそらく「NOT NULL」かなにかになっているとおもうので、「NULL」に変更します。

info_flgが空の値を許していないのに、NULL値がセットされてしまっているからだと思います。


すばやい回答ありがとう御座いました。

ご指摘の修正で解決いたしました。
本当にありがとう御座いました。


----------------
----------------------------------
EC-CUBEバージョン 2.2.0-beta
PHPバージョン PHP 5.2.8
DBバージョン MySQL 4.1.22
OS Redhat Enterprise Linux 4ES

ゲスト
投稿日時: 2008/3/31 0:32
対応状況: −−−
Re: カテゴリ毎のトップコンテンツ表示
2系でも問題なく導入できたという方いらっしゃいますか?
tao
投稿日時: 2008/3/31 2:01
対応状況: −−−
一人前
登録日: 2007/12/28
居住地: 東京
投稿: 82
Re: カテゴリ毎のトップコンテンツ表示
私は2系でも作成しましたが、問題なく稼動してます。
むしろ2系の方が作りやすかったです。
ゲスト
投稿日時: 2008/4/3 17:41
対応状況: −−−
Re: カテゴリ毎のトップコンテンツ表示
私はこちらうまくいかなかったので別の方が提示していただいていた方法でやってみたのですが50文字しか入れられない本当の説明だけを追記するものだったので使えませんでした。
スクリプト自体かなり変わっていると思うのですが該当ファイルに追記しただけでしょうか?
tao
投稿日時: 2008/4/4 0:10
対応状況: −−−
一人前
登録日: 2007/12/28
居住地: 東京
投稿: 82
Re: カテゴリ毎のトップコンテンツ表示
私の場合は、プログラムはそんなに変更していません。カゴラボさんと同様のカスタマイズを行い、ついでにエディタを設定し、プレビューボックスを追加しました。

データベースに関してはデータお入れるカラムをtext型に指定しており、今の所困っていません。
もっと違う大きなコンテンツを扱いたい場合は別ファイルにして読み込むのはいかがでしょうか?
ゲスト
投稿日時: 2008/4/30 23:22
対応状況: −−−
Re: カテゴリ毎のトップコンテンツ表示
是非とも2系で導入したいので、とてもお手数ですが
tao様のソースを公開して頂けませんか?
ゲスト
投稿日時: 2008/5/28 20:53
対応状況: −−−
Re: カテゴリ毎のトップコンテンツ表示
現在2.1.2で導入に手こずっています。

カテゴリ毎に説明文等のコンテンツを表示する

の方法をそのまま導入すると、
管理画面でカテゴリー管理に入った際、真っ白になります。

変更点はカテゴリ毎に説明文等のコンテンツを表示するの通りなのですが、2系の場合、特別な仕様変更は必要でしょうか?

下記変更済みコード
/data/class/pages/admin/products/LC_Page_Admin_Products_Category.php

// {{{ requires
require_once(CLASS_PATH . "pages/LC_Page.php");

/**
 * カテゴリ管理 のページクラス.
 *
 * @package Page
 * @author LOCKON CO.,LTD.
 * @version $Id: LC_Page_Admin_Products_Category.php 17226 2008-04-07 04:29:15Z satou $
 */
class LC_Page_Admin_Products_Category extends LC_Page {

    // {{{ properties

    /** フォームパラメータ */
    var $objFormParam;

    // }}}
    // {{{ functions

    /**
     * Page を初期化する.
     *
     * @return void
     */
    function init() {
        parent::init();
        $this->tpl_subtitle = 'カテゴリー登録';
        $this->tpl_mainpage = 'products/category.tpl';
        $this->tpl_subnavi = 'products/subnavi.tpl';
        $this->tpl_mainno = 'products';
        $this->tpl_subno = 'category';
        $this->tpl_onload = " fnSetFocus('category_name'); ";
    }

    /**
     * Page のプロセス.
     *
     * @return void
     */
    function process() {
        $conn = new SC_DBConn();
        $objView = new SC_AdminView();
        $objSess = new SC_Session();
        $objDb = new SC_Helper_DB_Ex();

        // 認証可否の判定
        SC_Utils_Ex::sfIsSuccess($objSess);

        // パラメータ管理クラス
        $this->objFormParam = new SC_FormParam();
        // パラメータ情報の初期化
        $this->lfInitParam();
        // POST値の取得
        $this->objFormParam->setParam($_POST);

        // 通常時は親カテゴリを0に設定する。
        $this->arrForm['parent_category_id'] =
            isset($_POST['parent_category_id']) ? $_POST['parent_category_id'] : "";

        if (!isset($_POST['mode'])) $_POST['mode'] = "";

        switch($_POST['mode']) {
        case 'edit':
            $this->objFormParam->convParam();
            $arrRet =  $this->objFormParam->getHashArray();
            $this->arrErr = $this->lfCheckError($arrRet);

            if(count($this->arrErr) == 0) {
                if($_POST['category_id'] == "") {
                    $objQuery = new SC_Query();
                    $count = $objQuery->count("dtb_category");
                    if($count < CATEGORY_MAX) {
                        $this->lfInsertCat($_POST['parent_category_id']);
                    } else {
                        print("カテゴリの登録最大数を超えました。");
                    }
                } else {
                    $this->lfUpdateCat($_POST['category_id']);
                }
            } else {
                $this->arrForm = array_merge($this->arrForm, $this->objFormParam->getHashArray());
                $this->arrForm['category_id'] = $_POST['category_id'];
            }
            break;
        case 'pre_edit':
            // 編集項目のカテゴリ名をDBより取得する。
            $objQuery = new SC_Query();
            $where = "category_id = ?";
            $col = "category_name, category_info, info_flg, level";
            $arrRet = $objQuery->select($col, "dtb_category", $where, array($_POST['category_id']));
            // 入力項目にカテゴリ名を入力する。
            $objPage->arrForm['category_name'] = $arrRet[0]['category_name'];
            $objPage->arrForm['category_info'] = $arrRet[0]['category_info'];
            $objPage->arrForm['info_flg']      = $arrRet[0]['info_flg'];
            $objPage->arrForm['level']         = $arrRet[0]['level'];
            // POSTデータを引き継ぐ
            $this->arrForm['category_id'] = $_POST['category_id'];
            break;
        case 'delete':
            $objQuery = new SC_Query();
            // 子カテゴリのチェック
            $where = "parent_category_id = ? AND del_flg = 0";
            $count = $objQuery->count("dtb_category", $where, array($_POST['category_id']));
            if($count != 0) {
                $this->arrErr['category_name'] = "※ 子カテゴリが存在するため削除できません。<br>";
            }
            // 登録商品のチェック
            $table = "dtb_product_categories AS T1 LEFT JOIN dtb_products AS T2 ON T1.product_id = T2.product_id";
            $where = "T1.category_id = ? AND T2.del_flg = 0";
            $count = $objQuery->count($table, $where, array($_POST['category_id']));
            if($count != 0) {
                $this->arrErr['category_name'] = "※ カテゴリ内に商品が存在するため削除できません。<br>";
            }

            if(!isset($this->arrErr['category_name'])) {
                // ランク付きレコードの削除(※処理負荷を考慮してレコードごと削除する。)
                $objDb->sfDeleteRankRecord("dtb_category", "category_id", $_POST['category_id'], "", true);
            }
            break;
        case 'up':
            $objQuery = new SC_Query();
            $objQuery->begin();
            $up_id = $this->lfGetUpRankID($objQuery, "dtb_category", "parent_category_id", "category_id", $_POST['category_id']);
            if($up_id != "") {
                // 上のグループのrankから減算する数
                $my_count = $this->lfCountChilds($objQuery, "dtb_category", "parent_category_id", "category_id", $_POST['category_id']);
                // 自分のグループのrankに加算する数
                $up_count = $this->lfCountChilds($objQuery, "dtb_category", "parent_category_id", "category_id", $up_id);
                if($my_count > 0 && $up_count > 0) {
                    // 自分のグループに加算
                    $this->lfUpRankChilds($objQuery, "dtb_category", "parent_category_id", "category_id", $_POST['category_id'], $up_count);
                    // 上のグループから減算
                    $this->lfDownRankChilds($objQuery, "dtb_category", "parent_category_id", "category_id", $up_id, $my_count);
                }
            }
            $objQuery->commit();
            break;
        case 'down':
            $objQuery = new SC_Query();
            $objQuery->begin();
            $down_id = $this->lfGetDownRankID($objQuery, "dtb_category", "parent_category_id", "category_id", $_POST['category_id']);
            if($down_id != "") {
                // 下のグループのrankに加算する数
                $my_count = $this->lfCountChilds($objQuery, "dtb_category", "parent_category_id", "category_id", $_POST['category_id']);
                // 自分のグループのrankから減算する数
                $down_count = $this->lfCountChilds($objQuery, "dtb_category", "parent_category_id", "category_id", $down_id);
                if($my_count > 0 && $down_count > 0) {
                    // 自分のグループから減算
                    $this->lfUpRankChilds($objQuery, "dtb_category", "parent_category_id", "category_id", $down_id, $my_count);
                    // 下のグループに加算
                    $this->lfDownRankChilds($objQuery, "dtb_category", "parent_category_id", "category_id", $_POST['category_id'], $down_count);
                }
            }
            $objQuery->commit();
            break;
        case 'tree':
            break;
        case 'csv':
            require_once(CLASS_EX_PATH . "helper_extends/SC_Helper_CSV_Ex.php");

            $objCSV = new SC_Helper_CSV_Ex();
            // オプションの指定
            $option = "ORDER BY rank DESC";
            // CSV出力タイトル行の作成
            $arrOutput = SC_Utils_Ex::sfSwapArray($objCSV->sfgetCsvOutput(5, " WHERE csv_id = 5 AND status = 1"));

            if (count($arrOutput) <= 0) break;

            $arrOutputCols = $arrOutput['col'];
            $arrOutputTitle = $arrOutput['disp_name'];

            $head = SC_Utils_Ex::sfGetCSVList($arrOutputTitle);

            $where = "del_flg = 0";
            $data = $objCSV->lfGetCategoryCSV($where, $option, $arrval, $arrOutputCols);

            // CSVを送信する。
            SC_Utils_Ex::sfCSVDownload($head.$data, 'category');
            exit;
            break;
        default:
            $this->arrForm['parent_category_id'] = 0;
            break;
        }

        $this->arrList = $this->lfGetCat($this->arrForm['parent_category_id']);
        $this->arrTree = $objDb->sfGetCatTree($this->arrForm['parent_category_id']);

        $objView->assignobj($this);
        $objView->display(MAIN_FRAME);
    }

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



    // カテゴリの新規追加
    function lfInsertCat($parent_category_id) {

        $objQuery = new SC_Query();
        $objQuery->begin(); // トランザクションの開始


        if($parent_category_id == 0) {
            // ROOT階層で最大のランクを取得する。
            $where = "parent_category_id = ?";
            $rank = $objQuery->max("dtb_category", "rank", $where, array($parent_category_id)) + 1;
        } else {
            // 親のランクを自分のランクとする。
            $where = "category_id = ?";
            $rank = $objQuery->get("dtb_category", "rank", $where, array($parent_category_id));
            // 追加レコードのランク以上のレコードを一つあげる。
            $sqlup = "UPDATE dtb_category SET rank = (rank + 1) WHERE rank >= ?";
            $objQuery->exec($sqlup, array($rank));
        }

        $where = "category_id = ?";
        // 自分のレベルを取得する(親のレベル + 1)
        $level = $objQuery->get("dtb_category", "level", $where, array($parent_category_id)) + 1;

        // 入力データを渡す。
        $sqlval = $this->objFormParam->getHashArray();
        $sqlval['create_date'] = "Now()";
        $sqlval['update_date'] = "Now()";
        $sqlval['creator_id'] = $_SESSION['member_id'];
        $sqlval['parent_category_id'] = $parent_category_id;
        $sqlval['rank'] = $rank;
        $sqlval['level'] = $level;
        
        //追記:親の設定を引き継ぐ時
        if($sqlval['info_flg']) {
        $sqlval['category_info'] = lfGetParentInfo($objQuery, $parent_category_id);
        }

        // INSERTの実行
        $objQuery->insert("dtb_category", $sqlval);

        $objQuery->commit();    // トランザクションの終了
    }

    // カテゴリの編集
    function lfUpdateCat($category_id) {
        $objQuery = new SC_Query();
        // 入力データを渡す。
        $sqlval = $this->objFormParam->getHashArray();
        $sqlval['update_date'] = "Now()";
        $where = "category_id = ?";
        //追記:親の設定を引き継ぐ時
        if($sqlval['info_flg']) {
           $parent_category_id = $objQuery->get("dtb_category", "parent_category_id", $where, array($category_id));
           $sqlval['category_info'] = lfGetParentInfo($objQuery, $parent_category_id);
        }
        $objQuery->update("dtb_category", $sqlval, $where, array($category_id));
    }

    // カテゴリの取得
    function lfGetCat($parent_category_id) {
        $objQuery = new SC_Query();

        if($parent_category_id == "") {
            $parent_category_id = '0';
        }

        $col = "category_id, category_name, level, rank";
        $where = "del_flg = 0 AND parent_category_id = ?";
        $objQuery->setoption("ORDER BY rank DESC");
        $arrRet = $objQuery->select($col, "dtb_category", $where, array($parent_category_id));
        return $arrRet;
    }

    /* パラメータ情報の初期化 */
    function lfInitParam() {
        $this->objFormParam->addParam("カテゴリ名", "category_name", STEXT_LEN, "KVa", array("EXIST_CHECK","SPTAB_CHECK","MAX_LENGTH_CHECK"));
        $objFormParam->addParam("カテゴリ情報", "category_info", LLTEXT_LEN, "KVa", array("SPTAB_CHECK","MAX_LENGTH_CHECK"));
        $objFormParam->addParam("引き継ぎ", "info_flg", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
    }

    /* 入力内容のチェック */
    function lfCheckError($array) {

        $objErr = new SC_CheckError($array);
        $objErr->arrErr = $this->objFormParam->checkError();

        // 階層チェック
        if(!isset($objErr->arrErr['category_name'])) {
            $objQuery = new SC_Query();
            $level = $objQuery->get("dtb_category", "level", "category_id = ?", array($_POST['parent_category_id']));

            if($level >= LEVEL_MAX) {
                $objErr->arrErr['category_name'] = "※ ".LEVEL_MAX."階層以上の登録はできません。<br>";
            }
        }

        if (!isset($_POST['category_id'])) $_POST['category_id'] = "";

        //

        // 重複チェック
        if(!isset($objErr->arrErr['category_name'])) {
            $objQuery = new SC_Query();
            $where = "parent_category_id = ? AND category_name = ?";
            $arrRet = $objQuery->select("category_id, category_name", "dtb_category", $where, array($_POST['parent_category_id'], $array['category_name']));

            if (empty($arrRet)) {
                $arrRet = array(array("category_id" => "", "category_name" => ""));
            }

            // 編集中のレコード以外に同じ名称が存在する場合
            if ($arrRet[0]['category_id'] != $_POST['category_id']
                && $arrRet[0]['category_name'] == $_POST['category_name']) {
                $objErr->arrErr['category_name'] = "※ 既に同じ内容の登録が存在します。<br>";
            }
        }

        return $objErr->arrErr;
    }


    // 並びが1つ下のIDを取得する。
    function lfGetDownRankID($objQuery, $table, $pid_name, $id_name, $id) {
        // 親IDを取得する。
        $col = "$pid_name";
        $where = "$id_name = ?";
        $pid = $objQuery->get($table, $col, $where, $id);
        // すべての子を取得する。
        $col = "$id_name";
        $where = "del_flg = 0 AND $pid_name = ? ORDER BY rank DESC";
        $arrRet = $objQuery->select($col, $table, $where, array($pid));
        $max = count($arrRet);
        $down_id = "";
        for($cnt = 0; $cnt < $max; $cnt++) {
            if($arrRet[$cnt][$id_name] == $id) {
                $down_id = $arrRet[($cnt + 1)][$id_name];
                break;
            }
        }
        return $down_id;
    }

    // 並びが1つ上のIDを取得する。
    function lfGetUpRankID($objQuery, $table, $pid_name, $id_name, $id) {
        // 親IDを取得する。
        $col = "$pid_name";
        $where = "$id_name = ?";
        $pid = $objQuery->get($table, $col, $where, $id);
        // すべての子を取得する。
        $col = "$id_name";
        $where = "del_flg = 0 AND $pid_name = ? ORDER BY rank DESC";
        $arrRet = $objQuery->select($col, $table, $where, array($pid));
        $max = count($arrRet);
        $up_id = "";
        for($cnt = 0; $cnt < $max; $cnt++) {
            if($arrRet[$cnt][$id_name] == $id) {
                $up_id = $arrRet[($cnt - 1)][$id_name];
                break;
            }
        }
        return $up_id;
    }

    function lfCountChilds($objQuery, $table, $pid_name, $id_name, $id) {
        $objDb = new SC_Helper_DB_Ex();
        // 子ID一覧を取得
        $arrRet = $objDb->sfGetChildrenArray($table, $pid_name, $id_name, $id);
        return count($arrRet);
    }

    function lfUpRankChilds($objQuery, $table, $pid_name, $id_name, $id, $count) {
        $objDb = new SC_Helper_DB_Ex();
        // 子ID一覧を取得
        $arrRet = $objDb->sfGetChildrenArray($table, $pid_name, $id_name, $id);
        $line = SC_Utils_Ex::sfGetCommaList($arrRet);
        $sql = "UPDATE $table SET rank = (rank + $count) WHERE $id_name IN ($line) ";
        $sql.= "AND del_flg = 0";
        $ret = $objQuery->exec($sql);
        return $ret;
    }

    function lfDownRankChilds($objQuery, $table, $pid_name, $id_name, $id, $count) {
        $objDb = new SC_Helper_DB_Ex();
        // 子ID一覧を取得
        $arrRet = $objDb->sfGetChildrenArray($table, $pid_name, $id_name, $id);
        $line = SC_Utils_Ex::sfGetCommaList($arrRet);
        $sql = "UPDATE $table SET rank = (rank - $count) WHERE $id_name IN ($line) ";
        $sql.= "AND del_flg = 0";
        $ret = $objQuery->exec($sql);
        return $ret;
    }
}
    // 追記:親のcategory_infoを取得する
    function lfGetParentInfo($objQuery, $pid) {
        $where = "category_id = ?";
        $parent_info = $objQuery->get("dtb_category", "category_info", $where, array($pid));
        return $parent_info;
    }
?>

それ以外はカゴラボさんのコードをそのまま使ってます。
ゲスト
投稿日時: 2008/6/13 11:38
対応状況: −−−
Re: カテゴリ毎のトップコンテンツ表示
下記アドレスにアクセスしたところ、リンク切れになっていました。。どこかにアーカイブは残存していませんでしょうか。

カテゴリ毎に説明文等のコンテンツを表示する

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


 



ログイン



統計情報

総メンバー数は76,867名です
総投稿数は105,256件です

投稿数ランキング

1
seasoft
7333
2
468
3217
3
AMUAMU
2712
4
nanasess
2275
5
umebius
2085
6
yuh
1669
7
red
1556
8
h_tanaka
1195
9
tsuji
944
10
fukap
907
11
shutta
835
12
tao_s
794
13 ramrun 789
14 karin 689
15 sumida 641
16
homan
633
17 DELIGHT 572
18
patapata
502
19
flealog
485
20 tonton 437


ネットショップの壺

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

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