У меня есть таблица опроса, которая выглядит так:
{
id: Id,
date: Date,
clients: [{
client_id: Id,
contacts: [{
contact_id: Id,
score: Number,
feedback: String,
email: String
}]
}]
}
Мне нужно обновить поля score
и feedback
под определенным контактом. В настоящее время я запускаю обновление следующим образом:
function saveScore(obj){
var dfd = q.defer();
var survey = surveys.get(obj.survey_id);
survey
.pluck({ clients: 'contacts' })
.run()
.then(results => {
results.clients.forEach((item, outerIndex) => {
item.contacts.forEach((item, index, array) => {
if(Number(item.contact_id) === Number(obj.contact_id)) {
array[index].score = obj.score;
console.log(outerIndex, index);
}
});
});
return survey.update(results).run()
})
.then(results => dfd.resolve(results))
.catch(err => dfd.resolve(err));
return dfd.promise;
};
Когда я смотрю на метод update, он указывает, как обновлять пары вложенных ключей: значение. Тем не менее, я не могу найти примеры для обновления отдельного элемента в массиве.
Есть ли лучший и, надеюсь, более чистый способ обновления элементов во вложенном массиве?