ShopGoods.php 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248
  1. <?php
  2. namespace common\models;
  3. /**
  4. * This is the model class for table "{{%SHOP_GOODS}}".
  5. *
  6. * @property string $ID
  7. * @property string $GOODS_NAME 商品名称
  8. * @property string $CATE_ID 所属分类ID
  9. * @property string $TYPE 商品来源
  10. * @property string $GIFT_TYPE 商品类型
  11. * @property string $CATEGORY_TYPE 商品分类
  12. * @property string $SELL_TYPE 允许购买方式
  13. * @property int $GOODS_NO 商品编号
  14. * @property string $UNIT 单位
  15. * @property string $COVER 商品封面
  16. * @property int $IMAGES 商品图片
  17. * @property string $CONTENT 商品内容
  18. * @property string $SELL_PRICE 销售价格
  19. * @property string $SELL_PRICE_STANDARD 标准价格
  20. * @property string $MARKET_PRICE 市场价格
  21. * @property int $PRICE_PV 价格PV
  22. * @property int $POINT 兑换积分
  23. * @property int $STORE_NUMS 库存
  24. * @property int $IS_DEL 是否删除
  25. * @property int $CREATED_AT 创建时间
  26. * @property int $UPDATED_AT 更新时间
  27. * @property int $DELETED_AT 删除时间
  28. * @property int $STATUS 状态
  29. * @property string $SORT 排序
  30. */
  31. class ShopGoods extends \common\components\ActiveRecord
  32. {
  33. const SALE_TYPE = [
  34. 1 => [
  35. 'id' => 1,
  36. 'name' => 'Balance payment', //余额购买
  37. 'label' => 'cash',
  38. ],
  39. // 2 => [
  40. // 'id' => 2,
  41. // 'name' => '复消兑换',
  42. // ],
  43. 3 => [
  44. 'id' => 3,
  45. 'name' => 'Bonus points', //兑换点数
  46. 'label' => 'exchange',
  47. ],
  48. 4 => [
  49. 'id' => 4,
  50. 'name' => 'Travel bonus', //旅游积分
  51. 'label' => 'travel_points',
  52. ],
  53. 5 => [
  54. 'id' => 5,
  55. 'name' => 'Car bonus',//名车积分
  56. 'label' => 'car_points',
  57. ],
  58. 6 => [
  59. 'id' => 6,
  60. 'name' => 'House bonus',//豪宅积分
  61. 'label' => 'house_points',
  62. ],
  63. 7 => [
  64. 'id' => 7,
  65. 'name' => 'PayStack',
  66. 'label' => 'pay_stack',
  67. ],
  68. ];
  69. const GOODS_TYPE = [
  70. 1 =>[
  71. 'name'=>'国内商品',//国内商品
  72. 'discount'=>'50',
  73. ],
  74. 2 =>[
  75. 'name'=>'进口商品',//进口商品
  76. 'discount'=>'60',
  77. ],
  78. ];
  79. const GIFT_TYPE = [
  80. 1 =>[
  81. 'name'=>'Entry area',//报单区
  82. ],
  83. 2 =>[
  84. 'name'=>'Reselling area',//复消区
  85. ],
  86. 3 =>[
  87. 'name'=>'Office Entry area',//工作室报单
  88. ],
  89. 4 =>[
  90. 'name'=>'Office Reselling area',//工作室复消
  91. ],
  92. ];
  93. const STATUS_NAME = [
  94. 1 => 'On sale',//已上架
  95. 0 => 'Sold out',//已下架
  96. ];
  97. const CATEGORY_TYPE = [
  98. [
  99. 'id' => 1,
  100. 'name' => 'Common products',//普通商品
  101. 'sell_type' => [
  102. self::SALE_TYPE[1],
  103. self::SALE_TYPE[3],
  104. self::SALE_TYPE[7],
  105. ]
  106. ],
  107. [
  108. 'id' => 4,
  109. 'name' => 'Travel bonus products',//旅游积分商品
  110. 'sell_type' => [
  111. self::SALE_TYPE[4]
  112. ]
  113. ],
  114. [
  115. 'id' => 5,
  116. 'name' => 'Car bonus products',//名车积分商品
  117. 'sell_type' => [
  118. self::SALE_TYPE[5]
  119. ]
  120. ],
  121. [
  122. 'id' => 6,
  123. 'name' => 'House bonus products',//豪宅积分商品
  124. 'sell_type' => [
  125. self::SALE_TYPE[6]
  126. ]
  127. ],
  128. ];
  129. /**
  130. * @inheritdoc
  131. */
  132. public static function tableName()
  133. {
  134. return '{{%SHOP_GOODS}}';
  135. }
  136. /**
  137. * @inheritdoc
  138. */
  139. public function rules()
  140. {
  141. return [
  142. [['SELL_DISCOUNT','GOODS_NAME', 'CATE_ID','GIFT_TYPE', 'GOODS_NO', 'SELL_PRICE','MARKET_PRICE','PRICE_PV','STORE_NUMS', 'SELL_TYPE', 'CATEGORY_TYPE', 'SELL_PRICE_STANDARD'], 'required'],
  143. [['STORE_NUMS'], 'integer'],
  144. [['SELL_PRICE','MARKET_PRICE','PRICE_PV','POINT',/* 'SELL_TYPE',*/ 'CATEGORY_TYPE' ,'SELL_PRICE_STANDARD'], 'number'],
  145. [['ID','CATE_ID', 'GOODS_NO','GIFT_TYPE'], 'string', 'max' => 32],
  146. [['UNIT'], 'string', 'max' => 16],
  147. [['COVER', 'GOODS_NAME'], 'string', 'max' => 255],
  148. [['IMAGES','CONTENT'], 'string', 'max' => 4000],
  149. [['GOODS_NAME'], 'unique'],
  150. [['ID'], 'unique'],
  151. ];
  152. }
  153. /**
  154. * @inheritdoc
  155. */
  156. public function attributeLabels()
  157. {
  158. return [
  159. 'ID' => 'ID',
  160. 'GOODS_NAME' => '商品名称',
  161. 'CATE_ID' => '所属分类ID',
  162. // 'TYPE' => '商品来源',
  163. 'SELL_DISCOUNT' => '会员折扣',
  164. 'GIFT_TYPE' => '商品类型',
  165. 'CATEGORY_TYPE' => '商品分类',
  166. 'SELL_TYPE' => '出售方式',
  167. 'GOODS_NO' => '商品编号',
  168. 'UNIT' => '商品单位',
  169. 'COVER' => '商品封面',
  170. 'IMAGES' => '商品图片',
  171. 'CONTENT' => '商品内容',
  172. 'SELL_PRICE' => '销售价格',
  173. 'SELL_PRICE_STANDARD' => '标准价格($)',
  174. 'MARKET_PRICE' => '市场价格',
  175. 'PRICE_PV' => '价格PV',
  176. 'POINT' => '兑换积分',
  177. 'STORE_NUMS' => '库存',
  178. 'STATUS' => '是否上架',
  179. 'IS_DEL' => '是否删除',
  180. 'CREATED_AT' => '创建时间',
  181. 'UPDATED_AT' => '更新时间',
  182. 'DELETED_AT' => '更新时间',
  183. 'SORT' => '排序',
  184. ];
  185. }
  186. /**
  187. * 判断提现状态
  188. * @param $nowStatus
  189. * @param $toStatus
  190. * @return string
  191. */
  192. public static function chkAuditStatus($nowStatus, $toStatus) {
  193. $statusName = self::STATUS_NAME;
  194. $msg = '当前商品状态为【' . $statusName[$nowStatus] . '】,无法设置为【' . $statusName[$toStatus] . '】';
  195. switch ($toStatus) {
  196. // 下架
  197. case 0:
  198. if ($nowStatus == 1) {
  199. $msg = '';
  200. }
  201. break;
  202. //上架
  203. case 1:
  204. if ($nowStatus == 0) {
  205. $msg = '';
  206. }
  207. break;
  208. default:
  209. }
  210. return $msg;
  211. }
  212. /**
  213. * 支付方式
  214. * @return array
  215. */
  216. public static function payTypes(){
  217. return [
  218. 'cash'=>[
  219. 'name'=>'余额支付' //余额支付
  220. ],
  221. 'point'=>[
  222. 'name'=>'积分支付' //积分支付
  223. ],
  224. 'exchange' => [
  225. 'name' => '积分点数' //积分点数
  226. ],
  227. 'travel_points'=>[
  228. 'name'=>'旅游积分' //旅游积分
  229. ],
  230. 'car_points'=>[
  231. 'name'=>'名车积分' //名车积分
  232. ],
  233. 'house_points' => [
  234. 'name' => '豪宅积分'
  235. ],
  236. 'pay_stack' => [
  237. 'name' => 'PayStack'
  238. ],
  239. ];
  240. }
  241. }