/* ===================================================
 * bootstrap-transition.js v2.3.2
 * http://getbootstrap.com/2.3.2/javascript.html#transitions
 * ===================================================
 * Copyright 2013 Twitter, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * ========================================================== */


!function ($) {

  "use strict"; // jshint ;_;


  /* CSS TRANSITION SUPPORT (http://www.modernizr.com/)
   * ======================================================= */

  $(function () {

    $.support.transition = (function () {

      var transitionEnd = (function () {

        var el = document.createElement('bootstrap')
          , transEndEventNames = {
               'WebkitTransition' : 'webkitTransitionEnd'
            ,  'MozTransition'    : 'transitionend'
            ,  'OTransition'      : 'oTransitionEnd otransitionend'
            ,  'transition'       : 'transitionend'
            }
          , name

        for (name in transEndEventNames){
          if (el.style[name] !== undefined) {
            return transEndEventNames[name]
          }
        }

      }())

      return transitionEnd && {
        end: transitionEnd
      }

    })()

  })

}(window.jQuery);
/* ==========================================================
 * bootstrap-carousel.js v2.3.2
 * http://getbootstrap.com/2.3.2/javascript.html#carousel
 * ==========================================================
 * Copyright 2013 Twitter, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * ========================================================== */


!function ($) {

  "use strict"; // jshint ;_;


 /* CAROUSEL CLASS DEFINITION
  * ========================= */

  var Carousel = function (element, options) {
    this.$element = $(element)
    this.$indicators = this.$element.find('.carousel-indicators')
    this.options = options
    this.options.pause == 'hover' && this.$element
      .on('mouseenter', $.proxy(this.pause, this))
      .on('mouseleave', $.proxy(this.cycle, this))
  }

  Carousel.prototype = {

    cycle: function (e) {
      if (!e) this.paused = false
      if (this.interval) clearInterval(this.interval);
      this.options.interval
        && !this.paused
        && (this.interval = setInterval($.proxy(this.next, this), this.options.interval))
      return this
    }

  , getActiveIndex: function () {
      this.$active = this.$element.find('.item.active')
      this.$items = this.$active.parent().children()
      return this.$items.index(this.$active)
    }

  , to: function (pos) {
      var activeIndex = this.getActiveIndex()
        , that = this

      if (pos > (this.$items.length - 1) || pos < 0) return

      if (this.sliding) {
        return this.$element.one('slid', function () {that.to(pos)})
      }

      if (activeIndex == pos) {
        return this.pause().cycle()
      }

      return this.slide(pos > activeIndex ? 'next' : 'prev', $(this.$items[pos]))
    }

  , pause: function (e) {
      if (!e) this.paused = true
      if (this.$element.find('.next, .prev').length && $.support.transition.end) {
        this.$element.trigger($.support.transition.end)
        this.cycle(true)
      }
      clearInterval(this.interval)
      this.interval = null
      return this
    }

  , next: function () {
      if (this.sliding) return
      return this.slide('next')
    }

  , prev: function () {
      if (this.sliding) return
      return this.slide('prev')
    }

  , slide: function (type, next) {
      var $active = this.$element.find('.item.active')
        , $next = next || $active[type]()
        , isCycling = this.interval
        , direction = type == 'next' ? 'left' : 'right'
        , fallback  = type == 'next' ? 'first' : 'last'
        , that = this
        , e

      this.sliding = true

      isCycling && this.pause()

      $next = $next.length ? $next : this.$element.find('.item')[fallback]()

      e = $.Event('slide', {
        relatedTarget: $next[0]
      , direction: direction
      })

      if ($next.hasClass('active')) return

      if (this.$indicators.length) {
        this.$indicators.find('.active').removeClass('active')
        this.$element.one('slid', function () {
          var $nextIndicator = $(that.$indicators.children()[that.getActiveIndex()])
          $nextIndicator && $nextIndicator.addClass('active')
        })
      }

      if ($.support.transition && this.$element.hasClass('slide')) {
        this.$element.trigger(e)
        if (e.isDefaultPrevented()) return
        $next.addClass(type)
        $next[0].offsetWidth // force reflow
        $active.addClass(direction)
        $next.addClass(direction)
        this.$element.one($.support.transition.end, function () {
          $next.removeClass([type, direction].join(' ')).addClass('active')
          $active.removeClass(['active', direction].join(' '))
          that.sliding = false
          setTimeout(function () {that.$element.trigger('slid')}, 0)
        })
      } else {
        this.$element.trigger(e)
        if (e.isDefaultPrevented()) return
        $active.removeClass('active')
        $next.addClass('active')
        this.sliding = false
        this.$element.trigger('slid')
      }

      isCycling && this.cycle()

      return this
    }

  }


 /* CAROUSEL PLUGIN DEFINITION
  * ========================== */

  var old = $.fn.carousel

  $.fn.carousel = function (option) {
    return this.each(function () {
      var $this = $(this)
        , data = $this.data('carousel')
        , options = $.extend({}, $.fn.carousel.defaults, typeof option == 'object' && option)
        , action = typeof option == 'string' ? option : options.slide
      if (!data) $this.data('carousel', (data = new Carousel(this, options)))
      if (typeof option == 'number') data.to(option)
      else if (action) data[action]()
      else if (options.interval) data.pause().cycle()
    })
  }

  $.fn.carousel.defaults = {
    interval: 5000
  , pause: 'hover'
  }

  $.fn.carousel.Constructor = Carousel


 /* CAROUSEL NO CONFLICT
  * ==================== */

  $.fn.carousel.noConflict = function () {
    $.fn.carousel = old
    return this
  }

 /* CAROUSEL DATA-API
  * ================= */

  $(document).on('click.carousel.data-api', '[data-slide], [data-slide-to]', function (e) {
    var $this = $(this), href
      , $target = $($this.attr('data-target') || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
      , options = $.extend({}, $target.data(), $this.data())
      , slideIndex

    $target.carousel(options)

    if (slideIndex = $this.attr('data-slide-to')) {$target.data('carousel').pause().to(slideIndex).cycle()}

    e.preventDefault()
  })

}(window.jQuery);

$(document).ready(function() {
	
	var stop = false;
	$("#carousel, #mobileCarousel").swiperight(function() {
		$("#carousel, #mobileCarousel").carousel('prev');
	});
	$("#carousel, #mobileCarousel").swipeleft(function() {
		$("#carousel, #mobileCarousel").carousel('next');
	});
	$("#carousel").carousel({
            interval: false
    });
	$("#stop").click(function() {
		if (stop == false) {
			$("#carousel").carousel("pause");
			$("#stop").removeClass('pause');
			$('#stop').addClass('play');
			stop = true;
		}
		else if (stop == true) {
			$("#myCarousel").carousel("cycle");
			$("#stop").removeClass('play');
			$('#stop').addClass('pause');
			stop = false;	
		}
	});
	$("#mobileCarousel").carousel({
            interval: false
    });
    $("#reccoCarousel").carousel({
            interval: false
    });
    $("#galleryCarousel").carousel({
            interval: false
    });
   
	/* Desktop nav 
	$('.parents-nav').find('.drop-item').click(function(e){
		
		var dropdown = $(this).children('.dropdown-group');
		var dropitem = $(this).children('a');
		
		$('.parents-nav .drop-item .dropdown-group').not(dropdown).slideUp('fast');
		$('.parents-nav').find('li a.open').not(dropitem).removeClass('open');
		dropitem.toggleClass('open');
		dropdown.slideToggle('fast');
		
	});*/
	
	$('.parents-nav .drop-item a[href|="#"]').click(function(e){
		e.preventDefault();
		
		var dropdown = $(this).parent().children('.dropdown-group');
		var dropitem = $(this).parent().children('a');
		
		$('.parents-nav .drop-item').children('.dropdown-group').slideUp('fast');
		$('.parents-nav').find('li a.open').not(dropitem).removeClass('open');
		
		if($(this).hasClass('open')) {
			return false;	
		}
		
		dropitem.toggleClass('open');
		dropdown.slideToggle('fast');
	})
	
	
	/* Mobile menu code*/
	$("#mmenu, .submenu").hide();
    $(".mtoggle").click(function() {$(this).next("ul").slideToggle(500);});
	$(document.links).each( function(){
		/* added additional check to prevent removal of _blank from content links */
		/* adjusted to be HTTP/S agnostic ~sb 2018-09-06 */
		if($(this).attr('href').indexOf('cbc.ca/parents') == -1){
			this.target = ~this.href.indexOf( "//www.cbc.ca/parents/") ? "" : "_blank";
		}
	});
	$('a.taphover').on("touchstart", function (e) {
		console.log("recco-engine");
		'use strict'; //satisfy code inspectors
		var link = $(this); //preselect the link
		if (link.hasClass('hover')) {
			return true;
		} else {
		link.addClass('hover');
		$('a.taphover').not(this).removeClass('hover');
			e.preventDefault();
			return false; //extra, and to make sure the function has consistent return points
		}
	});
});

$(document).bind('keyup', function(e) {
    if(e.which == 39){$('.carousel').carousel('next');}
    else if(e.which == 37){$('.carousel').carousel('prev');}
});
