Compare commits

...

84 Commits

Author SHA1 Message Date
JiaMing
c1881757a8 update dist and lib folder 2019-10-24 14:12:52 +08:00
JiaMing
a02654a565 update version to 2.4.7 2019-10-24 14:12:09 +08:00
JiaMing
36f9c6f8ab update change log 2019-10-24 14:11:25 +08:00
JiaMing
0b270cda52 Optimize memory leaks 2019-10-24 14:09:32 +08:00
JiaMing
2ca217a8af Optimize memory leaks 2019-10-24 10:29:07 +08:00
JiaMing
656de3a8dd update dist 2019-10-24 10:28:43 +08:00
JiaMing
915c54072d update version to 2.4.6 2019-10-24 10:28:34 +08:00
JiaMing
a01fcef7e4 update change log 2019-10-24 10:28:21 +08:00
JiaMing
1f1b1cb75d Optimize memory leaks 2019-10-24 10:22:03 +08:00
JiaMing
9b2395adf0 update readme 2019-10-22 13:52:58 +08:00
JiaMing
8d0ca493c9 update readme 2019-10-22 13:52:13 +08:00
JiaMing
6aa2d38b40 update repo url 2019-10-22 13:42:38 +08:00
JiaMing
2eeac4f247 update license 2019-10-22 11:45:29 +08:00
JiaMing
6d90ba617b update readme 2019-10-22 11:44:56 +08:00
JiaMing
8ae4aa7c17 update issue template url 2019-10-22 11:43:15 +08:00
JiaMing
c89f1d427a update icon url 2019-10-22 11:38:17 +08:00
JM
a5366587bc update readme 2019-09-25 12:11:21 +08:00
JM
e777112621 update dist and lib 2019-09-24 16:34:08 +08:00
JM
d6f33bb7dc Mobile terser execution order 2019-09-24 16:33:14 +08:00
JM
ee1d0cddf9 Fix spelling errors 2019-09-24 16:30:14 +08:00
JM
a7aa6278c8 Compatible with a calculation result of 0 2019-09-24 16:29:51 +08:00
JM
e533c55536 update version to v2.4.5 2019-09-24 16:29:11 +08:00
JM
89ea2f81b7 update change log for v2.4.5 2019-09-24 16:28:58 +08:00
jiaming743
9562c97730 update readme 2019-09-10 15:32:42 +08:00
jiaming743
7ba058d623 update change log 2019-09-10 15:23:12 +08:00
jiaming743
a22166d868 perfect ref production 2019-09-10 15:14:12 +08:00
jiaming743
fbc32552f0 update umd file 2019-09-10 15:11:56 +08:00
jiaming743
8ad8298c6f add auto deploy process 2019-09-10 15:11:25 +08:00
jiaming743
5796c92fc6 update rollup config (terser compress) 2019-09-10 15:11:09 +08:00
jiaming743
3ebbac5de3 update auto build process 2019-09-10 15:10:36 +08:00
jiaming743
5c80a93f4d add umd example 2019-09-10 15:10:11 +08:00
jiaming743
79bae7bea4 update readme 2019-09-10 15:10:02 +08:00
jiaming743
7b9174302e update questionnaire qr code img 2019-09-10 15:09:52 +08:00
jiaming743
259f1e4b4c add terser to compress umd file 2019-09-10 15:08:35 +08:00
jiaming743
015f334212 update ignore 2019-09-10 14:57:59 +08:00
jiaming743
44dffdc216 Merge branch 'master' of https://github.com/jiaming743/DataV 2019-09-10 11:23:03 +08:00
jiaming743
60c5ecfeba update readme 2019-09-10 11:22:42 +08:00
JM
bcb78fec32 Merge pull request #14 from Xiaoleng123/master
🐛 修改组件 ID 时间戳的生成方式
2019-09-10 09:17:04 +08:00
Xiaoleng123
856e43dc09 🐛 修改组件 ID 时间戳的生成方式 2019-09-09 21:17:50 +08:00
jiaming743
b511e3d786 add Questionnaire link 2019-09-06 10:59:55 +08:00
jiaming743
c281e56d6d update dist and lib 2019-09-05 17:33:05 +08:00
jiaming743
ba35f1b252 update version to 2.4.4 2019-09-05 17:32:58 +08:00
jiaming743
6819fdead9 update changelog 2019-09-05 17:32:51 +08:00
jiaming743
6169d2ac90 Bug Fixes for v 2.4.4 2019-09-05 17:32:44 +08:00
jiaming743
786761f1ca update todo 2019-09-05 11:55:25 +08:00
jiaming743
529b0154db update dist 2019-09-04 11:24:03 +08:00
jiaming743
26a5c3cedd add unit configuration item 2019-09-04 11:23:59 +08:00
jiaming743
10824d0c88 update version to 2.4.3 2019-09-04 11:23:41 +08:00
jiaming743
c34c493eb4 update changelog 2019-09-04 11:23:29 +08:00
jiaming743
1708d58215 update readme 2019-09-04 09:04:33 +08:00
jiaming743
948d6e0672 update readme 2019-09-04 08:56:40 +08:00
jiaming743
0a82102ec6 update readme 2019-09-04 08:54:48 +08:00
jiaming743
1aa5979968 add note 2019-09-03 16:02:07 +08:00
jiaming743
ff964f6b72 remove useless folder 2019-09-03 11:12:47 +08:00
jiaming743
b2b83d9474 Add import suffix 2019-09-03 11:08:17 +08:00
jiaming743
a1d7d4626d update build process 2019-09-03 11:07:45 +08:00
jiaming743
170facb3fc update dependencies 2019-09-03 11:07:26 +08:00
jiaming743
5224e80321 add feedback group img 2019-09-02 18:49:58 +08:00
jiaming743
1c4fa02e45 update readme 2019-09-02 18:49:37 +08:00
jiaming743
70164efe70 add TODO 2019-09-02 14:17:07 +08:00
jiaming743
7c0992e19f update lib 2019-08-30 18:24:50 +08:00
jiaming743
66c9a542cf update version to 2.4.2 2019-08-30 18:23:44 +08:00
jiaming743
47c2652ab4 update template 2019-08-30 14:40:45 +08:00
jiaming743
2c78715ff5 github template 2019-08-30 14:38:59 +08:00
jiaming743
4f078d984b update change log 2019-08-30 12:54:58 +08:00
jiaming743
720fd878b1 Class name compatibility optimization 2019-08-30 12:54:10 +08:00
jiaming743
f64ed65d3a update demo img 2019-08-30 12:53:43 +08:00
jiaming743
50fa3099a7 update readme 2019-08-30 12:53:31 +08:00
jiaming743
54bc52c1bf update lib 2019-08-30 09:44:38 +08:00
jiaming743
24a0c8a9e8 update version to 2.4.1 2019-08-29 17:47:40 +08:00
jiaming743
7bac2c6760 update changelog for v 2.4.1 2019-08-29 17:47:35 +08:00
jiaming743
0f9b00b525 Adaptive display unit 2019-08-29 17:47:14 +08:00
jiaming743
5376f01e3c add new component (borderBox10, capsuleChart) 2019-08-29 16:50:55 +08:00
jiaming743
8d1e0064a7 update lib 2019-08-29 16:50:19 +08:00
jiaming743
6adcd9c6cb update readme 2019-08-29 16:49:17 +08:00
jiaming743
3464c6b254 update version to 2.4.0 2019-08-29 16:49:09 +08:00
jiaming743
bd88a27ddc update change log for v2.4.0 2019-08-29 16:49:00 +08:00
jiaming743
bc0bf58baf update readme 2019-08-27 18:42:33 +08:00
jiaming743
46c72a9a68 update readme 2019-08-27 18:40:06 +08:00
jiaming743
1c33d4d7b8 update readme 2019-08-27 18:38:18 +08:00
jiaming743
0d59ebcc04 update version to v 2.3.9 2019-08-27 18:34:02 +08:00
jiaming743
c47f6133f4 update readme and add demo img 2019-08-27 18:33:14 +08:00
jiaming743
f8870f763a update change log for v 2.3.9 2019-08-27 18:27:54 +08:00
jiaming743
9f00506e73 Compatibility enhancement 2019-08-27 11:30:28 +08:00
65 changed files with 21455 additions and 97 deletions

28
.github/ISSUE_TEMPLATE/bug_report.md vendored Normal file
View File

@@ -0,0 +1,28 @@
---
name: Bug report
about: 提交Bug反馈
---
<!-- 请确定这是一个Bug反馈而不是一个需求反馈或问题求助否则ISSUE可能被关闭 -->
<!-- 请提供可供复现Bug的必要条件否则ISSUE可能被关闭 -->
<!-- 创建Bug反馈前请确定你的DataV是最新版的 -->
## Bug report
#### 出现Bug的组件
#### 组件配置数据?
<!-- (config等props若无配置请忽略) -->
#### 控制台错误输出?
<!-- (若无错误输出请忽略) -->
#### 期望情况?
#### 实际情况?
#### 其他相关信息
- DataV版本
- 浏览器版本
- 其他

View File

@@ -0,0 +1,14 @@
---
name: Feature request
about: 新特性建议
---
<!-- 创建新特性建议前请确定你的DataV是最新版的 -->
## Feature request
#### 这个特性解决了什么问题?
#### 这个特性的实现形式?
#### 是否愿意为此特性提交PR

View File

@@ -0,0 +1,20 @@
---
name: Component request
about: 新组件建议
---
<!-- 创建新组件建议前请确定你的DataV是最新版的 -->
<!-- (将[ ]修改为[x]) -->
## Component request
#### 新组件的类型?
* [ ] 边框
* [ ] 装饰
* [ ] 图表
* [ ] 其他
#### 这个组件的功能描述 (边框及装饰类,请提供样图)
#### 是否愿意为此组件提交PR

33
.github/PULL_REQUEST_TEMPLATE.md vendored Normal file
View File

@@ -0,0 +1,33 @@
<!-- (将[ ]修改为[x]) -->
**该PR的类型是** (至少选择一个)
- [ ] Bug修复
- [ ] 新特性
- [ ] 新组件
**该PR是否向下兼容?** (选择任一)
- [ ]
- [ ]
如果为否,请描述冲突情况:
**涉及到的ISSUE:**
- [ ] 该PR如果涉及到某个ISSUE, 请在PR标题中描述出来 (例如. `fix #xxx[,#xxx]`, "xxx"为ISSUE序号)
**是否在Chrome浏览器下进行过测试**
- [ ]
- [ ]
如果这是一个**新特性**或**新组件**相关的PR请提供如下信息
- [ ] 添加该特性或组件的原因
- [ ] 文档应该修改哪些信息
- [ ] 测试相关
提交**新特性**或**新组件**前请先发起一个相关的ISSUE请求
**其他信息:**

1
.gitignore vendored
View File

@@ -1,6 +1,7 @@
.DS_Store .DS_Store
node_modules node_modules
package-lock.json package-lock.json
/deploy/config.js
# local env files # local env files
.env.local .env.local

View File

