EC-CUBE2.13.5をレスポンシブにしようとしたらクーポンプラグインでエラーが出た

タイトル長い…

うちのわんこも長い…
最近ふすまと冷え冷え大理石の間に頭をぽっこり入れて寝るのがブームらしい

 

諸事情によりEC-CUBE3ではなくEC-CUBE2.135をレスポンシブにするにあたり、テンプレートを変更してみたら、クーポンプラグインの表示がエラーをはじきまくり

仕方がないのでエラー個所をつぶしていくことに

どうやら、クーポンが表示する個所を指定するのに、プラグイン側が、「このidのこのclassのこのタグのここんとこ!」的な指定をしているため、そのタグがないよ、というエラー

 

その前に、このクーポンプラグイン、【オーナーズストア】→【プラグイン管理】→【プラグイン管理】で、インストールして「有効」にしただけでは使えない
「使い方」とかどっかに書いてあったのかもしれないけど、見ていないのエラーログ見たら、以下の3ファイルのパーミッションを「644」に変えろって

・html/管理画面ディレクトリ/contents/plg_Coupon_coupon.php
・html/管理画面ディレクトリ/contents/plg_Coupon_product_select.php
・html/管理画面ディレクトリ/contents/plg_Coupon_coupon_input.php

 

次に、プラグインの
/data/downloads/plugin/Coupon/Coupon.php の、338行目あたりを見ると、ご親切に「カスタマイズしてある場合は要注意」と書いてある(ありがとうございます)個所を修正

 

・shopping/payment.tpl
・shopping/confirm.tpl
・mypage/history.tpl

↑だけをさわる【簡単バージョン】か、

・shopping/payment.tpl
・shopping/confirm.tpl
・mypage/history.tpl
・/data/downloads/plugin/Coupon/Coupon.php
・/data/Smarty/templates/使用テンプレート/shopping/plg_Coupon_payment.tpl
・/data/Smarty/templates/使用テンプレート/shopping/plg_Coupon_confirm.tpl
・/data/Smarty/templates/使用テンプレート/mypage/plg_Coupon_history.tpl

↑を変更する【推奨バージョン】か

 

【簡単バージョン】
空タグが多くなるので微妙だけど楽

「shopping/confirm.tpl」は、
#undercolumn #undercolumn_shopping の下に .delivname の table を作って、tr を 5つ作っておいたらOK
つまり、↓こんな感じでしょうか

「値引き」の記述
<table border="0" cellspacing="0" cellpadding="0" class="delivname">
<tr style="display:none;"><td>&nbsp;</td></tr>
<tr style="display:none;"><td>&nbsp;</td></tr>
<tr style="display:none;"><td>&nbsp;</td></tr>
<tr style="display:none;"><td>&nbsp;</td></tr>
<tr style="display:none;"><td>&nbsp;</td></tr>
</table>
「送料」の記述

 

「mypage/history.tpl」は、
#mycontents_area .mycondition_area の下に .delivname の table を作って、tr を 6つ作っておいたらOK
つまり、↓こんな感じでしょうか

「手数料」の記述
<table border="0" cellspacing="0" cellpadding="0" class="delivname">
<tr style="display:none;"><td>&nbsp;</td></tr>
<tr style="display:none;"><td>&nbsp;</td></tr>
<tr style="display:none;"><td>&nbsp;</td></tr>
<tr style="display:none;"><td>&nbsp;</td></tr>
<tr style="display:none;"><td>&nbsp;</td></tr>
<tr style="display:none;"><td>&nbsp;</td></tr>
</table>
「合計」の記述

 

お支払方法・お届け時間等の設定(shopping/payment.tpl)は表示されているのでcssで調整でいけるかな

 

【推奨バージョン】
やっぱりやるからには美しいタグで

まずは「/data/downloads/plugin/Coupon/Coupon.php」
クーポン関係の挿入個所を、必要なタグは、 .com_coupon の前に挿入してね!と変更

//クーポン利用確認画面(購入確認画面)
if (strpos($filename, 'shopping/confirm.tpl') !== false) {
     //indexの指定はカスタマイズしてある場合は要注意(デフォルトのec-cubeに対応)
     $objTransform->select('.com_coupon')->insertBefore(file_get_contents($template_dir . 'default/shopping/plg_Coupon_confirm.tpl'));
}
//購入履歴画面
if (strpos($filename, 'mypage/history.tpl') !== false) {
//indexの指定はカスタマイズしてある場合は要注意(デフォルトのec-cubeに対応)
     $objTransform->select('.com_coupon')->insertBefore(file_get_contents($template_dir . 'default/mypage/plg_Coupon_history.tpl'));
}

※クーポン利用画面がcssの変更でいけそうなのでさわらない

 

「shopping/confirm.tpl」は、
「送料」の上あたりにクーポンの記述を入れたいので変更

変更前
<small>送料:</small><strong><!--{$arrForm.deliv_fee|number_format}-->円</strong><br />
↓
変更後
<small class="com_coupon">送料:</small><strong><!--{$arrForm.deliv_fee|number_format}-->円</strong><br />

 

「mypage/history.tpl」は、
「合計」の上あたりにクーポンの記述を入れたいので変更

変更前
<div><small>合計:</small><span class="price text-bold"><!--{$tpl_arrOrderData.payment_total|number_format}-->円</span></div>
↓
変更後
<div class="com_coupon"><small>合計:</small><span class="price text-bold"><!--{$tpl_arrOrderData.payment_total|number_format}-->円</span></div>

 

「/data/Smarty/templates/使用テンプレート/shopping/plg_Coupon_confirm.tpl」は、以下に差し替え

<!--{*2011.11.27 SEED_KN クーポン機能*}-->
<!--{if $arrForm.coupon_check != "" && $arrForm.coupon_check != "0" }-->
<small>クーポン利用:</small><strong>-<!--{$arrForm.coupon_discount_price|number_format}-->円<!--{*(<!--{<!--{$arrForm.coupon_discount_percent|number_format}-->}-->%)*}--></strong><br />
<!--{/if}-->
<!--{*2011.11.27 SEED_KN クーポン機能*}-->

 

「/data/Smarty/templates/使用テンプレート/mypage/plg_Coupon_history.tpl」は、以下に差し替え

<!--{*2013.03.04 SEED クーポン機能*}-->
<div><small>クーポン利用:</small><!--{assign var=key value="coupon_discount_price"}--><!--{$tpl_arrOrderData[$key]*-1|number_format|h}-->円</div>
<!--{*2013.03.04 SEED クーポン機能*}-->

 

これで妙な空タグもなくOK

暑くなってきたので…

そろそろエアコン入るかな

昨夜涼しくなってお散歩に行ったのだけど、帰ってきてからの疲れようが半端なかった!

大量に水を飲んで顔中べちょべちょにして(きれいに飲めない…)倒れこんでしまいました

 

なので、写真は別の日の、前足をちょこんとそろえて笑顔のやつ♪

WordPress The Events Calendarプラグイン!

カレンダーを表示するプラグイン The Events Calendar すばらしすぎです!

何がって、カスタマイズし放題!!

 

・デフォルト表示の色がサイトに合わなくても、cssファイルで大幅修正可能

・表示したくないものもcssで修正可能!

・そして何より、設定されているタグ類の使用方法が公開されているので、WPの外で使うことも可能!

 

トップページにがっつりカレンダーを表示するのではなくて、よくある新着情報のような形で表示させ、カレンダーで見たかったらこっち、直接記事を見たかったらこっち、のようにカスタマイズもできるし

 

↓とても参考にさせていただきました
【WordPress】ウィジェットでなくトップページにそのままイベントカレンダーを表示できるプラグイン

 

追記するなら、The Events Calendarは、
投稿タイプ = tribe_events   タクソノミー = tribe_events_cat
です。

 

【スラッグの取得】

$cateslugs = tribe_get_event_cat_slugs( $post->ID );
echo $cateslugs[0];

 

【ターム名の取得】

$terms = get_the_terms( $post->ID , 'tribe_events_cat' );
foreach ( $terms as $term ) {
	echo $term->name;
}

 

 

 

 

 

Yahooショップで1つの商品を複数カテゴリーに登録する

楽天ならカテゴリーをいくつか作って、商品ページ作ったら、↓の「表示先カテゴリ」欄の1~5に属するカテゴリーの「カテゴリー名」を入れたらいいものを…

Yahooでは、商品ページにそんな設定箇所がないので、まずは1つのカテゴリーに所属させて商品ページを作って、地道に他のカテゴリーと結び付けていく…

1. 【ページ編集】のサイドメニュー「カテゴリーページ作成」でカテゴリーAを作る
2. 1で作ったカテゴリーAをクリックした状態で、サイドメニュー「商品ページ作成」をクリック
3. 普通に商品ページAを作成
4. 【ページ編集】の「カテゴリーページ作成」でカテゴリーBを作る
5. 【商品管理】のサイドメニュー「カテゴリリスト」で、3で作った商品ページAをクリック
6. 表示された「商品一覧」の中の商品ページAの左にある「選択」の□をチェック
7. 「商品一覧」の上部メニュー「リンク」をクリック
8. これまで作成されたカテゴリーの一覧が表示されるので、2個目に所属させたいカテゴリーの左の「選択」の○にチェック
9. 「確認」をクリック→「更新」をクリック

商品ページAが10個くらいのカテゴリーに所属してたら、地道に上記1~9を繰り返す…
商品数が多かったらCSVで一気に上げた方が早い

EC-CUBE3.013 WordPressの新着情報をトップページに表示

EC-CUBE3.013の同階層にWordpressをインストールして、その新着情報をショップのトップページに表示してみようかな、と
EC-CUBE2系ではPHPタグが普通に使えたので、「require (‘wp-load.php’);」でwordpressのタグを埋め込んで、うにゃうにゃと表示させていたのだけれど…

Symfony…苦手

でも↓こういうのを見つけた
TwigPHPExtension.php

twigの中で強引にPHPの関数を頭に「php_」を入れることで使えるようにしちゃう荒技

1.「src/Eccube/Twig/Extension/EccubeExtension.php」の「public function getFunctions()」に以下を追記

new \Twig_SimpleFunction('php_*', array($this,'phpFunctions'),array('is_safe' => array('html'))),

2.続いて「class EccubeExtension extends \Twig_Extension」内に以下を追記

public function phpFunctions()
    {
        $arg_list = func_get_args();
        $function = array_shift($arg_list);
 
        if(is_callable($function)){
            return call_user_func_array($function, $arg_list);
        }

        $errMsg = 'Called to an undefined function : <b>php_' . $function . "</b> ";
        trigger_error($errMsg, E_USER_NOTICE);
        return NULL;
    }

3.サーバー内のどこでもいいので、以下のような内容の「news.php」ファイルを作成
 ※「wp-load.php」のパスを間違えないように

<?php
$webroot = $_SERVER['DOCUMENT_ROOT'];
require ($webroot.'/wp-load.php'); ?>
<style type="text/css">
#top_info {
	padding:0 10px 15px 18px;
	width:100%;
}
#top_info span {
	padding-right:15px;
}
#top_info li {
	line-height:2;
}
#top_info li a {
	text-decoration:none;
	color:#666;
	display:block;
}
#top_info li a:hover {
	color:#333;
}
</style>
                <ul id="top_info">
				<?php 
				$newslist = get_posts( array(
					'category_name' => 'information',
					'posts_per_page' => 5
				));
				foreach( $newslist as $post ):
					setup_postdata( $post );
				?>
                    <li><a href="<?php the_permalink(); ?>" target="_blank"><span><?php the_time('Y.n.d'); ?></span>
					<?php the_title(); ?></a></li>
				<?php
                    endforeach;
                    wp_reset_postdata();
                ?>
                </ul>

