mirror of
https://github.com/discourse/discourse.git
synced 2025-01-18 16:52:45 +08:00
c34f8b65cb
As of #23867 this is now a real package, so updating the imports to use the real package name, rather than relying on the alias. The name change in the package name is because `I18n` is not a valid name as NPM packages must be all lowercase. This commit also introduces an eslint rule to prevent importing from the old I18n path. For themes/plugins, the old 'i18n' name remains functional.
176 lines
4.5 KiB
JavaScript
176 lines
4.5 KiB
JavaScript
import Controller, { inject as controller } from "@ember/controller";
|
|
import { action, computed } from "@ember/object";
|
|
import { inject as service } from "@ember/service";
|
|
import { setting } from "discourse/lib/computed";
|
|
import getURL from "discourse-common/lib/get-url";
|
|
import { makeArray } from "discourse-common/lib/helpers";
|
|
import discourseComputed from "discourse-common/utils/decorators";
|
|
import I18n from "discourse-i18n";
|
|
import PeriodComputationMixin from "admin/mixins/period-computation";
|
|
import AdminDashboard from "admin/models/admin-dashboard";
|
|
import Report from "admin/models/report";
|
|
import CustomDateRangeModal from "../components/modal/custom-date-range";
|
|
|
|
function staticReport(reportType) {
|
|
return computed("reports.[]", function () {
|
|
return makeArray(this.reports).find((report) => report.type === reportType);
|
|
});
|
|
}
|
|
|
|
export default class AdminDashboardGeneralController extends Controller.extend(
|
|
PeriodComputationMixin
|
|
) {
|
|
@service modal;
|
|
@service router;
|
|
@service siteSettings;
|
|
@controller("exception") exceptionController;
|
|
|
|
isLoading = false;
|
|
dashboardFetchedAt = null;
|
|
|
|
@setting("log_search_queries") logSearchQueriesEnabled;
|
|
|
|
@staticReport("users_by_type") usersByTypeReport;
|
|
@staticReport("users_by_trust_level") usersByTrustLevelReport;
|
|
@staticReport("storage_report") storageReport;
|
|
|
|
@discourseComputed("siteSettings.dashboard_general_tab_activity_metrics")
|
|
activityMetrics(metrics) {
|
|
return (metrics || "").split("|").filter(Boolean);
|
|
}
|
|
|
|
@computed("siteSettings.dashboard_hidden_reports")
|
|
get hiddenReports() {
|
|
return (this.siteSettings.dashboard_hidden_reports || "")
|
|
.split("|")
|
|
.filter(Boolean);
|
|
}
|
|
|
|
@computed("activityMetrics", "hiddenReports")
|
|
get isActivityMetricsVisible() {
|
|
return (
|
|
this.activityMetrics.length &&
|
|
this.activityMetrics.some((x) => !this.hiddenReports.includes(x))
|
|
);
|
|
}
|
|
|
|
@computed("hiddenReports")
|
|
get isSearchReportsVisible() {
|
|
return ["top_referred_topics", "trending_search"].some(
|
|
(x) => !this.hiddenReports.includes(x)
|
|
);
|
|
}
|
|
|
|
@computed("hiddenReports")
|
|
get isCommunityHealthVisible() {
|
|
return [
|
|
"consolidated_page_views",
|
|
"signups",
|
|
"topics",
|
|
"posts",
|
|
"dau_by_mau",
|
|
"daily_engaged_users",
|
|
"new_contributors",
|
|
].some((x) => !this.hiddenReports.includes(x));
|
|
}
|
|
|
|
@discourseComputed
|
|
activityMetricsFilters() {
|
|
return {
|
|
startDate: this.lastMonth,
|
|
endDate: this.today,
|
|
};
|
|
}
|
|
|
|
@discourseComputed
|
|
topReferredTopicsOptions() {
|
|
return {
|
|
table: { total: false, limit: 8 },
|
|
};
|
|
}
|
|
|
|
@discourseComputed
|
|
topReferredTopicsFilters() {
|
|
return {
|
|
startDate: moment().subtract(6, "days").startOf("day"),
|
|
endDate: this.today,
|
|
};
|
|
}
|
|
|
|
@discourseComputed
|
|
trendingSearchFilters() {
|
|
return {
|
|
startDate: moment().subtract(1, "month").startOf("day"),
|
|
endDate: this.today,
|
|
};
|
|
}
|
|
|
|
@discourseComputed
|
|
trendingSearchOptions() {
|
|
return {
|
|
table: { total: false, limit: 8 },
|
|
};
|
|
}
|
|
|
|
@discourseComputed
|
|
trendingSearchDisabledLabel() {
|
|
return I18n.t("admin.dashboard.reports.trending_search.disabled", {
|
|
basePath: getURL(""),
|
|
});
|
|
}
|
|
|
|
fetchDashboard() {
|
|
if (this.isLoading) {
|
|
return;
|
|
}
|
|
|
|
if (
|
|
!this.dashboardFetchedAt ||
|
|
moment().subtract(30, "minutes").toDate() > this.dashboardFetchedAt
|
|
) {
|
|
this.set("isLoading", true);
|
|
|
|
AdminDashboard.fetchGeneral()
|
|
.then((adminDashboardModel) => {
|
|
this.setProperties({
|
|
dashboardFetchedAt: new Date(),
|
|
model: adminDashboardModel,
|
|
reports: makeArray(adminDashboardModel.reports).map((x) =>
|
|
Report.create(x)
|
|
),
|
|
});
|
|
})
|
|
.catch((e) => {
|
|
this.exceptionController.set("thrown", e.jqXHR);
|
|
this.router.replaceWith("exception");
|
|
})
|
|
.finally(() => this.set("isLoading", false));
|
|
}
|
|
}
|
|
|
|
@discourseComputed("startDate", "endDate")
|
|
filters(startDate, endDate) {
|
|
return { startDate, endDate };
|
|
}
|
|
|
|
_reportsForPeriodURL(period) {
|
|
return getURL(`/admin?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,
|
|
},
|
|
});
|
|
}
|
|
}
|