$(document).ready(function(){ var $nonModalTabs = $('div.tabs:not(.list-search-tabs)'); haas.tabs.tabSetup($nonModalTabs); }); (function () { 'use strict'; var haas = window.haas || {}; haas.tabs = { tabSetup: function ($tabs) { $tabs.each(function(){ var $thisTab = $(this); var $tabGroup = $thisTab.find('.tabgroup'); var $tabHeader = $thisTab.find('ul.tabs'); var $tabLinks = $tabHeader.find('li a'); var $firstTabLink = $thisTab.find('ul.tabs li:first-of-type a'); var $tabContainers = $thisTab.find('div.tab'); var $firstTabContainer = $tabGroup.find('div.tab:first-of-type'); console.log('TAB LINKS!', $tabLinks); var submenuurl = window.location.pathname.split('/'); // breaks url into parts between / var urlslice = window.location.hash.substr(1); // delivers everything after # var tabreference; if (urlslice.indexOf(".") >= 0) { tabreference = window.location.hash.substr(1, (urlslice.indexOf('.'))); } else if (urlslice.indexOf("0") >= 0) { tabreference = window.location.hash.substr(1, (urlslice.indexOf('0'))); } else { tabreference = window.location.hash.substr(1); } $tabLinks.each(function(index, $tab){ $($tab).css('background-color', $($tab).attr('data-bgcolor')); $($tab).css('color', $($tab).attr('data-color')); }); // hide all tabcontainers, initially $tabContainers.hide(); // if there's a tab reference in the url, select that tab var tabcheck = tabreference.substr(0, 3); if (tabcheck === "tab") { var $this = $('ul.tabs a').filter('[href*="' + tabreference + '"]'), target = $this.attr('href'); $this.addClass('active'); $(target).addClass('activetab').show(); } else { // otherwise, just select the first tab $firstTabLink.addClass('active'); $firstTabContainer.addClass('activetab').show(); } //counts tabs and adds class to create css centering controls var tabnum = $tabLinks.length; if (tabnum === 1) { $tabHeader.addClass('one'); $thisTab.find('.tabs .button').addClass('one'); } if (tabnum === 2) { $tabHeader.addClass('two'); $thisTab.find('.tabs .button').addClass('two'); } if (tabnum === 3) { $tabHeader.addClass('three'); $thisTab.find('.tabs .button').addClass('three'); } if (tabnum === 4) { $tabHeader.addClass('four'); $thisTab.find('.tabs .button').addClass('four'); } if (tabnum === 5) { $tabHeader.addClass('five'); $thisTab.find('.tabs .button').addClass('five'); } $tabLinks.click(function (e) { e.preventDefault(); var $thisLink = $(this); var target = $thisLink.attr('href').replace('#',''); $tabLinks.removeClass('active'); $tabContainers.removeClass('activetab').hide(); $thisLink.addClass('active'); $tabContainers.each(function(){ // targeted this way so it can be used with tabs inside modals var $this = $(this); if($this.attr('id') === target){ $this.addClass('activetab').show(); } }); var pageurl = window.location.pathname; var linkref = $thisLink.attr('href'); if (linkref.indexOf(pageurl) > -1) { location.reload(); } }); }); } } })(); $(function() { const initGrids = () => { $('.grid .row').each(function(ndx, row) { var maxHeight = 0; $(row).children().each(function(ndx, val) { // find max height for all section headers in grid var $sectionHeader = $(val).find('.sectionHeader h2'); var currentHeight = $sectionHeader.height(); if (currentHeight) { maxHeight = currentHeight > maxHeight ? currentHeight : maxHeight; } }); // set margins for section headers so the height is equal $(row).children().each(function(ndx, val) { var $sectionHeaderParent = $($(val).find('.sectionHeader')[0]); var $sectionHeaderChild = $($(val).find('.sectionHeader')[1]); var extraMargin = maxHeight - $(val).find('.sectionHeader h2').height(); $sectionHeaderParent.addClass('grid-sh-parent-edit'); $sectionHeaderChild.addClass('grid-sh-child-edit'); $(val).find('.sectionHeader h2').css('margin-top', extraMargin); }); }); // set non-responsive grid lengths Array.from(document.querySelectorAll('.grid')).forEach(gridComponent => { let isResponsive = gridComponent.querySelector('.gridpad').dataset.nresponsive; if (isResponsive && isResponsive === 'true') { let columns = Array.from(gridComponent.querySelectorAll('.row > div')); columns.forEach(column => { // if 5 equal columns, class name is just "col" if (column.className === 'col-md-5') { column.style.width = '20%'; } else { // for other split types, take the number from the column class and adjust width accordingly let columnSplit = column.className.slice(column.className.lastIndexOf('-') + 1); column.style.width = ((100 / 12) * columnSplit) + '%'; } }); } }); Array.from(document.querySelectorAll('.grid')).forEach(gridComponent => { let gridLink = gridComponent.querySelector('.gridpad').dataset.gridLink; if (gridLink && gridLink.length) { gridLink = gridLink.includes('.html') ? gridLink : gridLink+'.html'; gridComponent.style.cursor = 'pointer'; gridComponent.onclick = () => window.location = gridLink; } }); } initGrids(); if (window.ContextHub) { window.ContextHub.eventing.on(ContextHub.SegmentEngine.PageInteraction.Teaser.prototype.info.loadEvent, function() { initGrids(); }); } }); //video thumb component - javascript// $(window).bind("load", function() { var tallest = 0; $(".video_thumb-wrapper").each(function(){ if($(this).height() > tallest) tallest = $(this).height(); }); $(".video_thumb-wrapper").height(tallest); }); $(function() { // Prepend an overlay div for popup videos ( not in markup to accomodate Mobile App ) const videoOverlayElement = document.createElement('div'); videoOverlayElement.classList.add('popup-video-overlay'); document.querySelectorAll('.video-popup-container .videoWrapper').forEach(elem => { elem.prepend(videoOverlayElement.cloneNode()); }); $('.video-popup-container').on('click', function(e) { var $dataContainer = $(e.target).is('.video-popup-container') ? $(e.target) : $(e.target).parents('.video-popup-container'); var videoSrc = $dataContainer.attr('data-vid-src'); if (videoSrc.includes('youtube')) videoSrc = videoSrc + '&autoplay=1' haas.components.Modal.open('
" + $vidContainer.data('description') + "
{{=msg}}
SN# "+sn.substr(1)+"
SN# "+sn+"
{{=err}}
yeet
Success! ' + quantity +' item(s) added to cart!
Error! Item Out of Stock!
Error! Your cart has expired, creating new cart!
'+errorTL+' '+outOfStockTL+'
'+errorTL+' '+expiredTL+'
'+successMsg+'
' + self.tooltipDescriptions[ndx] + '
'+errorTL+' '+wcErrorTL+'
'+errorTL+' '+wcMemberErrorTL+'
" + subtitle + "
There was an error loading our machines.
Best combination of value and performance in the industry.
Full-featured CNC with many options to choose from.
Affordable, easy to use mill with size flexibility.
Affordable, easy to use lathe with size flexibility.