EC-CUBE3.016 動的Blockを静的twingに記載する時に詰まった話

動的Blockを作って、それをtwingに書いたのに反応しない…

コントローラーにスペルミスがあるのか、何度も見直すも特にミスは見つけられず

子供がカゼひいてるから、うつったのかと悩む

で、解決

twingにtwingを読み込むのに、管理画面からえいっとしない場合、↓を記載していたのだけれど

{{ include('Block/ブロックのファイル名.twig', ignore_missing = true) }}

 

動的Blockをtwingに記載するには、↓と書くらしい

 
{% if app.config.http_cache.enabled %}
	{{ render_esi(path('block_ブロックのファイル名')) }}
{% else %}
	{{ render(path('block_ブロックのファイル名')) }}
{% endif %}

 

まだまだ勉強中です

※ワンコの後ろの毒々しい柄のブツは、わんこコタツ…こたつぶどん変えたいけど時間がなくて作ってあげれてない

 

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」を削除

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 }}

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