RegType.php 3.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. <?php
  2. namespace common\models;
  3. use Yii;
  4. /**
  5. * This is the model class for table "{{%REG_TYPE}}".
  6. *
  7. * @property string $ID
  8. * @property string $TYPE_NAME 类型名称
  9. * @property int $IS_PACT 是否启用协议
  10. * @property string $MONTH_LIMIT_AMOUNT 达到月提现金额升级应注册类型
  11. * @property string $YEAR_LIMIT_AMOUNT 达到年提现金额升级应注册类型
  12. * @property string $CREATE_ADMIN 创建管理员
  13. * @property string $UPDATE_ADMIN 修改管管理
  14. * @property string $REMARK 备注
  15. * @property int $SORT 排序
  16. * @property int $CREATED_AT 创建时间
  17. * @property int $UPDATED_AT 更新时间
  18. */
  19. class RegType extends \common\components\ActiveRecord {
  20. /**
  21. * {@inheritdoc}
  22. */
  23. public static function tableName() {
  24. return '{{%REG_TYPE}}';
  25. }
  26. /**
  27. * {@inheritdoc}
  28. */
  29. public function rules() {
  30. return [
  31. [['TYPE_NAME', 'CREATED_AT'], 'required'],
  32. [['IS_PACT', 'SORT', 'CREATED_AT', 'UPDATED_AT'], 'integer'],
  33. [['MONTH_LIMIT_AMOUNT', 'YEAR_LIMIT_AMOUNT'], 'number'],
  34. [['ID', 'CREATE_ADMIN', 'UPDATE_ADMIN'], 'string', 'max' => 32],
  35. [['TYPE_NAME'], 'string', 'max' => 48],
  36. [['REMARK'], 'string', 'max' => 4000],
  37. [['TYPE_NAME'], 'unique'],
  38. [['ID'], 'unique'],
  39. ];
  40. }
  41. /**
  42. * {@inheritdoc}
  43. */
  44. public function attributeLabels() {
  45. return [
  46. 'ID' => 'ID',
  47. 'TYPE_NAME' => '类型名称',
  48. 'IS_PACT' => '是否启用协议',
  49. 'MONTH_LIMIT_AMOUNT' => '达到月提现金额升级应注册类型',
  50. 'YEAR_LIMIT_AMOUNT' => '达到年提现金额升级应注册类型',
  51. 'CREATE_ADMIN' => '创建管理员',
  52. 'UPDATE_ADMIN' => '修改管理员',
  53. 'REMARK' => '备注',
  54. 'SORT' => '排序',
  55. 'CREATED_AT' => '创建时间',
  56. 'UPDATED_AT' => '更新时间',
  57. ];
  58. }
  59. /**
  60. * 获取注册类型
  61. * @return array|null
  62. */
  63. public static function getTypes() {
  64. return self::find()->indexBy('ID')->orderBy('SORT ASC')->asArray()->all();
  65. }
  66. /**
  67. * 是否满足修改应注册类型
  68. * @param $uid
  69. * @param $shouldRegType
  70. * @param $year
  71. * @param $month
  72. */
  73. public static function chkRegType($uid, $shouldRegType, $year, $month) {
  74. $status = [Withdraw::STATUS_APPLIED, Withdraw::STATUS_AUDITED, Withdraw::STATUS_WAIT_PAID, Withdraw::STATUS_PAID_FALSE, Withdraw::STATUS_PAID];
  75. $statusStr = implode("','", $status);
  76. $statusStr = "'" . $statusStr . "'";
  77. $withdrawMonth = Withdraw::find()->where('USER_ID=:USER_ID AND WITHDRAW_MONTH=:WITHDRAW_MONTH AND WITHDRAW_YEAR=:WITHDRAW_YEAR AND AUDIT_STATUS IN (' . $statusStr . ')', [':USER_ID' => $uid, ':WITHDRAW_MONTH' => $month, ':WITHDRAW_YEAR' => $year])->sum('AMOUNT');
  78. $withdrawYear = Withdraw::find()->where('USER_ID=:USER_ID AND WITHDRAW_YEAR=:WITHDRAW_YEAR AND AUDIT_STATUS IN (' . $statusStr . ')', [':USER_ID' => $uid, ':WITHDRAW_YEAR' => $year])->sum('AMOUNT');
  79. $regTypes = array_reverse(self::getTypes());
  80. $toType = $shouldRegType;
  81. foreach ($regTypes as $value) {
  82. if ($withdrawMonth >= $value['MONTH_LIMIT_AMOUNT'] || $withdrawYear >= $value['YEAR_LIMIT_AMOUNT']) {
  83. if ($value['SORT'] != 1) $toType = $value['ID'];
  84. break;
  85. }
  86. }
  87. if ($toType != $shouldRegType) {
  88. UserInfo::updateAll(['SHOULD_REG_TYPE' => $toType], 'USER_ID=:USER_ID', [':USER_ID' => $uid]);
  89. }
  90. }
  91. }