mirror of
https://github.com/misskey-dev/misskey.git
synced 2025-01-07 03:29:53 +01:00
Resolve #2978
This commit is contained in:
parent
7c7f32d9a6
commit
d3d612a89b
3 changed files with 74 additions and 63 deletions
|
@ -20,7 +20,6 @@
|
||||||
"format": "gulp format"
|
"format": "gulp format"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@antv/g2": "3.3.1",
|
|
||||||
"@fortawesome/fontawesome-svg-core": "1.2.6",
|
"@fortawesome/fontawesome-svg-core": "1.2.6",
|
||||||
"@fortawesome/free-brands-svg-icons": "5.4.1",
|
"@fortawesome/free-brands-svg-icons": "5.4.1",
|
||||||
"@fortawesome/free-regular-svg-icons": "5.4.1",
|
"@fortawesome/free-regular-svg-icons": "5.4.1",
|
||||||
|
@ -85,6 +84,7 @@
|
||||||
"@types/websocket": "0.0.40",
|
"@types/websocket": "0.0.40",
|
||||||
"@types/ws": "6.0.1",
|
"@types/ws": "6.0.1",
|
||||||
"animejs": "2.2.0",
|
"animejs": "2.2.0",
|
||||||
|
"apexcharts": "2.1.5",
|
||||||
"autobind-decorator": "2.1.0",
|
"autobind-decorator": "2.1.0",
|
||||||
"autosize": "4.0.2",
|
"autosize": "4.0.2",
|
||||||
"autwh": "0.1.0",
|
"autwh": "0.1.0",
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
import Vue from 'vue';
|
import Vue from 'vue';
|
||||||
import XColumn from './deck.column.vue';
|
import XColumn from './deck.column.vue';
|
||||||
import XHashtagTl from './deck.hashtag-tl.vue';
|
import XHashtagTl from './deck.hashtag-tl.vue';
|
||||||
import * as G2 from '@antv/g2';
|
import * as ApexCharts from 'apexcharts';
|
||||||
import * as tinycolor from 'tinycolor2';
|
import * as tinycolor from 'tinycolor2';
|
||||||
|
|
||||||
export default Vue.extend({
|
export default Vue.extend({
|
||||||
|
@ -43,7 +43,7 @@ export default Vue.extend({
|
||||||
(this as any).api('charts/hashtag', {
|
(this as any).api('charts/hashtag', {
|
||||||
tag: this.tag,
|
tag: this.tag,
|
||||||
span: 'hour',
|
span: 'hour',
|
||||||
limit: 30
|
limit: 24
|
||||||
}).then(stats => {
|
}).then(stats => {
|
||||||
const data = [];
|
const data = [];
|
||||||
|
|
||||||
|
@ -53,36 +53,35 @@ export default Vue.extend({
|
||||||
const d = now.getDate();
|
const d = now.getDate();
|
||||||
const h = now.getHours();
|
const h = now.getHours();
|
||||||
|
|
||||||
for (let i = 0; i < 30; i++) {
|
for (let i = 0; i < 24; i++) {
|
||||||
const x = new Date(y, m, d, h - i + 1);
|
const x = new Date(y, m, d, h - i);
|
||||||
data.push({
|
data.push([x, stats.count[i]]);
|
||||||
x: x,
|
|
||||||
count: stats.count[i]
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const chart = new G2.Chart({
|
const color = tinycolor(getComputedStyle(document.documentElement).getPropertyValue('--primary'));
|
||||||
container: this.$refs.chart as HTMLDivElement,
|
|
||||||
forceFit: true,
|
const chart = new ApexCharts(this.$refs.chart, {
|
||||||
height: 70,
|
chart: {
|
||||||
padding: 8,
|
type: 'area',
|
||||||
renderer: 'svg'
|
height: 60,
|
||||||
|
sparkline: {
|
||||||
|
enabled: true
|
||||||
|
},
|
||||||
|
},
|
||||||
|
stroke: {
|
||||||
|
curve: 'straight',
|
||||||
|
width: 2
|
||||||
|
},
|
||||||
|
series: [{
|
||||||
|
name: 'count',
|
||||||
|
data: data
|
||||||
|
}],
|
||||||
|
xaxis: {
|
||||||
|
type: 'datetime',
|
||||||
|
},
|
||||||
|
colors: [`#${color.clone().toHex()}`]
|
||||||
});
|
});
|
||||||
|
|
||||||
const text = tinycolor(getComputedStyle(document.documentElement).getPropertyValue('--primary'));
|
|
||||||
|
|
||||||
chart.area().position('x*count').color(`l(100) 0:${text.clone().setAlpha(0.5).toRgbString()} 1:${text.clone().setAlpha(0.25).toRgbString()}`);
|
|
||||||
chart.line().position('x*count').color(`#${text.clone().toHex()}`).size(2);
|
|
||||||
chart.legend(false);
|
|
||||||
chart.axis('x', false);
|
|
||||||
chart.axis('count', false);
|
|
||||||
chart.tooltip(true, {
|
|
||||||
showTitle: false,
|
|
||||||
crosshairs: {
|
|
||||||
type: 'line'
|
|
||||||
}
|
|
||||||
});
|
|
||||||
chart.source(data);
|
|
||||||
chart.render();
|
chart.render();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -94,7 +93,8 @@ export default Vue.extend({
|
||||||
background var(--deckColumnBg)
|
background var(--deckColumnBg)
|
||||||
|
|
||||||
> .chart
|
> .chart
|
||||||
margin 16px 0
|
padding 16px
|
||||||
|
margin-bottom 16px
|
||||||
background var(--face)
|
background var(--face)
|
||||||
|
|
||||||
> .tl
|
> .tl
|
||||||
|
|
|
@ -59,7 +59,7 @@ import Menu from '../../../../common/views/components/menu.vue';
|
||||||
import MkUserListsWindow from '../../components/user-lists-window.vue';
|
import MkUserListsWindow from '../../components/user-lists-window.vue';
|
||||||
import Ok from '../../../../common/views/components/ok.vue';
|
import Ok from '../../../../common/views/components/ok.vue';
|
||||||
import { concat } from '../../../../../../prelude/array';
|
import { concat } from '../../../../../../prelude/array';
|
||||||
import * as G2 from '@antv/g2';
|
import * as ApexCharts from 'apexcharts';
|
||||||
|
|
||||||
const fetchLimit = 10;
|
const fetchLimit = 10;
|
||||||
|
|
||||||
|
@ -137,7 +137,9 @@ export default Vue.extend({
|
||||||
span: 'day',
|
span: 'day',
|
||||||
limit: 30
|
limit: 30
|
||||||
}).then(stats => {
|
}).then(stats => {
|
||||||
const data = [];
|
const normal = [];
|
||||||
|
const reply = [];
|
||||||
|
const renote = [];
|
||||||
|
|
||||||
const now = new Date();
|
const now = new Date();
|
||||||
const y = now.getFullYear();
|
const y = now.getFullYear();
|
||||||
|
@ -145,40 +147,49 @@ export default Vue.extend({
|
||||||
const d = now.getDate();
|
const d = now.getDate();
|
||||||
|
|
||||||
for (let i = 0; i < 30; i++) {
|
for (let i = 0; i < 30; i++) {
|
||||||
const x = new Date(y, m, d - i + 1);
|
const x = new Date(y, m, d - i);
|
||||||
data.push({
|
normal.push([
|
||||||
x: x,
|
x,
|
||||||
type: 'normal',
|
stats.diffs.normal[i]
|
||||||
count: stats.diffs.normal[i]
|
]);
|
||||||
});
|
reply.push([
|
||||||
data.push({
|
x,
|
||||||
x: x,
|
stats.diffs.reply[i]
|
||||||
type: 'reply',
|
]);
|
||||||
count: stats.diffs.reply[i]
|
renote.push([
|
||||||
});
|
x,
|
||||||
data.push({
|
stats.diffs.renote[i]
|
||||||
x: x,
|
]);
|
||||||
type: 'renote',
|
|
||||||
count: stats.diffs.renote[i]
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const chart = new G2.Chart({
|
const chart = new ApexCharts(this.$refs.chart, {
|
||||||
container: this.$refs.chart as HTMLDivElement,
|
chart: {
|
||||||
forceFit: true,
|
type: 'bar',
|
||||||
height: 100,
|
stacked: true,
|
||||||
padding: 16,
|
height: 60,
|
||||||
renderer: 'svg'
|
sparkline: {
|
||||||
|
enabled: true
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tooltip: {
|
||||||
|
shared: true,
|
||||||
|
intersect: false
|
||||||
|
},
|
||||||
|
series: [{
|
||||||
|
name: 'Normal',
|
||||||
|
data: normal
|
||||||
|
}, {
|
||||||
|
name: 'Reply',
|
||||||
|
data: reply
|
||||||
|
}, {
|
||||||
|
name: 'Renote',
|
||||||
|
data: renote
|
||||||
|
}],
|
||||||
|
xaxis: {
|
||||||
|
type: 'datetime'
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
chart.intervalStack().position('x*count').color('type');
|
|
||||||
chart.legend(false);
|
|
||||||
chart.axis('x', false);
|
|
||||||
chart.axis('count', false);
|
|
||||||
chart.tooltip(true, {
|
|
||||||
showTitle: false,
|
|
||||||
});
|
|
||||||
chart.source(data);
|
|
||||||
chart.render();
|
chart.render();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -364,9 +375,9 @@ export default Vue.extend({
|
||||||
border-radius 4px
|
border-radius 4px
|
||||||
|
|
||||||
> .activity
|
> .activity
|
||||||
|
padding 16px
|
||||||
margin-bottom 16px
|
margin-bottom 16px
|
||||||
background var(--face)
|
background var(--face)
|
||||||
line-height 0
|
|
||||||
|
|
||||||
> .tl
|
> .tl
|
||||||
background var(--face)
|
background var(--face)
|
||||||
|
|
Loading…
Reference in a new issue