För närvarande ger GORM för MongoDB inte korrekta värden i dirtyPropertyNames
fält. Så du måste använda ett annat injicerat fält på lägre nivå i domäninstansen, dvs. $changedProperties
.
Men det finns också ett problem med $changedProperties
att även om du binder ett fält med samma värde, visas $changedProperties
kommer att ha en post för det. Så du kan justera den lite mer så här för att få din kod att fungera:
def beforeUpdate() {
def instance = this
Map updatedFields = instance.$changedProperties
updatedFields.each { name, value ->
if (updatedFields[name] != instance[name]) {
println "Field value $name is updated"
if (name == "addresses") {
// I've not run this for a long time, just confirm the old and new addresses values and swap the assignment of below lines
List newAddresses = updatedFields[name]
List oldAddresses = instance[name]
newAddresses.each { address ->
if (!address.id) {
println "Got new address: $address.status"
} else {
Address oldAddress = oldAddresses.find { it.id == address.id }
if (!oldAddress) { // This is just an edge condition
println "Got new address: $address.status"
} else if (oldAddress.status != address.staus) {
println "$address status is updated to $address.status"
}
}
}
}
}
}
}