cash_balance.rb 3.6 KB

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