salix/modules/agency/back/methods/zone/clone.js

78 lines
2.2 KiB
JavaScript
Raw Normal View History

2019-03-14 14:07:24 +00:00
module.exports = Self => {
Self.remoteMethod('clone', {
description: 'Clone zone and all its properties including geolocations',
accessType: 'WRITE',
accepts: {
arg: 'id',
type: 'number',
required: true,
description: 'Zone id',
http: {source: 'path'}
},
returns: {
root: true,
type: 'Object'
},
http: {
path: '/:id/clone',
verb: 'POST'
}
});
Self.clone = async id => {
const models = Self.app.models;
const transaction = await Self.beginTransaction({});
const options = {transaction};
2019-03-14 14:07:24 +00:00
// Find original zone
const zone = await models.Zone.findOne({
fields: [
'name',
'hour',
'warehouseFk',
'agencyModeFk',
'travelingDays',
'price',
'bonus',
'isVolumetric'],
where: {id}
}, options);
const hour = zone.hour;
const offset = hour.getTimezoneOffset() * 60000;
hour.setTime(hour.getTime() + offset);
2019-03-14 14:07:24 +00:00
// Find all original included geolocations
const includedGeo = await models.ZoneIncluded.find({
fields: ['geoFk', 'isIncluded'],
where: {zoneFk: id}
}, options);
// Find all original selected days
const calendarDays = await models.ZoneCalendar.find({
where: {zoneFk: id}
}, options);
2019-03-14 14:07:24 +00:00
try {
const newZone = await Self.create(zone, options);
2019-03-14 14:07:24 +00:00
const newIncludedGeo = includedGeo.map(included => {
included.zoneFk = newZone.id;
return included;
});
const newCalendayDays = calendarDays.map(day => {
day.zoneFk = newZone.id;
return day;
});
2019-03-14 14:07:24 +00:00
await models.ZoneIncluded.create(newIncludedGeo, options);
await models.ZoneCalendar.create(newCalendayDays, options);
2019-03-14 14:07:24 +00:00
await transaction.commit();
return newZone;
} catch (e) {
await transaction.rollback();
throw e;
}
};
};