$(function() {

        //remove js-disabled class
        $("#viewer").removeClass("js-disabled");

        //create new container for images
        $("<div>").attr("id", "container").css({ position:"absolute"}).width($(".rotator_wrapper").length * 150).height(150).appendTo("div#viewer");

        //add images to container
        $(".rotator_wrapper").each(function() {
          $(this).appendTo("div#container");
        });

        //work out duration of anim based on number of images (1 second for each image)
        var duration = $(".rotator_wrapper").length * 7500;

        //store speed for later (distance / time)
        var speed = (parseInt($("div#container").width()) + parseInt($("div#viewer").width())) / duration;

        //set direction
        var direction = "rtl";

        //set initial position and class based on direction
        (direction == "rtl") ? $("div#container").css("left", $("div#viewer").width()).addClass("rtl") : $("div#container").css("left", 0 - $("div#container").width()).addClass("ltr") ;

        //animator function
        var animator = function(el, time, dir) {

          //which direction to scroll
          if(dir == "rtl") {

            //add direction class
            el.removeClass("ltr").addClass("rtl");

            //animate the el
            el.animate({ left:"-" + el.width() + "px" }, time, "linear", function() {

              //reset container position
              $(this).css({ left:$("div#imageScroller").width(), right:"" });

              //restart animation
              animator($(this), duration, "rtl");

              //hide controls if visible
              ($("div#controls").length > 0) ? $("div#controls").slideUp("slow").remove() : null ;

            });
          } else {

            //add direction class
            el.removeClass("rtl").addClass("ltr");

            //animate the el
            el.animate({ left:$("div#viewer").width() + "px" }, time, "linear", function() {

              //reset container position
              $(this).css({ left:0 - $("div#container").width() });

              //restart animation
              animator($(this), duration, "ltr");

              //hide controls if visible
              ($("div#controls").length > 0) ? $("div#controls").slideUp("slow").remove() : null ;
            });
          }
        }

        //start anim
        animator($("div#container"), duration, direction);

        //pause on mouseover
        $("a.rotator_wrapper").live("mouseover", function() {

          //stop anim
          $("div#container").stop(true);

          //show controls
          ($("div#controls").length == 0) ? $("<div>").attr("id", "controls").appendTo("div#outerContainer").css({ opacity:0.7 }).slideDown("slow") : null ;
          ($("a#rtl").length == 0) ? $("<a>").attr({ id:"rtl", href:"#", title:"rtl" }).appendTo("#controls") : null ;
          ($("a#ltr").length == 0) ? $("<a>").attr({ id:"ltr", href:"#", title:"ltr" }).appendTo("#controls") : null ;

          //variable to hold trigger element
          var title = $(this).attr("title");

          //add p if doesn't exist, update it if it does
          ($("p#title").length == 0) ? $("<p>").attr("id", "title").text(title).appendTo("div#controls") : $("p#title").text(title) ;
        });

        //restart on mouseout
        $("a.rotator_wrapper").live("mouseout", function(e) {

          //hide controls if not hovering on them
          (e.relatedTarget == null) ? null : (e.relatedTarget.id != "controls") ? $("div#controls").slideUp("slow").remove() : null ;

          //work out total travel distance
          var totalDistance = parseInt($("div#container").width()) + parseInt($("div#viewer").width());

          //work out distance left to travel
          var distanceLeft = ($("div#container").hasClass("ltr")) ? totalDistance - (parseInt($("div#container").css("left")) + parseInt($("div#container").width())) : totalDistance - (parseInt($("div#viewer").width()) - (parseInt($("div#container").css("left")))) ;

          //new duration is distance left / speed)
          var newDuration = distanceLeft / speed;

          //restart anim
          animator($("div#container"), newDuration, $("div#container").attr("class"));

        });

        //handler for ltr button
        $("#ltr").live("click", function() {

          //stop anim
          $("div#container").stop(true);

          //swap class names
          $("div#container").removeClass("rtl").addClass("ltr");

          //work out total travel distance
          var totalDistance = parseInt($("div#container").width()) + parseInt($("div#viewer").width());

          //work out remaining distance
          var distanceLeft = totalDistance - (parseInt($("div#container").css("left")) + parseInt($("div#container").width()));

          //new duration is distance left / speed)
          var newDuration = distanceLeft / speed;

          //restart anim
          animator($("div#container"), newDuration, "ltr");
        });

        //handler for rtl button
        $("#rtl").live("click", function() {

          //stop anim
          $("div#container").stop(true);

          //swap class names
          $("div#container").removeClass("ltr").addClass("rtl");

          //work out total travel distance
          var totalDistance = parseInt($("div#container").width()) + parseInt($("div#viewer").width());

          //work out remaining distance
          var distanceLeft = totalDistance - (parseInt($("div#viewer").width()) - (parseInt($("div#container").css("left"))));

          //new duration is distance left / speed)
          var newDuration = distanceLeft / speed;

          //restart anim
          animator($("div#container"), newDuration, "rtl");
        });
      });

