mirror of
https://github.com/mail-in-a-box/mailinabox.git
synced 2025-04-03 00:07:05 +00:00
135 lines
5.2 KiB
JavaScript
135 lines
5.2 KiB
JavaScript
/////
|
|
///// This file is part of Mail-in-a-Box-LDAP which is released under the
|
|
///// terms of the GNU Affero General Public License as published by the
|
|
///// Free Software Foundation, either version 3 of the License, or (at
|
|
///// your option) any later version. See file LICENSE or go to
|
|
///// https://github.com/downtownallday/mailinabox-ldap for full license
|
|
///// details.
|
|
/////
|
|
|
|
import page_layout from '../../ui-common/page-layout.js';
|
|
import reports_page_header from './reports-page-header.js';
|
|
import date_range_picker from './date-range-picker.js';
|
|
import capture_db_stats from './capture-db-stats.js';
|
|
import panel_messages_sent from './panel-messages-sent.js';
|
|
import panel_messages_received from './panel-messages-received.js';
|
|
import panel_flagged_connections from './panel-flagged-connections.js';
|
|
import panel_user_activity from './panel-user-activity.js';
|
|
import panel_remote_sender_activity from './panel-remote-sender-activity.js';
|
|
|
|
import { TimeseriesData } from './charting.js';
|
|
|
|
|
|
export default Vue.component('page-reports-main', function(resolve, reject) {
|
|
axios.get('reports/ui/page-reports-main.html').then((response) => { resolve({
|
|
|
|
template: response.data,
|
|
|
|
components: {
|
|
'page-layout': page_layout,
|
|
'reports-page-header': reports_page_header,
|
|
'date-range-picker': date_range_picker,
|
|
'capture-db-stats': capture_db_stats,
|
|
'panel-messages-sent': panel_messages_sent,
|
|
'panel-messages-received': panel_messages_received,
|
|
'panel-flagged-connections': panel_flagged_connections,
|
|
'panel-user-activity': panel_user_activity,
|
|
'panel-remote-sender-activity': panel_remote_sender_activity,
|
|
},
|
|
|
|
data: function() {
|
|
return {
|
|
// page-header loading spinner
|
|
loading: 0,
|
|
|
|
// panels
|
|
panel: this.$route.params.panel || '',
|
|
|
|
// date picker - the range, if in the route, is set
|
|
// via date_change(), called during date picker
|
|
// create()
|
|
range_utc: null, // Array(2): Date objects (UTC)
|
|
range: null, // Array(2): YYYY-MM-DD (localtime)
|
|
range_type: null, // String: "custom","ytd","mtd", etc
|
|
};
|
|
},
|
|
|
|
beforeRouteUpdate: function(to, from, next) {
|
|
//console.log(`page route update: to=${JSON.stringify({path:to.path, query:to.query})} .... from=${JSON.stringify({path:from.path, query:from.query})}`);
|
|
this.panel = to.params.panel;
|
|
// note: the range is already set in the class data
|
|
//
|
|
// 1. at component start - the current range is extracted
|
|
// from $route by get_route_range() and passed to the
|
|
// date picker as a prop, which subsequently
|
|
// $emits('change') during creation where date_change()
|
|
// updates the class data.
|
|
//
|
|
// 2. during user interaction - the date picker
|
|
// $emits('change') where date_change() updates the
|
|
// class data.
|
|
next();
|
|
},
|
|
|
|
methods: {
|
|
get_start_range: function(to, default_range) {
|
|
if (to.query.range_type) {
|
|
return to.query.range_type;
|
|
}
|
|
else if (to.query.start && to.query.end) {
|
|
// start and end must be YYYY-MM-DD (localtime)
|
|
return [
|
|
to.query.start,
|
|
to.query.end
|
|
];
|
|
}
|
|
else {
|
|
return default_range;
|
|
}
|
|
},
|
|
|
|
get_binsize: function() {
|
|
if (! this.range_utc) return 0;
|
|
return TimeseriesData.binsizeOfRange(this.range_utc);
|
|
},
|
|
|
|
date_change: function(evt) {
|
|
// date picker 'change' event
|
|
this.range_type = evt.range_type;
|
|
this.range_utc = evt.range_utc;
|
|
this.range = evt.range;
|
|
var route = this.get_route(this.panel);
|
|
if (! evt.init) {
|
|
this.$router.replace(route);
|
|
}
|
|
},
|
|
|
|
get_route: function(panel, ex_query) {
|
|
// return vue-router route to `panel`
|
|
// eg: "/<panel>?start=YYYY-MM-DD&end=YYYY-MM-DD"
|
|
//
|
|
// additional panel query elements should be set in
|
|
// the panel's activate method
|
|
var route = { path: panel };
|
|
if (this.range_type != 'custom') {
|
|
route.query = {
|
|
range_type: this.range_type
|
|
};
|
|
}
|
|
else {
|
|
route.query = {
|
|
start: this.range[0],
|
|
end: this.range[1]
|
|
};
|
|
}
|
|
Object.assign(route.query, ex_query);
|
|
return route;
|
|
},
|
|
|
|
}
|
|
})}).catch((e) => {
|
|
reject(e);
|
|
});
|
|
|
|
});
|