promotion.rb 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. class Promotion < ActiveRecord::Base
  2. has_paper_trail
  3. self.table_name = "promotions"
  4. validates :begin_time,:end_time,:name,:order_type, presence: true
  5. has_and_belongs_to_many :depart_record
  6. def prodcut1
  7. prd1 = Product.where("id = ?", self.prod1).first
  8. if !prd1.blank?
  9. return format("%s-%d",prd1.name,self.nums1)
  10. else
  11. return "--"
  12. end
  13. end
  14. def prodcut2
  15. prd1 = Product.where("id = ?", self.prod2).first
  16. if !prd1.blank?
  17. return format("%s-%d",prd1.name,self.nums2)
  18. else
  19. return "--"
  20. end
  21. end
  22. def prodcut3
  23. prd1 = Product.where("id = ?", self.prod3).first
  24. if !prd1.blank?
  25. return format("%s-%d",prd1.name,self.nums3)
  26. else
  27. return "--"
  28. end
  29. end
  30. def prodcut4
  31. prd1 = Product.where("id = ?", self.prod4).first
  32. if !prd1.blank?
  33. return format("%s-%d",prd1.name,self.nums4)
  34. else
  35. return "--"
  36. end
  37. end
  38. def prodcut5
  39. prd1 = Product.where("id = ?", self.prod5).first
  40. if !prd1.blank?
  41. return format("%s-%d",prd1.name,self.nums5)
  42. else
  43. return "--"
  44. end
  45. end
  46. def send_prodcut1
  47. prd1 = Product.where("id = ?", self.send_prod1).first
  48. if !prd1.blank?
  49. return format("%s-%d",prd1.name,self.send_nums1)
  50. else
  51. return "--"
  52. end
  53. end
  54. def send_prodcut2
  55. prd1 = Product.where("id = ?", self.send_prod2).first
  56. if !prd1.blank?
  57. return format("%s-%d",prd1.name,self.send_nums2)
  58. else
  59. return "--"
  60. end
  61. end
  62. def send_prodcut3
  63. prd1 = Product.where("id = ?", self.send_prod3).first
  64. if !prd1.blank?
  65. return format("%s-%d",prd1.name,self.send_nums3)
  66. else
  67. return "--"
  68. end
  69. end
  70. def send_prodcut4
  71. prd1 = Product.where("id = ?", self.send_prod4).first
  72. if !prd1.blank?
  73. return format("%s-%d",prd1.name,self.send_nums4)
  74. else
  75. return "--"
  76. end
  77. end
  78. def send_prodcut5
  79. prd1 = Product.where("id = ?", self.send_prod5).first
  80. if !prd1.blank?
  81. return format("%s-%d",prd1.name,self.send_nums5)
  82. else
  83. return "--"
  84. end
  85. end
  86. TYPE_ENUM = [["普通",0],["秒杀",1],["店长",2]]
  87. rails_admin do
  88. navigation_label '促销管理'
  89. weight -100
  90. list do
  91. filters [:id,:name,:begin_time,:end_time]
  92. field :id
  93. field :name
  94. field :begin_time
  95. field :end_time
  96. field :is_first
  97. field :is_more
  98. field :depart_record
  99. field :order_type, :enum do
  100. filterable true
  101. enum do
  102. TYPE_ENUM
  103. end
  104. end
  105. field :min_total do
  106. label "订单最小金额(元)"
  107. formatted_value do # used in form views
  108. value.to_f / 100
  109. end
  110. end
  111. field :max_total do
  112. label "订单最大金额(元)"
  113. formatted_value do # used in form views
  114. value.to_f / 100
  115. end
  116. end
  117. field :prodcut1
  118. field :prodcut2
  119. field :prodcut3
  120. field :prodcut4
  121. field :prodcut5
  122. field :send_prodcut1
  123. field :send_prodcut2
  124. field :send_prodcut3
  125. field :send_prodcut4
  126. field :send_prodcut5
  127. field :cash do
  128. label "代办金(元)"
  129. formatted_value do # used in form views
  130. value.to_f / 100
  131. end
  132. end
  133. field :cent do
  134. label "积分(元)"
  135. formatted_value do # used in form views
  136. value.to_f / 100
  137. end
  138. end
  139. field :is_enable
  140. field :created_at
  141. end
  142. show do
  143. field :id
  144. field :name
  145. field :begin_time
  146. field :end_time
  147. field :is_first
  148. field :is_more
  149. field :depart_record
  150. field :order_type, :enum do
  151. filterable true
  152. enum do
  153. TYPE_ENUM
  154. end
  155. end
  156. field :min_total do
  157. label "订单最小金额(元)"
  158. formatted_value do # used in form views
  159. value.to_f / 100
  160. end
  161. end
  162. field :max_total do
  163. label "订单最大金额(元)"
  164. formatted_value do # used in form views
  165. value.to_f / 100
  166. end
  167. end
  168. field :prodcut1
  169. field :prodcut2
  170. field :prodcut3
  171. field :prodcut4
  172. field :prodcut5
  173. field :send_prodcut1
  174. field :send_prodcut2
  175. field :send_prodcut3
  176. field :send_prodcut4
  177. field :send_prodcut5
  178. field :is_enable
  179. field :cash
  180. field :cent
  181. field :created_at
  182. field :created_at
  183. field :updated_at
  184. end
  185. edit do
  186. field :name
  187. field :begin_time
  188. field :end_time
  189. field :is_first
  190. field :is_more
  191. field :depart_record
  192. field :order_type, :enum do
  193. filterable true
  194. enum do
  195. TYPE_ENUM
  196. end
  197. end
  198. field :min_total
  199. field :max_total
  200. field :prod1
  201. field :nums1
  202. field :prod2
  203. field :nums2
  204. field :prod3
  205. field :nums3
  206. field :prod4
  207. field :nums4
  208. field :prod5
  209. field :nums5
  210. field :send_prod1
  211. field :send_nums1
  212. field :send_prod2
  213. field :send_nums2
  214. field :send_prod3
  215. field :send_nums3
  216. field :send_prod4
  217. field :send_nums4
  218. field :send_prod5
  219. field :send_nums5
  220. field :cash
  221. field :cent
  222. field :is_enable
  223. end
  224. end
  225. end