cash_balance.rb 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. # encoding:utf-8
  2. class CashBalance < ActiveRecord::Base
  3. has_paper_trail
  4. self.table_name = "cash_balances"
  5. belongs_to :wx_user, :foreign_key => :wx_uid
  6. validates_presence_of :wx_uid, :count, :relate_id, :source
  7. attr_accessor :remain_sum,:get_happen_total
  8. #after_find :get_happen_total
  9. SOURCE_ENUM = [["提货券充值佣金", "balance_benefit"],
  10. ["商品佣金", "product_benefit"],
  11. ["店长申请", "shop_benefit"],
  12. ["好友购物佣金", "fx_product_benefit"],
  13. ["提现", "take_cash"],
  14. ["员工订餐", "order_food"],
  15. ["取消订餐", "cancel_food"],
  16. ["拒绝提现", "extract_reject"],
  17. ["销售奖金","sale_reward_monthly"],
  18. ["商品代销金", "product_sale"],
  19. ["助农项目", "project_invest"],
  20. ["充值","recharge"],
  21. ["预定活动","reserve_act_return"],
  22. ["项目回款","receive_buyback"],
  23. ["扣款","deduct"],
  24. ["借款","loan"],
  25. ["项目退款","project_refund"],
  26. ["商品退款","product_refund"],
  27. ["商品部分退款","product_part_refund"],
  28. ["冲正","correct"],
  29. ["项目放款","project_loan"],
  30. ["货款","good_payment"],
  31. ["活动退款","dollar_win_return"],
  32. ["活动报名","dollar_win"],
  33. ["佣金转提货券","cash_to_balance"],
  34. ["佣金自动分账","cash_to_profit"],
  35. ]
  36. def remain_sum
  37. b = CashBalance.where("wx_uid = ? and id < ?", self.wx_uid, self.id).last
  38. if !b.blank?
  39. return self.count + b.remain_sum
  40. else
  41. return self.count
  42. end
  43. end
  44. # puts Rails.request.request_uri
  45. @total=0
  46. LIST = []
  47. def get_happen_total
  48. unless LIST.include?(self.id)
  49. LIST.append(self.id)
  50. end
  51. # list.append(self.id)
  52. total = CashBalance.where(id:LIST).sum("count")
  53. return total
  54. end
  55. def profit_state
  56. if self.trade_no.length>0
  57. if self.profit_flag
  58. return "分账已完成"
  59. else
  60. return "分账处理中"
  61. end
  62. else
  63. return "--"
  64. end
  65. end
  66. rails_admin do
  67. navigation_label '资金管理'
  68. weight -920
  69. list do
  70. items_per_page 10
  71. filters [:id, :source, :wx_user, :relate_id, :created_at]
  72. # include_all_fields
  73. field :id
  74. field :wx_user
  75. field :wx_uid
  76. field :count do
  77. formatted_value do
  78. value.to_f / 100.0
  79. end
  80. end
  81. field :remain_sum do
  82. formatted_value do
  83. value.to_f / 100.0
  84. end
  85. end
  86. field :relate_id
  87. field :source, :enum do
  88. enum do
  89. SOURCE_ENUM
  90. end
  91. end
  92. field :remark
  93. field :profit_state
  94. field :created_at
  95. # field :updated_at
  96. =begin
  97. field :get_happen_total do
  98. formatted_value do
  99. value.to_f / 100.0
  100. end
  101. end
  102. =end
  103. end
  104. show do
  105. field :wx_uid
  106. field :count do
  107. formatted_value do # used in form views
  108. value.to_f / 100.0
  109. end
  110. end
  111. field :remain_sum do
  112. formatted_value do
  113. value.to_f / 100.0
  114. end
  115. end
  116. field :source, :enum do
  117. enum do
  118. SOURCE_ENUM
  119. end
  120. end
  121. field :relate_id
  122. field :remark
  123. field :profit_state
  124. field :created_at
  125. end
  126. edit do
  127. field :wx_uid
  128. field :count do
  129. label "变动金额,单位(分)"
  130. end
  131. field :relate_id
  132. field :source, :enum do
  133. enum do
  134. SOURCE_ENUM
  135. end
  136. end
  137. field :remark
  138. end
  139. end
  140. end