ApproachDeclarationForm.php 45 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965
  1. <?php
  2. namespace common\models\forms;
  3. use common\components\Model;
  4. use common\helpers\Cache;
  5. use common\helpers\Date;
  6. use common\helpers\Form;
  7. use common\helpers\LoggerTool;
  8. use common\helpers\user\Cash;
  9. use common\helpers\user\Reconsume;
  10. use common\helpers\user\Info;
  11. use common\models\ApproachDecOrder;
  12. use common\models\ApproachOrder;
  13. use common\models\ApproachOrderGoods;
  14. use common\models\DeclarationPackage;
  15. use common\models\DecOrder;
  16. use common\models\EmployLevel;
  17. use common\models\Order;
  18. use common\models\OrderGoods;
  19. use common\models\Period;
  20. use common\models\ReceiveAddress;
  21. use common\models\ReconsumePool;
  22. use common\models\ReconsumePoolFlow;
  23. use common\models\DeclarationLevel;
  24. use common\models\Region;
  25. use common\models\ShopGoods;
  26. use common\models\User;
  27. use common\models\UserInfo;
  28. use common\models\UserNetwork;
  29. use common\models\UserRelation;
  30. use common\models\Instalment;
  31. use Yii;
  32. use yii\base\Exception;
  33. /**
  34. * Login form
  35. */
  36. class ApproachDeclarationForm extends Model
  37. {
  38. public $type;
  39. public $decLv;
  40. public $decWay;
  41. public $packageId;
  42. public $goodsId;
  43. public $goodsNum;
  44. public $insertUserName;
  45. public $password;
  46. public $payPassword;
  47. public $realName;
  48. public $insertUserIdCard;
  49. public $mobile;
  50. public $email;
  51. public $address;
  52. public $openBank;
  53. public $bankAddress;
  54. public $bankNo;
  55. public $bankProvince;
  56. public $bankCity;
  57. public $bankCounty;
  58. public $conUserName;
  59. public $recUserName;
  60. public $decUserName;
  61. public $location;
  62. public $consignee;
  63. public $acceptMobile;
  64. public $province;
  65. public $city;
  66. public $county;
  67. public $cityName;
  68. public $lgaName;
  69. public $payType;
  70. public $decType;
  71. // 传过来的全部数据
  72. public $allData;
  73. private $_decId;
  74. public $_insertUserId;
  75. private $_decAmount;
  76. private $_decPv;
  77. private $_orderGoods;
  78. private $_standardAmount;
  79. private $_decAmountStandard;
  80. // 批量报单时添加会员的REDIS里面缓存的添加的会员资料
  81. const REDIS_WAIT_ADD_USER = 'user:dec:waitAdd';
  82. const TYPE_ZC = 'ZC';
  83. // const TYPE_YH = 'YH';
  84. const TYPE_ZG = 'ZG';
  85. const TYPE_LS = 'LS';
  86. const TYPE_FX = 'FX';
  87. // private $_modelClass = null;
  88. private $_oneOrder = null;
  89. private $_userForm = null;
  90. // 全部的上级(安置网和开拓网)
  91. private $_tempParentUser = [];
  92. // 全部的安置网上级
  93. private $_tempNetworkParentUser = [];
  94. // 全部的开拓网上级
  95. private $_tempRelationParentUser = [];
  96. private $_types = [
  97. self::TYPE_ZC => [
  98. 'name' => '首购单',
  99. ],
  100. // self::TYPE_YH => [
  101. // 'class' => DeclarationYH::class,
  102. // 'table' => '{{%DECLARATION_YH}}',
  103. // 'name' => '优惠单',
  104. // ],
  105. self::TYPE_ZG => [
  106. 'name' => '升级增购单',
  107. ],
  108. self::TYPE_LS => [
  109. 'name' => '零售单',
  110. ],
  111. self::TYPE_FX => [
  112. 'name' => '复销单',
  113. ],
  114. ];
  115. /**
  116. * @inheritdoc
  117. */
  118. public function rules()
  119. {
  120. return [
  121. [['type','decLv','decWay','packageId', 'insertUserName', 'realName',/* 'insertUserIdCard',*/ 'mobile', 'address', 'openBank', 'bankAddress', 'bankNo','bankProvince','bankCity','bankCounty','consignee','acceptMobile','province','city','county','cityName','lgaName','decUserName', 'conUserName', 'recUserName', 'location'], 'trim'],
  122. [['type','decLv','decWay','insertUserName',/* 'insertUserIdCard',*/'password','payPassword'], 'required'],
  123. [['type'], 'isType', 'on'=>['userDec', 'canDec']],
  124. [['insertUserName'], 'isCanAddUser'],
  125. [['decUserName', 'decType'], 'issetDec'],
  126. [['conUserName'], 'isConUserName'],
  127. [['recUserName'], 'isRecUserName'],
  128. [['location'], 'isLocation'],
  129. // [['insertUserIdCard'], 'isSameSystem'],
  130. ];
  131. }
  132. public function attributeLabels()
  133. {
  134. return [
  135. 'type' => 'Entry type',//报单类型
  136. 'decLv' => 'Entry level',//报单级别
  137. //'decPv' => '报单PV',
  138. 'decWay' => 'Entry method',//报单方式
  139. 'packageId' => 'Entry Package',//报单套餐
  140. 'goodsId' => 'product ID',//商品ID
  141. 'goodsNum' => 'Product quantity',//商品数量
  142. //'addType' => '新增会员方式',
  143. 'insertUserName' => 'Member user name',//会员用户名
  144. 'password' => 'Login password',//登陆密码
  145. 'payPassword' => 'Payment password',//支付密码
  146. 'realName' => 'Member Name',//会员姓名
  147. 'insertUserIdCard' => 'ID',//身份证号
  148. 'mobile' => 'Phone Number',//手机号
  149. 'openBank' => 'openBank',//开户行
  150. 'bankAddress' => 'bankAddress',//开户支行
  151. 'bankNo' => 'bankNo',//银行账号
  152. 'bankProvince' => 'bankProvince',//银行省份
  153. 'bankCity' => 'bankCity',//银行城市
  154. 'bankCounty' => 'bankCounty',//银行县区
  155. 'conUserName' => 'Instructor user name',//指导老师用户名
  156. 'recUserName' => 'Developer user name',//开拓人用户名
  157. 'decUserName' => 'Stockist user name',//报单中心用户名
  158. 'conUid' => 'Instructor member ID',//指导老师会员ID
  159. 'recUid' => 'Sponsor member ID',//'开拓人会员ID
  160. 'location' => 'market',//市场
  161. 'consignee' => 'consignee',//收货人
  162. 'acceptMobile' => 'Recipient Phone Number',//收货人手机
  163. 'province' => 'Receiving Province',//收货省
  164. 'city' => 'Receiving City',//收货市
  165. 'county' => 'Receiving area / county',//收货区县
  166. 'address' => 'Receiving detailed address',//收货详细地址
  167. ];
  168. }
  169. /**
  170. * 指定场景
  171. * @return array
  172. */
  173. public function scenarios()
  174. {
  175. $parentScenarios = parent::scenarios();
  176. $customScenarios = [
  177. 'userDec' => ['type','allData', 'decLv','decWay','insertUserName','password','payPassword', 'realName',/* 'insertUserIdCard',*/ 'mobile', 'address', 'openBank', 'bankAddress', 'bankNo', 'bankProvince','bankCity','bankCounty', 'consignee','acceptMobile','province',/*'city','county',*/ 'conUserName', 'recUserName','decUserName', 'location', 'email', 'decType'],
  178. 'canDec' => ['type', 'insertUserName',/* 'insertUserIdCard',*/ 'conUserName', 'recUserName', 'location', 'decType'],
  179. 'notFull' => ['type', 'insertUserName', 'conUserName', 'recUserName', 'location'],
  180. ];
  181. return array_merge($parentScenarios, $customScenarios);
  182. }
  183. /**
  184. * 判断报单中心是否存在
  185. * @param $attribute
  186. */
  187. public function issetDec($attribute){
  188. if(!$this->decUserName){
  189. $this->_decId = '';
  190. } else {
  191. if (!$decUser = User::find()->select('ID')->where('IS_DEC=1 AND USER_NAME=:USER_NAME', [':USER_NAME' => $this->decUserName])->asArray()->one()) {
  192. $this->addError($attribute, Yii::t('app', 'stockistDoesNotExist'));
  193. return false;
  194. } else {
  195. if ($this->decType !== 'ba') {
  196. // 判断报单中心是否在新加入会员的安置网上级中
  197. $this->loopFindParentToNetwork($this->insertUserName);
  198. //反转数组,in_array搜索错误
  199. //in_array($this->decUserName, $this->_tempNetworkParentUser[$this->insertUserName]);
  200. $flipParent = array_flip(array_filter($this->_tempNetworkParentUser[$this->insertUserName]));
  201. // if (!isset($flipParent[$this->decUserName])) {
  202. // //$this->addError($attribute, '为' . $this->insertUserName . '报单,报单中心' . $this->decUserName . '不在' . $this->insertUserName . '的安置网上级中');
  203. // $this->addError($attribute, 'To' . $this->insertUserName . 'Entry, Stockist' . $this->decUserName . 'not in exist' . $this->insertUserName . 'in the placement superiors');
  204. // return ;
  205. // }
  206. }
  207. $this->_decId = $decUser['ID'];
  208. }
  209. }
  210. }
  211. /**
  212. * 判断指导老师
  213. * @param $attribute
  214. */
  215. public function isConUserName($attribute){
  216. if($this->type == self::TYPE_ZC){
  217. // 从数据库查看接点会员是否在
  218. if(!isset($this->_tempParentUser[$this->conUserName])){
  219. $conUserTemp = UserInfo::findOneAsArray('USER_NAME=:USER_NAME', [':USER_NAME' => $this->conUserName]);
  220. if(!$conUserTemp){
  221. if($this->insertUserName){
  222. //$this->addError($attribute, '为'.$this->insertUserName.'报单,指导老师'.$this->conUserName.'不存在');
  223. $this->addError($attribute, 'To'.$this->insertUserName.'Entry,Instructor'.$this->conUserName.'not in exist');
  224. } else {
  225. //$this->addError($attribute, '指导老师'.$this->conUserName.'不存在');
  226. $this->addError($attribute, 'Instructor'.$this->conUserName.'not in exist');
  227. }
  228. return ;
  229. }
  230. $conUserTemp['CON_NUM'] = UserNetwork::firstFloorChildNum($conUserTemp['USER_ID']);
  231. $conUserTemp['REC_NUM'] = UserRelation::firstFloorChildNum($conUserTemp['USER_ID']);
  232. $this->_tempParentUser[$this->conUserName] = [
  233. 'USER_NAME' => $this->conUserName,
  234. 'ZC_PV' => $conUserTemp['ZC_PV'],
  235. 'CON_USER_NAME' => Info::getUserNameByUserId($conUserTemp['CON_UID']),
  236. 'REC_USER_NAME' => Info::getUserNameByUserId($conUserTemp['REC_UID']),
  237. 'CON_NUM' => $conUserTemp['CON_NUM'],
  238. 'REC_NUM' => $conUserTemp['REC_NUM'],
  239. 'SYSTEM_ID' => $conUserTemp['SYSTEM_ID'],
  240. 'LOCATION' => UserNetwork::getLocation($conUserTemp['USER_ID'], $conUserTemp['CON_UID']),
  241. ];
  242. // 把该会员下面的5个区是否存在会员都付上
  243. for($i=1;$i<=5;$i++){
  244. $this->_tempParentUser[$this->conUserName]["LOCATION$i"] = UserNetwork::issetUserInLocation($conUserTemp['USER_ID'], $i);
  245. }
  246. }
  247. $conUser = $this->_tempParentUser[$this->conUserName];
  248. // 判断接点会员的下级会员是否大于三个,如果大于三个则不允许
  249. if($conUser['CON_NUM'] >= 3){
  250. if($this->insertUserName){
  251. // $this->addError($attribute, '为'.$this->insertUserName.'报单,指导老师'.$this->conUserName.'下级点位已满');
  252. $this->addError($attribute, 'To'.$this->insertUserName.'Entry,Instructor'.$this->conUserName.'lower level is full');
  253. } else {
  254. //$this->addError($attribute, '指导老师'.$this->conUserName.'下级点位已满');
  255. $this->addError($attribute, 'Instructor'.$this->conUserName.'lower level is full');
  256. }
  257. return;
  258. }
  259. if($this->insertUserName){
  260. // 把自己加入到临时上级会员数组中
  261. $this->_tempParentUser[$this->insertUserName] = [
  262. 'USER_NAME' => $this->insertUserName,
  263. //'ZC_PV' => $this->decPv,
  264. 'CON_USER_NAME' => $this->conUserName,
  265. 'REC_USER_NAME' => $this->recUserName,
  266. 'CON_NUM' => 0,
  267. 'REC_NUM' => 0,
  268. 'SYSTEM_ID' => $conUser['SYSTEM_ID'],
  269. 'LOCATION' => $this->location,
  270. 'LOCATION1' => 0,
  271. 'LOCATION2' => 0,
  272. 'LOCATION3' => 0,
  273. 'LOCATION4' => 0,
  274. 'LOCATION5' => 0,
  275. ];
  276. }
  277. }
  278. }
  279. /**
  280. * 判断开拓人
  281. * @param $attribute
  282. */
  283. public function isRecUserName($attribute){
  284. if($this->type == self::TYPE_ZC){
  285. // 开拓人
  286. if(!isset($this->_tempParentUser[$this->recUserName])){
  287. $recUserTemp = UserInfo::findOneAsArray('USER_NAME=:USER_NAME', [':USER_NAME' => $this->recUserName]);
  288. if(!$recUserTemp){
  289. if($this->insertUserName){
  290. //$this->addError($attribute, '为'.$this->insertUserName.'报单,开拓人'.$this->recUserName.'不存在');
  291. $this->addError($attribute, 'To'.$this->insertUserName.'Entry, Sponsor'.$this->recUserName.'not in exist');
  292. } else {
  293. // $this->addError($attribute, '开拓人'.$this->recUserName.'不存在');
  294. $this->addError($attribute, 'Sponsor'.$this->recUserName.'not in exist');
  295. }
  296. return ;
  297. }
  298. $recUserTemp['CON_NUM'] = UserNetwork::firstFloorChildNum($recUserTemp['USER_ID']);
  299. $recUserTemp['REC_NUM'] = UserRelation::firstFloorChildNum($recUserTemp['USER_ID']);
  300. $this->_tempParentUser[$this->recUserName] = [
  301. 'USER_NAME' => $this->recUserName,
  302. 'ZC_PV' => $recUserTemp['ZC_PV'],
  303. 'CON_USER_NAME' => Info::getUserNameByUserId($recUserTemp['CON_UID']),
  304. 'REC_USER_NAME' => Info::getUserNameByUserId($recUserTemp['REC_UID']),
  305. 'CON_NUM' => $recUserTemp['CON_NUM'],
  306. 'REC_NUM' => $recUserTemp['REC_NUM'],
  307. 'SYSTEM_ID' => $recUserTemp['SYSTEM_ID'],
  308. 'LOCATION' => UserNetwork::getLocation($recUserTemp['USER_ID'], $recUserTemp['CON_UID']),
  309. ];
  310. // 把该会员下面的5个区是否存在会员都付上
  311. for($i=1;$i<=5;$i++){
  312. $this->_tempParentUser[$this->recUserName]["LOCATION$i"] = UserNetwork::issetUserInLocation($recUserTemp['USER_ID'], $i);
  313. }
  314. }
  315. $recUser = $this->_tempParentUser[$this->recUserName];
  316. $this->_tempParentUser[$this->recUserName]['REC_NUM'] += 1;
  317. // 存在新加入会员时查看开拓人是否在新加入会员的安置网上级中
  318. if($this->decType !== 'ba' && $this->insertUserName) {
  319. $this->loopFindParentToNetwork($this->insertUserName);
  320. if (!$this->recUserIsInNetworkParent()) {
  321. // $this->addError($attribute, '为' . $this->insertUserName . '报单,开拓人' . $this->recUserName . '不在' . $this->insertUserName . '的安置网上级中');
  322. $this->addError($attribute, 'To' . $this->insertUserName . 'Entry, Sponsor' . $this->recUserName . 'not in exist' . $this->insertUserName . 'in the placement superiors');
  323. return ;
  324. }
  325. }
  326. // 把自己加入到临时上级会员数组中
  327. $this->_tempParentUser[$this->insertUserName] = [
  328. 'USER_NAME' => $this->insertUserName,
  329. //'ZC_PV' => $this->decPv,
  330. 'CON_USER_NAME' => $this->conUserName,
  331. 'REC_USER_NAME' => $this->recUserName,
  332. 'CON_NUM' => 0,
  333. 'REC_NUM' => 0,
  334. 'SYSTEM_ID' => $recUser['SYSTEM_ID'],
  335. 'LOCATION' => $this->location,
  336. 'LOCATION1' => 0,
  337. 'LOCATION2' => 0,
  338. 'LOCATION3' => 0,
  339. 'LOCATION4' => 0,
  340. 'LOCATION5' => 0,
  341. ];
  342. }
  343. }
  344. /**
  345. * 循环把所有新加入的会员的上级加入到临时变量中
  346. * @param null $conUserName
  347. * @return bool
  348. */
  349. private function loopFindParentToNetwork($conUserName = null) {
  350. if($conUserName == null ){
  351. $conUserName = $this->insertUserName;
  352. }
  353. $findUserKey = array_search($conUserName, array_column($this->allData, 'insertUserName'));
  354. // 如果有这个新加入的会员,则查找其上级接点
  355. if($findUserKey !== false){
  356. if(strtoupper($this->allData[$findUserKey]['type']) == 'ZC'){
  357. $this->_tempNetworkParentUser[$this->insertUserName][] = $this->allData[$findUserKey]['conUserName'];
  358. $this->loopFindParentToNetwork($this->allData[$findUserKey]['conUserName']);
  359. }
  360. }
  361. // 如果没有这个新加入的接点,
  362. else {
  363. if($this->insertUserName == $conUserName){
  364. // $this->addError('recUserName', '新加入的会员不存在');
  365. $this->addError('recUserName', Yii::t('app', 'newMemberDoesNotExist'));
  366. return false;
  367. }
  368. // 去数据库里查找这个会员的所有上级
  369. // $allParentUser = UserNetwork::find()->select('PUI.USER_NAME')->where('UI.USER_NAME=:USER_NAME', [':USER_NAME'=>$conUserName])->from(UserNetwork::tableName().' AS UN')->join('LEFT JOIN', UserInfo::tableName().' AS UI', 'UN.USER_ID=UI.USER_ID')->join('LEFT JOIN', UserInfo::tableName().' AS PUI', 'UN.PARENT_UID=PUI.USER_ID')->orderBy('PUI.NETWORK_DEEP DESC')->asArray()->all();
  370. $baseUser = Info::getBaseUserByUserName($conUserName);
  371. $userNetworkInfo = UserNetwork::findOneAsArray('USER_ID=:USER_ID AND PARENT_UIDS <> ""', [':USER_ID' => $baseUser['ID']]);
  372. unset($baseUser);
  373. if ($userNetworkInfo) {
  374. $allParentUserIdsArr = explode(',', $userNetworkInfo['PARENT_UIDS']);
  375. unset($userNetworkInfo);
  376. $allParentUserIds = array_reverse($allParentUserIdsArr);
  377. unset($allParentUserIdsArr);
  378. if($allParentUserIds && count($allParentUserIds)){
  379. foreach($allParentUserIds as $parentUserId) {
  380. $parentBaseUser = Info::getBaseUserById($parentUserId);
  381. $this->_tempNetworkParentUser[$this->insertUserName][] = $parentBaseUser['USER_NAME'] ;
  382. unset($parentUserId, $parentBaseUser);
  383. }
  384. }
  385. unset($allParentUserIds);
  386. }
  387. }
  388. return true;
  389. }
  390. /**
  391. * 开拓人是否在新加入会员的上级中
  392. * @return bool
  393. */
  394. private function recUserIsInNetworkParent(){
  395. return in_array($this->recUserName, $this->_tempNetworkParentUser[$this->insertUserName]);
  396. }
  397. /**
  398. * 判断区域是否正确
  399. * @param $attribute
  400. */
  401. public function isLocation($attribute){
  402. if($this->type == self::TYPE_ZC){
  403. if(!in_array($this->location, [1, 2, 3])){
  404. //$this->addError($attribute, '市场必须在第1市场、第2市场或第三3市场');
  405. $this->addError($attribute, Yii::t('app', 'pleaseSelectMarket'));
  406. }
  407. $conUser = $recUser = null;
  408. if(isset($this->_tempParentUser[$this->conUserName])){
  409. $conUser = $this->_tempParentUser[$this->conUserName];
  410. }
  411. if(isset($this->_tempParentUser[$this->recUserName])){
  412. $recUser = $this->_tempParentUser[$this->recUserName];
  413. }
  414. if($conUser){
  415. // 判断指导老师相应的区位是否已满
  416. if($conUser['LOCATION'.$this->location]){
  417. if($this->insertUserName){
  418. // $this->addError($attribute, '为'.$this->insertUserName.'报单,指导老师'.$this->conUserName.'的第'.$this->location.'市场已存在会员');
  419. $this->addError($attribute, 'To'.$this->insertUserName.'Entry,Instructor'.$this->conUserName.'the'.($this->location == 1 ? 'left' : 'regiht').' superior already existing member');
  420. } else {
  421. // $this->addError($attribute, '指导老师'.$this->conUserName.'的第'.$this->location.'市场已存在会员');
  422. $this->addError($attribute, 'Instructor'.$this->conUserName.'the'.($this->location == 1 ? 'left' : 'regiht').'superior already existing member');
  423. }
  424. return;
  425. }
  426. $this->_tempParentUser[$this->conUserName]['CON_NUM'] += 1;
  427. $this->_tempParentUser[$this->conUserName]['LOCATION'.$this->location] = true;
  428. }
  429. }
  430. }
  431. /**
  432. * 判断会员是否可加入(通过redis结合数据库判断上级会员的情况)
  433. * @param $attribute
  434. */
  435. public function isCanAddUser($attribute){
  436. if($this->type == self::TYPE_ZC){
  437. // 从数据库查看接点会员是否在
  438. if(!isset($this->_tempParentUser[$this->conUserName])){
  439. $conUserTemp = UserInfo::findOneAsArray('USER_NAME=:USER_NAME', [':USER_NAME' => $this->conUserName]);
  440. if(!$conUserTemp){
  441. // $this->addError($attribute, '为'.$this->insertUserName.'报单,指导老师'.$this->conUserName.'不存在');
  442. $this->addError($attribute, 'To'.$this->insertUserName.'Entry,Instructor'.$this->conUserName.'not in exist');
  443. return ;
  444. }
  445. $conUserTemp['CON_NUM'] = UserNetwork::firstFloorChildNum($conUserTemp['USER_ID']);
  446. $conUserTemp['REC_NUM'] = UserRelation::firstFloorChildNum($conUserTemp['USER_ID']);
  447. $this->_tempParentUser[$this->conUserName] = [
  448. 'USER_NAME' => $this->conUserName,
  449. //'ZC_PV' => $conUserTemp['ZC_PV'],
  450. 'CON_USER_NAME' => Info::getUserNameByUserId($conUserTemp['CON_UID']),
  451. 'REC_USER_NAME' => Info::getUserNameByUserId($conUserTemp['REC_UID']),
  452. 'CON_NUM' => $conUserTemp['CON_NUM'],
  453. 'REC_NUM' => $conUserTemp['REC_NUM'],
  454. 'SYSTEM_ID' => $conUserTemp['SYSTEM_ID'],
  455. 'LOCATION' => UserNetwork::getLocation($conUserTemp['USER_ID'], $conUserTemp['CON_UID']),
  456. ];
  457. // 把该会员下面的5个区是否存在会员都付上
  458. for($i=1;$i<=5;$i++){
  459. $this->_tempParentUser[$this->conUserName]["LOCATION$i"] = UserNetwork::issetUserInLocation($conUserTemp['USER_ID'], $i);
  460. }
  461. }
  462. $conUser = $this->_tempParentUser[$this->conUserName];
  463. // 开拓人
  464. if(!isset($this->_tempParentUser[$this->recUserName])){
  465. $recUserTemp = UserInfo::findOneAsArray('USER_NAME=:USER_NAME', [':USER_NAME' => $this->recUserName]);
  466. if(!$recUserTemp){
  467. // $this->addError($attribute, '为'.$this->insertUserName.'报单,开拓人'.$this->recUserName.'不存在');
  468. $this->addError($attribute, 'To'.$this->insertUserName.'Entry, Sponsor'.$this->recUserName.'not in exist');
  469. return ;
  470. }
  471. $recUserTemp['CON_NUM'] = UserNetwork::firstFloorChildNum($recUserTemp['USER_ID']);
  472. $recUserTemp['REC_NUM'] = UserRelation::firstFloorChildNum($recUserTemp['USER_ID']);
  473. $this->_tempParentUser[$this->recUserName] = [
  474. 'USER_NAME' => $this->recUserName,
  475. //'ZC_PV' => $recUserTemp['ZC_PV'],
  476. 'CON_USER_NAME' => Info::getUserNameByUserId($recUserTemp['CON_UID']),
  477. 'REC_USER_NAME' => Info::getUserNameByUserId($recUserTemp['REC_UID']),
  478. 'CON_NUM' => $recUserTemp['CON_NUM'],
  479. 'REC_NUM' => $recUserTemp['REC_NUM'],
  480. 'SYSTEM_ID' => $recUserTemp['SYSTEM_ID'],
  481. 'LOCATION' => UserNetwork::getLocation($recUserTemp['USER_ID'], $recUserTemp['CON_UID']),
  482. ];
  483. // 把该会员下面的5个区是否存在会员都付上
  484. for($i=1;$i<=5;$i++){
  485. $this->_tempParentUser[$this->recUserName]["LOCATION$i"] = UserNetwork::issetUserInLocation($recUserTemp['USER_ID'], $i);
  486. }
  487. }
  488. $recUser = $this->_tempParentUser[$this->recUserName];
  489. // 判断接点会员的下级会员是否大于三个,如果大于三个则不允许
  490. if($conUser['CON_NUM'] >= 3){
  491. // $this->addError($attribute, '为'.$this->insertUserName.'报单,指导老师'.$this->conUserName.'下级点位已满');
  492. $this->addError($attribute, 'To'.$this->insertUserName.'Entry, Sponsor'.$this->conUserName.'lower level is full');
  493. return;
  494. }
  495. // 判断指导老师相应的区位是否已满
  496. if($conUser['LOCATION'.$this->location]){
  497. // $this->addError($attribute, '为'.$this->insertUserName.'报单,指导老师'.$this->conUserName.'该市场已存在会员');
  498. $this->addError($attribute, 'To'.$this->insertUserName.'Entry, Sponsor'.$this->conUserName.'Members already exist in this market');
  499. return;
  500. }
  501. // if($conUser['CON_NUM'] == 0 && $this->location != 1){
  502. // $this->addError($attribute, '为'.$this->insertUserName.'报单,市场必须为指导老师'.$this->conUserName.'下第一市场');
  503. // return;
  504. // }
  505. // 把指导老师的变量的相关数量增加数量
  506. // $this->_tempParentUser[$this->conUserName]['CON_NUM'] += 1;
  507. // $this->_tempParentUser[$this->conUserName]['LOCATION'.$this->location] = true;
  508. // $this->_tempParentUser[$this->recUserName]['REC_NUM'] += 1;
  509. // 把自己加入到临时上级会员数组中
  510. $this->_tempParentUser[$this->insertUserName] = [
  511. 'USER_NAME' => $this->insertUserName,
  512. //'ZC_PV' => $this->decPv,
  513. 'CON_USER_NAME' => $this->conUserName,
  514. 'REC_USER_NAME' => $this->recUserName,
  515. 'CON_NUM' => 0,
  516. 'REC_NUM' => 0,
  517. 'SYSTEM_ID' => $recUser['SYSTEM_ID'],
  518. 'LOCATION' => $this->location,
  519. 'LOCATION1' => 0,
  520. 'LOCATION2' => 0,
  521. 'LOCATION3' => 0,
  522. 'LOCATION4' => 0,
  523. 'LOCATION5' => 0,
  524. ];
  525. }
  526. }
  527. /**
  528. * 报单类型
  529. * @param $attribute
  530. * @param $params
  531. */
  532. public function isType($attribute, $params){
  533. if(array_key_exists($this->type, $this->_types)){
  534. if($this->type == self::TYPE_ZC){
  535. if($this->scenario == 'userDec'){
  536. if(!$this->insertUserName) $this->addError($attribute, Yii::t('app', 'MembershipNumberFilledInitialPurchase'));
  537. }
  538. if(!$this->insertUserName) $this->addError($attribute, Yii::t('app', 'MembershipNumberFilledInitialPurchase'));
  539. // if(!$this->insertUserIdCard) $this->addError($attribute, 'For the first purchase, the ID number of the member must be filled in');//首购必须填写加入会员的身份证号
  540. if(!$this->conUserName) $this->addError($attribute, Yii::t('app', 'fillTheInstructorNumberTheMember'));
  541. if(!$this->recUserName) $this->addError($attribute, Yii::t('app', 'sponsorNumberMustBeFilled'));
  542. if(!$this->location) $this->addError($attribute, Yii::t('app', 'beFilledTheMarketMember'));
  543. }
  544. } else {
  545. $this->addError($attribute, Yii::t('app', 'incorrectEntryType'));
  546. }
  547. }
  548. /**
  549. * 检验相同身份证 会员是否同一体系内(接点)
  550. * @param $attribute
  551. */
  552. // public function isSameSystem($attribute){
  553. // if(isset($this->_tempParentUser[$this->conUserName])){
  554. // // 新加入会员的身份证号对应网内的其他会员
  555. // $otherUser = User::findAllAsArray("ID_CARD=:ID_CARD AND IS_UNION=0 AND DELETED=0 AND (ID_CARD_PREFIX IS NULL OR ID_CARD_PREFIX='')", [':ID_CARD'=>$this->insertUserIdCard]);
  556. // if(count($otherUser)>=7){
  557. // $this->addError($attribute, 'Only 7 documents can be reported for the same ID card');//同一个身份证限制只能报7单
  558. // }
  559. // if($otherUser){
  560. // $flipParent = array_flip(array_filter($this->_tempNetworkParentUser[$this->insertUserName]));
  561. // $isExsit = false;
  562. // foreach ($otherUser as $conUser){
  563. // if(isset($flipParent[$conUser['USER_NAME']])){
  564. // $isExsit = true;
  565. // break;
  566. // }
  567. // }
  568. // if (!$isExsit) {
  569. //// $this->addError($attribute, '为' . $this->insertUserName . '报单,身份证号码相同的会员'.$otherUser[0]['USER_NAME'].'不在' . $this->insertUserName . '的安置网上级中');
  570. // $this->addError($attribute, 'To' . $this->insertUserName . 'Entry,Members with the same ID number'.$otherUser[0]['USER_NAME'].'not in exist' . $this->insertUserName . 'in the placement superiors');
  571. // return ;
  572. // }
  573. // }
  574. // } else {
  575. //// $this->addError($attribute, '为'.$this->insertUserName.'报单,接点人'.$this->conUserName.'不存在');
  576. // $this->addError($attribute, 'To'.$this->insertUserName.'Entry,Contact person'.$this->conUserName.'not in exist');
  577. // }
  578. // }
  579. /**
  580. * 添加报单
  581. * @param $allData
  582. * @return ApproachOrder
  583. * @throws Exception
  584. * @throws \yii\db\Exception
  585. */
  586. public function add($allData){
  587. if(!$this->validate()){
  588. return null;
  589. }
  590. $hasInstalment = 0;
  591. // 首购单,需要添加会员操作
  592. if($this->type == self::TYPE_ZC) {
  593. try {
  594. if (preg_match("/[\x7f-\xff]/", $this->insertUserName)) { //判断字符串中是否有中文
  595. throw new Exception(Yii::t('app', 'memberNumberCanNotContainChineseCharacters'));
  596. }
  597. //报单商品及PV判断
  598. $decLevelConfig = Cache::getDecLevelConfig();
  599. $decLevel = $decLevelConfig[$this->decLv];
  600. $toDecLevel = $this->decLv;
  601. if (!$this->decLv) {
  602. throw new Exception(Yii::t('app', 'pleaseSelectTheEntryLevel'));
  603. }
  604. if ($this->decWay == 1) {
  605. $decPackage = DeclarationPackage::findOneAsArray('ID=:ID', [':ID' => $this->packageId]);
  606. $this->_decAmount = $decPackage['AMOUNT'];
  607. $this->_decPv = $decPackage['PV'];
  608. $this->_orderGoods[] = [
  609. 'GOODS_ID' => $this->packageId,
  610. 'PRICE' => $this->_decAmount,
  611. 'REAL_PRICE' => $this->_decAmount,
  612. 'PV' => $this->_decPv,
  613. 'REAL_PV' => $this->_decPv,
  614. 'BUY_NUMS' => 1,
  615. 'SKU_CODE' => $decPackage['PACKAGE_NO'],
  616. 'GOODS_TITLE' => $decPackage['PACKAGE_NAME'],
  617. 'EMAIL' => $this->email
  618. ];
  619. } else {
  620. $ids = $this->goodsId;
  621. $totalAmount = 0;
  622. $totalAmountStandard = 0;
  623. $totalPv = 0;
  624. $exchangeRate = floatval(Cache::getSystemConfig()['exchangeRate']['VALUE'] ?? 0); // 汇率
  625. foreach ($this->goodsNum as $k => $v) {
  626. if ($v) {
  627. $goods = ShopGoods::findOneAsArray('ID=:ID AND STATUS=1', [':ID' => $ids[$k]]);
  628. if ($goods['STORE_NUMS'] > 0) {
  629. $totalAmount += $goods['SELL_PRICE'] * intval($v);
  630. $totalAmountStandard += $goods['SELL_PRICE_STANDARD'] * intval($v);
  631. $realPriceStandard = $goods['SELL_PRICE_STANDARD'];
  632. $totalPv += $goods['PRICE_PV'] * intval($v);
  633. $this->_orderGoods[] = [
  634. 'GOODS_ID' => $goods['ID'],
  635. 'PRICE' => $goods['SELL_PRICE'],
  636. 'REAL_PRICE' => $goods['SELL_PRICE'],
  637. 'PV' => $goods['PRICE_PV'],
  638. 'REAL_PV' => $goods['PRICE_PV'],
  639. 'POINT' => $goods['POINT'],
  640. 'BUY_NUMS' => intval($v),
  641. 'SKU_CODE' => $goods['GOODS_NO'],
  642. 'GOODS_TITLE' => $goods['GOODS_NAME'],
  643. 'EMAIL' => $this->email,
  644. 'STANDARD_PRICE' => $goods['SELL_PRICE_STANDARD'],
  645. 'REAL_STANDARD_PRICE' => $realPriceStandard,
  646. 'EXCHANGE_RATE' => $exchangeRate,
  647. 'TAX_RATE' => $goods['TAX_RATE'],
  648. ];
  649. }
  650. if($goods['INSTALMENT']>0){
  651. $hasInstalment = $goods['INSTALMENT'];
  652. }
  653. }
  654. }
  655. if($totalPv<$decLevel['PERF']){
  656. // if ($hasInstalment && $decLevel['LEVEL_NAME'] == 'Elite'){
  657. // }else{
  658. throw new Exception(Yii::t('app', 'totalBVCanNotLessThanSelectedBV'));
  659. // }
  660. }
  661. foreach ($decLevelConfig as $key => $val) {
  662. if ($totalPv >= $val['PERF']) {
  663. $toDecLevel = $key;
  664. }
  665. }
  666. if ($this->decLv != $toDecLevel) {
  667. // if ($hasInstalment && $decLevel['LEVEL_NAME'] == 'Elite'){
  668. // }else{
  669. throw new Exception(Yii::t('app', 'totalBVCanNotLessThanNextSelectedLevelBV'));
  670. // }
  671. }
  672. $this->_decAmount = $totalAmount;
  673. $this->_decPv = $totalPv;
  674. $this->_decAmountStandard = $totalAmountStandard;
  675. $this->_standardAmount = $this->_decAmountStandard;
  676. }
  677. if (!($zcResult = $this->addUser($allData))) {
  678. throw new Exception(Form::formatErrorsForApi($this->_userForm->getErrors()));
  679. }
  680. $decResult = $this->addDecOrder();
  681. if (!$decResult) {
  682. throw new Exception(Form::formatErrorsForApi($decResult->getErrors()));
  683. }
  684. if($hasInstalment){
  685. if(!($instalmentResult = $this->insertInstalment($zcResult))) {
  686. throw new Exception(Form::formatErrorsForApi('h'));
  687. }
  688. }
  689. return $decResult;
  690. } catch (\Exception $e) {
  691. // throw new Exception(Form::formatErrorsForApi($e->getFile() . ' ' . $e->getLine() . ' ' . $e->getMessage()));
  692. throw new Exception(Form::formatErrorsForApi($e->getMessage()));
  693. }
  694. }
  695. return true;
  696. }
  697. /**
  698. * 添加会员
  699. * @param $allData
  700. * @return bool|UserInfo|null
  701. * @throws \yii\db\Exception
  702. */
  703. public function addUser($allData){
  704. $period = Period::instance();
  705. // 增加会员
  706. $user = new User();
  707. $user->USER_NAME = $this->insertUserName;
  708. $user->PASSWORD_HASH = \Yii::$app->security->generatePasswordHash($this->password);
  709. $user->PAY_PASSWORD = \Yii::$app->security->generatePasswordHash($this->payPassword);
  710. $user->NATION = 0;
  711. $user->REAL_NAME = $this->realName;
  712. $user->ID_CARD = $this->mobile;
  713. $user->MOBILE = $this->mobile;
  714. $user->EMAIL = $this->email;
  715. $user->ADDRESS = $this->address ? $this->address : 'nothing';//无
  716. $user->OPEN_BANK = $this->openBank;
  717. $user->BANK_ADDRESS = $this->bankAddress;
  718. $user->BANK_NO = $this->bankNo;
  719. $user->BANK_PROVINCE = $this->bankProvince ?? 0;
  720. $user->BANK_CITY = $this->bankCity ?? 0;
  721. $user->BANK_COUNTY = $this->bankCounty ?? 0;
  722. $user->CREATED_AT = Date::nowTime();
  723. $user->STATUS = 0;
  724. $user->DEC_LV = $this->decLv;
  725. $user->LAST_DEC_LV = $this->decLv;
  726. $user->EMP_LV = EmployLevel::getDefaultLevelId();
  727. $user->PROVINCE = $this->province ?? 0;
  728. $user->LGA_NAME = $this->lgaName;
  729. $user->CITY_NAME = $this->cityName;
  730. // $user->CITY = $this->city ?? 0;
  731. // $user->COUNTY = intval($this->county) ?? 0;
  732. $user->AVATAR = 'avatar/1.png';
  733. $user->IS_DEC = 0;
  734. $user->DEC_ID = $this->_decId ?? null;
  735. $user->DEC_ROLE_ID = $this->decRoleId ?? null;
  736. $user->PERIOD_AT = $period->getNowPeriodNum();
  737. $user->IS_DIRECT_SELLER = 0;
  738. $user->VERIFIED = 1;
  739. $user->VERIFIED_AT = Date::nowTime();
  740. $user->IS_RECHARGE = 1;
  741. if (!$user->save()) {
  742. throw new Exception(Form::formatErrorsForApi($user->getErrors()));
  743. }
  744. $this->_insertUserId = $user->ID;
  745. $userForm = new UserForm();
  746. $this->_userForm = $userForm;
  747. $userForm->scenario = 'addWithUserName';
  748. $userForm->userId = $this->_insertUserId;
  749. $userForm->userName = $this->insertUserName;
  750. $userForm->zcPv = $this->_decPv;
  751. $userForm->zcAmount = $this->_decAmount;
  752. $userForm->conUserName = $this->conUserName;
  753. $userForm->recUserName = $this->recUserName;
  754. $userForm->location = $this->location;
  755. $userForm->idCard = $this->mobile;
  756. $userForm->allData = $allData;
  757. if(!$userForm->validate()){
  758. $this->addErrors($userForm->getErrors());
  759. return false;
  760. }
  761. if($result = $userForm->add()){
  762. return $result;
  763. } else {
  764. return false;
  765. }
  766. }
  767. /**
  768. * 添加报单订单
  769. * @throws \yii\db\Exception
  770. */
  771. public function addDecOrder(){
  772. $periodObj = Period::instance();
  773. $nowPeriodNum = $periodObj->getNowPeriodNum();
  774. $nowCalcMonth = $periodObj->getYearMonth($nowPeriodNum);
  775. $ord = date('Ymd').substr(implode(NULL, array_map('ord', str_split(substr(uniqid(), 7, 13), 1))), 0, 10);
  776. // 加入报单信息
  777. $decOrderModel = new ApproachDecOrder();
  778. $decOrderModel->DEC_SN = 'DS' . $ord;
  779. $decOrderModel->ORDER_SN = 'OS' . $ord;
  780. $decOrderModel->TYPE = $this->type;
  781. $decOrderModel->USER_ID = \Yii::$app->user->id;
  782. $decOrderModel->TO_USER_ID = $this->_insertUserId;
  783. $decOrderModel->DEC_AMOUNT = $this->_decAmount;
  784. $decOrderModel->DEC_PV = $this->_decPv;
  785. $decOrderModel->PERIOD_NUM = $nowPeriodNum;
  786. $decOrderModel->CALC_MONTH = $nowCalcMonth;
  787. $decOrderModel->P_CALC_MONTH = Date::ociToDate($nowCalcMonth, Date::OCI_TIME_FORMAT_SHORT_MONTH);
  788. $decOrderModel->PAID_WALLET = $this->payType;
  789. $decOrderModel->CON_USER_ID = Info::getUserIdByUserName($this->conUserName);
  790. $decOrderModel->REC_USER_ID = Info::getUserIdByUserName($this->recUserName);
  791. $decOrderModel->DEC_ID = $this->_decId;
  792. $decOrderModel->IS_DEL = 0;
  793. $decOrderModel->CREATED_AT = Date::nowTime();
  794. if(!$decOrderModel->save()){
  795. throw new Exception(Form::formatErrorsForApi($decOrderModel->getErrors()));
  796. }
  797. // 加入订单信息
  798. if ($this->province!=1) {
  799. // 仓库
  800. $warehouse = Region::getWarehouseByCode($this->province);
  801. if (!$warehouse) {
  802. // 地区暂时不支持配送,具体联系客服
  803. throw new Exception(Yii::t('app', 'deliveryTemporarilyNotSupported'));
  804. }
  805. } else {
  806. $warehouse = '01';
  807. }
  808. $exchangeRate = floatval(Cache::getSystemConfig()['exchangeRate']['VALUE'] ?? 0);
  809. $orderModel = new ApproachOrder();
  810. $orderModel->SN = 'OS' . $ord;
  811. $orderModel->DEC_SN = 'DS' . $ord;
  812. $orderModel->DEC_USER_ID = $this->_decId;
  813. $orderModel->ORDER_TYPE = $this->type;
  814. $orderModel->USER_ID = $this->_insertUserId;
  815. $orderModel->USER_NAME = $this->insertUserName;
  816. $orderModel->ORDER_AMOUNT = $this->_decAmount;
  817. $orderModel->PV = $this->_decPv;
  818. $orderModel->PAY_AMOUNT = $this->_decAmount;
  819. $orderModel->PAY_PV = $this->_decPv;
  820. $orderModel->PAY_AT = 0;
  821. $orderModel->PAY_TYPE = $this->payType;
  822. $orderModel->PERIOD_NUM = $nowPeriodNum;
  823. $orderModel->P_CALC_MONTH = Date::ociToDate($nowCalcMonth, Date::OCI_TIME_FORMAT_SHORT_MONTH);
  824. $orderModel->FREIGHT = 0;
  825. $orderModel->PAY_FREIGHT = 0;
  826. $orderModel->CONSIGNEE = $this->consignee;
  827. $orderModel->MOBILE = $this->acceptMobile;
  828. $orderModel->EMAIL = $this->email ?: $this->insertUserName . '@elken.net';
  829. $orderModel->PROVINCE = $this->province;
  830. $orderModel->LGA_NAME = $this->lgaName;
  831. $orderModel->CITY_NAME = $this->cityName;
  832. $orderModel->ADDRESS = $this->address;
  833. $orderModel->WAREHOUSE = $warehouse;
  834. $orderModel->STATUS = \Yii::$app->params['orderStatus']['notPaid']['value'];
  835. $orderModel->CREATED_AT = Date::nowTime();
  836. $orderModel->CREATE_USER = Info::getUserNameByUserId(\Yii::$app->user->id);
  837. $orderModel->ORDER_AMOUNT_STANDARD = $this->_decAmountStandard;
  838. $orderModel->PAY_AMOUNT_STANDARD = $this->_standardAmount;
  839. $orderModel->EXCHANGE_RATE = $exchangeRate;
  840. if ($this->province==1) {
  841. $orderModel->EXPRESS_TYPE = 1;
  842. }
  843. if (!$orderModel->save()) {
  844. throw new Exception(Form::formatErrorsForApi($orderModel->getErrors()));
  845. }
  846. // 加入商品到订单商品表
  847. foreach($this->_orderGoods as $key=>$value){
  848. $this->_orderGoods[$key]['ORDER_SN'] = $orderModel->SN;
  849. $this->_orderGoods[$key]['P_CALC_MONTH'] = Date::ociToDate($nowCalcMonth, Date::OCI_TIME_FORMAT_SHORT_MONTH);
  850. }
  851. ApproachOrderGoods::batchInsert($this->_orderGoods);
  852. // 写入收货地址信息,判断province字段,当不为1时,插入收货地址信息
  853. $addressModel = new ReceiveAddress();
  854. if ($this->province != 1) {
  855. $addressModel->USER_ID = $this->_insertUserId;
  856. $addressModel->USER_NAME = $this->insertUserName;
  857. $addressModel->CONSIGNEE = $this->consignee;
  858. $addressModel->MOBILE = $this->acceptMobile;
  859. $addressModel->PROVINCE = $this->province;
  860. $addressModel->CITY_NAME = $this->cityName;
  861. $addressModel->LGA_NAME = $this->lgaName;
  862. $addressModel->ADDRESS = $this->address;
  863. $addressModel->IS_DEFAULT = 1;
  864. if (!$addressModel->save()) {
  865. throw new Exception(Form::formatErrorsForApi($addressModel->getErrors()));
  866. }
  867. }
  868. return $orderModel;
  869. }
  870. /**
  871. * 删单
  872. * @return bool
  873. * @throws \yii\db\Exception
  874. */
  875. public function delete(){
  876. if(!$this->validate()){
  877. return false;
  878. }
  879. $transaction = \Yii::$app->db->beginTransaction();
  880. try {
  881. $oneOrder = $this->_oneOrder;
  882. // 首购单要删除会员
  883. if($this->type == self::TYPE_ZC){
  884. UserInfo::deleteUser($oneOrder['TO_USER_ID']);
  885. }
  886. // 如果是复销单的话,还需要考虑给会员的复销池减去金额
  887. elseif($this->type == self::TYPE_FX){
  888. // Reconsume::changePoolPV($oneOrder['TO_USER_ID'], -abs($oneOrder['DEC_PV']), ['REMARK'=>'删单扣除', 'DEAL_TYPE'=>Reconsume::TYPE_AUDIT_PV]);
  889. Reconsume::changePoolPV($oneOrder['TO_USER_ID'], -abs($oneOrder['DEC_PV']), ['REMARK'=>'Deletion deduction', 'DEAL_TYPE'=>Reconsume::TYPE_AUDIT_PV]);
  890. }
  891. $transaction->commit();
  892. } catch (Exception $e) {
  893. $transaction->rollBack();
  894. $this->addError('delete', $e->getMessage());
  895. return false;
  896. }
  897. return true;
  898. }
  899. /**
  900. * 添加会员分期付款记录
  901. * @param $allData
  902. * @return bool|UserInfo|null
  903. * @throws \yii\db\Exception
  904. */
  905. public function insertInstalment($zcResult){
  906. // 增加会员分期付款记录
  907. $instalment = new Instalment();
  908. $instalment->USER_ID = $zcResult->USER_ID;
  909. $instalment->STAGE = 1;
  910. $instalment->ORDER_TYPE = 'BD';
  911. $instalment->UPDATE_TIME = time();
  912. if (!$instalment->save()) {
  913. throw new Exception(Form::formatErrorsForApi($instalment->getErrors()));
  914. }
  915. return $instalment;
  916. }
  917. }