import dati prodotti + fornitore + produttore
This commit is contained in:
@@ -4,9 +4,13 @@ const Schema = mongoose.Schema;
|
||||
const tools = require('../tools/general');
|
||||
|
||||
const Producer = require('../models/producer');
|
||||
const Storehouse = require('../models/storehouse');
|
||||
const Provider = require('../models/provider');
|
||||
|
||||
const shared_consts = require('../tools/shared_nodejs');
|
||||
|
||||
const { ObjectID } = require('mongodb');
|
||||
|
||||
mongoose.Promise = global.Promise;
|
||||
mongoose.level = "F";
|
||||
|
||||
@@ -29,8 +33,10 @@ const productSchema = new Schema({
|
||||
idStorehouses: [
|
||||
{ type: Schema.Types.ObjectId, ref: 'Storehouse' }
|
||||
],
|
||||
idProvider: { type: Schema.Types.ObjectId, ref: 'Provider' },
|
||||
code: {
|
||||
type: String,
|
||||
unique: true,
|
||||
},
|
||||
codice_EAN: {
|
||||
type: String,
|
||||
@@ -139,7 +145,13 @@ const productSchema = new Schema({
|
||||
},
|
||||
producer_name: {
|
||||
type: String,
|
||||
}
|
||||
},
|
||||
provider_name: {
|
||||
type: String,
|
||||
},
|
||||
magazzino_name: {
|
||||
type: String,
|
||||
},
|
||||
});
|
||||
|
||||
var Product = module.exports = mongoose.model('Product', productSchema);
|
||||
@@ -175,6 +187,15 @@ module.exports.findAllIdApp = async function (idapp, code) {
|
||||
}
|
||||
},
|
||||
{ $unwind: '$producer' },
|
||||
{
|
||||
$lookup: {
|
||||
from: 'providers',
|
||||
localField: 'idProvider',
|
||||
foreignField: '_id',
|
||||
as: 'provider'
|
||||
}
|
||||
},
|
||||
{ $unwind: '$provider' },
|
||||
{
|
||||
$lookup: {
|
||||
from: 'storehouses',
|
||||
@@ -278,27 +299,93 @@ module.exports.createIndexes((err) => {
|
||||
if (err) throw err;
|
||||
});
|
||||
|
||||
module.exports.convertAfterImport = async function () {
|
||||
module.exports.convertAfterImport = async function (idapp, dataObjects) {
|
||||
|
||||
const arrprod = await Product.find({}).lean();
|
||||
const arrprod = await Product.find({idapp}).lean();
|
||||
for (const prod of arrprod) {
|
||||
let setta = false;
|
||||
|
||||
// Impostazioni Base:
|
||||
let objtoset = {
|
||||
idapp,
|
||||
img: 'upload/products/' + prod.code + '.jpg',
|
||||
}
|
||||
|
||||
if (prod.producer_name) {
|
||||
|
||||
// Cerca il produttore
|
||||
const recproducer = await Producer.findOne({ name: prod.producer_name }).lean();
|
||||
|
||||
const campodarimuovere = 'producer_name';
|
||||
let recproducer = await Producer.findOne({ idapp, name: prod.producer_name }).lean();
|
||||
if (!recproducer) {
|
||||
// Non esiste questo produttore, quindi lo creo !
|
||||
recproducer = await Producer.create({ idapp, name: prod.producer_name }, (err, recordCreato) => {
|
||||
return recordCreato
|
||||
})
|
||||
}
|
||||
|
||||
if (recproducer) {
|
||||
await Product.findOneAndUpdate({ _id: prod._id }, { $set: { idProducer: recproducer._id } })
|
||||
await Product.findOneAndUpdate({ _id: prod._id }, { $unset: { [campodarimuovere]: 1 } })
|
||||
objtoset = {
|
||||
...objtoset,
|
||||
idProducer: recproducer._id,
|
||||
}
|
||||
setta = true;
|
||||
}
|
||||
}
|
||||
|
||||
if (prod.magazzino_name) {
|
||||
// Cerca il produttore
|
||||
let recstorehouse = await Storehouse.findOne({ idapp, name: prod.magazzino_name }).lean();
|
||||
if (!recstorehouse) {
|
||||
// Non esiste questo produttore, quindi lo creo !
|
||||
recstorehouse = await Storehouse.create({ idapp, name: prod.magazzino_name }, (err, recordCreato) => {
|
||||
return recordCreato
|
||||
})
|
||||
}
|
||||
|
||||
if (recstorehouse) {
|
||||
objtoset = {
|
||||
...objtoset,
|
||||
idStorehouses: [recstorehouse._id],
|
||||
}
|
||||
setta = true;
|
||||
}
|
||||
}
|
||||
|
||||
if (prod.provider_name) {
|
||||
// Cerca il produttore
|
||||
let recprovider = await Provider.findOne({ idapp, name: prod.provider_name }).lean();
|
||||
if (!recprovider) {
|
||||
// Non esiste questo produttore, quindi lo creo !
|
||||
recprovider = await Provider.create({ idapp, name: prod.provider_name }, (err, recordCreato) => {
|
||||
return recordCreato
|
||||
})
|
||||
}
|
||||
|
||||
if (recprovider) {
|
||||
objtoset = {
|
||||
...objtoset,
|
||||
idProvider: recprovider._id,
|
||||
}
|
||||
setta = true;
|
||||
}
|
||||
}
|
||||
|
||||
// Aggiorna il prezzo ?
|
||||
const aggiornaprezzo = false;
|
||||
if (aggiornaprezzo) {
|
||||
// cerca il prodotto
|
||||
const myprodinput = dataObjects.find((rec) => rec._id === prod._id)
|
||||
if (myprodinput) {
|
||||
objtoset = {
|
||||
...objtoset,
|
||||
price: myprodinput.price,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (setta) {
|
||||
await Product.findOneAndUpdate({ _id: prod._id }, { $set: objtoset })
|
||||
|
||||
// const campodarimuovere = 'producer_name';
|
||||
// await Product.findOneAndUpdate({ _id: prod._id }, { $unset: { [campodarimuovere]: 1 } })
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// const Product = mongoose.model('Product', ProductSchema);
|
||||
|
||||
// module.exports = { Product };
|
||||
// PROVA
|
||||
}
|
||||
Reference in New Issue
Block a user