ProgressRateController.php 103 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461
  1. <?php
  2. /**
  3. * 建站期进度管理
  4. * @copyright 2021-浙江引擎力营销策划有限公司
  5. * @author Lc<sunshinecc1@163.com>
  6. * @since 2021-08-01
  7. */
  8. namespace App\Http\Controllers\Admin\Flow;
  9. use App\Exports\BasicExport;
  10. use App\Exports\BqProgressRateExport;
  11. use App\Exports\EditingScheduleExport;
  12. use App\Exports\PlannerScheduleExport;
  13. use App\Exports\ProgressRateExport;
  14. use App\Http\Controllers\Controller;
  15. use App\Http\Models\BqProjectProgress;
  16. use App\Http\Models\FlowInfo;
  17. use App\Http\Models\FlowStage;
  18. use App\Http\Models\Mailbox;
  19. use App\Http\Models\NotFound;
  20. use App\Http\Models\ProcessProgress;
  21. use App\Http\Models\ProjectFlowMemo;
  22. use App\Http\Models\ProjectFlowMemoRelation;
  23. use App\Http\Models\ProjectProgress;
  24. use App\Http\Models\ProjectProgressCurrentMonth;
  25. use App\Http\Models\ProjectProgressEditing;
  26. use App\Http\Models\ProjectProgressPlanner;
  27. use App\Http\Models\Role;
  28. use App\Http\Models\ScheduledTasks;
  29. use App\Http\Models\ScoreSummary;
  30. use App\Http\Models\Site;
  31. use App\Http\Models\SiteProcess;
  32. use App\Http\Models\User;
  33. use App\Http\Models\WeekTaskInfo;
  34. use App\Http\Services\FlowService;
  35. use App\Http\Services\HomeService;
  36. use Illuminate\Database\Eloquent\Builder;
  37. use Illuminate\Http\Request;
  38. use Illuminate\Support\Facades\DB;
  39. use Illuminate\Contracts\View\Factory;
  40. use Illuminate\View\View;
  41. /**
  42. * 建站期进度管理
  43. * Class ProgressRateController
  44. * @package App\Http\Controllers\Admin\Flow
  45. */
  46. class ProgressRateController extends Controller
  47. {
  48. public $userList = [];
  49. public const CAUSE = [
  50. '1' => '客户原因',
  51. '2' => '采编原因',
  52. '3' => '策划师原因',
  53. '4' => '设计原因',
  54. '5' => '项目经理原因',
  55. '6' => '其他原因',
  56. ];
  57. public function __construct()
  58. {
  59. $this->userList = User::query()->where('status', 1)->get() ?? [];
  60. }
  61. //当月上线目标
  62. public function currentMonthOnline(Request $request)
  63. {
  64. $result = $request->all();
  65. if (!empty($result['list'])) {
  66. $list = json_decode($result['list'], true);
  67. try {
  68. DB::transaction(function () use ($list) {
  69. $siteIds = [];
  70. foreach ($list as $key => $value) {
  71. $siteIds[] = $value['site_id'];
  72. $list[$key]['type'] = implode(',', $value['type']);
  73. }
  74. ProjectProgressCurrentMonth::query()->whereIn('site_id', $siteIds)->delete();
  75. ProjectProgressCurrentMonth::query()->insert($list);
  76. });
  77. } catch (\Throwable $exception) {
  78. return response()->json(['message' => $exception->getMessage()], 400);
  79. }
  80. return response()->json(['message' => '操作成功']);
  81. }
  82. $sites = $this->onlineBuilder($request, 0);
  83. $list = $this->arraySort($sites->toArray(), 'rank', 'desc');
  84. $list = array_merge($list);
  85. return view('admin/flow/current_month_online', [
  86. 'siteList' => $list,
  87. 'userList' => $this->userList,
  88. 'result' => $result
  89. ]);
  90. }
  91. //保存当月达标进度
  92. public function saveCurrentMonthOnline(Request $request)
  93. {
  94. $result = $request->all();
  95. $update = [
  96. 'site_id' => $result['siteId'] ?? 0,
  97. 'type' => implode(',', $result['project_progress'] ?? [0]),
  98. 'memo' => $result['memo'] ?? '',
  99. ];
  100. $info = ProjectProgressCurrentMonth::query()->where('site_id', $result['siteId'])->first();
  101. if (empty($info)) {
  102. ProjectProgressCurrentMonth::query()->insert($update);
  103. } else {
  104. ProjectProgressCurrentMonth::query()->where('site_id', $result['siteId'])->update($update);
  105. }
  106. $patten = "/^\d{4}[\-](0?[1-9]|1[012])[\-](0?[1-9]|[12][0-9]|3[01])(\s+(0?[0-9]|1[0-9]|2[0-3])\:(0?[0-9]|[1-5][0-9])\:(0?[0-9]|[1-5][0-9]))?$/";
  107. if (preg_match($patten, $result['month_range'])) {
  108. Site::query()->where('id', $result['siteId'])->update(['current_month_online_date' => $result['month_range']]);
  109. } else {
  110. return response()->json(['message' => '时间格式不正确'], 400);
  111. }
  112. return response()->json(['message' => '操作成功']);
  113. }
  114. public function onlineBuilder($request, $type = 0)
  115. {
  116. $filterUserIds = [];
  117. $editorId = $request->input('editorId');
  118. $editorId && $filterUserIds[] = $editorId;
  119. $manageHelperId = $request->input('manageHelperId');
  120. $manageHelperId && $filterUserIds[] = $manageHelperId;
  121. $optimizerId = $request->input('optimizerId');
  122. $optimizerId && $filterUserIds[] = $optimizerId;
  123. $webId = $request->input('webId');
  124. $webId && $filterUserIds[] = $webId;
  125. $plannerId = $request->input('plannerId');
  126. $plannerId && $filterUserIds[] = $plannerId;
  127. $keyword = $request->input('keyword');
  128. $schedule = $request->input('schedule');
  129. $site = Site::query();
  130. if (!empty($schedule)) {
  131. $siteIs = ProjectProgressCurrentMonth::query()->whereRaw('FIND_IN_SET(?,type)', [$schedule])->select('site_id')->pluck('site_id')->toArray() ?? [];
  132. $site->whereIn('id', $siteIs);
  133. }
  134. if ($type != 0) {
  135. $site->with(['projectProgressCurrentMonth', 'users'])->where('is_current_month_online', 1);
  136. } else {
  137. $site->with(['projectProgressCurrentMonth', 'users'])->where('is_current_month_online', 1)->whereBetween('current_month_online_date', [date('Y-m-01 00:00:00'), date('Y-m-t 23:59:59')]);
  138. }
  139. $builder = $site->where(function (Builder $q) use ($keyword) {
  140. if ($keyword) {
  141. $q->where('domain', 'like', '%' . $keyword . '%')
  142. ->orWhere('cn_title', 'like', '%' . $keyword . '%');
  143. }
  144. });
  145. if ($filterUserIds) {
  146. $builder->whereExists(function (\Illuminate\Database\Query\Builder $b) use ($filterUserIds) {
  147. $raw = sprintf('SUM(CASE WHEN user_id in (%s) then 1 ELSE 0 end) as total', implode(',', $filterUserIds));
  148. $b->select(DB::raw($raw))->from('user_has_sites')
  149. ->whereRaw(sprintf('user_has_sites.site_id=sites.id HAVING total=%s', count($filterUserIds)));
  150. });
  151. }
  152. $sites = $builder->orderByDesc('id')->get();
  153. foreach ($sites as $item) {
  154. $item->rank = $item->projectProgressCurrentMonth->rank ?? 0;
  155. $item->type = explode(',', $item->projectProgressCurrentMonth->type ?? 0);
  156. $item->memo = $item->projectProgressCurrentMonth->memo ?? '';
  157. $item->manage_helper_title = implode('-', $item->users->where('role_id', Role::TYPE_MANAGE_HELPER)->pluck('nickname')->toArray());
  158. $item->ae_title = implode('-', $item->users->where('role_id', Role::TYPE_AE)->pluck('nickname')->toArray());
  159. $item->planner = implode('-', $item->users->where('role_id', Role::TYPE_PLANNER)->pluck('nickname')->toArray());
  160. $item->web = implode('-', $item->users->where('role_id', Role::TYPE_WEB)->pluck('nickname')->toArray());
  161. $item->designerTitle = implode('-', $item->users->where('role_id', Role::TYPE_DESIGNER)->pluck('nickname')->toArray());
  162. };
  163. return $sites;
  164. }
  165. //未上线原因
  166. public function notOnlineReason(Request $request)
  167. {
  168. $result = $request->all();
  169. if (!empty($result['list'])) {
  170. $list = json_decode($result['list'], true);
  171. try {
  172. DB::transaction(function () use ($list) {
  173. $siteIds = [];
  174. foreach ($list as $key => $value) {
  175. $siteIds[] = $value['site_id'];
  176. $list[$key]['type'] = implode(',', $value['type']);
  177. }
  178. ProjectProgressCurrentMonth::query()->whereIn('site_id', $siteIds)->delete();
  179. ProjectProgressCurrentMonth::query()->insert($list);
  180. });
  181. } catch (\Throwable $exception) {
  182. return response()->json(['message' => $exception->getMessage()], 400);
  183. }
  184. return response()->json(['message' => '操作成功']);
  185. }
  186. $sites = $this->onlineBuilder($request, 1);
  187. $list = $this->arraySort($sites->toArray(), 'rank', 'desc');
  188. $list = array_merge($list);
  189. return view('admin/flow/not_online_reason', [
  190. 'siteList' => $list,
  191. 'userList' => $this->userList,
  192. 'result' => $result
  193. ]);
  194. }
  195. //项目进度(废弃不用)
  196. public function progressRate(Request $request)
  197. {
  198. $result = $request->all();
  199. if (!empty($result['list'])) {
  200. $list = json_decode($result['list'], true);
  201. try {
  202. DB::transaction(function () use ($list) {
  203. $siteIds = [];
  204. foreach ($list as $key => $value) {
  205. $siteIds[] = $value['site_id'];
  206. }
  207. ProjectProgress::query()->whereIn('site_id', $siteIds)->delete();
  208. ProjectProgress::query()->insert($list);
  209. });
  210. } catch (\Throwable $exception) {
  211. return response()->json(['message' => $exception->getMessage()], 400);
  212. }
  213. return response()->json(['message' => '操作成功']);
  214. }
  215. list($list, $user) = $this->progressRateBuild($request);
  216. return view('admin.flow.progress_rate', [
  217. 'siteList' => $list,
  218. 'role_id' => $user->role_id,
  219. 'userList' => $this->userList,
  220. 'result' => $result
  221. ]);
  222. }
  223. //项目进度(废弃不用)
  224. public function progressRateBuild($request, $type = 0)
  225. {
  226. $user = auth()->user();
  227. $list = Site::query()->with(['projectProgress', 'projectProgressEditing', 'projectProgressPlanner', 'users']);
  228. $list = $this->getAuthBySiteId($request, $list, $user)->whereIn('status', [1, 4])->get();
  229. foreach ($list as $key => $item) {
  230. $item->info = 0;
  231. $info = FlowInfo::query()->where('site_id', $item->id)->where('detail_list', 'like', '%网站架构定稿%')->first();
  232. if (!empty($info)) {
  233. foreach ($info->detail_list as $kk => $vv) {
  234. if ($vv['flow_name'] == '网站架构定稿') {
  235. if (!empty($vv['flow_done_date'])) {
  236. $item->info = 1;
  237. }
  238. }
  239. }
  240. }
  241. $item->rank = $item->projectProgress->rank ?? 0;
  242. $item->sort = $item->projectProgress->sort ?? 0;
  243. $item->memo = $item->projectProgress->memo ?? '';
  244. $item->prophase = 0;
  245. if (!empty($item->projectProgressEditing->is_backstage) &&
  246. !empty($item->projectProgressEditing->is_first_mail)) {
  247. $item->prophase = 1;
  248. }
  249. $item->data = 0;
  250. if (!empty($item->projectProgressEditing->is_data) &&
  251. !empty($item->projectProgressEditing->is_folder) &&
  252. !empty($item->projectProgressEditing->is_order_index) &&
  253. !empty($item->projectProgressEditing->is_product_index)) {
  254. $item->data = 1;
  255. }
  256. $item->test = 0;
  257. if (!empty($item->projectProgressEditing->is_test_station) &&
  258. !empty($item->projectProgressEditing->is_opinion) &&
  259. !empty($item->projectProgressEditing->is_project_group) &&
  260. !empty($item->projectProgressEditing->is_client_feedback)) {
  261. $item->test = 1;
  262. }
  263. $item->online = 0;
  264. if (!empty($item->projectProgressEditing->is_online_inspection_form) &&
  265. !empty($item->projectProgressEditing->is_in_group_inspection) &&
  266. !empty($item->projectProgressEditing->is_quality_inspection_departments) &&
  267. !empty($item->projectProgressEditing->is_optimization)) {
  268. $item->online = 1;
  269. }
  270. $item->is_keywords = $item->projectProgressPlanner->is_keywords ?? 0;
  271. $item->is_keywords_map = $item->projectProgressPlanner->is_keywords_map ?? 0;
  272. $item->is_tdk = $item->projectProgressPlanner->is_tdk ?? 0;
  273. $item->page_planning = 0;
  274. if (!empty($item->projectProgressPlanner->is_keywords_implantation) &&
  275. !empty($item->projectProgressPlanner->is_home_planning) &&
  276. !empty($item->projectProgressPlanner->is_product_guidance_document) &&
  277. !empty($item->projectProgressPlanner->is_inside_page_planning) &&
  278. !empty($item->projectProgressPlanner->is_special_page_planning)) {
  279. $item->page_planning = 1;
  280. }
  281. $item->editing = $item->users->where('role_id', Role::TYPE_AE)->first()->nickname ?? '';
  282. $item->project_manager = $item->users->where('role_id', Role::TYPE_MANAGE_HELPER)->first()->nickname ?? '';
  283. $item->planner = $item->users->where('role_id', Role::TYPE_PLANNER)->first()->nickname ?? '';
  284. }
  285. if ($type == 1) {
  286. $list = $list->toArray();
  287. }
  288. $list = $this->arraySort($list, 'rank', 'desc');
  289. $list = array_merge($list);
  290. return [$list, $user];
  291. }
  292. //百千项目进度
  293. public function bqProgressRate(Request $request)
  294. {
  295. $result = $request->all();
  296. if (!empty($result['list'])) {
  297. $list = json_decode($result['list'], true);
  298. try {
  299. DB::transaction(function () use ($list) {
  300. $siteIds = [];
  301. foreach ($list as $key => $value) {
  302. $siteIds[] = $value['site_id'];
  303. }
  304. BqProjectProgress::query()->whereIn('site_id', $siteIds)->delete();
  305. BqProjectProgress::query()->insert($list);
  306. });
  307. } catch (\Throwable $exception) {
  308. return response()->json(['message' => $exception->getMessage()], 400);
  309. }
  310. return response()->json(['message' => '操作成功']);
  311. }
  312. list($list, $userAuth) = $this->bqProgressRateBuild($request);
  313. return view('admin.flow.bq_progress_rate', [
  314. 'siteList' => $list,
  315. 'role_id' => $userAuth->role_id,
  316. 'userList' => $this->userList,
  317. 'result' => $result
  318. ]);
  319. }
  320. public function bqProgressRateBuild($request)
  321. {
  322. $userAuth = auth()->user();
  323. $list = Site::query()
  324. ->where('is_bq', 1)
  325. ->with(['bqProjectProgress', 'users', 'bqFlow.bqFlowInfo']);
  326. $list = $this->getAuthBySiteId($request, $list, $userAuth)->get()->toArray();
  327. $result = [];
  328. foreach ($list as $key => $item) {
  329. $data = [
  330. 'id' => $item['id'],
  331. 'bq_at' => date('Y-m-d', strtotime($item['bq_at'])),
  332. 'cn_title' => $item['cn_title'] ?? '',
  333. 'optimization' => '',
  334. 'bq_meeting' => 1,
  335. 'home_page_adjustment' => 1,
  336. 'product_series_page_adjustment' => 1,
  337. 'other_page_adjustments' => 1,
  338. 'code_adjustment' => 1,
  339. 'web_page_adjustment' => 1,
  340. 'website_seo_quality_inspection' => 1,
  341. 'small_language_station' => 1,
  342. 'rank' => $item['bq_project_progress']['rank'] ?? 0,
  343. 'memo' => $item['bq_project_progress']['memo'] ?? '',
  344. ];
  345. foreach ($item['users'] as $user) {
  346. if ($user['role_id'] == Role::TYPE_OPTIMIZER) {
  347. $data['optimization'] = $user['nickname'];
  348. }
  349. }
  350. if (empty($item['bq_flow'])) {
  351. $data['bq_meeting'] = 0;
  352. $data['home_page_adjustment'] = 0;
  353. $data['product_series_page_adjustment'] = 0;
  354. $data['other_page_adjustments'] = 0;
  355. $data['code_adjustment'] = 0;
  356. $data['web_page_adjustment'] = 0;
  357. $data['website_seo_quality_inspection'] = 0;
  358. $data['small_language_station'] = 0;
  359. } else {
  360. foreach ($item['bq_flow'] as $value) {
  361. foreach ($value['bq_flow_info'] as $index) {
  362. foreach ($index['detail_list'] as $k => $v) {
  363. foreach ($v['children'] as $vv) {
  364. $vv['title'] = $value['title'];
  365. if (empty($vv['flow_done_date']) && $vv['title'] == '百千会议') {
  366. $data['bq_meeting'] = 0;
  367. }
  368. if (empty($vv['flow_done_date']) && $vv['title'] == '首页调整') {
  369. $data['home_page_adjustment'] = 0;
  370. }
  371. if (empty($vv['flow_done_date']) && $vv['title'] == '产品系列页面调整') {
  372. $data['product_series_page_adjustment'] = 0;
  373. }
  374. if (empty($vv['flow_done_date']) && $vv['title'] == '其他页面调整') {
  375. $data['other_page_adjustments'] = 0;
  376. }
  377. if (empty($vv['flow_done_date']) && $vv['title'] == '代码调整') {
  378. $data['code_adjustment'] = 0;
  379. }
  380. if (empty($vv['flow_done_date']) && $vv['title'] == '网页调整') {
  381. $data['web_page_adjustment'] = 0;
  382. }
  383. if (empty($vv['flow_done_date']) && $vv['title'] == '网站SEO质检') {
  384. $data['website_seo_quality_inspection'] = 0;
  385. }
  386. if (empty($vv['flow_done_date']) && $vv['title'] == '小语言站') {
  387. $data['small_language_station'] = 0;
  388. }
  389. }
  390. }
  391. }
  392. }
  393. }
  394. $result[] = $data;
  395. }
  396. $result = $this->arraySort($result, 'rank', 'desc');
  397. $result = array_merge($result);
  398. return [$result, $userAuth];
  399. }
  400. //策划师进度(废弃不用)
  401. public function plannerSchedule(Request $request)
  402. {
  403. $result = $request->all();
  404. if (!empty($result['list'])) {
  405. $list = json_decode($result['list'], true);
  406. try {
  407. DB::transaction(function () use ($list) {
  408. $siteIds = [];
  409. foreach ($list as $key => $value) {
  410. $siteIds[] = $value['site_id'];
  411. }
  412. ProjectProgressPlanner::query()->whereIn('site_id', $siteIds)->delete();
  413. ProjectProgressPlanner::query()->insert($list);
  414. });
  415. } catch (\Throwable $exception) {
  416. return response()->json(['message' => $exception->getMessage()], 400);
  417. }
  418. return response()->json(['message' => '操作成功']);
  419. }
  420. $user = auth()->user();
  421. $list = Site::query()->with(['projectProgressPlanner', 'users']);
  422. $list = $this->getAuthBySiteId($request, $list, $user)->whereIn('status', [1, 4])->get();
  423. $siteProcess = SiteProcess::query()
  424. ->whereNotNull('deploy')
  425. ->where('process_id', 7)->where('active', 2)
  426. ->pluck('deploy', 'site_id')->toArray() ?? [];
  427. $siteProcessList = [];
  428. foreach ($siteProcess as $key => $process) {
  429. $siteProcessList[$key] = $process['domain'];
  430. }
  431. foreach ($list as $key => $item) {
  432. $item->url = $siteProcessList[$item->id] ?? '';
  433. $item->memo = $item->projectProgressPlanner->memo ?? '';
  434. $item->is_keywords = $item->projectProgressPlanner->is_keywords ?? 0;
  435. $item->is_keywords_map = $item->projectProgressPlanner->is_keywords_map ?? 0;
  436. $item->is_tdk = $item->projectProgressPlanner->is_tdk ?? 0;
  437. $item->is_keywords_implantation = $item->projectProgressPlanner->is_keywords_implantation ?? 0;
  438. $item->is_home_planning = $item->projectProgressPlanner->is_home_planning ?? 0;
  439. $item->is_product_guidance_document = $item->projectProgressPlanner->is_product_guidance_document ?? 0;
  440. $item->is_inside_page_planning = $item->projectProgressPlanner->is_inside_page_planning ?? 0;
  441. $item->is_special_page_planning = $item->projectProgressPlanner->is_special_page_planning ?? 0;
  442. $item->rank = $item->projectProgressPlanner->rank ?? 0;
  443. $item->editing = $item->users->where('role_id', Role::TYPE_AE)->first()->nickname ?? '';
  444. $item->nickname = $item->users->where('role_id', Role::TYPE_PLANNER)->first()->nickname ?? '';
  445. }
  446. $list = $this->arraySort($list, 'rank', 'desc');
  447. $list = array_merge($list);
  448. $editors = User::query()->where('status', 1)->where('role_id', Role::TYPE_PLANNER)->pluck('nickname', 'id');
  449. return view('admin.flow.planner_schedule', [
  450. 'siteList' => $list,
  451. 'editors' => $editors,
  452. 'role_id' => $user->role_id,
  453. ]);
  454. }
  455. //采编进度(废弃不用)
  456. public function editingSchedule(Request $request)
  457. {
  458. $result = $request->all();
  459. if (!empty($result['list'])) {
  460. $list = json_decode($result['list'], true);
  461. try {
  462. DB::transaction(function () use ($list) {
  463. $siteIds = [];
  464. foreach ($list as $key => $value) {
  465. $siteIds[] = $value['site_id'];
  466. }
  467. ProjectProgressEditing::query()->whereIn('site_id', $siteIds)->delete();
  468. ProjectProgressEditing::query()->insert($list);
  469. });
  470. } catch (\Throwable $exception) {
  471. return response()->json(['message' => $exception->getMessage()], 400);
  472. }
  473. return response()->json(['message' => '操作成功']);
  474. }
  475. $user = auth()->user();
  476. $list = Site::query()->with(['projectProgressEditing', 'users']);
  477. $list = $this->getAuthBySiteId($request, $list, $user)->whereIn('status', [1, 4])->get();
  478. foreach ($list as $key => $item) {
  479. $item->is_backstage = $item->projectProgressEditing->is_backstage ?? 0;
  480. $item->memo = $item->projectProgressEditing->memo ?? '';
  481. $item->is_first_mail = $item->projectProgressEditing->is_first_mail ?? 0;
  482. $item->is_data = $item->projectProgressEditing->is_data ?? 0;
  483. $item->is_folder = $item->projectProgressEditing->is_folder ?? 0;
  484. $item->is_order_index = $item->projectProgressEditing->is_order_index ?? 0;
  485. $item->is_product_index = $item->projectProgressEditing->is_product_index ?? 0;
  486. $item->is_test_station = $item->projectProgressEditing->is_test_station ?? 0;
  487. $item->is_opinion = $item->projectProgressEditing->is_opinion ?? 0;
  488. $item->is_project_group = $item->projectProgressEditing->is_project_group ?? 0;
  489. $item->is_client_feedback = $item->projectProgressEditing->is_client_feedback ?? 0;
  490. $item->is_online_inspection_form = $item->projectProgressEditing->is_online_inspection_form ?? 0;
  491. $item->is_in_group_inspection = $item->projectProgressEditing->is_in_group_inspection ?? 0;
  492. $item->is_quality_inspection_departments = $item->projectProgressEditing->is_quality_inspection_departments ?? 0;
  493. $item->is_optimization = $item->projectProgressEditing->is_optimization ?? 0;
  494. $item->rank = $item->projectProgressEditing->rank ?? 0;
  495. $item->nickname = $item->users->where('role_id', Role::TYPE_AE)->first()->nickname ?? '';
  496. }
  497. $list = $this->arraySort($list, 'rank', 'desc');
  498. $list = array_merge($list);
  499. $editors = User::query()->where('status', 1)->where('role_id', Role::TYPE_AE)->pluck('nickname', 'id');
  500. return view('admin.flow.editing_schedule', [
  501. 'siteList' => $list,
  502. 'editors' => $editors,
  503. 'role_id' => $user->role_id,
  504. ]);
  505. }
  506. //逾期导出(废弃不用)
  507. public function scheduleOverdueExport(Request $request)
  508. {
  509. $site = $this->scheduleOverdueBuilder($request)->get();
  510. $siteList = $this->resetScheduleOverdue($site);
  511. $result = [];
  512. foreach ($siteList as $item) {
  513. $data = [
  514. 'cn_title' => $item->cn_title,
  515. 'domain' => $item->domain,
  516. 'projectManager' => $item->projectManager,
  517. 'serverManager' => $item->serverManager,
  518. 'salesManager' => $item->salesManager,
  519. 'expectedDay' => $item->expectedDay,
  520. 'overdueDay' => $item->overdueDay,
  521. 'projectDataCollection' => $item->projectDataCollection,
  522. 'projectDataCollectionMemo' => $item->projectDataCollectionMemo,
  523. 'projectDataCollectionComplete' => $item->projectDataCollectionComplete,
  524. 'siteArchitecture' => $item->siteArchitecture,
  525. 'siteArchitectureMemo' => $item->siteArchitectureMemo,
  526. 'siteArchitectureComplete' => $item->siteArchitectureComplete,
  527. 'homepageDesign' => $item->homepageDesign,
  528. 'homepageDesignMemo' => $item->homepageDesignMemo,
  529. 'homepageDesignComplete' => $item->homepageDesignComplete,
  530. 'insidePageDesign' => $item->insidePageDesign,
  531. 'insidePageDesignMemo' => $item->insidePageDesignMemo,
  532. 'insidePageDesignComplete' => $item->insidePageDesignComplete,
  533. 'websiteInformationProvision' => $item->websiteInformationProvision,
  534. 'websiteInformationProvisionMemo' => $item->websiteInformationProvisionMemo,
  535. 'websiteInformationProvisionComplete' => $item->websiteInformationProvisionComplete,
  536. 'testStation' => $item->testStation,
  537. 'testStationMemo' => $item->testStationMemo,
  538. 'testStationComplete' => $item->testStationComplete,
  539. 'keyWords' => $item->keyWords,
  540. 'keyWordsMemo' => $item->keyWordsMemo,
  541. 'keyWordsComplete' => $item->keyWordsComplete,
  542. 'seo' => $item->seo,
  543. 'seoMemo' => $item->seoMemo,
  544. 'seoComplete' => $item->seoComplete,
  545. 'online' => $item->online,
  546. 'onlineMemo' => $item->onlineMemo,
  547. 'onlineComplete' => $item->onlineComplete,
  548. ];
  549. $result[] = $data;
  550. }
  551. array_unshift($result, ['项目名称', '域名', '项目经理', '销售经理', '项目管家', '预计总天数', '逾期天数', '项目资料搜集逾期时间', '逾期原因', '项目资料搜集完成用时', '网站架构逾期时间', '逾期原因', '网站架构完成用时', '首页设计逾期时间', '逾期原因', '首页设计完成用时', '内页设计逾期时间', '逾期原因', '内页设计完成用时', '整站资料提供逾期时间', '逾期原因', '整站资料提供完成用时', '测试站逾期时间', '逾期原因', '测试站完成用时', '关键词逾期时间', '逾期原因', '关键词完成用时', 'seo完善逾期时间', '逾期原因', 'seo完善完成用时', '上线逾期时间', '逾期原因', '上线完成用时']);
  552. return (new BasicExport($result))->download(sprintf('进度逾期%s.xls', date('YmdHis')));
  553. }
  554. //逾期汇总及原因(废弃不用)
  555. public function scheduleOverdue(Request $request)
  556. {
  557. if (!$request->ajax()) {
  558. $managerHelpers = User::query()->where('role_id', Role::TYPE_MANAGE_HELPER)->get();
  559. return view('admin.flow.schedule_overdue', [
  560. 'managerHelpers' => $managerHelpers,
  561. ]);
  562. }
  563. $site = $this->scheduleOverdueBuilder($request);
  564. $siteList = $site->paginate($request->input('pageSize') ?? TABLE_PAGE_SIZE);
  565. $siteList = $this->resetScheduleOverdue($siteList);
  566. return response()->json([
  567. 'rows' => $siteList->items(),
  568. 'total' => $siteList->total()
  569. ]);
  570. }
  571. //逾期汇总及原因(废弃不用)
  572. public function scheduleOverdueBuilder($request)
  573. {
  574. $site = Site::query();
  575. $keyword = $request->input('keyword');
  576. if ($keyword) {
  577. $site->where('domain', 'like', "%{$keyword}%")
  578. ->orWhere('cn_title', 'like', "%{$keyword}%");
  579. }
  580. $manageHelperId = $request->input('manageHelperId');
  581. if ($manageHelperId) {
  582. $siteIdList = DB::table('user_has_sites')->where('user_id', $manageHelperId)->pluck('site_id') ?? [];
  583. $site->whereIn('id', $siteIdList);
  584. }
  585. $date = $request->input('date');
  586. if ($date) {
  587. $siteIdList = FlowStage::query()
  588. ->whereBetween('expected_date', [date('Y-m-d', strtotime($date)), date('Y-m-t', strtotime($date))])
  589. ->groupBy('site_id')->pluck('site_id')->toArray() ?? [];
  590. $site->whereIn('id', $siteIdList);
  591. }
  592. $siteIds = FlowStage::query()->whereNotNull('expected_date')->groupBy('site_id')->pluck('site_id')->toArray() ?? [];
  593. if ($siteIds) {
  594. $site->whereIn('id', $siteIds);
  595. }
  596. $site = $site->with(['users', 'projectProgressFlowStage']);
  597. return $site;
  598. }
  599. //逾期汇总及原因(废弃不用)
  600. public function resetScheduleOverdue($siteList)
  601. {
  602. foreach ($siteList as $item) {
  603. $item->projectManager = implode('-', $item->users->where('role_id', Role::TYPE_MANAGE_HELPER)->pluck('nickname')->toArray());
  604. $item->serverManager = implode('-', $item->users->where('role_id', Role::TYPE_SERVER)->pluck('nickname')->toArray());
  605. $item->salesManager = implode('-', $item->users->where('role_id', Role::TYPE_SELLER)->pluck('nickname')->toArray());
  606. $item->expectedDay = '';
  607. $item->overdueDay = '';
  608. $item->projectDataCollection = '';
  609. $item->projectDataCollectionMemo = '';
  610. $item->projectDataCollectionComplete = '';
  611. $item->siteArchitecture = '';
  612. $item->siteArchitectureMemo = '';
  613. $item->siteArchitectureComplete = '';
  614. $item->homepageDesign = '';
  615. $item->homepageDesignMemo = '';
  616. $item->homepageDesignComplete = '';
  617. $item->insidePageDesign = '';
  618. $item->insidePageDesignMemo = '';
  619. $item->insidePageDesignComplete = '';
  620. $item->websiteInformationProvision = '';
  621. $item->websiteInformationProvisionMemo = '';
  622. $item->websiteInformationProvisionComplete = '';
  623. $item->testStation = '';
  624. $item->testStationMemo = '';
  625. $item->testStationComplete = '';
  626. $item->keyWords = '';
  627. $item->keyWordsMemo = '';
  628. $item->keyWordsComplete = '';
  629. $item->seo = '';
  630. $item->seoMemo = '';
  631. $item->seoComplete = '';
  632. $item->online = '';
  633. $item->onlineMemo = '';
  634. $item->onlineComplete = '';
  635. if (!empty($item->projectProgressFlowStage)) {
  636. $day = [];
  637. foreach ($item->projectProgressFlowStage as $value) {
  638. if (!empty($value->expected_date)) {
  639. $day[] = strtotime($value->expected_date);
  640. }
  641. $this->getOverdueList($item, $value);
  642. }
  643. $dayList = $this->maoPao($day);
  644. if (count($dayList) > 0) {
  645. $day = ($dayList[count($dayList) - 1] - $dayList[0]) / 86400;
  646. $item->expectedDay = $day;
  647. $overdueDay = (strtotime(date('Y-m-d')) - $dayList[0]) / 86400;
  648. $item->overdueDay = $overdueDay;
  649. }
  650. }
  651. }
  652. return $siteList;
  653. }
  654. //标记
  655. public function setSiteIdByRankId(Request $request)
  656. {
  657. $result = $request->all();
  658. if ($result['type'] == 1) {
  659. $model = ProjectProgressEditing::query();
  660. } elseif ($result['type'] == 2) {
  661. $model = ProjectProgressPlanner::query();
  662. } elseif ($result['type'] == 3) {
  663. $model = BqProjectProgress::query();
  664. } elseif ($result['type'] == 4) {
  665. $model = ProjectProgress::query();
  666. } elseif ($result['type'] == 5) {
  667. $model = ScoreSummary::query();
  668. } elseif ($result['type'] == 6) {
  669. $model = ProcessProgress::query();
  670. } elseif ($result['type'] == 7) {
  671. $model = ProjectProgressCurrentMonth::query();
  672. } else {
  673. $model = '';
  674. }
  675. $info = $model->where('site_id', $result['siteId'])->first();
  676. if (empty($info)) {
  677. return response()->json(['message' => '请先保存再标记'], 400);
  678. }
  679. $model->where('site_id', $result['siteId'])->update(['rank' => $result['rank']]);
  680. return response()->json(['message' => '操作成功']);
  681. }
  682. //二维数组排序
  683. public function arraySort($array, $keys, $sort = 'asc')
  684. {
  685. $newArr = $valArr = array();
  686. foreach ($array as $key => $value) {
  687. $valArr[$key] = $value[$keys];
  688. }
  689. ($sort == 'asc') ? asort($valArr) : arsort($valArr);
  690. reset($valArr);
  691. foreach ($valArr as $key => $value) {
  692. $newArr[$key] = $array[$key];
  693. }
  694. return $newArr;
  695. }
  696. /**
  697. * 筛选查询对象
  698. * @param $result
  699. * @param $site object
  700. * @param $user
  701. * @return mixed
  702. */
  703. public function getAuthBySiteId($result, $site, $user)
  704. {
  705. if (!empty($result['keyword'])) {
  706. $site->where('cn_title', 'like', '%' . $result['keyword'] . '%');
  707. }
  708. if (!empty($result['userId'])) {
  709. $siteIdList = DB::table('user_has_sites')->where('user_id', $result['userId'])->pluck('site_id') ?? [];
  710. $site->whereIn('id', $siteIdList);
  711. }
  712. if (!empty($result['projectManagerId'])) {
  713. $siteIdList = DB::table('user_has_sites')->where('user_id', $result['projectManagerId'])->pluck('site_id') ?? [];
  714. $site->whereIn('id', $siteIdList);
  715. }
  716. if (!empty($result['plannerId'])) {
  717. $siteIdList = DB::table('user_has_sites')->where('user_id', $result['plannerId'])->pluck('site_id') ?? [];
  718. $site->whereIn('id', $siteIdList);
  719. }
  720. if (!empty($result['editingId'])) {
  721. $siteIdList = DB::table('user_has_sites')->where('user_id', $result['editingId'])->pluck('site_id') ?? [];
  722. $site->whereIn('id', $siteIdList);
  723. }
  724. if (!empty($result['designerId'])) {
  725. $siteIdList = DB::table('user_has_sites')->where('user_id', $result['designerId'])->pluck('site_id') ?? [];
  726. $site->whereIn('id', $siteIdList);
  727. }
  728. if (!empty($result['webId'])) {
  729. $siteIdList = DB::table('user_has_sites')->where('user_id', $result['webId'])->pluck('site_id') ?? [];
  730. $site->whereIn('id', $siteIdList);
  731. }
  732. if (!empty($result['projectStewardId'])) {
  733. $siteIdList = DB::table('user_has_sites')->where('user_id', $result['projectStewardId'])->pluck('site_id') ?? [];
  734. $site->whereIn('id', $siteIdList);
  735. }
  736. if (!empty($result['sellerId'])) {
  737. $siteIdList = DB::table('user_has_sites')->where('user_id', $result['sellerId'])->pluck('site_id') ?? [];
  738. $site->whereIn('id', $siteIdList);
  739. }
  740. if (!empty($result['serverId'])) {
  741. $siteIdList = DB::table('user_has_sites')->where('user_id', $result['serverId'])->pluck('site_id') ?? [];
  742. $site->whereIn('id', $siteIdList);
  743. }
  744. if (!empty($result['sort'])) {
  745. $siteIdList = ProjectProgress::query()->where('sort', $result['sort'])->pluck('site_id') ?? [];
  746. $site->whereIn('id', $siteIdList);
  747. }
  748. if (!in_array($user->role_id, [Role::TYPE_MANAGE_LEADER, Role::TYPE_DESIGN_DIRECTOR, Role::TYPE_HR, Role::TYPE_CHONGQING_MANAGER, Role::TYPE_QUALITY])) {
  749. $siteIdList = DB::table('user_has_sites')->where('user_id', $user->id)->pluck('site_id') ?? [];
  750. $site->whereIn('id', $siteIdList);
  751. }
  752. return $site;
  753. }
  754. //逾期汇总及原因(废弃不用)
  755. public function getOverdueList(&$item, &$value)
  756. {
  757. if ($value->title == '项目资料搜集') {
  758. //逾期天数
  759. if (!empty($value->expected_date) && empty($value->complete_date)) {
  760. $time = strtotime(date('Y-m-d')) - strtotime($value->expected_date);
  761. if ($time > 0) {
  762. $item->projectDataCollection = floor($time / 86400);
  763. }
  764. }
  765. //逾期天数
  766. if (!empty($value->expected_date) && !empty($value->complete_date)) {
  767. //重置延期天数
  768. if ($value->complete_date > $value->expected_date) {
  769. $item->projectDataCollection = floor((strtotime($value->complete_date) - strtotime($value->expected_date)) / 86400);
  770. } else {
  771. $item->projectDataCollection = '';
  772. }
  773. }
  774. //逾期原因
  775. if (!empty($value->expected_date) && empty($value->complete_date)) {
  776. $result = explode(',', $value->extension);
  777. $projectDataCollectionMemo = [];
  778. foreach ($result as $index) {
  779. $projectDataCollectionMemo[] = self::CAUSE[$index] ?? '';
  780. }
  781. $item->projectDataCollectionMemo = implode(',', $projectDataCollectionMemo);
  782. }
  783. //完成用时
  784. if (!empty($value->complete_date)) {
  785. $time = strtotime($value->complete_date) - strtotime($value->expected_date);
  786. if ($time > 0) {
  787. $item->projectDataCollectionComplete = floor($time / 86400);
  788. }
  789. }
  790. }
  791. if ($value->title == '网站架构') {
  792. if (!empty($value->expected_date) && empty($value->complete_date)) {
  793. $time = strtotime(date('Y-m-d')) - strtotime($value->expected_date);
  794. if ($time > 0) {
  795. $item->siteArchitecture = floor($time / 86400);
  796. }
  797. }
  798. if (!empty($value->expected_date) && !empty($value->complete_date)) {
  799. if ($value->complete_date > $value->expected_date) {
  800. $item->siteArchitecture = floor((strtotime($value->complete_date) - strtotime($value->expected_date)) / 86400);
  801. } else {
  802. $item->siteArchitecture = '';
  803. }
  804. }
  805. if (!empty($value->extension)) {
  806. $result = explode(',', $value->extension);
  807. $siteArchitectureMemo = [];
  808. foreach ($result as $index) {
  809. $siteArchitectureMemo[] = self::CAUSE[$index] ?? '';
  810. }
  811. $item->siteArchitectureMemo = implode(',', $siteArchitectureMemo);
  812. }
  813. if (!empty($value->complete_date)) {
  814. $time = strtotime($value->complete_date) - strtotime($value->expected_date);
  815. if ($time > 0) {
  816. $item->siteArchitectureComplete = floor($time / 86400);
  817. }
  818. }
  819. }
  820. if ($value->title == '首页设计') {
  821. if (!empty($value->expected_date) && empty($value->complete_date)) {
  822. $time = strtotime(date('Y-m-d')) - strtotime($value->expected_date);
  823. if ($time > 0) {
  824. $item->homepageDesign = floor($time / 86400);
  825. }
  826. }
  827. if (!empty($value->expected_date) && !empty($value->complete_date)) {
  828. if ($value->complete_date > $value->expected_date) {
  829. $item->homepageDesign = floor((strtotime($value->complete_date) - strtotime($value->expected_date)) / 86400);
  830. } else {
  831. $item->homepageDesign = '';
  832. }
  833. }
  834. if (!empty($value->extension)) {
  835. $result = explode(',', $value->extension);
  836. $homepageDesignMemo = [];
  837. foreach ($result as $index) {
  838. $homepageDesignMemo[] = self::CAUSE[$index] ?? '';
  839. }
  840. $item->homepageDesignMemo = implode(',', $homepageDesignMemo);
  841. }
  842. if (!empty($value->complete_date)) {
  843. $time = strtotime($value->complete_date) - strtotime($value->expected_date);
  844. if ($time > 0) {
  845. $item->homepageDesignComplete = floor($time / 86400);
  846. }
  847. }
  848. }
  849. if ($value->title == '内页设计') {
  850. if (!empty($value->expected_date) && empty($value->complete_date)) {
  851. $time = strtotime(date('Y-m-d')) - strtotime($value->expected_date);
  852. if ($time > 0) {
  853. $item->insidePageDesign = floor($time / 86400);
  854. }
  855. }
  856. if (!empty($value->expected_date) && !empty($value->complete_date)) {
  857. //重置延期天数
  858. if ($value->complete_date > $value->expected_date) {
  859. $item->insidePageDesign = floor((strtotime($value->complete_date) - strtotime($value->expected_date)) / 86400);
  860. } else {
  861. $item->insidePageDesign = '';
  862. }
  863. }
  864. if (!empty($value->extension)) {
  865. $result = explode(',', $value->extension);
  866. $insidePageDesignMemo = [];
  867. foreach ($result as $index) {
  868. $insidePageDesignMemo[] = self::CAUSE[$index] ?? '';
  869. }
  870. $item->insidePageDesignMemo = implode(',', $insidePageDesignMemo);
  871. }
  872. if (!empty($value->complete_date)) {
  873. $time = strtotime($value->complete_date) - strtotime($value->expected_date);
  874. if ($time > 0) {
  875. $item->insidePageDesignComplete = floor($time / 86400);
  876. }
  877. }
  878. }
  879. if ($value->title == '整站资料提供') {
  880. if (!empty($value->expected_date) && empty($value->complete_date)) {
  881. $time = strtotime(date('Y-m-d')) - strtotime($value->expected_date);
  882. if ($time > 0) {
  883. $item->websiteInformationProvision = floor($time / 86400);
  884. }
  885. }
  886. if (!empty($value->expected_date) && !empty($value->complete_date)) {
  887. if ($value->complete_date > $value->expected_date) {
  888. $item->websiteInformationProvision = floor((strtotime($value->complete_date) - strtotime($value->expected_date)) / 86400);
  889. } else {
  890. $item->websiteInformationProvision = '';
  891. }
  892. }
  893. if (!empty($value->extension)) {
  894. $result = explode(',', $value->extension);
  895. $websiteInformationProvisionMemo = [];
  896. foreach ($result as $index) {
  897. $websiteInformationProvisionMemo[] = self::CAUSE[$index] ?? '';
  898. }
  899. $item->websiteInformationProvisionMemo = implode(',', $websiteInformationProvisionMemo);
  900. }
  901. if (!empty($value->complete_date)) {
  902. $time = strtotime($value->complete_date) - strtotime($value->expected_date);
  903. if ($time > 0) {
  904. $item->websiteInformationProvisionComplete = floor($time / 86400);
  905. }
  906. }
  907. }
  908. if ($value->title == '测试站') {
  909. if (!empty($value->expected_date) && empty($value->complete_date)) {
  910. $time = strtotime(date('Y-m-d')) - strtotime($value->expected_date);
  911. if ($time > 0) {
  912. $item->testStation = floor($time / 86400);
  913. }
  914. }
  915. if (!empty($value->expected_date) && !empty($value->complete_date)) {
  916. if ($value->complete_date > $value->expected_date) {
  917. $item->testStation = floor((strtotime($value->complete_date) - strtotime($value->expected_date)) / 86400);
  918. } else {
  919. $item->testStation = '';
  920. }
  921. }
  922. if (!empty($value->extension)) {
  923. $result = explode(',', $value->extension);
  924. $testStationMemo = [];
  925. foreach ($result as $index) {
  926. $testStationMemo[] = self::CAUSE[$index] ?? '';
  927. }
  928. $item->testStationMemo = implode(',', $testStationMemo);
  929. }
  930. if (!empty($value->complete_date)) {
  931. $time = strtotime($value->complete_date) - strtotime($value->expected_date);
  932. if ($time > 0) {
  933. $item->testStationComplete = floor($time / 86400);
  934. }
  935. }
  936. }
  937. if ($value->title == '关键词') {
  938. if (!empty($value->expected_date) && empty($value->complete_date)) {
  939. $time = strtotime(date('Y-m-d')) - strtotime($value->expected_date);
  940. if ($time > 0) {
  941. $item->keyWords = floor($time / 86400);
  942. }
  943. }
  944. if (!empty($value->expected_date) && !empty($value->complete_date)) {
  945. if ($value->complete_date > $value->expected_date) {
  946. $item->keyWords = floor((strtotime($value->complete_date) - strtotime($value->expected_date)) / 86400);
  947. } else {
  948. $item->keyWords = '';
  949. }
  950. }
  951. if (!empty($value->extension)) {
  952. $result = explode(',', $value->extension);
  953. $keyWordsMemo = [];
  954. foreach ($result as $index) {
  955. $keyWordsMemo[] = self::CAUSE[$index] ?? '';
  956. }
  957. $item->keyWordsMemo = implode(',', $keyWordsMemo);
  958. }
  959. if (!empty($value->complete_date)) {
  960. $time = strtotime($value->complete_date) - strtotime($value->expected_date);
  961. if ($time > 0) {
  962. $item->keyWordsComplete = floor($time / 86400);
  963. }
  964. }
  965. }
  966. if ($value->title == 'SEO完善') {
  967. if (!empty($value->expected_date) && empty($value->complete_date)) {
  968. $time = strtotime(date('Y-m-d')) - strtotime($value->expected_date);
  969. if ($time > 0) {
  970. $item->seo = floor($time / 86400);
  971. }
  972. }
  973. if (!empty($value->expected_date) && !empty($value->complete_date)) {
  974. if ($value->complete_date > $value->expected_date) {
  975. $item->seo = floor((strtotime($value->complete_date) - strtotime($value->expected_date)) / 86400);
  976. } else {
  977. $item->seo = '';
  978. }
  979. }
  980. if (!empty($value->extension)) {
  981. $result = explode(',', $value->extension);
  982. $seoMemo = [];
  983. foreach ($result as $index) {
  984. $seoMemo[] = self::CAUSE[$index] ?? '';
  985. }
  986. $item->seoMemo = implode(',', $seoMemo);
  987. }
  988. if (!empty($value->complete_date)) {
  989. $time = strtotime($value->complete_date) - strtotime($value->expected_date);
  990. if ($time > 0) {
  991. $item->seoComplete = floor($time / 86400);
  992. }
  993. }
  994. }
  995. if ($value->title == '上线') {
  996. if (!empty($value->expected_date) && empty($value->complete_date)) {
  997. $time = strtotime(date('Y-m-d')) - strtotime($value->expected_date);
  998. if ($time > 0) {
  999. $item->online = floor($time / 86400);
  1000. }
  1001. }
  1002. if (!empty($value->expected_date) && !empty($value->complete_date)) {
  1003. if ($value->complete_date > $value->expected_date) {
  1004. $item->online = floor((strtotime($value->complete_date) - strtotime($value->expected_date)) / 86400);
  1005. } else {
  1006. $item->online = '';
  1007. }
  1008. }
  1009. if (!empty($value->extension)) {
  1010. $result = explode(',', $value->extension);
  1011. $onlineMemo = [];
  1012. foreach ($result as $index) {
  1013. $onlineMemo[] = self::CAUSE[$index] ?? '';
  1014. }
  1015. $item->onlineMemo = implode(',', $onlineMemo);
  1016. }
  1017. if (!empty($value->complete_date)) {
  1018. $time = strtotime($value->complete_date) - strtotime($value->expected_date);
  1019. if ($time > 0) {
  1020. $item->onlineComplete = floor($time / 86400);
  1021. }
  1022. }
  1023. }
  1024. }
  1025. //冒泡
  1026. public function maoPao($a)
  1027. {
  1028. for ($i = 0; $i < count($a); $i++) {
  1029. for ($j = $i + 1; $j < count($a); $j++) {
  1030. if ($a[$i] > $a[$j]) {
  1031. $tem = $a[$i]; // 这里临时变量,存贮$i的值
  1032. $a[$i] = $a[$j]; // 第一次更换位置
  1033. $a[$j] = $tem; // 完成位置互换
  1034. }
  1035. }
  1036. }
  1037. return $a;
  1038. }
  1039. //策划师进度导出
  1040. public function plannerScheduleExport(Request $request)
  1041. {
  1042. $user = auth()->user();
  1043. $list = Site::query()->with(['projectProgressPlanner', 'users']);
  1044. $list = $this->getAuthBySiteId($request, $list, $user)->whereIn('status', [1, 4])->get();
  1045. $siteProcess = SiteProcess::query()
  1046. ->whereNotNull('deploy')
  1047. ->where('process_id', 7)->where('active', 2)
  1048. ->pluck('deploy', 'site_id')->toArray() ?? [];
  1049. $siteProcessList = [];
  1050. foreach ($siteProcess as $key => $process) {
  1051. $siteProcessList[$key] = $process['domain'];
  1052. }
  1053. $result = [];
  1054. foreach ($list as $key => $item) {
  1055. $ae = $item->users->where('role_id', Role::TYPE_AE)->first()->nickname ?? '';
  1056. $data = [
  1057. 'id' => ++$key,
  1058. 'cn_title' => $item->cn_title . '-' . $ae,
  1059. 'url' => $siteProcessList[$item->id] ?? '',
  1060. 'memo' => $item->projectProgressPlanner->memo ?? '',
  1061. 'nickname' => $item->users->where('role_id', Role::TYPE_PLANNER)->first()->nickname ?? '',
  1062. 'is_keywords' => $item->projectProgressPlanner->is_keywords ?? 0,
  1063. 'is_keywords_map' => $item->projectProgressPlanner->is_keywords_map ?? 0,
  1064. 'is_tdk' => $item->projectProgressPlanner->is_tdk ?? 0,
  1065. 'is_keywords_implantation' => $item->projectProgressPlanner->is_keywords_implantation ?? 0,
  1066. 'is_home_planning' => $item->projectProgressPlanner->is_home_planning ?? 0,
  1067. 'is_product_guidance_document' => $item->projectProgressPlanner->is_product_guidance_document ?? 0,
  1068. 'is_inside_page_planning' => $item->projectProgressPlanner->is_inside_page_planning ?? 0,
  1069. 'is_special_page_planning' => $item->projectProgressPlanner->is_special_page_planning ?? 0,
  1070. 'rank' => $item->projectProgressPlanner->rank ?? 0,
  1071. ];
  1072. $result[] = $data;
  1073. }
  1074. $result = $this->arraySort($result, 'rank', 'desc');
  1075. $result = array_merge($result);
  1076. foreach ($result as $key => $value) {
  1077. unset($result[$key]['rank']);
  1078. $result[$key]['id'] = $key + 1;
  1079. }
  1080. array_unshift($result, ['序号', '项目及采编', '测试站网址', '备注', '策划师', '关键词初选', '关键词地图', 'TDK', '关键词植入', '首页策划', '产品指导交流', '内页策划', '特殊页策划']);
  1081. array_unshift($result, ['项目配置', '', '', '', '', '关键词工作', '', '', '页面策划', '', '', '', '']);
  1082. array_unshift($result, ['策划师核心工作:关键词(关键词初选,关键词地图,关键词植入,TDK)+页面策划(首页策划,内页策划,软文策划)+产品指导文档' . "\n" . '注:个人邮箱发送常用文件;关键词地图定稿公共邮箱发送;提前安排关键词地图;日期加打钩']);
  1083. return (new PlannerScheduleExport($result))->download(sprintf('策划师进度%s.xls', date('YmdHis')));
  1084. }
  1085. //采编进度导出(废弃不用)
  1086. public function editingScheduleExport(Request $request)
  1087. {
  1088. $user = auth()->user();
  1089. $list = Site::query()->with(['projectProgressEditing', 'users']);
  1090. $list = $this->getAuthBySiteId($request, $list, $user)->whereIn('status', [1, 4])->get();
  1091. $result = [];
  1092. foreach ($list as $key => $item) {
  1093. $ae = $item->users->where('role_id', Role::TYPE_AE)->first()->nickname ?? '';
  1094. $result[] = [
  1095. 'id' => ++$key,
  1096. 'cn_title' => $item->cn_title ?? '',
  1097. 'domain' => $item->domain ?? '',
  1098. 'memo' => $item->projectProgressEditing->memo ?? '',
  1099. 'nickname' => $ae,
  1100. 'is_backstage' => $item->projectProgressEditing->is_backstage ?? 0,
  1101. 'is_first_mail' => $item->projectProgressEditing->is_first_mail ?? 0,
  1102. 'is_data' => $item->projectProgressEditing->is_data ?? 0,
  1103. 'is_folder' => $item->projectProgressEditing->is_folder ?? 0,
  1104. 'is_order_index' => $item->projectProgressEditing->is_order_index ?? 0,
  1105. 'is_product_index' => $item->projectProgressEditing->is_product_index ?? 0,
  1106. 'is_test_station' => $item->projectProgressEditing->is_test_station ?? 0,
  1107. 'is_opinion' => $item->projectProgressEditing->is_opinion ?? 0,
  1108. 'is_project_group' => $item->projectProgressEditing->is_project_group ?? 0,
  1109. 'is_client_feedback' => $item->projectProgressEditing->is_client_feedback ?? 0,
  1110. 'is_online_inspection_form' => $item->projectProgressEditing->is_online_inspection_form ?? 0,
  1111. 'is_in_group_inspection' => $item->projectProgressEditing->is_in_group_inspection ?? 0,
  1112. 'is_quality_inspection_departments' => $item->projectProgressEditing->is_quality_inspection_departments ?? 0,
  1113. 'is_optimization' => $item->projectProgressEditing->is_optimization ?? 0,
  1114. 'rank' => $item->projectProgressPlanner->rank ?? 0,
  1115. ];
  1116. }
  1117. $result = $this->arraySort($result, 'rank', 'desc');
  1118. $result = array_merge($result);
  1119. foreach ($result as $key => $value) {
  1120. unset($result[$key]['rank']);
  1121. $result[$key]['id'] = $key + 1;
  1122. }
  1123. array_unshift($result, ['序号', '项目', '网址', '备注', '采编', '后台搭建', '第一封邮件', '资料进度表', '共享盘文件夹整理', '单页面提供完整', '产品页面提供完整', '测试站检查表', '组内意见', '项目部群', '客户反馈', '上线检查表格', '组内检查', '质检部', 'Hina&优化师检查']);
  1124. array_unshift($result, ['项目配置', '', '', '', '', '建站前期', '', '资料', '', '', '', '测试站', '', '', '', '上线', '', '', '']);
  1125. array_unshift($result, ['采编核心工作:资料(资料进度表,共享盘文件夹) + 测试站(测试站检查表格,组内意见,项目部群,客户反馈) + 上线(上线检查表格,组内检查,组间互查,杜佳检查,Hina检查)注:资料要求客户邮件发送,及时查收;网站检查表格(放在共享盘);客户催促上线及时告知项目经理和采编']);
  1126. return (new EditingScheduleExport($result))->download(sprintf('采编进度 %s.xls', date('YmdHis')));
  1127. }
  1128. //项目进度导出(废弃不用)
  1129. public function progressRateExport(Request $request)
  1130. {
  1131. list($list, $user) = $this->progressRateBuild($request, 1);
  1132. $result = [];
  1133. foreach ($list as $key => $value) {
  1134. if ($value['sort'] == 1) {
  1135. $type = '上线阶段';
  1136. } elseif ($value['sort'] == 2) {
  1137. $type = '测试站阶段';
  1138. } elseif ($value['sort'] == 3) {
  1139. $type = '设计阶段策划师跟进';
  1140. } elseif ($value['sort'] == 4) {
  1141. $type = '架构阶段';
  1142. } elseif ($value['sort'] == 5) {
  1143. $type = '暂停项目';
  1144. } else {
  1145. $type = '请选择阶段';
  1146. }
  1147. $result[] = [
  1148. 'id' => ++$key,
  1149. 'cn_title' => $value['cn_title'],
  1150. 'sort' => $type,
  1151. 'project_manager' => $value['project_manager'],
  1152. 'planner' => $value['planner'],
  1153. 'editing' => $value['editing'],
  1154. 'memo' => $value['memo'],
  1155. 'info' => $value['info'],
  1156. 'prophase' => $value['prophase'],
  1157. 'data' => $value['data'],
  1158. 'test' => $value['test'],
  1159. 'online' => $value['online'],
  1160. 'is_keywords' => $value['is_keywords'],
  1161. 'is_keywords_map' => $value['is_keywords_map'],
  1162. 'is_tdk' => $value['is_tdk'],
  1163. 'page_planning' => $value['page_planning'],
  1164. 'rank' => $value['rank'],
  1165. 'domain' => $value['domain'],
  1166. ];
  1167. }
  1168. foreach ($result as $key => $value) {
  1169. unset($result[$key]['rank']);
  1170. $result[$key]['id'] = $key + 1;
  1171. }
  1172. array_unshift($result, ['序号', '项目', '阶级', '项目经理', '策划师', '采编', '备注', '架构&确定域名', '建站前期', '资料', '测试站', '上线', '关键词初选', '关键词地图', 'TDK', '页面策划']);
  1173. array_unshift($result, ['项目配置', '', '', '', '', '', '', '', '采编进度', '', '', '', '策划师进度', '', '', '']);
  1174. array_unshift($result, ['项目总进度']);
  1175. return (new ProgressRateExport($result))->download(sprintf('项目总进度 %s.xls', date('YmdHis')));
  1176. }
  1177. //项目进度导出(废弃不用)
  1178. public function bqProgressRateExport(Request $request)
  1179. {
  1180. list($list, $userAuth) = $this->bqProgressRateBuild($request);
  1181. $result = [];
  1182. foreach ($list as $key => $value) {
  1183. $result[] = [
  1184. 'id' => ++$key,
  1185. 'cn_title' => $value['cn_title'],
  1186. 'optimization' => $value['optimization'],
  1187. 'memo' => $value['memo'],
  1188. 'bq_at' => $value['bq_at'],
  1189. 'bq_meeting' => $value['bq_meeting'],
  1190. 'home_page_adjustment' => $value['home_page_adjustment'],
  1191. 'product_series_page_adjustment' => $value['product_series_page_adjustment'],
  1192. 'other_page_adjustments' => $value['other_page_adjustments'],
  1193. 'code_adjustment' => $value['code_adjustment'],
  1194. 'web_page_adjustment' => $value['web_page_adjustment'],
  1195. 'website_seo_quality_inspection' => $value['website_seo_quality_inspection'],
  1196. 'small_language_station' => $value['small_language_station'],
  1197. 'rank' => $value['rank'],
  1198. ];
  1199. }
  1200. foreach ($result as $key => $value) {
  1201. unset($result[$key]['rank']);
  1202. $result[$key]['id'] = $key + 1;
  1203. }
  1204. array_unshift($result, ['序号', '项目', '优化师', '备注', '百千约访时间', '百千会议', '首页调整', '产品系列页面调整', '其他页面调整', '代码调整', '网页调整', '网站SEO质检', '小语言站']);
  1205. array_unshift($result, ['百千项目总进度']);
  1206. return (new BqProgressRateExport($result))->download(sprintf('百千项目总进度 %s.xls', date('YmdHis')));
  1207. }
  1208. //评分统计
  1209. public function designScore(Request $request)
  1210. {
  1211. $result = $request->all();
  1212. if (!empty($result['list'])) {
  1213. $list = json_decode($result['list'], true);
  1214. try {
  1215. DB::transaction(function () use ($list) {
  1216. $siteIds = [];
  1217. foreach ($list as $key => $value) {
  1218. $siteIds[] = $value['site_id'];
  1219. }
  1220. ScoreSummary::query()->whereIn('site_id', $siteIds)->delete();
  1221. ScoreSummary::query()->insert($list);
  1222. });
  1223. } catch (\Throwable $exception) {
  1224. return response()->json(['message' => $exception->getMessage()], 400);
  1225. }
  1226. return response()->json(['message' => '操作成功']);
  1227. }
  1228. $user = auth()->user();
  1229. $siteIds = ProjectFlowMemo::query()->groupBy('site_id')->pluck('site_id');
  1230. $siteList = Site::query()->whereIn('id', $siteIds);
  1231. $siteList = $this->getAuthBySiteId($request, $siteList, $user);
  1232. $siteList = $siteList->select('id', 'cn_title', 'order_at', 'online_at')
  1233. ->with(['projectFlowMemo' => function ($query) {
  1234. $query->select('title', 'level', 'status', 'site_id', 'node_date', 'is_client_score', 'client_score');
  1235. }, 'scoreSummary', 'users'])->get();
  1236. $list = [];
  1237. foreach ($siteList as $item) {
  1238. $data = [
  1239. 'site_id' => $item->id,
  1240. 'cn_title' => $item->cn_title,
  1241. 'order_at' => $item->order_at,
  1242. 'online_at' => substr($item->online_at, 0, 10),
  1243. 'rank' => $item->scoreSummary->rank ?? 0,
  1244. 'project_manager' => $item->users->where('role_id', Role::TYPE_MANAGE_HELPER)->first()->nickname ?? '',
  1245. 'project_steward' => $item->users->where('role_id', Role::TYPE_SERVER)->first()->nickname ?? '',
  1246. 'editing' => $item->users->where('role_id', Role::TYPE_AE)->first()->nickname ?? '',
  1247. 'web' => $item->users->where('role_id', Role::TYPE_WEB)->first()->nickname ?? '',
  1248. 'design' => $item->users->where('role_id', Role::TYPE_DESIGNER)->first()->nickname ?? '',
  1249. 'plan' => $item->users->where('role_id', Role::TYPE_PLANNER)->first()->nickname ?? '',
  1250. ];
  1251. foreach ($item->projectFlowMemo as $progress) {
  1252. if ($progress->title == '竞争对手分析') {
  1253. $data['score1'] = $progress->client_score;
  1254. }
  1255. if ($progress->title == '网站架构定稿') {
  1256. $data['score2'] = $progress->client_score;
  1257. }
  1258. if ($progress->title == '首页设计定稿') {
  1259. $data['score3'] = $progress->client_score;
  1260. }
  1261. if ($progress->title == '手机端首页+两张banner设计定稿') {
  1262. $data['score4'] = $progress->client_score;
  1263. }
  1264. if ($progress->title == '产品内页设计定稿') {
  1265. $data['score5'] = $progress->client_score;
  1266. }
  1267. if ($progress->title == 'PC 端测试站客户验收反馈') {
  1268. $data['score6'] = $progress->client_score;
  1269. }
  1270. if ($progress->title == '关键词地图定稿') {
  1271. $data['score7'] = $progress->client_score;
  1272. }
  1273. if ($progress->title == '上线确认进入实施期') {
  1274. $data['score8'] = $progress->client_score;
  1275. }
  1276. }
  1277. $list[] = $data;
  1278. }
  1279. $siteList = $this->arraySort($list, 'rank', 'desc');
  1280. $siteList = array_merge($siteList);
  1281. return view('admin.flow.design_score', [
  1282. 'siteList' => $siteList,
  1283. 'request' => $request,
  1284. 'projectManager' => User::query()->where('status', 1)->where('role_id', Role::TYPE_MANAGE_HELPER)->pluck('nickname', 'id'),
  1285. 'planner' => User::query()->where('status', 1)->where('role_id', Role::TYPE_PLANNER)->pluck('nickname', 'id'),
  1286. 'editors' => User::query()->where('status', 1)->where('role_id', Role::TYPE_AE)->pluck('nickname', 'id'),
  1287. 'designer' => User::query()->where('status', 1)->where('role_id', Role::TYPE_DESIGNER)->pluck('nickname', 'id'),
  1288. 'web' => User::query()->where('status', 1)->where('role_id', Role::TYPE_WEB)->pluck('nickname', 'id'),
  1289. 'projectSteward' => User::query()->where('status', 1)->where('role_id', Role::TYPE_SERVER)->pluck('nickname', 'id'),
  1290. ]);
  1291. }
  1292. /**
  1293. * 建站流程表&&保存
  1294. * @param Request $request
  1295. * @param $siteId
  1296. * @param int $type 0全部,1局部
  1297. * @return Factory|View
  1298. */
  1299. public function siteConstructionProcess(Request $request, $siteId, $type = 0)
  1300. {
  1301. $user = auth()->user();
  1302. if ($user->role_id == 5) {
  1303. return redirect('/wap/site-flow/0');
  1304. /*return view('admin/site/not_found', [
  1305. 'tips' => '暂无权限,请登陆后台查看',
  1306. 'siteId' => $siteId,
  1307. ]);*/
  1308. }
  1309. $siteInfo = Site::query()->where('id', $siteId)->first();
  1310. if (empty($siteInfo)) {
  1311. return view('admin/site/not_found', [
  1312. 'tips' => '暂无项目',
  1313. 'siteId' => $siteId,
  1314. ]);
  1315. }
  1316. if (empty($siteInfo->task_at)) {
  1317. return view('admin/site/not_found', [
  1318. 'tips' => '项目任务起始时间未设置,初始化失败',
  1319. 'siteId' => $siteId,
  1320. ]);
  1321. }
  1322. $siteByUserList = Site::query()->where('id', $siteId)->with(['users'])->first();
  1323. $pm = $siteByUserList->users->where('role_id', Role::TYPE_MANAGE_HELPER)->first();
  1324. if (empty($pm)) {
  1325. return view('admin/site/not_found', [
  1326. 'tips' => '该项目没有分配项目经理,初始化失败',
  1327. 'siteId' => $siteId,
  1328. ]);
  1329. }
  1330. $server = $siteByUserList->users->where('role_id', Role::TYPE_SERVER)->first();
  1331. if (empty($server)) {
  1332. return view('admin/site/not_found', [
  1333. 'tips' => '该项目没有分配客服人员,初始化失败',
  1334. 'siteId' => $siteId,
  1335. ]);
  1336. }
  1337. $ae = $siteByUserList->users->where('role_id', Role::TYPE_AE)->first();
  1338. if (empty($ae)) {
  1339. return view('admin/site/not_found', [
  1340. 'tips' => '该项目没有分配采编人员,初始化失败',
  1341. 'siteId' => $siteId,
  1342. ]);
  1343. }
  1344. $result = $request->all();
  1345. if (!empty($result)) {
  1346. //保存流程
  1347. $this->saveFlow($result, $siteId);
  1348. }
  1349. //流程初始化
  1350. $siteInfo = $this->iniFlow($siteId, $siteInfo);
  1351. //区别权限
  1352. $flowService = new FlowService();
  1353. [$list, $count, $toBeCompletedCount, $nodeDate,
  1354. $user, $taskLastDateStart, $taskLastDateEnd, $newNodeDate,
  1355. $thisWeekTaskList, $nextWeekTaskList]
  1356. = $flowService->getFlowListByUserId($type, $siteId);
  1357. //测试站
  1358. $deploy = SiteProcess::query()
  1359. ->where('process_id', 7)
  1360. ->where('active', 2)
  1361. ->where('site_id', $siteId)
  1362. ->whereNotNull('deploy')->value('deploy');
  1363. return view('admin.flow.site_construction_process', [
  1364. 'count' => $count,
  1365. 'toBeCompletedCount' => $toBeCompletedCount,
  1366. 'list' => $list,
  1367. 'siteInfo' => $siteInfo,
  1368. 'siteName' => $this->substrFormat($siteInfo->cn_title, 4),
  1369. 'roles' => $user,
  1370. 'siteId' => $siteId,
  1371. 'reasonsForOverdueList' => ProjectFlowMemo::REASONS_FOR_OVERDUE_LIST,
  1372. 'scoreList' => ProjectFlowMemo::SCORE,
  1373. 'date' => date('Y-m-d H:i:s'),
  1374. 'nodeDate' => $nodeDate ?? '',
  1375. 'taskLastDateStart' => $taskLastDateStart,
  1376. 'taskLastDateEnd' => $taskLastDateEnd,
  1377. 'type' => $type,
  1378. 'newNodeDate' => $newNodeDate,
  1379. 'thisWeekTaskList' => $thisWeekTaskList,//这周任务规划
  1380. 'nextWeekTaskList' => $nextWeekTaskList,//下周任务规划
  1381. 'domain' => $deploy['domain'] ?? '',
  1382. ]);
  1383. }
  1384. //初始化流程
  1385. private function iniFlow($siteId, $siteInfo)
  1386. {
  1387. $result = ProjectFlowMemo::query()->where('site_id', $siteId)->first();
  1388. if (empty($result)) {
  1389. $data = [];
  1390. $list = DB::table('project_flow_memo_tpl')->get();
  1391. $days = 120;
  1392. $dayList = [];
  1393. for ($i = 1; $i <= $days; $i++) {
  1394. $day = date('Y-m-d', strtotime($siteInfo->task_at) + 86400 * $i);
  1395. $result = $this->isWeekend($day);
  1396. if (!$result) {
  1397. $dayList[] = $day;
  1398. }
  1399. }
  1400. foreach ($list as $value) {
  1401. $data[] = [
  1402. 'site_id' => $siteId,
  1403. 'status' => $value->status,
  1404. 'title' => $value->title,
  1405. 'level' => $value->level,
  1406. 'rank' => $value->rank,
  1407. 'memo' => $value->memo,
  1408. 'roles' => $value->roles,
  1409. 'acceptance' => $value->acceptance,
  1410. 'file' => $value->file,
  1411. 'file_path' => $value->file_path,
  1412. 'client_file' => $value->client_file,
  1413. 'client_file_path' => $value->client_file_path,
  1414. 'master_plate_path' => $value->master_plate_path,
  1415. 'file_list' => $value->file_list ?? null,
  1416. 'node_date' => $dayList[$value->day - 1],
  1417. 'node' => $value->node,
  1418. 'day' => $value->day,
  1419. 'overdue_day' => $value->overdue_day,
  1420. 'reasons_for_overdue' => $value->reasons_for_overdue,
  1421. 'overdue_memo' => $value->overdue_memo,
  1422. 'client_score' => $value->client_score,
  1423. 'is_client_score' => $value->is_client_score,
  1424. 'inspection_score' => $value->inspection_score,
  1425. 'is_inspection_score' => $value->is_inspection_score,
  1426. 'inspection' => 0,
  1427. 'color' => $value->color,
  1428. 'updated_at' => date('Y-m-d'),
  1429. ];
  1430. }
  1431. ProjectFlowMemo::query()->insert($data);
  1432. $userList = [];
  1433. $siteInfo = Site::query()->where('id', $siteId)->with(['users'])->first();
  1434. foreach ($siteInfo->users as $user) {
  1435. $userList[$user->role_id] = $user->id;
  1436. }
  1437. $flow = ProjectFlowMemo::query()->where('site_id', $siteId)->get();
  1438. $list = [];
  1439. foreach ($flow as $item) {
  1440. $rolesList = explode(',', $item->roles);
  1441. foreach ($rolesList as $roles) {
  1442. if ($roles != 5) {
  1443. $list[] = [
  1444. 'roles_id' => $roles,
  1445. 'memo_id' => $item->id,
  1446. ];
  1447. }
  1448. }
  1449. }
  1450. foreach ($list as $key => $item) {
  1451. $list[$key]['user_id'] = $userList[$item['roles_id']] ?? 0;
  1452. }
  1453. foreach ($list as $key => $item) {
  1454. if (empty($item['user_id'])) {
  1455. unset($list[$key]);
  1456. }
  1457. }
  1458. ProjectFlowMemoRelation::query()->insert($list);
  1459. }
  1460. return $siteInfo;
  1461. }
  1462. //保存流程
  1463. public function saveFlow($result, $siteId)
  1464. {
  1465. $data = [];
  1466. $user = [];
  1467. $ids = ProjectFlowMemo::query()->where('site_id', $siteId)->pluck('id') ?? 0;
  1468. foreach ($result as $key => $item) {
  1469. //拆分表单提交过来的字段
  1470. $filed = explode('-', $key);
  1471. if (!empty($filed[2])) {
  1472. foreach ($ids as $id) {
  1473. if ($filed[0] == $id && $filed[1]) {
  1474. $user[$filed[0]][] = [
  1475. $filed[1] => $item,
  1476. 'roles_id' => $filed[2],
  1477. 'memo_id' => $filed[0],
  1478. ];
  1479. }
  1480. }
  1481. } else {
  1482. foreach ($ids as $id) {
  1483. if ($filed[0] == $id && $filed[1]) {
  1484. $data[$filed[0]][] = [
  1485. $filed[1] => $item,
  1486. ];
  1487. }
  1488. }
  1489. }
  1490. }
  1491. $userList = [];
  1492. foreach ($user as $key => $item) {
  1493. foreach ($item as $value) {
  1494. $userList[] = $value;
  1495. }
  1496. }
  1497. $userResult = [];
  1498. $workingHoursResult = [];
  1499. //工时
  1500. foreach ($userList as $value) {
  1501. if (!empty($value['user_id'])) {
  1502. $userResult[] = $value;
  1503. }
  1504. if (!empty($value['working_hours'])) {
  1505. $workingHoursResult[] = $value;
  1506. }
  1507. }
  1508. foreach ($userResult as $key => $value) {
  1509. foreach ($workingHoursResult as $vv) {
  1510. if ($value['memo_id'] == $vv['memo_id'] && $value['roles_id'] == $vv['roles_id']) {
  1511. $userResult[$key]['working_hours'] = $vv['working_hours'] ?? '';
  1512. }
  1513. }
  1514. }
  1515. try {
  1516. DB::transaction(function () use ($userResult) {
  1517. $memoIds = array_unique(array_column($userResult, 'memo_id'));
  1518. ProjectFlowMemoRelation::query()->whereIn('memo_id', $memoIds)->delete();
  1519. foreach ($userResult as $value) {
  1520. ProjectFlowMemoRelation::query()->insert($value);
  1521. }
  1522. });
  1523. } catch (\Throwable $exception) {
  1524. return response()->json(['message' => $exception->getMessage()], 400);
  1525. }
  1526. $list = [];
  1527. foreach ($data as $key => $item) {
  1528. if (!empty($item[1]['id'])) {
  1529. $reasonsForOverdue = $item[3]['reasons_for_overdue'] ?? 0;
  1530. $inspectionScore = $item[3]['inspection_score'] ?? $item[4]['inspection_score'] ?? 0;
  1531. $overdueMemo = $item[3]['overdue_memo'] ?? $item[4]['overdue_memo'] ?? $item[5]['overdue_memo'] ?? '';
  1532. $planningWeek = $item[4]['planning_week'] ?? $item[5]['planning_week'] ?? $item[6]['planning_week'] ?? '';
  1533. $planningNextWeek = $item[4]['planning_next_week'] ?? $item[5]['planning_next_week'] ?? $item[6]['planning_next_week'] ?? '';
  1534. $update = [
  1535. 'id' => $item[1]['id'],
  1536. 'status' => $item[0]['status'] ?? 0,
  1537. 'memo' => $item[2]['memo'] ?? 0,
  1538. ];
  1539. if (!empty($reasonsForOverdue)) {
  1540. $update['reasons_for_overdue'] = $reasonsForOverdue;
  1541. }
  1542. if (!empty($inspectionScore)) {
  1543. $update['inspection_score'] = $inspectionScore;
  1544. }
  1545. if (!empty($overdueMemo)) {
  1546. $update['overdue_memo'] = $overdueMemo;
  1547. }
  1548. if (!empty($planningWeek)) {
  1549. $update['planning_week'] = $planningWeek;
  1550. }
  1551. if (!empty($planningNextWeek)) {
  1552. $update['planning_next_week'] = $planningNextWeek;
  1553. }
  1554. $list[] = $update;
  1555. }
  1556. }
  1557. if (!empty($list)) {
  1558. foreach ($list as $value) {
  1559. if (!empty($value['overdue_memo']) && mb_strlen($value['overdue_memo'], 'utf8') > 100) {
  1560. die('备注请保持在100字以内');
  1561. }
  1562. }
  1563. foreach ($list as $value) {
  1564. ProjectFlowMemo::query()->where('id', $value['id'])->update($value);
  1565. }
  1566. }
  1567. }
  1568. //流程上传资料(废弃不用 改oss)
  1569. public function uploadSiteFile(Request $request)
  1570. {
  1571. $file = $request->file('file');
  1572. if (empty($file)) {
  1573. return response()->json(['message' => '请上传文件'], 400);
  1574. }
  1575. $fileName = date('Y-m-d_His') . $file->getClientOriginalName();
  1576. $fileData['file_url'] = $file->storeAs(date('Y-m') . '/' . $file->getClientOriginalExtension(), $fileName, 'public');
  1577. $fileData['file_url'] = asset('storage/' . $fileData['file_url']);
  1578. $fileData['original_name'] = $file->getClientOriginalName();
  1579. $fileData['time'] = time();
  1580. return response()->json(['message' => '上传成功', 'data' => $fileData]);
  1581. }
  1582. //流程资料下载(废弃 不用 改oss)
  1583. public function downloadSiteFile($taskId, $type = 0)
  1584. {
  1585. $info = DB::table('project_flow_memo')
  1586. ->where('id', $taskId)
  1587. ->first();
  1588. $user = auth()->user();
  1589. if ($user->role_id == 5) {
  1590. if ($type == 1) {
  1591. $path = $info->master_plate_path;
  1592. } else {
  1593. $path = $info->client_file_path;
  1594. }
  1595. } else {
  1596. $path = $info->file_path;
  1597. }
  1598. if (empty($path)) {
  1599. die('暂无文件');
  1600. }
  1601. $pathInfo = pathinfo($path);
  1602. $dirnamePath = explode('storage', $pathInfo['dirname']);
  1603. return response()->download(realpath(base_path('public')) . '/storage' . $dirnamePath[1] . '/' . $pathInfo['basename'], $pathInfo['basename']);
  1604. }
  1605. private function substrFormat($text, $length, $replace = '...', $encoding = 'UTF-8')
  1606. {
  1607. if ($text && mb_strlen($text, $encoding) > $length) {
  1608. return mb_substr($text, 0, $length, $encoding) . $replace;
  1609. }
  1610. return $text;
  1611. }
  1612. //建站2.0进度逾期统计
  1613. public function stationConstructionOverdue(Request $request)
  1614. {
  1615. if (!$request->ajax()) {
  1616. $userList = User::query()->where('status', 1)->get();
  1617. return view('admin.flow.station_construction_overdue', [
  1618. 'userList' => $userList,
  1619. ]);
  1620. }
  1621. $list = $this->stationConstructionOverdueBuild($request, ProjectFlowMemo::query());
  1622. return response()->json([
  1623. 'rows' => $list->items(),
  1624. 'total' => $list->total()
  1625. ]);
  1626. }
  1627. public function stationConstructionOverdueExport(Request $request)
  1628. {
  1629. $projectFlowMemo = ProjectFlowMemo::query();
  1630. $list = $this->stationConstructionOverdueBuild($request, $projectFlowMemo, true);
  1631. $data = [];
  1632. foreach ($list as $item) {
  1633. $data[] = [
  1634. 'title' => $item->title ?? '',
  1635. 'rank' => $item->rank ?? '',
  1636. 'node_date' => $item->node_date ?? '',
  1637. 'user' => $item->user ?? '',
  1638. 'overdue_day' => $item->overdue_day ?? '',
  1639. 'cn_title' => $item->cn_title ?? '',
  1640. 'order_at' => $item->order_at ?? '',
  1641. ];
  1642. }
  1643. array_unshift($data, ['逾期事项', '阶段', '任务截止时间', '逾期阶段负责人', '逾期天数', '关联项目', '下单时间']);
  1644. return (new BasicExport($data))->download(sprintf('建站流程逾期列表%s.xls', date('YmdHis')));
  1645. }
  1646. /**
  1647. * 建站2.0进度逾期统计
  1648. * @param $request object
  1649. * @param $projectFlowMemo object
  1650. * @param bool $isExport
  1651. * @param bool $isAll
  1652. * @return mixed
  1653. */
  1654. private function stationConstructionOverdueBuild($request, $projectFlowMemo, $isExport = false, $isAll = false)
  1655. {
  1656. $role = auth()->user();
  1657. if ($role->is_super != 1 || !in_array($role->role_id, [Role::TYPE_MANAGE_LEADER, Role::TYPE_DESIGN_DIRECTOR, Role::TYPE_HR])) {
  1658. $memoIdList = ProjectFlowMemoRelation::query()->where('user_id', $role->id)->pluck('memo_id');
  1659. $projectFlowMemo->whereIn('id', $memoIdList ?? []);
  1660. }
  1661. $request = $request->all();
  1662. if (!empty($request['projectManagerId'])) {
  1663. $memoIds = ProjectFlowMemoRelation::query()->where('user_id', $request['projectManagerId'])->pluck('memo_id');
  1664. $projectFlowMemo->whereIn('id', $memoIds ?? []);
  1665. }
  1666. if (!empty($request['serverId'])) {
  1667. $memoIds = ProjectFlowMemoRelation::query()->where('user_id', $request['serverId'])->pluck('memo_id');
  1668. $projectFlowMemo->whereIn('id', $memoIds ?? []);
  1669. }
  1670. if (!empty($request['sellerId'])) {
  1671. $memoIds = ProjectFlowMemoRelation::query()->where('user_id', $request['sellerId'])->pluck('memo_id');
  1672. $projectFlowMemo->whereIn('id', $memoIds ?? []);
  1673. }
  1674. if (!empty($request['editingId'])) {
  1675. $memoIds = ProjectFlowMemoRelation::query()->where('user_id', $request['editingId'])->pluck('memo_id');
  1676. $projectFlowMemo->whereIn('id', $memoIds ?? []);
  1677. }
  1678. $task = $request['task'];
  1679. if (!empty($task)) {
  1680. $projectFlowMemo->where('title', 'like', '%' . $task . '%');
  1681. }
  1682. $projectFlowMemo->with(['sites', 'projectFlowMemoRelation'])->where('status', '=', 0);
  1683. if (!$isAll) {
  1684. $projectFlowMemo->where('node_date', '<', date('Y-m-d'));
  1685. }
  1686. if ($isExport) {
  1687. $list = $projectFlowMemo->get();
  1688. } else {
  1689. $list = $projectFlowMemo->paginate($request['pageSize'] ?? 10);
  1690. }
  1691. $userList = User::query()->where('status', 1)->pluck('nickname', 'id')->toArray();
  1692. foreach ($list as $item) {
  1693. $users = [];
  1694. $item->cn_title = $item->sites->cn_title ?? '';
  1695. $item->order_at = '';
  1696. $item->online_at = '';
  1697. if (!empty($item->sites->order_at)) {
  1698. $item->order_at = date('Y-m-d', strtotime($item->sites->order_at));
  1699. }
  1700. if (!empty($item->sites->online_at)) {
  1701. $item->online_at = date('Y-m-d', strtotime($item->sites->online_at));
  1702. }
  1703. foreach ($item->projectFlowMemoRelation as $user) {
  1704. $users[] = $userList[$user->user_id] ?? '';
  1705. }
  1706. $item->user = implode(',', $users);
  1707. if (strtotime($item->node_date) < strtotime(date('Y-m-d'))) {
  1708. $item->overdue_day = (strtotime(date('Y-m-d')) - strtotime($item->node_date)) / 3600 / 24 . '天';
  1709. } else {
  1710. $item->overdue_day = '';
  1711. }
  1712. if ($item->reasons_for_overdue == 0) {
  1713. $item->reasons_for_overdue = '';
  1714. } else {
  1715. $item->reasons_for_overdue = ProjectFlowMemo::REASONS_FOR_OVERDUE_LIST[$item->reasons_for_overdue] ?? '';
  1716. }
  1717. }
  1718. return $list;
  1719. }
  1720. //个人任务
  1721. public function personalTasks(Request $request)
  1722. {
  1723. if (!$request->ajax()) {
  1724. $managerHelpers = User::query()->where('status', 1)->where('role_id', Role::TYPE_MANAGE_HELPER)->get();
  1725. return view('admin.flow.test_remind', [
  1726. 'managerHelpers' => $managerHelpers,
  1727. ]);
  1728. }
  1729. $taskList = $this->stationConstructionOverdueBuild($request, ProjectFlowMemo::query(), false, true);
  1730. return response()->json([
  1731. 'rows' => $taskList->items(),
  1732. 'total' => $taskList->total()
  1733. ]);
  1734. }
  1735. //个人邮箱
  1736. public function mailbox(Request $request)
  1737. {
  1738. if (!$request->ajax()) {
  1739. return view('admin.flow.mailbox', [
  1740. ]);
  1741. }
  1742. $message = $request->input('message');
  1743. $user = auth()->user();
  1744. $list = Mailbox::query();
  1745. if (!empty($message)) {
  1746. $list->where('message', 'like', '%' . $message . '%');
  1747. }
  1748. if (!empty($user->is_super != 1)) {
  1749. $list->where('user_id', $user->id);
  1750. }
  1751. $userList = User::query()->where('status', 1)->pluck('nickname', 'id');
  1752. $list = $list->orderByDesc('id')->paginate($request->input('pageSize'));
  1753. foreach ($list as $item) {
  1754. $item->user = $userList[$item->user_id] ?? '';
  1755. $item->read = '未读';
  1756. if ($item->is_read == 1) {
  1757. $item->read = '已读';
  1758. }
  1759. }
  1760. return response()->json([
  1761. 'rows' => $list->items(),
  1762. 'total' => $list->total()
  1763. ]);
  1764. }
  1765. public function getMailboxStatus()
  1766. {
  1767. $user = auth()->user();
  1768. $mailbox = Mailbox::query();
  1769. $mailbox1 = Mailbox::query();
  1770. if (!empty($user->is_super != 1)) {
  1771. $mailbox->where('user_id', $user->id);
  1772. $mailbox1->where('user_id', $user->id);
  1773. }
  1774. $count = $mailbox->where('is_read', 0)->count() ?? 0;
  1775. $message = $mailbox1->where('is_read', 0)->orderByDesc('id')->value('message') ?? '';
  1776. return response()->json([
  1777. 'count' => $count,
  1778. 'message' => $message
  1779. ]);
  1780. }
  1781. public function batchRead()
  1782. {
  1783. $user = auth()->user();
  1784. if ($user->is_super == 1) {
  1785. return response()->json(['message' => '管理员不允许批量操作'], 400);
  1786. } else {
  1787. Mailbox::query()->where('user_id', $user->id)->update(['is_read' => 1]);
  1788. return response()->json(['message' => '操作成功']);
  1789. }
  1790. }
  1791. public function buildFlow(Request $request)
  1792. {
  1793. $result = $request->all();
  1794. if (!empty($result['list'])) {
  1795. $list = json_decode($result['list'], true);
  1796. try {
  1797. DB::transaction(function () use ($list) {
  1798. $siteIds = [];
  1799. foreach ($list as $key => $value) {
  1800. $siteIds[] = $value['site_id'];
  1801. }
  1802. ProcessProgress::query()->whereIn('site_id', $siteIds)->delete();
  1803. ProcessProgress::query()->insert($list);
  1804. });
  1805. } catch (\Throwable $exception) {
  1806. return response()->json(['message' => $exception->getMessage()], 400);
  1807. }
  1808. return response()->json(['message' => '操作成功']);
  1809. }
  1810. $user = auth()->user();
  1811. $sites = Site::query();
  1812. if (empty($result['status']) || $result['status'] == 1) {
  1813. $sites->where('status', 1);
  1814. } else {
  1815. $sites->where('status', '!=', 1);
  1816. }
  1817. $siteIds = ProjectFlowMemo::query()->groupBy('site_id')->pluck('site_id');
  1818. $siteList = $sites->whereIn('id', $siteIds)
  1819. ->select('id', 'cn_title', 'order_at')
  1820. ->with(['projectFlowMemo' => function ($query) {
  1821. $query->select('level', 'status', 'site_id', 'node_date');
  1822. }, 'processProgress']);
  1823. $flowService = new FlowService();
  1824. $siteList = $flowService->getFlowListBySiteId($this->getAuthBySiteId($request, $siteList, $user)->get()->toArray());
  1825. $sort = 'rank';
  1826. if (!empty($result['lv'])) {
  1827. $sort = $result['lv'];
  1828. }
  1829. $siteList = $this->arraySort($siteList, $sort, 'desc');
  1830. $siteList = array_merge($siteList);
  1831. return view('admin.flow.build_flow', [
  1832. 'siteList' => $siteList,
  1833. 'role_id' => $user->role_id,
  1834. 'result' => $result,
  1835. 'userList' => $this->userList,
  1836. ]);
  1837. }
  1838. public function delSitesTaskFlow($siteId)
  1839. {
  1840. DB::transaction(function () use ($siteId) {
  1841. $ids = ProjectFlowMemo::query()->where('site_id', $siteId)->pluck('id');
  1842. ProjectFlowMemoRelation::query()->where('memo_id', $ids)->delete();
  1843. ProjectFlowMemo::query()->where('site_id', $siteId)->delete();
  1844. ProcessProgress::query()->where('site_id', $siteId)->delete();
  1845. });
  1846. return response()->json(['message' => '清除成功']);
  1847. }
  1848. public function resetting(Request $request)
  1849. {
  1850. $siteId = $request->input('siteId');
  1851. $flowIds = ProjectFlowMemo::query()->where('site_id', $siteId)->pluck('id');
  1852. if ($flowIds) {
  1853. ProjectFlowMemo::query()->where('site_id', $siteId)->delete();
  1854. ProjectFlowMemoRelation::query()->whereIn('memo_id', $flowIds)->delete();
  1855. }
  1856. return response()->json(['message' => '重置成功']);
  1857. }
  1858. public function taskResetting(Request $request)
  1859. {
  1860. $taskId = $request->input('taskId');
  1861. $flowInfo = ProjectFlowMemo::query()->where('id', $taskId)->first();
  1862. if ($flowInfo) {
  1863. $memo = [
  1864. 'status' => 0,
  1865. 'overdue_memo' => '',
  1866. 'reasons_for_overdue' => '',
  1867. 'client_score' => 0,
  1868. 'inspection_score' => 0,
  1869. ];
  1870. ProjectFlowMemo::query()->where('id', $taskId)->update($memo);
  1871. $siteInfo = Site::query()->where('id', $flowInfo->site_id)->with(['users'])->first();
  1872. $role = explode(',', $flowInfo->roles);
  1873. $update = [];
  1874. foreach ($role as $item) {
  1875. if ($item != 5) {
  1876. $user = $siteInfo->users->where('role_id', $item)->first();
  1877. $update[] = [
  1878. 'user_id' => $user->id ?? 0,
  1879. 'working_hours' => '',
  1880. 'roles_id' => $user->role_id ?? 0,
  1881. 'memo_id' => $taskId,
  1882. ];
  1883. }
  1884. }
  1885. try {
  1886. DB::transaction(function () use ($update, $taskId) {
  1887. ProjectFlowMemoRelation::query()->where('memo_id', $taskId)->delete();
  1888. ProjectFlowMemoRelation::query()->insert($update);
  1889. });
  1890. return response()->json(['message' => '重置成功']);
  1891. } catch (\Throwable $exception) {
  1892. return response()->json(['message' => $exception->getMessage()], 400);
  1893. }
  1894. }
  1895. }
  1896. public function notFound(Request $request, $siteId)
  1897. {
  1898. if (!$request->ajax()) {
  1899. return view('admin.flow.not_found', [
  1900. 'siteId' => $siteId
  1901. ]);
  1902. }
  1903. $ids = NotFound::get404List($siteId);
  1904. $list = DB::table('site_status')
  1905. ->where('status', 404)
  1906. ->where('site_id', $siteId)
  1907. ->whereIn('id', $ids)
  1908. ->paginate($request->input('pageSize') ?? 10);
  1909. return response()->json([
  1910. 'rows' => $list->items(),
  1911. 'total' => $list->total()
  1912. ]);
  1913. }
  1914. public function isHandle(Request $request, $id)
  1915. {
  1916. $type = $request->input('type');
  1917. DB::table('site_status')->where('id', $id)->update(['is_handle' => $type]);
  1918. return response()->json(['message' => '处理成功']);
  1919. }
  1920. public function isWeekend($date)
  1921. {
  1922. if ((date('w', strtotime($date)) == 6) || (date('w', strtotime($date)) == 0)) {
  1923. return true;
  1924. } else {
  1925. return false;
  1926. }
  1927. }
  1928. public function home()
  1929. {
  1930. $homeService = new HomeService();
  1931. $taskList = $homeService->getTaskList(Role::TYPE_WEB) ?? [];
  1932. $taskList2 = $homeService->getTaskList(Role::TYPE_DESIGNER) ?? [];
  1933. $taskListByWeek = $homeService->getTaskByWeek(Role::TYPE_WEB);
  1934. $taskListByWeek2 = $homeService->getTaskByWeek(Role::TYPE_DESIGNER);
  1935. list($sitesStatusList,
  1936. $thisMonthOnlineSite,
  1937. $ratioOnlineSite,
  1938. $thisMonthOrderSite,
  1939. $ratioOrderSite,
  1940. $thisMonthQualifiedSite,
  1941. $ratioQualifiedSite,
  1942. $thisMonthAssignSite,
  1943. $ratioAssignSite) = $homeService->getProjectOverview();
  1944. $projectStatusList = $homeService->getProjectStatusList(Role::TYPE_WEB);
  1945. $projectStatusList2 = $homeService->getProjectStatusList(Role::TYPE_DESIGNER);
  1946. $monthBySiteList = $homeService->getMonthBySiteList();
  1947. $monthBySiteList2 = $homeService->getMonthBySiteList2();
  1948. $speedMeasurement = $homeService->getSpeedMeasurement();
  1949. $siteListCountByUsers = $homeService->getSiteListByProjectManagers();
  1950. $siteListByOptimizeEditing = $homeService->getSiteListByOptimizeEditing();
  1951. $siteListByProjectHousekeeper = $homeService->getSiteListByProjectHousekeeper();
  1952. $siteRenewListByProjectHousekeeper = $homeService->getSiteRenewListByProjectHousekeeper();
  1953. return view('admin.flow.home', [
  1954. 'sitesStatusList' => $sitesStatusList,
  1955. 'thisMonthOnlineSite' => $thisMonthOnlineSite,
  1956. 'ratioOnlineSite' => $ratioOnlineSite,
  1957. 'thisMonthOrderSite' => $thisMonthOrderSite,
  1958. 'ratioOrderSite' => $ratioOrderSite,
  1959. 'thisMonthQualifiedSite' => $thisMonthQualifiedSite,
  1960. 'ratioQualifiedSite' => $ratioQualifiedSite,
  1961. 'thisMonthAssignSite' => $thisMonthAssignSite,
  1962. 'ratioAssignSite' => $ratioAssignSite,
  1963. 'projectStatusList' => $projectStatusList,
  1964. 'projectStatusList2' => $projectStatusList2,
  1965. 'monthBySiteList' => $monthBySiteList,
  1966. 'monthBySiteList2' => $monthBySiteList2,
  1967. 'speedMeasurement' => $speedMeasurement,
  1968. 'siteListCountByUsers' => $siteListCountByUsers,
  1969. 'siteListByOptimizeEditing' => $siteListByOptimizeEditing,
  1970. 'siteListByProjectHousekeeper' => $siteListByProjectHousekeeper,
  1971. 'siteRenewListByProjectHousekeeper' => $siteRenewListByProjectHousekeeper,
  1972. 'date' => date('Y-m-d'),
  1973. 'user' => auth()->user(),
  1974. 'taskList' => $taskList,
  1975. 'taskList2' => $taskList2,
  1976. 'taskListByWeek' => $taskListByWeek,
  1977. 'taskListByWeek2' => $taskListByWeek2,
  1978. ]);
  1979. }
  1980. public function clientDataUpload(Request $request, $siteId, $type = 0)
  1981. {
  1982. $result = $request->all();
  1983. if (!empty($result)) {
  1984. $this->saveClientData($result);
  1985. return redirect("/admin/flow/clientDataUpload/{$siteId}/1");
  1986. }
  1987. if (!empty($type)) {
  1988. $user = auth()->user();
  1989. $siteIds = DB::table('user_has_sites')->where('user_id', $user->id)->first();
  1990. $siteId = $siteIds->site_id;
  1991. }
  1992. $list = DB::table('client_data_upload')->where('site_id', $siteId)->get();
  1993. $cnTitle = Site::query()->where('id', $siteId)->value('cn_title') ?? '';
  1994. return view('admin.flow.client_data_upload', [
  1995. 'siteId' => $siteId,
  1996. 'cn_title' => $cnTitle,
  1997. 'list' => $list,
  1998. 'token' => time(),
  1999. ]);
  2000. }
  2001. private function saveClientData($result)
  2002. {
  2003. $data = [];
  2004. foreach ($result as $key => $item) {
  2005. $array = explode(':', $key);
  2006. if (!empty($array[1])) {
  2007. foreach ($item as $value) {
  2008. $data[$array[0]][] = $value;
  2009. }
  2010. }
  2011. }
  2012. try {
  2013. DB::transaction(function () use ($data, $result) {
  2014. $user = auth()->user();
  2015. if ($user->role_id == Role::TYPE_CUSTOMER) {
  2016. foreach ($data as $key => $datum) {
  2017. $url = [];
  2018. $urls = DB::table('client_data_upload')
  2019. ->where('id', $key)
  2020. ->where('site_id', $result['siteId'])
  2021. ->value('url');
  2022. if (!empty($urls)) {
  2023. $url = json_decode($urls, true);
  2024. }
  2025. $datum = array_merge($url, $datum);
  2026. DB::table('client_data_upload')
  2027. ->where('id', $key)
  2028. ->where('site_id', $result['siteId'])
  2029. ->update(['url' => json_encode($datum)]);
  2030. }
  2031. } else {
  2032. foreach ($data as $key => $datum) {
  2033. $url = [];
  2034. $urls = DB::table('client_data_upload')
  2035. ->where('id', $key)
  2036. ->where('site_id', $result['siteId'])
  2037. ->value('list');
  2038. if (!empty($urls)) {
  2039. $url = json_decode($urls, true);
  2040. }
  2041. $datum = array_merge($url, $datum);
  2042. DB::table('client_data_upload')
  2043. ->where('id', $key)
  2044. ->where('site_id', $result['siteId'])
  2045. ->update(['list' => json_encode($datum)]);
  2046. }
  2047. }
  2048. });
  2049. } catch (\Throwable $exception) {
  2050. pre_dump($exception->getMessage());
  2051. }
  2052. }
  2053. public function clientData(Request $request, $siteId)
  2054. {
  2055. if (!$request->ajax()) {
  2056. return view('admin.flow.client_data', [
  2057. 'siteId' => $siteId,
  2058. ]);
  2059. }
  2060. $result = DB::table('client_data_upload')
  2061. ->where('site_id', $siteId)
  2062. ->paginate($request->input('pageSize') ?? 10);
  2063. $list = $result->items();
  2064. foreach ($list as $value) {
  2065. $value->data_memo = $this->substrFormat($value->data_memo, 20);
  2066. }
  2067. return response()->json([
  2068. 'rows' => $list,
  2069. 'total' => $result->total()
  2070. ]);
  2071. }
  2072. public function clientAdd(Request $request, $taskId, $siteId)
  2073. {
  2074. if (!$request->ajax()) {
  2075. $result = DB::table('client_data_upload')
  2076. ->where('id', $taskId)
  2077. ->first() ?? [];
  2078. return view('admin.flow.client_data_add', [
  2079. 'siteId' => $siteId,
  2080. 'taskId' => $taskId,
  2081. 'info' => $result,
  2082. ]);
  2083. }
  2084. $request = $request->all();
  2085. $data = [
  2086. 'site_id' => $request['siteId'] ?? 0,
  2087. 'page' => $request['page'] ?? '',
  2088. 'style_path' => $request['style_path'] ?? '',
  2089. 'data_memo' => $request['data_memo'] ?? '',
  2090. 'deadline' => $request['deadline'] ?? date('Y-m-d'),
  2091. ];
  2092. try {
  2093. if (empty($taskId)) {
  2094. $info = DB::table('client_data_upload')->where('id', $taskId)->first();
  2095. if (empty($info)) {
  2096. DB::table('client_data_upload')->insert($data);
  2097. }
  2098. } else {
  2099. DB::table('client_data_upload')->where('id', $taskId)->update($data);
  2100. }
  2101. return response()->json(['message' => 'success']);
  2102. } catch (\Throwable $exception) {
  2103. return response()->json(['message' => $exception->getMessage()], 400);
  2104. }
  2105. }
  2106. public function clientDel(Request $request)
  2107. {
  2108. $request = $request->input('ids');
  2109. try {
  2110. DB::table('client_data_upload')->whereIn('id', $request)->delete();
  2111. return response()->json(['message' => 'success']);
  2112. } catch (\Throwable $exception) {
  2113. return response()->json(['message' => $exception->getMessage()], 400);
  2114. }
  2115. }
  2116. //项目数量关联人员统计汇总
  2117. public function projectPersonnelStatistics(Request $request, $type = 1)
  2118. {
  2119. $roles = [Role::TYPE_AE, Role::TYPE_MANAGE_HELPER];
  2120. if (!$request->ajax()) {
  2121. $role = User::query()->where('status', 1)
  2122. ->whereIn('role_id', $roles)
  2123. ->select('id', 'role_id', 'nickname')
  2124. ->get();
  2125. return view('admin.flow.project_personnel_statistics', [
  2126. 'roles' => $role
  2127. ]);
  2128. }
  2129. $yearStart = date('Y-01-01 00:00:00');
  2130. $yearEnd = date('Y-m-d H:i:s', strtotime('+1 year', strtotime($yearStart)) - 1);
  2131. $role = Role::query()->pluck('name', 'id');
  2132. $user = User::query()->whereIn('role_id', $roles);
  2133. $editingId = $request->input('editingId');
  2134. if (!empty($editingId) && $editingId != -1) {
  2135. $user->where('id', $editingId);
  2136. }
  2137. if ($editingId == -1) {
  2138. $user->where('role_id', Role::TYPE_AE);
  2139. }
  2140. $projectManagerId = $request->input('projectManagerId');
  2141. if (!empty($projectManagerId) && $projectManagerId != -1) {
  2142. $user->where('id', $projectManagerId);
  2143. }
  2144. if ($projectManagerId == -1) {
  2145. $user->where('role_id', Role::TYPE_MANAGE_HELPER);
  2146. }
  2147. $list = $user->where('status', 1)->withCount(
  2148. ['sites' => function (Builder $query) {
  2149. $query->where('status', 1);
  2150. }, 'sites as sites_online' => function (Builder $query) use ($yearStart, $yearEnd) {
  2151. $query->whereBetween('online_at', [$yearStart, $yearEnd]);
  2152. }])->orderBy('role_id', 'desc')
  2153. ->paginate($request->input('pageSize') ?? 50);
  2154. foreach ($list as $item) {
  2155. $item->role = $role[$item->role_id] ?? '';
  2156. }
  2157. return response()->json([
  2158. 'rows' => $list->items(),
  2159. 'total' => $list->total()
  2160. ]);
  2161. }
  2162. public function optimizationPersonnel(Request $request)
  2163. {
  2164. $roles = [Role::TYPE_OPTIMIZATION_EDITING, Role::TYPE_OPTIMIZER];
  2165. if (!$request->ajax()) {
  2166. $role = User::query()->where('status', 1)
  2167. ->whereIn('role_id', $roles)
  2168. ->select('id', 'role_id', 'nickname')
  2169. ->get();
  2170. return view('admin.flow.optimization_personnel', [
  2171. 'roles' => $role
  2172. ]);
  2173. }
  2174. $user = User::query()->whereIn('role_id', $roles);
  2175. $optimizationId = $request->input('optimizationId');
  2176. if (!empty($optimizationId) && $optimizationId != -1) {
  2177. $user->where('id', $optimizationId);
  2178. }
  2179. if ($optimizationId == -1) {
  2180. $user->where('role_id', Role::TYPE_OPTIMIZER);
  2181. }
  2182. $optimizationEditingId = $request->input('optimizationEditingId');
  2183. if (!empty($optimizationEditingId) && $optimizationEditingId != -1) {
  2184. $user->where('id', $optimizationEditingId);
  2185. }
  2186. if ($optimizationEditingId == -1) {
  2187. $user->where('role_id', Role::TYPE_OPTIMIZATION_EDITING);
  2188. }
  2189. $yearStart = date('Y-01-01 00:00:00');
  2190. $yearEnd = date('Y-m-d H:i:s', strtotime('+1 year', strtotime($yearStart)) - 1);
  2191. $list = $user->where('status', 1)
  2192. ->withCount([
  2193. 'sites as count' => function (Builder $query) {
  2194. $query->whereIn('status', [2, 3]);
  2195. },
  2196. 'sites as implementCount' => function (Builder $query) {
  2197. $query->where('status', 2);
  2198. },
  2199. 'sites as serverCount' => function (Builder $query) {
  2200. $query->where('status', 3);
  2201. },
  2202. 'sites as reachCount' => function (Builder $query) use ($yearStart, $yearEnd) {
  2203. $query->whereBetween('reach_at', [$yearStart, $yearEnd]);
  2204. },
  2205. 'sites as renewalCount' => function (Builder $query) use ($yearStart, $yearEnd) {
  2206. $query->whereBetween('renewal_at', [$yearStart, $yearEnd]);
  2207. },
  2208. ])
  2209. ->orderBy('role_id', 'desc')
  2210. ->paginate($request->input('pageSize') ?? 50);
  2211. $role = Role::query()->pluck('name', 'id');
  2212. foreach ($list as $item) {
  2213. $item->role = $role[$item->role_id] ?? '';
  2214. }
  2215. return response()->json([
  2216. 'rows' => $list->items(),
  2217. 'total' => $list->total()
  2218. ]);
  2219. }
  2220. }