2017-12-26 31 views

答えて

2

あなたはこれらの2つのファイルを編集して、カテゴリ内で必要なオプションを表示することができます。

ファイル:

catalog\controller\product\category.php 

検索:

$data['products'][] = array(

と交換

$options = array(); foreach ($this->model_catalog_product->getProductOptions($result['product_id']) as $option) { if($option['required']){ $product_option_value_data = array(); foreach ($option['product_option_value'] as $option_value) { if (!$option_value['subtract'] || ($option_value['quantity'] > 0)) { if ((($this->config->get('config_customer_price') && $this->customer->isLogged()) || !$this->config->get('config_customer_price')) && (float)$option_value['price']) { $price = $this->currency->format($this->tax->calculate($option_value['price'], $result['tax_class_id'], $this->config->get('config_tax') ? 'P' : false), $this->session->data['currency']); } else { $price = false; } $product_option_value_data[] = array( 'product_option_value_id' => $option_value['product_option_value_id'], 'option_value_id' => $option_value['option_value_id'], 'name' => $option_value['name'], 'image' => $this->model_tool_image->resize($option_value['image'], 50, 50), 'price' => $price, 'price_prefix' => $option_value['price_prefix'] ); } } $options[] = array( 'product_option_id' => $option['product_option_id'], 'product_option_value' => $product_option_value_data, 'option_id' => $option['option_id'], 'name' => $option['name'], 'type' => $option['type'], 'value' => $option['value'], 'required' => $option['required'] ); } } $data['products'][] = array( 'options' => $options, 

ファイル:

catalog\view\theme\default\template\product\category.twig 

ループの内側のどこか、または見つける:

<div class="button-group"> 

は、その前に追加します。

{% if product.options %} 
<hr> 
<h3>{{ text_option }}</h3> 
{% for option in product.options %} 
{% if option.type == 'select' %} 
<div class="form-group{% if option.required %} required {% endif %}"> 
    <label class="control-label" for="input-option{{ option.product_option_id }}">{{ option.name }}</label> 
    <select name="option[{{ option.product_option_id }}]" id="input-option{{ option.product_option_id }}" class="form-control"> 
    <option value="">{{ text_select }}</option> 
    {% for option_value in option.product_option_value %} 
    <option value="{{ option_value.product_option_value_id }}">{{ option_value.name }} 
    {% if option_value.price %} 
    ({{ option_value.price_prefix }}{{ option_value.price }}) 
    {% endif %} </option> 
    {% endfor %} 
    </select> 
</div> 
{% endif %} 
{% if option.type == 'radio' %} 
<div class="form-group{% if option.required %} required {% endif %}"> 
    <label class="control-label">{{ option.name }}</label> 
    <div id="input-option{{ option.product_option_id }}"> {% for option_value in option.product_option_value %} 
    <div class="radio"> 
     <label> 
     <input type="radio" name="option[{{ option.product_option_id }}]" value="{{ option_value.product_option_value_id }}" /> 
     {% if option_value.image %} <img src="{{ option_value.image }}" alt="{{ option_value.name }} {% if option_value.price %} {{ option_value.price_prefix }} {{ option_value.price }} {% endif %}" class="img-thumbnail" /> {% endif %}     
     {{ option_value.name }} 
     {% if option_value.price %} 
     ({{ option_value.price_prefix }}{{ option_value.price }}) 
     {% endif %} </label> 
    </div> 
    {% endfor %} </div> 
</div> 
{% endif %} 
{% if option.type == 'checkbox' %} 
<div class="form-group{% if option.required %} required {% endif %}"> 
    <label class="control-label">{{ option.name }}</label> 
    <div id="input-option{{ option.product_option_id }}"> {% for option_value in option.product_option_value %} 
    <div class="checkbox"> 
     <label> 
     <input type="checkbox" name="option[{{ option.product_option_id }}][]" value="{{ option_value.product_option_value_id }}" /> 
     {% if option_value.image %} <img src="{{ option_value.image }}" alt="{{ option_value.name }} {% if option_value.price %} {{ option_value.price_prefix }} {{ option_value.price }} {% endif %}" class="img-thumbnail" /> {% endif %} 
     {{ option_value.name }} 
     {% if option_value.price %} 
     ({{ option_value.price_prefix }}{{ option_value.price }}) 
     {% endif %} </label> 
    </div> 
    {% endfor %} </div> 
</div> 
{% endif %} 
{% if option.type == 'text' %} 
<div class="form-group{% if option.required %} required {% endif %}"> 
    <label class="control-label" for="input-option{{ option.product_option_id }}">{{ option.name }}</label> 
    <input type="text" name="option[{{ option.product_option_id }}]" value="{{ option.value }}" placeholder="{{ option.name }}" id="input-option{{ option.product_option_id }}" class="form-control" /> 
</div> 
{% endif %} 
{% if option.type == 'textarea' %} 
<div class="form-group{% if option.required %} required {% endif %}"> 
    <label class="control-label" for="input-option{{ option.product_option_id }}">{{ option.name }}</label> 
    <textarea name="option[{{ option.product_option_id }}]" rows="5" placeholder="{{ option.name }}" id="input-option{{ option.product_option_id }}" class="form-control">{{ option.value }}</textarea> 
</div> 
{% endif %} 
{% if option.type == 'file' %} 
<div class="form-group{% if option.required %} required {% endif %}"> 
    <label class="control-label">{{ option.name }}</label> 
    <button type="button" id="button-upload{{ option.product_option_id }}" data-loading-text="{{ text_loading }}" class="btn btn-default btn-block"><i class="fa fa-upload"></i> {{ button_upload }}</button> 
    <input type="hidden" name="option[{{ option.product_option_id }}]" value="" id="input-option{{ option.product_option_id }}" /> 
</div> 
{% endif %} 
{% if option.type == 'date' %} 
<div class="form-group{% if option.required %} required {% endif %}"> 
    <label class="control-label" for="input-option{{ option.product_option_id }}">{{ option.name }}</label> 
    <div class="input-group date"> 
    <input type="text" name="option[{{ option.product_option_id }}]" value="{{ option.value }}" data-date-format="YYYY-MM-DD" id="input-option{{ option.product_option_id }}" class="form-control" /> 
    <span class="input-group-btn"> 
    <button class="btn btn-default" type="button"><i class="fa fa-calendar"></i></button> 
    </span></div> 
</div> 
{% endif %} 
{% if option.type == 'datetime' %} 
<div class="form-group{% if option.required %} required {% endif %}"> 
    <label class="control-label" for="input-option{{ option.product_option_id }}">{{ option.name }}</label> 
    <div class="input-group datetime"> 
    <input type="text" name="option[{{ option.product_option_id }}]" value="{{ option.value }}" data-date-format="YYYY-MM-DD HH:mm" id="input-option{{ option.product_option_id }}" class="form-control" /> 
    <span class="input-group-btn"> 
    <button type="button" class="btn btn-default"><i class="fa fa-calendar"></i></button> 
    </span></div> 
</div> 
{% endif %} 
{% if option.type == 'time' %} 
<div class="form-group{% if option.required %} required {% endif %}"> 
    <label class="control-label" for="input-option{{ option.product_option_id }}">{{ option.name }}</label> 
    <div class="input-group time"> 
    <input type="text" name="option[{{ option.product_option_id }}]" value="{{ option.value }}" data-date-format="HH:mm" id="input-option{{ option.product_option_id }}" class="form-control" /> 
    <span class="input-group-btn"> 
    <button type="button" class="btn btn-default"><i class="fa fa-calendar"></i></button> 
    </span></div> 
</div> 
{% endif %} 
{% endfor %} 
{% endif %} 

ocmodvqmod、およびtwigのキャッシュをクリアして確認します。

+0

私のために働いたが、オプションを変更することによって、製品のレートも更新する必要があります。 –

+0

オプションのOnChangeイベントで実装する必要があるいくつかのオプションを選択した後に製品価格を更新し、カートに追加ボタンを追加するには余分なコードが必要です。 – DigitCart

関連する問題