All Downloads are FREE. Search and download functionalities are using the official Maven repository.

freemarker.coverage.ftl Maven / Gradle / Ivy

<#assign dollar = "$">var labelType, useGradients, nativeTextSupport, animate;

(function() {
    var ua = navigator.userAgent,
            iStuff = ua.match(/iPhone/i) || ua.match(/iPad/i),
            typeOfCanvas = typeof HTMLCanvasElement,
            nativeCanvasSupport = (typeOfCanvas == 'object' || typeOfCanvas == 'function'),
            textSupport = nativeCanvasSupport
                    && (typeof document.createElement('canvas').getContext('2d').fillText == 'function');
    //I'm setting this based on the fact that ExCanvas provides text support for IE
    //and that as of today iPhone/iPad current text support is lame
    labelType = (!nativeCanvasSupport || (textSupport && !iStuff)) ? 'Native' : 'HTML';
    nativeTextSupport = labelType == 'Native';
    useGradients = nativeCanvasSupport;
    animate = !(iStuff || !nativeCanvasSupport);
})();

var Log = {
    elem: false,
    write: function(text) {
        if (!this.elem)
            this.elem = document.getElementById('log');
        this.elem.innerHTML = text;
        this.elem.style.left = (500 - this.elem.offsetWidth / 2) + 'px';
    }
};


function init() {
    //init data
    var json = ${coverageData};
    //end
    //init TreeMap
    var tm = new ${dollar}jit.TM.Squarified({
                //where to inject the visualization
                injectInto: 'infovis',
                //parent box title heights
                titleHeight: 20,
                //enable animations
                //animate: animate,
                //box offsets
                offset: 1,
                width: 700,
                height: 700,
                levelsToShow: 2,

                cushion: useGradients,
                //Attach left and right click events
                Events: {
                    enable: true,
                    onClick: function(node) {
                        if (node) {
                            var data = node.data;
                            if (data.report) {
                               window.document.location = data.report
                            } else {
                                tm.enter(node);
                            }
                        }
                    },
                    onRightClick: function() {
                        tm.out();
                    }
                },
                duration: 1000,
                //Enable tips
                Tips: {
                    enable: true,
                    //add positioning offsets
                    offsetX: 20,
                    offsetY: 20,
                    //implement the onShow method to
                    //add content to the tooltip when a node
                    //is hovered
                    onShow: function(tip, node, isLeaf, domElement) {
                        var html = "
" + node.name + "
"; var data = node.data; if (data.stories) { html += "User stories: " + data.stories + "
"; } if (data.tests) { html += "Tests: " + data.tests + "
"; } if (data.passing) { html += "  - Passing: " + data.passing + "
"; } if (data.pending) { html += "  - Pending: " + data.pending + "
"; } if (data.pending) { html += "  - Failing: " + data.failing + "
"; } if (data.steps) { html += "Total steps: " + data.steps + "
"; } tip.innerHTML = html; } }, //Add the name of the node in the correponding label //This method is called once, on label creation. onCreateLabel: function(domElement, node) { domElement.innerHTML = node.name; var style = domElement.style; if (node.id == 'root' ) { style.color = '#ffffff'; } if (node.data.progress) { if (node.data.progress > 50) { style.color = '#ffffff'; } else { style.color = '#000000'; } } style.display = ''; style.border = '1px solid transparent'; domElement.onmouseover = function() { style.border = '1px solid #9FD4FF'; }; domElement.onmouseout = function() { style.border = '1px solid transparent'; }; } }); tm.loadJSON(json); tm.refresh(); //end //add events to radio buttons var sq = ${dollar}jit.id('r-sq'), st = ${dollar}jit.id('r-st'), sd = ${dollar}jit.id('r-sd'); var util = ${dollar}jit.util; util.addEvent(sq, 'change', function() { if (!sq.checked) return; util.extend(tm, new ${dollar}jit.Layouts.TM.Squarified); tm.refresh(); }); util.addEvent(st, 'change', function() { if (!st.checked) return; util.extend(tm, new ${dollar}jit.Layouts.TM.Strip); tm.layout.orientation = "v"; tm.refresh(); }); util.addEvent(sd, 'change', function() { if (!sd.checked) return; util.extend(tm, new ${dollar}jit.Layouts.TM.SliceAndDice); tm.layout.orientation = "v"; tm.refresh(); }); //add event to the back button var back = ${dollar}jit.id('back'); ${dollar}jit.util.addEvent(back, 'click', function() { tm.out(); }); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy