Вход Регистрация
Файл: templates/backend/default/assets/plugins/jquery-ricksaw-chart/js/Rickshaw.Graph.Renderer.Area.js
Строк: 85
<?php
Rickshaw
.namespace('Rickshaw.Graph.Renderer.Area');

Rickshaw.Graph.Renderer.Area Rickshaw.Class.createRickshaw.Graph.Renderer, {

    
name'area',

    
defaults: function($super) {

        return 
Rickshaw.extend$super(), {
            
unstackfalse,
            
fillfalse,
            
strokefalse
        
} );
    },

    
seriesPathFactory: function() {

        var 
graph this.graph;

        var 
factory d3.svg.area()
            .
x( function(d) { return graph.x(d.x) } )
            .
y0( function(d) { return graph.y(d.y0) } )
            .
y1( function(d) { return graph.y(d.d.y0) } )
            .
interpolate(graph.interpolation).tension(this.tension);

        
factory.defined && factory.defined( function(d) { return d.!== null } );
        return 
factory;
    },

    
seriesStrokeFactory: function() {

        var 
graph this.graph;

        var 
factory d3.svg.line()
            .
x( function(d) { return graph.x(d.x) } )
            .
y( function(d) { return graph.y(d.d.y0) } )
            .
interpolate(graph.interpolation).tension(this.tension);

        
factory.defined && factory.defined( function(d) { return d.!== null } );
        return 
factory;
    },

    
render: function() {

        var 
graph this.graph;

        
graph.vis.selectAll('*').remove();

        
// insert or stacked areas so strokes lay on top of areas
        
var method this.unstack 'append' 'insert';

        var 
nodes graph.vis.selectAll("path")
            .
data(this.graph.stackedData)
            .
enter()[method]("svg:g"'g');

        
nodes.append("svg:path")
            .
attr("d"this.seriesPathFactory())
            .
attr("class"'area');

        if (
this.stroke) {
            
nodes.append("svg:path")
                .
attr("d"this.seriesStrokeFactory())
                .
attr("class"'line');
        }

        var 
0;
        
graph.series.forEach( function(series) {
            if (
series.disabled) return;
            
series.path nodes[0][i++];
            
this._styleSeries(series);
        }, 
this );
    },

    
_styleSeries: function(series) {

        if (!
series.path) return;

        
d3.select(series.path).select('.area')
            .
attr('fill'series.color);

        if (
this.stroke) {
            
d3.select(series.path).select('.line')
                .
attr('fill''none')
                .
attr('stroke'series.stroke || d3.interpolateRgb(series.color'black')(0.125))
                .
attr('stroke-width'this.strokeWidth);
        }

        if (
series.className) {
            
series.path.setAttribute('class'series.className);
        }
    }
} );
?>
Онлайн: 0
Реклама