Monday, May 20, 2024
 Popular · Latest · Hot · Upcoming
52
rated 0 times [  53] [ 1]  / answers: 1 / hits: 19612  / 10 Years ago, thu, december 4, 2014, 12:00:00

I have Cordova and Ionic based mobile application. On the default page which is loaded after the start of the application is need to work with SQLLite plugin.



https://github.com/brodysoft/Cordova-SQLitePlugin



Problem is that view contains



ng-init=setData()


Which is calling the controller method where is worked with SQL Lite plugin. And because of the the method is called before the deviceready event is not initialized (plugin can be initialized only after deviceready event).



So I tried this workaround:



.run(function($ionicPlatform) {
$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);
db = window.sqlitePlugin.openDatabase({name:callplanner});
}


But this not working for me.



So i tried second solution:



.factory('cordova', function () {
return {
test: function(){
document.addEventListener(deviceready, this.ready, false);
},
ready: function(){
alert(Ready);
db = window.sqlitePlugin.openDatabase({name:callplanner});
}

}
})


and in controller init i tried:



cordova.test();


But this is not working to (devicereadfy is fired after ng-init).



After that i found this article:



http://java.dzone.com/articles/ionic-and-cordovas-deviceready



But i did not understand how to put splash screen before app is ready and how to set timeout.



Have somebody idea how can I solve this problem?



Many Thanks for any advice or help.


More From » android

 Answers
43

You need to invert this, first you handle the cordova deviceready event and then you start the angularjs app. Like this:




  1. First remove the the ng-app attribute from the html/body tag


  2. Start the angular app after the devireready:



    <script>
    document.addEventListener('deviceready', function() {
    angular.bootstrap(document, ['YourAppName']);
    }, false);
    var YourAppName = angular.module('YourAppName', []);
    </script>



Similar questions:




[#68586] Tuesday, December 2, 2014, 10 Years  [reply] [flag answer]
Only authorized users can answer the question. Please sign in first, or register a free account.
jenamackennac

Total Points: 304
Total Questions: 110
Total Answers: 107

Location: Ecuador
Member since Thu, Jun 4, 2020
4 Years ago
jenamackennac questions
Fri, Feb 18, 22, 00:00, 2 Years ago
Wed, Apr 21, 21, 00:00, 3 Years ago
Thu, Apr 1, 21, 00:00, 3 Years ago
Tue, Feb 2, 21, 00:00, 3 Years ago
;