Last active
April 14, 2019 03:23
-
-
Save jdnichollsc/9ac79aaa3407e92677ba to your computer and use it in GitHub Desktop.
SQLite plugin with ngCordova in Ionic Framework => Using service pattern (Works for litehelpers/Cordova-sqlite-storage and MSOpenTech/cordova-plugin-websql) Code => http://1drv.ms/1Ono0Ys Template => https://github.com/jdnichollsc/Ionic-Starter-Template
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
angular.module('Demo', ['ionic', 'Demo.controllers', 'Demo.services', 'ngCordova']) | |
.run(function ($ionicPlatform, sqliteService) { | |
$ionicPlatform.ready(function () { | |
// Hide the accessory bar by default (remove this to show the accessory bar above the keyboard | |
// for form inputs) | |
if (window.cordova && window.cordova.plugins.Keyboard) { | |
cordova.plugins.Keyboard.hideKeyboardAccessoryBar(true); | |
cordova.plugins.Keyboard.disableScroll(true); | |
} | |
if (window.StatusBar) { | |
// org.apache.cordova.statusbar required | |
StatusBar.styleDefault(); | |
} | |
sqliteService.preloadDataBase(true); //true for debugging | |
}); | |
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
var queries = [ | |
"DROP TABLE IF EXISTS Users;", | |
"DROP TABLE IF EXISTS Products;", | |
"DROP TABLE IF EXISTS Categories;", | |
"CREATE TABLE Users (IdUser integer primary key , FirstName text not null);", | |
"CREATE TABLE Categories(IdCategory integer primary key, Name text not null);", | |
"CREATE TABLE Products(IdProduct integer primary key autoincrement, Name text not null, IdCategory integer not null);", | |
"INSERT INTO 'Users' ('IdUser','FirstName') VALUES (1, 'Daniel');", | |
"INSERT INTO 'Categories' ('IdCategory','Name') VALUES (1, 'Computadores');", | |
"INSERT INTO 'Categories' ('IdCategory','Name') VALUES (2, 'Celulares');", | |
"INSERT INTO 'Products' ('Name','IdCategory') VALUES ('Note 4', 2);" | |
]; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
controllers.controller('ProductsController', ['$scope', '$ionicPlatform', 'Products' function ($scope, $ionicPlatform, Products) { | |
$scope.products = []; | |
$scope.product = { | |
IdProduct: 1, | |
Name: 'Pizza', | |
Icon: 'ion-pizza', | |
Color: '#F056C2' | |
}; | |
$ionicPlatform.ready(function () { | |
Products.createTable().then(function(){ | |
return Products.addProduct($scope.product); //Insert a new product | |
}).then(function () { | |
return Products.getProducts(); //Get Products | |
}).then(function (products) { | |
$scope.products = angular.copy(products); | |
}).catch(function (err) { | |
console.log(err); | |
}); | |
}); | |
} ]); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
services.factory('Products', ['$q', 'sqliteService', function ($q, sqliteService) { | |
return { | |
getProducts: function () { | |
var query = 'SELECT * FROM Products'; | |
return $q.when(sqliteService.getItems(query)); | |
}, | |
addProduct: function (product) { | |
var query = "INSERT INTO Products (IdProduct, Name, Icon, Color) VALUES (?,?,?,?)"; | |
return $q.when(sqliteService.executeSql(query, [product.IdProduct, product.Name, product.Icon, product.Color])); | |
}, | |
dropTable: function () { | |
var query = 'DROP TABLE IF EXISTS Products'; | |
return $q.when(sqliteService.executeSql(query)); | |
}, | |
createTable: function () { | |
var query = 'CREATE TABLE IF NOT EXISTS Products (IdProduct integer primary key, Name text, Icon text, Color text)'; | |
return $q.when(sqliteService.executeSql(query)); | |
} | |
}; | |
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
services.service('sqliteService', ['$q', '$cordovaSQLite', function ($q, $cordovaSQLite) { | |
var self = this; | |
var _db; | |
self.db = function () { | |
if (!_db) { | |
if (window.sqlitePlugin !== undefined) { | |
//www/demo.db is a file created with SqliteBrowser tool :) | |
_db = window.sqlitePlugin.openDatabase({ name: "demo.db", location: 2, createFromLocation: 1 }); | |
} else { | |
// For debugging in the browser | |
_db = window.openDatabase("demo.db", "1.0", "Demo", 200000); | |
} | |
} | |
return _db; | |
}; | |
self.getFirstItem = function (query, parameters) { | |
var deferred = $q.defer(); | |
self.executeSql(query, parameters).then(function (res) { | |
if(res.rows.length > 0) | |
return deferred.resolve(res.rows.item(0)); | |
else | |
return deferred.reject("There aren't items matching"); | |
}, function (err) { | |
return deferred.reject(err); | |
}); | |
return deferred.promise; | |
}; | |
self.getFirstOrDefaultItem = function (query, parameters) { | |
var deferred = $q.defer(); | |
self.executeSql(query, parameters).then(function (res) { | |
if(res.rows.length > 0) | |
return deferred.resolve(res.rows.item(0)); | |
else | |
return deferred.resolve(null); | |
}, function (err) { | |
return deferred.reject(err); | |
}); | |
return deferred.promise; | |
}; | |
self.getItems = function (query, parameters) { | |
var deferred = $q.defer(); | |
self.executeSql(query, parameters).then(function (res) { | |
var items = []; | |
for (var i = 0; i < res.rows.length; i++) { | |
items.push(res.rows.item(i)); | |
} | |
return deferred.resolve(items); | |
}, function (err) { | |
return deferred.reject(err); | |
}); | |
return deferred.promise; | |
}; | |
self.preloadDataBase = function (enableLog) { | |
var deferred = $q.defer(); | |
if (window.sqlitePlugin === undefined) { | |
enableLog && console.log('%c ***************** Starting the creation of the database in the browser ***************** ', 'background: #222; color: #bada55'); | |
self.db().transaction(function (tx) { | |
for (var i = 0; i < window.queries.length; i++) { | |
enableLog && console.log(window.queries[i]); | |
tx.executeSql(queries[i]); | |
} | |
}, function (error) { | |
deferred.reject(error); | |
}, function () { | |
enableLog && console.log('%c ***************** Completing the creation of the database in the browser ***************** ', 'background: #222; color: #bada55'); | |
deferred.resolve("OK"); | |
}); | |
} | |
else { | |
deferred.resolve("OK"); | |
} | |
return deferred.promise; | |
}; | |
self.executeSql = function (query, parameters) { | |
return $cordovaSQLite.execute(self.db(), query, parameters); | |
}; | |
}]); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
You can see my new starter template that include this! 👯 https://github.com/jdnichollsc/Ionic-Starter-Template