mirror of
https://github.com/discourse/discourse-ai.git
synced 2025-10-24 02:58:39 +00:00
DEV: Use the new controller/period component for the dashboard (#435)
This commit is contained in:
parent
5802cd1a0c
commit
4b4aedb50f
@ -1,3 +1,4 @@
|
||||
< 3.2.0.beta5-dev: c70f43f130fb98e4a1adb1afd9b621aaa49088e3
|
||||
< 3.2.0.beta4-dev: 493b48477a9288f2f1b6f021954088705a6673d6
|
||||
< 3.2.0.beta2-dev: 3bced1c6f525553fe2b5b79d29bd66c1cf2a47d5
|
||||
3.1.999: c0415bb7eb878b1b7abf112d65cba981030df8df
|
||||
|
@ -1,38 +1,9 @@
|
||||
import Controller from "@ember/controller";
|
||||
import { action } from "@ember/object";
|
||||
import { inject as service } from "@ember/service";
|
||||
import getURL from "discourse-common/lib/get-url";
|
||||
import discourseComputed from "discourse-common/utils/decorators";
|
||||
import CustomDateRangeModal from "admin/components/modal/custom-date-range";
|
||||
import PeriodComputationMixin from "admin/mixins/period-computation";
|
||||
import { computed } from "@ember/object";
|
||||
import AdminDashboardTabController from "admin/controllers/admin-dashboard-tab";
|
||||
|
||||
export default class AdminDashboardSentiment extends Controller.extend(
|
||||
PeriodComputationMixin
|
||||
) {
|
||||
@service modal;
|
||||
|
||||
@discourseComputed("startDate", "endDate")
|
||||
filters(startDate, endDate) {
|
||||
return { startDate, endDate };
|
||||
}
|
||||
|
||||
_reportsForPeriodURL(period) {
|
||||
return getURL(`/admin/dashboard/sentiment?period=${period}`);
|
||||
}
|
||||
|
||||
@action
|
||||
setCustomDateRange(startDate, endDate) {
|
||||
this.setProperties({ startDate, endDate });
|
||||
}
|
||||
|
||||
@action
|
||||
openCustomDateRangeModal() {
|
||||
this.modal.show(CustomDateRangeModal, {
|
||||
model: {
|
||||
startDate: this.startDate,
|
||||
endDate: this.endDate,
|
||||
setCustomDateRange: this.setCustomDateRange,
|
||||
},
|
||||
});
|
||||
export default class AdminDashboardSentiment extends AdminDashboardTabController {
|
||||
@computed("startDate", "endDate")
|
||||
get filters() {
|
||||
return { startDate: this.startDate, endDate: this.endDate };
|
||||
}
|
||||
}
|
||||
|
@ -4,20 +4,14 @@
|
||||
<h2>
|
||||
{{i18n "discourse_ai.sentiments.dashboard.title"}}
|
||||
</h2>
|
||||
<span>
|
||||
<PeriodChooser
|
||||
@period={{this.period}}
|
||||
@action={{action "changePeriod"}}
|
||||
@content={{this.availablePeriods}}
|
||||
@fullDay={{false}}
|
||||
/>
|
||||
<DButton
|
||||
@icon="cog"
|
||||
class="custom-date-range-button"
|
||||
@action={{this.openCustomDateRangeModal}}
|
||||
@title="admin.dashboard.custom_date_range"
|
||||
/>
|
||||
</span>
|
||||
|
||||
<DashboardPeriodSelector
|
||||
@period={{this.period}}
|
||||
@setPeriod={{this.setPeriod}}
|
||||
@startDate={{this.startDate}}
|
||||
@endDate={{this.endDate}}
|
||||
@setCustomDateRange={{this.setCustomDateRange}}
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
@ -1,8 +1,4 @@
|
||||
.dashboard.dashboard-sentiment {
|
||||
.sentiment {
|
||||
margin-bottom: 1em;
|
||||
}
|
||||
|
||||
.navigation-item.sentiment {
|
||||
border-bottom: 0.4em solid var(--tertiary);
|
||||
}
|
||||
|
15
spec/system/admin_dashboard_spec.rb
Normal file
15
spec/system/admin_dashboard_spec.rb
Normal file
@ -0,0 +1,15 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
RSpec.describe "Admin dashboard", type: :system do
|
||||
fab!(:admin)
|
||||
|
||||
it "displays the sentiment dashboard" do
|
||||
SiteSetting.ai_sentiment_enabled = true
|
||||
sign_in(admin)
|
||||
|
||||
visit "/admin"
|
||||
find(".navigation-item.sentiment").click()
|
||||
|
||||
expect(page).to have_css(".section.sentiment")
|
||||
end
|
||||
end
|
Loading…
x
Reference in New Issue
Block a user