Compare commits

..

177 Commits

Author SHA1 Message Date
jiaming743
16013c0aa3 update dist 2020-08-05 10:03:59 +08:00
jiaming743
c3211c358e Merge branch 'master' of https://github.com/DataV-Team/Datav 2020-08-05 10:03:19 +08:00
jiaming743
536ded2964 update dist and lib 2020-08-05 09:59:49 +08:00
jiaming743
32b9757e0f Optmization: Reduce redundant node rendering 2020-08-05 09:59:20 +08:00
jiaming743
60247e548c update change log 2020-08-05 09:59:04 +08:00
jiaming743
58d27bc6b1 update version to 2.9.5 2020-08-05 09:58:58 +08:00
jiaming743
e0bd76032a update dist and lib 2020-07-03 17:40:19 +08:00
jiaming743
6139b5d9b7 update version to 2.9.4 2020-07-03 17:39:37 +08:00
jiaming743
c32d396f90 update change log 2020-07-03 17:39:12 +08:00
jiaming743
feada8a462 Optimize key value 2020-07-03 17:37:36 +08:00
jiaming743
9318431c88 update dist and lib 2020-07-02 11:15:51 +08:00
jiaming743
abba9ad931 update version to 2.9.3 2020-07-02 11:15:47 +08:00
jiaming743
2b06940ac7 update change log 2020-07-02 11:05:47 +08:00
jiaming743
026d9139c4 Optimize uuid 2020-07-02 11:00:19 +08:00
jiaming743
9b84417f01 update dist and lib 2020-06-16 14:49:59 +08:00
jiaming743
86da84af2e update version to 2.9.2 2020-06-16 14:49:32 +08:00
jiaming743
1ea106fd83 update change log 2020-06-16 14:49:11 +08:00
jiaming743
7491b34711 bug fixes: reset animationIndex when config upate 2020-06-16 14:48:16 +08:00
jiaming743
a2875684ce update dist and lib 2020-06-16 14:34:36 +08:00
jiaming743
f581aee5c3 update changelog 2020-06-16 14:34:30 +08:00
jiaming743
3f5148cea3 update version to 2.9.1 2020-06-16 14:27:11 +08:00
jiaming743
e270fadcd2 update change log 2020-06-16 14:26:55 +08:00
jiaming743
beaef5c59a optmization 2020-06-16 14:24:02 +08:00
jiaming743
b17399416a Merge branch 'pr/101' 2020-06-16 14:19:34 +08:00
jiaming743
5f3fdfc798 add number formatter 2020-06-16 14:06:12 +08:00
costa
e7c237cbac ativeRingChart: optimize method calcRowsData 2020-06-12 15:08:00 +08:00
jiaming743
3d3de766e3 update dist and lib 2020-06-10 09:50:30 +08:00
jiaming743
330815d90a update version to 2.9.0 2020-06-10 09:50:24 +08:00
jiaming743
4f6fc240d2 update change log 2020-06-10 09:50:10 +08:00
jiaming743
1d0f369509 optmization 2020-06-10 09:45:21 +08:00
gaoy
ea058a90c3 feature / 新增轮播表的鼠标悬停配置 hoverPause 2020-06-09 11:15:23 +08:00
jiaming743
934e3f314a Merge branch 'master' of https://github.com/DataV-Team/Datav 2020-05-25 17:03:44 +08:00
jiaming743
eea32d7e39 merge branch pr/83 2020-05-25 17:02:57 +08:00
jiaming743
7dd7baebba merge branch pr/83 2020-05-25 17:02:05 +08:00
jiaming743
4a7fdf0c1c Merge branch 'pr/83' 2020-05-25 17:01:06 +08:00
jiaming743
53991795a0 update dist and lib 2020-05-25 16:42:14 +08:00
jiaming743
dde29fa61a update version to 2.8.4 2020-05-25 15:59:20 +08:00
jiaming743
c82b979432 update change log 2020-05-25 15:59:10 +08:00
jiaming743
e938b66dc0 update dist and lib 2020-05-25 15:57:26 +08:00
jiaming743
71a9be2a13 Use uuid to produce unique id 2020-05-25 15:57:19 +08:00
jiahao
f0432e4c42 update uuid 2020-05-16 15:20:06 +08:00
jiahao
65f5b529bf fix id errors 2020-05-15 13:22:05 +08:00
jiaming743
054854480a update dist 2020-05-06 15:07:19 +08:00
jiaming743
6ce83e1fd8 update dist and lib 2020-05-06 14:15:15 +08:00
jiaming743
8e5f279b6e update version to 2.8.3 2020-05-06 14:15:02 +08:00
jiaming743
22afc8e787 update change log 2020-05-06 14:14:52 +08:00
jiaming743
eb78915c93 add showValue configuration 2020-05-06 14:13:49 +08:00
jiaming743
22c88c4ea5 add showOriginValue configuration 2020-05-06 14:13:34 +08:00
jiaming743
c98ca00179 Merge branch 'pr/76' into dev 2020-05-06 13:47:47 +08:00
jiaming743
c257ca6d9c update dist and lib 2020-05-06 13:20:20 +08:00
jiaming743
ce4cf0d342 add reverse configuration 2020-05-06 13:20:15 +08:00
jiaming743
7df0c0247a update version to 2.8.2 2020-05-06 13:20:04 +08:00
jiaming743
df2369dfe4 update change log 2020-05-06 13:19:55 +08:00
jiaming743
db52e8cdc0 update change log 2020-05-03 20:26:37 +08:00
jiaming743
f8e438b0c4 update version to 2.8.1 2020-05-03 20:26:33 +08:00
jiaming743
1a13bc08c5 update dist and lib 2020-05-03 20:15:35 +08:00
jiaming743
ba90fb2faa add rowGap configuration 2020-05-03 20:15:28 +08:00
costa
7799ef3dae capsule-item > div add position prop 2020-04-30 13:38:11 +08:00
jiaming743
33456176f7 update dist 2020-04-28 18:41:09 +08:00
costa
dd37ba167a format code 2020-04-28 16:43:44 +08:00
costa
fdd1e243a7 active-ring-chart add showOriginalValue 2020-04-28 16:15:12 +08:00
costa
57b6c726eb 1.add showVal prop;
2.optimize unit-label child style;
2020-04-27 18:19:20 +08:00
jiaming743
be410da013 update dist and lib 2020-04-25 16:46:33 +08:00
jiaming743
d4206f066c update version to 2.8.0 2020-04-25 16:46:27 +08:00
jiaming743
73a5084c0e update change log 2020-04-25 16:46:17 +08:00
jiaming743
9a039b3f10 Improve compatibility 2020-04-25 16:42:41 +08:00
jiaming743
5ee1d408b6 add backgroudColor config 2020-04-25 16:42:04 +08:00
JM
419fa0c3a9 update dist and lib 2020-04-15 14:03:45 +08:00
JM
d2bb06a36c update version to 2.7.4 2020-04-15 14:03:37 +08:00
JM
94824f32d8 update change log 2020-04-15 14:03:27 +08:00
wzx
b99410ef94 Bug Fixes:#59 修复胶囊图数值错误 2020-04-07 17:54:33 +08:00
JM
4b69668327 update dist and lib 2020-01-16 10:23:42 +08:00
JM
d15bcf34cb update version to 2.7.3 2020-01-16 10:23:15 +08:00
JM
43a04efb62 update changelog 2020-01-16 10:23:06 +08:00
JM
81b8bef8e1 Bug Fixes: parseInt precision lost 2020-01-16 10:21:58 +08:00
JM
6467bd516f remove useless character 2020-01-12 17:38:53 +08:00
JM
62c5998938 update version to 2.7.2 2020-01-10 14:30:09 +08:00
JM
247221729f update dist and lib 2020-01-10 14:29:37 +08:00
JM
c48aa8ee84 update change log 2020-01-10 14:29:28 +08:00
JM
b18962855c add digitalFlopToFixed configuration 2020-01-10 14:28:22 +08:00
JM
ae3345bd95 update change log 2020-01-08 19:05:14 +08:00
JM
dceb761e8c update dist and lib 2020-01-08 19:04:36 +08:00
JM
bd178192f1 update version to 2.7.1 2020-01-08 19:03:46 +08:00
JM
8c47ae03db update change log 2020-01-08 19:03:39 +08:00
JM
cc14ac7670 Bug Fixes: exception when relative is false 2020-01-08 19:02:32 +08:00
JM
b6c8134fa6 update readme 2020-01-05 22:19:43 +08:00
JM
8f87b3cab1 new component: flylineChartEnhanced 2020-01-05 22:19:04 +08:00
JM
005ae41e29 update dist and lib 2020-01-05 22:18:00 +08:00
JM
7e9cca32ad update version to 2.7.0 2020-01-05 22:17:34 +08:00
JM
31d94f3cfd update change log 2020-01-05 22:17:20 +08:00
JM
ca5252951f update dist and lib 2019-12-25 14:23:39 +08:00
JM
4036915fa2 update version to 2.6.0 2019-12-25 14:23:33 +08:00
JM
431cd57aa1 update change log 2019-12-25 14:23:23 +08:00
JM
c48c46335d Perfect: [issue35] & [issue36] 2019-12-25 14:19:25 +08:00
JM
a200e8ab41 update readme 2019-12-11 11:27:25 +08:00
JM
6876dec1ca update dist and lib 2019-12-06 21:07:16 +08:00
JM
aeb021e5e4 update readme 2019-12-06 21:04:49 +08:00
JM
80e29fdb9e update version to 2.5.0 2019-12-06 21:04:39 +08:00
JM
a6727767e6 update changelog 2019-12-06 21:04:28 +08:00
JM
aa78fee05b new borderbox 2019-12-06 20:56:12 +08:00
JM
b439b17593 new decoration 2019-12-06 20:56:05 +08:00
JM
14765c6e79 Add color configuration items to customize colors 2019-12-06 20:55:51 +08:00
JM
f4888ad9cd add new borderbox and decoration 2019-12-06 20:46:59 +08:00
JM
8564c23fbc Merge branch 'dev' 2019-12-06 20:40:31 +08:00
JM
325f700f08 Merge pull request #33 from RouRouX/dev
[Feature,#31] add index header configuration for scrollBoard
2019-11-28 16:03:10 +08:00
肉肉
07956687ab 增加序号表头配置 2019-11-28 12:18:32 +08:00
JiaMing
3ec7a22f98 add icon 2019-11-23 21:26:05 +08:00
JiaMing
d6382142a1 update version to 2.4.8 2019-11-12 12:46:49 +08:00
JiaMing
d21bcd304d update dist and lib 2019-11-12 12:46:39 +08:00
JiaMing
663cfd24db update changelog 2019-11-12 12:45:10 +08:00
JiaMing
3ad05eb1be Bug Fixes: #25 2019-11-12 12:42:36 +08:00
JiaMing
bbdf7ea5a9 update readme 2019-11-08 16:11:04 +08:00
JiaMing
cabe75fed8 Merge branch 'master' of https://github.com/DataV-Team/Datav 2019-11-08 16:10:24 +08:00
JiaMing
431dddf0b5 update umd example 2019-11-08 16:09:54 +08:00
JiaMing
8b8fb00988 add sponsor 2019-10-26 19:21:50 +08:00
JiaMing
9f26ff6280 update dist and lib 2019-10-25 10:57:11 +08:00
JiaMing
5c52f9d6b0 Optimize the update process 2019-10-25 10:56:37 +08:00
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
118 changed files with 29616 additions and 631 deletions

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,166 @@
# 2.9.5-alpha (2020-08-05)
### Optmization
- **scrollBoard:** Reduce redundant node rendering.
- **scrollRankingBoard:** Reduce redundant node rendering.
- **scrollBoard:** Add api to update row data.
# 2.9.4-alpha (2020-07-03)
### Optmization
- **scrollBoard:** Optimize key value [(#8)](https://github.com/DataV-Team/DataV-React/issues/8).
# 2.9.3-alpha (2020-07-02)
### Perfect
- **uuid:** Optimization of `-` in uuid will cause abnormal svg animation [(#108)](https://github.com/DataV-Team/DataV/issues/108).
# 2.9.2-alpha (2020-06-16)
### Bug Fixes
- **scrollBoard:** reset animationIndex when config upate.
# 2.9.1-alpha (2020-06-16)
### Bug Fixes
- **scrollRankingBoard:** Calculation optimization of negative values [(#101)](https://github.com/DataV-Team/DataV/pull/101).
### Perfect
- **digitalFlop:** add number formatter.
# 2.9.0-alpha (2020-06-10)
### ScrollBoard
- **hoverPause:** add `hoverPause` configuration [(#96)](https://github.com/DataV-Team/DataV/pull/96).
- **mouseover:** add `mouseover` event [(#96)](https://github.com/DataV-Team/DataV/pull/96).
# 2.8.4-alpha (2020-05-25)
### Perfect
- **uuid:** Use uuid to produce unique id.
# 2.8.3-alpha (2020-05-06)
### Perfect
- **activeRingChart:** add `showOriginValue` configuration.
- **capsuleChart:** add `showValue` configuration.
# 2.8.2-alpha (2020-05-06)
### Perfect
- **borderBox8:** add `reverse` configuration.
# 2.8.1-alpha (2020-05-03)
### Perfect
- **digitalFlop:** Use `\n` to start a newline.
- **digitalFlop:** `rowGap` configuration.
# 2.7.4-alpha (2020-04-15)
### Bug Fixes
- **capsuleChart:** Calculate exception when min value is less 5 [(#59)](https://github.com/DataV-Team/DataV/pull/59).
# 2.7.3-alpha (2020-01-16)
### Bug Fixes
- **activeRingChart:** `parseInt` precision lost.
# 2.7.2-alpha (2020-01-10)
### Perfect
- **ativeRingChart:** Add digitalFlopToFixed configuration.
# 2.7.1-alpha (2020-01-08)
### Bug Fixes
- **flylineChartEnhanced:** Exception when relative is false.
# 2.7.0-alpha (2020-01-05)
### New
- **flylineChartEnhanced:** Enhanced flylineChart [(#12)](https://github.com/DataV-Team/DataV/issues/12).
# 2.6.0-alpha (2019-12-25)
### Perfect
- **scrollRankingBoard:** Configurable auto-sequencing [(#35)](https://github.com/DataV-Team/DataV/pull/35).
- **scrollRankingBoard:** Render name using `v-html` [(#36)](https://github.com/DataV-Team/DataV/pull/36).
# 2.5.0-alpha (2019-12-06)
### Feature
- **borderBox & decoration:** **Configurable** colors.
```html
<!-- Example -->
<dv-border-box-1 :color="['red', 'green']" />
<dv-decoration-1 :color="['red', 'green']" />
```
- **scrollBoard:** Configurable index header [(#33)](https://github.com/DataV-Team/DataV/pull/33).
### New
- **borderBox11**
- **borderBox12**
- **borderBox13**
- **decoration11**
# 2.4.8-alpha (2019-11-12)
### Bug Fixes
- **scrollBoard:** After updating props, the carousel speed is abnormal [(#25)](https://github.com/jiaming743/DataV/issues/16),[(#20)](https://github.com/jiaming743/DataV/issues/25).
- **scrollRankingBorad:** After updating props, the carousel speed is abnormal[(#25)](https://github.com/jiaming743/DataV/issues/16),[(#20)](https://github.com/jiaming743/DataV/issues/25).
# 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) # 2.4.2-alpha (2019-08-30)
### Perfect ### Perfect

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,9 +1,12 @@
[ENGLISH](./README_EN.md) [ENGLISH](./README_EN.md)
<p align="center">
<img src="./icon.png">
</p>
<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" />
@@ -12,10 +15,10 @@
## DataV是干什么的? ## DataV是干什么的?
* DataV是一个基于**Vue**的数据可视化组件库. * DataV是一个基于**Vue**的数据可视化组件库(当然也有[React版本](https://github.com/DataV-Team/DataV-React)
* 提供用于提升页面视觉效果的**SVG**边框和装饰. * 提供用于提升页面视觉效果的**SVG**边框和装饰
* 提供常用的**图表**如折线图等. * 提供常用的**图表**如折线图等
* 飞线图/轮播表等其他组件. * 飞线图/轮播表等其他组件
### npm安装 ### npm安装
@@ -38,6 +41,24 @@ Vue.use(borderBox1)
详细文档及示例请移步[HomePage](http://datav.jiaminghi.com). 详细文档及示例请移步[HomePage](http://datav.jiaminghi.com).
### UMD版
`UMD`版可直接使用`script`标签引入,`UMD`版文件位于项目`dist`目录下,引入后将自动把所有组件注册为**Vue全局组件**,引入`DataV`前请确保已引入`Vue`
[UMD版使用示例](./umdExample.html)
### TODO
* **地图组件**
* **TS**重构组件库底层依赖
### 致谢
组件库的开发基于个人学习和兴趣由于技术水平及经验的限制组件尚有许多不完善之处如有BUG可及时提交[issue](https://github.com/DataV-Team/DataV/issues/new?template=bug_report.md)或添加反馈群进行反馈,也欢迎提供指正和建议,感谢各位的支持。
### 反馈
![Feedback](./QQGroup.png)
### Demo ### Demo
Demo页面使用了全屏组件请F11全屏后查看。 Demo页面使用了全屏组件请F11全屏后查看。

View File

@@ -1,10 +1,12 @@
[中文](./README.md) [中文](./README.md)
<h1 align="center">DataV</h1>
<p align="center"> <p align="center">
<a href="https://github.com/jiaming743/datav/blob/master/LICENSE"> <img src="./icon.png">
<img src="https://img.shields.io/github/license/jiaming743/datav.svg" alt="LICENSE" /> </p>
<h1 align="center">DataV</h1>
<p align="center">
<a href="https://github.com/DataV-Team/datav/blob/master/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 +15,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.
@@ -39,6 +41,35 @@ 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
* **Map Component**
* Refactor underlying dependencies using **TS**.
### 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 ### Demo
The Demo page uses the full-screen component, please view it after F11 full screen. The Demo page uses the full-screen component, please view it after F11 full screen.

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']
}

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

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

File diff suppressed because it is too large Load Diff

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

File diff suppressed because one or more lines are too long

BIN
icon.png Executable file

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.2 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'
@@ -28,7 +28,7 @@ export default {
default: () => ({}) default: () => ({})
} }
}, },
data () { data() {
return { return {
defaultConfig: { defaultConfig: {
/** /**
@@ -78,6 +78,11 @@ export default {
fontSize: 25, fontSize: 25,
fill: '#fff' fill: '#fff'
}, },
/**
* @description Digital flop toFixed
* @type {Number}
*/
digitalFlopToFixed: 0,
/** /**
* @description CRender animationCurve * @description CRender animationCurve
* @type {String} * @type {String}
@@ -89,7 +94,13 @@ export default {
* @type {String} * @type {String}
* @default animationFrame = 50 * @default animationFrame = 50
*/ */
animationFrame: 50 animationFrame: 50,
/**
* @description showOriginValue
* @type {Boolean}
* @default showOriginValue = false
*/
showOriginValue: false
}, },
mergedConfig: null, mergedConfig: null,
@@ -102,33 +113,47 @@ export default {
} }
}, },
computed: { computed: {
digitalFlop () { digitalFlop() {
const { mergedConfig, activeIndex } = this const { mergedConfig, activeIndex } = this
if (!mergedConfig) return {} if (!mergedConfig) return {}
const { digitalFlopStyle, data } = mergedConfig const {
digitalFlopStyle,
digitalFlopToFixed,
data,
showOriginValue
} = mergedConfig
const value = data.map(({ value }) => value) const value = data.map(({ value }) => value)
const sum = value.reduce((all, v) => all + v, 0) let displayValue
const percent = parseInt(value[activeIndex] / sum * 100) if (showOriginValue) {
displayValue = value[activeIndex]
} else {
const sum = value.reduce((all, v) => all + v, 0)
const percent = parseFloat((value[activeIndex] / sum) * 100) || 0
displayValue = percent
}
return { return {
content: '{nt}%', content: showOriginValue ? '{nt}' : '{nt}%',
number: [percent], number: [displayValue],
style: digitalFlopStyle style: digitalFlopStyle,
toFixed: digitalFlopToFixed
} }
}, },
ringName () { ringName() {
const { mergedConfig, activeIndex } = this const { mergedConfig, activeIndex } = this
if (!mergedConfig) return '' if (!mergedConfig) return ''
return mergedConfig.data[activeIndex].name return mergedConfig.data[activeIndex].name
}, },
fontSize () { fontSize() {
const { mergedConfig } = this const { mergedConfig } = this
if (!mergedConfig) return '' if (!mergedConfig) return ''
@@ -137,7 +162,7 @@ export default {
} }
}, },
watch: { watch: {
config () { config() {
const { animationHandler, mergeConfig, setRingOption } = this const { animationHandler, mergeConfig, setRingOption } = this
clearTimeout(animationHandler) clearTimeout(animationHandler)
@@ -150,7 +175,7 @@ export default {
} }
}, },
methods: { methods: {
init () { init() {
const { initChart, mergeConfig, setRingOption } = this const { initChart, mergeConfig, setRingOption } = this
initChart() initChart()
@@ -159,26 +184,29 @@ export default {
setRingOption() setRingOption()
}, },
initChart () { initChart() {
const { $refs } = this const { $refs } = this
this.chart = new Charts($refs['active-ring-chart']) this.chart = new Charts($refs['active-ring-chart'])
}, },
mergeConfig () { mergeConfig() {
const { defaultConfig, config } = this const { defaultConfig, config } = this
this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {}) this.mergedConfig = deepMerge(
deepClone(defaultConfig, true),
config || {}
)
}, },
setRingOption () { setRingOption() {
const { getRingOption, chart, ringAnimation } = this const { getRingOption, chart, ringAnimation } = this
const option = getRingOption() const option = getRingOption()
chart.setOption(option) chart.setOption(option, true)
ringAnimation() ringAnimation()
}, },
getRingOption () { getRingOption() {
const { mergedConfig, getRealRadius } = this const { mergedConfig, getRealRadius } = this
const radius = getRealRadius() const radius = getRealRadius()
@@ -200,7 +228,7 @@ export default {
color: mergedConfig.color color: mergedConfig.color
} }
}, },
getRealRadius (active = false) { getRealRadius(active = false) {
const { mergedConfig, chart } = this const { mergedConfig, chart } = this
const { radius, activeRadius, lineWidth } = mergedConfig const { radius, activeRadius, lineWidth } = mergedConfig
@@ -211,14 +239,15 @@ export default {
let realRadius = active ? activeRadius : radius let realRadius = active ? activeRadius : radius
if (typeof realRadius !== 'number') realRadius = parseInt(realRadius) / 100 * maxRadius if (typeof realRadius !== 'number')
realRadius = (parseInt(realRadius) / 100) * maxRadius
const insideRadius = realRadius - halfLineWidth const insideRadius = realRadius - halfLineWidth
const outSideRadius = realRadius + halfLineWidth const outSideRadius = realRadius + halfLineWidth
return [insideRadius, outSideRadius] return [insideRadius, outSideRadius]
}, },
ringAnimation () { ringAnimation() {
let { activeIndex, getRingOption, chart, getRealRadius } = this let { activeIndex, getRingOption, chart, getRealRadius } = this
const radius = getRealRadius() const radius = getRealRadius()
@@ -236,7 +265,7 @@ export default {
} }
}) })
chart.setOption(option) chart.setOption(option, true)
const { activeTimeGap } = option.series[0] const { activeTimeGap } = option.series[0]
@@ -251,12 +280,12 @@ export default {
}, activeTimeGap) }, activeTimeGap)
} }
}, },
mounted () { mounted() {
const { init } = this const { init } = this
init() init()
}, },
beforeDestroy () { beforeDestroy() {
const { animationHandler } = this const { animationHandler } = this
clearTimeout(animationHandler) clearTimeout(animationHandler)

View File

@@ -1,5 +1,16 @@
<template> <template>
<div class="dv-border-box-1"> <div class="dv-border-box-1" :ref="ref">
<svg class="border" :width="width" :height="height">
<polygon :fill="backgroundColor" :points="`10, 27 10, ${height - 27} 13, ${height - 24} 13, ${height - 21} 24, ${height - 11}
38, ${height - 11} 41, ${height - 8} 73, ${height - 8} 75, ${height - 10} 81, ${height - 10}
85, ${height - 6} ${width - 85}, ${height - 6} ${width - 81}, ${height - 10} ${width - 75}, ${height - 10}
${width - 73}, ${height - 8} ${width - 41}, ${height - 8} ${width - 38}, ${height - 11}
${width - 24}, ${height - 11} ${width - 13}, ${height - 21} ${width - 13}, ${height - 24}
${width - 10}, ${height - 27} ${width - 10}, 27 ${width - 13}, 25 ${width - 13}, 21
${width - 24}, 11 ${width - 38}, 11 ${width - 41}, 8 ${width - 73}, 8 ${width - 75}, 10
${width - 81}, 10 ${width - 85}, 6 85, 6 81, 10 75, 10 73, 8 41, 8 38, 11 24, 11 13, 21 13, 24`" />
</svg>
<svg <svg
width="150px" width="150px"
height="150px" height="150px"
@@ -8,36 +19,36 @@
:class="`${item} border`" :class="`${item} border`"
> >
<polygon <polygon
fill="#4fd2dd" :fill="mergedColor[0]"
points="6,66 6,18 12,12 18,12 24,6 27,6 30,9 36,9 39,6 84,6 81,9 75,9 73.2,7 40.8,7 37.8,10.2 24,10.2 12,21 12,24 9,27 9,51 7.8,54 7.8,63" points="6,66 6,18 12,12 18,12 24,6 27,6 30,9 36,9 39,6 84,6 81,9 75,9 73.2,7 40.8,7 37.8,10.2 24,10.2 12,21 12,24 9,27 9,51 7.8,54 7.8,63"
> >
<animate <animate
attributeName="fill" attributeName="fill"
values="#4fd2dd;#235fa7;#4fd2dd" :values="`${mergedColor[0]};${mergedColor[1]};${mergedColor[0]}`"
dur="0.5s" dur="0.5s"
begin="0s" begin="0s"
repeatCount="indefinite" repeatCount="indefinite"
/> />
</polygon> </polygon>
<polygon <polygon
fill="#235fa7" :fill="mergedColor[1]"
points="27.599999999999998,4.8 38.4,4.8 35.4,7.8 30.599999999999998,7.8" points="27.599999999999998,4.8 38.4,4.8 35.4,7.8 30.599999999999998,7.8"
> >
<animate <animate
attributeName="fill" attributeName="fill"
values="#235fa7;#4fd2dd;#235fa7" :values="`${mergedColor[1]};${mergedColor[0]};${mergedColor[1]}`"
dur="0.5s" dur="0.5s"
begin="0s" begin="0s"
repeatCount="indefinite" repeatCount="indefinite"
/> />
</polygon> </polygon>
<polygon <polygon
fill="#4fd2dd" :fill="mergedColor[0]"
points="9,54 9,63 7.199999999999999,66 7.199999999999999,75 7.8,78 7.8,110 8.4,110 8.4,66 9.6,66 9.6,54" points="9,54 9,63 7.199999999999999,66 7.199999999999999,75 7.8,78 7.8,110 8.4,110 8.4,66 9.6,66 9.6,54"
> >
<animate <animate
attributeName="fill" attributeName="fill"
values="#4fd2dd;#235fa7;transparent" :values="`${mergedColor[0]};${mergedColor[1]};transparent`"
dur="1s" dur="1s"
begin="0s" begin="0s"
repeatCount="indefinite" repeatCount="indefinite"
@@ -52,12 +63,54 @@
</template> </template>
<script> <script>
import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox1', name: 'DvBorderBox1',
mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () { data () {
return { return {
border: ['left-top', 'right-top', 'left-bottom', 'right-bottom'] ref: 'border-box-1',
border: ['left-top', 'right-top', 'left-bottom', 'right-bottom'],
defaultColor: ['#4fd2dd', '#235fa7'],
mergedColor: []
} }
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -2,7 +2,6 @@
position: relative; position: relative;
width: 100%; width: 100%;
height: 100%; height: 100%;
box-shadow: inset 0 0 25px 3px #1d48c4;
border-radius: 6px; border-radius: 6px;
} }
.dv-border-box-10 .border { .dv-border-box-10 .border {

View File

@@ -1,5 +1,12 @@
<template> <template>
<div class="dv-border-box-10"> <div class="dv-border-box-10" :ref="ref" :style="`box-shadow: inset 0 0 25px 3px ${mergedColor[0]}`">
<svg class="border" :width="width" :height="height">
<polygon :fill="backgroundColor" :points="`
4, 0 ${width - 4}, 0 ${width}, 4 ${width}, ${height - 4} ${width - 4}, ${height}
4, ${height} 0, ${height - 4} 0, 4
`" />
</svg>
<svg <svg
width="150px" width="150px"
height="150px" height="150px"
@@ -8,7 +15,7 @@
:class="`${item} border`" :class="`${item} border`"
> >
<polygon <polygon
fill="#d3e1f8" :fill="mergedColor[1]"
points="40, 0 5, 0 0, 5 0, 16 3, 19 3, 7 7, 3 35, 3" points="40, 0 5, 0 0, 5 0, 16 3, 19 3, 7 7, 3 35, 3"
/> />
</svg> </svg>
@@ -20,12 +27,54 @@
</template> </template>
<script> <script>
import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox10', name: 'DvBorderBox10',
mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () { data () {
return { return {
border: ['left-top', 'right-top', 'left-bottom', 'right-bottom'] ref: 'border-box-10',
border: ['left-top', 'right-top', 'left-bottom', 'right-bottom'],
defaultColor: ['#1d48c4', '#d3e1f8'],
mergedColor: []
} }
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

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

View File

@@ -0,0 +1,21 @@
.dv-border-box-11 {
position: relative;
width: 100%;
height: 100%;
}
.dv-border-box-11 .dv-border-svg-container {
position: absolute;
width: 100%;
height: 100%;
top: 0px;
left: 0px;
}
.dv-border-box-11 .dv-border-svg-container polyline {
fill: none;
stroke-width: 1;
}
.dv-border-box-11 .border-box-content {
position: relative;
width: 100%;
height: 100%;
}

View File

@@ -0,0 +1,280 @@
<template>
<div class="dv-border-box-11" :ref="ref">
<svg class="dv-border-svg-container" :width="width" :height="height">
<defs>
<filter :id="filterId" height="150%" width="150%" x="-25%" y="-25%">
<feMorphology operator="dilate" radius="2" in="SourceAlpha" result="thicken" />
<feGaussianBlur in="thicken" stdDeviation="3" result="blurred" />
<feFlood :flood-color="mergedColor[1]" result="glowColor" />
<feComposite in="glowColor" in2="blurred" operator="in" result="softGlowColored" />
<feMerge>
<feMergeNode in="softGlowColored"/>
<feMergeNode in="SourceGraphic"/>
</feMerge>
</filter>
</defs>
<polygon :fill="backgroundColor" :points="`
20, 32 ${width * 0.5 - titleWidth / 2}, 32 ${width * 0.5 - titleWidth / 2 + 20}, 53
${width * 0.5 + titleWidth / 2 - 20}, 53 ${width * 0.5 + titleWidth / 2}, 32
${width - 20}, 32 ${width - 8}, 48 ${width - 8}, ${height - 25} ${width - 20}, ${height - 8}
20, ${height - 8} 8, ${height - 25} 8, 50
`" />
<polyline
:stroke="mergedColor[0]"
:filter="`url(#${filterId})`"
:points="`
${(width - titleWidth) / 2}, 30
20, 30 7, 50 7, ${50 + (height - 167) / 2}
13, ${55 + (height - 167) / 2} 13, ${135 + (height - 167) / 2}
7, ${140 + (height - 167) / 2} 7, ${height - 27}
20, ${height - 7} ${width - 20}, ${height - 7} ${width - 7}, ${height - 27}
${width - 7}, ${140 + (height - 167) / 2} ${width - 13}, ${135 + (height - 167) / 2}
${width - 13}, ${55 + (height - 167) / 2} ${width - 7}, ${50 + (height - 167) / 2}
${width - 7}, 50 ${width - 20}, 30 ${(width + titleWidth) / 2}, 30
${(width + titleWidth) / 2 - 20}, 7 ${(width - titleWidth) / 2 + 20}, 7
${(width - titleWidth) / 2}, 30 ${(width - titleWidth) / 2 + 20}, 52
${(width + titleWidth) / 2 - 20}, 52 ${(width + titleWidth) / 2}, 30
`"
/>
<polygon
:stroke="mergedColor[0]"
fill="transparent"
:points="`
${(width + titleWidth) / 2 - 5}, 30 ${(width + titleWidth) / 2 - 21}, 11
${(width + titleWidth) / 2 - 27}, 11 ${(width + titleWidth) / 2 - 8}, 34
`"
/>
<polygon
:stroke="mergedColor[0]"
fill="transparent"
:points="`
${(width - titleWidth) / 2 + 5}, 30 ${(width - titleWidth) / 2 + 22}, 49
${(width - titleWidth) / 2 + 28}, 49 ${(width - titleWidth) / 2 + 8}, 26
`"
/>
<polygon
:stroke="mergedColor[0]"
:fill="fade(mergedColor[1] || defaultColor[1], 30)"
:filter="`url(#${filterId})`"
:points="`
${(width + titleWidth) / 2 - 11}, 37 ${(width + titleWidth) / 2 - 32}, 11
${(width - titleWidth) / 2 + 23}, 11 ${(width - titleWidth) / 2 + 11}, 23
${(width - titleWidth) / 2 + 33}, 49 ${(width + titleWidth) / 2 - 22}, 49
`"
/>
<polygon
:filter="`url(#${filterId})`"
:fill="mergedColor[0]"
opacity="1"
:points="`
${(width - titleWidth) / 2 - 10}, 37 ${(width - titleWidth) / 2 - 31}, 37
${(width - titleWidth) / 2 - 25}, 46 ${(width - titleWidth) / 2 - 4}, 46
`"
>
<animate
attributeName="opacity"
values="1;0.7;1"
dur="2s"
begin="0s"
repeatCount="indefinite"
/>
</polygon>
<polygon
:filter="`url(#${filterId})`"
:fill="mergedColor[0]"
opacity="0.7"
:points="`
${(width - titleWidth) / 2 - 40}, 37 ${(width - titleWidth) / 2 - 61}, 37
${(width - titleWidth) / 2 - 55}, 46 ${(width - titleWidth) / 2 - 34}, 46
`"
>
<animate
attributeName="opacity"
values="0.7;0.4;0.7"
dur="2s"
begin="0s"
repeatCount="indefinite"
/>
</polygon>
<polygon
:filter="`url(#${filterId})`"
:fill="mergedColor[0]"
opacity="0.5"
:points="`
${(width - titleWidth) / 2 - 70}, 37 ${(width - titleWidth) / 2 - 91}, 37
${(width - titleWidth) / 2 - 85}, 46 ${(width - titleWidth) / 2 - 64}, 46
`"
>
<animate
attributeName="opacity"
values="0.5;0.2;0.5"
dur="2s"
begin="0s"
repeatCount="indefinite"
/>
</polygon>
<polygon
:filter="`url(#${filterId})`"
:fill="mergedColor[0]"
opacity="1"
:points="`
${(width + titleWidth) / 2 + 30}, 37 ${(width + titleWidth) / 2 + 9}, 37
${(width + titleWidth) / 2 + 3}, 46 ${(width + titleWidth) / 2 + 24}, 46
`"
>
<animate
attributeName="opacity"
values="1;0.7;1"
dur="2s"
begin="0s"
repeatCount="indefinite"
/>
</polygon>
<polygon
:filter="`url(#${filterId})`"
:fill="mergedColor[0]"
opacity="0.7"
:points="`
${(width + titleWidth) / 2 + 60}, 37 ${(width + titleWidth) / 2 + 39}, 37
${(width + titleWidth) / 2 + 33}, 46 ${(width + titleWidth) / 2 + 54}, 46
`"
>
<animate
attributeName="opacity"
values="0.7;0.4;0.7"
dur="2s"
begin="0s"
repeatCount="indefinite"
/>
</polygon>
<polygon
:filter="`url(#${filterId})`"
:fill="mergedColor[0]"
opacity="0.5"
:points="`
${(width + titleWidth) / 2 + 90}, 37 ${(width + titleWidth) / 2 + 69}, 37
${(width + titleWidth) / 2 + 63}, 46 ${(width + titleWidth) / 2 + 84}, 46
`"
>
<animate
attributeName="opacity"
values="0.5;0.2;0.5"
dur="2s"
begin="0s"
repeatCount="indefinite"
/>
</polygon>
<text
class="dv-border-box-11-title"
:x="`${width / 2}`"
y="32"
fill="#fff"
font-size="18"
text-anchor="middle"
dominant-baseline="middle"
>
{{ title }}
</text>
<polygon
:fill="mergedColor[0]"
:filter="`url(#${filterId})`"
:points="`
7, ${53 + (height - 167) / 2} 11, ${57 + (height - 167) / 2}
11, ${133 + (height - 167) / 2} 7, ${137 + (height - 167) / 2}
`"
/>
<polygon
:fill="mergedColor[0]"
:filter="`url(#${filterId})`"
:points="`
${width - 7}, ${53 + (height - 167) / 2} ${width - 11}, ${57 + (height - 167) / 2}
${width - 11}, ${133 + (height - 167) / 2} ${width - 7}, ${137 + (height - 167) / 2}
`"
/>
</svg>
<div class="border-box-content">
<slot></slot>
</div>
</div>
</template>
<script>
import autoResize from '../../../mixin/autoResize'
import { uuid } from '../../../util/index'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
import { fade } from '@jiaminghi/color'
export default {
name: 'DvBorderBox11',
mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
titleWidth: {
type: Number,
default: 250
},
title: {
type: String,
default: ''
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () {
const id = uuid()
return {
ref: 'border-box-11',
filterId: `border-box-11-filterId-${id}`,
defaultColor: ['#8aaafb', '#1f33a2'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
},
fade
},
mounted () {
const { mergeColor } = this
mergeColor()
}
}
</script>

View File

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

View File

@@ -0,0 +1,17 @@
.dv-border-box-12 {
position: relative;
width: 100%;
height: 100%;
}
.dv-border-box-12 .dv-border-svg-container {
position: absolute;
width: 100%;
height: 100%;
top: 0px;
left: 0px;
}
.dv-border-box-12 .border-box-content {
position: relative;
width: 100%;
height: 100%;
}

View File

@@ -0,0 +1,148 @@
<template>
<div class="dv-border-box-12" :ref="ref">
<svg class="dv-border-svg-container" :width="width" :height="height">
<defs>
<filter :id="filterId" height="150%" width="150%" x="-25%" y="-25%">
<feMorphology operator="dilate" radius="1" in="SourceAlpha" result="thicken" />
<feGaussianBlur in="thicken" stdDeviation="2" result="blurred" />
<feFlood :flood-color="fade(mergedColor[1] || defaultColor[1], 70)" result="glowColor">
<animate
attributeName="flood-color"
:values="`
${fade(mergedColor[1] || defaultColor[1], 70)};
${fade(mergedColor[1] || defaultColor[1], 30)};
${fade(mergedColor[1] || defaultColor[1], 70)};
`"
dur="3s"
begin="0s"
repeatCount="indefinite"
/>
</feFlood>
<feComposite in="glowColor" in2="blurred" operator="in" result="softGlowColored" />
<feMerge>
<feMergeNode in="softGlowColored"/>
<feMergeNode in="SourceGraphic"/>
</feMerge>
</filter>
</defs>
<path
v-if="width && height"
:fill="backgroundColor"
stroke-width="2"
:stroke="mergedColor[0]"
:d="`
M15 5 L ${width - 15} 5 Q ${width - 5} 5, ${width - 5} 15
L ${width - 5} ${height - 15} Q ${width - 5} ${height - 5}, ${width - 15} ${height - 5}
L 15, ${height - 5} Q 5 ${height - 5} 5 ${height - 15} L 5 15
Q 5 5 15 5
`"
/>
<path
stroke-width="2"
fill="transparent"
stroke-linecap="round"
:filter="`url(#${filterId})`"
:stroke="mergedColor[1]"
:d="`M 20 5 L 15 5 Q 5 5 5 15 L 5 20`"
/>
<path
stroke-width="2"
fill="transparent"
stroke-linecap="round"
:filter="`url(#${filterId})`"
:stroke="mergedColor[1]"
:d="`M ${width - 20} 5 L ${width - 15} 5 Q ${width - 5} 5 ${width - 5} 15 L ${width - 5} 20`"
/>
<path
stroke-width="2"
fill="transparent"
stroke-linecap="round"
:filter="`url(#${filterId})`"
:stroke="mergedColor[1]"
:d="`
M ${width - 20} ${height - 5} L ${width - 15} ${height - 5}
Q ${width - 5} ${height - 5} ${width - 5} ${height - 15}
L ${width - 5} ${height - 20}
`"
/>
<path
stroke-width="2"
fill="transparent"
stroke-linecap="round"
:filter="`url(#${filterId})`"
:stroke="mergedColor[1]"
:d="`
M 20 ${height - 5} L 15 ${height - 5}
Q 5 ${height - 5} 5 ${height - 15}
L 5 ${height - 20}
`"
/>
</svg>
<div class="border-box-content">
<slot></slot>
</div>
</div>
</template>
<script>
import autoResize from '../../../mixin/autoResize'
import { uuid } from '../../../util/index'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
import { fade } from '@jiaminghi/color'
export default {
name: 'DvBorderBox12',
mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () {
const id = uuid()
return {
ref: 'border-box-12',
filterId: `borderr-box-12-filterId-${id}`,
defaultColor: ['#2e6099', '#7ce7fd'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
},
fade
},
mounted () {
const { mergeColor } = this
mergeColor()
}
}
</script>

View File

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

View File

@@ -0,0 +1,17 @@
.dv-border-box-13 {
position: relative;
width: 100%;
height: 100%;
}
.dv-border-box-13 .dv-border-svg-container {
position: absolute;
width: 100%;
height: 100%;
top: 0px;
left: 0px;
}
.dv-border-box-13 .border-box-content {
position: relative;
width: 100%;
height: 100%;
}

View File

@@ -0,0 +1,92 @@
<template>
<div class="dv-border-box-13" :ref="ref">
<svg class="dv-border-svg-container" :width="width" :height="height">
<path
:fill="backgroundColor"
:stroke="mergedColor[0]"
:d="`
M 5 20 L 5 10 L 12 3 L 60 3 L 68 10
L ${width - 20} 10 L ${width - 5} 25
L ${width - 5} ${height - 5} L 20 ${height - 5}
L 5 ${height - 20} L 5 20
`"
/>
<path
fill="transparent"
stroke-width="3"
stroke-linecap="round"
stroke-dasharray="10, 5"
:stroke="mergedColor[0]"
:d="`M 16 9 L 61 9`"
/>
<path
fill="transparent"
:stroke="mergedColor[1]"
:d="`M 5 20 L 5 10 L 12 3 L 60 3 L 68 10`"
/>
<path
fill="transparent"
:stroke="mergedColor[1]"
:d="`M ${width - 5} ${height - 30} L ${width - 5} ${height - 5} L ${width - 30} ${height - 5}`"
/>
</svg>
<div class="border-box-content">
<slot></slot>
</div>
</div>
</template>
<script>
import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default {
name: 'DvBorderBox13',
mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () {
return {
ref: 'border-box-13',
defaultColor: ['#6586ec', '#2cf7fe'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
}
}
</script>

View File

@@ -14,15 +14,6 @@
fill: none; fill: none;
stroke-width: 1; stroke-width: 1;
} }
.dv-border-box-2 .dv-border-svg-container circle {
fill: #fff;
}
.dv-border-box-2 .dv-bb2-line1 {
stroke: #fff;
}
.dv-border-box-2 .dv-bb2-line2 {
stroke: rgba(255, 255, 255, 0.6);
}
.dv-border-box-2 .border-box-content { .dv-border-box-2 .border-box-content {
position: relative; position: relative;
width: 100%; width: 100%;

View File

@@ -1,14 +1,22 @@
<template> <template>
<div class="dv-border-box-2" :ref="ref"> <div class="dv-border-box-2" :ref="ref">
<svg class="dv-border-svg-container" :width="width" :height="height"> <svg class="dv-border-svg-container" :width="width" :height="height">
<polyline class="dv-bb2-line1" <polygon :fill="backgroundColor" :points="`
:points="`2, 2 ${width - 2} ,2 ${width - 2}, ${height - 2} 2, ${height - 2} 2, 2`" /> 7, 7 ${width - 7}, 7 ${width - 7}, ${height - 7} 7, ${height - 7}
<polyline class="dv-bb2-line2" `" />
:points="`6, 6 ${width - 6}, 6 ${width - 6}, ${height - 6} 6, ${height - 6} 6, 6`" />
<circle cx="11" cy="11" r="1" /> <polyline
<circle :cx="width - 11" cy="11" r="1" /> :stroke="mergedColor[0]"
<circle :cx="width - 11" :cy="height - 11" r="1" /> :points="`2, 2 ${width - 2} ,2 ${width - 2}, ${height - 2} 2, ${height - 2} 2, 2`"
<circle cx="11" :cy="height - 11" r="1" /> />
<polyline
:stroke="mergedColor[1]"
:points="`6, 6 ${width - 6}, 6 ${width - 6}, ${height - 6} 6, ${height - 6} 6, 6`"
/>
<circle :fill="mergedColor[0]" cx="11" cy="11" r="1" />
<circle :fill="mergedColor[0]" :cx="width - 11" cy="11" r="1" />
<circle :fill="mergedColor[0]" :cx="width - 11" :cy="height - 11" r="1" />
<circle :fill="mergedColor[0]" cx="11" :cy="height - 11" r="1" />
</svg> </svg>
<div class="border-box-content"> <div class="border-box-content">
@@ -20,13 +28,50 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox2', name: 'DvBorderBox2',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () { data () {
return { return {
ref: 'border-box-2' ref: 'border-box-2',
defaultColor: ['#fff', 'rgba(255, 255, 255, 0.6)'],
mergedColor: []
} }
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -12,7 +12,6 @@
} }
.dv-border-box-3 .dv-border-svg-container polyline { .dv-border-box-3 .dv-border-svg-container polyline {
fill: none; fill: none;
stroke: #2862b7;
} }
.dv-border-box-3 .dv-bb3-line1 { .dv-border-box-3 .dv-bb3-line1 {
stroke-width: 3; stroke-width: 3;

View File

@@ -1,14 +1,26 @@
<template> <template>
<div class="dv-border-box-3" :ref="ref"> <div class="dv-border-box-3" :ref="ref">
<svg class="dv-border-svg-container" :width="width" :height="height"> <svg class="dv-border-svg-container" :width="width" :height="height">
<polygon :fill="backgroundColor" :points="`
23, 23 ${width - 24}, 23 ${width - 24}, ${height - 24} 23, ${height - 24}
`" />
<polyline class="dv-bb3-line1" <polyline class="dv-bb3-line1"
:points="`4, 4 ${width - 22} ,4 ${width - 22}, ${height - 22} 4, ${height - 22} 4, 4`" /> :stroke="mergedColor[0]"
:points="`4, 4 ${width - 22} ,4 ${width - 22}, ${height - 22} 4, ${height - 22} 4, 4`"
/>
<polyline class="dv-bb3-line2" <polyline class="dv-bb3-line2"
:points="`10, 10 ${width - 16}, 10 ${width - 16}, ${height - 16} 10, ${height - 16} 10, 10`" /> :stroke="mergedColor[1]"
:points="`10, 10 ${width - 16}, 10 ${width - 16}, ${height - 16} 10, ${height - 16} 10, 10`"
/>
<polyline class="dv-bb3-line2" <polyline class="dv-bb3-line2"
:points="`16, 16 ${width - 10}, 16 ${width - 10}, ${height - 10} 16, ${height - 10} 16, 16`" /> :stroke="mergedColor[1]"
:points="`16, 16 ${width - 10}, 16 ${width - 10}, ${height - 10} 16, ${height - 10} 16, 16`"
/>
<polyline class="dv-bb3-line2" <polyline class="dv-bb3-line2"
:points="`22, 22 ${width - 4}, 22 ${width - 4}, ${height - 4} 22, ${height - 4} 22, 22`" /> :stroke="mergedColor[1]"
:points="`22, 22 ${width - 4}, 22 ${width - 4}, ${height - 4} 22, ${height - 4} 22, 22`"
/>
</svg> </svg>
<div class="border-box-content"> <div class="border-box-content">
@@ -20,13 +32,50 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox3', name: 'DvBorderBox3',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () { data () {
return { return {
ref: 'border-box-3' ref: 'border-box-3',
defaultColor: ['#2862b7', '#2862b7'],
mergedColor: []
} }
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -16,12 +16,6 @@
.dv-border-box-4 .dv-border-svg-container polyline { .dv-border-box-4 .dv-border-svg-container polyline {
fill: none; fill: none;
} }
.dv-border-box-4 .sred {
stroke: red;
}
.dv-border-box-4 .sblue {
stroke: rgba(0, 0, 255, 0.8);
}
.dv-border-box-4 .sw1 { .dv-border-box-4 .sw1 {
stroke-width: 1; stroke-width: 1;
} }
@@ -30,48 +24,38 @@
stroke-linecap: round; stroke-linecap: round;
} }
.dv-border-box-4 .dv-bb4-line-1 { .dv-border-box-4 .dv-bb4-line-1 {
stroke: red;
stroke-width: 1; stroke-width: 1;
} }
.dv-border-box-4 .dv-bb4-line-2 { .dv-border-box-4 .dv-bb4-line-2 {
stroke: rgba(0, 0, 255, 0.8);
stroke-width: 1; stroke-width: 1;
} }
.dv-border-box-4 .dv-bb4-line-3 { .dv-border-box-4 .dv-bb4-line-3 {
stroke: red;
stroke-width: 3px; stroke-width: 3px;
stroke-linecap: round; stroke-linecap: round;
} }
.dv-border-box-4 .dv-bb4-line-4 { .dv-border-box-4 .dv-bb4-line-4 {
stroke: red;
stroke-width: 3px; stroke-width: 3px;
stroke-linecap: round; stroke-linecap: round;
} }
.dv-border-box-4 .dv-bb4-line-5 { .dv-border-box-4 .dv-bb4-line-5 {
stroke: red;
stroke-width: 1; stroke-width: 1;
} }
.dv-border-box-4 .dv-bb4-line-6 { .dv-border-box-4 .dv-bb4-line-6 {
stroke: rgba(0, 0, 255, 0.8);
stroke-width: 1; stroke-width: 1;
} }
.dv-border-box-4 .dv-bb4-line-7 { .dv-border-box-4 .dv-bb4-line-7 {
stroke: rgba(0, 0, 255, 0.8);
stroke-width: 1; stroke-width: 1;
} }
.dv-border-box-4 .dv-bb4-line-8 { .dv-border-box-4 .dv-bb4-line-8 {
stroke: rgba(0, 0, 255, 0.8);
stroke-width: 3px; stroke-width: 3px;
stroke-linecap: round; stroke-linecap: round;
} }
.dv-border-box-4 .dv-bb4-line-9 { .dv-border-box-4 .dv-bb4-line-9 {
stroke: red;
stroke-width: 3px; stroke-width: 3px;
stroke-linecap: round; stroke-linecap: round;
stroke-dasharray: 100 250; stroke-dasharray: 100 250;
} }
.dv-border-box-4 .dv-bb4-line-10 { .dv-border-box-4 .dv-bb4-line-10 {
stroke: rgba(0, 0, 255, 0.8);
stroke-width: 1; stroke-width: 1;
stroke-dasharray: 80 270; stroke-dasharray: 80 270;
} }

View File

@@ -1,18 +1,30 @@
<template> <template>
<div class="dv-border-box-4" :ref="ref"> <div class="dv-border-box-4" :ref="ref">
<svg :class="`dv-border-svg-container ${reverse && 'dv-reverse'}`" :width="width" :height="height"> <svg :class="`dv-border-svg-container ${reverse && 'dv-reverse'}`" :width="width" :height="height">
<polyline class="dv-bb4-line-1" :points="`145, ${height - 5} 40, ${height - 5} 10, ${height - 35} <polygon :fill="backgroundColor" :points="`
10, 40 40, 5 150, 5 170, 20 ${width - 15}, 20`"/> ${width - 15}, 22 170, 22 150, 7 40, 7 28, 21 32, 24
<polyline class="dv-bb4-line-2" :points="`245, ${height - 1} 36, ${height - 1} 14, ${height - 23} 16, 42 16, ${height - 32} 41, ${height - 7} ${width - 15}, ${height - 7}
14, ${height - 100}`" /> `" />
<polyline class="dv-bb4-line-3" :points="`7, ${height - 40} 7, ${height - 75}`" />
<polyline class="dv-bb4-line-4" :points="`28, 24 13, 41 13, 64`" /> <polyline class="dv-bb4-line-1"
<polyline class="dv-bb4-line-5" :points="`5, 45 5, 140`" /> :stroke="mergedColor[0]"
<polyline class="dv-bb4-line-6" :points="`14, 75 14, 180`" /> :points="`145, ${height - 5} 40, ${height - 5} 10, ${height - 35}
<polyline class="dv-bb4-line-7" :points="`55, 11 147, 11 167, 26 250, 26`" /> 10, 40 40, 5 150, 5 170, 20 ${width - 15}, 20`"
<polyline class="dv-bb4-line-8" :points="`158, 5 173, 16`" /> />
<polyline class="dv-bb4-line-9" :points="`200, 17 ${width - 10}, 17`" /> <polyline
<polyline class="dv-bb4-line-10" :points="`385, 17 ${width - 10}, 17`" /> :stroke="mergedColor[1]"
class="dv-bb4-line-2" :points="`245, ${height - 1} 36, ${height - 1} 14, ${height - 23}
14, ${height - 100}`"
/>
<polyline class="dv-bb4-line-3" :stroke="mergedColor[0]" :points="`7, ${height - 40} 7, ${height - 75}`" />
<polyline class="dv-bb4-line-4" :stroke="mergedColor[0]" :points="`28, 24 13, 41 13, 64`" />
<polyline class="dv-bb4-line-5" :stroke="mergedColor[0]" :points="`5, 45 5, 140`" />
<polyline class="dv-bb4-line-6" :stroke="mergedColor[1]" :points="`14, 75 14, 180`" />
<polyline class="dv-bb4-line-7" :stroke="mergedColor[1]" :points="`55, 11 147, 11 167, 26 250, 26`" />
<polyline class="dv-bb4-line-8" :stroke="mergedColor[1]" :points="`158, 5 173, 16`" />
<polyline class="dv-bb4-line-9" :stroke="mergedColor[0]" :points="`200, 17 ${width - 10}, 17`" />
<polyline class="dv-bb4-line-10" :stroke="mergedColor[1]" :points="`385, 17 ${width - 10}, 17`" />
</svg> </svg>
<div class="border-box-content"> <div class="border-box-content">
@@ -24,19 +36,54 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox4', name: 'DvBorderBox4',
mixins: [autoResize], mixins: [autoResize],
data () {
return {
ref: 'border-box-4'
}
},
props: { props: {
color: {
type: Array,
default: () => ([])
},
reverse: { reverse: {
type: Boolean, type: Boolean,
default: false default: false
},
backgroundColor: {
type: String,
default: 'transparent'
} }
},
data () {
return {
ref: 'border-box-4',
defaultColor: ['red', 'rgba(0,0,255,0.8)'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -16,22 +16,17 @@
.dv-border-box-5 .dv-svg-container polyline { .dv-border-box-5 .dv-svg-container polyline {
fill: none; fill: none;
} }
.dv-border-box-5 .dv-bb5-line-1 { .dv-border-box-5 .dv-bb5-line-1,
stroke-width: 1;
stroke: rgba(255, 255, 255, 0.35);
}
.dv-border-box-5 .dv-bb5-line-2 { .dv-border-box-5 .dv-bb5-line-2 {
stroke: rgba(255, 255, 255, 0.2); stroke-width: 1;
} }
.dv-border-box-5 .dv-bb5-line-3, .dv-border-box-5 .dv-bb5-line-3,
.dv-border-box-5 .dv-bb5-line-6 { .dv-border-box-5 .dv-bb5-line-6 {
stroke-width: 5; stroke-width: 5;
stroke: rgba(255, 255, 255, 0.15);
} }
.dv-border-box-5 .dv-bb5-line-4, .dv-border-box-5 .dv-bb5-line-4,
.dv-border-box-5 .dv-bb5-line-5 { .dv-border-box-5 .dv-bb5-line-5 {
stroke-width: 2; stroke-width: 2;
stroke: rgba(255, 255, 255, 0.15);
} }
.dv-border-box-5 .border-box-content { .dv-border-box-5 .border-box-content {
position: relative; position: relative;

View File

@@ -1,14 +1,26 @@
<template> <template>
<div class="dv-border-box-5" :ref="ref"> <div class="dv-border-box-5" :ref="ref">
<svg :class="`dv-svg-container ${reverse && 'dv-reverse'}`" :width="width" :height="height"> <svg :class="`dv-svg-container ${reverse && 'dv-reverse'}`" :width="width" :height="height">
<polyline class="dv-bb5-line-1" :points="`8, 5 ${width - 5}, 5 ${width - 5}, ${height - 100} <polygon :fill="backgroundColor" :points="`
${width - 100}, ${height - 5} 8, ${height - 5} 8, 5`" /> 10, 22 ${width - 22}, 22 ${width - 22}, ${height - 86} ${width - 84}, ${height - 24} 10, ${height - 24}
<polyline class="dv-bb5-line-2" :points="`3, 5 ${width - 20}, 5 ${width - 20}, ${height - 60} `" />
${width - 74}, ${height - 5} 3, ${height - 5} 3, 5`" />
<polyline class="dv-bb5-line-3" :points="`50, 13 ${width - 35}, 13`" /> <polyline
<polyline class="dv-bb5-line-4" :points="`15, 20 ${width - 35}, 20`" /> class="dv-bb5-line-1"
<polyline class="dv-bb5-line-5" :points="`15, ${height - 20} ${width - 110}, ${height - 20}`" /> :stroke="mergedColor[0]"
<polyline class="dv-bb5-line-6" :points="`15, ${height - 13} ${width - 110}, ${height - 13}`" /> :points="`8, 5 ${width - 5}, 5 ${width - 5}, ${height - 100}
${width - 100}, ${height - 5} 8, ${height - 5} 8, 5`"
/>
<polyline
class="dv-bb5-line-2"
:stroke="mergedColor[1]"
:points="`3, 5 ${width - 20}, 5 ${width - 20}, ${height - 60}
${width - 74}, ${height - 5} 3, ${height - 5} 3, 5`"
/>
<polyline class="dv-bb5-line-3" :stroke="mergedColor[1]" :points="`50, 13 ${width - 35}, 13`" />
<polyline class="dv-bb5-line-4" :stroke="mergedColor[1]" :points="`15, 20 ${width - 35}, 20`" />
<polyline class="dv-bb5-line-5" :stroke="mergedColor[1]" :points="`15, ${height - 20} ${width - 110}, ${height - 20}`" />
<polyline class="dv-bb5-line-6" :stroke="mergedColor[1]" :points="`15, ${height - 13} ${width - 110}, ${height - 13}`" />
</svg> </svg>
<div class="border-box-content"> <div class="border-box-content">
@@ -20,19 +32,54 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox5', name: 'DvBorderBox5',
mixins: [autoResize], mixins: [autoResize],
data () {
return {
ref: 'border-box-5'
}
},
props: { props: {
color: {
type: Array,
default: () => ([])
},
reverse: { reverse: {
type: Boolean, type: Boolean,
default: false default: false
},
backgroundColor: {
type: String,
default: 'transparent'
} }
},
data () {
return {
ref: 'border-box-5',
defaultColor: ['rgba(255, 255, 255, 0.35)', 'rgba(255, 255, 255, 0.20)'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -10,13 +10,9 @@
width: 100%; width: 100%;
height: 100%; height: 100%;
} }
.dv-border-box-6 .dv-svg-container circle {
fill: gray;
}
.dv-border-box-6 .dv-svg-container polyline { .dv-border-box-6 .dv-svg-container polyline {
fill: none; fill: none;
stroke-width: 1; stroke-width: 1;
stroke: rgba(255, 255, 255, 0.35);
} }
.dv-border-box-6 .border-box-content { .dv-border-box-6 .border-box-content {
position: relative; position: relative;

View File

@@ -1,22 +1,26 @@
<template> <template>
<div class="dv-border-box-6" :ref="ref"> <div class="dv-border-box-6" :ref="ref">
<svg class="dv-svg-container" :width="width" :height="height"> <svg class="dv-svg-container" :width="width" :height="height">
<circle cx="5" cy="5" r="2"/> <polygon :fill="backgroundColor" :points="`
<circle :cx="width - 5" cy="5" r="2" /> 9, 7 ${width - 9}, 7 ${width - 9}, ${height - 7} 9, ${height - 7}
<circle :cx="width - 5" :cy="height - 5" r="2" /> `" />
<circle cx="5" :cy="height - 5" r="2" />
<polyline :points="`10, 4 ${width - 10}, 4`" /> <circle :fill="mergedColor[1]" cx="5" cy="5" r="2"/>
<polyline :points="`10, ${height - 4} ${width - 10}, ${height - 4}`" /> <circle :fill="mergedColor[1]" :cx="width - 5" cy="5" r="2" />
<polyline :points="`5, 70 5, ${height - 70}`" /> <circle :fill="mergedColor[1]" :cx="width - 5" :cy="height - 5" r="2" />
<polyline :points="`${width - 5}, 70 ${width - 5}, ${height - 70}`" /> <circle :fill="mergedColor[1]" cx="5" :cy="height - 5" r="2" />
<polyline :points="`3, 10, 3, 50`" /> <polyline :stroke="mergedColor[0]" :points="`10, 4 ${width - 10}, 4`" />
<polyline :points="`7, 30 7, 80`" /> <polyline :stroke="mergedColor[0]" :points="`10, ${height - 4} ${width - 10}, ${height - 4}`" />
<polyline :points="`${width - 3}, 10 ${width - 3}, 50`" /> <polyline :stroke="mergedColor[0]" :points="`5, 70 5, ${height - 70}`" />
<polyline :points="`${width - 7}, 30 ${width - 7}, 80`" /> <polyline :stroke="mergedColor[0]" :points="`${width - 5}, 70 ${width - 5}, ${height - 70}`" />
<polyline :points="`3, ${height - 10} 3, ${height - 50}`" /> <polyline :stroke="mergedColor[0]" :points="`3, 10, 3, 50`" />
<polyline :points="`7, ${height - 30} 7, ${height - 80}`" /> <polyline :stroke="mergedColor[0]" :points="`7, 30 7, 80`" />
<polyline :points="`${width - 3}, ${height - 10} ${width - 3}, ${height - 50}`" /> <polyline :stroke="mergedColor[0]" :points="`${width - 3}, 10 ${width - 3}, 50`" />
<polyline :points="`${width - 7}, ${height - 30} ${width - 7}, ${height - 80}`" /> <polyline :stroke="mergedColor[0]" :points="`${width - 7}, 30 ${width - 7}, 80`" />
<polyline :stroke="mergedColor[0]" :points="`3, ${height - 10} 3, ${height - 50}`" />
<polyline :stroke="mergedColor[0]" :points="`7, ${height - 30} 7, ${height - 80}`" />
<polyline :stroke="mergedColor[0]" :points="`${width - 3}, ${height - 10} ${width - 3}, ${height - 50}`" />
<polyline :stroke="mergedColor[0]" :points="`${width - 7}, ${height - 30} ${width - 7}, ${height - 80}`" />
</svg> </svg>
<div class="border-box-content"> <div class="border-box-content">
@@ -28,13 +32,50 @@
<script> <script>
import autoResize from '../../../mixin/autoResize.js' import autoResize from '../../../mixin/autoResize.js'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox6', name: 'DvBorderBox6',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () { data () {
return { return {
ref: 'border-box-6' ref: 'border-box-6',
defaultColor: ['rgba(255, 255, 255, 0.35)', 'gray'],
mergedColor: []
} }
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -2,8 +2,6 @@
position: relative; position: relative;
width: 100%; width: 100%;
height: 100%; height: 100%;
box-shadow: inset 0 0 40px rgba(128, 128, 128, 0.3);
border: 1px solid rgba(128, 128, 128, 0.3);
} }
.dv-border-box-7 .dv-svg-container { .dv-border-box-7 .dv-svg-container {
position: absolute; position: absolute;
@@ -17,11 +15,9 @@
stroke-linecap: round; stroke-linecap: round;
} }
.dv-border-box-7 .dv-bb7-line-width-2 { .dv-border-box-7 .dv-bb7-line-width-2 {
stroke: rgba(128, 128, 128, 0.3);
stroke-width: 2; stroke-width: 2;
} }
.dv-border-box-7 .dv-bb7-line-width-5 { .dv-border-box-7 .dv-bb7-line-width-5 {
stroke: rgba(128, 128, 128, 0.5);
stroke-width: 5; stroke-width: 5;
} }
.dv-border-box-7 .border-box-content { .dv-border-box-7 .border-box-content {

View File

@@ -1,15 +1,20 @@
<template>
<div class="dv-border-box-7" :ref="ref">
<svg class="dv-svg-container" :width="width" :height="height">
<polyline class="dv-bb7-line-width-2" :points="`0, 25 0, 0 25, 0`" />
<polyline class="dv-bb7-line-width-2" :points="`${width - 25}, 0 ${width}, 0 ${width}, 25`" />
<polyline class="dv-bb7-line-width-2" :points="`${width - 25}, ${height} ${width}, ${height} ${width}, ${height - 25}`" />
<polyline class="dv-bb7-line-width-2" :points="`0, ${height - 25} 0, ${height} 25, ${height}`" />
<polyline class="dv-bb7-line-width-5" :points="`0, 10 0, 0 10, 0`" /> <template>
<polyline class="dv-bb7-line-width-5" :points="`${width - 10}, 0 ${width}, 0 ${width}, 10`" /> <div
<polyline class="dv-bb7-line-width-5" :points="`${width - 10}, ${height} ${width}, ${height} ${width}, ${height - 10}`" /> class="dv-border-box-7"
<polyline class="dv-bb7-line-width-5" :points="`0, ${height - 10} 0, ${height} 10, ${height}`" /> :style="`box-shadow: inset 0 0 40px ${mergedColor[0]}; border: 1px solid ${mergedColor[0]}; background-color: ${backgroundColor}`"
:ref="ref"
>
<svg class="dv-svg-container" :width="width" :height="height">
<polyline class="dv-bb7-line-width-2" :stroke="mergedColor[0]" :points="`0, 25 0, 0 25, 0`" />
<polyline class="dv-bb7-line-width-2" :stroke="mergedColor[0]" :points="`${width - 25}, 0 ${width}, 0 ${width}, 25`" />
<polyline class="dv-bb7-line-width-2" :stroke="mergedColor[0]" :points="`${width - 25}, ${height} ${width}, ${height} ${width}, ${height - 25}`" />
<polyline class="dv-bb7-line-width-2" :stroke="mergedColor[0]" :points="`0, ${height - 25} 0, ${height} 25, ${height}`" />
<polyline class="dv-bb7-line-width-5" :stroke="mergedColor[1]" :points="`0, 10 0, 0 10, 0`" />
<polyline class="dv-bb7-line-width-5" :stroke="mergedColor[1]" :points="`${width - 10}, 0 ${width}, 0 ${width}, 10`" />
<polyline class="dv-bb7-line-width-5" :stroke="mergedColor[1]" :points="`${width - 10}, ${height} ${width}, ${height} ${width}, ${height - 10}`" />
<polyline class="dv-bb7-line-width-5" :stroke="mergedColor[1]" :points="`0, ${height - 10} 0, ${height} 10, ${height}`" />
</svg> </svg>
<div class="border-box-content"> <div class="border-box-content">
@@ -21,13 +26,50 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox7', name: 'DvBorderBox7',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () { data () {
return { return {
ref: 'border-box-7' ref: 'border-box-7',
defaultColor: ['rgba(128,128,128,0.3)', 'rgba(128,128,128,0.5)'],
mergedColor: []
} }
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -4,7 +4,7 @@
<defs> <defs>
<path <path
:id="path" :id="path"
:d="`M2.5, 2.5 L${width - 2.5}, 2.5 L${width - 2.5}, ${height - 2.5} L2.5, ${height - 2.5} L2.5, 2.5`" :d="pathD"
fill="transparent" fill="transparent"
/> />
<radialGradient <radialGradient
@@ -24,8 +24,8 @@
<mask :id="mask"> <mask :id="mask">
<circle cx="0" cy="0" r="150" :fill="`url(#${gradient})`"> <circle cx="0" cy="0" r="150" :fill="`url(#${gradient})`">
<animateMotion <animateMotion
dur="3s" :dur="`${dur}s`"
:path="`M2.5, 2.5 L${width - 2.5}, 2.5 L${width - 2.5}, ${height - 2.5} L2.5, ${height - 2.5} L2.5, 2.5`" :path="pathD"
rotate="auto" rotate="auto"
repeatCount="indefinite" repeatCount="indefinite"
/> />
@@ -33,14 +33,16 @@
</mask> </mask>
</defs> </defs>
<polygon :fill="backgroundColor" :points="`5, 5 ${width - 5}, 5 ${width - 5} ${height - 5} 5, ${height - 5}`" />
<use <use
stroke="#235fa7" :stroke="mergedColor[0]"
stroke-width="1" stroke-width="1"
:xlink:href="`#${path}`" :xlink:href="`#${path}`"
/> />
<use <use
stroke="#4fd2dd" :stroke="mergedColor[1]"
stroke-width="3" stroke-width="3"
:xlink:href="`#${path}`" :xlink:href="`#${path}`"
:mask="`url(#${mask})`" :mask="`url(#${mask})`"
@@ -49,7 +51,7 @@
attributeName="stroke-dasharray" attributeName="stroke-dasharray"
:from="`0, ${length}`" :from="`0, ${length}`"
:to="`${length}, 0`" :to="`${length}, 0`"
dur="3s" :dur="`${dur}s`"
repeatCount="indefinite" repeatCount="indefinite"
/> />
</use> </use>
@@ -63,16 +65,44 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { uuid } from '../../../util/index'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox8', name: 'DvBorderBox8',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
dur: {
type: Number,
default: 3
},
backgroundColor: {
type: String,
default: 'transparent'
},
reverse: {
type: Boolean,
default: false
}
},
data () { data () {
const id = uuid()
return { return {
ref: 'border-box-8', ref: 'border-box-8',
path: `border-box-8-path-${(new Date()).getTime()}`, path: `border-box-8-path-${id}`,
gradient: `border-box-8-gradient-${(new Date()).getTime()}`, gradient: `border-box-8-gradient-${id}`,
mask: `border-box-8-mask-${(new Date()).getTime()}` mask: `border-box-8-mask-${id}`,
defaultColor: ['#235fa7', '#4fd2dd'],
mergedColor: []
} }
}, },
computed: { computed: {
@@ -80,7 +110,33 @@ export default {
const { width, height } = this const { width, height } = this
return (width + height - 5) * 2 return (width + height - 5) * 2
},
pathD () {
const { reverse, width, height } = this
if (reverse) return `M 2.5, 2.5 L 2.5, ${height - 2.5} L ${width - 2.5}, ${height - 2.5} L ${width - 2.5}, 2.5 L 2.5, 2.5`
return `M2.5, 2.5 L${width - 2.5}, 2.5 L${width - 2.5}, ${height - 2.5} L2.5, ${height - 2.5} L2.5, 2.5`
} }
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -3,8 +3,40 @@
<svg class="dv-svg-container" :width="width" :height="height"> <svg class="dv-svg-container" :width="width" :height="height">
<defs> <defs>
<linearGradient :id="gradientId" x1="0%" y1="0%" x2="100%" y2="100%"> <linearGradient :id="gradientId" x1="0%" y1="0%" x2="100%" y2="100%">
<stop offset="0%" stop-color="#11eefd" /> <animate
<stop offset="100%" stop-color="#0078d2" /> attributeName="x1"
values="0%;100%;0%"
dur="10s"
begin="0s"
repeatCount="indefinite"
/>
<animate
attributeName="x2"
values="100%;0%;100%"
dur="10s"
begin="0s"
repeatCount="indefinite"
/>
<stop offset="0%" :stop-color="mergedColor[0]">
<animate
attributeName="stop-color"
:values="`${mergedColor[0]};${mergedColor[1]};${mergedColor[0]}`"
dur="10s"
begin="0s"
repeatCount="indefinite"
/>
</stop>
<stop offset="100%" :stop-color="mergedColor[1]">
<animate
attributeName="stop-color"
:values="`${mergedColor[1]};${mergedColor[0]};${mergedColor[1]}`"
dur="10s"
begin="0s"
repeatCount="indefinite"
/>
</stop>
</linearGradient> </linearGradient>
<mask :id="maskId"> <mask :id="maskId">
@@ -73,6 +105,15 @@
</mask> </mask>
</defs> </defs>
<polygon :fill="backgroundColor" :points="`
15, 9 ${width * 0.1 + 1}, 9 ${width * 0.1 + 4}, 6 ${width * 0.52 + 2}, 6
${width * 0.52 + 6}, 10 ${width * 0.58 - 7}, 10 ${width * 0.58 - 2}, 6
${width * 0.9 + 2}, 6 ${width * 0.9 + 6}, 10 ${width - 10}, 10 ${width - 10}, ${height * 0.1 - 6}
${width - 6}, ${height * 0.1 - 1} ${width - 6}, ${height * 0.8 + 1} ${width - 10}, ${height * 0.8 + 6}
${width - 10}, ${height - 10} ${width * 0.92 + 7}, ${height - 10} ${width * 0.92 + 2}, ${height - 6}
11, ${height - 6} 11, ${height * 0.15 - 2} 15, ${height * 0.15 - 7}
`" />
<rect x="0" y="0" :width="width" :height="height" :fill="`url(#${gradientId})`" :mask="`url(#${maskId})`" /> <rect x="0" y="0" :width="width" :height="height" :fill="`url(#${gradientId})`" :mask="`url(#${maskId})`" />
</svg> </svg>
@@ -84,17 +125,56 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { uuid } from '../../../util/index'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox9', name: 'DvBorderBox9',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () { data () {
const id = uuid()
return { return {
ref: 'border-box-9', ref: 'border-box-9',
gradientId: `border-box-9-gradient-${(new Date()).getTime()}`, gradientId: `border-box-9-gradient-${id}`,
maskId: `border-box-9-mask-${(new Date()).getTime()}` maskId: `border-box-9-mask-${id}`,
defaultColor: ['#11eefd', '#0078d2'],
mergedColor: []
} }
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -31,19 +31,27 @@
margin: 5px 0px; margin: 5px 0px;
border-radius: 5px; border-radius: 5px;
} }
.dv-capsule-chart .capsule-item div { .dv-capsule-chart .capsule-item .capsule-item-column {
position: relative;
height: 8px; height: 8px;
margin-top: 1px; margin-top: 1px;
border-radius: 5px; border-radius: 5px;
transition: all 0.3s; transition: all 0.3s;
display: flex;
justify-content: flex-end;
align-items: center;
}
.dv-capsule-chart .capsule-item .capsule-item-column .capsule-item-value {
font-size: 12px;
transform: translateX(100%);
} }
.dv-capsule-chart .unit-label { .dv-capsule-chart .unit-label {
height: 20px; height: 20px;
font-size: 12px; font-size: 12px;
position: relative;
display: flex; display: flex;
flex-direction: row;
align-items: center;
justify-content: space-between; justify-content: space-between;
align-items: center;
} }
.dv-capsule-chart .unit-text { .dv-capsule-chart .unit-text {
text-align: right; text-align: right;

View File

@@ -7,16 +7,23 @@
</div> </div>
<div class="capsule-container"> <div class="capsule-container">
<div <div class="capsule-item" v-for="(capsule, index) in capsuleLength" :key="index">
class="capsule-item" <div
v-for="(capsule, index) in capsuleLength" class="capsule-item-column"
:key="index" :style="`width: ${capsule * 100}%; background-color: ${mergedConfig.colors[index % mergedConfig.colors.length]};`"
> >
<div :style="`width: ${capsule * 100}%; background-color: ${mergedConfig.colors[index % mergedConfig.colors.length]};`"></div> <div
v-if="mergedConfig.showValue"
class="capsule-item-value"
>{{ capsuleValue[index] }}</div>
</div>
</div> </div>
<div class="unit-label"> <div class="unit-label">
<div v-for="(label, index) in labelData" :key="label + index">{{ label }}</div> <div
v-for="(label, index) in labelData"
:key="label + index"
>{{ label }}</div>
</div> </div>
</div> </div>
@@ -38,7 +45,7 @@ export default {
default: () => ({}) default: () => ({})
} }
}, },
data () { data() {
return { return {
defaultConfig: { defaultConfig: {
/** /**
@@ -54,42 +61,61 @@ export default {
* @default color = ['#37a2da', '#32c5e9', '#67e0e3', '#9fe6b8', '#ffdb5c', '#ff9f7f', '#fb7293'] * @default color = ['#37a2da', '#32c5e9', '#67e0e3', '#9fe6b8', '#ffdb5c', '#ff9f7f', '#fb7293']
* @example color = ['#000', 'rgb(0, 0, 0)', 'rgba(0, 0, 0, 1)', 'red'] * @example color = ['#000', 'rgb(0, 0, 0)', 'rgba(0, 0, 0, 1)', 'red']
*/ */
colors: ['#37a2da', '#32c5e9', '#67e0e3', '#9fe6b8', '#ffdb5c', '#ff9f7f', '#fb7293'], colors: [
'#37a2da',
'#32c5e9',
'#67e0e3',
'#9fe6b8',
'#ffdb5c',
'#ff9f7f',
'#fb7293'
],
/** /**
* @description Chart unit * @description Chart unit
* @type {String} * @type {String}
* @default unit = '' * @default unit = ''
*/ */
unit: '' unit: '',
/**
* @description Show item value
* @type {Boolean}
* @default showValue = false
*/
showValue: false
}, },
mergedConfig: null, mergedConfig: null,
capsuleLength: [], capsuleLength: [],
labelData: [] capsuleValue: [],
labelData: [],
labelDataLength: []
} }
}, },
watch: { watch: {
config () { config() {
const { calcData } = this const { calcData } = this
calcData() calcData()
} }
}, },
methods: { methods: {
calcData () { calcData() {
const { mergeConfig, calcCapsuleLengthAndLabelData } = this const { mergeConfig, calcCapsuleLengthAndLabelData } = this
mergeConfig() mergeConfig()
calcCapsuleLengthAndLabelData() calcCapsuleLengthAndLabelData()
}, },
mergeConfig () { mergeConfig() {
let { config, defaultConfig } = this let { config, defaultConfig } = this
this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {}) this.mergedConfig = deepMerge(
deepClone(defaultConfig, true),
config || {}
)
}, },
calcCapsuleLengthAndLabelData () { calcCapsuleLengthAndLabelData() {
const { data } = this.mergedConfig const { data } = this.mergedConfig
if (!data.length) return if (!data.length) return
@@ -98,14 +124,24 @@ export default {
const maxValue = Math.max(...capsuleValue) const maxValue = Math.max(...capsuleValue)
this.capsuleLength = capsuleValue.map(v => maxValue ? v / maxValue : 0) this.capsuleValue = capsuleValue
this.capsuleLength = capsuleValue.map(v => (maxValue ? v / maxValue : 0))
const oneFifth = maxValue / 5 const oneFifth = maxValue / 5
this.labelData = new Array(6).fill(0).map((v, i) => Math.ceil(i * oneFifth)) const labelData = Array.from(
new Set(new Array(6).fill(0).map((v, i) => Math.ceil(i * oneFifth)))
)
this.labelData = labelData
this.labelDataLength = Array.from(labelData).map(v =>
maxValue ? v / maxValue : 0
)
} }
}, },
mounted () { mounted() {
const { calcData } = this const { calcData } = this
calcData() calcData()

View File

@@ -5,6 +5,8 @@
</template> </template>
<script> <script>
import { uuid } from '../../../util/index'
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import Charts from '@jiaminghi/charts' import Charts from '@jiaminghi/charts'
@@ -19,9 +21,10 @@ export default {
} }
}, },
data () { data () {
const id = uuid()
return { return {
ref: `charts-container-${(new Date()).getTime()}`, ref: `charts-container-${id}`,
chartRef: `chart-${(new Date()).getTime()}`, chartRef: `chart-${id}`,
chart: null chart: null
} }
@@ -34,7 +37,7 @@ export default {
if (!option) option = {} if (!option) option = {}
chart.setOption(option) chart.setOption(option, true)
} }
}, },
methods: { methods: {

View File

@@ -8,7 +8,7 @@
<rect <rect
v-if="Math.random() > 0.6" v-if="Math.random() > 0.6"
:key="i" :key="i"
fill="#fff" :fill="mergedColor[0]"
:x="point[0] - halfPointSideLength" :x="point[0] - halfPointSideLength"
:y="point[1] - halfPointSideLength" :y="point[1] - halfPointSideLength"
:width="pointSideLength" :width="pointSideLength"
@@ -17,7 +17,7 @@
<animate <animate
v-if="Math.random() > 0.6" v-if="Math.random() > 0.6"
attributeName="fill" attributeName="fill"
values="#fff;transparent" :values="`${mergedColor[0]};transparent`"
dur="1s" dur="1s"
:begin="Math.random() * 2" :begin="Math.random() * 2"
repeatCount="indefinite" repeatCount="indefinite"
@@ -27,7 +27,7 @@
<rect <rect
v-if="rects[0]" v-if="rects[0]"
fill="#0de7c2" :fill="mergedColor[1]"
:x="rects[0][0] - pointSideLength" :x="rects[0][0] - pointSideLength"
:y="rects[0][1] - pointSideLength" :y="rects[0][1] - pointSideLength"
:width="pointSideLength * 2" :width="pointSideLength * 2"
@@ -61,7 +61,7 @@
<rect <rect
v-if="rects[1]" v-if="rects[1]"
fill="#0de7c2" :fill="mergedColor[1]"
:x="rects[1][0] - 40" :x="rects[1][0] - 40"
:y="rects[1][1] - pointSideLength" :y="rects[1][1] - pointSideLength"
:width="40" :width="40"
@@ -87,9 +87,19 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvDecoration1', name: 'DvDecoration1',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
}
},
data () { data () {
const pointSideLength = 2.5 const pointSideLength = 2.5
@@ -108,7 +118,18 @@ export default {
points: [], points: [],
rects: [] rects: [],
defaultColor: ['#fff', '#0de7c2'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
} }
}, },
methods: { methods: {
@@ -160,7 +181,17 @@ export default {
const { calcSVGData } = this const { calcSVGData } = this
calcSVGData() calcSVGData()
},
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
} }
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -2,13 +2,13 @@
<div class="dv-decoration-10" :ref="ref"> <div class="dv-decoration-10" :ref="ref">
<svg :width="width" :height="height"> <svg :width="width" :height="height">
<polyline <polyline
stroke="rgba(0, 194, 255, 0.3)" :stroke="mergedColor[1]"
stroke-width="2" stroke-width="2"
:points="`0, ${height / 2} ${width}, ${height / 2}`" :points="`0, ${height / 2} ${width}, ${height / 2}`"
/> />
<polyline <polyline
stroke="rgba(0, 194, 255, 1)" :stroke="mergedColor[0]"
stroke-width="2" stroke-width="2"
:points="`5, ${height / 2} ${width * 0.2 - 3}, ${height / 2}`" :points="`5, ${height / 2} ${width * 0.2 - 3}, ${height / 2}`"
:stroke-dasharray="`0, ${width * 0.2}`" :stroke-dasharray="`0, ${width * 0.2}`"
@@ -32,7 +32,7 @@
</polyline> </polyline>
<polyline <polyline
stroke="rgba(0, 194, 255, 1)" :stroke="mergedColor[0]"
stroke-width="2" stroke-width="2"
:points="`${width * 0.2 + 3}, ${height / 2} ${width * 0.8 - 3}, ${height / 2}`" :points="`${width * 0.2 + 3}, ${height / 2} ${width * 0.8 - 3}, ${height / 2}`"
:stroke-dasharray="`0, ${width * 0.6}`" :stroke-dasharray="`0, ${width * 0.6}`"
@@ -55,7 +55,7 @@
</polyline> </polyline>
<polyline <polyline
stroke="rgba(0, 194, 255, 1)" :stroke="mergedColor[0]"
stroke-width="2" stroke-width="2"
:points="`${width * 0.8 + 3}, ${height / 2} ${width - 5}, ${height / 2}`" :points="`${width * 0.8 + 3}, ${height / 2} ${width - 5}, ${height / 2}`"
:stroke-dasharray="`0, ${width * 0.2}`" :stroke-dasharray="`0, ${width * 0.2}`"
@@ -77,65 +77,65 @@
/> />
</polyline> </polyline>
<circle cx="2" :cy="height / 2" r="2" fill="#03709f"> <circle cx="2" :cy="height / 2" r="2" :fill="mergedColor[1]">
<animate <animate
:id="animationId1" :id="animationId1"
attributeName="fill" attributeName="fill"
values="#03709f;#00c2ff" :values="`${mergedColor[1]};${mergedColor[0]}`"
:begin="`0s;${animationId7}.end`" :begin="`0s;${animationId7}.end`"
dur="0.3s" dur="0.3s"
fill="freeze" fill="freeze"
/> />
</circle> </circle>
<circle :cx="width * 0.2" :cy="height / 2" r="2" fill="#03709f"> <circle :cx="width * 0.2" :cy="height / 2" r="2" :fill="mergedColor[1]">
<animate <animate
:id="animationId3" :id="animationId3"
attributeName="fill" attributeName="fill"
values="#03709f;#00c2ff" :values="`${mergedColor[1]};${mergedColor[0]}`"
:begin="`${animationId2}.end`" :begin="`${animationId2}.end`"
dur="0.3s" dur="0.3s"
fill="freeze" fill="freeze"
/> />
<animate <animate
attributeName="fill" attributeName="fill"
values="#03709f;#03709f" :values="`${mergedColor[1]};${mergedColor[1]}`"
dur="0.01s" dur="0.01s"
:begin="`${animationId7}.end`" :begin="`${animationId7}.end`"
fill="freeze" fill="freeze"
/> />
</circle> </circle>
<circle :cx="width * 0.8" :cy="height / 2" r="2" fill="#03709f"> <circle :cx="width * 0.8" :cy="height / 2" r="2" :fill="mergedColor[1]">
<animate <animate
:id="animationId5" :id="animationId5"
attributeName="fill" attributeName="fill"
values="#03709f;#00c2ff" :values="`${mergedColor[1]};${mergedColor[0]}`"
:begin="`${animationId4}.end`" :begin="`${animationId4}.end`"
dur="0.3s" dur="0.3s"
fill="freeze" fill="freeze"
/> />
<animate <animate
attributeName="fill" attributeName="fill"
values="#03709f;#03709f" :values="`${mergedColor[1]};${mergedColor[1]}`"
dur="0.01s" dur="0.01s"
:begin="`${animationId7}.end`" :begin="`${animationId7}.end`"
fill="freeze" fill="freeze"
/> />
</circle> </circle>
<circle :cx="width - 2" :cy="height / 2" r="2" fill="#03709f"> <circle :cx="width - 2" :cy="height / 2" r="2" :fill="mergedColor[1]">
<animate <animate
:id="animationId7" :id="animationId7"
attributeName="fill" attributeName="fill"
values="#03709f;#00c2ff" :values="`${mergedColor[1]};${mergedColor[0]}`"
:begin="`${animationId6}.end`" :begin="`${animationId6}.end`"
dur="0.3s" dur="0.3s"
fill="freeze" fill="freeze"
/> />
<animate <animate
attributeName="fill" attributeName="fill"
values="#03709f;#03709f" :values="`${mergedColor[1]};${mergedColor[1]}`"
dur="0.01s" dur="0.01s"
:begin="`${animationId7}.end`" :begin="`${animationId7}.end`"
fill="freeze" fill="freeze"
@@ -147,22 +147,57 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { uuid } from '../../../util/index'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvDecoration10', name: 'DvDecoration10',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
}
},
data () { data () {
const id = uuid()
return { return {
ref: 'decoration-10', ref: 'decoration-10',
animationId1: `d10ani1${(new Date()).getTime()}`, animationId1: `d10ani1${id}`,
animationId2: `d10ani2${(new Date()).getTime()}`, animationId2: `d10ani2${id}`,
animationId3: `d10ani3${(new Date()).getTime()}`, animationId3: `d10ani3${id}`,
animationId4: `d10ani4${(new Date()).getTime()}`, animationId4: `d10ani4${id}`,
animationId5: `d10ani5${(new Date()).getTime()}`, animationId5: `d10ani5${id}`,
animationId6: `d10ani6${(new Date()).getTime()}`, animationId6: `d10ani6${id}`,
animationId7: `d10ani7${(new Date()).getTime()}` animationId7: `d10ani7${id}`,
defaultColor: ['#00c2ff', 'rgba(0, 194, 255, 0.3)'],
mergedColor: []
} }
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

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

View File

@@ -0,0 +1,16 @@
.dv-decoration-11 {
position: relative;
width: 100%;
height: 100%;
display: flex;
}
.dv-decoration-11 .decoration-content {
position: absolute;
top: 0px;
left: 0px;
width: 100%;
height: 100%;
display: flex;
align-items: center;
justify-content: center;
}

View File

@@ -0,0 +1,104 @@
<template>
<div class="dv-decoration-11" :ref="ref">
<svg :width="width" :height="height">
<polygon
:fill="fade(mergedColor[1] || defaultColor[1], 10)"
:stroke="mergedColor[1]"
:points="`20 10, 25 4, 55 4 60 10`"
/>
<polygon
:fill="fade(mergedColor[1] || defaultColor[1], 10)"
:stroke="mergedColor[1]"
:points="`20 ${height - 10}, 25 ${height - 4}, 55 ${height - 4} 60 ${height - 10}`"
/>
<polygon
:fill="fade(mergedColor[1] || defaultColor[1], 10)"
:stroke="mergedColor[1]"
:points="`${width - 20} 10, ${width - 25} 4, ${width - 55} 4 ${width - 60} 10`"
/>
<polygon
:fill="fade(mergedColor[1] || defaultColor[1], 10)"
:stroke="mergedColor[1]"
:points="`${width - 20} ${height - 10}, ${width - 25} ${height - 4}, ${width - 55} ${height - 4} ${width - 60} ${height - 10}`"
/>
<polygon
:fill="fade(mergedColor[0] || defaultColor[0], 20)"
:stroke="mergedColor[0]"
:points="`
20 10, 5 ${height / 2} 20 ${height - 10}
${width - 20} ${height - 10} ${width - 5} ${height / 2} ${width - 20} 10
`"
/>
<polyline
fill="transparent"
:stroke="fade(mergedColor[0] || defaultColor[0], 70)"
:points="`25 18, 15 ${height / 2} 25 ${height - 18}`"
/>
<polyline
fill="transparent"
:stroke="fade(mergedColor[0] || defaultColor[0], 70)"
:points="`${width - 25} 18, ${width - 15} ${height / 2} ${width - 25} ${height - 18}`"
/>
</svg>
<div class="decoration-content">
<slot></slot>
</div>
</div>
</template>
<script>
import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
import { fade } from '@jiaminghi/color'
export default {
name: 'DvDecoration11',
mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
}
},
data () {
return {
ref: 'decoration-11',
defaultColor: ['#1a98fc', '#2cf7fe'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
},
fade
},
mounted () {
const { mergeColor } = this
mergeColor()
}
}
</script>

View File

@@ -1,7 +1,7 @@
<template> <template>
<div class="dv-decoration-2" :ref="ref"> <div class="dv-decoration-2" :ref="ref">
<svg :width="`${width}px`" :height="`${height}px`"> <svg :width="`${width}px`" :height="`${height}px`">
<rect :x="x" :y="y" :width="w" :height="h" fill="#3faacb"> <rect :x="x" :y="y" :width="w" :height="h" :fill="mergedColor[0]">
<animate <animate
:attributeName="reverse ? 'height' : 'width'" :attributeName="reverse ? 'height' : 'width'"
from="0" from="0"
@@ -14,7 +14,7 @@
/> />
</rect> </rect>
<rect :x="x" :y="y" width="1" height="1" fill="#fff"> <rect :x="x" :y="y" width="1" height="1" :fill="mergedColor[1]">
<animate <animate
:attributeName="reverse ? 'y' : 'x'" :attributeName="reverse ? 'y' : 'x'"
from="0" from="0"
@@ -33,10 +33,18 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvDecoration2', name: 'DvDecoration2',
mixins: [autoResize], mixins: [autoResize],
props: { props: {
color: {
type: Array,
default: () => ([])
},
reverse: { reverse: {
type: Boolean, type: Boolean,
default: false default: false
@@ -50,10 +58,19 @@ export default {
y: 0, y: 0,
w: 0, w: 0,
h: 0 h: 0,
defaultColor: ['#3faacb', '#fff'],
mergedColor: []
} }
}, },
watch: { watch: {
color () {
const { mergeColor } = this
mergeColor()
},
reverse () { reverse () {
const { calcSVGData } = this const { calcSVGData } = this
@@ -85,7 +102,17 @@ export default {
const { calcSVGData } = this const { calcSVGData } = this
calcSVGData() calcSVGData()
},
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
} }
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -7,7 +7,7 @@
> >
<rect <rect
:key="i" :key="i"
fill="#7acaec" :fill="mergedColor[0]"
:x="point[0] - halfPointSideLength" :x="point[0] - halfPointSideLength"
:y="point[1] - halfPointSideLength" :y="point[1] - halfPointSideLength"
:width="pointSideLength" :width="pointSideLength"
@@ -16,7 +16,7 @@
<animate <animate
v-if="Math.random() > 0.6" v-if="Math.random() > 0.6"
attributeName="fill" attributeName="fill"
values="#7acaec;transparent" :values="`${mergedColor.join(';')}`"
:dur="Math.random() + 1 + 's'" :dur="Math.random() + 1 + 's'"
:begin="Math.random() * 2" :begin="Math.random() * 2"
repeatCount="indefinite" repeatCount="indefinite"
@@ -30,9 +30,19 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvDecoration3', name: 'DvDecoration3',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
}
},
data () { data () {
const pointSideLength = 7 const pointSideLength = 7
@@ -49,7 +59,18 @@ export default {
pointSideLength, pointSideLength,
halfPointSideLength: pointSideLength / 2, halfPointSideLength: pointSideLength / 2,
points: [] points: [],
defaultColor: ['#7acaec', 'transparent'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
} }
}, },
methods: { methods: {
@@ -91,7 +112,17 @@ export default {
const { calcSVGData } = this const { calcSVGData } = this
calcSVGData() calcSVGData()
},
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
} }
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -7,20 +7,22 @@
display: flex; display: flex;
overflow: hidden; overflow: hidden;
position: absolute; position: absolute;
flex: 1;
} }
.dv-decoration-4 .normal { .dv-decoration-4 .normal {
height: 0% !important;
animation: ani-height 3s ease-in-out infinite; animation: ani-height 3s ease-in-out infinite;
left: 50%; left: 50%;
margin-left: -2px; margin-left: -2px;
} }
.dv-decoration-4 .reverse { .dv-decoration-4 .reverse {
width: 0% !important;
animation: ani-width 3s ease-in-out infinite; animation: ani-width 3s ease-in-out infinite;
top: 50%; top: 50%;
margin-top: -2px; margin-top: -2px;
} }
@keyframes ani-height { @keyframes ani-height {
0% {
height: 0%;
}
70% { 70% {
height: 100%; height: 100%;
} }
@@ -29,6 +31,9 @@
} }
} }
@keyframes ani-width { @keyframes ani-width {
0% {
width: 0%;
}
70% { 70% {
width: 100%; width: 100%;
} }

View File

@@ -6,12 +6,12 @@
> >
<svg :width="reverse ? width : 5" :height="reverse ? 5 : height"> <svg :width="reverse ? width : 5" :height="reverse ? 5 : height">
<polyline <polyline
stroke="rgba(255, 255, 255, 0.3)" :stroke="mergedColor[0]"
:points="reverse ? `0, 2.5 ${width}, 2.5` : `2.5, 0 2.5, ${height}`" :points="reverse ? `0, 2.5 ${width}, 2.5` : `2.5, 0 2.5, ${height}`"
/> />
<polyline <polyline
class="bold-line" class="bold-line"
stroke="rgba(255, 255, 255, 0.3)" :stroke="mergedColor[1]"
stroke-width="3" stroke-width="3"
stroke-dasharray="20, 80" stroke-dasharray="20, 80"
stroke-dashoffset="-30" stroke-dashoffset="-30"
@@ -25,14 +25,50 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvDecoration4', name: 'DvDecoration4',
mixins: [autoResize], mixins: [autoResize],
props: ['reverse'], props: {
color: {
type: Array,
default: () => ([])
},
reverse: {
type: Boolean,
default: false
}
},
data () { data () {
return { return {
ref: 'decoration-4' ref: 'decoration-4',
defaultColor: ['rgba(255, 255, 255, 0.3)', 'rgba(255, 255, 255, 0.3)'],
mergedColor: []
} }
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -3,7 +3,7 @@
<svg :width="width" :height="height"> <svg :width="width" :height="height">
<polyline <polyline
fill="transparent" fill="transparent"
stroke="#3f96a5" :stroke="mergedColor[0]"
stroke-width="3" stroke-width="3"
:points="line1Points" :points="line1Points"
> >
@@ -22,7 +22,7 @@
</polyline> </polyline>
<polyline <polyline
fill="transparent" fill="transparent"
stroke="#3f96a5" :stroke="mergedColor[1]"
stroke-width="2" stroke-width="2"
:points="line2Points" :points="line2Points"
> >
@@ -48,9 +48,19 @@ import autoResize from '../../../mixin/autoResize'
import { getPolylineLength } from '@jiaminghi/charts/lib/util' import { getPolylineLength } from '@jiaminghi/charts/lib/util'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvDecoration5', name: 'DvDecoration5',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
}
},
data () { data () {
return { return {
ref: 'decoration-5', ref: 'decoration-5',
@@ -59,7 +69,18 @@ export default {
line2Points: '', line2Points: '',
line1Length: 0, line1Length: 0,
line2Length: 0 line2Length: 0,
defaultColor: ['#3f96a5', '#3f96a5'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
} }
}, },
methods: { methods: {
@@ -97,7 +118,17 @@ export default {
const { calcSVGData } = this const { calcSVGData } = this
calcSVGData() calcSVGData()
},
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
} }
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -6,7 +6,7 @@
> >
<rect <rect
:key="i" :key="i"
fill="#7acaec" :fill="mergedColor[Math.random() > 0.5 ? 0 : 1]"
:x="point[0] - halfRectWidth" :x="point[0] - halfRectWidth"
:y="point[1] - heights[i] / 2" :y="point[1] - heights[i] / 2"
:width="rectWidth" :width="rectWidth"
@@ -43,9 +43,19 @@ import autoResize from '../../../mixin/autoResize'
import { randomExtend } from '../../../util' import { randomExtend } from '../../../util'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvDecoration6', name: 'DvDecoration6',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
}
},
data () { data () {
const rectWidth = 7 const rectWidth = 7
@@ -65,7 +75,18 @@ export default {
points: [], points: [],
heights: [], heights: [],
minHeights: [], minHeights: [],
randoms: [] randoms: [],
defaultColor: ['#7acaec', '#7acaec'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
} }
}, },
methods: { methods: {
@@ -116,7 +137,17 @@ export default {
const { calcSVGData } = this const { calcSVGData } = this
calcSVGData() calcSVGData()
},
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
} }
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -4,13 +4,13 @@
<polyline <polyline
stroke-width="4" stroke-width="4"
fill="transparent" fill="transparent"
stroke="#1dc1f5" :stroke="mergedColor[0]"
points="10, 0 19, 10 10, 20" points="10, 0 19, 10 10, 20"
/> />
<polyline <polyline
stroke-width="2" stroke-width="2"
fill="transparent" fill="transparent"
stroke="#1dc1f5" :stroke="mergedColor[1]"
points="2, 0 11, 10 2, 20" points="2, 0 11, 10 2, 20"
/> />
</svg> </svg>
@@ -19,13 +19,13 @@
<polyline <polyline
stroke-width="4" stroke-width="4"
fill="transparent" fill="transparent"
stroke="#1dc1f5" :stroke="mergedColor[0]"
points="11, 0 2, 10 11, 20" points="11, 0 2, 10 11, 20"
/> />
<polyline <polyline
stroke-width="2" stroke-width="2"
fill="transparent" fill="transparent"
stroke="#1dc1f5" :stroke="mergedColor[1]"
points="19, 0 10, 10 19, 20" points="19, 0 10, 10 19, 20"
/> />
</svg> </svg>
@@ -33,7 +33,43 @@
</template> </template>
<script> <script>
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvDecoration7' name: 'DvDecoration7',
props: {
color: {
type: Array,
default: () => ([])
}
},
data () {
return {
defaultColor: ['#1dc1f5', '#1dc1f5'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
}
} }
</script> </script>

View File

@@ -2,21 +2,21 @@
<div class="dv-decoration-8" :ref="ref"> <div class="dv-decoration-8" :ref="ref">
<svg :width="width" :height="height"> <svg :width="width" :height="height">
<polyline <polyline
stroke="#3f96a5" :stroke="mergedColor[0]"
stroke-width="2" stroke-width="2"
fill="transparent" fill="transparent"
:points="`${xPos(0)}, 0 ${xPos(30)}, ${height / 2}`" :points="`${xPos(0)}, 0 ${xPos(30)}, ${height / 2}`"
/> />
<polyline <polyline
stroke="#3f96a5" :stroke="mergedColor[0]"
stroke-width="2" stroke-width="2"
fill="transparent" fill="transparent"
:points="`${xPos(20)}, 0 ${xPos(50)}, ${height / 2} ${xPos(width)}, ${height / 2}`" :points="`${xPos(20)}, 0 ${xPos(50)}, ${height / 2} ${xPos(width)}, ${height / 2}`"
/> />
<polyline <polyline
stroke="#3f96a5" :stroke="mergedColor[1]"
fill="transparent" fill="transparent"
stroke-width="3" stroke-width="3"
:points="`${xPos(0)}, ${height - 3}, ${xPos(200)}, ${height - 3}`" :points="`${xPos(0)}, ${height - 3}, ${xPos(200)}, ${height - 3}`"
@@ -28,10 +28,18 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvDecoration8', name: 'DvDecoration8',
mixins: [autoResize], mixins: [autoResize],
props: { props: {
color: {
type: Array,
default: () => ([])
},
reverse: { reverse: {
type: Boolean, type: Boolean,
default: false default: false
@@ -39,7 +47,18 @@ export default {
}, },
data () { data () {
return { return {
ref: 'decoration-8' ref: 'decoration-8',
defaultColor: ['#3f96a5', '#3f96a5'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
} }
}, },
methods: { methods: {
@@ -49,7 +68,17 @@ export default {
if (!reverse) return pos if (!reverse) return pos
return width - pos return width - pos
},
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
} }
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -10,7 +10,7 @@
cy="50" cy="50"
r="45" r="45"
fill="transparent" fill="transparent"
stroke="rgba(3, 166, 224, 0.5)" :stroke="mergedColor[1]"
stroke-width="10" stroke-width="10"
stroke-dasharray="80, 100, 30, 100" stroke-dasharray="80, 100, 30, 100"
> >
@@ -18,7 +18,7 @@
attributeName="transform" attributeName="transform"
type="rotate" type="rotate"
values="0 50 50;360 50 50" values="0 50 50;360 50 50"
dur="3s" :dur="`${dur}s`"
repeatCount="indefinite" repeatCount="indefinite"
/> />
</circle> </circle>
@@ -28,7 +28,7 @@
cy="50" cy="50"
r="45" r="45"
fill="transparent" fill="transparent"
stroke="rgba(3, 166, 224, 0.8)" :stroke="mergedColor[0]"
stroke-width="6" stroke-width="6"
stroke-dasharray="50, 66, 100, 66" stroke-dasharray="50, 66, 100, 66"
> >
@@ -36,7 +36,7 @@
attributeName="transform" attributeName="transform"
type="rotate" type="rotate"
values="0 50 50;-360 50 50" values="0 50 50;-360 50 50"
dur="3s" :dur="`${dur}s`"
repeatCount="indefinite" repeatCount="indefinite"
/> />
</circle> </circle>
@@ -46,7 +46,7 @@
cy="50" cy="50"
r="38" r="38"
fill="transparent" fill="transparent"
stroke="rgba(3, 166, 224, 0.2)" :stroke="fade(mergedColor[1] || defaultColor[1], 30)"
stroke-width="1" stroke-width="1"
stroke-dasharray="5, 1" stroke-dasharray="5, 1"
/> />
@@ -55,15 +55,15 @@
v-for="(foo, i) in new Array(20).fill(0)" v-for="(foo, i) in new Array(20).fill(0)"
:key="i" :key="i"
:xlink:href="`#${polygonId}`" :xlink:href="`#${polygonId}`"
stroke="rgba(3, 166, 224, 0.6)" :stroke="mergedColor[1]"
:fill="Math.random() > 0.4 ? 'transparent' : 'rgba(3, 166, 224, 0.8)'" :fill="Math.random() > 0.4 ? 'transparent' : mergedColor[0]"
> >
<animateTransform <animateTransform
attributeName="transform" attributeName="transform"
type="rotate" type="rotate"
values="0 50 50;360 50 50" values="0 50 50;360 50 50"
dur="3s" :dur="`${dur}s`"
:begin="`${i * 0.15}s`" :begin="`${i * dur / 20}s`"
repeatCount="indefinite" repeatCount="indefinite"
/> />
</use> </use>
@@ -73,7 +73,7 @@
cy="50" cy="50"
r="26" r="26"
fill="transparent" fill="transparent"
stroke="rgba(3, 166, 224, 0.2)" :stroke="fade(mergedColor[1] || defaultColor[1], 30)"
stroke-width="1" stroke-width="1"
stroke-dasharray="5, 1" stroke-dasharray="5, 1"
/> />
@@ -85,19 +85,48 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { uuid } from '../../../util/index'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
import { fade } from '@jiaminghi/color'
export default { export default {
name: 'DvDecoration9', name: 'DvDecoration9',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
dur: {
type: Number,
default: 3
}
},
data () { data () {
const id = uuid()
return { return {
ref: 'decoration-9', ref: 'decoration-9',
polygonId: `decoration-9-polygon-${(new Date()).getTime()}`, polygonId: `decoration-9-polygon-${id}`,
svgWH: [100, 100], svgWH: [100, 100],
svgScale: [1, 1] svgScale: [1, 1],
defaultColor: ['rgba(3, 166, 224, 0.8)', 'rgba(3, 166, 224, 0.5)'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
} }
}, },
methods: { methods: {
@@ -117,7 +146,18 @@ export default {
const { calcScale } = this const { calcScale } = this
calcScale() calcScale()
} },
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
},
fade
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -53,6 +53,12 @@ export default {
* @example textAlign = 'center' | 'left' | 'right' * @example textAlign = 'center' | 'left' | 'right'
*/ */
textAlign: 'center', textAlign: 'center',
/**
* @description rowGap
* @type {Number}
@default rowGap = 0
*/
rowGap: 0,
/** /**
* @description Text style configuration * @description Text style configuration
* @type {Object} {CRender Class Style} * @type {Object} {CRender Class Style}
@@ -61,6 +67,11 @@ export default {
fontSize: 30, fontSize: 30,
fill: '#3de7c9' fill: '#3de7c9'
}, },
/**
* @description Number formatter
* @type {Null|Function}
*/
formatter: undefined,
/** /**
* @description CRender animationCurve * @description CRender animationCurve
* @type {String} * @type {String}
@@ -124,7 +135,7 @@ export default {
}) })
}, },
getShape () { getShape () {
const { number, content, toFixed, textAlign } = this.mergedConfig const { number, content, toFixed, textAlign, rowGap, formatter } = this.mergedConfig
const [w, h] = this.renderer.area const [w, h] = this.renderer.area
@@ -137,7 +148,9 @@ export default {
number, number,
content, content,
toFixed, toFixed,
position position,
rowGap,
formatter
} }
}, },
getStyle () { getStyle () {
@@ -151,6 +164,8 @@ export default {
update () { update () {
const { mergeConfig, mergeShape, getShape, getStyle, graph, mergedConfig } = this const { mergeConfig, mergeShape, getShape, getStyle, graph, mergedConfig } = this
graph.animationEnd()
mergeConfig() mergeConfig()
if (!graph) return if (!graph) return

View File

@@ -153,7 +153,7 @@ import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util' import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
import { randomExtend, getPointDistance } from '../../../util/index' import { randomExtend, getPointDistance, uuid } from '../../../util/index'
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
@@ -171,13 +171,14 @@ export default {
} }
}, },
data () { data () {
const id = uuid()
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-${id}`,
maskCircleId: `mask-circle-id-${(new Date()).getTime()}`, maskCircleId: `mask-circle-id-${id}`,
gradientId: `gradient-id-${(new Date()).getTime()}`, gradientId: `gradient-id-${id}`,
gradient2Id: `gradient2-id-${(new Date()).getTime()}`, gradient2Id: `gradient2-id-${id}`,
defaultConfig: { defaultConfig: {
/** /**

View File

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

View File

@@ -0,0 +1,9 @@
.dv-flyline-chart-enhanced {
display: flex;
flex-direction: column;
background-size: 100% 100%;
}
.dv-flyline-chart-enhanced text {
text-anchor: middle;
dominant-baseline: middle;
}

View File

@@ -0,0 +1,566 @@
<template>
<div
class="dv-flyline-chart-enhanced"
:style="`background-image: url(${mergedConfig ? mergedConfig.bgImgSrc : ''})`"
:ref="ref"
@click="consoleClickPos"
>
<svg v-if="flylines.length" :width="width" :height="height">
<defs>
<radialGradient
:id="flylineGradientId"
cx="50%" cy="50%" r="50%"
>
<stop
offset="0%" stop-color="#fff"
stop-opacity="1"
/>
<stop
offset="100%" stop-color="#fff"
stop-opacity="0"
/>
</radialGradient>
<radialGradient
:id="haloGradientId"
cx="50%" cy="50%" r="50%"
>
<stop
offset="0%" stop-color="#fff"
stop-opacity="0"
/>
<stop
offset="100%" stop-color="#fff"
stop-opacity="1"
/>
</radialGradient>
</defs>
<!-- points -->
<g v-for="point in flylinePoints" :key="point.key + Math.random()">
<defs>
<circle
v-if="point.halo.show"
:id="`halo${unique}${point.key}`"
:cx="point.coordinate[0]"
:cy="point.coordinate[1]"
>
<animate
attributeName="r"
:values="`1;${point.halo.radius}`"
:dur="`${point.halo.time}s`"
repeatCount="indefinite"
/>
<animate
attributeName="opacity"
values="1;0"
:dur="`${point.halo.time}s`"
repeatCount="indefinite"
/>
</circle>
</defs>
<!-- halo gradient mask -->
<mask :id="`mask${unique}${point.key}`">
<use
v-if="point.halo.show"
:xlink:href="`#halo${unique}${point.key}`"
:fill="`url(#${haloGradientId})`"
/>
</mask>
<!-- point halo -->
<use
v-if="point.halo.show"
:xlink:href="`#halo${unique}${point.key}`"
:fill="point.halo.color"
:mask="`url(#mask${unique}${point.key})`"
/>
<!-- point icon -->
<image
v-if="point.icon.show"
:xlink:href="point.icon.src"
:width="point.icon.width"
:height="point.icon.height"
:x="point.icon.x"
:y="point.icon.y"
/>
<!-- point text -->
<text
v-if="point.text.show"
:style="`fontSize:${point.text.fontSize}px;color:${point.text.color}`"
:fill="point.text.color"
:x="point.text.x"
:y="point.text.y"
>
{{ point.name }}
</text>
</g>
<!-- flylines -->
<g v-for="(line, i) in flylines" :key="line.key + Math.random()">
<defs>
<path
:id="line.key"
:ref="line.key"
:d="line.d"
fill="transparent"
/>
</defs>
<!-- orbit line -->
<use
:xlink:href="`#${line.key}`"
:stroke-width="line.width"
:stroke="line.orbitColor"
/>
<!-- fly line gradient mask -->
<mask :id="`mask${unique}${line.key}`">
<circle cx="0" cy="0" :r="line.radius" :fill="`url(#${flylineGradientId})`">
<animateMotion
:dur="line.time"
:path="line.d"
rotate="auto"
repeatCount="indefinite"
/>
</circle>
</mask>
<!-- fly line -->
<use
v-if="flylineLengths[i]"
:xlink:href="`#${line.key}`"
:stroke-width="line.width"
:stroke="line.color"
:mask="`url(#mask${unique}${line.key})`"
>
<animate
attributeName="stroke-dasharray"
:from="`0, ${flylineLengths[i]}`"
:to="`${flylineLengths[i]}, 0`"
:dur="line.time"
repeatCount="indefinite"
/>
</use>
</g>
</svg>
</div>
</template>
<script>
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
import { randomExtend, getPointDistance, uuid } from '../../../util/index'
import autoResize from '../../../mixin/autoResize'
export default {
name: 'DvFlylineChartEnhanced',
mixins: [autoResize],
props: {
config: {
type: Object,
default: () => ({})
},
dev: {
type: Boolean,
default: false
}
},
data () {
const id = uuid()
return {
ref: 'dv-flyline-chart-enhanced',
unique: Math.random(),
flylineGradientId: `flyline-gradient-id-${id}`,
haloGradientId: `halo-gradient-id-${id}`,
/**
* @description Type Declaration
*
* interface Halo {
* show?: boolean
* duration?: [number, number]
* color?: string
* radius?: number
* }
*
* interface Text {
* show?: boolean
* offset?: [number, number]
* color?: string
* fontSize?: number
* }
*
* interface Icon {
* show?: boolean
* src?: string
* width?: number
* height?: number
* }
*
* interface Point {
* name: string
* coordinate: [number, number]
* halo?: Halo
* text?: Text
* icon?: Icon
* }
*
* interface Line {
* width?: number
* color?: string
* orbitColor?: string
* duration?: [number, number]
* radius?: string
* }
*
* interface Flyline extends Line {
* source: string
* target: string
* }
*
* interface FlylineWithPath extends Flyline {
* d: string
* path: [[number, number], [number, number], [number, number]]
* key: string
* }
*/
defaultConfig: {
/**
* @description Flyline chart points
* @type {Point[]}
* @default points = []
*/
points: [],
/**
* @description Lines
* @type {Flyline[]}
* @default lines = []
*/
lines: [],
/**
* @description Global halo configuration
* @type {Halo}
*/
halo: {
/**
* @description Whether to show halo
* @type {Boolean}
* @default show = false
*/
show: false,
/**
* @description Halo animation duration (1s = 10)
* @type {[number, number]}
*/
duration: [20, 30],
/**
* @description Halo color
* @type {String}
* @default color = '#fb7293'
*/
color: '#fb7293',
/**
* @description Halo radius
* @type {Number}
* @default radius = 120
*/
radius: 120
},
/**
* @description Global text configuration
* @type {Text}
*/
text: {
/**
* @description Whether to show text
* @type {Boolean}
* @default show = false
*/
show: false,
/**
* @description Text offset
* @type {[number, number]}
* @default offset = [0, 15]
*/
offset: [0, 15],
/**
* @description Text color
* @type {String}
* @default color = '#ffdb5c'
*/
color: '#ffdb5c',
/**
* @description Text font size
* @type {Number}
* @default fontSize = 12
*/
fontSize: 12
},
/**
* @description Global icon configuration
* @type {Icon}
*/
icon: {
/**
* @description Whether to show icon
* @type {Boolean}
* @default show = false
*/
show: false,
/**
* @description Icon src
* @type {String}
* @default src = ''
*/
src: '',
/**
* @description Icon width
* @type {Number}
* @default width = 15
*/
width: 15,
/**
* @description Icon height
* @type {Number}
* @default width = 15
*/
height: 15
},
/**
* @description Global line configuration
* @type {Line}
*/
line: {
/**
* @description Line width
* @type {Number}
* @default width = 1
*/
width: 1,
/**
* @description Flyline color
* @type {String}
* @default color = '#ffde93'
*/
color: '#ffde93',
/**
* @description Orbit color
* @type {String}
* @default orbitColor = 'rgba(103, 224, 227, .2)'
*/
orbitColor: 'rgba(103, 224, 227, .2)',
/**
* @description Flyline animation duration
* @type {[number, number]}
* @default duration = [20, 30]
*/
duration: [20, 30],
/**
* @description Flyline radius
* @type {Number}
* @default radius = 100
*/
radius: 100
},
/**
* @description Back ground image url
* @type {String}
* @default bgImgSrc = ''
*/
bgImgSrc: '',
/**
* @description K value
* @type {Number}
* @default k = -0.5
* @example k = -1 ~ 1
*/
k: -0.5,
/**
* @description Flyline curvature
* @type {Number}
* @default curvature = 5
*/
curvature: 5,
/**
* @description Relative points position
* @type {Boolean}
* @default relative = true
*/
relative: true
},
/**
* @description Fly line data
* @type {FlylineWithPath[]}
* @default flylines = []
*/
flylines: [],
/**
* @description Fly line lengths
* @type {Number[]}
* @default flylineLengths = []
*/
flylineLengths: [],
/**
* @description Fly line points
* @default flylinePoints = []
*/
flylinePoints: [],
mergedConfig: null
}
},
watch: {
config () {
const { calcData } = this
calcData()
}
},
methods: {
afterAutoResizeMixinInit () {
const { calcData } = this
calcData()
},
onResize () {
const { calcData } = this
calcData()
},
async calcData () {
const { mergeConfig, calcflylinePoints, calcLinePaths } = this
mergeConfig()
calcflylinePoints()
calcLinePaths()
const { calcLineLengths } = this
await calcLineLengths()
},
mergeConfig () {
let { config, defaultConfig } = this
const mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {})
const { points, lines, halo, text, icon, line } = mergedConfig
mergedConfig.points = points.map(item => {
item.halo = deepMerge(deepClone(halo, true), item.halo || {})
item.text = deepMerge(deepClone(text, true), item.text || {})
item.icon = deepMerge(deepClone(icon, true), item.icon || {})
return item
})
mergedConfig.lines = lines.map(item => {
return deepMerge(deepClone(line, true), item)
})
this.mergedConfig = mergedConfig
},
calcflylinePoints () {
const { mergedConfig, width, height } = this
const { relative, points } = mergedConfig
this.flylinePoints = points.map((item, i) => {
const { coordinate: [x, y], halo, icon, text } = item
if (relative) item.coordinate = [x * width, y * height]
item.halo.time = randomExtend(...halo.duration) / 10
const { width: iw, height: ih } = icon
item.icon.x = item.coordinate[0] - iw / 2
item.icon.y = item.coordinate[1] - ih / 2
const [ox, oy] = text.offset
item.text.x = item.coordinate[0] + ox
item.text.y = item.coordinate[1] + oy
item.key = `${item.coordinate.toString()}${i}`
return item
})
},
calcLinePaths () {
const { getPath, mergedConfig } = this
const { points, lines } = mergedConfig
this.flylines = lines.map(item => {
const { source, target, duration } = item
const sourcePoint = points.find(({ name }) => name === source).coordinate
const targetPoint = points.find(({ name }) => name === target).coordinate
const path = getPath(sourcePoint, targetPoint).map(item => item.map(v => parseFloat(v.toFixed(10))))
const d = `M${path[0].toString()} Q${path[1].toString()} ${path[2].toString()}`
const key = `path${path.toString()}`
const time = randomExtend(...duration) / 10
return { ...item, path, key, d, time }
})
},
getPath (start, end) {
const { getControlPoint } = this
const controlPoint = getControlPoint(start, end)
return [start, controlPoint, end]
},
getControlPoint ([sx, sy], [ex, ey]) {
const { getKLinePointByx, mergedConfig } = this
const { curvature, k } = mergedConfig
const [mx, my] = [(sx + ex) / 2, (sy + ey) / 2]
const distance = getPointDistance([sx, sy], [ex, ey])
const targetLength = distance / curvature
const disDived = targetLength / 2
let [dx, dy] = [mx, my]
do {
dx += disDived
dy = getKLinePointByx(k, [mx, my], dx)[1]
} while (getPointDistance([mx, my], [dx, dy]) < targetLength)
return [dx, dy]
},
getKLinePointByx (k, [lx, ly], x) {
const y = ly - k * lx + k * x
return [x, y]
},
async calcLineLengths () {
const { $nextTick, flylines, $refs } = this
await $nextTick()
this.flylineLengths = flylines.map(({ key }) => $refs[key][0].getTotalLength())
},
consoleClickPos ({ offsetX, offsetY }) {
const { width, height, dev } = this
if (!dev) return
const relativeX = (offsetX / width).toFixed(2)
const relativeY = (offsetY / height).toFixed(2)
console.warn(`dv-flyline-chart-enhanced DEV: \n Click Position is [${offsetX}, ${offsetY}] \n Relative Position is [${relativeX}, ${relativeY}]`)
}
}
}
</script>

View File

@@ -44,6 +44,8 @@
</template> </template>
<script> <script>
import { uuid } from '../../../util/index'
import { deepMerge } from '@jiaminghi/charts/lib/util/index' import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util' import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
@@ -57,9 +59,10 @@ export default {
} }
}, },
data () { data () {
const id = uuid()
return { return {
gradientId1: `percent-pond-gradientId1-${(new Date()).getTime()}`, gradientId1: `percent-pond-gradientId1-${id}`,
gradientId2: `percent-pond-gradientId2-${(new Date()).getTime()}`, gradientId2: `percent-pond-gradientId2-${id}`,
width: 0, width: 0,
height: 0, height: 0,
@@ -233,13 +236,13 @@ export default {
await $nextTick() await $nextTick()
const dom = $refs['percent-pond'] const { clientWidth, clientHeight } = $refs['percent-pond']
this.width = dom.clientWidth this.width = clientWidth
this.height = dom.clientHeight this.height = 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

@@ -4,7 +4,7 @@
<div <div
class="header-item" class="header-item"
v-for="(headerItem, i) in header" v-for="(headerItem, i) in header"
:key="headerItem + i" :key="`${headerItem}${i}`"
:style="` :style="`
height: ${mergedConfig.headerHeight}px; height: ${mergedConfig.headerHeight}px;
line-height: ${mergedConfig.headerHeight}px; line-height: ${mergedConfig.headerHeight}px;
@@ -23,7 +23,7 @@
<div <div
class="row-item" class="row-item"
v-for="(row, ri) in rows" v-for="(row, ri) in rows"
:key="row.toString() + row.scroll" :key="`${row.toString()}${row.scroll}`"
:style="` :style="`
height: ${heights[ri]}px; height: ${heights[ri]}px;
line-height: ${heights[ri]}px; line-height: ${heights[ri]}px;
@@ -33,11 +33,13 @@
<div <div
class="ceil" class="ceil"
v-for="(ceil, ci) in row.ceils" v-for="(ceil, ci) in row.ceils"
:key="ceil + ri + ci" :key="`${ceil}${ri}${ci}`"
:style="`width: ${widths[ci]}px;`" :style="`width: ${widths[ci]}px;`"
:align="aligns[ci]" :align="aligns[ci]"
v-html="ceil" v-html="ceil"
@click="emitEvent(ri, ci, row, ceil)" @click="emitEvent('click', ri, ci, row, ceil)"
@mouseenter="handleHover(true, ri, ci, row, ceil)"
@mouseleave="handleHover(false)"
/> />
</div> </div>
@@ -134,13 +136,26 @@ export default {
* @default index = false * @default index = false
*/ */
index: false, index: false,
/**
* @description index Header
* @type {String}
* @default indexHeader = '#'
*/
indexHeader: '#',
/** /**
* @description Carousel type * @description Carousel type
* @type {String} * @type {String}
* @default carousel = 'single' * @default carousel = 'single'
* @example carousel = 'single' | 'page' * @example carousel = 'single' | 'page'
*/ */
carousel: 'single' carousel: 'single',
/**
* @description Pause scroll when mouse hovered
* @type {Boolean}
* @default hoverPause = true
* @example hoverPause = true | false
*/
hoverPause: true
}, },
mergedConfig: null, mergedConfig: null,
@@ -161,7 +176,9 @@ export default {
animationIndex: 0, animationIndex: 0,
animationHandler: '' animationHandler: '',
updater: 0
} }
}, },
watch: { watch: {
@@ -170,10 +187,24 @@ export default {
stopAnimation() stopAnimation()
this.animationIndex = 0
calcData() calcData()
} }
}, },
methods: { methods: {
handleHover(enter, ri, ci, row, ceil){
const { mergedConfig, emitEvent, stopAnimation, animation } = this
if (enter) emitEvent('mouseover', ri, ci, row, ceil)
if (!mergedConfig.hoverPause) return
if (enter) {
stopAnimation()
} else {
animation(true)
}
},
afterAutoResizeMixinInit () { afterAutoResizeMixinInit () {
const { calcData } = this const { calcData } = this
@@ -215,7 +246,7 @@ export default {
this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {}) this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {})
}, },
calcHeaderData () { calcHeaderData () {
let { header, index } = this.mergedConfig let { header, index, indexHeader} = this.mergedConfig
if (!header.length) { if (!header.length) {
this.header = [] this.header = []
@@ -225,7 +256,7 @@ export default {
header = [...header] header = [...header]
if (index) header.unshift('#') if (index) header.unshift(indexHeader)
this.header = header this.header = header
}, },
@@ -236,7 +267,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 +291,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)
@@ -299,7 +335,7 @@ export default {
this.aligns = deepMerge(aligns, align) this.aligns = deepMerge(aligns, align)
}, },
async animation (start = false) { async animation (start = false) {
let { avgHeight, animationIndex, mergedConfig, rowsData, animation } = this let { avgHeight, animationIndex, mergedConfig, rowsData, animation, updater } = this
const { waitTime, carousel, rowNum } = mergedConfig const { waitTime, carousel, rowNum } = mergedConfig
@@ -307,17 +343,21 @@ export default {
if (rowNum >= rowLength) return if (rowNum >= rowLength) return
if (start) await new Promise(resolve => setTimeout(resolve, waitTime)) if (start) {
await new Promise(resolve => setTimeout(resolve, waitTime))
if (updater !== this.updater) return
}
const animationNum = carousel === 'single' ? 1 : rowNum const animationNum = carousel === 'single' ? 1 : rowNum
let rows = rowsData.slice(animationIndex) let rows = rowsData.slice(animationIndex)
rows.push(...rowsData.slice(0, animationIndex)) rows.push(...rowsData.slice(0, animationIndex))
this.rows = rows this.rows = rows.slice(0, rowNum + 1)
this.heights = new Array(rowLength).fill(avgHeight) this.heights = new Array(rowLength).fill(avgHeight)
await new Promise(resolve => setTimeout(resolve, 300)) await new Promise(resolve => setTimeout(resolve, 300))
if (updater !== this.updater) return
this.heights.splice(0, animationNum, ...new Array(animationNum).fill(0)) this.heights.splice(0, animationNum, ...new Array(animationNum).fill(0))
@@ -330,21 +370,36 @@ export default {
this.animationHandler = setTimeout(animation, waitTime - 300) this.animationHandler = setTimeout(animation, waitTime - 300)
}, },
stopAnimation () { stopAnimation () {
const { animationHandler } = this const { animationHandler, updater } = this
this.updater = (updater + 1) % 999999
if (!animationHandler) return if (!animationHandler) return
clearTimeout(animationHandler) clearTimeout(animationHandler)
}, },
emitEvent (ri, ci, row, ceil) { emitEvent (type, ri, ci, row, ceil) {
const { ceils, rowIndex } = row const { ceils, rowIndex } = row
this.$emit('click', { this.$emit(type, {
row: ceils, row: ceils,
ceil, ceil,
rowIndex, rowIndex,
columnIndex: ci columnIndex: ci
}) })
},
updateRows(rows, animationIndex) {
const { mergedConfig, calcRowsData, calcHeights, animationHandler, animation } = this
this.mergedConfig = {
...mergedConfig,
data: [...rows]
}
calcRowsData()
calcHeights()
if (typeof animationIndex === 'number') this.animationIndex = animationIndex
if (!animationHandler) animation(true)
} }
}, },
destroyed () { destroyed () {

View File

@@ -8,8 +8,8 @@
> >
<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" v-html="item.name" />
<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,20 @@ 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: '',
/**
* @description Auto sort by value
* @type {Boolean}
* @default sort = true
*/
sort: true
}, },
mergedConfig: null, mergedConfig: null,
@@ -82,7 +95,9 @@ export default {
animationIndex: 0, animationIndex: 0,
animationHandler: '' animationHandler: '',
updater: 0
} }
}, },
watch: { watch: {
@@ -128,19 +143,29 @@ export default {
this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {}) this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {})
}, },
calcRowsData () { calcRowsData () {
let { data, rowNum } = this.mergedConfig let { data, rowNum, sort } = this.mergedConfig
data.sort(({ value: a }, { value: b }) => { sort && data.sort(({ value: a }, { value: b }) => {
if (a > b) return -1 if (a > b) return -1
if (a < b) return 1 if (a < b) return 1
if (a === b) return 0 if (a === b) return 0
}) })
const value = data.map(({ value }) => value) const value = data.map(({ value }) => value)
const min = Math.min(...value) || 0
// abs of min
const minAbs = Math.abs(min)
const max = Math.max(...value) || 0 const max = Math.max(...value) || 0
data = data.map((row, i) => ({ ...row, ranking: i + 1, percent: row.value / max * 100 })) // abs of max
const maxAbs = Math.abs(max)
const total = max + minAbs
data = data.map((row, i) => ({ ...row, ranking: i + 1, percent: (row.value + minAbs) / total * 100 }))
const rowLength = data.length const rowLength = data.length
@@ -165,7 +190,7 @@ export default {
if (!onresize) this.heights = new Array(data.length).fill(avgHeight) if (!onresize) this.heights = new Array(data.length).fill(avgHeight)
}, },
async animation (start = false) { async animation (start = false) {
let { avgHeight, animationIndex, mergedConfig, rowsData, animation } = this let { avgHeight, animationIndex, mergedConfig, rowsData, animation, updater } = this
const { waitTime, carousel, rowNum } = mergedConfig const { waitTime, carousel, rowNum } = mergedConfig
@@ -173,17 +198,21 @@ export default {
if (rowNum >= rowLength) return if (rowNum >= rowLength) return
if (start) await new Promise(resolve => setTimeout(resolve, waitTime)) if (start) {
await new Promise(resolve => setTimeout(resolve, waitTime))
if (updater !== this.updater) return
}
const animationNum = carousel === 'single' ? 1 : rowNum const animationNum = carousel === 'single' ? 1 : rowNum
let rows = rowsData.slice(animationIndex) let rows = rowsData.slice(animationIndex)
rows.push(...rowsData.slice(0, animationIndex)) rows.push(...rowsData.slice(0, animationIndex))
this.rows = rows this.rows = rows.slice(0, rowNum + 1)
this.heights = new Array(rowLength).fill(avgHeight) this.heights = new Array(rowLength).fill(avgHeight)
await new Promise(resolve => setTimeout(resolve, 300)) await new Promise(resolve => setTimeout(resolve, 300))
if (updater !== this.updater) return
this.heights.splice(0, animationNum, ...new Array(animationNum).fill(0)) this.heights.splice(0, animationNum, ...new Array(animationNum).fill(0))
@@ -196,7 +225,9 @@ export default {
this.animationHandler = setTimeout(animation, waitTime - 300) this.animationHandler = setTimeout(animation, waitTime - 300)
}, },
stopAnimation () { stopAnimation () {
const { animationHandler } = this const { animationHandler, updater } = this
this.updater = (updater + 1) % 999999
if (!animationHandler) return if (!animationHandler) return

View File

@@ -40,6 +40,8 @@
</template> </template>
<script> <script>
import { uuid } from '../../../util/index'
import { deepMerge } from '@jiaminghi/charts/lib/util/index' import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util' import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
@@ -53,8 +55,9 @@ export default {
default: () => ({}) default: () => ({})
}, },
data () { data () {
const id = uuid()
return { return {
gradientId: `water-level-pond-${(new Date()).getTime()}`, gradientId: `water-level-pond-${id}`,
defaultConfig: { defaultConfig: {
/** /**

View File

@@ -4,6 +4,9 @@
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 borderBox10 } from './components/borderBox10/index'
export { default as borderBox11 } from './components/borderBox11/index'
export { default as borderBox12 } from './components/borderBox12/index'
export { default as borderBox13 } from './components/borderBox13/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'
@@ -17,6 +20,7 @@ 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'
export { default as decoration10 } from './components/decoration10/index' export { default as decoration10 } from './components/decoration10/index'
export { default as decoration11 } from './components/decoration11/index'
export { default as decoration2 } from './components/decoration2/index' export { default as decoration2 } from './components/decoration2/index'
export { default as decoration3 } from './components/decoration3/index' export { default as decoration3 } from './components/decoration3/index'
export { default as decoration4 } from './components/decoration4/index' export { default as decoration4 } from './components/decoration4/index'
@@ -27,6 +31,7 @@ export { default as decoration8 } from './components/decoration8/index'
export { default as decoration9 } from './components/decoration9/index' export { default as decoration9 } from './components/decoration9/index'
export { default as digitalFlop } from './components/digitalFlop/index' export { default as digitalFlop } from './components/digitalFlop/index'
export { default as flylineChart } from './components/flylineChart/index' export { default as flylineChart } from './components/flylineChart/index'
export { default as flylineChartEnhanced } from './components/flylineChartEnhanced/index'
export { default as fullScreenContainer } from './components/fullScreenContainer/index' export { default as fullScreenContainer } from './components/fullScreenContainer/index'
export { default as loading } from './components/loading/index' export { default as loading } from './components/loading/index'
export { default as percentPond } from './components/percentPond/index' export { default as percentPond } from './components/percentPond/index'
@@ -50,6 +55,9 @@ 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' import borderBox10 from './components/borderBox10/index'
import borderBox11 from './components/borderBox11/index'
import borderBox12 from './components/borderBox12/index'
import borderBox13 from './components/borderBox13/index'
// decoration // decoration
import decoration1 from './components/decoration1/index' import decoration1 from './components/decoration1/index'
@@ -62,6 +70,7 @@ import decoration7 from './components/decoration7/index'
import decoration8 from './components/decoration8/index' import decoration8 from './components/decoration8/index'
import decoration9 from './components/decoration9/index' import decoration9 from './components/decoration9/index'
import decoration10 from './components/decoration10/index' import decoration10 from './components/decoration10/index'
import decoration11 from './components/decoration11/index'
// charts // charts
import charts from './components/charts/index' import charts from './components/charts/index'
@@ -71,6 +80,7 @@ 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'
import flylineChartEnhanced from './components/flylineChartEnhanced'
import conicalColumnChart from './components/conicalColumnChart' import conicalColumnChart from './components/conicalColumnChart'
import digitalFlop from './components/digitalFlop' import digitalFlop from './components/digitalFlop'
import scrollBoard from './components/scrollBoard/index' import scrollBoard from './components/scrollBoard/index'
@@ -94,6 +104,9 @@ export default function (Vue) {
Vue.use(borderBox8) Vue.use(borderBox8)
Vue.use(borderBox9) Vue.use(borderBox9)
Vue.use(borderBox10) Vue.use(borderBox10)
Vue.use(borderBox11)
Vue.use(borderBox12)
Vue.use(borderBox13)
// decoration // decoration
Vue.use(decoration1) Vue.use(decoration1)
@@ -106,6 +119,7 @@ export default function (Vue) {
Vue.use(decoration8) Vue.use(decoration8)
Vue.use(decoration9) Vue.use(decoration9)
Vue.use(decoration10) Vue.use(decoration10)
Vue.use(decoration11)
// charts // charts
Vue.use(charts) Vue.use(charts)
@@ -115,6 +129,7 @@ export default function (Vue) {
Vue.use(waterLevelPond) Vue.use(waterLevelPond)
Vue.use(percentPond) Vue.use(percentPond)
Vue.use(flylineChart) Vue.use(flylineChart)
Vue.use(flylineChartEnhanced)
Vue.use(conicalColumnChart) Vue.use(conicalColumnChart)
Vue.use(digitalFlop) Vue.use(digitalFlop)
Vue.use(scrollBoard) Vue.use(scrollBoard)

View File

@@ -37,3 +37,11 @@ export function getPointDistance (pointOne, pointTwo) {
return Math.sqrt(minusX * minusX + minusY * minusY) return Math.sqrt(minusX * minusX + minusY * minusY)
} }
export function uuid (hasHyphen) {
return (hasHyphen ? 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx' : 'xxxxxxxxxxxx4xxxyxxxxxxxxxxxxxxx').replace(/[xy]/g, function (c) {
const r = Math.random() * 16 | 0
const v = c == 'x' ? r : (r & 0x3 | 0x8)
return v.toString(16)
})
}

View File

@@ -1,21 +1,22 @@
{ {
"name": "@jiaminghi/data-view", "name": "@jiaminghi/data-view",
"version": "2.4.2", "version": "2.9.5",
"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()

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'
@@ -28,7 +28,7 @@ export default {
default: () => ({}) default: () => ({})
} }
}, },
data () { data() {
return { return {
defaultConfig: { defaultConfig: {
/** /**
@@ -78,6 +78,11 @@ export default {
fontSize: 25, fontSize: 25,
fill: '#fff' fill: '#fff'
}, },
/**
* @description Digital flop toFixed
* @type {Number}
*/
digitalFlopToFixed: 0,
/** /**
* @description CRender animationCurve * @description CRender animationCurve
* @type {String} * @type {String}
@@ -89,7 +94,13 @@ export default {
* @type {String} * @type {String}
* @default animationFrame = 50 * @default animationFrame = 50
*/ */
animationFrame: 50 animationFrame: 50,
/**
* @description showOriginValue
* @type {Boolean}
* @default showOriginValue = false
*/
showOriginValue: false
}, },
mergedConfig: null, mergedConfig: null,
@@ -102,33 +113,47 @@ export default {
} }
}, },
computed: { computed: {
digitalFlop () { digitalFlop() {
const { mergedConfig, activeIndex } = this const { mergedConfig, activeIndex } = this
if (!mergedConfig) return {} if (!mergedConfig) return {}
const { digitalFlopStyle, data } = mergedConfig const {
digitalFlopStyle,
digitalFlopToFixed,
data,
showOriginValue
} = mergedConfig
const value = data.map(({ value }) => value) const value = data.map(({ value }) => value)
const sum = value.reduce((all, v) => all + v, 0) let displayValue
const percent = parseInt(value[activeIndex] / sum * 100) if (showOriginValue) {
displayValue = value[activeIndex]
} else {
const sum = value.reduce((all, v) => all + v, 0)
const percent = parseFloat((value[activeIndex] / sum) * 100) || 0
displayValue = percent
}
return { return {
content: '{nt}%', content: showOriginValue ? '{nt}' : '{nt}%',
number: [percent], number: [displayValue],
style: digitalFlopStyle style: digitalFlopStyle,
toFixed: digitalFlopToFixed
} }
}, },
ringName () { ringName() {
const { mergedConfig, activeIndex } = this const { mergedConfig, activeIndex } = this
if (!mergedConfig) return '' if (!mergedConfig) return ''
return mergedConfig.data[activeIndex].name return mergedConfig.data[activeIndex].name
}, },
fontSize () { fontSize() {
const { mergedConfig } = this const { mergedConfig } = this
if (!mergedConfig) return '' if (!mergedConfig) return ''
@@ -137,7 +162,7 @@ export default {
} }
}, },
watch: { watch: {
config () { config() {
const { animationHandler, mergeConfig, setRingOption } = this const { animationHandler, mergeConfig, setRingOption } = this
clearTimeout(animationHandler) clearTimeout(animationHandler)
@@ -150,7 +175,7 @@ export default {
} }
}, },
methods: { methods: {
init () { init() {
const { initChart, mergeConfig, setRingOption } = this const { initChart, mergeConfig, setRingOption } = this
initChart() initChart()
@@ -159,26 +184,29 @@ export default {
setRingOption() setRingOption()
}, },
initChart () { initChart() {
const { $refs } = this const { $refs } = this
this.chart = new Charts($refs['active-ring-chart']) this.chart = new Charts($refs['active-ring-chart'])
}, },
mergeConfig () { mergeConfig() {
const { defaultConfig, config } = this const { defaultConfig, config } = this
this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {}) this.mergedConfig = deepMerge(
deepClone(defaultConfig, true),
config || {}
)
}, },
setRingOption () { setRingOption() {
const { getRingOption, chart, ringAnimation } = this const { getRingOption, chart, ringAnimation } = this
const option = getRingOption() const option = getRingOption()
chart.setOption(option) chart.setOption(option, true)
ringAnimation() ringAnimation()
}, },
getRingOption () { getRingOption() {
const { mergedConfig, getRealRadius } = this const { mergedConfig, getRealRadius } = this
const radius = getRealRadius() const radius = getRealRadius()
@@ -200,7 +228,7 @@ export default {
color: mergedConfig.color color: mergedConfig.color
} }
}, },
getRealRadius (active = false) { getRealRadius(active = false) {
const { mergedConfig, chart } = this const { mergedConfig, chart } = this
const { radius, activeRadius, lineWidth } = mergedConfig const { radius, activeRadius, lineWidth } = mergedConfig
@@ -211,14 +239,15 @@ export default {
let realRadius = active ? activeRadius : radius let realRadius = active ? activeRadius : radius
if (typeof realRadius !== 'number') realRadius = parseInt(realRadius) / 100 * maxRadius if (typeof realRadius !== 'number')
realRadius = (parseInt(realRadius) / 100) * maxRadius
const insideRadius = realRadius - halfLineWidth const insideRadius = realRadius - halfLineWidth
const outSideRadius = realRadius + halfLineWidth const outSideRadius = realRadius + halfLineWidth
return [insideRadius, outSideRadius] return [insideRadius, outSideRadius]
}, },
ringAnimation () { ringAnimation() {
let { activeIndex, getRingOption, chart, getRealRadius } = this let { activeIndex, getRingOption, chart, getRealRadius } = this
const radius = getRealRadius() const radius = getRealRadius()
@@ -236,7 +265,7 @@ export default {
} }
}) })
chart.setOption(option) chart.setOption(option, true)
const { activeTimeGap } = option.series[0] const { activeTimeGap } = option.series[0]
@@ -251,12 +280,12 @@ export default {
}, activeTimeGap) }, activeTimeGap)
} }
}, },
mounted () { mounted() {
const { init } = this const { init } = this
init() init()
}, },
beforeDestroy () { beforeDestroy() {
const { animationHandler } = this const { animationHandler } = this
clearTimeout(animationHandler) clearTimeout(animationHandler)

View File

@@ -1,5 +1,16 @@
<template> <template>
<div class="dv-border-box-1"> <div class="dv-border-box-1" :ref="ref">
<svg class="border" :width="width" :height="height">
<polygon :fill="backgroundColor" :points="`10, 27 10, ${height - 27} 13, ${height - 24} 13, ${height - 21} 24, ${height - 11}
38, ${height - 11} 41, ${height - 8} 73, ${height - 8} 75, ${height - 10} 81, ${height - 10}
85, ${height - 6} ${width - 85}, ${height - 6} ${width - 81}, ${height - 10} ${width - 75}, ${height - 10}
${width - 73}, ${height - 8} ${width - 41}, ${height - 8} ${width - 38}, ${height - 11}
${width - 24}, ${height - 11} ${width - 13}, ${height - 21} ${width - 13}, ${height - 24}
${width - 10}, ${height - 27} ${width - 10}, 27 ${width - 13}, 25 ${width - 13}, 21
${width - 24}, 11 ${width - 38}, 11 ${width - 41}, 8 ${width - 73}, 8 ${width - 75}, 10
${width - 81}, 10 ${width - 85}, 6 85, 6 81, 10 75, 10 73, 8 41, 8 38, 11 24, 11 13, 21 13, 24`" />
</svg>
<svg <svg
width="150px" width="150px"
height="150px" height="150px"
@@ -8,36 +19,36 @@
:class="`${item} border`" :class="`${item} border`"
> >
<polygon <polygon
fill="#4fd2dd" :fill="mergedColor[0]"
points="6,66 6,18 12,12 18,12 24,6 27,6 30,9 36,9 39,6 84,6 81,9 75,9 73.2,7 40.8,7 37.8,10.2 24,10.2 12,21 12,24 9,27 9,51 7.8,54 7.8,63" points="6,66 6,18 12,12 18,12 24,6 27,6 30,9 36,9 39,6 84,6 81,9 75,9 73.2,7 40.8,7 37.8,10.2 24,10.2 12,21 12,24 9,27 9,51 7.8,54 7.8,63"
> >
<animate <animate
attributeName="fill" attributeName="fill"
values="#4fd2dd;#235fa7;#4fd2dd" :values="`${mergedColor[0]};${mergedColor[1]};${mergedColor[0]}`"
dur="0.5s" dur="0.5s"
begin="0s" begin="0s"
repeatCount="indefinite" repeatCount="indefinite"
/> />
</polygon> </polygon>
<polygon <polygon
fill="#235fa7" :fill="mergedColor[1]"
points="27.599999999999998,4.8 38.4,4.8 35.4,7.8 30.599999999999998,7.8" points="27.599999999999998,4.8 38.4,4.8 35.4,7.8 30.599999999999998,7.8"
> >
<animate <animate
attributeName="fill" attributeName="fill"
values="#235fa7;#4fd2dd;#235fa7" :values="`${mergedColor[1]};${mergedColor[0]};${mergedColor[1]}`"
dur="0.5s" dur="0.5s"
begin="0s" begin="0s"
repeatCount="indefinite" repeatCount="indefinite"
/> />
</polygon> </polygon>
<polygon <polygon
fill="#4fd2dd" :fill="mergedColor[0]"
points="9,54 9,63 7.199999999999999,66 7.199999999999999,75 7.8,78 7.8,110 8.4,110 8.4,66 9.6,66 9.6,54" points="9,54 9,63 7.199999999999999,66 7.199999999999999,75 7.8,78 7.8,110 8.4,110 8.4,66 9.6,66 9.6,54"
> >
<animate <animate
attributeName="fill" attributeName="fill"
values="#4fd2dd;#235fa7;transparent" :values="`${mergedColor[0]};${mergedColor[1]};transparent`"
dur="1s" dur="1s"
begin="0s" begin="0s"
repeatCount="indefinite" repeatCount="indefinite"
@@ -52,12 +63,54 @@
</template> </template>
<script> <script>
import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox1', name: 'DvBorderBox1',
mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () { data () {
return { return {
border: ['left-top', 'right-top', 'left-bottom', 'right-bottom'] ref: 'border-box-1',
border: ['left-top', 'right-top', 'left-bottom', 'right-bottom'],
defaultColor: ['#4fd2dd', '#235fa7'],
mergedColor: []
} }
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -1,5 +1,12 @@
<template> <template>
<div class="dv-border-box-10"> <div class="dv-border-box-10" :ref="ref" :style="`box-shadow: inset 0 0 25px 3px ${mergedColor[0]}`">
<svg class="border" :width="width" :height="height">
<polygon :fill="backgroundColor" :points="`
4, 0 ${width - 4}, 0 ${width}, 4 ${width}, ${height - 4} ${width - 4}, ${height}
4, ${height} 0, ${height - 4} 0, 4
`" />
</svg>
<svg <svg
width="150px" width="150px"
height="150px" height="150px"
@@ -8,7 +15,7 @@
:class="`${item} border`" :class="`${item} border`"
> >
<polygon <polygon
fill="#d3e1f8" :fill="mergedColor[1]"
points="40, 0 5, 0 0, 5 0, 16 3, 19 3, 7 7, 3 35, 3" points="40, 0 5, 0 0, 5 0, 16 3, 19 3, 7 7, 3 35, 3"
/> />
</svg> </svg>
@@ -20,12 +27,54 @@
</template> </template>
<script> <script>
import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox10', name: 'DvBorderBox10',
mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () { data () {
return { return {
border: ['left-top', 'right-top', 'left-bottom', 'right-bottom'] ref: 'border-box-10',
border: ['left-top', 'right-top', 'left-bottom', 'right-bottom'],
defaultColor: ['#1d48c4', '#d3e1f8'],
mergedColor: []
} }
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>
@@ -35,7 +84,6 @@ export default {
position: relative; position: relative;
width: 100%; width: 100%;
height: 100%; height: 100%;
box-shadow: inset 0 0 25px 3px #1d48c4;
border-radius: 6px; border-radius: 6px;
.border { .border {

View File

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

View File

@@ -0,0 +1,307 @@
<template>
<div class="dv-border-box-11" :ref="ref">
<svg class="dv-border-svg-container" :width="width" :height="height">
<defs>
<filter :id="filterId" height="150%" width="150%" x="-25%" y="-25%">
<feMorphology operator="dilate" radius="2" in="SourceAlpha" result="thicken" />
<feGaussianBlur in="thicken" stdDeviation="3" result="blurred" />
<feFlood :flood-color="mergedColor[1]" result="glowColor" />
<feComposite in="glowColor" in2="blurred" operator="in" result="softGlowColored" />
<feMerge>
<feMergeNode in="softGlowColored"/>
<feMergeNode in="SourceGraphic"/>
</feMerge>
</filter>
</defs>
<polygon :fill="backgroundColor" :points="`
20, 32 ${width * 0.5 - titleWidth / 2}, 32 ${width * 0.5 - titleWidth / 2 + 20}, 53
${width * 0.5 + titleWidth / 2 - 20}, 53 ${width * 0.5 + titleWidth / 2}, 32
${width - 20}, 32 ${width - 8}, 48 ${width - 8}, ${height - 25} ${width - 20}, ${height - 8}
20, ${height - 8} 8, ${height - 25} 8, 50
`" />
<polyline
:stroke="mergedColor[0]"
:filter="`url(#${filterId})`"
:points="`
${(width - titleWidth) / 2}, 30
20, 30 7, 50 7, ${50 + (height - 167) / 2}
13, ${55 + (height - 167) / 2} 13, ${135 + (height - 167) / 2}
7, ${140 + (height - 167) / 2} 7, ${height - 27}
20, ${height - 7} ${width - 20}, ${height - 7} ${width - 7}, ${height - 27}
${width - 7}, ${140 + (height - 167) / 2} ${width - 13}, ${135 + (height - 167) / 2}
${width - 13}, ${55 + (height - 167) / 2} ${width - 7}, ${50 + (height - 167) / 2}
${width - 7}, 50 ${width - 20}, 30 ${(width + titleWidth) / 2}, 30
${(width + titleWidth) / 2 - 20}, 7 ${(width - titleWidth) / 2 + 20}, 7
${(width - titleWidth) / 2}, 30 ${(width - titleWidth) / 2 + 20}, 52
${(width + titleWidth) / 2 - 20}, 52 ${(width + titleWidth) / 2}, 30
`"
/>
<polygon
:stroke="mergedColor[0]"
fill="transparent"
:points="`
${(width + titleWidth) / 2 - 5}, 30 ${(width + titleWidth) / 2 - 21}, 11
${(width + titleWidth) / 2 - 27}, 11 ${(width + titleWidth) / 2 - 8}, 34
`"
/>
<polygon
:stroke="mergedColor[0]"
fill="transparent"
:points="`
${(width - titleWidth) / 2 + 5}, 30 ${(width - titleWidth) / 2 + 22}, 49
${(width - titleWidth) / 2 + 28}, 49 ${(width - titleWidth) / 2 + 8}, 26
`"
/>
<polygon
:stroke="mergedColor[0]"
:fill="fade(mergedColor[1] || defaultColor[1], 30)"
:filter="`url(#${filterId})`"
:points="`
${(width + titleWidth) / 2 - 11}, 37 ${(width + titleWidth) / 2 - 32}, 11
${(width - titleWidth) / 2 + 23}, 11 ${(width - titleWidth) / 2 + 11}, 23
${(width - titleWidth) / 2 + 33}, 49 ${(width + titleWidth) / 2 - 22}, 49
`"
/>
<polygon
:filter="`url(#${filterId})`"
:fill="mergedColor[0]"
opacity="1"
:points="`
${(width - titleWidth) / 2 - 10}, 37 ${(width - titleWidth) / 2 - 31}, 37
${(width - titleWidth) / 2 - 25}, 46 ${(width - titleWidth) / 2 - 4}, 46
`"
>
<animate
attributeName="opacity"
values="1;0.7;1"
dur="2s"
begin="0s"
repeatCount="indefinite"
/>
</polygon>
<polygon
:filter="`url(#${filterId})`"
:fill="mergedColor[0]"
opacity="0.7"
:points="`
${(width - titleWidth) / 2 - 40}, 37 ${(width - titleWidth) / 2 - 61}, 37
${(width - titleWidth) / 2 - 55}, 46 ${(width - titleWidth) / 2 - 34}, 46
`"
>
<animate
attributeName="opacity"
values="0.7;0.4;0.7"
dur="2s"
begin="0s"
repeatCount="indefinite"
/>
</polygon>
<polygon
:filter="`url(#${filterId})`"
:fill="mergedColor[0]"
opacity="0.5"
:points="`
${(width - titleWidth) / 2 - 70}, 37 ${(width - titleWidth) / 2 - 91}, 37
${(width - titleWidth) / 2 - 85}, 46 ${(width - titleWidth) / 2 - 64}, 46
`"
>
<animate
attributeName="opacity"
values="0.5;0.2;0.5"
dur="2s"
begin="0s"
repeatCount="indefinite"
/>
</polygon>
<polygon
:filter="`url(#${filterId})`"
:fill="mergedColor[0]"
opacity="1"
:points="`
${(width + titleWidth) / 2 + 30}, 37 ${(width + titleWidth) / 2 + 9}, 37
${(width + titleWidth) / 2 + 3}, 46 ${(width + titleWidth) / 2 + 24}, 46
`"
>
<animate
attributeName="opacity"
values="1;0.7;1"
dur="2s"
begin="0s"
repeatCount="indefinite"
/>
</polygon>
<polygon
:filter="`url(#${filterId})`"
:fill="mergedColor[0]"
opacity="0.7"
:points="`
${(width + titleWidth) / 2 + 60}, 37 ${(width + titleWidth) / 2 + 39}, 37
${(width + titleWidth) / 2 + 33}, 46 ${(width + titleWidth) / 2 + 54}, 46
`"
>
<animate
attributeName="opacity"
values="0.7;0.4;0.7"
dur="2s"
begin="0s"
repeatCount="indefinite"
/>
</polygon>
<polygon
:filter="`url(#${filterId})`"
:fill="mergedColor[0]"
opacity="0.5"
:points="`
${(width + titleWidth) / 2 + 90}, 37 ${(width + titleWidth) / 2 + 69}, 37
${(width + titleWidth) / 2 + 63}, 46 ${(width + titleWidth) / 2 + 84}, 46
`"
>
<animate
attributeName="opacity"
values="0.5;0.2;0.5"
dur="2s"
begin="0s"
repeatCount="indefinite"
/>
</polygon>
<text
class="dv-border-box-11-title"
:x="`${width / 2}`"
y="32"
fill="#fff"
font-size="18"
text-anchor="middle"
dominant-baseline="middle"
>
{{ title }}
</text>
<polygon
:fill="mergedColor[0]"
:filter="`url(#${filterId})`"
:points="`
7, ${53 + (height - 167) / 2} 11, ${57 + (height - 167) / 2}
11, ${133 + (height - 167) / 2} 7, ${137 + (height - 167) / 2}
`"
/>
<polygon
:fill="mergedColor[0]"
:filter="`url(#${filterId})`"
:points="`
${width - 7}, ${53 + (height - 167) / 2} ${width - 11}, ${57 + (height - 167) / 2}
${width - 11}, ${133 + (height - 167) / 2} ${width - 7}, ${137 + (height - 167) / 2}
`"
/>
</svg>
<div class="border-box-content">
<slot></slot>
</div>
</div>
</template>
<script>
import autoResize from '../../../mixin/autoResize'
import { uuid } from '../../../util/index'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
import { fade } from '@jiaminghi/color'
export default {
name: 'DvBorderBox11',
mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
titleWidth: {
type: Number,
default: 250
},
title: {
type: String,
default: ''
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () {
const id = uuid()
return {
ref: 'border-box-11',
filterId: `border-box-11-filterId-${id}`,
defaultColor: ['#8aaafb', '#1f33a2'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
},
fade
},
mounted () {
const { mergeColor } = this
mergeColor()
}
}
</script>
<style lang="less">
.dv-border-box-11 {
position: relative;
width: 100%;
height: 100%;
.dv-border-svg-container {
position: absolute;
width: 100%;
height: 100%;
top: 0px;
left: 0px;
polyline {
fill: none;
stroke-width: 1;
}
}
.border-box-content {
position: relative;
width: 100%;
height: 100%;
}
}
</style>

View File

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

View File

@@ -0,0 +1,170 @@
<template>
<div class="dv-border-box-12" :ref="ref">
<svg class="dv-border-svg-container" :width="width" :height="height">
<defs>
<filter :id="filterId" height="150%" width="150%" x="-25%" y="-25%">
<feMorphology operator="dilate" radius="1" in="SourceAlpha" result="thicken" />
<feGaussianBlur in="thicken" stdDeviation="2" result="blurred" />
<feFlood :flood-color="fade(mergedColor[1] || defaultColor[1], 70)" result="glowColor">
<animate
attributeName="flood-color"
:values="`
${fade(mergedColor[1] || defaultColor[1], 70)};
${fade(mergedColor[1] || defaultColor[1], 30)};
${fade(mergedColor[1] || defaultColor[1], 70)};
`"
dur="3s"
begin="0s"
repeatCount="indefinite"
/>
</feFlood>
<feComposite in="glowColor" in2="blurred" operator="in" result="softGlowColored" />
<feMerge>
<feMergeNode in="softGlowColored"/>
<feMergeNode in="SourceGraphic"/>
</feMerge>
</filter>
</defs>
<path
v-if="width && height"
:fill="backgroundColor"
stroke-width="2"
:stroke="mergedColor[0]"
:d="`
M15 5 L ${width - 15} 5 Q ${width - 5} 5, ${width - 5} 15
L ${width - 5} ${height - 15} Q ${width - 5} ${height - 5}, ${width - 15} ${height - 5}
L 15, ${height - 5} Q 5 ${height - 5} 5 ${height - 15} L 5 15
Q 5 5 15 5
`"
/>
<path
stroke-width="2"
fill="transparent"
stroke-linecap="round"
:filter="`url(#${filterId})`"
:stroke="mergedColor[1]"
:d="`M 20 5 L 15 5 Q 5 5 5 15 L 5 20`"
/>
<path
stroke-width="2"
fill="transparent"
stroke-linecap="round"
:filter="`url(#${filterId})`"
:stroke="mergedColor[1]"
:d="`M ${width - 20} 5 L ${width - 15} 5 Q ${width - 5} 5 ${width - 5} 15 L ${width - 5} 20`"
/>
<path
stroke-width="2"
fill="transparent"
stroke-linecap="round"
:filter="`url(#${filterId})`"
:stroke="mergedColor[1]"
:d="`
M ${width - 20} ${height - 5} L ${width - 15} ${height - 5}
Q ${width - 5} ${height - 5} ${width - 5} ${height - 15}
L ${width - 5} ${height - 20}
`"
/>
<path
stroke-width="2"
fill="transparent"
stroke-linecap="round"
:filter="`url(#${filterId})`"
:stroke="mergedColor[1]"
:d="`
M 20 ${height - 5} L 15 ${height - 5}
Q 5 ${height - 5} 5 ${height - 15}
L 5 ${height - 20}
`"
/>
</svg>
<div class="border-box-content">
<slot></slot>
</div>
</div>
</template>
<script>
import autoResize from '../../../mixin/autoResize'
import { uuid } from '../../../util/index'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
import { fade } from '@jiaminghi/color'
export default {
name: 'DvBorderBox12',
mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () {
const id = uuid()
return {
ref: 'border-box-12',
filterId: `borderr-box-12-filterId-${id}`,
defaultColor: ['#2e6099', '#7ce7fd'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
},
fade
},
mounted () {
const { mergeColor } = this
mergeColor()
}
}
</script>
<style lang="less">
.dv-border-box-12 {
position: relative;
width: 100%;
height: 100%;
.dv-border-svg-container {
position: absolute;
width: 100%;
height: 100%;
top: 0px;
left: 0px;
}
.border-box-content {
position: relative;
width: 100%;
height: 100%;
}
}
</style>

View File

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

View File

@@ -0,0 +1,114 @@
<template>
<div class="dv-border-box-13" :ref="ref">
<svg class="dv-border-svg-container" :width="width" :height="height">
<path
:fill="backgroundColor"
:stroke="mergedColor[0]"
:d="`
M 5 20 L 5 10 L 12 3 L 60 3 L 68 10
L ${width - 20} 10 L ${width - 5} 25
L ${width - 5} ${height - 5} L 20 ${height - 5}
L 5 ${height - 20} L 5 20
`"
/>
<path
fill="transparent"
stroke-width="3"
stroke-linecap="round"
stroke-dasharray="10, 5"
:stroke="mergedColor[0]"
:d="`M 16 9 L 61 9`"
/>
<path
fill="transparent"
:stroke="mergedColor[1]"
:d="`M 5 20 L 5 10 L 12 3 L 60 3 L 68 10`"
/>
<path
fill="transparent"
:stroke="mergedColor[1]"
:d="`M ${width - 5} ${height - 30} L ${width - 5} ${height - 5} L ${width - 30} ${height - 5}`"
/>
</svg>
<div class="border-box-content">
<slot></slot>
</div>
</div>
</template>
<script>
import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default {
name: 'DvBorderBox13',
mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () {
return {
ref: 'border-box-13',
defaultColor: ['#6586ec', '#2cf7fe'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
}
}
</script>
<style lang="less">
.dv-border-box-13 {
position: relative;
width: 100%;
height: 100%;
.dv-border-svg-container {
position: absolute;
width: 100%;
height: 100%;
top: 0px;
left: 0px;
}
.border-box-content {
position: relative;
width: 100%;
height: 100%;
}
}
</style>

View File

@@ -1,14 +1,22 @@
<template> <template>
<div class="dv-border-box-2" :ref="ref"> <div class="dv-border-box-2" :ref="ref">
<svg class="dv-border-svg-container" :width="width" :height="height"> <svg class="dv-border-svg-container" :width="width" :height="height">
<polyline class="dv-bb2-line1" <polygon :fill="backgroundColor" :points="`
:points="`2, 2 ${width - 2} ,2 ${width - 2}, ${height - 2} 2, ${height - 2} 2, 2`" /> 7, 7 ${width - 7}, 7 ${width - 7}, ${height - 7} 7, ${height - 7}
<polyline class="dv-bb2-line2" `" />
:points="`6, 6 ${width - 6}, 6 ${width - 6}, ${height - 6} 6, ${height - 6} 6, 6`" />
<circle cx="11" cy="11" r="1" /> <polyline
<circle :cx="width - 11" cy="11" r="1" /> :stroke="mergedColor[0]"
<circle :cx="width - 11" :cy="height - 11" r="1" /> :points="`2, 2 ${width - 2} ,2 ${width - 2}, ${height - 2} 2, ${height - 2} 2, 2`"
<circle cx="11" :cy="height - 11" r="1" /> />
<polyline
:stroke="mergedColor[1]"
:points="`6, 6 ${width - 6}, 6 ${width - 6}, ${height - 6} 6, ${height - 6} 6, 6`"
/>
<circle :fill="mergedColor[0]" cx="11" cy="11" r="1" />
<circle :fill="mergedColor[0]" :cx="width - 11" cy="11" r="1" />
<circle :fill="mergedColor[0]" :cx="width - 11" :cy="height - 11" r="1" />
<circle :fill="mergedColor[0]" cx="11" :cy="height - 11" r="1" />
</svg> </svg>
<div class="border-box-content"> <div class="border-box-content">
@@ -20,13 +28,50 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox2', name: 'DvBorderBox2',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () { data () {
return { return {
ref: 'border-box-2' ref: 'border-box-2',
defaultColor: ['#fff', 'rgba(255, 255, 255, 0.6)'],
mergedColor: []
} }
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>
@@ -48,18 +93,6 @@ export default {
fill: none; fill: none;
stroke-width: 1; stroke-width: 1;
} }
circle {
fill: #fff;
}
}
.dv-bb2-line1 {
stroke: #fff;
}
.dv-bb2-line2 {
stroke: fade(#fff, 60);
} }
.border-box-content { .border-box-content {

View File

@@ -1,14 +1,26 @@
<template> <template>
<div class="dv-border-box-3" :ref="ref"> <div class="dv-border-box-3" :ref="ref">
<svg class="dv-border-svg-container" :width="width" :height="height"> <svg class="dv-border-svg-container" :width="width" :height="height">
<polygon :fill="backgroundColor" :points="`
23, 23 ${width - 24}, 23 ${width - 24}, ${height - 24} 23, ${height - 24}
`" />
<polyline class="dv-bb3-line1" <polyline class="dv-bb3-line1"
:points="`4, 4 ${width - 22} ,4 ${width - 22}, ${height - 22} 4, ${height - 22} 4, 4`" /> :stroke="mergedColor[0]"
:points="`4, 4 ${width - 22} ,4 ${width - 22}, ${height - 22} 4, ${height - 22} 4, 4`"
/>
<polyline class="dv-bb3-line2" <polyline class="dv-bb3-line2"
:points="`10, 10 ${width - 16}, 10 ${width - 16}, ${height - 16} 10, ${height - 16} 10, 10`" /> :stroke="mergedColor[1]"
:points="`10, 10 ${width - 16}, 10 ${width - 16}, ${height - 16} 10, ${height - 16} 10, 10`"
/>
<polyline class="dv-bb3-line2" <polyline class="dv-bb3-line2"
:points="`16, 16 ${width - 10}, 16 ${width - 10}, ${height - 10} 16, ${height - 10} 16, 16`" /> :stroke="mergedColor[1]"
:points="`16, 16 ${width - 10}, 16 ${width - 10}, ${height - 10} 16, ${height - 10} 16, 16`"
/>
<polyline class="dv-bb3-line2" <polyline class="dv-bb3-line2"
:points="`22, 22 ${width - 4}, 22 ${width - 4}, ${height - 4} 22, ${height - 4} 22, 22`" /> :stroke="mergedColor[1]"
:points="`22, 22 ${width - 4}, 22 ${width - 4}, ${height - 4} 22, ${height - 4} 22, 22`"
/>
</svg> </svg>
<div class="border-box-content"> <div class="border-box-content">
@@ -20,13 +32,50 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox3', name: 'DvBorderBox3',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () { data () {
return { return {
ref: 'border-box-3' ref: 'border-box-3',
defaultColor: ['#2862b7', '#2862b7'],
mergedColor: []
} }
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>
@@ -46,7 +95,6 @@ export default {
polyline { polyline {
fill: none; fill: none;
stroke: #2862b7;
} }
} }

View File

@@ -1,18 +1,30 @@
<template> <template>
<div class="dv-border-box-4" :ref="ref"> <div class="dv-border-box-4" :ref="ref">
<svg :class="`dv-border-svg-container ${reverse && 'dv-reverse'}`" :width="width" :height="height"> <svg :class="`dv-border-svg-container ${reverse && 'dv-reverse'}`" :width="width" :height="height">
<polyline class="dv-bb4-line-1" :points="`145, ${height - 5} 40, ${height - 5} 10, ${height - 35} <polygon :fill="backgroundColor" :points="`
10, 40 40, 5 150, 5 170, 20 ${width - 15}, 20`"/> ${width - 15}, 22 170, 22 150, 7 40, 7 28, 21 32, 24
<polyline class="dv-bb4-line-2" :points="`245, ${height - 1} 36, ${height - 1} 14, ${height - 23} 16, 42 16, ${height - 32} 41, ${height - 7} ${width - 15}, ${height - 7}
14, ${height - 100}`" /> `" />
<polyline class="dv-bb4-line-3" :points="`7, ${height - 40} 7, ${height - 75}`" />
<polyline class="dv-bb4-line-4" :points="`28, 24 13, 41 13, 64`" /> <polyline class="dv-bb4-line-1"
<polyline class="dv-bb4-line-5" :points="`5, 45 5, 140`" /> :stroke="mergedColor[0]"
<polyline class="dv-bb4-line-6" :points="`14, 75 14, 180`" /> :points="`145, ${height - 5} 40, ${height - 5} 10, ${height - 35}
<polyline class="dv-bb4-line-7" :points="`55, 11 147, 11 167, 26 250, 26`" /> 10, 40 40, 5 150, 5 170, 20 ${width - 15}, 20`"
<polyline class="dv-bb4-line-8" :points="`158, 5 173, 16`" /> />
<polyline class="dv-bb4-line-9" :points="`200, 17 ${width - 10}, 17`" /> <polyline
<polyline class="dv-bb4-line-10" :points="`385, 17 ${width - 10}, 17`" /> :stroke="mergedColor[1]"
class="dv-bb4-line-2" :points="`245, ${height - 1} 36, ${height - 1} 14, ${height - 23}
14, ${height - 100}`"
/>
<polyline class="dv-bb4-line-3" :stroke="mergedColor[0]" :points="`7, ${height - 40} 7, ${height - 75}`" />
<polyline class="dv-bb4-line-4" :stroke="mergedColor[0]" :points="`28, 24 13, 41 13, 64`" />
<polyline class="dv-bb4-line-5" :stroke="mergedColor[0]" :points="`5, 45 5, 140`" />
<polyline class="dv-bb4-line-6" :stroke="mergedColor[1]" :points="`14, 75 14, 180`" />
<polyline class="dv-bb4-line-7" :stroke="mergedColor[1]" :points="`55, 11 147, 11 167, 26 250, 26`" />
<polyline class="dv-bb4-line-8" :stroke="mergedColor[1]" :points="`158, 5 173, 16`" />
<polyline class="dv-bb4-line-9" :stroke="mergedColor[0]" :points="`200, 17 ${width - 10}, 17`" />
<polyline class="dv-bb4-line-10" :stroke="mergedColor[1]" :points="`385, 17 ${width - 10}, 17`" />
</svg> </svg>
<div class="border-box-content"> <div class="border-box-content">
@@ -24,19 +36,54 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox4', name: 'DvBorderBox4',
mixins: [autoResize], mixins: [autoResize],
data () {
return {
ref: 'border-box-4'
}
},
props: { props: {
color: {
type: Array,
default: () => ([])
},
reverse: { reverse: {
type: Boolean, type: Boolean,
default: false default: false
},
backgroundColor: {
type: String,
default: 'transparent'
} }
},
data () {
return {
ref: 'border-box-4',
defaultColor: ['red', 'rgba(0,0,255,0.8)'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>
@@ -63,14 +110,6 @@ export default {
} }
} }
.sred {
stroke: red;
}
.sblue {
stroke: fade(blue, 80);
}
.sw1 { .sw1 {
stroke-width: 1; stroke-width: 1;
} }
@@ -81,53 +120,43 @@ export default {
} }
.dv-bb4-line-1 { .dv-bb4-line-1 {
.sred;
.sw1; .sw1;
} }
.dv-bb4-line-2 { .dv-bb4-line-2 {
.sblue;
.sw1; .sw1;
} }
.dv-bb4-line-3 { .dv-bb4-line-3 {
.sred;
.sw3; .sw3;
} }
.dv-bb4-line-4 { .dv-bb4-line-4 {
.sred;
.sw3; .sw3;
} }
.dv-bb4-line-5 { .dv-bb4-line-5 {
.sred;
.sw1; .sw1;
} }
.dv-bb4-line-6 { .dv-bb4-line-6 {
.sblue;
.sw1; .sw1;
} }
.dv-bb4-line-7 { .dv-bb4-line-7 {
.sblue;
.sw1; .sw1;
} }
.dv-bb4-line-8 { .dv-bb4-line-8 {
.sblue;
.sw3; .sw3;
} }
.dv-bb4-line-9 { .dv-bb4-line-9 {
.sred;
.sw3; .sw3;
stroke-dasharray: 100 250; stroke-dasharray: 100 250;
} }
.dv-bb4-line-10 { .dv-bb4-line-10 {
.sblue;
.sw1; .sw1;
stroke-dasharray: 80 270; stroke-dasharray: 80 270;
} }

View File

@@ -1,14 +1,26 @@
<template> <template>
<div class="dv-border-box-5" :ref="ref"> <div class="dv-border-box-5" :ref="ref">
<svg :class="`dv-svg-container ${reverse && 'dv-reverse'}`" :width="width" :height="height"> <svg :class="`dv-svg-container ${reverse && 'dv-reverse'}`" :width="width" :height="height">
<polyline class="dv-bb5-line-1" :points="`8, 5 ${width - 5}, 5 ${width - 5}, ${height - 100} <polygon :fill="backgroundColor" :points="`
${width - 100}, ${height - 5} 8, ${height - 5} 8, 5`" /> 10, 22 ${width - 22}, 22 ${width - 22}, ${height - 86} ${width - 84}, ${height - 24} 10, ${height - 24}
<polyline class="dv-bb5-line-2" :points="`3, 5 ${width - 20}, 5 ${width - 20}, ${height - 60} `" />
${width - 74}, ${height - 5} 3, ${height - 5} 3, 5`" />
<polyline class="dv-bb5-line-3" :points="`50, 13 ${width - 35}, 13`" /> <polyline
<polyline class="dv-bb5-line-4" :points="`15, 20 ${width - 35}, 20`" /> class="dv-bb5-line-1"
<polyline class="dv-bb5-line-5" :points="`15, ${height - 20} ${width - 110}, ${height - 20}`" /> :stroke="mergedColor[0]"
<polyline class="dv-bb5-line-6" :points="`15, ${height - 13} ${width - 110}, ${height - 13}`" /> :points="`8, 5 ${width - 5}, 5 ${width - 5}, ${height - 100}
${width - 100}, ${height - 5} 8, ${height - 5} 8, 5`"
/>
<polyline
class="dv-bb5-line-2"
:stroke="mergedColor[1]"
:points="`3, 5 ${width - 20}, 5 ${width - 20}, ${height - 60}
${width - 74}, ${height - 5} 3, ${height - 5} 3, 5`"
/>
<polyline class="dv-bb5-line-3" :stroke="mergedColor[1]" :points="`50, 13 ${width - 35}, 13`" />
<polyline class="dv-bb5-line-4" :stroke="mergedColor[1]" :points="`15, 20 ${width - 35}, 20`" />
<polyline class="dv-bb5-line-5" :stroke="mergedColor[1]" :points="`15, ${height - 20} ${width - 110}, ${height - 20}`" />
<polyline class="dv-bb5-line-6" :stroke="mergedColor[1]" :points="`15, ${height - 13} ${width - 110}, ${height - 13}`" />
</svg> </svg>
<div class="border-box-content"> <div class="border-box-content">
@@ -20,19 +32,54 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox5', name: 'DvBorderBox5',
mixins: [autoResize], mixins: [autoResize],
data () {
return {
ref: 'border-box-5'
}
},
props: { props: {
color: {
type: Array,
default: () => ([])
},
reverse: { reverse: {
type: Boolean, type: Boolean,
default: false default: false
},
backgroundColor: {
type: String,
default: 'transparent'
} }
},
data () {
return {
ref: 'border-box-5',
defaultColor: ['rgba(255, 255, 255, 0.35)', 'rgba(255, 255, 255, 0.20)'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>
@@ -59,23 +106,16 @@ export default {
} }
} }
.dv-bb5-line-1 { .dv-bb5-line-1, .dv-bb5-line-2 {
stroke-width: 1; stroke-width: 1;
stroke: fade(#fff, 35);
}
.dv-bb5-line-2 {
stroke: fade(#fff, 20);
} }
.dv-bb5-line-3, .dv-bb5-line-6 { .dv-bb5-line-3, .dv-bb5-line-6 {
stroke-width: 5; stroke-width: 5;
stroke: fade(#fff, 15);
} }
.dv-bb5-line-4, .dv-bb5-line-5 { .dv-bb5-line-4, .dv-bb5-line-5 {
stroke-width: 2; stroke-width: 2;
stroke: fade(#fff, 15);
} }
.border-box-content { .border-box-content {

View File

@@ -1,22 +1,26 @@
<template> <template>
<div class="dv-border-box-6" :ref="ref"> <div class="dv-border-box-6" :ref="ref">
<svg class="dv-svg-container" :width="width" :height="height"> <svg class="dv-svg-container" :width="width" :height="height">
<circle cx="5" cy="5" r="2"/> <polygon :fill="backgroundColor" :points="`
<circle :cx="width - 5" cy="5" r="2" /> 9, 7 ${width - 9}, 7 ${width - 9}, ${height - 7} 9, ${height - 7}
<circle :cx="width - 5" :cy="height - 5" r="2" /> `" />
<circle cx="5" :cy="height - 5" r="2" />
<polyline :points="`10, 4 ${width - 10}, 4`" /> <circle :fill="mergedColor[1]" cx="5" cy="5" r="2"/>
<polyline :points="`10, ${height - 4} ${width - 10}, ${height - 4}`" /> <circle :fill="mergedColor[1]" :cx="width - 5" cy="5" r="2" />
<polyline :points="`5, 70 5, ${height - 70}`" /> <circle :fill="mergedColor[1]" :cx="width - 5" :cy="height - 5" r="2" />
<polyline :points="`${width - 5}, 70 ${width - 5}, ${height - 70}`" /> <circle :fill="mergedColor[1]" cx="5" :cy="height - 5" r="2" />
<polyline :points="`3, 10, 3, 50`" /> <polyline :stroke="mergedColor[0]" :points="`10, 4 ${width - 10}, 4`" />
<polyline :points="`7, 30 7, 80`" /> <polyline :stroke="mergedColor[0]" :points="`10, ${height - 4} ${width - 10}, ${height - 4}`" />
<polyline :points="`${width - 3}, 10 ${width - 3}, 50`" /> <polyline :stroke="mergedColor[0]" :points="`5, 70 5, ${height - 70}`" />
<polyline :points="`${width - 7}, 30 ${width - 7}, 80`" /> <polyline :stroke="mergedColor[0]" :points="`${width - 5}, 70 ${width - 5}, ${height - 70}`" />
<polyline :points="`3, ${height - 10} 3, ${height - 50}`" /> <polyline :stroke="mergedColor[0]" :points="`3, 10, 3, 50`" />
<polyline :points="`7, ${height - 30} 7, ${height - 80}`" /> <polyline :stroke="mergedColor[0]" :points="`7, 30 7, 80`" />
<polyline :points="`${width - 3}, ${height - 10} ${width - 3}, ${height - 50}`" /> <polyline :stroke="mergedColor[0]" :points="`${width - 3}, 10 ${width - 3}, 50`" />
<polyline :points="`${width - 7}, ${height - 30} ${width - 7}, ${height - 80}`" /> <polyline :stroke="mergedColor[0]" :points="`${width - 7}, 30 ${width - 7}, 80`" />
<polyline :stroke="mergedColor[0]" :points="`3, ${height - 10} 3, ${height - 50}`" />
<polyline :stroke="mergedColor[0]" :points="`7, ${height - 30} 7, ${height - 80}`" />
<polyline :stroke="mergedColor[0]" :points="`${width - 3}, ${height - 10} ${width - 3}, ${height - 50}`" />
<polyline :stroke="mergedColor[0]" :points="`${width - 7}, ${height - 30} ${width - 7}, ${height - 80}`" />
</svg> </svg>
<div class="border-box-content"> <div class="border-box-content">
@@ -28,13 +32,50 @@
<script> <script>
import autoResize from '../../../mixin/autoResize.js' import autoResize from '../../../mixin/autoResize.js'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox6', name: 'DvBorderBox6',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () { data () {
return { return {
ref: 'border-box-6' ref: 'border-box-6',
defaultColor: ['rgba(255, 255, 255, 0.35)', 'gray'],
mergedColor: []
} }
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>
@@ -52,14 +93,9 @@ export default {
width: 100%; width: 100%;
height: 100%; height: 100%;
circle {
fill: gray;
}
polyline { polyline {
fill: none; fill: none;
stroke-width: 1; stroke-width: 1;
stroke: fade(#fff, 35);
} }
} }

View File

@@ -1,15 +1,20 @@
<template>
<div class="dv-border-box-7" :ref="ref">
<svg class="dv-svg-container" :width="width" :height="height">
<polyline class="dv-bb7-line-width-2" :points="`0, 25 0, 0 25, 0`" />
<polyline class="dv-bb7-line-width-2" :points="`${width - 25}, 0 ${width}, 0 ${width}, 25`" />
<polyline class="dv-bb7-line-width-2" :points="`${width - 25}, ${height} ${width}, ${height} ${width}, ${height - 25}`" />
<polyline class="dv-bb7-line-width-2" :points="`0, ${height - 25} 0, ${height} 25, ${height}`" />
<polyline class="dv-bb7-line-width-5" :points="`0, 10 0, 0 10, 0`" /> <template>
<polyline class="dv-bb7-line-width-5" :points="`${width - 10}, 0 ${width}, 0 ${width}, 10`" /> <div
<polyline class="dv-bb7-line-width-5" :points="`${width - 10}, ${height} ${width}, ${height} ${width}, ${height - 10}`" /> class="dv-border-box-7"
<polyline class="dv-bb7-line-width-5" :points="`0, ${height - 10} 0, ${height} 10, ${height}`" /> :style="`box-shadow: inset 0 0 40px ${mergedColor[0]}; border: 1px solid ${mergedColor[0]}; background-color: ${backgroundColor}`"
:ref="ref"
>
<svg class="dv-svg-container" :width="width" :height="height">
<polyline class="dv-bb7-line-width-2" :stroke="mergedColor[0]" :points="`0, 25 0, 0 25, 0`" />
<polyline class="dv-bb7-line-width-2" :stroke="mergedColor[0]" :points="`${width - 25}, 0 ${width}, 0 ${width}, 25`" />
<polyline class="dv-bb7-line-width-2" :stroke="mergedColor[0]" :points="`${width - 25}, ${height} ${width}, ${height} ${width}, ${height - 25}`" />
<polyline class="dv-bb7-line-width-2" :stroke="mergedColor[0]" :points="`0, ${height - 25} 0, ${height} 25, ${height}`" />
<polyline class="dv-bb7-line-width-5" :stroke="mergedColor[1]" :points="`0, 10 0, 0 10, 0`" />
<polyline class="dv-bb7-line-width-5" :stroke="mergedColor[1]" :points="`${width - 10}, 0 ${width}, 0 ${width}, 10`" />
<polyline class="dv-bb7-line-width-5" :stroke="mergedColor[1]" :points="`${width - 10}, ${height} ${width}, ${height} ${width}, ${height - 10}`" />
<polyline class="dv-bb7-line-width-5" :stroke="mergedColor[1]" :points="`0, ${height - 10} 0, ${height} 10, ${height}`" />
</svg> </svg>
<div class="border-box-content"> <div class="border-box-content">
@@ -21,26 +26,59 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox7', name: 'DvBorderBox7',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () { data () {
return { return {
ref: 'border-box-7' ref: 'border-box-7',
defaultColor: ['rgba(128,128,128,0.3)', 'rgba(128,128,128,0.5)'],
mergedColor: []
} }
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>
<style lang="less"> <style lang="less">
.dv-border-box-7 { .dv-border-box-7 {
@color: fade(gray, 30);
position: relative; position: relative;
width: 100%; width: 100%;
height: 100%; height: 100%;
box-shadow: inset 0 0 40px fade(@color, 30);
border: 1px solid @color;
.dv-svg-container { .dv-svg-container {
position: absolute; position: absolute;
@@ -56,12 +94,10 @@ export default {
} }
.dv-bb7-line-width-2 { .dv-bb7-line-width-2 {
stroke: @color;
stroke-width: 2; stroke-width: 2;
} }
.dv-bb7-line-width-5 { .dv-bb7-line-width-5 {
stroke: fade(gray, 50);
stroke-width: 5; stroke-width: 5;
} }

View File

@@ -4,7 +4,7 @@
<defs> <defs>
<path <path
:id="path" :id="path"
:d="`M2.5, 2.5 L${width - 2.5}, 2.5 L${width - 2.5}, ${height - 2.5} L2.5, ${height - 2.5} L2.5, 2.5`" :d="pathD"
fill="transparent" fill="transparent"
/> />
<radialGradient <radialGradient
@@ -24,8 +24,8 @@
<mask :id="mask"> <mask :id="mask">
<circle cx="0" cy="0" r="150" :fill="`url(#${gradient})`"> <circle cx="0" cy="0" r="150" :fill="`url(#${gradient})`">
<animateMotion <animateMotion
dur="3s" :dur="`${dur}s`"
:path="`M2.5, 2.5 L${width - 2.5}, 2.5 L${width - 2.5}, ${height - 2.5} L2.5, ${height - 2.5} L2.5, 2.5`" :path="pathD"
rotate="auto" rotate="auto"
repeatCount="indefinite" repeatCount="indefinite"
/> />
@@ -33,14 +33,16 @@
</mask> </mask>
</defs> </defs>
<polygon :fill="backgroundColor" :points="`5, 5 ${width - 5}, 5 ${width - 5} ${height - 5} 5, ${height - 5}`" />
<use <use
stroke="#235fa7" :stroke="mergedColor[0]"
stroke-width="1" stroke-width="1"
:xlink:href="`#${path}`" :xlink:href="`#${path}`"
/> />
<use <use
stroke="#4fd2dd" :stroke="mergedColor[1]"
stroke-width="3" stroke-width="3"
:xlink:href="`#${path}`" :xlink:href="`#${path}`"
:mask="`url(#${mask})`" :mask="`url(#${mask})`"
@@ -49,7 +51,7 @@
attributeName="stroke-dasharray" attributeName="stroke-dasharray"
:from="`0, ${length}`" :from="`0, ${length}`"
:to="`${length}, 0`" :to="`${length}, 0`"
dur="3s" :dur="`${dur}s`"
repeatCount="indefinite" repeatCount="indefinite"
/> />
</use> </use>
@@ -63,16 +65,44 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { uuid } from '../../../util/index'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox8', name: 'DvBorderBox8',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
dur: {
type: Number,
default: 3
},
backgroundColor: {
type: String,
default: 'transparent'
},
reverse: {
type: Boolean,
default: false
}
},
data () { data () {
const id = uuid()
return { return {
ref: 'border-box-8', ref: 'border-box-8',
path: `border-box-8-path-${(new Date()).getTime()}`, path: `border-box-8-path-${id}`,
gradient: `border-box-8-gradient-${(new Date()).getTime()}`, gradient: `border-box-8-gradient-${id}`,
mask: `border-box-8-mask-${(new Date()).getTime()}` mask: `border-box-8-mask-${id}`,
defaultColor: ['#235fa7', '#4fd2dd'],
mergedColor: []
} }
}, },
computed: { computed: {
@@ -80,7 +110,33 @@ export default {
const { width, height } = this const { width, height } = this
return (width + height - 5) * 2 return (width + height - 5) * 2
},
pathD () {
const { reverse, width, height } = this
if (reverse) return `M 2.5, 2.5 L 2.5, ${height - 2.5} L ${width - 2.5}, ${height - 2.5} L ${width - 2.5}, 2.5 L 2.5, 2.5`
return `M2.5, 2.5 L${width - 2.5}, 2.5 L${width - 2.5}, ${height - 2.5} L2.5, ${height - 2.5} L2.5, 2.5`
} }
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -3,8 +3,40 @@
<svg class="dv-svg-container" :width="width" :height="height"> <svg class="dv-svg-container" :width="width" :height="height">
<defs> <defs>
<linearGradient :id="gradientId" x1="0%" y1="0%" x2="100%" y2="100%"> <linearGradient :id="gradientId" x1="0%" y1="0%" x2="100%" y2="100%">
<stop offset="0%" stop-color="#11eefd" /> <animate
<stop offset="100%" stop-color="#0078d2" /> attributeName="x1"
values="0%;100%;0%"
dur="10s"
begin="0s"
repeatCount="indefinite"
/>
<animate
attributeName="x2"
values="100%;0%;100%"
dur="10s"
begin="0s"
repeatCount="indefinite"
/>
<stop offset="0%" :stop-color="mergedColor[0]">
<animate
attributeName="stop-color"
:values="`${mergedColor[0]};${mergedColor[1]};${mergedColor[0]}`"
dur="10s"
begin="0s"
repeatCount="indefinite"
/>
</stop>
<stop offset="100%" :stop-color="mergedColor[1]">
<animate
attributeName="stop-color"
:values="`${mergedColor[1]};${mergedColor[0]};${mergedColor[1]}`"
dur="10s"
begin="0s"
repeatCount="indefinite"
/>
</stop>
</linearGradient> </linearGradient>
<mask :id="maskId"> <mask :id="maskId">
@@ -73,6 +105,15 @@
</mask> </mask>
</defs> </defs>
<polygon :fill="backgroundColor" :points="`
15, 9 ${width * 0.1 + 1}, 9 ${width * 0.1 + 4}, 6 ${width * 0.52 + 2}, 6
${width * 0.52 + 6}, 10 ${width * 0.58 - 7}, 10 ${width * 0.58 - 2}, 6
${width * 0.9 + 2}, 6 ${width * 0.9 + 6}, 10 ${width - 10}, 10 ${width - 10}, ${height * 0.1 - 6}
${width - 6}, ${height * 0.1 - 1} ${width - 6}, ${height * 0.8 + 1} ${width - 10}, ${height * 0.8 + 6}
${width - 10}, ${height - 10} ${width * 0.92 + 7}, ${height - 10} ${width * 0.92 + 2}, ${height - 6}
11, ${height - 6} 11, ${height * 0.15 - 2} 15, ${height * 0.15 - 7}
`" />
<rect x="0" y="0" :width="width" :height="height" :fill="`url(#${gradientId})`" :mask="`url(#${maskId})`" /> <rect x="0" y="0" :width="width" :height="height" :fill="`url(#${gradientId})`" :mask="`url(#${maskId})`" />
</svg> </svg>
@@ -84,17 +125,56 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { uuid } from '../../../util/index'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvBorderBox9', name: 'DvBorderBox9',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
},
backgroundColor: {
type: String,
default: 'transparent'
}
},
data () { data () {
const id = uuid()
return { return {
ref: 'border-box-9', ref: 'border-box-9',
gradientId: `border-box-9-gradient-${(new Date()).getTime()}`, gradientId: `border-box-9-gradient-${id}`,
maskId: `border-box-9-mask-${(new Date()).getTime()}` maskId: `border-box-9-mask-${id}`,
defaultColor: ['#11eefd', '#0078d2'],
mergedColor: []
} }
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -7,16 +7,23 @@
</div> </div>
<div class="capsule-container"> <div class="capsule-container">
<div <div class="capsule-item" v-for="(capsule, index) in capsuleLength" :key="index">
class="capsule-item" <div
v-for="(capsule, index) in capsuleLength" class="capsule-item-column"
:key="index" :style="`width: ${capsule * 100}%; background-color: ${mergedConfig.colors[index % mergedConfig.colors.length]};`"
> >
<div :style="`width: ${capsule * 100}%; background-color: ${mergedConfig.colors[index % mergedConfig.colors.length]};`"></div> <div
v-if="mergedConfig.showValue"
class="capsule-item-value"
>{{ capsuleValue[index] }}</div>
</div>
</div> </div>
<div class="unit-label"> <div class="unit-label">
<div v-for="(label, index) in labelData" :key="label + index">{{ label }}</div> <div
v-for="(label, index) in labelData"
:key="label + index"
>{{ label }}</div>
</div> </div>
</div> </div>
@@ -38,7 +45,7 @@ export default {
default: () => ({}) default: () => ({})
} }
}, },
data () { data() {
return { return {
defaultConfig: { defaultConfig: {
/** /**
@@ -54,42 +61,61 @@ export default {
* @default color = ['#37a2da', '#32c5e9', '#67e0e3', '#9fe6b8', '#ffdb5c', '#ff9f7f', '#fb7293'] * @default color = ['#37a2da', '#32c5e9', '#67e0e3', '#9fe6b8', '#ffdb5c', '#ff9f7f', '#fb7293']
* @example color = ['#000', 'rgb(0, 0, 0)', 'rgba(0, 0, 0, 1)', 'red'] * @example color = ['#000', 'rgb(0, 0, 0)', 'rgba(0, 0, 0, 1)', 'red']
*/ */
colors: ['#37a2da', '#32c5e9', '#67e0e3', '#9fe6b8', '#ffdb5c', '#ff9f7f', '#fb7293'], colors: [
'#37a2da',
'#32c5e9',
'#67e0e3',
'#9fe6b8',
'#ffdb5c',
'#ff9f7f',
'#fb7293'
],
/** /**
* @description Chart unit * @description Chart unit
* @type {String} * @type {String}
* @default unit = '' * @default unit = ''
*/ */
unit: '' unit: '',
/**
* @description Show item value
* @type {Boolean}
* @default showValue = false
*/
showValue: false
}, },
mergedConfig: null, mergedConfig: null,
capsuleLength: [], capsuleLength: [],
labelData: [] capsuleValue: [],
labelData: [],
labelDataLength: []
} }
}, },
watch: { watch: {
config () { config() {
const { calcData } = this const { calcData } = this
calcData() calcData()
} }
}, },
methods: { methods: {
calcData () { calcData() {
const { mergeConfig, calcCapsuleLengthAndLabelData } = this const { mergeConfig, calcCapsuleLengthAndLabelData } = this
mergeConfig() mergeConfig()
calcCapsuleLengthAndLabelData() calcCapsuleLengthAndLabelData()
}, },
mergeConfig () { mergeConfig() {
let { config, defaultConfig } = this let { config, defaultConfig } = this
this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {}) this.mergedConfig = deepMerge(
deepClone(defaultConfig, true),
config || {}
)
}, },
calcCapsuleLengthAndLabelData () { calcCapsuleLengthAndLabelData() {
const { data } = this.mergedConfig const { data } = this.mergedConfig
if (!data.length) return if (!data.length) return
@@ -98,14 +124,24 @@ export default {
const maxValue = Math.max(...capsuleValue) const maxValue = Math.max(...capsuleValue)
this.capsuleLength = capsuleValue.map(v => maxValue ? v / maxValue : 0) this.capsuleValue = capsuleValue
this.capsuleLength = capsuleValue.map(v => (maxValue ? v / maxValue : 0))
const oneFifth = maxValue / 5 const oneFifth = maxValue / 5
this.labelData = new Array(6).fill(0).map((v, i) => Math.ceil(i * oneFifth)) const labelData = Array.from(
new Set(new Array(6).fill(0).map((v, i) => Math.ceil(i * oneFifth)))
)
this.labelData = labelData
this.labelDataLength = Array.from(labelData).map(v =>
maxValue ? v / maxValue : 0
)
} }
}, },
mounted () { mounted() {
const { calcData } = this const { calcData } = this
calcData() calcData()
@@ -150,21 +186,30 @@ export default {
margin: 5px 0px; margin: 5px 0px;
border-radius: 5px; border-radius: 5px;
div { .capsule-item-column {
position: relative;
height: 8px; height: 8px;
margin-top: 1px; margin-top: 1px;
border-radius: 5px; border-radius: 5px;
transition: all 0.3s; transition: all 0.3s;
display: flex;
justify-content: flex-end;
align-items: center;
.capsule-item-value {
font-size: 12px;
transform: translateX(100%);
}
} }
} }
.unit-label { .unit-label {
height: 20px; height: 20px;
font-size: 12px; font-size: 12px;
position: relative;
display: flex; display: flex;
flex-direction: row;
align-items: center;
justify-content: space-between; justify-content: space-between;
align-items: center;
} }
.unit-text { .unit-text {

View File

@@ -5,6 +5,8 @@
</template> </template>
<script> <script>
import { uuid } from '../../../util/index'
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import Charts from '@jiaminghi/charts' import Charts from '@jiaminghi/charts'
@@ -19,9 +21,10 @@ export default {
} }
}, },
data () { data () {
const id = uuid()
return { return {
ref: `charts-container-${(new Date()).getTime()}`, ref: `charts-container-${id}`,
chartRef: `chart-${(new Date()).getTime()}`, chartRef: `chart-${id}`,
chart: null chart: null
} }
@@ -34,7 +37,7 @@ export default {
if (!option) option = {} if (!option) option = {}
chart.setOption(option) chart.setOption(option, true)
} }
}, },
methods: { methods: {

View File

@@ -8,7 +8,7 @@
<rect <rect
v-if="Math.random() > 0.6" v-if="Math.random() > 0.6"
:key="i" :key="i"
fill="#fff" :fill="mergedColor[0]"
:x="point[0] - halfPointSideLength" :x="point[0] - halfPointSideLength"
:y="point[1] - halfPointSideLength" :y="point[1] - halfPointSideLength"
:width="pointSideLength" :width="pointSideLength"
@@ -17,7 +17,7 @@
<animate <animate
v-if="Math.random() > 0.6" v-if="Math.random() > 0.6"
attributeName="fill" attributeName="fill"
values="#fff;transparent" :values="`${mergedColor[0]};transparent`"
dur="1s" dur="1s"
:begin="Math.random() * 2" :begin="Math.random() * 2"
repeatCount="indefinite" repeatCount="indefinite"
@@ -27,7 +27,7 @@
<rect <rect
v-if="rects[0]" v-if="rects[0]"
fill="#0de7c2" :fill="mergedColor[1]"
:x="rects[0][0] - pointSideLength" :x="rects[0][0] - pointSideLength"
:y="rects[0][1] - pointSideLength" :y="rects[0][1] - pointSideLength"
:width="pointSideLength * 2" :width="pointSideLength * 2"
@@ -61,7 +61,7 @@
<rect <rect
v-if="rects[1]" v-if="rects[1]"
fill="#0de7c2" :fill="mergedColor[1]"
:x="rects[1][0] - 40" :x="rects[1][0] - 40"
:y="rects[1][1] - pointSideLength" :y="rects[1][1] - pointSideLength"
:width="40" :width="40"
@@ -87,9 +87,19 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvDecoration1', name: 'DvDecoration1',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
}
},
data () { data () {
const pointSideLength = 2.5 const pointSideLength = 2.5
@@ -108,7 +118,18 @@ export default {
points: [], points: [],
rects: [] rects: [],
defaultColor: ['#fff', '#0de7c2'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
} }
}, },
methods: { methods: {
@@ -160,7 +181,17 @@ export default {
const { calcSVGData } = this const { calcSVGData } = this
calcSVGData() calcSVGData()
},
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
} }
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

@@ -2,13 +2,13 @@
<div class="dv-decoration-10" :ref="ref"> <div class="dv-decoration-10" :ref="ref">
<svg :width="width" :height="height"> <svg :width="width" :height="height">
<polyline <polyline
stroke="rgba(0, 194, 255, 0.3)" :stroke="mergedColor[1]"
stroke-width="2" stroke-width="2"
:points="`0, ${height / 2} ${width}, ${height / 2}`" :points="`0, ${height / 2} ${width}, ${height / 2}`"
/> />
<polyline <polyline
stroke="rgba(0, 194, 255, 1)" :stroke="mergedColor[0]"
stroke-width="2" stroke-width="2"
:points="`5, ${height / 2} ${width * 0.2 - 3}, ${height / 2}`" :points="`5, ${height / 2} ${width * 0.2 - 3}, ${height / 2}`"
:stroke-dasharray="`0, ${width * 0.2}`" :stroke-dasharray="`0, ${width * 0.2}`"
@@ -32,7 +32,7 @@
</polyline> </polyline>
<polyline <polyline
stroke="rgba(0, 194, 255, 1)" :stroke="mergedColor[0]"
stroke-width="2" stroke-width="2"
:points="`${width * 0.2 + 3}, ${height / 2} ${width * 0.8 - 3}, ${height / 2}`" :points="`${width * 0.2 + 3}, ${height / 2} ${width * 0.8 - 3}, ${height / 2}`"
:stroke-dasharray="`0, ${width * 0.6}`" :stroke-dasharray="`0, ${width * 0.6}`"
@@ -55,7 +55,7 @@
</polyline> </polyline>
<polyline <polyline
stroke="rgba(0, 194, 255, 1)" :stroke="mergedColor[0]"
stroke-width="2" stroke-width="2"
:points="`${width * 0.8 + 3}, ${height / 2} ${width - 5}, ${height / 2}`" :points="`${width * 0.8 + 3}, ${height / 2} ${width - 5}, ${height / 2}`"
:stroke-dasharray="`0, ${width * 0.2}`" :stroke-dasharray="`0, ${width * 0.2}`"
@@ -77,65 +77,65 @@
/> />
</polyline> </polyline>
<circle cx="2" :cy="height / 2" r="2" fill="#03709f"> <circle cx="2" :cy="height / 2" r="2" :fill="mergedColor[1]">
<animate <animate
:id="animationId1" :id="animationId1"
attributeName="fill" attributeName="fill"
values="#03709f;#00c2ff" :values="`${mergedColor[1]};${mergedColor[0]}`"
:begin="`0s;${animationId7}.end`" :begin="`0s;${animationId7}.end`"
dur="0.3s" dur="0.3s"
fill="freeze" fill="freeze"
/> />
</circle> </circle>
<circle :cx="width * 0.2" :cy="height / 2" r="2" fill="#03709f"> <circle :cx="width * 0.2" :cy="height / 2" r="2" :fill="mergedColor[1]">
<animate <animate
:id="animationId3" :id="animationId3"
attributeName="fill" attributeName="fill"
values="#03709f;#00c2ff" :values="`${mergedColor[1]};${mergedColor[0]}`"
:begin="`${animationId2}.end`" :begin="`${animationId2}.end`"
dur="0.3s" dur="0.3s"
fill="freeze" fill="freeze"
/> />
<animate <animate
attributeName="fill" attributeName="fill"
values="#03709f;#03709f" :values="`${mergedColor[1]};${mergedColor[1]}`"
dur="0.01s" dur="0.01s"
:begin="`${animationId7}.end`" :begin="`${animationId7}.end`"
fill="freeze" fill="freeze"
/> />
</circle> </circle>
<circle :cx="width * 0.8" :cy="height / 2" r="2" fill="#03709f"> <circle :cx="width * 0.8" :cy="height / 2" r="2" :fill="mergedColor[1]">
<animate <animate
:id="animationId5" :id="animationId5"
attributeName="fill" attributeName="fill"
values="#03709f;#00c2ff" :values="`${mergedColor[1]};${mergedColor[0]}`"
:begin="`${animationId4}.end`" :begin="`${animationId4}.end`"
dur="0.3s" dur="0.3s"
fill="freeze" fill="freeze"
/> />
<animate <animate
attributeName="fill" attributeName="fill"
values="#03709f;#03709f" :values="`${mergedColor[1]};${mergedColor[1]}`"
dur="0.01s" dur="0.01s"
:begin="`${animationId7}.end`" :begin="`${animationId7}.end`"
fill="freeze" fill="freeze"
/> />
</circle> </circle>
<circle :cx="width - 2" :cy="height / 2" r="2" fill="#03709f"> <circle :cx="width - 2" :cy="height / 2" r="2" :fill="mergedColor[1]">
<animate <animate
:id="animationId7" :id="animationId7"
attributeName="fill" attributeName="fill"
values="#03709f;#00c2ff" :values="`${mergedColor[1]};${mergedColor[0]}`"
:begin="`${animationId6}.end`" :begin="`${animationId6}.end`"
dur="0.3s" dur="0.3s"
fill="freeze" fill="freeze"
/> />
<animate <animate
attributeName="fill" attributeName="fill"
values="#03709f;#03709f" :values="`${mergedColor[1]};${mergedColor[1]}`"
dur="0.01s" dur="0.01s"
:begin="`${animationId7}.end`" :begin="`${animationId7}.end`"
fill="freeze" fill="freeze"
@@ -147,22 +147,57 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { uuid } from '../../../util/index'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvDecoration10', name: 'DvDecoration10',
mixins: [autoResize], mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
}
},
data () { data () {
const id = uuid()
return { return {
ref: 'decoration-10', ref: 'decoration-10',
animationId1: `d10ani1${(new Date()).getTime()}`, animationId1: `d10ani1${id}`,
animationId2: `d10ani2${(new Date()).getTime()}`, animationId2: `d10ani2${id}`,
animationId3: `d10ani3${(new Date()).getTime()}`, animationId3: `d10ani3${id}`,
animationId4: `d10ani4${(new Date()).getTime()}`, animationId4: `d10ani4${id}`,
animationId5: `d10ani5${(new Date()).getTime()}`, animationId5: `d10ani5${id}`,
animationId6: `d10ani6${(new Date()).getTime()}`, animationId6: `d10ani6${id}`,
animationId7: `d10ani7${(new Date()).getTime()}` animationId7: `d10ani7${id}`,
defaultColor: ['#00c2ff', 'rgba(0, 194, 255, 0.3)'],
mergedColor: []
} }
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
}
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

View File

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

View File

@@ -0,0 +1,124 @@
<template>
<div class="dv-decoration-11" :ref="ref">
<svg :width="width" :height="height">
<polygon
:fill="fade(mergedColor[1] || defaultColor[1], 10)"
:stroke="mergedColor[1]"
:points="`20 10, 25 4, 55 4 60 10`"
/>
<polygon
:fill="fade(mergedColor[1] || defaultColor[1], 10)"
:stroke="mergedColor[1]"
:points="`20 ${height - 10}, 25 ${height - 4}, 55 ${height - 4} 60 ${height - 10}`"
/>
<polygon
:fill="fade(mergedColor[1] || defaultColor[1], 10)"
:stroke="mergedColor[1]"
:points="`${width - 20} 10, ${width - 25} 4, ${width - 55} 4 ${width - 60} 10`"
/>
<polygon
:fill="fade(mergedColor[1] || defaultColor[1], 10)"
:stroke="mergedColor[1]"
:points="`${width - 20} ${height - 10}, ${width - 25} ${height - 4}, ${width - 55} ${height - 4} ${width - 60} ${height - 10}`"
/>
<polygon
:fill="fade(mergedColor[0] || defaultColor[0], 20)"
:stroke="mergedColor[0]"
:points="`
20 10, 5 ${height / 2} 20 ${height - 10}
${width - 20} ${height - 10} ${width - 5} ${height / 2} ${width - 20} 10
`"
/>
<polyline
fill="transparent"
:stroke="fade(mergedColor[0] || defaultColor[0], 70)"
:points="`25 18, 15 ${height / 2} 25 ${height - 18}`"
/>
<polyline
fill="transparent"
:stroke="fade(mergedColor[0] || defaultColor[0], 70)"
:points="`${width - 25} 18, ${width - 15} ${height / 2} ${width - 25} ${height - 18}`"
/>
</svg>
<div class="decoration-content">
<slot></slot>
</div>
</div>
</template>
<script>
import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
import { fade } from '@jiaminghi/color'
export default {
name: 'DvDecoration11',
mixins: [autoResize],
props: {
color: {
type: Array,
default: () => ([])
}
},
data () {
return {
ref: 'decoration-11',
defaultColor: ['#1a98fc', '#2cf7fe'],
mergedColor: []
}
},
watch: {
color () {
const { mergeColor } = this
mergeColor()
}
},
methods: {
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
},
fade
},
mounted () {
const { mergeColor } = this
mergeColor()
}
}
</script>
<style lang="less">
.dv-decoration-11 {
position: relative;
width: 100%;
height: 100%;
display: flex;
.decoration-content {
position: absolute;
top: 0px;
left: 0px;
width: 100%;
height: 100%;
display: flex;
align-items: center;
justify-content: center;
}
}
</style>

View File

@@ -1,7 +1,7 @@
<template> <template>
<div class="dv-decoration-2" :ref="ref"> <div class="dv-decoration-2" :ref="ref">
<svg :width="`${width}px`" :height="`${height}px`"> <svg :width="`${width}px`" :height="`${height}px`">
<rect :x="x" :y="y" :width="w" :height="h" fill="#3faacb"> <rect :x="x" :y="y" :width="w" :height="h" :fill="mergedColor[0]">
<animate <animate
:attributeName="reverse ? 'height' : 'width'" :attributeName="reverse ? 'height' : 'width'"
from="0" from="0"
@@ -14,7 +14,7 @@
/> />
</rect> </rect>
<rect :x="x" :y="y" width="1" height="1" fill="#fff"> <rect :x="x" :y="y" width="1" height="1" :fill="mergedColor[1]">
<animate <animate
:attributeName="reverse ? 'y' : 'x'" :attributeName="reverse ? 'y' : 'x'"
from="0" from="0"
@@ -33,10 +33,18 @@
<script> <script>
import autoResize from '../../../mixin/autoResize' import autoResize from '../../../mixin/autoResize'
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
export default { export default {
name: 'DvDecoration2', name: 'DvDecoration2',
mixins: [autoResize], mixins: [autoResize],
props: { props: {
color: {
type: Array,
default: () => ([])
},
reverse: { reverse: {
type: Boolean, type: Boolean,
default: false default: false
@@ -50,10 +58,19 @@ export default {
y: 0, y: 0,
w: 0, w: 0,
h: 0 h: 0,
defaultColor: ['#3faacb', '#fff'],
mergedColor: []
} }
}, },
watch: { watch: {
color () {
const { mergeColor } = this
mergeColor()
},
reverse () { reverse () {
const { calcSVGData } = this const { calcSVGData } = this
@@ -85,7 +102,17 @@ export default {
const { calcSVGData } = this const { calcSVGData } = this
calcSVGData() calcSVGData()
},
mergeColor () {
const { color, defaultColor } = this
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
} }
},
mounted () {
const { mergeColor } = this
mergeColor()
} }
} }
</script> </script>

Some files were not shown because too many files have changed in this diff Show More