WorkflowAdminBundle/Resources/public/ecmascript/OpenOrchestra/Application/Router/Status/StatusRouter.js
import AbstractWorkflowRouter from 'OpenOrchestra/Application/Router/AbstractWorkflowRouter'
import Application from 'OpenOrchestra/Application/Application'
import StatusFormView from 'OpenOrchestra/Application/View/Status/StatusFormView'
import FormBuilder from 'OpenOrchestra/Service/Form/Model/FormBuilder'
import Statuses from 'OpenOrchestra/Application/Collection/Status/Statuses'
import StatusesView from 'OpenOrchestra/Application/View/Status/StatusesView'
/**
* @class StatusRouter
*/
class StatusRouter extends AbstractWorkflowRouter
{
/**
* @inheritdoc
*/
preinitialize(options) {
this.routes = {
'workflow/status/new' : 'newStatus',
'workflow/status/edit/:statusId': 'editStatus',
'workflow/status/list(/:page)' : 'listStatus'
};
}
/**
* @inheritdoc
*/
getMenuHighlight() {
return {
'*' : 'navigation-workflow'
};
}
/**
* @inheritdoc
*/
getBreadcrumbHighlight() {
return {
'*' : 'navigation-status'
};
}
/**
* New status
*/
newStatus() {
let url = Routing.generate('open_orchestra_workflow_admin_status_new');
this._displayLoader(Application.getRegion('content'));
FormBuilder.createFormFromUrl(url, (form) => {
let statusFormView = new StatusFormView({
form: form
});
Application.getRegion('content').html(statusFormView.render().$el);
});
}
/**
* Edit Status
*
* @param {String} statusId
*/
editStatus(statusId) {
let url = Routing.generate('open_orchestra_workflow_admin_status_form', {statusId: statusId});
this._displayLoader(Application.getRegion('content'));
FormBuilder.createFormFromUrl(url, (form) => {
let statusFormView = new StatusFormView({
form: form,
statusId: statusId
});
Application.getRegion('content').html(statusFormView.render().$el);
});
}
/**
* List Status
*
* @param {String} page
*/
listStatus(page) {
if (null === page) {
page = 1
}
this._displayLoader(Application.getRegion('content'));
let pageLength = Application.getConfiguration().getParameter('datatable').pageLength;
page = Number(page) - 1;
new Statuses().fetch({
apiContext: 'table',
data : {
start: page * pageLength,
length: pageLength
},
success: (statuses) => {
let statusesView = new StatusesView({
collection: statuses,
settings: {
page: page,
deferLoading: [statuses.recordsTotal, statuses.recordsFiltered],
data: statuses.models,
pageLength: pageLength
}
});
let el = statusesView.render().$el;
Application.getRegion('content').html(el);
}
});
}
}
export default StatusRouter;