MemberModel.php 62 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * Author: 芸众商城 www.yunzshop.com
  5. * Date: 17/2/22
  6. * Time: 下午4:53
  7. */
  8. /**
  9. * 会员表
  10. */
  11. namespace app\frontend\modules\member\models;
  12. use app\backend\modules\member\models\MemberRelation;
  13. use app\common\helpers\Url;
  14. use app\common\models\Member;
  15. use app\common\models\member\MemberChildren;
  16. use app\common\models\MemberShopInfo;
  17. use app\common\models\Setting;
  18. use Illuminate\Support\Facades\DB;
  19. use phpDocumentor\Reflection\Types\This;
  20. use SimpleSoftwareIO\QrCode\Facades\QrCode;
  21. use app\common\models\Order;
  22. use Yunshop\AgentListSet\admin\SetController;
  23. use Yunshop\CloudLinkPort\common\models\ChangeLog;
  24. use Yunshop\CloudLinkPort\common\models\SetModel;
  25. use Yunshop\CloudLinkPort\common\services\AdvertService;
  26. use Yunshop\Commission\models\AgentLevel;
  27. use Yunshop\ConsumerReward\common\models\ConsumerRewardRecordModel;
  28. use Yunshop\EcologicalPoint\common\models\PointModel;
  29. use Yunshop\Integral\Common\Models\IntegralMemberModel;
  30. use Yunshop\Integral\Common\Services\SetService;
  31. use Yunshop\Love\Common\Models\MemberLove;
  32. use Yunshop\Love\Common\Services\ConstService;
  33. use Yunshop\Love\Common\Services\LoveChangeService;
  34. use Yunshop\Merchant\common\models\MerchantLevel;
  35. use Yunshop\Micro\common\models\MicroShopLevel;
  36. use Yunshop\TeamDividend\models\TeamDividendLevelModel;
  37. use app\common\helpers\ImageHelper;
  38. use Yunshop\UniversalCard\models\ConsumeCoupon;
  39. class MemberModel extends Member
  40. {
  41. /**
  42. * 获取用户uid
  43. *
  44. * @param $uniacid
  45. * @param $mobile
  46. * @return mixed
  47. */
  48. public static function getId($uniacid, $mobile)
  49. {
  50. return self::select('uid')
  51. ->where('uniacid', $uniacid)
  52. ->where('mobile', $mobile)
  53. ->first();
  54. }
  55. public static function getMemberinfo($uniacid, $mobile)
  56. {
  57. return self::where('uniacid', $uniacid)
  58. ->where('mobile', $mobile)
  59. ->first();
  60. }
  61. /**
  62. * 添加数据并返回id
  63. *
  64. * @param $data
  65. * @return mixed
  66. */
  67. public static function insertData($userinfo, $data)
  68. {
  69. $member_model = new MemberModel();
  70. $member_model->uniacid = $data['uniacid'];
  71. $member_model->email = '';
  72. $member_model->groupid = is_null($data['groupid']) ? 0 : $data['groupid'];
  73. $member_model->createtime = time();
  74. $member_model->nickname = stripslashes($userinfo['nickname']);
  75. // $member_model->avatar = (isset($userinfo['headimgurl']) && !empty($userinfo['headimgurl'])) ? $userinfo['headimgurl'] : Url::shopUrl('static/images/photo-mr.jpg');
  76. $member_model->avatar = (isset($userinfo['headimgurl']) && !empty($userinfo['headimgurl'])) ? $userinfo['headimgurl'] : '';
  77. $member_model->gender = isset($userinfo['sex']) ? $userinfo['sex'] : -1;
  78. $member_model->nationality = isset($userinfo['country']) ? $userinfo['country'] : '';
  79. $member_model->resideprovince = isset($userinfo['province']) ? $userinfo['province'] : '' . '省';
  80. $member_model->residecity = isset($userinfo['city']) ? $userinfo['city'] : '' . '市';
  81. $member_model->salt = '';
  82. $member_model->password = '';
  83. if ($member_model->save()) {
  84. return $member_model->uid;
  85. } else {
  86. return false;
  87. }
  88. }
  89. /**
  90. * 获取手机号码
  91. *
  92. * @param int $member_id 用户id
  93. * @return mixed
  94. */
  95. public static function getMobile($member_id)
  96. {
  97. return self::uniacid()
  98. ->where('uid', $member_id)
  99. ->value('mobile');
  100. }
  101. /**
  102. * 检查手机号是否存在
  103. *
  104. * @param $uniacid
  105. * @param $mobile
  106. * @return mixed
  107. */
  108. public static function checkMobile($uniacid, $mobile)
  109. {
  110. return self::where('uniacid', $uniacid)
  111. ->where('mobile', $mobile)
  112. ->first();
  113. }
  114. /**
  115. * 获取用户信息
  116. *
  117. * @param $uniacid
  118. * @param $mobile
  119. * @param $password
  120. * @return mixed
  121. */
  122. public static function getUserInfo($uniacid, $mobile, $password)
  123. {
  124. return self::where('uniacid', $uniacid)
  125. ->where('mobile', $mobile)
  126. ->where('password', $password);
  127. }
  128. /**
  129. * 更新数据
  130. *
  131. * @param $uid
  132. * @param $data
  133. * @return mixed
  134. */
  135. public static function updataData($uid, $data)
  136. {
  137. return self::uniacid()
  138. ->where('uid', $uid)
  139. ->update($data);
  140. }
  141. /**
  142. * 我的推荐人信息
  143. *
  144. * @param $uid
  145. * @return mixed
  146. */
  147. public static function getMyReferrerInfo($uid)
  148. {
  149. return self::select(['uid', 'avatar', 'nickname','mobile'])->uniacid()
  150. ->where('uid', $uid)
  151. ->with([
  152. 'yzMember' => function ($query) {
  153. return $query->select(['member_id', 'parent_id', 'is_agent', 'group_id', 'level_id', 'is_black', 'alipayname', 'alipay', 'status', 'inviter','wechat'])
  154. ->where('is_black', 0)
  155. ->with(['level' => function ($query2) {
  156. return $query2->select(['id', 'level_name'])->uniacid();
  157. }]);
  158. }
  159. ]);
  160. }
  161. /**
  162. * 获取我的下线
  163. *
  164. * @return mixed
  165. */
  166. public static function getAgentCount($uid)
  167. {
  168. return self::uniacid()
  169. ->whereHas('yzMember', function ($query) use ($uid) {
  170. $query->where('parent_id', $uid)->where('inviter', 1);
  171. })
  172. ->count();
  173. }
  174. /**
  175. * 我的下线信息 1级
  176. *
  177. * @param $uid
  178. * @return mixed
  179. */
  180. public static function getMyAgentInfo($uid)
  181. {
  182. return self::uniacid()
  183. ->whereHas('yzMember', function ($query) use ($uid) {
  184. $query->where('parent_id', $uid)->where('inviter', 1);
  185. })
  186. ->with(['hasOneOrder' => function ($query) {
  187. return $query->selectRaw('uid, count(uid) as total, sum(price) as sum')
  188. ->uniacid()
  189. ->where('status', 3)
  190. ->groupBy('uid');
  191. }]);
  192. }
  193. public static function getMyAllAgentsInfo($uid, $level)
  194. {
  195. $child_member = DB::table('yz_member_children')
  196. ->select('child_id')
  197. ->where('member_id', $uid)
  198. ->where('uniacid', \YunShop::app()->uniacid)
  199. ->where('level', $level)
  200. ->get();
  201. foreach ($child_member as $child_id) {
  202. $child_id[] = $child_id['child_id'];
  203. }
  204. return self::uniacid()->whereIn('uid', $child_id);
  205. }
  206. /**
  207. * 查出用户的某一级别下线的会员资料
  208. * @param $uid
  209. * @param $level
  210. * @return MemberModel
  211. */
  212. public static function getMyAllAgentsInfoBySearch($uid, $level)
  213. {
  214. $child_member1 = DB::table('yz_member_children')->select('child_id')->where('member_id', $uid)->where('uniacid', \YunShop::app()->uniacid)->where('level', 1)->get();
  215. foreach ($child_member1 as $child_id) {
  216. $child_id1[] = $child_id['child_id'];
  217. }
  218. $child_member2 = DB::table('yz_member_children')->select('child_id')->where('member_id', $uid)->where('uniacid', \YunShop::app()->uniacid)->where('level', 2)->get();
  219. foreach ($child_member2 as $child_id) {
  220. $child_id2[] = $child_id['child_id'];
  221. }
  222. $child_member3 = DB::table('yz_member_children')->select('child_id')->where('member_id', $uid)->where('uniacid', \YunShop::app()->uniacid)->where('level', 3)->get();
  223. foreach ($child_member3 as $child_id) {
  224. $child_id3[] = $child_id['child_id'];
  225. }
  226. if ($level == 1) {
  227. $result = self::uniacid()->whereIn('uid', $child_id1);
  228. } elseif ($level == 2) {
  229. $result = self::uniacid()->whereIn('uid', $child_id2);
  230. } else {
  231. $result = self::uniacid()->whereIn('uid', $child_id3);
  232. }
  233. $result = $result->with(['yzMember' => function ($query) {
  234. return $query->select('member_id', 'is_agent', 'status', 'wechat', 'deleted_at');
  235. }]);
  236. return $result->orderBy('uid', 'desc');
  237. }
  238. /**
  239. * 我的下线信息 3级
  240. *
  241. * @param $uid
  242. * @return mixed
  243. */
  244. public static function getMyAgentsInfo($uid)
  245. {
  246. return self::uniacid()
  247. ->with(['hasManyYzMember' => function ($query) {
  248. return $query->with(['hasManySelf' => function ($query) {
  249. return $query->with(['hasManySelf' => function ($query) {
  250. return $query->get();
  251. }])->get();
  252. }])->get();
  253. }])
  254. ->where('uid', $uid);
  255. }
  256. /**
  257. * 我的上级 3级
  258. *
  259. * @param $uid
  260. * @return mixed
  261. */
  262. public static function getMyAgentsParentInfo($uid)
  263. {
  264. return self::select(['uid'])
  265. ->uniacid()
  266. ->with(['yzMember' => function ($query) {
  267. return $query->select(['member_id', 'parent_id'])
  268. ->with(['hasOnePreSelf' => function ($query) {
  269. return $query->select(['member_id', 'parent_id'])
  270. ->with(['hasOnePreSelf' => function ($query) {
  271. return $query->select(['member_id', 'parent_id'])
  272. ->with(['hasOnePreSelf' => function ($query) {
  273. return $query->select(['member_id', 'parent_id'])->first();
  274. }])->first();
  275. }])->first();
  276. }])->first();
  277. }])
  278. ->where('uid', $uid);
  279. }
  280. /**
  281. *
  282. * @return mixed
  283. */
  284. public function hasManyYzMember()
  285. {
  286. return $this->hasMany('app\common\models\MemberShopInfo', 'parent_id', 'uid');
  287. }
  288. /**
  289. * 用户是否有推广权限
  290. *
  291. * @return mixed
  292. */
  293. public static function isAgent()
  294. {
  295. $uid = \YunShop::app()->getMemberId();
  296. if (!empty($uid)) {
  297. //MemberRelation::checkAgent($uid);
  298. $member_info = SubMemberModel::getMemberShopInfo($uid);
  299. if ($member_info && $member_info->is_agent == 1 && $member_info->status == 2) {
  300. return true;
  301. }
  302. }
  303. return false;
  304. }
  305. /**
  306. * 我的推荐人
  307. *
  308. * @return array
  309. */
  310. public static function getMyReferral()
  311. {
  312. $member_info = self::getMyReferrerInfo(\YunShop::app()->getMemberId())->first();
  313. $set = \Setting::get('shop.member');
  314. $data = [];
  315. if (!empty($member_info)) {
  316. if (isset($set) && $set['headimg']) {
  317. $avatar = replace_yunshop(tomedia($set['headimg']));
  318. } else {
  319. $avatar = Url::shopUrl('static/images/photo-mr.jpg');
  320. }
  321. $member_info = $member_info->toArray();
  322. $referrer_info = self::getUserInfos($member_info['yz_member']['parent_id'])->first();
  323. if ($member_info['yz_member']['inviter'] == 1) {
  324. if (!empty($referrer_info)) {
  325. $info = $referrer_info->toArray();
  326. $data = [
  327. 'uid' => $info['uid'],
  328. 'avatar' => $info['avatar'],
  329. 'nickname' => $info['nickname'],
  330. 'level' => $info['yz_member']['level']['level_name'],
  331. 'is_show' => $set['is_referrer']
  332. ];
  333. } else {
  334. $data = [
  335. 'uid' => '',
  336. 'avatar' => $avatar,
  337. 'nickname' => '总店',
  338. 'level' => '',
  339. 'is_show' => $set['is_referrer']
  340. ];
  341. }
  342. } else {
  343. $data = [
  344. 'uid' => '',
  345. 'avatar' => $avatar,
  346. 'nickname' => '暂无',
  347. 'level' => '',
  348. 'is_show' => $set['is_referrer']
  349. ];
  350. }
  351. }
  352. return $data;
  353. }
  354. /**
  355. * 我的推荐人
  356. * @param $yz_member
  357. * @param $set
  358. * @return array
  359. */
  360. public static function getMyReferral_v3($yz_member, $set)
  361. {
  362. if (isset($set) && $set['headimg']) {
  363. $avatar = replace_yunshop(tomedia($set['headimg']));
  364. } else {
  365. $avatar = Url::shopUrl('static/images/photo-mr.jpg');
  366. }
  367. $referrer_info = self::getMyReferrerInfo($yz_member['parent_id'])->first();
  368. /* if ($yz_member['inviter'] == 1) {
  369. if (!empty($referrer_info)) {
  370. $info = $referrer_info->toArray();
  371. $data = [
  372. 'uid' => $info['uid'],
  373. 'avatar' => $info['avatar'],
  374. 'nickname' => $info['nickname'],
  375. 'level' => $info['yz_member']['level']['level_name'],
  376. 'is_show' => $set['is_referrer']
  377. ];
  378. } else {
  379. $data = [
  380. 'uid' => '',
  381. 'avatar' => $avatar,
  382. 'nickname' => '总店',
  383. 'level' => '',
  384. 'is_show' => $set['is_referrer']
  385. ];
  386. }
  387. } else {
  388. $data = [
  389. 'uid' => '',
  390. 'avatar' => $avatar,
  391. 'nickname' => '暂无',
  392. 'level' => '',
  393. 'is_show' => $set['is_referrer']
  394. ];
  395. }*/
  396. if (!empty($referrer_info)) {
  397. $info = $referrer_info->toArray();
  398. if ($yz_member['inviter'] == 1) {
  399. $set_name = '';
  400. $data = [
  401. 'uid' => $info['uid'],
  402. 'avatar' => $info['avatar'],
  403. 'nickname' => $set_name . $info['nickname'],
  404. 'level' => $info['yz_member']['level']['level_name'],
  405. 'is_show' => $set['is_referrer']
  406. ];
  407. } else {
  408. $set_name = '(暂定)';
  409. $data = [
  410. 'uid' => $info['uid'],
  411. 'avatar' => $info['avatar'],
  412. 'nickname' => $set_name . $info['nickname'],
  413. 'level' => $info['yz_member']['level']['level_name'],
  414. 'is_show' => $set['is_referrer']
  415. ];
  416. }
  417. } else {
  418. $data = [
  419. 'uid' => '',
  420. 'avatar' => $avatar,
  421. 'nickname' => '总店',
  422. 'level' => '',
  423. 'is_show' => $set['is_referrer']
  424. ];
  425. }
  426. return $data;
  427. }
  428. /**
  429. * 我的推荐人 v2
  430. *
  431. * @return array
  432. */
  433. public static function getMyReferral_v2()
  434. {
  435. ini_set('memory_limit', -1);
  436. $member_id = \YunShop::app()->getMemberId();
  437. $member_info = self::getMyReferrerInfo($member_id)->first();
  438. $unicid = \YunShop::app()->uniacid;
  439. $set = \Setting::get('shop.member');
  440. $data = [];
  441. $member_set = \Setting::get('relation_base');
  442. if (!empty($member_info)) {
  443. if (isset($set) && $set['headimg']) {
  444. $avatar = replace_yunshop(yz_tomedia($set['headimg']));
  445. } else {
  446. $avatar = Url::shopUrl('static/images/photo-mr.jpg');
  447. }
  448. $member_info = $member_info->toArray();
  449. $member_info['avatar'] = yz_tomedia($member_info['avatar']);
  450. $builder = self::getUserInfos($member_info['yz_member']['parent_id']);
  451. $referrer_info = self::getMemberRole($builder)->first();
  452. if ($member_info['yz_member']['inviter'] == 1) {
  453. if (!empty($referrer_info)) {
  454. $info = $referrer_info->toArray();
  455. $data = [
  456. 'uid' => $info['uid'],
  457. 'avatar' => $info['avatar'],
  458. 'nickname' => $info['nickname'],
  459. 'level' => $info['yz_member']['level']['level_name'],
  460. 'is_show' => $member_set['is_referrer'] ?: 0,
  461. 'referrer_phone' => $info['mobile'],
  462. 'referrer_wechat' => $info['yz_member']['wechat'],
  463. ];
  464. } else {
  465. $data = [
  466. 'uid' => '',
  467. 'avatar' => $avatar,
  468. 'nickname' => '总店',
  469. 'level' => '',
  470. 'is_show' => $member_set['is_referrer'] ?: 0,
  471. ];
  472. }
  473. } else {
  474. $data = [
  475. 'uid' => '',
  476. 'avatar' => $avatar,
  477. 'nickname' => '暂无',
  478. 'level' => '',
  479. 'is_show' => $member_set['is_referrer'] ?: 0,
  480. ];
  481. }
  482. //团队1级会员
  483. // $order = DB::table('yz_order')->select('uid', 'price', 'goods_total', 'status')->where(['status' => 3, 'uniacid' => $unicid])->get();
  484. // $order_goods = DB::table('yz_order')->select('uid', 'price', 'goods_total', 'status')->where(['uniacid' => $unicid])->where('status', '>=', 1)->get();
  485. //
  486. // $member_1 = DB::table('yz_member_children')->select('child_id')->where('member_id', $member_id)->where('level', 1)->where('uniacid', $unicid)->get();
  487. // foreach ($member_1 as $child_id) {
  488. // $child_id1[] = $child_id['child_id'];
  489. // }
  490. // $data['child_total'] = collect($child_id1)->count();
  491. // $data['child_order_money'] = round($order->whereIn('uid', $child_id1)->sum('price'), 2);
  492. //
  493. // 团队会员
  494. // $childMemberTeam = DB::table('yz_member_children')->select('child_id')->where('member_id', $member_id)->where('uniacid', $unicid)->get();
  495. // foreach ($childMemberTeam as $child_id) {
  496. // $child_idAll[] = $child_id['child_id'];
  497. // }
  498. // $data['team_total'] = collect($child_idAll)->count();
  499. // $data['team_order_money'] = round($order->whereIn('uid', $child_idAll)->sum('price'), 2);
  500. // $data['team_goods_total'] = $order_goods->whereIn('uid', $child_idAll)->sum('goods_total');
  501. //---------------------new-----------------------
  502. //团队1级会员
  503. $data['child_total'] = DB::table('yz_member_children')
  504. ->join('yz_member', function ($join) {
  505. $join->on('yz_member.member_id', '=', 'yz_member_children.child_id')
  506. ->whereNull('deleted_at');
  507. })
  508. ->where('yz_member_children.uniacid',$unicid)
  509. ->where('yz_member_children.member_id',$member_id)
  510. ->where('level',1)
  511. ->count();
  512. $childs = MemberChildren::uniacid()->where("member_id",$member_id)->pluck("child_id");
  513. $level_childs = MemberChildren::uniacid()->where("member_id",$member_id)->where("level",1)->pluck("child_id");
  514. if(app('plugins')->isEnabled('agent-list-set') && \Setting::get('plugin.agent-liset-set.pay_order')){
  515. $team_order_money = SetController::getChildOrderMoney($member_id, $unicid); //统计已完成+已支付订单+自己的订单
  516. }else{
  517. if (empty($level_childs)) {
  518. $team_order_money = 0 ;
  519. } else {
  520. $team_order_money = Order::uniacid()
  521. ->whereIn("uid",$level_childs)
  522. ->where('yz_order.status',3)
  523. ->sum('yz_order.price');
  524. }
  525. }
  526. $data['child_order_money'] = round($team_order_money,2);
  527. //团队会员
  528. $data['team_total'] = DB::table('yz_member_children')
  529. ->join('yz_member', function ($join) {
  530. $join->on('yz_member.member_id', '=', 'yz_member_children.child_id')
  531. ->whereNull('deleted_at');
  532. })
  533. ->where('yz_member_children.uniacid',$unicid)
  534. ->where('yz_member_children.member_id',$member_id)
  535. ->count();
  536. if(app('plugins')->isEnabled('agent-list-set') && \Setting::get('plugin.agent-liset-set.pay_order')){
  537. $team_all = SetController::getAllOrderMoney($member_id, $unicid); //统计已完成+已支付订单+自己的订单
  538. }else {
  539. if (empty($childs)) {
  540. $team_all = 0;
  541. } else {
  542. $team_all = Order::uniacid()
  543. ->whereIn("uid", $childs)
  544. ->where('yz_order.status', 3)
  545. ->sum('yz_order.price');
  546. }
  547. }
  548. $data['team_order_money'] = round($team_all,2);
  549. if (empty($childs)) {
  550. $team_goods_total = 0;
  551. } else {
  552. $team_goods_total = Order::uniacid()
  553. ->whereIn("uid",$childs)
  554. ->where('yz_order.status','>=',1)
  555. ->sum('yz_order.goods_total');
  556. }
  557. $data['team_goods_total'] = intval($team_goods_total);
  558. //---------------------new-----------------------
  559. }
  560. $data['self'] = $member_info;
  561. $data['is_recommend_wechat'] = $member_set['is_recommend_wechat'] ?: 0;
  562. $data['wechat'] = $member_set['relation_level']['wechat'] ?: 0;
  563. $data['phone'] = $member_set['relation_level']['phone'] ?: 0;
  564. $data['realname'] = $member_set['relation_level']['realname'] ?: 0;
  565. $data['name1'] = $member_set['relation_level']['name1'] ?: '';
  566. $data['name2'] = $member_set['relation_level']['name2'] ?: '';
  567. $data['name3'] = $member_set['relation_level']['name3'] ?: '';
  568. return $data;
  569. }
  570. /**
  571. * 推广二维码
  572. *
  573. * @param string $extra
  574. * @return mixed
  575. */
  576. public static function getAgentQR($extra = '')
  577. {
  578. //把首页链接换成会员中心链接
  579. $url = Url::absoluteApp('/member');
  580. $url = $url . '&mid=' . \YunShop::app()->getMemberId();
  581. if (!empty($extra)) {
  582. $extra = '_' . $extra;
  583. }
  584. $extend = 'png';
  585. $filename = \YunShop::app()->uniacid . '_' . \YunShop::app()->getMemberId() . $extra . '.' . $extend;
  586. $path = \Storage::url('app/public/qr/');
  587. //格式 参数 保存路径
  588. QrCode::format($extend)->size(400)->generate($url, base_path($path) . $filename);
  589. return request()->getSchemeAndHttpHost() . config('app.webPath') . $path . $filename;
  590. }
  591. //生成小程序二维码
  592. public function getWxacode($extra = '')
  593. {
  594. if (!empty($extra)) {
  595. $extra = '_' . $extra;
  596. }
  597. $extend = 'png';
  598. $filename = \YunShop::app()->uniacid . '_' . \YunShop::app()->getMemberId() . $extra . '.' . $extend;
  599. $paths = \Storage::url('app/public/qr/');
  600. $decorate_open = \Setting::get('plugin.decorate.is_open');
  601. $page = 'pages/member/index_v2/index_v2';
  602. if (\YunShop::plugin()->get('decorate') && $decorate_open == 1) {
  603. $page = 'packageG/member_v2/member_v2';
  604. }
  605. $url = "https://api.weixin.qq.com/wxa/getwxacodeunlimit?";
  606. $token = self::getTokenUrlStr();
  607. $url .= "access_token=" . $token;
  608. $postdata = [
  609. "scene" => 'mid=' . \YunShop::app()->getMemberId(),
  610. "page" => $page,
  611. 'width' => 200
  612. ];
  613. $res = self::curl_post($url, json_encode($postdata), $options = array());//请求生成二维码
  614. \Log::debug('------生成小程序二维码------', json_decode($res, true));
  615. file_put_contents(base_path($paths) . $filename, $res);//保存二维码
  616. return request()->getSchemeAndHttpHost() . config('app.webPath') . $paths . $filename;
  617. }
  618. //获取token的url参数拼接
  619. public function getTokenUrlStr()
  620. {
  621. $set = \Setting::get('plugin.min_app');
  622. $getTokenUrl = "https://api.weixin.qq.com/cgi-bin/token?"; //获取token的url
  623. $WXappid = $set['key']; //APPID
  624. $WXsecret = $set['secret']; //secret
  625. $str = $getTokenUrl;
  626. $str .= "grant_type=client_credential&";
  627. $str .= "appid=" . $WXappid . "&";
  628. $str .= "secret=" . $WXsecret;
  629. $res = self::curl_post($str, $postdata = '', $options = array());
  630. $data = json_decode($res, JSON_FORCE_OBJECT);
  631. return $data['access_token'];
  632. }
  633. public function curl_post($url = '', $postdata = '', $options = array())
  634. {
  635. $ch = curl_init($url);
  636. curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
  637. curl_setopt($ch, CURLOPT_POST, 1);
  638. curl_setopt($ch, CURLOPT_POSTFIELDS, $postdata);
  639. curl_setopt($ch, CURLOPT_TIMEOUT, 5);
  640. curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
  641. curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
  642. if (!empty($options)) {
  643. curl_setopt_array($ch, $options);
  644. }
  645. $data = curl_exec($ch);
  646. curl_close($ch);
  647. return $data;
  648. }
  649. /**
  650. * 我推荐的人
  651. * @return array
  652. */
  653. public static function getMyAgent()
  654. {
  655. $agent_ids = [];
  656. $data = [];
  657. $agent_info = MemberModel::getMyAgentInfo(\YunShop::app()->getMemberId());
  658. $agent_model = $agent_info->get();
  659. if (!empty($agent_model)) {
  660. $agent_data = $agent_model->toArray();
  661. foreach ($agent_data as $key => $item) {
  662. $agent_ids[$key] = $item['uid'];
  663. $agent_data[$key]['agent_total'] = 0;
  664. }
  665. } else {
  666. return '数据为空';
  667. }
  668. $all_count = MemberShopInfo::getAgentAllCount($agent_ids);
  669. foreach ($all_count as $k => $rows) {
  670. foreach ($agent_data as $key => $item) {
  671. if ($rows['parent_id'] == $item['uid']) {
  672. $agent_data[$key]['agent_total'] = $rows['total'];
  673. break 1;
  674. }
  675. }
  676. }
  677. if ($agent_data) {
  678. foreach ($agent_data as $item) {
  679. $data[] = [
  680. 'uid' => $item['uid'],
  681. 'avatar' => $item['avatar'],
  682. 'nickname' => $item['nickname'],
  683. 'order_total' => $item['has_one_order']['total'],
  684. 'order_price' => $item['has_one_order']['sum'],
  685. 'agent_total' => $item['agent_total'],
  686. ];
  687. }
  688. }
  689. return $data;
  690. }
  691. /**
  692. * 我推荐的人v2 基本信息
  693. * @return array
  694. */
  695. public static function getMyAgent_v2()
  696. {
  697. set_time_limit(0);
  698. $data = [
  699. 'total' => 0
  700. ];
  701. $total = 0;
  702. $first = true;
  703. $second = true;
  704. $relation_base = \Setting::get('relation_base');
  705. if (!empty($relation_base['relation_level'])) {
  706. $first = $relation_base['relation_level'][0] ? true : false;
  707. $second = $relation_base['relation_level'][1] ? true : false;
  708. }
  709. for ($i = 1; $i <= 3; $i++) {
  710. $text = 'level' . $i;
  711. switch ($i) {
  712. case 1:
  713. $is_show = $first;
  714. $level = '一级';
  715. $level_p = 1;
  716. break;
  717. case 2:
  718. $is_show = $second;
  719. $level = '二级';
  720. $level_p = 2;
  721. break;
  722. case 3:
  723. $is_show = false;
  724. $level = '三级';
  725. $level_p = 3;
  726. break;
  727. }
  728. if ($is_show) {
  729. $builder = MemberModel::getMyAllAgentsInfo(\YunShop::app()->getMemberId(), $i);
  730. $agent_info = self::getMemberRole($builder)->get();
  731. $agent_data = $agent_info->toArray();
  732. $total += count($agent_data);
  733. $data[$text] = [
  734. 'level' => $level,
  735. 'total' => count($agent_data),
  736. 'is_show' => $is_show,
  737. 'level_p' => $level_p,
  738. ];
  739. } else {
  740. $total += 0;
  741. $data[$text] = [
  742. 'level' => $level,
  743. 'total' => 0,
  744. 'is_show' => $is_show,
  745. 'level_p' => $level_p,
  746. ];
  747. }
  748. }
  749. $data['total'] = $total;
  750. return $data;
  751. }
  752. public function orders()
  753. {
  754. return $this->hasMany(Order::class, 'uid', 'uid');
  755. }
  756. public function memberChildren()
  757. {
  758. return $this->hasMany(MemberChildren::class, 'member_id', 'uid');
  759. }
  760. /**
  761. * 我推荐的人v2 数据
  762. * @return array
  763. */
  764. public static function getMyAgentData_v2()
  765. {
  766. $relationLevel = request()->input('relationLevel', 1);
  767. $pageSize = 10;
  768. $keyword = request()->input('keyword');
  769. // 查出用户的某一级别下线的会员资料
  770. $member = MemberModel::find(\app\frontend\models\Member::current()->uid);
  771. if (!$member) {
  772. return [];
  773. }
  774. //获取一级下级会员ID
  775. $teamMembersIds = $member->memberChildren()->where('level', $relationLevel)->pluck('child_id')->toArray();
  776. if (!empty($keyword)) {
  777. $key_uid = MemberModel::uniacid()->where('nickname', 'like', '%' . $keyword . '%')
  778. ->orWhere('mobile', 'like', '%' . $keyword . '%')
  779. ->orWhere('realname', 'like', '%' . $keyword . '%')
  780. ->pluck('uid')
  781. ->toArray();
  782. $teamMembersIds = array_intersect($teamMembersIds, $key_uid);
  783. }
  784. // 总订单数,总订单金额
  785. // todo yz_member 中的wechat 拿到外层 uid as id withSum
  786. if(app('plugins')->isEnabled('agent-list-set') && \Setting::get('plugin.agent-liset-set.pay_order')){
  787. $teamMembers = SetController::getTeamMember($pageSize, $teamMembersIds); //统计已完成+已支付订单
  788. }else{
  789. $teamMembers = MemberModel::select(['mobile', 'createtime', 'avatar', 'nickname', 'uid','realname'])
  790. ->whereIn('uid', $teamMembersIds)
  791. ->with(['yzMember' => function ($builder) {
  792. $builder->select(['member_id', 'is_agent', 'status', 'wechat', 'deleted_at', 'inviter']);
  793. }, 'orders' => function ($order) {
  794. $order->select(['id', 'uid', 'price', 'status'])->where('status', 3);
  795. }, 'memberChildren' => function ($member) {
  796. $member->select(['id', 'child_id', 'level', 'member_id'])->where('level', 1)
  797. ->with(['orders' => function ($order) {
  798. $order->select(['id', 'uid', 'price', 'status'])->where('status', 3);
  799. }]);
  800. }])
  801. ->orderBy('uid', 'desc')
  802. ->simplePaginate($pageSize)
  803. ->toArray();
  804. }
  805. $teamMembers['total'] = count($teamMembersIds);
  806. $teamMembers['last_page'] = ceil($teamMembers['total'] / $pageSize);
  807. foreach ($teamMembers['data'] as &$v) {
  808. $v['team_order_money'] = round(collect($v['member_children'])->sum(function ($member_children) {
  809. return collect($member_children['orders'])->sum('price');
  810. }), 2);
  811. $v['team_total'] = collect($v['member_children'])->count();
  812. //会员自己
  813. $v['child_order_money'] = round(collect($v['orders'])->sum('price'), 2);
  814. $v['child_order_total'] = collect($v['orders'])->count();
  815. $v['avatar'] = $v['avatar_image'];
  816. $v['createtime'] = date('Y-m-d H:i:s', $v['createtime']);
  817. unset($v['avatar_image']);
  818. $v['id'] = $v['uid'];
  819. unset($v['uid']);
  820. $v['wechat'] = $v['yz_member']['wechat'] ?: 0;
  821. $v['mobile'] = $v['mobile'] ?: 0;
  822. $v['realname'] = $v['realname'] ?: 0;
  823. if (empty($v['yz_member']['inviter'])) {
  824. $v['inviter'] = 1;
  825. } else {
  826. $v['inviter'] = 0;
  827. }
  828. if (!is_null($v['yz_member'])) {
  829. if (1 == $v['yz_member']['is_agent'] && 2 == $v['yz_member']['status']) {
  830. $v['is_agent'] = 1;
  831. }
  832. }
  833. unset($v['yz_member']);
  834. unset($v['member_children']);
  835. unset($v['orders']);
  836. }
  837. return $teamMembers;
  838. }
  839. /**
  840. * 获取用户信息
  841. *
  842. * @param $member_id
  843. * @return mixed
  844. */
  845. public static function getUserInfos_v2($member_id)
  846. {
  847. return self::select(['uid', 'uniacid', 'credit1', 'credit2', 'credit3', 'createtime', 'nickname', 'realname', 'avatar', 'mobile', 'birthyear', 'birthmonth', 'birthday', 'gender', 'alipay'])
  848. ->uniacid()
  849. ->where('uid', $member_id)
  850. ->with([
  851. 'yzMember' => function ($query) {
  852. return $query->select(['*'])->where('is_black', 0)
  853. ->with([
  854. 'group' => function ($query1) {
  855. return $query1->select(['id', 'group_name']);
  856. },
  857. 'level' => function ($query2) {
  858. return $query2->select(['id', 'level_name']);
  859. },
  860. 'agent' => function ($query3) {
  861. return $query3->select(['uid', 'avatar', 'nickname']);
  862. }
  863. ]);
  864. },
  865. 'hasOneFans' => function ($query4) {
  866. return $query4->select(['uid', 'openid', 'follow as followed']);
  867. },
  868. ]);
  869. }
  870. /**
  871. * 会员中心返回数据
  872. *
  873. * @param $member_info
  874. * @param $yz_member
  875. * @return mixed
  876. */
  877. public static function userData($member_info, $yz_member)
  878. {
  879. $set = \Setting::get('shop.member');
  880. if (!empty($yz_member)) {
  881. $member_info['alipay_name'] = $yz_member['alipayname'];
  882. $member_info['alipay'] = $yz_member['alipay'];
  883. $member_info['province_name'] = $yz_member['province_name'];
  884. $member_info['city_name'] = $yz_member['city_name'];
  885. $member_info['area_name'] = $yz_member['area_name'];
  886. $member_info['province'] = $yz_member['province'];
  887. $member_info['city'] = $yz_member['city'];
  888. $member_info['area'] = $yz_member['area'];
  889. $member_info['address'] = $yz_member['address'];
  890. $member_info['wechat'] = $yz_member['wechat'];
  891. if (!empty($yz_member['group'])) {
  892. $member_info['group_id'] = $yz_member['group']['id'];
  893. $member_info['group_name'] = $yz_member['group']['group_name'];
  894. }
  895. if (!empty($yz_member['level'])) {
  896. $member_info['level_id'] = $yz_member['level']['id'];
  897. $member_info['level_name'] = $yz_member['level']['level_name'];
  898. } else {
  899. $member_info['level_id'] = 0;
  900. $member_info['level_name'] = $set['level_name'] ? $set['level_name'] : '普通会员';
  901. }
  902. $member_info['is_agent'] = $yz_member['is_agent'] == 1 && $yz_member['status'] == 2 ? true : false;
  903. $member_info['referral'] = self::getMyReferral_v3($yz_member, $set);
  904. }
  905. if (!empty($member_info['birthyear'])) {
  906. $member_info['birthday'] = date('Y-m-d', strtotime($member_info['birthyear'] . '-' . $member_info['birthmonth'] . '-' . $member_info['birthday']));
  907. } else {
  908. $member_info['birthday'] = date('Y-m-d', time());
  909. }
  910. //创建二维码目录
  911. self::createDir(storage_path('app/public/qr'));
  912. //创建头像目录
  913. self::createDir(storage_path('app/public/avatar'));
  914. $member_info['qr'] = self::getAgentQR();
  915. $member_info['avatar_dir'] = request()->getSchemeAndHttpHost() . config('app.webPath') . \Storage::url('app/public/avatar/');
  916. $member_info['avatar'] = $member_info['avatar'] ? yz_tomedia($member_info['avatar']) : yz_tomedia(\Setting::get('shop.member.headimg'));
  917. //修复微信头像地址
  918. $member_info['avatar'] = ImageHelper::fix_wechatAvatar($member_info['avatar']);
  919. //IOS时,把微信头像url改为https前缀
  920. $member_info['avatar'] = ImageHelper::iosWechatAvatar($member_info['avatar']);
  921. $shop = \Setting::get('shop.shop');
  922. //版权信息
  923. $member_info['copyright'] = $shop['copyright'] ?: '';
  924. $member_info['credit'] = [
  925. //增加是否显示余额值
  926. 'is_show' => \Setting::get('shop.member.show_balance') ? 0 : 1,
  927. 'text' => !empty($shop['credit']) ? $shop['credit'] : '余额',
  928. 'data' => $member_info['credit2']
  929. ];
  930. //显示积分
  931. $member_info['integral'] = [
  932. 'text' => !empty($shop['credit1']) ? $shop['credit1'] : '积分',
  933. 'data' => $member_info['credit1']
  934. ];
  935. //增加是否显示爱心值值
  936. $member_info['love_show'] = [
  937. 'is_show' => \Setting::get('love.member_center_show') ? 1 : 0,
  938. 'text' => '爱心值',
  939. 'data' => '0.00'
  940. ];
  941. if (app('plugins')->isEnabled('love')) {
  942. $memberLove = MemberLove::where('member_id', \YunShop::app()->getMemberId())->first();
  943. $member_info['love_show']['text'] = LOVE_NAME;
  944. $member_info['love_show']['data'] = $memberLove->usable ?: '0.00';
  945. }
  946. //订单显示
  947. // $order_info = \app\frontend\models\Order::getOrderCountGroupByStatus([Order::WAIT_PAY,Order::WAIT_SEND,Order::WAIT_RECEIVE,Order::COMPLETE,Order::REFUND]);
  948. // $member_info['order'] = $order_info;
  949. // if (app('plugins')->isEnabled('hotel')) {
  950. // $member_info['hotel_order'] = \Yunshop\Hotel\common\models\Order::getHotelOrderCountGroupByStatus([Order::WAIT_PAY,Order::WAIT_SEND,Order::WAIT_RECEIVE,Order::COMPLETE,Order::REFUND]);
  951. // }
  952. //
  953. // if (\app\common\services\plugin\leasetoy\LeaseToySet::whetherEnabled()) {
  954. // $member_info['lease_order'] = \Yunshop\LeaseToy\models\Order::getLeaseOrderCountGroupByStatus([Order::WAIT_PAY,Order::WAIT_SEND,Order::WAIT_RECEIVE,Order::COMPLETE,Order::REFUND]);
  955. // }
  956. $member_info['is_agent'] = self::isAgent();
  957. $member_info['referral'] = self::getMyReferral();
  958. return $member_info;
  959. }
  960. /**
  961. * 会员中心返回数据
  962. *
  963. * @param $member_info
  964. * @param $yz_member
  965. * @return mixed
  966. */
  967. public static function userData_v2($member_info, $yz_member)
  968. {
  969. $set = \Setting::get('shop.member');
  970. if (!empty($yz_member)) {
  971. if (!empty($yz_member['group'])) {
  972. $member_info['group_id'] = $yz_member['group']['id'];
  973. $member_info['group_name'] = $yz_member['group']['group_name'];
  974. }
  975. if (!empty($yz_member['level'])) {
  976. $member_info['level_id'] = $yz_member['level']['id'];
  977. $member_info['level_name'] = $yz_member['level']['level_name'];
  978. } else {
  979. $member_info['level_id'] = 0;
  980. $member_info['level_name'] = $set['level_name'] ? $set['level_name'] : '普通会员';
  981. }
  982. $member_info['alipay_name'] = $yz_member['alipayname'];
  983. $member_info['alipay'] = $yz_member['alipay'];
  984. $member_info['province_name'] = $yz_member['province_name'];
  985. $member_info['city_name'] = $yz_member['city_name'];
  986. $member_info['area_name'] = $yz_member['area_name'];
  987. $member_info['province'] = $yz_member['province'];
  988. $member_info['city'] = $yz_member['city'];
  989. $member_info['area'] = $yz_member['area'];
  990. $member_info['address'] = $yz_member['address'];
  991. $member_info['wechat'] = $yz_member['wechat'];
  992. $member_info['is_agent'] = $yz_member['is_agent'] == 1 && $yz_member['status'] == 2 ? true : false;
  993. $member_info['referral'] = self::getMyReferral_v3($yz_member, $set);
  994. }
  995. if (!empty($member_info['birthyear'])) {
  996. $member_info['birthday'] = date('Y-m-d', strtotime($member_info['birthyear'] . '-' . $member_info['birthmonth'] . '-' . $member_info['birthday']));
  997. } else {
  998. $member_info['birthday'] = date('Y-m-d', time());
  999. }
  1000. //创建二维码目录
  1001. //self::createDir(storage_path('app/public/qr'));
  1002. //创建头像目录
  1003. self::createDir(storage_path('app/public/avatar'));
  1004. //$member_info['qr'] = self::getAgentQR();
  1005. $member_info['avatar_dir'] = request()->getSchemeAndHttpHost() . config('app.webPath') . \Storage::url('app/public/avatar/');
  1006. $member_info['avatar'] = $member_info['avatar'] ? yz_tomedia($member_info['avatar']) : yz_tomedia(\Setting::get('shop.member.headimg'));
  1007. //修复微信头像地址
  1008. $member_info['avatar'] = ImageHelper::fix_wechatAvatar($member_info['avatar']);
  1009. //IOS时,把微信头像url改为https前缀
  1010. $member_info['avatar'] = ImageHelper::iosWechatAvatar($member_info['avatar']);
  1011. $shop = \Setting::get('shop.shop');
  1012. //版权信息
  1013. $member_info['copyright'] = \Setting::get('shop.shop.copyright','');
  1014. $member_info['credit'] = [
  1015. //增加是否显示余额值
  1016. 'is_show' => \Setting::get('shop.member.show_balance') ? 0 : 1,
  1017. 'text' => \Setting::get('shop.shop.credit')?:'余额',
  1018. 'data' => $member_info['credit2']
  1019. ];
  1020. //显示积分
  1021. $member_info['integral'] = [
  1022. 'is_show' => \Setting::get('shop.member.show_point') ? 0 : 1,
  1023. 'text' => \Setting::get('shop.shop.credit1')?:'积分',
  1024. 'data' => $member_info['credit1']
  1025. ];
  1026. //显示优惠券
  1027. $member_info['coupon'] = [
  1028. 'is_show' => 1,
  1029. 'text' => '优惠券',
  1030. 'data' => \app\frontend\modules\coupon\models\MemberCoupon::getCouponsOfMember($yz_member['member_id'])
  1031. ->where('used', '=', 0)
  1032. ->where('is_member_deleted', 0)
  1033. ->where('is_expired', 0)
  1034. ->count()
  1035. ];
  1036. //增加是否显示爱心值值
  1037. $member_info['love_show'] = [
  1038. 'usable_love_show' => \Setting::get('love.member_center_show') ? 1 : 0,
  1039. 'unable_love_show' => \Setting::get('love.member_center_unable_show') ? 1 : 0,
  1040. 'usable_text' => '爱心值',
  1041. 'unable_text' => '白爱心值',
  1042. 'usable_data' => '0.00',
  1043. 'unable_data' => '0.00'
  1044. ];
  1045. if (app('plugins')->isEnabled('love')) {
  1046. $memberLove = MemberLove::where('member_id', \YunShop::app()->getMemberId())->first();
  1047. if (app('plugins')->isEnabled('cloud-link-port')) {
  1048. self::loveChange($member_info, $memberLove);
  1049. }
  1050. $memberLove = MemberLove::where('member_id', \YunShop::app()->getMemberId())->first();//改完之后要重新查获取新的
  1051. $member_info['love_show']['usable_text'] = \Yunshop\Love\Common\Services\SetService::getLoveSet('usable_name') ?: LOVE_NAME;
  1052. $member_info['love_show']['usable_data'] = $memberLove->usable ?: '0.00';
  1053. $member_info['love_show']['unable_text'] = \Yunshop\Love\Common\Services\SetService::getLoveSet('unable_name') ?: '白' . LOVE_NAME;
  1054. $member_info['love_show']['unable_data'] = $memberLove->froze ?: '0.00';
  1055. } else {
  1056. $member_info['love_show']['usable_love_show'] = 0;
  1057. $member_info['love_show']['unable_love_show'] = 0;
  1058. }
  1059. //增加是否显示消费积分值
  1060. $member_info['integral_show'] = [
  1061. 'is_show' => false,
  1062. 'text' => '消费积分',
  1063. 'data' => '0.00'
  1064. ];
  1065. if (app('plugins')->isEnabled('integral')) {
  1066. $memberIntegral = IntegralMemberModel::where('uid', \YunShop::app()->getMemberId())->first();
  1067. $member_info['integral_show']['is_show'] = !!SetService::getIntegralSet('member_show_integral');
  1068. $member_info['integral_show']['text'] = INTEGRAL_NAME;
  1069. $member_info['integral_show']['data'] = $memberIntegral->integral ?: '0.00';
  1070. }
  1071. //增加供销积分显示
  1072. $member_info['ecological_point_show'] = [
  1073. 'is_show' => false,
  1074. 'text' => '供销积分',
  1075. 'data' => '0.000000000000'
  1076. ];
  1077. if (app('plugins')->isEnabled('ecological-point') && \Setting::get('plugin.ecological_point.plugin_switch')) {
  1078. $memberEcologicalPoint = PointModel::getPointModel(\YunShop::app()->getMemberId());
  1079. /**
  1080. * @var PointModel $memberEcologicalPoint
  1081. */
  1082. $member_info['ecological_point_show'] = [
  1083. 'is_show' => true,
  1084. 'text' => ECOLOGICAL_POINT,
  1085. 'data' => $memberEcologicalPoint->point
  1086. ];
  1087. }
  1088. if (app('plugins')->isEnabled('consume-coupon-switch') && \Setting::get('plugin.consume_coupon_switch.status') == 1) {
  1089. if (app('plugins')->isEnabled('universal-card')) {
  1090. $consume_coupon = ConsumeCoupon::uniacid()->where('member_id', \YunShop::app()->getMemberId())->first();
  1091. $member_info['consume_coupon_show']['is_show'] = \Setting::get('plugin.universal_card.member_center_show');
  1092. $member_info['consume_coupon_show']['text'] = \Setting::get('plugin.universal_card.consume_coupon_text')?:'消费券余额';
  1093. $member_info['consume_coupon_show']['amount'] = $consume_coupon->amount ?: 0.00;
  1094. }
  1095. }
  1096. if (app('plugins')->isEnabled('consumer-reward') && \Setting::get('plugin.consumer_reward.is_open') == 1) {
  1097. $consume_amount = ConsumerRewardRecordModel::getRecord(\YunShop::app()->getMemberId())->sum('reward_amount');
  1098. $member_info['consumer_reward_show']['is_show'] = \Setting::get('plugin.consumer_reward.is_display');
  1099. $member_info['consumer_reward_show']['text'] = \Setting::get('plugin.consumer_reward.name')?:'消费奖励';
  1100. $member_info['consumer_reward_show']['amount'] = $consume_amount ?: 0.00;
  1101. }
  1102. //会员等级日期
  1103. if (!is_null($member_info['yz_member']['validity'])) {
  1104. if ($member_info['yz_member']['level_id'] == 0) {
  1105. $member_info['yz_member']['validity'] = '';
  1106. } else {
  1107. $day = $member_info['yz_member']['validity'] - 1;
  1108. $member_info['yz_member']['validity'] = date('Y-m-d',strtotime($day.' days'));
  1109. }
  1110. }
  1111. return $member_info;
  1112. }
  1113. public function loveChange($member_info, $memberLove)
  1114. {
  1115. $set = SetModel::uniacid()->first(['is_advert']);
  1116. if ($set && $set['is_advert'] && $member_info['mobile']) {
  1117. $advertService = new AdvertService();
  1118. $advertService->bindMember($member_info['mobile']);
  1119. $res = $advertService->queryMemberAndChange($member_info['mobile']);
  1120. if ($res['code'] == 200) {
  1121. $compare_res = bccomp($res['data'][0]['balance'], $memberLove->usable,2);
  1122. switch ($compare_res) {
  1123. case 1 :
  1124. self::add($res['data'][0]['balance'], $memberLove->usable, $member_info);
  1125. break;
  1126. case -1 :
  1127. self::reduce($res['data'][0]['balance'], $memberLove->usable, $member_info);
  1128. break;
  1129. }
  1130. }
  1131. }
  1132. }
  1133. public function add($balance, $usable, $member_info)
  1134. {
  1135. $change_value = bcsub($balance, $usable, 2);
  1136. (new LoveChangeService())->CloudLinkAdd(
  1137. [
  1138. 'member_id' => $member_info['uid'],
  1139. 'change_value' => $change_value,
  1140. 'operator' => ConstService::OPERATOR_MEMBER,
  1141. 'operator_id' => $member_info['uid'],
  1142. 'remark' => '云链接口增加',
  1143. 'relation' => '',
  1144. ]
  1145. );
  1146. $save_data = [
  1147. 'uniacid' => $member_info['uniacid'],
  1148. 'uid' => $member_info['uid'],
  1149. 'mobile' => $member_info['mobile'],
  1150. 'change_type' => 1,
  1151. 'love' => $change_value,
  1152. 'love_before' => $usable,
  1153. 'love_after' => $balance,
  1154. 'call_back_status' => 1,
  1155. 'call_back_message' => '',
  1156. ];
  1157. return ChangeLog::create($save_data);
  1158. }
  1159. public function reduce($balance, $usable, $member_info)
  1160. {
  1161. $change_value = bcsub($usable, $balance, 2);
  1162. (new LoveChangeService())->CloudLinkReduce(
  1163. [
  1164. 'member_id' => $member_info['uid'],
  1165. 'change_value' => $change_value,
  1166. 'operator' => ConstService::OPERATOR_MEMBER,
  1167. 'operator_id' => $member_info['uid'],
  1168. 'remark' => '云链接口减少',
  1169. 'relation' => '',
  1170. ]
  1171. );
  1172. $save_data = [
  1173. 'uniacid' => $member_info['uniacid'],
  1174. 'uid' => $member_info['uid'],
  1175. 'mobile' => $member_info['mobile'],
  1176. 'change_type' => 1,
  1177. 'love' => -$change_value,
  1178. 'love_before' => $usable,
  1179. 'love_after' => $balance,
  1180. 'call_back_status' => 1,
  1181. 'call_back_message' => '',
  1182. ];
  1183. return ChangeLog::create($save_data);
  1184. }
  1185. public static function createDir($dest)
  1186. {
  1187. if (!is_dir($dest)) {
  1188. (@mkdir($dest, 0777, true));
  1189. }
  1190. }
  1191. public static function convertRoleText($member_modle)
  1192. {
  1193. $commission = self::langFiled('commission');
  1194. $member_role = '';
  1195. if (!is_null($member_modle)) {
  1196. if (app('plugins')->isEnabled('commission')) {
  1197. if (!is_null($member_modle->hasOneAgent)) {
  1198. $member_role .= $commission['agent'] ?: '分销商';
  1199. $member_role .= '&';
  1200. }
  1201. }
  1202. if (app('plugins')->isEnabled('team-dividend')) {
  1203. if (!is_null($member_modle->hasOneTeamDividend)) {
  1204. $member_role .= '经销商&';
  1205. }
  1206. }
  1207. if (app('plugins')->isEnabled('area-dividend')) {
  1208. if (!is_null($member_modle->hasOneAreaDividend)) {
  1209. $member_role .= '区域代理&';
  1210. }
  1211. }
  1212. if (app('plugins')->isEnabled('merchant')) {
  1213. if (!is_null($member_modle->hasOneMerchant)) {
  1214. $member_role .= '招商员&';
  1215. }
  1216. if (!is_null($member_modle->hasOneMerchantCenter)) {
  1217. if (1 == $member_modle->hasOneMerchant->is_center) {
  1218. $member_role .= '招商中心&';
  1219. }
  1220. }
  1221. }
  1222. if (app('plugins')->isEnabled('micro')) {
  1223. if (!is_null($member_modle->hasOneMicro)) {
  1224. $member_role .= '微店店主&';
  1225. }
  1226. }
  1227. if (app('plugins')->isEnabled('supplier')) {
  1228. if (!is_null($member_modle->hasOneSupplier)) {
  1229. $member_role .= '供应商&';
  1230. }
  1231. }
  1232. }
  1233. if (!empty($member_role)) {
  1234. $member_role = rtrim($member_role, '&');
  1235. }
  1236. return $member_role;
  1237. }
  1238. public static function fetchAgentInfo($agent_info)
  1239. {
  1240. if (empty($agent_info)) {
  1241. return [];
  1242. }
  1243. return collect($agent_info)->map(function ($item) {
  1244. $is_agent = 0;
  1245. if (!is_null($item->yzMember)) {
  1246. if (1 == $item->yzMember->is_agent && 2 == $item->yzMember->status) {
  1247. $is_agent = 1;
  1248. }
  1249. }
  1250. //团队1级会员
  1251. $order = DB::table('yz_order')->select('uid', 'price', 'status')->where('status', 3)->where('uniacid', \YunShop::app()->uniacid)->get();
  1252. $result['child_order_total'] = $order->whereIn('uid', $item->uid)->count();
  1253. $result['child_order_money'] = $order->whereIn('uid', $item->uid)->sum('price');
  1254. //团队全部会员
  1255. $childMemberTeam = DB::table('yz_member_children')->select('child_id')->where('member_id', $item->uid)->where('uniacid', \YunShop::app()->uniacid)->where('level', 1)->get();
  1256. foreach ($childMemberTeam as $child_id) {
  1257. $child_idAll[] = $child_id['child_id'];
  1258. }
  1259. $result['team_total'] = collect($child_idAll)->count();
  1260. $result['team_order_money'] = $order->whereIn('uid', $child_idAll)->sum('price');
  1261. // dd($result);
  1262. return [
  1263. 'id' => $item->uid,
  1264. 'is_agent' => $is_agent,
  1265. 'nickname' => $item->nickname,
  1266. 'avatar' => $item->avatar,
  1267. // 'order_price' => $order_price,
  1268. // 'agent_total' => $agent_total,
  1269. // 'agent_order_price' => $agent_order_price,
  1270. // 'role' => $role,
  1271. // 'role_type' => $role_type,
  1272. 'createtime' => date('Y-m-d H:i:s', $item->createtime),
  1273. 'mobile' => $item->mobile ?: 0,
  1274. 'wechat' => $item->yzMember->wechat ?: 0,
  1275. 'child_order_money' => $result['child_order_money'] ?: 0,
  1276. 'child_order_total' => $result['child_order_total'] ?: 0,
  1277. 'team_order_money' => $result['team_order_money'] ?: 0,
  1278. 'team_total' => $result['team_total'] ?: 0,
  1279. ];
  1280. });
  1281. }
  1282. public static function searchMemberRelation($data)
  1283. {
  1284. $result = [];
  1285. $keyword = \YunShop::request()->keyword;
  1286. $level = \YunShop::request()->level;
  1287. $filter = ['招商员', '供应商']; //没有等级
  1288. $coll = collect($data)->filter(function ($item) use ($keyword, $level, $filter) {
  1289. $role_level = false;
  1290. $role = preg_match("/{$keyword}/", $item['role']);
  1291. if ($role) {
  1292. if (in_array($keyword, $filter) || empty($level)) {
  1293. $role_level = true;
  1294. }
  1295. if (!empty($item['role_type'])) {
  1296. foreach ($item['role_type'] as $rows) {
  1297. foreach ($rows as $key => $val) {
  1298. if ($key == $keyword && $val == $level) {
  1299. $role_level = true;
  1300. }
  1301. break 2;
  1302. }
  1303. }
  1304. }
  1305. }
  1306. return $role && $role_level;
  1307. });
  1308. if (!$coll->isEmpty()) {
  1309. $result = array_values($coll->toArray());
  1310. }
  1311. return $result;
  1312. }
  1313. public static function setRoleLevel($member_modle)
  1314. {
  1315. $commission = self::langFiled('commission');
  1316. $commission_filed = $commission['agent'] ?: '分销商';
  1317. $role_type = [];
  1318. if (!is_null($member_modle)) {
  1319. if (app('plugins')->isEnabled('commission')) {
  1320. if (!is_null($member_modle->hasOneAgent)) {
  1321. array_push($role_type, [$commission_filed => $member_modle->hasOneAgent->agent_level_id]);
  1322. }
  1323. }
  1324. if (app('plugins')->isEnabled('team-dividend')) {
  1325. if (!is_null($member_modle->hasOneTeamDividend)) {
  1326. array_push($role_type, ['经销商' => $member_modle->hasOneTeamDividend->level]);
  1327. }
  1328. }
  1329. if (app('plugins')->isEnabled('area-dividend')) {
  1330. if (!is_null($member_modle->hasOneAreaDividend)) {
  1331. array_push($role_type, ['区域代理' => $member_modle->hasOneAreaDividend->agent_level]);
  1332. }
  1333. }
  1334. if (app('plugins')->isEnabled('merchant')) {
  1335. if (!is_null($member_modle->hasOneMerchant)) {
  1336. }
  1337. if (!is_null($member_modle->hasOneMerchantCenter)) {
  1338. if (1 == $member_modle->hasOneMerchant->is_center) {
  1339. array_push($role_type, ['招商中心' => $member_modle->hasOneMerchantCenter->level_id]);
  1340. }
  1341. }
  1342. }
  1343. if (app('plugins')->isEnabled('micro')) {
  1344. if (!is_null($member_modle->hasOneMicro)) {
  1345. array_push($role_type, ['微店店主' => $member_modle->hasOneMicro->level_id]);
  1346. }
  1347. }
  1348. if (app('plugins')->isEnabled('supplier')) {
  1349. if (!is_null($member_modle->hasOneSupplier)) {
  1350. }
  1351. }
  1352. }
  1353. return $role_type;
  1354. }
  1355. public static function filterMemberRoleAndLevel()
  1356. {
  1357. $commission = self::langFiled('commission');
  1358. $commission_filed = $commission['agent'] ?: '分销商';
  1359. $data = [];
  1360. if (app('plugins')->isEnabled('commission')) {
  1361. $agent_level = AgentLevel::uniacid()->get();
  1362. if (!$agent_level->isEmpty()) {
  1363. $agent_level = collect($agent_level)->map(function ($item) {
  1364. return [
  1365. 'id' => $item->id,
  1366. 'level_name' => $item->name
  1367. ];
  1368. });
  1369. array_push($data, ['role' => $commission_filed, 'level' => $agent_level->all()]);
  1370. } else {
  1371. array_push($data, ['role' => $commission_filed, 'level' => []]);
  1372. }
  1373. }
  1374. if (app('plugins')->isEnabled('team-dividend')) {
  1375. $teamdividend_level = TeamDividendLevelModel::uniacid()->get();
  1376. if (!$teamdividend_level->isEmpty()) {
  1377. array_push($data, ['role' => '经销商', 'level' => $teamdividend_level->toArray()]);
  1378. } else {
  1379. array_push($data, ['role' => '经销商', 'level' => []]);
  1380. }
  1381. }
  1382. if (app('plugins')->isEnabled('area-dividend')) {
  1383. array_push($data, ['role' => '区域代理', 'level' => [
  1384. ['id' => 1, 'level_name' => '省代理'], ['id' => 2, 'level_name' => '市代理'], ['id' => 3, 'level_name' => '区代理'], ['id' => 4, 'level_name' => '街道代理']
  1385. ]]);
  1386. }
  1387. if (app('plugins')->isEnabled('merchant')) {
  1388. array_push($data, ['role' => '招商员', 'level' => []]);
  1389. $merchant_level = MerchantLevel::uniacid()->get();
  1390. if (!$merchant_level->isEmpty()) {
  1391. array_push($data, ['role' => '招商中心', 'level' => $merchant_level->toArray()]);
  1392. } else {
  1393. array_push($data, ['role' => '招商中心', 'level' => []]);
  1394. }
  1395. }
  1396. if (app('plugins')->isEnabled('micro')) {
  1397. $microShop_level = MicroShopLevel::uniacid()->get();
  1398. if (!$microShop_level->isEmpty()) {
  1399. array_push($data, ['role' => '微店店主', 'level' => $microShop_level->toArray()]);
  1400. } else {
  1401. array_push($data, ['role' => '微店店主', 'level' => []]);
  1402. }
  1403. }
  1404. if (app('plugins')->isEnabled('supplier')) {
  1405. array_push($data, ['role' => '供应商', 'level' => []]);
  1406. }
  1407. return $data;
  1408. }
  1409. private static function langFiled($filed)
  1410. {
  1411. $lang = \Setting::get('shop.lang', ['lang' => 'zh_cn']);
  1412. $set = $lang[$lang['lang']];
  1413. return $set[$filed];
  1414. }
  1415. /**
  1416. * 获取邀请码
  1417. *
  1418. * @param $member_id
  1419. * @return string
  1420. */
  1421. public static function getInviteCode($member_id = null)
  1422. {
  1423. $member_id = $member_id ?: \YunShop::app()->getMemberId();
  1424. $invite_code = self::generateInviteCode();
  1425. if (self::chkInviteCode($invite_code)) {
  1426. MemberShopInfo::updateInviteCode($member_id, $invite_code);
  1427. return $invite_code;
  1428. } else {
  1429. while (true) {
  1430. self::getInviteCode($member_id);
  1431. }
  1432. }
  1433. }
  1434. /**
  1435. * 生成邀请码
  1436. *
  1437. * @return string
  1438. */
  1439. public static function generateInviteCode()
  1440. {
  1441. $str = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
  1442. $rand = $str[rand(0, 25)]
  1443. . strtoupper(dechex(date('m')))
  1444. . date('d') . substr(time(), -5)
  1445. . substr(microtime(), 2, 5)
  1446. . sprintf('%02d', rand(0, 99));
  1447. $code = '';
  1448. for ($f = 0; $f < 8; $f++) {
  1449. $a = md5($rand, true);
  1450. $s = '0123456789ABCDEFGHIJKLMNOPQRSTUV';
  1451. $g = ord($a[$f]);
  1452. $code .= $s[($g ^ ord($a[$f + 8])) - $g & 0x1F];
  1453. };
  1454. return $code;
  1455. }
  1456. /**
  1457. * 验证邀请码
  1458. *
  1459. * @param $code
  1460. */
  1461. public static function chkInviteCode($code)
  1462. {
  1463. if (!MemberShopInfo::chkInviteCode($code)) {
  1464. return true;
  1465. }
  1466. return false;
  1467. }
  1468. /**
  1469. * 获取我的下线全部(包含为确定的)
  1470. *
  1471. * @return mixed
  1472. */
  1473. public static function getAgentCount_v2($uid)
  1474. {
  1475. return self::uniacid()
  1476. ->whereHas('yzMember', function ($query) use ($uid) {
  1477. $query->where('parent_id', $uid);
  1478. })
  1479. ->count();
  1480. }
  1481. /**
  1482. * 注册时验证会员邀请码
  1483. */
  1484. public static function getUniqueInviteCode()
  1485. {
  1486. do {
  1487. $invite_code = self::generateInviteCode();
  1488. } while (!self::chkInviteCode($invite_code));
  1489. return $invite_code;
  1490. }
  1491. /***
  1492. * 验证用户是否有权限访问前端页面(权限设置在店面装修中)
  1493. *
  1494. */
  1495. public function getUserInfoByUid($id){
  1496. return $this->with(['yzMember'])->uniacid()->select(["uid",'uniacid','realname','nickname'])->where('uid',$id)->first();
  1497. }
  1498. public function yzMember()
  1499. {
  1500. return parent::yzMember()->select(['member_id',"level_id",'uniacid']); // TODO: Change the autogenerated stub
  1501. }
  1502. }