1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-20 18:48:28 +02:00
joplin/ReactNativeClient/lib/database-driver-react-native.js

57 lines
1.1 KiB
JavaScript
Raw Normal View History

2017-06-11 22:11:14 +01:00
import SQLite from 'react-native-sqlite-storage';
class DatabaseDriverReactNative {
open(options) {
2017-07-05 22:29:00 +01:00
//SQLite.DEBUG(true);
2017-06-11 22:11:14 +01:00
return new Promise((resolve, reject) => {
SQLite.openDatabase({ name: options.name }, (db) => {
this.db_ = db;
resolve();
}, (error) => {
reject(error);
});
});
}
2017-07-05 22:29:00 +01:00
sqliteErrorToJsError(error, sql = null, params = null) {
return error;
}
2017-06-24 18:40:03 +01:00
setDebugMode(v) {
//SQLite.DEBUG(v);
2017-06-11 22:11:14 +01:00
}
selectOne(sql, params = null) {
return new Promise((resolve, reject) => {
this.db_.executeSql(sql, params, (r) => {
resolve(r.rows.length ? r.rows.item(0) : null);
}, (error) => {
reject(error);
});
});
}
selectAll(sql, params = null) {
return this.exec(sql, params).then((r) => {
let output = []
for (let i = 0; i < r.rows.length; i++) {
output.push(r.rows.item(i));
}
return output;
});
}
exec(sql, params = null) {
return new Promise((resolve, reject) => {
this.db_.executeSql(sql, params, (r) => {
resolve(r);
}, (error) => {
reject(error);
});
});
}
}
export { DatabaseDriverReactNative }