Compare commits
	
		
			63 Commits
		
	
	
		
			V2.3.4-alp
			...
			V2.4.3-alp
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 529b0154db | ||
|   | 26a5c3cedd | ||
|   | 10824d0c88 | ||
|   | c34c493eb4 | ||
|   | 1708d58215 | ||
|   | 948d6e0672 | ||
|   | 0a82102ec6 | ||
|   | 1aa5979968 | ||
|   | ff964f6b72 | ||
|   | b2b83d9474 | ||
|   | a1d7d4626d | ||
|   | 170facb3fc | ||
|   | 5224e80321 | ||
|   | 1c4fa02e45 | ||
|   | 70164efe70 | ||
|   | 7c0992e19f | ||
|   | 66c9a542cf | ||
|   | 47c2652ab4 | ||
|   | 2c78715ff5 | ||
|   | 4f078d984b | ||
|   | 720fd878b1 | ||
|   | f64ed65d3a | ||
|   | 50fa3099a7 | ||
|   | 54bc52c1bf | ||
|   | 24a0c8a9e8 | ||
|   | 7bac2c6760 | ||
|   | 0f9b00b525 | ||
|   | 5376f01e3c | ||
|   | 8d1e0064a7 | ||
|   | 6adcd9c6cb | ||
|   | 3464c6b254 | ||
|   | bd88a27ddc | ||
|   | bc0bf58baf | ||
|   | 46c72a9a68 | ||
|   | 1c33d4d7b8 | ||
|   | 0d59ebcc04 | ||
|   | c47f6133f4 | ||
|   | f8870f763a | ||
|   | 9f00506e73 | ||
|   | e069d52544 | ||
|   | 4bd17d0a07 | ||
|   | a1edd0d6f2 | ||
|   | 3cba31db56 | ||
|   | c6974cd2e4 | ||
|   | 56cc4534d1 | ||
|   | 8884121c4c | ||
|   | 60bf393fd7 | ||
|   | d497dfa7d7 | ||
|   | 37469f7097 | ||
|   | 104e636bd7 | ||
|   | 0d1b1d9c29 | ||
|   | 429e5b9478 | ||
|   | e470b2ed8a | ||
|   | fdf5b76fe0 | ||
|   | 93bc3615ea | ||
|   | e98f7caf96 | ||
|   | 7a2c0e7e4e | ||
|   | b86fd4d222 | ||
|   | 3ee305df19 | ||
|   | 26a05978f5 | ||
|   | 1ed7740a39 | ||
|   | ec1bb34018 | ||
|   | 4ab07bffcc | 
							
								
								
									
										28
									
								
								.github/ISSUE_TEMPLATE/bug_report.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								.github/ISSUE_TEMPLATE/bug_report.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | |||||||
|  | --- | ||||||
|  | name: Bug report | ||||||
|  | about: 提交Bug反馈 | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | <!-- 请确定这是一个Bug反馈,而不是一个需求反馈或问题求助,否则ISSUE可能被关闭 --> | ||||||
|  | <!-- 请提供可供复现Bug的必要条件,否则ISSUE可能被关闭 --> | ||||||
|  | <!-- 创建Bug反馈前请确定你的DataV是最新版的 --> | ||||||
|  |  | ||||||
|  | ## Bug report | ||||||
|  |  | ||||||
|  | #### 出现Bug的组件? | ||||||
|  |  | ||||||
|  | #### 组件配置数据? | ||||||
|  | <!-- (config等props,若无配置请忽略) --> | ||||||
|  |  | ||||||
|  | #### 控制台错误输出? | ||||||
|  | <!-- (若无错误输出请忽略) --> | ||||||
|  |  | ||||||
|  | #### 期望情况? | ||||||
|  |  | ||||||
|  | #### 实际情况? | ||||||
|  |  | ||||||
|  | #### 其他相关信息 | ||||||
|  |  | ||||||
|  | - DataV版本 | ||||||
|  | - 浏览器版本 | ||||||
|  | - 其他 | ||||||
							
								
								
									
										14
									
								
								.github/ISSUE_TEMPLATE/feature_request.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								.github/ISSUE_TEMPLATE/feature_request.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | --- | ||||||
|  | name: Feature request | ||||||
|  | about: 新特性建议 | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | <!-- 创建新特性建议前请确定你的DataV是最新版的 --> | ||||||
|  |  | ||||||
|  | ## Feature request | ||||||
|  |  | ||||||
|  | #### 这个特性解决了什么问题? | ||||||
|  |  | ||||||
|  | #### 这个特性的实现形式? | ||||||
|  |  | ||||||
|  | #### 是否愿意为此特性提交PR? | ||||||
							
								
								
									
										20
									
								
								.github/ISSUE_TEMPLATE/new_component_request.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								.github/ISSUE_TEMPLATE/new_component_request.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | --- | ||||||
|  | name: Component request | ||||||
|  | about: 新组件建议 | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | <!-- 创建新组件建议前请确定你的DataV是最新版的 --> | ||||||
|  | <!-- (将[ ]修改为[x]) --> | ||||||
|  |  | ||||||
|  | ## Component request | ||||||
|  |  | ||||||
|  | #### 新组件的类型? | ||||||
|  |  | ||||||
|  | * [ ] 边框 | ||||||
|  | * [ ] 装饰 | ||||||
|  | * [ ] 图表 | ||||||
|  | * [ ] 其他 | ||||||
|  |  | ||||||
|  | #### 这个组件的功能描述 (边框及装饰类,请提供样图)? | ||||||
|  |  | ||||||
|  | #### 是否愿意为此组件提交PR? | ||||||
							
								
								
									
										33
									
								
								.github/PULL_REQUEST_TEMPLATE.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								.github/PULL_REQUEST_TEMPLATE.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | |||||||
