feat: refs #7882 Added osrmservice #3281

Merged
guillermo merged 16 commits from 7882-locationiq into dev 2024-12-16 06:58:54 +00:00
3 changed files with 24 additions and 10 deletions
Showing only changes of commit 186ef52518 - Show all commits

View File

@ -24,7 +24,7 @@ module.exports = Self => {
} }
}); });
Self.optimize = async(addressIds, firstAddressId) => { Self.optimize = async(addressIds, firstAddressId, lastAddressId) => {
const models = Self.app.models; const models = Self.app.models;
try { try {
const osrmConfig = await models.OsrmConfig.findOne(); const osrmConfig = await models.OsrmConfig.findOne();
@ -53,13 +53,24 @@ module.exports = Self => {
} }
} }
if (lastAddressId) {
const firstAddress = await models.Address.findById(lastAddressId);
guillermo marked this conversation as resolved Outdated

donali un altre nom, ixe l'has gastat dalt i pots ser confús.

donali un altre nom, ixe l'has gastat dalt i pots ser confús.
if (firstAddress.latitude && firstAddress.longitude) {
coords.push({
addressId: firstAddress.id,
latitude: firstAddress.latitude.toFixed(6),
longitude: firstAddress.longitude.toFixed(6)
});
}
}
if (!coords.length) throw new UserError('No address has coordinates'); if (!coords.length) throw new UserError('No address has coordinates');
const concatCoords = coords const concatCoords = coords
.map(coord => `${coord.longitude},${coord.latitude}`) .map(coord => `${coord.longitude},${coord.latitude}`)
.join(';'); .join(';');
const response = await axios.post(` const response = await axios.post(`
${osrmConfig.url}/trip/v1/driving/${concatCoords}?source=first&roundtrip=true ${osrmConfig.url}/trip/v1/driving/${concatCoords}?source=first&destination=last&roundtrip=true
`); `);
const tolerance = osrmConfig.tolerance; const tolerance = osrmConfig.tolerance;
guillermo marked this conversation as resolved Outdated

en tots els for declaren la variable
for (let waypoint of response.data.waypoints) {

en tots els for declaren la variable ` for (let waypoint of response.data.waypoints) { `
for (waypoint of response.data.waypoints) { for (waypoint of response.data.waypoints) {
guillermo marked this conversation as resolved Outdated

conve posar açò?

if (!response.data || !response.data.waypoints) {
    throw new UserError('Invalid response from OSRM');
}
conve posar açò? ``` if (!response.data || !response.data.waypoints) { throw new UserError('Invalid response from OSRM'); } ```

No perque dins ja se maneja

No perque dins ja se maneja

View File

@ -396,6 +396,6 @@
"Invalid options or too many coordinates": "Opciones invalidas o demasiadas coordenadas", "Invalid options or too many coordinates": "Opciones invalidas o demasiadas coordenadas",
"No address has coordinates": "Ninguna dirección tiene coordenadas", "No address has coordinates": "Ninguna dirección tiene coordenadas",
"An item type with the same code already exists": "Un tipo con el mismo código ya existe", "An item type with the same code already exists": "Un tipo con el mismo código ya existe",
"Holidays to past days not available": "Las vacaciones a días pasados no están disponibles" "Holidays to past days not available": "Las vacaciones a días pasados no están disponibles",
"All tickets have a route order": "Todos los tickets tienen orden de ruta"
} }

View File

@ -71,13 +71,16 @@ module.exports = Self => {
}, {}); }, {});
const [mostFrequentZoneId] = Object.entries(zoneFrequency) const [mostFrequentZoneId] = Object.entries(zoneFrequency)
.reduce((maxEntry, entry) => entry[1] > maxEntry[1] ? entry : maxEntry, [null, 0]); .reduce((maxEntry, entry) => entry[1] > maxEntry[1] ? entry : maxEntry, [null, 0]);
const zone = await models.Zone.findById(mostFrequentZoneId, myOptions);
let firstAddress = zone.addressFk; // Obtenemos los address inicio y fin
if (!firstAddress) firstAddress = (await models.ZoneConfig.findOne()).defaultAddressFk; const maxPosition = Math.max(...ticketAddress.map(g => g.priority));
let firstAddress = (await models.Zone.findById(mostFrequentZoneId, myOptions))?.addressFk
|| (await models.ZoneConfig.findOne())?.defaultAddressFk;
const lastAddress = firstAddress;
if (maxPosition) firstAddress = ticketAddress.find(g => g.priority === maxPosition)?.addressId;
// Revisamos las coincidencias y actualizamos la prioridad en el array // Revisamos las coincidencias y actualizamos la prioridad en el array
const addressPositions = await models.OsrmConfig.optimize(addressIds, firstAddress, myOptions); const addressPositions = await models.OsrmConfig.optimize(addressIds, firstAddress, lastAddress, myOptions);
const maxPosition = Math.max(...ticketAddress.map(g => g.priority));
await Promise.all(ticketAddress.map(async i => { await Promise.all(ticketAddress.map(async i => {
const foundPosition = addressPositions.coords.find(item => item.addressId === i.addressId); const foundPosition = addressPositions.coords.find(item => item.addressId === i.addressId);
if (foundPosition) i.priority = foundPosition.position + (maxPosition + 1); if (foundPosition) i.priority = foundPosition.position + (maxPosition + 1);