mirror of
https://github.com/frappe/books.git
synced 2025-01-24 15:48:25 +00:00
fix: Database
- Fix frappe.db.get for non existent record with children - triggerChange in frappe.db.rename - Handle null value in getAll filters
This commit is contained in:
parent
218b1a7a6b
commit
4d616c075f
@ -160,7 +160,7 @@ module.exports = class Database extends Observable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async getForeignKeys(doctype, field) {
|
async getForeignKeys(doctype, field) {
|
||||||
return []
|
return [];
|
||||||
}
|
}
|
||||||
|
|
||||||
async getTableColumns(doctype) {
|
async getTableColumns(doctype) {
|
||||||
@ -179,6 +179,9 @@ module.exports = class Database extends Observable {
|
|||||||
}
|
}
|
||||||
doc = await this.getOne(doctype, name, fields);
|
doc = await this.getOne(doctype, name, fields);
|
||||||
}
|
}
|
||||||
|
if (!doc) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
await this.loadChildren(doc, meta);
|
await this.loadChildren(doc, meta);
|
||||||
return doc;
|
return doc;
|
||||||
}
|
}
|
||||||
@ -316,7 +319,9 @@ module.exports = class Database extends Observable {
|
|||||||
updateOne(doctype, doc) {
|
updateOne(doctype, doc) {
|
||||||
let validFields = this.getValidFields(doctype);
|
let validFields = this.getValidFields(doctype);
|
||||||
let fieldsToUpdate = Object.keys(doc).filter(f => f !== 'name');
|
let fieldsToUpdate = Object.keys(doc).filter(f => f !== 'name');
|
||||||
let fields = validFields.filter(df => fieldsToUpdate.includes(df.fieldname));
|
let fields = validFields.filter(df =>
|
||||||
|
fieldsToUpdate.includes(df.fieldname)
|
||||||
|
);
|
||||||
let formattedDoc = this.getFormattedDoc(fields, doc);
|
let formattedDoc = this.getFormattedDoc(fields, doc);
|
||||||
|
|
||||||
return this.knex(doctype)
|
return this.knex(doctype)
|
||||||
@ -361,6 +366,8 @@ module.exports = class Database extends Observable {
|
|||||||
.update({ name: newName })
|
.update({ name: newName })
|
||||||
.where('name', oldName);
|
.where('name', oldName);
|
||||||
await frappe.db.commit();
|
await frappe.db.commit();
|
||||||
|
|
||||||
|
this.triggerChange(doctype, newName);
|
||||||
}
|
}
|
||||||
|
|
||||||
prepareChild(parenttype, parent, child, field, idx) {
|
prepareChild(parenttype, parent, child, field, idx) {
|
||||||
@ -574,7 +581,11 @@ module.exports = class Database extends Observable {
|
|||||||
|
|
||||||
filtersArray.map(filter => {
|
filtersArray.map(filter => {
|
||||||
const [field, operator, comparisonValue] = filter;
|
const [field, operator, comparisonValue] = filter;
|
||||||
builder.where(field, operator, comparisonValue);
|
if (operator === '=') {
|
||||||
|
builder.where(field, comparisonValue);
|
||||||
|
} else {
|
||||||
|
builder.where(field, operator, comparisonValue);
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -16,7 +16,8 @@ class SqliteDatabase extends Database {
|
|||||||
done();
|
done();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
useNullAsDefault: true
|
useNullAsDefault: true,
|
||||||
|
asyncStackTraces: process.env.NODE_ENV === 'development'
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user