|  | <!-- (将[ ]修改为[x]) --> | ||||||
|  |  | ||||||
|  | **该PR的类型是?** (至少选择一个) | ||||||
|  |  | ||||||
|  | - [ ] Bug修复 | ||||||
|  | - [ ] 新特性 | ||||||
|  | - [ ] 新组件 | ||||||
|  |  | ||||||
|  | **该PR是否向下兼容?** (选择任一) | ||||||
|  |  | ||||||
|  | - [ ] 是 | ||||||
|  | - [ ] 否 | ||||||
|  |  | ||||||
|  | 如果为否,请描述冲突情况: | ||||||
|  |  | ||||||
|  | **涉及到的ISSUE:** | ||||||
|  |  | ||||||
|  | - [ ] 该PR如果涉及到某个ISSUE, 请在PR标题中描述出来 (例如. `fix #xxx[,#xxx]`, "xxx"为ISSUE序号) | ||||||
|  |  | ||||||
|  | **是否在Chrome浏览器下进行过测试?** | ||||||
|  |  | ||||||
|  | - [ ] 是 | ||||||
|  | - [ ] 否 | ||||||
|  |  | ||||||
|  | 如果这是一个**新特性**或**新组件**相关的PR,请提供如下信息 | ||||||
|  |  | ||||||
|  | - [ ] 添加该特性或组件的原因 | ||||||
|  | - [ ] 文档应该修改哪些信息 | ||||||
|  | - [ ] 测试相关 | ||||||
|  |  | ||||||
|  | 提交**新特性**或**新组件**前请先发起一个相关的ISSUE请求 | ||||||
|  |  | ||||||
|  | **其他信息:** | ||||||
							
								
								
									
										5
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,9 +1,6 @@ | |||||||
| .DS_Store | .DS_Store | ||||||
| node_modules | node_modules | ||||||
| /lib | package-lock.json | ||||||
| /dist |  | ||||||
| /.svn |  | ||||||
| /DataV |  | ||||||
|  |  | ||||||
| # local env files | # local env files | ||||||
| .env.local | .env.local | ||||||
|   | |||||||
| @@ -1,7 +0,0 @@ | |||||||
| src/ |  | ||||||
| publish/ |  | ||||||
|  |  | ||||||
| package-lock.json |  | ||||||
|  |  | ||||||
| prepublish.js |  | ||||||
| publish.js |  | ||||||
							
								
								
									
										61
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										61
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,4 +1,63 @@ | |||||||
| # 2.3.4-alpha (2019-00-15) | # 2.4.3-alpha (2019-09-04) | ||||||
|  |  | ||||||
|  | ### Perfect | ||||||
|  |  | ||||||
|  | - **scrollRankingBoard:** Add a unit configuration item. | ||||||
|  |  | ||||||
|  | # 2.4.2-alpha (2019-08-30) | ||||||
|  |  | ||||||
|  | ### Perfect | ||||||
|  |  | ||||||
|  | - **capsuleChart:** Class name compatibility optimization. | ||||||
|  |  | ||||||
|  | # 2.4.1-alpha (2019-08-29) | ||||||
|  |  | ||||||
|  | ### Perfect | ||||||
|  |  | ||||||
|  | - **capsuleChart:** Adaptive display unit. | ||||||
|  |  | ||||||
|  | # 2.4.0-alpha (2019-08-29) | ||||||
|  |  | ||||||
|  | ### New | ||||||
|  |  | ||||||
|  | - **borderBox10** | ||||||
|  | - **capsuleChart** | ||||||
|  |  | ||||||
|  | # 2.3.9-alpha (2019-08-27) | ||||||
|  |  | ||||||
|  | ### Perfect | ||||||
|  |  | ||||||
|  | - **percentPond:** Compatibility enhancement.  | ||||||
|  |  | ||||||
|  | # 2.3.8-alpha (2019-08-27) | ||||||
|  |  | ||||||
|  | ### Bug Fixes | ||||||
|  |  | ||||||
|  | - **percentPond:** Style compatibility and gradient exceptions.  | ||||||
|  |  | ||||||
|  | # 2.3.7-alpha (2019-08-26) | ||||||
|  |  | ||||||
|  | ### Bug Fixes | ||||||
|  |  | ||||||
|  | - **borderBox1:** Parent container setting `text-align: center` to cause display exception [(#6)](https://github.com/jiaming743/DataV/issues/6).  | ||||||
|  |  | ||||||
|  | # 2.3.6-alpha (2019-08-24) | ||||||
|  |  | ||||||
|  | ### Bug Fixes | ||||||
|  |  | ||||||
|  | - **borderBox1:** Animation exception caused by incompatible syntax and spelling mistake [(#4)](https://github.com/jiaming743/DataV/issues/4)[(#5)](https://github.com/jiaming743/DataV/pull/5).  | ||||||
|  |  | ||||||
|  | ### Perfect | ||||||
|  |  | ||||||
|  | - **svg:** Svg animation compatibility enhancement. | ||||||
|  |  | ||||||
|  | # 2.3.5-alpha (2019-08-22) | ||||||
|  |  | ||||||
|  | ### Bug Fixes | ||||||
|  |  | ||||||
|  | - **activeRingChart:** Color configuration does not take effect [(#3)](https://github.com/jiaming743/DataV/pull/3).  | ||||||
|  |  | ||||||
|  | # 2.3.4-alpha (2019-08-15) | ||||||
|  |  | ||||||
| ### Bug Fixes | ### Bug Fixes | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								QQGroup.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								QQGroup.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 18 KiB | 
							
								
								
									
										31
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										31
									
								
								README.md
									
									
									
									
									
								
							| @@ -1,7 +1,6 @@ | |||||||
| [ENGLISH](./README_EN.md) | [ENGLISH](./README_EN.md) | ||||||
|  |  | ||||||
| <h1 align="center">DataV</h1> | <h1 align="center">DataV</h1> | ||||||
|  |  | ||||||
| <p align="center"> | <p align="center"> | ||||||
|     <a href="https://github.com/jiaming743/datav/blob/master/LICENSE"> |     <a href="https://github.com/jiaming743/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/jiaming743/datav.svg" alt="LICENSE" /> | ||||||
| @@ -37,4 +36,32 @@ import { borderBox1 } from '@jiaminghi/data-view' | |||||||
| Vue.use(borderBox1) | Vue.use(borderBox1) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| 详细文档及示例请移步[HomePage](http://datav.jiaminghi.com). | 详细文档及示例请移步[HomePage](http://datav.jiaminghi.com). | ||||||
|  |  | ||||||
|  | ### TODO | ||||||
|  |  | ||||||
|  | * **边框**及**装饰**添加颜色及其他必要配置项,增强可配置性及灵活性. | ||||||
|  |  | ||||||
|  | ### 致谢 | ||||||
|  |  | ||||||
|  | 组件库的开发基于个人学习和兴趣,由于技术水平及经验的限制,组件尚有许多不完善之处,如有BUG可及时提交[issue](https://github.com/jiaming743/DataV/issues/new?template=bug_report.md)或添加反馈群进行反馈,也欢迎提供指正和建议,感谢各位的支持。 | ||||||
|  |  | ||||||
|  | ### 反馈 | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### Demo | ||||||
|  |  | ||||||
|  | Demo页面使用了全屏组件,请F11全屏后查看。 | ||||||
|  |  | ||||||
|  | * [施工养护综合数据](http://datav.jiaminghi.com/demo/construction-data/index.html) | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | * [机电运维管理台](http://datav.jiaminghi.com/demo/manage-desk/index.html) | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | * [机电设备电子档案](http://datav.jiaminghi.com/demo/electronic-file/index.html) | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										30
									
								
								README_EN.md
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								README_EN.md
									
									
									
									
									
								
							| @@ -37,4 +37,32 @@ import { borderBox1 } from '@jiaminghi/data-view' | |||||||
| Vue.use(borderBox1) | Vue.use(borderBox1) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Detailed documents and examples can be viewed on the [HomePage](http://datav.jiaminghi.com). | Detailed documents and examples can be viewed on the [HomePage](http://datav.jiaminghi.com). | ||||||
|  |  | ||||||
|  | ### TODO | ||||||
|  |  | ||||||
|  | * Add color and other necessary configuration to the **borderBox** and **decoration** to enhance configurability and flexibility. | ||||||
|  |  | ||||||
|  | ### Acknowledgement | ||||||
|  |  | ||||||
|  | The development of the component library is based on personal learning and interest. Due to technical level and experience limitations, there are still many imperfections in the components. If there are errors, you can submit [issue](https://github.com/jiaming743/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 | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### Demo | ||||||
|  |  | ||||||
|  | The Demo page uses the full-screen component, please view it after F11 full screen. | ||||||
|  |  | ||||||
|  | * [Construction Data](http://datav.jiaminghi.com/demo/construction-data/index.html) | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | * [Manage-Desk](http://datav.jiaminghi.com/demo/manage-desk/index.html) | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | * [Electronic-File](http://datav.jiaminghi.com/demo/electronic-file/index.html) | ||||||
|  |  | ||||||
|  |  | ||||||
							
								
								
									
										4
									
								
								build/entry.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								build/entry.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | import Vue from 'vue' | ||||||
|  | import datav from '../src/index' | ||||||
|  |  | ||||||
|  | Vue.use(datav) | ||||||
| @@ -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 uglifyjs = await exec(`uglifyjs dist/${libName}.map.js -o dist/${libName}.min.js`)
 | ||||||
|  | 
 | ||||||
|  |   // if (!uglifyjs) {
 | ||||||
|  |   //   print.error('Exception in uglifyjs')
 | ||||||
|  | 
 | ||||||
|  |   //   return
 | ||||||
|  |   // }
 | ||||||
|  | 
 | ||||||
|  |   // print.tip('After uglifyjs')
 | ||||||
|  | 
 | ||||||
|   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() | ||||||
							
								
								
									
										23
									
								
								build/rollup.config.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								build/rollup.config.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | |||||||
|  | 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', | ||||||
|  |   // input: 'src/index.js', | ||||||
|  |   output: { | ||||||
|  |     format: 'umd', | ||||||
|  |     file: 'dist/datav.map.js', | ||||||
|  |     name: 'datav' | ||||||
|  |   }, | ||||||
|  |   plugins: [ | ||||||
|  |     resolve(), | ||||||
|  |     babel({ | ||||||
|  |       exclude: 'node_modules/**' | ||||||
|  |     }), | ||||||
|  |     commonjs(), | ||||||
|  |     vue(), | ||||||
|  |   ], | ||||||
|  |   external: ['Vue'] | ||||||
|  | } | ||||||
							
								
								
									
										
											BIN
										
									
								
								demoImg/construction-data.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								demoImg/construction-data.jpg
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 99 KiB | 
							
								
								
									
										
											BIN
										
									
								
								demoImg/electronic-file.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								demoImg/electronic-file.jpg
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 118 KiB | 
							
								
								
									
										
											BIN
										
									
								
								demoImg/manage-desk.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								demoImg/manage-desk.jpg
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 101 KiB | 
							
								
								
									
										23693
									
								
								dist/datav.map.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										23693
									
								
								dist/datav.map.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										6
									
								
								lib/components/activeRingChart/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/activeRingChart/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import ActiveRingChart from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(ActiveRingChart.name, ActiveRingChart) | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								lib/components/activeRingChart/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								lib/components/activeRingChart/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | .dv-active-ring-chart { | ||||||
|  |   position: relative; | ||||||
|  | } | ||||||
|  | .dv-active-ring-chart .active-ring-chart-container { | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .dv-active-ring-chart .active-ring-info { | ||||||
|  |   position: absolute; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  |   left: 0px; | ||||||
|  |   top: 0px; | ||||||
|  |   display: flex; | ||||||
|  |   flex-direction: column; | ||||||
|  |   justify-content: center; | ||||||
|  |   align-items: center; | ||||||
|  | } | ||||||
|  | .dv-active-ring-chart .active-ring-info .dv-digital-flop { | ||||||
|  |   width: 100px; | ||||||
|  |   height: 30px; | ||||||
|  | } | ||||||
|  | .dv-active-ring-chart .active-ring-info .active-ring-name { | ||||||
|  |   width: 100px; | ||||||
|  |   height: 30px; | ||||||
|  |   color: #fff; | ||||||
|  |   text-align: center; | ||||||
|  |   vertical-align: middle; | ||||||
|  |   text-overflow: ellipsis; | ||||||
|  |   overflow: hidden; | ||||||
|  |   white-space: nowrap; | ||||||
|  | } | ||||||
							
								
								
									
										265
									
								
								lib/components/activeRingChart/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										265
									
								
								lib/components/activeRingChart/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,265 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-active-ring-chart"> | ||||||
|  |     <div class="active-ring-chart-container" ref="active-ring-chart" /> | ||||||
|  |     <div class="active-ring-info"> | ||||||
|  |       <dv-digital-flop :config="digitalFlop" /> | ||||||
|  |       <div class="active-ring-name" :style="fontSize">{{ ringName }}</div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import Charts from '@jiaminghi/charts' | ||||||
|  |  | ||||||
|  | import dvDigitalFlop from '../../digitalFlop/src/main.vue' | ||||||
|  |  | ||||||
|  | import { deepMerge } from '@jiaminghi/charts/lib/util/index' | ||||||
|  |  | ||||||
|  | import { deepClone } from '@jiaminghi/c-render/lib/plugin/util' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvActiveRingChart', | ||||||
|  |   components: { | ||||||
|  |     dvDigitalFlop | ||||||
|  |   }, | ||||||
|  |   props: { | ||||||
|  |     config: { | ||||||
|  |       type: Object, | ||||||
|  |       default: () => ({}) | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       defaultConfig: { | ||||||
|  |         /** | ||||||
|  |          * @description Ring radius | ||||||
|  |          * @type {String|Number} | ||||||
|  |          * @default radius = '50%' | ||||||
|  |          * @example radius = '50%' | 100 | ||||||
|  |          */ | ||||||
|  |         radius: '50%', | ||||||
|  |         /** | ||||||
|  |          * @description Active ring radius | ||||||
|  |          * @type {String|Number} | ||||||
|  |          * @default activeRadius = '55%' | ||||||
|  |          * @example activeRadius = '55%' | 110 | ||||||
|  |          */ | ||||||
|  |         activeRadius: '55%', | ||||||
|  |         /** | ||||||
|  |          * @description Ring data | ||||||
|  |          * @type {Array<Object>} | ||||||
|  |          * @default data = [{ name: '', value: 0 }] | ||||||
|  |          */ | ||||||
|  |         data: [{ name: '', value: 0 }], | ||||||
|  |         /** | ||||||
|  |          * @description Ring line width | ||||||
|  |          * @type {Number} | ||||||
|  |          * @default lineWidth = 20 | ||||||
|  |          */ | ||||||
|  |         lineWidth: 20, | ||||||
|  |         /** | ||||||
|  |          * @description Active time gap (ms) | ||||||
|  |          * @type {Number} | ||||||
|  |          * @default activeTimeGap = 3000 | ||||||
|  |          */ | ||||||
|  |         activeTimeGap: 3000, | ||||||
|  |         /** | ||||||
|  |          * @description Ring color (hex|rgb|rgba|color keywords) | ||||||
|  |          * @type {Array<String>} | ||||||
|  |          * @default color = [Charts Default Color] | ||||||
|  |          * @example color = ['#000', 'rgb(0, 0, 0)', 'rgba(0, 0, 0, 1)', 'red'] | ||||||
|  |          */ | ||||||
|  |         color: [], | ||||||
|  |         /** | ||||||
|  |          * @description Digital flop style | ||||||
|  |          * @type {Object} | ||||||
|  |          */ | ||||||
|  |         digitalFlopStyle: { | ||||||
|  |           fontSize: 25, | ||||||
|  |           fill: '#fff' | ||||||
|  |         }, | ||||||
|  |         /** | ||||||
|  |          * @description CRender animationCurve | ||||||
|  |          * @type {String} | ||||||
|  |          * @default animationCurve = 'easeOutCubic' | ||||||
|  |          */ | ||||||
|  |         animationCurve: 'easeOutCubic', | ||||||
|  |         /** | ||||||
|  |          * @description CRender animationFrame | ||||||
|  |          * @type {String} | ||||||
|  |          * @default animationFrame = 50 | ||||||
|  |          */ | ||||||
|  |         animationFrame: 50 | ||||||
|  |       }, | ||||||
|  |  | ||||||
|  |       mergedConfig: null, | ||||||
|  |  | ||||||
|  |       chart: null, | ||||||
|  |  | ||||||
|  |       activeIndex: 0, | ||||||
|  |  | ||||||
|  |       animationHandler: '' | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   computed: { | ||||||
|  |     digitalFlop () { | ||||||
|  |       const { mergedConfig, activeIndex } = this | ||||||
|  |  | ||||||
|  |       if (!mergedConfig) return {} | ||||||
|  |  | ||||||
|  |       const { digitalFlopStyle, data } = mergedConfig | ||||||
|  |  | ||||||
|  |       const value = data.map(({ value }) => value) | ||||||
|  |  | ||||||
|  |       const sum = value.reduce((all, v) => all + v, 0) | ||||||
|  |  | ||||||
|  |       const percent = parseInt(value[activeIndex] / sum * 100) | ||||||
|  |  | ||||||
|  |       return { | ||||||
|  |         content: '{nt}%', | ||||||
|  |         number: [percent], | ||||||
|  |         style: digitalFlopStyle | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     ringName () { | ||||||
|  |       const { mergedConfig, activeIndex } = this | ||||||
|  |  | ||||||
|  |       if (!mergedConfig) return '' | ||||||
|  |  | ||||||
|  |       return mergedConfig.data[activeIndex].name | ||||||
|  |     }, | ||||||
|  |     fontSize () { | ||||||
|  |       const { mergedConfig } = this | ||||||
|  |  | ||||||
|  |       if (!mergedConfig) return '' | ||||||
|  |  | ||||||
|  |       return `font-size: ${mergedConfig.digitalFlopStyle.fontSize}px;` | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   watch: { | ||||||
|  |     config () { | ||||||
|  |       const { animationHandler, mergeConfig, setRingOption } = this | ||||||
|  |  | ||||||
|  |       clearTimeout(animationHandler) | ||||||
|  |  | ||||||
|  |       this.activeIndex = 0 | ||||||
|  |  | ||||||
|  |       mergeConfig() | ||||||
|  |  | ||||||
|  |       setRingOption() | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     init () { | ||||||
|  |       const { initChart, mergeConfig, setRingOption } = this | ||||||
|  |  | ||||||
|  |       initChart() | ||||||
|  |  | ||||||
|  |       mergeConfig() | ||||||
|  |  | ||||||
|  |       setRingOption() | ||||||
|  |     }, | ||||||
|  |     initChart () { | ||||||
|  |       const { $refs } = this | ||||||
|  |  | ||||||
|  |       this.chart = new Charts($refs['active-ring-chart']) | ||||||
|  |     }, | ||||||
|  |     mergeConfig () { | ||||||
|  |       const { defaultConfig, config } = this | ||||||
|  |  | ||||||
|  |       this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {}) | ||||||
|  |     }, | ||||||
|  |     setRingOption () { | ||||||
|  |       const { getRingOption, chart, ringAnimation } = this | ||||||
|  |  | ||||||
|  |       const option = getRingOption() | ||||||
|  |  | ||||||
|  |       chart.setOption(option) | ||||||
|  |  | ||||||
|  |       ringAnimation() | ||||||
|  |     }, | ||||||
|  |     getRingOption () { | ||||||
|  |       const { mergedConfig, getRealRadius } = this | ||||||
|  |  | ||||||
|  |       const radius = getRealRadius() | ||||||
|  |  | ||||||
|  |       mergedConfig.data.forEach(dataItem => { | ||||||
|  |         dataItem.radius = radius | ||||||
|  |       }) | ||||||
|  |  | ||||||
|  |       return { | ||||||
|  |         series: [ | ||||||
|  |           { | ||||||
|  |             type: 'pie', | ||||||
|  |             ...mergedConfig, | ||||||
|  |             outsideLabel: { | ||||||
|  |               show: false | ||||||
|  |             } | ||||||
|  |           } | ||||||
|  |         ], | ||||||
|  |         color: mergedConfig.color | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     getRealRadius (active = false) { | ||||||
|  |       const { mergedConfig, chart } = this | ||||||
|  |  | ||||||
|  |       const { radius, activeRadius, lineWidth } = mergedConfig | ||||||
|  |  | ||||||
|  |       const maxRadius = Math.min(...chart.render.area) / 2 | ||||||
|  |  | ||||||
|  |       const halfLineWidth = lineWidth / 2 | ||||||
|  |  | ||||||
|  |       let realRadius = active ? activeRadius : radius | ||||||
|  |  | ||||||
|  |       if (typeof realRadius !== 'number') realRadius = parseInt(realRadius) / 100 * maxRadius | ||||||
|  |  | ||||||
|  |       const insideRadius = realRadius - halfLineWidth | ||||||
|  |       const outSideRadius = realRadius + halfLineWidth | ||||||
|  |  | ||||||
|  |       return [insideRadius, outSideRadius] | ||||||
|  |     }, | ||||||
|  |     ringAnimation () { | ||||||
|  |       let { activeIndex, getRingOption, chart, getRealRadius } = this | ||||||
|  |  | ||||||
|  |       const radius = getRealRadius() | ||||||
|  |       const active = getRealRadius(true) | ||||||
|  |  | ||||||
|  |       const option = getRingOption() | ||||||
|  |  | ||||||
|  |       const { data } = option.series[0] | ||||||
|  |  | ||||||
|  |       data.forEach((dataItem, i) => { | ||||||
|  |         if (i === activeIndex) { | ||||||
|  |           dataItem.radius = active | ||||||
|  |         } else { | ||||||
|  |           dataItem.radius = radius | ||||||
|  |         } | ||||||
|  |       }) | ||||||
|  |  | ||||||
|  |       chart.setOption(option) | ||||||
|  |  | ||||||
|  |       const { activeTimeGap } = option.series[0] | ||||||
|  |  | ||||||
|  |       this.animationHandler = setTimeout(foo => { | ||||||
|  |         activeIndex += 1 | ||||||
|  |  | ||||||
|  |         if (activeIndex >= data.length) activeIndex = 0 | ||||||
|  |  | ||||||
|  |         this.activeIndex = activeIndex | ||||||
|  |  | ||||||
|  |         this.ringAnimation() | ||||||
|  |       }, activeTimeGap) | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   mounted () { | ||||||
|  |     const { init } = this | ||||||
|  |  | ||||||
|  |     init() | ||||||
|  |   }, | ||||||
|  |   beforeDestroy () { | ||||||
|  |     const { animationHandler } = this | ||||||
|  |  | ||||||
|  |     clearTimeout(animationHandler) | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/borderBox1/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/borderBox1/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import BorderBox1 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(BorderBox1.name, BorderBox1) | ||||||
|  | } | ||||||
							
								
								
									
										27
									
								
								lib/components/borderBox1/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								lib/components/borderBox1/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | |||||||
|  | .dv-border-box-1 { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .dv-border-box-1 .border { | ||||||
|  |   position: absolute; | ||||||
|  |   display: block; | ||||||
|  | } | ||||||
|  | .dv-border-box-1 .right-top { | ||||||
|  |   right: 0px; | ||||||
|  |   transform: rotateY(180deg); | ||||||
|  | } | ||||||
|  | .dv-border-box-1 .left-bottom { | ||||||
|  |   bottom: 0px; | ||||||
|  |   transform: rotateX(180deg); | ||||||
|  | } | ||||||
|  | .dv-border-box-1 .right-bottom { | ||||||
|  |   right: 0px; | ||||||
|  |   bottom: 0px; | ||||||
|  |   transform: rotateX(180deg) rotateY(180deg); | ||||||
|  | } | ||||||
|  | .dv-border-box-1 .border-box-content { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
							
								
								
									
										63
									
								
								lib/components/borderBox1/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								lib/components/borderBox1/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,63 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-border-box-1"> | ||||||
|  |     <svg | ||||||
|  |       width="150px" | ||||||
|  |       height="150px" | ||||||
|  |       :key="item" | ||||||
|  |       v-for="item in border" | ||||||
|  |       :class="`${item} border`" | ||||||
|  |     > | ||||||
|  |       <polygon | ||||||
|  |         fill="#4fd2dd" | ||||||
|  |         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 | ||||||
|  |           attributeName="fill" | ||||||
|  |           values="#4fd2dd;#235fa7;#4fd2dd" | ||||||
|  |           dur="0.5s" | ||||||
|  |           begin="0s" | ||||||
|  |           repeatCount="indefinite" | ||||||
|  |         /> | ||||||
|  |       </polygon> | ||||||
|  |       <polygon | ||||||
|  |         fill="#235fa7" | ||||||
|  |         points="27.599999999999998,4.8 38.4,4.8 35.4,7.8 30.599999999999998,7.8" | ||||||
|  |       > | ||||||
|  |         <animate | ||||||
|  |           attributeName="fill" | ||||||
|  |           values="#235fa7;#4fd2dd;#235fa7" | ||||||
|  |           dur="0.5s" | ||||||
|  |           begin="0s" | ||||||
|  |           repeatCount="indefinite" | ||||||
|  |         /> | ||||||
|  |       </polygon> | ||||||
|  |       <polygon | ||||||
|  |         fill="#4fd2dd" | ||||||
|  |         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 | ||||||
|  |           attributeName="fill" | ||||||
|  |           values="#4fd2dd;#235fa7;transparent" | ||||||
|  |           dur="1s" | ||||||
|  |           begin="0s" | ||||||
|  |           repeatCount="indefinite" | ||||||
|  |         /> | ||||||
|  |       </polygon> | ||||||
|  |     </svg> | ||||||
|  |  | ||||||
|  |     <div class="border-box-content"> | ||||||
|  |       <slot></slot> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | export default { | ||||||
|  |   name: 'DvBorderBox1', | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       border: ['left-top', 'right-top', 'left-bottom', 'right-bottom'] | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/borderBox10/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/borderBox10/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import BorderBox10 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(BorderBox10.name, BorderBox10) | ||||||
|  | } | ||||||
							
								
								
									
										29
									
								
								lib/components/borderBox10/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								lib/components/borderBox10/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | |||||||
|  | .dv-border-box-10 { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  |   box-shadow: inset 0 0 25px 3px #1d48c4; | ||||||
|  |   border-radius: 6px; | ||||||
|  | } | ||||||
|  | .dv-border-box-10 .border { | ||||||
|  |   position: absolute; | ||||||
|  |   display: block; | ||||||
|  | } | ||||||
|  | .dv-border-box-10 .right-top { | ||||||
|  |   right: 0px; | ||||||
|  |   transform: rotateY(180deg); | ||||||
|  | } | ||||||
|  | .dv-border-box-10 .left-bottom { | ||||||
|  |   bottom: 0px; | ||||||
|  |   transform: rotateX(180deg); | ||||||
|  | } | ||||||
|  | .dv-border-box-10 .right-bottom { | ||||||
|  |   right: 0px; | ||||||
|  |   bottom: 0px; | ||||||
|  |   transform: rotateX(180deg) rotateY(180deg); | ||||||
|  | } | ||||||
|  | .dv-border-box-10 .border-box-content { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
							
								
								
									
										31
									
								
								lib/components/borderBox10/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								lib/components/borderBox10/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-border-box-10"> | ||||||
|  |     <svg | ||||||
|  |       width="150px" | ||||||
|  |       height="150px" | ||||||
|  |       :key="item" | ||||||
|  |       v-for="item in border" | ||||||
|  |       :class="`${item} border`" | ||||||
|  |     > | ||||||
|  |       <polygon | ||||||
|  |         fill="#d3e1f8" | ||||||
|  |         points="40, 0 5, 0 0, 5 0, 16 3, 19 3, 7 7, 3 35, 3" | ||||||
|  |       /> | ||||||
|  |     </svg> | ||||||
|  |  | ||||||
|  |     <div class="border-box-content"> | ||||||
|  |       <slot></slot> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | export default { | ||||||
|  |   name: 'DvBorderBox10', | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       border: ['left-top', 'right-top', 'left-bottom', 'right-bottom'] | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/borderBox2/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/borderBox2/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import BorderBox2 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(BorderBox2.name, BorderBox2) | ||||||
|  | } | ||||||
							
								
								
									
										30
									
								
								lib/components/borderBox2/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								lib/components/borderBox2/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | |||||||
|  | .dv-border-box-2 { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .dv-border-box-2 .dv-border-svg-container { | ||||||
|  |   position: absolute; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  |   top: 0px; | ||||||
|  |   left: 0px; | ||||||
|  | } | ||||||
|  | .dv-border-box-2 .dv-border-svg-container polyline { | ||||||
|  |   fill: none; | ||||||
|  |   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 { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								lib/components/borderBox2/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								lib/components/borderBox2/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-border-box-2" :ref="ref"> | ||||||
|  |     <svg class="dv-border-svg-container" :width="width" :height="height"> | ||||||
|  |       <polyline class="dv-bb2-line1" | ||||||
|  |         :points="`2, 2 ${width - 2} ,2 ${width - 2}, ${height - 2} 2, ${height - 2} 2, 2`" /> | ||||||
|  |       <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" /> | ||||||
|  |       <circle :cx="width - 11" cy="11" r="1" /> | ||||||
|  |       <circle :cx="width - 11" :cy="height - 11" r="1" /> | ||||||
|  |       <circle cx="11" :cy="height - 11" r="1" /> | ||||||
|  |     </svg> | ||||||
|  |  | ||||||
|  |     <div class="border-box-content"> | ||||||
|  |       <slot></slot> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import autoResize from '../../../mixin/autoResize' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvBorderBox2', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       ref: 'border-box-2' | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/borderBox3/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/borderBox3/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import BorderBox3 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(BorderBox3.name, BorderBox3) | ||||||
|  | } | ||||||
							
								
								
									
										27
									
								
								lib/components/borderBox3/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								lib/components/borderBox3/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | |||||||
|  | .dv-border-box-3 { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .dv-border-box-3 .dv-border-svg-container { | ||||||
|  |   position: absolute; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  |   top: 0px; | ||||||
|  |   left: 0px; | ||||||
|  | } | ||||||
|  | .dv-border-box-3 .dv-border-svg-container polyline { | ||||||
|  |   fill: none; | ||||||
|  |   stroke: #2862b7; | ||||||
|  | } | ||||||
|  | .dv-border-box-3 .dv-bb3-line1 { | ||||||
|  |   stroke-width: 3; | ||||||
|  | } | ||||||
|  | .dv-border-box-3 .dv-bb3-line2 { | ||||||
|  |   stroke-width: 1; | ||||||
|  | } | ||||||
|  | .dv-border-box-3 .border-box-content { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								lib/components/borderBox3/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								lib/components/borderBox3/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-border-box-3" :ref="ref"> | ||||||
|  |     <svg class="dv-border-svg-container" :width="width" :height="height"> | ||||||
|  |       <polyline class="dv-bb3-line1" | ||||||
|  |         :points="`4, 4 ${width - 22} ,4 ${width - 22}, ${height - 22} 4, ${height - 22} 4, 4`" /> | ||||||
|  |       <polyline class="dv-bb3-line2" | ||||||
|  |         :points="`10, 10 ${width - 16}, 10 ${width - 16}, ${height - 16} 10, ${height - 16} 10, 10`" /> | ||||||
|  |       <polyline class="dv-bb3-line2" | ||||||
|  |         :points="`16, 16 ${width - 10}, 16 ${width - 10}, ${height - 10} 16, ${height - 10} 16, 16`" /> | ||||||
|  |       <polyline class="dv-bb3-line2" | ||||||
|  |         :points="`22, 22 ${width - 4}, 22 ${width - 4}, ${height - 4} 22, ${height - 4} 22, 22`" /> | ||||||
|  |     </svg> | ||||||
|  |  | ||||||
|  |     <div class="border-box-content"> | ||||||
|  |       <slot></slot> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import autoResize from '../../../mixin/autoResize' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvBorderBox3', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       ref: 'border-box-3' | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/borderBox4/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/borderBox4/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import BorderBox4 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(BorderBox4.name, BorderBox4) | ||||||
|  | } | ||||||
							
								
								
									
										82
									
								
								lib/components/borderBox4/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										82
									
								
								lib/components/borderBox4/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,82 @@ | |||||||
|  | .dv-border-box-4 { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .dv-border-box-4 .dv-reverse { | ||||||
|  |   transform: rotate(180deg); | ||||||
|  | } | ||||||
|  | .dv-border-box-4 .dv-border-svg-container { | ||||||
|  |   position: absolute; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  |   top: 0px; | ||||||
|  |   left: 0px; | ||||||
|  | } | ||||||
|  | .dv-border-box-4 .dv-border-svg-container polyline { | ||||||
|  |   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 { | ||||||
|  |   stroke-width: 1; | ||||||
|  | } | ||||||
|  | .dv-border-box-4 .sw3 { | ||||||
|  |   stroke-width: 3px; | ||||||
|  |   stroke-linecap: round; | ||||||
|  | } | ||||||
|  | .dv-border-box-4 .dv-bb4-line-1 { | ||||||
|  |   stroke: red; | ||||||
|  |   stroke-width: 1; | ||||||
|  | } | ||||||
|  | .dv-border-box-4 .dv-bb4-line-2 { | ||||||
|  |   stroke: rgba(0, 0, 255, 0.8); | ||||||
|  |   stroke-width: 1; | ||||||
|  | } | ||||||
|  | .dv-border-box-4 .dv-bb4-line-3 { | ||||||
|  |   stroke: red; | ||||||
|  |   stroke-width: 3px; | ||||||
|  |   stroke-linecap: round; | ||||||
|  | } | ||||||
|  | .dv-border-box-4 .dv-bb4-line-4 { | ||||||
|  |   stroke: red; | ||||||
|  |   stroke-width: 3px; | ||||||
|  |   stroke-linecap: round; | ||||||
|  | } | ||||||
|  | .dv-border-box-4 .dv-bb4-line-5 { | ||||||
|  |   stroke: red; | ||||||
|  |   stroke-width: 1; | ||||||
|  | } | ||||||
|  | .dv-border-box-4 .dv-bb4-line-6 { | ||||||
|  |   stroke: rgba(0, 0, 255, 0.8); | ||||||
|  |   stroke-width: 1; | ||||||
|  | } | ||||||
|  | .dv-border-box-4 .dv-bb4-line-7 { | ||||||
|  |   stroke: rgba(0, 0, 255, 0.8); | ||||||
|  |   stroke-width: 1; | ||||||
|  | } | ||||||
|  | .dv-border-box-4 .dv-bb4-line-8 { | ||||||
|  |   stroke: rgba(0, 0, 255, 0.8); | ||||||
|  |   stroke-width: 3px; | ||||||
|  |   stroke-linecap: round; | ||||||
|  | } | ||||||
|  | .dv-border-box-4 .dv-bb4-line-9 { | ||||||
|  |   stroke: red; | ||||||
|  |   stroke-width: 3px; | ||||||
|  |   stroke-linecap: round; | ||||||
|  |   stroke-dasharray: 100 250; | ||||||
|  | } | ||||||
|  | .dv-border-box-4 .dv-bb4-line-10 { | ||||||
|  |   stroke: rgba(0, 0, 255, 0.8); | ||||||
|  |   stroke-width: 1; | ||||||
|  |   stroke-dasharray: 80 270; | ||||||
|  | } | ||||||
|  | .dv-border-box-4 .border-box-content { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
							
								
								
									
										42
									
								
								lib/components/borderBox4/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								lib/components/borderBox4/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,42 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-border-box-4" :ref="ref"> | ||||||
|  |     <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} | ||||||
|  |         10, 40 40, 5 150, 5 170, 20 ${width - 15}, 20`"/> | ||||||
|  |       <polyline class="dv-bb4-line-2" :points="`245, ${height - 1} 36, ${height - 1} 14, ${height - 23} | ||||||
|  |         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-5" :points="`5, 45 5, 140`" /> | ||||||
|  |       <polyline class="dv-bb4-line-6" :points="`14, 75 14, 180`" /> | ||||||
|  |       <polyline class="dv-bb4-line-7" :points="`55, 11 147, 11 167, 26 250, 26`" /> | ||||||
|  |       <polyline class="dv-bb4-line-8" :points="`158, 5 173, 16`" /> | ||||||
|  |       <polyline class="dv-bb4-line-9" :points="`200, 17 ${width - 10}, 17`" /> | ||||||
|  |       <polyline class="dv-bb4-line-10" :points="`385, 17 ${width - 10}, 17`" /> | ||||||
|  |     </svg> | ||||||
|  |  | ||||||
|  |     <div class="border-box-content"> | ||||||
|  |       <slot></slot> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import autoResize from '../../../mixin/autoResize' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvBorderBox4', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       ref: 'border-box-4' | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   props: { | ||||||
|  |     reverse: { | ||||||
|  |       type: Boolean, | ||||||
|  |       default: false | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/borderBox5/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/borderBox5/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import BorderBox5 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(BorderBox5.name, BorderBox5) | ||||||
|  | } | ||||||
							
								
								
									
										40
									
								
								lib/components/borderBox5/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								lib/components/borderBox5/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,40 @@ | |||||||
|  | .dv-border-box-5 { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .dv-border-box-5 .dv-reverse { | ||||||
|  |   transform: rotate(180deg); | ||||||
|  | } | ||||||
|  | .dv-border-box-5 .dv-svg-container { | ||||||
|  |   position: absolute; | ||||||
|  |   top: 0px; | ||||||
|  |   left: 0px; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .dv-border-box-5 .dv-svg-container polyline { | ||||||
|  |   fill: none; | ||||||
|  | } | ||||||
|  | .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 { | ||||||
|  |   stroke: rgba(255, 255, 255, 0.2); | ||||||
|  | } | ||||||
|  | .dv-border-box-5 .dv-bb5-line-3, | ||||||
|  | .dv-border-box-5 .dv-bb5-line-6 { | ||||||
|  |   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-5 { | ||||||
|  |   stroke-width: 2; | ||||||
|  |   stroke: rgba(255, 255, 255, 0.15); | ||||||
|  | } | ||||||
|  | .dv-border-box-5 .border-box-content { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
							
								
								
									
										38
									
								
								lib/components/borderBox5/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								lib/components/borderBox5/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,38 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-border-box-5" :ref="ref"> | ||||||
|  |     <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} | ||||||
|  |         ${width - 100}, ${height - 5} 8, ${height - 5} 8, 5`" /> | ||||||
|  |       <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 class="dv-bb5-line-4" :points="`15, 20 ${width - 35}, 20`" /> | ||||||
|  |       <polyline class="dv-bb5-line-5" :points="`15, ${height - 20} ${width - 110}, ${height - 20}`" /> | ||||||
|  |       <polyline class="dv-bb5-line-6" :points="`15, ${height - 13} ${width - 110}, ${height - 13}`" /> | ||||||
|  |     </svg> | ||||||
|  |  | ||||||
|  |     <div class="border-box-content"> | ||||||
|  |       <slot></slot> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import autoResize from '../../../mixin/autoResize' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvBorderBox5', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       ref: 'border-box-5' | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   props: { | ||||||
|  |     reverse: { | ||||||
|  |       type: Boolean, | ||||||
|  |       default: false | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/borderBox6/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/borderBox6/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import BorderBox6 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(BorderBox6.name, BorderBox6) | ||||||
|  | } | ||||||
							
								
								
									
										25
									
								
								lib/components/borderBox6/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								lib/components/borderBox6/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,25 @@ | |||||||
|  | .dv-border-box-6 { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .dv-border-box-6 .dv-svg-container { | ||||||
|  |   position: absolute; | ||||||
|  |   top: 0px; | ||||||
|  |   left: 0px; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .dv-border-box-6 .dv-svg-container circle { | ||||||
|  |   fill: gray; | ||||||
|  | } | ||||||
|  | .dv-border-box-6 .dv-svg-container polyline { | ||||||
|  |   fill: none; | ||||||
|  |   stroke-width: 1; | ||||||
|  |   stroke: rgba(255, 255, 255, 0.35); | ||||||
|  | } | ||||||
|  | .dv-border-box-6 .border-box-content { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
							
								
								
									
										40
									
								
								lib/components/borderBox6/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								lib/components/borderBox6/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,40 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-border-box-6" :ref="ref"> | ||||||
|  |     <svg class="dv-svg-container" :width="width" :height="height"> | ||||||
|  |       <circle cx="5" cy="5" r="2"/> | ||||||
|  |       <circle :cx="width - 5" cy="5" r="2" /> | ||||||
|  |       <circle :cx="width - 5" :cy="height - 5" r="2" /> | ||||||
|  |       <circle cx="5" :cy="height - 5" r="2" /> | ||||||
|  |       <polyline :points="`10, 4 ${width - 10}, 4`" /> | ||||||
|  |       <polyline :points="`10, ${height - 4} ${width - 10}, ${height - 4}`" /> | ||||||
|  |       <polyline :points="`5, 70 5, ${height - 70}`" /> | ||||||
|  |       <polyline :points="`${width - 5}, 70 ${width - 5}, ${height - 70}`" /> | ||||||
|  |       <polyline :points="`3, 10, 3, 50`" /> | ||||||
|  |       <polyline :points="`7, 30 7, 80`" /> | ||||||
|  |       <polyline :points="`${width - 3}, 10 ${width - 3}, 50`" /> | ||||||
|  |       <polyline :points="`${width - 7}, 30 ${width - 7}, 80`" /> | ||||||
|  |       <polyline :points="`3, ${height - 10} 3, ${height - 50}`" /> | ||||||
|  |       <polyline :points="`7, ${height - 30} 7, ${height - 80}`" /> | ||||||
|  |       <polyline :points="`${width - 3}, ${height - 10} ${width - 3}, ${height - 50}`" /> | ||||||
|  |       <polyline :points="`${width - 7}, ${height - 30} ${width - 7}, ${height - 80}`" /> | ||||||
|  |     </svg> | ||||||
|  |  | ||||||
|  |     <div class="border-box-content"> | ||||||
|  |       <slot></slot> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import autoResize from '../../../mixin/autoResize.js' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvBorderBox6', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       ref: 'border-box-6' | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/borderBox7/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/borderBox7/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import BorderBox7 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(BorderBox7.name, BorderBox7) | ||||||
|  | } | ||||||
							
								
								
									
										31
									
								
								lib/components/borderBox7/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								lib/components/borderBox7/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | |||||||
|  | .dv-border-box-7 { | ||||||
|  |   position: relative; | ||||||
|  |   width: 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 { | ||||||
|  |   position: absolute; | ||||||
|  |   top: 0px; | ||||||
|  |   left: 0px; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .dv-border-box-7 .dv-svg-container polyline { | ||||||
|  |   fill: none; | ||||||
|  |   stroke-linecap: round; | ||||||
|  | } | ||||||
|  | .dv-border-box-7 .dv-bb7-line-width-2 { | ||||||
|  |   stroke: rgba(128, 128, 128, 0.3); | ||||||
|  |   stroke-width: 2; | ||||||
|  | } | ||||||
|  | .dv-border-box-7 .dv-bb7-line-width-5 { | ||||||
|  |   stroke: rgba(128, 128, 128, 0.5); | ||||||
|  |   stroke-width: 5; | ||||||
|  | } | ||||||
|  | .dv-border-box-7 .border-box-content { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
							
								
								
									
										33
									
								
								lib/components/borderBox7/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								lib/components/borderBox7/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | |||||||
|  | <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`" /> | ||||||
|  |       <polyline class="dv-bb7-line-width-5" :points="`${width - 10}, 0 ${width}, 0 ${width}, 10`" /> | ||||||
|  |       <polyline class="dv-bb7-line-width-5" :points="`${width - 10}, ${height} ${width}, ${height} ${width}, ${height - 10}`" /> | ||||||
|  |       <polyline class="dv-bb7-line-width-5" :points="`0, ${height - 10} 0, ${height} 10, ${height}`" /> | ||||||
|  |     </svg> | ||||||
|  |  | ||||||
|  |     <div class="border-box-content"> | ||||||
|  |       <slot></slot> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import autoResize from '../../../mixin/autoResize' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvBorderBox7', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       ref: 'border-box-7' | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/borderBox8/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/borderBox8/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import BorderBox8 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(BorderBox8.name, BorderBox8) | ||||||
|  | } | ||||||
							
								
								
									
										17
									
								
								lib/components/borderBox8/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								lib/components/borderBox8/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | |||||||
|  | .dv-border-box-8 { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .dv-border-box-8 svg { | ||||||
|  |   position: absolute; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  |   left: 0px; | ||||||
|  |   top: 0px; | ||||||
|  | } | ||||||
|  | .dv-border-box-8 .border-box-content { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
							
								
								
									
										86
									
								
								lib/components/borderBox8/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										86
									
								
								lib/components/borderBox8/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,86 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-border-box-8" :ref="ref"> | ||||||
|  |     <svg class="dv-svg-container" :width="width" :height="height"> | ||||||
|  |       <defs> | ||||||
|  |         <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`" | ||||||
|  |           fill="transparent" | ||||||
|  |         /> | ||||||
|  |         <radialGradient | ||||||
|  |           :id="gradient" | ||||||
|  |           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> | ||||||
|  |  | ||||||
|  |         <mask :id="mask"> | ||||||
|  |           <circle cx="0" cy="0" r="150" :fill="`url(#${gradient})`"> | ||||||
|  |             <animateMotion | ||||||
|  |               dur="3s" | ||||||
|  |               :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`" | ||||||
|  |               rotate="auto" | ||||||
|  |               repeatCount="indefinite" | ||||||
|  |             /> | ||||||
|  |           </circle> | ||||||
|  |         </mask> | ||||||
|  |       </defs> | ||||||
|  |  | ||||||
|  |       <use | ||||||
|  |         stroke="#235fa7" | ||||||
|  |         stroke-width="1" | ||||||
|  |         :xlink:href="`#${path}`" | ||||||
|  |       /> | ||||||
|  |  | ||||||
|  |       <use | ||||||
|  |         stroke="#4fd2dd" | ||||||
|  |         stroke-width="3" | ||||||
|  |         :xlink:href="`#${path}`" | ||||||
|  |         :mask="`url(#${mask})`" | ||||||
|  |       > | ||||||
|  |         <animate | ||||||
|  |           attributeName="stroke-dasharray" | ||||||
|  |           :from="`0, ${length}`" | ||||||
|  |           :to="`${length}, 0`" | ||||||
|  |           dur="3s" | ||||||
|  |           repeatCount="indefinite" | ||||||
|  |         /> | ||||||
|  |       </use> | ||||||
|  |     </svg> | ||||||
|  |  | ||||||
|  |     <div class="border-box-content"> | ||||||
|  |       <slot></slot> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import autoResize from '../../../mixin/autoResize' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvBorderBox8', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       ref: 'border-box-8', | ||||||
|  |       path: `border-box-8-path-${(new Date()).getTime()}`, | ||||||
|  |       gradient: `border-box-8-gradient-${(new Date()).getTime()}`, | ||||||
|  |       mask: `border-box-8-mask-${(new Date()).getTime()}` | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   computed: { | ||||||
|  |     length () { | ||||||
|  |       const { width, height } = this | ||||||
|  |  | ||||||
|  |       return (width + height - 5) * 2 | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/borderBox9/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/borderBox9/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import BorderBox9 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(BorderBox9.name, BorderBox9) | ||||||
|  | } | ||||||
							
								
								
									
										17
									
								
								lib/components/borderBox9/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								lib/components/borderBox9/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | |||||||
|  | .dv-border-box-9 { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .dv-border-box-9 svg { | ||||||
|  |   position: absolute; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  |   left: 0px; | ||||||
|  |   top: 0px; | ||||||
|  | } | ||||||
|  | .dv-border-box-9 .border-box-content { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
							
								
								
									
										100
									
								
								lib/components/borderBox9/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										100
									
								
								lib/components/borderBox9/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,100 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-border-box-9" :ref="ref"> | ||||||
|  |     <svg class="dv-svg-container" :width="width" :height="height"> | ||||||
|  |       <defs> | ||||||
|  |         <linearGradient :id="gradientId" x1="0%" y1="0%" x2="100%" y2="100%"> | ||||||
|  |           <stop offset="0%" stop-color="#11eefd" /> | ||||||
|  |           <stop offset="100%" stop-color="#0078d2" /> | ||||||
|  |         </linearGradient> | ||||||
|  |  | ||||||
|  |         <mask :id="maskId"> | ||||||
|  |           <polyline | ||||||
|  |             stroke="#fff" | ||||||
|  |             stroke-width="3" | ||||||
|  |             fill="transparent" | ||||||
|  |             :points="`8, ${height * 0.4} 8, 3, ${width * 0.4 + 7}, 3`" | ||||||
|  |           /> | ||||||
|  |           <polyline | ||||||
|  |             fill="#fff" | ||||||
|  |             :points=" | ||||||
|  |               `8, ${height * 0.15} 8, 3, ${width * 0.1 + 7}, 3 | ||||||
|  |               ${width * 0.1}, 8 14, 8 14, ${height * 0.15 - 7} | ||||||
|  |             `" | ||||||
|  |           /> | ||||||
|  |  | ||||||
|  |           <polyline | ||||||
|  |             stroke="#fff" | ||||||
|  |             stroke-width="3" | ||||||
|  |             fill="transparent" | ||||||
|  |             :points="`${width * 0.5}, 3 ${width - 3}, 3, ${width - 3}, ${height * 0.25}`" | ||||||
|  |           /> | ||||||
|  |           <polyline | ||||||
|  |             fill="#fff" | ||||||
|  |             :points="` | ||||||
|  |               ${width * 0.52}, 3 ${width * 0.58}, 3 | ||||||
|  |               ${width * 0.58 - 7}, 9 ${width * 0.52 + 7}, 9 | ||||||
|  |             `" | ||||||
|  |           /> | ||||||
|  |           <polyline | ||||||
|  |             fill="#fff" | ||||||
|  |             :points="` | ||||||
|  |               ${width * 0.9}, 3 ${width - 3}, 3 ${width - 3}, ${height * 0.1} | ||||||
|  |               ${width - 9}, ${height * 0.1 - 7} ${width - 9}, 9 ${width * 0.9 + 7}, 9 | ||||||
|  |             `" | ||||||
|  |           /> | ||||||
|  |  | ||||||
|  |           <polyline | ||||||
|  |             stroke="#fff" | ||||||
|  |             stroke-width="3" | ||||||
|  |             fill="transparent" | ||||||
|  |             :points="`8, ${height * 0.5} 8, ${height - 3} ${width * 0.3 + 7}, ${height - 3}`" | ||||||
|  |           /> | ||||||
|  |           <polyline | ||||||
|  |             fill="#fff" | ||||||
|  |             :points="` | ||||||
|  |               8, ${height * 0.55} 8, ${height * 0.7} | ||||||
|  |               2, ${height * 0.7 - 7} 2, ${height * 0.55 + 7} | ||||||
|  |             `" | ||||||
|  |           /> | ||||||
|  |  | ||||||
|  |           <polyline | ||||||
|  |             stroke="#fff" | ||||||
|  |             stroke-width="3" | ||||||
|  |             fill="transparent" | ||||||
|  |             :points="`${width * 0.35}, ${height - 3} ${width - 3}, ${height - 3} ${width - 3}, ${height * 0.35}`" | ||||||
|  |           /> | ||||||
|  |           <polyline | ||||||
|  |             fill="#fff" | ||||||
|  |             :points="` | ||||||
|  |               ${width * 0.92}, ${height - 3} ${width - 3}, ${height - 3} ${width - 3}, ${height * 0.8} | ||||||
|  |               ${width - 9}, ${height * 0.8 + 7} ${width - 9}, ${height - 9} ${width * 0.92 + 7}, ${height - 9} | ||||||
|  |             `" | ||||||
|  |           /> | ||||||
|  |         </mask> | ||||||
|  |       </defs> | ||||||
|  |  | ||||||
|  |       <rect x="0" y="0" :width="width" :height="height" :fill="`url(#${gradientId})`" :mask="`url(#${maskId})`" /> | ||||||
|  |     </svg> | ||||||
|  |  | ||||||
|  |     <div class="border-box-content"> | ||||||
|  |       <slot></slot> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import autoResize from '../../../mixin/autoResize' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvBorderBox9', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       ref: 'border-box-9', | ||||||
|  |  | ||||||
|  |       gradientId: `border-box-9-gradient-${(new Date()).getTime()}`, | ||||||
|  |       maskId: `border-box-9-mask-${(new Date()).getTime()}` | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/capsuleChart/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/capsuleChart/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import CapsuleChart from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(CapsuleChart.name, CapsuleChart) | ||||||
|  | } | ||||||
							
								
								
									
										55
									
								
								lib/components/capsuleChart/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								lib/components/capsuleChart/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,55 @@ | |||||||
|  | .dv-capsule-chart { | ||||||
|  |   position: relative; | ||||||
|  |   display: flex; | ||||||
|  |   flex-direction: row; | ||||||
|  |   box-sizing: border-box; | ||||||
|  |   padding: 10px; | ||||||
|  |   color: #fff; | ||||||
|  | } | ||||||
|  | .dv-capsule-chart .label-column { | ||||||
|  |   display: flex; | ||||||
|  |   flex-direction: column; | ||||||
|  |   justify-content: space-between; | ||||||
|  |   box-sizing: border-box; | ||||||
|  |   padding-right: 10px; | ||||||
|  |   text-align: right; | ||||||
|  |   font-size: 12px; | ||||||
|  | } | ||||||
|  | .dv-capsule-chart .label-column div { | ||||||
|  |   height: 20px; | ||||||
|  |   line-height: 20px; | ||||||
|  | } | ||||||
|  | .dv-capsule-chart .capsule-container { | ||||||
|  |   flex: 1; | ||||||
|  |   display: flex; | ||||||
|  |   flex-direction: column; | ||||||
|  |   justify-content: space-between; | ||||||
|  | } | ||||||
|  | .dv-capsule-chart .capsule-item { | ||||||
|  |   box-shadow: 0 0 3px #999; | ||||||
|  |   height: 10px; | ||||||
|  |   margin: 5px 0px; | ||||||
|  |   border-radius: 5px; | ||||||
|  | } | ||||||
|  | .dv-capsule-chart .capsule-item div { | ||||||
|  |   height: 8px; | ||||||
|  |   margin-top: 1px; | ||||||
|  |   border-radius: 5px; | ||||||
|  |   transition: all 0.3s; | ||||||
|  | } | ||||||
|  | .dv-capsule-chart .unit-label { | ||||||
|  |   height: 20px; | ||||||
|  |   font-size: 12px; | ||||||
|  |   display: flex; | ||||||
|  |   flex-direction: row; | ||||||
|  |   align-items: center; | ||||||
|  |   justify-content: space-between; | ||||||
|  | } | ||||||
|  | .dv-capsule-chart .unit-text { | ||||||
|  |   text-align: right; | ||||||
|  |   display: flex; | ||||||
|  |   align-items: flex-end; | ||||||
|  |   font-size: 12px; | ||||||
|  |   line-height: 20px; | ||||||
|  |   margin-left: 10px; | ||||||
|  | } | ||||||
							
								
								
									
										114
									
								
								lib/components/capsuleChart/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										114
									
								
								lib/components/capsuleChart/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,114 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-capsule-chart"> | ||||||
|  |     <template v-if="mergedConfig"> | ||||||
|  |       <div class="label-column"> | ||||||
|  |         <div v-for="item in mergedConfig.data" :key="item.name">{{ item.name }}</div> | ||||||
|  |         <div> </div> | ||||||
|  |       </div> | ||||||
|  |  | ||||||
|  |       <div class="capsule-container"> | ||||||
|  |         <div | ||||||
|  |           class="capsule-item" | ||||||
|  |           v-for="(capsule, index) in capsuleLength" | ||||||
|  |           :key="index" | ||||||
|  |         > | ||||||
|  |           <div :style="`width: ${capsule * 100}%; background-color: ${mergedConfig.colors[index % mergedConfig.colors.length]};`"></div> | ||||||
|  |         </div> | ||||||
|  |  | ||||||
|  |         <div class="unit-label"> | ||||||
|  |           <div v-for="(label, index) in labelData" :key="label + index">{{ label }}</div> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |  | ||||||
|  |       <div class="unit-text" v-if="mergedConfig.unit">{{ mergedConfig.unit }}</div> | ||||||
|  |     </template> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import { deepMerge } from '@jiaminghi/charts/lib/util/index' | ||||||
|  |  | ||||||
|  | import { deepClone } from '@jiaminghi/c-render/lib/plugin/util' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvCapsuleChart', | ||||||
|  |   props: { | ||||||
|  |     config: { | ||||||
|  |       type: Object, | ||||||
|  |       default: () => ({}) | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       defaultConfig: { | ||||||
|  |         /** | ||||||
|  |          * @description Capsule chart data | ||||||
|  |          * @type {Array<Object>} | ||||||
|  |          * @default data = [] | ||||||
|  |          * @example data = [{ name: 'foo1', value: 100 }, { name: 'foo2', value: 100 }] | ||||||
|  |          */ | ||||||
|  |         data: [], | ||||||
|  |         /** | ||||||
|  |          * @description Colors (hex|rgb|rgba|color keywords) | ||||||
|  |          * @type {Array<String>} | ||||||
|  |          * @default color = ['#37a2da', '#32c5e9', '#67e0e3', '#9fe6b8', '#ffdb5c', '#ff9f7f', '#fb7293'] | ||||||
|  |          * @example color = ['#000', 'rgb(0, 0, 0)', 'rgba(0, 0, 0, 1)', 'red'] | ||||||
|  |          */ | ||||||
|  |         colors: ['#37a2da', '#32c5e9', '#67e0e3', '#9fe6b8', '#ffdb5c', '#ff9f7f', '#fb7293'], | ||||||
|  |         /** | ||||||
|  |          * @description Chart unit | ||||||
|  |          * @type {String} | ||||||
|  |          * @default unit = '' | ||||||
|  |          */ | ||||||
|  |         unit: '' | ||||||
|  |       }, | ||||||
|  |  | ||||||
|  |       mergedConfig: null, | ||||||
|  |  | ||||||
|  |       capsuleLength: [], | ||||||
|  |       labelData: [] | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   watch: { | ||||||
|  |     config () { | ||||||
|  |       const { calcData } = this | ||||||
|  |  | ||||||
|  |       calcData() | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     calcData () { | ||||||
|  |       const { mergeConfig, calcCapsuleLengthAndLabelData } = this | ||||||
|  |  | ||||||
|  |       mergeConfig() | ||||||
|  |  | ||||||
|  |       calcCapsuleLengthAndLabelData() | ||||||
|  |     }, | ||||||
|  |     mergeConfig () { | ||||||
|  |       let { config, defaultConfig } = this | ||||||
|  |  | ||||||
|  |       this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {}) | ||||||
|  |     }, | ||||||
|  |     calcCapsuleLengthAndLabelData () { | ||||||
|  |       const { data } = this.mergedConfig | ||||||
|  |  | ||||||
|  |       if (!data.length) return | ||||||
|  |  | ||||||
|  |       const capsuleValue = data.map(({ value }) => value) | ||||||
|  |  | ||||||
|  |       const maxValue = Math.max(...capsuleValue) | ||||||
|  |  | ||||||
|  |       this.capsuleLength = capsuleValue.map(v => maxValue ? v / maxValue : 0) | ||||||
|  |  | ||||||
|  |       const oneFifth = maxValue / 5 | ||||||
|  |  | ||||||
|  |       this.labelData = new Array(6).fill(0).map((v, i) => Math.ceil(i * oneFifth)) | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   mounted () { | ||||||
|  |     const { calcData } = this | ||||||
|  |  | ||||||
|  |     calcData() | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/charts/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/charts/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import Charts from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(Charts.name, Charts) | ||||||
|  | } | ||||||
							
								
								
									
										9
									
								
								lib/components/charts/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								lib/components/charts/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | |||||||
|  | .dv-charts-container { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .dv-charts-container .charts-canvas-container { | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
							
								
								
									
										64
									
								
								lib/components/charts/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								lib/components/charts/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,64 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-charts-container" :ref="ref"> | ||||||
|  |     <div class="charts-canvas-container" :ref="chartRef" /> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import autoResize from '../../../mixin/autoResize' | ||||||
|  |  | ||||||
|  | import Charts from '@jiaminghi/charts' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvCharts', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   props: { | ||||||
|  |     option: { | ||||||
|  |       type: Object, | ||||||
|  |       default: () => ({}) | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       ref: `charts-container-${(new Date()).getTime()}`, | ||||||
|  |       chartRef: `chart-${(new Date()).getTime()}`, | ||||||
|  |  | ||||||
|  |       chart: null | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   watch: { | ||||||
|  |     option () { | ||||||
|  |       let { chart, option } = this | ||||||
|  |  | ||||||
|  |       if (!chart) return | ||||||
|  |  | ||||||
|  |       if (!option) option = {} | ||||||
|  |  | ||||||
|  |       chart.setOption(option) | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     afterAutoResizeMixinInit () { | ||||||
|  |       const { initChart } = this | ||||||
|  |  | ||||||
|  |       initChart() | ||||||
|  |     }, | ||||||
|  |     initChart () { | ||||||
|  |       const { $refs, chartRef, option } = this | ||||||
|  |  | ||||||
|  |       const chart = this.chart = new Charts($refs[chartRef]) | ||||||
|  |  | ||||||
|  |       if (!option) return | ||||||
|  |  | ||||||
|  |       chart.setOption(option) | ||||||
|  |     }, | ||||||
|  |     onResize () { | ||||||
|  |       const { chart } = this | ||||||
|  |  | ||||||
|  |       if (!chart) return | ||||||
|  |  | ||||||
|  |       chart.resize() | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/conicalColumnChart/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/conicalColumnChart/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import ConicalColumnChart from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(ConicalColumnChart.name, ConicalColumnChart) | ||||||
|  | } | ||||||
							
								
								
									
										7
									
								
								lib/components/conicalColumnChart/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								lib/components/conicalColumnChart/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | .dv-conical-column-chart { | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .dv-conical-column-chart text { | ||||||
|  |   text-anchor: middle; | ||||||
|  | } | ||||||
							
								
								
									
										208
									
								
								lib/components/conicalColumnChart/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										208
									
								
								lib/components/conicalColumnChart/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,208 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-conical-column-chart" :ref="ref"> | ||||||
|  |     <svg :width="width" :height="height"> | ||||||
|  |       <g | ||||||
|  |         v-for="(item, i) in column" | ||||||
|  |         :key="i" | ||||||
|  |       > | ||||||
|  |         <path | ||||||
|  |           :d="item.d" | ||||||
|  |           :fill="mergedConfig.columnColor" | ||||||
|  |         /> | ||||||
|  |         <text | ||||||
|  |           :style="`fontSize:${mergedConfig.fontSize}px`" | ||||||
|  |           :fill="mergedConfig.textColor" | ||||||
|  |           :x="item.x" | ||||||
|  |           :y="height - 4" | ||||||
|  |         > | ||||||
|  |           {{ item.name }} | ||||||
|  |         </text> | ||||||
|  |         <image | ||||||
|  |           v-if="mergedConfig.img.length" | ||||||
|  |           :xlink:href="mergedConfig.img[i % mergedConfig.img.length]" | ||||||
|  |           :width="mergedConfig.imgSideLength" | ||||||
|  |           :height="mergedConfig.imgSideLength" | ||||||
|  |           :x="item.x - mergedConfig.imgSideLength / 2" | ||||||
|  |           :y="item.y - mergedConfig.imgSideLength" | ||||||
|  |         /> | ||||||
|  |         <text | ||||||
|  |           v-if="mergedConfig.showValue" | ||||||
|  |           :style="`fontSize:${mergedConfig.fontSize}px`" | ||||||
|  |           :fill="mergedConfig.textColor" | ||||||
|  |           :x="item.x" | ||||||
|  |           :y="item.textY" | ||||||
|  |         > | ||||||
|  |           {{ item.value }} | ||||||
|  |         </text> | ||||||
|  |       </g> | ||||||
|  |     </svg> | ||||||
|  |   </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: 'DvConicalColumnChart', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   props: { | ||||||
|  |     config: { | ||||||
|  |       type: Object, | ||||||
|  |       default: () => ({}) | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       ref: 'conical-column-chart', | ||||||
|  |  | ||||||
|  |       defaultConfig: { | ||||||
|  |         /** | ||||||
|  |          * @description Chart data | ||||||
|  |          * @type {Array<Object>} | ||||||
|  |          * @default data = [] | ||||||
|  |          */ | ||||||
|  |         data: [], | ||||||
|  |         /** | ||||||
|  |          * @description Chart img | ||||||
|  |          * @type {Array<String>} | ||||||
|  |          * @default img = [] | ||||||
|  |          */ | ||||||
|  |         img: [], | ||||||
|  |         /** | ||||||
|  |          * @description Chart font size | ||||||
|  |          * @type {Number} | ||||||
|  |          * @default fontSize = 12 | ||||||
|  |          */ | ||||||
|  |         fontSize: 12, | ||||||
|  |         /** | ||||||
|  |          * @description Img side length | ||||||
|  |          * @type {Number} | ||||||
|  |          * @default imgSideLength = 30 | ||||||
|  |          */ | ||||||
|  |         imgSideLength: 30, | ||||||
|  |         /** | ||||||
|  |          * @description Column color | ||||||
|  |          * @type {String} | ||||||
|  |          * @default columnColor = 'rgba(0, 194, 255, 0.4)' | ||||||
|  |          */ | ||||||
|  |         columnColor: 'rgba(0, 194, 255, 0.4)', | ||||||
|  |         /** | ||||||
|  |          * @description Text color | ||||||
|  |          * @type {String} | ||||||
|  |          * @default textColor = '#fff' | ||||||
|  |          */ | ||||||
|  |         textColor: '#fff', | ||||||
|  |         /** | ||||||
|  |          * @description Show value | ||||||
|  |          * @type {Boolean} | ||||||
|  |          * @default showValue = false | ||||||
|  |          */ | ||||||
|  |         showValue: false | ||||||
|  |       }, | ||||||
|  |  | ||||||
|  |       mergedConfig: null, | ||||||
|  |  | ||||||
|  |       column: [] | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   watch: { | ||||||
|  |     config () { | ||||||
|  |       const { calcData } = this | ||||||
|  |  | ||||||
|  |       calcData() | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     afterAutoResizeMixinInit () { | ||||||
|  |       const { calcData } = this | ||||||
|  |  | ||||||
|  |       calcData() | ||||||
|  |     }, | ||||||
|  |     onResize () { | ||||||
|  |       const { calcData } = this | ||||||
|  |  | ||||||
|  |       calcData() | ||||||
|  |     }, | ||||||
|  |     calcData () { | ||||||
|  |       const { mergeConfig, initData, calcSVGPath } = this | ||||||
|  |  | ||||||
|  |       mergeConfig() | ||||||
|  |  | ||||||
|  |       initData() | ||||||
|  |  | ||||||
|  |       calcSVGPath() | ||||||
|  |     }, | ||||||
|  |     mergeConfig () { | ||||||
|  |       const { defaultConfig, config } = this | ||||||
|  |  | ||||||
|  |       this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {}) | ||||||
|  |     }, | ||||||
|  |     initData () { | ||||||
|  |       const { mergedConfig } = this | ||||||
|  |       let { data } = mergedConfig | ||||||
|  |  | ||||||
|  |       data = deepClone(data, true) | ||||||
|  |  | ||||||
|  |       data.sort(({ value: a }, { value: b }) => { | ||||||
|  |         if (a > b) return -1 | ||||||
|  |         if (a < b) return 1 | ||||||
|  |         if (a === b) return 0 | ||||||
|  |       }) | ||||||
|  |  | ||||||
|  |       const max = data[0] ? data[0].value : 10 | ||||||
|  |  | ||||||
|  |       data = data.map(item => ({ | ||||||
|  |         ...item, | ||||||
|  |         percent: item.value / max | ||||||
|  |       })) | ||||||
|  |  | ||||||
|  |       mergedConfig.data = data | ||||||
|  |     }, | ||||||
|  |     calcSVGPath () { | ||||||
|  |       const { mergedConfig, width, height } = this | ||||||
|  |  | ||||||
|  |       const { imgSideLength, fontSize, data } = mergedConfig | ||||||
|  |  | ||||||
|  |       const itemNum = data.length | ||||||
|  |       const gap = width / (itemNum + 1) | ||||||
|  |  | ||||||
|  |       const useAbleHeight = height - imgSideLength - fontSize - 5 | ||||||
|  |       const svgBottom = height - fontSize - 5 | ||||||
|  |  | ||||||
|  |       this.column = data.map((item, i) => { | ||||||
|  |         const { percent } = item | ||||||
|  |  | ||||||
|  |         const middleXPos = gap * (i + 1) | ||||||
|  |         const leftXPos = gap * i | ||||||
|  |         const rightXpos = gap * (i + 2) | ||||||
|  |  | ||||||
|  |         const middleYPos = svgBottom - useAbleHeight * percent | ||||||
|  |         const controlYPos = useAbleHeight * percent * 0.6 + middleYPos | ||||||
|  |  | ||||||
|  |         const d = ` | ||||||
|  |           M${leftXPos}, ${svgBottom} | ||||||
|  |           Q${middleXPos}, ${controlYPos} ${middleXPos},${middleYPos} | ||||||
|  |           M${middleXPos},${middleYPos} | ||||||
|  |           Q${middleXPos}, ${controlYPos} ${rightXpos},${svgBottom} | ||||||
|  |           L${leftXPos}, ${svgBottom} | ||||||
|  |           Z | ||||||
|  |         ` | ||||||
|  |  | ||||||
|  |         const textY = (svgBottom + middleYPos) / 2 + fontSize / 2 | ||||||
|  |  | ||||||
|  |         return { | ||||||
|  |           ...item, | ||||||
|  |           d, | ||||||
|  |           x: middleXPos, | ||||||
|  |           y: middleYPos, | ||||||
|  |           textY | ||||||
|  |         } | ||||||
|  |       }) | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/decoration1/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/decoration1/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import Decoration1 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(Decoration1.name, Decoration1) | ||||||
|  | } | ||||||
							
								
								
									
										7
									
								
								lib/components/decoration1/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								lib/components/decoration1/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | .dv-decoration-1 { | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .dv-decoration-1 svg { | ||||||
|  |   transform-origin: left top; | ||||||
|  | } | ||||||
							
								
								
									
										166
									
								
								lib/components/decoration1/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										166
									
								
								lib/components/decoration1/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,166 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-decoration-1" :ref="ref"> | ||||||
|  |     <svg :width="`${svgWH[0]}px`" :height="`${svgWH[1]}px`" :style="`transform:scale(${svgScale[0]},${svgScale[1]});`"> | ||||||
|  |  | ||||||
|  |       <template | ||||||
|  |         v-for="(point, i) in points" | ||||||
|  |       > | ||||||
|  |         <rect | ||||||
|  |           v-if="Math.random() > 0.6" | ||||||
|  |           :key="i" | ||||||
|  |           fill="#fff" | ||||||
|  |           :x="point[0] - halfPointSideLength" | ||||||
|  |           :y="point[1] - halfPointSideLength" | ||||||
|  |           :width="pointSideLength" | ||||||
|  |           :height="pointSideLength" | ||||||
|  |         > | ||||||
|  |           <animate | ||||||
|  |             v-if="Math.random() > 0.6" | ||||||
|  |             attributeName="fill" | ||||||
|  |             values="#fff;transparent" | ||||||
|  |             dur="1s" | ||||||
|  |             :begin="Math.random() * 2" | ||||||
|  |             repeatCount="indefinite" | ||||||
|  |           /> | ||||||
|  |         </rect> | ||||||
|  |       </template> | ||||||
|  |  | ||||||
|  |       <rect | ||||||
|  |         v-if="rects[0]" | ||||||
|  |         fill="#0de7c2" | ||||||
|  |         :x="rects[0][0] - pointSideLength" | ||||||
|  |         :y="rects[0][1] - pointSideLength" | ||||||
|  |         :width="pointSideLength * 2" | ||||||
|  |         :height="pointSideLength * 2" | ||||||
|  |       > | ||||||
|  |         <animate | ||||||
|  |           attributeName="width" | ||||||
|  |           :values="`0;${pointSideLength * 2}`" | ||||||
|  |           dur="2s" | ||||||
|  |           repeatCount="indefinite" | ||||||
|  |         /> | ||||||
|  |         <animate | ||||||
|  |           attributeName="height" | ||||||
|  |           :values="`0;${pointSideLength * 2}`" | ||||||
|  |           dur="2s" | ||||||
|  |           repeatCount="indefinite" | ||||||
|  |         /> | ||||||
|  |         <animate | ||||||
|  |           attributeName="x" | ||||||
|  |           :values="`${rects[0][0]};${rects[0][0] - pointSideLength}`" | ||||||
|  |           dur="2s" | ||||||
|  |           repeatCount="indefinite" | ||||||
|  |         /> | ||||||
|  |         <animate | ||||||
|  |           attributeName="y" | ||||||
|  |           :values="`${rects[0][1]};${rects[0][1] - pointSideLength}`" | ||||||
|  |           dur="2s" | ||||||
|  |           repeatCount="indefinite" | ||||||
|  |         /> | ||||||
|  |       </rect> | ||||||
|  |  | ||||||
|  |       <rect | ||||||
|  |         v-if="rects[1]" | ||||||
|  |         fill="#0de7c2" | ||||||
|  |         :x="rects[1][0] - 40" | ||||||
|  |         :y="rects[1][1] - pointSideLength" | ||||||
|  |         :width="40" | ||||||
|  |         :height="pointSideLength * 2" | ||||||
|  |       > | ||||||
|  |         <animate | ||||||
|  |           attributeName="width" | ||||||
|  |           values="0;40;0" | ||||||
|  |           dur="2s" | ||||||
|  |           repeatCount="indefinite" | ||||||
|  |         /> | ||||||
|  |         <animate | ||||||
|  |           attributeName="x" | ||||||
|  |           :values="`${rects[1][0]};${rects[1][0] - 40};${rects[1][0]}`" | ||||||
|  |           dur="2s" | ||||||
|  |           repeatCount="indefinite" | ||||||
|  |         /> | ||||||
|  |       </rect> | ||||||
|  |     </svg> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import autoResize from '../../../mixin/autoResize' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvDecoration1', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   data () { | ||||||
|  |     const pointSideLength = 2.5 | ||||||
|  |  | ||||||
|  |     return { | ||||||
|  |       ref: 'decoration-1', | ||||||
|  |  | ||||||
|  |       svgWH: [200, 50], | ||||||
|  |  | ||||||
|  |       svgScale: [1, 1], | ||||||
|  |  | ||||||
|  |       rowNum: 4, | ||||||
|  |       rowPoints: 20, | ||||||
|  |  | ||||||
|  |       pointSideLength, | ||||||
|  |       halfPointSideLength: pointSideLength / 2, | ||||||
|  |  | ||||||
|  |       points: [], | ||||||
|  |  | ||||||
|  |       rects: [] | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     afterAutoResizeMixinInit () { | ||||||
|  |       const { calcSVGData } = this | ||||||
|  |  | ||||||
|  |       calcSVGData() | ||||||
|  |     }, | ||||||
|  |     calcSVGData () { | ||||||
|  |       const { calcPointsPosition, calcRectsPosition, calcScale } = this | ||||||
|  |  | ||||||
|  |       calcPointsPosition() | ||||||
|  |  | ||||||
|  |       calcRectsPosition() | ||||||
|  |  | ||||||
|  |       calcScale() | ||||||
|  |     }, | ||||||
|  |     calcPointsPosition () { | ||||||
|  |       const { svgWH, rowNum, rowPoints } = this | ||||||
|  |  | ||||||
|  |       const [w, h] = svgWH | ||||||
|  |  | ||||||
|  |       const horizontalGap = w / (rowPoints + 1) | ||||||
|  |       const verticalGap = h / (rowNum + 1) | ||||||
|  |  | ||||||
|  |       let points = new Array(rowNum).fill(0).map((foo, i) => | ||||||
|  |         new Array(rowPoints).fill(0).map((foo, j) => [ | ||||||
|  |           horizontalGap * (j + 1), verticalGap * (i + 1) | ||||||
|  |         ])) | ||||||
|  |  | ||||||
|  |       this.points = points.reduce((all, item) => [...all, ...item], []) | ||||||
|  |     }, | ||||||
|  |     calcRectsPosition () { | ||||||
|  |       const { points, rowPoints } = this | ||||||
|  |  | ||||||
|  |       const rect1 = points[rowPoints * 2 - 1] | ||||||
|  |       const rect2 = points[rowPoints * 2 - 3] | ||||||
|  |  | ||||||
|  |       this.rects = [rect1, rect2] | ||||||
|  |     }, | ||||||
|  |     calcScale () { | ||||||
|  |       const { width, height, svgWH } = this | ||||||
|  |  | ||||||
|  |       const [w, h] = svgWH | ||||||
|  |  | ||||||
|  |       this.svgScale = [width / w, height / h] | ||||||
|  |     }, | ||||||
|  |     onResize () { | ||||||
|  |       const { calcSVGData } = this | ||||||
|  |  | ||||||
|  |       calcSVGData() | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/decoration10/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/decoration10/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import Decoration10 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(Decoration10.name, Decoration10) | ||||||
|  | } | ||||||
							
								
								
									
										5
									
								
								lib/components/decoration10/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								lib/components/decoration10/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | .dv-decoration-10 { | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  |   display: flex; | ||||||
|  | } | ||||||
							
								
								
									
										168
									
								
								lib/components/decoration10/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										168
									
								
								lib/components/decoration10/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,168 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-decoration-10" :ref="ref"> | ||||||
|  |     <svg :width="width" :height="height"> | ||||||
|  |       <polyline | ||||||
|  |         stroke="rgba(0, 194, 255, 0.3)" | ||||||
|  |         stroke-width="2" | ||||||
|  |         :points="`0, ${height / 2} ${width}, ${height / 2}`" | ||||||
|  |       /> | ||||||
|  |  | ||||||
|  |       <polyline | ||||||
|  |         stroke="rgba(0, 194, 255, 1)" | ||||||
|  |         stroke-width="2" | ||||||
|  |         :points="`5, ${height / 2} ${width * 0.2 - 3}, ${height / 2}`" | ||||||
|  |         :stroke-dasharray="`0, ${width * 0.2}`" | ||||||
|  |         fill="freeze" | ||||||
|  |       > | ||||||
|  |         <animate | ||||||
|  |           :id="animationId2" | ||||||
|  |           attributeName="stroke-dasharray" | ||||||
|  |           :values="`0, ${width * 0.2};${width * 0.2}, 0;`" | ||||||
|  |           dur="3s" | ||||||
|  |           :begin="`${animationId1}.end`" | ||||||
|  |           fill="freeze" | ||||||
|  |         /> | ||||||
|  |         <animate | ||||||
|  |           attributeName="stroke-dasharray" | ||||||
|  |           :values="`${width * 0.2}, 0;0, ${width * 0.2}`" | ||||||
|  |           dur="0.01s" | ||||||
|  |           :begin="`${animationId7}.end`" | ||||||
|  |           fill="freeze" | ||||||
|  |         /> | ||||||
|  |       </polyline> | ||||||
|  |  | ||||||
|  |       <polyline | ||||||
|  |         stroke="rgba(0, 194, 255, 1)" | ||||||
|  |         stroke-width="2" | ||||||
|  |         :points="`${width * 0.2 + 3}, ${height / 2} ${width * 0.8 - 3}, ${height / 2}`" | ||||||
|  |         :stroke-dasharray="`0, ${width * 0.6}`" | ||||||
|  |       > | ||||||
|  |         <animate | ||||||
|  |           :id="animationId4" | ||||||
|  |           attributeName="stroke-dasharray" | ||||||
|  |           :values="`0, ${width * 0.6};${width * 0.6}, 0`" | ||||||
|  |           dur="3s" | ||||||
|  |           :begin="`${animationId3}.end + 1s`" | ||||||
|  |           fill="freeze" | ||||||
|  |         /> | ||||||
|  |         <animate | ||||||
|  |           attributeName="stroke-dasharray" | ||||||
|  |           :values="`${width * 0.6}, 0;0, ${width * 0.6}`" | ||||||
|  |           dur="0.01s" | ||||||
|  |           :begin="`${animationId7}.end`" | ||||||
|  |           fill="freeze" | ||||||
|  |         /> | ||||||
|  |       </polyline> | ||||||
|  |  | ||||||
|  |       <polyline | ||||||
|  |         stroke="rgba(0, 194, 255, 1)" | ||||||
|  |         stroke-width="2" | ||||||
|  |         :points="`${width * 0.8 + 3}, ${height / 2} ${width - 5}, ${height / 2}`" | ||||||
|  |         :stroke-dasharray="`0, ${width * 0.2}`" | ||||||
|  |       > | ||||||
|  |         <animate | ||||||
|  |           :id="animationId6" | ||||||
|  |           attributeName="stroke-dasharray" | ||||||
|  |           :values="`0, ${width * 0.2};${width * 0.2}, 0`" | ||||||
|  |           dur="3s" | ||||||
|  |           :begin="`${animationId5}.end + 1s`" | ||||||
|  |           fill="freeze" | ||||||
|  |         /> | ||||||
|  |         <animate | ||||||
|  |           attributeName="stroke-dasharray" | ||||||
|  |           :values="`${width * 0.2}, 0;0, ${width * 0.3}`" | ||||||
|  |           dur="0.01s" | ||||||
|  |           :begin="`${animationId7}.end`" | ||||||
|  |           fill="freeze" | ||||||
|  |         /> | ||||||
|  |       </polyline> | ||||||
|  |  | ||||||
|  |       <circle cx="2" :cy="height / 2" r="2" fill="#03709f"> | ||||||
|  |         <animate | ||||||
|  |           :id="animationId1" | ||||||
|  |           attributeName="fill" | ||||||
|  |           values="#03709f;#00c2ff" | ||||||
|  |           :begin="`0s;${animationId7}.end`" | ||||||
|  |           dur="0.3s" | ||||||
|  |           fill="freeze" | ||||||
|  |         /> | ||||||
|  |       </circle> | ||||||
|  |  | ||||||
|  |       <circle :cx="width * 0.2" :cy="height / 2" r="2" fill="#03709f"> | ||||||
|  |         <animate | ||||||
|  |           :id="animationId3" | ||||||
|  |           attributeName="fill" | ||||||
|  |           values="#03709f;#00c2ff" | ||||||
|  |           :begin="`${animationId2}.end`" | ||||||
|  |           dur="0.3s" | ||||||
|  |           fill="freeze" | ||||||
|  |         /> | ||||||
|  |         <animate | ||||||
|  |           attributeName="fill" | ||||||
|  |           values="#03709f;#03709f" | ||||||
|  |           dur="0.01s" | ||||||
|  |           :begin="`${animationId7}.end`" | ||||||
|  |           fill="freeze" | ||||||
|  |         /> | ||||||
|  |       </circle> | ||||||
|  |  | ||||||
|  |       <circle :cx="width * 0.8" :cy="height / 2" r="2" fill="#03709f"> | ||||||
|  |         <animate | ||||||
|  |           :id="animationId5" | ||||||
|  |           attributeName="fill" | ||||||
|  |           values="#03709f;#00c2ff" | ||||||
|  |           :begin="`${animationId4}.end`" | ||||||
|  |           dur="0.3s" | ||||||
|  |           fill="freeze" | ||||||
|  |         /> | ||||||
|  |         <animate | ||||||
|  |           attributeName="fill" | ||||||
|  |           values="#03709f;#03709f" | ||||||
|  |           dur="0.01s" | ||||||
|  |           :begin="`${animationId7}.end`" | ||||||
|  |           fill="freeze" | ||||||
|  |         /> | ||||||
|  |       </circle> | ||||||
|  |  | ||||||
|  |       <circle :cx="width - 2" :cy="height / 2" r="2" fill="#03709f"> | ||||||
|  |         <animate | ||||||
|  |           :id="animationId7" | ||||||
|  |           attributeName="fill" | ||||||
|  |           values="#03709f;#00c2ff" | ||||||
|  |           :begin="`${animationId6}.end`" | ||||||
|  |           dur="0.3s" | ||||||
|  |           fill="freeze" | ||||||
|  |         /> | ||||||
|  |         <animate | ||||||
|  |           attributeName="fill" | ||||||
|  |           values="#03709f;#03709f" | ||||||
|  |           dur="0.01s" | ||||||
|  |           :begin="`${animationId7}.end`" | ||||||
|  |           fill="freeze" | ||||||
|  |         /> | ||||||
|  |       </circle> | ||||||
|  |     </svg> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import autoResize from '../../../mixin/autoResize' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvDecoration10', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       ref: 'decoration-10', | ||||||
|  |  | ||||||
|  |       animationId1: `d10ani1${(new Date()).getTime()}`, | ||||||
|  |       animationId2: `d10ani2${(new Date()).getTime()}`, | ||||||
|  |       animationId3: `d10ani3${(new Date()).getTime()}`, | ||||||
|  |       animationId4: `d10ani4${(new Date()).getTime()}`, | ||||||
|  |       animationId5: `d10ani5${(new Date()).getTime()}`, | ||||||
|  |       animationId6: `d10ani6${(new Date()).getTime()}`, | ||||||
|  |       animationId7: `d10ani7${(new Date()).getTime()}` | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/decoration2/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/decoration2/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import Decoration2 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(Decoration2.name, Decoration2) | ||||||
|  | } | ||||||
							
								
								
									
										7
									
								
								lib/components/decoration2/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								lib/components/decoration2/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | .dv-decoration-2 { | ||||||
|  |   display: flex; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  |   justify-content: center; | ||||||
|  |   align-items: center; | ||||||
|  | } | ||||||
							
								
								
									
										91
									
								
								lib/components/decoration2/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								lib/components/decoration2/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,91 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-decoration-2" :ref="ref"> | ||||||
|  |     <svg :width="`${width}px`" :height="`${height}px`"> | ||||||
|  |       <rect :x="x" :y="y" :width="w" :height="h" fill="#3faacb"> | ||||||
|  |         <animate | ||||||
|  |           :attributeName="reverse ? 'height' : 'width'" | ||||||
|  |           from="0" | ||||||
|  |           :to="reverse ? height : width" | ||||||
|  |           dur="6s" | ||||||
|  |           calcMode="spline" | ||||||
|  |           keyTimes="0;1" | ||||||
|  |           keySplines=".42,0,.58,1" | ||||||
|  |           repeatCount="indefinite" | ||||||
|  |         /> | ||||||
|  |       </rect> | ||||||
|  |  | ||||||
|  |       <rect :x="x" :y="y" width="1" height="1" fill="#fff"> | ||||||
|  |         <animate | ||||||
|  |           :attributeName="reverse ? 'y' : 'x'" | ||||||
|  |           from="0" | ||||||
|  |           :to="reverse ? height : width" | ||||||
|  |           dur="6s" | ||||||
|  |           calcMode="spline" | ||||||
|  |           keyTimes="0;1" | ||||||
|  |           keySplines="0.42,0,0.58,1" | ||||||
|  |           repeatCount="indefinite" | ||||||
|  |         /> | ||||||
|  |       </rect> | ||||||
|  |     </svg> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import autoResize from '../../../mixin/autoResize' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvDecoration2', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   props: { | ||||||
|  |     reverse: { | ||||||
|  |       type: Boolean, | ||||||
|  |       default: false | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       ref: 'decoration-2', | ||||||
|  |  | ||||||
|  |       x: 0, | ||||||
|  |       y: 0, | ||||||
|  |  | ||||||
|  |       w: 0, | ||||||
|  |       h: 0 | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   watch: { | ||||||
|  |     reverse () { | ||||||
|  |       const { calcSVGData } = this | ||||||
|  |  | ||||||
|  |       calcSVGData() | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     afterAutoResizeMixinInit () { | ||||||
|  |       const { calcSVGData } = this | ||||||
|  |  | ||||||
|  |       calcSVGData() | ||||||
|  |     }, | ||||||
|  |     calcSVGData () { | ||||||
|  |       const { reverse, width, height } = this | ||||||
|  |  | ||||||
|  |       if (reverse) { | ||||||
|  |         this.w = 1 | ||||||
|  |         this.h = height | ||||||
|  |         this.x = width / 2 | ||||||
|  |         this.y = 0 | ||||||
|  |       } else { | ||||||
|  |         this.w = width | ||||||
|  |         this.h = 1 | ||||||
|  |         this.x = 0 | ||||||
|  |         this.y = height / 2 | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     onResize () { | ||||||
|  |       const { calcSVGData } = this | ||||||
|  |  | ||||||
|  |       calcSVGData() | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/decoration3/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/decoration3/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import Decoration3 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(Decoration3.name, Decoration3) | ||||||
|  | } | ||||||
							
								
								
									
										7
									
								
								lib/components/decoration3/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								lib/components/decoration3/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | .dv-decoration-3 { | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .dv-decoration-3 svg { | ||||||
|  |   transform-origin: left top; | ||||||
|  | } | ||||||
							
								
								
									
										97
									
								
								lib/components/decoration3/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										97
									
								
								lib/components/decoration3/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,97 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-decoration-3" :ref="ref"> | ||||||
|  |     <svg :width="`${svgWH[0]}px`" :height="`${svgWH[1]}px`" :style="`transform:scale(${svgScale[0]},${svgScale[1]});`"> | ||||||
|  |  | ||||||
|  |       <template | ||||||
|  |         v-for="(point, i) in points" | ||||||
|  |       > | ||||||
|  |         <rect | ||||||
|  |           :key="i" | ||||||
|  |           fill="#7acaec" | ||||||
|  |           :x="point[0] - halfPointSideLength" | ||||||
|  |           :y="point[1] - halfPointSideLength" | ||||||
|  |           :width="pointSideLength" | ||||||
|  |           :height="pointSideLength" | ||||||
|  |         > | ||||||
|  |           <animate | ||||||
|  |             v-if="Math.random() > 0.6" | ||||||
|  |             attributeName="fill" | ||||||
|  |             values="#7acaec;transparent" | ||||||
|  |             :dur="Math.random() + 1 + 's'" | ||||||
|  |             :begin="Math.random() * 2" | ||||||
|  |             repeatCount="indefinite" | ||||||
|  |           /> | ||||||
|  |         </rect> | ||||||
|  |       </template> | ||||||
|  |     </svg> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import autoResize from '../../../mixin/autoResize' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvDecoration3', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   data () { | ||||||
|  |     const pointSideLength = 7 | ||||||
|  |  | ||||||
|  |     return { | ||||||
|  |       ref: 'decoration-3', | ||||||
|  |  | ||||||
|  |       svgWH: [300, 35], | ||||||
|  |  | ||||||
|  |       svgScale: [1, 1], | ||||||
|  |  | ||||||
|  |       rowNum: 2, | ||||||
|  |       rowPoints: 25, | ||||||
|  |  | ||||||
|  |       pointSideLength, | ||||||
|  |       halfPointSideLength: pointSideLength / 2, | ||||||
|  |  | ||||||
|  |       points: [] | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     afterAutoResizeMixinInit () { | ||||||
|  |       const { calcSVGData } = this | ||||||
|  |  | ||||||
|  |       calcSVGData() | ||||||
|  |     }, | ||||||
|  |     calcSVGData () { | ||||||
|  |       const { calcPointsPosition, calcScale } = this | ||||||
|  |  | ||||||
|  |       calcPointsPosition() | ||||||
|  |  | ||||||
|  |       calcScale() | ||||||
|  |     }, | ||||||
|  |     calcPointsPosition () { | ||||||
|  |       const { svgWH, rowNum, rowPoints } = this | ||||||
|  |  | ||||||
|  |       const [w, h] = svgWH | ||||||
|  |  | ||||||
|  |       const horizontalGap = w / (rowPoints + 1) | ||||||
|  |       const verticalGap = h / (rowNum + 1) | ||||||
|  |  | ||||||
|  |       let points = new Array(rowNum).fill(0).map((foo, i) => | ||||||
|  |         new Array(rowPoints).fill(0).map((foo, j) => [ | ||||||
|  |           horizontalGap * (j + 1), verticalGap * (i + 1) | ||||||
|  |         ])) | ||||||
|  |  | ||||||
|  |       this.points = points.reduce((all, item) => [...all, ...item], []) | ||||||
|  |     }, | ||||||
|  |     calcScale () { | ||||||
|  |       const { width, height, svgWH } = this | ||||||
|  |  | ||||||
|  |       const [w, h] = svgWH | ||||||
|  |  | ||||||
|  |       this.svgScale = [width / w, height / h] | ||||||
|  |     }, | ||||||
|  |     onResize () { | ||||||
|  |       const { calcSVGData } = this | ||||||
|  |  | ||||||
|  |       calcSVGData() | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/decoration4/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/decoration4/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import Decoration4 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(Decoration4.name, Decoration4) | ||||||
|  | } | ||||||
							
								
								
									
										38
									
								
								lib/components/decoration4/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								lib/components/decoration4/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,38 @@ | |||||||
|  | .dv-decoration-4 { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .dv-decoration-4 .container { | ||||||
|  |   display: flex; | ||||||
|  |   overflow: hidden; | ||||||
|  |   position: absolute; | ||||||
|  | } | ||||||
|  | .dv-decoration-4 .normal { | ||||||
|  |   height: 0% !important; | ||||||
|  |   animation: ani-height 3s ease-in-out infinite; | ||||||
|  |   left: 50%; | ||||||
|  |   margin-left: -2px; | ||||||
|  | } | ||||||
|  | .dv-decoration-4 .reverse { | ||||||
|  |   width: 0% !important; | ||||||
|  |   animation: ani-width 3s ease-in-out infinite; | ||||||
|  |   top: 50%; | ||||||
|  |   margin-top: -2px; | ||||||
|  | } | ||||||
|  | @keyframes ani-height { | ||||||
|  |   70% { | ||||||
|  |     height: 100%; | ||||||
|  |   } | ||||||
|  |   100% { | ||||||
|  |     height: 100%; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | @keyframes ani-width { | ||||||
|  |   70% { | ||||||
|  |     width: 100%; | ||||||
|  |   } | ||||||
|  |   100% { | ||||||
|  |     width: 100%; | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										38
									
								
								lib/components/decoration4/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								lib/components/decoration4/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,38 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-decoration-4" :ref="ref"> | ||||||
|  |     <div | ||||||
|  |       :class="`container ${reverse ? 'reverse' : 'normal'}`" | ||||||
|  |       :style="reverse ? `width:${width}px;height:5px` : `width:5px;height:${height}px;`" | ||||||
|  |     > | ||||||
|  |       <svg :width="reverse ? width : 5" :height="reverse ? 5 : height"> | ||||||
|  |         <polyline | ||||||
|  |           stroke="rgba(255, 255, 255, 0.3)" | ||||||
|  |           :points="reverse ? `0, 2.5 ${width}, 2.5` : `2.5, 0 2.5, ${height}`" | ||||||
|  |         /> | ||||||
|  |         <polyline | ||||||
|  |           class="bold-line" | ||||||
|  |           stroke="rgba(255, 255, 255, 0.3)" | ||||||
|  |           stroke-width="3" | ||||||
|  |           stroke-dasharray="20, 80" | ||||||
|  |           stroke-dashoffset="-30" | ||||||
|  |           :points="reverse ? `0, 2.5 ${width}, 2.5` : `2.5, 0 2.5, ${height}`" | ||||||
|  |         /> | ||||||
|  |       </svg> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import autoResize from '../../../mixin/autoResize' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvDecoration4', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   props: ['reverse'], | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       ref: 'decoration-4' | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/decoration5/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/decoration5/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import Decoration5 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(Decoration5.name, Decoration5) | ||||||
|  | } | ||||||
							
								
								
									
										4
									
								
								lib/components/decoration5/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								lib/components/decoration5/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | .dv-decoration-5 { | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
							
								
								
									
										103
									
								
								lib/components/decoration5/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										103
									
								
								lib/components/decoration5/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,103 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-decoration-5" :ref="ref"> | ||||||
|  |     <svg :width="width" :height="height"> | ||||||
|  |       <polyline | ||||||
|  |         fill="transparent" | ||||||
|  |         stroke="#3f96a5" | ||||||
|  |         stroke-width="3" | ||||||
|  |         :points="line1Points" | ||||||
|  |       > | ||||||
|  |         <animate | ||||||
|  |           attributeName="stroke-dasharray" | ||||||
|  |           attributeType="XML" | ||||||
|  |           :from="`0, ${line1Length / 2}, 0, ${line1Length / 2}`" | ||||||
|  |           :to="`0, 0, ${line1Length}, 0`" | ||||||
|  |           dur="1.2s" | ||||||
|  |           begin="0s" | ||||||
|  |           calcMode="spline" | ||||||
|  |           keyTimes="0;1" | ||||||
|  |           keySplines="0.4,1,0.49,0.98" | ||||||
|  |           repeatCount="indefinite" | ||||||
|  |         /> | ||||||
|  |       </polyline> | ||||||
|  |       <polyline | ||||||
|  |         fill="transparent" | ||||||
|  |         stroke="#3f96a5" | ||||||
|  |         stroke-width="2" | ||||||
|  |         :points="line2Points" | ||||||
|  |       > | ||||||
|  |         <animate | ||||||
|  |           attributeName="stroke-dasharray" | ||||||
|  |           attributeType="XML" | ||||||
|  |           :from="`0, ${line2Length / 2}, 0, ${line2Length / 2}`" | ||||||
|  |           :to="`0, 0, ${line2Length}, 0`" | ||||||
|  |           dur="1.2s" | ||||||
|  |           begin="0s" | ||||||
|  |           calcMode="spline" | ||||||
|  |           keyTimes="0;1" | ||||||
|  |           keySplines=".4,1,.49,.98" | ||||||
|  |           repeatCount="indefinite" | ||||||
|  |         /> | ||||||
|  |       </polyline> | ||||||
|  |     </svg> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import autoResize from '../../../mixin/autoResize' | ||||||
|  |  | ||||||
|  | import { getPolylineLength } from '@jiaminghi/charts/lib/util' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvDecoration5', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       ref: 'decoration-5', | ||||||
|  |  | ||||||
|  |       line1Points: '', | ||||||
|  |       line2Points: '', | ||||||
|  |  | ||||||
|  |       line1Length: 0, | ||||||
|  |       line2Length: 0 | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     afterAutoResizeMixinInit () { | ||||||
|  |       const { calcSVGData } = this | ||||||
|  |  | ||||||
|  |       calcSVGData() | ||||||
|  |     }, | ||||||
|  |     calcSVGData () { | ||||||
|  |       const { width, height } = this | ||||||
|  |  | ||||||
|  |       let line1Points = [ | ||||||
|  |         [0, height * 0.2], [width * 0.18, height * 0.2], [width * 0.2, height * 0.4], [width * 0.25, height * 0.4], | ||||||
|  |         [width * 0.27, height * 0.6], [width * 0.72, height * 0.6], [width * 0.75, height * 0.4], | ||||||
|  |         [width * 0.8, height * 0.4], [width * 0.82, height * 0.2], [width, height * 0.2] | ||||||
|  |       ] | ||||||
|  |  | ||||||
|  |       let line2Points = [ | ||||||
|  |         [width * 0.3, height * 0.8], [width * 0.7, height * 0.8] | ||||||
|  |       ] | ||||||
|  |  | ||||||
|  |       const line1Length = getPolylineLength(line1Points) | ||||||
|  |       const line2Length = getPolylineLength(line2Points) | ||||||
|  |  | ||||||
|  |       line1Points = line1Points.map(point => point.join(',')).join(' ') | ||||||
|  |       line2Points = line2Points.map(point => point.join(',')).join(' ') | ||||||
|  |  | ||||||
|  |       this.line1Points = line1Points | ||||||
|  |       this.line2Points = line2Points | ||||||
|  |  | ||||||
|  |       this.line1Length = line1Length | ||||||
|  |       this.line2Length = line2Length | ||||||
|  |     }, | ||||||
|  |     onResize () { | ||||||
|  |       const { calcSVGData } = this | ||||||
|  |  | ||||||
|  |       calcSVGData() | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/decoration6/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/decoration6/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import Decoration6 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(Decoration6.name, Decoration6) | ||||||
|  | } | ||||||
							
								
								
									
										7
									
								
								lib/components/decoration6/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								lib/components/decoration6/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | .dv-decoration-6 { | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .dv-decoration-6 svg { | ||||||
|  |   transform-origin: left top; | ||||||
|  | } | ||||||
							
								
								
									
										122
									
								
								lib/components/decoration6/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										122
									
								
								lib/components/decoration6/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,122 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-decoration-6" :ref="ref"> | ||||||
|  |     <svg :width="`${svgWH[0]}px`" :height="`${svgWH[1]}px`" :style="`transform:scale(${svgScale[0]},${svgScale[1]});`"> | ||||||
|  |       <template | ||||||
|  |         v-for="(point, i) in points" | ||||||
|  |       > | ||||||
|  |         <rect | ||||||
|  |           :key="i" | ||||||
|  |           fill="#7acaec" | ||||||
|  |           :x="point[0] - halfRectWidth" | ||||||
|  |           :y="point[1] - heights[i] / 2" | ||||||
|  |           :width="rectWidth" | ||||||
|  |           :height="heights[i]" | ||||||
|  |         > | ||||||
|  |           <animate | ||||||
|  |             attributeName="y" | ||||||
|  |             :values="`${point[1] - minHeights[i] / 2};${point[1] - heights[i] / 2};${point[1] - minHeights[i] / 2}`" | ||||||
|  |             :dur="`${randoms[i]}s`" | ||||||
|  |             keyTimes="0;0.5;1" | ||||||
|  |             calcMode="spline" | ||||||
|  |             keySplines="0.42,0,0.58,1;0.42,0,0.58,1" | ||||||
|  |             begin="0s" | ||||||
|  |             repeatCount="indefinite" | ||||||
|  |           /> | ||||||
|  |           <animate | ||||||
|  |             attributeName="height" | ||||||
|  |             :values="`${minHeights[i]};${heights[i]};${minHeights[i]}`" | ||||||
|  |             :dur="`${randoms[i]}s`" | ||||||
|  |             keyTimes="0;0.5;1" | ||||||
|  |             calcMode="spline" | ||||||
|  |             keySplines="0.42,0,0.58,1;0.42,0,0.58,1" | ||||||
|  |             begin="0s" | ||||||
|  |             repeatCount="indefinite" | ||||||
|  |           /> | ||||||
|  |         </rect> | ||||||
|  |       </template> | ||||||
|  |     </svg> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import autoResize from '../../../mixin/autoResize' | ||||||
|  |  | ||||||
|  | import { randomExtend } from '../../../util' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvDecoration6', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   data () { | ||||||
|  |     const rectWidth = 7 | ||||||
|  |  | ||||||
|  |     return { | ||||||
|  |       ref: 'decoration-6', | ||||||
|  |  | ||||||
|  |       svgWH: [300, 35], | ||||||
|  |  | ||||||
|  |       svgScale: [1, 1], | ||||||
|  |  | ||||||
|  |       rowNum: 1, | ||||||
|  |       rowPoints: 40, | ||||||
|  |  | ||||||
|  |       rectWidth, | ||||||
|  |       halfRectWidth: rectWidth / 2, | ||||||
|  |  | ||||||
|  |       points: [], | ||||||
|  |       heights: [], | ||||||
|  |       minHeights: [], | ||||||
|  |       randoms: [] | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     afterAutoResizeMixinInit () { | ||||||
|  |       const { calcSVGData } = this | ||||||
|  |  | ||||||
|  |       calcSVGData() | ||||||
|  |     }, | ||||||
|  |     calcSVGData () { | ||||||
|  |       const { calcPointsPosition, calcScale } = this | ||||||
|  |  | ||||||
|  |       calcPointsPosition() | ||||||
|  |  | ||||||
|  |       calcScale() | ||||||
|  |     }, | ||||||
|  |     calcPointsPosition () { | ||||||
|  |       const { svgWH, rowNum, rowPoints } = this | ||||||
|  |  | ||||||
|  |       const [w, h] = svgWH | ||||||
|  |  | ||||||
|  |       const horizontalGap = w / (rowPoints + 1) | ||||||
|  |       const verticalGap = h / (rowNum + 1) | ||||||
|  |  | ||||||
|  |       let points = new Array(rowNum).fill(0).map((foo, i) => | ||||||
|  |         new Array(rowPoints).fill(0).map((foo, j) => [ | ||||||
|  |           horizontalGap * (j + 1), verticalGap * (i + 1) | ||||||
|  |         ])) | ||||||
|  |  | ||||||
|  |       this.points = points.reduce((all, item) => [...all, ...item], []) | ||||||
|  |       const heights = this.heights = new Array(rowNum * rowPoints) | ||||||
|  |         .fill(0).map(foo => | ||||||
|  |           Math.random() > 0.8 ? randomExtend(0.7 * h, h) : randomExtend(0.2 * h, 0.5 * h)) | ||||||
|  |  | ||||||
|  |       this.minHeights = new Array(rowNum * rowPoints) | ||||||
|  |         .fill(0).map((foo, i) => heights[i] * Math.random()) | ||||||
|  |  | ||||||
|  |       this.randoms = new Array(rowNum * rowPoints) | ||||||
|  |         .fill(0).map(foo => Math.random() + 1.5) | ||||||
|  |     }, | ||||||
|  |     calcScale () { | ||||||
|  |       const { width, height, svgWH } = this | ||||||
|  |  | ||||||
|  |       const [w, h] = svgWH | ||||||
|  |  | ||||||
|  |       this.svgScale = [width / w, height / h] | ||||||
|  |     }, | ||||||
|  |     onResize () { | ||||||
|  |       const { calcSVGData } = this | ||||||
|  |  | ||||||
|  |       calcSVGData() | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/decoration7/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/decoration7/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import Decoration7 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(Decoration7.name, Decoration7) | ||||||
|  | } | ||||||
							
								
								
									
										7
									
								
								lib/components/decoration7/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								lib/components/decoration7/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | .dv-decoration-7 { | ||||||
|  |   display: flex; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  |   justify-content: center; | ||||||
|  |   align-items: center; | ||||||
|  | } | ||||||
							
								
								
									
										39
									
								
								lib/components/decoration7/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								lib/components/decoration7/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,39 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-decoration-7"> | ||||||
|  |     <svg width="21px" height="20px"> | ||||||
|  |       <polyline | ||||||
|  |         stroke-width="4" | ||||||
|  |         fill="transparent" | ||||||
|  |         stroke="#1dc1f5" | ||||||
|  |         points="10, 0 19, 10 10, 20" | ||||||
|  |       /> | ||||||
|  |       <polyline | ||||||
|  |         stroke-width="2" | ||||||
|  |         fill="transparent" | ||||||
|  |         stroke="#1dc1f5" | ||||||
|  |         points="2, 0 11, 10 2, 20" | ||||||
|  |       /> | ||||||
|  |     </svg> | ||||||
|  |     <slot></slot> | ||||||
|  |     <svg width="21px" height="20px"> | ||||||
|  |       <polyline | ||||||
|  |         stroke-width="4" | ||||||
|  |         fill="transparent" | ||||||
|  |         stroke="#1dc1f5" | ||||||
|  |         points="11, 0 2, 10 11, 20" | ||||||
|  |       /> | ||||||
|  |       <polyline | ||||||
|  |         stroke-width="2" | ||||||
|  |         fill="transparent" | ||||||
|  |         stroke="#1dc1f5" | ||||||
|  |         points="19, 0 10, 10 19, 20" | ||||||
|  |       /> | ||||||
|  |     </svg> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | export default { | ||||||
|  |   name: 'DvDecoration7' | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/decoration8/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/decoration8/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import Decoration8 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(Decoration8.name, Decoration8) | ||||||
|  | } | ||||||
							
								
								
									
										5
									
								
								lib/components/decoration8/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								lib/components/decoration8/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | .dv-decoration-8 { | ||||||
|  |   display: flex; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
							
								
								
									
										55
									
								
								lib/components/decoration8/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								lib/components/decoration8/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,55 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-decoration-8" :ref="ref"> | ||||||
|  |     <svg :width="width" :height="height"> | ||||||
|  |       <polyline | ||||||
|  |         stroke="#3f96a5" | ||||||
|  |         stroke-width="2" | ||||||
|  |         fill="transparent" | ||||||
|  |         :points="`${xPos(0)}, 0 ${xPos(30)}, ${height / 2}`" | ||||||
|  |       /> | ||||||
|  |  | ||||||
|  |       <polyline | ||||||
|  |         stroke="#3f96a5" | ||||||
|  |         stroke-width="2" | ||||||
|  |         fill="transparent" | ||||||
|  |         :points="`${xPos(20)}, 0 ${xPos(50)}, ${height / 2} ${xPos(width)}, ${height / 2}`" | ||||||
|  |       /> | ||||||
|  |  | ||||||
|  |       <polyline | ||||||
|  |         stroke="#3f96a5" | ||||||
|  |         fill="transparent" | ||||||
|  |         stroke-width="3" | ||||||
|  |         :points="`${xPos(0)}, ${height - 3}, ${xPos(200)}, ${height - 3}`" | ||||||
|  |       /> | ||||||
|  |     </svg> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import autoResize from '../../../mixin/autoResize' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvDecoration8', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   props: { | ||||||
|  |     reverse: { | ||||||
|  |       type: Boolean, | ||||||
|  |       default: false | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       ref: 'decoration-8' | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     xPos (pos) { | ||||||
|  |       const { reverse, width } = this | ||||||
|  |  | ||||||
|  |       if (!reverse) return pos | ||||||
|  |  | ||||||
|  |       return width - pos | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/decoration9/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/decoration9/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import Decoration9 from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(Decoration9.name, Decoration9) | ||||||
|  | } | ||||||
							
								
								
									
										14
									
								
								lib/components/decoration9/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								lib/components/decoration9/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | .dv-decoration-9 { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  |   display: flex; | ||||||
|  |   align-items: center; | ||||||
|  |   justify-content: center; | ||||||
|  | } | ||||||
|  | .dv-decoration-9 svg { | ||||||
|  |   position: absolute; | ||||||
|  |   left: 0px; | ||||||
|  |   top: 0px; | ||||||
|  |   transform-origin: left top; | ||||||
|  | } | ||||||
							
								
								
									
										123
									
								
								lib/components/decoration9/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										123
									
								
								lib/components/decoration9/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,123 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-decoration-9" :ref="ref"> | ||||||
|  |     <svg :width="`${svgWH[0]}px`" :height="`${svgWH[1]}px`" :style="`transform:scale(${svgScale[0]},${svgScale[1]});`"> | ||||||
|  |       <defs> | ||||||
|  |         <polygon :id="polygonId" points="15, 46.5, 21, 47.5, 21, 52.5, 15, 53.5" /> | ||||||
|  |       </defs> | ||||||
|  |  | ||||||
|  |       <circle | ||||||
|  |         cx="50" | ||||||
|  |         cy="50" | ||||||
|  |         r="45" | ||||||
|  |         fill="transparent" | ||||||
|  |         stroke="rgba(3, 166, 224, 0.5)" | ||||||
|  |         stroke-width="10" | ||||||
|  |         stroke-dasharray="80, 100, 30, 100" | ||||||
|  |       > | ||||||
|  |         <animateTransform | ||||||
|  |           attributeName="transform" | ||||||
|  |           type="rotate" | ||||||
|  |           values="0 50 50;360 50 50" | ||||||
|  |           dur="3s" | ||||||
|  |           repeatCount="indefinite" | ||||||
|  |         /> | ||||||
|  |       </circle> | ||||||
|  |  | ||||||
|  |       <circle | ||||||
|  |         cx="50" | ||||||
|  |         cy="50" | ||||||
|  |         r="45" | ||||||
|  |         fill="transparent" | ||||||
|  |         stroke="rgba(3, 166, 224, 0.8)" | ||||||
|  |         stroke-width="6" | ||||||
|  |         stroke-dasharray="50, 66, 100, 66" | ||||||
|  |       > | ||||||
|  |         <animateTransform | ||||||
|  |           attributeName="transform" | ||||||
|  |           type="rotate" | ||||||
|  |           values="0 50 50;-360 50 50" | ||||||
|  |           dur="3s" | ||||||
|  |           repeatCount="indefinite" | ||||||
|  |         /> | ||||||
|  |       </circle> | ||||||
|  |  | ||||||
|  |       <circle | ||||||
|  |         cx="50" | ||||||
|  |         cy="50" | ||||||
|  |         r="38" | ||||||
|  |         fill="transparent" | ||||||
|  |         stroke="rgba(3, 166, 224, 0.2)" | ||||||
|  |         stroke-width="1" | ||||||
|  |         stroke-dasharray="5, 1" | ||||||
|  |       /> | ||||||
|  |  | ||||||
|  |       <use | ||||||
|  |         v-for="(foo, i) in new Array(20).fill(0)" | ||||||
|  |         :key="i" | ||||||
|  |         :xlink:href="`#${polygonId}`" | ||||||
|  |         stroke="rgba(3, 166, 224, 0.6)" | ||||||
|  |         :fill="Math.random() > 0.4 ? 'transparent' : 'rgba(3, 166, 224, 0.8)'" | ||||||
|  |       > | ||||||
|  |         <animateTransform | ||||||
|  |           attributeName="transform" | ||||||
|  |           type="rotate" | ||||||
|  |           values="0 50 50;360 50 50" | ||||||
|  |           dur="3s" | ||||||
|  |           :begin="`${i * 0.15}s`" | ||||||
|  |           repeatCount="indefinite" | ||||||
|  |         /> | ||||||
|  |       </use> | ||||||
|  |  | ||||||
|  |       <circle | ||||||
|  |         cx="50" | ||||||
|  |         cy="50" | ||||||
|  |         r="26" | ||||||
|  |         fill="transparent" | ||||||
|  |         stroke="rgba(3, 166, 224, 0.2)" | ||||||
|  |         stroke-width="1" | ||||||
|  |         stroke-dasharray="5, 1" | ||||||
|  |       /> | ||||||
|  |     </svg> | ||||||
|  |  | ||||||
|  |     <slot></slot> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import autoResize from '../../../mixin/autoResize' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvDecoration9', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       ref: 'decoration-9', | ||||||
|  |  | ||||||
|  |       polygonId: `decoration-9-polygon-${(new Date()).getTime()}`, | ||||||
|  |  | ||||||
|  |       svgWH: [100, 100], | ||||||
|  |  | ||||||
|  |       svgScale: [1, 1] | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     afterAutoResizeMixinInit () { | ||||||
|  |       const { calcScale } = this | ||||||
|  |  | ||||||
|  |       calcScale() | ||||||
|  |     }, | ||||||
|  |     calcScale () { | ||||||
|  |       const { width, height, svgWH } = this | ||||||
|  |  | ||||||
|  |       const [w, h] = svgWH | ||||||
|  |  | ||||||
|  |       this.svgScale = [width / w, height / h] | ||||||
|  |     }, | ||||||
|  |     onResize () { | ||||||
|  |       const { calcScale } = this | ||||||
|  |  | ||||||
|  |       calcScale() | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/digitalFlop/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/digitalFlop/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import DigitalFlop from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(DigitalFlop.name, DigitalFlop) | ||||||
|  | } | ||||||
							
								
								
									
										4
									
								
								lib/components/digitalFlop/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								lib/components/digitalFlop/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | .dv-digital-flop canvas { | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
							
								
								
									
										184
									
								
								lib/components/digitalFlop/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										184
									
								
								lib/components/digitalFlop/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,184 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="dv-digital-flop"> | ||||||
|  |     <canvas ref="digital-flop" /> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import CRender from '@jiaminghi/c-render' | ||||||
|  |  | ||||||
|  | import '@jiaminghi/charts/lib/extend/index' | ||||||
|  |  | ||||||
|  | import { deepMerge } from '@jiaminghi/charts/lib/util/index' | ||||||
|  |  | ||||||
|  | import { deepClone } from '@jiaminghi/c-render/lib/plugin/util' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvDigitalFlop', | ||||||
|  |   props: { | ||||||
|  |     config: { | ||||||
|  |       type: Object, | ||||||
|  |       default: () => ({}) | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       renderer: null, | ||||||
|  |  | ||||||
|  |       defaultConfig: { | ||||||
|  |         /** | ||||||
|  |          * @description Number for digital flop | ||||||
|  |          * @type {Array<Number>} | ||||||
|  |          * @default number = [] | ||||||
|  |          * @example number = [10] | ||||||
|  |          */ | ||||||
|  |         number: [], | ||||||
|  |         /** | ||||||
|  |          * @description Content formatter | ||||||
|  |          * @type {String} | ||||||
|  |          * @default content = '' | ||||||
|  |          * @example content = '{nt}个' | ||||||
|  |          */ | ||||||
|  |         content: '', | ||||||
|  |         /** | ||||||
|  |          * @description Number toFixed | ||||||
|  |          * @type {Number} | ||||||
|  |          * @default toFixed = 0 | ||||||
|  |          */ | ||||||
|  |         toFixed: 0, | ||||||
|  |         /** | ||||||
|  |          * @description Text align | ||||||
|  |          * @type {String} | ||||||
|  |          * @default textAlign = 'center' | ||||||
|  |          * @example textAlign = 'center' | 'left' | 'right' | ||||||
|  |          */ | ||||||
|  |         textAlign: 'center', | ||||||
|  |         /** | ||||||
|  |          * @description Text style configuration | ||||||
|  |          * @type {Object} {CRender Class Style} | ||||||
|  |          */ | ||||||
|  |         style: { | ||||||
|  |           fontSize: 30, | ||||||
|  |           fill: '#3de7c9' | ||||||
|  |         }, | ||||||
|  |         /** | ||||||
|  |          * @description CRender animationCurve | ||||||
|  |          * @type {String} | ||||||
|  |          * @default animationCurve = 'easeOutCubic' | ||||||
|  |          */ | ||||||
|  |         animationCurve: 'easeOutCubic', | ||||||
|  |         /** | ||||||
|  |          * @description CRender animationFrame | ||||||
|  |          * @type {String} | ||||||
|  |          * @default animationFrame = 50 | ||||||
|  |          */ | ||||||
|  |         animationFrame: 50 | ||||||
|  |       }, | ||||||
|  |  | ||||||
|  |       mergedConfig: null, | ||||||
|  |  | ||||||
|  |       graph: null | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   watch: { | ||||||
|  |     config () { | ||||||
|  |       const { update } = this | ||||||
|  |  | ||||||
|  |       update() | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     init () { | ||||||
|  |       const { initRender, mergeConfig, initGraph } = this | ||||||
|  |  | ||||||
|  |       initRender() | ||||||
|  |  | ||||||
|  |       mergeConfig() | ||||||
|  |  | ||||||
|  |       initGraph() | ||||||
|  |     }, | ||||||
|  |     initRender () { | ||||||
|  |       const { $refs } = this | ||||||
|  |  | ||||||
|  |       this.renderer = new CRender($refs['digital-flop']) | ||||||
|  |     }, | ||||||
|  |     mergeConfig () { | ||||||
|  |       const { defaultConfig, config } = this | ||||||
|  |  | ||||||
|  |       this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {}) | ||||||
|  |     }, | ||||||
|  |     initGraph () { | ||||||
|  |       const { getShape, getStyle, renderer, mergedConfig } = this | ||||||
|  |  | ||||||
|  |       const { animationCurve, animationFrame } = mergedConfig | ||||||
|  |  | ||||||
|  |       const shape = getShape() | ||||||
|  |       const style = getStyle() | ||||||
|  |  | ||||||
|  |       this.graph = renderer.add({ | ||||||
|  |         name: 'numberText', | ||||||
|  |         animationCurve, | ||||||
|  |         animationFrame, | ||||||
|  |         shape, | ||||||
|  |         style | ||||||
|  |       }) | ||||||
|  |     }, | ||||||
|  |     getShape () { | ||||||
|  |       const { number, content, toFixed, textAlign } = this.mergedConfig | ||||||
|  |  | ||||||
|  |       const [w, h] = this.renderer.area | ||||||
|  |  | ||||||
|  |       const position = [w / 2, h / 2] | ||||||
|  |  | ||||||
|  |       if (textAlign === 'left') position[0] = 0 | ||||||
|  |       if (textAlign === 'right') position[0] = w | ||||||
|  |  | ||||||
|  |       return { | ||||||
|  |         number, | ||||||
|  |         content, | ||||||
|  |         toFixed, | ||||||
|  |         position | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     getStyle () { | ||||||
|  |       const { style, textAlign } = this.mergedConfig | ||||||
|  |  | ||||||
|  |       return deepMerge(style, { | ||||||
|  |         textAlign, | ||||||
|  |         textBaseline: 'middle' | ||||||
|  |       }) | ||||||
|  |     }, | ||||||
|  |     update () { | ||||||
|  |       const { mergeConfig, mergeShape, getShape, getStyle, graph, mergedConfig } = this | ||||||
|  |  | ||||||
|  |       mergeConfig() | ||||||
|  |  | ||||||
|  |       if (!graph) return | ||||||
|  |  | ||||||
|  |       const { animationCurve, animationFrame } = mergedConfig | ||||||
|  |  | ||||||
|  |       const shape = getShape() | ||||||
|  |       const style = getStyle() | ||||||
|  |  | ||||||
|  |       mergeShape(graph, shape) | ||||||
|  |  | ||||||
|  |       graph.animationCurve = animationCurve | ||||||
|  |       graph.animationFrame = animationFrame | ||||||
|  |  | ||||||
|  |       graph.animation('style', style, true) | ||||||
|  |       graph.animation('shape', shape) | ||||||
|  |     }, | ||||||
|  |     mergeShape (graph, shape) { | ||||||
|  |       const cacheNum = graph.shape.number.length | ||||||
|  |       const shapeNum = shape.number.length | ||||||
|  |  | ||||||
|  |       if (cacheNum !== shapeNum) graph.shape.number = shape.number | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   mounted () { | ||||||
|  |     const { init } = this | ||||||
|  |  | ||||||
|  |     init() | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/flylineChart/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/flylineChart/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import FlylineChart from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(FlylineChart.name, FlylineChart) | ||||||
|  | } | ||||||
							
								
								
									
										12
									
								
								lib/components/flylineChart/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								lib/components/flylineChart/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | |||||||
|  | .dv-flyline-chart { | ||||||
|  |   display: flex; | ||||||
|  |   flex-direction: column; | ||||||
|  |   background-size: 100% 100%; | ||||||
|  | } | ||||||
|  | .dv-flyline-chart polyline { | ||||||
|  |   transition: all 0.3s; | ||||||
|  | } | ||||||
|  | .dv-flyline-chart text { | ||||||
|  |   text-anchor: middle; | ||||||
|  |   dominant-baseline: middle; | ||||||
|  | } | ||||||
							
								
								
									
										492
									
								
								lib/components/flylineChart/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										492
									
								
								lib/components/flylineChart/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,492 @@ | |||||||
|  | <template> | ||||||
|  |   <div | ||||||
|  |     class="dv-flyline-chart" | ||||||
|  |     ref="dv-flyline-chart" | ||||||
|  |     :style="`background-image: url(${mergedConfig ? mergedConfig.bgImgUrl : ''})`" | ||||||
|  |     @click="consoleClickPos" | ||||||
|  |   > | ||||||
|  |     <svg v-if="mergedConfig" :width="width" :height="height"> | ||||||
|  |       <defs> | ||||||
|  |         <radialGradient | ||||||
|  |           :id="gradientId" | ||||||
|  |           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="gradient2Id" | ||||||
|  |           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> | ||||||
|  |  | ||||||
|  |         <circle | ||||||
|  |           v-if="paths[0]" | ||||||
|  |           :id="`circle${paths[0].toString()}`" | ||||||
|  |           :cx="paths[0][2][0]" | ||||||
|  |           :cy="paths[0][2][1]" | ||||||
|  |         > | ||||||
|  |           <animate | ||||||
|  |             attributeName="r" | ||||||
|  |             :values="`1;${mergedConfig.halo.radius}`" | ||||||
|  |             :dur="mergedConfig.halo.duration / 10 + 's'" | ||||||
|  |             repeatCount="indefinite" | ||||||
|  |           /> | ||||||
|  |           <animate | ||||||
|  |             attributeName="opacity" | ||||||
|  |             values="1;0" | ||||||
|  |             :dur="mergedConfig.halo.duration / 10 + 's'" | ||||||
|  |             repeatCount="indefinite" | ||||||
|  |           /> | ||||||
|  |         </circle> | ||||||
|  |       </defs> | ||||||
|  |  | ||||||
|  |       <image | ||||||
|  |         v-if="paths[0]" | ||||||
|  |         :xlink:href="mergedConfig.centerPointImg.url" | ||||||
|  |         :width="mergedConfig.centerPointImg.width" | ||||||
|  |         :height="mergedConfig.centerPointImg.height" | ||||||
|  |         :x="paths[0][2][0] - mergedConfig.centerPointImg.width / 2" | ||||||
|  |         :y="paths[0][2][1] - mergedConfig.centerPointImg.height / 2" | ||||||
|  |       /> | ||||||
|  |  | ||||||
|  |       <mask :id="`maskhalo${paths[0].toString()}`"> | ||||||
|  |         <use | ||||||
|  |           v-if="paths[0]" | ||||||
|  |           :xlink:href="`#circle${paths[0].toString()}`" | ||||||
|  |           :fill="`url(#${gradient2Id})`" | ||||||
|  |         /> | ||||||
|  |       </mask> | ||||||
|  |  | ||||||
|  |       <use | ||||||
|  |         v-if="paths[0] && mergedConfig.halo.show" | ||||||
|  |         :xlink:href="`#circle${paths[0].toString()}`" | ||||||
|  |         :fill="mergedConfig.halo.color" | ||||||
|  |         :mask="`url(#maskhalo${paths[0].toString()})`" | ||||||
|  |       /> | ||||||
|  |  | ||||||
|  |       <g | ||||||
|  |         v-for="(path, i) in paths" | ||||||
|  |         :key="i" | ||||||
|  |       > | ||||||
|  |         <defs> | ||||||
|  |           <path | ||||||
|  |             :id="`path${path.toString()}`" | ||||||
|  |             :ref="`path${i}`" | ||||||
|  |             :d="`M${path[0].toString()} Q${path[1].toString()} ${path[2].toString()}`" | ||||||
|  |             fill="transparent" | ||||||
|  |           /> | ||||||
|  |         </defs> | ||||||
|  |  | ||||||
|  |         <use | ||||||
|  |           :xlink:href="`#path${path.toString()}`" | ||||||
|  |           :stroke-width="mergedConfig.lineWidth" | ||||||
|  |           :stroke="mergedConfig.orbitColor" | ||||||
|  |         /> | ||||||
|  |  | ||||||
|  |         <use | ||||||
|  |           v-if="lengths[i]" | ||||||
|  |           :xlink:href="`#path${path.toString()}`" | ||||||
|  |           :stroke-width="mergedConfig.lineWidth" | ||||||
|  |           :stroke="mergedConfig.flylineColor" | ||||||
|  |           :mask="`url(#mask${unique}${path.toString()})`" | ||||||
|  |         > | ||||||
|  |           <animate | ||||||
|  |             attributeName="stroke-dasharray" | ||||||
|  |             :from="`0, ${lengths[i]}`" | ||||||
|  |             :to="`${lengths[i]}, 0`" | ||||||
|  |             :dur="times[i] || 0" | ||||||
|  |             repeatCount="indefinite" | ||||||
|  |           /> | ||||||
|  |         </use> | ||||||
|  |  | ||||||
|  |         <mask :id="`mask${unique}${path.toString()}`"> | ||||||
|  |           <circle cx="0" cy="0" :r="mergedConfig.flylineRadius" :fill="`url(#${gradientId})`"> | ||||||
|  |             <animateMotion | ||||||
|  |               :dur="times[i] || 0" | ||||||
|  |               :path="`M${path[0].toString()} Q${path[1].toString()} ${path[2].toString()}`" | ||||||
|  |               rotate="auto" | ||||||
|  |               repeatCount="indefinite" | ||||||
|  |             /> | ||||||
|  |           </circle> | ||||||
|  |         </mask> | ||||||
|  |  | ||||||
|  |         <image | ||||||
|  |           :xlink:href="mergedConfig.pointsImg.url" | ||||||
|  |           :width="mergedConfig.pointsImg.width" | ||||||
|  |           :height="mergedConfig.pointsImg.height" | ||||||
|  |           :x="path[0][0] - mergedConfig.pointsImg.width / 2" | ||||||
|  |           :y="path[0][1] - mergedConfig.pointsImg.height / 2" | ||||||
|  |         /> | ||||||
|  |  | ||||||
|  |         <text | ||||||
|  |           :style="`fontSize:${mergedConfig.text.fontSize}px;`" | ||||||
|  |           :fill="mergedConfig.text.color" | ||||||
|  |           :x="path[0][0] + mergedConfig.text.offset[0]" | ||||||
|  |           :y="path[0][1] + mergedConfig.text.offset[1]" | ||||||
|  |         > | ||||||
|  |           {{ texts[i] }} | ||||||
|  |         </text> | ||||||
|  |  | ||||||
|  |       </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 } from '../../../util/index' | ||||||
|  |  | ||||||
|  | import autoResize from '../../../mixin/autoResize' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvFlylineChart', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   props: { | ||||||
|  |     config: { | ||||||
|  |       type: Object, | ||||||
|  |       default: () => ({}) | ||||||
|  |     }, | ||||||
|  |     dev: { | ||||||
|  |       type: Boolean, | ||||||
|  |       default: false | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       ref: 'dv-flyline-chart', | ||||||
|  |       unique: Math.random(), | ||||||
|  |       maskId: `flyline-mask-id-${(new Date()).getTime()}`, | ||||||
|  |       maskCircleId: `mask-circle-id-${(new Date()).getTime()}`, | ||||||
|  |       gradientId: `gradient-id-${(new Date()).getTime()}`, | ||||||
|  |       gradient2Id: `gradient2-id-${(new Date()).getTime()}`, | ||||||
|  |  | ||||||
|  |       defaultConfig: { | ||||||
|  |         /** | ||||||
|  |          * @description Flyline chart center point | ||||||
|  |          * @type {Array<Number>} | ||||||
|  |          * @default centerPoint = [0, 0] | ||||||
|  |          */ | ||||||
|  |         centerPoint: [0, 0], | ||||||
|  |         /** | ||||||
|  |          * @description Flyline start points | ||||||
|  |          * @type {Array<Array<Number>>} | ||||||
|  |          * @default points = [] | ||||||
|  |          * @example points = [[10, 10], [100, 100]] | ||||||
|  |          */ | ||||||
|  |         points: [], | ||||||
|  |         /** | ||||||
|  |          * @description Flyline width | ||||||
|  |          * @type {Number} | ||||||
|  |          * @default lineWidth = 1 | ||||||
|  |          */ | ||||||
|  |         lineWidth: 1, | ||||||
|  |         /** | ||||||
|  |          * @description Orbit color | ||||||
|  |          * @type {String} | ||||||
|  |          * @default orbitColor = 'rgba(103, 224, 227, .2)' | ||||||
|  |          */ | ||||||
|  |         orbitColor: 'rgba(103, 224, 227, .2)', | ||||||
|  |         /** | ||||||
|  |          * @description Flyline color | ||||||
|  |          * @type {String} | ||||||
|  |          * @default orbitColor = '#ffde93' | ||||||
|  |          */ | ||||||
|  |         flylineColor: '#ffde93', | ||||||
|  |         /** | ||||||
|  |          * @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 Flyline radius | ||||||
|  |          * @type {Number} | ||||||
|  |          * @default flylineRadius = 100 | ||||||
|  |          */ | ||||||
|  |         flylineRadius: 100, | ||||||
|  |         /** | ||||||
|  |          * @description Flyline animation duration | ||||||
|  |          * @type {Array<Number>} | ||||||
|  |          * @default duration = [20, 30] | ||||||
|  |          */ | ||||||
|  |         duration: [20, 30], | ||||||
|  |         /** | ||||||
|  |          * @description Relative points position | ||||||
|  |          * @type {Boolean} | ||||||
|  |          * @default relative = true | ||||||
|  |          */ | ||||||
|  |         relative: true, | ||||||
|  |         /** | ||||||
|  |          * @description Back ground image url | ||||||
|  |          * @type {String} | ||||||
|  |          * @default bgImgUrl = '' | ||||||
|  |          * @example bgImgUrl = './img/bg.jpg' | ||||||
|  |          */ | ||||||
|  |         bgImgUrl: '', | ||||||
|  |         /** | ||||||
|  |          * @description Text configuration | ||||||
|  |          * @type {Object} | ||||||
|  |          */ | ||||||
|  |         text: { | ||||||
|  |           /** | ||||||
|  |            * @description Text offset | ||||||
|  |            * @type {Array<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 Halo configuration | ||||||
|  |          * @type {Object} | ||||||
|  |          */ | ||||||
|  |         halo: { | ||||||
|  |           /** | ||||||
|  |            * @description Weather to show halo | ||||||
|  |            * @type {Boolean} | ||||||
|  |            * @default show = true | ||||||
|  |            * @example show = true | false | ||||||
|  |            */ | ||||||
|  |           show: true, | ||||||
|  |           /** | ||||||
|  |            * @description Halo animation duration (10 = 1s) | ||||||
|  |            * @type {Number} | ||||||
|  |            * @default duration = 30 | ||||||
|  |            */ | ||||||
|  |           duration: 30, | ||||||
|  |           /** | ||||||
|  |            * @description Halo color | ||||||
|  |            * @type {String} | ||||||
|  |            * @default color = '#fb7293' | ||||||
|  |            */ | ||||||
|  |           color: '#fb7293', | ||||||
|  |           /** | ||||||
|  |            * @description Halo max radius | ||||||
|  |            * @type {Number} | ||||||
|  |            * @default radius = 120 | ||||||
|  |            */ | ||||||
|  |           radius: 120 | ||||||
|  |         }, | ||||||
|  |         /** | ||||||
|  |          * @description Center point img configuration | ||||||
|  |          * @type {Object} | ||||||
|  |          */ | ||||||
|  |         centerPointImg: { | ||||||
|  |           /** | ||||||
|  |            * @description Center point img width | ||||||
|  |            * @type {Number} | ||||||
|  |            * @default width = 40 | ||||||
|  |            */ | ||||||
|  |           width: 40, | ||||||
|  |           /** | ||||||
|  |            * @description Center point img height | ||||||
|  |            * @type {Number} | ||||||
|  |            * @default height = 40 | ||||||
|  |            */ | ||||||
|  |           height: 40, | ||||||
|  |           /** | ||||||
|  |            * @description Center point img url | ||||||
|  |            * @type {String} | ||||||
|  |            * @default url = '' | ||||||
|  |            */ | ||||||
|  |           url: '' | ||||||
|  |         }, | ||||||
|  |         /** | ||||||
|  |          * @description Points img configuration | ||||||
|  |          * @type {Object} | ||||||
|  |          * @default radius = 120 | ||||||
|  |          */ | ||||||
|  |         pointsImg: { | ||||||
|  |           /** | ||||||
|  |            * @description Points img width | ||||||
|  |            * @type {Number} | ||||||
|  |            * @default width = 15 | ||||||
|  |            */ | ||||||
|  |           width: 15, | ||||||
|  |           /** | ||||||
|  |            * @description Points img height | ||||||
|  |            * @type {Number} | ||||||
|  |            * @default height = 15 | ||||||
|  |            */ | ||||||
|  |           height: 15, | ||||||
|  |           /** | ||||||
|  |            * @description Points img url | ||||||
|  |            * @type {String} | ||||||
|  |            * @default url = '' | ||||||
|  |            */ | ||||||
|  |           url: '' | ||||||
|  |         } | ||||||
|  |       }, | ||||||
|  |  | ||||||
|  |       mergedConfig: null, | ||||||
|  |  | ||||||
|  |       paths: [], | ||||||
|  |       lengths: [], | ||||||
|  |       times: [], | ||||||
|  |       texts: [] | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   watch: { | ||||||
|  |     config () { | ||||||
|  |       const { calcData } = this | ||||||
|  |  | ||||||
|  |       calcData() | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     afterAutoResizeMixinInit () { | ||||||
|  |       const { calcData } = this | ||||||
|  |  | ||||||
|  |       calcData() | ||||||
|  |     }, | ||||||
|  |     onResize () { | ||||||
|  |       const { calcData } = this | ||||||
|  |  | ||||||
|  |       calcData() | ||||||
|  |     }, | ||||||
|  |     async calcData () { | ||||||
|  |       const { mergeConfig, createFlylinePaths, calcLineLengths } = this | ||||||
|  |  | ||||||
|  |       mergeConfig() | ||||||
|  |  | ||||||
|  |       createFlylinePaths() | ||||||
|  |  | ||||||
|  |       await calcLineLengths() | ||||||
|  |  | ||||||
|  |       const { calcTimes, calcTexts } = this | ||||||
|  |  | ||||||
|  |       calcTimes() | ||||||
|  |  | ||||||
|  |       calcTexts() | ||||||
|  |     }, | ||||||
|  |     mergeConfig () { | ||||||
|  |       let { config, defaultConfig } = this | ||||||
|  |  | ||||||
|  |       const mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {}) | ||||||
|  |  | ||||||
|  |       const { points } = mergedConfig | ||||||
|  |  | ||||||
|  |       mergedConfig.points = points.map(item => { | ||||||
|  |         if (item instanceof Array) { | ||||||
|  |           return { position: item, text: '' } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return item | ||||||
|  |       }) | ||||||
|  |  | ||||||
|  |       this.mergedConfig = mergedConfig | ||||||
|  |     }, | ||||||
|  |     createFlylinePaths () { | ||||||
|  |       const { getPath, mergedConfig, width, height } = this | ||||||
|  |  | ||||||
|  |       let { centerPoint, points, relative } = mergedConfig | ||||||
|  |  | ||||||
|  |       points = points.map(({ position }) => position) | ||||||
|  |  | ||||||
|  |       if (relative) { | ||||||
|  |         centerPoint = [width * centerPoint[0], height * centerPoint[1]] | ||||||
|  |         points = points.map(([x, y]) => [width * x, height * y]) | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       this.paths = points.map(point => getPath(centerPoint, point)) | ||||||
|  |     }, | ||||||
|  |     getPath (center, point) { | ||||||
|  |       const { getControlPoint } = this | ||||||
|  |  | ||||||
|  |       const controlPoint = getControlPoint(center, point) | ||||||
|  |  | ||||||
|  |       return [point, controlPoint, center] | ||||||
|  |     }, | ||||||
|  |     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, paths, $refs } = this | ||||||
|  |  | ||||||
|  |       await $nextTick() | ||||||
|  |  | ||||||
|  |       this.lengths = paths.map((foo, i) => $refs[`path${i}`][0].getTotalLength()) | ||||||
|  |     }, | ||||||
|  |     calcTimes () { | ||||||
|  |       const { duration, points } = this.mergedConfig | ||||||
|  |  | ||||||
|  |       this.times = points.map(foo => randomExtend(...duration) / 10) | ||||||
|  |     }, | ||||||
|  |     calcTexts () { | ||||||
|  |       const { points } = this.mergedConfig | ||||||
|  |  | ||||||
|  |       this.texts = points.map(({ text }) => text) | ||||||
|  |     }, | ||||||
|  |     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 DEV: \n Click Position is [${offsetX}, ${offsetY}] \n Relative Position is [${relativeX}, ${relativeY}]`) | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										6
									
								
								lib/components/fullScreenContainer/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								lib/components/fullScreenContainer/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import './src/main.css' | ||||||
|  | import FullScreenContainer from './src/main.vue' | ||||||
|  |  | ||||||
|  | export default function (Vue) { | ||||||
|  |   Vue.component(FullScreenContainer.name, FullScreenContainer) | ||||||
|  | } | ||||||
							
								
								
									
										8
									
								
								lib/components/fullScreenContainer/src/main.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								lib/components/fullScreenContainer/src/main.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | |||||||
|  | #dv-full-screen-container { | ||||||
|  |   position: fixed; | ||||||
|  |   top: 0px; | ||||||
|  |   left: 0px; | ||||||
|  |   overflow: hidden; | ||||||
|  |   transform-origin: left top; | ||||||
|  |   z-index: 999; | ||||||
|  | } | ||||||
							
								
								
									
										57
									
								
								lib/components/fullScreenContainer/src/main.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								lib/components/fullScreenContainer/src/main.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,57 @@ | |||||||
|  | <template> | ||||||
|  |   <div id="dv-full-screen-container" :ref="ref"> | ||||||
|  |     <template v-if="ready"> | ||||||
|  |       <slot></slot> | ||||||
|  |     </template> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import autoResize from '../../../mixin/autoResize.js' | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   name: 'DvFullScreenContainer', | ||||||
|  |   mixins: [autoResize], | ||||||
|  |   data () { | ||||||
|  |     return { | ||||||
|  |       ref: 'full-screen-container', | ||||||
|  |       allWidth: 0, | ||||||
|  |       scale: 0, | ||||||
|  |       datavRoot: '', | ||||||
|  |       ready: false | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     afterAutoResizeMixinInit () { | ||||||
|  |       const { initConfig, setAppScale } = this | ||||||
|  |  | ||||||
|  |       initConfig() | ||||||
|  |  | ||||||
|  |       setAppScale() | ||||||
|  |  | ||||||
|  |       this.ready = true | ||||||
|  |     }, | ||||||
|  |     initConfig () { | ||||||
|  |       const { dom } = this | ||||||
|  |       const { width, height } = screen | ||||||
|  |  | ||||||
|  |       this.allWidth = width | ||||||
|  |  | ||||||
|  |       dom.style.width = `${width}px` | ||||||
|  |       dom.style.height = `${height}px` | ||||||
|  |     }, | ||||||
|  |     setAppScale () { | ||||||
|  |       const { allWidth, dom } = this | ||||||
|  |  | ||||||
|  |       const currentWidth = document.body.clientWidth | ||||||
|  |  | ||||||
|  |       dom.style.transform = `scale(${currentWidth / allWidth})` | ||||||
|  |     }, | ||||||
|  |     onResize () { | ||||||
|  |       const { setAppScale } = this | ||||||
|  |  | ||||||
|  |       setAppScale() | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user