2
0
mirror of https://github.com/frappe/books.git synced 2024-11-10 07:40:55 +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:
Faris Ansari 2019-12-11 17:57:25 +05:30
parent 218b1a7a6b
commit 4d616c075f
2 changed files with 16 additions and 4 deletions

View File

@ -160,7 +160,7 @@ module.exports = class Database extends Observable {
}
async getForeignKeys(doctype, field) {
return []
return [];
}
async getTableColumns(doctype) {
@ -179,6 +179,9 @@ module.exports = class Database extends Observable {
}
doc = await this.getOne(doctype, name, fields);
}
if (!doc) {
return;
}
await this.loadChildren(doc, meta);
return doc;
}
@ -316,7 +319,9 @@ module.exports = class Database extends Observable {
updateOne(doctype, doc) {
let validFields = this.getValidFields(doctype);
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);
return this.knex(doctype)
@ -361,6 +366,8 @@ module.exports = class Database extends Observable {
.update({ name: newName })
.where('name', oldName);
await frappe.db.commit();
this.triggerChange(doctype, newName);
}
prepareChild(parenttype, parent, child, field, idx) {
@ -574,7 +581,11 @@ module.exports = class Database extends Observable {
filtersArray.map(filter => {
const [field, operator, comparisonValue] = filter;
if (operator === '=') {
builder.where(field, comparisonValue);
} else {
builder.where(field, operator, comparisonValue);
}
});
}

View File

@ -16,7 +16,8 @@ class SqliteDatabase extends Database {
done();
}
},
useNullAsDefault: true
useNullAsDefault: true,
asyncStackTraces: process.env.NODE_ENV === 'development'
};
}