app.js 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. angular.module('odoo',['ionic', 'ngCordova', 'xml-rpc', 'jett.ionic.filter.bar'])
  2. .run(function($ionicPlatform) {
  3. $ionicPlatform.ready(function() {
  4. if (window.cordova && window.cordova.plugins.Keyboard) {
  5. cordova.plugins.Keyboard.hideKeyboardAccessoryBar(true);
  6. cordova.plugins.Keyboard.disableScroll(true);
  7. }
  8. if (window.StatusBar) {
  9. StatusBar.overlaysWebView(false);
  10. StatusBar.backgroundColorByHexString('#387ef5');
  11. }
  12. db = window.sqlitePlugin.openDatabase({ name: 'odoo.db', location: 'default' });
  13. db.executeSql("CREATE TABLE IF NOT EXISTS 'user' (\n\
  14. 'id' INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,\n\
  15. 'remote_id' INTEGER DEFAULT 0,\n\
  16. 'host' VARCHAR(35) DEFAULT 0,\n\
  17. 'port' INTEGER DEFAULT 0,\n\
  18. 'database' VARCHAR(35) DEFAULT NULL,\n\
  19. 'username' VARCHAR(35) DEFAULT NULL,\n\
  20. 'password' VARCHAR(35) DEFAULT NULL)");
  21. db.executeSql("CREATE TABLE IF NOT EXISTS 'partner' (\n\
  22. 'id' INTEGER DEFAULT NULL PRIMARY KEY AUTOINCREMENT,\n\
  23. 'remote_id' INTEGER DEFAULT 0,\n\
  24. 'modified' INTEGER DEFAULT 0,\n\
  25. 'modifiedDate' TEXT DEFAULT CURRENT_TIMESTAMP,\n\
  26. 'name' VARCHAR(35) DEFAULT NULL,\n\
  27. 'city' VARCHAR(35) DEFAULT NULL,\n\
  28. 'mobile' VARCHAR(20) DEFAULT NULL,\n\
  29. 'phone' VARCHAR(20) DEFAULT NULL,\n\
  30. 'fax' VARCHAR(20) DEFAULT NULL,\n\
  31. 'email' VARCHAR(100) DEFAULT NULL,\n\
  32. 'street' VARCHAR(35) DEFAULT NULL,\n\
  33. 'street2' VARCHAR(35) DEFAULT NULL,\n\
  34. 'image_medium' BLOB DEFAULT NULL,\n\
  35. 'image_small' BLOB DEFAULT NULL,\n\
  36. 'comment' VARCHAR(160) DEFAULT NULL,\n\
  37. 'customer' INTEGER DEFAULT 0,\n\
  38. 'employee' INTEGER DEFAULT 0,\n\
  39. 'is_company' INTEGER DEFAULT 0,\n\
  40. 'debit' INTEGER DEFAULT 0,\n\
  41. 'debit_limit' INTEGER DEFAULT 0,\n\
  42. 'opportunity_count' INTEGER DEFAULT 0,\n\
  43. 'contracts_count' INTEGER DEFAULT 0,\n\
  44. 'journal_item_count' INTEGER DEFAULT 0,\n\
  45. 'meeting_count' INTEGER DEFAULT 0,\n\
  46. 'phonecall_count' INTEGER DEFAULT 0,\n\
  47. 'sale_order_count' INTEGER DEFAULT NULL,\n\
  48. 'total_invoiced' INTEGER DEFAULT NULL);");
  49. db.executeSql("CREATE TABLE IF NOT EXISTS 'lead' (\n\
  50. 'id' INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,\n\
  51. 'remote_id' INTEGER DEFAULT 0,\n\
  52. 'modified' INTEGER DEFAULT 0,\n\
  53. 'modifiedDate' TEXT DEFAULT CURRENT_TIMESTAMP,\n\
  54. 'name' VARCHAR(35) DEFAULT NULL,\n\
  55. 'description' VARCHAR(100) DEFAULT NULL,\n\
  56. 'contact_name' VARCHAR(100) DEFAULT NULL,\n\
  57. 'phone' VARCHAR(20) DEFAULT NULL,\n\
  58. 'mobile' VARCHAR(20) DEFAULT NULL,\n\
  59. 'fax' VARCHAR(20) DEFAULT NULL,\n\
  60. 'street' VARCHAR(35) DEFAULT NULL,\n\
  61. 'street2' VARCHAR(35) DEFAULT NULL,\n\
  62. 'meeting_count' INTEGER DEFAULT 0,\n\
  63. 'message_bounce' INTEGER DEFAULT 0,\n\
  64. 'planned_cost' INTEGER DEFAULT 0,\n\
  65. 'planned_revenue' INTEGER DEFAULT 0,\n\
  66. 'priority' INTEGER DEFAULT 0,\n\
  67. 'probability' INTEGER DEFAULT 0,\n\
  68. 'type' VARCHAR(20) DEFAULT NULL,\n\
  69. 'partner_id' INTEGER DEFAULT 0);");
  70. });
  71. })
  72. .config(function($stateProvider, $urlRouterProvider, $ionicFilterBarConfigProvider) {
  73. $stateProvider
  74. .state('app', {
  75. url: '/app',
  76. abstract: true,
  77. templateUrl: 'templates/menu.html'
  78. })
  79. .state('app.main', {
  80. url: 'app/main',
  81. views: {
  82. 'content': {
  83. templateUrl: 'templates/main.html',
  84. controller: 'MainController'
  85. }
  86. }
  87. })
  88. .state('app.sales', {
  89. url: 'app/sales',
  90. views: {
  91. 'content': {
  92. templateUrl: 'templates/sales/sales.html',
  93. controller: 'SaleController'
  94. }
  95. }
  96. })
  97. .state('app.customers', {
  98. url: 'app/customers',
  99. views: {
  100. 'content': {
  101. templateUrl: 'templates/sales/customers.html',
  102. controller: 'CustomersController'
  103. }
  104. }
  105. })
  106. .state('app.leads', {
  107. url: 'app/leads',
  108. views: {
  109. 'content': {
  110. templateUrl: 'templates/sales/leads.html',
  111. controller: 'LeadsController'
  112. }
  113. }
  114. })
  115. .state('app.preferences', {
  116. url: 'app/preferences',
  117. views: {
  118. 'content': {
  119. templateUrl: 'templates/preferences.html',
  120. controller: 'PreferencesController'
  121. }
  122. }
  123. })
  124. .state('configuration', {
  125. url: '/configuration',
  126. templateUrl: 'templates/configuration.html',
  127. controller: 'ConfigurationController'
  128. });
  129. $urlRouterProvider.otherwise('/configuration');
  130. $ionicFilterBarConfigProvider.theme('positive');
  131. $ionicFilterBarConfigProvider.placeholder('Buscar');
  132. });