@@ -1,3 +1,59 @@
# 2.4.7-alpha (2019-10-24)
### perfect
- **charts:** Optimize memory leaks.
- **digitalFlop:** Optimize memory leaks.
# 2.4.6-alpha (2019-10-24)
### Bug Fixes
- **activeRingChart:** Optimize memory leaks [(#16)](https://github.com/jiaming743/DataV/issues/16),[(#20)](https://github.com/jiaming743/DataV/issues/20).
# 2.4.5-alpha (2019-09-24)
### Bug Fixes
- **activeRingChart:** Calculation exception due to data value being 0 [(#17)](https://github.com/jiaming743/DataV/issues/17).
# 2.4.4-alpha (2019-09-05)
### Bug Fixes
- **scrollBoard:** Header column width is abnormal when row data is empty.
# 2.4.3-alpha (2019-09-04)
### Perfect
- **scrollRankingBoard:** Add a unit configuration item.
# 2.4.2-alpha (2019-08-30)
### Perfect
- **capsuleChart:** Class name compatibility optimization.
# 2.4.1-alpha (2019-08-29)
### Perfect
- **capsuleChart:** Adaptive display unit.
# 2.4.0-alpha (2019-08-29)
### New
- **borderBox10**
- **capsuleChart**
# 2.3.9-alpha (2019-08-27)
### Perfect
- **percentPond:** Compatibility enhancement.
# 2.3.8-alpha (2019-08-27) # 2.3.8-alpha (2019-08-27)
### Bug Fixes ### Bug Fixes

View File

@@ -1,6 +1,6 @@
The MIT License (MIT) The MIT License (MIT)
Copyright (c) 2019-present, JiaMing Copyright (c) 2019-present, DataV-Team
Permission is hereby granted, free of charge, to any person obtaining a copy Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal of this software and associated documentation files (the "Software"), to deal

BIN
QQGroup.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 18 KiB

View File

@@ -1,10 +1,9 @@
[ENGLISH](./README_EN.md) [ENGLISH](./README_EN.md)
<h1 align="center">DataV</h1> <h1 align="center">DataV</h1>
<p align="center"> <p align="center">
<a href="https://github.com/jiaming743/datav/blob/master/LICENSE"> <a href="https://github.com/DataV-Team/datav/blob/master/LICENSE">
<img src="https://img.shields.io/github/license/jiaming743/datav.svg" alt="LICENSE" /> <img src="https://img.shields.io/github/license/DataV-Team/datav.svg" alt="LICENSE" />
</a> </a>
<a href="https://www.npmjs.com/package/@jiaminghi/data-view"> <a href="https://www.npmjs.com/package/@jiaminghi/data-view">
<img src="https://img.shields.io/npm/v/@jiaminghi/data-view.svg" alt="LICENSE" /> <img src="https://img.shields.io/npm/v/@jiaminghi/data-view.svg" alt="LICENSE" />
@@ -13,10 +12,10 @@
## DataV是干什么的? ## DataV是干什么的?
* DataV是一个基于**Vue**的数据可视化组件库. * DataV是一个基于**Vue**的数据可视化组件库(当然也有[React版本](https://github.com/DataV-Team/DataV-React)
* 提供用于提升页面视觉效果的**SVG**边框和装饰. * 提供用于提升页面视觉效果的**SVG**边框和装饰
* 提供常用的**图表**如折线图等. * 提供常用的**图表**如折线图等
* 飞线图/轮播表等其他组件. * 飞线图/轮播表等其他组件
### npm安装 ### npm安装
@@ -37,4 +36,45 @@ import { borderBox1 } from '@jiaminghi/data-view'
Vue.use(borderBox1) Vue.use(borderBox1)
``` ```
详细文档及示例请移步[HomePage](http://datav.jiaminghi.com). 详细文档及示例请移步[HomePage](http://datav.jiaminghi.com).
### UMD版
`UMD`版可直接使用`script`标签引入,`UMD`版文件位于项目`dist`目录下,引入后将自动把所有组件注册为**Vue全局组件**,引入`DataV`前请确保已引入`Vue`
[UMD版使用示例](./umdExample.html)
### 调研
关于React版本组件库及反馈请移步[问卷调查](https://www.wjx.cn/jq/45326197.aspx)
![问卷调查](./questionnaire.jpg)
### TODO
* **飞线图**添加多中心点及反向飞线功能
* **边框**及**装饰**添加颜色及其他必要配置项,增强可配置性及灵活性.
### 致谢
组件库的开发基于个人学习和兴趣由于技术水平及经验的限制组件尚有许多不完善之处如有BUG可及时提交[issue](https://github.com/DataV-Team/DataV/issues/new?template=bug_report.md)或添加反馈群进行反馈,也欢迎提供指正和建议,感谢各位的支持。
### 反馈
![Feedback](./QQGroup.png)
### Demo
Demo页面使用了全屏组件请F11全屏后查看。
* [施工养护综合数据](http://datav.jiaminghi.com/demo/construction-data/index.html)
![construction-data](./demoImg/construction-data.jpg)
* [机电运维管理台](http://datav.jiaminghi.com/demo/manage-desk/index.html)
![manage-desk](./demoImg/manage-desk.jpg)
* [机电设备电子档案](http://datav.jiaminghi.com/demo/electronic-file/index.html)
![electronic-file](./demoImg/electronic-file.jpg)

View File

@@ -3,8 +3,8 @@
<h1 align="center">DataV</h1> <h1 align="center">DataV</h1>
<p align="center"> <p align="center">
<a href="https://github.com/jiaming743/datav/blob/master/LICENSE"> <a href="https://github.com/DataV-Team/datav/blob/master/LICENSE">
<img src="https://img.shields.io/github/license/jiaming743/datav.svg" alt="LICENSE" /> <img src="https://img.shields.io/github/license/DataV-Team/datav.svg" alt="LICENSE" />
</a> </a>
<a href="https://www.npmjs.com/package/@jiaminghi/data-view"> <a href="https://www.npmjs.com/package/@jiaminghi/data-view">
<img src="https://img.shields.io/npm/v/@jiaminghi/data-view.svg" alt="LICENSE" /> <img src="https://img.shields.io/npm/v/@jiaminghi/data-view.svg" alt="LICENSE" />
@@ -13,7 +13,7 @@
## What is DataV? ## What is DataV?
* DataV is a data **visualization** components library based on **Vue**. * DataV is a data **visualization** components library based on **Vue**Of course there are also [React versions](https://github.com/DataV-Team/DataV-React).
* Provide cool **SVG** borders and decorations. * Provide cool **SVG** borders and decorations.
* Provide common **charts** such as line chart, etc.. * Provide common **charts** such as line chart, etc..
* flying line chart, carousel table and etc. * flying line chart, carousel table and etc.
@@ -37,4 +37,49 @@ import { borderBox1 } from '@jiaminghi/data-view'
Vue.use(borderBox1) Vue.use(borderBox1)
``` ```
Detailed documents and examples can be viewed on the [HomePage](http://datav.jiaminghi.com). Detailed documents and examples can be viewed on the [HomePage](http://datav.jiaminghi.com).
### UMD version
The `UMD` version can be directly imported using the `script` tag. The `UMD` version file is located in the project `dist` directory. After import, all components will be automatically registered as **Vue global components**. Be sure to introduce `Vue` before introducing `DataV`.
[UMD version usage example](./umdExample.html)
### React version
The reaction version is already under development, so stay tuned
### Questionnaire
React version of the component library and feedback[Questionnaire](https://www.wjx.cn/jq/45326197.aspx)
![问卷调查](./questionnaire.jpg)
### TODO
* **flylineChart**Add multi-center point and reverse fly line function.
* Add color and other necessary configuration to the **borderBox** and **decoration** to enhance configurability and flexibility.
### Acknowledgement
The development of the component library is based on personal learning and interest. Due to technical level and experience limitations, there are still many imperfections in the components. If there are errors, you can submit [issue](https://github.com/DataV-team/DataV/issues/new?template=bug_report.md) in time or add feedback groups for feedback. Welcome to provide corrections and suggestions. Thank you for your support.
### Feedback
![Feedback](./QQGroup.png)
### Demo
The Demo page uses the full-screen component, please view it after F11 full screen.
* [Construction Data](http://datav.jiaminghi.com/demo/construction-data/index.html)
![construction-data](./demoImg/construction-data.jpg)
* [Manage-Desk](http://datav.jiaminghi.com/demo/manage-desk/index.html)
![manage-desk](./demoImg/manage-desk.jpg)
* [Electronic-File](http://datav.jiaminghi.com/demo/electronic-file/index.html)
![electronic-file](./demoImg/electronic-file.jpg)

4
build/entry.js Normal file
View File

@@ -0,0 +1,4 @@
import Vue from 'vue'
import datav from '../src/index'
Vue.use(datav)

View File

@@ -1,14 +1,17 @@
const { copyDir, fileForEach, readFile, writeFile, unlinkDirFileByExtname, dirForEach } = require('@jiaminghi/fs') const { copyDir, fileForEach, readFile, writeFile, unlinkDirFileByExtname, dirForEach } = require('@jiaminghi/fs')
const print = require('./plugin/print') const print = require('./plugin/print')
const path = require('path') const path = require('path')
const doExec = require('./plugin/exec') const exec = require('./plugin/exec')
const PACKAGE_SRC = './src' const PACKAGE_SRC = './src'
const COMPILE_SRC = './lib' const COMPILE_SRC = './lib'
const COMPONENTS_DIR = '/components' const COMPONENTS_DIR = '/components'
const ENTRANCE = '/index.js' const ENTRANCE = '/index.js'
const libName = 'datav'
async function start () { async function start () {
// Compile for NPM
const copyPackage = await copyDir(PACKAGE_SRC, COMPILE_SRC) const copyPackage = await copyDir(PACKAGE_SRC, COMPILE_SRC)
if (!copyPackage) { if (!copyPackage) {
@@ -63,6 +66,27 @@ async function start () {
print.success('Finish adding components export statement!') print.success('Finish adding components export statement!')
// Compile for UMD version
const rollupCompile = await exec(`rollup -c build/rollup.config.js`)
if (!rollupCompile) {
print.error('Exception in rollupCompile')
return
}
print.tip('After rollupCompile')
const terser = await exec(`rollup -c build/rollup.terser.config.js`)
if (!terser) {
print.error('Exception in terser')
return
}
print.tip('After terser')
print.yellow('-------------------------------------') print.yellow('-------------------------------------')
print.success(' DataV Lib Compile Success! ') print.success(' DataV Lib Compile Success! ')
print.yellow('-------------------------------------') print.yellow('-------------------------------------')
@@ -122,7 +146,7 @@ async function compileLessToCss () {
maxBuffer: 1024 ** 5 maxBuffer: 1024 ** 5
}) })
const compile = await doExec(execString) const compile = await exec(execString)
if (!compile) { if (!compile) {
print.error(execString + ' Error!') print.error(execString + ' Error!')
@@ -180,6 +204,8 @@ async function addComponentsExport () {
return write return write
} }
module.exports = start async function compileUMDVersion () {
}
start()

22
build/rollup.config.js Normal file
View File

@@ -0,0 +1,22 @@
import resolve from 'rollup-plugin-node-resolve'
import vue from 'rollup-plugin-vue'
import commonjs from 'rollup-plugin-commonjs'
import babel from 'rollup-plugin-babel'
export default {
input: 'build/entry.js',
output: {
format: 'umd',
file: 'dist/datav.map.vue.js',
name: 'datav'
},
plugins: [
resolve(),
babel({
exclude: 'node_modules/**'
}),
commonjs(),
vue(),
],
external: ['Vue']
}

View File

@@ -0,0 +1,24 @@
import resolve from 'rollup-plugin-node-resolve'
import vue from 'rollup-plugin-vue'
import commonjs from 'rollup-plugin-commonjs'
import babel from 'rollup-plugin-babel'
import { terser } from "rollup-plugin-terser"
export default {
input: 'build/entry.js',
output: {
format: 'umd',
file: 'dist/datav.min.vue.js',
name: 'datav'
},
plugins: [
resolve(),
babel({
exclude: 'node_modules/**'
}),
commonjs(),
vue(),
terser(),
],
external: ['Vue']
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 99 KiB

BIN
demoImg/electronic-file.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 118 KiB

BIN
demoImg/manage-desk.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 101 KiB

81
deploy/index.js Normal file
View File

@@ -0,0 +1,81 @@
const { fileForEach } = require('@jiaminghi/fs')
const Client = require('ftp')
const print = require('./plugin/print')
const { emptyDir, put } = require('./plugin/ftp')
const getNodeParams = require('./plugin/nodeParams')
let config = null
try {
config = require('./config')
} catch (err) {
void 0
}
const DIST_PATH = './dist/'
const FTP_PATH = './datav/'
const ftp = new Client()
ftp.on('ready', async foo => {
print.tip('FTP connected!')
const isEmpty = await emptyDir(ftp, FTP_PATH)
if (!isEmpty) {
print.error('Exception in emptyDir!')
return false
}
let status = true
await fileForEach(DIST_PATH, async src => {
const destPath = FTP_PATH + src.split('/').slice(-1)[0]
print.tip('Upload: ' + destPath)
if (!await put(ftp, src, destPath)) {
status = false
print.error('Exception in upload ' + destPath)
}
})
if (status) {
print.yellow('-------------------------------------')
print.success(' Automatic Deployment Success! ')
print.yellow('-------------------------------------')
}
ftp.destroy()
})
ftp.on('greeting', foo => {
print.tip('FTP greeting')
})
ftp.on('close', foo => {
print.tip('FTP close')
})
ftp.on('end', foo => {
print.tip('FTP end')
})
ftp.on('error', foo => {
print.tip('FTP error')
})
const { host, user, pass } = config || getNodeParams()
if (!host || !user || !pass) {
print.error('Upload Dist to FTP Missing Parameters!')
return false
}
print.tip('Start Upload!')
ftp.connect({
host,
user,
password: pass
})

99
deploy/plugin/ftp.js Normal file
View File

@@ -0,0 +1,99 @@
async function getList (ftp, src) {
return new Promise(resolve => {
ftp.list(src, (err, list) => {
if (err) {
console.error(err)
resolve(false)
} else {
resolve(list)
}
})
})
}
async function rmDir (ftp, src, recusive = true) {
return new Promise(resolve => {
ftp.rmdir(src, recusive, err => {
if (err) {
console.error(err)
resolve(false)
} else {
resolve(true)
}
})
})
}
async function deleteFile (ftp, src) {
return new Promise(resolve => {
ftp.delete(src, err => {
if (err) {
console.error(err)
resolve(false)
} else {
resolve(true)
}
})
})
}
async function emptyDir (ftp, src, except = []) {
const list = await getList(ftp, src)
for (let i = 0, listNum = list.length; i < listNum; i++) {
const { type, name } = list[i]
if (type === 'd' && (name === '.' || name === '..')) continue
if (except.find(n => n === name)) continue
const fullSrc = `${src}${name}`
if (type === 'd') {
if (!await rmDir(ftp, fullSrc, true)) return false
} else {
if (!await deleteFile(ftp, fullSrc)) return false
}
}
return true
}
async function put (ftp, src, dest) {
return new Promise(resolve => {
ftp.put(src, dest, err => {
if (err) {
console.error(err)
resolve(false)
} else {
resolve(true)
}
})
})
}
async function mkDir (ftp, src, recusive = true) {
return new Promise(resolve => {
ftp.mkdir(src, recusive, err => {
if (err) {
console.error(err)
resolve(false)
} else {
resolve(true)
}
})
})
}
module.exports = {
put,
rmDir,
mkDir,
getList,
emptyDir,
deleteFile
}

View File

@@ -0,0 +1,13 @@
function getNodeParams () {
const params = {}
process.argv.slice(2).forEach(param => {
param = param.split('=')
params[param[0]] = param[1]
})
return params
}
module.exports = getNodeParams

22
deploy/plugin/print.js Normal file
View File

@@ -0,0 +1,22 @@
const print = {
log (info) {
console.log(info)
},
warn (info) {
console.log('\033[31;33m' + info + '\033[0m')
},
error (info) {
console.log('\033[31;40m' + info + '\033[0m')
},
tip (info) {
console.log('\033[40;32m' + info + '\033[0m')
},
success (info) {
console.log('\033[42;30m' + info + '\033[0m')
},
yellow (info) {
console.log('\033[31;33m' + info + '\033[0m')
}
}
module.exports = print

20224
dist/datav.map.vue.js vendored Normal file

File diff suppressed because one or more lines are too long

1
dist/datav.min.vue.js vendored Normal file

File diff suppressed because one or more lines are too long

View File

@@ -11,7 +11,7 @@
<script> <script>
import Charts from '@jiaminghi/charts' import Charts from '@jiaminghi/charts'
import dvDigitalFlop from '../../digitalFlop/src/main' import dvDigitalFlop from '../../digitalFlop/src/main.vue'
import { deepMerge } from '@jiaminghi/charts/lib/util/index' import { deepMerge } from '@jiaminghi/charts/lib/util/index'
@@ -113,7 +113,7 @@ export default {
const sum = value.reduce((all, v) => all + v, 0) const sum = value.reduce((all, v) => all + v, 0)
const percent = parseInt(value[activeIndex] / sum * 100) const percent = parseInt(value[activeIndex] / sum * 100) || 0
return { return {
content: '{nt}%', content: '{nt}%',
@@ -174,7 +174,7 @@ export default {
const option = getRingOption() const option = getRingOption()
chart.setOption(option) chart.setOption(option, true)
ringAnimation() ringAnimation()
}, },
@@ -236,7 +236,7 @@ export default {
} }
}) })
chart.setOption(option) chart.setOption(option, true)
const { activeTimeGap } = option.series[0] const { activeTimeGap } = option.series[0]

View File

@@ -0,0 +1,6 @@
import './src/main.css'
import BorderBox10 from './src/main.vue'
export default function (Vue) {
Vue.component(BorderBox10.name, BorderBox10)
}

View File

@@ -0,0 +1,29 @@
.dv-border-box-10 {
position: relative;
width: 100%;
height: 100%;
box-shadow: inset 0 0 25px 3px #1d48c4;
border-radius: 6px;
}
.dv-border-box-10 .border {
position: absolute;
display: block;
}
.dv-border-box-10 .right-top {
right: 0px;
transform: rotateY(180deg);
}
.dv-border-box-10 .left-bottom {
bottom: 0px;
transform: rotateX(180deg);
}
.dv-border-box-10 .right-bottom {
right: 0px;
bottom: 0px;
transform: rotateX(180deg) rotateY(180deg);
}
.dv-border-box-10 .border-box-content {
position: relative;
width: 100%;
height: 100%;
}

View File

@@ -0,0 +1,31 @@
<template>
<div class="dv-border-box-10">
<svg
width="150px"
height="150px"
:key="item"
v-for="item in border"
:class="`${item} border`"
>
<polygon
fill="#d3e1f8"
points="40, 0 5, 0 0, 5 0, 16 3, 19 3, 7 7, 3 35, 3"
/>
</svg>
<div class="border-box-content">
<slot></slot>
</div>
</div>
</template>
<script>
export default {
name: 'DvBorderBox10',
data () {
return {
border: ['left-top', 'right-top', 'left-bottom', 'right-bottom']
}
}
}
</script>

View File

@@ -68,11 +68,12 @@ export default {
name: 'DvBorderBox8', name: 'DvBorderBox8',
mixins: [autoResize], mixins: [autoResize],
data () { data () {
const timestamp = Date.now()
return { return {
ref: 'border-box-8', ref: 'border-box-8',
path: `border-box-8-path-${(new Date()).getTime()}`, path: `border-box-8-path-${timestamp}`,
gradient: `border-box-8-gradient-${(new Date()).getTime()}`, gradient: `border-box-8-gradient-${timestamp}`,
mask: `border-box-8-mask-${(new Date()).getTime()}` mask: `border-box-8-mask-${timestamp}`
} }
}, },
computed: { computed: {

View File

@@ -89,11 +89,12 @@ export default {
name: 'DvBorderBox9', name: 'DvBorderBox9',
mixins: [autoResize], mixins: [autoResize],
data () { data () {
const timestamp = Date.now()
return { return {
ref: 'border-box-9', ref: 'border-box-9',
gradientId: `border-box-9-gradient-${(new Date()).getTime()}`, gradientId: `border-box-9-gradient-${timestamp}`,
maskId: `border-box-9-mask-${(new Date()).getTime()}` maskId: `border-box-9-mask-${timestamp}`
} }
} }
} }

View File

@@ -0,0 +1,6 @@
import './src/main.css'
import CapsuleChart from './src/main.vue'
export default function (Vue) {
Vue.component(CapsuleChart.name, CapsuleChart)
}

View File

@@ -0,0 +1,55 @@
.dv-capsule-chart {
position: relative;
display: flex;
flex-direction: row;
box-sizing: border-box;
padding: 10px;
color: #fff;
}
.dv-capsule-chart .label-column {
display: flex;
flex-direction: column;
justify-content: space-between;
box-sizing: border-box;
padding-right: 10px;
text-align: right;
font-size: 12px;
}
.dv-capsule-chart .label-column div {
height: 20px;
line-height: 20px;
}
.dv-capsule-chart .capsule-container {
flex: 1;
display: flex;
flex-direction: column;
justify-content: space-between;
}
.dv-capsule-chart .capsule-item {
box-shadow: 0 0 3px #999;
height: 10px;
margin: 5px 0px;
border-radius: 5px;
}
.dv-capsule-chart .capsule-item div {
height: 8px;
margin-top: 1px;
border-radius: 5px;
transition: all 0.3s;
}
.dv-capsule-chart .unit-label {
height: 20px;
font-size: 12px;
display: flex;
flex-direction: row;
align-items: center;
justify-content: space-between;
}
.dv-capsule-chart .unit-text {
text-align: right;
display: flex;
align-items: flex-end;
font-size: 12px;
line-height: 20px;
margin-left: 10px;
}

View File

@@ -0,0 +1,114 @@
<template>
<div class="dv-capsule-chart">
<template v-if="mergedConfig">
<div class="label-column">
<div v-for="item in mergedConfig.data" :key="item.name">{{ item.name }}</div>
<div>&nbsp;</div>
</div>
<div class="capsule-container">
<div
class="capsule-item"
v-for="(capsule, index) in capsuleLength"
:key="index"
>
<div :style="`width: ${capsule * 100}%; background-color: ${mergedConfig.colors[index % mergedConfig.colors.length]};`"></div>
</div>
<div class="unit-label">
<div v-for="(label, index) in labelData" :key="label + index">{{ label }}</div>
</div>
</div>
<div class="unit-text" v-if="mergedConfig.unit">{{ mergedConfig.unit }}</div>
</template>
</div>
</template>
<script>
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default {
name: 'DvCapsuleChart',
props: {
config: {
type: Object,
default: () => ({})
}
},
data () {
return {
defaultConfig: {
/**
* @description Capsule chart data
* @type {Array<Object>}
* @default data = []
* @example data = [{ name: 'foo1', value: 100 }, { name: 'foo2', value: 100 }]
*/
data: [],
/**
* @description Colors (hex|rgb|rgba|color keywords)
* @type {Array<String>}
* @default color = ['#37a2da', '#32c5e9', '#67e0e3', '#9fe6b8', '#ffdb5c', '#ff9f7f', '#fb7293']
* @example color = ['#000', 'rgb(0, 0, 0)', 'rgba(0, 0, 0, 1)', 'red']
*/
colors: ['#37a2da', '#32c5e9', '#67e0e3', '#9fe6b8', '#ffdb5c', '#ff9f7f', '#fb7293'],
/**
* @description Chart unit
* @type {String}
* @default unit = ''
*/
unit: ''
},
mergedConfig: null,
capsuleLength: [],
labelData: []
}
},
watch: {
config () {
const { calcData } = this
calcData()
}
},
methods: {
calcData () {
const { mergeConfig, calcCapsuleLengthAndLabelData } = this
mergeConfig()
calcCapsuleLengthAndLabelData()
},
mergeConfig () {
let { config, defaultConfig } = this
this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {})
},
calcCapsuleLengthAndLabelData () {
const { data } = this.mergedConfig
if (!data.length) return
const capsuleValue = data.map(({ value }) => value)
const maxValue = Math.max(...capsuleValue)
this.capsuleLength = capsuleValue.map(v => maxValue ? v / maxValue : 0)
const oneFifth = maxValue / 5
this.labelData = new Array(6).fill(0).map((v, i) => Math.ceil(i * oneFifth))
}
},
mounted () {
const { calcData } = this
calcData()
}
}
</script>

View File

@@ -19,9 +19,10 @@ export default {
} }
}, },
data () { data () {
const timestamp = Date.now()
return { return {
ref: `charts-container-${(new Date()).getTime()}`, ref: `charts-container-${timestamp}`,
chartRef: `chart-${(new Date()).getTime()}`, chartRef: `chart-${timestamp}`,
chart: null chart: null
} }
@@ -34,7 +35,7 @@ export default {
if (!option) option = {} if (!option) option = {}
chart.setOption(option) chart.setOption(option, true)
} }
}, },
methods: { methods: {

View File

@@ -152,16 +152,17 @@ export default {
name: 'DvDecoration10', name: 'DvDecoration10',
mixins: [autoResize], mixins: [autoResize],
data () { data () {
const timestamp = Date.now()
return { return {
ref: 'decoration-10', ref: 'decoration-10',
animationId1: `d10ani1${(new Date()).getTime()}`, animationId1: `d10ani1${timestamp}`,
animationId2: `d10ani2${(new Date()).getTime()}`, animationId2: `d10ani2${timestamp}`,
animationId3: `d10ani3${(new Date()).getTime()}`, animationId3: `d10ani3${timestamp}`,
animationId4: `d10ani4${(new Date()).getTime()}`, animationId4: `d10ani4${timestamp}`,
animationId5: `d10ani5${(new Date()).getTime()}`, animationId5: `d10ani5${timestamp}`,
animationId6: `d10ani6${(new Date()).getTime()}`, animationId6: `d10ani6${timestamp}`,
animationId7: `d10ani7${(new Date()).getTime()}` animationId7: `d10ani7${timestamp}`
} }
} }
} }

View File

@@ -90,10 +90,11 @@ export default {
name: 'DvDecoration9', name: 'DvDecoration9',
mixins: [autoResize], mixins: [autoResize],
data () { data () {
const timestamp = Date.now()
return { return {
ref: 'decoration-9', ref: 'decoration-9',
polygonId: `decoration-9-polygon-${(new Date()).getTime()}`, polygonId: `decoration-9-polygon-${timestamp}`,
svgWH: [100, 100], svgWH: [100, 100],

View File

@@ -165,6 +165,8 @@ export default {
graph.animationCurve = animationCurve graph.animationCurve = animationCurve
graph.animationFrame = animationFrame graph.animationFrame = animationFrame
graph.animationEnd()
graph.animation('style', style, true) graph.animation('style', style, true)
graph.animation('shape', shape) graph.animation('shape', shape)
}, },

View File

@@ -171,13 +171,14 @@ export default {
} }
}, },
data () { data () {
const timestamp = Date.now()
return { return {
ref: 'dv-flyline-chart', ref: 'dv-flyline-chart',
unique: Math.random(), unique: Math.random(),
maskId: `flyline-mask-id-${(new Date()).getTime()}`, maskId: `flyline-mask-id-${timestamp}`,
maskCircleId: `mask-circle-id-${(new Date()).getTime()}`, maskCircleId: `mask-circle-id-${timestamp}`,
gradientId: `gradient-id-${(new Date()).getTime()}`, gradientId: `gradient-id-${timestamp}`,
gradient2Id: `gradient2-id-${(new Date()).getTime()}`, gradient2Id: `gradient2-id-${timestamp}`,
defaultConfig: { defaultConfig: {
/** /**

View File

@@ -22,8 +22,8 @@
fill="transparent" fill="transparent"
:stroke-width="mergedConfig ? mergedConfig.borderWidth : '0'" :stroke-width="mergedConfig ? mergedConfig.borderWidth : '0'"
:stroke="`url(#${gradientId1})`" :stroke="`url(#${gradientId1})`"
:width="rectWidth" :width="rectWidth > 0 ? rectWidth : 0"
:height="rectHeight" :height="rectHeight > 0 ? rectHeight : 0"
/> />
<polyline <polyline
:stroke-width="polylineWidth" :stroke-width="polylineWidth"
@@ -57,9 +57,10 @@ export default {
} }
}, },
data () { data () {
const timestamp = Date.now()
return { return {
gradientId1: `percent-pond-gradientId1-${(new Date()).getTime()}`, gradientId1: `percent-pond-gradientId1-${timestamp}`,
gradientId2: `percent-pond-gradientId2-${(new Date()).getTime()}`, gradientId2: `percent-pond-gradientId2-${timestamp}`,
width: 0, width: 0,
height: 0, height: 0,
@@ -239,7 +240,7 @@ export default {
this.height = dom.clientHeight this.height = dom.clientHeight
}, },
mergeConfig () { mergeConfig () {
let { config, defaultConfig } = this const { config, defaultConfig } = this
this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {}) this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {})
} }

View File

@@ -236,7 +236,7 @@ export default {
data = data.map((row, i) => { data = data.map((row, i) => {
row = [...row] row = [...row]
const indexTag = `<span class="index" style="background-color: ${headerBGC};">${i + 1}</spand>` const indexTag = `<span class="index" style="background-color: ${headerBGC};">${i + 1}</span>`
row.unshift(indexTag) row.unshift(indexTag)
@@ -260,11 +260,16 @@ export default {
calcWidths () { calcWidths () {
const { width, mergedConfig, rowsData } = this const { width, mergedConfig, rowsData } = this
const { columnWidth } = mergedConfig const { columnWidth, header } = mergedConfig
const usedWidth = columnWidth.reduce((all, w) => all + w, 0) const usedWidth = columnWidth.reduce((all, w) => all + w, 0)
const columnNum = rowsData[0] ? rowsData[0].ceils.length : 0 let columnNum = 0
if (rowsData[0]) {
columnNum = rowsData[0].ceils.length
} else if (header.length) {
columnNum = header.length
}
const avgWidth = (width - usedWidth) / (columnNum - columnWidth.length) const avgWidth = (width - usedWidth) / (columnNum - columnWidth.length)

View File

@@ -9,7 +9,7 @@
<div class="ranking-info"> <div class="ranking-info">
<div class="rank">No.{{ item.ranking }}</div> <div class="rank">No.{{ item.ranking }}</div>
<div class="info-name">{{ item.name }}</div> <div class="info-name">{{ item.name }}</div>
<div class="ranking-value">{{ item.value }}</div> <div class="ranking-value">{{ item.value + mergedConfig.unit }}</div>
</div> </div>
<div class="ranking-column"> <div class="ranking-column">
@@ -69,7 +69,14 @@ export default {
* @default carousel = 'single' * @default carousel = 'single'
* @example carousel = 'single' | 'page' * @example carousel = 'single' | 'page'
*/ */
carousel: 'single' carousel: 'single',
/**
* @description Value unit
* @type {String}
* @default unit = ''
* @example unit = 'ton'
*/
unit: ''
}, },
mergedConfig: null, mergedConfig: null,

View File

@@ -53,8 +53,9 @@ export default {
default: () => ({}) default: () => ({})
}, },
data () { data () {
const timestamp = Date.now()
return { return {
gradientId: `water-level-pond-${(new Date()).getTime()}`, gradientId: `water-level-pond-${timestamp}`,
defaultConfig: { defaultConfig: {
/** /**

View File

@@ -3,6 +3,7 @@
*/ */
export { default as activeRingChart } from './components/activeRingChart/index' export { default as activeRingChart } from './components/activeRingChart/index'
export { default as borderBox1 } from './components/borderBox1/index' export { default as borderBox1 } from './components/borderBox1/index'
export { default as borderBox10 } from './components/borderBox10/index'
export { default as borderBox2 } from './components/borderBox2/index' export { default as borderBox2 } from './components/borderBox2/index'
export { default as borderBox3 } from './components/borderBox3/index' export { default as borderBox3 } from './components/borderBox3/index'
export { default as borderBox4 } from './components/borderBox4/index' export { default as borderBox4 } from './components/borderBox4/index'
@@ -11,6 +12,7 @@ export { default as borderBox6 } from './components/borderBox6/index'
export { default as borderBox7 } from './components/borderBox7/index' export { default as borderBox7 } from './components/borderBox7/index'
export { default as borderBox8 } from './components/borderBox8/index' export { default as borderBox8 } from './components/borderBox8/index'
export { default as borderBox9 } from './components/borderBox9/index' export { default as borderBox9 } from './components/borderBox9/index'
export { default as capsuleChart } from './components/capsuleChart/index'
export { default as charts } from './components/charts/index' export { default as charts } from './components/charts/index'
export { default as conicalColumnChart } from './components/conicalColumnChart/index' export { default as conicalColumnChart } from './components/conicalColumnChart/index'
export { default as decoration1 } from './components/decoration1/index' export { default as decoration1 } from './components/decoration1/index'
@@ -47,6 +49,7 @@ import borderBox6 from './components/borderBox6/index'
import borderBox7 from './components/borderBox7/index' import borderBox7 from './components/borderBox7/index'
import borderBox8 from './components/borderBox8/index' import borderBox8 from './components/borderBox8/index'
import borderBox9 from './components/borderBox9/index' import borderBox9 from './components/borderBox9/index'
import borderBox10 from './components/borderBox10/index'
// decoration // decoration
import decoration1 from './components/decoration1/index' import decoration1 from './components/decoration1/index'
@@ -64,6 +67,7 @@ import decoration10 from './components/decoration10/index'
import charts from './components/charts/index' import charts from './components/charts/index'
import activeRingChart from './components/activeRingChart' import activeRingChart from './components/activeRingChart'
import capsuleChart from './components/capsuleChart'
import waterLevelPond from './components/waterLevelPond/index' import waterLevelPond from './components/waterLevelPond/index'
import percentPond from './components/percentPond/index' import percentPond from './components/percentPond/index'
import flylineChart from './components/flylineChart' import flylineChart from './components/flylineChart'
@@ -89,6 +93,7 @@ export default function (Vue) {
Vue.use(borderBox7) Vue.use(borderBox7)
Vue.use(borderBox8) Vue.use(borderBox8)
Vue.use(borderBox9) Vue.use(borderBox9)
Vue.use(borderBox10)
// decoration // decoration
Vue.use(decoration1) Vue.use(decoration1)
@@ -106,6 +111,7 @@ export default function (Vue) {
Vue.use(charts) Vue.use(charts)
Vue.use(activeRingChart) Vue.use(activeRingChart)
Vue.use(capsuleChart)
Vue.use(waterLevelPond) Vue.use(waterLevelPond)
Vue.use(percentPond) Vue.use(percentPond)
Vue.use(flylineChart) Vue.use(flylineChart)

View File

@@ -1,21 +1,22 @@
{ {
"name": "@jiaminghi/data-view", "name": "@jiaminghi/data-view",
"version": "2.3.8", "version": "2.4.7",
"author": "JiaMing <743192023@qq.com>", "author": "JiaMing <743192023@qq.com>",
"description": "Vue Large screen data display component library", "description": "Vue Large screen data display component library",
"main": "lib/index.js", "main": "lib/index.js",
"repository": { "repository": {
"type": "git", "type": "git",
"url": "https://github.com/jiaming743/DataV.git" "url": "https://github.com/DataV-Team/DataV.git"
}, },
"scripts": { "scripts": {
"compile": "node publish.js", "build": "node build/index.js",
"prepublish": "npm run compile", "prepublish": "npm run build",
"deploy": "node deploy/index.js",
"test": "echo \"Error: no test specified\" && exit 1" "test": "echo \"Error: no test specified\" && exit 1"
}, },
"license": "MIT", "license": "MIT",
"bugs": { "bugs": {
"url": "https://github.com/jiaming743/DataV/issues" "url": "https://github.com/DataV-Team/DataV/issues"
}, },
"keywords": [ "keywords": [
"vue", "vue",
@@ -24,10 +25,22 @@
"datavisual" "datavisual"
], ],
"dependencies": { "dependencies": {
"@jiaminghi/charts": "*" "@jiaminghi/charts": "*",
"@babel/runtime": "^7.5.5"
}, },
"homepage": "https://github.com/jiaming743/DataV#readme", "homepage": "https://github.com/DataV-Team/DataV#readme",
"devDependencies": { "devDependencies": {
"@jiaminghi/fs": "0.0.1" "@babel/cli": "^7.4.4",
"@babel/core": "^7.4.5",
"@babel/plugin-transform-runtime": "^7.5.5",
"@babel/preset-env": "^7.5.5",
"@jiaminghi/fs": "0.0.1",
"ftp": "^0.3.10",
"rollup-plugin-babel": "^4.3.3",
"rollup-plugin-commonjs": "^10.1.0",
"rollup-plugin-node-resolve": "^5.2.0",
"rollup-plugin-terser": "^5.1.1",
"rollup-plugin-vue": "^5.0.1",
"vue-template-compiler": "^2.6.10"
} }
} }

View File

@@ -1,3 +0,0 @@
const start = require('./publish/index')
start()

BIN
questionnaire.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.6 KiB

View File

@@ -11,7 +11,7 @@
<script> <script>
import Charts from '@jiaminghi/charts' import Charts from '@jiaminghi/charts'
import dvDigitalFlop from '../../digitalFlop/src/main' import dvDigitalFlop from '../../digitalFlop/src/main.vue'
import { deepMerge } from '@jiaminghi/charts/lib/util/index' import { deepMerge } from '@jiaminghi/charts/lib/util/index'
@@ -113,7 +113,7 @@ export default {
const sum = value.reduce((all, v) => all + v, 0) const sum = value.reduce((all, v) => all + v, 0)
const percent = parseInt(value[activeIndex] / sum * 100) const percent = parseInt(value[activeIndex] / sum * 100) || 0
return { return {
content: '{nt}%', content: '{nt}%',
@@ -174,7 +174,7 @@ export default {
const option = getRingOption() const option = getRingOption()
chart.setOption(option) chart.setOption(option, true)
ringAnimation() ringAnimation()
}, },
@@ -236,7 +236,7 @@ export default {
} }
}) })
chart.setOption(option) chart.setOption(option, true)
const { activeTimeGap } = option.series[0] const { activeTimeGap } = option.series[0]

View File

@@ -0,0 +1,5 @@
import BorderBox10 from './src/main.vue'
export default function (Vue) {
Vue.component(BorderBox10.name, BorderBox10)
}

View File

@@ -0,0 +1,68 @@
<template>
<div class="dv-border-box-10">
<svg
width="150px"
height="150px"
:key="item"
v-for="item in border"
:class="`${item} border`"
>
<polygon
fill="#d3e1f8"
points="40, 0 5, 0 0, 5 0, 16 3, 19 3, 7 7, 3 35, 3"
/>
</svg>
<div class="border-box-content">
<slot></slot>
</div>
</div>
</template>
<script>
export default {
name: 'DvBorderBox10',
data () {
return {
border: ['left-top', 'right-top', 'left-bottom', 'right-bottom']
}
}
}
</script>
<style lang="less">
.dv-border-box-10 {
position: relative;
width: 100%;
height: 100%;
box-shadow: inset 0 0 25px 3px #1d48c4;
border-radius: 6px;
.border {
position: absolute;
display: block;
}
.right-top {
right: 0px;
transform: rotateY(180deg);
}
.left-bottom {
bottom: 0px;
transform: rotateX(180deg);
}
.right-bottom {
right: 0px;
bottom: 0px;
transform: rotateX(180deg) rotateY(180deg);
}
.border-box-content {
position: relative;
width: 100%;
height: 100%;
}
}
</style>

View File

@@ -68,11 +68,12 @@ export default {
name: 'DvBorderBox8', name: 'DvBorderBox8',
mixins: [autoResize], mixins: [autoResize],
data () { data () {
const timestamp = Date.now()
return { return {
ref: 'border-box-8', ref: 'border-box-8',
path: `border-box-8-path-${(new Date()).getTime()}`, path: `border-box-8-path-${timestamp}`,
gradient: `border-box-8-gradient-${(new Date()).getTime()}`, gradient: `border-box-8-gradient-${timestamp}`,
mask: `border-box-8-mask-${(new Date()).getTime()}` mask: `border-box-8-mask-${timestamp}`
} }
}, },
computed: { computed: {

View File

@@ -89,11 +89,12 @@ export default {
name: 'DvBorderBox9', name: 'DvBorderBox9',
mixins: [autoResize], mixins: [autoResize],
data () { data () {
const timestamp = Date.now()
return { return {
ref: 'border-box-9', ref: 'border-box-9',
gradientId: `border-box-9-gradient-${(new Date()).getTime()}`, gradientId: `border-box-9-gradient-${timestamp}`,
maskId: `border-box-9-mask-${(new Date()).getTime()}` maskId: `border-box-9-mask-${timestamp}`
} }
} }
} }

View File

@@ -0,0 +1,5 @@
import CapsuleChart from './src/main.vue'
export default function (Vue) {
Vue.component(CapsuleChart.name, CapsuleChart)
}

View File

@@ -0,0 +1,179 @@
<template>
<div class="dv-capsule-chart">
<template v-if="mergedConfig">
<div class="label-column">
<div v-for="item in mergedConfig.data" :key="item.name">{{ item.name }}</div>
<div>&nbsp;</div>
</div>
<div class="capsule-container">
<div
class="capsule-item"
v-for="(capsule, index) in capsuleLength"
:key="index"
>
<div :style="`width: ${capsule * 100}%; background-color: ${mergedConfig.colors[index % mergedConfig.colors.length]};`"></div>
</div>
<div class="unit-label">
<div v-for="(label, index) in labelData" :key="label + index">{{ label }}</div>
</div>
</div>
<div class="unit-text" v-if="mergedConfig.unit">{{ mergedConfig.unit }}</div>
</template>
</div>
</template>
<script>
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default {
name: 'DvCapsuleChart',
props: {
config: {
type: Object,
default: () => ({})
}
},
data () {
return {
defaultConfig: {
/**
* @description Capsule chart data
* @type {Array<Object>}
* @default data = []
* @example data = [{ name: 'foo1', value: 100 }, { name: 'foo2', value: 100 }]
*/
data: [],
/**
* @description Colors (hex|rgb|rgba|color keywords)
* @type {Array<String>}
* @default color = ['#37a2da', '#32c5e9', '#67e0e3', '#9fe6b8', '#ffdb5c', '#ff9f7f', '#fb7293']
* @example color = ['#000', 'rgb(0, 0, 0)', 'rgba(0, 0, 0, 1)', 'red']
*/
colors: ['#37a2da', '#32c5e9', '#67e0e3', '#9fe6b8', '#ffdb5c', '#ff9f7f', '#fb7293'],
/**
* @description Chart unit
* @type {String}
* @default unit = ''
*/
unit: ''
},
mergedConfig: null,
capsuleLength: [],
labelData: []
}
},
watch: {
config () {
const { calcData } = this
calcData()
}
},
methods: {
calcData () {
const { mergeConfig, calcCapsuleLengthAndLabelData } = this
mergeConfig()
calcCapsuleLengthAndLabelData()
},
mergeConfig () {
let { config, defaultConfig } = this
this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {})
},
calcCapsuleLengthAndLabelData () {
const { data } = this.mergedConfig
if (!data.length) return
const capsuleValue = data.map(({ value }) => value)
const maxValue = Math.max(...capsuleValue)
this.capsuleLength = capsuleValue.map(v => maxValue ? v / maxValue : 0)
const oneFifth = maxValue / 5
this.labelData = new Array(6).fill(0).map((v, i) => Math.ceil(i * oneFifth))
}
},
mounted () {
const { calcData } = this
calcData()
}
}
</script>
<style lang="less">
.dv-capsule-chart {
position: relative;
display: flex;
flex-direction: row;
box-sizing: border-box;
padding: 10px;
color: #fff;
.label-column {
display: flex;
flex-direction: column;
justify-content: space-between;
box-sizing: border-box;
padding-right: 10px;
text-align: right;
font-size: 12px;
div {
height: 20px;
line-height: 20px;
}
}
.capsule-container {
flex: 1;
display: flex;
flex-direction: column;
justify-content: space-between;
}
.capsule-item {
box-shadow: 0 0 3px #999;
height: 10px;
margin: 5px 0px;
border-radius: 5px;
div {
height: 8px;
margin-top: 1px;
border-radius: 5px;
transition: all 0.3s;
}
}
.unit-label {
height: 20px;
font-size: 12px;
display: flex;
flex-direction: row;
align-items: center;
justify-content: space-between;
}
.unit-text {
text-align: right;
display: flex;
align-items: flex-end;
font-size: 12px;
line-height: 20px;
margin-left: 10px;
}
}
</style>

View File

@@ -19,9 +19,10 @@ export default {
} }
}, },
data () { data () {
const timestamp = Date.now()
return { return {
ref: `charts-container-${(new Date()).getTime()}`, ref: `charts-container-${timestamp}`,
chartRef: `chart-${(new Date()).getTime()}`, chartRef: `chart-${timestamp}`,
chart: null chart: null
} }
@@ -34,7 +35,7 @@ export default {
if (!option) option = {} if (!option) option = {}
chart.setOption(option) chart.setOption(option, true)
} }
}, },
methods: { methods: {

View File

@@ -152,16 +152,17 @@ export default {
name: 'DvDecoration10', name: 'DvDecoration10',
mixins: [autoResize], mixins: [autoResize],
data () { data () {
const timestamp = Date.now()
return { return {
ref: 'decoration-10', ref: 'decoration-10',
animationId1: `d10ani1${(new Date()).getTime()}`, animationId1: `d10ani1${timestamp}`,
animationId2: `d10ani2${(new Date()).getTime()}`, animationId2: `d10ani2${timestamp}`,
animationId3: `d10ani3${(new Date()).getTime()}`, animationId3: `d10ani3${timestamp}`,
animationId4: `d10ani4${(new Date()).getTime()}`, animationId4: `d10ani4${timestamp}`,
animationId5: `d10ani5${(new Date()).getTime()}`, animationId5: `d10ani5${timestamp}`,
animationId6: `d10ani6${(new Date()).getTime()}`, animationId6: `d10ani6${timestamp}`,
animationId7: `d10ani7${(new Date()).getTime()}` animationId7: `d10ani7${timestamp}`
} }
} }
} }

View File

@@ -90,10 +90,11 @@ export default {
name: 'DvDecoration9', name: 'DvDecoration9',
mixins: [autoResize], mixins: [autoResize],
data () { data () {
const timestamp = Date.now()
return { return {
ref: 'decoration-9', ref: 'decoration-9',
polygonId: `decoration-9-polygon-${(new Date()).getTime()}`, polygonId: `decoration-9-polygon-${timestamp}`,
svgWH: [100, 100], svgWH: [100, 100],

View File

@@ -165,6 +165,8 @@ export default {
graph.animationCurve = animationCurve graph.animationCurve = animationCurve
graph.animationFrame = animationFrame graph.animationFrame = animationFrame
graph.animationEnd()
graph.animation('style', style, true) graph.animation('style', style, true)
graph.animation('shape', shape) graph.animation('shape', shape)
}, },

View File

@@ -171,13 +171,14 @@ export default {
} }
}, },
data () { data () {
const timestamp = Date.now()
return { return {
ref: 'dv-flyline-chart', ref: 'dv-flyline-chart',
unique: Math.random(), unique: Math.random(),
maskId: `flyline-mask-id-${(new Date()).getTime()}`, maskId: `flyline-mask-id-${timestamp}`,
maskCircleId: `mask-circle-id-${(new Date()).getTime()}`, maskCircleId: `mask-circle-id-${timestamp}`,
gradientId: `gradient-id-${(new Date()).getTime()}`, gradientId: `gradient-id-${timestamp}`,
gradient2Id: `gradient2-id-${(new Date()).getTime()}`, gradient2Id: `gradient2-id-${timestamp}`,
defaultConfig: { defaultConfig: {
/** /**

View File

@@ -22,8 +22,8 @@
fill="transparent" fill="transparent"
:stroke-width="mergedConfig ? mergedConfig.borderWidth : '0'" :stroke-width="mergedConfig ? mergedConfig.borderWidth : '0'"
:stroke="`url(#${gradientId1})`" :stroke="`url(#${gradientId1})`"
:width="rectWidth" :width="rectWidth > 0 ? rectWidth : 0"
:height="rectHeight" :height="rectHeight > 0 ? rectHeight : 0"
/> />
<polyline <polyline
:stroke-width="polylineWidth" :stroke-width="polylineWidth"
@@ -57,9 +57,10 @@ export default {
} }
}, },
data () { data () {
const timestamp = Date.now()
return { return {
gradientId1: `percent-pond-gradientId1-${(new Date()).getTime()}`, gradientId1: `percent-pond-gradientId1-${timestamp}`,
gradientId2: `percent-pond-gradientId2-${(new Date()).getTime()}`, gradientId2: `percent-pond-gradientId2-${timestamp}`,
width: 0, width: 0,
height: 0, height: 0,
@@ -239,7 +240,7 @@ export default {
this.height = dom.clientHeight this.height = dom.clientHeight
}, },
mergeConfig () { mergeConfig () {
let { config, defaultConfig } = this const { config, defaultConfig } = this
this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {}) this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {})
} }

View File

@@ -236,7 +236,7 @@ export default {
data = data.map((row, i) => { data = data.map((row, i) => {
row = [...row] row = [...row]
const indexTag = `<span class="index" style="background-color: ${headerBGC};">${i + 1}</spand>` const indexTag = `<span class="index" style="background-color: ${headerBGC};">${i + 1}</span>`
row.unshift(indexTag) row.unshift(indexTag)
@@ -260,11 +260,16 @@ export default {
calcWidths () { calcWidths () {
const { width, mergedConfig, rowsData } = this const { width, mergedConfig, rowsData } = this
const { columnWidth } = mergedConfig const { columnWidth, header } = mergedConfig
const usedWidth = columnWidth.reduce((all, w) => all + w, 0) const usedWidth = columnWidth.reduce((all, w) => all + w, 0)
const columnNum = rowsData[0] ? rowsData[0].ceils.length : 0 let columnNum = 0
if (rowsData[0]) {
columnNum = rowsData[0].ceils.length
} else if (header.length) {
columnNum = header.length
}
const avgWidth = (width - usedWidth) / (columnNum - columnWidth.length) const avgWidth = (width - usedWidth) / (columnNum - columnWidth.length)

View File

@@ -9,7 +9,7 @@
<div class="ranking-info"> <div class="ranking-info">
<div class="rank">No.{{ item.ranking }}</div> <div class="rank">No.{{ item.ranking }}</div>
<div class="info-name">{{ item.name }}</div> <div class="info-name">{{ item.name }}</div>
<div class="ranking-value">{{ item.value }}</div> <div class="ranking-value">{{ item.value + mergedConfig.unit }}</div>
</div> </div>
<div class="ranking-column"> <div class="ranking-column">
@@ -69,7 +69,14 @@ export default {
* @default carousel = 'single' * @default carousel = 'single'
* @example carousel = 'single' | 'page' * @example carousel = 'single' | 'page'
*/ */
carousel: 'single' carousel: 'single',
/**
* @description Value unit
* @type {String}
* @default unit = ''
* @example unit = 'ton'
*/
unit: ''
}, },
mergedConfig: null, mergedConfig: null,

View File

@@ -53,8 +53,9 @@ export default {
default: () => ({}) default: () => ({})
}, },
data () { data () {
const timestamp = Date.now()
return { return {
gradientId: `water-level-pond-${(new Date()).getTime()}`, gradientId: `water-level-pond-${timestamp}`,
defaultConfig: { defaultConfig: {
/** /**

View File

@@ -14,6 +14,7 @@ import borderBox6 from './components/borderBox6/index'
import borderBox7 from './components/borderBox7/index' import borderBox7 from './components/borderBox7/index'
import borderBox8 from './components/borderBox8/index' import borderBox8 from './components/borderBox8/index'
import borderBox9 from './components/borderBox9/index' import borderBox9 from './components/borderBox9/index'
import borderBox10 from './components/borderBox10/index'
// decoration // decoration
import decoration1 from './components/decoration1/index' import decoration1 from './components/decoration1/index'
@@ -31,6 +32,7 @@ import decoration10 from './components/decoration10/index'
import charts from './components/charts/index' import charts from './components/charts/index'
import activeRingChart from './components/activeRingChart' import activeRingChart from './components/activeRingChart'
import capsuleChart from './components/capsuleChart'
import waterLevelPond from './components/waterLevelPond/index' import waterLevelPond from './components/waterLevelPond/index'
import percentPond from './components/percentPond/index' import percentPond from './components/percentPond/index'
import flylineChart from './components/flylineChart' import flylineChart from './components/flylineChart'
@@ -56,6 +58,7 @@ export default function (Vue) {
Vue.use(borderBox7) Vue.use(borderBox7)
Vue.use(borderBox8) Vue.use(borderBox8)
Vue.use(borderBox9) Vue.use(borderBox9)
Vue.use(borderBox10)
// decoration // decoration
Vue.use(decoration1) Vue.use(decoration1)
@@ -73,6 +76,7 @@ export default function (Vue) {
Vue.use(charts) Vue.use(charts)
Vue.use(activeRingChart) Vue.use(activeRingChart)
Vue.use(capsuleChart)
Vue.use(waterLevelPond) Vue.use(waterLevelPond)
Vue.use(percentPond) Vue.use(percentPond)
Vue.use(flylineChart) Vue.use(flylineChart)

43
umdExample.html Normal file
View File

@@ -0,0 +1,43 @@
<!DOCTYPE html>
<html>
<head>
<title>DataV</title>
<script src="https://unpkg.com/vue"></script>
<!--Resources are located on personal servers for experience and testing only, do not use in production environments-->
<!--资源位于个人服务器仅供体验和测试,请勿在生产环境使用-->
<!--Debug version-->
<!--调试版-->
<script src="http://lib.jiaminghi.com/datav/datav.map.vue.js"></script>
<!--Compression version-->
<!--压缩版-->
<!-- <script src="http://lib.jiaminghi.com/datav/datav.min.vue.js"></script> -->
<style>
html, body, #app {
width: 100%;
height: 100%;
margin: 0px;
padding: 0px;
}
.border-box-content {
color: rgb(66,185,131);
font-size: 40px;
font-weight: bold;
display: flex;
justify-content: center;
align-items: center;
}
</style>
</head>
<body>
<div id="app">
<dv-border-box-1>Welcome to DataV</dv-border-box-1>
</div>
<script>
var app = new Vue({
el: '#app'
})
</script>
</body>
</html>