mirror of
https://iceshrimp.dev/limepotato/jormungandr-bite.git
synced 2025-01-10 23:51:01 -07:00
ハッシュタグチャートでローカルとリモートを分離するように
This commit is contained in:
parent
778a775e0a
commit
c41c2c83e2
3 changed files with 40 additions and 20 deletions
|
@ -1,36 +1,55 @@
|
||||||
import autobind from 'autobind-decorator';
|
import autobind from 'autobind-decorator';
|
||||||
import * as mongo from 'mongodb';
|
import Chart, { Obj } from './';
|
||||||
import Chart, { Partial } from './';
|
import { IUser, isLocalUser } from '../models/user';
|
||||||
|
import db from '../db/mongodb';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ハッシュタグに関するチャート
|
* ハッシュタグに関するチャート
|
||||||
*/
|
*/
|
||||||
type HashtagLog = {
|
type HashtagLog = {
|
||||||
/**
|
local: {
|
||||||
* 投稿された数
|
/**
|
||||||
*/
|
* 投稿された数
|
||||||
count: number;
|
*/
|
||||||
|
count: number;
|
||||||
|
};
|
||||||
|
|
||||||
|
remote: HashtagLog['local'];
|
||||||
};
|
};
|
||||||
|
|
||||||
class HashtagChart extends Chart<HashtagLog> {
|
class HashtagChart extends Chart<HashtagLog> {
|
||||||
constructor() {
|
constructor() {
|
||||||
super('hashtag', true);
|
super('hashtag', true);
|
||||||
|
|
||||||
|
// 後方互換性のため
|
||||||
|
db.get('chart.hashtag').findOne().then(doc => {
|
||||||
|
if (doc != null && doc.data.local == null) {
|
||||||
|
db.get('chart.hashtag').drop();
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@autobind
|
@autobind
|
||||||
protected async getTemplate(init: boolean, latest?: HashtagLog): Promise<HashtagLog> {
|
protected async getTemplate(init: boolean, latest?: HashtagLog): Promise<HashtagLog> {
|
||||||
return {
|
return {
|
||||||
count: 0
|
local: {
|
||||||
|
count: 0
|
||||||
|
},
|
||||||
|
remote: {
|
||||||
|
count: 0
|
||||||
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@autobind
|
@autobind
|
||||||
public async update(hashtag: string, userId: mongo.ObjectId) {
|
public async update(hashtag: string, user: IUser) {
|
||||||
const inc: Partial<HashtagLog> = {
|
const update: Obj = {
|
||||||
count: 1
|
count: 1
|
||||||
};
|
};
|
||||||
|
|
||||||
await this.incIfUnique(inc, 'users', userId.toHexString(), hashtag);
|
await this.incIfUnique({
|
||||||
|
[isLocalUser(user) ? 'local' : 'remote']: update
|
||||||
|
}, 'users', user._id.toHexString(), hashtag);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -16,7 +16,6 @@ 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 ApexCharts from 'apexcharts';
|
import * as ApexCharts from 'apexcharts';
|
||||||
import * as tinycolor from 'tinycolor2';
|
|
||||||
|
|
||||||
export default Vue.extend({
|
export default Vue.extend({
|
||||||
components: {
|
components: {
|
||||||
|
@ -45,7 +44,8 @@ export default Vue.extend({
|
||||||
span: 'hour',
|
span: 'hour',
|
||||||
limit: 24
|
limit: 24
|
||||||
}).then(stats => {
|
}).then(stats => {
|
||||||
const data = [];
|
const local = [];
|
||||||
|
const remote = [];
|
||||||
|
|
||||||
const now = new Date();
|
const now = new Date();
|
||||||
const y = now.getFullYear();
|
const y = now.getFullYear();
|
||||||
|
@ -55,11 +55,10 @@ export default Vue.extend({
|
||||||
|
|
||||||
for (let i = 0; i < 24; i++) {
|
for (let i = 0; i < 24; i++) {
|
||||||
const x = new Date(y, m, d, h - i);
|
const x = new Date(y, m, d, h - i);
|
||||||
data.push([x, stats.count[i]]);
|
local.push([x, stats.local.count[i]]);
|
||||||
|
remote.push([x, stats.remote.count[i]]);
|
||||||
}
|
}
|
||||||
|
|
||||||
const color = tinycolor(getComputedStyle(document.documentElement).getPropertyValue('--primary'));
|
|
||||||
|
|
||||||
const chart = new ApexCharts(this.$refs.chart, {
|
const chart = new ApexCharts(this.$refs.chart, {
|
||||||
chart: {
|
chart: {
|
||||||
type: 'area',
|
type: 'area',
|
||||||
|
@ -82,13 +81,15 @@ export default Vue.extend({
|
||||||
width: 2
|
width: 2
|
||||||
},
|
},
|
||||||
series: [{
|
series: [{
|
||||||
name: 'count',
|
name: 'Local',
|
||||||
data: data
|
data: local
|
||||||
|
}, {
|
||||||
|
name: 'Remote',
|
||||||
|
data: remote
|
||||||
}],
|
}],
|
||||||
xaxis: {
|
xaxis: {
|
||||||
type: 'datetime',
|
type: 'datetime',
|
||||||
},
|
}
|
||||||
colors: [`#${color.clone().toHex()}`]
|
|
||||||
});
|
});
|
||||||
|
|
||||||
chart.render();
|
chart.render();
|
||||||
|
|
|
@ -27,5 +27,5 @@ export default async function(user: IUser, tag: string) {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
hashtagChart.update(tag, user._id);
|
hashtagChart.update(tag, user);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue