diff --git a/package.json b/package.json index d5067993..a15c4f44 100644 --- a/package.json +++ b/package.json @@ -56,9 +56,7 @@ "release": "webpack --progress --hide-modules --config ./build/webpack.release.js && cross-env NODE_ENV=production webpack --progress --hide-modules --config ./build/webpack.release.min.js", "prepublishOnly": "yarn run lint && yarn run test && yarn run build" }, - "dependencies": { - "lodash.merge": "^4.6.0" - }, + "dependencies": {}, "peerDependencies": { "chart.js": "2.7.x" }, diff --git a/src/BaseCharts/Bar.js b/src/BaseCharts/Bar.js index a52fd57b..41a0df66 100644 --- a/src/BaseCharts/Bar.js +++ b/src/BaseCharts/Bar.js @@ -1,5 +1,4 @@ import Chart from 'chart.js' -import { mergeOptions } from '../helpers/options' export default { render: function (createElement) { @@ -52,25 +51,6 @@ export default { data () { return { _chart: null, - defaultOptions: { - scales: { - yAxes: [{ - ticks: { - beginAtZero: true - }, - gridLines: { - display: false - } - }], - xAxes: [ { - gridLines: { - display: false - }, - categoryPercentage: 0.5, - barPercentage: 0.2 - }] - } - }, _plugins: this.plugins } }, @@ -80,12 +60,11 @@ export default { this.$data._plugins.push(plugin) }, renderChart (data, options) { - let chartOptions = mergeOptions(this.defaultOptions, options) this.$data._chart = new Chart( this.$refs.canvas.getContext('2d'), { type: 'bar', data: data, - options: chartOptions, + options: options, plugins: this.$data._plugins } ) diff --git a/src/BaseCharts/Bubble.js b/src/BaseCharts/Bubble.js index 14df228a..af104a77 100644 --- a/src/BaseCharts/Bubble.js +++ b/src/BaseCharts/Bubble.js @@ -1,5 +1,4 @@ import Chart from 'chart.js' -import { mergeOptions } from '../helpers/options' export default { render: function (createElement) { @@ -54,25 +53,6 @@ export default { data () { return { _chart: null, - defaultOptions: { - scales: { - yAxes: [{ - ticks: { - beginAtZero: true - }, - gridLines: { - display: false - } - }], - xAxes: [ { - gridLines: { - display: false - }, - categoryPercentage: 0.5, - barPercentage: 0.2 - }] - } - }, _plugins: this.plugins } }, @@ -82,13 +62,11 @@ export default { this.$data._plugins.push(plugin) }, renderChart (data, options) { - let chartOptions = mergeOptions(this.defaultOptions, options) - this.$data._chart = new Chart( this.$refs.canvas.getContext('2d'), { type: 'bubble', data: data, - options: chartOptions, + options: options, plugins: this.$data._plugins } ) diff --git a/src/BaseCharts/Doughnut.js b/src/BaseCharts/Doughnut.js index aaab9c79..d106f907 100644 --- a/src/BaseCharts/Doughnut.js +++ b/src/BaseCharts/Doughnut.js @@ -1,5 +1,4 @@ import Chart from 'chart.js' -import { mergeOptions } from '../helpers/options' export default { render: function (createElement) { @@ -54,8 +53,6 @@ export default { data () { return { _chart: null, - defaultOptions: { - }, _plugins: this.plugins } }, @@ -64,14 +61,13 @@ export default { addPlugin (plugin) { this.$data._plugins.push(plugin) }, - renderChart (data, options) { - let chartOptions = mergeOptions(this.defaultOptions, options) + renderChart (data, options) { this.$data._chart = new Chart( this.$refs.canvas.getContext('2d'), { type: 'doughnut', data: data, - options: chartOptions, + options: options, plugins: this.$data._plugins } ) diff --git a/src/BaseCharts/HorizontalBar.js b/src/BaseCharts/HorizontalBar.js index b9e57d58..af07d880 100644 --- a/src/BaseCharts/HorizontalBar.js +++ b/src/BaseCharts/HorizontalBar.js @@ -1,5 +1,4 @@ import Chart from 'chart.js' -import { mergeOptions } from '../helpers/options' export default { render: function (createElement) { @@ -54,25 +53,6 @@ export default { data () { return { _chart: null, - defaultOptions: { - scales: { - yAxes: [{ - ticks: { - beginAtZero: true - }, - gridLines: { - display: false - } - }], - xAxes: [ { - gridLines: { - display: false - }, - categoryPercentage: 0.5, - barPercentage: 0.2 - }] - } - }, _plugins: this.plugins } }, @@ -81,13 +61,12 @@ export default { addPlugin (plugin) { this.$data._plugins.push(plugin) }, - renderChart (data, options, type) { - let chartOptions = mergeOptions(this.defaultOptions, options) + renderChart (data, options) { this.$data._chart = new Chart( this.$refs.canvas.getContext('2d'), { type: 'horizontalBar', data: data, - options: chartOptions, + options: options, plugins: this.$data._plugins } ) diff --git a/src/BaseCharts/Line.js b/src/BaseCharts/Line.js index 3daa6591..883a4350 100644 --- a/src/BaseCharts/Line.js +++ b/src/BaseCharts/Line.js @@ -1,5 +1,4 @@ import Chart from 'chart.js' -import { mergeOptions } from '../helpers/options' export default { render: function (createElement) { @@ -54,23 +53,6 @@ export default { data () { return { _chart: null, - defaultOptions: { - scales: { - yAxes: [{ - ticks: { - beginAtZero: true - }, - gridLines: { - display: false - } - }], - xAxes: [ { - gridLines: { - display: false - } - }] - } - }, _plugins: this.plugins } }, @@ -80,13 +62,11 @@ export default { this.$data._plugins.push(plugin) }, renderChart (data, options) { - let chartOptions = mergeOptions(this.defaultOptions, options) - this.$data._chart = new Chart( this.$refs.canvas.getContext('2d'), { type: 'line', data: data, - options: chartOptions, + options: options, plugins: this.$data._plugins } ) diff --git a/src/BaseCharts/Pie.js b/src/BaseCharts/Pie.js index 99d7a4f0..e6c61443 100644 --- a/src/BaseCharts/Pie.js +++ b/src/BaseCharts/Pie.js @@ -1,5 +1,4 @@ import Chart from 'chart.js' -import { mergeOptions } from '../helpers/options' export default { render: function (createElement) { @@ -54,8 +53,6 @@ export default { data () { return { _chart: null, - defaultOptions: { - }, _plugins: this.plugins } }, @@ -65,13 +62,11 @@ export default { this.$data._plugins.push(plugin) }, renderChart (data, options) { - let chartOptions = mergeOptions(this.defaultOptions, options) - this.$data._chart = new Chart( this.$refs.canvas.getContext('2d'), { type: 'pie', data: data, - options: chartOptions, + options: options, plugins: this.$data._plugins } ) diff --git a/src/BaseCharts/PolarArea.js b/src/BaseCharts/PolarArea.js index f33b6823..241e2229 100644 --- a/src/BaseCharts/PolarArea.js +++ b/src/BaseCharts/PolarArea.js @@ -1,5 +1,4 @@ import Chart from 'chart.js' -import { mergeOptions } from '../helpers/options' export default { render: function (createElement) { @@ -54,8 +53,6 @@ export default { data () { return { _chart: null, - defaultOptions: { - }, _plugins: this.plugins } }, @@ -65,13 +62,11 @@ export default { this.$data._plugins.push(plugin) }, renderChart (data, options) { - let chartOptions = mergeOptions(this.defaultOptions, options) - this.$data._chart = new Chart( this.$refs.canvas.getContext('2d'), { type: 'polarArea', data: data, - options: chartOptions, + options: options, plugins: this.$data._plugins } ) diff --git a/src/BaseCharts/Radar.js b/src/BaseCharts/Radar.js index e6acd914..ed62e257 100644 --- a/src/BaseCharts/Radar.js +++ b/src/BaseCharts/Radar.js @@ -1,5 +1,4 @@ import Chart from 'chart.js' -import { mergeOptions } from '../helpers/options' export default { render: function (createElement) { @@ -54,8 +53,6 @@ export default { data () { return { _chart: null, - defaultOptions: { - }, _plugins: this.plugins } }, @@ -65,13 +62,11 @@ export default { this.$data._plugins.push(plugin) }, renderChart (data, options) { - let chartOptions = mergeOptions(this.defaultOptions, options) - this.$data._chart = new Chart( this.$refs.canvas.getContext('2d'), { type: 'radar', data: data, - options: chartOptions, + options: options, plugins: this.$data._plugins } ) diff --git a/src/BaseCharts/Scatter.js b/src/BaseCharts/Scatter.js index e29e0cb0..b1b099e8 100644 --- a/src/BaseCharts/Scatter.js +++ b/src/BaseCharts/Scatter.js @@ -1,5 +1,4 @@ import Chart from 'chart.js' -import { mergeOptions } from '../helpers/options' export default { render: function (createElement) { @@ -54,14 +53,6 @@ export default { data () { return { _chart: null, - defaultOptions: { - scales: { - xAxes: [{ - type: 'linear', - position: 'bottom' - }] - } - }, _plugins: this.plugins } }, @@ -71,13 +62,11 @@ export default { this.$data._plugins.push(plugin) }, renderChart (data, options) { - let chartOptions = mergeOptions(this.defaultOptions, options) - this.$data._chart = new Chart( this.$refs.canvas.getContext('2d'), { type: 'scatter', data: data, - options: chartOptions, + options: options, plugins: this.$data._plugins } ) diff --git a/src/examples/App.vue b/src/examples/App.vue index a7da41eb..1107e632 100644 --- a/src/examples/App.vue +++ b/src/examples/App.vue @@ -5,6 +5,11 @@ +
+

Horizontal Barchart

+ +
+

Barchart with reactive mixing for live data

@@ -63,6 +68,7 @@ import ReactiveExample from './ReactiveExample' import ReactivePropExample from './ReactivePropExample' import ScatterExample from './ScatterExample' + import HorizontalBarExample from './HorizontalBarExample' export default { components: { @@ -75,7 +81,8 @@ BubbleExample, ReactiveExample, ReactivePropExample, - ScatterExample + ScatterExample, + HorizontalBarExample }, data () { return { diff --git a/src/helpers/options.js b/src/helpers/options.js deleted file mode 100644 index ccae2338..00000000 --- a/src/helpers/options.js +++ /dev/null @@ -1,5 +0,0 @@ -import merge from 'lodash.merge' - -export function mergeOptions (obj, src) { - return merge(obj, src) -} diff --git a/test/unit/specs/helpers/options.spec.js b/test/unit/specs/helpers/options.spec.js deleted file mode 100644 index 8e2f90e3..00000000 --- a/test/unit/specs/helpers/options.spec.js +++ /dev/null @@ -1,54 +0,0 @@ -import { mergeOptions } from '@/helpers/options' - -describe('mergeOptions.js', () => { - const a = { - a: 'a', - b: 'a' - } - - const b = { - a: 'b', - b: 'b' - } - - const c = { - c: 'c' - } - - const an = { - a: { - a: 'a' - }, - b: { - b: 'a' - } - } - - const bn = { - a: { - a: 'a' - }, - b: { - b: 'b' - } - } - - it('should replace old a and b if a and b are new', () => { - const ab = mergeOptions(a, b) - expect(ab).to.have.property('a').and.to.equal('b') - expect(ab).to.have.property('b').and.to.equal('b') - }) - - it('should add c if c is new', () => { - const ac = mergeOptions(a, c) - expect(ac).to.have.property('a').and.to.equal('b') - expect(ac).to.have.property('b').and.to.equal('b') - expect(ac).to.have.property('c').and.to.equal('c') - }) - - it('should replace old a and b if a and b are new in nested objects', () => { - const ab = mergeOptions(an, bn) - expect(ab).to.have.deep.property('a.a').and.to.equal('a') - expect(ab).to.have.deep.property('b.b').and.to.equal('b') - }) -}) diff --git a/test/unit/specs/mixins/reactiveData.js b/test/unit/specs/mixins/reactiveData.js deleted file mode 100644 index e69de29b..00000000 diff --git a/yarn.lock b/yarn.lock index 7acbcb99..3b4f77a1 100644 --- a/yarn.lock +++ b/yarn.lock @@ -4014,10 +4014,6 @@ lodash.memoize@^4.1.2: version "4.1.2" resolved "https://registry.yarnpkg.com/lodash.memoize/-/lodash.memoize-4.1.2.tgz#bcc6c49a42a2840ed997f323eada5ecd182e0bfe" -lodash.merge@^4.6.0: - version "4.6.0" - resolved "https://registry.yarnpkg.com/lodash.merge/-/lodash.merge-4.6.0.tgz#69884ba144ac33fe699737a6086deffadd0f89c5" - lodash.mergewith@^4.0.0: version "4.6.0" resolved "https://registry.yarnpkg.com/lodash.mergewith/-/lodash.mergewith-4.6.0.tgz#150cf0a16791f5903b8891eab154609274bdea55"