ParentOfMemberBack.php 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: dingran
  5. * Date: 2018/10/22
  6. * Time: 下午5:29
  7. */
  8. namespace app\common\models\member;
  9. use app\common\models\BaseModel;
  10. use Illuminate\Support\Facades\DB;
  11. class ParentOfMemberBack extends BaseModel
  12. {
  13. public $table = 'yz_member_parent_back';
  14. protected $guarded = [];
  15. private $uniacid = 0;
  16. private $parents = [];
  17. public function __construct(array $attributes = [])
  18. {
  19. $this->uniacid = \YunShop::app()->uniacid;
  20. parent::__construct($attributes);
  21. }
  22. public function CreateData($data)
  23. {
  24. \Log::debug('----------insert data-----');
  25. $rs = DB::table($this->getTable())->insert($data);
  26. return $rs;
  27. }
  28. public function DeletedData($uniacid = 0)
  29. {
  30. \Log::debug('----------DeletedData Parent--------');
  31. return DB::table($this->getTable())->where('uniacid', $uniacid)->delete();
  32. }
  33. public function getParentOfMember($uid)
  34. {
  35. return self::uniacid()
  36. ->where('member_id', $uid)
  37. ->get();
  38. }
  39. public function getMemberIdByParent($parent_id)
  40. {
  41. return self::uniacid()
  42. ->where('parent_id', $parent_id)
  43. ->pluck('member_id');
  44. }
  45. public function delRelationOfParentByMemberId($parent_id, $uid)
  46. {
  47. return self::uniacid()
  48. ->where('member_id', $uid)
  49. ->where('parent_id', $parent_id)
  50. ->delete();
  51. }
  52. public function delRelation($member_ids)
  53. {
  54. return self::uniacid()
  55. ->whereIn('member_id', $member_ids)
  56. ->delete();
  57. }
  58. public function hasParentOfMember($uid, $parent, $level)
  59. {
  60. return self::uniacid()
  61. ->where('member_id', $uid)
  62. ->where('parent_id', $parent)
  63. ->where('level', $level)
  64. ->count();
  65. }
  66. public function addNewParentData($uid, $parent_id)
  67. {
  68. $attr = [];
  69. $depth = 1;
  70. $parents = $this->getParentOfMember($parent_id);
  71. $default_exists = $this->hasParentOfMember($uid, $parent_id, $depth);
  72. if (!$default_exists) {
  73. \Log::debug('------parent level------', [$depth]);
  74. $attr[] = [
  75. 'uniacid' => $this->uniacid,
  76. 'parent_id' => $parent_id,
  77. 'level' => $depth,
  78. 'member_id' => $uid,
  79. 'created_at' => time()
  80. ];
  81. }
  82. if (!empty($parents)) {
  83. foreach ($parents as $key => $val) {
  84. $level = ++$val['level'];
  85. $parent_exists = $this->hasParentOfMember($uid, $val['parent_id'], $level);
  86. if (!$parent_exists) {
  87. \Log::debug('------parent level------', [$level]);
  88. $attr[] = [
  89. 'uniacid' => $this->uniacid,
  90. 'parent_id' => $val['parent_id'],
  91. 'level' => $level,
  92. 'member_id' => $uid,
  93. 'created_at' => time()
  94. ];
  95. }
  96. }
  97. }
  98. $this->CreateData($attr);
  99. }
  100. public function delMemberOfRelation(ChildrenOfMember $childObj, $uid, $n_parent_id)
  101. {
  102. $parents = $this->getParentOfMember($uid);
  103. $childs = $childObj->getChildOfMember($uid);
  104. //删除重新分配节点本身在父表中原父级的记录
  105. if (!$parents->isEmpty()) {
  106. foreach ($parents as $val) {
  107. $this->delRelationOfParentByMemberId($val['parent_id'], $val['member_id']);
  108. }
  109. }
  110. //删除重新分配节点的子级在父表中原父级的记录
  111. if (!$childs->isEmpty()) {
  112. foreach ($parents as $val) {
  113. foreach ($childs as $rows) {
  114. $this->delRelationOfParentByMemberId($val['parent_id'], $rows['child_id']);
  115. }
  116. }
  117. }
  118. //可优化
  119. if ($n_parent_id > 0) {
  120. //删除重新分配节点的所有子级(新节点中层级已改变)
  121. $member_ids = $this->getMemberIdByParent($uid);
  122. if (!$member_ids->isEmpty()) {
  123. $this->delRelation($member_ids);
  124. }
  125. }
  126. }
  127. public function hasRelationOfParent($uid, $depth)
  128. {
  129. return $this->getRelationOfParent($uid, $depth);
  130. }
  131. public function getParentsOfMember($uid)
  132. {
  133. return self::uniacid()
  134. ->where('member_id', $uid)
  135. ->get();
  136. }
  137. public function getParents($uid)
  138. {
  139. $parents = $this->getParentsOfMember($uid);
  140. if (!is_null($parents)) {
  141. foreach ($parents as $val) {
  142. $this->parents[] = $val['parent_id'];
  143. }
  144. }
  145. }
  146. public function fixParentData($uid, $parent_id)
  147. {
  148. $attr = [];
  149. $depth = 1;
  150. $parents = $this->getParentOfMember($parent_id);
  151. $default_exists = $this->hasParentOfMember($uid, $parent_id, $depth);
  152. if (!$default_exists) {
  153. echo '------parent level------' . $depth . '<BR>';
  154. $attr[] = [
  155. 'uniacid' => $this->uniacid,
  156. 'parent_id' => $parent_id,
  157. 'level' => $depth,
  158. 'member_id' => $uid,
  159. 'created_at' => time()
  160. ];
  161. }
  162. if (!empty($parents)) {
  163. foreach ($parents as $key => $val) {
  164. $level = ++$val['level'];
  165. $parent_exists = $this->hasParentOfMember($uid, $val['parent_id'], $level);
  166. if (!$parent_exists) {
  167. echo '------parent level------' . $level . '<BR>';
  168. $attr[] = [
  169. 'uniacid' => $this->uniacid,
  170. 'parent_id' => $val['parent_id'],
  171. 'level' => $level,
  172. 'member_id' => $uid,
  173. 'created_at' => time()
  174. ];
  175. }
  176. }
  177. }
  178. $this->CreateData($attr);
  179. }
  180. public function getRelationOfParent($uid, $depth)
  181. {
  182. return self::uniacid()
  183. ->where('member_id', $uid)
  184. ->where('level', $depth)
  185. ->get();
  186. }
  187. }