0 Пользователей и 1 Гость просматривают эту тему.
  • 15 Ответов
  • 377 Просмотров
*

apofisgold

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Здравствуйте.

Как выбранному пользователем атрибуту (тип radio) в карточке товара присвоит значение data-bme

Заранее, спасибо.
*

kit2m2

  • Завсегдатай
  • 1708
  • 147 / 1
Не меняя ядро компонента, только плагином, который нужно писать...

Насколько я помню - папка tables, файл product.php
*

dmitry_stas

  • Легенда
  • 12842
  • 1204 / 8
я вообще не понял что нужно
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

apofisgold

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Не меняя ядро компонента, только плагином, который нужно писать...

Насколько я помню - папка tables, файл product.php

Здесь я смотрел изначально, в коде:

                    $radioseparator = '';
                    if ($jshopConfig->radio_attr_value_vertical) $radioseparator = "<br/>";
                    foreach($options as $k2=>$v2){
                        $options[$k2]->value_name = "<span class='radio_attr_label'>".$v2->value_name."</span>";
                    }

Но это не то. Если здесь править то (data-bme) присваивается всем атрибутам. А надо присвоение только выбранным атрибутам!

Думал что может здесь надо править, но у меня ничего не получилось
components\com_jshopping\js\functions.js

function reloadAttrValue(){
for(var id in attr_value){
if (jQuery("input[name=jshop_attr_id\\["+id+"\\]]").attr("type")=="radio"){
attr_value[id] = jQuery("input[name=jshop_attr_id\\["+id+"\\]]:checked").val();
}else{
attr_value[id] = jQuery("#jshop_attr_id"+id).val();
}
}
}

Я в JS не совсем, а точнее "0"

Может что подскажите.

Спасибо.
*

apofisgold

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
я вообще не понял что нужно

Что нужно!

Привожу пример...

Не выбран ни один атрибут

<span class="radio_attr_label tooltip-src">XXL</span>
<span class="radio_attr_label tooltip-src">XXXL</span>
<span class="radio_attr_label tooltip-src">XXXXL</span>



Выбран к примеру атрибут XXXL

<span class="radio_attr_label tooltip-src">XXL</span>
<span class="radio_attr_label tooltip-src" data-bme="">XXXL</span>
<span class="radio_attr_label tooltip-src">XXXXL</span>
*

dmitry_stas

  • Легенда
  • 12842
  • 1204 / 8
Код
jQuery(function($){
    $('body').on('click', '.radio_attr_label', function(){
        $(this).data('bme', '');
    });
});
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

apofisgold

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Извиняюсь за не компетентность, но если вставляю в

components\com_jshopping\js\functions.js

jQuery(function($){
    $('body').on('click', '.radio_attr_label', function(){
        $(this).data('bme', '');
    });
});

или в  /templates/Ваш-шаблон/html/com_jshopping/product/product_default.php

<script>
jQuery(function($){
    $('body').on('click', '.radio_attr_label', function(){
        $(this).data('bme', '');
    });
});
</script>

Результата ни какого, НЕ срабатывает.

Может я не так что-то делаю?

Направте пожалуйста.

Спасибо.
*

dmitry_stas

  • Легенда
  • 12842
  • 1204 / 8
сайт покажите
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

dmitry_stas

  • Легенда
  • 12842
  • 1204 / 8
Код
jQuery(function($){
    $('body').on('click', '.input_type_radio label', function(){
        $(this).find('.radio_attr_label').attr('data-bme', '');
    });
});
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

apofisgold

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Большое спасибо dmitry_stas.

 Все работает отлично, но есть один нюанс, когда выбираеш один атрибут (XXL) присваивается 'data-bme' а потом другой (XXXL) то другому тоже нормально присваиваеться 'data-bme' но и у первого выбранного атрибута (XXL) присвоинный 'data-bme' остается.

Как сделать чтобы при выборе другого атрибута (XXXL) с первого выбранного атрибута (XXL) присвоинный 'data-bme' удалялся.

И еще раз большое спасибо за помощь!
« Последнее редактирование: 16.01.2019, 03:31:34 от apofisgold »
*

apofisgold

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Как сделать чтобы при выборе другого атрибута (XXXL) с первого выбранного атрибута (XXL) присвоинный 'data-bme' удалялся.
Есть возможность такой реализации?
 Повторюсь, что я в JS полный "0".
 Буду рад любой помощи...


*

apofisgold

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Как добавить при (checked="checked") к класу radio_attr_label  значени data-bme=""?


