app2-api/helpers/composes.helper.js

239 lines
7.0 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-09-27 10:04:45 +00:00
var request = require("request");
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
};
2019-09-27 10:04:45 +00:00
let partners = []
if (event && event.location && event.location.country == 'España'){
console.log('Meter banners correspondientes');
if (event.stateCode && event.stateCode == 'current_event') {
console.log('leer json de banners current', cdnHelper.getCDNCurrentPartnersJSON);
request({url: cdnHelper.getCDNCurrentPartnersJSON, json: true}, function (error, response, data) {
if (!error && response.statusCode === 200) {
let aaa = JSON.parse(JSON.stringify(data));
// let aaa = Object.assign({}, JSON.stringify(data));
//let aa = JSON.
2019-09-27 10:05:45 +00:00
// console.log(aaa.partners);
2019-09-27 10:04:45 +00:00
// partners = data;
// data.partners.forEach(function (item) {
// partners.push(item);
// });
// var arr = data.map((detail) => {partners.push(detail)});
// console.log(partners);
}});
/*
getJSON(cdnHelper.getCDNCurrentPartnersJSON, function (err,data) {
if (err !== null) {
alert('Something went wrong: ' + err);
} else {
alert('Your query count: ' + data);
}
}) ;
*/
/* fs.readFile(cdnHelper.getCDNCurrentPartnersJSON, 'utf-8', function (err, fileContents) {
if (err) {console.log(err); throw err;}
partners = JSON.parse(fileContents);
console.log(partners);
});
*/
} else if (event.stateCode == 'closed_event'){
console.log('leer json de banners current', cdnHelper.getCDNPastPartnersJSON);
}
};
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-09-27 10:04:45 +00:00
{ speakers: speakers },
{ partners: partners },
2019-07-25 17:06:12 +00:00
)
};
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
}