feat: Adding public-companies/users
This commit is contained in:
@@ -4,5 +4,6 @@ const services= require('./services.js');
|
||||
|
||||
router.get('/shipper', services.getListShippers);
|
||||
router.get('/carrier', services.getListCarriers);
|
||||
router.get('/users/:companyId', services.getUserLists);
|
||||
|
||||
module.exports = router;
|
||||
|
||||
@@ -7,12 +7,15 @@ const { getPagination , getPage } = require( `${ROOT_PATH}/${LIB_PATH}/Misc.js`
|
||||
const { GenericHandler } = require( `${ROOT_PATH}/${HANDLERS_PATH}/Generic.handler.js` );
|
||||
const Model = require( `${ROOT_PATH}/${MODELS_PATH}/companies.model.js` );
|
||||
const categoriesModel = require( `${ROOT_PATH}/${MODELS_PATH}/product-categories.model.js` );
|
||||
const usersModel = require( `${ROOT_PATH}/${MODELS_PATH}/users.model.js` );
|
||||
|
||||
const populate_select = {
|
||||
categories:"-_id name",
|
||||
};
|
||||
const generic = new GenericHandler( Model, null, null , populate_select );
|
||||
|
||||
const user_generic = new GenericHandler( usersModel );
|
||||
|
||||
function join_field_list( obj_with_fields , list_of_fields )
|
||||
{
|
||||
for(let field_idx=0; field_idx < list_of_fields.length; field_idx++){
|
||||
@@ -81,4 +84,63 @@ const getListCarriers = async(req, res) => {
|
||||
res.send( retVal );
|
||||
};
|
||||
|
||||
module.exports = { getListShippers, getListCarriers };
|
||||
const getUserLists = async(req, res) => {
|
||||
try{
|
||||
const companyId = req.params.companyId;
|
||||
|
||||
const { elements } = getPagination( req.query );
|
||||
const page = 0;// No pagination allowed to this endpoint
|
||||
let query_elements;
|
||||
if( elements >= 100 ){
|
||||
query_elements = 100;// Never return more than 100 elements
|
||||
}else{
|
||||
query_elements = elements;
|
||||
}
|
||||
|
||||
const select = [
|
||||
"first_name",
|
||||
"middle_name",
|
||||
"last_name",
|
||||
"company",
|
||||
"employe_id",
|
||||
"phone",
|
||||
"phone2",
|
||||
"email",
|
||||
"categories",
|
||||
"user_city",
|
||||
"user_state",
|
||||
"truck_type"
|
||||
];
|
||||
const queryVal = await user_generic.getList(page , query_elements, { company : companyId }, select );
|
||||
const data_list = queryVal.data;
|
||||
for(let i=0; i<data_list.length; i++){
|
||||
data_list[i] = data_list[i].toObject();
|
||||
let name;
|
||||
name = ( !data_list[i].first_name )? "" : data_list[i].first_name;
|
||||
name += ( !data_list[i].middle_name )? "": " " + data_list[i].middle_name;
|
||||
name += ( !data_list[i].last_name )? "": " " + data_list[i].last_name;
|
||||
|
||||
data_list[i].name = name;
|
||||
data_list[i] = join_field_list( data_list[i] , ["categories","user_city","user_state","truck_type"] );
|
||||
let categories = data_list[i].categories.map( ( c ) => c.name);
|
||||
|
||||
/** Remove not requried fields */
|
||||
delete data_list[i].categories;
|
||||
delete data_list[i].user_city;
|
||||
delete data_list[i].user_state;
|
||||
delete data_list[i].truck_type;
|
||||
}
|
||||
const retVal = {
|
||||
total : queryVal.total,
|
||||
limit : queryVal.limit,
|
||||
skip : queryVal.skip,
|
||||
data : data_list
|
||||
};
|
||||
return res.status(200).send( retVal );
|
||||
} catch ( err ){
|
||||
console.error( err );
|
||||
return res.status(500).send({ error : "Public-Companies: Internal error" });
|
||||
}
|
||||
};
|
||||
|
||||
module.exports = { getListShippers, getListCarriers, getUserLists };
|
||||
|
||||
Reference in New Issue
Block a user