a1b490afa7
Closes #1411
63 lines
1.3 KiB
Vue
63 lines
1.3 KiB
Vue
<template>
|
|
<div class="mk-activity">
|
|
<svg v-if="data" ref="canvas" viewBox="0 0 30 1" preserveAspectRatio="none">
|
|
<g v-for="(d, i) in data">
|
|
<rect width="0.8" :height="d.notesH"
|
|
:x="i + 0.1" :y="1 - d.notesH - d.repliesH - d.renotesH"
|
|
fill="#41ddde"/>
|
|
<rect width="0.8" :height="d.repliesH"
|
|
:x="i + 0.1" :y="1 - d.repliesH - d.renotesH"
|
|
fill="#f7796c"/>
|
|
<rect width="0.8" :height="d.renotesH"
|
|
:x="i + 0.1" :y="1 - d.renotesH"
|
|
fill="#a1de41"/>
|
|
</g>
|
|
</svg>
|
|
</div>
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import Vue from 'vue';
|
|
export default Vue.extend({
|
|
props: ['user'],
|
|
data() {
|
|
return {
|
|
fetching: true,
|
|
data: [],
|
|
peak: null
|
|
};
|
|
},
|
|
mounted() {
|
|
(this as any).api('aggregation/users/activity', {
|
|
userId: this.user.id,
|
|
limit: 30
|
|
}).then(data => {
|
|
data.forEach(d => d.total = d.notes + d.replies + d.renotes);
|
|
this.peak = Math.max.apply(null, data.map(d => d.total));
|
|
data.forEach(d => {
|
|
d.notesH = d.notes / this.peak;
|
|
d.repliesH = d.replies / this.peak;
|
|
d.renotesH = d.renotes / this.peak;
|
|
});
|
|
data.reverse();
|
|
this.data = data;
|
|
});
|
|
}
|
|
});
|
|
</script>
|
|
|
|
<style lang="stylus" scoped>
|
|
.mk-activity
|
|
max-width 600px
|
|
margin 0 auto
|
|
|
|
> svg
|
|
display block
|
|
width 100%
|
|
height 80px
|
|
|
|
> rect
|
|
transform-origin center
|
|
|
|
</style>
|