HOME


Mini Shell 1.0
DIR:/home/drsekaran/public_html/admin/vendors/Flot/tests/
Upload File :
Current File : /home/drsekaran/public_html/admin/vendors/Flot/tests/jquery.flot.legend.Test.js
/* eslint-disable */
/* global $, describe, it, xit, xdescribe, after, afterEach, expect*/

describe("flot legend plugin", function() {
    var placeholder, plot;
    var options, legendContainer, legendSettings

    beforeEach(function() {
        var legendSettings = {
                position: "nw",
                show: true,
                container: null
            };

        options = {
            legend: legendSettings,
            series: {
                shadowSize: 0, // don't draw shadows
            }
        };

        placeholder = setFixtures('<div id="test-container" style="width: 600px;height: 400px">')
            .find('#test-container');
    });

    var positions = ['nw', 'ne', 'sw', 'se'];
    positions.forEach(function (pos) {
        it ('shold draw a legend over graph at cardinal position: ' + pos + ', if a container is not provided', function () {
            options.legend.position = pos;
            plot = $.plot(placeholder, [[1, 3, 5, 6]], options);

            var legend = document.getElementsByClassName('legend')[0];

            expect(legend.style.position).toBe('absolute');
            switch (pos) {
                case "nw":
                    expect(legend.style.top).toContain('px')
                    expect(legend.style.bottom).toBe('');
                    expect(legend.style.left).toContain('px')
                    expect(legend.style.right).toBe('');
                    break;
                case "ne":
                    expect(legend.style.top).toContain('px')
                    expect(legend.style.bottom).toBe('');
                    expect(legend.style.left).toBe('');
                    expect(legend.style.right).toContain('px')
                    break;
                case "sw":
                    expect(legend.style.top).toBe('');
                    expect(legend.style.bottom).toContain('px')
                    expect(legend.style.left).toContain('px')
                    expect(legend.style.right).toBe('');
                    break;
                case "se":
                    expect(legend.style.top).toBe('');
                    expect(legend.style.bottom).toContain('px')
                    expect(legend.style.left).toBe('');
                    expect(legend.style.right).toContain('px')
                    break;
            }
        });
    });

    it('should draw the legend inside the container if one is provided', function(){
        var legendContainer = document.createElement("div");
        document.body.appendChild(legendContainer);

        options.legend.container = legendContainer;
        plot = $.plot(placeholder, [[1, 3, 5, 6]], options);

        expect(legendContainer.style.width).toContain('em');
        expect(legendContainer.style.height).toContain('em');
        document.body.removeChild(legendContainer);
    });

    it('should assign a default plot label if none is provided', function(){
        plot = $.plot(placeholder, [[1, 3, 5, 6]], options);

        var legendSvg = document.getElementsByClassName('legendLayer')[0];
        var firstLegendEntry = legendSvg.getElementsByTagNameNS('http://www.w3.org/2000/svg', 'g')[0];
        var entryLabel = firstLegendEntry.getElementsByTagNameNS('http://www.w3.org/2000/svg', 'text')[0];

        expect(entryLabel.textContent).toBe('Plot 1');
    });

    it('should display the plot label', function(){
        var label = 'custom label';
        options.series.label = label;
        plot = $.plot(placeholder, [[1, 3, 5, 6]], options);

        var legendSvg = document.getElementsByClassName('legendLayer')[0];
        var firstLegendEntry = legendSvg.getElementsByTagNameNS('http://www.w3.org/2000/svg', 'g')[0];
        var entryLabel =  firstLegendEntry.getElementsByTagNameNS('http://www.w3.org/2000/svg', 'text')[0];

        expect(entryLabel.textContent).toBe(label);
    });

    it('should take into account the show option', function() {
        options.legend.show = false;
        plot = $.plot(placeholder, [[1, 3, 5, 6]], options);

        var legendSvg = document.getElementsByClassName('legendLayer')[0];

        expect(legendSvg).toBe(undefined);
    });
});