Snippets

Keetrax Kee Subscriptions Theme Tweak (Bootstrap 4)

Created by Fairnia last modified Mike Martel
<!-- Kee Subscriptions pricing -->
[%extra_options id:'[@SKU@]'%]
  [%PARAM *select_option%]
  [%if [@name@] eq 'Auto-delivery' or [@name@] eq 'Auto Delivery' or [@name@] eq 'Auto-Delivery'%]
  <div class="auto-delivery col my-3 px-0">
    <div class="auto-delivery-wrapper card card-body">
      <div class="row">
        <div class="col-md-4 col-sm-5 col-8">
          <h3><i class="fa fa-undo fa-flip-vertical pr-1"></i><strong> Auto Delivery</strong></h3>
          <span class="d-sm-none ad-save badge badge-success mobile-save">Save <span class="ad-save-pre">up to </span>$<span class="ad-discount"></span> every time</span>
        </div>
        <div class="col-md-5 col-4 d-sm-block d-none desktop-save">
          <span class="ad-save badge badge-success">Save <span class="ad-save-pre">up to </span>$<span class="ad-discount"></span> every time</span>
        </div>
        <div class="col-4 col-sm-3 text-right as-low-wrapper" style="display:none;">
          <span class="as-low">As low as:<br /></span>
          <span class="ad-price h1" id="sub-box-price"></span>
        </div>
      </div>
      <p class="ad-select-sect">
        <label for="aproductextra[@count@]">Frequency:</label>
          <select name="extra[@count@]" class="form-control ad-select" id="productextra[@count@]" rel="[@SKU@]">
            [@choices@]
          </select>
      </p>
      <div class="ad-about">

        <a role="button" data-toggle="collapse" href="#ad-explain" aria-expanded="false" aria-controls="ad-explain-heading" class="collapsed">
          <span class="fa-stack" style="color:#989898;">
            <i class="fa fa-circle fa-stack-2x"></i>
            <i class="fa fa-info fa-stack-1x fa-inverse"></i>
          </span>
          <span style="text-decoration: underline; color:#989898;">How auto delivery works.</span>
        </a>

        <div id="ad-explain" class="panel-collapse collapse p-3" role="tabpanel" aria-labelledby="ad-explain-heading">
          [%content_zone id:'Keesubscriptions-How'%]
           [%param if_empty%]
                <p>Select the frequency and your items will be delivered to you as often as you prefer.</p>
                <p>Auto Delivery isn't a contract, you are free to cancel anytime.</p>
           [%/param%]
          [%end content_zone%]
        </div>

      </div>
    </div>
  </div>
  <span id="keesubscriptions-data"
    data-rrp="[%trim%][%if [@retail@]%][@retail@][%else%][@store_price@][%/if%][%/trim%]"
    data-storeprice="[%trim%][@store_price@][%/trim%]"
    data-productprice="[%trim%][%if [@inpromo@]%][@promo_price@][%else%][@store_price@][%/if%][%/trim%]"
    />
  [%/if%]
  [%END PARAM%]
  [%PARAM *choices%]
    <option type="text" class="form-control" value="[@option_id@]" data-price="[@price@]">
      [%nohtml%][@text@][%end nohtml%]
    </option>
  [%END PARAM%]
[%END extra_options%]

