cash_balance.rb 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  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. puts Parameters
  10. puts Parameters
  11. SOURCE_ENUM = [["提货券充值佣金", "balance_benefit"],
  12. ["商品佣金", "product_benefit"],
  13. ["店长申请", "shop_benefit"],
  14. ["好友购物佣金", "fx_product_benefit"],
  15. ["提现", "take_cash"],
  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. @total=0
  45. LIST = []
  46. def get_happen_total
  47. unless LIST.include?(self.id)
  48. LIST.append(self.id)
  49. end
  50. # list.append(self.id)
  51. total = CashBalance.where(id:LIST).sum("count")
  52. return total
  53. end
  54. def profit_state
  55. if self.trade_no.length>0
  56. if self.profit_flag
  57. return "分账已完成"
  58. else
  59. return "分账处理中"
  60. end
  61. else
  62. return "--"
  63. end
  64. end
  65. rails_admin do
  66. navigation_label '资金管理'
  67. weight -920
  68. list do
  69. items_per_page 10
  70. filters [:id, :source, :wx_user, :relate_id, :created_at]
  71. # include_all_fields
  72. field :id
  73. field :wx_user
  74. field :wx_uid
  75. field :count do
  76. formatted_value do
  77. value.to_f / 100.0
  78. end
  79. end
  80. field :remain_sum do
  81. formatted_value do
  82. value.to_f / 100.0
  83. end
  84. end
  85. field :relate_id
  86. field :source, :enum do
  87. enum do
  88. SOURCE_ENUM
  89. end
  90. end
  91. field :remark
  92. field :profit_state
  93. field :created_at
  94. # field :updated_at
  95. field :get_happen_total do
  96. formatted_value do
  97. value.to_f / 100.0
  98. end
  99. end
  100. end
  101. show do
  102. field :wx_uid
  103. field :count do
  104. formatted_value do # used in form views
  105. value.to_f / 100.0
  106. end
  107. end
  108. field :remain_sum do
  109. formatted_value do
  110. value.to_f / 100.0
  111. end
  112. end
  113. field :source, :enum do
  114. enum do
  115. SOURCE_ENUM
  116. end
  117. end
  118. field :relate_id
  119. field :remark
  120. field :profit_state
  121. field :created_at
  122. end
  123. edit do
  124. field :wx_uid
  125. field :count do
  126. label "变动金额,单位(分)"
  127. end
  128. field :relate_id
  129. field :source, :enum do
  130. enum do
  131. SOURCE_ENUM
  132. end
  133. end
  134. field :remark
  135. end
  136. end
  137. end