promotion.rb 6.0 KB

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