Skip to content
Snippets Groups Projects
TooltipPositionOptionSpec.js 5.40 KiB
/*
  *************************

  tooltip_position Option Test

  *************************
*/
describe("'tooltip_position' Option tests", function() {

  var testSlider;

  afterEach(function() {
    if(testSlider) {
      testSlider.destroy();
      testSlider = null;
    }
  });

  describe("vertical slider tests", function() {

    it("should be aligned to the left of the handle if set to 'left'", function() {
      // Create slider
      testSlider = new Slider("#testSlider1", {
        min: 0,
        max: 10,
        value: 5,
        tooltip_position: "left",
        orientation: "vertical"
      });

      // Extract needed references/values
      var mainTooltipHasClassLeft = testSlider.tooltip.classList.contains("left");

      // Assert
      expect(mainTooltipHasClassLeft).toBeTruthy();
      expect(testSlider.tooltip.style.right).toBe("100%");
    });

    it("should be aligned to the right of the handle if set to 'right'", function() {
      // Create slider
      testSlider = new Slider("#testSlider1", {
        min: 0,
        max: 10,
        value: 5,
        tooltip_position: "right",
        orientation: "vertical"
      });

      // Extract needed references/values
      var mainTooltipHasClassRight = testSlider.tooltip.classList.contains("right");

      // Assert
      expect(mainTooltipHasClassRight).toBeTruthy();
      expect(testSlider.tooltip.style.left).toBe("100%");
    });

    it("should default to 'right' if tooltip_position set to 'top'", function() {
      // Create slider
      testSlider = new Slider("#testSlider1", {
        min: 0,
        max: 10,
        value: 5,
        tooltip_position: "top",
        orientation: "vertical"
      });

      // Extract needed references/values
      var mainTooltipHasClassRight = testSlider.tooltip.classList.contains("right");

      // Assert
      expect(mainTooltipHasClassRight).toBeTruthy();
      expect(testSlider.tooltip.style.left).toBe("100%");
    });

    it("should default to 'right' if tooltip_position set to 'bottom'", function() {
      // Create slider
      testSlider = new Slider("#testSlider1", {
        min: 0,
        max: 10,
        value: 5,
        tooltip_position: "bottom",
        orientation: "vertical"
      });

      // Extract needed references/values
      var mainTooltipHasClassRight = testSlider.tooltip.classList.contains("right");

      // Assert
      expect(mainTooltipHasClassRight).toBeTruthy();
      expect(testSlider.tooltip.style.left).toBe("100%");
    });

  });


  describe("horizontal slider tests", function() {

    it("should be aligned above the handle if set to 'top'", function() {
      // Create slider
      testSlider = new Slider("#testSlider1", {
        min: 0,
        max: 10,
        value: 5,
        tooltip_position: "top",
        orientation: "horizontal"
      });

      // Extract needed references/values
      var mainTooltipHasClassTop = testSlider.tooltip.classList.contains("top");

      // Assert
      expect(mainTooltipHasClassTop).toBeTruthy();
      expect(testSlider.tooltip.style.top).toBe("");
    });

    it("should be aligned below the handle if set to 'bottom'", function() {
      // Create slider
      testSlider = new Slider("#testSlider1", {
        min: 0,
        max: 10,
        value: 5,
        tooltip_position: "bottom",
        orientation: "horizontal"
      });

      // Extract needed references/values
      var mainTooltipHasClassTop = testSlider.tooltip.classList.contains("bottom");

      // Assert
      expect(mainTooltipHasClassTop).toBeTruthy();
      expect(testSlider.tooltip.style.top).toBe("22px");
    });

    it("should be aligned below the handle if set to 'bottom' for range", function() {
      // Create slider
      testSlider = new Slider("#testSlider1", {
        min: 0,
        max: 20,
        value: [0, 10],
        range: true,
        tooltip_position: "bottom",
        orientation: "horizontal"
      });

      // Extract needed references/values
      var mainTooltipHasClassTopMin = testSlider.tooltip_min.classList.contains("bottom");
      var mainTooltipHasClassTopMax = testSlider.tooltip_max.classList.contains("bottom");

      // Assert
      expect(mainTooltipHasClassTopMin).toBeTruthy();
      expect(mainTooltipHasClassTopMax).toBeTruthy();
      expect(testSlider.tooltip_min.style.top).toBe("22px");
      expect(testSlider.tooltip_max.style.top).toBe("22px");
    });

    it("should default to 'top' if tooltip_position set to 'left'", function() {
      // Create slider
      testSlider = new Slider("#testSlider1", {
        min: 0,
        max: 10,
        value: 5,
        tooltip_position: "left",
        orientation: "horizontal"
      });

      // Extract needed references/values
      var mainTooltipHasClassTop = testSlider.tooltip.classList.contains("top");

      // Assert
      expect(mainTooltipHasClassTop).toBeTruthy();
      expect(testSlider.tooltip.style.top).toBe("");
    });

    it("should default to 'top' if tooltip_position set to 'right'", function() {
      // Create slider
      testSlider = new Slider("#testSlider1", {
        min: 0,
        max: 10,
        value: 5,
        tooltip_position: "right",
        orientation: "horizontal"
      });

      // Extract needed references/values
      var mainTooltipHasClassTop = testSlider.tooltip.classList.contains("top");

      // Assert
      expect(mainTooltipHasClassTop).toBeTruthy();
      expect(testSlider.tooltip.style.top).toBe("");
    });

  });

});