Структура radio атрибутов такая.

Код
<span id="block_attr_sel_5">

<span class="input_type_radio">
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id561" value="61" onclick="setAttrValue('5', this.value);">
<label for="jshop_attr_id561">
<span class="radio_attr_label tooltip-src">
<img src="1.jpg" alt="">
Светло-серый
</span>
</label>
</span>

<span class="input_type_radio">
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id562" value="62" onclick="setAttrValue('5', this.value);">
<label for="jshop_attr_id562">
<span class="radio_attr_label tooltip-src">
<img src="1.jpg" alt="">
Светло-серый
</span>
</label>
</span>

<span class="input_type_radio">
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id563" value="63" onclick="setAttrValue('5', this.value);">
<label for="jshop_attr_id563">
<span class="radio_attr_label tooltip-src">
<img src="1.jpg" alt="">
Светло-серый
</span>
</label>
</span>

</span>

Это выбранный атрибут (checked="checked")
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id562" value="62" checked="checked" onclick="setAttrValue('5', this.value);">

Это НЕ выбранный атрибут (БЕЗ checked="checked")
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id562" value="627а" onclick="setAttrValue('5', this.value);">

-------

<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id561" value="61" onclick="setAttrValue('5', this.value);">
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id562" value="62" checked="checked" onclick="setAttrValue('5', this.value);">
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id563" value="63" onclick="setAttrValue('5', this.value);">

-------

Как сделать чтобы активному атрибуту со значением (checked="checked") к класу <span class="radio_attr_label tooltip-src"> добавлялось значение ( 'data-bme' )
Чтото на подобие
-------

<span id="block_attr_sel_5">

<span class="input_type_radio">
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id561" value="61" onclick="setAttrValue('5', this.value);">
<label for="jshop_attr_id561">
<span class="radio_attr_label tooltip-src">
<img src="1.jpg" alt="">
Светло-серый
</span>
</label>
</span>

<span class="input_type_radio">
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id562" value="62" checked="checked" onclick="setAttrValue('5', this.value);">
<label for="jshop_attr_id562">
<span class="radio_attr_label tooltip-src" data-bme="">
<img src="1.jpg" alt="">
Светло-серый
</span>
</label>
</span>

<span class="input_type_radio">
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id563" value="63" onclick="setAttrValue('5', this.value);">
<label for="jshop_attr_id563">
<span class="radio_attr_label tooltip-src">
<img src="1.jpg" alt="">
Светло-серый
</span>
</label>
</span>

</span>



Решение изложенное решение Не подходит, так-как через onclick срабатывает через раз...
*

apofisgold

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Если я не ошибаюсь за (checked="checked") отвечает js по пути:

components\com_jshopping\js\functions.js

function reloadAttrValue(){
for(var id in attr_value){
if (jQuery("input[name=jshop_attr_id\\["+id+"\\]]").attr("type")=="radio"){
attr_value[id] = jQuery("input[name=jshop_attr_id\\["+id+"\\]]:checked").val();
}else{
attr_value[id] = jQuery("#jshop_attr_id"+id).val();
}
}
}
*

apofisgold

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Здесь есть кто?
*

nevigen

  • Moderator
  • 9799
  • 833 / 23
  • http://n*****n.com
всегда кто-то есть.
Профессиональные / Бесплатные решения для JoomShopping
Не лечи бесплатно, ибо тот, кто лечится бесплатно, рано или поздно перестает ценить свое здоровье,
а тот, кто лечит бесплатно, рано или поздно перестает ценить результаты своего труда/ (с) Гиппократ?
Не ищите ответов, ищите решение !
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Сортировка заказов по выбранному критерию (по умолчанию)

Автор Accentor

Ответов: 6
Просмотров: 843
Последний ответ 31.07.2018, 06:32:19
от semak85
Неправильное значение итоговой суммы в корзине

Автор Playmaker8

Ответов: 8
Просмотров: 1274
Последний ответ 23.05.2018, 23:00:34
от warlife
Получить значение кастомного поля JoomShopping в файле шаблона

Автор Ragnarok

Ответов: 2
Просмотров: 348
Последний ответ 07.05.2018, 18:57:52
от Ragnarok
Дефолтное значение для поля "Описание"

Автор viteg

Ответов: 13
Просмотров: 897
Последний ответ 31.05.2016, 13:29:05
от SmokerMan
Минимальное значение для покупки

Автор Prosever

Ответов: 1
Просмотров: 452
Последний ответ 16.10.2015, 11:53:56
от Prosever