4.EC-CUBE内の新着情報を表示するブロック「app/template/default/Block/news.twig」を以下に書き換え

<div class="col-sm-9 news_contents">
    <div id="news_area">
        <h2 class="heading01">新着情報</h2>
        <div class="accordion">
            <div class="newslist">
			{{ php_file_get_contents('http://ドメイン名/news.php') }}
            </div>
        </div>
    </div>
</div>

いつかSymfonyを好きになれる日が来るのかな…

EC-CUBE3.013 URLの変更(ドメイン直下に)

1.本家サイトからダウンロードしたEC-CUBE3を解凍して、以下だけアップロード

	app
	html
	src
	vender
	autoload.php
	cli-config.php

2.「http://○○○/html/」にアクセスし、インストール

3.サーバーの以下をダウンロードして、変更後、アップロード

「index.php」

require __DIR__.'/../autoload.php'; を require __DIR__.'/autoload.php';

「index_dev.php」

'/../autoload.php' を '/autoload.php'
'/../app/config/eccube/config_dev.yml' を '/app/config/eccube/config_dev.yml'
'/../app/cache/profiler' を '/app/cache/profiler'

「/app/config/eccube/path.yml」

「root_urlpath:」の「/html」を削除

雪遊び

先週末の雪で庭に約20cm積もりました
そこで雪遊び
1歩進むにもジャンプなので、かなり体力使ったのではないかと思われます

ほぼほぼ埋もれています…
この日、「遊ぶ→洗う→乾かす」×3セット
この「洗う」は足が短すぎて「足だけ」というわけにはいかず、大変な作業でした

EC-CUBE3.013 お問い合わせフォームに項目を増やす

セレクトボックスと普通のテキスト欄と追加してみる

☆セレクトボックスは必須項目に
☆管理画面からセレクトボックスの内容を追加できない簡単使用

 

1.「src/Eccube/Form/Type/Front/ContactType.php」に追記

    public function buildForm(FormBuilderInterface $builder, array $options)
    {
            ->add('onumber', 'text', array(
                'label'     => 'ご注文番号',
                'required' => false,
            ))

            ->add('sentaku', 'choice', array(
        			'choices'  => array(
            			'1' => 'お問い合わせ',
            			'2' => 'ご要望'
					),
                'label'     => 'お問い合わせ種類',
                'required' => true,
            ));
    }

2.「app/template/default/Contact/index.twig」に追記

	<dl id="top_box__sentaku">
		<dt>{{ form_label(form.sentaku) }}</dt>
		<dd class="form-group">
		{{ form_widget(form.sentaku) }}
		{{ form_errors(form.sentaku) }}
		</dd>
	</dl>
                                                                
	<dl id="top_box__onumber">
		<dt>{{ form_label(form.onumber) }}</dt>
		<dd class="form-group">
		{{ form_widget(form.onumber) }}
		{{ form_errors(form.onumber) }}
		</dd>
	</dl>

3.「app/template/default/Contact/confirm.twig」に追記

	<dl id="top_box__sentaku">
		<dt>{{ form_label(form.sentaku) }}</dt>
		<dd class="form-group">
		{{ form_widget(form.sentaku) }}
		</dd>
	</dl>

	<dl id="confirm_box__onumber">
		<dt>{{ form_label(form.onumber) }}</dt>
		<dd>
		<div class="form-group">
		{{ form_widget(form.onumber) }}
		</div>
		</dd>
	</dl>

4.「app/template/default/Mail/contact_mail.twig」に追記

	お問い合わせ種類:{% if data.sentaku == 1 %}お問い合わせ{% elseif data.sentaku == 2 %}ご要望{% endif %}

	ご注文番号:{{ data.onumber }}

↓かなり参考にさせていただきました!
問い合わせフォームと確認画面に項目追加する方法