Compare commits
126 Commits
v2.6.4
...
feature/re
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
ac5d4d824c | ||
|
|
db0040e613 | ||
|
|
3b46bc8f03 | ||
|
|
39ff839d92 | ||
|
|
0506b4ee35 | ||
|
|
072724fc6f | ||
|
|
dd9a5b855d | ||
|
|
5486560257 | ||
|
|
ae13d71081 | ||
|
|
1902bf0b0e | ||
|
|
b0ad387856 | ||
|
|
b7074e428f | ||
|
|
d9e5d5a5f0 | ||
|
|
a5f112e952 | ||
|
|
6e24da3c90 | ||
|
|
2f0ab67b79 | ||
|
|
474b58196e | ||
|
|
d104e628e2 | ||
|
|
b17602d041 | ||
|
|
0b50728b28 | ||
|
|
9abdaa9f66 | ||
|
|
f19c6a4cfa | ||
|
|
d2f2374d7d | ||
|
|
d11eb27bc1 | ||
|
|
50130a7a4d | ||
|
|
05d69520af | ||
|
|
b465070a7a | ||
|
|
d498b7c8cf | ||
|
|
0fa8261664 | ||
|
|
653b4d7580 | ||
|
|
8b52bae9c1 | ||
|
|
b8012b9944 | ||
|
|
4b363b3e29 | ||
|
|
b46d193caf | ||
|
|
831a70574f | ||
|
|
a6593910ac | ||
|
|
892c5ed2ab | ||
|
|
3451769a65 | ||
|
|
7e5bf7d9bc | ||
|
|
58523d6155 | ||
|
|
b71cd6c2eb | ||
|
|
3fea6f413b | ||
|
|
fcd9071f9a | ||
|
|
37a92813eb | ||
|
|
1260b8aa3b | ||
|
|
644859ce85 | ||
|
|
e4977a6be7 | ||
|
|
41736c840d | ||
|
|
4c37616d00 | ||
|
|
5dc655a47a | ||
|
|
3d291996f6 | ||
|
|
750abb2e88 | ||
|
|
46569a89cb | ||
|
|
932b73a1dc | ||
|
|
0569a9f794 | ||
|
|
154e284528 | ||
|
|
491625b49b | ||
|
|
d26078f08c | ||
|
|
6de69631b3 | ||
|
|
82712948e9 | ||
|
|
9237fa538f | ||
|
|
82c502cf45 | ||
|
|
676a60a363 | ||
|
|
f60f87c141 | ||
|
|
b7f2bf7db2 | ||
|
|
0e419886b1 | ||
|
|
f95ea49a19 | ||
|
|
1e392091ea | ||
|
|
4bf4f5736c | ||
|
|
703a91dafa | ||
|
|
d68af61dce | ||
|
|
0fbdcc10b0 | ||
|
|
ab31dfe727 | ||
|
|
a5b58c3b98 | ||
|
|
85fafd9b58 | ||
|
|
54d85da955 | ||
|
|
60f87e72ae | ||
|
|
896b7ddfa3 | ||
|
|
6d19370687 | ||
|
|
c9bc36ee59 | ||
|
|
7e52380bd4 | ||
|
|
32229fbfdd | ||
|
|
e0c771f3d3 | ||
|
|
57cff76747 | ||
|
|
79c138d65a | ||
|
|
64c6cedd74 | ||
|
|
188ab83989 | ||
|
|
d9f53e6ef4 | ||
|
|
7d1dacf77c | ||
|
|
67c01133d0 | ||
|
|
ab9721b577 | ||
|
|
71bcafa804 | ||
|
|
882bdd86b8 | ||
|
|
4f7dda3c3b | ||
|
|
f04441ab36 | ||
|
|
acb3d5c823 | ||
|
|
92bac84dae | ||
|
|
85e946dbe1 | ||
|
|
640ce5c932 | ||
|
|
ef77c0d831 | ||
|
|
a996049a6b | ||
|
|
4109fb30f3 | ||
|
|
b23ce23015 | ||
|
|
7f62914edb | ||
|
|
677c53d9fe | ||
|
|
3e423fd7ae | ||
|
|
362639c4e2 | ||
|
|
ef127686cd | ||
|
|
0a483946bc | ||
|
|
ba5cedc981 | ||
|
|
9b8e961d1c | ||
|
|
d304a2c5ab | ||
|
|
80799b7bd5 | ||
|
|
9d44758976 | ||
|
|
e8cbef7fa7 | ||
|
|
a2b023d226 | ||
|
|
7a048a07df | ||
|
|
10535095be | ||
|
|
0b12e0f8b7 | ||
|
|
43bada7b15 | ||
|
|
6736715895 | ||
|
|
5d159e7841 | ||
|
|
c22bd65a8e | ||
|
|
030ba0c035 | ||
|
|
ab3321001b | ||
|
|
0f6e04cd5e |
13
.babelrc
@@ -1,5 +1,14 @@
|
|||||||
{
|
{
|
||||||
"presets": ["es2015", "stage-2"],
|
"presets": [
|
||||||
"plugins": ["transform-runtime"],
|
["@babel/preset-env", {
|
||||||
|
"modules": false,
|
||||||
|
"targets": {
|
||||||
|
"browsers": [
|
||||||
|
"last 2 versions"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}],
|
||||||
|
"@babel/stage-2"
|
||||||
|
],
|
||||||
"comments": false
|
"comments": false
|
||||||
}
|
}
|
||||||
|
|||||||
18
.codeclimate.yml
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
engines:
|
||||||
|
eslint:
|
||||||
|
enabled: true
|
||||||
|
duplication:
|
||||||
|
enabled: true
|
||||||
|
config:
|
||||||
|
languages:
|
||||||
|
- javascript:
|
||||||
|
ratings:
|
||||||
|
paths:
|
||||||
|
- "**.js"
|
||||||
|
exclude_paths:
|
||||||
|
- "dist/"
|
||||||
|
- "test/**/*"
|
||||||
|
- "es/"
|
||||||
|
- "build/"
|
||||||
|
- "config/"
|
||||||
|
- "src/examples/**"
|
||||||
1
.gitignore
vendored
@@ -4,5 +4,4 @@ npm-debug.log
|
|||||||
selenium-debug.log
|
selenium-debug.log
|
||||||
test/unit/coverage
|
test/unit/coverage
|
||||||
test/e2e/reports
|
test/e2e/reports
|
||||||
dist/
|
|
||||||
es/
|
es/
|
||||||
|
|||||||
279
CHANGELOG.md
@@ -1,5 +1,282 @@
|
|||||||
# Change Log
|
# Change Log
|
||||||
|
|
||||||
|
## [v3.0.1](https://github.com/apertureless/vue-chartjs/tree/v3.0.1) (2017-11-06)
|
||||||
|
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v3.0.0...v3.0.1)
|
||||||
|
|
||||||
|
**Closed issues:**
|
||||||
|
|
||||||
|
- \[Suggestion\]Loose package dependencies [\#245](https://github.com/apertureless/vue-chartjs/issues/245)
|
||||||
|
- reactiveData mixin [\#244](https://github.com/apertureless/vue-chartjs/issues/244)
|
||||||
|
- Customise individual Axis Labels [\#243](https://github.com/apertureless/vue-chartjs/issues/243)
|
||||||
|
- presets es2015 [\#242](https://github.com/apertureless/vue-chartjs/issues/242)
|
||||||
|
- Uncaught TypeError: Cannot read property 'transition' of null [\#241](https://github.com/apertureless/vue-chartjs/issues/241)
|
||||||
|
- Is it possible to create an callback on the onAnimationComplete option [\#240](https://github.com/apertureless/vue-chartjs/issues/240)
|
||||||
|
- When resizing window, chart returns to first loaded state [\#239](https://github.com/apertureless/vue-chartjs/issues/239)
|
||||||
|
- Reactively change chart properties [\#237](https://github.com/apertureless/vue-chartjs/issues/237)
|
||||||
|
- how to enforce the max value on y axis [\#236](https://github.com/apertureless/vue-chartjs/issues/236)
|
||||||
|
- Chart is not rendered when maintainAspectRatio is set to false and chart container is hidden [\#235](https://github.com/apertureless/vue-chartjs/issues/235)
|
||||||
|
- How to access Chart.defaults.global [\#234](https://github.com/apertureless/vue-chartjs/issues/234)
|
||||||
|
- Blank Chart - no data [\#233](https://github.com/apertureless/vue-chartjs/issues/233)
|
||||||
|
- Maxin with multiple chartData [\#231](https://github.com/apertureless/vue-chartjs/issues/231)
|
||||||
|
- How to destroy chart before re-rendering? [\#230](https://github.com/apertureless/vue-chartjs/issues/230)
|
||||||
|
- chnage gridlines color [\#228](https://github.com/apertureless/vue-chartjs/issues/228)
|
||||||
|
- Stacked bar chart? [\#226](https://github.com/apertureless/vue-chartjs/issues/226)
|
||||||
|
- Chart crashes when reentering page [\#223](https://github.com/apertureless/vue-chartjs/issues/223)
|
||||||
|
- 在图表上左右滑动会出现数据错乱的问题 [\#222](https://github.com/apertureless/vue-chartjs/issues/222)
|
||||||
|
- How do I set the scale of the Y axis? [\#220](https://github.com/apertureless/vue-chartjs/issues/220)
|
||||||
|
- Upgrading from 2.8.2 to 2.8.3 breaks charts [\#209](https://github.com/apertureless/vue-chartjs/issues/209)
|
||||||
|
- How to scale the radius property of each bubble in a vue-chartjs bubble chart [\#205](https://github.com/apertureless/vue-chartjs/issues/205)
|
||||||
|
- Last release is causing problems with Firefox [\#203](https://github.com/apertureless/vue-chartjs/issues/203)
|
||||||
|
- 🔥 Remove Vue.extend\(\) [\#201](https://github.com/apertureless/vue-chartjs/issues/201)
|
||||||
|
- Update to webpack@3 [\#134](https://github.com/apertureless/vue-chartjs/issues/134)
|
||||||
|
|
||||||
|
**Merged pull requests:**
|
||||||
|
|
||||||
|
- Feature/dependency and build fix [\#246](https://github.com/apertureless/vue-chartjs/pull/246) ([apertureless](https://github.com/apertureless))
|
||||||
|
- Typo fix in EN docs [\#238](https://github.com/apertureless/vue-chartjs/pull/238) ([chakan](https://github.com/chakan))
|
||||||
|
- Made some small edits to French README.MD [\#232](https://github.com/apertureless/vue-chartjs/pull/232) ([music-mind](https://github.com/music-mind))
|
||||||
|
- update webpack to version 3 [\#227](https://github.com/apertureless/vue-chartjs/pull/227) ([kingkong64](https://github.com/kingkong64))
|
||||||
|
|
||||||
|
## [v3.0.0](https://github.com/apertureless/vue-chartjs/tree/v3.0.0) (2017-10-14)
|
||||||
|
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v2.8.7...v3.0.0)
|
||||||
|
|
||||||
|
**Closed issues:**
|
||||||
|
|
||||||
|
- Create an image of the chart to download [\#219](https://github.com/apertureless/vue-chartjs/issues/219)
|
||||||
|
- How to achieve this effect? [\#218](https://github.com/apertureless/vue-chartjs/issues/218)
|
||||||
|
- Some Error [\#217](https://github.com/apertureless/vue-chartjs/issues/217)
|
||||||
|
- Avoid mutating a prop directly since the value will be overwritten whenever the parent component re-renders. Instead, use a data or computed property based on the prop's value. Prop being mutated: "chartData" [\#216](https://github.com/apertureless/vue-chartjs/issues/216)
|
||||||
|
- can't get legendCallback to fire at all [\#212](https://github.com/apertureless/vue-chartjs/issues/212)
|
||||||
|
- this demo is not support, is it because version older? [\#210](https://github.com/apertureless/vue-chartjs/issues/210)
|
||||||
|
- how to change value without reload?? [\#208](https://github.com/apertureless/vue-chartjs/issues/208)
|
||||||
|
- typescript definition? [\#207](https://github.com/apertureless/vue-chartjs/issues/207)
|
||||||
|
- 使用动态数据时报错 [\#204](https://github.com/apertureless/vue-chartjs/issues/204)
|
||||||
|
- Commit the final dist js files to github [\#202](https://github.com/apertureless/vue-chartjs/issues/202)
|
||||||
|
- \[Best Practices❓\] Usage of Private Data [\#182](https://github.com/apertureless/vue-chartjs/issues/182)
|
||||||
|
- 📝 Update docs & examples - SSR with nuxt [\#172](https://github.com/apertureless/vue-chartjs/issues/172)
|
||||||
|
- 📝 Update Docs - Section about extending [\#171](https://github.com/apertureless/vue-chartjs/issues/171)
|
||||||
|
- Register vue-chartjs as vue-plugin? [\#168](https://github.com/apertureless/vue-chartjs/issues/168)
|
||||||
|
- Avoid mutating a prop directly since the value will be overwritten whenever the parent component re-renders [\#151](https://github.com/apertureless/vue-chartjs/issues/151)
|
||||||
|
|
||||||
|
**Merged pull requests:**
|
||||||
|
|
||||||
|
- Feature/v3 [\#225](https://github.com/apertureless/vue-chartjs/pull/225) ([apertureless](https://github.com/apertureless))
|
||||||
|
- ✏️ Spelling in docs [\#215](https://github.com/apertureless/vue-chartjs/pull/215) ([cugu](https://github.com/cugu))
|
||||||
|
- Fix inaccuracies in Russian translation [\#214](https://github.com/apertureless/vue-chartjs/pull/214) ([pushkyn](https://github.com/pushkyn))
|
||||||
|
- Add id docs readme support [\#213](https://github.com/apertureless/vue-chartjs/pull/213) ([tesarwijaya](https://github.com/tesarwijaya))
|
||||||
|
- French translation for README.md [\#211](https://github.com/apertureless/vue-chartjs/pull/211) ([julienc91](https://github.com/julienc91))
|
||||||
|
|
||||||
|
## [v2.8.7](https://github.com/apertureless/vue-chartjs/tree/v2.8.7) (2017-09-16)
|
||||||
|
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v2.8.6...v2.8.7)
|
||||||
|
|
||||||
|
**Closed issues:**
|
||||||
|
|
||||||
|
- 真机和浏览器呈现的效果不一样的问题 [\#199](https://github.com/apertureless/vue-chartjs/issues/199)
|
||||||
|
- can not use npm install? [\#198](https://github.com/apertureless/vue-chartjs/issues/198)
|
||||||
|
- Reactive Props - Max Call Stack Exceeded Error [\#197](https://github.com/apertureless/vue-chartjs/issues/197)
|
||||||
|
- Unmet Peer Dependency [\#196](https://github.com/apertureless/vue-chartjs/issues/196)
|
||||||
|
- Is there a way to update options? [\#195](https://github.com/apertureless/vue-chartjs/issues/195)
|
||||||
|
- deepmerge [\#194](https://github.com/apertureless/vue-chartjs/issues/194)
|
||||||
|
- TypeError: Cannot convert undefined or null to object [\#193](https://github.com/apertureless/vue-chartjs/issues/193)
|
||||||
|
|
||||||
|
## [v2.8.6](https://github.com/apertureless/vue-chartjs/tree/v2.8.6) (2017-09-12)
|
||||||
|
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v2.8.5...v2.8.6)
|
||||||
|
|
||||||
|
## [v2.8.5](https://github.com/apertureless/vue-chartjs/tree/v2.8.5) (2017-09-12)
|
||||||
|
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v2.8.4...v2.8.5)
|
||||||
|
|
||||||
|
**Closed issues:**
|
||||||
|
|
||||||
|
- Chart error since the addition of deepmerge in build 2.8.4 [\#192](https://github.com/apertureless/vue-chartjs/issues/192)
|
||||||
|
|
||||||
|
## [v2.8.4](https://github.com/apertureless/vue-chartjs/tree/v2.8.4) (2017-09-08)
|
||||||
|
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v2.8.3...v2.8.4)
|
||||||
|
|
||||||
|
**Closed issues:**
|
||||||
|
|
||||||
|
- Regression in 2.8.3 [\#190](https://github.com/apertureless/vue-chartjs/issues/190)
|
||||||
|
- Why default Chart.js styles are overridden? [\#189](https://github.com/apertureless/vue-chartjs/issues/189)
|
||||||
|
- Legend or other options not working in reactiveProps [\#188](https://github.com/apertureless/vue-chartjs/issues/188)
|
||||||
|
- Changes to yAxisID property does not re-render chart [\#177](https://github.com/apertureless/vue-chartjs/issues/177)
|
||||||
|
|
||||||
|
**Merged pull requests:**
|
||||||
|
|
||||||
|
- Replace Object.assign with deepmerge [\#191](https://github.com/apertureless/vue-chartjs/pull/191) ([apertureless](https://github.com/apertureless))
|
||||||
|
|
||||||
|
## [v2.8.3](https://github.com/apertureless/vue-chartjs/tree/v2.8.3) (2017-09-06)
|
||||||
|
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v2.8.2...v2.8.3)
|
||||||
|
|
||||||
|
**Closed issues:**
|
||||||
|
|
||||||
|
- Rounded corner for Bar chart [\#185](https://github.com/apertureless/vue-chartjs/issues/185)
|
||||||
|
- Access canvas object from parents [\#184](https://github.com/apertureless/vue-chartjs/issues/184)
|
||||||
|
- Issue with DonutChart in Safari [\#183](https://github.com/apertureless/vue-chartjs/issues/183)
|
||||||
|
- Responsive Width, Fixed Height [\#180](https://github.com/apertureless/vue-chartjs/issues/180)
|
||||||
|
- Entire Lodash Library Is Loaded!! 200kb chunk! [\#179](https://github.com/apertureless/vue-chartjs/issues/179)
|
||||||
|
- height changed unexpectedly after re-rendering [\#178](https://github.com/apertureless/vue-chartjs/issues/178)
|
||||||
|
- Default height no longer working in 2.8 [\#176](https://github.com/apertureless/vue-chartjs/issues/176)
|
||||||
|
- how to get click on point in bar chart? [\#175](https://github.com/apertureless/vue-chartjs/issues/175)
|
||||||
|
- clean install of from npm cannot be used in gulp / browserify [\#174](https://github.com/apertureless/vue-chartjs/issues/174)
|
||||||
|
- tooltip callbacks possible? [\#173](https://github.com/apertureless/vue-chartjs/issues/173)
|
||||||
|
- Computed object won't populate chart [\#170](https://github.com/apertureless/vue-chartjs/issues/170)
|
||||||
|
- Error in nextTick: "RangeError: Maximum call stack size exceeded" [\#169](https://github.com/apertureless/vue-chartjs/issues/169)
|
||||||
|
- Standalone chartjs build \(don't include moment.js\) [\#124](https://github.com/apertureless/vue-chartjs/issues/124)
|
||||||
|
|
||||||
|
**Merged pull requests:**
|
||||||
|
|
||||||
|
- 🔥 Remove default styles object as it causes problems [\#187](https://github.com/apertureless/vue-chartjs/pull/187) ([apertureless](https://github.com/apertureless))
|
||||||
|
- remvove lodash merge [\#186](https://github.com/apertureless/vue-chartjs/pull/186) ([apertureless](https://github.com/apertureless))
|
||||||
|
|
||||||
|
## [v2.8.2](https://github.com/apertureless/vue-chartjs/tree/v2.8.2) (2017-08-12)
|
||||||
|
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v2.8.1...v2.8.2)
|
||||||
|
|
||||||
|
**Closed issues:**
|
||||||
|
|
||||||
|
- UNMET PEER DEPENDENCY [\#167](https://github.com/apertureless/vue-chartjs/issues/167)
|
||||||
|
- Base Charts' height: 200% [\#164](https://github.com/apertureless/vue-chartjs/issues/164)
|
||||||
|
|
||||||
|
**Merged pull requests:**
|
||||||
|
|
||||||
|
- Add support for xLabels and yLabels [\#166](https://github.com/apertureless/vue-chartjs/pull/166) ([dsbert](https://github.com/dsbert))
|
||||||
|
- Update README.md [\#165](https://github.com/apertureless/vue-chartjs/pull/165) ([mikeybeck](https://github.com/mikeybeck))
|
||||||
|
|
||||||
|
## [v2.8.1](https://github.com/apertureless/vue-chartjs/tree/v2.8.1) (2017-08-05)
|
||||||
|
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v2.8.0...v2.8.1)
|
||||||
|
|
||||||
|
**Merged pull requests:**
|
||||||
|
|
||||||
|
- Add Russian documentation [\#163](https://github.com/apertureless/vue-chartjs/pull/163) ([dood-](https://github.com/dood-))
|
||||||
|
|
||||||
|
## [v2.8.0](https://github.com/apertureless/vue-chartjs/tree/v2.8.0) (2017-08-04)
|
||||||
|
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v1.2.0...v2.8.0)
|
||||||
|
|
||||||
|
**Closed issues:**
|
||||||
|
|
||||||
|
- Update README CDN link [\#161](https://github.com/apertureless/vue-chartjs/issues/161)
|
||||||
|
- Options being ignored [\#160](https://github.com/apertureless/vue-chartjs/issues/160)
|
||||||
|
- Fails to dynamically change height. [\#158](https://github.com/apertureless/vue-chartjs/issues/158)
|
||||||
|
- Chart doesn't load in bootstrap tab [\#157](https://github.com/apertureless/vue-chartjs/issues/157)
|
||||||
|
- Add scatter chart to vue-chatjs@legacy [\#155](https://github.com/apertureless/vue-chartjs/issues/155)
|
||||||
|
- \[Error\] Get error when $destroy is started. [\#149](https://github.com/apertureless/vue-chartjs/issues/149)
|
||||||
|
|
||||||
|
**Merged pull requests:**
|
||||||
|
|
||||||
|
- Feature/dynamic styles [\#162](https://github.com/apertureless/vue-chartjs/pull/162) ([apertureless](https://github.com/apertureless))
|
||||||
|
- Add Chinese simplified docs support. [\#159](https://github.com/apertureless/vue-chartjs/pull/159) ([Mooooooon](https://github.com/Mooooooon))
|
||||||
|
|
||||||
|
## [v1.2.0](https://github.com/apertureless/vue-chartjs/tree/v1.2.0) (2017-07-25)
|
||||||
|
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v2.7.2...v1.2.0)
|
||||||
|
|
||||||
|
**Closed issues:**
|
||||||
|
|
||||||
|
- this.$refs doesn't seem to have expected canvas property [\#156](https://github.com/apertureless/vue-chartjs/issues/156)
|
||||||
|
|
||||||
|
**Merged pull requests:**
|
||||||
|
|
||||||
|
- Before destroy fix [\#152](https://github.com/apertureless/vue-chartjs/pull/152) ([DenisLapi](https://github.com/DenisLapi))
|
||||||
|
|
||||||
|
## [v2.7.2](https://github.com/apertureless/vue-chartjs/tree/v2.7.2) (2017-07-22)
|
||||||
|
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v2.7.1...v2.7.2)
|
||||||
|
|
||||||
|
**Closed issues:**
|
||||||
|
|
||||||
|
- Accessibility - Add unique titles to frames [\#150](https://github.com/apertureless/vue-chartjs/issues/150)
|
||||||
|
- update\(\) not refreshing chart [\#148](https://github.com/apertureless/vue-chartjs/issues/148)
|
||||||
|
- Custome label y axis [\#147](https://github.com/apertureless/vue-chartjs/issues/147)
|
||||||
|
- Access specific points on the canvas and labels for styling [\#146](https://github.com/apertureless/vue-chartjs/issues/146)
|
||||||
|
- legendCallback\(\) doesn't render a custom legend [\#144](https://github.com/apertureless/vue-chartjs/issues/144)
|
||||||
|
- where can i get the demo sources code? thanks [\#143](https://github.com/apertureless/vue-chartjs/issues/143)
|
||||||
|
- Props not works as expected, updating of value doesn't work [\#138](https://github.com/apertureless/vue-chartjs/issues/138)
|
||||||
|
|
||||||
|
**Merged pull requests:**
|
||||||
|
|
||||||
|
- ⬆️ Update dependency vue to 2.4.2 [\#154](https://github.com/apertureless/vue-chartjs/pull/154) ([apertureless](https://github.com/apertureless))
|
||||||
|
- Remove useless labels [\#153](https://github.com/apertureless/vue-chartjs/pull/153) ([clarkdo](https://github.com/clarkdo))
|
||||||
|
- :pencil2: Remove generateLegend\(\) from initialization codes [\#145](https://github.com/apertureless/vue-chartjs/pull/145) ([k-rumi](https://github.com/k-rumi))
|
||||||
|
|
||||||
|
## [v2.7.1](https://github.com/apertureless/vue-chartjs/tree/v2.7.1) (2017-07-05)
|
||||||
|
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v2.7.0...v2.7.1)
|
||||||
|
|
||||||
|
**Closed issues:**
|
||||||
|
|
||||||
|
- Default backgroundColor needed [\#142](https://github.com/apertureless/vue-chartjs/issues/142)
|
||||||
|
|
||||||
|
**Merged pull requests:**
|
||||||
|
|
||||||
|
- Fix links to images in translated documents [\#141](https://github.com/apertureless/vue-chartjs/pull/141) ([k-rumi](https://github.com/k-rumi))
|
||||||
|
|
||||||
|
## [v2.7.0](https://github.com/apertureless/vue-chartjs/tree/v2.7.0) (2017-07-04)
|
||||||
|
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v2.6.5...v2.7.0)
|
||||||
|
|
||||||
|
**Closed issues:**
|
||||||
|
|
||||||
|
- Reactive Data Tutorial [\#132](https://github.com/apertureless/vue-chartjs/issues/132)
|
||||||
|
- Using inline plugins [\#130](https://github.com/apertureless/vue-chartjs/issues/130)
|
||||||
|
- Scatter Chart [\#129](https://github.com/apertureless/vue-chartjs/issues/129)
|
||||||
|
- Generating Chart after clicking submit button [\#128](https://github.com/apertureless/vue-chartjs/issues/128)
|
||||||
|
- Ticks not working with reactive props [\#127](https://github.com/apertureless/vue-chartjs/issues/127)
|
||||||
|
- Error in callback for watcher "chartData": "TypeError: Cannot read property 'data' of undefined" [\#126](https://github.com/apertureless/vue-chartjs/issues/126)
|
||||||
|
- Passing the data from vue to chartjs [\#125](https://github.com/apertureless/vue-chartjs/issues/125)
|
||||||
|
- Combination of Bar and Line Chart [\#123](https://github.com/apertureless/vue-chartjs/issues/123)
|
||||||
|
- Reactive data example not working [\#122](https://github.com/apertureless/vue-chartjs/issues/122)
|
||||||
|
- vue-chartjs height was 0 when i set v-show [\#120](https://github.com/apertureless/vue-chartjs/issues/120)
|
||||||
|
- Bar chart, barPercentage in X axis [\#119](https://github.com/apertureless/vue-chartjs/issues/119)
|
||||||
|
- update event not firing on data change [\#118](https://github.com/apertureless/vue-chartjs/issues/118)
|
||||||
|
|
||||||
|
**Merged pull requests:**
|
||||||
|
|
||||||
|
- ✅ Update tests for addPlugin method [\#140](https://github.com/apertureless/vue-chartjs/pull/140) ([apertureless](https://github.com/apertureless))
|
||||||
|
- Fix beforeDestory when renderChart was not called [\#139](https://github.com/apertureless/vue-chartjs/pull/139) ([ZhangYiJiang](https://github.com/ZhangYiJiang))
|
||||||
|
- Add support for inline plugins [\#137](https://github.com/apertureless/vue-chartjs/pull/137) ([kurbar](https://github.com/kurbar))
|
||||||
|
- Feature/scatter chart [\#136](https://github.com/apertureless/vue-chartjs/pull/136) ([apertureless](https://github.com/apertureless))
|
||||||
|
- 🐛 Fix \#122 reactive mixin [\#135](https://github.com/apertureless/vue-chartjs/pull/135) ([apertureless](https://github.com/apertureless))
|
||||||
|
- 📝 Add resources & tutorials to docs [\#133](https://github.com/apertureless/vue-chartjs/pull/133) ([apertureless](https://github.com/apertureless))
|
||||||
|
- fix a typo in an example [\#131](https://github.com/apertureless/vue-chartjs/pull/131) ([JobV](https://github.com/JobV))
|
||||||
|
- Update README [\#121](https://github.com/apertureless/vue-chartjs/pull/121) ([stoykostanchev](https://github.com/stoykostanchev))
|
||||||
|
|
||||||
|
## [v2.6.5](https://github.com/apertureless/vue-chartjs/tree/v2.6.5) (2017-06-10)
|
||||||
|
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v2.6.4...v2.6.5)
|
||||||
|
|
||||||
|
## [v2.6.4](https://github.com/apertureless/vue-chartjs/tree/v2.6.4) (2017-06-04)
|
||||||
|
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v2.6.3...v2.6.4)
|
||||||
|
|
||||||
|
**Closed issues:**
|
||||||
|
|
||||||
|
- Transition leave-active-class not working [\#117](https://github.com/apertureless/vue-chartjs/issues/117)
|
||||||
|
- chartOptions reactivity [\#116](https://github.com/apertureless/vue-chartjs/issues/116)
|
||||||
|
- Cannot switch off legend [\#114](https://github.com/apertureless/vue-chartjs/issues/114)
|
||||||
|
- run error on my mac pro [\#113](https://github.com/apertureless/vue-chartjs/issues/113)
|
||||||
|
- Update install instructions in docs [\#112](https://github.com/apertureless/vue-chartjs/issues/112)
|
||||||
|
- Typo in docs [\#111](https://github.com/apertureless/vue-chartjs/issues/111)
|
||||||
|
- Charts are given a fixed width, even when they are set to be responsive [\#108](https://github.com/apertureless/vue-chartjs/issues/108)
|
||||||
|
- Use Reactive Data with \<script\> version of vue-chartjs [\#107](https://github.com/apertureless/vue-chartjs/issues/107)
|
||||||
|
|
||||||
|
**Merged pull requests:**
|
||||||
|
|
||||||
|
- Fix typo in docs [\#115](https://github.com/apertureless/vue-chartjs/pull/115) ([euledge](https://github.com/euledge))
|
||||||
|
- :memo: Add pt-br readme support [\#110](https://github.com/apertureless/vue-chartjs/pull/110) ([kimuraz](https://github.com/kimuraz))
|
||||||
|
- Fix reactive mixins animation re-rendering issue. [\#109](https://github.com/apertureless/vue-chartjs/pull/109) ([MuseofMoose](https://github.com/MuseofMoose))
|
||||||
|
|
||||||
|
## [v2.6.3](https://github.com/apertureless/vue-chartjs/tree/v2.6.3) (2017-05-14)
|
||||||
|
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v2.6.2...v2.6.3)
|
||||||
|
|
||||||
|
**Closed issues:**
|
||||||
|
|
||||||
|
- Reactivity of Options [\#106](https://github.com/apertureless/vue-chartjs/issues/106)
|
||||||
|
- Do not use built-in or reserved HTML elements as component id: MenuItem [\#104](https://github.com/apertureless/vue-chartjs/issues/104)
|
||||||
|
- Is it possible to use with axios? [\#103](https://github.com/apertureless/vue-chartjs/issues/103)
|
||||||
|
- How to change momentjs locale for time scale? [\#101](https://github.com/apertureless/vue-chartjs/issues/101)
|
||||||
|
- It seems that the reactiveProp couldn't let the chart update itself [\#99](https://github.com/apertureless/vue-chartjs/issues/99)
|
||||||
|
- vue-chartjs not working with lodash-webpack-plugin installed [\#97](https://github.com/apertureless/vue-chartjs/issues/97)
|
||||||
|
- multi lines with same options [\#95](https://github.com/apertureless/vue-chartjs/issues/95)
|
||||||
|
- Zoom And Pan Options in Vue Charts [\#94](https://github.com/apertureless/vue-chartjs/issues/94)
|
||||||
|
|
||||||
|
**Merged pull requests:**
|
||||||
|
|
||||||
|
- Update README.md [\#105](https://github.com/apertureless/vue-chartjs/pull/105) ([guilherfp](https://github.com/guilherfp))
|
||||||
|
- translated README.md into Japanese [\#102](https://github.com/apertureless/vue-chartjs/pull/102) ([euledge](https://github.com/euledge))
|
||||||
|
- add CDNJS version badge in README.md [\#100](https://github.com/apertureless/vue-chartjs/pull/100) ([extend1994](https://github.com/extend1994))
|
||||||
|
|
||||||
## [v2.6.2](https://github.com/apertureless/vue-chartjs/tree/v2.6.2) (2017-04-29)
|
## [v2.6.2](https://github.com/apertureless/vue-chartjs/tree/v2.6.2) (2017-04-29)
|
||||||
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v2.6.1...v2.6.2)
|
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v2.6.1...v2.6.2)
|
||||||
|
|
||||||
@@ -80,7 +357,7 @@
|
|||||||
|
|
||||||
**Merged pull requests:**
|
**Merged pull requests:**
|
||||||
|
|
||||||
- Update dependencies to enable Greenkeeper 🌴 [\#65](https://github.com/apertureless/vue-chartjs/pull/65) ([greenkeeper[bot]](https://github.com/integration/greenkeeper))
|
- Update dependencies to enable Greenkeeper 🌴 [\#65](https://github.com/apertureless/vue-chartjs/pull/65) ([greenkeeper[bot]](https://github.com/apps/greenkeeper))
|
||||||
|
|
||||||
## [v2.5.3](https://github.com/apertureless/vue-chartjs/tree/v2.5.3) (2017-03-17)
|
## [v2.5.3](https://github.com/apertureless/vue-chartjs/tree/v2.5.3) (2017-03-17)
|
||||||
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v2.5.2...v2.5.3)
|
[Full Changelog](https://github.com/apertureless/vue-chartjs/compare/v2.5.2...v2.5.3)
|
||||||
|
|||||||
92
README.md
@@ -27,9 +27,9 @@
|
|||||||
- v2 later
|
- v2 later
|
||||||
- Vue.js 2.x
|
- Vue.js 2.x
|
||||||
|
|
||||||
After the final release of vue.js 2, you also get the v2 per default if you install vue-chartjs over npm.
|
After the final release of vue.js 2, you also get the v2 by default if you install vue-chartjs over npm.
|
||||||
No need for the @next tag anymore. If you want the v1 you need to define the version or use the legacy tag.
|
No need for the @next tag anymore. If you want the v1 you need to define the version or use the legacy tag.
|
||||||
If you're looking for v1 check this [branch](https://github.com/apertureless/vue-chartjs/tree/release/1.1.3)
|
If you're looking for v1 check this [branch](https://github.com/apertureless/vue-chartjs/tree/release/1.x)
|
||||||
|
|
||||||
## Install
|
## Install
|
||||||
|
|
||||||
@@ -38,44 +38,50 @@ Simply run `yarn add vue-chartjs chart.js`
|
|||||||
Or if you want to use it directly in the browser add
|
Or if you want to use it directly in the browser add
|
||||||
|
|
||||||
```html
|
```html
|
||||||
<script src="https://unpkg.com/vue-chartjs@2.6.0/dist/vue-chartjs.full.min.js"></script>
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.7.1/Chart.min.js"></script>
|
||||||
|
<script src="https://unpkg.com/vue-chartjs/dist/vue-chartjs.min.js"></script>
|
||||||
```
|
```
|
||||||
to your scripts. See [Codepen](https://codepen.io/apertureless/pen/vxWbqB?editors=1010)
|
to your scripts. See [Codepen](https://codepen.io/apertureless/pen/zEvvWM)
|
||||||
|
|
||||||
## Explanation of Different Builds
|
|
||||||
There are three different entry points. It depends on which build setup do you have. The dependencies are bundled or required as a peerDependency.
|
|
||||||
|
|
||||||
- Browser
|
|
||||||
- Browserify / Webpack 1
|
|
||||||
- Webpack 2
|
|
||||||
|
|
||||||
|
|
||||||
| Build | Chart.js | Vue.js |
|
|
||||||
|---|---|---|
|
|
||||||
| vue-chartjs.full.js | Bundled | Bundled |
|
|
||||||
| vue-chartjs.full.min.js | Bundled | Bundled |
|
|
||||||
| vue-chartjs.js | peerDependency | peerDependency |
|
|
||||||
| vue-chartjs.min.js | peerDependency | peerDependency |
|
|
||||||
| es/index* | peerDependency | peerDependency |
|
|
||||||
|
|
||||||
### Browser
|
### Browser
|
||||||
You can use `vue-chartjs` directly in the browser without any build setup. Like in this [codepen](https://codepen.io/apertureless/pen/vxWbqB?editors=1010). For this case, please use the `vue-chartjs.full.min.js` which is the minified version. It has Vue.js and Chart.js bundled into it. And bundled to a UMD Module. So you only need that one file.
|
You can use `vue-chartjs` directly in the browser without any build setup. Like in this [codepen](https://codepen.io/apertureless/pen/zEvvWM). For this case, please use the `vue-chartjs.min.js` which is the minified version. You also need to add the Chart.js CDN script.
|
||||||
|
|
||||||
|
You can then simply register your component:
|
||||||
|
|
||||||
|
```js
|
||||||
|
Vue.component('line-chart', {
|
||||||
|
extends: VueChartJs.Line,
|
||||||
|
mounted () {
|
||||||
|
this.renderChart({
|
||||||
|
labels: ['January', 'February', 'March', 'April', 'May', 'June', 'July'],
|
||||||
|
datasets: [
|
||||||
|
{
|
||||||
|
label: 'Data One',
|
||||||
|
backgroundColor: '#f87979',
|
||||||
|
data: [40, 39, 10, 40, 39, 80, 40]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}, {responsive: true, maintainAspectRatio: false})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
### Browserify / Webpack 1
|
### Browserify / Webpack 1
|
||||||
|
|
||||||
If you're using Gulp, Browserify or Webpack 1 the entry is `vue-chartjs.js` which is __transpiled__ and __bundled__ UMD Module.
|
If you're using Gulp, Browserify or Webpack 1 the entry is `vue-chartjs.js` which is __transpiled__ and __bundled__ UMD Module.
|
||||||
|
|
||||||
However Vue.js and Chart.js are `deerDependencies` so you have to install them seperately. In most projects you will have `Vue.js` already installed anyways. This way, you can have different versions of Vue.js and Chart.js then in this package.
|
However Chart.js is a `peerDependencies` so you have to install it separately. In most projects This way, you can have different versions of Chart.js then in this package.
|
||||||
|
|
||||||
### Webpack 2
|
### Webpack 2
|
||||||
If you're using Webpack 2 it will automatically use the `jsnext:main` / `module` entry point. Which is `es/index.js`
|
If you're using Webpack 2 it will automatically use the `jsnext:main` / `module` entry point. Which is `es/index.js`
|
||||||
It is a __transpiled__ es version of the source. And is not __bundled__ to a module. This way you three shaking will work. Like in the bundled version, `Vue.js` and `Chart.js` are `peerDependencies` and need to be installed.
|
It is a __transpiled__ es version of the source. And is not __bundled__ to a module. This way you tree shaking will work. Like in the bundled version, `Chart.js` is a `peerDependencies` and need to be installed.
|
||||||
|
|
||||||
|
|
||||||
## How to use
|
## How to use
|
||||||
|
|
||||||
You need to import the base chart class and extend it. This gives much more flexibility when working with different data. You can pass the data over props or vue-resource.
|
You need to import the component and then either use `extends` or `mixins` and add it.
|
||||||
|
|
||||||
You can import the whole package or each module individual.
|
You can import the whole package or each module individual.
|
||||||
|
|
||||||
@@ -90,7 +96,8 @@ Just create your own component.
|
|||||||
// CommitChart.js
|
// CommitChart.js
|
||||||
import { Bar } from 'vue-chartjs'
|
import { Bar } from 'vue-chartjs'
|
||||||
|
|
||||||
export default Bar.extend({
|
export default {
|
||||||
|
extends: Bar,
|
||||||
mounted () {
|
mounted () {
|
||||||
// Overwriting base render method with actual data.
|
// Overwriting base render method with actual data.
|
||||||
this.renderChart({
|
this.renderChart({
|
||||||
@@ -104,7 +111,7 @@ export default Bar.extend({
|
|||||||
]
|
]
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
Then simply import and use your own extended component and use it like a normal vue component
|
Then simply import and use your own extended component and use it like a normal vue component
|
||||||
@@ -118,15 +125,16 @@ import CommitChart from 'path/to/component/CommitChart'
|
|||||||
You can overwrite the default chart options. Just pass the options object as a second paramenter to the render method
|
You can overwrite the default chart options. Just pass the options object as a second paramenter to the render method
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
// MonthlyIncome.js
|
// MonthlyIncome.vue
|
||||||
import { Line } from 'vue-chartjs'
|
import { Line } from 'vue-chartjs'
|
||||||
|
|
||||||
export default Line.extend({
|
export default {
|
||||||
|
extends: Line,
|
||||||
props: ['data', 'options'],
|
props: ['data', 'options'],
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart(this.data, this.options)
|
this.renderChart(this.data, this.options)
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
Use it in your vue app
|
Use it in your vue app
|
||||||
@@ -149,7 +157,7 @@ export default {
|
|||||||
## Reactivity
|
## Reactivity
|
||||||
|
|
||||||
Chart.js does not update or re-render the chart if new data is passed.
|
Chart.js does not update or re-render the chart if new data is passed.
|
||||||
However you can simply implement this by your own or use one of the two mixins which are included.
|
However you can simply implement this on your own or use one of the two mixins which are included.
|
||||||
|
|
||||||
- `reactiveProp`
|
- `reactiveProp`
|
||||||
- `reactiveData`
|
- `reactiveData`
|
||||||
@@ -163,13 +171,14 @@ However keep in mind the limitations of vue and javascript for mutations on arra
|
|||||||
// MonthlyIncome.js
|
// MonthlyIncome.js
|
||||||
import { Line, mixins } from 'vue-chartjs'
|
import { Line, mixins } from 'vue-chartjs'
|
||||||
|
|
||||||
export default Line.extend({
|
export default {
|
||||||
|
extends: Line,
|
||||||
mixins: [mixins.reactiveProp],
|
mixins: [mixins.reactiveProp],
|
||||||
props: ['chartData', 'options'],
|
props: ['chartData', 'options'],
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart(this.chartData, this.options)
|
this.renderChart(this.chartData, this.options)
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
@@ -181,26 +190,28 @@ Some ways to import them:
|
|||||||
// Load complete module with all charts
|
// Load complete module with all charts
|
||||||
import VueCharts from 'vue-chartjs'
|
import VueCharts from 'vue-chartjs'
|
||||||
|
|
||||||
export default VueCharts.Line.extend({
|
export default {
|
||||||
|
extends: VueCharts.Line,
|
||||||
mixins: [VueCharts.mixins.reactiveProp],
|
mixins: [VueCharts.mixins.reactiveProp],
|
||||||
props: ['chartData', 'options'],
|
props: ['chartData', 'options'],
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart(this.chartData, this.options)
|
this.renderChart(this.chartData, this.options)
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
// Load speperate modules
|
// Load speperate modules
|
||||||
import { Line, mixins } from 'vue-chartjs'
|
import { Line, mixins } from 'vue-chartjs'
|
||||||
|
|
||||||
export default Line.extend({
|
export default {
|
||||||
|
extends: Line,
|
||||||
mixins: [mixins.reactiveProp],
|
mixins: [mixins.reactiveProp],
|
||||||
props: ['chartData', 'options'],
|
props: ['chartData', 'options'],
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart(this.chartData, this.options)
|
this.renderChart(this.chartData, this.options)
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
@@ -208,13 +219,14 @@ export default Line.extend({
|
|||||||
import { Line, mixins } from 'vue-chartjs'
|
import { Line, mixins } from 'vue-chartjs'
|
||||||
const { reactiveProp } = mixins
|
const { reactiveProp } = mixins
|
||||||
|
|
||||||
export default Line.extend({
|
export default {
|
||||||
|
extends: Line,
|
||||||
mixins: [reactiveProp],
|
mixins: [reactiveProp],
|
||||||
props: ['chartData', 'options'],
|
props: ['chartData', 'options'],
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart(this.chartData, this.options)
|
this.renderChart(this.chartData, this.options)
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
## Available Charts
|
## Available Charts
|
||||||
@@ -247,6 +259,10 @@ export default Line.extend({
|
|||||||
|
|
||||||

|

|
||||||
|
|
||||||
|
### Scatter
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
## Build Setup
|
## Build Setup
|
||||||
|
|
||||||
``` bash
|
``` bash
|
||||||
@@ -269,7 +285,7 @@ npm run e2e
|
|||||||
npm test
|
npm test
|
||||||
```
|
```
|
||||||
|
|
||||||
For detailed explanation on how things work, checkout the [guide](http://vuejs-templates.github.io/webpack/) and [docs for vue-loader](http://vuejs.github.io/vue-loader).
|
For a detailed explanation on how things work, check out the [guide](http://vuejs-templates.github.io/webpack/) and [docs for vue-loader](http://vuejs.github.io/vue-loader).
|
||||||
|
|
||||||
## Contributing
|
## Contributing
|
||||||
|
|
||||||
|
|||||||
BIN
assets/bar.png
Normal file → Executable file
|
Before Width: | Height: | Size: 95 KiB After Width: | Height: | Size: 25 KiB |
BIN
assets/bubble.png
Normal file → Executable file
|
Before Width: | Height: | Size: 83 KiB After Width: | Height: | Size: 26 KiB |
BIN
assets/doughnut.png
Normal file → Executable file
|
Before Width: | Height: | Size: 91 KiB After Width: | Height: | Size: 41 KiB |
BIN
assets/line.png
Normal file → Executable file
|
Before Width: | Height: | Size: 125 KiB After Width: | Height: | Size: 31 KiB |
BIN
assets/pie.png
Normal file → Executable file
|
Before Width: | Height: | Size: 97 KiB After Width: | Height: | Size: 76 KiB |
BIN
assets/polar.png
Normal file → Executable file
|
Before Width: | Height: | Size: 200 KiB After Width: | Height: | Size: 87 KiB |
BIN
assets/radar.png
Normal file → Executable file
|
Before Width: | Height: | Size: 180 KiB After Width: | Height: | Size: 75 KiB |
BIN
assets/scatter.png
Executable file
|
After Width: | Height: | Size: 43 KiB |
@@ -1,35 +1,41 @@
|
|||||||
// https://github.com/shelljs/shelljs
|
'use strict'
|
||||||
require('shelljs/global')
|
require('./check-versions')()
|
||||||
env.NODE_ENV = 'production'
|
|
||||||
|
|
||||||
var path = require('path')
|
process.env.NODE_ENV = 'production'
|
||||||
var config = require('../config')
|
|
||||||
var ora = require('ora')
|
|
||||||
var webpack = require('webpack')
|
|
||||||
var webpackConfig = require('./webpack.prod.conf')
|
|
||||||
|
|
||||||
console.log(
|
const ora = require('ora')
|
||||||
' Tip:\n' +
|
const rm = require('rimraf')
|
||||||
' Built files are meant to be served over an HTTP server.\n' +
|
const path = require('path')
|
||||||
' Opening index.html over file:// won\'t work.\n'
|
const chalk = require('chalk')
|
||||||
)
|
const webpack = require('webpack')
|
||||||
|
const config = require('../config')
|
||||||
|
const webpackConfig = require('./webpack.prod.conf')
|
||||||
|
|
||||||
var spinner = ora('building UMD module...')
|
const spinner = ora('building for production...')
|
||||||
spinner.start()
|
spinner.start()
|
||||||
|
|
||||||
var assetsPath = path.join(config.build.assetsRoot, config.build.assetsSubDirectory)
|
rm(path.join(config.build.assetsRoot, config.build.assetsSubDirectory), err => {
|
||||||
rm('-rf', assetsPath)
|
|
||||||
mkdir('-p', assetsPath)
|
|
||||||
|
|
||||||
|
|
||||||
webpack(webpackConfig, function (err, stats) {
|
|
||||||
spinner.stop()
|
|
||||||
if (err) throw err
|
if (err) throw err
|
||||||
process.stdout.write(stats.toString({
|
webpack(webpackConfig, function (err, stats) {
|
||||||
colors: true,
|
spinner.stop()
|
||||||
modules: false,
|
if (err) throw err
|
||||||
children: false,
|
process.stdout.write(stats.toString({
|
||||||
chunks: false,
|
colors: true,
|
||||||
chunkModules: false
|
modules: false,
|
||||||
}) + '\n')
|
children: false,
|
||||||
|
chunks: false,
|
||||||
|
chunkModules: false
|
||||||
|
}) + '\n\n')
|
||||||
|
|
||||||
|
if (stats.hasErrors()) {
|
||||||
|
console.log(chalk.red(' Build failed with errors.\n'))
|
||||||
|
process.exit(1)
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log(chalk.cyan(' Build complete.\n'))
|
||||||
|
console.log(chalk.yellow(
|
||||||
|
' Tip: built files are meant to be served over an HTTP server.\n' +
|
||||||
|
' Opening index.html over file:// won\'t work.\n'
|
||||||
|
))
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
49
build/check-versions.js
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
'use strict'
|
||||||
|
const chalk = require('chalk')
|
||||||
|
const semver = require('semver')
|
||||||
|
const packageConfig = require('../package.json')
|
||||||
|
const shell = require('shelljs')
|
||||||
|
function exec (cmd) {
|
||||||
|
return require('child_process').execSync(cmd).toString().trim()
|
||||||
|
}
|
||||||
|
|
||||||
|
const versionRequirements = [
|
||||||
|
{
|
||||||
|
name: 'node',
|
||||||
|
currentVersion: semver.clean(process.version),
|
||||||
|
versionRequirement: packageConfig.engines.node
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
|
if (shell.which('npm')) {
|
||||||
|
versionRequirements.push({
|
||||||
|
name: 'npm',
|
||||||
|
currentVersion: exec('npm --version'),
|
||||||
|
versionRequirement: packageConfig.engines.npm
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = function () {
|
||||||
|
const warnings = []
|
||||||
|
for (let i = 0; i < versionRequirements.length; i++) {
|
||||||
|
const mod = versionRequirements[i]
|
||||||
|
if (!semver.satisfies(mod.currentVersion, mod.versionRequirement)) {
|
||||||
|
warnings.push(mod.name + ': ' +
|
||||||
|
chalk.red(mod.currentVersion) + ' should be ' +
|
||||||
|
chalk.green(mod.versionRequirement)
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (warnings.length) {
|
||||||
|
console.log('')
|
||||||
|
console.log(chalk.yellow('To use this template, you must update following to modules:'))
|
||||||
|
console.log()
|
||||||
|
for (let i = 0; i < warnings.length; i++) {
|
||||||
|
const warning = warnings[i]
|
||||||
|
console.log(' ' + warning)
|
||||||
|
}
|
||||||
|
console.log()
|
||||||
|
process.exit(1)
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,4 +1,5 @@
|
|||||||
/* eslint-disable */
|
/* eslint-disable */
|
||||||
|
'use strict'
|
||||||
require('eventsource-polyfill')
|
require('eventsource-polyfill')
|
||||||
var hotClient = require('webpack-hot-middleware/client?noInfo=true&reload=true')
|
var hotClient = require('webpack-hot-middleware/client?noInfo=true&reload=true')
|
||||||
|
|
||||||
|
|||||||
@@ -1,45 +1,61 @@
|
|||||||
var path = require('path')
|
'use strict'
|
||||||
var express = require('express')
|
require('./check-versions')()
|
||||||
var webpack = require('webpack')
|
|
||||||
var config = require('../config')
|
const config = require('../config')
|
||||||
var proxyMiddleware = require('http-proxy-middleware')
|
if (!process.env.NODE_ENV) {
|
||||||
var webpackConfig = process.env.NODE_ENV === 'testing'
|
process.env.NODE_ENV = JSON.parse(config.dev.env.NODE_ENV)
|
||||||
|
}
|
||||||
|
|
||||||
|
const opn = require('opn')
|
||||||
|
const path = require('path')
|
||||||
|
const express = require('express')
|
||||||
|
const webpack = require('webpack')
|
||||||
|
const proxyMiddleware = require('http-proxy-middleware')
|
||||||
|
const webpackConfig = (process.env.NODE_ENV === 'testing' || process.env.NODE_ENV === 'production')
|
||||||
? require('./webpack.prod.conf')
|
? require('./webpack.prod.conf')
|
||||||
: require('./webpack.dev.conf')
|
: require('./webpack.dev.conf')
|
||||||
|
|
||||||
// default port where dev server listens for incoming traffic
|
// default port where dev server listens for incoming traffic
|
||||||
var port = process.env.PORT || config.dev.port
|
const port = process.env.PORT || config.dev.port
|
||||||
|
// automatically open browser, if not set will be false
|
||||||
|
const autoOpenBrowser = !!config.dev.autoOpenBrowser
|
||||||
// Define HTTP proxies to your custom API backend
|
// Define HTTP proxies to your custom API backend
|
||||||
// https://github.com/chimurai/http-proxy-middleware
|
// https://github.com/chimurai/http-proxy-middleware
|
||||||
var proxyTable = config.dev.proxyTable
|
const proxyTable = config.dev.proxyTable
|
||||||
|
|
||||||
var app = express()
|
const app = express()
|
||||||
var compiler = webpack(webpackConfig)
|
const compiler = webpack(webpackConfig)
|
||||||
|
|
||||||
var devMiddleware = require('webpack-dev-middleware')(compiler, {
|
const devMiddleware = require('webpack-dev-middleware')(compiler, {
|
||||||
publicPath: webpackConfig.output.publicPath,
|
publicPath: webpackConfig.output.publicPath,
|
||||||
stats: {
|
quiet: true
|
||||||
colors: true,
|
|
||||||
chunks: false
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
|
|
||||||
var hotMiddleware = require('webpack-hot-middleware')(compiler)
|
const hotMiddleware = require('webpack-hot-middleware')(compiler, {
|
||||||
// force page reload when html-webpack-plugin template changes
|
log: false,
|
||||||
compiler.plugin('compilation', function (compilation) {
|
heartbeat: 2000
|
||||||
compilation.plugin('html-webpack-plugin-after-emit', function (data, cb) {
|
|
||||||
hotMiddleware.publish({ action: 'reload' })
|
|
||||||
cb()
|
|
||||||
})
|
|
||||||
})
|
})
|
||||||
|
// force page reload when html-webpack-plugin template changes
|
||||||
|
// currently disabled until this is resolved:
|
||||||
|
// https://github.com/jantimon/html-webpack-plugin/issues/680
|
||||||
|
// compiler.plugin('compilation', function (compilation) {
|
||||||
|
// compilation.plugin('html-webpack-plugin-after-emit', function (data, cb) {
|
||||||
|
// hotMiddleware.publish({ action: 'reload' })
|
||||||
|
// cb()
|
||||||
|
// })
|
||||||
|
// })
|
||||||
|
|
||||||
|
// enable hot-reload and state-preserving
|
||||||
|
// compilation error display
|
||||||
|
app.use(hotMiddleware)
|
||||||
|
|
||||||
// proxy api requests
|
// proxy api requests
|
||||||
Object.keys(proxyTable).forEach(function (context) {
|
Object.keys(proxyTable).forEach(function (context) {
|
||||||
var options = proxyTable[context]
|
const options = proxyTable[context]
|
||||||
if (typeof options === 'string') {
|
if (typeof options === 'string') {
|
||||||
options = { target: options }
|
options = { target: options }
|
||||||
}
|
}
|
||||||
app.use(proxyMiddleware(context, options))
|
app.use(proxyMiddleware(options.filter || context, options))
|
||||||
})
|
})
|
||||||
|
|
||||||
// handle fallback for HTML5 history API
|
// handle fallback for HTML5 history API
|
||||||
@@ -48,18 +64,44 @@ app.use(require('connect-history-api-fallback')())
|
|||||||
// serve webpack bundle output
|
// serve webpack bundle output
|
||||||
app.use(devMiddleware)
|
app.use(devMiddleware)
|
||||||
|
|
||||||
// enable hot-reload and state-preserving
|
|
||||||
// compilation error display
|
|
||||||
app.use(hotMiddleware)
|
|
||||||
|
|
||||||
// serve pure static assets
|
// serve pure static assets
|
||||||
var staticPath = path.posix.join(config.build.assetsPublicPath, config.build.assetsSubDirectory)
|
const staticPath = path.posix.join(config.dev.assetsPublicPath, config.dev.assetsSubDirectory)
|
||||||
app.use(staticPath, express.static('./static'))
|
app.use(staticPath, express.static('./static'))
|
||||||
|
|
||||||
module.exports = app.listen(port, function (err) {
|
const uri = 'http://localhost:' + port
|
||||||
if (err) {
|
|
||||||
console.log(err)
|
var _resolve
|
||||||
return
|
var _reject
|
||||||
}
|
var readyPromise = new Promise((resolve, reject) => {
|
||||||
console.log('Listening at http://localhost:' + port + '\n')
|
_resolve = resolve
|
||||||
|
_reject = reject
|
||||||
})
|
})
|
||||||
|
|
||||||
|
var server
|
||||||
|
var portfinder = require('portfinder')
|
||||||
|
portfinder.basePort = port
|
||||||
|
|
||||||
|
console.log('> Starting dev server...')
|
||||||
|
devMiddleware.waitUntilValid(() => {
|
||||||
|
portfinder.getPort((err, port) => {
|
||||||
|
if (err) {
|
||||||
|
_reject(err)
|
||||||
|
}
|
||||||
|
process.env.PORT = port
|
||||||
|
var uri = 'http://localhost:' + port
|
||||||
|
console.log('> Listening at ' + uri + '\n')
|
||||||
|
// when env is testing, don't need open it
|
||||||
|
if (autoOpenBrowser && process.env.NODE_ENV !== 'testing') {
|
||||||
|
opn(uri)
|
||||||
|
}
|
||||||
|
server = app.listen(port)
|
||||||
|
_resolve()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
ready: readyPromise,
|
||||||
|
close: () => {
|
||||||
|
server.close()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
@@ -1,55 +1,71 @@
|
|||||||
var path = require('path')
|
'use strict'
|
||||||
var config = require('../config')
|
const path = require('path')
|
||||||
var ExtractTextPlugin = require('extract-text-webpack-plugin')
|
const config = require('../config')
|
||||||
|
const ExtractTextPlugin = require('extract-text-webpack-plugin')
|
||||||
|
|
||||||
exports.assetsPath = function (_path) {
|
exports.assetsPath = function (_path) {
|
||||||
return path.posix.join(config.build.assetsSubDirectory, _path)
|
const assetsSubDirectory = process.env.NODE_ENV === 'production'
|
||||||
|
? config.build.assetsSubDirectory
|
||||||
|
: config.dev.assetsSubDirectory
|
||||||
|
return path.posix.join(assetsSubDirectory, _path)
|
||||||
}
|
}
|
||||||
|
|
||||||
exports.cssLoaders = function (options) {
|
exports.cssLoaders = function (options) {
|
||||||
options = options || {}
|
options = options || {}
|
||||||
// generate loader string to be used with extract text plugin
|
|
||||||
function generateLoaders (loaders) {
|
|
||||||
var sourceLoader = loaders.map(function (loader) {
|
|
||||||
var extraParamChar
|
|
||||||
if (/\?/.test(loader)) {
|
|
||||||
loader = loader.replace(/\?/, '-loader?')
|
|
||||||
extraParamChar = '&'
|
|
||||||
} else {
|
|
||||||
loader = loader + '-loader'
|
|
||||||
extraParamChar = '?'
|
|
||||||
}
|
|
||||||
return loader + (options.sourceMap ? extraParamChar + 'sourceMap' : '')
|
|
||||||
}).join('!')
|
|
||||||
|
|
||||||
if (options.extract) {
|
const cssLoader = {
|
||||||
return ExtractTextPlugin.extract('vue-style-loader', sourceLoader)
|
loader: 'css-loader',
|
||||||
} else {
|
options: {
|
||||||
return ['vue-style-loader', sourceLoader].join('!')
|
minimize: process.env.NODE_ENV === 'production',
|
||||||
|
sourceMap: options.sourceMap
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// http://vuejs.github.io/vue-loader/configurations/extract-css.html
|
// generate loader string to be used with extract text plugin
|
||||||
|
function generateLoaders (loader, loaderOptions) {
|
||||||
|
const loaders = [cssLoader]
|
||||||
|
if (loader) {
|
||||||
|
loaders.push({
|
||||||
|
loader: loader + '-loader',
|
||||||
|
options: Object.assign({}, loaderOptions, {
|
||||||
|
sourceMap: options.sourceMap
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// Extract CSS when that option is specified
|
||||||
|
// (which is the case during production build)
|
||||||
|
if (options.extract) {
|
||||||
|
return ExtractTextPlugin.extract({
|
||||||
|
use: loaders,
|
||||||
|
fallback: 'vue-style-loader'
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
return ['vue-style-loader'].concat(loaders)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// https://vue-loader.vuejs.org/en/configurations/extract-css.html
|
||||||
return {
|
return {
|
||||||
css: generateLoaders(['css']),
|
css: generateLoaders(),
|
||||||
postcss: generateLoaders(['css']),
|
postcss: generateLoaders(),
|
||||||
less: generateLoaders(['css', 'less']),
|
less: generateLoaders('less'),
|
||||||
sass: generateLoaders(['css', 'sass?indentedSyntax']),
|
sass: generateLoaders('sass', { indentedSyntax: true }),
|
||||||
scss: generateLoaders(['css', 'sass']),
|
scss: generateLoaders('sass'),
|
||||||
stylus: generateLoaders(['css', 'stylus']),
|
stylus: generateLoaders('stylus'),
|
||||||
styl: generateLoaders(['css', 'stylus'])
|
styl: generateLoaders('stylus')
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Generate loaders for standalone style files (outside of .vue)
|
// Generate loaders for standalone style files (outside of .vue)
|
||||||
exports.styleLoaders = function (options) {
|
exports.styleLoaders = function (options) {
|
||||||
var output = []
|
const output = []
|
||||||
var loaders = exports.cssLoaders(options)
|
const loaders = exports.cssLoaders(options)
|
||||||
for (var extension in loaders) {
|
for (const extension in loaders) {
|
||||||
var loader = loaders[extension]
|
const loader = loaders[extension]
|
||||||
output.push({
|
output.push({
|
||||||
test: new RegExp('\\.' + extension + '$'),
|
test: new RegExp('\\.' + extension + '$'),
|
||||||
loader: loader
|
use: loader
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
return output
|
return output
|
||||||
|
|||||||
19
build/vue-loader.conf.js
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
'use strict'
|
||||||
|
const utils = require('./utils')
|
||||||
|
const config = require('../config')
|
||||||
|
const isProduction = process.env.NODE_ENV === 'production'
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
loaders: utils.cssLoaders({
|
||||||
|
sourceMap: isProduction
|
||||||
|
? config.build.productionSourceMap
|
||||||
|
: config.dev.cssSourceMap,
|
||||||
|
extract: isProduction
|
||||||
|
}),
|
||||||
|
transformToRequire: {
|
||||||
|
video: 'src',
|
||||||
|
source: 'src',
|
||||||
|
img: 'src',
|
||||||
|
image: 'xlink:href'
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,7 +1,12 @@
|
|||||||
var path = require('path')
|
'use strict'
|
||||||
var config = require('../config')
|
const path = require('path')
|
||||||
var utils = require('./utils')
|
const utils = require('./utils')
|
||||||
var projectRoot = path.resolve(__dirname, '../')
|
const config = require('../config')
|
||||||
|
const vueLoaderConfig = require('./vue-loader.conf')
|
||||||
|
|
||||||
|
function resolve (dir) {
|
||||||
|
return path.join(__dirname, '..', dir)
|
||||||
|
}
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
entry: {
|
entry: {
|
||||||
@@ -9,77 +14,63 @@ module.exports = {
|
|||||||
},
|
},
|
||||||
output: {
|
output: {
|
||||||
path: config.build.assetsRoot,
|
path: config.build.assetsRoot,
|
||||||
publicPath: config.build.assetsPublicPath,
|
filename: '[name].js',
|
||||||
filename: '[name].js'
|
publicPath: process.env.NODE_ENV === 'production'
|
||||||
|
? config.build.assetsPublicPath
|
||||||
|
: config.dev.assetsPublicPath
|
||||||
},
|
},
|
||||||
resolve: {
|
resolve: {
|
||||||
extensions: ['', '.js', '.vue'],
|
extensions: ['.js', '.vue', '.json'],
|
||||||
fallback: [path.join(__dirname, '../node_modules')],
|
|
||||||
alias: {
|
alias: {
|
||||||
'src': path.resolve(__dirname, '../src'),
|
'vue$': 'vue/dist/vue.esm.js',
|
||||||
'mixins': path.resolve(__dirname, '../src/mixins'),
|
'@': resolve('src')
|
||||||
'BaseCharts': path.resolve(__dirname, '../src/BaseCharts')
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
resolveLoader: {
|
|
||||||
fallback: [path.join(__dirname, '../node_modules')]
|
|
||||||
},
|
|
||||||
module: {
|
module: {
|
||||||
preLoaders: [
|
rules: [
|
||||||
|
{
|
||||||
|
test: /\.(js|vue)$/,
|
||||||
|
loader: 'eslint-loader',
|
||||||
|
enforce: 'pre',
|
||||||
|
include: [resolve('src'), resolve('test')],
|
||||||
|
options: {
|
||||||
|
formatter: require('eslint-friendly-formatter')
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
test: /\.vue$/,
|
test: /\.vue$/,
|
||||||
loader: 'eslint',
|
loader: 'vue-loader',
|
||||||
include: projectRoot,
|
options: vueLoaderConfig
|
||||||
exclude: /node_modules/
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
test: /\.js$/,
|
test: /\.js$/,
|
||||||
loader: 'eslint',
|
loader: 'babel-loader',
|
||||||
include: projectRoot,
|
include: [resolve('src'), resolve('test')]
|
||||||
exclude: /node_modules/
|
|
||||||
}
|
|
||||||
],
|
|
||||||
loaders: [
|
|
||||||
{
|
|
||||||
test: /\.vue$/,
|
|
||||||
loader: 'vue'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
test: /\.js$/,
|
|
||||||
loader: 'babel',
|
|
||||||
include: projectRoot,
|
|
||||||
exclude: /node_modules/
|
|
||||||
},
|
|
||||||
{
|
|
||||||
test: /\.json$/,
|
|
||||||
loader: 'json'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
test: /\.html$/,
|
|
||||||
loader: 'vue-html'
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,
|
test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,
|
||||||
loader: 'url',
|
loader: 'url-loader',
|
||||||
query: {
|
options: {
|
||||||
limit: 10000,
|
limit: 10000,
|
||||||
name: utils.assetsPath('img/[name].[hash:7].[ext]')
|
name: utils.assetsPath('img/[name].[hash:7].[ext]')
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
test: /\.(mp4|webm|ogg|mp3|wav|flac|aac)(\?.*)?$/,
|
||||||
|
loader: 'url-loader',
|
||||||
|
options: {
|
||||||
|
limit: 10000,
|
||||||
|
name: utils.assetsPath('media/[name].[hash:7].[ext]')
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
|
test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
|
||||||
loader: 'url',
|
loader: 'url-loader',
|
||||||
query: {
|
options: {
|
||||||
limit: 10000,
|
limit: 10000,
|
||||||
name: utils.assetsPath('fonts/[name].[hash:7].[ext]')
|
name: utils.assetsPath('fonts/[name].[hash:7].[ext]')
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
|
||||||
eslint: {
|
|
||||||
formatter: require('eslint-friendly-formatter')
|
|
||||||
},
|
|
||||||
vue: {
|
|
||||||
loaders: utils.cssLoaders()
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,9 +1,11 @@
|
|||||||
var config = require('../config')
|
'use strict'
|
||||||
var webpack = require('webpack')
|
const utils = require('./utils')
|
||||||
var merge = require('webpack-merge')
|
const webpack = require('webpack')
|
||||||
var utils = require('./utils')
|
const config = require('../config')
|
||||||
var baseWebpackConfig = require('./webpack.base.conf')
|
const merge = require('webpack-merge')
|
||||||
var HtmlWebpackPlugin = require('html-webpack-plugin')
|
const baseWebpackConfig = require('./webpack.base.conf')
|
||||||
|
const HtmlWebpackPlugin = require('html-webpack-plugin')
|
||||||
|
const FriendlyErrorsPlugin = require('friendly-errors-webpack-plugin')
|
||||||
|
|
||||||
// add hot-reload related code to entry chunks
|
// add hot-reload related code to entry chunks
|
||||||
Object.keys(baseWebpackConfig.entry).forEach(function (name) {
|
Object.keys(baseWebpackConfig.entry).forEach(function (name) {
|
||||||
@@ -12,23 +14,23 @@ Object.keys(baseWebpackConfig.entry).forEach(function (name) {
|
|||||||
|
|
||||||
module.exports = merge(baseWebpackConfig, {
|
module.exports = merge(baseWebpackConfig, {
|
||||||
module: {
|
module: {
|
||||||
loaders: utils.styleLoaders()
|
rules: utils.styleLoaders({ sourceMap: config.dev.cssSourceMap })
|
||||||
},
|
},
|
||||||
// eval-source-map is faster for development
|
// cheap-module-eval-source-map is faster for development
|
||||||
devtool: '#eval-source-map',
|
devtool: '#cheap-module-eval-source-map',
|
||||||
plugins: [
|
plugins: [
|
||||||
new webpack.DefinePlugin({
|
new webpack.DefinePlugin({
|
||||||
'process.env': config.dev.env
|
'process.env': config.dev.env
|
||||||
}),
|
}),
|
||||||
// https://github.com/glenjamin/webpack-hot-middleware#installation--usage
|
// https://github.com/glenjamin/webpack-hot-middleware#installation--usage
|
||||||
new webpack.optimize.OccurenceOrderPlugin(),
|
|
||||||
new webpack.HotModuleReplacementPlugin(),
|
new webpack.HotModuleReplacementPlugin(),
|
||||||
new webpack.NoErrorsPlugin(),
|
new webpack.NoEmitOnErrorsPlugin(),
|
||||||
// https://github.com/ampedandwired/html-webpack-plugin
|
// https://github.com/ampedandwired/html-webpack-plugin
|
||||||
new HtmlWebpackPlugin({
|
new HtmlWebpackPlugin({
|
||||||
filename: 'index.html',
|
filename: 'index.html',
|
||||||
template: 'index.html',
|
template: 'index.html',
|
||||||
inject: true
|
inject: true
|
||||||
})
|
}),
|
||||||
|
new FriendlyErrorsPlugin()
|
||||||
]
|
]
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -1,33 +1,128 @@
|
|||||||
|
'use strict'
|
||||||
|
const path = require('path')
|
||||||
|
const utils = require('./utils')
|
||||||
const webpack = require('webpack')
|
const webpack = require('webpack')
|
||||||
const base = require('./webpack.base.conf')
|
|
||||||
const config = require('../config')
|
const config = require('../config')
|
||||||
var env = process.env.NODE_ENV === 'testing'
|
const merge = require('webpack-merge')
|
||||||
|
const baseWebpackConfig = require('./webpack.base.conf')
|
||||||
|
const CopyWebpackPlugin = require('copy-webpack-plugin')
|
||||||
|
const HtmlWebpackPlugin = require('html-webpack-plugin')
|
||||||
|
const ExtractTextPlugin = require('extract-text-webpack-plugin')
|
||||||
|
const OptimizeCSSPlugin = require('optimize-css-assets-webpack-plugin')
|
||||||
|
|
||||||
|
const env = process.env.NODE_ENV === 'testing'
|
||||||
? require('../config/test.env')
|
? require('../config/test.env')
|
||||||
: config.build.env
|
: config.build.env
|
||||||
|
|
||||||
base.entry = {
|
const webpackConfig = merge(baseWebpackConfig, {
|
||||||
lib: './src/index.js'
|
module: {
|
||||||
|
rules: utils.styleLoaders({
|
||||||
|
sourceMap: config.build.productionSourceMap,
|
||||||
|
extract: true
|
||||||
|
})
|
||||||
|
},
|
||||||
|
devtool: config.build.productionSourceMap ? '#source-map' : false,
|
||||||
|
output: {
|
||||||
|
path: config.build.assetsRoot,
|
||||||
|
filename: utils.assetsPath('js/[name].[chunkhash].js'),
|
||||||
|
chunkFilename: utils.assetsPath('js/[id].[chunkhash].js')
|
||||||
|
},
|
||||||
|
plugins: [
|
||||||
|
// http://vuejs.github.io/vue-loader/en/workflow/production.html
|
||||||
|
new webpack.DefinePlugin({
|
||||||
|
'process.env': env
|
||||||
|
}),
|
||||||
|
// UglifyJs do not support ES6+, you can also use babel-minify for better treeshaking: https://github.com/babel/minify
|
||||||
|
new webpack.optimize.UglifyJsPlugin({
|
||||||
|
compress: {
|
||||||
|
warnings: false
|
||||||
|
},
|
||||||
|
sourceMap: true
|
||||||
|
}),
|
||||||
|
// extract css into its own file
|
||||||
|
new ExtractTextPlugin({
|
||||||
|
filename: utils.assetsPath('css/[name].[contenthash].css')
|
||||||
|
}),
|
||||||
|
// Compress extracted CSS. We are using this plugin so that possible
|
||||||
|
// duplicated CSS from different components can be deduped.
|
||||||
|
new OptimizeCSSPlugin({
|
||||||
|
cssProcessorOptions: {
|
||||||
|
safe: true
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
// generate dist index.html with correct asset hash for caching.
|
||||||
|
// you can customize output by editing /index.html
|
||||||
|
// see https://github.com/ampedandwired/html-webpack-plugin
|
||||||
|
new HtmlWebpackPlugin({
|
||||||
|
filename: process.env.NODE_ENV === 'testing'
|
||||||
|
? 'index.html'
|
||||||
|
: config.build.index,
|
||||||
|
template: 'index.html',
|
||||||
|
inject: true,
|
||||||
|
minify: {
|
||||||
|
removeComments: true,
|
||||||
|
collapseWhitespace: true,
|
||||||
|
removeAttributeQuotes: true
|
||||||
|
// more options:
|
||||||
|
// https://github.com/kangax/html-minifier#options-quick-reference
|
||||||
|
},
|
||||||
|
// necessary to consistently work with multiple chunks via CommonsChunkPlugin
|
||||||
|
chunksSortMode: 'dependency'
|
||||||
|
}),
|
||||||
|
// keep module.id stable when vender modules does not change
|
||||||
|
new webpack.HashedModuleIdsPlugin(),
|
||||||
|
// split vendor js into its own file
|
||||||
|
new webpack.optimize.CommonsChunkPlugin({
|
||||||
|
name: 'vendor',
|
||||||
|
minChunks: function (module) {
|
||||||
|
// any required modules inside node_modules are extracted to vendor
|
||||||
|
return (
|
||||||
|
module.resource &&
|
||||||
|
/\.js$/.test(module.resource) &&
|
||||||
|
module.resource.indexOf(
|
||||||
|
path.join(__dirname, '../node_modules')
|
||||||
|
) === 0
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
// extract webpack runtime and module manifest to its own file in order to
|
||||||
|
// prevent vendor hash from being updated whenever app bundle is updated
|
||||||
|
new webpack.optimize.CommonsChunkPlugin({
|
||||||
|
name: 'manifest',
|
||||||
|
chunks: ['vendor']
|
||||||
|
}),
|
||||||
|
// copy custom static assets
|
||||||
|
new CopyWebpackPlugin([
|
||||||
|
{
|
||||||
|
from: path.resolve(__dirname, '../static'),
|
||||||
|
to: config.build.assetsSubDirectory,
|
||||||
|
ignore: ['.*']
|
||||||
|
}
|
||||||
|
])
|
||||||
|
]
|
||||||
|
})
|
||||||
|
|
||||||
|
if (config.build.productionGzip) {
|
||||||
|
const CompressionWebpackPlugin = require('compression-webpack-plugin')
|
||||||
|
|
||||||
|
webpackConfig.plugins.push(
|
||||||
|
new CompressionWebpackPlugin({
|
||||||
|
asset: '[path].gz[query]',
|
||||||
|
algorithm: 'gzip',
|
||||||
|
test: new RegExp(
|
||||||
|
'\\.(' +
|
||||||
|
config.build.productionGzipExtensions.join('|') +
|
||||||
|
')$'
|
||||||
|
),
|
||||||
|
threshold: 10240,
|
||||||
|
minRatio: 0.8
|
||||||
|
})
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
base.output = {
|
if (config.build.bundleAnalyzerReport) {
|
||||||
path: config.build.assetsRoot,
|
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin
|
||||||
publicPath: config.build.assetsPublicPath,
|
webpackConfig.plugins.push(new BundleAnalyzerPlugin())
|
||||||
filename: 'vue-chartjs.js',
|
|
||||||
library: 'VueChartJs',
|
|
||||||
libraryTarget: 'umd'
|
|
||||||
}
|
}
|
||||||
|
|
||||||
var webpackConfig = Object.assign({}, base)
|
|
||||||
|
|
||||||
webpackConfig.devtool = '#source-map'
|
|
||||||
webpackConfig.plugins = (webpackConfig.plugins || []).concat([
|
|
||||||
new webpack.DefinePlugin({
|
|
||||||
'process.env.NODE_ENV': env
|
|
||||||
}),
|
|
||||||
new webpack.optimize.UglifyJsPlugin({
|
|
||||||
compress: { warnings: false }
|
|
||||||
}),
|
|
||||||
new webpack.optimize.OccurenceOrderPlugin(),
|
|
||||||
])
|
|
||||||
|
|
||||||
module.exports = webpackConfig
|
module.exports = webpackConfig
|
||||||
|
|||||||
@@ -1,92 +0,0 @@
|
|||||||
var vue = require('vue-loader')
|
|
||||||
var path = require('path')
|
|
||||||
var webpack = require("webpack")
|
|
||||||
var ExtractTextPlugin = require("extract-text-webpack-plugin")
|
|
||||||
var projectRoot = path.resolve(__dirname, '../')
|
|
||||||
var cssLoader = ExtractTextPlugin.extract('style-loader', 'css-loader')
|
|
||||||
const npmCfg = require('../package.json');
|
|
||||||
|
|
||||||
var banner = [
|
|
||||||
npmCfg.name + ' v' + npmCfg.version,
|
|
||||||
'(c) ' + (new Date().getFullYear()) + ' ' + npmCfg.author,
|
|
||||||
npmCfg.homepage
|
|
||||||
].join('\n')
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
entry: {
|
|
||||||
'vue-chartjs': './src/index.js'
|
|
||||||
},
|
|
||||||
output: {
|
|
||||||
filename: './dist/[name].full.js',
|
|
||||||
library: 'VueChartJs',
|
|
||||||
libraryTarget: 'umd',
|
|
||||||
umdNamedDefine: true
|
|
||||||
},
|
|
||||||
module: {
|
|
||||||
preLoaders: [
|
|
||||||
{
|
|
||||||
test: /\.vue$/,
|
|
||||||
loader: 'eslint',
|
|
||||||
include: projectRoot,
|
|
||||||
exclude: /node_modules/
|
|
||||||
},
|
|
||||||
{
|
|
||||||
test: /\.js$/,
|
|
||||||
loader: 'eslint',
|
|
||||||
include: projectRoot,
|
|
||||||
exclude: /node_modules/
|
|
||||||
}
|
|
||||||
],
|
|
||||||
loaders: [
|
|
||||||
{
|
|
||||||
test: /\.vue$/,
|
|
||||||
loader: 'vue'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
test: /\.js$/,
|
|
||||||
exclude: /node_modules/,
|
|
||||||
loader: 'babel'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
test: /\.css$/,
|
|
||||||
loader: cssLoader
|
|
||||||
},
|
|
||||||
{
|
|
||||||
test: /\.s[a|c]ss$/,
|
|
||||||
loader: ExtractTextPlugin.extract('style-loader','css-loader!sass-loader')
|
|
||||||
},
|
|
||||||
{
|
|
||||||
test: /\.json$/, loader: 'json'
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
eslint: {
|
|
||||||
formatter: require('eslint-friendly-formatter')
|
|
||||||
},
|
|
||||||
babel: {
|
|
||||||
presets: ['es2015'],
|
|
||||||
plugins: ['transform-runtime']
|
|
||||||
},
|
|
||||||
plugins: [
|
|
||||||
new webpack.BannerPlugin(banner)
|
|
||||||
]
|
|
||||||
}
|
|
||||||
|
|
||||||
if (process.env.NODE_ENV === 'production') {
|
|
||||||
|
|
||||||
delete module.exports.devtool
|
|
||||||
module.exports.plugins = [
|
|
||||||
new webpack.DefinePlugin({
|
|
||||||
'process.env': {
|
|
||||||
NODE_ENV: '"production"'
|
|
||||||
}
|
|
||||||
}),
|
|
||||||
new webpack.optimize.UglifyJsPlugin({
|
|
||||||
compress: {
|
|
||||||
warnings: false
|
|
||||||
}
|
|
||||||
}),
|
|
||||||
new webpack.optimize.OccurenceOrderPlugin()
|
|
||||||
// new ExtractTextPlugin('build.css')
|
|
||||||
]
|
|
||||||
}
|
|
||||||
18
build/webpack.release.full.min.js
vendored
@@ -1,18 +0,0 @@
|
|||||||
var config = require('./webpack.release.full.js')
|
|
||||||
var webpack = require('webpack')
|
|
||||||
|
|
||||||
config.output.filename = config.output.filename.replace(/\.js$/, '.min.js')
|
|
||||||
|
|
||||||
delete config.devtool
|
|
||||||
|
|
||||||
config.plugins = [
|
|
||||||
new webpack.optimize.UglifyJsPlugin({
|
|
||||||
sourceMap: false,
|
|
||||||
compress: {
|
|
||||||
warnings: false
|
|
||||||
}
|
|
||||||
}),
|
|
||||||
new webpack.optimize.OccurenceOrderPlugin()
|
|
||||||
]
|
|
||||||
|
|
||||||
module.exports = config
|
|
||||||
@@ -1,17 +1,20 @@
|
|||||||
var vue = require('vue-loader')
|
|
||||||
var path = require('path')
|
var path = require('path')
|
||||||
var webpack = require("webpack")
|
var webpack = require('webpack')
|
||||||
var ExtractTextPlugin = require("extract-text-webpack-plugin")
|
var ExtractTextPlugin = require('extract-text-webpack-plugin')
|
||||||
var projectRoot = path.resolve(__dirname, '../')
|
|
||||||
var cssLoader = ExtractTextPlugin.extract('style-loader', 'css-loader')
|
var cssLoader = ExtractTextPlugin.extract('style-loader', 'css-loader')
|
||||||
const npmCfg = require('../package.json');
|
const npmCfg = require('../package.json')
|
||||||
|
const vueLoaderConfig = require('./vue-loader.conf')
|
||||||
|
|
||||||
var banner = [
|
var banner = [
|
||||||
npmCfg.name + ' v' + npmCfg.version,
|
npmCfg.name + ' v' + npmCfg.version,
|
||||||
'(c) ' + (new Date().getFullYear()) + ' ' + npmCfg.author,
|
'(c) ' + (new Date().getFullYear()) + ' ' + npmCfg.author,
|
||||||
npmCfg.homepage
|
npmCfg.homepage
|
||||||
].join('\n')
|
].join('\n')
|
||||||
|
|
||||||
|
function resolve (dir) {
|
||||||
|
return path.join(__dirname, '..', dir)
|
||||||
|
}
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
entry: {
|
entry: {
|
||||||
'vue-chartjs': './src/index.js'
|
'vue-chartjs': './src/index.js'
|
||||||
@@ -23,33 +26,40 @@ module.exports = {
|
|||||||
umdNamedDefine: true
|
umdNamedDefine: true
|
||||||
},
|
},
|
||||||
externals: {
|
externals: {
|
||||||
'vue': 'vue',
|
'chart.js': {
|
||||||
'chart.js': 'chart.js'
|
root: 'Chart',
|
||||||
|
commonjs: 'chart.js',
|
||||||
|
commonjs2: 'chart.js',
|
||||||
|
amd: 'chart.js'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
resolve: {
|
||||||
|
extensions: ['.js', '.vue', '.json'],
|
||||||
|
alias: {
|
||||||
|
'vue$': 'vue/dist/vue.esm.js',
|
||||||
|
'@': resolve('src')
|
||||||
|
}
|
||||||
},
|
},
|
||||||
module: {
|
module: {
|
||||||
preLoaders: [
|
rules: [
|
||||||
|
{
|
||||||
|
test: /\.(js|vue)$/,
|
||||||
|
loader: 'eslint-loader',
|
||||||
|
enforce: 'pre',
|
||||||
|
include: [resolve('src'), resolve('test')],
|
||||||
|
options: {
|
||||||
|
formatter: require('eslint-friendly-formatter')
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
test: /\.vue$/,
|
test: /\.vue$/,
|
||||||
loader: 'eslint',
|
loader: 'vue-loader',
|
||||||
include: projectRoot,
|
options: vueLoaderConfig
|
||||||
exclude: /node_modules/
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
test: /\.js$/,
|
test: /\.js$/,
|
||||||
loader: 'eslint',
|
loader: 'babel-loader',
|
||||||
include: projectRoot,
|
include: [resolve('src'), resolve('test')]
|
||||||
exclude: /node_modules/
|
|
||||||
}
|
|
||||||
],
|
|
||||||
loaders: [
|
|
||||||
{
|
|
||||||
test: /\.vue$/,
|
|
||||||
loader: 'vue'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
test: /\.js$/,
|
|
||||||
exclude: /node_modules/,
|
|
||||||
loader: 'babel'
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
test: /\.css$/,
|
test: /\.css$/,
|
||||||
@@ -57,27 +67,21 @@ module.exports = {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
test: /\.s[a|c]ss$/,
|
test: /\.s[a|c]ss$/,
|
||||||
loader: ExtractTextPlugin.extract('style-loader','css-loader!sass-loader')
|
loader: ExtractTextPlugin.extract('style-loader', 'css-loader!sass-loader')
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
test: /\.json$/, loader: 'json'
|
test: /\.json$/,
|
||||||
|
loader: 'json-loader'
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
eslint: {
|
|
||||||
formatter: require('eslint-friendly-formatter')
|
|
||||||
},
|
|
||||||
babel: {
|
|
||||||
presets: ['es2015'],
|
|
||||||
plugins: ['transform-runtime']
|
|
||||||
},
|
|
||||||
plugins: [
|
plugins: [
|
||||||
new webpack.BannerPlugin(banner)
|
new webpack.BannerPlugin(banner),
|
||||||
|
new webpack.optimize.ModuleConcatenationPlugin()
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
||||||
if (process.env.NODE_ENV === 'production') {
|
if (process.env.NODE_ENV === 'production') {
|
||||||
|
|
||||||
delete module.exports.devtool
|
delete module.exports.devtool
|
||||||
module.exports.plugins = [
|
module.exports.plugins = [
|
||||||
new webpack.DefinePlugin({
|
new webpack.DefinePlugin({
|
||||||
@@ -89,8 +93,6 @@ if (process.env.NODE_ENV === 'production') {
|
|||||||
compress: {
|
compress: {
|
||||||
warnings: false
|
warnings: false
|
||||||
}
|
}
|
||||||
}),
|
})
|
||||||
new webpack.optimize.OccurenceOrderPlugin()
|
|
||||||
// new ExtractTextPlugin('build.css')
|
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
4
build/webpack.release.min.js
vendored
@@ -6,13 +6,13 @@ config.output.filename = config.output.filename.replace(/\.js$/, '.min.js')
|
|||||||
delete config.devtool
|
delete config.devtool
|
||||||
|
|
||||||
config.plugins = [
|
config.plugins = [
|
||||||
|
new webpack.optimize.ModuleConcatenationPlugin(),
|
||||||
new webpack.optimize.UglifyJsPlugin({
|
new webpack.optimize.UglifyJsPlugin({
|
||||||
sourceMap: false,
|
sourceMap: false,
|
||||||
compress: {
|
compress: {
|
||||||
warnings: false
|
warnings: false
|
||||||
}
|
}
|
||||||
}),
|
})
|
||||||
new webpack.optimize.OccurenceOrderPlugin()
|
|
||||||
]
|
]
|
||||||
|
|
||||||
module.exports = config
|
module.exports = config
|
||||||
|
|||||||
32
build/webpack.test.conf.js
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
'use strict'
|
||||||
|
// This is the webpack config used for unit tests.
|
||||||
|
|
||||||
|
const utils = require('./utils')
|
||||||
|
const webpack = require('webpack')
|
||||||
|
const merge = require('webpack-merge')
|
||||||
|
const baseWebpackConfig = require('./webpack.base.conf')
|
||||||
|
|
||||||
|
const webpackConfig = merge(baseWebpackConfig, {
|
||||||
|
// use inline sourcemap for karma-sourcemap-loader
|
||||||
|
module: {
|
||||||
|
rules: utils.styleLoaders()
|
||||||
|
},
|
||||||
|
devtool: '#inline-source-map',
|
||||||
|
resolveLoader: {
|
||||||
|
alias: {
|
||||||
|
// necessary to to make lang="scss" work in test when using vue-loader's ?inject option
|
||||||
|
// see discussion at https://github.com/vuejs/vue-loader/issues/724
|
||||||
|
'scss-loader': 'sass-loader'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
plugins: [
|
||||||
|
new webpack.DefinePlugin({
|
||||||
|
'process.env': require('../config/test.env')
|
||||||
|
})
|
||||||
|
]
|
||||||
|
})
|
||||||
|
|
||||||
|
// no need for app entry during tests
|
||||||
|
delete webpackConfig.entry
|
||||||
|
|
||||||
|
module.exports = webpackConfig
|
||||||
@@ -1,5 +1,6 @@
|
|||||||
var merge = require('webpack-merge')
|
'use strict'
|
||||||
var prodEnv = require('./prod.env')
|
const merge = require('webpack-merge')
|
||||||
|
const prodEnv = require('./prod.env')
|
||||||
|
|
||||||
module.exports = merge(prodEnv, {
|
module.exports = merge(prodEnv, {
|
||||||
NODE_ENV: '"development"'
|
NODE_ENV: '"development"'
|
||||||
|
|||||||
@@ -1,21 +1,42 @@
|
|||||||
|
|
||||||
|
'use strict'
|
||||||
|
// Template version: 1.1.1
|
||||||
// see http://vuejs-templates.github.io/webpack for documentation.
|
// see http://vuejs-templates.github.io/webpack for documentation.
|
||||||
var path = require('path')
|
|
||||||
|
const path = require('path')
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
build: {
|
build: {
|
||||||
env: require('./prod.env'),
|
env: require('./prod.env'),
|
||||||
|
index: path.resolve(__dirname, '../dist/index.html'),
|
||||||
assetsRoot: path.resolve(__dirname, '../dist'),
|
assetsRoot: path.resolve(__dirname, '../dist'),
|
||||||
assetsSubDirectory: '',
|
assetsSubDirectory: 'static',
|
||||||
assetsPublicPath: '/',
|
assetsPublicPath: '/',
|
||||||
productionSourceMap: true,
|
productionSourceMap: true,
|
||||||
|
// Gzip off by default as many popular static hosts such as
|
||||||
|
// Surge or Netlify already gzip all static assets for you.
|
||||||
|
// Before setting to `true`, make sure to:
|
||||||
|
// npm install --save-dev compression-webpack-plugin
|
||||||
|
productionGzip: false,
|
||||||
|
productionGzipExtensions: ['js', 'css'],
|
||||||
|
// Run the build command with an extra argument to
|
||||||
|
// View the bundle analyzer report after build finishes:
|
||||||
|
// `npm run build --report`
|
||||||
|
// Set to `true` or `false` to always turn it on or off
|
||||||
|
bundleAnalyzerReport: process.env.npm_config_report
|
||||||
},
|
},
|
||||||
dev: {
|
dev: {
|
||||||
env: require('./dev.env'),
|
env: require('./dev.env'),
|
||||||
port: 8080,
|
port: process.env.PORT || 8080,
|
||||||
proxyTable: {}
|
autoOpenBrowser: true,
|
||||||
},
|
assetsSubDirectory: 'static',
|
||||||
umd: {
|
assetsPublicPath: '/',
|
||||||
assetsRoot: path.resolve(__dirname, '../umd'),
|
proxyTable: {},
|
||||||
assetsPublicPath: '/'
|
// CSS Sourcemaps off by default because relative paths are "buggy"
|
||||||
|
// with this option, according to the CSS-Loader README
|
||||||
|
// (https://github.com/webpack/css-loader#sourcemaps)
|
||||||
|
// In our experience, they generally work as expected,
|
||||||
|
// just be aware of this issue when enabling this option.
|
||||||
|
cssSourceMap: false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
'use strict'
|
||||||
module.exports = {
|
module.exports = {
|
||||||
NODE_ENV: '"production"'
|
NODE_ENV: '"production"'
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
var merge = require('webpack-merge')
|
'use strict'
|
||||||
var devEnv = require('./dev.env')
|
const merge = require('webpack-merge')
|
||||||
|
const devEnv = require('./dev.env')
|
||||||
|
|
||||||
module.exports = merge(devEnv, {
|
module.exports = merge(devEnv, {
|
||||||
NODE_ENV: '"testing"'
|
NODE_ENV: '"testing"'
|
||||||
|
|||||||
3238
dist/vue-chartjs.js
vendored
Normal file
1
dist/vue-chartjs.min.js
vendored
Normal file
112
docs/README.md
@@ -3,26 +3,26 @@ search: en
|
|||||||
---
|
---
|
||||||
|
|
||||||
# vue-chartjs
|
# vue-chartjs
|
||||||
**vue-chartjs** is a wrapper for [Chart.js](https://github.com/chartjs/Chart.js) in vue. You can easily create reuseable chart components.
|
**vue-chartjs** is a wrapper for [Chart.js](https://github.com/chartjs/Chart.js) in Vue. You can easily create reusable chart components.
|
||||||
|
|
||||||
## Introduction
|
## Introduction
|
||||||
`vue-chartjs` let you use chart.js without much hassle inside vue. It's perfect for people who need simple charts up and running as fast as possible.
|
`vue-chartjs` lets you use Chart.js without much hassle inside Vue. It's perfect for people who need simple charts up and running as fast as possible.
|
||||||
|
|
||||||
It abstracts the basic logic but exposes the chart.js object to give you the most possible flexibility.
|
It abstracts the basic logic but exposes the Chart.js object to give you maximal flexibility.
|
||||||
|
|
||||||
## Installation
|
## Installation
|
||||||
If you are working with Vue.js 2+ simple run:
|
If you are working with Vue.js 2+ simple run:
|
||||||
|
|
||||||
`yarn add vue-chartjs chart.js`
|
`yarn add vue-chartjs chart.js`
|
||||||
|
|
||||||
If you are using vue 1.x please use the `legacy` tag. However the vue 1 version is not maintained anymore.
|
If you are using vue 1.x please use the `legacy` tag. However the Vue 1 version is not maintained anymore.
|
||||||
|
|
||||||
`yarn add vue-chartjs@legacy`
|
`yarn add vue-chartjs@legacy`
|
||||||
|
|
||||||
## Quick Start
|
## Quick Start
|
||||||
|
|
||||||
You need to import the base chart and extend it. This gives much more flexibility when working with different data.
|
You need to import the base chart and extend it. This gives more flexibility when working with different data.
|
||||||
You can encapsulate your components and use props to pass data or you can directly imput them inside the component. However this way, your component is not reuseable.
|
You can encapsulate your components and use props to pass data or you can input them directly inside the component. However your component is not reusable this way.
|
||||||
|
|
||||||
You can import the whole package or each module individual.
|
You can import the whole package or each module individual.
|
||||||
|
|
||||||
@@ -30,15 +30,16 @@ You can import the whole package or each module individual.
|
|||||||
// CommitChart.js
|
// CommitChart.js
|
||||||
import { Bar } from 'vue-chartjs'
|
import { Bar } from 'vue-chartjs'
|
||||||
|
|
||||||
export default Bar.extend({
|
export default {
|
||||||
|
extends: Bar,
|
||||||
mounted () {
|
mounted () {
|
||||||
// Overwriting base render method with actual data.
|
// Overwriting base render method with actual data.
|
||||||
this.renderChart(data, options)
|
this.renderChart(data, options)
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
You can pass the `renderChart()` method, two arguments:
|
You can pass two arguments to the `renderChart()` method:
|
||||||
|
|
||||||
- Data object
|
- Data object
|
||||||
- Options object
|
- Options object
|
||||||
@@ -71,26 +72,28 @@ There are some basic props defined in the BaseCharts. Because you `extend()` the
|
|||||||
| width | chart width |
|
| width | chart width |
|
||||||
| height | chart height |
|
| height | chart height |
|
||||||
| chart-id | id of the canvas |
|
| chart-id | id of the canvas |
|
||||||
|
| css-classes | String with css classes for the surrounding div |
|
||||||
|
| styles | Object with css styles for the surrounding div container |
|
||||||
|
|
||||||
## Examples
|
## Examples
|
||||||
|
|
||||||
Here are some exmaples
|
Here are some examples
|
||||||
|
|
||||||
### Chart with props
|
### Chart with props
|
||||||
|
|
||||||
You can create the data and options props to pass data to the chart.
|
You can create data and options props to pass data to the chart.
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
// LineChart.js
|
// LineChart.js
|
||||||
import { Line } from 'vue-chartjs'
|
import { Line } from 'vue-chartjs'
|
||||||
|
|
||||||
export default Line.extend({
|
export default {
|
||||||
|
extends: Line,
|
||||||
props: ['data', 'options'],
|
props: ['data', 'options'],
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart(this.data, this.options)
|
this.renderChart(this.data, this.options)
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
After you add your component you can use it:
|
After you add your component you can use it:
|
||||||
@@ -99,7 +102,7 @@ After you add your component you can use it:
|
|||||||
<line-chart :data="{your data object}" :options="{your options}"></line-chart>
|
<line-chart :data="{your data object}" :options="{your options}"></line-chart>
|
||||||
```
|
```
|
||||||
|
|
||||||
If you want to overwrite the width and height:
|
If you want to overwrite width and height:
|
||||||
|
|
||||||
```html
|
```html
|
||||||
<line-chart
|
<line-chart
|
||||||
@@ -112,7 +115,7 @@ If you want to overwrite the width and height:
|
|||||||
```
|
```
|
||||||
|
|
||||||
<p class="warning">
|
<p class="warning">
|
||||||
Please keep in mind, that you have to set `responsive: false` to be able to set a fix `width` and `height`.
|
Please keep in mind, that you have to set `responsive: false` to be able to set a fixed `width` and `height`.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
### Chart with local data
|
### Chart with local data
|
||||||
@@ -120,7 +123,8 @@ If you want to overwrite the width and height:
|
|||||||
```javascript
|
```javascript
|
||||||
import {Bar} from 'vue-chartjs'
|
import {Bar} from 'vue-chartjs'
|
||||||
|
|
||||||
export default Bar.extend({
|
export default {
|
||||||
|
extends: Bar,
|
||||||
data () {
|
data () {
|
||||||
return {
|
return {
|
||||||
datacollection: {
|
datacollection: {
|
||||||
@@ -134,28 +138,27 @@ export default Bar.extend({
|
|||||||
]
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart(this.datacollection, {responsive: true, maintainAspectRatio: false})
|
this.renderChart(this.datacollection, {responsive: true, maintainAspectRatio: false})
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
### Reusebale Components
|
### Reusable Components
|
||||||
|
|
||||||
If you want to keep your chart components reuseable, it's the best to add a wrapper to them. This way the chart component is only responsable for the pure data representation and the wrapper component for the logic behind it. There are many different usecases and it is different if you're running a Single Page Application or integrate it in for example laravel.
|
If you want to keep your chart components reusable, it's the best to add a wrapper to them. This way the chart component is only responsible for the pure data representation and the wrapper component for the logic behind it. There are many different use cases and it is different if you're running a single page application or integrate it in for example laravel.
|
||||||
|
|
||||||
## Reactive Data
|
## Reactive Data
|
||||||
|
|
||||||
Chart.js does not provide a live update if you change the datasets. However `vue-chartjs` provides two mixins to achive this.
|
Chart.js does not provide a live update if you change the datasets. However `vue-chartjs` provides two mixins to achieve this.
|
||||||
|
|
||||||
- `reactiveProp`
|
- `reactiveProp`
|
||||||
- `reactiveData`
|
- `reactiveData`
|
||||||
|
|
||||||
Both mixins to actually the same. Most of the time you will use `reactiveProp`. It extends the logic of your chart component and automatically creates a prop names `chartData` and add a `vue watch` on this prop. On data change, it will either call `update()` if only the data inside the datasets has changed or `renderChart()` if new datasets were added.
|
Both mixins do actually achieve the same. Most of the time you will use `reactiveProp`. It extends the logic of your chart component and automatically creates a prop named `chartData` and adds a `vue watch` on this prop. On data change, it will either call `update()` if only the data inside the datasets has changed or `renderChart()` if new datasets were added.
|
||||||
|
|
||||||
`reactiveData` simply creates a local chartData variable which is not a prop! And add a watcher.
|
`reactiveData` simply creates a local chartData variable which is not a prop! and adds a watcher. This is only useful, if you need single purpose charts and make an API call inside your chart component.
|
||||||
This is only usefull, if you need single purpose charts and make an API call inside your chart component.
|
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
data () {
|
data () {
|
||||||
@@ -172,14 +175,16 @@ data () {
|
|||||||
import { Line, mixins } from 'vue-chartjs'
|
import { Line, mixins } from 'vue-chartjs'
|
||||||
const { reactiveProp } = mixins
|
const { reactiveProp } = mixins
|
||||||
|
|
||||||
export default Line.extend({
|
export default {
|
||||||
|
extends: Line,
|
||||||
mixins: [reactiveProp],
|
mixins: [reactiveProp],
|
||||||
props: ['options'],
|
props: ['options'],
|
||||||
mounted () {
|
mounted () {
|
||||||
// this.chartData is created in the mixin
|
// this.chartData is created in the mixin.
|
||||||
|
// If you want to pass options please create a local options object
|
||||||
this.renderChart(this.chartData, this.options)
|
this.renderChart(this.chartData, this.options)
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
**RandomChart.vue**
|
**RandomChart.vue**
|
||||||
@@ -240,7 +245,7 @@ export default Line.extend({
|
|||||||
```
|
```
|
||||||
|
|
||||||
<p class="warning">
|
<p class="warning">
|
||||||
⚠ Attention: If you mutate your data in a parent component and pass it to your child chart component keep in mind the javascript limitiations.
|
⚠ Attention: If you mutate your data in a parent component and pass it to your child chart component keep the javascript limitations in mind.
|
||||||
More info in this [issue#44](https://github.com/apertureless/vue-chartjs/issues/44)
|
More info in this [issue#44](https://github.com/apertureless/vue-chartjs/issues/44)
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
@@ -253,13 +258,33 @@ export default Line.extend({
|
|||||||
|
|
||||||
## Chart.js object
|
## Chart.js object
|
||||||
|
|
||||||
Sometimes you need more control over chart.js. Thats why you can access the chart.js instance over `this._chart`
|
Sometimes you need more control over Chart.js. That's why you can access the Chart.js instance over `this.$data._chart`.
|
||||||
|
|
||||||
|
## Inline plugins
|
||||||
|
|
||||||
|
In Chart.js you can define global and inline plugins. Global plugins are working without problems with `vue-chartjs` like in the [Chart.js docs](http://www.chartjs.org/docs/latest/developers/plugins.html) described.
|
||||||
|
|
||||||
|
If you want to add inline plugins, `vue-chartjs` exposes a helper method called `addPlugin()`
|
||||||
|
You should call `addPlugin()` before the `renderChart()` method.
|
||||||
|
|
||||||
|
### Example
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
mounted () {
|
||||||
|
this.addPlugin({
|
||||||
|
id: 'my-plugin',
|
||||||
|
beforeInit: function (chart) {
|
||||||
|
....
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
## Available Charts
|
## Available Charts
|
||||||
|
|
||||||
### Bar Chart
|
### Bar Chart
|
||||||
<p class="tip">
|
<p class="tip">
|
||||||
There are two versions of the Bar chart. `{Bar}` and `{HorizontalBar}`
|
There are two versions of the Bar chart: `{Bar}` and `{HorizontalBar}`
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||

|

|
||||||
@@ -287,9 +312,15 @@ Sometimes you need more control over chart.js. Thats why you can access the char
|
|||||||
|
|
||||||

|

|
||||||
|
|
||||||
|
### Scatter
|
||||||
|
|
||||||
|
This chart has a different data structure then the others. Right now the reactive mixins are not working for this chart type.
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
|
||||||
## Explanation of Different Builds
|
## Explanation of Different Builds
|
||||||
There are three different entry points. It depends on which build setup do you have. The dependencies are bundled or required as a peerDependency.
|
There are three different entry points. It depends on your build setup. The dependencies are bundled or required as a peerDependency.
|
||||||
|
|
||||||
- Browser
|
- Browser
|
||||||
- Browserify / Webpack 1
|
- Browserify / Webpack 1
|
||||||
@@ -305,15 +336,24 @@ There are three different entry points. It depends on which build setup do you h
|
|||||||
| es/index* | peerDependency | peerDependency |
|
| es/index* | peerDependency | peerDependency |
|
||||||
|
|
||||||
### Browser
|
### Browser
|
||||||
You can use `vue-chartjs` directly in the browser without any build setup. Like in this [codepen](https://codepen.io/apertureless/pen/vxWbqB?editors=1010). For this case, please use the `vue-chartjs.full.min.js` which is the minified version. It has Vue.js and Chart.js bundled into it. And bundled to a UMD Module. So you only need that one file.
|
You can use `vue-chartjs` directly in the browser without any build setup, like in this [codepen](https://codepen.io/apertureless/pen/vxWbqB?editors=1010). In this case, please use the `vue-chartjs.full.min.js` which is the minified version. It has Vue.js and Chart.js bundled into it and is bundled to a UMD module, so you only need that one file.
|
||||||
|
|
||||||
|
|
||||||
### Browserify / Webpack 1
|
### Browserify / Webpack 1
|
||||||
|
|
||||||
If you're using Gulp, Browserify or Webpack 1 the entry is `vue-chartjs.js` which is __transpiled__ and __bundled__ UMD Module.
|
If you're using Gulp, Browserify or Webpack 1 the entry is `vue-chartjs.js` which is __transpiled__ and __bundled__ UMD Module.
|
||||||
|
|
||||||
However Vue.js and Chart.js are `peerDependencies` so you have to install them seperately. In most projects you will have `Vue.js` already installed anyways. This way, you can have different versions of Vue.js and Chart.js then in this package.
|
However Vue.js and Chart.js are `peerDependencies` so you have to install them separately. In most projects you will have Vue.js already installed anyways. This way, you can have different versions of Vue.js and Chart.js then in this package.
|
||||||
|
|
||||||
### Webpack 2
|
### Webpack 2
|
||||||
If you're using Webpack 2 it will automatically use the `jsnext:main` / `module` entry point. Which is `es/index.js`
|
If you're using Webpack 2 it will automatically use the `jsnext:main` / `module` entry point, which is `es/index.js`. It is a __transpiled__ es version of the source and is not __bundled__ to a module. This way your tree shaking will work. Like in the bundled version, Vue.js and Chart.js are `peerDependencies` and need to be installed.
|
||||||
It is a __transpiled__ es version of the source. And is not __bundled__ to a module. This way your tree shaking will work. Like in the bundled version, `Vue.js` and `Chart.js` are `peerDependencies` and need to be installed.
|
|
||||||
|
## Resources
|
||||||
|
|
||||||
|
You can find here some resources like tutorials on how to use `vue-chartjs`
|
||||||
|
|
||||||
|
- [Using vue-chartjs with WordPress](https://medium.com/@apertureless/wordpress-vue-and-chart-js-6b61493e289f)
|
||||||
|
- [Create stunning Charts with Vue and Chart.js](https://hackernoon.com/creating-stunning-charts-with-vue-js-and-chart-js-28af584adc0a)
|
||||||
|
- [Let’s Build a Web App with Vue, Chart.js and an API Part I](https://hackernoon.com/lets-build-a-web-app-with-vue-chart-js-and-an-api-544eb81c4b44)
|
||||||
|
- [Let’s Build a Web App with Vue, Chart.js and an API Part II](https://hackernoon.com/lets-build-a-web-app-with-vue-chart-js-and-an-api-part-ii-39781b1d5acf)
|
||||||
|
- [Build a realtime chart with VueJS and Pusher](https://blog.pusher.com/build-realtime-chart-with-vuejs-pusher/)
|
||||||
|
|||||||
BIN
docs/assets/bar.png
Normal file → Executable file
|
Before Width: | Height: | Size: 95 KiB After Width: | Height: | Size: 25 KiB |
BIN
docs/assets/bubble.png
Normal file → Executable file
|
Before Width: | Height: | Size: 83 KiB After Width: | Height: | Size: 26 KiB |
BIN
docs/assets/doughnut.png
Normal file → Executable file
|
Before Width: | Height: | Size: 91 KiB After Width: | Height: | Size: 41 KiB |
BIN
docs/assets/line.png
Normal file → Executable file
|
Before Width: | Height: | Size: 125 KiB After Width: | Height: | Size: 31 KiB |
BIN
docs/assets/pie.png
Normal file → Executable file
|
Before Width: | Height: | Size: 97 KiB After Width: | Height: | Size: 76 KiB |
BIN
docs/assets/polar.png
Normal file → Executable file
|
Before Width: | Height: | Size: 200 KiB After Width: | Height: | Size: 87 KiB |
BIN
docs/assets/radar.png
Normal file → Executable file
|
Before Width: | Height: | Size: 180 KiB After Width: | Height: | Size: 75 KiB |
BIN
docs/assets/scatter.png
Executable file
|
After Width: | Height: | Size: 43 KiB |
@@ -1,8 +1,12 @@
|
|||||||
const langs = [
|
const langs = [
|
||||||
{title: 'English', path: '/home', matchPath: /^\/(home|changelog)/},
|
{title: 'English', path: '/home', matchPath: /^\/(home|changelog)/},
|
||||||
{title: 'Deutsch', path: '/de/', matchPath: /^\/de/},
|
{title: 'Deutsch', path: '/de/', matchPath: /^\/de/},
|
||||||
|
{title: 'Français', path: '/fr-fr/', matchPath: /^\/fr-fr/},
|
||||||
{title: '日本語', path: '/ja/', matchPath: /^\/ja/},
|
{title: '日本語', path: '/ja/', matchPath: /^\/ja/},
|
||||||
{title: 'Português do Brasil', path: '/pt-br/', matchPath: /^\/pt-br/}
|
{title: 'Português do Brasil', path: '/pt-br/', matchPath: /^\/pt-br/},
|
||||||
|
{title: '中文(简体)', path: '/zh-cn/', matchPath: /^\/zh-cn/},
|
||||||
|
{title: 'Русский', path: '/ru/', matchPath: /^\/ru/},
|
||||||
|
{title: 'Bahasa Indonesia', path: '/id/', matchPath: /^\/ru/}
|
||||||
]
|
]
|
||||||
|
|
||||||
docute.init({
|
docute.init({
|
||||||
@@ -37,7 +41,7 @@ docute.init({
|
|||||||
apiKey: 'b3544f7387612693644777553675d56a',
|
apiKey: 'b3544f7387612693644777553675d56a',
|
||||||
indexName: 'vue-chartjs',
|
indexName: 'vue-chartjs',
|
||||||
// algolia docsearch allows you to search with tag filter
|
// algolia docsearch allows you to search with tag filter
|
||||||
tags: ['en', 'de', 'ja', 'pt-br'],
|
tags: ['en', 'fr', 'ja', 'pt-br', 'ru'],
|
||||||
// this plugin does require a url too
|
// this plugin does require a url too
|
||||||
// where docsearch fetches contents
|
// where docsearch fetches contents
|
||||||
url: 'https://vue-chartjs.org'
|
url: 'https://vue-chartjs.org'
|
||||||
|
|||||||
@@ -1,311 +0,0 @@
|
|||||||
---
|
|
||||||
search: de
|
|
||||||
---
|
|
||||||
|
|
||||||
# vue-chartjs
|
|
||||||
**vue-chartjs** ist ein Wrapper für [Chart.js](https://github.com/chartjs/Chart.js) in vue. Man kann einfach wiederverwendbare Chart Components erstellen.
|
|
||||||
|
|
||||||
## Einleitung
|
|
||||||
`vue-chartjs` let you use chart.js without much hassle inside vue. It's perfect for people who need simple charts up and running as fast as possible.
|
|
||||||
|
|
||||||
It abstracts the basic logic but exposes the chart.js object to give you the most possible flexibility.
|
|
||||||
|
|
||||||
## Installation
|
|
||||||
If you are working with Vue.js 2+ simple run:
|
|
||||||
|
|
||||||
`yarn add vue-chartjs chart.js`
|
|
||||||
|
|
||||||
If you are using vue 1.x please use the `legacy` tag. However the vue 1 version is not maintained anymore.
|
|
||||||
|
|
||||||
`yarn add vue-chartjs@legacy`
|
|
||||||
|
|
||||||
## Schnellstart
|
|
||||||
|
|
||||||
You need to import the base chart and extend it. This gives much more flexibility when working with different data.
|
|
||||||
You can encapsulate your components and use props to pass data or you can directly imput them inside the component. However this way, your component is not reuseable.
|
|
||||||
|
|
||||||
You can import the whole package or each module individual.
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
// CommitChart.js
|
|
||||||
import { Bar } from 'vue-chartjs'
|
|
||||||
|
|
||||||
export default Bar.extend({
|
|
||||||
mounted () {
|
|
||||||
// Overwriting base render method with actual data.
|
|
||||||
this.renderChart(data, options)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
```
|
|
||||||
|
|
||||||
You can pass the `renderChart()` method, two arguments:
|
|
||||||
|
|
||||||
- Data object
|
|
||||||
- Options object
|
|
||||||
|
|
||||||
### Data object
|
|
||||||
|
|
||||||
The data object looks like this:
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
{
|
|
||||||
labels: ['January', 'February'],
|
|
||||||
datasets: [
|
|
||||||
{
|
|
||||||
label: 'GitHub Commits',
|
|
||||||
backgroundColor: '#f87979',
|
|
||||||
data: [40, 20]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
For more information take a look at the [Chart.js](http://www.chartjs.org/docs/#chart-configuration-chart-data) docs.
|
|
||||||
|
|
||||||
## Props
|
|
||||||
|
|
||||||
There are some basic props defined in the BaseCharts. Because you `extend()` them, they are *invisible*, but you can overwrite them:
|
|
||||||
|
|
||||||
| Prop | Description |
|
|
||||||
|---|---|
|
|
||||||
| width | chart width |
|
|
||||||
| height | chart height |
|
|
||||||
| chart-id | id of the canvas |
|
|
||||||
|
|
||||||
|
|
||||||
## Examples
|
|
||||||
|
|
||||||
Here are some exmaples
|
|
||||||
|
|
||||||
### Chart with props
|
|
||||||
|
|
||||||
You can create the data and options props to pass data to the chart.
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
// LineChart.js
|
|
||||||
import { Line } from 'vue-chartjs'
|
|
||||||
|
|
||||||
export default Line.extend({
|
|
||||||
props: ['data', 'options'],
|
|
||||||
mounted () {
|
|
||||||
this.renderChart(this.data, this.options)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
```
|
|
||||||
|
|
||||||
After you add your component you can use it:
|
|
||||||
|
|
||||||
```html
|
|
||||||
<line-chart :data="{your data object}" :options="{your options}"></line-chart>
|
|
||||||
```
|
|
||||||
|
|
||||||
If you want to overwrite the width and height:
|
|
||||||
|
|
||||||
```html
|
|
||||||
<line-chart
|
|
||||||
:data="{your data object}"
|
|
||||||
:options="{responsive: false, maintainAspectRatio: false}"
|
|
||||||
:width="400"
|
|
||||||
:height="200"
|
|
||||||
>
|
|
||||||
</line-chart>
|
|
||||||
```
|
|
||||||
|
|
||||||
<p class="warning">
|
|
||||||
Please keep in mind, that you have to set `responsive: false` to be able to set a fix `width` and `height.
|
|
||||||
</p>
|
|
||||||
|
|
||||||
### Chart with local data
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
import {Bar} from 'vue-chartjs'
|
|
||||||
|
|
||||||
export default Bar.extend({
|
|
||||||
data () {
|
|
||||||
return {
|
|
||||||
datacollection: {
|
|
||||||
labels: ['January', 'February'],
|
|
||||||
datasets: [
|
|
||||||
{
|
|
||||||
label: 'Data One',
|
|
||||||
backgroundColor: '#f87979',
|
|
||||||
data: [40, 20]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
mounted () {
|
|
||||||
this.renderChart(this.datacollection, {responsive: true, maintainAspectRatio: false})
|
|
||||||
}
|
|
||||||
})
|
|
||||||
```
|
|
||||||
|
|
||||||
### Reusebale Components
|
|
||||||
|
|
||||||
If you want to keep your chart components reuseable, it's the best to add a wrapper to them. This way the chart component is only responsable for the pure data representation and the wrapper component for the logic behind it. There are many different usecases and it is different if you're running a Single Page Application or integrate it in for example laravel.
|
|
||||||
|
|
||||||
## Reactive Data
|
|
||||||
|
|
||||||
Chart.js does not provide a live update if you change the datasets. However `vue-chartjs` provides two mixins to achive this.
|
|
||||||
|
|
||||||
- `reactiveProp`
|
|
||||||
- `reactiveData`
|
|
||||||
|
|
||||||
Both mixins to actually the same. Most of the time you will use `reactiveProp`. It extends the logic of your chart component and automatically creates a prop names `chartData` and add a `vue watch` on this prop. On data change, it will either call `update()` if only the data inside the datasets has changed or `renderChart()` if new datasets were added.
|
|
||||||
|
|
||||||
`reactiveData` simply creates a local chartData variable which is not a prop! And add a watcher.
|
|
||||||
This is only usefull, if you need single purpose charts and make an API call inside your chart component.
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
data () {
|
|
||||||
return {
|
|
||||||
chartData: null
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
### Example
|
|
||||||
|
|
||||||
**LineChart.js**
|
|
||||||
```javascript
|
|
||||||
import { Line, mixins } from 'vue-chartjs'
|
|
||||||
const { reactiveProp } = mixins
|
|
||||||
|
|
||||||
export default Line.extend({
|
|
||||||
mixins: [reactiveProp],
|
|
||||||
props: ['options'],
|
|
||||||
mounted () {
|
|
||||||
// this.chartData is created in the mixin
|
|
||||||
this.renderChart(this.chartData, this.options)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
```
|
|
||||||
|
|
||||||
**RandomChart.vue**
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
<template>
|
|
||||||
<div class="small">
|
|
||||||
<line-chart :chart-data="datacollection"></line-chart>
|
|
||||||
<button @click="fillData()">Randomize</button>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script>
|
|
||||||
import LineChart from './LineChart.js'
|
|
||||||
|
|
||||||
export default {
|
|
||||||
components: {
|
|
||||||
LineChart
|
|
||||||
},
|
|
||||||
data () {
|
|
||||||
return {
|
|
||||||
datacollection: null
|
|
||||||
}
|
|
||||||
},
|
|
||||||
mounted () {
|
|
||||||
this.fillData()
|
|
||||||
},
|
|
||||||
methods: {
|
|
||||||
fillData () {
|
|
||||||
this.datacollection = {
|
|
||||||
labels: [this.getRandomInt(), this.getRandomInt()],
|
|
||||||
datasets: [
|
|
||||||
{
|
|
||||||
label: 'Data One',
|
|
||||||
backgroundColor: '#f87979',
|
|
||||||
data: [this.getRandomInt(), this.getRandomInt()]
|
|
||||||
}, {
|
|
||||||
label: 'Data One',
|
|
||||||
backgroundColor: '#f87979',
|
|
||||||
data: [this.getRandomInt(), this.getRandomInt()]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
getRandomInt () {
|
|
||||||
return Math.floor(Math.random() * (50 - 5 + 1)) + 5
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style>
|
|
||||||
.small {
|
|
||||||
max-width: 600px;
|
|
||||||
margin: 150px auto;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
```
|
|
||||||
|
|
||||||
<p class="warning">
|
|
||||||
⚠ Attention: If you mutate your data in a parent component and pass it to your child chart component keep in mind the javascript limitiations.
|
|
||||||
More info in this [issue#44](https://github.com/apertureless/vue-chartjs/issues/44)
|
|
||||||
</p>
|
|
||||||
|
|
||||||
### Limitations
|
|
||||||
<ul>
|
|
||||||
<li>[Caveats](https://vuejs.org/v2/guide/list.html#Caveats)</li>
|
|
||||||
<li>[Change-Detection-Caveats](https://vuejs.org/v2/guide/reactivity.html#Change-Detection-Caveats)</li>
|
|
||||||
<li>[vm.$watch](https://vuejs.org/v2/api/#vm-watch)</li>
|
|
||||||
</ul>
|
|
||||||
|
|
||||||
## Chart.js object
|
|
||||||
|
|
||||||
Sometimes you need more control over chart.js. Thats why you can access the chart.js instance over `this._chart`
|
|
||||||
|
|
||||||
## Available Charts
|
|
||||||
|
|
||||||
### Bar Chart
|
|
||||||
<p class="tip">
|
|
||||||
There are two versions of the Bar chart. `{Bar}` and `{HorizontalBar}`
|
|
||||||
</p>
|
|
||||||
|
|
||||||

|
|
||||||
### Line Chart
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
### Doughnut
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
### Pie
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
### Radar
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
### Polar Area
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
### Bubble
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
## Webpack, Browserify and dist files.
|
|
||||||
|
|
||||||
If you use `import VueCharts from 'vue-chartjs'` you will mostly import the UMD build of vue-chart.js
|
|
||||||
This is because of compatibility reasons. This approach however has a downside: vue.js and chart.js are bundled into the file.
|
|
||||||
And you end up with two vue instances.
|
|
||||||
|
|
||||||
If you're using webpack 2 or rollup however, it will automatically import the transpiled ES sources.
|
|
||||||
If you know what you're doing you can import directly from the transpiled es sources:
|
|
||||||
|
|
||||||
```
|
|
||||||
import { Line } from 'vue-chartjs/es'
|
|
||||||
```
|
|
||||||
|
|
||||||
### Browserify
|
|
||||||
|
|
||||||
In order for a browserify user to transpile the code, they would need to install `babelify` and `babel-preset-es2015` and add a .babelrc file in the root of their project with the following code:
|
|
||||||
|
|
||||||
```
|
|
||||||
{
|
|
||||||
"presets": ["es2015"]
|
|
||||||
}
|
|
||||||
```
|
|
||||||
366
docs/fr-fr/README.md
Normal file
@@ -0,0 +1,366 @@
|
|||||||
|
---
|
||||||
|
search: fr-fr
|
||||||
|
---
|
||||||
|
|
||||||
|
# vue-chartjs
|
||||||
|
**vue-chartjs** is a wrapper for [Chart.js](https://github.com/chartjs/Chart.js) in vue. You can easily create reuseable chart components.
|
||||||
|
|
||||||
|
## Introduction
|
||||||
|
`vue-chartjs` vous permet d'utiliser chart.js avec vue sans prise de tête. C'est la solution idéale pour ceux qui souhaitent créer des graphes simplement et rapidement.
|
||||||
|
|
||||||
|
La logique interne de chart.js est abstraite, mais l'objet sous-jacent est exposé, de sorte que vous puissiez bénéficier de la plus grande flexibilité possible.
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
Si vous travaillez avec Vue.js 2+, exécutez simplement :
|
||||||
|
|
||||||
|
`yarn add vue-chartjs chart.js`
|
||||||
|
|
||||||
|
Avec vue 1.x, il vous faudra utiliser le marqueur `legacy`. Notez toutefois que la version 1 de vue n'est plus maintenue à l'heure actuelle.
|
||||||
|
|
||||||
|
`yarn add vue-chartjs@legacy`
|
||||||
|
|
||||||
|
## Démarrage rapide
|
||||||
|
|
||||||
|
Importez l'objet graphe de base afin de l'étendre. Cette façon de faire offre beaucoup plus de flexibilité lorsque plusieurs sources de données sont utilisées.
|
||||||
|
Il est possible d'encapsuler vos composants et d'utiliser les props pour transmettre les données, ou vous pouvez également les indiquer directement à l'intérieur du composant. Cependant, cette seconde méthode ne créera pas des composants réutilisables.
|
||||||
|
|
||||||
|
Vous pouvez choisir d'importer le package dans son intégralité, ou chaque composant individuellement.
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
// CommitChart.js
|
||||||
|
import { Bar } from 'vue-chartjs'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: Bar,
|
||||||
|
mounted () {
|
||||||
|
// Surcharge de la méthode render avec les données.
|
||||||
|
this.renderChart(data, options)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
La méthode `renderChart()` prend deux paramètres :
|
||||||
|
|
||||||
|
- un objet de données
|
||||||
|
- un objet d'options
|
||||||
|
|
||||||
|
### Objet de données
|
||||||
|
|
||||||
|
L'objet de données prend la structure suivante :
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
{
|
||||||
|
labels: ['Janvier', 'Février'],
|
||||||
|
datasets: [
|
||||||
|
{
|
||||||
|
label: 'Commits sur GitHub',
|
||||||
|
backgroundColor: '#f87979',
|
||||||
|
data: [40, 20]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Pour plus d'informations, vous pouvez lire la documentation [Chart.js](http://www.chartjs.org/docs/#chart-configuration-chart-data).
|
||||||
|
|
||||||
|
## Props
|
||||||
|
|
||||||
|
Certains props de base sont définis dans BaseCharts. Grâce à l'héritage de l'opération `extend()`, ceux-ci peuvent être surchargés, bien qu'ils soient *invisibles*.
|
||||||
|
|
||||||
|
| Prop | Description |
|
||||||
|
|---|---|
|
||||||
|
| width | largeur du graphe |
|
||||||
|
| height | hauteur du graphe |
|
||||||
|
| chart-id | id du canvas |
|
||||||
|
| css-classes | Chaîne de caractères avec les classes CSS à appliquer à l'élément div parent |
|
||||||
|
| styles | Object avec les styles CSS à appliquer à l'élément div parent |
|
||||||
|
|
||||||
|
## Exemples
|
||||||
|
|
||||||
|
Voici quelques exemples.
|
||||||
|
|
||||||
|
### Graphe avec props
|
||||||
|
|
||||||
|
Vous pouvez créer les props data et options à transmetttre au graphe.
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
// LineChart.js
|
||||||
|
import { Line } from 'vue-chartjs'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: Line,
|
||||||
|
props: ['data', 'options'],
|
||||||
|
mounted () {
|
||||||
|
this.renderChart(this.data, this.options)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Vous pourrez les utiliser après avoir ajouté votre composant :
|
||||||
|
|
||||||
|
```html
|
||||||
|
<line-chart :data="{votre objet de données}" :options="{vos options}"></line-chart>
|
||||||
|
```
|
||||||
|
|
||||||
|
Si vous souhaitez modifier la hauteur ou la largeur :
|
||||||
|
|
||||||
|
```html
|
||||||
|
<line-chart
|
||||||
|
:data="{votre objet de données}"
|
||||||
|
:options="{responsive: false, maintainAspectRatio: false}"
|
||||||
|
:width="400"
|
||||||
|
:height="200"
|
||||||
|
>
|
||||||
|
</line-chart>
|
||||||
|
```
|
||||||
|
|
||||||
|
<p class="warning">
|
||||||
|
Vous devrez préciser `responsive: false` si vous souhaitez appliquer une taille fixe avec `width` et `height`.
|
||||||
|
</p>
|
||||||
|
|
||||||
|
### Graphe avec données locales
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
import {Bar} from 'vue-chartjs'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: Bar,
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
datacollection: {
|
||||||
|
labels: ['Janvier', 'Février'],
|
||||||
|
datasets: [
|
||||||
|
{
|
||||||
|
label: 'Data One',
|
||||||
|
backgroundColor: '#f87979',
|
||||||
|
data: [40, 20]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
mounted () {
|
||||||
|
this.renderChart(this.datacollection, {responsive: true, maintainAspectRatio: false})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Composants réutilisables
|
||||||
|
|
||||||
|
Si vous souhaitez faire en sorte que vos composants restent réutilisables, appliquez un wrapper. De cette manière, le composant graphique est seulement responsable de la représentation de la donnée, alors que le wrapper se charge de la logique derrière elle. Il y a de nombreux cas d'utilisations, et la manière de faire sera différente si vous êtes sur une Application Monopage (SPA) ou si vous intégrez sur du Laravel par exemple.
|
||||||
|
|
||||||
|
## Données en direct
|
||||||
|
|
||||||
|
Chart.js ne fournit pas de mécanisme de mise à jour automatique si jamais vous deviez modifier vos jeux de données. Cependant, `vue-chartjs` met à disposition deux mixins pour cela :
|
||||||
|
|
||||||
|
- `reactiveProp`
|
||||||
|
- `reactiveData`
|
||||||
|
|
||||||
|
Tous deux réalisent le même travail. La plupart du temps, c'est `reactiveProp` que vous utiliserez. Il reprend la logique de votre composant graphique, et crée automatiquement une prop `chartData` et ajoute une `vue watch` sur celle-ci. Lorsque la donnée change, `update()` sera appelée si c'est seulement le coeur de la donnée qui est modifié, et `renderChart()` si de nouveaux jeux de données ont été ajoutés.
|
||||||
|
|
||||||
|
`reactiveData` crée une variable locale chartData (pas une prop !), et lui ajoute un watcher.
|
||||||
|
Le seul cas d'utilisation est celui où vous souhaitez un graphe à usage unique, et que vous effectuez des appels API à l'intérieur même du composant.
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
chartData: null
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Exemple
|
||||||
|
|
||||||
|
**LineChart.js**
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
import { Line, mixins } from 'vue-chartjs'
|
||||||
|
const { reactiveProp } = mixins
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: Line,
|
||||||
|
mixins: [reactiveProp],
|
||||||
|
props: ['options'],
|
||||||
|
mounted () {
|
||||||
|
// this.chartData est créé par le mixin.
|
||||||
|
// si vous voulez transmettre des options, il faudra créer une variable locale
|
||||||
|
this.renderChart(this.chartData, this.options)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
**RandomChart.vue**
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
<template>
|
||||||
|
<div class="small">
|
||||||
|
<line-chart :chart-data="datacollection"></line-chart>
|
||||||
|
<button @click="fillData()">Aléatoire</button>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import LineChart from './LineChart.js'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
components: {
|
||||||
|
LineChart
|
||||||
|
},
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
datacollection: null
|
||||||
|
}
|
||||||
|
},
|
||||||
|
mounted () {
|
||||||
|
this.fillData()
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
fillData () {
|
||||||
|
this.datacollection = {
|
||||||
|
labels: [this.getRandomInt(), this.getRandomInt()],
|
||||||
|
datasets: [
|
||||||
|
{
|
||||||
|
label: 'Data One',
|
||||||
|
backgroundColor: '#f87979',
|
||||||
|
data: [this.getRandomInt(), this.getRandomInt()]
|
||||||
|
}, {
|
||||||
|
label: 'Data One',
|
||||||
|
backgroundColor: '#f87979',
|
||||||
|
data: [this.getRandomInt(), this.getRandomInt()]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
getRandomInt () {
|
||||||
|
return Math.floor(Math.random() * (50 - 5 + 1)) + 5
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style>
|
||||||
|
.small {
|
||||||
|
max-width: 600px;
|
||||||
|
margin: 150px auto;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
```
|
||||||
|
|
||||||
|
<p class="warning">
|
||||||
|
⚠ Attention : si vous permutez vos données dans un composant parent puis les transmettez à un composant enfant, gardez à l'esprit les limitations de javascript.
|
||||||
|
Plus d'infos sur [issue#44](https://github.com/apertureless/vue-chartjs/issues/44).
|
||||||
|
</p>
|
||||||
|
|
||||||
|
### Limitations
|
||||||
|
<ul>
|
||||||
|
<li>[Mises en garde](https://vuejs.org/v2/guide/list.html#Caveats)</li>
|
||||||
|
<li>[Mise en garde sur la détection des modifications](https://vuejs.org/v2/guide/reactivity.html#Change-Detection-Caveats)</li>
|
||||||
|
<li>[vm.$watch](https://vuejs.org/v2/api/#vm-watch)</li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
## Objet Chart.js
|
||||||
|
|
||||||
|
Il peut arriver d'avoir besoin de plus de contrôle sur l'objet chart.js. Vous pouvez, à cet effet, accéder à cet objet via `this.$data._chart`.
|
||||||
|
|
||||||
|
## Plugins inline
|
||||||
|
|
||||||
|
Avec Chart.js, vous pouvez définir des pugins globaux ou inline. Les plugins globaux fonctionnent sans souci avec `vue-chartjs`, comme décrit dans la [documentation chart.js](http://www.chartjs.org/docs/latest/developers/plugins.html).
|
||||||
|
|
||||||
|
Si vous désirez ajouter des plugins inline, `vue-chartjs` expose une méthode `addPlugin()`. L'appel à cette méthode doit se faire avant celui de `renderChart()`.
|
||||||
|
|
||||||
|
### Exemple
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
mounted () {
|
||||||
|
this.addPlugin({
|
||||||
|
id: 'mon-plugin',
|
||||||
|
beforeInit: function (chart) {
|
||||||
|
....
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Diagrammes disponibles
|
||||||
|
|
||||||
|
### Colonnes
|
||||||
|
|
||||||
|
<p class="tip">
|
||||||
|
Il y a deux versions du diagramme colonnes : `{Bar}` et `{HorizontalBar}`
|
||||||
|
</p>
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### Ligne
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### Beignet
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### Circulaire
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### Radar
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### Polaire
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### Bulles
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
|
||||||
|
### Nuages de points
|
||||||
|
|
||||||
|
Ce diagramme utilise une structure de données différente des autres. Pour le moment, les mixis de mise à jour de données ne fonctionnent pas avec ce type de graphique.
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
|
||||||
|
## Explications sur les différents builds
|
||||||
|
|
||||||
|
Il y a trois builds différents. Le choix dépend de votre projet. Les dépendances sont soient intégrées, soit marquées comme peerDependency.
|
||||||
|
|
||||||
|
- Browser
|
||||||
|
- Browserify / Webpack 1
|
||||||
|
- Webpack 2
|
||||||
|
|
||||||
|
|
||||||
|
| Build | Chart.js | Vue.js |
|
||||||
|
|---|---|---|
|
||||||
|
| vue-chartjs.full.js | Intégré | Intégré |
|
||||||
|
| vue-chartjs.full.min.js | Intégré | Intégré |
|
||||||
|
| vue-chartjs.js | peerDependency | peerDependency |
|
||||||
|
| vue-chartjs.min.js | peerDependency | peerDependency |
|
||||||
|
| es/index* | peerDependency | peerDependency |
|
||||||
|
|
||||||
|
### Browser
|
||||||
|
|
||||||
|
Vous pouvez utiliser `vue-chartjs` directement depuis votre navigateur sans aucun pré-requis. Comme par exemple sur ce [codepen](https://codepen.io/apertureless/pen/vxWbqB?editors=1010). Dans une telle situation, veuillez utiliser `vue-chartjs.full.min.js`, qui est la version compressée. Elle intègre Vue.js et Chart.js, et est bundlée à un module UMD. Donc ce fichier se suffit à lui-même.
|
||||||
|
|
||||||
|
|
||||||
|
### Browserify / Webpack 1
|
||||||
|
|
||||||
|
Si vous utilisez Gulp, Browserify ou Webpack 1, vous devrez prendre `vue-chartjs.js`, qui est __transpilé__ et __bundlé__ comme module UMD.
|
||||||
|
|
||||||
|
Toutefois, Vue.js et Chart.js sont des `peerDependencies`, vous devrez donc les installer séparemment. Dans la plupart des projets, `Vue.js` sera de toute façon déjà installé. De cette manière, vous pouvez utiliser des versions différentes de Vue.js et Chart.js dans un même package.
|
||||||
|
|
||||||
|
### Webpack 2
|
||||||
|
|
||||||
|
Si vous utilisez Webpack 2, `jsnext:main` / `module` sera automatiquement sélectionné. `es/index.js`est une version es __transpilée__ des sources, et n'est pas __bundlée__ à un module. Ainsi, rien ne devrait bloquer l'élimination de code mort. Comme dans la version bundlée précédente, `Vue.js` et `Chart.js` sont des `peerDependencies` et doivent être installés.
|
||||||
|
|
||||||
|
## Ressources
|
||||||
|
|
||||||
|
Voici une liste de ressources et tutoriels sur comment utiliser `vue-chartjs` :
|
||||||
|
|
||||||
|
- [Using vue-chartjs with WordPress](https://medium.com/@apertureless/wordpress-vue-and-chart-js-6b61493e289f)
|
||||||
|
- [Create stunning Charts with Vue and Chart.js](https://hackernoon.com/creating-stunning-charts-with-vue-js-and-chart-js-28af584adc0a)
|
||||||
|
- [Let’s Build a Web App with Vue, Chart.js and an API Part I](https://hackernoon.com/lets-build-a-web-app-with-vue-chart-js-and-an-api-544eb81c4b44)
|
||||||
|
- [Let’s Build a Web App with Vue, Chart.js and an API Part II](https://hackernoon.com/lets-build-a-web-app-with-vue-chart-js-and-an-api-part-ii-39781b1d5acf)
|
||||||
|
- [Build a realtime chart with VueJS and Pusher](https://blog.pusher.com/build-realtime-chart-with-vuejs-pusher/)
|
||||||
363
docs/id/README.md
Normal file
@@ -0,0 +1,363 @@
|
|||||||
|
---
|
||||||
|
search: id
|
||||||
|
---
|
||||||
|
|
||||||
|
# vue-chartjs
|
||||||
|
**vue-chartjs** adalah wrapper [Chart.js](https://github.com/chartjs/Chart.js) dalam vue. Kamu dapat dengan mudah membuat komponen chart reusable.
|
||||||
|
|
||||||
|
## Pengenalan
|
||||||
|
`vue-chartjs` memungkinkan kamu untuk menggunakan chart.js tanpa usaha lebih didalam vue. Sempurna untuk orang-orang yang membutuhkan bagan/chart simpel dengan cepat.
|
||||||
|
|
||||||
|
Flexibel karena langsung menampilkan objek chart.js.
|
||||||
|
|
||||||
|
|
||||||
|
## Instalasi
|
||||||
|
Jika kamu menggunakan Vue.js 2+:
|
||||||
|
|
||||||
|
`yarn add vue-chartjs chart.js`
|
||||||
|
|
||||||
|
Jika menggunakan vue 1.x gunakan tag `legacy`. versi vue 1 sudah tidak diurus lagi.
|
||||||
|
|
||||||
|
`yarn add vue-chartjs@legacy`
|
||||||
|
|
||||||
|
## Mulai Cepat
|
||||||
|
|
||||||
|
Kamu perlu untuk meng-import base chart dan meng-extend-nya. Dengan cara ini akan lebih fleksibel ketika bekerja dengan data yang berbeda.
|
||||||
|
Kamu dapat melakukan enkapsulasi komponen-komponen dan menggunakan props untuk menyampaikan data atau bisa juga dengan menginputkan langsung didalam komponen. Namun komponenmu tidak reuseable.
|
||||||
|
|
||||||
|
Kamu bisa meng-import seluruh package atau modul-modul terpisah.
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
// CommitChart.js
|
||||||
|
import { Bar } from 'vue-chartjs'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: Bar,
|
||||||
|
mounted () {
|
||||||
|
// Overwriting base render method with actual data.
|
||||||
|
this.renderChart(data, options)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Kamu dapat melewatkan dua argumen pada `renderChart()`:
|
||||||
|
|
||||||
|
- Objek Data
|
||||||
|
- Objek Opsi
|
||||||
|
|
||||||
|
### Data object
|
||||||
|
|
||||||
|
Objek data:
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
{
|
||||||
|
labels: ['January', 'February'],
|
||||||
|
datasets: [
|
||||||
|
{
|
||||||
|
label: 'GitHub Commits',
|
||||||
|
backgroundColor: '#f87979',
|
||||||
|
data: [40, 20]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Untuk keterangan lebih lanjut dapat dilihat di dokumentasi [Chart.js](http://www.chartjs.org/docs/#chart-configuration-chart-data).
|
||||||
|
|
||||||
|
## Props
|
||||||
|
|
||||||
|
Terdapat beberapa props standar yang didefinisikan didalam BaseChart. Karena menggunakan `extend()`, props-props tersebut *tidak terlihat*, Namun kamu tetap bisa menulis ulang:
|
||||||
|
|
||||||
|
| Prop | Description |
|
||||||
|
|---|---|
|
||||||
|
| width | lebar chart |
|
||||||
|
| height | tinggi chart |
|
||||||
|
| chart-id | id canvas |
|
||||||
|
| css-classes | String dengan kelas css mengelilingi div |
|
||||||
|
| styles | Objek dengan style css mengelilingi div |
|
||||||
|
|
||||||
|
## Contoh
|
||||||
|
|
||||||
|
Berikut adalah beberapa contoh penggunaan
|
||||||
|
|
||||||
|
### Chart dengan props
|
||||||
|
|
||||||
|
Kamu dapat membuat props data dan opsi untuk melewatkan data pada chart.
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
// LineChart.js
|
||||||
|
import { Line } from 'vue-chartjs'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: Line,
|
||||||
|
props: ['data', 'options'],
|
||||||
|
mounted () {
|
||||||
|
this.renderChart(this.data, this.options)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Setelah kamu menambahkannya kamu dapat menggunakannya seperti biasa:
|
||||||
|
|
||||||
|
```html
|
||||||
|
<line-chart :data="{your data object}" :options="{your options}"></line-chart>
|
||||||
|
```
|
||||||
|
|
||||||
|
Jika kamu ingin mengatur tinggi dan lebar:
|
||||||
|
|
||||||
|
```html
|
||||||
|
<line-chart
|
||||||
|
:data="{your data object}"
|
||||||
|
:options="{responsive: false, maintainAspectRatio: false}"
|
||||||
|
:width="400"
|
||||||
|
:height="200"
|
||||||
|
>
|
||||||
|
</line-chart>
|
||||||
|
```
|
||||||
|
|
||||||
|
<p class="warning">
|
||||||
|
Perlu diingat, kamu perlu untuk mengatur `responsive: false` agaar dapat mengatur `width` dan `height`.
|
||||||
|
</p>
|
||||||
|
|
||||||
|
### Chart dengan data lokal
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
import {Bar} from 'vue-chartjs'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: Bar,
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
datacollection: {
|
||||||
|
labels: ['January', 'February'],
|
||||||
|
datasets: [
|
||||||
|
{
|
||||||
|
label: 'Data One',
|
||||||
|
backgroundColor: '#f87979',
|
||||||
|
data: [40, 20]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
mounted () {
|
||||||
|
this.renderChart(this.datacollection, {responsive: true, maintainAspectRatio: false})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Reusable Komponen
|
||||||
|
|
||||||
|
Jika kamu ingin agar komponen chart reusable, cara paling baik adalah dengan menambahkan sebuah wrapper. Dengan cara ini komponen chart hanya bertanggung jawab dalam representasi data dan wrapper komponen bertanggung jawab dengan logika didalamnya. Banyak kasus-kasus yang berbeda dan juga berbeda jika kamu menjalankan Single Page Application atau mengintegrasikannya pada contoh laravel.
|
||||||
|
|
||||||
|
## Reactive Data
|
||||||
|
|
||||||
|
Chart.js tidak menyediakan live update jika kamu mengubah datasets. Akan tetapi `vue-chartjs` menyediakan 2 mixins untuk melakukannya.
|
||||||
|
|
||||||
|
- `reactiveProp`
|
||||||
|
- `reactiveData`
|
||||||
|
|
||||||
|
Kedua mixins tersebut sebenarnya sama. `reactiveProp` akan sering digunakan. `reactiveProp` meng-extend logika dari komponen chart dan secara otomatis membuat props `chartData` dan menambahkan `vue watch` dalam props ini. Pada saat data berubah, itu akan memanggil `update()` jika data memiliki datasets atau `renderChart()` jika datasets telah ada sebelumnya.
|
||||||
|
|
||||||
|
`reactiveData` secara sederhana membuat variabel lokal chartData dimana itu bukan sebuah props! dan watcher. Hal ini bisa berguna, jika kamu membutuhkan chart tertentu dan melakukan akses API didalam komponen chart.
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
chartData: null
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Contoh
|
||||||
|
|
||||||
|
**LineChart.js**
|
||||||
|
```javascript
|
||||||
|
import { Line, mixins } from 'vue-chartjs'
|
||||||
|
const { reactiveProp } = mixins
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: Line,
|
||||||
|
mixins: [reactiveProp],
|
||||||
|
props: ['options'],
|
||||||
|
mounted () {
|
||||||
|
// this.chartData is created in the mixin.
|
||||||
|
// If you want to pass options please create a local options object
|
||||||
|
this.renderChart(this.chartData, this.options)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
**RandomChart.vue**
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
<template>
|
||||||
|
<div class="small">
|
||||||
|
<line-chart :chart-data="datacollection"></line-chart>
|
||||||
|
<button @click="fillData()">Randomize</button>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import LineChart from './LineChart.js'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
components: {
|
||||||
|
LineChart
|
||||||
|
},
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
datacollection: null
|
||||||
|
}
|
||||||
|
},
|
||||||
|
mounted () {
|
||||||
|
this.fillData()
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
fillData () {
|
||||||
|
this.datacollection = {
|
||||||
|
labels: [this.getRandomInt(), this.getRandomInt()],
|
||||||
|
datasets: [
|
||||||
|
{
|
||||||
|
label: 'Data One',
|
||||||
|
backgroundColor: '#f87979',
|
||||||
|
data: [this.getRandomInt(), this.getRandomInt()]
|
||||||
|
}, {
|
||||||
|
label: 'Data One',
|
||||||
|
backgroundColor: '#f87979',
|
||||||
|
data: [this.getRandomInt(), this.getRandomInt()]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
getRandomInt () {
|
||||||
|
return Math.floor(Math.random() * (50 - 5 + 1)) + 5
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style>
|
||||||
|
.small {
|
||||||
|
max-width: 600px;
|
||||||
|
margin: 150px auto;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
```
|
||||||
|
|
||||||
|
<p class="warning">
|
||||||
|
⚠ Perhatian: jika kamu memutasi data didalam komponen parent dan melewatkannya pada child komponen chart perlu diingat batasan javascript.
|
||||||
|
Info lebih lanjut [issue#44](https://github.com/apertureless/vue-chartjs/issues/44)
|
||||||
|
</p>
|
||||||
|
|
||||||
|
### Batasan
|
||||||
|
<ul>
|
||||||
|
<li>[Caveats](https://vuejs.org/v2/guide/list.html#Caveats)</li>
|
||||||
|
<li>[Change-Detection-Caveats](https://vuejs.org/v2/guide/reactivity.html#Change-Detection-Caveats)</li>
|
||||||
|
<li>[vm.$watch](https://vuejs.org/v2/api/#vm-watch)</li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
## Objek Chart.js
|
||||||
|
|
||||||
|
Suatu ketika kamu membutuhkan kontrol chart.js. Kamu dapat mengaksesnya dengan `this.$data._chart`
|
||||||
|
|
||||||
|
## Inline plugins
|
||||||
|
|
||||||
|
Di Chart.js kamu dapat mendefinisikan plugin global dan inline. Plugin global bekerja tanpa masalah dengan `vue-chartjs` seperti yang dijelaskan pada [chart.js docs](http://www.chartjs.org/docs/latest/developers/plugins.html)
|
||||||
|
|
||||||
|
If you want to add inline plugins, `vue-chartjs` exposes a helper method called `addPlugin()`
|
||||||
|
You should call `addPlugin()` before the `renderChart()` method.
|
||||||
|
Jika kamu ingin menambahkan plugin inline, `vue-chartjs` menyediakan method helper `addPlugin()` kamu harus memanggil `addPlugin()` sebelum method `renderChart()`.
|
||||||
|
|
||||||
|
### Contoh
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
mounted () {
|
||||||
|
this.addPlugin({
|
||||||
|
id: 'my-plugin',
|
||||||
|
beforeInit: function (chart) {
|
||||||
|
....
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Charts yang Tersedia
|
||||||
|
|
||||||
|
### Bar Chart
|
||||||
|
<p class="tip">
|
||||||
|
Terdapat dua versi bar chart. `{Bar}` dan `{HorizontalBar}`
|
||||||
|
</p>
|
||||||
|
|
||||||
|

|
||||||
|
### Line Chart
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### Doughnut
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### Pie
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### Radar
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### Polar Area
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### Bubble
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### Scatter
|
||||||
|
|
||||||
|
This chart has a different data structure then the others. Right now the reactive Mixins are not working for this chart type.
|
||||||
|
Chart ini memiliki struktur data yang berbeda dengan yang lainnya. Untuk sekarang reactive mixins tidak dapat bekerja pada tipe chart ini.
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
|
||||||
|
## Penjelasan Build
|
||||||
|
Terdapat tiga jenis titik entri. Tergantung setup mana yang kamu gunakan. Dependensi-dependensi telah di-bundle atau require sebagai peerDependency.
|
||||||
|
|
||||||
|
- Browser
|
||||||
|
- Browserify / Webpack 1
|
||||||
|
- Webpack 2
|
||||||
|
|
||||||
|
|
||||||
|
| Build | Chart.js | Vue.js |
|
||||||
|
|---|---|---|
|
||||||
|
| vue-chartjs.full.js | Bundled | Bundled |
|
||||||
|
| vue-chartjs.full.min.js | Bundled | Bundled |
|
||||||
|
| vue-chartjs.js | peerDependency | peerDependency |
|
||||||
|
| vue-chartjs.min.js | peerDependency | peerDependency |
|
||||||
|
| es/index* | peerDependency | peerDependency |
|
||||||
|
|
||||||
|
### Browser
|
||||||
|
Kamu dapat menggunakan `vue-chartjs` secara langsung didalam browser tanpa setup build. Seperti berikut [codepen](https://codepen.io/apertureless/pen/vxWbqB?editors=1010). Dalam kasus ini, mohon gunakan `vue-chartjs.full.min.js` yang telah di-minify. Didalamnya terdapat Vue.js dan Chart.js. Dan bundel modul UMD. Jadi kamu hanya membutuhkan satu file saja.
|
||||||
|
|
||||||
|
|
||||||
|
### Browserify / Webpack 1
|
||||||
|
|
||||||
|
Jika kamu menggunakan GUlp, Browserify atau Webpack 1 entri yang digunakan adalah `vue-chartjs.js` dimana telah di__transpile__ dan di__bundle__ UMD Module.
|
||||||
|
|
||||||
|
Bagaimanapun juga Vue.js dan Chart.js adalah `peerDependencies` jadi kamu harus meng-instalnya secara terpisah. Jika kamu telah memiliki `Vue.js` kamu dapat menggunakan versi Vue.js dan Chart.js yang terdapat di-package ini.
|
||||||
|
|
||||||
|
### Webpack 2
|
||||||
|
Jika kamu menggunakan Webpack 2 secara otomatis akan menggunakan titik entri `jsnext:main` / `module`. Di `es/index.js`
|
||||||
|
Di__transpile__ es sumber dari versi ini. Dan tidak di__bundle__ pada modul. Sehingga tree shaking akan bekerja. Sama seperti versi bundle, `Vue.js` dan `Chart.js` adalah `peerDependencies` dan butuh untuk diinstal.
|
||||||
|
|
||||||
|
## Sumber-sumber
|
||||||
|
|
||||||
|
Kamu dapat menemukan sumber-sumber seperti tutrial bagaimana cara untuk menggunakan `vue-chartjs`
|
||||||
|
|
||||||
|
- [Using vue-chartjs with WordPress](https://medium.com/@apertureless/wordpress-vue-and-chart-js-6b61493e289f)
|
||||||
|
- [Create stunning Charts with Vue and Chart.js](https://hackernoon.com/creating-stunning-charts-with-vue-js-and-chart-js-28af584adc0a)
|
||||||
|
- [Let’s Build a Web App with Vue, Chart.js and an API Part I](https://hackernoon.com/lets-build-a-web-app-with-vue-chart-js-and-an-api-544eb81c4b44)
|
||||||
|
- [Let’s Build a Web App with Vue, Chart.js and an API Part II](https://hackernoon.com/lets-build-a-web-app-with-vue-chart-js-and-an-api-part-ii-39781b1d5acf)
|
||||||
|
- [Build a realtime chart with VueJS and Pusher](https://blog.pusher.com/build-realtime-chart-with-vuejs-pusher/)
|
||||||
@@ -32,12 +32,13 @@ BaseChartをインポートしてextendします。
|
|||||||
// CommitChart.js
|
// CommitChart.js
|
||||||
import { Bar } from 'vue-chartjs'
|
import { Bar } from 'vue-chartjs'
|
||||||
|
|
||||||
export default Bar.extend({
|
export default {
|
||||||
|
extends: Bar,
|
||||||
mounted () {
|
mounted () {
|
||||||
// Overwriting base render method with actual data.
|
// Overwriting base render method with actual data.
|
||||||
this.renderChart(data, options)
|
this.renderChart(data, options)
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
renderChart()メソッドに2つの引数を渡すことができます:
|
renderChart()メソッドに2つの引数を渡すことができます:
|
||||||
@@ -86,12 +87,13 @@ dataとoptionsプロパティを作成して、チャートにデータを渡す
|
|||||||
// LineChart.js
|
// LineChart.js
|
||||||
import { Line } from 'vue-chartjs'
|
import { Line } from 'vue-chartjs'
|
||||||
|
|
||||||
export default Line.extend({
|
export default {
|
||||||
|
extends: Line,
|
||||||
props: ['data', 'options'],
|
props: ['data', 'options'],
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart(this.data, this.options)
|
this.renderChart(this.data, this.options)
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
コンポーネントに追加して、使用することができます。
|
コンポーネントに追加して、使用することができます。
|
||||||
@@ -121,7 +123,8 @@ export default Line.extend({
|
|||||||
```javascript
|
```javascript
|
||||||
import {Bar} from 'vue-chartjs'
|
import {Bar} from 'vue-chartjs'
|
||||||
|
|
||||||
export default Bar.extend({
|
export default {
|
||||||
|
extends: Bar,
|
||||||
data () {
|
data () {
|
||||||
return {
|
return {
|
||||||
datacollection: {
|
datacollection: {
|
||||||
@@ -139,7 +142,7 @@ export default Bar.extend({
|
|||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart(this.datacollection, {responsive: true, maintainAspectRatio: false})
|
this.renderChart(this.datacollection, {responsive: true, maintainAspectRatio: false})
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
### コンポーネントの再利用
|
### コンポーネントの再利用
|
||||||
@@ -174,14 +177,15 @@ data () {
|
|||||||
import { Line, mixins } from 'vue-chartjs'
|
import { Line, mixins } from 'vue-chartjs'
|
||||||
const { reactiveProp } = mixins
|
const { reactiveProp } = mixins
|
||||||
|
|
||||||
export default Line.extend({
|
export default {
|
||||||
|
extends: Line,
|
||||||
mixins: [reactiveProp],
|
mixins: [reactiveProp],
|
||||||
props: ['options'],
|
props: ['options'],
|
||||||
mounted () {
|
mounted () {
|
||||||
// this.chartData is created in the mixin
|
// this.chartData is created in the mixin
|
||||||
this.renderChart(this.chartData, this.options)
|
this.renderChart(this.chartData, this.options)
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
**RandomChart.vue**
|
**RandomChart.vue**
|
||||||
@@ -255,7 +259,7 @@ export default Line.extend({
|
|||||||
|
|
||||||
## Chart.js オブジェクト
|
## Chart.js オブジェクト
|
||||||
|
|
||||||
場合によっては、chart.jsをより詳細に制御する必要があります。Chart.jsインスタンスには `this._chart` を使ってアクセスします。
|
場合によっては、chart.jsをより詳細に制御する必要があります。Chart.jsインスタンスには `this.$data._chart` を使ってアクセスします。
|
||||||
|
|
||||||
## 利用可能なグラフ
|
## 利用可能なグラフ
|
||||||
|
|
||||||
@@ -264,30 +268,30 @@ export default Line.extend({
|
|||||||
棒グラフには `{Bar}` と `{HorizontalBar}` の2つのバージョンがあります。
|
棒グラフには `{Bar}` と `{HorizontalBar}` の2つのバージョンがあります。
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||

|

|
||||||
### 折れ線グラフ
|
### 折れ線グラフ
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
### ドーナツチャート
|
### ドーナツチャート
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
### パイチャート
|
### パイチャート
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
### レーダーチャート
|
### レーダーチャート
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
### 鶏頭図
|
### 鶏頭図
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
### バブルチャート
|
### バブルチャート
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
|
|
||||||
## ビルド方法の違い
|
## ビルド方法の違い
|
||||||
|
|||||||
@@ -90,7 +90,8 @@ Apenas crie seu próprio componente.
|
|||||||
// CommitChart.js
|
// CommitChart.js
|
||||||
import { Bar } from 'vue-chartjs'
|
import { Bar } from 'vue-chartjs'
|
||||||
|
|
||||||
export default Bar.extend({
|
export default {
|
||||||
|
extends: Bar,
|
||||||
mounted () {
|
mounted () {
|
||||||
// Overwriting base render method with actual data.
|
// Overwriting base render method with actual data.
|
||||||
this.renderChart({
|
this.renderChart({
|
||||||
@@ -104,7 +105,7 @@ export default Bar.extend({
|
|||||||
]
|
]
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
Então, simplesmente importe e use seu próprio componente extendido como um componente vue.
|
Então, simplesmente importe e use seu próprio componente extendido como um componente vue.
|
||||||
@@ -121,12 +122,13 @@ Você pode sobreescrever as options (opções) padrão do gráfico. Basta passar
|
|||||||
// MonthlyIncome.js
|
// MonthlyIncome.js
|
||||||
import { Line } from 'vue-chartjs'
|
import { Line } from 'vue-chartjs'
|
||||||
|
|
||||||
export default Line.extend({
|
export default {
|
||||||
|
extends: Line,
|
||||||
props: ["data", "options"],
|
props: ["data", "options"],
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart(this.data, this.options)
|
this.renderChart(this.data, this.options)
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
Use isso no seu componente vue
|
Use isso no seu componente vue
|
||||||
@@ -163,13 +165,14 @@ Os mixins criam automaticamente o `chartData` como um prop ou como um data. E ad
|
|||||||
// MonthlyIncome.js
|
// MonthlyIncome.js
|
||||||
import { Line, mixins } from 'vue-chartjs'
|
import { Line, mixins } from 'vue-chartjs'
|
||||||
|
|
||||||
export default Line.extend({
|
export default {
|
||||||
|
extends: Line,
|
||||||
mixins: [mixins.reactiveProp],
|
mixins: [mixins.reactiveProp],
|
||||||
props: ["chartData", "options"],
|
props: ["chartData", "options"],
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart(this.chartData, this.options)
|
this.renderChart(this.chartData, this.options)
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
@@ -181,26 +184,28 @@ Algumas maneiras de importá-los:
|
|||||||
// Load complete module with all charts
|
// Load complete module with all charts
|
||||||
import VueCharts from 'vue-chartjs'
|
import VueCharts from 'vue-chartjs'
|
||||||
|
|
||||||
export default VueCharts.Line.extend({
|
export default {
|
||||||
|
extends: VueCharts.Line,
|
||||||
mixins: [VueCharts.mixins.reactiveProp],
|
mixins: [VueCharts.mixins.reactiveProp],
|
||||||
props: ["chartData", "options"],
|
props: ["chartData", "options"],
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart(this.chartData, this.options)
|
this.renderChart(this.chartData, this.options)
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
// Load speperate modules
|
// Load speperate modules
|
||||||
import { Line, mixins } from 'vue-chartjs'
|
import { Line, mixins } from 'vue-chartjs'
|
||||||
|
|
||||||
export default Line.extend({
|
export default {
|
||||||
|
extends: Line,
|
||||||
mixins: [mixins.reactiveProp],
|
mixins: [mixins.reactiveProp],
|
||||||
props: ["chartData", "options"],
|
props: ["chartData", "options"],
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart(this.chartData, this.options)
|
this.renderChart(this.chartData, this.options)
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
@@ -208,44 +213,45 @@ export default Line.extend({
|
|||||||
import { Line, mixins } from 'vue-chartjs'
|
import { Line, mixins } from 'vue-chartjs'
|
||||||
const { reactiveProp } = mixins
|
const { reactiveProp } = mixins
|
||||||
|
|
||||||
export default Line.extend({
|
export default {
|
||||||
|
extends: Line,
|
||||||
mixins: [reactiveProp],
|
mixins: [reactiveProp],
|
||||||
props: ["chartData", "options"],
|
props: ["chartData", "options"],
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart(this.chartData, this.options)
|
this.renderChart(this.chartData, this.options)
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
## Gráficos disponíveis
|
## Gráficos disponíveis
|
||||||
|
|
||||||
### Gráfico de Barra
|
### Gráfico de Barra
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
### Gráfico de Linha
|
### Gráfico de Linha
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
### Donut
|
### Donut
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
### Pizza
|
### Pizza
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
### Radar
|
### Radar
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
### Área Polar
|
### Área Polar
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
### Bolha
|
### Bolha
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
## Configurações de Build
|
## Configurações de Build
|
||||||
|
|
||||||
|
|||||||
300
docs/ru/README.md
Normal file
@@ -0,0 +1,300 @@
|
|||||||
|
---
|
||||||
|
search: ru
|
||||||
|
---
|
||||||
|
|
||||||
|
<div align="center">
|
||||||
|
<img width="256" heigth="256" src="../../assets/vue-chartjs.png" alt="vue-chartjs logo">
|
||||||
|
</div>
|
||||||
|
|
||||||
|
[](https://badge.fury.io/js/vue-chartjs)
|
||||||
|
[](https://codecov.io/gh/apertureless/vue-chartjs)
|
||||||
|
[](https://travis-ci.org/apertureless/vue-chartjs)
|
||||||
|
[](http://packagequality.com/#?package=vue-chartjs)
|
||||||
|
[](https://www.npmjs.com/package/vue-chartjs)
|
||||||
|
[](https://gitter.im/vue-chartjs/Lobby)
|
||||||
|
[](https://github.com/apertureless/vue-chartjs/blob/master/LICENSE.txt)
|
||||||
|
[](https://cdnjs.com/libraries/vue-chartjs)
|
||||||
|
|
||||||
|
# vue-chartjs
|
||||||
|
|
||||||
|
**vue-chartjs** это обертка для [Chart.js](https://github.com/chartjs/Chart.js) в vue. Вы можете с легкостью создавать многоразовые компоненты диаграмм.
|
||||||
|
|
||||||
|
## Демо & Документация
|
||||||
|
|
||||||
|
- 📺 [Demo](http://demo.vue-chartjs.org/)
|
||||||
|
- 📖 [Docs](http://www.vue-chartjs.org/)
|
||||||
|
|
||||||
|
### Совместимость
|
||||||
|
|
||||||
|
- v1 later `@legacy`
|
||||||
|
- Vue.js 1.x
|
||||||
|
- v2 later
|
||||||
|
- Vue.js 2.x
|
||||||
|
|
||||||
|
После финального выпуска vue.js 2, вы получите v2 по умолчанию, если установите vue-chartjs через npm.
|
||||||
|
Больше нет необходимости в @next теге. Если вы нуждаетесь в v1, вам необходимо указать версию или использовать legacy тег.
|
||||||
|
Если вы ищите v1, проверьте эту [ветку](https://github.com/apertureless/vue-chartjs/tree/release/1.x).
|
||||||
|
|
||||||
|
## Установка
|
||||||
|
|
||||||
|
Просто выполните `yarn add vue-chartjs chart.js`
|
||||||
|
|
||||||
|
В случае если вы хотите использовать библиотеку прямо в браузере, добавьте
|
||||||
|
|
||||||
|
```html
|
||||||
|
<script src="https://unpkg.com/vue-chartjs@2.6.0/dist/vue-chartjs.full.min.js"></script>
|
||||||
|
```
|
||||||
|
в ваши скрипты. Смотрите пример на [Codepen](https://codepen.io/apertureless/pen/vxWbqB?editors=1010)
|
||||||
|
|
||||||
|
## Описание различий сборок
|
||||||
|
|
||||||
|
Существует три различные точки входа. Это зависит от того, какая сборка стоит у вас. Зависимости собираются или подключаются как peerDependency.
|
||||||
|
|
||||||
|
- Browser
|
||||||
|
- Browserify / Webpack 1
|
||||||
|
- Webpack 2
|
||||||
|
|
||||||
|
|
||||||
|
| Build | Chart.js | Vue.js |
|
||||||
|
|---|---|---|
|
||||||
|
| vue-chartjs.full.js | Bundled | Bundled |
|
||||||
|
| vue-chartjs.full.min.js | Bundled | Bundled |
|
||||||
|
| vue-chartjs.js | peerDependency | peerDependency |
|
||||||
|
| vue-chartjs.min.js | peerDependency | peerDependency |
|
||||||
|
| es/index* | peerDependency | peerDependency |
|
||||||
|
|
||||||
|
### Браузер
|
||||||
|
Вы можете использовать `vue-chartjs` прямо в браузере без установки каких-либо сборок. Пример на [codepen](https://codepen.io/apertureless/pen/vxWbqB?editors=1010). В этом случае, пожалуйста, используйте `vue-chartjs.full.min.js`. Это минифицированная версия библиотеки, содержащая Vue.js и Chart.js в себе, с возможностью подключения при помощи UMD Module. Таким образом, вам необходим лишь один файл.
|
||||||
|
|
||||||
|
|
||||||
|
### Browserify / Webpack 1
|
||||||
|
|
||||||
|
Если вы используете Gulp, Browserify или Webpack 1, входная точка находится в `vue-chartjs.js`. Она __транслируется__ и __собирается__ при помощи UMD Module.
|
||||||
|
|
||||||
|
Однако Vue.js и Chart.js являются `peerDependencies`, поэтому вы можете устанавливать их отдельно. В большинстве проектов вы в любом случае будете иметь установленный `Vue.js`. В этом случае, вы можете иметь различные версии Vue.js и Chart.js.
|
||||||
|
|
||||||
|
### Webpack 2
|
||||||
|
Если вы используете Webpack 2, он будет автоматически использовать `jsnext:main` / `module` в качестве входной точки, которая расположена в `es/index.js`.
|
||||||
|
Это транслированная es версия кода, которая не __собирается__ в модуль. Таким образом, three shaking будет работать.
|
||||||
|
Как и в собранной версии, `Vue.js` и `Chart.js` являются `peerDependencies` и не нуждаются в установке.
|
||||||
|
|
||||||
|
|
||||||
|
## Как использовать
|
||||||
|
|
||||||
|
Вам необходимо импортировать базовый класс диаграммы и унаследовать его. Это даст гораздо большую гибкость при работе с различными данными. Вы можете передать данные через props или vue-resource.
|
||||||
|
|
||||||
|
Вы можете импортировать весь проект или каждый модуль по отдельности.
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
import VueCharts from 'vue-chartjs'
|
||||||
|
import { Bar, Line } from 'vue-chartjs'
|
||||||
|
```
|
||||||
|
|
||||||
|
Просто создайте ваш собственный компонент.
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
// CommitChart.js
|
||||||
|
import { Bar } from 'vue-chartjs'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: Bar,
|
||||||
|
mounted () {
|
||||||
|
// Переопределение базового рендер метода с реальными данными.
|
||||||
|
this.renderChart({
|
||||||
|
labels: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],
|
||||||
|
datasets: [
|
||||||
|
{
|
||||||
|
label: 'GitHub Commits',
|
||||||
|
backgroundColor: '#f87979',
|
||||||
|
data: [40, 20, 12, 39, 10, 40, 39, 80, 40, 20, 12, 11]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Затем просто импортируйте и используйте ваши собственные расширенные компоненты как обычные vue компоненты.
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
import CommitChart from 'path/to/component/CommitChart'
|
||||||
|
```
|
||||||
|
|
||||||
|
## Другой пример с options
|
||||||
|
|
||||||
|
Вы можете переопределить стандартные опции графика. Просто передайте объект с опциями в качестве второго параметра в рендер метод.
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
// MonthlyIncome.js
|
||||||
|
import { Line } from 'vue-chartjs'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: Line,
|
||||||
|
props: ['data', 'options'],
|
||||||
|
mounted () {
|
||||||
|
this.renderChart(this.data, this.options)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Используйте это в вашем vue приложении
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
import MonthlyIncome from 'path/to/component/MonthlyIncome'
|
||||||
|
|
||||||
|
<template>
|
||||||
|
<monthly-income :data={....} />
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
export default {
|
||||||
|
components: { MonthlyIncome },
|
||||||
|
....
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
```
|
||||||
|
|
||||||
|
## Реактивность
|
||||||
|
|
||||||
|
Chart.js не обновляет и не перерисовывает диаграмму при передаче новых данных.
|
||||||
|
Впрочем, вы можете реализовать это самостоятельно или использовать один из двух подключенных миксинов:
|
||||||
|
|
||||||
|
- `reactiveProp`
|
||||||
|
- `reactiveData`
|
||||||
|
|
||||||
|
Оба включены в `mixins` модуль.
|
||||||
|
|
||||||
|
Миксины автоматически создают `chartData` в виде prop или data. И добавляют watcher. Если данные были измененны, график обновится.
|
||||||
|
Но помните про ограничения vue и javascript на изменение массивов и объектов. Больше информации можно получить [здесь](http://vue-chartjs.org/#/home?id=reactive-data)
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
// MonthlyIncome.js
|
||||||
|
import { Line, mixins } from 'vue-chartjs'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: Line,
|
||||||
|
mixins: [mixins.reactiveProp],
|
||||||
|
props: ['chartData', 'options'],
|
||||||
|
mounted () {
|
||||||
|
this.renderChart(this.chartData, this.options)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
### Mixins модуль
|
||||||
|
Модуль `mixins` включен в `VueCharts`, а также доступен в виде отдельного модуля.
|
||||||
|
Несколько способов импортировать их:
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
// Load complete module with all charts
|
||||||
|
import VueCharts from 'vue-chartjs'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: VueCharts.Line,
|
||||||
|
mixins: [VueCharts.mixins.reactiveProp],
|
||||||
|
props: ['chartData', 'options'],
|
||||||
|
mounted () {
|
||||||
|
this.renderChart(this.chartData, this.options)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
// Load speperate modules
|
||||||
|
import { Line, mixins } from 'vue-chartjs'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: Line,
|
||||||
|
mixins: [mixins.reactiveProp],
|
||||||
|
props: ['chartData', 'options'],
|
||||||
|
mounted () {
|
||||||
|
this.renderChart(this.chartData, this.options)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
// Load speperate modules with destructure assign
|
||||||
|
import { Line, mixins } from 'vue-chartjs'
|
||||||
|
const { reactiveProp } = mixins
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: Line,
|
||||||
|
mixins: [reactiveProp],
|
||||||
|
props: ['chartData', 'options'],
|
||||||
|
mounted () {
|
||||||
|
this.renderChart(this.chartData, this.options)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Доступные диаграммы
|
||||||
|
|
||||||
|
### Bar Chart
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### Line Chart
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### Doughnut
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### Pie
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### Radar
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### Polar Area
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### Bubble
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### Scatter
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
## Настройка сборки
|
||||||
|
|
||||||
|
``` bash
|
||||||
|
# инициализация зависимостей
|
||||||
|
npm install
|
||||||
|
|
||||||
|
# сборка с горячей заменой на localhost:8080
|
||||||
|
npm run dev
|
||||||
|
|
||||||
|
# сборка для production с минификацией
|
||||||
|
npm run build
|
||||||
|
|
||||||
|
# запуск unit тестов
|
||||||
|
npm run unit
|
||||||
|
|
||||||
|
# запуск e2e тестов
|
||||||
|
npm run e2e
|
||||||
|
|
||||||
|
# запуск всех тестов
|
||||||
|
npm test
|
||||||
|
```
|
||||||
|
|
||||||
|
Для получения детальных объяснений того, как это работает, перейдите в [руководство](http://vuejs-templates.github.io/webpack/) и [документацию для vue-loader](http://vuejs.github.io/vue-loader).
|
||||||
|
|
||||||
|
## Contributing
|
||||||
|
|
||||||
|
1. Fork it ( https://github.com/apertureless/vue-chartjs/fork )
|
||||||
|
2. Create your feature branch (`git checkout -b my-new-feature`)
|
||||||
|
3. Commit your changes (`git commit -am 'Add some feature'`)
|
||||||
|
4. Push to the branch (`git push origin my-new-feature`)
|
||||||
|
5. Create a new Pull Request
|
||||||
|
|
||||||
|
## License
|
||||||
|
|
||||||
|
This software is distributed under [MIT license](LICENSE.txt).
|
||||||
362
docs/zh-cn/README.md
Normal file
@@ -0,0 +1,362 @@
|
|||||||
|
---
|
||||||
|
search: zh-cn
|
||||||
|
---
|
||||||
|
|
||||||
|
# vue-chartjs
|
||||||
|
**vue-chartjs** 是基于 vue 的 [Chart.js](https://github.com/chartjs/Chart.js) 封装。你可以轻松的创建可复用的图表组件。
|
||||||
|
|
||||||
|
## 简介
|
||||||
|
`vue-chartjs` 让你在 vue 中使用 chart.js 省去很多麻烦。非常适合需要快速生成简单图表的人。
|
||||||
|
|
||||||
|
它抽象化了基本逻辑但提供了非常灵活的 chart.js 对象。
|
||||||
|
|
||||||
|
## 安装
|
||||||
|
如果你正在使用 Vue.js 2.x 的版本,只需要运行:
|
||||||
|
|
||||||
|
`yarn add vue-chartjs chart.js`
|
||||||
|
|
||||||
|
如果你正在使用 Vue.js 1.x 的版本,请使用 `legacy` 标签。然而这个版本已经不再维护了。
|
||||||
|
|
||||||
|
`yarn add vue-chartjs@legacy`
|
||||||
|
|
||||||
|
## 快速开始
|
||||||
|
|
||||||
|
你需要引入基本图表并且扩展它。这在处理不同的数据时提供了更多的灵活性。
|
||||||
|
|
||||||
|
你可以封装您的组件,并使用 props 来传递数据。或者直接将数据放入组件中,但是这样做组件就不能复用了。
|
||||||
|
|
||||||
|
你可以加载整个包或者按需加载。
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
// CommitChart.js
|
||||||
|
import { Bar } from 'vue-chartjs'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: Bar,
|
||||||
|
mounted () {
|
||||||
|
// Overwriting base render method with actual data.
|
||||||
|
this.renderChart(data, options)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
你可以给 `renderChart()` 方法传递两个参数:
|
||||||
|
|
||||||
|
- Data object
|
||||||
|
- Options object
|
||||||
|
|
||||||
|
### 数据对象
|
||||||
|
|
||||||
|
数据对象如下所示:
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
{
|
||||||
|
labels: ['January', 'February'],
|
||||||
|
datasets: [
|
||||||
|
{
|
||||||
|
label: 'GitHub Commits',
|
||||||
|
backgroundColor: '#f87979',
|
||||||
|
data: [40, 20]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
详细信息请查阅 [Chart.js](http://www.chartjs.org/docs/#chart-configuration-chart-data) 的文档。
|
||||||
|
|
||||||
|
## 属性
|
||||||
|
|
||||||
|
基本图表中定义了一些属性。因为你 `extend()` 了它们,他们使用 *初始值*,但是你可以覆盖它们:
|
||||||
|
|
||||||
|
| 属性 | 说明 |
|
||||||
|
|---|---|
|
||||||
|
| width | 图表宽度 |
|
||||||
|
| height | 图表高度 |
|
||||||
|
| chart-id | canvas的id |
|
||||||
|
|
||||||
|
|
||||||
|
## 实例
|
||||||
|
|
||||||
|
下面是一些实例。
|
||||||
|
|
||||||
|
### 图表和属性
|
||||||
|
|
||||||
|
你可以创建数据和选项传递给图表。
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
// LineChart.js
|
||||||
|
import { Line } from 'vue-chartjs'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: Line,
|
||||||
|
props: ['data', 'options'],
|
||||||
|
mounted () {
|
||||||
|
this.renderChart(this.data, this.options)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
然后你可以把它作为组件使用。
|
||||||
|
|
||||||
|
```html
|
||||||
|
<line-chart :data="{your data object}" :options="{your options}"></line-chart>
|
||||||
|
```
|
||||||
|
|
||||||
|
如果你想要覆盖宽度和高度:
|
||||||
|
|
||||||
|
```html
|
||||||
|
<line-chart
|
||||||
|
:data="{your data object}"
|
||||||
|
:options="{responsive: false, maintainAspectRatio: false}"
|
||||||
|
:width="400"
|
||||||
|
:height="200"
|
||||||
|
>
|
||||||
|
</line-chart>
|
||||||
|
```
|
||||||
|
|
||||||
|
<p class="warning">
|
||||||
|
请注意,你必须设置 `responsive: false` 才可以使用 `width` 和 `height`。
|
||||||
|
</p>
|
||||||
|
|
||||||
|
### 使用本地数据创建图表
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
import {Bar} from 'vue-chartjs'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: Bar,
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
datacollection: {
|
||||||
|
labels: ['January', 'February'],
|
||||||
|
datasets: [
|
||||||
|
{
|
||||||
|
label: 'Data One',
|
||||||
|
backgroundColor: '#f87979',
|
||||||
|
data: [40, 20]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
mounted () {
|
||||||
|
this.renderChart(this.datacollection, {responsive: true, maintainAspectRatio: false})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### 可复用的组件
|
||||||
|
|
||||||
|
如果你希望你的组件可以复用,那么你最好封装它们。这样图表组件只是负责显示你封装的数据。单页应用和集成到 laravel 中有不同的使用方式。
|
||||||
|
|
||||||
|
## 动态数据
|
||||||
|
|
||||||
|
Chart.js 并不提供实时更新,然而 `vue-chartjs` 提供了两种方式。
|
||||||
|
|
||||||
|
- `reactiveProp`
|
||||||
|
- `reactiveData`
|
||||||
|
|
||||||
|
两种方式其实是一样的。多部分情况会使用 `reactiveProp`。它扩展了图表逻辑并且自动添加 `chartData` props 和 `vue watch`。当数据改变,它将会调用 `update()`。当添加了新的数据集,将会调用 `renderChart()`。
|
||||||
|
|
||||||
|
`reactiveData` 只是创建了本地变量并且添加到 watcher,而不是 prop,他只用在你创建单一图表并且在组件创建 api 的时候。
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
chartData: null
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### 实例
|
||||||
|
|
||||||
|
**LineChart.js**
|
||||||
|
```javascript
|
||||||
|
import { Line, mixins } from 'vue-chartjs'
|
||||||
|
const { reactiveProp } = mixins
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: Line,
|
||||||
|
mixins: [reactiveProp],
|
||||||
|
props: ['options'],
|
||||||
|
mounted () {
|
||||||
|
// this.chartData is created in the mixin
|
||||||
|
this.renderChart(this.chartData, this.options)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
**RandomChart.vue**
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
<template>
|
||||||
|
<div class="small">
|
||||||
|
<line-chart :chart-data="datacollection"></line-chart>
|
||||||
|
<button @click="fillData()">Randomize</button>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import LineChart from './LineChart.js'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
components: {
|
||||||
|
LineChart
|
||||||
|
},
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
datacollection: null
|
||||||
|
}
|
||||||
|
},
|
||||||
|
mounted () {
|
||||||
|
this.fillData()
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
fillData () {
|
||||||
|
this.datacollection = {
|
||||||
|
labels: [this.getRandomInt(), this.getRandomInt()],
|
||||||
|
datasets: [
|
||||||
|
{
|
||||||
|
label: 'Data One',
|
||||||
|
backgroundColor: '#f87979',
|
||||||
|
data: [this.getRandomInt(), this.getRandomInt()]
|
||||||
|
}, {
|
||||||
|
label: 'Data One',
|
||||||
|
backgroundColor: '#f87979',
|
||||||
|
data: [this.getRandomInt(), this.getRandomInt()]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
getRandomInt () {
|
||||||
|
return Math.floor(Math.random() * (50 - 5 + 1)) + 5
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style>
|
||||||
|
.small {
|
||||||
|
max-width: 600px;
|
||||||
|
margin: 150px auto;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
```
|
||||||
|
|
||||||
|
<p class="warning">
|
||||||
|
⚠ 注意:如果在父组件中修改数据并将数据传递给子图表组件时,请注意 JavaScript 的限制。
|
||||||
|
更多信息请查阅 [issue#44](https://github.com/apertureless/vue-chartjs/issues/44)
|
||||||
|
</p>
|
||||||
|
|
||||||
|
### 限制
|
||||||
|
<ul>
|
||||||
|
<li>[Caveats](https://vuejs.org/v2/guide/list.html#Caveats)</li>
|
||||||
|
<li>[Change-Detection-Caveats](https://vuejs.org/v2/guide/reactivity.html#Change-Detection-Caveats)</li>
|
||||||
|
<li>[vm.$watch](https://vuejs.org/v2/api/#vm-watch)</li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
## Chart.js 对象
|
||||||
|
|
||||||
|
有时你需要更多的调整 chart.js。你可以访问 `this.$data._chart` 实例。
|
||||||
|
|
||||||
|
## 内联插件
|
||||||
|
|
||||||
|
在 Chart.js 你可以定义全局和内联插件。全局插件在 `vue-chartjs` 中没有问题,参照 [chart.js docs](http://www.chartjs.org/docs/latest/developers/plugins.html) 的说明。
|
||||||
|
|
||||||
|
如果你想添加内联插件 `vue-chartjs` 提供了一个方法 `addPlugin()`
|
||||||
|
|
||||||
|
你必须在 `renderChart()` 之前调用 `addPlugin()` 方法。
|
||||||
|
|
||||||
|
### 实例
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
mounted () {
|
||||||
|
this.addPlugin({
|
||||||
|
id: 'my-plugin',
|
||||||
|
beforeInit: function (chart) {
|
||||||
|
....
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## 支持的图表
|
||||||
|
|
||||||
|
### 柱状图
|
||||||
|
|
||||||
|
<p class="tip">
|
||||||
|
柱状图有两个版本。 `{Bar}` 和 `{HorizontalBar}`
|
||||||
|
</p>
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### 折线图
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### 环形图
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### 饼图
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### 雷达图
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### 极坐标
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### 热点图
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### 散点图
|
||||||
|
|
||||||
|
这个图表有不同的数据结构。目前动态数据不适用于此图表类型。
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
|
||||||
|
## 不同构建工具的说明
|
||||||
|
有三种不同的切入点,取决于你用哪种构建工具。作为 dependencies 或者 peerDependency。
|
||||||
|
|
||||||
|
- Browser
|
||||||
|
- Browserify / Webpack 1
|
||||||
|
- Webpack 2
|
||||||
|
|
||||||
|
|
||||||
|
| Build | Chart.js | Vue.js |
|
||||||
|
|---|---|---|
|
||||||
|
| vue-chartjs.full.js | Bundled | Bundled |
|
||||||
|
| vue-chartjs.full.min.js | Bundled | Bundled |
|
||||||
|
| vue-chartjs.js | peerDependency | peerDependency |
|
||||||
|
| vue-chartjs.min.js | peerDependency | peerDependency |
|
||||||
|
| es/index* | peerDependency | peerDependency |
|
||||||
|
|
||||||
|
### 浏览器
|
||||||
|
你可以在浏览中直接使用 `vue-chartjs`。像是 [codepen](https://codepen.io/apertureless/pen/vxWbqB?editors=1010) 这种情况,请使用 `vue-chartjs.full.min.js` 捆绑版本。他将 Vue.js 和 Chart.js 绑定在了一起,你只需要一个文件。
|
||||||
|
|
||||||
|
|
||||||
|
### Browserify / Webpack 1
|
||||||
|
|
||||||
|
如果你使用 Gulp, Browserify 或者 Webpack 1,`vue-chartjs.js` 被捆绑到 UMD 模块。
|
||||||
|
|
||||||
|
然而 Vue.js 和 Chart.js 是 `peerDependencies` 所以你需要独立安装它们。 大部分情况下你已经安装了 `Vue.js`,你可以使用不同版本的 Vue.js 和 Chart.js。
|
||||||
|
|
||||||
|
### Webpack 2
|
||||||
|
如果你使用 Webpack 2 它将自动使用 `jsnext:main` / `module` 入口。
|
||||||
|
像捆绑版本一样,`Vue.js` 和 `Chart.js` 都是 `peerDependencies`,需要安装。
|
||||||
|
|
||||||
|
## 资源
|
||||||
|
|
||||||
|
你可以在这里找到一些如何使用 `vue-chartjs` 的资源。
|
||||||
|
|
||||||
|
- [Using vue-chartjs with WordPress](https://medium.com/@apertureless/wordpress-vue-and-chart-js-6b61493e289f)
|
||||||
|
- [Create stunning Charts with Vue and Chart.js](https://hackernoon.com/creating-stunning-charts-with-vue-js-and-chart-js-28af584adc0a)
|
||||||
|
- [Let’s Build a Web App with Vue, Chart.js and an API Part I](https://hackernoon.com/lets-build-a-web-app-with-vue-chart-js-and-an-api-544eb81c4b44)
|
||||||
|
- [Let’s Build a Web App with Vue, Chart.js and an API Part II](https://hackernoon.com/lets-build-a-web-app-with-vue-chart-js-and-an-api-part-ii-39781b1d5acf)
|
||||||
|
- [Build a realtime chart with VueJS and Pusher](https://blog.pusher.com/build-realtime-chart-with-vuejs-pusher/)
|
||||||
10646
package-lock.json
generated
Normal file
65
package.json
@@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "vue-chartjs",
|
"name": "vue-chartjs",
|
||||||
"version": "2.6.4",
|
"version": "3.0.2",
|
||||||
"description": "vue.js wrapper for chart.js",
|
"description": "Vue.js wrapper for chart.js for creating beautiful charts.",
|
||||||
"author": "Jakub Juszczak <jakub@posteo.de>",
|
"author": "Jakub Juszczak <jakub@posteo.de>",
|
||||||
"homepage": "http://vue-chartjs.org",
|
"homepage": "http://vue-chartjs.org",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
@@ -37,7 +37,7 @@
|
|||||||
"Charts"
|
"Charts"
|
||||||
],
|
],
|
||||||
"main": "dist/vue-chartjs.js",
|
"main": "dist/vue-chartjs.js",
|
||||||
"unpkg": "dist/vue-chartjs.full.min.js",
|
"unpkg": "dist/vue-chartjs.min.js",
|
||||||
"module": "es/index.js",
|
"module": "es/index.js",
|
||||||
"jsnext:main": "es/index.js",
|
"jsnext:main": "es/index.js",
|
||||||
"files": [
|
"files": [
|
||||||
@@ -53,29 +53,24 @@
|
|||||||
"e2e": "node test/e2e/runner.js",
|
"e2e": "node test/e2e/runner.js",
|
||||||
"test": "npm run unit",
|
"test": "npm run unit",
|
||||||
"lint": "eslint --ext .js,.vue src test/unit/specs test/e2e/specs",
|
"lint": "eslint --ext .js,.vue src test/unit/specs test/e2e/specs",
|
||||||
"release": "webpack --progress --hide-modules --config ./build/webpack.release.js && NODE_ENV=production webpack --progress --hide-modules --config ./build/webpack.release.min.js && webpack --progress --hide-modules --config ./build/webpack.release.full.js && NODE_ENV=production webpack --progress --hide-modules --config ./build/webpack.release.full.min.js",
|
"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",
|
||||||
"prepublish": "yarn run lint && yarn run test && yarn run build"
|
"prepublishOnly": "yarn run lint && yarn run test && yarn run build"
|
||||||
},
|
|
||||||
"dependencies": {
|
|
||||||
"lodash": "^4.17.4"
|
|
||||||
},
|
},
|
||||||
|
"dependencies": {},
|
||||||
"peerDependencies": {
|
"peerDependencies": {
|
||||||
"chart.js": "^2.5.0",
|
"chart.js": "2.7.x"
|
||||||
"vue": "^2.3.3"
|
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"babel-cli": "^6.24.1",
|
"@babel/cli": "^7.0.0-beta.31",
|
||||||
"babel-core": "^6.24.1",
|
"@babel/core": "^7.0.0-beta.31",
|
||||||
"babel-loader": "^7.0.0",
|
"@babel/preset-env": "^7.0.0-beta.31",
|
||||||
"babel-plugin-transform-runtime": "^6.23.0",
|
"@babel/preset-stage-2": "^7.0.0-beta.31",
|
||||||
"babel-preset-es2015": "^6.24.1",
|
"babel-loader": "8.0.0-beta.0",
|
||||||
"babel-preset-stage-2": "^6.24.1",
|
|
||||||
"babel-runtime": "^6.23.0",
|
|
||||||
"chai": "^3.5.0",
|
"chai": "^3.5.0",
|
||||||
"chart.js": "^2.5.0",
|
"chart.js": "2.7.0",
|
||||||
"chromedriver": "^2.28.0",
|
"chromedriver": "^2.28.0",
|
||||||
"connect-history-api-fallback": "^1.1.0",
|
"connect-history-api-fallback": "^1.1.0",
|
||||||
"cross-env": "^3.2.4",
|
"cross-env": "^5.1.1",
|
||||||
"cross-spawn": "^5.1.0",
|
"cross-spawn": "^5.1.0",
|
||||||
"css-loader": "^0.28.0",
|
"css-loader": "^0.28.0",
|
||||||
"eslint": "^3.19.0",
|
"eslint": "^3.19.0",
|
||||||
@@ -89,13 +84,14 @@
|
|||||||
"eslint-plugin-standard": "^3.0.1",
|
"eslint-plugin-standard": "^3.0.1",
|
||||||
"eventsource-polyfill": "^0.9.6",
|
"eventsource-polyfill": "^0.9.6",
|
||||||
"express": "^4.15.2",
|
"express": "^4.15.2",
|
||||||
"extract-text-webpack-plugin": "^1.0.1",
|
"extract-text-webpack-plugin": "^3.0.1",
|
||||||
"file-loader": "^0.10.1",
|
"file-loader": "^0.10.1",
|
||||||
|
"friendly-errors-webpack-plugin": "^1.6.1",
|
||||||
"function-bind": "^1.0.2",
|
"function-bind": "^1.0.2",
|
||||||
"html-webpack-plugin": "^2.28.0",
|
"html-webpack-plugin": "^2.28.0",
|
||||||
"http-proxy-middleware": "^0.17.4",
|
"http-proxy-middleware": "^0.17.4",
|
||||||
"inject-loader": "^3.0.0",
|
"inject-loader": "^3.0.0",
|
||||||
"isparta-loader": "^2.0.0",
|
"isparta": "^4.0.0",
|
||||||
"jasmine-core": "^2.5.2",
|
"jasmine-core": "^2.5.2",
|
||||||
"json-loader": "^0.5.4",
|
"json-loader": "^0.5.4",
|
||||||
"karma": "^1.5.0",
|
"karma": "^1.5.0",
|
||||||
@@ -103,38 +99,37 @@
|
|||||||
"karma-jasmine": "^1.0.2",
|
"karma-jasmine": "^1.0.2",
|
||||||
"karma-mocha": "^1.2.0",
|
"karma-mocha": "^1.2.0",
|
||||||
"karma-phantomjs-launcher": "^1.0.4",
|
"karma-phantomjs-launcher": "^1.0.4",
|
||||||
|
"karma-phantomjs-shim": "^1.4.0",
|
||||||
"karma-sinon-chai": "^1.2.0",
|
"karma-sinon-chai": "^1.2.0",
|
||||||
"karma-sourcemap-loader": "^0.3.7",
|
"karma-sourcemap-loader": "^0.3.7",
|
||||||
"karma-spec-reporter": "0.0.30",
|
"karma-spec-reporter": "0.0.30",
|
||||||
"karma-webpack": "1.8.1",
|
"karma-webpack": "2",
|
||||||
"lolex": "^1.6.0",
|
"lolex": "^1.6.0",
|
||||||
"mocha": "^3.1.0",
|
"mocha": "^3.1.0",
|
||||||
"nightwatch": "^0.9.14",
|
"nightwatch": "^0.9.14",
|
||||||
|
"opn": "^5.1.0",
|
||||||
"ora": "^1.2.0",
|
"ora": "^1.2.0",
|
||||||
"phantomjs-prebuilt": "^2.1.13",
|
"phantomjs-prebuilt": "^2.1.13",
|
||||||
|
"portfinder": "^1.0.13",
|
||||||
"selenium-server": "^3.3.1",
|
"selenium-server": "^3.3.1",
|
||||||
"shelljs": "^0.7.7",
|
"shelljs": "^0.7.7",
|
||||||
"sinon": "^2.1.0",
|
"sinon": "^2.1.0",
|
||||||
"sinon-chai": "^2.9.0",
|
"sinon-chai": "^2.9.0",
|
||||||
"url-loader": "^0.5.8",
|
"url-loader": "^0.5.8",
|
||||||
"vue": "^2.3.3",
|
"vue": "2.5.2",
|
||||||
"vue-hot-reload-api": "^2.1.0",
|
"vue-hot-reload-api": "2.1.0",
|
||||||
"vue-html-loader": "^1.2.4",
|
"vue-html-loader": "^1.2.4",
|
||||||
"vue-loader": "^12.0.4",
|
"vue-loader": "^13.3.0",
|
||||||
"vue-style-loader": "^3.0.1",
|
"vue-style-loader": "3.0.1",
|
||||||
"vue-template-compiler": "^2.3.3",
|
"vue-template-compiler": "2.5.2",
|
||||||
"webpack": "^1.13.2",
|
"webpack": "^3.7.1",
|
||||||
"webpack-dev-middleware": "^1.10.1",
|
"webpack-dev-middleware": "^1.10.1",
|
||||||
"webpack-hot-middleware": "^2.17.1",
|
"webpack-hot-middleware": "^2.17.1",
|
||||||
"webpack-merge": "1.1.1"
|
"webpack-merge": "^4.1.0"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=6.9.0"
|
"node": ">=6.9.0",
|
||||||
},
|
"npm": ">= 3.0.0"
|
||||||
"babel": {
|
|
||||||
"presets": [
|
|
||||||
"es2015"
|
|
||||||
]
|
|
||||||
},
|
},
|
||||||
"browserify": {
|
"browserify": {
|
||||||
"transform": [
|
"transform": [
|
||||||
|
|||||||
@@ -1,11 +1,12 @@
|
|||||||
import Vue from 'vue'
|
|
||||||
import Chart from 'chart.js'
|
import Chart from 'chart.js'
|
||||||
import { mergeOptions } from '../helpers/options'
|
|
||||||
|
|
||||||
export default Vue.extend({
|
export default {
|
||||||
render: function (createElement) {
|
render: function (createElement) {
|
||||||
return createElement(
|
return createElement(
|
||||||
'div',
|
'div', {
|
||||||
|
style: this.styles,
|
||||||
|
class: this.cssClasses
|
||||||
|
},
|
||||||
[
|
[
|
||||||
createElement(
|
createElement(
|
||||||
'canvas', {
|
'canvas', {
|
||||||
@@ -20,7 +21,6 @@ export default Vue.extend({
|
|||||||
]
|
]
|
||||||
)
|
)
|
||||||
},
|
},
|
||||||
|
|
||||||
props: {
|
props: {
|
||||||
chartId: {
|
chartId: {
|
||||||
default: 'bar-chart',
|
default: 'bar-chart',
|
||||||
@@ -33,47 +33,46 @@ export default Vue.extend({
|
|||||||
height: {
|
height: {
|
||||||
default: 400,
|
default: 400,
|
||||||
type: Number
|
type: Number
|
||||||
|
},
|
||||||
|
cssClasses: {
|
||||||
|
type: String,
|
||||||
|
default: ''
|
||||||
|
},
|
||||||
|
styles: {
|
||||||
|
type: Object
|
||||||
|
},
|
||||||
|
plugins: {
|
||||||
|
type: Array,
|
||||||
|
default () {
|
||||||
|
return []
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
data () {
|
data () {
|
||||||
return {
|
return {
|
||||||
defaultOptions: {
|
_chart: null,
|
||||||
scales: {
|
_plugins: this.plugins
|
||||||
yAxes: [{
|
|
||||||
ticks: {
|
|
||||||
beginAtZero: true
|
|
||||||
},
|
|
||||||
gridLines: {
|
|
||||||
display: false
|
|
||||||
}
|
|
||||||
}],
|
|
||||||
xAxes: [ {
|
|
||||||
gridLines: {
|
|
||||||
display: false
|
|
||||||
},
|
|
||||||
categoryPercentage: 0.5,
|
|
||||||
barPercentage: 0.2
|
|
||||||
}]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
|
addPlugin (plugin) {
|
||||||
|
this.$data._plugins.push(plugin)
|
||||||
|
},
|
||||||
renderChart (data, options) {
|
renderChart (data, options) {
|
||||||
let chartOptions = mergeOptions(this.defaultOptions, options)
|
this.$data._chart = new Chart(
|
||||||
this._chart = new Chart(
|
|
||||||
this.$refs.canvas.getContext('2d'), {
|
this.$refs.canvas.getContext('2d'), {
|
||||||
type: 'bar',
|
type: 'bar',
|
||||||
data: data,
|
data: data,
|
||||||
options: chartOptions
|
options: options,
|
||||||
|
plugins: this.$data._plugins
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
this._chart.generateLegend()
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
beforeDestroy () {
|
beforeDestroy () {
|
||||||
this._chart.destroy()
|
if (this.$data._chart) {
|
||||||
|
this.$data._chart.destroy()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|||||||
@@ -1,11 +1,12 @@
|
|||||||
import Vue from 'vue'
|
|
||||||
import Chart from 'chart.js'
|
import Chart from 'chart.js'
|
||||||
import { mergeOptions } from '../helpers/options'
|
|
||||||
|
|
||||||
export default Vue.extend({
|
export default {
|
||||||
render: function (createElement) {
|
render: function (createElement) {
|
||||||
return createElement(
|
return createElement(
|
||||||
'div',
|
'div', {
|
||||||
|
style: this.styles,
|
||||||
|
class: this.cssClasses
|
||||||
|
},
|
||||||
[
|
[
|
||||||
createElement(
|
createElement(
|
||||||
'canvas', {
|
'canvas', {
|
||||||
@@ -33,48 +34,47 @@ export default Vue.extend({
|
|||||||
height: {
|
height: {
|
||||||
default: 400,
|
default: 400,
|
||||||
type: Number
|
type: Number
|
||||||
|
},
|
||||||
|
cssClasses: {
|
||||||
|
type: String,
|
||||||
|
default: ''
|
||||||
|
},
|
||||||
|
styles: {
|
||||||
|
type: Object
|
||||||
|
},
|
||||||
|
plugins: {
|
||||||
|
type: Array,
|
||||||
|
default () {
|
||||||
|
return []
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
data () {
|
data () {
|
||||||
return {
|
return {
|
||||||
defaultOptions: {
|
_chart: null,
|
||||||
scales: {
|
_plugins: this.plugins
|
||||||
yAxes: [{
|
|
||||||
ticks: {
|
|
||||||
beginAtZero: true
|
|
||||||
},
|
|
||||||
gridLines: {
|
|
||||||
display: false
|
|
||||||
}
|
|
||||||
}],
|
|
||||||
xAxes: [ {
|
|
||||||
gridLines: {
|
|
||||||
display: false
|
|
||||||
},
|
|
||||||
categoryPercentage: 0.5,
|
|
||||||
barPercentage: 0.2
|
|
||||||
}]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
|
addPlugin (plugin) {
|
||||||
|
this.$data._plugins.push(plugin)
|
||||||
|
},
|
||||||
renderChart (data, options) {
|
renderChart (data, options) {
|
||||||
let chartOptions = mergeOptions(this.defaultOptions, options)
|
this.$data._chart = new Chart(
|
||||||
|
|
||||||
this._chart = new Chart(
|
|
||||||
this.$refs.canvas.getContext('2d'), {
|
this.$refs.canvas.getContext('2d'), {
|
||||||
type: 'bubble',
|
type: 'bubble',
|
||||||
data: data,
|
data: data,
|
||||||
options: chartOptions
|
options: options,
|
||||||
|
plugins: this.$data._plugins
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
this._chart.generateLegend()
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
beforeDestroy () {
|
beforeDestroy () {
|
||||||
this._chart.destroy()
|
if (this.$data._chart) {
|
||||||
|
this.$data._chart.destroy()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|||||||
@@ -1,11 +1,12 @@
|
|||||||
import Vue from 'vue'
|
|
||||||
import Chart from 'chart.js'
|
import Chart from 'chart.js'
|
||||||
import { mergeOptions } from '../helpers/options'
|
|
||||||
|
|
||||||
export default Vue.extend({
|
export default {
|
||||||
render: function (createElement) {
|
render: function (createElement) {
|
||||||
return createElement(
|
return createElement(
|
||||||
'div',
|
'div', {
|
||||||
|
style: this.styles,
|
||||||
|
class: this.cssClasses
|
||||||
|
},
|
||||||
[
|
[
|
||||||
createElement(
|
createElement(
|
||||||
'canvas', {
|
'canvas', {
|
||||||
@@ -33,31 +34,48 @@ export default Vue.extend({
|
|||||||
height: {
|
height: {
|
||||||
default: 400,
|
default: 400,
|
||||||
type: Number
|
type: Number
|
||||||
|
},
|
||||||
|
cssClasses: {
|
||||||
|
type: String,
|
||||||
|
default: ''
|
||||||
|
},
|
||||||
|
styles: {
|
||||||
|
type: Object
|
||||||
|
},
|
||||||
|
plugins: {
|
||||||
|
type: Array,
|
||||||
|
default () {
|
||||||
|
return []
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
data () {
|
data () {
|
||||||
return {
|
return {
|
||||||
defaultOptions: {
|
_chart: null,
|
||||||
}
|
_plugins: this.plugins
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
renderChart (data, options) {
|
addPlugin (plugin) {
|
||||||
let chartOptions = mergeOptions(this.defaultOptions, options)
|
this.$data._plugins.push(plugin)
|
||||||
|
},
|
||||||
|
|
||||||
this._chart = new Chart(
|
renderChart (data, options) {
|
||||||
|
this.$data._chart = new Chart(
|
||||||
this.$refs.canvas.getContext('2d'), {
|
this.$refs.canvas.getContext('2d'), {
|
||||||
type: 'doughnut',
|
type: 'doughnut',
|
||||||
data: data,
|
data: data,
|
||||||
options: chartOptions
|
options: options,
|
||||||
|
plugins: this.$data._plugins
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
this._chart.generateLegend()
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
beforeDestroy () {
|
beforeDestroy () {
|
||||||
this._chart.destroy()
|
if (this.$data._chart) {
|
||||||
|
this.$data._chart.destroy()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|||||||
@@ -1,11 +1,12 @@
|
|||||||
import Vue from 'vue'
|
|
||||||
import Chart from 'chart.js'
|
import Chart from 'chart.js'
|
||||||
import { mergeOptions } from '../helpers/options'
|
|
||||||
|
|
||||||
export default Vue.extend({
|
export default {
|
||||||
render: function (createElement) {
|
render: function (createElement) {
|
||||||
return createElement(
|
return createElement(
|
||||||
'div',
|
'div', {
|
||||||
|
style: this.styles,
|
||||||
|
class: this.cssClasses
|
||||||
|
},
|
||||||
[
|
[
|
||||||
createElement(
|
createElement(
|
||||||
'canvas', {
|
'canvas', {
|
||||||
@@ -33,47 +34,47 @@ export default Vue.extend({
|
|||||||
height: {
|
height: {
|
||||||
default: 400,
|
default: 400,
|
||||||
type: Number
|
type: Number
|
||||||
|
},
|
||||||
|
cssClasses: {
|
||||||
|
type: String,
|
||||||
|
default: ''
|
||||||
|
},
|
||||||
|
styles: {
|
||||||
|
type: Object
|
||||||
|
},
|
||||||
|
plugins: {
|
||||||
|
type: Array,
|
||||||
|
default () {
|
||||||
|
return []
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
data () {
|
data () {
|
||||||
return {
|
return {
|
||||||
defaultOptions: {
|
_chart: null,
|
||||||
scales: {
|
_plugins: this.plugins
|
||||||
yAxes: [{
|
|
||||||
ticks: {
|
|
||||||
beginAtZero: true
|
|
||||||
},
|
|
||||||
gridLines: {
|
|
||||||
display: false
|
|
||||||
}
|
|
||||||
}],
|
|
||||||
xAxes: [ {
|
|
||||||
gridLines: {
|
|
||||||
display: false
|
|
||||||
},
|
|
||||||
categoryPercentage: 0.5,
|
|
||||||
barPercentage: 0.2
|
|
||||||
}]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
renderChart (data, options, type) {
|
addPlugin (plugin) {
|
||||||
let chartOptions = mergeOptions(this.defaultOptions, options)
|
this.$data._plugins.push(plugin)
|
||||||
this._chart = new Chart(
|
},
|
||||||
|
renderChart (data, options) {
|
||||||
|
this.$data._chart = new Chart(
|
||||||
this.$refs.canvas.getContext('2d'), {
|
this.$refs.canvas.getContext('2d'), {
|
||||||
type: 'horizontalBar',
|
type: 'horizontalBar',
|
||||||
data: data,
|
data: data,
|
||||||
options: chartOptions
|
options: options,
|
||||||
|
plugins: this.$data._plugins
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
this._chart.generateLegend()
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
beforeDestroy () {
|
beforeDestroy () {
|
||||||
this._chart.destroy()
|
if (this.$data._chart) {
|
||||||
|
this.$data._chart.destroy()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|||||||
@@ -1,11 +1,12 @@
|
|||||||
import Vue from 'vue'
|
|
||||||
import Chart from 'chart.js'
|
import Chart from 'chart.js'
|
||||||
import { mergeOptions } from '../helpers/options'
|
|
||||||
|
|
||||||
export default Vue.extend({
|
export default {
|
||||||
render: function (createElement) {
|
render: function (createElement) {
|
||||||
return createElement(
|
return createElement(
|
||||||
'div',
|
'div', {
|
||||||
|
style: this.styles,
|
||||||
|
class: this.cssClasses
|
||||||
|
},
|
||||||
[
|
[
|
||||||
createElement(
|
createElement(
|
||||||
'canvas', {
|
'canvas', {
|
||||||
@@ -33,46 +34,47 @@ export default Vue.extend({
|
|||||||
height: {
|
height: {
|
||||||
default: 400,
|
default: 400,
|
||||||
type: Number
|
type: Number
|
||||||
|
},
|
||||||
|
cssClasses: {
|
||||||
|
type: String,
|
||||||
|
default: ''
|
||||||
|
},
|
||||||
|
styles: {
|
||||||
|
type: Object
|
||||||
|
},
|
||||||
|
plugins: {
|
||||||
|
type: Array,
|
||||||
|
default () {
|
||||||
|
return []
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
data () {
|
data () {
|
||||||
return {
|
return {
|
||||||
defaultOptions: {
|
_chart: null,
|
||||||
scales: {
|
_plugins: this.plugins
|
||||||
yAxes: [{
|
|
||||||
ticks: {
|
|
||||||
beginAtZero: true
|
|
||||||
},
|
|
||||||
gridLines: {
|
|
||||||
display: false
|
|
||||||
}
|
|
||||||
}],
|
|
||||||
xAxes: [ {
|
|
||||||
gridLines: {
|
|
||||||
display: false
|
|
||||||
}
|
|
||||||
}]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
|
addPlugin (plugin) {
|
||||||
|
this.$data._plugins.push(plugin)
|
||||||
|
},
|
||||||
renderChart (data, options) {
|
renderChart (data, options) {
|
||||||
let chartOptions = mergeOptions(this.defaultOptions, options)
|
this.$data._chart = new Chart(
|
||||||
|
|
||||||
this._chart = new Chart(
|
|
||||||
this.$refs.canvas.getContext('2d'), {
|
this.$refs.canvas.getContext('2d'), {
|
||||||
type: 'line',
|
type: 'line',
|
||||||
data: data,
|
data: data,
|
||||||
options: chartOptions
|
options: options,
|
||||||
|
plugins: this.$data._plugins
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
this._chart.generateLegend()
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
beforeDestroy () {
|
beforeDestroy () {
|
||||||
this._chart.destroy()
|
if (this.$data._chart) {
|
||||||
|
this.$data._chart.destroy()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|||||||
@@ -1,11 +1,12 @@
|
|||||||
import Vue from 'vue'
|
|
||||||
import Chart from 'chart.js'
|
import Chart from 'chart.js'
|
||||||
import { mergeOptions } from '../helpers/options'
|
|
||||||
|
|
||||||
export default Vue.extend({
|
export default {
|
||||||
render: function (createElement) {
|
render: function (createElement) {
|
||||||
return createElement(
|
return createElement(
|
||||||
'div',
|
'div', {
|
||||||
|
style: this.styles,
|
||||||
|
class: this.cssClasses
|
||||||
|
},
|
||||||
[
|
[
|
||||||
createElement(
|
createElement(
|
||||||
'canvas', {
|
'canvas', {
|
||||||
@@ -33,31 +34,47 @@ export default Vue.extend({
|
|||||||
height: {
|
height: {
|
||||||
default: 400,
|
default: 400,
|
||||||
type: Number
|
type: Number
|
||||||
|
},
|
||||||
|
cssClasses: {
|
||||||
|
type: String,
|
||||||
|
default: ''
|
||||||
|
},
|
||||||
|
styles: {
|
||||||
|
type: Object
|
||||||
|
},
|
||||||
|
plugins: {
|
||||||
|
type: Array,
|
||||||
|
default () {
|
||||||
|
return []
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
data () {
|
data () {
|
||||||
return {
|
return {
|
||||||
defaultOptions: {
|
_chart: null,
|
||||||
}
|
_plugins: this.plugins
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
|
addPlugin (plugin) {
|
||||||
|
this.$data._plugins.push(plugin)
|
||||||
|
},
|
||||||
renderChart (data, options) {
|
renderChart (data, options) {
|
||||||
let chartOptions = mergeOptions(this.defaultOptions, options)
|
this.$data._chart = new Chart(
|
||||||
|
|
||||||
this._chart = new Chart(
|
|
||||||
this.$refs.canvas.getContext('2d'), {
|
this.$refs.canvas.getContext('2d'), {
|
||||||
type: 'pie',
|
type: 'pie',
|
||||||
data: data,
|
data: data,
|
||||||
options: chartOptions
|
options: options,
|
||||||
|
plugins: this.$data._plugins
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
this._chart.generateLegend()
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
beforeDestroy () {
|
beforeDestroy () {
|
||||||
this._chart.destroy()
|
if (this.$data._chart) {
|
||||||
|
this.$data._chart.destroy()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|||||||
@@ -1,11 +1,12 @@
|
|||||||
import Vue from 'vue'
|
|
||||||
import Chart from 'chart.js'
|
import Chart from 'chart.js'
|
||||||
import { mergeOptions } from '../helpers/options'
|
|
||||||
|
|
||||||
export default Vue.extend({
|
export default {
|
||||||
render: function (createElement) {
|
render: function (createElement) {
|
||||||
return createElement(
|
return createElement(
|
||||||
'div',
|
'div', {
|
||||||
|
style: this.styles,
|
||||||
|
class: this.cssClasses
|
||||||
|
},
|
||||||
[
|
[
|
||||||
createElement(
|
createElement(
|
||||||
'canvas', {
|
'canvas', {
|
||||||
@@ -33,31 +34,47 @@ export default Vue.extend({
|
|||||||
height: {
|
height: {
|
||||||
default: 400,
|
default: 400,
|
||||||
type: Number
|
type: Number
|
||||||
|
},
|
||||||
|
cssClasses: {
|
||||||
|
type: String,
|
||||||
|
default: ''
|
||||||
|
},
|
||||||
|
styles: {
|
||||||
|
type: Object
|
||||||
|
},
|
||||||
|
plugins: {
|
||||||
|
type: Array,
|
||||||
|
default () {
|
||||||
|
return []
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
data () {
|
data () {
|
||||||
return {
|
return {
|
||||||
defaultOptions: {
|
_chart: null,
|
||||||
}
|
_plugins: this.plugins
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
|
addPlugin (plugin) {
|
||||||
|
this.$data._plugins.push(plugin)
|
||||||
|
},
|
||||||
renderChart (data, options) {
|
renderChart (data, options) {
|
||||||
let chartOptions = mergeOptions(this.defaultOptions, options)
|
this.$data._chart = new Chart(
|
||||||
|
|
||||||
this._chart = new Chart(
|
|
||||||
this.$refs.canvas.getContext('2d'), {
|
this.$refs.canvas.getContext('2d'), {
|
||||||
type: 'polarArea',
|
type: 'polarArea',
|
||||||
data: data,
|
data: data,
|
||||||
options: chartOptions
|
options: options,
|
||||||
|
plugins: this.$data._plugins
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
this._chart.generateLegend()
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
beforeDestroy () {
|
beforeDestroy () {
|
||||||
this._chart.destroy()
|
if (this.$data._chart) {
|
||||||
|
this.$data._chart.destroy()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|||||||
@@ -1,11 +1,12 @@
|
|||||||
import Vue from 'vue'
|
|
||||||
import Chart from 'chart.js'
|
import Chart from 'chart.js'
|
||||||
import { mergeOptions } from '../helpers/options'
|
|
||||||
|
|
||||||
export default Vue.extend({
|
export default {
|
||||||
render: function (createElement) {
|
render: function (createElement) {
|
||||||
return createElement(
|
return createElement(
|
||||||
'div',
|
'div', {
|
||||||
|
style: this.styles,
|
||||||
|
class: this.cssClasses
|
||||||
|
},
|
||||||
[
|
[
|
||||||
createElement(
|
createElement(
|
||||||
'canvas', {
|
'canvas', {
|
||||||
@@ -33,31 +34,47 @@ export default Vue.extend({
|
|||||||
height: {
|
height: {
|
||||||
default: 400,
|
default: 400,
|
||||||
type: Number
|
type: Number
|
||||||
|
},
|
||||||
|
cssClasses: {
|
||||||
|
type: String,
|
||||||
|
default: ''
|
||||||
|
},
|
||||||
|
styles: {
|
||||||
|
type: Object
|
||||||
|
},
|
||||||
|
plugins: {
|
||||||
|
type: Array,
|
||||||
|
default () {
|
||||||
|
return []
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
data () {
|
data () {
|
||||||
return {
|
return {
|
||||||
defaultOptions: {
|
_chart: null,
|
||||||
}
|
_plugins: this.plugins
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
|
addPlugin (plugin) {
|
||||||
|
this.$data._plugins.push(plugin)
|
||||||
|
},
|
||||||
renderChart (data, options) {
|
renderChart (data, options) {
|
||||||
let chartOptions = mergeOptions(this.defaultOptions, options)
|
this.$data._chart = new Chart(
|
||||||
|
|
||||||
this._chart = new Chart(
|
|
||||||
this.$refs.canvas.getContext('2d'), {
|
this.$refs.canvas.getContext('2d'), {
|
||||||
type: 'radar',
|
type: 'radar',
|
||||||
data: data,
|
data: data,
|
||||||
options: chartOptions
|
options: options,
|
||||||
|
plugins: this.$data._plugins
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
this._chart.generateLegend()
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
beforeDestroy () {
|
beforeDestroy () {
|
||||||
this._chart.destroy()
|
if (this.$data._chart) {
|
||||||
|
this.$data._chart.destroy()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|||||||
80
src/BaseCharts/Scatter.js
Normal file
@@ -0,0 +1,80 @@
|
|||||||
|
import Chart from 'chart.js'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
'div', {
|
||||||
|
style: this.styles,
|
||||||
|
class: this.cssClasses
|
||||||
|
},
|
||||||
|
[
|
||||||
|
createElement(
|
||||||
|
'canvas', {
|
||||||
|
attrs: {
|
||||||
|
id: this.chartId,
|
||||||
|
width: this.width,
|
||||||
|
height: this.height
|
||||||
|
},
|
||||||
|
ref: 'canvas'
|
||||||
|
}
|
||||||
|
)
|
||||||
|
]
|
||||||
|
)
|
||||||
|
},
|
||||||
|
|
||||||
|
props: {
|
||||||
|
chartId: {
|
||||||
|
default: 'scatter-chart',
|
||||||
|
type: String
|
||||||
|
},
|
||||||
|
width: {
|
||||||
|
default: 400,
|
||||||
|
type: Number
|
||||||
|
},
|
||||||
|
height: {
|
||||||
|
default: 400,
|
||||||
|
type: Number
|
||||||
|
},
|
||||||
|
cssClasses: {
|
||||||
|
type: String,
|
||||||
|
default: ''
|
||||||
|
},
|
||||||
|
styles: {
|
||||||
|
type: Object
|
||||||
|
},
|
||||||
|
plugins: {
|
||||||
|
type: Array,
|
||||||
|
default () {
|
||||||
|
return []
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
_chart: null,
|
||||||
|
_plugins: this.plugins
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
methods: {
|
||||||
|
addPlugin (plugin) {
|
||||||
|
this.$data._plugins.push(plugin)
|
||||||
|
},
|
||||||
|
renderChart (data, options) {
|
||||||
|
this.$data._chart = new Chart(
|
||||||
|
this.$refs.canvas.getContext('2d'), {
|
||||||
|
type: 'scatter',
|
||||||
|
data: data,
|
||||||
|
options: options,
|
||||||
|
plugins: this.$data._plugins
|
||||||
|
}
|
||||||
|
)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
beforeDestroy () {
|
||||||
|
if (this.$data._chart) {
|
||||||
|
this.$data._chart.destroy()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,21 +1,59 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<h1 style="text-align:center;margin:40px 0;">Barchart</h1>
|
<div class="Chart">
|
||||||
<bar-example></bar-example>
|
<h1 style="text-align:center;">Barchart</h1>
|
||||||
<h1 style="text-align:center;margin:40px 0;">Barchart with reactive mixing for live data</h1>
|
<bar-example></bar-example>
|
||||||
<reactive-example></reactive-example>
|
</div>
|
||||||
<h1 style="text-align:center;margin:40px 0;">Linechart</h1>
|
|
||||||
<line-example></line-example>
|
<div class="Chart">
|
||||||
<h1 style="text-align:center;margin:40px 0;">Doughnutchart</h1>
|
<h1 style="text-align:center;">Horizontal Barchart</h1>
|
||||||
<doughnut-example></doughnut-example>
|
<horizontal-bar-example></horizontal-bar-example>
|
||||||
<h1 style="text-align:center;margin:40px 0;">Piechart</h1>
|
</div>
|
||||||
<pie-example></pie-example>
|
|
||||||
<h1 style="text-align:center;margin:40px 0;">Radarchart</h1>
|
<div class="Chart">
|
||||||
<radar-example></radar-example>
|
<h1 style="text-align:center;">Barchart with reactive mixing for live data</h1>
|
||||||
<h1 style="text-align:center;margin:40px 0;">Polararea</h1>
|
<reactive-example></reactive-example>
|
||||||
<polar-area-example></polar-area-example>
|
</div>
|
||||||
<h1 style="text-align:center;margin:40px 0;">Bubblechart</h1>
|
|
||||||
<bubble-example></bubble-example>
|
<div class="Chart">
|
||||||
|
<h1 style="text-align:center;">Barchart with reactive mixing for live data as props</h1>
|
||||||
|
<reactive-prop-example :chart-data="dataPoints"></reactive-prop-example>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="Chart">
|
||||||
|
<h1 style="text-align:center;">Linechart</h1>
|
||||||
|
<line-example></line-example>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="Chart">
|
||||||
|
<h1 style="text-align:center;">Doughnutchart</h1>
|
||||||
|
<doughnut-example></doughnut-example>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="Chart">
|
||||||
|
<h1 style="text-align:center;">Piechart</h1>
|
||||||
|
<pie-example></pie-example>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="Chart">
|
||||||
|
<h1 style="text-align:center;">Radarchart</h1>
|
||||||
|
<radar-example></radar-example>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="Chart">
|
||||||
|
<h1 style="text-align:center;">Polararea</h1>
|
||||||
|
<polar-area-example></polar-area-example>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="Chart">
|
||||||
|
<h1 style="text-align:center;">Bubblechart</h1>
|
||||||
|
<bubble-example></bubble-example>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="Chart">
|
||||||
|
<h1 style="text-align:center;">Scatter Chart</h1>
|
||||||
|
<scatter-example></scatter-example>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
@@ -29,6 +67,8 @@
|
|||||||
import BubbleExample from './BubbleExample'
|
import BubbleExample from './BubbleExample'
|
||||||
import ReactiveExample from './ReactiveExample'
|
import ReactiveExample from './ReactiveExample'
|
||||||
import ReactivePropExample from './ReactivePropExample'
|
import ReactivePropExample from './ReactivePropExample'
|
||||||
|
import ScatterExample from './ScatterExample'
|
||||||
|
import HorizontalBarExample from './HorizontalBarExample'
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
components: {
|
components: {
|
||||||
@@ -40,7 +80,48 @@
|
|||||||
PolarAreaExample,
|
PolarAreaExample,
|
||||||
BubbleExample,
|
BubbleExample,
|
||||||
ReactiveExample,
|
ReactiveExample,
|
||||||
ReactivePropExample
|
ReactivePropExample,
|
||||||
|
ScatterExample,
|
||||||
|
HorizontalBarExample
|
||||||
|
},
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
dataPoints: null,
|
||||||
|
height: 20
|
||||||
|
}
|
||||||
|
},
|
||||||
|
mounted () {
|
||||||
|
setInterval(() => {
|
||||||
|
this.fillData()
|
||||||
|
}, 2000)
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
increaseHeight () {
|
||||||
|
this.height += 10
|
||||||
|
},
|
||||||
|
getRandomInt () {
|
||||||
|
return Math.floor(Math.random() * (50 - 5 + 1)) + 5
|
||||||
|
},
|
||||||
|
fillData () {
|
||||||
|
this.dataPoints = {
|
||||||
|
labels: ['January' + this.getRandomInt(), 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],
|
||||||
|
datasets: [
|
||||||
|
{
|
||||||
|
label: 'Data One',
|
||||||
|
backgroundColor: '#f87979',
|
||||||
|
data: [this.getRandomInt(), this.getRandomInt(), this.getRandomInt(), this.getRandomInt(), this.getRandomInt(), this.getRandomInt(), this.getRandomInt(), this.getRandomInt(), this.getRandomInt(), this.getRandomInt(), this.getRandomInt(), this.getRandomInt()]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
myStyles () {
|
||||||
|
return {
|
||||||
|
height: `${this.height}px`,
|
||||||
|
position: 'relative'
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
@@ -50,4 +131,21 @@
|
|||||||
max-width: 800px;
|
max-width: 800px;
|
||||||
margin: 0 auto;
|
margin: 0 auto;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
font-family: 'Helvetica', Arial;
|
||||||
|
color: #464646;
|
||||||
|
text-transform: uppercase;
|
||||||
|
border-bottom: 1px solid #f1f1f1;
|
||||||
|
padding-bottom: 15px;
|
||||||
|
font-size: 28px;
|
||||||
|
margin-top: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.Chart {
|
||||||
|
padding: 20px;
|
||||||
|
box-shadow: 0px 0px 20px 2px rgba(0, 0, 0, .4);
|
||||||
|
border-radius: 20px;
|
||||||
|
margin: 50px 0;
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
import BarChart from '../BaseCharts/Bar'
|
import Bar from '../BaseCharts/Bar'
|
||||||
|
|
||||||
export default BarChart.extend({
|
export default {
|
||||||
|
extends: Bar,
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart({
|
this.renderChart({
|
||||||
labels: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],
|
labels: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],
|
||||||
@@ -13,4 +14,4 @@ export default BarChart.extend({
|
|||||||
]
|
]
|
||||||
}, {responsive: true, maintainAspectRatio: false})
|
}, {responsive: true, maintainAspectRatio: false})
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
import BubbleChart from '../BaseCharts/Bubble'
|
import Bubble from '../BaseCharts/Bubble'
|
||||||
|
|
||||||
export default BubbleChart.extend({
|
export default {
|
||||||
|
extends: Bubble,
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart({
|
this.renderChart({
|
||||||
datasets: [
|
datasets: [
|
||||||
@@ -49,4 +50,4 @@ export default BubbleChart.extend({
|
|||||||
]
|
]
|
||||||
}, {responsive: true, maintainAspectRatio: false})
|
}, {responsive: true, maintainAspectRatio: false})
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
import DoughnutChart from '../BaseCharts/Doughnut'
|
import Doughnut from '../BaseCharts/Doughnut'
|
||||||
|
|
||||||
export default DoughnutChart.extend({
|
export default {
|
||||||
|
extends: Doughnut,
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart({
|
this.renderChart({
|
||||||
labels: ['VueJs', 'EmberJs', 'ReactJs', 'AngularJs'],
|
labels: ['VueJs', 'EmberJs', 'ReactJs', 'AngularJs'],
|
||||||
@@ -17,4 +18,4 @@ export default DoughnutChart.extend({
|
|||||||
]
|
]
|
||||||
}, {responsive: true, maintainAspectRatio: false})
|
}, {responsive: true, maintainAspectRatio: false})
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
import HorizontalBarChart from '../BaseCharts/HorizontalBar'
|
import HorizontalBar from '../BaseCharts/HorizontalBar'
|
||||||
|
|
||||||
export default HorizontalBarChart.extend({
|
export default {
|
||||||
|
extends: HorizontalBar,
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart({
|
this.renderChart({
|
||||||
labels: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],
|
labels: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],
|
||||||
@@ -13,4 +14,4 @@ export default HorizontalBarChart.extend({
|
|||||||
]
|
]
|
||||||
}, {responsive: true, maintainAspectRatio: false})
|
}, {responsive: true, maintainAspectRatio: false})
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
import LineChart from '../BaseCharts/Line'
|
import Line from '../BaseCharts/Line'
|
||||||
|
|
||||||
export default LineChart.extend({
|
export default {
|
||||||
|
extends: Line,
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart({
|
this.renderChart({
|
||||||
labels: ['January', 'February', 'March', 'April', 'May', 'June', 'July'],
|
labels: ['January', 'February', 'March', 'April', 'May', 'June', 'July'],
|
||||||
@@ -13,4 +14,4 @@ export default LineChart.extend({
|
|||||||
]
|
]
|
||||||
}, {responsive: true, maintainAspectRatio: false})
|
}, {responsive: true, maintainAspectRatio: false})
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
import PieChart from '../BaseCharts/Pie'
|
import Pie from '../BaseCharts/Pie'
|
||||||
|
|
||||||
export default PieChart.extend({
|
export default {
|
||||||
|
extends: Pie,
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart({
|
this.renderChart({
|
||||||
labels: ['VueJs', 'EmberJs', 'ReactJs', 'AngularJs'],
|
labels: ['VueJs', 'EmberJs', 'ReactJs', 'AngularJs'],
|
||||||
@@ -17,4 +18,4 @@ export default PieChart.extend({
|
|||||||
]
|
]
|
||||||
}, {responsive: true, maintainAspectRatio: false})
|
}, {responsive: true, maintainAspectRatio: false})
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
import PolarAreaChart from '../BaseCharts/PolarArea'
|
import PolarArea from '../BaseCharts/PolarArea'
|
||||||
|
|
||||||
export default PolarAreaChart.extend({
|
export default {
|
||||||
|
extends: PolarArea,
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart({
|
this.renderChart({
|
||||||
labels: ['Eating', 'Drinking', 'Sleeping', 'Designing', 'Coding', 'Cycling', 'Running'],
|
labels: ['Eating', 'Drinking', 'Sleeping', 'Designing', 'Coding', 'Cycling', 'Running'],
|
||||||
@@ -26,4 +27,4 @@ export default PolarAreaChart.extend({
|
|||||||
]
|
]
|
||||||
}, {responsive: true, maintainAspectRatio: false})
|
}, {responsive: true, maintainAspectRatio: false})
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
import RadarChart from '../BaseCharts/Radar'
|
import Radar from '../BaseCharts/Radar'
|
||||||
|
|
||||||
export default RadarChart.extend({
|
export default {
|
||||||
|
extends: Radar,
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart({
|
this.renderChart({
|
||||||
labels: ['Eating', 'Drinking', 'Sleeping', 'Designing', 'Coding', 'Cycling', 'Running'],
|
labels: ['Eating', 'Drinking', 'Sleeping', 'Designing', 'Coding', 'Cycling', 'Running'],
|
||||||
@@ -28,4 +29,4 @@ export default RadarChart.extend({
|
|||||||
]
|
]
|
||||||
}, {responsive: true, maintainAspectRatio: false})
|
}, {responsive: true, maintainAspectRatio: false})
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|||||||
@@ -1,7 +1,8 @@
|
|||||||
import BarChart from '../BaseCharts/Bar'
|
import Bar from '../BaseCharts/Bar'
|
||||||
import reactiveData from '../mixins/reactiveData'
|
import reactiveData from '../mixins/reactiveData'
|
||||||
|
|
||||||
export default BarChart.extend({
|
export default {
|
||||||
|
extends: Bar,
|
||||||
mixins: [reactiveData],
|
mixins: [reactiveData],
|
||||||
data () {
|
data () {
|
||||||
return {
|
return {
|
||||||
@@ -38,4 +39,4 @@ export default BarChart.extend({
|
|||||||
return Math.floor(Math.random() * (50 - 5 + 1)) + 5
|
return Math.floor(Math.random() * (50 - 5 + 1)) + 5
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|||||||
@@ -1,10 +1,11 @@
|
|||||||
import BarChart from '../BaseCharts/Bar'
|
import Bar from '../BaseCharts/Bar'
|
||||||
import reactiveProp from '../mixins/reactiveProp'
|
import reactiveProp from '../mixins/reactiveProp'
|
||||||
|
|
||||||
export default BarChart.extend({
|
export default {
|
||||||
|
extends: Bar,
|
||||||
mixins: [reactiveProp],
|
mixins: [reactiveProp],
|
||||||
|
|
||||||
mounted () {
|
mounted () {
|
||||||
this.renderChart(this.chartData)
|
this.renderChart(this.chartData, {responsive: true, maintainAspectRatio: false})
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|||||||
53
src/examples/ScatterExample.js
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
import Scatter from '../BaseCharts/Scatter'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: Scatter,
|
||||||
|
mounted () {
|
||||||
|
this.renderChart({
|
||||||
|
datasets: [{
|
||||||
|
label: 'Scatter Dataset 1',
|
||||||
|
fill: false,
|
||||||
|
borderColor: '#f87979',
|
||||||
|
backgroundColor: '#f87979',
|
||||||
|
data: [{
|
||||||
|
x: -2,
|
||||||
|
y: 4
|
||||||
|
}, {
|
||||||
|
x: -1,
|
||||||
|
y: 1
|
||||||
|
}, {
|
||||||
|
x: 0,
|
||||||
|
y: 0
|
||||||
|
}, {
|
||||||
|
x: 1,
|
||||||
|
y: 1
|
||||||
|
}, {
|
||||||
|
x: 2,
|
||||||
|
y: 4
|
||||||
|
}]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Scatter Dataset 2',
|
||||||
|
fill: false,
|
||||||
|
borderColor: '#7acbf9',
|
||||||
|
backgroundColor: '#7acbf9',
|
||||||
|
data: [{
|
||||||
|
x: -2,
|
||||||
|
y: -4
|
||||||
|
}, {
|
||||||
|
x: -1,
|
||||||
|
y: -1
|
||||||
|
}, {
|
||||||
|
x: 0,
|
||||||
|
y: 1
|
||||||
|
}, {
|
||||||
|
x: 1,
|
||||||
|
y: -1
|
||||||
|
}, {
|
||||||
|
x: 2,
|
||||||
|
y: -4
|
||||||
|
}]
|
||||||
|
}]
|
||||||
|
}, {responsive: true, maintainAspectRatio: false})
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
import merge from 'lodash/fp/merge'
|
|
||||||
|
|
||||||
export function mergeOptions (obj, src) {
|
|
||||||
return merge(obj, src)
|
|
||||||
}
|
|
||||||
@@ -6,6 +6,7 @@ import Pie from './BaseCharts/Pie'
|
|||||||
import PolarArea from './BaseCharts/PolarArea'
|
import PolarArea from './BaseCharts/PolarArea'
|
||||||
import Radar from './BaseCharts/Radar'
|
import Radar from './BaseCharts/Radar'
|
||||||
import Bubble from './BaseCharts/Bubble'
|
import Bubble from './BaseCharts/Bubble'
|
||||||
|
import Scatter from './BaseCharts/Scatter'
|
||||||
import mixins from './mixins/index.js'
|
import mixins from './mixins/index.js'
|
||||||
import npmCfg from '../package.json'
|
import npmCfg from '../package.json'
|
||||||
|
|
||||||
@@ -19,6 +20,7 @@ const VueCharts = {
|
|||||||
PolarArea,
|
PolarArea,
|
||||||
Radar,
|
Radar,
|
||||||
Bubble,
|
Bubble,
|
||||||
|
Scatter,
|
||||||
mixins
|
mixins
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -34,5 +36,6 @@ export {
|
|||||||
PolarArea,
|
PolarArea,
|
||||||
Radar,
|
Radar,
|
||||||
Bubble,
|
Bubble,
|
||||||
|
Scatter,
|
||||||
mixins
|
mixins
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ module.exports = {
|
|||||||
'chartData': {
|
'chartData': {
|
||||||
handler (newData, oldData) {
|
handler (newData, oldData) {
|
||||||
if (oldData) {
|
if (oldData) {
|
||||||
let chart = this._chart
|
let chart = this.$data._chart
|
||||||
|
|
||||||
// Get new and old DataSet Labels
|
// Get new and old DataSet Labels
|
||||||
let newDatasetLabels = newData.datasets.map((dataset) => {
|
let newDatasetLabels = newData.datasets.map((dataset) => {
|
||||||
@@ -48,12 +48,25 @@ module.exports = {
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
chart.data.labels = newData.labels
|
if (newData.hasOwnProperty('labels')) {
|
||||||
|
chart.data.labels = newData.labels
|
||||||
|
}
|
||||||
|
if (newData.hasOwnProperty('xLabels')) {
|
||||||
|
chart.data.xLabels = newData.xLabels
|
||||||
|
}
|
||||||
|
if (newData.hasOwnProperty('yLabels')) {
|
||||||
|
chart.data.yLabels = newData.yLabels
|
||||||
|
}
|
||||||
chart.update()
|
chart.update()
|
||||||
} else {
|
} else {
|
||||||
chart.destroy()
|
chart.destroy()
|
||||||
this.renderChart(this.chartData, this.options)
|
this.renderChart(this.chartData, this.options)
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
if (this.$data._chart) {
|
||||||
|
this.$data._chart.destroy()
|
||||||
|
}
|
||||||
|
this.renderChart(this.chartData, this.options)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ module.exports = {
|
|||||||
'chartData': {
|
'chartData': {
|
||||||
handler (newData, oldData) {
|
handler (newData, oldData) {
|
||||||
if (oldData) {
|
if (oldData) {
|
||||||
let chart = this._chart
|
let chart = this.$data._chart
|
||||||
|
|
||||||
// Get new and old DataSet Labels
|
// Get new and old DataSet Labels
|
||||||
let newDatasetLabels = newData.datasets.map((dataset) => {
|
let newDatasetLabels = newData.datasets.map((dataset) => {
|
||||||
@@ -48,12 +48,25 @@ module.exports = {
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
chart.data.labels = newData.labels
|
if (newData.hasOwnProperty('labels')) {
|
||||||
|
chart.data.labels = newData.labels
|
||||||
|
}
|
||||||
|
if (newData.hasOwnProperty('xLabels')) {
|
||||||
|
chart.data.xLabels = newData.xLabels
|
||||||
|
}
|
||||||
|
if (newData.hasOwnProperty('yLabels')) {
|
||||||
|
chart.data.yLabels = newData.yLabels
|
||||||
|
}
|
||||||
chart.update()
|
chart.update()
|
||||||
} else {
|
} else {
|
||||||
chart.destroy()
|
chart.destroy()
|
||||||
this.renderChart(this.chartData, this.options)
|
this.renderChart(this.chartData, this.options)
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
if (this.$data._chart) {
|
||||||
|
this.$data._chart.destroy()
|
||||||
|
}
|
||||||
|
this.renderChart(this.chartData, this.options)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -16,11 +16,6 @@ var webpackConfig = merge(baseConfig, {
|
|||||||
loaders: utils.styleLoaders()
|
loaders: utils.styleLoaders()
|
||||||
},
|
},
|
||||||
devtool: '#inline-source-map',
|
devtool: '#inline-source-map',
|
||||||
vue: {
|
|
||||||
loaders: {
|
|
||||||
js: 'isparta'
|
|
||||||
}
|
|
||||||
},
|
|
||||||
plugins: [
|
plugins: [
|
||||||
new webpack.DefinePlugin({
|
new webpack.DefinePlugin({
|
||||||
'process.env': require('../../config/test.env')
|
'process.env': require('../../config/test.env')
|
||||||
@@ -31,15 +26,18 @@ var webpackConfig = merge(baseConfig, {
|
|||||||
// no need for app entry during tests
|
// no need for app entry during tests
|
||||||
delete webpackConfig.entry
|
delete webpackConfig.entry
|
||||||
|
|
||||||
|
// function resolve (dir) {
|
||||||
|
// return path.join(__dirname, '..', dir)
|
||||||
|
// }
|
||||||
// make sure isparta loader is applied before eslint
|
// make sure isparta loader is applied before eslint
|
||||||
webpackConfig.module.preLoaders = webpackConfig.module.preLoaders || []
|
// webpackConfig.module.rules = webpackConfig.module.rules || []
|
||||||
webpackConfig.module.preLoaders.unshift({
|
// webpackConfig.module.rules.unshift({
|
||||||
test: /\.js$/,
|
// test: /\.js$/,
|
||||||
loader: 'isparta',
|
// loader: 'babel-loader',
|
||||||
include: path.resolve(projectRoot, 'src')
|
// include: [resolve('src'), resolve('test')]
|
||||||
})
|
// })
|
||||||
|
|
||||||
// only apply babel for test files when using isparta
|
// // only apply babel for test files when using isparta
|
||||||
webpackConfig.module.loaders.some(function (loader, i) {
|
webpackConfig.module.loaders.some(function (loader, i) {
|
||||||
if (loader.loader === 'babel') {
|
if (loader.loader === 'babel') {
|
||||||
loader.include = path.resolve(projectRoot, 'test/unit')
|
loader.include = path.resolve(projectRoot, 'test/unit')
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
import Vue from 'vue'
|
import Vue from 'vue'
|
||||||
import BarChart from 'src/examples/BarExample'
|
import BarChart from '@/examples/BarExample'
|
||||||
|
|
||||||
describe('BarChart', () => {
|
describe('BarChart', () => {
|
||||||
let el
|
let el
|
||||||
@@ -51,14 +51,56 @@ describe('BarChart', () => {
|
|||||||
components: { BarChart }
|
components: { BarChart }
|
||||||
}).$mount(el)
|
}).$mount(el)
|
||||||
|
|
||||||
expect(vm.$children[0]._chart.chart.ctx).not.to.be.null
|
expect(vm.$children[0].$data._chart.chart.ctx).not.to.be.null
|
||||||
|
|
||||||
vm.$destroy()
|
vm.$destroy()
|
||||||
|
|
||||||
vm.$nextTick(() => {
|
vm.$nextTick(() => {
|
||||||
vm.$forceUpdate()
|
vm.$forceUpdate()
|
||||||
expect(vm.$children[0]._chart.chart.ctx).to.be.null
|
expect(vm.$children[0].$data._chart.chart.ctx).to.equal
|
||||||
done()
|
done()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('should add an inline plugin to the array', () => {
|
||||||
|
const testPlugin = {
|
||||||
|
id: 'test'
|
||||||
|
}
|
||||||
|
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
BarChart
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { BarChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins).to.exist
|
||||||
|
vm.$children[0].addPlugin(testPlugin)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should add inline plugins based on prop', () => {
|
||||||
|
const testPlugin = {
|
||||||
|
id: 'test'
|
||||||
|
}
|
||||||
|
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
BarChart, {
|
||||||
|
props: {
|
||||||
|
plugins: [testPlugin]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { BarChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins).to.exist
|
||||||
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
import Vue from 'vue'
|
import Vue from 'vue'
|
||||||
import BubbleChart from 'src/examples/BubbleExample'
|
import BubbleChart from '@/examples/BubbleExample'
|
||||||
|
|
||||||
describe('BubbleChart', () => {
|
describe('BubbleChart', () => {
|
||||||
let el
|
let el
|
||||||
@@ -51,14 +51,56 @@ describe('BubbleChart', () => {
|
|||||||
components: { BubbleChart }
|
components: { BubbleChart }
|
||||||
}).$mount(el)
|
}).$mount(el)
|
||||||
|
|
||||||
expect(vm.$children[0]._chart.chart.ctx).not.to.be.null
|
expect(vm.$children[0].$data._chart.chart.ctx).not.to.be.null
|
||||||
|
|
||||||
vm.$destroy()
|
vm.$destroy()
|
||||||
|
|
||||||
vm.$nextTick(() => {
|
vm.$nextTick(() => {
|
||||||
vm.$forceUpdate()
|
vm.$forceUpdate()
|
||||||
expect(vm.$children[0]._chart.chart.ctx).to.be.null
|
expect(vm.$children[0].$data._chart.chart.ctx).to.be.null
|
||||||
done()
|
done()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('should add an inline plugin to the array', () => {
|
||||||
|
const testPlugin = {
|
||||||
|
id: 'test'
|
||||||
|
}
|
||||||
|
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
BubbleChart
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { BubbleChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins).to.exist
|
||||||
|
vm.$children[0].addPlugin(testPlugin)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should add inline plugins based on prop', () => {
|
||||||
|
const testPlugin = {
|
||||||
|
id: 'test'
|
||||||
|
}
|
||||||
|
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
BubbleChart, {
|
||||||
|
props: {
|
||||||
|
plugins: [testPlugin]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { BubbleChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins).to.exist
|
||||||
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
import Vue from 'vue'
|
import Vue from 'vue'
|
||||||
import DoughnutChart from 'src/examples/DoughnutExample'
|
import DoughnutChart from '@/examples/DoughnutExample'
|
||||||
|
|
||||||
describe('DoughnutChart', () => {
|
describe('DoughnutChart', () => {
|
||||||
let el
|
let el
|
||||||
@@ -51,14 +51,56 @@ describe('DoughnutChart', () => {
|
|||||||
components: { DoughnutChart }
|
components: { DoughnutChart }
|
||||||
}).$mount(el)
|
}).$mount(el)
|
||||||
|
|
||||||
expect(vm.$children[0]._chart.chart.ctx).not.to.be.null
|
expect(vm.$children[0].$data._chart.chart.ctx).not.to.be.null
|
||||||
|
|
||||||
vm.$destroy()
|
vm.$destroy()
|
||||||
|
|
||||||
vm.$nextTick(() => {
|
vm.$nextTick(() => {
|
||||||
vm.$forceUpdate()
|
vm.$forceUpdate()
|
||||||
expect(vm.$children[0]._chart.chart.ctx).to.be.null
|
expect(vm.$children[0].$data._chart.chart.ctx).to.be.null
|
||||||
done()
|
done()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('should add an inline plugin to the array', () => {
|
||||||
|
const testPlugin = {
|
||||||
|
id: 'test'
|
||||||
|
}
|
||||||
|
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
DoughnutChart
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { DoughnutChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins).to.exist
|
||||||
|
vm.$children[0].addPlugin(testPlugin)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should add inline plugins based on prop', () => {
|
||||||
|
const testPlugin = {
|
||||||
|
id: 'test'
|
||||||
|
}
|
||||||
|
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
DoughnutChart, {
|
||||||
|
props: {
|
||||||
|
plugins: [testPlugin]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { DoughnutChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins).to.exist
|
||||||
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
import Vue from 'vue'
|
import Vue from 'vue'
|
||||||
import HorizontalBarChart from 'src/examples/HorizontalBarExample'
|
import HorizontalBarChart from '@/examples/HorizontalBarExample'
|
||||||
|
|
||||||
describe('HorizontalBarChart', () => {
|
describe('HorizontalBarChart', () => {
|
||||||
let el
|
let el
|
||||||
@@ -51,14 +51,56 @@ describe('HorizontalBarChart', () => {
|
|||||||
components: { HorizontalBarChart }
|
components: { HorizontalBarChart }
|
||||||
}).$mount(el)
|
}).$mount(el)
|
||||||
|
|
||||||
expect(vm.$children[0]._chart.chart.ctx).not.to.be.null
|
expect(vm.$children[0].$data._chart.chart.ctx).not.to.be.null
|
||||||
|
|
||||||
vm.$destroy()
|
vm.$destroy()
|
||||||
|
|
||||||
vm.$nextTick(() => {
|
vm.$nextTick(() => {
|
||||||
vm.$forceUpdate()
|
vm.$forceUpdate()
|
||||||
expect(vm.$children[0]._chart.chart.ctx).to.be.null
|
expect(vm.$children[0].$data._chart.chart.ctx).to.be.null
|
||||||
done()
|
done()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('should add an inline plugin to the array', () => {
|
||||||
|
const testPlugin = {
|
||||||
|
id: 'test'
|
||||||
|
}
|
||||||
|
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
HorizontalBarChart
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { HorizontalBarChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins).to.exist
|
||||||
|
vm.$children[0].addPlugin(testPlugin)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should add inline plugins based on prop', () => {
|
||||||
|
const testPlugin = {
|
||||||
|
id: 'test'
|
||||||
|
}
|
||||||
|
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
HorizontalBarChart, {
|
||||||
|
props: {
|
||||||
|
plugins: [testPlugin]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { HorizontalBarChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins).to.exist
|
||||||
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
import Vue from 'vue'
|
import Vue from 'vue'
|
||||||
import LineChart from 'src/examples/LineExample'
|
import LineChart from '@/examples/LineExample'
|
||||||
|
|
||||||
describe('LineChart', () => {
|
describe('LineChart', () => {
|
||||||
let el
|
let el
|
||||||
@@ -51,14 +51,56 @@ describe('LineChart', () => {
|
|||||||
components: { LineChart }
|
components: { LineChart }
|
||||||
}).$mount(el)
|
}).$mount(el)
|
||||||
|
|
||||||
expect(vm.$children[0]._chart.chart.ctx).not.to.be.null
|
expect(vm.$children[0].$data._chart.chart.ctx).not.to.be.null
|
||||||
|
|
||||||
vm.$destroy()
|
vm.$destroy()
|
||||||
|
|
||||||
vm.$nextTick(() => {
|
vm.$nextTick(() => {
|
||||||
vm.$forceUpdate()
|
vm.$forceUpdate()
|
||||||
expect(vm.$children[0]._chart.chart.ctx).to.be.null
|
expect(vm.$children[0].$data._chart.chart.ctx).to.be.null
|
||||||
done()
|
done()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('should add an inline plugin to the array', () => {
|
||||||
|
const testPlugin = {
|
||||||
|
id: 'test'
|
||||||
|
}
|
||||||
|
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
LineChart
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { LineChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins).to.exist
|
||||||
|
vm.$children[0].addPlugin(testPlugin)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should add inline plugins based on prop', () => {
|
||||||
|
const testPlugin = {
|
||||||
|
id: 'test'
|
||||||
|
}
|
||||||
|
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
LineChart, {
|
||||||
|
props: {
|
||||||
|
plugins: [testPlugin]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { LineChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins).to.exist
|
||||||
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
import Vue from 'vue'
|
import Vue from 'vue'
|
||||||
import PieChart from 'src/examples/PieExample'
|
import PieChart from '@/examples/PieExample'
|
||||||
|
|
||||||
describe('PieChart', () => {
|
describe('PieChart', () => {
|
||||||
let el
|
let el
|
||||||
@@ -50,14 +50,56 @@ describe('PieChart', () => {
|
|||||||
components: { PieChart }
|
components: { PieChart }
|
||||||
}).$mount(el)
|
}).$mount(el)
|
||||||
|
|
||||||
expect(vm.$children[0]._chart.chart.ctx).not.to.be.null
|
expect(vm.$children[0].$data._chart.chart.ctx).not.to.be.null
|
||||||
|
|
||||||
vm.$destroy()
|
vm.$destroy()
|
||||||
|
|
||||||
vm.$nextTick(() => {
|
vm.$nextTick(() => {
|
||||||
vm.$forceUpdate()
|
vm.$forceUpdate()
|
||||||
expect(vm.$children[0]._chart.chart.ctx).to.be.null
|
expect(vm.$children[0].$data._chart.chart.ctx).to.be.null
|
||||||
done()
|
done()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('should add an inline plugin to the array', () => {
|
||||||
|
const testPlugin = {
|
||||||
|
id: 'test'
|
||||||
|
}
|
||||||
|
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
PieChart
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { PieChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins).to.exist
|
||||||
|
vm.$children[0].addPlugin(testPlugin)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should add inline plugins based on prop', () => {
|
||||||
|
const testPlugin = {
|
||||||
|
id: 'test'
|
||||||
|
}
|
||||||
|
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
PieChart, {
|
||||||
|
props: {
|
||||||
|
plugins: [testPlugin]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { PieChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins).to.exist
|
||||||
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
import Vue from 'vue'
|
import Vue from 'vue'
|
||||||
import PolarChart from 'src/examples/PolarAreaExample'
|
import PolarChart from '@/examples/PolarAreaExample'
|
||||||
|
|
||||||
describe('PolarChart', () => {
|
describe('PolarChart', () => {
|
||||||
let el
|
let el
|
||||||
@@ -51,14 +51,56 @@ describe('PolarChart', () => {
|
|||||||
components: { PolarChart }
|
components: { PolarChart }
|
||||||
}).$mount(el)
|
}).$mount(el)
|
||||||
|
|
||||||
expect(vm.$children[0]._chart.chart.ctx).not.to.be.null
|
expect(vm.$children[0].$data._chart.chart.ctx).not.to.be.null
|
||||||
|
|
||||||
vm.$destroy()
|
vm.$destroy()
|
||||||
|
|
||||||
vm.$nextTick(() => {
|
vm.$nextTick(() => {
|
||||||
vm.$forceUpdate()
|
vm.$forceUpdate()
|
||||||
expect(vm.$children[0]._chart.chart.ctx).to.be.null
|
expect(vm.$children[0].$data._chart.chart.ctx).to.be.null
|
||||||
done()
|
done()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('should add an inline plugin to the array', () => {
|
||||||
|
const testPlugin = {
|
||||||
|
id: 'test'
|
||||||
|
}
|
||||||
|
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
PolarChart
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { PolarChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins).to.exist
|
||||||
|
vm.$children[0].addPlugin(testPlugin)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should add inline plugins based on prop', () => {
|
||||||
|
const testPlugin = {
|
||||||
|
id: 'test'
|
||||||
|
}
|
||||||
|
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
PolarChart, {
|
||||||
|
props: {
|
||||||
|
plugins: [testPlugin]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { PolarChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins).to.exist
|
||||||
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
import Vue from 'vue'
|
import Vue from 'vue'
|
||||||
import RadarChart from 'src/examples/RadarExample'
|
import RadarChart from '@/examples/RadarExample'
|
||||||
|
|
||||||
describe('RadarChart', () => {
|
describe('RadarChart', () => {
|
||||||
let el
|
let el
|
||||||
@@ -50,14 +50,56 @@ describe('RadarChart', () => {
|
|||||||
components: { RadarChart }
|
components: { RadarChart }
|
||||||
}).$mount(el)
|
}).$mount(el)
|
||||||
|
|
||||||
expect(vm.$children[0]._chart.chart.ctx).not.to.be.null
|
expect(vm.$children[0].$data._chart.chart.ctx).not.to.be.null
|
||||||
|
|
||||||
vm.$destroy()
|
vm.$destroy()
|
||||||
|
|
||||||
vm.$nextTick(() => {
|
vm.$nextTick(() => {
|
||||||
vm.$forceUpdate()
|
vm.$forceUpdate()
|
||||||
expect(vm.$children[0]._chart.chart.ctx).to.be.null
|
expect(vm.$children[0].$data._chart.chart.ctx).to.be.null
|
||||||
done()
|
done()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('should add an inline plugin to the array', () => {
|
||||||
|
const testPlugin = {
|
||||||
|
id: 'test'
|
||||||
|
}
|
||||||
|
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
RadarChart
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { RadarChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins).to.exist
|
||||||
|
vm.$children[0].addPlugin(testPlugin)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should add inline plugins based on prop', () => {
|
||||||
|
const testPlugin = {
|
||||||
|
id: 'test'
|
||||||
|
}
|
||||||
|
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
RadarChart, {
|
||||||
|
props: {
|
||||||
|
plugins: [testPlugin]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { RadarChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins).to.exist
|
||||||
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
106
test/unit/specs/Scatter.spec.js
Normal file
@@ -0,0 +1,106 @@
|
|||||||
|
import Vue from 'vue'
|
||||||
|
import ScatterChart from '@/examples/ScatterExample'
|
||||||
|
|
||||||
|
describe('ScatterChart', () => {
|
||||||
|
let el
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
el = document.createElement('div')
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should render a canvas', () => {
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
ScatterChart
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { ScatterChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$el.querySelector('#scatter-chart')).not.to.be.an('undefined')
|
||||||
|
expect(vm.$el.querySelector('canvas')).not.to.be.an('undefined')
|
||||||
|
expect(vm.$el.querySelector('canvas')).not.to.be.an('null')
|
||||||
|
expect(vm.$el.querySelector('canvas')).to.exist
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should change id based on prop', () => {
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
ScatterChart, {
|
||||||
|
props: {
|
||||||
|
chartId: 'linechartprop'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { ScatterChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$el.querySelector('#linechartprop')).not.to.be.an('undefined')
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should destroy chart instance', (done) => {
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
ScatterChart
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { ScatterChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._chart.chart.ctx).not.to.be.null
|
||||||
|
|
||||||
|
vm.$destroy()
|
||||||
|
|
||||||
|
vm.$nextTick(() => {
|
||||||
|
vm.$forceUpdate()
|
||||||
|
expect(vm.$children[0].$data._chart.chart.ctx).to.be.null
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should add an inline plugin to the array', () => {
|
||||||
|
const testPlugin = {
|
||||||
|
id: 'test'
|
||||||
|
}
|
||||||
|
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
ScatterChart
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { ScatterChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins).to.exist
|
||||||
|
vm.$children[0].addPlugin(testPlugin)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should add inline plugins based on prop', () => {
|
||||||
|
const testPlugin = {
|
||||||
|
id: 'test'
|
||||||
|
}
|
||||||
|
|
||||||
|
const vm = new Vue({
|
||||||
|
render: function (createElement) {
|
||||||
|
return createElement(
|
||||||
|
ScatterChart, {
|
||||||
|
props: {
|
||||||
|
plugins: [testPlugin]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
|
},
|
||||||
|
components: { ScatterChart }
|
||||||
|
}).$mount(el)
|
||||||
|
|
||||||
|
expect(vm.$children[0].$data._plugins).to.exist
|
||||||
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
||||||
|
})
|
||||||
|
})
|
||||||
@@ -1,30 +0,0 @@
|
|||||||
import { mergeOptions } from 'src/helpers/options'
|
|
||||||
|
|
||||||
describe('mergeOptions.js', () => {
|
|
||||||
const a = {
|
|
||||||
a: 'a',
|
|
||||||
b: 'a'
|
|
||||||
}
|
|
||||||
|
|
||||||
const b = {
|
|
||||||
a: 'b',
|
|
||||||
b: 'b'
|
|
||||||
}
|
|
||||||
|
|
||||||
const c = {
|
|
||||||
c: 'c'
|
|
||||||
}
|
|
||||||
|
|
||||||
it('should replace old a and b if a and b are new', () => {
|
|
||||||
let 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', () => {
|
|
||||||
let ac = mergeOptions(a, c)
|
|
||||||
expect(ac).to.have.property('a').and.to.equal('a')
|
|
||||||
expect(ac).to.have.property('b').and.to.equal('a')
|
|
||||||
expect(ac).to.have.property('c').and.to.equal('c')
|
|
||||||
})
|
|
||||||
})
|
|
||||||