app2-api/helpers/composes.helper.js

193 lines
5.1 KiB
JavaScript
Raw Normal View History

2019-07-25 17:06:12 +00:00
'use strict';
2019-07-25 17:16:28 +00:00
const cdnHelper = require('./cdn.helper');
2019-07-25 17:06:12 +00:00
2019-07-25 18:29:33 +00:00
const valuesComposer = (values) => (values) ? values.map(value => ({id: value.id, name: value.name,})): values;
2019-08-28 10:43:41 +00:00
const citiesComposer = (city, context) => {
2019-07-29 13:39:52 +00:00
if (city) {
2019-08-28 10:43:41 +00:00
if (city.location)
city.location = locationComposer(city.location, context);
2019-07-29 13:39:52 +00:00
return {
...city,
};
}
else return city;
}
2019-07-25 18:29:33 +00:00
2019-08-27 11:08:04 +00:00
const locationComposer = (location, context) => {
if (location) {
let multimedias = [];
2019-08-28 10:43:41 +00:00
if (location.multimedias)
2019-08-27 11:08:04 +00:00
multimedias = multimediaComposer(location.multimedias);
return {
...location,
multimedias: multimedias,
};
}
else return location;
}
2019-07-26 14:50:53 +00:00
const commentComposer = (comment, context) => {
if (comment.user) {
comment.user_name = comment.user.name + '---';
comment.profile_picture = cdnHelper.getCDNMediaUrl(comment.user.profile_picture);
}else {
comment.user_name = comment.nameUserOld;
comment.profile_picture = cdnHelper.getCDNMediaUrl(comment.profile_pictureOld);
}
delete comment.nameUserOld;
delete comment.profile_pictureOld;
delete comment.userId;
delete comment.user;
return Object.assign({},
comment);
};
2019-07-29 17:17:28 +00:00
const commentsComposer = (comments) => {
if (comments) {
return comments.map(comment => ({
...commentComposer(comment)
}));
}
else return comments;
};
2019-07-26 14:50:53 +00:00
2019-07-25 17:16:28 +00:00
2019-07-25 18:29:33 +00:00
const multimediaComposer = (multimedias) => {
if(multimedias) {
return multimedias.map(multimedia => ({
...multimedia,
...multimedia.multimediaFile,
type: multimedia.type,
media_type: multimedia.multimediaFile.type,
multimediaFile: undefined,
createdAt: undefined,
updatedAt: undefined,
userId: undefined,
url: (multimedia.multimediaFile.provider === 'cdn') ? cdnHelper.getCDNMediaUrl(multimedia.multimediaFile.url) : multimedia.multimediaFile.url,
}));
2019-07-25 17:16:28 +00:00
}
2019-07-25 18:29:33 +00:00
else
return multimedias;
};
const socialNetworksComposer = (speaker) => {
if (speaker) {
return {
rrss: {
twitter: speaker.twitter ? speaker.twitter : null,
facebook: speaker.facebook ? speaker.facebook : null,
youtube: speaker.youtube ? speaker.youtube : null,
linkedin: speaker.linkedin ? speaker.linkedin : null,
instagram: speaker.instagram ? speaker.instagram : null,
web: speaker.web ? speaker.web : null
},
twitter: undefined,
facebook: undefined,
youtube: undefined,
linkedin: undefined,
instagram: undefined,
web: undefined
};
}
else
return speaker;
2019-07-25 17:06:12 +00:00
};
2019-07-25 17:16:28 +00:00
2019-07-25 17:06:12 +00:00
const speakerComposer = (speaker, context) => {
2019-07-25 18:29:33 +00:00
2019-07-25 17:16:28 +00:00
let multimedias = [];
2019-07-25 18:29:33 +00:00
if ((context.scopes) && (context.scopes.includes('includeMultimedias'))) {
2019-07-25 17:16:28 +00:00
multimedias = multimediaComposer(speaker.multimedias);
};
let comments = [];
2019-07-25 18:29:33 +00:00
if ((context.scopes) && (context.scopes.includes('includeComments'))) {
2019-07-25 17:16:28 +00:00
comments = commentsComposer(speaker.comments);
2019-07-25 17:06:12 +00:00
};
2019-08-20 12:10:49 +00:00
if (speaker.type) {
speaker.typename = speaker.type.name;
delete speaker.type;
}
2019-07-25 17:06:12 +00:00
speaker.values = valuesComposer(speaker.values);
const rrss = socialNetworksComposer(speaker, context);
return Object.assign({},
speaker,
rrss,
{ multimedias: multimedias },
2019-07-25 17:16:28 +00:00
{ comments: comments },
2019-07-25 17:06:12 +00:00
)
};
const eventComposer = (event, context) => {
2019-07-25 18:29:33 +00:00
if ((context.scopes) && (context.scopes.includes('includeVenue'))){
2019-08-22 12:19:41 +00:00
if (event.venue) {
delete event.venue.updatedAt;
delete event.venue.createdAt;
//event.venue.image_url = cdnHelper.getCDNCityMediaUrl(event.venue.city); <-- se hace en el modelo
}
2019-07-25 17:06:12 +00:00
};
let multimedias = []
2019-07-25 18:29:33 +00:00
if ((context.scopes) && (context.scopes.includes('includeMultimedias'))) {
2019-07-25 17:06:12 +00:00
multimedias = multimediaComposer(event.multimedias)
};
let speakers = []
2019-08-14 17:49:38 +00:00
let details = []
if ((context.scopes) && (context.scopes.includes('includeDetails'))) {
event.details.map((detail) => {
if (detail.type == 'speaker')
speakers.push({
order: detail.order,
...speakerComposer(detail.speaker, context),
});
if (detail.type == 'info')
details.push({
...detail,
speaker: undefined,
});
});
2019-07-25 17:06:12 +00:00
};
return Object.assign({},
event,
{ multimedias: multimedias },
2019-08-14 17:49:38 +00:00
{ details: details },
2019-07-25 17:06:12 +00:00
{ speakers: speakers }
)
};
const entityComposer = (entity, context) => {
delete entity.contact_person;
delete entity.contact_email;
return Object.assign({},
entity,
)
};
module.exports = {
entityComposer,
speakerComposer,
2019-07-26 14:50:53 +00:00
eventComposer,
2019-07-29 13:39:52 +00:00
commentComposer,
2019-08-27 11:08:04 +00:00
citiesComposer,
locationComposer
2019-07-25 17:06:12 +00:00
}