NetworkList.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. <?php
  2. namespace backendApi\modules\v1\models\lists\atlas;
  3. use backendApi\modules\v1\models\Admin;
  4. use common\helpers\Cache;
  5. use common\helpers\Tool;
  6. use common\helpers\user\Info;
  7. use common\helpers\user\Perf;
  8. use common\libs\dataList\column\Price;
  9. use common\libs\dataList\DataListInterface;
  10. use common\models\CalcBonus;
  11. use common\models\PerfMonth;
  12. use common\models\Period;
  13. use common\models\UserBind;
  14. use common\models\UserInfo;
  15. use common\libs\dataList\column\DateTime;
  16. use common\models\UserNetwork;
  17. use common\models\UserRelation;
  18. use common\models\UserSystem;
  19. use common\models\UserTeamwork;
  20. use Yii;
  21. class NetworkList extends \common\libs\dataList\DataList implements DataListInterface {
  22. /**
  23. * 列表名称
  24. * @return string
  25. */
  26. public function getListName() {
  27. return '安置网络列表';
  28. }
  29. /**
  30. * 列表筛选到的数据
  31. * @throws \yii\base\Exception
  32. */
  33. public function dataHandle() {
  34. $userId = $this->others['userId'];
  35. $deep = $this->others['deep'];
  36. $periodNum = $this->others['periodNum'];
  37. $period = Period::instance();
  38. $mainUserInfo = Info::baseInfo($userId, $periodNum);
  39. $decLevelConfig = Cache::getDecLevelConfig();
  40. $empLevelConfig = Cache::getEmpLevelConfig();
  41. $param = [];
  42. if ( $this->pageSize ) $param['pageSize'] = $this->pageSize;
  43. if ( $this->page !== null ) $param['page'] = $this->page;
  44. $this->listData = UserNetwork::getChildrenInDeepFromPeriodWithPage($userId, $deep, $periodNum, $param);
  45. foreach($this->listData['list'] as $key=>$value){
  46. $userBaseInfo = Info::baseInfo($value['USER_ID'], $periodNum);
  47. $this->listData['list'][$key]['LIST_PERIOD_NUM'] = $periodNum?$periodNum:$period->getNowPeriodNum();
  48. // $this->listData['list'][$key]['COUNT_DEEP'] = (int)($userBaseInfo['NETWORK_DEEP']-$mainUserInfo['NETWORK_DEEP']);
  49. $this->listData['list'][$key]['COUNT_DEEP'] = (int)($userBaseInfo['NETWORK_DEEP']);
  50. $this->listData['list'][$key]['USER_NAME'] = $userBaseInfo['USER_NAME'];
  51. $this->listData['list'][$key]['SEE_USER_NAME'] = $userBaseInfo['USER_NAME'];
  52. $this->listData['list'][$key]['REAL_NAME'] = $userBaseInfo['REAL_NAME'];
  53. $this->listData['list'][$key]['PERIOD_AT'] = $userBaseInfo['PERIOD_AT'];
  54. $this->listData['list'][$key]['DEC_LV_NAME'] = $decLevelConfig[$userBaseInfo['DEC_LV']]['LEVEL_NAME'];
  55. $this->listData['list'][$key]['EMP_LV_NAME'] = isset($empLevelConfig[$userBaseInfo['EMP_LV']])?$empLevelConfig[$userBaseInfo['EMP_LV']]['LEVEL_NAME']:'';
  56. }
  57. $this->listData['periodNum'] = $periodNum;
  58. $this->listData['listTopDeep'] = $mainUserInfo['NETWORK_DEEP'];
  59. }
  60. /**
  61. * 要展示和导出的所有字段
  62. * @return array
  63. */
  64. public function getColumn() {
  65. if (!$this->columns) {
  66. $this->columns = [
  67. 'USER_ID' => null, // 这种传输方式主要是用于索引,因为过滤后的字段可能没有这种ID,但是一些功能的操作还需要用这种ID去关联,例如前台会员列表中的勾选批量状态管理,这里需要的就是USER_ID
  68. 'SEE_USER_NAME' => null,
  69. 'COUNT_DEEP' => [
  70. 'header' => 'Number of layers',//层数
  71. 'headerOther' => ['width' => '100'],
  72. ],
  73. 'USER_NAME' => [
  74. 'header' => 'Placement member number',//安置会员编号
  75. // 'headerOther' => ['width' => '150'],
  76. ],
  77. 'REAL_NAME' => [
  78. 'header' => 'Placement member name',//安置会员姓名
  79. // 'headerOther' => [
  80. // 'width' => '120',
  81. // ],
  82. ],
  83. // 'LOCATION' => [
  84. // 'header' => '区位',
  85. // 'value' => function($row) {
  86. // return 'A'.$row['LOCATION'];
  87. // },
  88. // 'headerOther' => ['width' => '110'],
  89. // ],
  90. 'DEC_LV_NAME' => [
  91. 'header' => 'Recommended member level',//推荐会员级别
  92. 'headerOther' => [
  93. 'width' => '110',
  94. ],
  95. ],
  96. 'EMP_LV_NAME' => [
  97. 'header' => 'Recommended member Rank',//推荐会员聘级
  98. 'headerOther' => [
  99. 'width' => '130',
  100. ],
  101. ],
  102. 'PERIOD_AT' => [
  103. 'header' => 'Number of joining periods',//加入期数
  104. 'headerOther' => ['width' => '110'],
  105. ],
  106. ];
  107. }
  108. return $this->columns;
  109. }
  110. /**
  111. * 前台用于筛选的类型集合
  112. * @return mixed
  113. */
  114. public function getFilterTypes() {
  115. if (!$this->filterTypes) {
  116. $this->filterTypes = [
  117. 'userName' => ['isUserTable' => false, 'name' => 'Member code'],//会员编号
  118. 'deep' => ['isUserTable' => false, 'name' => 'depth'],//深度
  119. 'periodNum' => ['isUserTable' => false, 'name' => 'Number of periods'],//期数
  120. ];
  121. }
  122. return $this->filterTypes;
  123. }
  124. }