| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461 | <?php/** * 建站期进度管理 * @copyright 2021-浙江引擎力营销策划有限公司 * @author Lc<sunshinecc1@163.com> * @since 2021-08-01 */namespace App\Http\Controllers\Admin\Flow;use App\Exports\BasicExport;use App\Exports\BqProgressRateExport;use App\Exports\EditingScheduleExport;use App\Exports\PlannerScheduleExport;use App\Exports\ProgressRateExport;use App\Http\Controllers\Controller;use App\Http\Models\BqProjectProgress;use App\Http\Models\FlowInfo;use App\Http\Models\FlowStage;use App\Http\Models\Mailbox;use App\Http\Models\NotFound;use App\Http\Models\ProcessProgress;use App\Http\Models\ProjectFlowMemo;use App\Http\Models\ProjectFlowMemoRelation;use App\Http\Models\ProjectProgress;use App\Http\Models\ProjectProgressCurrentMonth;use App\Http\Models\ProjectProgressEditing;use App\Http\Models\ProjectProgressPlanner;use App\Http\Models\Role;use App\Http\Models\ScheduledTasks;use App\Http\Models\ScoreSummary;use App\Http\Models\Site;use App\Http\Models\SiteProcess;use App\Http\Models\User;use App\Http\Models\WeekTaskInfo;use App\Http\Services\FlowService;use App\Http\Services\HomeService;use Illuminate\Database\Eloquent\Builder;use Illuminate\Http\Request;use Illuminate\Support\Facades\DB;use Illuminate\Contracts\View\Factory;use Illuminate\View\View;/** * 建站期进度管理 * Class ProgressRateController * @package App\Http\Controllers\Admin\Flow */class ProgressRateController extends Controller{    public $userList = [];    public const CAUSE = [        '1' => '客户原因',        '2' => '采编原因',        '3' => '策划师原因',        '4' => '设计原因',        '5' => '项目经理原因',        '6' => '其他原因',    ];    public function __construct()    {        $this->userList = User::query()->where('status', 1)->get() ?? [];    }    //当月上线目标    public function currentMonthOnline(Request $request)    {        $result = $request->all();        if (!empty($result['list'])) {            $list = json_decode($result['list'], true);            try {                DB::transaction(function () use ($list) {                    $siteIds = [];                    foreach ($list as $key => $value) {                        $siteIds[] = $value['site_id'];                        $list[$key]['type'] = implode(',', $value['type']);                    }                    ProjectProgressCurrentMonth::query()->whereIn('site_id', $siteIds)->delete();                    ProjectProgressCurrentMonth::query()->insert($list);                });            } catch (\Throwable $exception) {                return response()->json(['message' => $exception->getMessage()], 400);            }            return response()->json(['message' => '操作成功']);        }        $sites = $this->onlineBuilder($request, 0);        $list = $this->arraySort($sites->toArray(), 'rank', 'desc');        $list = array_merge($list);        return view('admin/flow/current_month_online', [            'siteList' => $list,            'userList' => $this->userList,            'result' => $result        ]);    }    //保存当月达标进度    public function saveCurrentMonthOnline(Request $request)    {        $result = $request->all();        $update = [            'site_id' => $result['siteId'] ?? 0,            'type' => implode(',', $result['project_progress'] ?? [0]),            'memo' => $result['memo'] ?? '',        ];        $info = ProjectProgressCurrentMonth::query()->where('site_id', $result['siteId'])->first();        if (empty($info)) {            ProjectProgressCurrentMonth::query()->insert($update);        } else {            ProjectProgressCurrentMonth::query()->where('site_id', $result['siteId'])->update($update);        }        $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]))?$/";        if (preg_match($patten, $result['month_range'])) {            Site::query()->where('id', $result['siteId'])->update(['current_month_online_date' => $result['month_range']]);        } else {            return response()->json(['message' => '时间格式不正确'], 400);        }        return response()->json(['message' => '操作成功']);    }    public function onlineBuilder($request, $type = 0)    {        $filterUserIds = [];        $editorId = $request->input('editorId');        $editorId && $filterUserIds[] = $editorId;        $manageHelperId = $request->input('manageHelperId');        $manageHelperId && $filterUserIds[] = $manageHelperId;        $optimizerId = $request->input('optimizerId');        $optimizerId && $filterUserIds[] = $optimizerId;        $webId = $request->input('webId');        $webId && $filterUserIds[] = $webId;        $plannerId = $request->input('plannerId');        $plannerId && $filterUserIds[] = $plannerId;        $keyword = $request->input('keyword');        $schedule = $request->input('schedule');        $site = Site::query();        if (!empty($schedule)) {            $siteIs = ProjectProgressCurrentMonth::query()->whereRaw('FIND_IN_SET(?,type)', [$schedule])->select('site_id')->pluck('site_id')->toArray() ?? [];            $site->whereIn('id', $siteIs);        }        if ($type != 0) {            $site->with(['projectProgressCurrentMonth', 'users'])->where('is_current_month_online', 1);        } else {            $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')]);        }        $builder = $site->where(function (Builder $q) use ($keyword) {            if ($keyword) {                $q->where('domain', 'like', '%' . $keyword . '%')                    ->orWhere('cn_title', 'like', '%' . $keyword . '%');            }        });        if ($filterUserIds) {            $builder->whereExists(function (\Illuminate\Database\Query\Builder $b) use ($filterUserIds) {                $raw = sprintf('SUM(CASE WHEN user_id in (%s) then  1 ELSE  0 end) as total', implode(',', $filterUserIds));                $b->select(DB::raw($raw))->from('user_has_sites')                    ->whereRaw(sprintf('user_has_sites.site_id=sites.id HAVING total=%s', count($filterUserIds)));            });        }        $sites = $builder->orderByDesc('id')->get();        foreach ($sites as $item) {            $item->rank = $item->projectProgressCurrentMonth->rank ?? 0;            $item->type = explode(',', $item->projectProgressCurrentMonth->type ?? 0);            $item->memo = $item->projectProgressCurrentMonth->memo ?? '';            $item->manage_helper_title = implode('-', $item->users->where('role_id', Role::TYPE_MANAGE_HELPER)->pluck('nickname')->toArray());            $item->ae_title = implode('-', $item->users->where('role_id', Role::TYPE_AE)->pluck('nickname')->toArray());            $item->planner = implode('-', $item->users->where('role_id', Role::TYPE_PLANNER)->pluck('nickname')->toArray());            $item->web = implode('-', $item->users->where('role_id', Role::TYPE_WEB)->pluck('nickname')->toArray());            $item->designerTitle = implode('-', $item->users->where('role_id', Role::TYPE_DESIGNER)->pluck('nickname')->toArray());        };        return $sites;    }    //未上线原因    public function notOnlineReason(Request $request)    {        $result = $request->all();        if (!empty($result['list'])) {            $list = json_decode($result['list'], true);            try {                DB::transaction(function () use ($list) {                    $siteIds = [];                    foreach ($list as $key => $value) {                        $siteIds[] = $value['site_id'];                        $list[$key]['type'] = implode(',', $value['type']);                    }                    ProjectProgressCurrentMonth::query()->whereIn('site_id', $siteIds)->delete();                    ProjectProgressCurrentMonth::query()->insert($list);                });            } catch (\Throwable $exception) {                return response()->json(['message' => $exception->getMessage()], 400);            }            return response()->json(['message' => '操作成功']);        }        $sites = $this->onlineBuilder($request, 1);        $list = $this->arraySort($sites->toArray(), 'rank', 'desc');        $list = array_merge($list);        return view('admin/flow/not_online_reason', [            'siteList' => $list,            'userList' => $this->userList,            'result' => $result        ]);    }    //项目进度(废弃不用)    public function progressRate(Request $request)    {        $result = $request->all();        if (!empty($result['list'])) {            $list = json_decode($result['list'], true);            try {                DB::transaction(function () use ($list) {                    $siteIds = [];                    foreach ($list as $key => $value) {                        $siteIds[] = $value['site_id'];                    }                    ProjectProgress::query()->whereIn('site_id', $siteIds)->delete();                    ProjectProgress::query()->insert($list);                });            } catch (\Throwable $exception) {                return response()->json(['message' => $exception->getMessage()], 400);            }            return response()->json(['message' => '操作成功']);        }        list($list, $user) = $this->progressRateBuild($request);        return view('admin.flow.progress_rate', [            'siteList' => $list,            'role_id' => $user->role_id,            'userList' => $this->userList,            'result' => $result        ]);    }    //项目进度(废弃不用)    public function progressRateBuild($request, $type = 0)    {        $user = auth()->user();        $list = Site::query()->with(['projectProgress', 'projectProgressEditing', 'projectProgressPlanner', 'users']);        $list = $this->getAuthBySiteId($request, $list, $user)->whereIn('status', [1, 4])->get();        foreach ($list as $key => $item) {            $item->info = 0;            $info = FlowInfo::query()->where('site_id', $item->id)->where('detail_list', 'like', '%网站架构定稿%')->first();            if (!empty($info)) {                foreach ($info->detail_list as $kk => $vv) {                    if ($vv['flow_name'] == '网站架构定稿') {                        if (!empty($vv['flow_done_date'])) {                            $item->info = 1;                        }                    }                }            }            $item->rank = $item->projectProgress->rank ?? 0;            $item->sort = $item->projectProgress->sort ?? 0;            $item->memo = $item->projectProgress->memo ?? '';            $item->prophase = 0;            if (!empty($item->projectProgressEditing->is_backstage) &&                !empty($item->projectProgressEditing->is_first_mail)) {                $item->prophase = 1;            }            $item->data = 0;            if (!empty($item->projectProgressEditing->is_data) &&                !empty($item->projectProgressEditing->is_folder) &&                !empty($item->projectProgressEditing->is_order_index) &&                !empty($item->projectProgressEditing->is_product_index)) {                $item->data = 1;            }            $item->test = 0;            if (!empty($item->projectProgressEditing->is_test_station) &&                !empty($item->projectProgressEditing->is_opinion) &&                !empty($item->projectProgressEditing->is_project_group) &&                !empty($item->projectProgressEditing->is_client_feedback)) {                $item->test = 1;            }            $item->online = 0;            if (!empty($item->projectProgressEditing->is_online_inspection_form) &&                !empty($item->projectProgressEditing->is_in_group_inspection) &&                !empty($item->projectProgressEditing->is_quality_inspection_departments) &&                !empty($item->projectProgressEditing->is_optimization)) {                $item->online = 1;            }            $item->is_keywords = $item->projectProgressPlanner->is_keywords ?? 0;            $item->is_keywords_map = $item->projectProgressPlanner->is_keywords_map ?? 0;            $item->is_tdk = $item->projectProgressPlanner->is_tdk ?? 0;            $item->page_planning = 0;            if (!empty($item->projectProgressPlanner->is_keywords_implantation) &&                !empty($item->projectProgressPlanner->is_home_planning) &&                !empty($item->projectProgressPlanner->is_product_guidance_document) &&                !empty($item->projectProgressPlanner->is_inside_page_planning) &&                !empty($item->projectProgressPlanner->is_special_page_planning)) {                $item->page_planning = 1;            }            $item->editing = $item->users->where('role_id', Role::TYPE_AE)->first()->nickname ?? '';            $item->project_manager = $item->users->where('role_id', Role::TYPE_MANAGE_HELPER)->first()->nickname ?? '';            $item->planner = $item->users->where('role_id', Role::TYPE_PLANNER)->first()->nickname ?? '';        }        if ($type == 1) {            $list = $list->toArray();        }        $list = $this->arraySort($list, 'rank', 'desc');        $list = array_merge($list);        return [$list, $user];    }    //百千项目进度    public function bqProgressRate(Request $request)    {        $result = $request->all();        if (!empty($result['list'])) {            $list = json_decode($result['list'], true);            try {                DB::transaction(function () use ($list) {                    $siteIds = [];                    foreach ($list as $key => $value) {                        $siteIds[] = $value['site_id'];                    }                    BqProjectProgress::query()->whereIn('site_id', $siteIds)->delete();                    BqProjectProgress::query()->insert($list);                });            } catch (\Throwable $exception) {                return response()->json(['message' => $exception->getMessage()], 400);            }            return response()->json(['message' => '操作成功']);        }        list($list, $userAuth) = $this->bqProgressRateBuild($request);        return view('admin.flow.bq_progress_rate', [            'siteList' => $list,            'role_id' => $userAuth->role_id,            'userList' => $this->userList,            'result' => $result        ]);    }    public function bqProgressRateBuild($request)    {        $userAuth = auth()->user();        $list = Site::query()            ->where('is_bq', 1)            ->with(['bqProjectProgress', 'users', 'bqFlow.bqFlowInfo']);        $list = $this->getAuthBySiteId($request, $list, $userAuth)->get()->toArray();        $result = [];        foreach ($list as $key => $item) {            $data = [                'id' => $item['id'],                'bq_at' => date('Y-m-d', strtotime($item['bq_at'])),                'cn_title' => $item['cn_title'] ?? '',                'optimization' => '',                'bq_meeting' => 1,                'home_page_adjustment' => 1,                'product_series_page_adjustment' => 1,                'other_page_adjustments' => 1,                'code_adjustment' => 1,                'web_page_adjustment' => 1,                'website_seo_quality_inspection' => 1,                'small_language_station' => 1,                'rank' => $item['bq_project_progress']['rank'] ?? 0,                'memo' => $item['bq_project_progress']['memo'] ?? '',            ];            foreach ($item['users'] as $user) {                if ($user['role_id'] == Role::TYPE_OPTIMIZER) {                    $data['optimization'] = $user['nickname'];                }            }            if (empty($item['bq_flow'])) {                $data['bq_meeting'] = 0;                $data['home_page_adjustment'] = 0;                $data['product_series_page_adjustment'] = 0;                $data['other_page_adjustments'] = 0;                $data['code_adjustment'] = 0;                $data['web_page_adjustment'] = 0;                $data['website_seo_quality_inspection'] = 0;                $data['small_language_station'] = 0;            } else {                foreach ($item['bq_flow'] as $value) {                    foreach ($value['bq_flow_info'] as $index) {                        foreach ($index['detail_list'] as $k => $v) {                            foreach ($v['children'] as $vv) {                                $vv['title'] = $value['title'];                                if (empty($vv['flow_done_date']) && $vv['title'] == '百千会议') {                                    $data['bq_meeting'] = 0;                                }                                if (empty($vv['flow_done_date']) && $vv['title'] == '首页调整') {                                    $data['home_page_adjustment'] = 0;                                }                                if (empty($vv['flow_done_date']) && $vv['title'] == '产品系列页面调整') {                                    $data['product_series_page_adjustment'] = 0;                                }                                if (empty($vv['flow_done_date']) && $vv['title'] == '其他页面调整') {                                    $data['other_page_adjustments'] = 0;                                }                                if (empty($vv['flow_done_date']) && $vv['title'] == '代码调整') {                                    $data['code_adjustment'] = 0;                                }                                if (empty($vv['flow_done_date']) && $vv['title'] == '网页调整') {                                    $data['web_page_adjustment'] = 0;                                }                                if (empty($vv['flow_done_date']) && $vv['title'] == '网站SEO质检') {                                    $data['website_seo_quality_inspection'] = 0;                                }                                if (empty($vv['flow_done_date']) && $vv['title'] == '小语言站') {                                    $data['small_language_station'] = 0;                                }                            }                        }                    }                }            }            $result[] = $data;        }        $result = $this->arraySort($result, 'rank', 'desc');        $result = array_merge($result);        return [$result, $userAuth];    }    //策划师进度(废弃不用)    public function plannerSchedule(Request $request)    {        $result = $request->all();        if (!empty($result['list'])) {            $list = json_decode($result['list'], true);            try {                DB::transaction(function () use ($list) {                    $siteIds = [];                    foreach ($list as $key => $value) {                        $siteIds[] = $value['site_id'];                    }                    ProjectProgressPlanner::query()->whereIn('site_id', $siteIds)->delete();                    ProjectProgressPlanner::query()->insert($list);                });            } catch (\Throwable $exception) {                return response()->json(['message' => $exception->getMessage()], 400);            }            return response()->json(['message' => '操作成功']);        }        $user = auth()->user();        $list = Site::query()->with(['projectProgressPlanner', 'users']);        $list = $this->getAuthBySiteId($request, $list, $user)->whereIn('status', [1, 4])->get();        $siteProcess = SiteProcess::query()                ->whereNotNull('deploy')                ->where('process_id', 7)->where('active', 2)                ->pluck('deploy', 'site_id')->toArray() ?? [];        $siteProcessList = [];        foreach ($siteProcess as $key => $process) {            $siteProcessList[$key] = $process['domain'];        }        foreach ($list as $key => $item) {            $item->url = $siteProcessList[$item->id] ?? '';            $item->memo = $item->projectProgressPlanner->memo ?? '';            $item->is_keywords = $item->projectProgressPlanner->is_keywords ?? 0;            $item->is_keywords_map = $item->projectProgressPlanner->is_keywords_map ?? 0;            $item->is_tdk = $item->projectProgressPlanner->is_tdk ?? 0;            $item->is_keywords_implantation = $item->projectProgressPlanner->is_keywords_implantation ?? 0;            $item->is_home_planning = $item->projectProgressPlanner->is_home_planning ?? 0;            $item->is_product_guidance_document = $item->projectProgressPlanner->is_product_guidance_document ?? 0;            $item->is_inside_page_planning = $item->projectProgressPlanner->is_inside_page_planning ?? 0;            $item->is_special_page_planning = $item->projectProgressPlanner->is_special_page_planning ?? 0;            $item->rank = $item->projectProgressPlanner->rank ?? 0;            $item->editing = $item->users->where('role_id', Role::TYPE_AE)->first()->nickname ?? '';            $item->nickname = $item->users->where('role_id', Role::TYPE_PLANNER)->first()->nickname ?? '';        }        $list = $this->arraySort($list, 'rank', 'desc');        $list = array_merge($list);        $editors = User::query()->where('status', 1)->where('role_id', Role::TYPE_PLANNER)->pluck('nickname', 'id');        return view('admin.flow.planner_schedule', [            'siteList' => $list,            'editors' => $editors,            'role_id' => $user->role_id,        ]);    }    //采编进度(废弃不用)    public function editingSchedule(Request $request)    {        $result = $request->all();        if (!empty($result['list'])) {            $list = json_decode($result['list'], true);            try {                DB::transaction(function () use ($list) {                    $siteIds = [];                    foreach ($list as $key => $value) {                        $siteIds[] = $value['site_id'];                    }                    ProjectProgressEditing::query()->whereIn('site_id', $siteIds)->delete();                    ProjectProgressEditing::query()->insert($list);                });            } catch (\Throwable $exception) {                return response()->json(['message' => $exception->getMessage()], 400);            }            return response()->json(['message' => '操作成功']);        }        $user = auth()->user();        $list = Site::query()->with(['projectProgressEditing', 'users']);        $list = $this->getAuthBySiteId($request, $list, $user)->whereIn('status', [1, 4])->get();        foreach ($list as $key => $item) {            $item->is_backstage = $item->projectProgressEditing->is_backstage ?? 0;            $item->memo = $item->projectProgressEditing->memo ?? '';            $item->is_first_mail = $item->projectProgressEditing->is_first_mail ?? 0;            $item->is_data = $item->projectProgressEditing->is_data ?? 0;            $item->is_folder = $item->projectProgressEditing->is_folder ?? 0;            $item->is_order_index = $item->projectProgressEditing->is_order_index ?? 0;            $item->is_product_index = $item->projectProgressEditing->is_product_index ?? 0;            $item->is_test_station = $item->projectProgressEditing->is_test_station ?? 0;            $item->is_opinion = $item->projectProgressEditing->is_opinion ?? 0;            $item->is_project_group = $item->projectProgressEditing->is_project_group ?? 0;            $item->is_client_feedback = $item->projectProgressEditing->is_client_feedback ?? 0;            $item->is_online_inspection_form = $item->projectProgressEditing->is_online_inspection_form ?? 0;            $item->is_in_group_inspection = $item->projectProgressEditing->is_in_group_inspection ?? 0;            $item->is_quality_inspection_departments = $item->projectProgressEditing->is_quality_inspection_departments ?? 0;            $item->is_optimization = $item->projectProgressEditing->is_optimization ?? 0;            $item->rank = $item->projectProgressEditing->rank ?? 0;            $item->nickname = $item->users->where('role_id', Role::TYPE_AE)->first()->nickname ?? '';        }        $list = $this->arraySort($list, 'rank', 'desc');        $list = array_merge($list);        $editors = User::query()->where('status', 1)->where('role_id', Role::TYPE_AE)->pluck('nickname', 'id');        return view('admin.flow.editing_schedule', [            'siteList' => $list,            'editors' => $editors,            'role_id' => $user->role_id,        ]);    }    //逾期导出(废弃不用)    public function scheduleOverdueExport(Request $request)    {        $site = $this->scheduleOverdueBuilder($request)->get();        $siteList = $this->resetScheduleOverdue($site);        $result = [];        foreach ($siteList as $item) {            $data = [                'cn_title' => $item->cn_title,                'domain' => $item->domain,                'projectManager' => $item->projectManager,                'serverManager' => $item->serverManager,                'salesManager' => $item->salesManager,                'expectedDay' => $item->expectedDay,                'overdueDay' => $item->overdueDay,                'projectDataCollection' => $item->projectDataCollection,                'projectDataCollectionMemo' => $item->projectDataCollectionMemo,                'projectDataCollectionComplete' => $item->projectDataCollectionComplete,                'siteArchitecture' => $item->siteArchitecture,                'siteArchitectureMemo' => $item->siteArchitectureMemo,                'siteArchitectureComplete' => $item->siteArchitectureComplete,                'homepageDesign' => $item->homepageDesign,                'homepageDesignMemo' => $item->homepageDesignMemo,                'homepageDesignComplete' => $item->homepageDesignComplete,                'insidePageDesign' => $item->insidePageDesign,                'insidePageDesignMemo' => $item->insidePageDesignMemo,                'insidePageDesignComplete' => $item->insidePageDesignComplete,                'websiteInformationProvision' => $item->websiteInformationProvision,                'websiteInformationProvisionMemo' => $item->websiteInformationProvisionMemo,                'websiteInformationProvisionComplete' => $item->websiteInformationProvisionComplete,                'testStation' => $item->testStation,                'testStationMemo' => $item->testStationMemo,                'testStationComplete' => $item->testStationComplete,                'keyWords' => $item->keyWords,                'keyWordsMemo' => $item->keyWordsMemo,                'keyWordsComplete' => $item->keyWordsComplete,                'seo' => $item->seo,                'seoMemo' => $item->seoMemo,                'seoComplete' => $item->seoComplete,                'online' => $item->online,                'onlineMemo' => $item->onlineMemo,                'onlineComplete' => $item->onlineComplete,            ];            $result[] = $data;        }        array_unshift($result, ['项目名称', '域名', '项目经理', '销售经理', '项目管家', '预计总天数', '逾期天数', '项目资料搜集逾期时间', '逾期原因', '项目资料搜集完成用时', '网站架构逾期时间', '逾期原因', '网站架构完成用时', '首页设计逾期时间', '逾期原因', '首页设计完成用时', '内页设计逾期时间', '逾期原因', '内页设计完成用时', '整站资料提供逾期时间', '逾期原因', '整站资料提供完成用时', '测试站逾期时间', '逾期原因', '测试站完成用时', '关键词逾期时间', '逾期原因', '关键词完成用时', 'seo完善逾期时间', '逾期原因', 'seo完善完成用时', '上线逾期时间', '逾期原因', '上线完成用时']);        return (new BasicExport($result))->download(sprintf('进度逾期%s.xls', date('YmdHis')));    }    //逾期汇总及原因(废弃不用)    public function scheduleOverdue(Request $request)    {        if (!$request->ajax()) {            $managerHelpers = User::query()->where('role_id', Role::TYPE_MANAGE_HELPER)->get();            return view('admin.flow.schedule_overdue', [                'managerHelpers' => $managerHelpers,            ]);        }        $site = $this->scheduleOverdueBuilder($request);        $siteList = $site->paginate($request->input('pageSize') ?? TABLE_PAGE_SIZE);        $siteList = $this->resetScheduleOverdue($siteList);        return response()->json([            'rows' => $siteList->items(),            'total' => $siteList->total()        ]);    }    //逾期汇总及原因(废弃不用)    public function scheduleOverdueBuilder($request)    {        $site = Site::query();        $keyword = $request->input('keyword');        if ($keyword) {            $site->where('domain', 'like', "%{$keyword}%")                ->orWhere('cn_title', 'like', "%{$keyword}%");        }        $manageHelperId = $request->input('manageHelperId');        if ($manageHelperId) {            $siteIdList = DB::table('user_has_sites')->where('user_id', $manageHelperId)->pluck('site_id') ?? [];            $site->whereIn('id', $siteIdList);        }        $date = $request->input('date');        if ($date) {            $siteIdList = FlowStage::query()                    ->whereBetween('expected_date', [date('Y-m-d', strtotime($date)), date('Y-m-t', strtotime($date))])                    ->groupBy('site_id')->pluck('site_id')->toArray() ?? [];            $site->whereIn('id', $siteIdList);        }        $siteIds = FlowStage::query()->whereNotNull('expected_date')->groupBy('site_id')->pluck('site_id')->toArray() ?? [];        if ($siteIds) {            $site->whereIn('id', $siteIds);        }        $site = $site->with(['users', 'projectProgressFlowStage']);        return $site;    }    //逾期汇总及原因(废弃不用)    public function resetScheduleOverdue($siteList)    {        foreach ($siteList as $item) {            $item->projectManager = implode('-', $item->users->where('role_id', Role::TYPE_MANAGE_HELPER)->pluck('nickname')->toArray());            $item->serverManager = implode('-', $item->users->where('role_id', Role::TYPE_SERVER)->pluck('nickname')->toArray());            $item->salesManager = implode('-', $item->users->where('role_id', Role::TYPE_SELLER)->pluck('nickname')->toArray());            $item->expectedDay = '';            $item->overdueDay = '';            $item->projectDataCollection = '';            $item->projectDataCollectionMemo = '';            $item->projectDataCollectionComplete = '';            $item->siteArchitecture = '';            $item->siteArchitectureMemo = '';            $item->siteArchitectureComplete = '';            $item->homepageDesign = '';            $item->homepageDesignMemo = '';            $item->homepageDesignComplete = '';            $item->insidePageDesign = '';            $item->insidePageDesignMemo = '';            $item->insidePageDesignComplete = '';            $item->websiteInformationProvision = '';            $item->websiteInformationProvisionMemo = '';            $item->websiteInformationProvisionComplete = '';            $item->testStation = '';            $item->testStationMemo = '';            $item->testStationComplete = '';            $item->keyWords = '';            $item->keyWordsMemo = '';            $item->keyWordsComplete = '';            $item->seo = '';            $item->seoMemo = '';            $item->seoComplete = '';            $item->online = '';            $item->onlineMemo = '';            $item->onlineComplete = '';            if (!empty($item->projectProgressFlowStage)) {                $day = [];                foreach ($item->projectProgressFlowStage as $value) {                    if (!empty($value->expected_date)) {                        $day[] = strtotime($value->expected_date);                    }                    $this->getOverdueList($item, $value);                }                $dayList = $this->maoPao($day);                if (count($dayList) > 0) {                    $day = ($dayList[count($dayList) - 1] - $dayList[0]) / 86400;                    $item->expectedDay = $day;                    $overdueDay = (strtotime(date('Y-m-d')) - $dayList[0]) / 86400;                    $item->overdueDay = $overdueDay;                }            }        }        return $siteList;    }    //标记    public function setSiteIdByRankId(Request $request)    {        $result = $request->all();        if ($result['type'] == 1) {            $model = ProjectProgressEditing::query();        } elseif ($result['type'] == 2) {            $model = ProjectProgressPlanner::query();        } elseif ($result['type'] == 3) {            $model = BqProjectProgress::query();        } elseif ($result['type'] == 4) {            $model = ProjectProgress::query();        } elseif ($result['type'] == 5) {            $model = ScoreSummary::query();        } elseif ($result['type'] == 6) {            $model = ProcessProgress::query();        } elseif ($result['type'] == 7) {            $model = ProjectProgressCurrentMonth::query();        } else {            $model = '';        }        $info = $model->where('site_id', $result['siteId'])->first();        if (empty($info)) {            return response()->json(['message' => '请先保存再标记'], 400);        }        $model->where('site_id', $result['siteId'])->update(['rank' => $result['rank']]);        return response()->json(['message' => '操作成功']);    }    //二维数组排序    public function arraySort($array, $keys, $sort = 'asc')    {        $newArr = $valArr = array();        foreach ($array as $key => $value) {            $valArr[$key] = $value[$keys];        }        ($sort == 'asc') ? asort($valArr) : arsort($valArr);        reset($valArr);        foreach ($valArr as $key => $value) {            $newArr[$key] = $array[$key];        }        return $newArr;    }    /**     * 筛选查询对象     * @param $result     * @param $site object     * @param $user     * @return mixed     */    public function getAuthBySiteId($result, $site, $user)    {        if (!empty($result['keyword'])) {            $site->where('cn_title', 'like', '%' . $result['keyword'] . '%');        }        if (!empty($result['userId'])) {            $siteIdList = DB::table('user_has_sites')->where('user_id', $result['userId'])->pluck('site_id') ?? [];            $site->whereIn('id', $siteIdList);        }        if (!empty($result['projectManagerId'])) {            $siteIdList = DB::table('user_has_sites')->where('user_id', $result['projectManagerId'])->pluck('site_id') ?? [];            $site->whereIn('id', $siteIdList);        }        if (!empty($result['plannerId'])) {            $siteIdList = DB::table('user_has_sites')->where('user_id', $result['plannerId'])->pluck('site_id') ?? [];            $site->whereIn('id', $siteIdList);        }        if (!empty($result['editingId'])) {            $siteIdList = DB::table('user_has_sites')->where('user_id', $result['editingId'])->pluck('site_id') ?? [];            $site->whereIn('id', $siteIdList);        }        if (!empty($result['designerId'])) {            $siteIdList = DB::table('user_has_sites')->where('user_id', $result['designerId'])->pluck('site_id') ?? [];            $site->whereIn('id', $siteIdList);        }        if (!empty($result['webId'])) {            $siteIdList = DB::table('user_has_sites')->where('user_id', $result['webId'])->pluck('site_id') ?? [];            $site->whereIn('id', $siteIdList);        }        if (!empty($result['projectStewardId'])) {            $siteIdList = DB::table('user_has_sites')->where('user_id', $result['projectStewardId'])->pluck('site_id') ?? [];            $site->whereIn('id', $siteIdList);        }        if (!empty($result['sellerId'])) {            $siteIdList = DB::table('user_has_sites')->where('user_id', $result['sellerId'])->pluck('site_id') ?? [];            $site->whereIn('id', $siteIdList);        }        if (!empty($result['serverId'])) {            $siteIdList = DB::table('user_has_sites')->where('user_id', $result['serverId'])->pluck('site_id') ?? [];            $site->whereIn('id', $siteIdList);        }        if (!empty($result['sort'])) {            $siteIdList = ProjectProgress::query()->where('sort', $result['sort'])->pluck('site_id') ?? [];            $site->whereIn('id', $siteIdList);        }        if (!in_array($user->role_id, [Role::TYPE_MANAGE_LEADER, Role::TYPE_DESIGN_DIRECTOR, Role::TYPE_HR, Role::TYPE_CHONGQING_MANAGER, Role::TYPE_QUALITY])) {            $siteIdList = DB::table('user_has_sites')->where('user_id', $user->id)->pluck('site_id') ?? [];            $site->whereIn('id', $siteIdList);        }        return $site;    }    //逾期汇总及原因(废弃不用)    public function getOverdueList(&$item, &$value)    {        if ($value->title == '项目资料搜集') {            //逾期天数            if (!empty($value->expected_date) && empty($value->complete_date)) {                $time = strtotime(date('Y-m-d')) - strtotime($value->expected_date);                if ($time > 0) {                    $item->projectDataCollection = floor($time / 86400);                }            }            //逾期天数            if (!empty($value->expected_date) && !empty($value->complete_date)) {                //重置延期天数                if ($value->complete_date > $value->expected_date) {                    $item->projectDataCollection = floor((strtotime($value->complete_date) - strtotime($value->expected_date)) / 86400);                } else {                    $item->projectDataCollection = '';                }            }            //逾期原因            if (!empty($value->expected_date) && empty($value->complete_date)) {                $result = explode(',', $value->extension);                $projectDataCollectionMemo = [];                foreach ($result as $index) {                    $projectDataCollectionMemo[] = self::CAUSE[$index] ?? '';                }                $item->projectDataCollectionMemo = implode(',', $projectDataCollectionMemo);            }            //完成用时            if (!empty($value->complete_date)) {                $time = strtotime($value->complete_date) - strtotime($value->expected_date);                if ($time > 0) {                    $item->projectDataCollectionComplete = floor($time / 86400);                }            }        }        if ($value->title == '网站架构') {            if (!empty($value->expected_date) && empty($value->complete_date)) {                $time = strtotime(date('Y-m-d')) - strtotime($value->expected_date);                if ($time > 0) {                    $item->siteArchitecture = floor($time / 86400);                }            }            if (!empty($value->expected_date) && !empty($value->complete_date)) {                if ($value->complete_date > $value->expected_date) {                    $item->siteArchitecture = floor((strtotime($value->complete_date) - strtotime($value->expected_date)) / 86400);                } else {                    $item->siteArchitecture = '';                }            }            if (!empty($value->extension)) {                $result = explode(',', $value->extension);                $siteArchitectureMemo = [];                foreach ($result as $index) {                    $siteArchitectureMemo[] = self::CAUSE[$index] ?? '';                }                $item->siteArchitectureMemo = implode(',', $siteArchitectureMemo);            }            if (!empty($value->complete_date)) {                $time = strtotime($value->complete_date) - strtotime($value->expected_date);                if ($time > 0) {                    $item->siteArchitectureComplete = floor($time / 86400);                }            }        }        if ($value->title == '首页设计') {            if (!empty($value->expected_date) && empty($value->complete_date)) {                $time = strtotime(date('Y-m-d')) - strtotime($value->expected_date);                if ($time > 0) {                    $item->homepageDesign = floor($time / 86400);                }            }            if (!empty($value->expected_date) && !empty($value->complete_date)) {                if ($value->complete_date > $value->expected_date) {                    $item->homepageDesign = floor((strtotime($value->complete_date) - strtotime($value->expected_date)) / 86400);                } else {                    $item->homepageDesign = '';                }            }            if (!empty($value->extension)) {                $result = explode(',', $value->extension);                $homepageDesignMemo = [];                foreach ($result as $index) {                    $homepageDesignMemo[] = self::CAUSE[$index] ?? '';                }                $item->homepageDesignMemo = implode(',', $homepageDesignMemo);            }            if (!empty($value->complete_date)) {                $time = strtotime($value->complete_date) - strtotime($value->expected_date);                if ($time > 0) {                    $item->homepageDesignComplete = floor($time / 86400);                }            }        }        if ($value->title == '内页设计') {            if (!empty($value->expected_date) && empty($value->complete_date)) {                $time = strtotime(date('Y-m-d')) - strtotime($value->expected_date);                if ($time > 0) {                    $item->insidePageDesign = floor($time / 86400);                }            }            if (!empty($value->expected_date) && !empty($value->complete_date)) {                //重置延期天数                if ($value->complete_date > $value->expected_date) {                    $item->insidePageDesign = floor((strtotime($value->complete_date) - strtotime($value->expected_date)) / 86400);                } else {                    $item->insidePageDesign = '';                }            }            if (!empty($value->extension)) {                $result = explode(',', $value->extension);                $insidePageDesignMemo = [];                foreach ($result as $index) {                    $insidePageDesignMemo[] = self::CAUSE[$index] ?? '';                }                $item->insidePageDesignMemo = implode(',', $insidePageDesignMemo);            }            if (!empty($value->complete_date)) {                $time = strtotime($value->complete_date) - strtotime($value->expected_date);                if ($time > 0) {                    $item->insidePageDesignComplete = floor($time / 86400);                }            }        }        if ($value->title == '整站资料提供') {            if (!empty($value->expected_date) && empty($value->complete_date)) {                $time = strtotime(date('Y-m-d')) - strtotime($value->expected_date);                if ($time > 0) {                    $item->websiteInformationProvision = floor($time / 86400);                }            }            if (!empty($value->expected_date) && !empty($value->complete_date)) {                if ($value->complete_date > $value->expected_date) {                    $item->websiteInformationProvision = floor((strtotime($value->complete_date) - strtotime($value->expected_date)) / 86400);                } else {                    $item->websiteInformationProvision = '';                }            }            if (!empty($value->extension)) {                $result = explode(',', $value->extension);                $websiteInformationProvisionMemo = [];                foreach ($result as $index) {                    $websiteInformationProvisionMemo[] = self::CAUSE[$index] ?? '';                }                $item->websiteInformationProvisionMemo = implode(',', $websiteInformationProvisionMemo);            }            if (!empty($value->complete_date)) {                $time = strtotime($value->complete_date) - strtotime($value->expected_date);                if ($time > 0) {                    $item->websiteInformationProvisionComplete = floor($time / 86400);                }            }        }        if ($value->title == '测试站') {            if (!empty($value->expected_date) && empty($value->complete_date)) {                $time = strtotime(date('Y-m-d')) - strtotime($value->expected_date);                if ($time > 0) {                    $item->testStation = floor($time / 86400);                }            }            if (!empty($value->expected_date) && !empty($value->complete_date)) {                if ($value->complete_date > $value->expected_date) {                    $item->testStation = floor((strtotime($value->complete_date) - strtotime($value->expected_date)) / 86400);                } else {                    $item->testStation = '';                }            }            if (!empty($value->extension)) {                $result = explode(',', $value->extension);                $testStationMemo = [];                foreach ($result as $index) {                    $testStationMemo[] = self::CAUSE[$index] ?? '';                }                $item->testStationMemo = implode(',', $testStationMemo);            }            if (!empty($value->complete_date)) {                $time = strtotime($value->complete_date) - strtotime($value->expected_date);                if ($time > 0) {                    $item->testStationComplete = floor($time / 86400);                }            }        }        if ($value->title == '关键词') {            if (!empty($value->expected_date) && empty($value->complete_date)) {                $time = strtotime(date('Y-m-d')) - strtotime($value->expected_date);                if ($time > 0) {                    $item->keyWords = floor($time / 86400);                }            }            if (!empty($value->expected_date) && !empty($value->complete_date)) {                if ($value->complete_date > $value->expected_date) {                    $item->keyWords = floor((strtotime($value->complete_date) - strtotime($value->expected_date)) / 86400);                } else {                    $item->keyWords = '';                }            }            if (!empty($value->extension)) {                $result = explode(',', $value->extension);                $keyWordsMemo = [];                foreach ($result as $index) {                    $keyWordsMemo[] = self::CAUSE[$index] ?? '';                }                $item->keyWordsMemo = implode(',', $keyWordsMemo);            }            if (!empty($value->complete_date)) {                $time = strtotime($value->complete_date) - strtotime($value->expected_date);                if ($time > 0) {                    $item->keyWordsComplete = floor($time / 86400);                }            }        }        if ($value->title == 'SEO完善') {            if (!empty($value->expected_date) && empty($value->complete_date)) {                $time = strtotime(date('Y-m-d')) - strtotime($value->expected_date);                if ($time > 0) {                    $item->seo = floor($time / 86400);                }            }            if (!empty($value->expected_date) && !empty($value->complete_date)) {                if ($value->complete_date > $value->expected_date) {                    $item->seo = floor((strtotime($value->complete_date) - strtotime($value->expected_date)) / 86400);                } else {                    $item->seo = '';                }            }            if (!empty($value->extension)) {                $result = explode(',', $value->extension);                $seoMemo = [];                foreach ($result as $index) {                    $seoMemo[] = self::CAUSE[$index] ?? '';                }                $item->seoMemo = implode(',', $seoMemo);            }            if (!empty($value->complete_date)) {                $time = strtotime($value->complete_date) - strtotime($value->expected_date);                if ($time > 0) {                    $item->seoComplete = floor($time / 86400);                }            }        }        if ($value->title == '上线') {            if (!empty($value->expected_date) && empty($value->complete_date)) {                $time = strtotime(date('Y-m-d')) - strtotime($value->expected_date);                if ($time > 0) {                    $item->online = floor($time / 86400);                }            }            if (!empty($value->expected_date) && !empty($value->complete_date)) {                if ($value->complete_date > $value->expected_date) {                    $item->online = floor((strtotime($value->complete_date) - strtotime($value->expected_date)) / 86400);                } else {                    $item->online = '';                }            }            if (!empty($value->extension)) {                $result = explode(',', $value->extension);                $onlineMemo = [];                foreach ($result as $index) {                    $onlineMemo[] = self::CAUSE[$index] ?? '';                }                $item->onlineMemo = implode(',', $onlineMemo);            }            if (!empty($value->complete_date)) {                $time = strtotime($value->complete_date) - strtotime($value->expected_date);                if ($time > 0) {                    $item->onlineComplete = floor($time / 86400);                }            }        }    }    //冒泡    public function maoPao($a)    {        for ($i = 0; $i < count($a); $i++) {            for ($j = $i + 1; $j < count($a); $j++) {                if ($a[$i] > $a[$j]) {                    $tem = $a[$i]; // 这里临时变量,存贮$i的值                    $a[$i] = $a[$j]; // 第一次更换位置                    $a[$j] = $tem; // 完成位置互换                }            }        }        return $a;    }    //策划师进度导出    public function plannerScheduleExport(Request $request)    {        $user = auth()->user();        $list = Site::query()->with(['projectProgressPlanner', 'users']);        $list = $this->getAuthBySiteId($request, $list, $user)->whereIn('status', [1, 4])->get();        $siteProcess = SiteProcess::query()                ->whereNotNull('deploy')                ->where('process_id', 7)->where('active', 2)                ->pluck('deploy', 'site_id')->toArray() ?? [];        $siteProcessList = [];        foreach ($siteProcess as $key => $process) {            $siteProcessList[$key] = $process['domain'];        }        $result = [];        foreach ($list as $key => $item) {            $ae = $item->users->where('role_id', Role::TYPE_AE)->first()->nickname ?? '';            $data = [                'id' => ++$key,                'cn_title' => $item->cn_title . '-' . $ae,                'url' => $siteProcessList[$item->id] ?? '',                'memo' => $item->projectProgressPlanner->memo ?? '',                'nickname' => $item->users->where('role_id', Role::TYPE_PLANNER)->first()->nickname ?? '',                'is_keywords' => $item->projectProgressPlanner->is_keywords ?? 0,                'is_keywords_map' => $item->projectProgressPlanner->is_keywords_map ?? 0,                'is_tdk' => $item->projectProgressPlanner->is_tdk ?? 0,                'is_keywords_implantation' => $item->projectProgressPlanner->is_keywords_implantation ?? 0,                'is_home_planning' => $item->projectProgressPlanner->is_home_planning ?? 0,                'is_product_guidance_document' => $item->projectProgressPlanner->is_product_guidance_document ?? 0,                'is_inside_page_planning' => $item->projectProgressPlanner->is_inside_page_planning ?? 0,                'is_special_page_planning' => $item->projectProgressPlanner->is_special_page_planning ?? 0,                'rank' => $item->projectProgressPlanner->rank ?? 0,            ];            $result[] = $data;        }        $result = $this->arraySort($result, 'rank', 'desc');        $result = array_merge($result);        foreach ($result as $key => $value) {            unset($result[$key]['rank']);            $result[$key]['id'] = $key + 1;        }        array_unshift($result, ['序号', '项目及采编', '测试站网址', '备注', '策划师', '关键词初选', '关键词地图', 'TDK', '关键词植入', '首页策划', '产品指导交流', '内页策划', '特殊页策划']);        array_unshift($result, ['项目配置', '', '', '', '', '关键词工作', '', '', '页面策划', '', '', '', '']);        array_unshift($result, ['策划师核心工作:关键词(关键词初选,关键词地图,关键词植入,TDK)+页面策划(首页策划,内页策划,软文策划)+产品指导文档' . "\n" . '注:个人邮箱发送常用文件;关键词地图定稿公共邮箱发送;提前安排关键词地图;日期加打钩']);        return (new PlannerScheduleExport($result))->download(sprintf('策划师进度%s.xls', date('YmdHis')));    }    //采编进度导出(废弃不用)    public function editingScheduleExport(Request $request)    {        $user = auth()->user();        $list = Site::query()->with(['projectProgressEditing', 'users']);        $list = $this->getAuthBySiteId($request, $list, $user)->whereIn('status', [1, 4])->get();        $result = [];        foreach ($list as $key => $item) {            $ae = $item->users->where('role_id', Role::TYPE_AE)->first()->nickname ?? '';            $result[] = [                'id' => ++$key,                'cn_title' => $item->cn_title ?? '',                'domain' => $item->domain ?? '',                'memo' => $item->projectProgressEditing->memo ?? '',                'nickname' => $ae,                'is_backstage' => $item->projectProgressEditing->is_backstage ?? 0,                'is_first_mail' => $item->projectProgressEditing->is_first_mail ?? 0,                'is_data' => $item->projectProgressEditing->is_data ?? 0,                'is_folder' => $item->projectProgressEditing->is_folder ?? 0,                'is_order_index' => $item->projectProgressEditing->is_order_index ?? 0,                'is_product_index' => $item->projectProgressEditing->is_product_index ?? 0,                'is_test_station' => $item->projectProgressEditing->is_test_station ?? 0,                'is_opinion' => $item->projectProgressEditing->is_opinion ?? 0,                'is_project_group' => $item->projectProgressEditing->is_project_group ?? 0,                'is_client_feedback' => $item->projectProgressEditing->is_client_feedback ?? 0,                'is_online_inspection_form' => $item->projectProgressEditing->is_online_inspection_form ?? 0,                'is_in_group_inspection' => $item->projectProgressEditing->is_in_group_inspection ?? 0,                'is_quality_inspection_departments' => $item->projectProgressEditing->is_quality_inspection_departments ?? 0,                'is_optimization' => $item->projectProgressEditing->is_optimization ?? 0,                'rank' => $item->projectProgressPlanner->rank ?? 0,            ];        }        $result = $this->arraySort($result, 'rank', 'desc');        $result = array_merge($result);        foreach ($result as $key => $value) {            unset($result[$key]['rank']);            $result[$key]['id'] = $key + 1;        }        array_unshift($result, ['序号', '项目', '网址', '备注', '采编', '后台搭建', '第一封邮件', '资料进度表', '共享盘文件夹整理', '单页面提供完整', '产品页面提供完整', '测试站检查表', '组内意见', '项目部群', '客户反馈', '上线检查表格', '组内检查', '质检部', 'Hina&优化师检查']);        array_unshift($result, ['项目配置', '', '', '', '', '建站前期', '', '资料', '', '', '', '测试站', '', '', '', '上线', '', '', '']);        array_unshift($result, ['采编核心工作:资料(资料进度表,共享盘文件夹) + 测试站(测试站检查表格,组内意见,项目部群,客户反馈) + 上线(上线检查表格,组内检查,组间互查,杜佳检查,Hina检查)注:资料要求客户邮件发送,及时查收;网站检查表格(放在共享盘);客户催促上线及时告知项目经理和采编']);        return (new EditingScheduleExport($result))->download(sprintf('采编进度 %s.xls', date('YmdHis')));    }    //项目进度导出(废弃不用)    public function progressRateExport(Request $request)    {        list($list, $user) = $this->progressRateBuild($request, 1);        $result = [];        foreach ($list as $key => $value) {            if ($value['sort'] == 1) {                $type = '上线阶段';            } elseif ($value['sort'] == 2) {                $type = '测试站阶段';            } elseif ($value['sort'] == 3) {                $type = '设计阶段策划师跟进';            } elseif ($value['sort'] == 4) {                $type = '架构阶段';            } elseif ($value['sort'] == 5) {                $type = '暂停项目';            } else {                $type = '请选择阶段';            }            $result[] = [                'id' => ++$key,                'cn_title' => $value['cn_title'],                'sort' => $type,                'project_manager' => $value['project_manager'],                'planner' => $value['planner'],                'editing' => $value['editing'],                'memo' => $value['memo'],                'info' => $value['info'],                'prophase' => $value['prophase'],                'data' => $value['data'],                'test' => $value['test'],                'online' => $value['online'],                'is_keywords' => $value['is_keywords'],                'is_keywords_map' => $value['is_keywords_map'],                'is_tdk' => $value['is_tdk'],                'page_planning' => $value['page_planning'],                'rank' => $value['rank'],                'domain' => $value['domain'],            ];        }        foreach ($result as $key => $value) {            unset($result[$key]['rank']);            $result[$key]['id'] = $key + 1;        }        array_unshift($result, ['序号', '项目', '阶级', '项目经理', '策划师', '采编', '备注', '架构&确定域名', '建站前期', '资料', '测试站', '上线', '关键词初选', '关键词地图', 'TDK', '页面策划']);        array_unshift($result, ['项目配置', '', '', '', '', '', '', '', '采编进度', '', '', '', '策划师进度', '', '', '']);        array_unshift($result, ['项目总进度']);        return (new ProgressRateExport($result))->download(sprintf('项目总进度 %s.xls', date('YmdHis')));    }    //项目进度导出(废弃不用)    public function bqProgressRateExport(Request $request)    {        list($list, $userAuth) = $this->bqProgressRateBuild($request);        $result = [];        foreach ($list as $key => $value) {            $result[] = [                'id' => ++$key,                'cn_title' => $value['cn_title'],                'optimization' => $value['optimization'],                'memo' => $value['memo'],                'bq_at' => $value['bq_at'],                'bq_meeting' => $value['bq_meeting'],                'home_page_adjustment' => $value['home_page_adjustment'],                'product_series_page_adjustment' => $value['product_series_page_adjustment'],                'other_page_adjustments' => $value['other_page_adjustments'],                'code_adjustment' => $value['code_adjustment'],                'web_page_adjustment' => $value['web_page_adjustment'],                'website_seo_quality_inspection' => $value['website_seo_quality_inspection'],                'small_language_station' => $value['small_language_station'],                'rank' => $value['rank'],            ];        }        foreach ($result as $key => $value) {            unset($result[$key]['rank']);            $result[$key]['id'] = $key + 1;        }        array_unshift($result, ['序号', '项目', '优化师', '备注', '百千约访时间', '百千会议', '首页调整', '产品系列页面调整', '其他页面调整', '代码调整', '网页调整', '网站SEO质检', '小语言站']);        array_unshift($result, ['百千项目总进度']);        return (new BqProgressRateExport($result))->download(sprintf('百千项目总进度 %s.xls', date('YmdHis')));    }    //评分统计    public function designScore(Request $request)    {        $result = $request->all();        if (!empty($result['list'])) {            $list = json_decode($result['list'], true);            try {                DB::transaction(function () use ($list) {                    $siteIds = [];                    foreach ($list as $key => $value) {                        $siteIds[] = $value['site_id'];                    }                    ScoreSummary::query()->whereIn('site_id', $siteIds)->delete();                    ScoreSummary::query()->insert($list);                });            } catch (\Throwable $exception) {                return response()->json(['message' => $exception->getMessage()], 400);            }            return response()->json(['message' => '操作成功']);        }        $user = auth()->user();        $siteIds = ProjectFlowMemo::query()->groupBy('site_id')->pluck('site_id');        $siteList = Site::query()->whereIn('id', $siteIds);        $siteList = $this->getAuthBySiteId($request, $siteList, $user);        $siteList = $siteList->select('id', 'cn_title', 'order_at', 'online_at')            ->with(['projectFlowMemo' => function ($query) {                $query->select('title', 'level', 'status', 'site_id', 'node_date', 'is_client_score', 'client_score');            }, 'scoreSummary', 'users'])->get();        $list = [];        foreach ($siteList as $item) {            $data = [                'site_id' => $item->id,                'cn_title' => $item->cn_title,                'order_at' => $item->order_at,                'online_at' => substr($item->online_at, 0, 10),                'rank' => $item->scoreSummary->rank ?? 0,                'project_manager' => $item->users->where('role_id', Role::TYPE_MANAGE_HELPER)->first()->nickname ?? '',                'project_steward' => $item->users->where('role_id', Role::TYPE_SERVER)->first()->nickname ?? '',                'editing' => $item->users->where('role_id', Role::TYPE_AE)->first()->nickname ?? '',                'web' => $item->users->where('role_id', Role::TYPE_WEB)->first()->nickname ?? '',                'design' => $item->users->where('role_id', Role::TYPE_DESIGNER)->first()->nickname ?? '',                'plan' => $item->users->where('role_id', Role::TYPE_PLANNER)->first()->nickname ?? '',            ];            foreach ($item->projectFlowMemo as $progress) {                if ($progress->title == '竞争对手分析') {                    $data['score1'] = $progress->client_score;                }                if ($progress->title == '网站架构定稿') {                    $data['score2'] = $progress->client_score;                }                if ($progress->title == '首页设计定稿') {                    $data['score3'] = $progress->client_score;                }                if ($progress->title == '手机端首页+两张banner设计定稿') {                    $data['score4'] = $progress->client_score;                }                if ($progress->title == '产品内页设计定稿') {                    $data['score5'] = $progress->client_score;                }                if ($progress->title == 'PC 端测试站客户验收反馈') {                    $data['score6'] = $progress->client_score;                }                if ($progress->title == '关键词地图定稿') {                    $data['score7'] = $progress->client_score;                }                if ($progress->title == '上线确认进入实施期') {                    $data['score8'] = $progress->client_score;                }            }            $list[] = $data;        }        $siteList = $this->arraySort($list, 'rank', 'desc');        $siteList = array_merge($siteList);        return view('admin.flow.design_score', [            'siteList' => $siteList,            'request' => $request,            'projectManager' => User::query()->where('status', 1)->where('role_id', Role::TYPE_MANAGE_HELPER)->pluck('nickname', 'id'),            'planner' => User::query()->where('status', 1)->where('role_id', Role::TYPE_PLANNER)->pluck('nickname', 'id'),            'editors' => User::query()->where('status', 1)->where('role_id', Role::TYPE_AE)->pluck('nickname', 'id'),            'designer' => User::query()->where('status', 1)->where('role_id', Role::TYPE_DESIGNER)->pluck('nickname', 'id'),            'web' => User::query()->where('status', 1)->where('role_id', Role::TYPE_WEB)->pluck('nickname', 'id'),            'projectSteward' => User::query()->where('status', 1)->where('role_id', Role::TYPE_SERVER)->pluck('nickname', 'id'),        ]);    }    /**     * 建站流程表&&保存     * @param Request $request     * @param $siteId     * @param int $type 0全部,1局部     * @return Factory|View     */    public function siteConstructionProcess(Request $request, $siteId, $type = 0)    {        $user = auth()->user();        if ($user->role_id == 5) {            return redirect('/wap/site-flow/0');            /*return view('admin/site/not_found', [                'tips' => '暂无权限,请登陆后台查看',                'siteId' => $siteId,            ]);*/        }        $siteInfo = Site::query()->where('id', $siteId)->first();        if (empty($siteInfo)) {            return view('admin/site/not_found', [                'tips' => '暂无项目',                'siteId' => $siteId,            ]);        }        if (empty($siteInfo->task_at)) {            return view('admin/site/not_found', [                'tips' => '项目任务起始时间未设置,初始化失败',                'siteId' => $siteId,            ]);        }        $siteByUserList = Site::query()->where('id', $siteId)->with(['users'])->first();        $pm = $siteByUserList->users->where('role_id', Role::TYPE_MANAGE_HELPER)->first();        if (empty($pm)) {            return view('admin/site/not_found', [                'tips' => '该项目没有分配项目经理,初始化失败',                'siteId' => $siteId,            ]);        }        $server = $siteByUserList->users->where('role_id', Role::TYPE_SERVER)->first();        if (empty($server)) {            return view('admin/site/not_found', [                'tips' => '该项目没有分配客服人员,初始化失败',                'siteId' => $siteId,            ]);        }        $ae = $siteByUserList->users->where('role_id', Role::TYPE_AE)->first();        if (empty($ae)) {            return view('admin/site/not_found', [                'tips' => '该项目没有分配采编人员,初始化失败',                'siteId' => $siteId,            ]);        }        $result = $request->all();        if (!empty($result)) {            //保存流程            $this->saveFlow($result, $siteId);        }        //流程初始化        $siteInfo = $this->iniFlow($siteId, $siteInfo);        //区别权限        $flowService = new FlowService();        [$list, $count, $toBeCompletedCount, $nodeDate,            $user, $taskLastDateStart, $taskLastDateEnd, $newNodeDate,            $thisWeekTaskList, $nextWeekTaskList]            = $flowService->getFlowListByUserId($type, $siteId);        //测试站        $deploy = SiteProcess::query()            ->where('process_id', 7)            ->where('active', 2)            ->where('site_id', $siteId)            ->whereNotNull('deploy')->value('deploy');        return view('admin.flow.site_construction_process', [            'count' => $count,            'toBeCompletedCount' => $toBeCompletedCount,            'list' => $list,            'siteInfo' => $siteInfo,            'siteName' => $this->substrFormat($siteInfo->cn_title, 4),            'roles' => $user,            'siteId' => $siteId,            'reasonsForOverdueList' => ProjectFlowMemo::REASONS_FOR_OVERDUE_LIST,            'scoreList' => ProjectFlowMemo::SCORE,            'date' => date('Y-m-d H:i:s'),            'nodeDate' => $nodeDate ?? '',            'taskLastDateStart' => $taskLastDateStart,            'taskLastDateEnd' => $taskLastDateEnd,            'type' => $type,            'newNodeDate' => $newNodeDate,            'thisWeekTaskList' => $thisWeekTaskList,//这周任务规划            'nextWeekTaskList' => $nextWeekTaskList,//下周任务规划            'domain' => $deploy['domain'] ?? '',        ]);    }    //初始化流程    private function iniFlow($siteId, $siteInfo)    {        $result = ProjectFlowMemo::query()->where('site_id', $siteId)->first();        if (empty($result)) {            $data = [];            $list = DB::table('project_flow_memo_tpl')->get();            $days = 120;            $dayList = [];            for ($i = 1; $i <= $days; $i++) {                $day = date('Y-m-d', strtotime($siteInfo->task_at) + 86400 * $i);                $result = $this->isWeekend($day);                if (!$result) {                    $dayList[] = $day;                }            }            foreach ($list as $value) {                $data[] = [                    'site_id' => $siteId,                    'status' => $value->status,                    'title' => $value->title,                    'level' => $value->level,                    'rank' => $value->rank,                    'memo' => $value->memo,                    'roles' => $value->roles,                    'acceptance' => $value->acceptance,                    'file' => $value->file,                    'file_path' => $value->file_path,                    'client_file' => $value->client_file,                    'client_file_path' => $value->client_file_path,                    'master_plate_path' => $value->master_plate_path,                    'file_list' => $value->file_list ?? null,                    'node_date' => $dayList[$value->day - 1],                    'node' => $value->node,                    'day' => $value->day,                    'overdue_day' => $value->overdue_day,                    'reasons_for_overdue' => $value->reasons_for_overdue,                    'overdue_memo' => $value->overdue_memo,                    'client_score' => $value->client_score,                    'is_client_score' => $value->is_client_score,                    'inspection_score' => $value->inspection_score,                    'is_inspection_score' => $value->is_inspection_score,                    'inspection' => 0,                    'color' => $value->color,                    'updated_at' => date('Y-m-d'),                ];            }            ProjectFlowMemo::query()->insert($data);            $userList = [];            $siteInfo = Site::query()->where('id', $siteId)->with(['users'])->first();            foreach ($siteInfo->users as $user) {                $userList[$user->role_id] = $user->id;            }            $flow = ProjectFlowMemo::query()->where('site_id', $siteId)->get();            $list = [];            foreach ($flow as $item) {                $rolesList = explode(',', $item->roles);                foreach ($rolesList as $roles) {                    if ($roles != 5) {                        $list[] = [                            'roles_id' => $roles,                            'memo_id' => $item->id,                        ];                    }                }            }            foreach ($list as $key => $item) {                $list[$key]['user_id'] = $userList[$item['roles_id']] ?? 0;            }            foreach ($list as $key => $item) {                if (empty($item['user_id'])) {                    unset($list[$key]);                }            }            ProjectFlowMemoRelation::query()->insert($list);        }        return $siteInfo;    }    //保存流程    public function saveFlow($result, $siteId)    {        $data = [];        $user = [];        $ids = ProjectFlowMemo::query()->where('site_id', $siteId)->pluck('id') ?? 0;        foreach ($result as $key => $item) {            //拆分表单提交过来的字段            $filed = explode('-', $key);            if (!empty($filed[2])) {                foreach ($ids as $id) {                    if ($filed[0] == $id && $filed[1]) {                        $user[$filed[0]][] = [                            $filed[1] => $item,                            'roles_id' => $filed[2],                            'memo_id' => $filed[0],                        ];                    }                }            } else {                foreach ($ids as $id) {                    if ($filed[0] == $id && $filed[1]) {                        $data[$filed[0]][] = [                            $filed[1] => $item,                        ];                    }                }            }        }        $userList = [];        foreach ($user as $key => $item) {            foreach ($item as $value) {                $userList[] = $value;            }        }        $userResult = [];        $workingHoursResult = [];        //工时        foreach ($userList as $value) {            if (!empty($value['user_id'])) {                $userResult[] = $value;            }            if (!empty($value['working_hours'])) {                $workingHoursResult[] = $value;            }        }        foreach ($userResult as $key => $value) {            foreach ($workingHoursResult as $vv) {                if ($value['memo_id'] == $vv['memo_id'] && $value['roles_id'] == $vv['roles_id']) {                    $userResult[$key]['working_hours'] = $vv['working_hours'] ?? '';                }            }        }        try {            DB::transaction(function () use ($userResult) {                $memoIds = array_unique(array_column($userResult, 'memo_id'));                ProjectFlowMemoRelation::query()->whereIn('memo_id', $memoIds)->delete();                foreach ($userResult as $value) {                    ProjectFlowMemoRelation::query()->insert($value);                }            });        } catch (\Throwable $exception) {            return response()->json(['message' => $exception->getMessage()], 400);        }        $list = [];        foreach ($data as $key => $item) {            if (!empty($item[1]['id'])) {                $reasonsForOverdue = $item[3]['reasons_for_overdue'] ?? 0;                $inspectionScore = $item[3]['inspection_score'] ?? $item[4]['inspection_score'] ?? 0;                $overdueMemo = $item[3]['overdue_memo'] ?? $item[4]['overdue_memo'] ?? $item[5]['overdue_memo'] ?? '';                $planningWeek = $item[4]['planning_week'] ?? $item[5]['planning_week'] ?? $item[6]['planning_week'] ?? '';                $planningNextWeek = $item[4]['planning_next_week'] ?? $item[5]['planning_next_week'] ?? $item[6]['planning_next_week'] ?? '';                $update = [                    'id' => $item[1]['id'],                    'status' => $item[0]['status'] ?? 0,                    'memo' => $item[2]['memo'] ?? 0,                ];                if (!empty($reasonsForOverdue)) {                    $update['reasons_for_overdue'] = $reasonsForOverdue;                }                if (!empty($inspectionScore)) {                    $update['inspection_score'] = $inspectionScore;                }                if (!empty($overdueMemo)) {                    $update['overdue_memo'] = $overdueMemo;                }                if (!empty($planningWeek)) {                    $update['planning_week'] = $planningWeek;                }                if (!empty($planningNextWeek)) {                    $update['planning_next_week'] = $planningNextWeek;                }                $list[] = $update;            }        }        if (!empty($list)) {            foreach ($list as $value) {                if (!empty($value['overdue_memo']) && mb_strlen($value['overdue_memo'], 'utf8') > 100) {                    die('备注请保持在100字以内');                }            }            foreach ($list as $value) {                ProjectFlowMemo::query()->where('id', $value['id'])->update($value);            }        }    }    //流程上传资料(废弃不用 改oss)    public function uploadSiteFile(Request $request)    {        $file = $request->file('file');        if (empty($file)) {            return response()->json(['message' => '请上传文件'], 400);        }        $fileName = date('Y-m-d_His') . $file->getClientOriginalName();        $fileData['file_url'] = $file->storeAs(date('Y-m') . '/' . $file->getClientOriginalExtension(), $fileName, 'public');        $fileData['file_url'] = asset('storage/' . $fileData['file_url']);        $fileData['original_name'] = $file->getClientOriginalName();        $fileData['time'] = time();        return response()->json(['message' => '上传成功', 'data' => $fileData]);    }    //流程资料下载(废弃 不用 改oss)    public function downloadSiteFile($taskId, $type = 0)    {        $info = DB::table('project_flow_memo')            ->where('id', $taskId)            ->first();        $user = auth()->user();        if ($user->role_id == 5) {            if ($type == 1) {                $path = $info->master_plate_path;            } else {                $path = $info->client_file_path;            }        } else {            $path = $info->file_path;        }        if (empty($path)) {            die('暂无文件');        }        $pathInfo = pathinfo($path);        $dirnamePath = explode('storage', $pathInfo['dirname']);        return response()->download(realpath(base_path('public')) . '/storage' . $dirnamePath[1] . '/' . $pathInfo['basename'], $pathInfo['basename']);    }    private function substrFormat($text, $length, $replace = '...', $encoding = 'UTF-8')    {        if ($text && mb_strlen($text, $encoding) > $length) {            return mb_substr($text, 0, $length, $encoding) . $replace;        }        return $text;    }    //建站2.0进度逾期统计    public function stationConstructionOverdue(Request $request)    {        if (!$request->ajax()) {            $userList = User::query()->where('status', 1)->get();            return view('admin.flow.station_construction_overdue', [                'userList' => $userList,            ]);        }        $list = $this->stationConstructionOverdueBuild($request, ProjectFlowMemo::query());        return response()->json([            'rows' => $list->items(),            'total' => $list->total()        ]);    }    public function stationConstructionOverdueExport(Request $request)    {        $projectFlowMemo = ProjectFlowMemo::query();        $list = $this->stationConstructionOverdueBuild($request, $projectFlowMemo, true);        $data = [];        foreach ($list as $item) {            $data[] = [                'title' => $item->title ?? '',                'rank' => $item->rank ?? '',                'node_date' => $item->node_date ?? '',                'user' => $item->user ?? '',                'overdue_day' => $item->overdue_day ?? '',                'cn_title' => $item->cn_title ?? '',                'order_at' => $item->order_at ?? '',            ];        }        array_unshift($data, ['逾期事项', '阶段', '任务截止时间', '逾期阶段负责人', '逾期天数', '关联项目', '下单时间']);        return (new BasicExport($data))->download(sprintf('建站流程逾期列表%s.xls', date('YmdHis')));    }    /**     * 建站2.0进度逾期统计     * @param $request object     * @param $projectFlowMemo object     * @param bool $isExport     * @param bool $isAll     * @return mixed     */    private function stationConstructionOverdueBuild($request, $projectFlowMemo, $isExport = false, $isAll = false)    {        $role = auth()->user();        if ($role->is_super != 1 || !in_array($role->role_id, [Role::TYPE_MANAGE_LEADER, Role::TYPE_DESIGN_DIRECTOR, Role::TYPE_HR])) {            $memoIdList = ProjectFlowMemoRelation::query()->where('user_id', $role->id)->pluck('memo_id');            $projectFlowMemo->whereIn('id', $memoIdList ?? []);        }        $request = $request->all();        if (!empty($request['projectManagerId'])) {            $memoIds = ProjectFlowMemoRelation::query()->where('user_id', $request['projectManagerId'])->pluck('memo_id');            $projectFlowMemo->whereIn('id', $memoIds ?? []);        }        if (!empty($request['serverId'])) {            $memoIds = ProjectFlowMemoRelation::query()->where('user_id', $request['serverId'])->pluck('memo_id');            $projectFlowMemo->whereIn('id', $memoIds ?? []);        }        if (!empty($request['sellerId'])) {            $memoIds = ProjectFlowMemoRelation::query()->where('user_id', $request['sellerId'])->pluck('memo_id');            $projectFlowMemo->whereIn('id', $memoIds ?? []);        }        if (!empty($request['editingId'])) {            $memoIds = ProjectFlowMemoRelation::query()->where('user_id', $request['editingId'])->pluck('memo_id');            $projectFlowMemo->whereIn('id', $memoIds ?? []);        }        $task = $request['task'];        if (!empty($task)) {            $projectFlowMemo->where('title', 'like', '%' . $task . '%');        }        $projectFlowMemo->with(['sites', 'projectFlowMemoRelation'])->where('status', '=', 0);        if (!$isAll) {            $projectFlowMemo->where('node_date', '<', date('Y-m-d'));        }        if ($isExport) {            $list = $projectFlowMemo->get();        } else {            $list = $projectFlowMemo->paginate($request['pageSize'] ?? 10);        }        $userList = User::query()->where('status', 1)->pluck('nickname', 'id')->toArray();        foreach ($list as $item) {            $users = [];            $item->cn_title = $item->sites->cn_title ?? '';            $item->order_at = '';            $item->online_at = '';            if (!empty($item->sites->order_at)) {                $item->order_at = date('Y-m-d', strtotime($item->sites->order_at));            }            if (!empty($item->sites->online_at)) {                $item->online_at = date('Y-m-d', strtotime($item->sites->online_at));            }            foreach ($item->projectFlowMemoRelation as $user) {                $users[] = $userList[$user->user_id] ?? '';            }            $item->user = implode(',', $users);            if (strtotime($item->node_date) < strtotime(date('Y-m-d'))) {                $item->overdue_day = (strtotime(date('Y-m-d')) - strtotime($item->node_date)) / 3600 / 24 . '天';            } else {                $item->overdue_day = '';            }            if ($item->reasons_for_overdue == 0) {                $item->reasons_for_overdue = '';            } else {                $item->reasons_for_overdue = ProjectFlowMemo::REASONS_FOR_OVERDUE_LIST[$item->reasons_for_overdue] ?? '';            }        }        return $list;    }    //个人任务    public function personalTasks(Request $request)    {        if (!$request->ajax()) {            $managerHelpers = User::query()->where('status', 1)->where('role_id', Role::TYPE_MANAGE_HELPER)->get();            return view('admin.flow.test_remind', [                'managerHelpers' => $managerHelpers,            ]);        }        $taskList = $this->stationConstructionOverdueBuild($request, ProjectFlowMemo::query(), false, true);        return response()->json([            'rows' => $taskList->items(),            'total' => $taskList->total()        ]);    }    //个人邮箱    public function mailbox(Request $request)    {        if (!$request->ajax()) {            return view('admin.flow.mailbox', [            ]);        }        $message = $request->input('message');        $user = auth()->user();        $list = Mailbox::query();        if (!empty($message)) {            $list->where('message', 'like', '%' . $message . '%');        }        if (!empty($user->is_super != 1)) {            $list->where('user_id', $user->id);        }        $userList = User::query()->where('status', 1)->pluck('nickname', 'id');        $list = $list->orderByDesc('id')->paginate($request->input('pageSize'));        foreach ($list as $item) {            $item->user = $userList[$item->user_id] ?? '';            $item->read = '未读';            if ($item->is_read == 1) {                $item->read = '已读';            }        }        return response()->json([            'rows' => $list->items(),            'total' => $list->total()        ]);    }    public function getMailboxStatus()    {        $user = auth()->user();        $mailbox = Mailbox::query();        $mailbox1 = Mailbox::query();        if (!empty($user->is_super != 1)) {            $mailbox->where('user_id', $user->id);            $mailbox1->where('user_id', $user->id);        }        $count = $mailbox->where('is_read', 0)->count() ?? 0;        $message = $mailbox1->where('is_read', 0)->orderByDesc('id')->value('message') ?? '';        return response()->json([            'count' => $count,            'message' => $message        ]);    }    public function batchRead()    {        $user = auth()->user();        if ($user->is_super == 1) {            return response()->json(['message' => '管理员不允许批量操作'], 400);        } else {            Mailbox::query()->where('user_id', $user->id)->update(['is_read' => 1]);            return response()->json(['message' => '操作成功']);        }    }    public function buildFlow(Request $request)    {        $result = $request->all();        if (!empty($result['list'])) {            $list = json_decode($result['list'], true);            try {                DB::transaction(function () use ($list) {                    $siteIds = [];                    foreach ($list as $key => $value) {                        $siteIds[] = $value['site_id'];                    }                    ProcessProgress::query()->whereIn('site_id', $siteIds)->delete();                    ProcessProgress::query()->insert($list);                });            } catch (\Throwable $exception) {                return response()->json(['message' => $exception->getMessage()], 400);            }            return response()->json(['message' => '操作成功']);        }        $user = auth()->user();        $sites = Site::query();        if (empty($result['status']) || $result['status'] == 1) {            $sites->where('status', 1);        } else {            $sites->where('status', '!=', 1);        }        $siteIds = ProjectFlowMemo::query()->groupBy('site_id')->pluck('site_id');        $siteList = $sites->whereIn('id', $siteIds)            ->select('id', 'cn_title', 'order_at')            ->with(['projectFlowMemo' => function ($query) {                $query->select('level', 'status', 'site_id', 'node_date');            }, 'processProgress']);        $flowService = new FlowService();        $siteList = $flowService->getFlowListBySiteId($this->getAuthBySiteId($request, $siteList, $user)->get()->toArray());        $sort = 'rank';        if (!empty($result['lv'])) {            $sort = $result['lv'];        }        $siteList = $this->arraySort($siteList, $sort, 'desc');        $siteList = array_merge($siteList);        return view('admin.flow.build_flow', [            'siteList' => $siteList,            'role_id' => $user->role_id,            'result' => $result,            'userList' => $this->userList,        ]);    }    public function delSitesTaskFlow($siteId)    {        DB::transaction(function () use ($siteId) {            $ids = ProjectFlowMemo::query()->where('site_id', $siteId)->pluck('id');            ProjectFlowMemoRelation::query()->where('memo_id', $ids)->delete();            ProjectFlowMemo::query()->where('site_id', $siteId)->delete();            ProcessProgress::query()->where('site_id', $siteId)->delete();        });        return response()->json(['message' => '清除成功']);    }    public function resetting(Request $request)    {        $siteId = $request->input('siteId');        $flowIds = ProjectFlowMemo::query()->where('site_id', $siteId)->pluck('id');        if ($flowIds) {            ProjectFlowMemo::query()->where('site_id', $siteId)->delete();            ProjectFlowMemoRelation::query()->whereIn('memo_id', $flowIds)->delete();        }        return response()->json(['message' => '重置成功']);    }    public function taskResetting(Request $request)    {        $taskId = $request->input('taskId');        $flowInfo = ProjectFlowMemo::query()->where('id', $taskId)->first();        if ($flowInfo) {            $memo = [                'status' => 0,                'overdue_memo' => '',                'reasons_for_overdue' => '',                'client_score' => 0,                'inspection_score' => 0,            ];            ProjectFlowMemo::query()->where('id', $taskId)->update($memo);            $siteInfo = Site::query()->where('id', $flowInfo->site_id)->with(['users'])->first();            $role = explode(',', $flowInfo->roles);            $update = [];            foreach ($role as $item) {                if ($item != 5) {                    $user = $siteInfo->users->where('role_id', $item)->first();                    $update[] = [                        'user_id' => $user->id ?? 0,                        'working_hours' => '',                        'roles_id' => $user->role_id ?? 0,                        'memo_id' => $taskId,                    ];                }            }            try {                DB::transaction(function () use ($update, $taskId) {                    ProjectFlowMemoRelation::query()->where('memo_id', $taskId)->delete();                    ProjectFlowMemoRelation::query()->insert($update);                });                return response()->json(['message' => '重置成功']);            } catch (\Throwable $exception) {                return response()->json(['message' => $exception->getMessage()], 400);            }        }    }    public function notFound(Request $request, $siteId)    {        if (!$request->ajax()) {            return view('admin.flow.not_found', [                'siteId' => $siteId            ]);        }        $ids = NotFound::get404List($siteId);        $list = DB::table('site_status')            ->where('status', 404)            ->where('site_id', $siteId)            ->whereIn('id', $ids)            ->paginate($request->input('pageSize') ?? 10);        return response()->json([            'rows' => $list->items(),            'total' => $list->total()        ]);    }    public function isHandle(Request $request, $id)    {        $type = $request->input('type');        DB::table('site_status')->where('id', $id)->update(['is_handle' => $type]);        return response()->json(['message' => '处理成功']);    }    public function isWeekend($date)    {        if ((date('w', strtotime($date)) == 6) || (date('w', strtotime($date)) == 0)) {            return true;        } else {            return false;        }    }    public function home()    {        $homeService = new HomeService();        $taskList = $homeService->getTaskList(Role::TYPE_WEB) ?? [];        $taskList2 = $homeService->getTaskList(Role::TYPE_DESIGNER) ?? [];        $taskListByWeek = $homeService->getTaskByWeek(Role::TYPE_WEB);        $taskListByWeek2 = $homeService->getTaskByWeek(Role::TYPE_DESIGNER);        list($sitesStatusList,            $thisMonthOnlineSite,            $ratioOnlineSite,            $thisMonthOrderSite,            $ratioOrderSite,            $thisMonthQualifiedSite,            $ratioQualifiedSite,            $thisMonthAssignSite,            $ratioAssignSite) = $homeService->getProjectOverview();        $projectStatusList = $homeService->getProjectStatusList(Role::TYPE_WEB);        $projectStatusList2 = $homeService->getProjectStatusList(Role::TYPE_DESIGNER);        $monthBySiteList = $homeService->getMonthBySiteList();        $monthBySiteList2 = $homeService->getMonthBySiteList2();        $speedMeasurement = $homeService->getSpeedMeasurement();        $siteListCountByUsers = $homeService->getSiteListByProjectManagers();        $siteListByOptimizeEditing = $homeService->getSiteListByOptimizeEditing();        $siteListByProjectHousekeeper = $homeService->getSiteListByProjectHousekeeper();        $siteRenewListByProjectHousekeeper = $homeService->getSiteRenewListByProjectHousekeeper();        return view('admin.flow.home', [            'sitesStatusList' => $sitesStatusList,            'thisMonthOnlineSite' => $thisMonthOnlineSite,            'ratioOnlineSite' => $ratioOnlineSite,            'thisMonthOrderSite' => $thisMonthOrderSite,            'ratioOrderSite' => $ratioOrderSite,            'thisMonthQualifiedSite' => $thisMonthQualifiedSite,            'ratioQualifiedSite' => $ratioQualifiedSite,            'thisMonthAssignSite' => $thisMonthAssignSite,            'ratioAssignSite' => $ratioAssignSite,            'projectStatusList' => $projectStatusList,            'projectStatusList2' => $projectStatusList2,            'monthBySiteList' => $monthBySiteList,            'monthBySiteList2' => $monthBySiteList2,            'speedMeasurement' => $speedMeasurement,            'siteListCountByUsers' => $siteListCountByUsers,            'siteListByOptimizeEditing' => $siteListByOptimizeEditing,            'siteListByProjectHousekeeper' => $siteListByProjectHousekeeper,            'siteRenewListByProjectHousekeeper' => $siteRenewListByProjectHousekeeper,            'date' => date('Y-m-d'),            'user' => auth()->user(),            'taskList' => $taskList,            'taskList2' => $taskList2,            'taskListByWeek' => $taskListByWeek,            'taskListByWeek2' => $taskListByWeek2,        ]);    }    public function clientDataUpload(Request $request, $siteId, $type = 0)    {        $result = $request->all();        if (!empty($result)) {            $this->saveClientData($result);            return redirect("/admin/flow/clientDataUpload/{$siteId}/1");        }        if (!empty($type)) {            $user = auth()->user();            $siteIds = DB::table('user_has_sites')->where('user_id', $user->id)->first();            $siteId = $siteIds->site_id;        }        $list = DB::table('client_data_upload')->where('site_id', $siteId)->get();        $cnTitle = Site::query()->where('id', $siteId)->value('cn_title') ?? '';        return view('admin.flow.client_data_upload', [            'siteId' => $siteId,            'cn_title' => $cnTitle,            'list' => $list,            'token' => time(),        ]);    }    private function saveClientData($result)    {        $data = [];        foreach ($result as $key => $item) {            $array = explode(':', $key);            if (!empty($array[1])) {                foreach ($item as $value) {                    $data[$array[0]][] = $value;                }            }        }        try {            DB::transaction(function () use ($data, $result) {                $user = auth()->user();                if ($user->role_id == Role::TYPE_CUSTOMER) {                    foreach ($data as $key => $datum) {                        $url = [];                        $urls = DB::table('client_data_upload')                            ->where('id', $key)                            ->where('site_id', $result['siteId'])                            ->value('url');                        if (!empty($urls)) {                            $url = json_decode($urls, true);                        }                        $datum = array_merge($url, $datum);                        DB::table('client_data_upload')                            ->where('id', $key)                            ->where('site_id', $result['siteId'])                            ->update(['url' => json_encode($datum)]);                    }                } else {                    foreach ($data as $key => $datum) {                        $url = [];                        $urls = DB::table('client_data_upload')                            ->where('id', $key)                            ->where('site_id', $result['siteId'])                            ->value('list');                        if (!empty($urls)) {                            $url = json_decode($urls, true);                        }                        $datum = array_merge($url, $datum);                        DB::table('client_data_upload')                            ->where('id', $key)                            ->where('site_id', $result['siteId'])                            ->update(['list' => json_encode($datum)]);                    }                }            });        } catch (\Throwable $exception) {            pre_dump($exception->getMessage());        }    }    public function clientData(Request $request, $siteId)    {        if (!$request->ajax()) {            return view('admin.flow.client_data', [                'siteId' => $siteId,            ]);        }        $result = DB::table('client_data_upload')            ->where('site_id', $siteId)            ->paginate($request->input('pageSize') ?? 10);        $list = $result->items();        foreach ($list as $value) {            $value->data_memo = $this->substrFormat($value->data_memo, 20);        }        return response()->json([            'rows' => $list,            'total' => $result->total()        ]);    }    public function clientAdd(Request $request, $taskId, $siteId)    {        if (!$request->ajax()) {            $result = DB::table('client_data_upload')                    ->where('id', $taskId)                    ->first() ?? [];            return view('admin.flow.client_data_add', [                'siteId' => $siteId,                'taskId' => $taskId,                'info' => $result,            ]);        }        $request = $request->all();        $data = [            'site_id' => $request['siteId'] ?? 0,            'page' => $request['page'] ?? '',            'style_path' => $request['style_path'] ?? '',            'data_memo' => $request['data_memo'] ?? '',            'deadline' => $request['deadline'] ?? date('Y-m-d'),        ];        try {            if (empty($taskId)) {                $info = DB::table('client_data_upload')->where('id', $taskId)->first();                if (empty($info)) {                    DB::table('client_data_upload')->insert($data);                }            } else {                DB::table('client_data_upload')->where('id', $taskId)->update($data);            }            return response()->json(['message' => 'success']);        } catch (\Throwable $exception) {            return response()->json(['message' => $exception->getMessage()], 400);        }    }    public function clientDel(Request $request)    {        $request = $request->input('ids');        try {            DB::table('client_data_upload')->whereIn('id', $request)->delete();            return response()->json(['message' => 'success']);        } catch (\Throwable $exception) {            return response()->json(['message' => $exception->getMessage()], 400);        }    }    //项目数量关联人员统计汇总    public function projectPersonnelStatistics(Request $request, $type = 1)    {        $roles = [Role::TYPE_AE, Role::TYPE_MANAGE_HELPER];        if (!$request->ajax()) {            $role = User::query()->where('status', 1)                ->whereIn('role_id', $roles)                ->select('id', 'role_id', 'nickname')                ->get();            return view('admin.flow.project_personnel_statistics', [                'roles' => $role            ]);        }        $yearStart = date('Y-01-01 00:00:00');        $yearEnd = date('Y-m-d H:i:s', strtotime('+1 year', strtotime($yearStart)) - 1);        $role = Role::query()->pluck('name', 'id');        $user = User::query()->whereIn('role_id', $roles);        $editingId = $request->input('editingId');        if (!empty($editingId) && $editingId != -1) {            $user->where('id', $editingId);        }        if ($editingId == -1) {            $user->where('role_id', Role::TYPE_AE);        }        $projectManagerId = $request->input('projectManagerId');        if (!empty($projectManagerId) && $projectManagerId != -1) {            $user->where('id', $projectManagerId);        }        if ($projectManagerId == -1) {            $user->where('role_id', Role::TYPE_MANAGE_HELPER);        }        $list = $user->where('status', 1)->withCount(            ['sites' => function (Builder $query) {                $query->where('status', 1);            }, 'sites as sites_online' => function (Builder $query) use ($yearStart, $yearEnd) {                $query->whereBetween('online_at', [$yearStart, $yearEnd]);            }])->orderBy('role_id', 'desc')            ->paginate($request->input('pageSize') ?? 50);        foreach ($list as $item) {            $item->role = $role[$item->role_id] ?? '';        }        return response()->json([            'rows' => $list->items(),            'total' => $list->total()        ]);    }    public function optimizationPersonnel(Request $request)    {        $roles = [Role::TYPE_OPTIMIZATION_EDITING, Role::TYPE_OPTIMIZER];        if (!$request->ajax()) {            $role = User::query()->where('status', 1)                ->whereIn('role_id', $roles)                ->select('id', 'role_id', 'nickname')                ->get();            return view('admin.flow.optimization_personnel', [                'roles' => $role            ]);        }        $user = User::query()->whereIn('role_id', $roles);        $optimizationId = $request->input('optimizationId');        if (!empty($optimizationId) && $optimizationId != -1) {            $user->where('id', $optimizationId);        }        if ($optimizationId == -1) {            $user->where('role_id', Role::TYPE_OPTIMIZER);        }        $optimizationEditingId = $request->input('optimizationEditingId');        if (!empty($optimizationEditingId) && $optimizationEditingId != -1) {            $user->where('id', $optimizationEditingId);        }        if ($optimizationEditingId == -1) {            $user->where('role_id', Role::TYPE_OPTIMIZATION_EDITING);        }        $yearStart = date('Y-01-01 00:00:00');        $yearEnd = date('Y-m-d H:i:s', strtotime('+1 year', strtotime($yearStart)) - 1);        $list = $user->where('status', 1)            ->withCount([                'sites as count' => function (Builder $query) {                    $query->whereIn('status', [2, 3]);                },                'sites as implementCount' => function (Builder $query) {                    $query->where('status', 2);                },                'sites as serverCount' => function (Builder $query) {                    $query->where('status', 3);                },                'sites as reachCount' => function (Builder $query) use ($yearStart, $yearEnd) {                    $query->whereBetween('reach_at', [$yearStart, $yearEnd]);                },                'sites as renewalCount' => function (Builder $query) use ($yearStart, $yearEnd) {                    $query->whereBetween('renewal_at', [$yearStart, $yearEnd]);                },            ])            ->orderBy('role_id', 'desc')            ->paginate($request->input('pageSize') ?? 50);        $role = Role::query()->pluck('name', 'id');        foreach ($list as $item) {            $item->role = $role[$item->role_id] ?? '';        }        return response()->json([            'rows' => $list->items(),            'total' => $list->total()        ]);    }}
 |