FIX: Misc fixes for sentiment in the admin dashboard (#928)
* FIX: Misc fixes for sentiment in the admin dashboard - Fixes missing filters for the main graph - Fixes previous 30 days trend in emotion table Also moves links to individual cells in emotion table, so admins can drill down to the specific time period on their reports. * lints
This commit is contained in:
parent
a9afa04329
commit
2c8d81827f
|
@ -2,16 +2,26 @@
|
||||||
{{#if this.model.icon}}
|
{{#if this.model.icon}}
|
||||||
{{d-icon this.model.icon}}
|
{{d-icon this.model.icon}}
|
||||||
{{/if}}
|
{{/if}}
|
||||||
<a href="{{this.filterURL}}{{this.model.type}}">{{this.model.title}}</a>
|
{{this.model.title}}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="cell value today-count">{{number this.model.todayCount}}</div>
|
<div class="cell value today-count">
|
||||||
|
<a
|
||||||
|
href="{{this.filterURL}}activity-after%3A{{this.today}}%20order%3A{{this.model.type}}"
|
||||||
|
>
|
||||||
|
{{number this.model.todayCount}}
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div
|
<div
|
||||||
class="cell value yesterday-count {{this.model.yesterdayTrend}}"
|
class="cell value yesterday-count {{this.model.yesterdayTrend}}"
|
||||||
title={{this.model.yesterdayCountTitle}}
|
title={{this.model.yesterdayCountTitle}}
|
||||||
>
|
>
|
||||||
{{number this.model.yesterdayCount}}
|
<a
|
||||||
|
href="{{this.filterURL}}activity-after%3A{{this.yesterday}}%20order%3A{{this.model.type}}"
|
||||||
|
>
|
||||||
|
{{number this.model.yesterdayCount}}
|
||||||
|
</a>
|
||||||
{{d-icon this.model.yesterdayTrendIcon}}
|
{{d-icon this.model.yesterdayTrendIcon}}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -19,7 +29,11 @@
|
||||||
class="cell value sevendays-count {{this.model.sevenDaysTrend}}"
|
class="cell value sevendays-count {{this.model.sevenDaysTrend}}"
|
||||||
title={{this.model.sevenDaysCountTitle}}
|
title={{this.model.sevenDaysCountTitle}}
|
||||||
>
|
>
|
||||||
{{number this.model.lastSevenDaysCount}}
|
<a
|
||||||
|
href="{{this.filterURL}}activity-after%3A{{this.lastWeek}}%20order%3A{{this.model.type}}"
|
||||||
|
>
|
||||||
|
{{number this.model.lastSevenDaysCount}}
|
||||||
|
</a>
|
||||||
{{d-icon this.model.sevenDaysTrendIcon}}
|
{{d-icon this.model.sevenDaysTrendIcon}}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -27,7 +41,11 @@
|
||||||
class="cell value thirty-days-count {{this.model.thirtyDaysTrend}}"
|
class="cell value thirty-days-count {{this.model.thirtyDaysTrend}}"
|
||||||
title={{this.model.thirtyDaysCountTitle}}
|
title={{this.model.thirtyDaysCountTitle}}
|
||||||
>
|
>
|
||||||
{{number this.model.lastThirtyDaysCount}}
|
<a
|
||||||
|
href="{{this.filterURL}}activity-after%3A{{this.lastMonth}}%20order%3A{{this.model.type}}"
|
||||||
|
>
|
||||||
|
{{number this.model.lastThirtyDaysCount}}
|
||||||
|
</a>
|
||||||
|
|
||||||
{{#if this.model.canDisplayTrendIcon}}
|
{{#if this.model.canDisplayTrendIcon}}
|
||||||
{{d-icon this.model.thirtyDaysTrendIcon}}
|
{{d-icon this.model.thirtyDaysTrendIcon}}
|
||||||
|
|
|
@ -6,7 +6,22 @@ import getURL from "discourse-common/lib/get-url";
|
||||||
@attributeBindings("model.description:title")
|
@attributeBindings("model.description:title")
|
||||||
export default class AdminReportEmotion extends Component {
|
export default class AdminReportEmotion extends Component {
|
||||||
get filterURL() {
|
get filterURL() {
|
||||||
let aMonthAgo = moment().subtract(1, "month").format("YYYY-MM-DD");
|
return getURL(`/filter?q=`);
|
||||||
return getURL(`/filter?q=activity-after%3A${aMonthAgo}%20order%3A`);
|
}
|
||||||
|
|
||||||
|
get today() {
|
||||||
|
return moment().format("YYYY-MM-DD");
|
||||||
|
}
|
||||||
|
|
||||||
|
get yesterday() {
|
||||||
|
return moment().subtract(1, "day").format("YYYY-MM-DD");
|
||||||
|
}
|
||||||
|
|
||||||
|
get lastWeek() {
|
||||||
|
return moment().subtract(1, "week").format("YYYY-MM-DD");
|
||||||
|
}
|
||||||
|
|
||||||
|
get lastMonth() {
|
||||||
|
return moment().subtract(1, "month").format("YYYY-MM-DD");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,12 @@
|
||||||
|
import { computed } from "@ember/object";
|
||||||
import AdminDashboardTabController from "admin/controllers/admin-dashboard-tab";
|
import AdminDashboardTabController from "admin/controllers/admin-dashboard-tab";
|
||||||
|
|
||||||
export default class AdminDashboardSentiment extends AdminDashboardTabController {
|
export default class AdminDashboardSentiment extends AdminDashboardTabController {
|
||||||
|
@computed("startDate", "endDate")
|
||||||
|
get filters() {
|
||||||
|
return { startDate: this.startDate, endDate: this.endDate };
|
||||||
|
}
|
||||||
|
|
||||||
get emotions() {
|
get emotions() {
|
||||||
const emotions = [
|
const emotions = [
|
||||||
"admiration",
|
"admiration",
|
||||||
|
|
|
@ -9,7 +9,7 @@ module DiscourseAi
|
||||||
query_results = DiscourseAi::Sentiment::EmotionDashboardReport.fetch_data
|
query_results = DiscourseAi::Sentiment::EmotionDashboardReport.fetch_data
|
||||||
report.data = query_results.pop(30).map { |row| { x: row.day, y: row.send(emotion) } }
|
report.data = query_results.pop(30).map { |row| { x: row.day, y: row.send(emotion) } }
|
||||||
report.prev30Days =
|
report.prev30Days =
|
||||||
query_results.take(30).map { |row| { x: row.day, y: row.send(emotion) } }
|
query_results.take(30).reduce(0) { |sum, row| sum + row.send(emotion) }.to_i
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue