dort
Version:
File sharing through web with wonderful alternation.
378 lines (377 loc) • 11.8 kB
HTML
<html lang="en">
<head>
<title>Code coverage report for src/components/Barrage/item.vue</title>
<meta charset="utf-8" />
<link rel="stylesheet" href="../../../prettify.css" />
<link rel="stylesheet" href="../../../base.css" />
<meta name="viewport" content="width=device-width, initial-scale=1">
<style type='text/css'>
.coverage-summary .sorter {
background-image: url(../../../sort-arrow-sprite.png);
}
</style>
</head>
<body>
<div class='wrapper'>
<div class='pad1'>
<h1>
<a href="../../../index.html">all files</a> / <a href="index.html">src/components/Barrage/</a> item.vue
</h1>
<div class='clearfix'>
<div class='fl pad1y space-right2'>
<span class="strong">0% </span>
<span class="quiet">Statements</span>
<span class='fraction'>0/21</span>
</div>
<div class='fl pad1y space-right2'>
<span class="strong">0% </span>
<span class="quiet">Branches</span>
<span class='fraction'>0/4</span>
</div>
<div class='fl pad1y space-right2'>
<span class="strong">0% </span>
<span class="quiet">Functions</span>
<span class='fraction'>0/4</span>
</div>
<div class='fl pad1y space-right2'>
<span class="strong">0% </span>
<span class="quiet">Lines</span>
<span class='fraction'>0/21</span>
</div>
</div>
</div>
<div class='status-line low'></div>
<pre><table class="coverage">
<tr><td class="line-count quiet">1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105</td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js"><template>
<li class="barrage-item"
:style="styles"
:class="[
playing ? 'playing' : '',
played ? 'played' : ''
]">
<span class="content" v-text="barrage.text" :style="{color: barrage.color}"></span>
</li>
</template>
<script>
export default {
name: 'barrage-item',
props: {
id: {
type: Number
},
delay: {
type: Number,
default: 10
},
barrage: {
type: Object,
required: true
}
},
data () {
<span class="cstat-no" title="statement not covered" > return {</span>
// 定时器
timers: {
transform: null,
playing: null
},
// 播放状态
played: false,
playing: false,
styles: {
'z-index': (this.id + 1) * 10,
transition: `transform ${this.delay}s linear`
}
}
},
ready () {
<span class="cstat-no" title="statement not covered" > this.startAnimation(</span>)
},
mounted () {
<span class="cstat-no" title="statement not covered" > this.startAnimation(</span>)
},
beforeDestroy () {
<span class="cstat-no" title="statement not covered" > if (this.timers.transform) {</span>
<span class="cstat-no" title="statement not covered" > clearTimeout(this.timers.transform</span>)
<span class="cstat-no" title="statement not covered" > this.timers.transform = nul</span>l
}
<span class="cstat-no" title="statement not covered" > if (this.timers.playing) {</span>
<span class="cstat-no" title="statement not covered" > clearTimeout(this.timers.playing</span>)
<span class="cstat-no" title="statement not covered" > this.timers.playing = nul</span>l
}
},
methods: {
randomTop () {
// cound height range
const innerHeight <span class="cstat-no" title="statement not covered" >= document.documentElement.clientHeight - 50</span>0
let top <span class="cstat-no" title="statement not covered" >= Math.floor(Math.random() * innerHeight</span>)
<span class="cstat-no" title="statement not covered" > return `${top}px</span>`
},
startAnimation () {
<span class="cstat-no" title="statement not covered" > this.$nextTick(() =<span class="fstat-no" title="function not covered" >> {</span></span>
// 开始动画
<span class="cstat-no" title="statement not covered" > this.timers.transform = setTimeout(() =<span class="fstat-no" title="function not covered" >> {</span></span>
<span class="cstat-no" title="statement not covered" > this.playing = tru</span>e
// 计算出一个随机高度,相对左距
<span class="cstat-no" title="statement not covered" > this.$set(this.styles, 'top', this.randomTop()</span>)
})
// 结束动画
<span class="cstat-no" title="statement not covered" > this.timers.playing = setTimeout(() =<span class="fstat-no" title="function not covered" >> {</span></span>
<span class="cstat-no" title="statement not covered" > this.playing = fals</span>e
<span class="cstat-no" title="statement not covered" > this.played = tru</span>e
<span class="cstat-no" title="statement not covered" > this.$nextTick(() =<span class="fstat-no" title="function not covered" >> {</span></span>
<span class="cstat-no" title="statement not covered" > this.$emit('end', this.id</span>)
})
}, this.delay * 1000)
})
}
}
}
</script>
<style lang="scss" scoped>
.barrage-item {
width: auto;
right: 0px;
display: block;
position: fixed;
transform: translate3d(100%, 0, 0);
&.playing {
transform: translate3d(calc(-100vw - 200%), 0, 0);
}
&.played {
visibility: hidden;
}
}
</style>
</pre></td></tr>
</table></pre>
<div class='push'></div><!-- for sticky footer -->
</div><!-- /wrapper -->
<div class='footer quiet pad2 space-top1 center small'>
Code coverage
generated by <a href="http://istanbul-js.org/" target="_blank">istanbul</a> at Sun Jun 03 2018 23:15:40 GMT+0800 (CST)
</div>
</div>
<script src="../../../prettify.js"></script>
<script>
window.onload = function () {
if (typeof prettyPrint === 'function') {
prettyPrint();
}
};
</script>
<script src="../../../sorter.js"></script>
</body>
</html>