balanceLog.js 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302
  1. define(['$', 'template', 'IScroll', 'user', 'product', 'native', 'config', 'address', 'api'], function ($, template, IScroll, user, product, native, config, address, api) {
  2. var backHash;
  3. var myDate = new Date();
  4. var year = myDate.getFullYear();
  5. var month = myDate.getMonth();
  6. var BalancsView=true;
  7. function back (event) {
  8. event.preventDefault();
  9. $(document).trigger('spa:navigate', {
  10. hash: backHash,
  11. pushData: {
  12. dontNeedReload: true
  13. }
  14. });
  15. }
  16. function payCharge(a,b,time){
  17. var c=parseInt($(a).text());
  18. if(b){
  19. if(time=='month'){
  20. if(c<12){
  21. c++;
  22. }
  23. }else {
  24. c++;
  25. }
  26. }else {
  27. if(c>1){
  28. c--;
  29. }
  30. }
  31. $(a).text(c)
  32. }
  33. /* 重置页面时调用,重新生成IScroll */
  34. function fixScroll(pageData,type) {
  35. var id;
  36. switch (type) {
  37. case 1:
  38. id='#productDescScroll';
  39. break;
  40. case 2:
  41. id='#orderContainer';
  42. break;
  43. }
  44. if (pageData.scroll) {
  45. pageData.scroll.destroy();
  46. pageData.scroll = null;
  47. }
  48. var placeOrderScroll;
  49. setTimeout(function () {
  50. pageData.scroll = new IScroll(id);
  51. }, 100);
  52. }
  53. function select(pageData,view){
  54. var type = $('.control-item.active').data('order-type');
  55. var startTime = $('.year-span').text()+'-'+$('.month-span').text()+'-01';
  56. var endTime = $('.year-span').text()+'-'+$('.month-span').text()+'-30';
  57. $('.type-container', view).hide();
  58. switch (type) {
  59. case 1:
  60. $('#descContainer').show();
  61. api.getBalanceLog({
  62. id: user.id,
  63. start_time:startTime,
  64. end_time:endTime
  65. },function(res){
  66. var balanceLog = res.message;
  67. // 判断余额使用记录是否为空
  68. var j=0;
  69. for(var i in balanceLog) {
  70. if (balanceLog[i].amount > 0 && balanceLog[i].memo !== "微信下订单" && balanceLog[i].memo !== "下订单") {
  71. j++;
  72. }
  73. }
  74. if(j != 0){
  75. BalancsView=false;
  76. } else {
  77. BalancsView=true;
  78. }
  79. if (!cachePageData.massage) {
  80. var tpl = template('balanceLog/productDescScroll', {
  81. balanceLog: balanceLog,
  82. BalancsView:BalancsView,
  83. });
  84. $('.pad-b-1', view).html(tpl);
  85. setTimeout(function () {
  86. pageData.scroll = new IScroll('#productDescScroll');
  87. }, 100);
  88. }
  89. });
  90. break;
  91. case 2:
  92. $('#reviewContainer').show();
  93. api.getBalanceLog({
  94. id: user.id,
  95. start_time:startTime,
  96. end_time:endTime
  97. },function(res){
  98. var balanceLog = res.message;
  99. // 判断余额使用记录是否为空
  100. var j=0;
  101. for(var i in balanceLog){
  102. if(balanceLog[i].memo=="微信下订单" || balanceLog[i].memo=="下订单" || balanceLog[i].amount<0 ){
  103. j++;
  104. }
  105. }
  106. if(j != 0){
  107. BalancsView=false;
  108. }else {
  109. BalancsView=true;
  110. }
  111. if (!cachePageData.massage) {
  112. var tpl = template('balanceLog/orderContainer', {
  113. balanceLog: balanceLog,
  114. BalancsView:BalancsView,
  115. });
  116. $('.list-content', view).html(tpl);
  117. setTimeout(function () {
  118. pageData.scroll = new IScroll('#orderContainer');
  119. }, 100);
  120. }
  121. });
  122. break;
  123. }
  124. }
  125. var cachePageData = {}; //page内部的数据传递
  126. return {
  127. title: '余额明细',
  128. body: '',
  129. init: function (pageData, dtd) {
  130. /* this是什么? */
  131. var $view = this;
  132. var $doc = $(document);
  133. // 返回
  134. $view.on('swipeRight', function (event) {
  135. back.call(this, event);
  136. });
  137. $.newTouch('.back-button', function (event) {
  138. back.call(this, event);
  139. }, $view);
  140. $view.on('tapBackButton', function (event) {
  141. back.call(this, event);
  142. });
  143. //tab切换
  144. $.newTouch('.order-type-control .control-item', function (event) {
  145. event.preventDefault();
  146. select(pageData,$view);
  147. var type = $('.control-item.active').data('order-type');
  148. fixScroll(pageData,type);
  149. }, $view);
  150. // 切换时间
  151. $.newTouch('.time-year', function (event) {
  152. event.preventDefault();
  153. if($('.o2o-modal').css('display')=='none'){
  154. $('.o2o-modal').css('display','block')
  155. }
  156. $('.modal-box-year').text($('.year-span').text());
  157. $('.modal-box-month').text($('.month-span').text());
  158. }, $view);
  159. // 加减
  160. $.newTouch('.btn-year-add',function(event){
  161. event.preventDefault();
  162. payCharge($('.modal-box-year'),true,'year');
  163. },$view);
  164. $.newTouch('.btn-year-sub',function(event){
  165. event.preventDefault();
  166. payCharge($('.modal-box-year'),false,'year');
  167. },$view);
  168. $.newTouch('.btn-month-add',function(event){
  169. event.preventDefault();
  170. payCharge($('.modal-box-month'),true,'month');
  171. },$view);
  172. $.newTouch('.btn-month-sub',function(event){
  173. event.preventDefault();
  174. payCharge($('.modal-box-month'),false,'month');
  175. },$view);
  176. // 取消
  177. $.newTouch('.cancel',function(event){
  178. event.preventDefault();
  179. $('.o2o-modal').css('display','none')
  180. },$view);
  181. // 确定
  182. $.newTouch('.determine',function(event){
  183. event.preventDefault();
  184. $('.o2o-modal').css('display','none')
  185. $('.year-span').text($('.modal-box-year').text());
  186. $('.month-span').text($('.modal-box-month').text());
  187. select(pageData,$view);
  188. },$view);
  189. // 充值
  190. $.newTouch('.btn-recharge',function (event) {
  191. event.preventDefault();
  192. $doc.trigger('spa:navigate', {
  193. hash: 'recharge',
  194. pushData: {
  195. needReload: true,
  196. backHash: 'balanceLog'
  197. }
  198. });
  199. },$view);
  200. // IScroll
  201. $.newTouch('.arrow',function (event){
  202. event.preventDefault();
  203. var type = $('.control-item.active').data('order-type');
  204. // fixScroll(pageData,type);
  205. },$view);
  206. // 扩展显示
  207. $.newTouch('.recharge-details',function (event) {
  208. event.preventDefault();
  209. $(this).children('div.arrow').toggleClass('active');
  210. if($(this).children('div.extended').css('display')=='none'){
  211. $(this).children('div.extended').css('height','4rem').css('display','block');
  212. $(this).siblings().children('div.extended').css('height','0').css('display','none');
  213. $(this).siblings().children('div.arrow').removeClass('active');
  214. }else {
  215. $(this).children('div.extended').css('height','0').css('display','none');
  216. $(this).children('div.arrow-block').addClass('arrow')
  217. }
  218. },$view);
  219. dtd.resolve();
  220. },
  221. beforeopen: function (pageData, dtd) {
  222. /*获取上一页跳转的路由名称*/
  223. var pushData = pageData.pushData;
  224. backHash = pushData.backHash ? pushData.backHash : '';
  225. var $view = this;
  226. var $doc = $(document);
  227. var startTime = year+'-'+(month+1)+'-01';
  228. var endTime = year+'-'+(month+1)+'-30';
  229. // 获取余额明细
  230. api.getBalanceLog({
  231. id: user.id,
  232. start_time:startTime,
  233. end_time:endTime
  234. }, function (res) {
  235. if (res.success) {
  236. var balanceLog = res.message;
  237. // 判断余额使用记录是否为空
  238. var j = 0;
  239. for(var i in balanceLog){
  240. if(balanceLog[i].amount>0 && balanceLog[i].memo!=="微信下订单" && balanceLog[i].memo!=="下订单"){
  241. j++;
  242. }
  243. }
  244. if(j != 0){
  245. BalancsView=false;
  246. } else {
  247. BalancsView=true;
  248. }
  249. if (!cachePageData.massage) {
  250. var tpl = template('balanceLog/index', {
  251. balanceLog: balanceLog,
  252. year: year,
  253. BalancsView:BalancsView,
  254. month: month,
  255. title:'余额明细',
  256. userBalance: user.balance,
  257. showNavBar: !config.isWX && !config.isChubao,
  258. });
  259. $('.spa-page-body', $view).html(tpl);
  260. setTimeout(function () {
  261. pageData.scroll = new IScroll('#productDescScroll');
  262. }, 100);
  263. }
  264. } else if (res.error) {
  265. console.log('失败!');
  266. }
  267. });
  268. dtd.resolve();
  269. },
  270. afteropen: function (pageData, dtd) {
  271. var $view = this;
  272. var $doc = $(document);
  273. dtd.resolve();
  274. },
  275. beforeclose: function (pageData, dtd) {
  276. dtd.resolve();
  277. }
  278. }
  279. })