<script type="text/javascript" language="javascript">
(function(){

  var settings = {
    autoSelect: false
  };

  // Don't initialize twice
  if (typeof window.keesubscriptions_reload !== 'undefined'){
    return;
  }

  // Don't initialise if we're not needed
  if ( !document.querySelector('#keesubscriptions-data') ) {
    return;
  }

  var selectedIndex = false;

  function _on_change_option() {
    var adSelect = document.querySelector('.ad-select');

    // Store the selectedIndex
    selectedIndex = adSelect.selectedIndex;
    var dataEl = document.getElementById('keesubscriptions-data');

    var adDiscount = document.querySelectorAll(".ad-discount");

    // Set the savings to the currently selected item
    for (i = 0; i < adSelect.options.length; i++) {
      if(i > 0 && i === Number(adSelect.options[adSelect.selectedIndex].value)){
        adDiscount.forEach((el)=>{
          el.innerHTML = adSelect.options[adSelect.selectedIndex].getAttribute('data-price').replace('-', '');
        });
      }
    }
  }

  function _init_template() {
    var dataEl = document.getElementById('keesubscriptions-data');

    if (!dataEl || dataEl.getAttribute('data-init')) {
      return;
    }

    dataEl.setAttribute('data-init', true);

    //In Neto product dashboard - Default option must be "don't select auto delivery"(wording can be different) and autoSavings must have negative numbers
    var rrp          = parseFloat(dataEl.getAttribute('data-rrp'));
    var storePrice   = parseFloat(dataEl.getAttribute('data-storeprice'));
    var currentPrice = parseFloat(dataEl.getAttribute('data-productprice'));
    var adSelect     = document.querySelector('.ad-select');

    var choices = Array.prototype.map.call(adSelect.options, (function (node) {
        return parseFloat(node.getAttribute('data-price') * -1)||0;
    }));

    var maxDiscount = Math.max.apply(Math, choices);
    var adPrice     = (currentPrice - maxDiscount).toFixed(2);
    var rrpSave     = Math.round(((1 - storePrice/rrp)) * 100);

    // Set the prices in the box
    var adPriceEl = document.querySelector(".ad-price");
    if ( adPriceEl ) {
      adPriceEl.innerHTML = '$'+adPrice;
    }

    // Set the discounts in the select dropdown
    var foundMax = false;

    for (i = 0; i < choices.length; i++) {
      if(i > 0 && choices[i] > 0){
        var discountPercent = Number((choices[i]/currentPrice * 100).toFixed(2));
        adSelect.options[i].innerHTML += ' (save ' + discountPercent + '%)';
      }

      if (selectedIndex !== false && selectedIndex == i) {
        adSelect.options[i].selected = true;
      }

      // Select the option with the largest discount by default
      if(settings.autoSelect && maxDiscount> 0 && choices[i] === maxDiscount && !foundMax){

        if ( selectedIndex === false ) { // Only if we don't have a cached selection
          adSelect.options[i].selected = true;
        }

        foundMax = true;
      }
    }

    // Hide savings if there are no savings
    var adSave = document.querySelectorAll(".ad-save");
    if(maxDiscount === 0){
      for (i = 0; i < adSave.length; i++) {
        adSave[i].style.display = 'none';
      }

      // Select the first option if we have no cached value
      if ( settings.autoSelect && selectedIndex === false ) {
        adSelect.options[1].selected = true;
      }

    }

    // Show the largest discount where applicable
    var adDiscount = document.querySelectorAll(".ad-discount");
    for (i = 0; i < adDiscount.length; i++) {
      adDiscount[i].innerHTML = maxDiscount;
    }

    // Updates the price in the subscription box
    document.addEventListener("DOMContentLoaded", function(event) {
      $('#productextra0').on('change', function(){
        var dataEl = document.getElementById('keesubscriptions-data');
        var adSelect = document.querySelector('.ad-select');
        var price = parseFloat(dataEl.getAttribute('data-productprice'));

        if($('#productextra0').val() != 0) {
          var discount = parseFloat(adSelect.options[adSelect.selectedIndex].getAttribute('data-price').replace('-', ''));
          var dPrice = price - discount;
          // Set the prices in the box
          var adPriceEl = document.querySelector(".ad-price");
          adPriceEl.innerHTML = '$'+dPrice.toFixed(2);
          $('.as-low-wrapper').show(500);
          $('.ad-save-pre').hide();
        } else {
          $('.as-low-wrapper').hide();
          $('.ad-save-pre').show();
          adDiscount.forEach((el) => {
              el.innerHTML = maxDiscount;
          });
        }
      });
    });

    // Init listeners

    // Update the discount with the currently selected option
    adSelect.addEventListener('change', _on_change_option.bind(this));

  }

  window.keesubscriptions_reload = _init_template;

  _init_template();
  
  // Reload whenever buying options is reloaded
  (new MutationObserver(_init_template)).observe(document.getElementById('_jstl__buying_options_r'), { attributes: false, childList: true, subtree: true });

  document.addEventListener('click', function (event) {

    if (!event.target.matches('.addtocart')) {
      return;
    }

    var autodeliveryMsg = document.querySelector('.auto-delivery-msg');

    if (autodeliveryMsg === null ) {

      autodeliveryMsg = document.createElement('div');
      autodeliveryMsg.classList.add('npopup-body', 'auto-delivery-msg', 'p-3');

      var npopupDiv = document.querySelector('.npopup');
      npopupDiv.appendChild(autodeliveryMsg);
    }

    var adSelect = document.querySelector('.ad-select');

    if(adSelect.options[adSelect.selectedIndex].value !== "0" && autodeliveryMsg.innerHTML === ''){
      autodeliveryMsg.innerHTML = 'Please note: you have selected an auto delivery subscription for this item, to review please <a href="/_mycart">click here</a>.';
    }
    if(adSelect.options[adSelect.selectedIndex].value === "0"){
      autodeliveryMsg.innerHTML = '';
    }

  }, false);
})();
</script>
<!-- END of Kee Subscriptions -->

