123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127 |
- describe 'Morris.Bar', ->
- describe 'when using vertical grid', ->
- defaults =
- element: 'graph'
- data: [{x: 'foo', y: 2, z: 3}, {x: 'bar', y: 4, z: 6}]
- xkey: 'x'
- ykeys: ['y', 'z']
- labels: ['Y', 'Z']
- barColors: [ '#0b62a4', '#7a92a3']
- gridLineColor: '#aaa'
- gridStrokeWidth: 0.5
- gridTextColor: '#888'
- gridTextSize: 12
- verticalGridCondition: (index) -> index % 2
- verticalGridColor: '#888888'
- verticalGridOpacity: '0.2'
- describe 'svg structure', ->
- it 'should contain extra rectangles for vertical grid', ->
- $('#graph').css('height', '250px').css('width', '800px')
- chart = Morris.Bar $.extend {}, defaults
- $('#graph').find("rect").size().should.equal 6
- describe 'svg attributes', ->
- it 'should have to bars with verticalGrid.color', ->
- chart = Morris.Bar $.extend {}, defaults
- $('#graph').find("rect[fill='#{defaults.verticalGridColor}']").size().should.equal 2
- it 'should have to bars with verticalGrid.color', ->
- chart = Morris.Bar $.extend {}, defaults
- $('#graph').find("rect[fill-opacity='#{defaults.verticalGridOpacity}']").size().should.equal 2
- describe 'svg structure', ->
- defaults =
- element: 'graph'
- data: [{x: 'foo', y: 2, z: 3}, {x: 'bar', y: 4, z: 6}]
- xkey: 'x'
- ykeys: ['y', 'z']
- labels: ['Y', 'Z']
- it 'should contain a rect for each bar', ->
- chart = Morris.Bar $.extend {}, defaults
- $('#graph').find("rect").size().should.equal 4
- it 'should contain 5 grid lines', ->
- chart = Morris.Bar $.extend {}, defaults
- $('#graph').find("path").size().should.equal 5
- it 'should contain 7 text elements', ->
- chart = Morris.Bar $.extend {}, defaults
- $('#graph').find("text").size().should.equal 7
- describe 'svg attributes', ->
- defaults =
- element: 'graph'
- data: [{x: 'foo', y: 2, z: 3}, {x: 'bar', y: 4, z: 6}]
- xkey: 'x'
- ykeys: ['y', 'z']
- labels: ['Y', 'Z']
- barColors: [ '#0b62a4', '#7a92a3']
- gridLineColor: '#aaa'
- gridStrokeWidth: 0.5
- gridTextColor: '#888'
- gridTextSize: 12
- it 'should have a bar with the first default color', ->
- chart = Morris.Bar $.extend {}, defaults
- $('#graph').find("rect[fill='#0b62a4']").size().should.equal 2
- it 'should have a bar with no stroke', ->
- chart = Morris.Bar $.extend {}, defaults
- $('#graph').find("rect[stroke='none']").size().should.equal 4
- it 'should have text with configured fill color', ->
- chart = Morris.Bar $.extend {}, defaults
- $('#graph').find("text[fill='#888888']").size().should.equal 7
- it 'should have text with configured font size', ->
- chart = Morris.Bar $.extend {}, defaults
- $('#graph').find("text[font-size='12px']").size().should.equal 7
- describe 'when setting bar radius', ->
- describe 'svg structure', ->
- defaults =
- element: 'graph'
- data: [{x: 'foo', y: 2, z: 3}, {x: 'bar', y: 4, z: 6}]
- xkey: 'x'
- ykeys: ['y', 'z']
- labels: ['Y', 'Z']
- barRadius: [5, 5, 0, 0]
- it 'should contain a path for each bar', ->
- chart = Morris.Bar $.extend {}, defaults
- $('#graph').find("path").size().should.equal 9
- it 'should use rects if radius is too big', ->
- delete defaults.barStyle
- chart = Morris.Bar $.extend {}, defaults,
- barRadius: [300, 300, 0, 0]
- $('#graph').find("rect").size().should.equal 4
- describe 'barSize option', ->
- describe 'svg attributes', ->
- defaults =
- element: 'graph'
- barSize: 20
- data: [
- {x: '2011 Q1', y: 3, z: 2, a: 3}
- {x: '2011 Q2', y: 2, z: null, a: 1}
- {x: '2011 Q3', y: 0, z: 2, a: 4}
- {x: '2011 Q4', y: 2, z: 4, a: 3}
- ],
- xkey: 'x'
- ykeys: ['y', 'z', 'a']
- labels: ['Y', 'Z', 'A']
- it 'should calc the width if too narrow for barSize', ->
- $('#graph').width('200px')
- chart = Morris.Bar $.extend {}, defaults
- $('#graph').find("rect").filter((i) ->
- parseFloat($(@).attr('width'), 10) < 10
- ).size().should.equal 11
- it 'should set width to @options.barSize if possible', ->
- chart = Morris.Bar $.extend {}, defaults
- $('#graph').find("rect[width='#{defaults.barSize}']").size().should.equal 11
|