DealType.php 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. <?php
  2. namespace common\models;
  3. use backendApi\modules\v1\models\Admin;
  4. use common\libs\logging\operate\valueType\Config as ValueTypeConfig;
  5. use Yii;
  6. /**
  7. * This is the model class for table "{{%DEAL_TYPE}}".
  8. *
  9. * @property string $ID
  10. * @property string $TYPE_NAME 类型名称
  11. * @property string $CREATE_ADMIN 创建人
  12. * @property string $UPDATE_ADMIN 修改人
  13. * @property string $CREATE_REMARK 创建备注
  14. * @property string $UPDATE_REMARK 修改备注
  15. * @property int $IS_PRESET 是否系统预置
  16. * @property int $IS_ENABLE 是否启用
  17. * @property int $CREATED_AT 创建时间
  18. * @property int $UPDATED_AT 修改时间
  19. * @property int $SORT_ORDER 排序
  20. */
  21. class DealType extends \common\components\ActiveRecord
  22. {
  23. //系统预置类型id
  24. CONST BONUS_SEND = '141E52002AAE43B7AC304F4BAEFDA268';//奖金发放
  25. CONST WITHDRAW = '6626ED606DB34A11B6CCEA768B6E36C2';//奖金提现
  26. // CONST DEDUCT = '7E3255C33BD6457B8F7155F2A86FFF73';//责任业绩扣除
  27. CONST WITHDRAW_RETURN = '01A753D2548F44FA99B847133C1B5F79';//提现退回
  28. CONST TRANSFER_OUT = 'DAA0FB1465F748908680D941D589326E';//转出
  29. CONST TRANSFER_IN = 'DB62879E6C6B4B2F8591FAD920A2822C';//转入
  30. // CONST BIND_TRANSFER_OUT = 'E57A779B2E064081B335C5D6B9E4B59B';//点位绑定转出
  31. // CONST BIND_TRANSFER_IN = '082485287F3148B7A44DC62D5D17473A';//点位绑定转入
  32. // CONST TEAMWORK_TRANSFER_OUT = '38EB53BCAAF24BA38B2E5FDA313EC928';//点位合作转出
  33. // CONST TEAMWORK_TRANSFER_IN = '64198F701D374D2996AA8EF1D37769AB';//点位合作转入
  34. CONST RECONSUME_POINTS_SEND = 'A6BDF8A2E5F7450B80CBF3B28D8010D2';//复消积分发放
  35. CONST EXCHANGE_POINTS_SEND = '316868755701501952';//兑换积分发放
  36. // CONST LX_SEND = '12840830348E456696834E0624FE2331';//领袖分红发放
  37. CONST RECONSUME_POINTS_OUT = '01C2916A2ECA4D1B9C29AA333C6D13E7';//复消积分转出
  38. // CONST LX_TRANSFER_OUT = '3CD904D1D0764A3FA3E9114DA1D930BD';//领袖分红转出
  39. CONST RECONSUME_POINTS_TRANSFER_IN = 'F6AA8D767E654D86917BBF1A5C24F439';//复消积分转入
  40. // CONST LX_TRANSFER_IN = '0C092D8D6D804F4B84134DBAB5BBE05C';//领袖分红转入
  41. CONST RESEND = '37B81A45F38646A0A16499AB27B51923';//补发
  42. CONST SMS = '1145D8ABA7A7471FB59B6760BDB19019';//短信服务费
  43. CONST DEDUCT_CLOSE = '37EFF25E5E3F46A6BB84B8C55997F276';//永久关停扣除
  44. CONST DEDUCT_LOGOUT = 'A1F1E76F34EE4981AB3BF4F8D20BB53E';//注销扣除
  45. CONST RECONSUME_POINTS_EXCHANGE = 'YA627DTHN81OBO7NIQ1OP8N3PGZX5C66';//复消积分兑换
  46. CONST EXCHANGE_POINTS_EXCHANGE = '316872011148300288';//兑换积分兑换
  47. /**
  48. * {@inheritdoc}
  49. */
  50. public static function tableName()
  51. {
  52. return '{{%DEAL_TYPE}}';
  53. }
  54. /**
  55. * {@inheritdoc}
  56. */
  57. public function rules()
  58. {
  59. return [
  60. [['TYPE_NAME', 'CREATE_ADMIN', 'CREATED_AT'], 'required'],
  61. [['IS_PRESET', 'IS_ENABLE', 'CREATED_AT', 'UPDATED_AT', 'SORT_ORDER'], 'integer'],
  62. [['ID', 'CREATE_ADMIN', 'UPDATE_ADMIN'], 'string', 'max' => 32],
  63. [['TYPE_NAME'], 'string', 'max' => 255],
  64. [['CREATE_REMARK', 'UPDATE_REMARK'], 'string', 'max' => 4000],
  65. [['ID','TYPE_NAME'], 'unique'],
  66. ];
  67. }
  68. /**
  69. * {@inheritdoc}
  70. */
  71. public function attributeLabels()
  72. {
  73. return [
  74. 'ID' => 'ID',
  75. 'TYPE_NAME' => '类型名称',
  76. 'CREATE_ADMIN' => '创建人',
  77. 'UPDATE_ADMIN' => '修改人',
  78. 'CREATE_REMARK' => '创建备注',
  79. 'UPDATE_REMARK' => '修改备注',
  80. 'IS_PRESET' => '是否系统预置',
  81. 'IS_ENABLE' => '是否启用',
  82. 'CREATED_AT' => '创建时间',
  83. 'UPDATED_AT' => '修改时间',
  84. 'SORT_ORDER' => '排序',
  85. ];
  86. }
  87. /**
  88. * 获取注册类型
  89. * @return array|null
  90. */
  91. public static function getTypes(){
  92. return self::find()->select('ID,TYPE_NAME')->where('IS_PRESET=0 AND IS_ENABLE=1')->indexBy('ID')->orderBy('SORT_ORDER DESC')->asArray()->all();
  93. }
  94. /**
  95. * 获取全部交易类型
  96. * @return array|\yii\db\ActiveRecord[]
  97. */
  98. public static function getAllTypes(){
  99. return self::find()->select('ID,TYPE_NAME,IS_PRESET')->where('IS_ENABLE=1')->indexBy('ID')->orderBy('IS_PRESET ASC,SORT_ORDER DESC')->asArray()->all();
  100. }
  101. /**
  102. * 获取用于显示的交易类型
  103. * @return array|\yii\db\ActiveRecord[]
  104. */
  105. public static function getAllTypesForShow(){
  106. return self::find()->select('ID,TYPE_NAME,IS_PRESET')->indexBy('ID')->orderBy('IS_PRESET ASC,SORT_ORDER DESC')->asArray()->all();
  107. }
  108. /**
  109. * 操作日志记录条件
  110. * @return array
  111. */
  112. public function attrLabelsWithLogType(){
  113. return [
  114. 'TYPE_NAME' => '类型名称',
  115. 'IS_PRESET' => [
  116. 'label' => '是否系统预置',
  117. 'type' => ValueTypeConfig::YES_NO_TYPE,
  118. ],
  119. 'IS_ENABLE' => [
  120. 'label' => '是否启用',
  121. 'type' => ValueTypeConfig::YES_NO_TYPE,
  122. ],
  123. 'CREATE_ADMIN' => [
  124. 'label' => '创建人',
  125. 'type' => function($data){
  126. $value = is_array($data) && isset($data['value']) ? $data['value'] : '';
  127. $result = Admin::findOneAsArray('ID=:ID', [':ID'=>$value], 'ADMIN_NAME');
  128. return !empty($result) ? $result['ADMIN_NAME'] : '';
  129. },
  130. ],
  131. 'CREATED_AT' => [
  132. 'label' => '创建时间',
  133. 'type' => ValueTypeConfig::DATE_TIME_TYPE,
  134. ],
  135. 'UPDATE_ADMIN' => [
  136. 'label' => '修改人',
  137. 'type' => function($data){
  138. $value = is_array($data) && isset($data['value']) ? $data['value'] : '';
  139. $result = Admin::findOneAsArray('ID=:ID', [':ID'=>$value], 'ADMIN_NAME');
  140. return !empty($result) ? $result['ADMIN_NAME'] : '';
  141. },
  142. ],
  143. 'UPDATED_AT' => [
  144. 'label' => '修改时间',
  145. 'type' => ValueTypeConfig::DATE_TIME_TYPE,
  146. ],
  147. 'CREATE_REMARK' => '备注',
  148. 'SORT_ORDER' => '排序',
  149. ];
  150. }
  151. }