2019-08-22 14:41:07 +08:00
|
|
|
<template>
|
2020-04-25 16:46:33 +08:00
|
|
|
<div class="dv-border-box-1" :ref="ref">
|
|
|
|
<svg class="border" :width="width" :height="height">
|
|
|
|
<polygon :fill="backgroundColor" :points="`10, 27 10, ${height - 27} 13, ${height - 24} 13, ${height - 21} 24, ${height - 11}
|
|
|
|
38, ${height - 11} 41, ${height - 8} 73, ${height - 8} 75, ${height - 10} 81, ${height - 10}
|
|
|
|
85, ${height - 6} ${width - 85}, ${height - 6} ${width - 81}, ${height - 10} ${width - 75}, ${height - 10}
|
|
|
|
${width - 73}, ${height - 8} ${width - 41}, ${height - 8} ${width - 38}, ${height - 11}
|
|
|
|
${width - 24}, ${height - 11} ${width - 13}, ${height - 21} ${width - 13}, ${height - 24}
|
|
|
|
${width - 10}, ${height - 27} ${width - 10}, 27 ${width - 13}, 25 ${width - 13}, 21
|
|
|
|
${width - 24}, 11 ${width - 38}, 11 ${width - 41}, 8 ${width - 73}, 8 ${width - 75}, 10
|
|
|
|
${width - 81}, 10 ${width - 85}, 6 85, 6 81, 10 75, 10 73, 8 41, 8 38, 11 24, 11 13, 21 13, 24`" />
|
|
|
|
</svg>
|
|
|
|
|
2019-08-24 13:05:15 +08:00
|
|
|
<svg
|
|
|
|
width="150px"
|
|
|
|
height="150px"
|
|
|
|
:key="item"
|
|
|
|
v-for="item in border"
|
|
|
|
:class="`${item} border`"
|
|
|
|
>
|
2019-08-22 14:41:07 +08:00
|
|
|
<polygon
|
2019-12-06 21:07:16 +08:00
|
|
|
:fill="mergedColor[0]"
|
2019-08-22 14:41:07 +08:00
|
|
|
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"
|
2019-12-06 21:07:16 +08:00
|
|
|
:values="`${mergedColor[0]};${mergedColor[1]};${mergedColor[0]}`"
|
2019-08-23 22:20:40 +08:00
|
|
|
dur="0.5s"
|
2019-08-22 14:41:07 +08:00
|
|
|
begin="0s"
|
|
|
|
repeatCount="indefinite"
|
|
|
|
/>
|
|
|
|
</polygon>
|
|
|
|
<polygon
|
2019-12-06 21:07:16 +08:00
|
|
|
:fill="mergedColor[1]"
|
2019-08-22 14:41:07 +08:00
|
|
|
points="27.599999999999998,4.8 38.4,4.8 35.4,7.8 30.599999999999998,7.8"
|
|
|
|
>
|
|
|
|
<animate
|
|
|
|
attributeName="fill"
|
2019-12-06 21:07:16 +08:00
|
|
|
:values="`${mergedColor[1]};${mergedColor[0]};${mergedColor[1]}`"
|
2019-08-23 22:20:40 +08:00
|
|
|
dur="0.5s"
|
2019-08-22 14:41:07 +08:00
|
|
|
begin="0s"
|
|
|
|
repeatCount="indefinite"
|
|
|
|
/>
|
|
|
|
</polygon>
|
|
|
|
<polygon
|
2019-12-06 21:07:16 +08:00
|
|
|
:fill="mergedColor[0]"
|
2019-08-22 14:41:07 +08:00
|
|
|
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"
|
2019-12-06 21:07:16 +08:00
|
|
|
:values="`${mergedColor[0]};${mergedColor[1]};transparent`"
|
2019-08-22 14:41:07 +08:00
|
|
|
dur="1s"
|
|
|
|
begin="0s"
|
|
|
|
repeatCount="indefinite"
|
|
|
|
/>
|
|
|
|
</polygon>
|
|
|
|
</svg>
|
|
|
|
|
|
|
|
<div class="border-box-content">
|
|
|
|
<slot></slot>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
2020-04-25 16:46:33 +08:00
|
|
|
import autoResize from '../../../mixin/autoResize'
|
|
|
|
|
2019-12-06 21:07:16 +08:00
|
|
|
import { deepMerge } from '@jiaminghi/charts/lib/util/index'
|
|
|
|
|
|
|
|
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util'
|
|
|
|
|
2019-08-22 14:41:07 +08:00
|
|
|
export default {
|
|
|
|
name: 'DvBorderBox1',
|
2020-04-25 16:46:33 +08:00
|
|
|
mixins: [autoResize],
|
2019-12-06 21:07:16 +08:00
|
|
|
props: {
|
|
|
|
color: {
|
|
|
|
type: Array,
|
|
|
|
default: () => ([])
|
2020-04-25 16:46:33 +08:00
|
|
|
},
|
|
|
|
backgroundColor: {
|
|
|
|
type: String,
|
|
|
|
default: 'transparent'
|
2019-12-06 21:07:16 +08:00
|
|
|
}
|
|
|
|
},
|
2019-08-22 14:41:07 +08:00
|
|
|
data () {
|
|
|
|
return {
|
2020-04-25 16:46:33 +08:00
|
|
|
ref: 'border-box-1',
|
|
|
|
|
2019-12-06 21:07:16 +08:00
|
|
|
border: ['left-top', 'right-top', 'left-bottom', 'right-bottom'],
|
|
|
|
|
|
|
|
defaultColor: ['#4fd2dd', '#235fa7'],
|
|
|
|
|
|
|
|
mergedColor: []
|
2019-08-22 14:41:07 +08:00
|
|
|
}
|
2019-12-06 21:07:16 +08:00
|
|
|
},
|
|
|
|
watch: {
|
|
|
|
color () {
|
|
|
|
const { mergeColor } = this
|
|
|
|
|
|
|
|
mergeColor()
|
|
|
|
}
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
mergeColor () {
|
|
|
|
const { color, defaultColor } = this
|
|
|
|
|
|
|
|
this.mergedColor = deepMerge(deepClone(defaultColor, true), color || [])
|
|
|
|
}
|
|
|
|
},
|
|
|
|
mounted () {
|
|
|
|
const { mergeColor } = this
|
|
|
|
|
|
|
|
mergeColor()
|
2019-08-22 14:41:07 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|