DealType.php 7.6 KB

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