@ducna01120/fleetops-engine
Version:
Fleet & Transport Management Extension for Fleetbase
93 lines (79 loc) • 2.68 kB
JavaScript
import Component from '@glimmer/component';
import { tracked } from '@glimmer/tracking';
import { inject as service } from '@ember/service';
import { task } from 'ember-concurrency-decorators';
export default class WidgetFleetOpsKeyMetricsComponent extends Component {
/**
* The widget ID to use for registering.
*
* @memberof WidgetFleetOpsKeyMetricsComponent
*/
static widgetId = 'fleet-ops-key-metrics-widget';
/**
* Inject the fetch service.
*
* @memberof WidgetKeyMetricsComponent
*/
fetch;
/**
* Property for loading metrics to.
*
* @memberof WidgetKeyMetricsComponent
*/
metrics = {};
/**
* Creates an instance of WidgetKeyMetricsComponent.
* @memberof WidgetKeyMetricsComponent
*/
constructor() {
super(...arguments);
this.getDashboardMetrics.perform();
}
/**
* Task which fetches key metrics.
*
* @memberof WidgetKeyMetricsComponent
*/
*getDashboardMetrics() {
this.metrics = yield this.fetch.get('fleet-ops/metrics').then((response) => {
return this.createMetricsMapFromResponse(response);
});
}
/**
* Creates a map of metrics from the response data. This method organizes the metrics data into a more usable format.
*
* @param {Object} metrics - The metrics object fetched from the server.
* @returns {Object} A map of metrics where each key is a metric name and its value is an object of metric options.
* @memberof WidgetKeyMetricsComponent
*/
createMetricsMapFromResponse(metrics = {}) {
const keys = Object.keys(metrics);
const map = {};
for (let i = 0; i < keys.length; i++) {
const key = keys[i];
map[key] = this.createMetricOptionsHash(key, metrics[key]);
}
return map;
}
/**
* Creates a hash of options for a given metric. Depending on the metric key, it assigns a specific format.
*
* @param {string} key - The key representing the specific metric.
* @param {number} value - The value of the metric.
* @returns {Object} An object containing the metric value and its format.
* @memberof WidgetKeyMetricsComponent
*/
createMetricOptionsHash(key, value) {
const options = { value };
if (key === 'earnings') {
options.format = 'money';
}
if (key === 'fuel_costs') {
options.format = 'money';
}
if (key === 'total_distance_traveled') {
options.format = 'meters';
}
return options;
}
}