2019-08-08 06:33:27 +00:00
|
|
|
module.exports = Self => {
|
|
|
|
Self.remoteMethodCtx('editableStates', {
|
|
|
|
description: 'Gets the editable states according the user role ',
|
|
|
|
accessType: 'READ',
|
2020-03-26 11:00:07 +00:00
|
|
|
accepts: {
|
|
|
|
arg: 'filter',
|
|
|
|
type: 'object'
|
|
|
|
},
|
2019-08-08 06:33:27 +00:00
|
|
|
returns: {
|
2021-10-07 07:57:07 +00:00
|
|
|
type: ['object'],
|
2019-08-08 06:33:27 +00:00
|
|
|
root: true
|
|
|
|
},
|
|
|
|
http: {
|
|
|
|
path: `/editableStates`,
|
|
|
|
verb: 'GET'
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2021-10-07 07:57:07 +00:00
|
|
|
Self.editableStates = async(ctx, filter, options) => {
|
|
|
|
const models = Self.app.models;
|
|
|
|
const userId = ctx.req.accessToken.userId;
|
|
|
|
const myOptions = {};
|
|
|
|
|
|
|
|
if (typeof options == 'object')
|
|
|
|
Object.assign(myOptions, options);
|
2019-08-08 06:33:27 +00:00
|
|
|
|
2021-10-07 07:57:07 +00:00
|
|
|
let statesList = await models.State.find({where: filter.where}, myOptions);
|
|
|
|
const isProduction = await models.Account.hasRole(userId, 'production', myOptions);
|
|
|
|
const isSalesPerson = await models.Account.hasRole(userId, 'salesPerson', myOptions);
|
|
|
|
const isAdministrative = await models.Account.hasRole(userId, 'administrative', myOptions);
|
2019-08-08 06:33:27 +00:00
|
|
|
|
|
|
|
if (isProduction || isAdministrative)
|
|
|
|
return statesList;
|
|
|
|
|
|
|
|
if (isSalesPerson) {
|
|
|
|
return statesList = statesList.filter(stateList =>
|
|
|
|
stateList.alertLevel === 0 || stateList.code === 'PICKER_DESIGNED'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return statesList.filter(stateList => stateList.alertLevel === 0);
|
|
|
|
};
|
|
|
|
};
|