(function (w, d) { var businessKey = "nvu1k1ma"; var locationKey = ""; var tenantKey = ""; var tag = ""; var accessToken = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJlbnRpdHlJZCI6Im52dTFrMW1hIiwiZXhwIjoxNzE0MjIzODIxLCJpc3MiOiJUcnVzdGlzdCIsImF1ZCI6IldpZGdldHMifQ.9EKNQdOSAm3VgfyTeIhKzg-EFBXXZ0W9h8f4JrPGVXA"; var templates = { main: '
', noborder: '
', }; var responsiveTemplate = '
'; var footer = '
Trustist
'; function start(f) { /in/.test(document.readyState) ? setTimeout(start, 5, f) : f(); } // add tags tsAddCssTag("https://wassets.trustist.com/assets/css/cleanslate.css"); tsAddCssTag("https://wassets.trustist.com/assets/css/reviewslider.css"); start(function () { // iterate over all widgets on the page and render var divs = d.querySelectorAll("[ts-reviewSliderWidget],div.ts-reviewSliderWidget"); if (divs.length === 0) { return; } for (var i = 0; i < divs.length; i++) { tsDisplayWidget(divs[i], tenantKey, businessKey, locationKey, tag); } }); function tsDisplayWidget(target, tenantKey, businessKey, locationKey, tag) { // get options before cleanslate var options = tsReadAttributes(target); var template = templates[options.templateName]; // see if the widget requested a different location var lkey = options.locationKey || locationKey; var bkey = options.businessKey || businessKey; var tkey = options.tenantKey || tenantKey; var tagkey = options.tag || tag; // introduce js/css for responsive version if (options.responsive === "true") { template = responsiveTemplate; tsAddCssTag("https://wassets.trustist.com/assets/css/responsiveslides.css"); tsAddScriptTag("https://wassets.trustist.com/assets/js/lib/responsiveslides.min.js"); } // set the target's identifiers for later drawing target.setAttribute("ts-location", lkey); target.setAttribute("ts-business", bkey); target.setAttribute("ts-tenant", tkey); target.setAttribute("ts-tag", tagkey); // put the container on the page target.innerHTML = template .replace("{{font-family}}", options.fontFamily) .replace("{{color}}", options.color) .replace(new RegExp("{{link-color}}", "g"), options.linkColor) .replace("{{border-width}}", options.borderWidth) .replace(new RegExp("{{shadow}}", "g"), options.shadow) .replace("{{shadow-blur}}", options.shadowBlur) .replace("{{slider-interval}}", options.sliderInterval * 4); // multiplied by the number of reviews to be displayed for css version // draw widget var xhr2 = new XMLHttpRequest(); var url = "https://widget.trustist.com/reviewlistdata?v=1&accessToken=" + accessToken + "&pageSize=" + options.pageSize + "&businessKey=" + bkey; if (typeof tkey !== "undefined" && tkey !== "") url += "&tenantKey=" + tkey; if (typeof bkey !== "undefined" && bkey !== "") url += "&businessKey=" + bkey; if (typeof lkey !== "undefined" && lkey !== "") url += "&locationKey=" + lkey; if (typeof tagkey !== "undefined" && tagkey !== "") url += "&tag=" + tagkey; if (options.ratingsAbove > 0) url += "&ratingFrom=" + options.ratingsAbove; if (options.exclude > '') url += "&exclude=" + options.exclude; xhr2.open("GET", url); xhr2.onload = function () { if (xhr2.status === 200 && xhr2.responseText !== "") { var reviews = JSON.parse(xhr2.responseText); // load and draw reviews tsDrawWidget(target, reviews, tenantKey, businessKey, locationKey, tagkey, options); } }; xhr2.send(); } function tsDrawWidget(target, reviews, tenantKey, businessKey, locationKey, tagKey, options) { var reviewContent = ""; reviews.forEach(function (review) { reviewContent += tsRenderReview(review, options); }); target.innerHTML = target.innerHTML .replace("", reviewContent); if (options.suppressFooter !== "true") { target.innerHTML = target.innerHTML .replace("", footer); } if (options.responsive === "true") { tsStartResponsiveSlideshow(options.sliderInterval); } } function tsStartResponsiveSlideshow(interval) { // wait until function becomes available then execute if (!jQuery(".ts-responsive-slides").responsiveSlides) { window.setTimeout(tsStartResponsiveSlideshow, 100, interval); } else { jQuery(".ts-responsive-slides").responsiveSlides({ pause: true, timeout: interval * 1000, nav: true, namespace: "centered-btns", }); } } function tsRenderReview(review, options) { var months = ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"]; var d = new Date(review.datePublished); var curr_date = d.getDate(); var curr_month = d.getMonth(); //Months are zero based var curr_year = d.getFullYear(); var dateString = curr_date + " " + months[curr_month] + " " + curr_year; var reply = ""; if (review.reply && review.reply !== "") { var replyDate = new Date(review.replyDate); var replyDateString = replyDate.getDate() + " " + months[replyDate.getMonth()] + " " + replyDate.getFullYear(); reply = "

Reply left " + replyDateString + ":  " + review.reply; } var reviewText = review.reviewBody || ""; var reviewId = review.datePublished.replace(new RegExp(":", "g"), "-"); var truncateLength = Number(options.truncateLength); if (isNaN(truncateLength) === false && truncateLength > 0 && reviewText.length > truncateLength) { reviewText = reviewText.substr(0, truncateLength) + '... read more' + '' + reviewText.substr(truncateLength, reviewText.length - truncateLength) + ''; } return '
  • ' + '

    ' + '" + '

    ' + '
    ' + reviewText + reply + "
  • "; } function tsGetSliderTextStyle(options) { if (options.lineClamp !== "") { return "-webkit-line-clamp: " + options.lineClamp + " !important;"; } return ""; } function tsGetContainerStyle(options) { if (options.templateName === "left") { return "ts-slider-container"; } return "ts-slider-container ts-slider-centre"; } function tsGetElementStyle(options) { if (options.templateName === "left") { return "ts-reviewSliderContentElementLeft"; } return ""; } function tsReadAttributes(target) { return { templateName: target.getAttribute("ts-reviewSliderWidget") || "main", locationKey: target.getAttribute("ts-location"), businessKey: target.getAttribute("ts-business"), fontFamily: target.getAttribute("ts-font-family") || "Lato, Helvetica, sans-serif", color: target.getAttribute("ts-color") || "#5a6a74", linkColor: target.getAttribute("ts-link-color") || "#111b47", pageSize: target.getAttribute("ts-page-size") || 5, borderWidth: target.getAttribute("ts-border-width") || 1, shadow: target.getAttribute("ts-shadow") || 2, shadowBlur: target.getAttribute("ts-shadow-blur") || 14, sliderInterval: target.getAttribute("ts-slider-interval") || 10, responsive: target.getAttribute("ts-responsive") || "false", linkTarget: target.getAttribute("ts-link-target") || "_self", truncateLength: target.getAttribute("ts-truncate-length") || "0", ratingsAbove: parseInt(target.getAttribute("ts-ratings-above")) || 0, suppressFooter: target.getAttribute("ts-suppress-footer") || "false", lineClamp: target.getAttribute("ts-line-clamp") || "", exclude: target.getAttribute("ts-exclude") || "", }; } function tsAddCssTag(url) { var includedAlready = tsCheckIfIncluded(url); var head = d.getElementsByTagName("head")[0]; if (!includedAlready) { var tag = d.createElement("link"); tag.rel = "stylesheet"; tag.type = "text/css"; tag.href = url; head.appendChild(tag); } } function tsAddScriptTag(url) { var includedAlready = tsCheckIfIncluded(url); var head = d.getElementsByTagName("head")[0]; if (!includedAlready) { var tag = d.createElement("script"); tag.src = url; head.appendChild(tag); } } function tsCheckIfIncluded(file) { var links = d.getElementsByTagName("link"); for (var i = 0; i < links.length; i++) { if (links[i].href.substr(-file.length) === file) return true; } var scripts = d.getElementsByTagName("script"); for (var j = 0; j < scripts.length; j++) { if (scripts[j].src.substr(-file.length) === file) return true; } return false; } })(window, document);