misskey/src/client/app/desktop/views/components/charts.vue

724 lines
19 KiB
Vue
Raw Normal View History

2018-08-23 22:37:19 +02:00
<template>
<div class="gkgckalzgidaygcxnugepioremxvxvpt">
2018-08-23 22:37:19 +02:00
<header>
<b>%i18n:@title%:</b>
<select v-model="chartType">
2018-10-23 23:44:09 +02:00
<optgroup label="%i18n:@federation%">
<option value="federation-instances">%i18n:@charts.federation-instances%</option>
<option value="federation-instances-total">%i18n:@charts.federation-instances-total%</option>
</optgroup>
2018-08-23 23:41:53 +02:00
<optgroup label="%i18n:@users%">
2018-08-24 07:55:58 +02:00
<option value="users">%i18n:@charts.users%</option>
<option value="users-total">%i18n:@charts.users-total%</option>
2018-08-23 23:41:53 +02:00
</optgroup>
<optgroup label="%i18n:@notes%">
2018-08-24 07:55:58 +02:00
<option value="notes">%i18n:@charts.notes%</option>
<option value="local-notes">%i18n:@charts.local-notes%</option>
<option value="remote-notes">%i18n:@charts.remote-notes%</option>
<option value="notes-total">%i18n:@charts.notes-total%</option>
2018-08-23 23:41:53 +02:00
</optgroup>
<optgroup label="%i18n:@drive%">
2018-08-24 07:55:58 +02:00
<option value="drive-files">%i18n:@charts.drive-files%</option>
<option value="drive-files-total">%i18n:@charts.drive-files-total%</option>
<option value="drive">%i18n:@charts.drive%</option>
<option value="drive-total">%i18n:@charts.drive-total%</option>
2018-08-23 23:41:53 +02:00
</optgroup>
2018-09-14 22:40:58 +02:00
<optgroup label="%i18n:@network%">
<option value="network-requests">%i18n:@charts.network-requests%</option>
<option value="network-time">%i18n:@charts.network-time%</option>
<option value="network-usage">%i18n:@charts.network-usage%</option>
</optgroup>
2018-08-23 22:37:19 +02:00
</select>
<div>
2018-08-24 07:55:58 +02:00
<span @click="span = 'day'" :class="{ active: span == 'day' }">%i18n:@per-day%</span> | <span @click="span = 'hour'" :class="{ active: span == 'hour' }">%i18n:@per-hour%</span>
2018-08-23 22:37:19 +02:00
</div>
</header>
2018-08-24 00:17:17 +02:00
<div>
<x-chart v-if="chart" :data="data[0]" :opts="data[1]"/>
</div>
2018-08-23 22:37:19 +02:00
</div>
</template>
<script lang="ts">
import Vue from 'vue';
import XChart from './charts.chart.ts';
2018-08-23 22:37:19 +02:00
2018-08-25 08:25:16 +02:00
const colors = {
local: 'rgb(246, 88, 79)',
remote: 'rgb(65, 221, 222)',
localPlus: 'rgb(52, 178, 118)',
remotePlus: 'rgb(158, 255, 209)',
localMinus: 'rgb(255, 97, 74)',
2018-09-14 22:40:58 +02:00
remoteMinus: 'rgb(255, 149, 134)',
incoming: 'rgb(52, 178, 118)',
outgoing: 'rgb(255, 97, 74)',
2018-08-25 08:25:16 +02:00
};
const rgba = (color: string): string => {
return color.replace('rgb', 'rgba').replace(')', ', 0.1)');
};
2018-10-21 03:24:56 +02:00
const limit = 35;
2018-10-22 09:51:45 +02:00
const sum = (...arr) => arr.reduce((r, a) => r.map((b, i) => a[i] + b));
const negate = arr => arr.map(x => -x);
2018-08-23 22:37:19 +02:00
export default Vue.extend({
components: {
XChart
},
2018-08-25 08:25:16 +02:00
2018-08-23 22:37:19 +02:00
data() {
return {
2018-10-21 03:24:56 +02:00
now: null,
chart: null,
2018-08-24 07:55:58 +02:00
chartType: 'notes',
2018-08-23 22:37:19 +02:00
span: 'hour'
};
},
2018-08-25 08:25:16 +02:00
2018-08-23 22:37:19 +02:00
computed: {
data(): any {
if (this.chart == null) return null;
switch (this.chartType) {
2018-10-23 23:44:09 +02:00
case 'federation-instances': return this.federationInstancesChart(false);
case 'federation-instances-total': return this.federationInstancesChart(true);
2018-08-24 07:55:58 +02:00
case 'users': return this.usersChart(false);
case 'users-total': return this.usersChart(true);
case 'notes': return this.notesChart('combined');
case 'local-notes': return this.notesChart('local');
case 'remote-notes': return this.notesChart('remote');
case 'notes-total': return this.notesTotalChart();
2018-08-25 01:35:41 +02:00
case 'drive': return this.driveChart();
case 'drive-total': return this.driveTotalChart();
case 'drive-files': return this.driveFilesChart();
case 'drive-files-total': return this.driveFilesTotalChart();
2018-09-14 22:40:58 +02:00
case 'network-requests': return this.networkRequestsChart();
case 'network-time': return this.networkTimeChart();
case 'network-usage': return this.networkUsageChart();
2018-08-23 22:37:19 +02:00
}
},
2018-08-25 08:25:16 +02:00
2018-08-23 22:37:19 +02:00
stats(): any[] {
2018-10-21 00:10:35 +02:00
const stats =
2018-08-23 22:37:19 +02:00
this.span == 'day' ? this.chart.perDay :
this.span == 'hour' ? this.chart.perHour :
2018-10-21 00:10:35 +02:00
null;
return stats;
2018-08-23 22:37:19 +02:00
}
},
2018-08-25 08:25:16 +02:00
2018-10-21 02:20:11 +02:00
async created() {
2018-10-21 03:24:56 +02:00
this.now = new Date();
2018-10-21 02:20:11 +02:00
const [perHour, perDay] = await Promise.all([Promise.all([
2018-10-23 23:44:09 +02:00
(this as any).api('charts/federation', { limit: limit, span: 'hour' }),
2018-10-21 02:20:11 +02:00
(this as any).api('charts/users', { limit: limit, span: 'hour' }),
(this as any).api('charts/notes', { limit: limit, span: 'hour' }),
(this as any).api('charts/drive', { limit: limit, span: 'hour' }),
(this as any).api('charts/network', { limit: limit, span: 'hour' })
]), Promise.all([
2018-10-23 23:44:09 +02:00
(this as any).api('charts/federation', { limit: limit, span: 'day' }),
2018-10-21 02:20:11 +02:00
(this as any).api('charts/users', { limit: limit, span: 'day' }),
(this as any).api('charts/notes', { limit: limit, span: 'day' }),
(this as any).api('charts/drive', { limit: limit, span: 'day' }),
(this as any).api('charts/network', { limit: limit, span: 'day' })
])]);
const chart = {
2018-10-21 03:24:56 +02:00
perHour: {
2018-10-23 23:44:09 +02:00
federation: perHour[0],
users: perHour[1],
notes: perHour[2],
drive: perHour[3],
network: perHour[4]
2018-10-21 03:24:56 +02:00
},
perDay: {
2018-10-23 23:44:09 +02:00
federation: perDay[0],
users: perDay[1],
notes: perDay[2],
drive: perDay[3],
network: perDay[4]
2018-10-21 03:24:56 +02:00
}
2018-10-21 02:20:11 +02:00
};
this.chart = chart;
},
2018-08-25 08:25:16 +02:00
2018-08-23 22:37:19 +02:00
methods: {
2018-10-21 03:24:56 +02:00
getDate(i: number) {
const y = this.now.getFullYear();
const m = this.now.getMonth();
const d = this.now.getDate();
const h = this.now.getHours();
return (
this.span == 'day' ? new Date(y, m, d - i) :
this.span == 'hour' ? new Date(y, m, d, h - i) :
null
);
},
2018-10-22 09:51:45 +02:00
format(arr) {
return arr.map((v, i) => ({ t: this.getDate(i).getTime(), y: v }));
},
2018-08-23 22:37:19 +02:00
2018-10-23 23:44:09 +02:00
federationInstancesChart(total: boolean): any {
return [{
datasets: [{
label: 'Instances',
fill: true,
backgroundColor: rgba(colors.localPlus),
borderColor: colors.localPlus,
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
data: this.format(total
? this.stats.federation.instance.total
: sum(this.stats.federation.instance.inc, negate(this.stats.federation.instance.dec)))
}]
}];
},
2018-10-22 09:51:45 +02:00
notesChart(type: string): any {
2018-08-23 22:37:19 +02:00
return [{
datasets: [{
2018-08-23 23:41:53 +02:00
label: 'All',
fill: false,
borderColor: '#555',
borderWidth: 2,
2018-08-24 02:39:16 +02:00
borderDash: [4, 4],
2018-08-23 23:41:53 +02:00
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(type == 'combined'
? sum(this.stats.notes.local.inc, negate(this.stats.notes.local.dec), this.stats.notes.remote.inc, negate(this.stats.notes.remote.dec))
: sum(this.stats.notes[type].inc, negate(this.stats.notes[type].dec))
)
2018-08-23 23:41:53 +02:00
}, {
2018-08-24 07:55:58 +02:00
label: 'Renotes',
2018-08-24 01:56:57 +02:00
fill: true,
2018-08-24 07:55:58 +02:00
backgroundColor: 'rgba(161, 222, 65, 0.1)',
borderColor: '#a1de41',
2018-08-23 22:37:19 +02:00
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(type == 'combined'
? sum(this.stats.notes.local.diffs.renote, this.stats.notes.remote.diffs.renote)
: this.stats.notes[type].diffs.renote
)
2018-08-23 22:37:19 +02:00
}, {
label: 'Replies',
2018-08-24 01:56:57 +02:00
fill: true,
backgroundColor: 'rgba(247, 121, 108, 0.1)',
2018-08-23 22:37:19 +02:00
borderColor: '#f7796c',
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(type == 'combined'
? sum(this.stats.notes.local.diffs.reply, this.stats.notes.remote.diffs.reply)
: this.stats.notes[type].diffs.reply
)
2018-08-23 22:37:19 +02:00
}, {
2018-08-24 07:55:58 +02:00
label: 'Normal',
2018-08-24 01:56:57 +02:00
fill: true,
2018-08-24 07:55:58 +02:00
backgroundColor: 'rgba(65, 221, 222, 0.1)',
borderColor: '#41ddde',
2018-08-23 22:37:19 +02:00
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(type == 'combined'
? sum(this.stats.notes.local.diffs.normal, this.stats.notes.remote.diffs.normal)
: this.stats.notes[type].diffs.normal
)
2018-08-23 22:37:19 +02:00
}]
2018-08-24 07:55:58 +02:00
}, {
scales: {
yAxes: [{
ticks: {
callback: value => {
return Vue.filter('number')(value);
}
}
}]
},
tooltips: {
callbacks: {
label: (tooltipItem, data) => {
const label = data.datasets[tooltipItem.datasetIndex].label || '';
return `${label}: ${Vue.filter('number')(tooltipItem.yLabel)}`;
}
}
}
2018-08-23 22:37:19 +02:00
}];
},
2018-08-23 23:41:53 +02:00
2018-08-24 07:55:58 +02:00
notesTotalChart(): any {
2018-08-23 22:37:19 +02:00
return [{
datasets: [{
2018-08-25 01:35:41 +02:00
label: 'Combined',
2018-08-24 07:55:58 +02:00
fill: false,
borderColor: '#555',
borderWidth: 2,
borderDash: [4, 4],
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(sum(this.stats.notes.local.total, this.stats.notes.remote.total))
2018-08-24 07:55:58 +02:00
}, {
2018-08-25 08:25:16 +02:00
label: 'Local',
2018-08-24 07:55:58 +02:00
fill: true,
2018-08-25 08:25:16 +02:00
backgroundColor: rgba(colors.local),
borderColor: colors.local,
2018-08-24 07:55:58 +02:00
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(this.stats.notes.local.total)
2018-08-24 07:55:58 +02:00
}, {
2018-08-25 08:25:16 +02:00
label: 'Remote',
2018-08-24 00:17:17 +02:00
fill: true,
2018-08-25 08:25:16 +02:00
backgroundColor: rgba(colors.remote),
borderColor: colors.remote,
2018-08-23 22:37:19 +02:00
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(this.stats.notes.remote.total)
2018-08-23 22:37:19 +02:00
}]
2018-08-24 07:55:58 +02:00
}, {
scales: {
yAxes: [{
ticks: {
callback: value => {
return Vue.filter('number')(value);
}
}
}]
},
tooltips: {
callbacks: {
label: (tooltipItem, data) => {
const label = data.datasets[tooltipItem.datasetIndex].label || '';
return `${label}: ${Vue.filter('number')(tooltipItem.yLabel)}`;
}
}
}
2018-08-23 22:37:19 +02:00
}];
},
2018-08-23 23:41:53 +02:00
2018-08-24 07:55:58 +02:00
usersChart(total: boolean): any {
2018-08-23 22:37:19 +02:00
return [{
datasets: [{
2018-08-25 01:35:41 +02:00
label: 'Combined',
2018-08-24 07:55:58 +02:00
fill: false,
borderColor: '#555',
borderWidth: 2,
borderDash: [4, 4],
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(total
? sum(this.stats.users.local.total, this.stats.users.remote.total)
: sum(this.stats.users.local.inc, negate(this.stats.users.local.dec), this.stats.users.remote.inc, negate(this.stats.users.remote.dec))
)
2018-08-24 07:55:58 +02:00
}, {
2018-08-25 08:25:16 +02:00
label: 'Local',
2018-08-24 07:55:58 +02:00
fill: true,
2018-08-25 08:25:16 +02:00
backgroundColor: rgba(colors.local),
borderColor: colors.local,
2018-08-24 07:55:58 +02:00
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(total
? this.stats.users.local.total
: sum(this.stats.users.local.inc, negate(this.stats.users.local.dec))
)
2018-08-24 07:55:58 +02:00
}, {
2018-08-25 08:25:16 +02:00
label: 'Remote',
2018-08-24 00:17:17 +02:00
fill: true,
2018-08-25 08:25:16 +02:00
backgroundColor: rgba(colors.remote),
borderColor: colors.remote,
2018-08-23 22:37:19 +02:00
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(total
? this.stats.users.remote.total
: sum(this.stats.users.remote.inc, negate(this.stats.users.remote.dec))
)
2018-08-23 22:37:19 +02:00
}]
2018-08-24 07:55:58 +02:00
}, {
scales: {
yAxes: [{
ticks: {
callback: value => {
return Vue.filter('number')(value);
}
}
}]
},
tooltips: {
callbacks: {
label: (tooltipItem, data) => {
const label = data.datasets[tooltipItem.datasetIndex].label || '';
return `${label}: ${Vue.filter('number')(tooltipItem.yLabel)}`;
}
}
}
2018-08-23 22:37:19 +02:00
}];
},
2018-08-23 23:41:53 +02:00
2018-08-25 01:35:41 +02:00
driveChart(): any {
2018-08-23 22:37:19 +02:00
return [{
datasets: [{
2018-08-25 01:35:41 +02:00
label: 'All',
fill: false,
borderColor: '#555',
borderWidth: 2,
borderDash: [4, 4],
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(sum(this.stats.drive.local.incSize, negate(this.stats.drive.local.decSize), this.stats.drive.remote.incSize, negate(this.stats.drive.remote.decSize)))
2018-08-25 01:35:41 +02:00
}, {
2018-08-25 08:25:16 +02:00
label: 'Local +',
2018-08-25 01:35:41 +02:00
fill: true,
2018-08-25 08:25:16 +02:00
backgroundColor: rgba(colors.localPlus),
borderColor: colors.localPlus,
2018-08-25 01:35:41 +02:00
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(this.stats.drive.local.incSize)
2018-08-25 01:35:41 +02:00
}, {
2018-08-25 08:25:16 +02:00
label: 'Local -',
2018-08-25 01:35:41 +02:00
fill: true,
2018-08-25 08:25:16 +02:00
backgroundColor: rgba(colors.localMinus),
borderColor: colors.localMinus,
2018-08-25 01:35:41 +02:00
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(negate(this.stats.drive.local.decSize))
2018-08-25 01:35:41 +02:00
}, {
2018-08-25 08:25:16 +02:00
label: 'Remote +',
2018-08-25 01:35:41 +02:00
fill: true,
2018-08-25 08:25:16 +02:00
backgroundColor: rgba(colors.remotePlus),
borderColor: colors.remotePlus,
2018-08-25 01:35:41 +02:00
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(this.stats.drive.remote.incSize)
2018-08-25 01:35:41 +02:00
}, {
2018-08-25 08:25:16 +02:00
label: 'Remote -',
2018-08-25 01:35:41 +02:00
fill: true,
2018-08-25 08:25:16 +02:00
backgroundColor: rgba(colors.remoteMinus),
borderColor: colors.remoteMinus,
2018-08-25 01:35:41 +02:00
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(negate(this.stats.drive.remote.decSize))
2018-08-25 01:35:41 +02:00
}]
}, {
scales: {
yAxes: [{
ticks: {
callback: value => {
2018-08-25 05:14:36 +02:00
return Vue.filter('bytes')(value, 1);
2018-08-25 01:35:41 +02:00
}
}
}]
},
tooltips: {
callbacks: {
label: (tooltipItem, data) => {
const label = data.datasets[tooltipItem.datasetIndex].label || '';
2018-08-25 05:14:36 +02:00
return `${label}: ${Vue.filter('bytes')(tooltipItem.yLabel, 1)}`;
2018-08-25 01:35:41 +02:00
}
}
}
}];
},
driveTotalChart(): any {
return [{
datasets: [{
label: 'Combined',
2018-08-24 07:55:58 +02:00
fill: false,
borderColor: '#555',
borderWidth: 2,
borderDash: [4, 4],
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(sum(this.stats.drive.local.totalSize, this.stats.drive.remote.totalSize))
2018-08-24 07:55:58 +02:00
}, {
2018-08-25 08:25:16 +02:00
label: 'Local',
2018-08-24 07:55:58 +02:00
fill: true,
2018-08-25 08:25:16 +02:00
backgroundColor: rgba(colors.local),
borderColor: colors.local,
2018-08-24 07:55:58 +02:00
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(this.stats.drive.local.totalSize)
2018-08-24 07:55:58 +02:00
}, {
2018-08-25 08:25:16 +02:00
label: 'Remote',
2018-08-24 00:17:17 +02:00
fill: true,
2018-08-25 08:25:16 +02:00
backgroundColor: rgba(colors.remote),
borderColor: colors.remote,
2018-08-23 22:37:19 +02:00
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(this.stats.drive.remote.totalSize)
2018-08-23 22:37:19 +02:00
}]
}, {
scales: {
yAxes: [{
ticks: {
2018-08-24 01:56:57 +02:00
callback: value => {
2018-08-25 12:34:54 +02:00
return Vue.filter('bytes')(value, 1);
2018-08-23 22:37:19 +02:00
}
}
}]
2018-08-24 01:56:57 +02:00
},
tooltips: {
callbacks: {
2018-08-24 07:55:58 +02:00
label: (tooltipItem, data) => {
const label = data.datasets[tooltipItem.datasetIndex].label || '';
2018-08-25 12:34:54 +02:00
return `${label}: ${Vue.filter('bytes')(tooltipItem.yLabel, 1)}`;
2018-08-24 01:56:57 +02:00
}
}
2018-08-23 22:37:19 +02:00
}
}];
2018-08-23 23:41:53 +02:00
},
2018-08-25 01:35:41 +02:00
driveFilesChart(): any {
2018-08-23 23:41:53 +02:00
return [{
datasets: [{
2018-08-25 01:35:41 +02:00
label: 'All',
2018-08-24 07:55:58 +02:00
fill: false,
borderColor: '#555',
borderWidth: 2,
borderDash: [4, 4],
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(sum(this.stats.drive.local.incCount, negate(this.stats.drive.local.decCount), this.stats.drive.remote.incCount, negate(this.stats.drive.remote.decCount)))
2018-08-25 01:35:41 +02:00
}, {
2018-08-25 08:25:16 +02:00
label: 'Local +',
2018-08-25 01:35:41 +02:00
fill: true,
2018-08-25 08:25:16 +02:00
backgroundColor: rgba(colors.localPlus),
borderColor: colors.localPlus,
2018-08-25 01:35:41 +02:00
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(this.stats.drive.local.incCount)
2018-08-25 01:35:41 +02:00
}, {
2018-08-25 08:25:16 +02:00
label: 'Local -',
2018-08-25 01:35:41 +02:00
fill: true,
2018-08-25 08:25:16 +02:00
backgroundColor: rgba(colors.localMinus),
borderColor: colors.localMinus,
2018-08-25 01:35:41 +02:00
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(negate(this.stats.drive.local.decCount))
2018-08-25 01:35:41 +02:00
}, {
2018-08-25 08:25:16 +02:00
label: 'Remote +',
2018-08-25 01:35:41 +02:00
fill: true,
2018-08-25 08:25:16 +02:00
backgroundColor: rgba(colors.remotePlus),
borderColor: colors.remotePlus,
2018-08-25 01:35:41 +02:00
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(this.stats.drive.remote.incCount)
2018-08-25 01:35:41 +02:00
}, {
2018-08-25 08:25:16 +02:00
label: 'Remote -',
2018-08-25 01:35:41 +02:00
fill: true,
2018-08-25 08:25:16 +02:00
backgroundColor: rgba(colors.remoteMinus),
borderColor: colors.remoteMinus,
2018-08-25 01:35:41 +02:00
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(negate(this.stats.drive.remote.decCount))
2018-08-25 01:35:41 +02:00
}]
}, {
scales: {
yAxes: [{
ticks: {
callback: value => {
return Vue.filter('number')(value);
}
}
}]
},
tooltips: {
callbacks: {
label: (tooltipItem, data) => {
const label = data.datasets[tooltipItem.datasetIndex].label || '';
return `${label}: ${Vue.filter('number')(tooltipItem.yLabel)}`;
}
}
}
}];
},
driveFilesTotalChart(): any {
return [{
datasets: [{
label: 'Combined',
fill: false,
borderColor: '#555',
borderWidth: 2,
borderDash: [4, 4],
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(sum(this.stats.drive.local.totalCount, this.stats.drive.remote.totalCount))
2018-08-24 07:55:58 +02:00
}, {
2018-08-25 08:25:16 +02:00
label: 'Local',
2018-08-24 07:55:58 +02:00
fill: true,
2018-08-25 08:25:16 +02:00
backgroundColor: rgba(colors.local),
borderColor: colors.local,
2018-08-24 07:55:58 +02:00
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(this.stats.drive.local.totalCount)
2018-08-24 07:55:58 +02:00
}, {
2018-08-25 08:25:16 +02:00
label: 'Remote',
2018-08-24 02:39:16 +02:00
fill: true,
2018-08-25 08:25:16 +02:00
backgroundColor: rgba(colors.remote),
borderColor: colors.remote,
2018-08-23 23:41:53 +02:00
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(this.stats.drive.remote.totalCount)
2018-08-23 23:41:53 +02:00
}]
2018-08-24 07:55:58 +02:00
}, {
scales: {
yAxes: [{
ticks: {
callback: value => {
return Vue.filter('number')(value);
}
}
}]
},
tooltips: {
callbacks: {
label: (tooltipItem, data) => {
const label = data.datasets[tooltipItem.datasetIndex].label || '';
return `${label}: ${Vue.filter('number')(tooltipItem.yLabel)}`;
}
}
}
2018-08-23 23:41:53 +02:00
}];
2018-09-14 22:40:58 +02:00
},
networkRequestsChart(): any {
return [{
datasets: [{
2018-10-21 00:10:35 +02:00
label: 'Incoming',
2018-09-14 22:40:58 +02:00
fill: true,
backgroundColor: rgba(colors.localPlus),
borderColor: colors.localPlus,
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(this.stats.network.incomingRequests)
2018-09-14 22:40:58 +02:00
}]
}];
},
networkTimeChart(): any {
2018-10-21 03:24:56 +02:00
const data = [];
for (let i = 0; i < limit; i++) {
2018-10-22 09:51:45 +02:00
data.push(this.stats.network.incomingRequests[i] != 0 ? (this.stats.network.totalTime[i] / this.stats.network.incomingRequests[i]) : 0);
2018-10-21 03:24:56 +02:00
}
2018-09-14 22:40:58 +02:00
return [{
datasets: [{
label: 'Avg time (ms)',
fill: true,
backgroundColor: rgba(colors.localPlus),
borderColor: colors.localPlus,
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(data)
2018-09-14 22:40:58 +02:00
}]
}];
},
networkUsageChart(): any {
return [{
datasets: [{
label: 'Incoming',
fill: true,
backgroundColor: rgba(colors.incoming),
borderColor: colors.incoming,
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(this.stats.network.incomingBytes)
2018-09-14 22:40:58 +02:00
}, {
label: 'Outgoing',
fill: true,
backgroundColor: rgba(colors.outgoing),
borderColor: colors.outgoing,
borderWidth: 2,
pointBackgroundColor: '#fff',
lineTension: 0,
2018-10-22 09:51:45 +02:00
data: this.format(this.stats.network.outgoingBytes)
2018-09-14 22:40:58 +02:00
}]
}, {
scales: {
yAxes: [{
ticks: {
callback: value => {
return Vue.filter('bytes')(value, 1);
}
}
}]
},
tooltips: {
callbacks: {
label: (tooltipItem, data) => {
const label = data.datasets[tooltipItem.datasetIndex].label || '';
return `${label}: ${Vue.filter('bytes')(tooltipItem.yLabel, 1)}`;
}
}
}
}];
},
2018-08-23 22:37:19 +02:00
}
});
</script>
<style lang="stylus" scoped>
.gkgckalzgidaygcxnugepioremxvxvpt
padding 32px
background #fff
box-shadow 0 2px 8px rgba(#000, 0.1)
2018-08-24 01:56:57 +02:00
*
user-select none
2018-08-23 22:37:19 +02:00
> header
display flex
margin 0 0 1em 0
padding 0 0 8px 0
font-size 1em
color #555
border-bottom solid 1px #eee
2018-08-23 22:37:19 +02:00
> b
margin-right 8px
> *:last-child
margin-left auto
2018-08-24 07:55:58 +02:00
*
&:not(.active)
2018-09-26 13:19:35 +02:00
color var(--primary)
2018-08-24 07:55:58 +02:00
cursor pointer
2018-08-24 00:17:17 +02:00
> div
> *
display block
2018-09-16 19:56:57 +02:00
height 350px
2018-08-24 00:17:17 +02:00
2018-08-23 22:37:19 +02:00
</style>