2017-08-24 10:16:12 +00:00
|
|
|
<template>
|
|
|
|
<div class="doughnut-chart">
|
|
|
|
<doughnut-chart :data="doughnutChartData" :options="{ legend: { display: false }, maintainAspectRatio: false }"/>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
import DoughnutChart from '~/components/doughnut-chart'
|
|
|
|
import axios from 'axios'
|
|
|
|
|
|
|
|
function getRandomColor() {
|
2018-07-20 15:42:31 +00:00
|
|
|
const letters = '0123456789ABCDEF'
|
|
|
|
let color = '#'
|
|
|
|
for (let i = 0; i < 6; i++) {
|
2017-10-31 13:43:55 +00:00
|
|
|
color += letters[Math.floor(Math.random() * 16)]
|
2017-08-24 10:16:12 +00:00
|
|
|
}
|
2017-10-31 13:43:55 +00:00
|
|
|
return color
|
2017-08-24 10:16:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
export default {
|
|
|
|
async asyncData({ env }) {
|
|
|
|
const res = await axios.get(`https://api.github.com/repos/nuxt/nuxt.js/stats/contributors?access_token=${env.githubToken}`)
|
|
|
|
return {
|
|
|
|
doughnutChartData: {
|
2018-08-06 00:12:44 +00:00
|
|
|
labels: res.data.map(stat => stat.author.login),
|
2017-08-24 10:16:12 +00:00
|
|
|
datasets: [
|
|
|
|
{
|
|
|
|
label: 'Nuxt.js Contributors',
|
2018-07-20 15:42:31 +00:00
|
|
|
backgroundColor: res.data.map(getRandomColor),
|
|
|
|
data: res.data.map(() => 1)
|
2017-08-24 10:16:12 +00:00
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
components: {
|
|
|
|
DoughnutChart
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style scoped>
|
|
|
|
.doughnut-chart {
|
|
|
|
position: fixed;
|
|
|
|
left: 10%;
|
|
|
|
top: 10%;
|
|
|
|
width: 80%;
|
|
|
|
height: 80%;
|
|
|
|
}
|
|
|
|
</style>
|