DealType.php 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  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 LX_SEND = '12840830348E456696834E0624FE2331';//领袖分红发放
  36. CONST RECONSUME_POINTS_OUT = '01C2916A2ECA4D1B9C29AA333C6D13E7';//复消积分转出
  37. // CONST LX_TRANSFER_OUT = '3CD904D1D0764A3FA3E9114DA1D930BD';//领袖分红转出
  38. CONST RECONSUME_POINTS_TRANSFER_IN = 'F6AA8D767E654D86917BBF1A5C24F439';//复消积分转入
  39. // CONST LX_TRANSFER_IN = '0C092D8D6D804F4B84134DBAB5BBE05C';//领袖分红转入
  40. CONST RESEND = '37B81A45F38646A0A16499AB27B51923';//补发
  41. CONST SMS = '1145D8ABA7A7471FB59B6760BDB19019';//短信服务费
  42. CONST DEDUCT_CLOSE = '37EFF25E5E3F46A6BB84B8C55997F276';//永久关停扣除
  43. CONST DEDUCT_LOGOUT = 'A1F1E76F34EE4981AB3BF4F8D20BB53E';//注销扣除
  44. CONST RECONSUME_POINTS_EXCHANGE = 'YA627DTHN81OBO7NIQ1OP8N3PGZX5C66';//复消积分兑换
  45. /**
  46. * {@inheritdoc}
  47. */
  48. public static function tableName()
  49. {
  50. return '{{%DEAL_TYPE}}';
  51. }
  52. /**
  53. * {@inheritdoc}
  54. */
  55. public function rules()
  56. {
  57. return [
  58. [['TYPE_NAME', 'CREATE_ADMIN', 'CREATED_AT'], 'required'],
  59. [['IS_PRESET', 'IS_ENABLE', 'CREATED_AT', 'UPDATED_AT', 'SORT_ORDER'], 'integer'],
  60. [['ID', 'CREATE_ADMIN', 'UPDATE_ADMIN'], 'string', 'max' => 32],
  61. [['TYPE_NAME'], 'string', 'max' => 255],
  62. [['CREATE_REMARK', 'UPDATE_REMARK'], 'string', 'max' => 4000],
  63. [['ID','TYPE_NAME'], 'unique'],
  64. ];
  65. }
  66. /**
  67. * {@inheritdoc}
  68. */
  69. public function attributeLabels()
  70. {
  71. return [
  72. 'ID' => 'ID',
  73. 'TYPE_NAME' => '类型名称',
  74. 'CREATE_ADMIN' => '创建人',
  75. 'UPDATE_ADMIN' => '修改人',
  76. 'CREATE_REMARK' => '创建备注',
  77. 'UPDATE_REMARK' => '修改备注',
  78. 'IS_PRESET' => '是否系统预置',
  79. 'IS_ENABLE' => '是否启用',
  80. 'CREATED_AT' => '创建时间',
  81. 'UPDATED_AT' => '修改时间',
  82. 'SORT_ORDER' => '排序',
  83. ];
  84. }
  85. /**
  86. * 获取注册类型
  87. * @return array|null
  88. */
  89. public static function getTypes(){
  90. return self::find()->select('ID,TYPE_NAME')->where('IS_PRESET=0 AND IS_ENABLE=1')->indexBy('ID')->orderBy('SORT_ORDER DESC')->asArray()->all();
  91. }
  92. /**
  93. * 获取全部交易类型
  94. * @return array|\yii\db\ActiveRecord[]
  95. */
  96. public static function getAllTypes(){
  97. return self::find()->select('ID,TYPE_NAME,IS_PRESET')->where('IS_ENABLE=1')->indexBy('ID')->orderBy('IS_PRESET ASC,SORT_ORDER DESC')->asArray()->all();
  98. }
  99. /**
  100. * 获取用于显示的交易类型
  101. * @return array|\yii\db\ActiveRecord[]
  102. */
  103. public static function getAllTypesForShow(){
  104. return self::find()->select('ID,TYPE_NAME,IS_PRESET')->indexBy('ID')->orderBy('IS_PRESET ASC,SORT_ORDER DESC')->asArray()->all();
  105. }
  106. /**
  107. * 操作日志记录条件
  108. * @return array
  109. */
  110. public function attrLabelsWithLogType(){
  111. return [
  112. 'TYPE_NAME' => '类型名称',
  113. 'IS_PRESET' => [
  114. 'label' => '是否系统预置',
  115. 'type' => ValueTypeConfig::YES_NO_TYPE,
  116. ],
  117. 'IS_ENABLE' => [
  118. 'label' => '是否启用',
  119. 'type' => ValueTypeConfig::YES_NO_TYPE,
  120. ],
  121. 'CREATE_ADMIN' => [
  122. 'label' => '创建人',
  123. 'type' => function($data){
  124. $value = $data['value'];
  125. $result = Admin::findOneAsArray('ID=:ID', [':ID'=>$value], 'ADMIN_NAME');
  126. return $result['ADMIN_NAME'];
  127. },
  128. ],
  129. 'CREATED_AT' => [
  130. 'label' => '创建时间',
  131. 'type' => ValueTypeConfig::DATE_TIME_TYPE,
  132. ],
  133. 'UPDATE_ADMIN' => [
  134. 'label' => '修改人',
  135. 'type' => function($data){
  136. $value = $data['value'];
  137. $result = Admin::findOneAsArray('ID=:ID', [':ID'=>$value], 'ADMIN_NAME');
  138. return $result['ADMIN_NAME'];
  139. },
  140. ],
  141. 'UPDATED_AT' => [
  142. 'label' => '修改时间',
  143. 'type' => ValueTypeConfig::DATE_TIME_TYPE,
  144. ],
  145. 'CREATE_REMARK' => '备注',
  146. 'SORT_ORDER' => '排序',
  147. ];
  148. }
  149. }