This blog article will illustrate how the admin-statistics-mail and admin-statistics-session API are implemented on the admin dashboard page in Open Event Frontend.Our discussion primarily will involve the admin/index route to illustrate the process.The primary end points of Open Event API with which we are concerned with for fetching the admin statistics for the dashboard are
GET /v1/admin/statistics/mails
GET /v1/admin/statistics/sessions
First we need to create the corresponding models according to the type of the response returned by the server , which in this case will be admin-statistics-event and admin-statistics-sessions, so we proceed with the ember CLI commands:
ember g model admin-statistics-mail ember g model admin-statistics-session
Next we define the model according to the requirements. The model needs to extend the base model class, and all the fields will be number since the all the data obtained via these models from the API will be numerical statistics
import attr from 'ember-data/attr'; import ModelBase from 'open-event-frontend/models/base'; export default ModelBase.extend({ oneDay : attr('number'), threeDays : attr('number'), sevenDays : attr('number'), thirtyDays : attr('number') });
And the model for sessions will be the following. It too will consist all the attributes of type number since it represents statistics
import attr from 'ember-data/attr'; import ModelBase from 'open-event-frontend/models/base'; export default ModelBase.extend({ confirmed : attr('number'), accepted : attr('number'), submitted : attr('number'), draft : attr('number'), rejected : attr('number'), pending : attr('number') });
Now we need to load the data from the api using the models, so will send a get request to the api to fetch the current permissions. This can be easily achieved via a store query in the model hook of the admin/index route.However this cannot be a normal get request. Because the the urls for the end point are /v1/admin/statistics/mails & /v1/admin/statistics/sessions but there are no relationships between statistics and various sub routes, which is what ember’s default behaviour would expect.
Hence we need to override the generated default request url using custom adapters and use buildUrl method to customize the request urls.
import ApplicationAdapter from './application'; export default ApplicationAdapter.extend({ buildURL(modelName, id, snapshot, requestType, query) { let url = this._super(modelName, id, snapshot, requestType, query); url = url.replace('admin-statistics-session', 'admin/statistics/session'); return url; } });
The buildURL method replaces the the default URL for admin-statistics-session with admin/statistics/session otherwise the the default request would have been
GET v1/admin-statistics-session
Similarly it must be done for the mail statistics too. These will ensure that the correct request is sent to the server. Now all that remains is making the requests in the model hooks and adjusting the template slightly for the new model.
model() { return RSVP.hash({ mails: this.get('store').queryRecord('admin-statistics-mail', { filter: { name : 'id', op : 'eq', val : 1 } }), sessions: this.get('store').queryRecord('admin-statistics-session', { filter: { name : 'id', op : 'eq', val : 1 } }) }); }
queryRecord is used instead of query because only a single record is expected to be returned by the API.
Resources
- Ember JS-models – Official ember documentation
- Ember JS adapters – Official ember documentation
- Open Event API Docs – authored by Fossasia project open-event-orga-server contributors
Tags :
Open event, Open event frontend, ember JS, ember service, semantic UI, ember-data, ember adapters, tickets, Open Event API, Ember models