utils.factory.js 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  1. angular.module('odoo')
  2. /**
  3. * -----------------------------------------------------------------------------
  4. * Description: Native SQL util instructions
  5. * -----------------------------------------------------------------------------
  6. */
  7. .factory('sqlFactory', function () {
  8. /**
  9. *
  10. */
  11. var count = function (tableName, success, error) {
  12. var sql = 'SELECT COUNT(*) AS total FROM ' + tableName;
  13. db.executeSql(sql, [], function (result) {
  14. success(result.rows.item(0).total);
  15. }, function (err) {
  16. error(err);
  17. });
  18. };
  19. // Execute native SQL SELECT instruction
  20. var select = function (tableName, success, error) {
  21. var sql = 'SELECT * FROM ' + tableName;
  22. db.executeSql(sql, [], function (result) {
  23. success(result.rows);
  24. }, function (err) {
  25. error(err);
  26. });
  27. };
  28. // Execute native SQL SELECT instruction with a constraint
  29. var selectByConstraint = function (tableName, constraint, success, error) {
  30. var sql = 'SELECT * FROM ' + tableName + ' WHERE ' + constraint;
  31. db.executeSql(sql, [], function (result) {
  32. success(result.rows);
  33. }, function (err) {
  34. error(err);
  35. });
  36. };
  37. // Execute native SQL SELECT instruction with count instruction
  38. var count = function (tableName, success, error) {
  39. var sql = 'SELECT COUNT(*) AS total FROM ' + tableName;
  40. db.executeSql(sql, [], function (result) {
  41. success(result.rows.item(0).total);
  42. }, function (err) {
  43. error(err);
  44. });
  45. };
  46. return {
  47. select: select,
  48. selectByConstraint: selectByConstraint,
  49. count: count
  50. }
  51. })
  52. /**
  53. * -----------------------------------------------------------------------------
  54. * Description: Get user configuration from local database
  55. * -----------------------------------------------------------------------------
  56. */
  57. .factory('configFactory', function (sqlFactory) {
  58. return function (success, error) {
  59. sqlFactory.select('user', function (users) {
  60. if (users.length == 0) {
  61. success(0);
  62. } else if (users.length == 1) {
  63. success(users.item(0));
  64. } else {
  65. var configs = [];
  66. for (var i = 0; i < users.length; i++) {
  67. configs.push(users.item(i))
  68. }
  69. success(configs);
  70. }
  71. }, function (err) {
  72. error(err);
  73. });
  74. };
  75. })
  76. /**
  77. * -----------------------------------------------------------------------------
  78. * Description: Async loop util v2
  79. * -----------------------------------------------------------------------------
  80. */
  81. .factory('asyncLoopFactory', function () {
  82. return function (iterations, func, callback) {
  83. var index = 0;
  84. var done = false;
  85. var loop = {
  86. next: function () {
  87. if (done) {
  88. return;
  89. }
  90. if (index < iterations) {
  91. index++;
  92. func(loop);
  93. } else {
  94. done = true;
  95. callback();
  96. }
  97. },
  98. iteration: function () {
  99. return index - 1;
  100. },
  101. break: function () {
  102. done = true;
  103. callback();
  104. }
  105. };
  106. loop.next();
  107. return loop;
  108. }
  109. })
  110. /**
  111. * -----------------------------------------------------------------------------
  112. * Description: Native camera manager
  113. * -----------------------------------------------------------------------------
  114. */
  115. .factory('cameraFactory', function ($cordovaCamera) {
  116. // Take a picture using native camera
  117. var takePicture = function (success, error) {
  118. var options = {
  119. quality: 75,
  120. destinationType: Camera.DestinationType.DATA_URL,
  121. sourceType: Camera.PictureSourceType.CAMERA,
  122. allowEdit: true,
  123. encodingType: Camera.EncodingType.JPEG,
  124. targetWidth: 300,
  125. targetHeight: 300,
  126. popoverOptions: CameraPopoverOptions,
  127. saveToPhotoAlbum: false,
  128. correctOrientation: true
  129. };
  130. $cordovaCamera.getPicture(options).then(function (imageData) {
  131. success(imageData);
  132. }, function (err) {
  133. error(err);
  134. });
  135. };
  136. return {
  137. takePicture: takePicture
  138. }
  139. })
  140. /**
  141. * -----------------------------------------------------------------------------
  142. * Description: Native contacts manager
  143. * -----------------------------------------------------------------------------
  144. */
  145. .factory('contactFactory', function ($cordovaContacts) {
  146. // Save customer information to device contacts
  147. var save = function (customer, success, error) {
  148. if (!customer.mobile && !customer.phone && !customer.email) {
  149. error();
  150. return;
  151. }
  152. var contact = {
  153. name: {
  154. givenName: customer.name,
  155. familyName: '',
  156. formatted: ''
  157. },
  158. nickname: '',
  159. phoneNumbers: [
  160. {
  161. value: customer.phone,
  162. type: 'phone'
  163. },
  164. {
  165. value: customer.mobile,
  166. type: 'mobile'
  167. }
  168. ],
  169. emails: [
  170. {
  171. value: customer.email,
  172. type: 'home'
  173. }
  174. ],
  175. addresses: [
  176. {
  177. type: 'home',
  178. formatted: '',
  179. streetAddress: customer.street,
  180. locality: customer.city,
  181. region: '',
  182. postalCode: '',
  183. country: 'Paraguay'
  184. }
  185. ],
  186. ims: null,
  187. organizations: null,
  188. birthday: null,
  189. note: null,
  190. photos: null,
  191. categories: null,
  192. urls: null
  193. };
  194. $cordovaContacts.save(contact).then(function (result) {
  195. success(result);
  196. }, function (err) {
  197. error(err);
  198. });
  199. };
  200. return {
  201. save: save
  202. }
  203. });