api.zoom-spec.ts 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. import { initChart } from './c3-helper'
  2. describe('c3 api zoom', function() {
  3. 'use strict'
  4. var chart, args
  5. beforeEach(function(done) {
  6. chart = initChart(chart, args, done)
  7. })
  8. describe('zoom', function() {
  9. beforeAll(function() {
  10. args = {
  11. data: {
  12. columns: [
  13. ['data1', 30, 200, 100, 400, 150, 250],
  14. ['data2', 50, 20, 10, 40, 15, 25],
  15. ['data3', 150, 120, 110, 140, 115, 125]
  16. ]
  17. },
  18. zoom: {
  19. enabled: true
  20. }
  21. }
  22. })
  23. it('should return the correct extent', function() {
  24. var zoomDomain = chart.zoom(),
  25. expectedDomain = chart.internal.x.domain()
  26. expect(+zoomDomain[0]).toBe(+expectedDomain[0])
  27. expect(+zoomDomain[1]).toBe(+expectedDomain[1])
  28. })
  29. it('should be zoomed properly', function() {
  30. var target = [3, 5],
  31. domain
  32. chart.zoom(target)
  33. domain = chart.internal.x.domain()
  34. expect(domain[0]).toBe(target[0])
  35. expect(domain[1]).toBe(target[1])
  36. })
  37. it('should be zoomed properly again', function() {
  38. var target = [1, 4],
  39. domain
  40. chart.zoom(target)
  41. domain = chart.internal.x.domain()
  42. expect(domain[0]).toBe(target[0])
  43. expect(domain[1]).toBe(target[1])
  44. })
  45. it('should set the max zoom properly', function() {
  46. chart.zoom.max(100)
  47. expect(chart.zoom.max()).toBe(100)
  48. })
  49. it('should set the min zoom properly', function() {
  50. chart.zoom.min(-1)
  51. expect(chart.zoom.min()).toBe(-1)
  52. })
  53. describe('with timeseries data', function() {
  54. beforeAll(function() {
  55. args = {
  56. data: {
  57. x: 'date',
  58. columns: [
  59. ['date', '2014-01-01', '2014-01-02', '2014-08-01', '2014-10-19'],
  60. ['data1', 30, 200, 100, 400]
  61. ]
  62. },
  63. axis: {
  64. x: {
  65. type: 'timeseries'
  66. }
  67. },
  68. zoom: {
  69. enabled: true
  70. }
  71. }
  72. })
  73. it('should be zoomed properly', function() {
  74. var target = [new Date(2014, 7, 1), new Date(2014, 8, 1)],
  75. domain
  76. chart.zoom(target)
  77. domain = chart.internal.x.domain()
  78. expect(+domain[0]).toBe(+target[0])
  79. expect(+domain[1]).toBe(+target[1])
  80. })
  81. it('should be zoomed properly', function() {
  82. var target = ['2014-08-01', '2014-09-01'],
  83. domain
  84. chart.zoom(target)
  85. domain = chart.internal.x.domain()
  86. expect(+domain[0]).toBe(+chart.internal.parseDate(target[0]))
  87. expect(+domain[1]).toBe(+chart.internal.parseDate(target[1]))
  88. })
  89. })
  90. })
  91. describe('unzoom', function() {
  92. beforeAll(function() {
  93. args = {
  94. data: {
  95. columns: [['data1', 30, 200, 100, 400, 150, 250]]
  96. },
  97. zoom: {
  98. enabled: true
  99. }
  100. }
  101. })
  102. it('should be unzoomed properly', function() {
  103. var target = [1, 4],
  104. orginal = chart.internal.x.domain(),
  105. domain
  106. chart.zoom(target)
  107. domain = chart.internal.x.domain()
  108. expect(domain[0]).toBe(target[0])
  109. expect(domain[1]).toBe(target[1])
  110. chart.unzoom()
  111. domain = chart.internal.x.domain()
  112. expect(domain[0]).toBe(orginal[0])
  113. expect(domain[1]).toBe(orginal[1])
  114. })
  115. })
  116. })