Comments (3)

  1. aputsiaqgeisler

    Prepare for success with our Salesforce-AI-Associate Exam dumps! Our comprehensive study materials are meticulously crafted to help you master every aspect of the exam. Whether you're aiming to validate your knowledge of Salesforce AI or enhance your career prospects, our dumps provide the perfect preparation solution. With a focus on real-world scenarios and industry-relevant content, you'll gain the confidence to ace the exam on your first attempt. Each question is expertly designed to test your understanding of Salesforce AI concepts, ensuring you're fully equipped to excel in your role. Don't leave your success to chance – invest in our Salesforce AI Associate Exam dumps today and unlock your full potential in the world of artificial intelligence and Salesforce technology.

  2. Linda Melson

    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    metin2 pvp serverler
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna
    okey oyna

    Damar Romeyelle Hamlin, 24 Mart 1998 doğumlu, Amerikan futbolunda Buffalo Bills takımının güvenlik oyuncusudur. Üniversite kariyerini Pittsburgh Üniversitesi’nde oynayarak tamamladı ve 2021 NFL Draftı’nın altıncı turunda Bills tarafından seçildi. İşte Hamlin hakkında daha fazla bilgi:

    Hamlin, 2023 yılında NFLPA Alan Page Topluluk ÖdülüNFL Yılın Geri Dönen Oyuncusu Ödülü ve George Halas Ödülü gibi önemli ödüller kazandı. Ayrıca 2020’de All-ACC İkinci Takımı’na seçildi.

    Jeremy Lee Renner, 7 Ocak 1971 doğumlu, Amerikalı bir aktördür. Kariyerine Dahmer (2002) ve Neo Ned (2005) gibi bağımsız filmlerde rol alarak başladı. Daha sonra S.W.A.T. (2003) ve 28 Weeks Later (2007) gibi büyük yapımlarda yardımcı rollerde yer aldı. Renner, The Hurt Locker (2009) filmindeki asker performansıyla En İyi Erkek Oyuncu dalında Akademi Ödülü’ne aday gösterildi ve The Town (2010) filminde hırçın bir soyguncuyu canlandırarak En İyi Yardımcı Erkek Oyuncu dalında bir kez daha aday gösterildi.

    Ayrıca Renner, Marvel Sinematik Evreni’nde Clint Barton / Hawkeye karakterini canlandırdı. Bu rolü, The Avengers (2012) filminde ve Disney+ mini dizisi Hawkeye (2021)'da üstlendi. Ayrıca Mission: Impossible – Ghost Protocol (2011)The Bourne Legacy (2012)Hansel & Gretel: Witch Hunters (2013) ve Mission: Impossible – Rogue Nation (2015) gibi aksiyon filmlerinde ve American Hustle (2013)Arrival (2016) ve Wind River (2017) gibi dramalarda da yer aldı.

    Renner, 2021’den bu yana Paramount+ suç gerilimi dizisi Mayor of Kingstown’da başrol oynuyor. Modesto, California’da doğan Renner, İrlandalı ve Alman kökenlidir. Lise eğitimini Fred C. Beyer High School’da tamamladıktan sonra Modesto Junior College’da bilgisayar bilimi ve kriminoloji okudu. Ancak bir drama dersi alarak oyunculuğa yönelmeye karar verdi.

    Jeremy Renner, hem bağımsız yapımlarda hem de büyük stüdyo filmlerindeki başarılı kariyeriyle tanınan bir aktördür.

    Travis Michael Kelce, 5 Ekim 1989 doğumlu, Amerikan Ulusal Futbol Ligi (NFL) takımlarından Kansas City Chiefs’te oynayan bir Amerikan futbolu tight end’idir. 2013 NFL Draftı’nın üçüncü turunda Chiefs tarafından seçildi ve daha sonra takımıyla Super Bowl LIVLVII ve LVIII’i kazandı.

    Kelce, Cincinnati Bearcats üniversitesinde kolej futbolu oynadı. Kariyeri boyunca dokuz kez Pro Bowl seçildi ve dört kez birinci takım ve üç kez ikinci takım All-Pro seçildi. Aynı zamanda NFL tarihinde bir tight end olarak en fazla ve ardışık olarak yedi sezon boyunca 1.000 alım yapan oyuncu unvanını elinde bulunduruyor. 2020’de sadece 15 maçta oynamasına rağmen tek sezon içinde bir tight end olarak en fazla alım yapan oyuncu rekorunu kırdı ve 1.416 alım yaptı.

    2022 sezonunda Kelce, NFL tarihinde 10.000 alım yapan beşinci tight end oldu ve bu kilometre taşını NFL tarihinde en hızlı şekilde geçen tight end olarak kaydetti. Ayrıca NFL 2010’ların On Yıl Takımı’na seçildi. Dış saha etkinliklerinin ötesinde, Kelce, gerçeklik ve senaryolu televizyon programlarında ve reklamlarda da yer aldı. Ayrıca kardeşi Jason ile birlikte popüler kültürden futbola kadar birçok konuyu ele alan “New Heights” adlı bir podcast sunuyor.

    Travis Kelce, muhteşem atletizmi ve bölge kapsamını okuma yeteneği ile tanınan bir tight end olarak NFL tarihindeki en büyük oyunculardan biri olarak kabul ediliyor.

    Tucker Swanson McNear Carlson, 16 Mayıs 1969 doğumlu, Amerikalı bir muhafazakâr siyasi yorumcu ve yazardır. 2016’dan 2023’e kadar Fox News’de gecenin siyasi tartışma programı Tucker Carlson Tonight’ı sunmuştu. Fox News ile olan sözleşmesi sona erdikten sonra Tucker on X adlı bir programı sunmaktadır.

    Carlson, eski ABD Başkanı Donald Trump’ın bir savunucusu olarak bilinir ve “muhtemelen Trumpizmin en tanınmış taraftarı” olarak tanımlanmıştır. Ayrıca “sağ medyanın en etkili sesi” olarak kabul edilir. Medya kariyerine 1990’larda başlayan CarlsonThe Weekly Standard ve diğer yayınlar için yazdı. 2000-2005 yılları arasında CNN yorumcusu ve 2001-2005 yılları arasında ağın prime-time haber tartışma programı Crossfire’ın sunucusu olarak görev yaptı. 2005-2008 yılları arasında MSNBC’de gecenin programı Tucker’ı sundu. 2009’da Fox News için politik analist oldu ve kendi programını başlattı.

    Carlson, sağcı haber ve görüş web sitesi The Daily Caller’ın kurucu ortağı ve ilk baş editörü olarak da bilinir. Üç kitap yazdı: Politicians, Partisans, and Parasites (2003)Ship of Fools (2018) ve The Long Slide (2021). Beyaz şikayet politikalarının önde gelen seslerinden biri olarak tanınan Carlson, aşırı sağ fikirleri genel politika ve söyleme taşıma konusunda bilinir. Demografik değişim, COVID-19, 6 Ocak Amerika Birleşik Devletleri Kongre Baskını ve Ukrayna biyosilahları gibi konularda komplo teorilerini destekledi ve bu konularda yanıltıcı ifadelerde bulundu.

HTTPS SSH

You can clone a snippet to your computer for local editing. Learn more.