2018-04-16 16:42:06 +08:00
|
|
|
import DiscourseURL from 'discourse/lib/url';
|
|
|
|
import computed from 'ember-addons/ember-computed-decorators';
|
|
|
|
|
|
|
|
export default Ember.Controller.extend({
|
|
|
|
queryParams: ["period"],
|
|
|
|
|
|
|
|
period: "all",
|
|
|
|
|
|
|
|
@computed("period")
|
|
|
|
startDate(period) {
|
|
|
|
switch (period) {
|
|
|
|
case "yearly":
|
|
|
|
return moment().subtract(1, "year").startOf("day");
|
|
|
|
break;
|
|
|
|
case "quarterly":
|
|
|
|
return moment().subtract(3, "month").startOf("day");
|
|
|
|
break;
|
|
|
|
case "weekly":
|
|
|
|
return moment().subtract(1, "week").startOf("day");
|
|
|
|
break;
|
|
|
|
case "monthly":
|
|
|
|
return moment().subtract(1, "month").startOf("day");
|
|
|
|
break;
|
|
|
|
case "daily":
|
|
|
|
return moment().startOf("day");
|
|
|
|
break;
|
2018-04-16 22:01:29 +08:00
|
|
|
default:
|
|
|
|
return null;
|
2018-04-16 16:42:06 +08:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
@computed("period")
|
|
|
|
endDate(period) {
|
2018-04-16 22:01:29 +08:00
|
|
|
return period === "all" ? null : moment().endOf("day");
|
2018-04-16 16:42:06 +08:00
|
|
|
},
|
|
|
|
|
|
|
|
actions: {
|
|
|
|
changePeriod(period) {
|
|
|
|
DiscourseURL.routeTo(this._reportsForPeriodURL(period));
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
_reportsForPeriodURL(period) {
|
2018-04-17 17:01:06 +08:00
|
|
|
return `/admin/dashboard-next?period=${period}`;
|
2018-04-16 16:42:06 +08:00
|
|
|
}
|
|
|
|
});
|