FJService.cs 417 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385538653875388538953905391539253935394539553965397539853995400540154025403540454055406540754085409541054115412541354145415541654175418541954205421542254235424542554265427542854295430543154325433543454355436543754385439544054415442544354445445544654475448544954505451545254535454545554565457545854595460546154625463546454655466546754685469547054715472547354745475547654775478547954805481548254835484548554865487548854895490549154925493549454955496549754985499550055015502550355045505550655075508550955105511551255135514551555165517551855195520552155225523552455255526552755285529553055315532553355345535553655375538553955405541554255435544554555465547554855495550555155525553555455555556555755585559556055615562556355645565556655675568556955705571557255735574557555765577557855795580558155825583558455855586558755885589559055915592559355945595559655975598559956005601560256035604560556065607560856095610561156125613561456155616561756185619562056215622562356245625562656275628562956305631563256335634563556365637563856395640564156425643564456455646564756485649565056515652565356545655565656575658565956605661566256635664566556665667566856695670567156725673567456755676567756785679568056815682568356845685568656875688568956905691569256935694569556965697569856995700570157025703570457055706570757085709571057115712571357145715571657175718571957205721572257235724572557265727572857295730573157325733573457355736573757385739574057415742574357445745574657475748574957505751575257535754575557565757575857595760576157625763576457655766576757685769577057715772577357745775577657775778577957805781578257835784578557865787578857895790579157925793579457955796579757985799580058015802580358045805580658075808580958105811581258135814581558165817581858195820582158225823582458255826582758285829583058315832583358345835583658375838583958405841584258435844584558465847584858495850585158525853585458555856585758585859586058615862586358645865586658675868586958705871587258735874587558765877587858795880588158825883588458855886588758885889589058915892589358945895589658975898589959005901590259035904590559065907590859095910591159125913591459155916591759185919592059215922592359245925592659275928592959305931593259335934593559365937593859395940594159425943594459455946594759485949595059515952595359545955595659575958595959605961596259635964596559665967596859695970597159725973597459755976597759785979598059815982598359845985598659875988598959905991599259935994599559965997599859996000600160026003600460056006600760086009601060116012601360146015601660176018601960206021602260236024602560266027602860296030603160326033603460356036603760386039604060416042604360446045604660476048604960506051605260536054605560566057605860596060606160626063606460656066606760686069607060716072607360746075607660776078607960806081608260836084608560866087608860896090609160926093609460956096609760986099610061016102610361046105610661076108610961106111611261136114611561166117611861196120612161226123612461256126612761286129613061316132613361346135613661376138613961406141614261436144614561466147614861496150615161526153615461556156615761586159616061616162616361646165616661676168616961706171617261736174617561766177617861796180618161826183618461856186618761886189619061916192619361946195619661976198619962006201620262036204620562066207620862096210621162126213621462156216621762186219622062216222622362246225622662276228622962306231623262336234623562366237623862396240624162426243624462456246624762486249625062516252625362546255625662576258625962606261626262636264626562666267626862696270627162726273627462756276627762786279628062816282628362846285628662876288628962906291629262936294629562966297629862996300630163026303630463056306630763086309631063116312631363146315631663176318631963206321632263236324632563266327632863296330633163326333633463356336633763386339634063416342634363446345634663476348634963506351635263536354635563566357635863596360636163626363636463656366636763686369637063716372637363746375637663776378637963806381638263836384638563866387638863896390639163926393639463956396639763986399640064016402640364046405640664076408640964106411641264136414641564166417641864196420642164226423642464256426642764286429643064316432643364346435643664376438643964406441644264436444644564466447644864496450645164526453645464556456645764586459646064616462646364646465646664676468646964706471647264736474647564766477647864796480648164826483648464856486648764886489649064916492649364946495649664976498649965006501650265036504650565066507650865096510651165126513651465156516651765186519652065216522652365246525652665276528652965306531653265336534653565366537653865396540654165426543654465456546654765486549655065516552655365546555655665576558655965606561656265636564656565666567656865696570657165726573657465756576657765786579658065816582658365846585658665876588658965906591659265936594659565966597659865996600660166026603660466056606660766086609661066116612661366146615661666176618661966206621662266236624662566266627662866296630663166326633663466356636663766386639664066416642664366446645664666476648664966506651665266536654665566566657665866596660666166626663666466656666666766686669667066716672667366746675667666776678667966806681668266836684668566866687668866896690669166926693669466956696669766986699670067016702670367046705670667076708670967106711671267136714671567166717671867196720672167226723672467256726672767286729673067316732673367346735673667376738673967406741674267436744674567466747674867496750675167526753675467556756675767586759676067616762676367646765676667676768676967706771677267736774677567766777677867796780678167826783678467856786678767886789679067916792679367946795679667976798679968006801680268036804680568066807680868096810681168126813681468156816681768186819682068216822682368246825682668276828682968306831683268336834683568366837683868396840684168426843684468456846684768486849685068516852685368546855685668576858685968606861686268636864686568666867686868696870687168726873687468756876687768786879688068816882688368846885688668876888688968906891689268936894689568966897689868996900690169026903690469056906690769086909691069116912691369146915691669176918691969206921692269236924692569266927692869296930693169326933693469356936693769386939694069416942694369446945694669476948694969506951695269536954695569566957695869596960696169626963696469656966696769686969697069716972697369746975697669776978697969806981698269836984698569866987698869896990699169926993699469956996699769986999700070017002700370047005700670077008700970107011701270137014701570167017701870197020702170227023702470257026702770287029703070317032703370347035703670377038703970407041704270437044704570467047704870497050705170527053705470557056705770587059706070617062706370647065706670677068706970707071707270737074707570767077707870797080708170827083708470857086708770887089709070917092709370947095709670977098709971007101710271037104710571067107710871097110711171127113711471157116711771187119712071217122712371247125712671277128712971307131713271337134713571367137713871397140714171427143714471457146714771487149715071517152715371547155715671577158715971607161716271637164716571667167716871697170717171727173717471757176717771787179718071817182718371847185718671877188718971907191719271937194719571967197719871997200720172027203720472057206720772087209721072117212721372147215721672177218721972207221722272237224722572267227722872297230723172327233723472357236723772387239724072417242724372447245724672477248724972507251725272537254725572567257725872597260726172627263726472657266726772687269727072717272727372747275727672777278727972807281728272837284728572867287728872897290729172927293729472957296729772987299730073017302730373047305730673077308730973107311731273137314731573167317731873197320732173227323732473257326732773287329733073317332733373347335733673377338733973407341734273437344734573467347734873497350735173527353735473557356735773587359736073617362736373647365736673677368736973707371737273737374737573767377737873797380738173827383738473857386738773887389739073917392739373947395739673977398739974007401740274037404740574067407740874097410741174127413741474157416741774187419742074217422742374247425742674277428742974307431743274337434743574367437743874397440744174427443744474457446744774487449745074517452745374547455745674577458745974607461746274637464746574667467746874697470747174727473747474757476747774787479748074817482748374847485748674877488748974907491749274937494749574967497749874997500750175027503750475057506750775087509751075117512751375147515751675177518751975207521752275237524752575267527752875297530753175327533753475357536753775387539754075417542754375447545754675477548754975507551755275537554755575567557755875597560756175627563756475657566756775687569757075717572757375747575757675777578757975807581758275837584758575867587758875897590759175927593759475957596759775987599760076017602760376047605760676077608760976107611761276137614761576167617761876197620762176227623762476257626762776287629763076317632763376347635763676377638763976407641764276437644764576467647764876497650765176527653765476557656765776587659766076617662766376647665766676677668766976707671767276737674767576767677767876797680768176827683768476857686768776887689769076917692769376947695769676977698769977007701770277037704770577067707770877097710771177127713771477157716771777187719772077217722772377247725772677277728772977307731773277337734773577367737773877397740774177427743774477457746774777487749775077517752775377547755775677577758775977607761776277637764776577667767776877697770777177727773777477757776777777787779778077817782778377847785778677877788778977907791779277937794779577967797779877997800780178027803780478057806780778087809781078117812781378147815781678177818781978207821782278237824782578267827782878297830783178327833783478357836783778387839784078417842784378447845784678477848784978507851785278537854785578567857785878597860786178627863786478657866786778687869787078717872787378747875787678777878787978807881788278837884788578867887788878897890789178927893789478957896789778987899790079017902790379047905790679077908790979107911791279137914791579167917791879197920792179227923792479257926792779287929793079317932793379347935793679377938793979407941794279437944794579467947794879497950795179527953795479557956795779587959796079617962796379647965796679677968796979707971797279737974797579767977797879797980798179827983798479857986798779887989799079917992799379947995799679977998799980008001800280038004800580068007800880098010801180128013801480158016801780188019802080218022802380248025802680278028802980308031803280338034803580368037803880398040804180428043804480458046804780488049805080518052805380548055805680578058805980608061806280638064806580668067806880698070807180728073807480758076807780788079808080818082808380848085808680878088808980908091809280938094809580968097809880998100810181028103810481058106810781088109811081118112811381148115811681178118811981208121812281238124812581268127812881298130813181328133813481358136813781388139814081418142814381448145814681478148814981508151815281538154815581568157815881598160816181628163816481658166816781688169817081718172817381748175817681778178817981808181818281838184818581868187818881898190819181928193819481958196819781988199820082018202820382048205820682078208820982108211821282138214821582168217821882198220822182228223822482258226822782288229823082318232823382348235823682378238823982408241824282438244824582468247824882498250825182528253825482558256825782588259826082618262826382648265826682678268826982708271827282738274827582768277827882798280828182828283828482858286828782888289829082918292829382948295829682978298829983008301830283038304830583068307830883098310831183128313831483158316831783188319832083218322832383248325832683278328832983308331833283338334833583368337833883398340834183428343834483458346834783488349835083518352835383548355835683578358835983608361836283638364836583668367836883698370837183728373837483758376837783788379838083818382838383848385838683878388838983908391839283938394839583968397839883998400840184028403840484058406840784088409841084118412841384148415841684178418841984208421842284238424842584268427842884298430843184328433843484358436843784388439844084418442844384448445844684478448844984508451845284538454845584568457845884598460846184628463846484658466846784688469847084718472847384748475847684778478847984808481848284838484848584868487848884898490849184928493849484958496849784988499850085018502850385048505850685078508850985108511851285138514851585168517851885198520852185228523852485258526852785288529853085318532853385348535853685378538853985408541854285438544854585468547854885498550855185528553855485558556855785588559856085618562856385648565856685678568856985708571857285738574857585768577857885798580858185828583858485858586858785888589859085918592859385948595859685978598859986008601860286038604860586068607860886098610861186128613861486158616861786188619862086218622862386248625862686278628862986308631863286338634863586368637863886398640864186428643864486458646864786488649865086518652865386548655865686578658865986608661866286638664866586668667866886698670867186728673867486758676867786788679868086818682868386848685868686878688868986908691869286938694869586968697869886998700870187028703870487058706870787088709871087118712871387148715871687178718871987208721872287238724872587268727872887298730873187328733873487358736873787388739874087418742874387448745874687478748874987508751875287538754875587568757875887598760876187628763876487658766876787688769877087718772877387748775877687778778877987808781878287838784878587868787878887898790879187928793879487958796879787988799880088018802880388048805880688078808880988108811881288138814881588168817881888198820882188228823882488258826882788288829883088318832883388348835883688378838883988408841884288438844884588468847884888498850885188528853885488558856885788588859886088618862886388648865886688678868886988708871887288738874887588768877887888798880888188828883888488858886888788888889889088918892889388948895889688978898889989008901890289038904890589068907890889098910891189128913891489158916891789188919892089218922892389248925892689278928892989308931893289338934893589368937893889398940894189428943894489458946894789488949895089518952895389548955895689578958895989608961896289638964896589668967896889698970897189728973897489758976897789788979898089818982898389848985898689878988898989908991899289938994899589968997899889999000900190029003900490059006900790089009901090119012901390149015901690179018901990209021902290239024902590269027902890299030903190329033903490359036903790389039904090419042904390449045904690479048904990509051905290539054905590569057905890599060906190629063906490659066906790689069907090719072907390749075907690779078907990809081908290839084908590869087908890899090909190929093909490959096909790989099910091019102910391049105910691079108910991109111911291139114911591169117911891199120912191229123912491259126912791289129913091319132913391349135913691379138913991409141914291439144914591469147914891499150915191529153915491559156915791589159916091619162916391649165916691679168916991709171917291739174917591769177917891799180918191829183918491859186918791889189919091919192
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Linq.Expressions;
  5. using System.Text.RegularExpressions;
  6. using AutoMapper;
  7. using Castle.Core.Internal;
  8. using Microsoft.Extensions.Logging;
  9. using Newtonsoft.Json;
  10. using SqlSugar;
  11. using SqlSugar.Extensions;
  12. using WCS.Entity.fj;
  13. using wms.dataservice.IDataSetvice;
  14. using wms.dto;
  15. using wms.dto.request;
  16. using wms.dto.request.fj;
  17. using wms.dto.request.hj;
  18. using wms.dto.request.share;
  19. using wms.dto.response;
  20. using wms.dto.response.fj;
  21. using wms.service.Extensions;
  22. using wms.service.IService;
  23. using wms.sqlsugar;
  24. using wms.sqlsugar.model;
  25. using wms.sqlsugar.model.fj;
  26. using wms.util.Check;
  27. using wms.util.Ext;
  28. using TaskStatus = wms.dto.TaskStatus;
  29. namespace wms.service.Service
  30. {
  31. /// <summary>
  32. /// 分拣服务
  33. /// </summary>
  34. public class FJService : IFJService
  35. {
  36. private static object lockInOrOut = new object();
  37. private readonly IFJDataService _IFJDataService;
  38. private readonly ILogger<FJService> _logger;
  39. private readonly IMapper _mapper;
  40. public FJService(IMapper mapper, ILogger<FJService> logger, IFJDataService IFJDataService)
  41. {
  42. _mapper = mapper;
  43. _logger = logger;
  44. _IFJDataService = IFJDataService;
  45. }
  46. private ITenant _db => SqlSugarHelper.Db; //处理事务
  47. /// <summary>
  48. /// 获取配置内容信息
  49. /// </summary>
  50. /// <param name="code">配置表code值</param>
  51. /// <returns></returns>
  52. public string GetSysConfigContentByCode(string code)
  53. {
  54. //先读缓存
  55. var cacheContent = RedisHelper.Get("sys_config" + code);
  56. if (!string.IsNullOrEmpty(cacheContent)) return cacheContent;
  57. var sysconf = _sysconfigrepository.GetSingle(p => p.Code == code);
  58. if (sysconf == null) throw new Exception("数据表没有配置" + code);
  59. var content = sysconf.SContent;
  60. var sysname = sysconf.Default1; //所属系统mes/erp
  61. RedisHelper.Set("sys_config" + code, content + "|" + sysname);
  62. return content;
  63. }
  64. /// <summary>
  65. /// 获取配置信息
  66. /// </summary>
  67. /// <param name="code"></param>
  68. /// <returns></returns>
  69. public fjSysConfig GetSysConfigByCode(string code)
  70. {
  71. return _sysconfigrepository.GetSingle(p => p.Code == code);
  72. }
  73. public fjSysJob GetSysJobEntity(DetailRequest2Str req)
  74. {
  75. return _jobRepository.GetFirst(p => p.Id == long.Parse(req.Id));
  76. }
  77. public fjSysJob GetSysJobEntityByCode(string Code)
  78. {
  79. return _jobRepository.GetSingle(p => p.Code == Code);
  80. }
  81. public List<fjSysJobApiRelation> GetSysApiDetail(long Id)
  82. {
  83. return _jobApiRepository.GetList(p => p.JobId == Id);
  84. }
  85. /// <summary>
  86. /// 创建货位,用于少数虚拟货位及平库
  87. /// </summary>
  88. /// <param name="WarehouseCode">仓库号</param>
  89. /// <param name="Code">货位号</param>
  90. /// <returns></returns>
  91. public SRes CreatWarecell(string WarehouseCode, string Code)
  92. {
  93. var res = new SRes();
  94. //找到对应的仓库
  95. var warehouse = _basewarehouserepository.GetFirst(x => x.Code == WarehouseCode);
  96. var wareCell = new BaseWarecell
  97. {
  98. WarehouseId = warehouse.Id,
  99. WarehouseCode = WarehouseCode,
  100. WareAreaId = 1669154208777113600,
  101. IsStop = 0,
  102. Code = Code,
  103. Name = Code,
  104. StateNum = FjLocationState.Empty,
  105. TypeNum = FjLocationType.Virtual,
  106. Size = 1,
  107. Row = 1,
  108. Col = 1,
  109. Layer = 1,
  110. Depth = 1,
  111. Tunnel = 1,
  112. SCRel = "芯股虚拟货位",
  113. ContGrpBarCode = "0",
  114. ContGrpId = 0,
  115. Shelf = "L",
  116. AddWho = "Admin",
  117. AddTime = DateTime.Now,
  118. EditWho = "Admin",
  119. EditTime = DateTime.Now,
  120. Memo = "芯股货架",
  121. GroupID = 0,
  122. XYNO = 0
  123. };
  124. _db.BeginTran();
  125. try
  126. {
  127. _basewarecellrepository.InsertReturnEntity(wareCell);
  128. }
  129. catch (Exception e)
  130. {
  131. _db.RollbackTran();
  132. _logger.LogInformation(e.Message);
  133. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  134. res.ResMsg = ResponseStatusCodeEnum.Fail.GetDescription();
  135. return res;
  136. }
  137. _db.CommitTran();
  138. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  139. res.ResMsg = ResponseStatusCodeEnum.Sucess.GetDescription();
  140. return res;
  141. }
  142. public List<fjSysJob> GetJobList()
  143. {
  144. return _jobRepository.GetList();
  145. }
  146. /// <summary>
  147. /// 获取配置信息
  148. /// </summary>
  149. /// <param name="code"></param>
  150. /// <returns></returns>
  151. public fjSysConfig GetSysConfigByExpression(Expression<Func<fjSysConfig, bool>> WhereExpression)
  152. {
  153. return _sysconfigrepository.GetSingle(WhereExpression);
  154. }
  155. /// <summary>
  156. /// 获取反馈信息
  157. /// </summary>
  158. /// <param name="code"></param>
  159. /// <returns></returns>
  160. public List<BillPushinfo> GetBillPushinfoList(Expression<Func<BillPushinfo, bool>> WhereExpression,
  161. bool type = false)
  162. {
  163. if (type)
  164. return _billPushinforepository.AsQueryable().Where(WhereExpression).OrderBy(x => x.AddTime).Take(1)
  165. .ToList();
  166. return _billPushinforepository.GetList(WhereExpression);
  167. }
  168. public bool UpdatePushModelColumns(UpdateModelColumns<BillPushinfo> updateModel)
  169. {
  170. return _billPushinforepository.Update(updateModel.Columns, updateModel.WhereExpression);
  171. }
  172. /// <summary>
  173. /// 更新SysConfig表字段
  174. /// </summary>
  175. /// <param name="updateModel"></param>
  176. /// <returns></returns>
  177. public bool UpdateSysConfigModelColumns(UpdateModelColumns<fjSysConfig> updateModel)
  178. {
  179. return _sysconfigrepository.Update(updateModel.Columns, updateModel.WhereExpression);
  180. }
  181. public List<BaseMatinfo> GetBaseMatinfoList(Expression<Func<BaseMatinfo, bool>> WhereExpression)
  182. {
  183. return _basematerrepository.GetList(WhereExpression);
  184. }
  185. /// <summary>
  186. /// 更新物料基础信息表
  187. /// </summary>
  188. /// <param name="updateModel"></param>
  189. /// <returns></returns>
  190. public bool UpdateMaterModelColumns(UpdateModelColumns<BaseMatinfo> updateModel)
  191. {
  192. return _basematerrepository.Update(updateModel.Columns, updateModel.WhereExpression);
  193. }
  194. public bool UpdateMaterModel(BaseMatinfo updateModel)
  195. {
  196. return _basematerrepository.Update(updateModel);
  197. }
  198. /// <summary>
  199. /// 更新BillPushinfo表字段
  200. /// </summary>
  201. /// <param name="updateModel"></param>
  202. /// <returns></returns>
  203. public bool UpdateBillPushinfoModelColumns(UpdateModelColumns<BillPushinfo> updateModel)
  204. {
  205. return _billPushinforepository.Update(updateModel.Columns, updateModel.WhereExpression);
  206. }
  207. public bool SyncMaterInfo(List<FJSyncMaterInfoResponseItem> ResData)
  208. {
  209. foreach (var item in ResData)
  210. {
  211. item.UpdatedTime = DateTime.Now;
  212. if (_basematerrepository.IsAny(p => p.Code == item.MatCode))
  213. {
  214. _basematerrepository.UpdateModelColumns(
  215. p => new BaseMatinfo
  216. {
  217. IsHold = item.IsHold, HoldDuration = item.HoldDuration, Name = item.MatName,
  218. EditTime = DateTime.Now, Description = item.Describe
  219. },
  220. p => p.Code == item.MatCode);
  221. }
  222. else
  223. {
  224. var model = _mapper.Map<BaseMatinfo>(item);
  225. model.AddTime = DateTime.Now;
  226. _basematerrepository.Insert(model);
  227. }
  228. }
  229. return true;
  230. }
  231. /// <summary>
  232. /// 帘线同步物料
  233. /// </summary>
  234. /// <param name="ResData"></param>
  235. /// <returns></returns>
  236. public bool SyncMaterInfoLX(List<SxSyncMaterInfoListRequestItem> ResData)
  237. {
  238. foreach (var item in ResData)
  239. if (_basematerrepository.IsAny(p => p.Code == item.MatCode))
  240. {
  241. _basematerrepository.UpdateModelColumns(
  242. p => new BaseMatinfo
  243. {
  244. IsHold = item.IsHold, HoldDuration = item.HoldDuration, Name = item.MatName,
  245. EditTime = DateTime.Now, Description = item.Describe
  246. },
  247. p => p.Code == item.MatCode);
  248. }
  249. else
  250. {
  251. var model = _mapper.Map<BaseMatinfo>(item);
  252. model.AddTime = DateTime.Now;
  253. _basematerrepository.Insert(model);
  254. }
  255. return true;
  256. }
  257. public SRes SyncMachineInfo(SyncMachineInfoRequest req)
  258. {
  259. if (_basemachinforepository.IsAny(p => p.MachNo == req.MachineCode))
  260. {
  261. _basemachinforepository.UpdateModelColumns(
  262. p => new BillMachinfo { Direction = req.VehicleDirection, EditTime = DateTime.Now },
  263. p => p.MachNo == req.MachineCode);
  264. }
  265. else
  266. {
  267. var model = _mapper.Map<BillMachinfo>(req);
  268. model.AddTime = DateTime.Now;
  269. model.EditTime = DateTime.Now;
  270. model.AddWho = "wms";
  271. model.EditWho = "wms";
  272. model.AddWho = "wms";
  273. model.EditWho = "wms";
  274. model.WarehouseCode = "";
  275. model.WarehouseId = 0;
  276. model.WarehouseSort = 0;
  277. model.Direction = "";
  278. model.WareAreaId = 0;
  279. model.IsStop = 0;
  280. model.GrpCode = "";
  281. model.Station = "";
  282. model.BillCode = "";
  283. model.WorkOrder = "";
  284. model.SetGrpCode = "";
  285. model.ProBillCode = "";
  286. model.ProWorkOrder = "";
  287. model.ProSetGrpCode = "";
  288. model.WareDirect = "";
  289. _basemachinforepository.Insert(model);
  290. }
  291. return new SRes();
  292. }
  293. /// <summary>
  294. /// 投料信息接收
  295. /// </summary>
  296. /// <param name="reqDto"></param>
  297. /// <returns></returns>
  298. public SRes WetFormulaInfo(WetFormulaInfoRequest reqDto)
  299. {
  300. var res = new SRes();
  301. //保存表Bill_BomInfo
  302. foreach (var item in reqDto.FeedList)
  303. {
  304. var procodelist = _billBominfoRepository.GetList(p => p.MatCode == item.InMaterialCode)
  305. .Select(p => p.ProCode).Distinct();
  306. if (procodelist.Any() && procodelist.Count() > 1)
  307. {
  308. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  309. res.ResMsg = item.InMaterialCode + "不允许率属于两个投料大类编码,接收失败";
  310. return res;
  311. }
  312. if (_billBominfoRepository.IsAny(p =>
  313. p.Code == reqDto.FeedCode && p.ProMatCode == item.OutMaterialCode &&
  314. p.MatCode == item.InMaterialCode))
  315. {
  316. //var mat = _basematerrepository.GetSingle(p => p.Code == item.InMaterialCode);
  317. //_billBominfoRepository.UpdateModelColumns(p => new BillBominfo() { MatCode = item.InMaterialCode, MatId = mat.Id, Name = item.InMaterialCode, HWCountQty = item.Count, EditTime = DateTime.Now },
  318. // p => p.Code == reqDto.FeedCode && p.MatCode == item.InMaterialCode);
  319. }
  320. else
  321. {
  322. var procode = string.Join('|',
  323. reqDto.FeedList.Where(p => p.OutMaterialCode == item.OutMaterialCode)
  324. .Select(p => p.InMaterialCode).OrderBy(p => p).ToList());
  325. var mat = _basematerrepository.GetSingle(p => p.Code == item.InMaterialCode);
  326. if (mat == null)
  327. {
  328. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  329. res.ResMsg = "投入料" + ResponseStatusCodeEnum.MaterInfoNotExist.GetDescription();
  330. return res;
  331. }
  332. var model = new BillBominfo
  333. {
  334. ProCode = procode,
  335. Code = reqDto.FeedCode,
  336. Name = reqDto.FeedName,
  337. MatCode = item.InMaterialCode,
  338. MatId = mat.Id,
  339. AddTime = DateTime.Now,
  340. AddWho = "wms",
  341. EditTime = DateTime.Now,
  342. EditWho = "wms",
  343. IsStop = 0,
  344. HWCountQty = item.Count,
  345. ProMatCode = item.OutMaterialCode,
  346. Memo = reqDto.Remark
  347. };
  348. model.AddTime = DateTime.Now;
  349. _billBominfoRepository.Insert(model);
  350. }
  351. }
  352. return res;
  353. }
  354. /// <summary>
  355. /// 帘线工单信息传输
  356. /// </summary>
  357. /// <param name="reqDto"></param>
  358. /// <returns></returns>
  359. public SRes CurtainProductionOrder(CurtainProductionOrderRequest reqDto)
  360. {
  361. var res = new SRes();
  362. //先判断是否有配方信息和物料基础信息
  363. var outmat = _basematerrepository.GetSingle(p => p.Code == reqDto.MatCode);
  364. if (outmat == null)
  365. {
  366. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  367. res.ResMsg = reqDto.MatCode + "不存在该物料基础信息,请先同步基础信息";
  368. return res;
  369. }
  370. var procode = string.Join('|', reqDto.FeedList.Select(p => p.InMaterialCode).OrderBy(p => p).ToList());
  371. if (reqDto.ProdFlag == 1)
  372. {
  373. var bominfo =_billBominfoRepository.GetFirst(p => p.Code == reqDto.FeedCode && p.ProMatCode == reqDto.MatCode);
  374. if (bominfo == null)
  375. {
  376. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  377. res.ResMsg = string.Format("当前产出为芯股,此芯股投料信息不存在请先同步投料信息,投料编码{0},产出物{1}", reqDto.FeedCode,
  378. reqDto.MatCode);
  379. return res;
  380. }
  381. procode = bominfo.ProCode;
  382. }
  383. BillBomsetgrp stack = null; //垛型固定获取最早更新的垛型
  384. //后续一个配方会有多个垛型
  385. if (reqDto.MatCode.StartsWith("57")) //是芯股
  386. {
  387. stack = _billBomsetgrpRepository.GetList(p =>
  388. (p.BomCode == procode || procode.Contains(p.BomCode)) && p.ProMaterCode.StartsWith("57") &&
  389. p.IsStop == 0)
  390. .OrderBy(x => x.EditTime).First();
  391. if (stack == null)
  392. {
  393. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  394. res.ResMsg = string.Format("{0}该单据配方没有垛型信息,请先配置垛型,bom编码{1},bom大类编码{2},产出物料{3}", reqDto.BillCode,
  395. reqDto.FeedCode, procode, reqDto.MatCode);
  396. return res;
  397. }
  398. }
  399. else //不是芯股
  400. {
  401. var stackList = _billBomsetgrpRepository.GetList(p =>
  402. (p.BomCode == procode || procode.Contains(p.BomCode)) && !p.ProMaterCode.StartsWith("57") &&
  403. p.IsStop == 0).ToList();
  404. stack = stackList.OrderBy(x => x.EditTime).First();
  405. if (stack == null)
  406. {
  407. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  408. res.ResMsg = string.Format("{0}该单据配方没有垛型信息,请先配置垛型,bom编码{1},bom大类编码{2},产出物料{3}", reqDto.BillCode,
  409. reqDto.FeedCode, procode, reqDto.MatCode);
  410. return res;
  411. }
  412. }
  413. var reqjson = JsonConvert.SerializeObject(reqDto);
  414. if (reqjson.Length > 5000) reqjson = "内容量过大,已截取";
  415. if (reqDto.BillState == CurtainBillState.初始化.GetHashCode().ToString() ||
  416. reqDto.BillState == CurtainBillState.已合并.GetHashCode().ToString() ||
  417. reqDto.BillState == CurtainBillState.已排产.GetHashCode().ToString())
  418. {
  419. var doc = _billdocrepository.GetSingle(p => p.DocsNo == reqDto.BillCode);
  420. if (doc == null)
  421. {
  422. doc = new BillDocsinfo();
  423. doc.WarehouseId = 0;
  424. doc.ReqNo = reqDto.BillCode;
  425. doc.DocsNo = reqDto.BillCode;
  426. doc.TypeNum = DocType.DocType_FJ_CurtainProduction.GetHashCode();
  427. doc.StateNum = DocState.DocState_Create.GetHashCode();
  428. doc.JsonContent = reqjson;
  429. doc.DownQty = 1;
  430. doc.IsStop = 0;
  431. doc.BomCode = reqDto.FeedCode;
  432. doc.ProMaterCode = reqDto.MatCode;
  433. doc.SetGrpCode = stack.Code;
  434. doc.WorkOrder = reqDto.WorkOrder;
  435. doc.SkuCode = reqDto.SkuCode;
  436. doc.PackRule = reqDto.PackRule;
  437. var docinsert = _billdocrepository.Insert(doc);
  438. if (!docinsert)
  439. {
  440. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  441. res.ResMsg = ResponseStatusCodeEnum.ErrParam.GetDescription();
  442. return res;
  443. }
  444. }
  445. _basemachinforepository.UpdateModelColumns(
  446. p => new BillMachinfo
  447. {
  448. ProBillCode = reqDto.BillCode, ProWorkOrder = reqDto.WorkOrder, ProSetGrpCode = stack.Code,
  449. EditTime = DateTime.Now
  450. }, p => reqDto.WbList.Contains(p.MachNo));
  451. //箱号处理
  452. //根据箱号更新装箱信息表
  453. }
  454. else if (reqDto.BillState == CurtainBillState.生产中.GetHashCode().ToString())
  455. {
  456. var doc = _billdocrepository.GetSingle(p => p.DocsNo == reqDto.BillCode);
  457. if (doc == null)
  458. {
  459. doc = new BillDocsinfo();
  460. doc.WarehouseId = 0;
  461. doc.ReqNo = reqDto.BillCode;
  462. doc.DocsNo = reqDto.BillCode;
  463. doc.TypeNum = DocType.DocType_FJ_CurtainProduction.GetHashCode();
  464. doc.StateNum = DocState.DocState_Execute.GetHashCode();
  465. doc.JsonContent = reqjson;
  466. doc.DownQty = 1;
  467. doc.IsStop = 0;
  468. doc.BomCode = reqDto.FeedCode;
  469. doc.ProMaterCode = reqDto.MatCode;
  470. doc.SetGrpCode = stack.Code;
  471. doc.WorkOrder = reqDto.WorkOrder;
  472. doc.SkuCode = reqDto.SkuCode;
  473. doc.PackRule = reqDto.PackRule;
  474. var docinsert = _billdocrepository.Insert(doc);
  475. if (!docinsert)
  476. {
  477. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  478. res.ResMsg = ResponseStatusCodeEnum.ErrParam.GetDescription();
  479. return res;
  480. }
  481. }
  482. var state = DocState.DocState_Execute.GetHashCode();
  483. _billdocrepository.UpdateModelColumns(
  484. p => new BillDocsinfo { StateNum = state, SetGrpCode = stack.Code },
  485. p => p.DocsNo == reqDto.BillCode);
  486. _basemachinforepository.UpdateModelColumns(
  487. p => new BillMachinfo
  488. {
  489. BillCode = reqDto.BillCode, WorkOrder = reqDto.WorkOrder, SetGrpCode = stack.Code,
  490. EditTime = DateTime.Now
  491. }, p => reqDto.WbList.Contains(p.MachNo));
  492. //箱号处理
  493. //根据箱号更新装箱信息表
  494. }
  495. else if (reqDto.BillState == CurtainBillState.生产结束.GetHashCode().ToString() ||
  496. reqDto.BillState == CurtainBillState.计划关闭.GetHashCode().ToString())
  497. {
  498. var state = DocState.DocState_Complete.GetHashCode();
  499. _billdocrepository.UpdateModelColumns(p => new BillDocsinfo { StateNum = state },
  500. p => p.DocsNo == reqDto.BillCode);
  501. }
  502. return res;
  503. }
  504. /// <summary>
  505. /// 湿拉工单启动验证
  506. /// </summary>
  507. /// <param name="reqDto"></param>
  508. /// <returns></returns>
  509. public SRes CurtainOrderStartCheck(CurtainOrderStartCheckRequest reqDto)
  510. {
  511. var res = new SRes();
  512. var doc = _billdocrepository.GetList(p => p.WorkOrder == reqDto.BillCode);
  513. if (doc == null || !doc.Any())
  514. {
  515. res.ResCode = 0;
  516. res.ResMsg = reqDto.BillCode + "工单不存在";
  517. return res;
  518. }
  519. if (doc.Any(p => string.IsNullOrEmpty(p.BomCode)))
  520. {
  521. res.ResCode = 0;
  522. res.ResMsg = reqDto.BillCode + "帘线工序工单没有配置垛型信息,请先配置垛型";
  523. return res;
  524. }
  525. return res;
  526. }
  527. public SRes ManualBuildEmptyStock(ManualBuildEmptyStockRequest request)
  528. {
  529. var result = new SRes();
  530. if (string.IsNullOrEmpty(request.ContGrpBarCode))
  531. {
  532. result.ResCode = ResponseStatusCodeEnum.ErrParamNotNull.GetHashCode();
  533. result.ResMsg = ResponseStatusCodeEnum.ErrParamNotNull.GetDescription();
  534. return result;
  535. }
  536. var mater = _basematerrepository.GetSingle(p => request.ContGrpBarCode.Substring(0, 3) == p.Code);
  537. if (mater == null)
  538. {
  539. result.ResCode = ResponseStatusCodeEnum.BaseMaterCodeNotExist.GetHashCode();
  540. result.ResMsg = request.ContGrpBarCode.Substring(0, 3) + "托盘类型不存在";
  541. return result;
  542. }
  543. var taskold = _wcstaskoldrepository.AsQueryable().With(SqlWith.NoLock)
  544. .Where(p => p.BarCode == request.ContGrpBarCode && p.Status < TaskStatus.Finish)
  545. .SplitTable(p => p.Take(2)).ToList();
  546. if (taskold.Any())
  547. {
  548. result.ResCode = ResponseStatusCodeEnum.WcsTaskExist.GetHashCode();
  549. result.ResMsg = request.ContGrpBarCode + ResponseStatusCodeEnum.WcsTaskExist.GetDescription() + "不允许绑定";
  550. return result;
  551. }
  552. var BarCode = _billInvnowrepository.GetSingle(p => p.ContGrpBarCode == request.ContGrpBarCode);
  553. if (BarCode != null && BarCode?.InvStateCode == InvState.InvEcecState_In.ToString())
  554. {
  555. result.ResCode = ResponseStatusCodeEnum.BarcodeContainerRepeat.GetHashCode();
  556. result.ResMsg = request.ContGrpBarCode + ResponseStatusCodeEnum.BarcodeContainerRepeat.GetDescription();
  557. return result;
  558. }
  559. if (BarCode != null && BarCode?.InvStateCode == InvState.InvEcecState_BuildUp.ToString())
  560. {
  561. result.ResCode = ResponseStatusCodeEnum.GroupStockDetailMaterialBarCodeExist.GetHashCode();
  562. result.ResMsg = request.ContGrpBarCode +
  563. ResponseStatusCodeEnum.GroupStockDetailMaterialBarCodeExist.GetDescription();
  564. return result;
  565. }
  566. if (BarCode != null)
  567. {
  568. result.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  569. result.ResMsg = request.ContGrpBarCode + "存在库存信息,请先处理遗留的库存信息";
  570. return result;
  571. }
  572. //空托盘
  573. var code = _baseContinfo.GetSingle(p => p.ContBarCode == request.ContGrpBarCode);
  574. if (code == null)
  575. {
  576. var init = new BaseContinfo
  577. {
  578. ContBarCode = request.ContGrpBarCode,
  579. Name = mater.Name,
  580. IsStop = 0,
  581. WarehouseId = 0,
  582. TypeCode = "1",
  583. PrintQty = 1,
  584. AddWho = "wms",
  585. EditWho = "wms"
  586. };
  587. _baseContinfo.Insert(init);
  588. }
  589. try
  590. {
  591. var nov = new BillInvnow
  592. {
  593. WarehouseId = 0,
  594. ContGrpBarCode = request.ContGrpBarCode,
  595. ContGrpId = IdFactory.NewId(),
  596. BoxBarCode = "",
  597. InvStateCode = InvState.InvEcecState_BuildUp.ToString(),
  598. ExecStateCode = InvLockState.InvState_Normal.ToString(),
  599. MatId = mater.Id,
  600. MatCode = mater.Code,
  601. MatName = mater.Name,
  602. RFIDBarCode = request.ContGrpBarCode,
  603. HWBarCode = request.ContGrpBarCode,
  604. HWTypeCode = "",
  605. InvInOut = FJInvInOutType.In,
  606. Size = 2,
  607. ContGrpType = FJContGrpType.EmptyCon,
  608. LengthQty = request.Count //存放托盘数量
  609. };
  610. _db.BeginTran();
  611. _billInvnowrepository.Insert(nov);
  612. _billInvflow.Insert(_mapper.Map<BillInvflow>(nov));
  613. _db.CommitTran();
  614. }
  615. catch (Exception ex)
  616. {
  617. _db.RollbackTran();
  618. result.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  619. result.ResMsg = request.ContGrpBarCode + ResponseStatusCodeEnum.DataSaveErr.GetDescription();
  620. return result;
  621. }
  622. return result;
  623. }
  624. /// <summary>
  625. /// 获取工字轮流向(江锦调用)
  626. /// </summary>
  627. /// <param name="reqDto"></param>
  628. /// <returns></returns>
  629. public SRes<string> AllocatedSpoolFlow(AllocatedSpoolFlowRequest reqDto)
  630. {
  631. var spoolbar = _billSpoolTransrepository.AsQueryable().With(SqlWith.NoLock)
  632. .Where(p => p.ConBarCode == reqDto.SpoolBarCode).OrderByDescending(x => x.AddTime).First();
  633. if (spoolbar == null)
  634. {
  635. var error = new BaseErrorInfo
  636. {
  637. BusName = "江景获取流向",
  638. Message = $"{reqDto.SpoolBarCode}没有工字轮信息,{DateTime.Now:yyyyMMddHH}",
  639. Count = 1,
  640. Memo = "WCS"
  641. };
  642. error.UpdataErrorinfo(_baseErrorInfoRepository);
  643. return new SRes<string>
  644. {
  645. ResMsg = reqDto.SpoolBarCode + "没有工字轮信息",
  646. ResData = "",
  647. ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode()
  648. };
  649. }
  650. //验证产品等级与下线时间
  651. var invInt = _billInvinitrepository.AsQueryable().With(SqlWith.NoLock)
  652. .Single(x => x.HWBarCode == spoolbar.ConBarCode);
  653. if (invInt == null)
  654. {
  655. var error = new BaseErrorInfo
  656. {
  657. BusName = "江景获取流向",
  658. Message = $"{reqDto.SpoolBarCode}没有工字轮信息,{DateTime.Now:yyyyMMddHH}",
  659. Count = 1,
  660. Memo = "WCS"
  661. };
  662. error.UpdataErrorinfo(_baseErrorInfoRepository);
  663. return new SRes<string>
  664. {
  665. ResMsg = reqDto.SpoolBarCode + "没有工字轮条码信息",
  666. ResData = "",
  667. ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode()
  668. };
  669. }
  670. if (invInt.Grade != "A")
  671. {
  672. var error = new BaseErrorInfo
  673. {
  674. BusName = "江景获取流向",
  675. Message = $"{reqDto.SpoolBarCode}-{invInt.Grade}质量,进入BC区,{DateTime.Now:yyyyMMddHH}",
  676. Count = 1,
  677. Memo = "WCS"
  678. };
  679. error.UpdataErrorinfo(_baseErrorInfoRepository);
  680. return new SRes<string>
  681. {
  682. ResMsg = $"{invInt.Grade}质量,进入BC区",
  683. ResData = "",
  684. ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode()
  685. };
  686. }
  687. if (invInt.ProductTime < DateTime.Now.AddHours(-12))
  688. {
  689. var error = new BaseErrorInfo
  690. {
  691. BusName = "江景获取流向",
  692. Message = $"{reqDto.SpoolBarCode}生产时间超时十二小时,{DateTime.Now:yyyyMMddHH}",
  693. Count = 1,
  694. Memo = "WCS"
  695. };
  696. error.UpdataErrorinfo(_baseErrorInfoRepository);
  697. return new SRes<string>
  698. {
  699. ResMsg = "生产时间超时十二小时",
  700. ResData = "",
  701. ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode()
  702. };
  703. }
  704. return new SRes<string>
  705. {
  706. ResMsg = "成功",
  707. ResData = spoolbar.Direct,
  708. ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode()
  709. };
  710. }
  711. /// <summary>
  712. /// 取分流异常的结果
  713. /// </summary>
  714. /// <param name="reqDto"></param>
  715. /// <returns></returns>
  716. public SRes QueryFlowDirectionExceptions(GetFlowExceptionResultsRequest reqDto)
  717. {
  718. var res = new SRes();
  719. //时间处理
  720. var prodate = reqDto.ProductDate.GetDateTime(_logger).AddMinutes(-1);
  721. //是否有异常
  722. if (_baseErrorInfoRepository.AsQueryable().With(SqlWith.NoLock)
  723. .Any(x => x.Message.Contains(reqDto.qrCode) && x.AddTime > prodate))
  724. {
  725. var regInfo = _baseErrorInfoRepository.AsQueryable().With(SqlWith.NoLock).First(x =>
  726. x.BusName.Contains("湿拉下盘注册") && x.Message.Contains(reqDto.qrCode) && x.AddTime > prodate);
  727. if (regInfo != null) //表示此工字轮注册时失败
  728. {
  729. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  730. res.ResMsg = regInfo.Message + $"[{reqDto.ProductDate}]";
  731. return res;
  732. }
  733. var flow = _baseErrorInfoRepository.AsQueryable().With(SqlWith.NoLock).First(x =>
  734. x.BusName.Contains("江景获取流向") && x.Message.Contains(reqDto.qrCode) && x.AddTime > prodate);
  735. if (flow != null) //表示此工字轮获取流向时出现的错误结果
  736. {
  737. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  738. res.ResMsg = flow.Message + $"[{reqDto.ProductDate}]";
  739. return res;
  740. }
  741. }
  742. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  743. res.ResMsg = ResponseStatusCodeEnum.Sucess.GetDescription();
  744. return res;
  745. }
  746. /// <summary>
  747. /// 人工创建满托入库任务
  748. /// </summary>
  749. /// <param name="reqDto"></param>
  750. /// <returns></returns>
  751. public SRes CreateMaterialPalletWarehouTask(CreateMaterialPalletWarehouTaskRequest reqDto)
  752. {
  753. var res = new SRes { ResCode = ResponseStatusCodeEnum.Fail.GetHashCode(), ResMsg = "失败" };
  754. var taskMax = Convert.ToInt32(_sysconfigrepository.AsQueryable().With(SqlWith.NoLock)
  755. .First(x => x.Code == "FullPalletInMax").SContent);
  756. var taskCount = _taskrepository.AsQueryable().With(SqlWith.NoLock).Count(x =>
  757. x.BusType == FJTaskBusType.人工满托入库.GetDescription() && x.Status < TaskStatus.Finish);
  758. if (string.IsNullOrEmpty(reqDto.LocCode))
  759. {
  760. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  761. res.ResMsg = "站台编号不可为空,请扫描站台编号!!!!!!";
  762. return res;
  763. }
  764. if (string.IsNullOrEmpty(reqDto.TrayCode))
  765. {
  766. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  767. res.ResMsg = "托盘条码不可为空,请扫描托盘条码!!!!!!";
  768. return res;
  769. }
  770. //获取工字轮任务信息
  771. var taskInfo = _taskrepository.AsQueryable().With(SqlWith.NoLock)
  772. .First(x => x.BarCode == reqDto.TrayCode && x.Status < TaskStatus.Finish);
  773. if (taskInfo != null)
  774. {
  775. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  776. res.ResMsg = reqDto.TrayCode + "已有任务,请联系智能制造人员进行处理!!!!!!";
  777. return res;
  778. }
  779. //托盘
  780. var container = _baseContinfo.GetSingle(p => p.ContBarCode == reqDto.TrayCode);
  781. if (container == null)
  782. {
  783. var insertcon = new BaseContinfo
  784. {
  785. ContBarCode = reqDto.TrayCode,
  786. Name = reqDto.TrayCode,
  787. TypeCode = ContainerType.ContainerType_Spool.ToString(),
  788. PrintQty = 1,
  789. IsStop = 0,
  790. WarehouseId = 0,
  791. WeightQty = 0,
  792. AddWho = "wms",
  793. AddTime = DateTime.Now
  794. };
  795. //新加载具信息
  796. if (!_baseContinfo.Insert(insertcon))
  797. {
  798. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  799. res.ResMsg = "托盘载具初始化失败";
  800. return res;
  801. }
  802. }
  803. //工字轮
  804. var spoolNr = _baseContinfo.GetSingle(p => p.ContBarCode == reqDto.SpoolNr);
  805. if (spoolNr == null)
  806. {
  807. var insertcon = new BaseContinfo
  808. {
  809. ContBarCode = reqDto.TrayCode,
  810. Name = reqDto.TrayCode,
  811. TypeCode = ContainerType.ContainerType_Spool.ToString(),
  812. PrintQty = 1,
  813. IsStop = 0,
  814. WarehouseId = 0,
  815. WeightQty = 0,
  816. AddWho = "wms",
  817. AddTime = DateTime.Now
  818. };
  819. //新加载具信息
  820. if (!_baseContinfo.Insert(insertcon))
  821. {
  822. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  823. res.ResMsg = "工字轮载具初始化失败";
  824. return res;
  825. }
  826. }
  827. //物料
  828. var mater = _basematerrepository.GetSingle(p => p.Code == reqDto.InMaterialCode);
  829. if (mater == null)
  830. {
  831. res.ResCode = ResponseStatusCodeEnum.MaterInfoNotExist.GetHashCode();
  832. res.ResMsg = ResponseStatusCodeEnum.MaterInfoNotExist.GetDescription();
  833. return res;
  834. }
  835. //工字轮库存
  836. var stock = _billInvnowrepository.GetSingle(p => p.HWBarCode == reqDto.SpoolNr);
  837. if (stock != null && stock.InvStateCode == InvState.InvEcecState_In.ToString())
  838. {
  839. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  840. res.ResMsg = "该工字轮条码号已在库中,请检查RFID号是否重复";
  841. return res;
  842. }
  843. if (stock != null && stock.InvStateCode == InvState.InvEcecState_OutGoing.ToString())
  844. {
  845. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  846. res.ResMsg = "该工字轮条码号存在出库中任务,请检查上一个任务是否已经完成";
  847. return res;
  848. }
  849. //托盘库存
  850. var trayCode = _billInvnowrepository.GetSingle(p => p.ContGrpBarCode == reqDto.TrayCode);
  851. if (trayCode != null && trayCode.InvStateCode == InvState.InvEcecState_In.ToString())
  852. {
  853. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  854. res.ResMsg = "该工字轮条码号已在库中,请检查RFID号是否重复";
  855. return res;
  856. }
  857. if (trayCode != null && trayCode.InvStateCode == InvState.InvEcecState_OutGoing.ToString())
  858. {
  859. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  860. res.ResMsg = "该工字轮条码号存在出库中任务,请检查上一个任务是否已经完成";
  861. return res;
  862. }
  863. //通过投入物料找到垛型编码
  864. var stackdetail =
  865. _billBomsetinfoRepository.GetFirst(p => p.MatCode == reqDto.InMaterialCode && p.IsStop == 0);
  866. if (stackdetail == null)
  867. {
  868. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  869. res.ResMsg = reqDto.SpoolNr + "没有对应的垛型信息,物料编码" + reqDto.InMaterialCode;
  870. return res;
  871. }
  872. //获取垛型主表
  873. var stack = _BillBomsetgrpRepository.GetSingle(p => p.Id == stackdetail.BomSetHdrId && p.IsStop == 0);
  874. //获取工字轮任务信息
  875. var task = _taskrepository.AsQueryable().With(SqlWith.NoLock).First(x => x.BarCode == reqDto.SpoolNr);
  876. if (task == null)
  877. {
  878. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  879. res.ResMsg = reqDto.SpoolNr + "没有组盘任务,请从新注册";
  880. return res;
  881. }
  882. //工字轮条码信息
  883. var barInfo = _billInvinitrepository.GetFirst(p => p.HWBarCode == reqDto.SpoolNr);
  884. if (barInfo == null)
  885. {
  886. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  887. res.ResMsg = reqDto.SpoolNr + "没有条码信息";
  888. return res;
  889. }
  890. try
  891. {
  892. _db.BeginTran();
  893. //更新条码信息
  894. _billInvinitrepository.UpdateModelColumns(p => new BillInvinit
  895. {
  896. ContGrpBarCode = reqDto.TrayCode,
  897. EditTime = DateTime.Now
  898. }, p => p.HWBarCode == reqDto.SpoolNr);
  899. //删除因异常导致残留的对应库存信息
  900. _billInvnowrepository.Delete(x => x.ContGrpBarCode == reqDto.TrayCode || x.HWBarCode == reqDto.SpoolNr);
  901. barInfo.ContGrpBarCode = reqDto.TrayCode;
  902. //创建库存信息
  903. //将条码表映射到库存表
  904. var invnow = _mapper.Map<BillInvnow>(barInfo);
  905. invnow.IsTorsChk = true;
  906. invnow.AddTime = DateTime.Now;
  907. invnow.Id = IdFactory.NewId();
  908. if (!_billInvnowrepository.Insert(invnow))
  909. {
  910. _db.RollbackTran();
  911. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  912. res.ResMsg = "人工满轮入库存储库存失败";
  913. return res;
  914. }
  915. //删除这个任务的阻盘记录
  916. var taskIdList = _taskrepository.AsQueryable().With(SqlWith.NoLock)
  917. .Where(x => x.BarCode == reqDto.SpoolNr).Select(x => x.ID).ToList();
  918. if (taskIdList != null)
  919. {
  920. //删除当前任务与更新历史任务
  921. _taskrepository.Delete(x => taskIdList.Contains(x.ID));
  922. _wcstaskoldrepository.UpdateSplitTableModelColumns(x => new WCS_TaskOld
  923. {
  924. Status = TaskStatus.Cancel,
  925. ManualRemarks = "人工满托入库,清除信息"
  926. }, x => taskIdList.Contains(x.Id));
  927. //TODO:入库算法
  928. //TODO:出库算法
  929. //TODO:最优验证算法
  930. }
  931. //判断对应仓库中空货位数量
  932. var invnowCount_1N = _basewarecellrepository.AsQueryable().With(SqlWith.NoLock).Count(x =>
  933. x.WarehouseCode == "1N" && x.IsStop == 0 && x.StateNum == FjLocationState.Empty && x.Layer < 9);
  934. var invnowCount_2N = _basewarecellrepository.AsQueryable().With(SqlWith.NoLock).Count(x =>
  935. x.WarehouseCode == "2N" && x.IsStop == 0 && x.StateNum == FjLocationState.Empty && x.Layer < 9);
  936. var taskInfoCount_1N = _taskrepository.AsQueryable().With(SqlWith.NoLock).Count(x =>
  937. x.Status < TaskStatus.Finish && x.BusType == FJTaskBusType.人工满托入库.GetDescription() &&
  938. x.WarehouseCode == "1N");
  939. var taskInfoCount_2N = _taskrepository.AsQueryable().With(SqlWith.NoLock).Count(x =>
  940. x.Status < TaskStatus.Finish && x.BusType == FJTaskBusType.人工满托入库.GetDescription() &&
  941. x.WarehouseCode == "2N");
  942. //创建对应任务
  943. var count_1N = invnowCount_1N - taskInfoCount_1N;
  944. var count_2N = invnowCount_2N - taskInfoCount_2N;
  945. var wCode = count_1N >= count_2N ? "1N" : "2N";
  946. if ( taskCount > 0)
  947. if ((wCode == "1N" && taskMax <= taskInfoCount_1N) ||
  948. (wCode == "2N" && taskMax <= taskInfoCount_2N))
  949. {
  950. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  951. res.ResMsg = $"禁止入库,最大入库任务数量已达{taskMax}";
  952. return res;
  953. }
  954. //创建入库记录
  955. var createStockInWcsTaskReqest = new FJCreateStockInWcsTaskRequest
  956. {
  957. BusType = FJTaskBusType.人工满托入库.GetDescription(),
  958. ContGrpBarCode = reqDto.TrayCode,
  959. Qty = 1,
  960. Floor = 2,
  961. MatCode = reqDto.InMaterialCode,
  962. EquCode = reqDto.LocCode,
  963. Type = TaskType.EnterDepot,
  964. DocCode = "",
  965. WorkBench = task.WorkBench,
  966. WarehouseCode = wCode /*(count_1N <= count_2N) ? "1N" : "2N"*/
  967. };
  968. //下发wcs任务 - 分解方法
  969. var taskRes = CreateStockInWcsTask(createStockInWcsTaskReqest, task.Grade, true);
  970. if (taskRes.ResCode != 200)
  971. {
  972. _db.RollbackTran();
  973. res.ResCode = taskRes.ResCode;
  974. res.ResMsg = taskRes.ResMsg;
  975. return res;
  976. }
  977. _db.CommitTran();
  978. }
  979. catch (Exception ex)
  980. {
  981. _db.RollbackTran();
  982. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  983. res.ResMsg = ex.StackTrace;
  984. return res;
  985. }
  986. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  987. res.ResMsg = ResponseStatusCodeEnum.Sucess.ToString();
  988. return res;
  989. }
  990. /// <summary>
  991. /// 人工创建UT满托入库任务
  992. /// </summary>
  993. /// <param name="reqDto"></param>
  994. /// <returns></returns>
  995. public SRes CreateMaterialUTPalletWarehouTask(CreateMaterialPalletWarehouTaskRequest reqDto)
  996. {
  997. var res = new SRes { ResCode = ResponseStatusCodeEnum.Fail.GetHashCode(), ResMsg = "失败" };
  998. var taskMax = Convert.ToInt32(_sysconfigrepository.AsQueryable().With(SqlWith.NoLock)
  999. .First(x => x.Code == "UTFullPalletInMax").SContent);
  1000. var taskCount = _taskrepository.AsQueryable().With(SqlWith.NoLock).Count(x =>
  1001. x.BusType == FJTaskBusType.UT人工满托入库.GetDescription() && x.Status < TaskStatus.Finish);
  1002. if (string.IsNullOrEmpty(reqDto.LocCode))
  1003. {
  1004. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1005. res.ResMsg = "站台编号不可为空,请扫描站台编号!!!!!!";
  1006. return res;
  1007. }
  1008. if (string.IsNullOrEmpty(reqDto.TrayCode))
  1009. {
  1010. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1011. res.ResMsg = "托盘条码不可为空,请扫描托盘条码!!!!!!";
  1012. return res;
  1013. }
  1014. //获取工字轮任务信息
  1015. var taskInfo = _taskrepository.AsQueryable().With(SqlWith.NoLock)
  1016. .First(x => x.BarCode == reqDto.TrayCode && x.Status < TaskStatus.Finish);
  1017. if (taskInfo != null)
  1018. {
  1019. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1020. res.ResMsg = reqDto.TrayCode + "已有任务,请联系智能制造人员进行处理!!!!!!";
  1021. return res;
  1022. }
  1023. //托盘
  1024. var container = _baseContinfo.GetSingle(p => p.ContBarCode == reqDto.TrayCode);
  1025. if (container == null)
  1026. {
  1027. var insertcon = new BaseContinfo
  1028. {
  1029. ContBarCode = reqDto.TrayCode,
  1030. Name = reqDto.TrayCode,
  1031. TypeCode = ContainerType.ContainerType_Spool.ToString(),
  1032. PrintQty = 1,
  1033. IsStop = 0,
  1034. WarehouseId = 0,
  1035. WeightQty = 0,
  1036. AddWho = "wms",
  1037. AddTime = DateTime.Now
  1038. };
  1039. //新加载具信息
  1040. if (!_baseContinfo.Insert(insertcon))
  1041. {
  1042. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  1043. res.ResMsg = "托盘载具初始化失败";
  1044. return res;
  1045. }
  1046. }
  1047. //工字轮
  1048. var spoolNr = _baseContinfo.GetSingle(p => p.ContBarCode == reqDto.SpoolNr);
  1049. if (spoolNr == null)
  1050. {
  1051. var insertcon = new BaseContinfo
  1052. {
  1053. ContBarCode = reqDto.TrayCode,
  1054. Name = reqDto.TrayCode,
  1055. TypeCode = ContainerType.ContainerType_Spool.ToString(),
  1056. PrintQty = 1,
  1057. IsStop = 0,
  1058. WarehouseId = 0,
  1059. WeightQty = 0,
  1060. AddWho = "wms",
  1061. AddTime = DateTime.Now
  1062. };
  1063. //新加载具信息
  1064. if (!_baseContinfo.Insert(insertcon))
  1065. {
  1066. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  1067. res.ResMsg = "工字轮载具初始化失败";
  1068. return res;
  1069. }
  1070. }
  1071. //物料
  1072. var mater = _basematerrepository.GetSingle(p => p.Code == reqDto.InMaterialCode);
  1073. if (mater == null)
  1074. {
  1075. res.ResCode = ResponseStatusCodeEnum.MaterInfoNotExist.GetHashCode();
  1076. res.ResMsg = ResponseStatusCodeEnum.MaterInfoNotExist.GetDescription();
  1077. return res;
  1078. }
  1079. //工字轮库存
  1080. var stock = _billInvnowrepository.GetSingle(p => p.HWBarCode == reqDto.SpoolNr);
  1081. if (stock != null && stock.InvStateCode == InvState.InvEcecState_In.ToString())
  1082. {
  1083. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1084. res.ResMsg = "该工字轮条码号已在库中,请检查RFID号是否重复";
  1085. return res;
  1086. }
  1087. if (stock != null && stock.InvStateCode == InvState.InvEcecState_OutGoing.ToString())
  1088. {
  1089. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1090. res.ResMsg = "该工字轮条码号存在出库中任务,请检查上一个任务是否已经完成";
  1091. return res;
  1092. }
  1093. //托盘库存
  1094. var trayCode = _billInvnowrepository.GetSingle(p => p.ContGrpBarCode == reqDto.TrayCode);
  1095. if (trayCode != null && trayCode.InvStateCode == InvState.InvEcecState_In.ToString())
  1096. {
  1097. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1098. res.ResMsg = "该工字轮条码号已在库中,请检查RFID号是否重复";
  1099. return res;
  1100. }
  1101. if (trayCode != null && trayCode.InvStateCode == InvState.InvEcecState_OutGoing.ToString())
  1102. {
  1103. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1104. res.ResMsg = "该工字轮条码号存在出库中任务,请检查上一个任务是否已经完成";
  1105. return res;
  1106. }
  1107. //通过投入物料找到垛型编码
  1108. var stackdetail =
  1109. _billBomsetinfoRepository.GetFirst(p => p.MatCode == reqDto.InMaterialCode && p.IsStop == 0);
  1110. if (stackdetail == null)
  1111. {
  1112. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1113. res.ResMsg = reqDto.SpoolNr + "没有对应的垛型信息,物料编码" + reqDto.InMaterialCode;
  1114. return res;
  1115. }
  1116. //获取垛型主表
  1117. var stack = _BillBomsetgrpRepository.GetSingle(p => p.Id == stackdetail.BomSetHdrId && p.IsStop == 0);
  1118. //获取工字轮任务信息
  1119. var task = _taskrepository.AsQueryable().With(SqlWith.NoLock).First(x => x.BarCode == reqDto.SpoolNr);
  1120. if (task == null)
  1121. {
  1122. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1123. res.ResMsg = reqDto.SpoolNr + "没有组盘任务,请从新注册";
  1124. return res;
  1125. }
  1126. //工字轮条码信息
  1127. var barInfo = _billInvinitrepository.GetFirst(p => p.HWBarCode == reqDto.SpoolNr);
  1128. if (barInfo == null)
  1129. {
  1130. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1131. res.ResMsg = reqDto.SpoolNr + "没有条码信息";
  1132. return res;
  1133. }
  1134. try
  1135. {
  1136. _db.BeginTran();
  1137. //更新条码信息
  1138. _billInvinitrepository.UpdateModelColumns(p => new BillInvinit
  1139. {
  1140. ContGrpBarCode = reqDto.TrayCode,
  1141. EditTime = DateTime.Now
  1142. }, p => p.HWBarCode == reqDto.SpoolNr);
  1143. //删除因异常导致残留的对应库存信息
  1144. _billInvnowrepository.Delete(x => x.ContGrpBarCode == reqDto.TrayCode || x.HWBarCode == reqDto.SpoolNr);
  1145. barInfo.ContGrpBarCode = reqDto.TrayCode;
  1146. //创建库存信息
  1147. //将条码表映射到库存表
  1148. var invnow = _mapper.Map<BillInvnow>(barInfo);
  1149. invnow.IsTorsChk = true;
  1150. invnow.AddTime = DateTime.Now;
  1151. invnow.Id = IdFactory.NewId();
  1152. if (!_billInvnowrepository.Insert(invnow))
  1153. {
  1154. _db.RollbackTran();
  1155. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  1156. res.ResMsg = "人工满轮入库存储库存失败";
  1157. return res;
  1158. }
  1159. //删除这个任务的阻盘记录
  1160. var taskIdList = _taskrepository.AsQueryable().With(SqlWith.NoLock)
  1161. .Where(x => x.BarCode == reqDto.SpoolNr).Select(x => x.ID).ToList();
  1162. if (taskIdList != null)
  1163. {
  1164. //删除当前任务与更新历史任务
  1165. _taskrepository.Delete(x => taskIdList.Contains(x.ID));
  1166. _wcstaskoldrepository.UpdateSplitTableModelColumns(x => new WCS_TaskOld
  1167. {
  1168. Status = TaskStatus.Cancel,
  1169. ManualRemarks = "人工满托入库,清除信息"
  1170. }, x => taskIdList.Contains(x.Id));
  1171. //TODO:入库算法
  1172. //TODO:出库算法
  1173. //TODO:最优验证算法
  1174. }
  1175. //判断对应仓库中空货位数量
  1176. var invnowCount_1N = _basewarecellrepository.AsQueryable().With(SqlWith.NoLock).Count(x =>
  1177. x.WarehouseCode == "1N" && x.IsStop == 0 && x.StateNum == FjLocationState.Empty && x.Layer < 9);
  1178. var invnowCount_2N = _basewarecellrepository.AsQueryable().With(SqlWith.NoLock).Count(x =>
  1179. x.WarehouseCode == "2N" && x.IsStop == 0 && x.StateNum == FjLocationState.Empty && x.Layer < 9);
  1180. var taskInfoCount_1N = _taskrepository.AsQueryable().With(SqlWith.NoLock).Count(x =>
  1181. x.Status < TaskStatus.Finish && x.BusType == FJTaskBusType.人工满托入库.GetDescription() &&
  1182. x.WarehouseCode == "1N");
  1183. var taskInfoCount_2N = _taskrepository.AsQueryable().With(SqlWith.NoLock).Count(x =>
  1184. x.Status < TaskStatus.Finish && x.BusType == FJTaskBusType.人工满托入库.GetDescription() &&
  1185. x.WarehouseCode == "2N");
  1186. //创建对应任务
  1187. var count_1N = invnowCount_1N - taskInfoCount_1N;
  1188. var count_2N = invnowCount_2N - taskInfoCount_2N;
  1189. var wCode = count_1N >= count_2N ? "1N" : "2N";
  1190. if (taskMax > 0 && taskCount > 0)
  1191. if ((wCode == "1N" && taskMax <= taskInfoCount_1N) ||
  1192. (wCode == "2N" && taskMax <= taskInfoCount_2N))
  1193. {
  1194. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1195. res.ResMsg = $"禁止入库,最大入库任务数量已达{taskMax}";
  1196. return res;
  1197. }
  1198. //创建入库记录
  1199. var createStockInWcsTaskReqest = new FJCreateStockInWcsTaskRequest
  1200. {
  1201. BusType = FJTaskBusType.UT人工满托入库.GetDescription(),
  1202. ContGrpBarCode = reqDto.TrayCode,
  1203. Qty = 1,
  1204. Floor = 2,
  1205. MatCode = reqDto.InMaterialCode,
  1206. EquCode = reqDto.LocCode,
  1207. Type = TaskType.EnterDepot,
  1208. DocCode = "",
  1209. WorkBench = task.WorkBench,
  1210. WarehouseCode = wCode /*(count_1N <= count_2N) ? "1N" : "2N"*/
  1211. };
  1212. //下发wcs任务 - 分解方法
  1213. var taskRes = CreateStockInWcsTask(createStockInWcsTaskReqest, task.Grade, true);
  1214. if (taskRes.ResCode != 200)
  1215. {
  1216. _db.RollbackTran();
  1217. res.ResCode = taskRes.ResCode;
  1218. res.ResMsg = taskRes.ResMsg;
  1219. return res;
  1220. }
  1221. _db.CommitTran();
  1222. }
  1223. catch (Exception ex)
  1224. {
  1225. _db.RollbackTran();
  1226. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1227. res.ResMsg = ex.StackTrace;
  1228. return res;
  1229. }
  1230. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  1231. res.ResMsg = ResponseStatusCodeEnum.Sucess.ToString();
  1232. return res;
  1233. }
  1234. /// <summary>
  1235. /// 芯股满托创建库存信息
  1236. /// </summary>
  1237. /// <param name="reqDto"></param>
  1238. /// <returns></returns>
  1239. public SRes CreateMaterialPalletWarehouTask1(CreateMaterialPalletWarehouTask1Request reqDto)
  1240. {
  1241. var res = new SRes { ResCode = ResponseStatusCodeEnum.Fail.GetHashCode(), ResMsg = "失败" };
  1242. //获取工字轮任务信息
  1243. var taskInfo = _taskrepository.AsQueryable().With(SqlWith.NoLock)
  1244. .First(x => x.BarCode == reqDto.TrayCode && x.Status < TaskStatus.Finish);
  1245. if (taskInfo != null)
  1246. {
  1247. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1248. res.ResMsg = reqDto.TrayCode + "已有任务,请联系智能制造人员进行处理!!!!!!";
  1249. return res;
  1250. }
  1251. //托盘
  1252. var container = _baseContinfo.GetSingle(p => p.ContBarCode == reqDto.TrayCode);
  1253. if (container == null)
  1254. {
  1255. var insertcon = new BaseContinfo
  1256. {
  1257. ContBarCode = reqDto.TrayCode,
  1258. Name = reqDto.TrayCode,
  1259. TypeCode = ContainerType.ContainerType_Spool.ToString(),
  1260. PrintQty = 1,
  1261. IsStop = 0,
  1262. WarehouseId = 0,
  1263. WeightQty = 0,
  1264. AddWho = "wms",
  1265. AddTime = DateTime.Now
  1266. };
  1267. //新加载具信息
  1268. if (!_baseContinfo.Insert(insertcon))
  1269. {
  1270. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  1271. res.ResMsg = "托盘载具初始化失败";
  1272. return res;
  1273. }
  1274. }
  1275. //工字轮
  1276. var spoolNr = _baseContinfo.GetSingle(p => p.ContBarCode == reqDto.SpoolNr);
  1277. if (spoolNr == null)
  1278. {
  1279. var insertcon = new BaseContinfo
  1280. {
  1281. ContBarCode = reqDto.TrayCode,
  1282. Name = reqDto.TrayCode,
  1283. TypeCode = ContainerType.ContainerType_Spool.ToString(),
  1284. PrintQty = 1,
  1285. IsStop = 0,
  1286. WarehouseId = 0,
  1287. WeightQty = 0,
  1288. AddWho = "wms",
  1289. AddTime = DateTime.Now
  1290. };
  1291. //新加载具信息
  1292. if (!_baseContinfo.Insert(insertcon))
  1293. {
  1294. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  1295. res.ResMsg = "工字轮载具初始化失败";
  1296. return res;
  1297. }
  1298. }
  1299. //物料
  1300. var mater = _basematerrepository.GetSingle(p => p.Code == reqDto.InMaterialCode);
  1301. if (mater == null)
  1302. {
  1303. res.ResCode = ResponseStatusCodeEnum.MaterInfoNotExist.GetHashCode();
  1304. res.ResMsg = ResponseStatusCodeEnum.MaterInfoNotExist.GetDescription();
  1305. return res;
  1306. }
  1307. //工字轮库存
  1308. var stock = _billInvnowrepository.GetSingle(p => p.HWBarCode == reqDto.SpoolNr);
  1309. if (stock != null && stock.InvStateCode == InvState.InvEcecState_In.ToString())
  1310. {
  1311. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1312. res.ResMsg = "该工字轮条码号已在库中,请检查RFID号是否重复";
  1313. return res;
  1314. }
  1315. if (stock != null && stock.InvStateCode == InvState.InvEcecState_OutGoing.ToString())
  1316. {
  1317. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1318. res.ResMsg = "该工字轮条码号存在出库中任务,请检查上一个任务是否已经完成";
  1319. return res;
  1320. }
  1321. //托盘库存
  1322. var trayCode = _billInvnowrepository.GetSingle(p => p.ContGrpBarCode == reqDto.TrayCode);
  1323. if (trayCode != null && trayCode.InvStateCode == InvState.InvEcecState_In.ToString())
  1324. {
  1325. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1326. res.ResMsg = "该工字轮条码号已在库中,请检查RFID号是否重复";
  1327. return res;
  1328. }
  1329. if (trayCode != null && trayCode.InvStateCode == InvState.InvEcecState_OutGoing.ToString())
  1330. {
  1331. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1332. res.ResMsg = "该工字轮条码号存在出库中任务,请检查上一个任务是否已经完成";
  1333. return res;
  1334. }
  1335. //通过投入物料找到垛型编码
  1336. var stackdetail =
  1337. _billBomsetinfoRepository.GetFirst(p => p.MatCode == reqDto.InMaterialCode && p.IsStop == 0);
  1338. if (stackdetail == null)
  1339. {
  1340. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1341. res.ResMsg = reqDto.SpoolNr + "没有对应的垛型信息,物料编码" + reqDto.InMaterialCode;
  1342. return res;
  1343. }
  1344. //获取垛型主表
  1345. var stack = _BillBomsetgrpRepository.GetSingle(p => p.Id == stackdetail.BomSetHdrId && p.IsStop == 0);
  1346. //获取工字轮任务信息
  1347. var task = _taskrepository.AsQueryable().With(SqlWith.NoLock).First(x => x.BarCode == reqDto.SpoolNr);
  1348. if (task == null)
  1349. {
  1350. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1351. res.ResMsg = reqDto.SpoolNr + "没有组盘任务,请从新注册";
  1352. return res;
  1353. }
  1354. //工字轮条码信息
  1355. var barInfo = _billInvinitrepository.GetFirst(p => p.HWBarCode == reqDto.SpoolNr);
  1356. if (barInfo == null)
  1357. {
  1358. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1359. res.ResMsg = reqDto.SpoolNr + "没有条码信息";
  1360. return res;
  1361. }
  1362. //对应货位是否存在
  1363. var wareCell = _basewarecellrepository.GetFirst(p => p.Code == reqDto.LocCode);
  1364. if (wareCell == null)
  1365. {
  1366. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1367. res.ResMsg = reqDto.LocCode + "没有货位信息";
  1368. return res;
  1369. }
  1370. //判断货位是否已经存储
  1371. if (wareCell.StateNum != FjLocationState.Empty)
  1372. {
  1373. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1374. res.ResMsg = $"货位{reqDto.LocCode}状态不是空,当前状态位{wareCell.StateNum.GetDescription()},请联系相关人员进行处理!!!";
  1375. return res;
  1376. }
  1377. try
  1378. {
  1379. _db.BeginTran();
  1380. //更新条码信息
  1381. _billInvinitrepository.UpdateModelColumns(p => new BillInvinit
  1382. {
  1383. ContGrpBarCode = reqDto.TrayCode,
  1384. EditTime = DateTime.Now
  1385. }, p => p.HWBarCode == reqDto.SpoolNr);
  1386. //删除因异常导致残留的对应库存信息
  1387. _billInvnowrepository.Delete(x => x.ContGrpBarCode == reqDto.TrayCode || x.HWBarCode == reqDto.SpoolNr);
  1388. wareCell.ContGrpBarCode = reqDto.TrayCode;
  1389. //创建库存信息
  1390. //将条码表映射到库存表
  1391. var invnow = _mapper.Map<BillInvnow>(barInfo);
  1392. invnow.IsTorsChk = true;
  1393. invnow.AddTime = DateTime.Now;
  1394. invnow.InvStateCode = FJInvState.InvEcecState_In.ToString();
  1395. invnow.ContGrpBarCode = reqDto.TrayCode;
  1396. invnow.Id = IdFactory.NewId();
  1397. invnow.WarehouseId = wareCell.WarehouseId;
  1398. if (!_billInvnowrepository.Insert(invnow))
  1399. {
  1400. _db.RollbackTran();
  1401. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  1402. res.ResMsg = "芯股满托存储库存失败";
  1403. return res;
  1404. }
  1405. //存储进入对应的货位
  1406. //更新条码信息
  1407. _basewarecellrepository.UpdateModelColumns(p => new BaseWarecell
  1408. {
  1409. ContGrpBarCode = reqDto.TrayCode,
  1410. ContGrpId = invnow.ContGrpId,
  1411. StateNum = FjLocationState.Full,
  1412. EditTime = DateTime.Now
  1413. }, p => p.Code == reqDto.LocCode);
  1414. _db.CommitTran();
  1415. }
  1416. catch (Exception ex)
  1417. {
  1418. _db.RollbackTran();
  1419. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1420. res.ResMsg = ex.StackTrace;
  1421. return res;
  1422. }
  1423. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  1424. res.ResMsg = ResponseStatusCodeEnum.Sucess.ToString();
  1425. return res;
  1426. }
  1427. /// <summary>
  1428. /// 重绕区组盘信息
  1429. /// </summary>
  1430. /// <param name="reqDto"></param>
  1431. /// <returns></returns>
  1432. public SRes CreateMaterialPalletWarehouTask2(RewindFullPalletTaskRequest reqDto)
  1433. {
  1434. var res = new SRes { ResCode = ResponseStatusCodeEnum.Fail.GetHashCode(), ResMsg = "失败" };
  1435. //获取工字轮任务信息
  1436. var taskInfo = _taskrepository.AsQueryable().With(SqlWith.NoLock)
  1437. .First(x => x.BarCode == reqDto.TrayCode && x.Status < TaskStatus.Finish);
  1438. if (taskInfo != null)
  1439. {
  1440. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1441. res.ResMsg = reqDto.TrayCode + "已有任务,请联系智能制造人员进行处理!!!!!!";
  1442. return res;
  1443. }
  1444. //托盘
  1445. var container = _baseContinfo.GetSingle(p => p.ContBarCode == reqDto.TrayCode);
  1446. if (container == null)
  1447. {
  1448. var insertcon = new BaseContinfo
  1449. {
  1450. ContBarCode = reqDto.TrayCode,
  1451. Name = reqDto.TrayCode,
  1452. TypeCode = ContainerType.ContainerType_Spool.ToString(),
  1453. PrintQty = 1,
  1454. IsStop = 0,
  1455. WarehouseId = 0,
  1456. WeightQty = 0,
  1457. AddWho = "wms",
  1458. AddTime = DateTime.Now
  1459. };
  1460. //新加载具信息
  1461. if (!_baseContinfo.Insert(insertcon))
  1462. {
  1463. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  1464. res.ResMsg = "托盘载具初始化失败";
  1465. return res;
  1466. }
  1467. }
  1468. //托盘库存
  1469. var trayCode = _billInvnowrepository.GetFirst(p => p.ContGrpBarCode == reqDto.TrayCode);
  1470. if (trayCode != null && trayCode.InvStateCode == InvState.InvEcecState_BuildUp.ToString())
  1471. {
  1472. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1473. res.ResMsg = $"{reqDto.TrayCode}已有组盘信息,请确认库存信息";
  1474. return res;
  1475. }
  1476. if (trayCode != null && trayCode.InvStateCode == InvState.InvEcecState_In.ToString())
  1477. {
  1478. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1479. res.ResMsg = "该托盘条码号已在库中,请检查条码号是否重复";
  1480. return res;
  1481. }
  1482. if (trayCode != null && trayCode.InvStateCode == InvState.InvEcecState_OutGoing.ToString())
  1483. {
  1484. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1485. res.ResMsg = "该托盘条码号存在出库中任务,请检查上一个任务是否已经完成";
  1486. return res;
  1487. }
  1488. var SpoolNoGroup = reqDto.SpoolGroup.Select(x => x.SpoolCode).ToList();
  1489. var stackHeaderSet = new List<BillBomsetgrp>();
  1490. var matCodes = "";
  1491. #region 校验工字轮信息并获取对应垛型
  1492. foreach (var spool in reqDto.SpoolGroup)
  1493. {
  1494. var spoolNr = _baseContinfo.GetSingle(p => p.ContBarCode == spool.SpoolCode);
  1495. if (spoolNr == null)
  1496. {
  1497. var insertcon = new BaseContinfo
  1498. {
  1499. ContBarCode = spool.SpoolCode,
  1500. Name = spool.SpoolCode,
  1501. TypeCode = ContainerType.ContainerType_Spool.ToString(),
  1502. PrintQty = 1,
  1503. IsStop = 0,
  1504. WarehouseId = 0,
  1505. WeightQty = 0,
  1506. AddWho = "wms",
  1507. AddTime = DateTime.Now
  1508. };
  1509. //新加载具信息
  1510. if (!_baseContinfo.Insert(insertcon))
  1511. {
  1512. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  1513. res.ResMsg = "工字轮载具初始化失败";
  1514. return res;
  1515. }
  1516. }
  1517. //物料
  1518. var mater = _basematerrepository.GetSingle(p => p.Code == spool.MatCode);
  1519. if (mater == null)
  1520. {
  1521. res.ResCode = ResponseStatusCodeEnum.MaterInfoNotExist.GetHashCode();
  1522. res.ResMsg = ResponseStatusCodeEnum.MaterInfoNotExist.GetDescription();
  1523. return res;
  1524. }
  1525. //工字轮库存
  1526. var stock = _billInvnowrepository.GetSingle(p => p.HWBarCode == spool.SpoolCode);
  1527. if (stock != null && stock.InvStateCode == InvState.InvEcecState_In.ToString())
  1528. {
  1529. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1530. res.ResMsg = "该工字轮条码号已在库中,请检查工字轮条码号是否重复";
  1531. return res;
  1532. }
  1533. if (stock != null && stock.InvStateCode == InvState.InvEcecState_OutGoing.ToString())
  1534. {
  1535. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1536. res.ResMsg = "该工字轮条码号存在出库中任务,请检查上一个任务是否已经完成";
  1537. return res;
  1538. }
  1539. //通过投入物料找到垛型编码
  1540. var stackDetail = _billBomsetinfoRepository.GetFirst(p => p.MatCode == spool.MatCode && p.IsStop == 0);
  1541. if (stackDetail == null)
  1542. {
  1543. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1544. res.ResMsg = reqDto.SpoolGroup + "没有对应的垛型信息,物料编码" + spool.MatCode;
  1545. return res;
  1546. }
  1547. //获取垛型主表
  1548. var stack = _BillBomsetgrpRepository.GetSingle(p => p.Id == stackDetail.BomSetHdrId && p.IsStop == 0);
  1549. var mat = _basematerrepository.GetSingle(p => p.Code == spool.MatCode);
  1550. if (mat != null && string.IsNullOrEmpty(matCodes))
  1551. {
  1552. matCodes += mat.Code;
  1553. }
  1554. else if(mat != null && !string.IsNullOrEmpty(matCodes) && !matCodes.Contains(mat.Code))
  1555. {
  1556. matCodes += "," + mat.Code;
  1557. }
  1558. stackHeaderSet.Add(stack);
  1559. }
  1560. //if (stackHeaderSet.GroupBy(x => x.Id).Count() != 1)
  1561. //{
  1562. // res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1563. // res.ResMsg = "扫描托盘不属于同一个垛型,请手动处理后重新组盘";
  1564. // return res;
  1565. //}
  1566. #endregion
  1567. var stackHeader = stackHeaderSet.First();
  1568. try
  1569. {
  1570. _db.BeginTran();
  1571. #region 删除所有工字轮信息,并创建新信息
  1572. _billInvinitrepository.Delete(x => SpoolNoGroup.Contains(x.ContGrpBarCode));
  1573. _billSpoolTransrepository.Delete(x => SpoolNoGroup.Contains(x.ConBarCode));
  1574. var materiel = _basematerrepository.GetSingle(p => p.Code == stackHeader.ProMaterCode);
  1575. var wareHouse = _basewarehouserepository.GetFirst(x => x.Code == "CRZP"); //TODO:1换成满托平库满盘Code
  1576. var barInfoList = new List<BillInvinit>();
  1577. var invNowList = new List<BillInvnow>();
  1578. var invFlowList = new List<BillInvflow>();
  1579. foreach (var spool in reqDto.SpoolGroup)
  1580. {
  1581. var mater = _basematerrepository.GetSingle(p => p.Code == spool.MatCode);
  1582. //工字轮需要用到的托盘类型
  1583. var fJPalletType = FJPalletType.Pallet09;
  1584. if (spool.SpoolType != "WS09") fJPalletType = FJPalletType.PalletNo09;
  1585. var barinfo = InitInvinitInfo(spool, wareHouse, stackHeader, mater, materiel, fJPalletType);
  1586. barInfoList.Add(barinfo);
  1587. //删除因异常导致残留的对应库存信息
  1588. _billInvnowrepository.Delete(x =>
  1589. x.ContGrpBarCode == barinfo.ContGrpBarCode || x.HWBarCode == barinfo.ContGrpBarCode);
  1590. //将条码表映射到库存表
  1591. var invnow = _mapper.Map<BillInvnow>(barinfo);
  1592. invnow.IsTorsChk = true;
  1593. invnow.AddTime = DateTime.Now;
  1594. invnow.InvStateCode = FJInvState.InvEcecState_BuildUp.ToString();
  1595. invnow.ContGrpBarCode = reqDto.TrayCode;
  1596. invnow.Id = IdFactory.NewId();
  1597. invnow.WarehouseId = wareHouse.Id;
  1598. invnow.MatCode = matCodes;
  1599. invnow.Memo = mater.Code;
  1600. invNowList.Add(invnow);
  1601. }
  1602. if (!_billInvinitrepository.InsertRange(barInfoList))
  1603. {
  1604. _db.RollbackTran();
  1605. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  1606. res.ResMsg = "重绕满托存储条码信息失败";
  1607. return res;
  1608. }
  1609. if (!_billInvnowrepository.InsertRange(invNowList))
  1610. {
  1611. _db.RollbackTran();
  1612. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  1613. res.ResMsg = "重绕满托存储库存信息失败";
  1614. return res;
  1615. }
  1616. //if (!_billInvflow.InsertRange(invFlowList))
  1617. //{
  1618. // _db.RollbackTran();
  1619. // res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  1620. // res.ResMsg = "重绕满托存储库存流水信息失败";
  1621. // return res;
  1622. //}
  1623. //创建入库记录
  1624. var createStockInWcsTaskReqest = new FJCreateStockInWcsTaskRequest
  1625. {
  1626. BusType = FJTaskBusType.重绕满托入库.GetDescription(),
  1627. ContGrpBarCode = reqDto.TrayCode,
  1628. Qty = 1,
  1629. Floor = 1,
  1630. MatCode = "",
  1631. EquCode = "",
  1632. Type = TaskType.EnterDepot,
  1633. DocCode = "",
  1634. WorkBench = "",
  1635. WarehouseCode = wareHouse.Code
  1636. };
  1637. //下发wcs任务 - 分解方法
  1638. var taskRes = CreateStockInWcsTask(createStockInWcsTaskReqest, "A", true);
  1639. if (taskRes.ResCode != 200)
  1640. {
  1641. _db.RollbackTran();
  1642. res.ResCode = taskRes.ResCode;
  1643. res.ResMsg = taskRes.ResMsg;
  1644. return res;
  1645. }
  1646. _db.CommitTran();
  1647. #endregion
  1648. }
  1649. catch (Exception e)
  1650. {
  1651. _db.RollbackTran();
  1652. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1653. res.ResMsg = e.Message;
  1654. return res;
  1655. }
  1656. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  1657. res.ResMsg = ResponseStatusCodeEnum.Sucess.ToString();
  1658. return res;
  1659. }
  1660. /// <summary>
  1661. /// 创建退料任务
  1662. /// </summary>
  1663. /// <param name="reqDto"></param>
  1664. /// <returns></returns>
  1665. public SRes MaterialReturnTaskCreator(MaterialReturnTaskCreatorRequest reqDto)
  1666. {
  1667. var res = new SRes { ResCode = ResponseStatusCodeEnum.Fail.GetHashCode(), ResMsg = "失败" };
  1668. var taskMaxNum = Convert.ToInt32(_sysconfigrepository.AsQueryable().With(SqlWith.NoLock)
  1669. .First(x => x.Code == "CRBackNum").SContent);
  1670. var taskNum = _taskrepository.AsQueryable().With(SqlWith.NoLock)
  1671. .Count(x => x.BusType == FJTaskBusType.帘线退料重绕.GetDescription() && x.Status < TaskStatus.Finish);
  1672. if ( taskMaxNum <= taskNum)
  1673. {
  1674. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1675. res.ResMsg = $"任务数量已达{taskNum},请稍后再操作!!!!!!";
  1676. return res;
  1677. }
  1678. var taskInfo = _taskrepository.AsQueryable().With(SqlWith.NoLock)
  1679. .First(x => x.BarCode == reqDto.TrayCode && x.Status < TaskStatus.Finish);
  1680. if (taskInfo != null)
  1681. {
  1682. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1683. res.ResMsg = reqDto.TrayCode + "已有任务,不要重复申请,请联系智能制造人员确认处理!!!!!!";
  1684. return res;
  1685. }
  1686. //托盘
  1687. var container = _baseContinfo.GetSingle(p => p.ContBarCode == reqDto.TrayCode);
  1688. if (container == null)
  1689. {
  1690. var insertcon = new BaseContinfo
  1691. {
  1692. ContBarCode = reqDto.TrayCode,
  1693. Name = reqDto.TrayCode,
  1694. TypeCode = ContainerType.ContainerType_Spool.ToString(),
  1695. PrintQty = 1,
  1696. IsStop = 0,
  1697. WarehouseId = 0,
  1698. WeightQty = 0,
  1699. AddWho = "wms",
  1700. AddTime = DateTime.Now
  1701. };
  1702. //新加载具信息
  1703. if (!_baseContinfo.Insert(insertcon))
  1704. {
  1705. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  1706. res.ResMsg = "托盘载具初始化失败";
  1707. return res;
  1708. }
  1709. }
  1710. //托盘库存
  1711. var trayCode = _billInvnowrepository.GetSingle(p => p.ContGrpBarCode == reqDto.TrayCode);
  1712. if (trayCode != null && trayCode.InvStateCode == InvState.InvEcecState_In.ToString())
  1713. {
  1714. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1715. res.ResMsg = "该托盘条码号已在库中,请检查条码号是否重复";
  1716. return res;
  1717. }
  1718. if (trayCode != null && trayCode.InvStateCode == InvState.InvEcecState_OutGoing.ToString())
  1719. {
  1720. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1721. res.ResMsg = "该托盘条码号存在出库中任务,请检查上一个任务是否已经完成";
  1722. return res;
  1723. }
  1724. var mac = _basemachinforepository.GetFirst(x => x.MachNo == reqDto.LocCode);
  1725. try
  1726. {
  1727. _db.BeginTran();
  1728. var wareHouse = _basewarehouserepository.GetFirst(x => x.Code == "CRTL"); //TODO:1换成退料平库满盘Code
  1729. //创建入库记录
  1730. var createStockInWcsTaskReqest = new FJCreateStockInWcsTaskRequest
  1731. {
  1732. BusType = FJTaskBusType.帘线退料重绕.GetDescription(),
  1733. ContGrpBarCode = reqDto.TrayCode,
  1734. Qty = 1,
  1735. Floor = 1,
  1736. MatCode = "",
  1737. EquCode = mac.Station,
  1738. Type = TaskType.EnterDepot,
  1739. DocCode = "",
  1740. WorkBench = mac.Station, //TODO:是否是AGV站台
  1741. WarehouseCode = wareHouse.Code
  1742. };
  1743. //下发wcs任务 - 分解方法
  1744. var taskRes = CreateStockInWcsTask(createStockInWcsTaskReqest, "A", true);
  1745. if (taskRes.ResCode != 200)
  1746. {
  1747. _db.RollbackTran();
  1748. res.ResCode = taskRes.ResCode;
  1749. res.ResMsg = taskRes.ResMsg;
  1750. return res;
  1751. }
  1752. _db.CommitTran();
  1753. }
  1754. catch (Exception e)
  1755. {
  1756. _db.RollbackTran();
  1757. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1758. res.ResMsg = e.StackTrace;
  1759. return res;
  1760. }
  1761. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  1762. res.ResMsg = ResponseStatusCodeEnum.Sucess.ToString();
  1763. return res;
  1764. }
  1765. public SRes ManualBuildStockTrans(ManualBuildStockTransRequest reqDto)
  1766. {
  1767. var res = new SRes();
  1768. return res;
  1769. }
  1770. /// <summary>
  1771. /// 分配分拣库
  1772. /// </summary>
  1773. /// <returns></returns>
  1774. public bool AllocationWarehouseSort(AllocationWarehouseSortRequest reqDto)
  1775. {
  1776. return true;
  1777. }
  1778. /// <summary>
  1779. /// agv状态同步接口
  1780. /// </summary>
  1781. /// <param name="reqDto">请求信息</param>
  1782. /// <returns></returns>
  1783. public AgvCallbackResponse AgvCallback(AgvCallbackRequest reqDto)
  1784. {
  1785. var res = new AgvCallbackResponse { code = AgvResponseCode.Error, message = "失败" };
  1786. try
  1787. {
  1788. _db.BeginTran();
  1789. //跟据AGVid找到对应的AGV任务
  1790. var agvTask = _agvTaskInfoRepository.AsQueryable().With(SqlWith.RowLock)
  1791. .SplitTable(tabs => tabs.Take(2))
  1792. .First(v => v.AgvID == reqDto.taskCode && v.Status < AGVTaskStatus.MissionCompleted);
  1793. if (agvTask == null)
  1794. {
  1795. _db.RollbackTran();
  1796. res.code = AgvResponseCode.Fail;
  1797. res.message = "未找到对应的AGV任务";
  1798. return res;
  1799. }
  1800. switch (reqDto.method)
  1801. {
  1802. case "applyContinue": //表示请求巷道
  1803. agvTask.AgvStatus = AGVTaskStatus.RequestOrPermission1;
  1804. break;
  1805. case "outbin": //小车退出取货位
  1806. agvTask.AgvStatus = AGVTaskStatus.LeaveGet;
  1807. break;
  1808. case "applySecurity": //表示请求放货或取货
  1809. agvTask.AgvStatus = AGVTaskStatus.RequestOrPermission2;
  1810. break;
  1811. case "applySecurityPut": //表示请求放货或取货
  1812. agvTask.AgvStatus = AGVTaskStatus.PutRequestOrPermission;
  1813. break;
  1814. case "FJend": //任务完成
  1815. agvTask.AgvStatus = AGVTaskStatus.MissionCompleted;
  1816. break;
  1817. case "cancel": //取消任务
  1818. if (agvTask.TaskType == AGVTaskType.EnterDepot) agvTask.AgvStatus = AGVTaskStatus.Cancel;
  1819. break;
  1820. }
  1821. //更新agv任务状态
  1822. if (!_agvTaskInfoRepository.UpdateSplitTableModelColumns(x => new WCS_AgvTaskInfo
  1823. {
  1824. AgvStatus = agvTask.AgvStatus
  1825. }, x => x.ID == agvTask.ID && x.AgvID == agvTask.AgvID))
  1826. {
  1827. _db.RollbackTran();
  1828. res.code = AgvResponseCode.Fail;
  1829. res.message = $"agv任务{agvTask.AgvID}更新状态至{agvTask.AgvStatus}失败";
  1830. return res;
  1831. }
  1832. _db.CommitTran();
  1833. res.code = AgvResponseCode.Success;
  1834. res.message = "成功";
  1835. }
  1836. catch (Exception ex)
  1837. {
  1838. _db.RollbackTran();
  1839. res.code = AgvResponseCode.Error;
  1840. res.message = ex.Message;
  1841. }
  1842. return res;
  1843. }
  1844. /// <summary>
  1845. /// 帘线领料出库
  1846. /// </summary>
  1847. /// <param name="reqDto"></param>
  1848. /// <returns></returns>
  1849. public SRes CurtainProductionStockOut(CurtainProductionStockOutRequest reqDto)
  1850. {
  1851. var res = new SRes();
  1852. var agvMaxSm = Convert.ToInt32(_sysconfigrepository.AsQueryable().With(SqlWith.NoLock)
  1853. .First(x => x.Code == "AGVSendsMaxQuantity").SContent);
  1854. var agvMaxFk = Convert.ToInt32(_sysconfigrepository.AsQueryable().With(SqlWith.NoLock)
  1855. .First(x => x.Code == "AGVMaxNumberEmptyRetur").SContent);
  1856. var agvSmNumber = _agvTaskInfoRepository.AsQueryable().With(SqlWith.NoLock)
  1857. .Where(x => x.AgvStatus < AGVTaskStatus.MissionCompleted && x.TaskType == AGVTaskType.CallMaterial)
  1858. .SplitTable(x => x.Take(2)).Count();
  1859. var agvFkNumber = _agvTaskInfoRepository.AsQueryable().With(SqlWith.NoLock)
  1860. .Where(x => x.AgvStatus < AGVTaskStatus.MissionCompleted && x.TaskType == AGVTaskType.EnterDepot)
  1861. .SplitTable(x => x.Take(2)).Count();
  1862. var waitingTask = _taskrepository.AsQueryable().With(SqlWith.NoLock)
  1863. .Where(x => x.BusType == FJTaskBusType.车间叫料.GetDescription() && x.Status == TaskStatus.WaitingToExecute)
  1864. .Count();
  1865. switch (reqDto.Type)
  1866. {
  1867. case "1":
  1868. if (agvMaxSm <= agvSmNumber)
  1869. {
  1870. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1871. res.ResMsg = $"禁止叫料,最大送满任务已达{agvSmNumber}";
  1872. return res;
  1873. }
  1874. if (agvMaxFk <= agvFkNumber)
  1875. {
  1876. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1877. res.ResMsg = $"禁止叫料,最大返空任务已达{agvFkNumber}";
  1878. return res;
  1879. }
  1880. if (agvMaxSm <= waitingTask)
  1881. {
  1882. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1883. res.ResMsg = $"禁止叫料,最大待执行叫料任务已达{waitingTask}";
  1884. return res;
  1885. }
  1886. break;
  1887. case "2":
  1888. if (agvMaxFk <= agvFkNumber)
  1889. {
  1890. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1891. res.ResMsg = $"禁止叫料,最大返空任务已达{agvFkNumber}";
  1892. return res;
  1893. }
  1894. break;
  1895. case "3":
  1896. if (agvMaxSm <= agvSmNumber)
  1897. {
  1898. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1899. res.ResMsg = $"禁止叫料,最大送满任务已达{agvSmNumber}";
  1900. return res;
  1901. }
  1902. if (agvMaxSm <= waitingTask)
  1903. {
  1904. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  1905. res.ResMsg = $"禁止叫料,最大待执行叫料任务已达{waitingTask}";
  1906. return res;
  1907. }
  1908. break;
  1909. }
  1910. if (reqDto.Type == "1" || reqDto.Type == "3")
  1911. {
  1912. var doc = _billdocrepository.GetSingle(p => p.DocsNo == reqDto.BillCode);
  1913. if (doc == null)
  1914. {
  1915. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  1916. res.ResMsg = reqDto.BillCode + "工单信息不存在";
  1917. return res;
  1918. }
  1919. //获取机台信息
  1920. var mach = _basemachinforepository.GetSingle(x => x.MachNo == reqDto.WbCode);
  1921. if (mach == null || string.IsNullOrEmpty(mach.Station))
  1922. {
  1923. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  1924. res.ResMsg = reqDto.WbCode + "机台号没有配置AGV点位坐标";
  1925. return res;
  1926. }
  1927. //找到所有的立库货位
  1928. var warehouse = _basewarehouserepository.GetList(x => x.TypeNum == FjLocationType.Storage)
  1929. .Select(x => x.Id).ToList();
  1930. var task = _wcstaskoldrepository.AsQueryable().With(SqlWith.NoLock)
  1931. .Where(p => p.WorkBench == mach.Station && p.Status < TaskStatus.Finish)
  1932. .SplitTable(tabs => tabs.Take(2));
  1933. if (task != null && task.Any())
  1934. {
  1935. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  1936. res.ResMsg = mach.Station + "站台号存在进行中的任务,不要重复申请";
  1937. return res;
  1938. }
  1939. var setGrpCode = reqDto.TypeCode;
  1940. if (setGrpCode.IsNullOrEmpty()) setGrpCode = doc.SetGrpCode;
  1941. //获取所有的立库有货库位信息
  1942. var wareCellList = _basewarecellrepository.Context.Queryable<BaseWarecell, BillInvnow>((loc, inv) =>
  1943. new object[] { JoinType.Inner, loc.ContGrpBarCode == inv.ContGrpBarCode })
  1944. .Where((loc, inv) => warehouse.Contains(loc.WarehouseId) &&
  1945. loc.StateNum == FjLocationState.Full &&
  1946. inv.InvStateCode == InvState.InvEcecState_In.ToString() &&
  1947. inv.SetGrpCode == setGrpCode &&
  1948. (!inv.Secondary || inv.ProductTime < DateTime.Now.AddHours(-6)))
  1949. .Where((loc, inv) => inv.IsTorsChk == false)
  1950. .Select((loc, inv) => new
  1951. {
  1952. locId = loc.Id,
  1953. loc.ContGrpBarCode,
  1954. loc.WarehouseId,
  1955. loc.WarehouseCode,
  1956. loc.Code,
  1957. loc.Row,
  1958. loc.Col,
  1959. loc.Layer,
  1960. loc.Depth,
  1961. loc.EditTime,
  1962. inv.MatCode,
  1963. inv.SideNum,
  1964. inv.CLBarCode,
  1965. inv.ProductTime,
  1966. invId = inv.Id
  1967. }).ToList().DistinctBy(x => x.ContGrpBarCode).ToList();
  1968. if (!wareCellList.Any())
  1969. {
  1970. res.ResCode = ResponseStatusCodeEnum.NotEnoughStock.GetHashCode();
  1971. res.ResMsg = ResponseStatusCodeEnum.NotEnoughStock.GetDescription();
  1972. return res;
  1973. }
  1974. var warehouseCodes = new List<string>();
  1975. switch (mach.WarehouseCode)
  1976. {
  1977. case "1N":
  1978. warehouseCodes.AddRange(new List<string> { "1N", "1S", "2N", "2S", "3N", "3S" });
  1979. break;
  1980. case "1S":
  1981. warehouseCodes.AddRange(new List<string> { "1S", "1N", "2S", "2N", "3S", "3N" });
  1982. break;
  1983. case "2N":
  1984. warehouseCodes.AddRange(new List<string> { "2N", "2S", "1N", "1S", "3N", "3S" });
  1985. break;
  1986. case "2S":
  1987. warehouseCodes.AddRange(new List<string> { "2S", "2N", "1S", "1N", "3S", "3N" });
  1988. break;
  1989. case "3N":
  1990. warehouseCodes.AddRange(new List<string> { "3N", "3S", "2N", "2S", "1N", "1S" });
  1991. break;
  1992. case "3S":
  1993. warehouseCodes.AddRange(new List<string> { "3S", "3N", "2S", "2N", "1S", "1N" });
  1994. break;
  1995. }
  1996. var wareCell = wareCellList.OrderBy(x => x.ProductTime) //按照优先级排序
  1997. .ThenBy(x => warehouseCodes.IndexOf(x.WarehouseCode))
  1998. .FirstOrDefault();
  1999. try
  2000. {
  2001. //获取所有的库存信息
  2002. var sotcks = _billInvnowrepository.GetList(x => x.ContGrpBarCode == wareCell.ContGrpBarCode);
  2003. var nowTime = DateTime.Now;
  2004. //创建流水信息
  2005. var invFlowList = _mapper.Map<List<BillInvflow>>(sotcks);
  2006. foreach (var invFlow in invFlowList)
  2007. {
  2008. invFlow.InvStateCode = InvState.InvEcecState_OutGoing.ToString();
  2009. invFlow.AddTime = nowTime;
  2010. invFlow.Id = IdFactory.NewId();
  2011. }
  2012. _db.BeginTran(); //创建事务
  2013. //更新货位信息
  2014. if (!_basewarecellrepository.UpdateModelColumns(
  2015. p => new BaseWarecell { StateNum = FjLocationState.StockOut },
  2016. p => p.Id == wareCell.locId && p.StateNum == FjLocationState.Full))
  2017. {
  2018. _db.RollbackTran();
  2019. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2020. res.ResMsg = $"请重新叫料,{wareCell.Code}货位货物已被其他机台叫走!";
  2021. return res;
  2022. }
  2023. //跟新库存
  2024. _billInvnowrepository.UpdateModelColumns(
  2025. p => new BillInvnow
  2026. {
  2027. InvStateCode = InvState.InvEcecState_OutGoing.ToString(),
  2028. EditTime = nowTime
  2029. }, p => p.ContGrpBarCode == wareCell.ContGrpBarCode);
  2030. //新建流水
  2031. _billInvflow.InsertRange(invFlowList);
  2032. //添加出库任务
  2033. RingCreateStockOutWcsTask(new FJCreateStockOutWcsTaskRequest
  2034. {
  2035. ContGrpBarCode = wareCell.ContGrpBarCode,
  2036. CellNo = wareCell.Code,
  2037. MatCode = wareCell.MatCode,
  2038. EquCode = "1",
  2039. Floor = 1,
  2040. Device = wareCell.WarehouseCode switch
  2041. {
  2042. "1N" => "SRM1",
  2043. "1S" => "SRM2",
  2044. "2N" => "SRM3",
  2045. "2S" => "SRM4",
  2046. "3N" => "SRM5",
  2047. "3S" => "SRM6",
  2048. _ => "ERROR"
  2049. },
  2050. WorkBench = mach.Station,
  2051. WarehouseCode = wareCell.WarehouseCode,
  2052. BusType = FJTaskBusType.车间叫料,
  2053. LastInteractionPoint = reqDto.Type,
  2054. MesNo = reqDto.ReqId,
  2055. EmptyInventory = mach.NearestWarehouseName.IsNullOrEmpty()
  2056. ? wareCell.WarehouseCode
  2057. : mach.NearestWarehouseName
  2058. });
  2059. _db.CommitTran();
  2060. }
  2061. catch (Exception ex)
  2062. {
  2063. _db.RollbackTran();
  2064. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2065. res.ResMsg = ex.Message;
  2066. }
  2067. }
  2068. else if (reqDto.Type == "2") //单独取空
  2069. {
  2070. //获取对应机台绑定的仓库
  2071. var mach = _basemachinforepository.GetFirst(x => x.MachNo == reqDto.WbCode);
  2072. if (mach == null)
  2073. {
  2074. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2075. res.ResMsg = $"没有对应机台-{reqDto.WbCode}";
  2076. return res;
  2077. }
  2078. var taskold = _wcstaskoldrepository.AsQueryable().With(SqlWith.NoLock).Where(p =>
  2079. p.WorkBench == mach.Station && p.Type == TaskType.EnterDepot && p.Status < TaskStatus.Finish)
  2080. .SplitTable(tabs => tabs.Take(2));
  2081. if (taskold != null && taskold.Any())
  2082. {
  2083. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  2084. res.ResMsg = mach.Station + "站台号存在进行中的单独取空任务任务,不要重复申请";
  2085. return res;
  2086. }
  2087. if (string.IsNullOrEmpty(mach.Station))
  2088. {
  2089. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  2090. res.ResMsg = reqDto.WbCode + "机台号没有配置AGV点位坐标";
  2091. return res;
  2092. }
  2093. //获取对应仓库
  2094. var warehouse = _basewarehouserepository.GetFirst(x => x.Id == mach.WarehouseId);
  2095. if (warehouse == null)
  2096. {
  2097. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2098. res.ResMsg = $"当前机台没有分配对应仓库-{reqDto.WbCode}";
  2099. return res;
  2100. }
  2101. //创建入库任务
  2102. var wcstask = new WCS_TaskInfo
  2103. {
  2104. Type = TaskType.EnterDepot,
  2105. Status = TaskStatus.NewBuild,
  2106. Priority = 0,
  2107. Device = warehouse.Code switch
  2108. {
  2109. "1N" => "SRM1",
  2110. "1S" => "SRM2",
  2111. "2N" => "SRM3",
  2112. "2S" => "SRM4",
  2113. "3N" => "SRM5",
  2114. "3S" => "SRM6",
  2115. _ => "ERROR"
  2116. },
  2117. AddrFrom = reqDto.WbCode,
  2118. AddrTo = warehouse.Code switch
  2119. {
  2120. "1N" => "SRM1",
  2121. "1S" => "SRM2",
  2122. "2N" => "SRM3",
  2123. "2S" => "SRM4",
  2124. "3N" => "SRM5",
  2125. "3S" => "SRM6",
  2126. _ => "ERROR"
  2127. },
  2128. LastInteractionPoint = reqDto.Type,
  2129. BarCode = reqDto.WbCode,
  2130. Floor = 1,
  2131. Length = 1,
  2132. AddTime = DateTime.Now,
  2133. DocID = 0,
  2134. PalletType = 1,
  2135. ProdLine = 1,
  2136. FullQty = 1,
  2137. AddWho = "WMS",
  2138. WarehouseCode = warehouse.Code,
  2139. Enabled = true,
  2140. WorkBench = mach.Station,
  2141. GoodsType = 1,
  2142. BusType = FJTaskBusType.皮盘入库.GetDescription(),
  2143. MatCode = "",
  2144. MaterialCode = mach.NearestWarehouseName.IsNullOrEmpty()
  2145. ? warehouse.Code
  2146. : mach.NearestWarehouseName
  2147. };
  2148. var wcstaskhis = _mapper.Map<WCS_TaskOld>(wcstask);
  2149. try
  2150. {
  2151. var task = _taskrepository.InsertReturnEntity(wcstask);
  2152. wcstaskhis.Id = task.ID;
  2153. _wcstaskoldrepository.InsertableSplitTable(wcstaskhis);
  2154. var taskdetail = new WCS_TaskDtl
  2155. {
  2156. ID = Guid.NewGuid(),
  2157. CurPoint = reqDto.WbCode,
  2158. AddTime = DateTime.Now,
  2159. AddWho = "wms",
  2160. Enabled = true,
  2161. ParentTaskCode = task.ID,
  2162. Desc = "单独返空任务"
  2163. };
  2164. _taskdetailrepository.InsertableSplitTable(taskdetail);
  2165. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  2166. }
  2167. catch (Exception ex)
  2168. {
  2169. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  2170. res.ResMsg = ResponseStatusCodeEnum.DataSaveErr.GetDescription();
  2171. _logger.LogInformation("保存任务异常:" + ex);
  2172. return res;
  2173. }
  2174. return res;
  2175. }
  2176. else
  2177. {
  2178. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2179. res.ResMsg = $"位置业务类型-{reqDto.Type}";
  2180. }
  2181. return res;
  2182. }
  2183. /// <summary>
  2184. /// 帘线叫料接口(人工码垛托盘/芯股)
  2185. /// </summary>
  2186. /// <param name="reqDto"></param>
  2187. /// <returns></returns>
  2188. public SRes CurtainProductionStockOut1(CurtainProductionStockOutRequest1 reqDto)
  2189. {
  2190. var res = new SRes();
  2191. var agvMaxSm = Convert.ToInt32(_sysconfigrepository.AsQueryable().With(SqlWith.NoLock)
  2192. .First(x => x.Code == "AGVSendsMaxQuantity").SContent);
  2193. var agvMaxFk = Convert.ToInt32(_sysconfigrepository.AsQueryable().With(SqlWith.NoLock)
  2194. .First(x => x.Code == "AGVMaxNumberEmptyRetur").SContent);
  2195. var agvSmNumber = _agvTaskInfoRepository.AsQueryable().With(SqlWith.NoLock)
  2196. .Where(x => x.AgvStatus < AGVTaskStatus.MissionCompleted && x.TaskType == AGVTaskType.CallMaterial)
  2197. .SplitTable(x => x.Take(2)).Count();
  2198. var agvFkNumber = _agvTaskInfoRepository.AsQueryable().With(SqlWith.NoLock)
  2199. .Where(x => x.AgvStatus < AGVTaskStatus.MissionCompleted && x.TaskType == AGVTaskType.EnterDepot)
  2200. .SplitTable(x => x.Take(2)).Count();
  2201. var waitingTask = _taskrepository.AsQueryable().With(SqlWith.NoLock)
  2202. .Where(x => x.BusType == FJTaskBusType.车间叫料.GetDescription() && x.Status == TaskStatus.WaitingToExecute)
  2203. .Count();
  2204. switch (reqDto.Type)
  2205. {
  2206. case "1":
  2207. if (agvMaxSm <= agvSmNumber)
  2208. {
  2209. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2210. res.ResMsg = $"禁止叫料,最大送满任务已达{agvSmNumber}";
  2211. return res;
  2212. }
  2213. if (agvMaxFk <= agvFkNumber)
  2214. {
  2215. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2216. res.ResMsg = $"禁止叫料,最大返空任务已达{agvFkNumber}";
  2217. return res;
  2218. }
  2219. if (agvMaxSm <= waitingTask)
  2220. {
  2221. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2222. res.ResMsg = $"禁止叫料,最大待执行叫料任务已达{waitingTask}";
  2223. return res;
  2224. }
  2225. break;
  2226. case "2":
  2227. if (agvMaxFk <= agvFkNumber)
  2228. {
  2229. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2230. res.ResMsg = $"禁止叫料,最大返空任务已达{agvFkNumber}";
  2231. return res;
  2232. }
  2233. break;
  2234. case "3":
  2235. if (agvMaxSm <= agvSmNumber)
  2236. {
  2237. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2238. res.ResMsg = $"禁止叫料,最大送满任务已达{agvSmNumber}";
  2239. return res;
  2240. }
  2241. if (agvMaxSm <= waitingTask)
  2242. {
  2243. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2244. res.ResMsg = $"禁止叫料,最大待执行叫料任务已达{waitingTask}";
  2245. return res;
  2246. }
  2247. break;
  2248. }
  2249. if (reqDto.Type == "1" || reqDto.Type == "3")
  2250. {
  2251. var doc = _billdocrepository.GetSingle(p => p.DocsNo == reqDto.BillCode);
  2252. if (doc == null)
  2253. {
  2254. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  2255. res.ResMsg = reqDto.BillCode + "工单信息不存在";
  2256. return res;
  2257. }
  2258. //获取机台信息
  2259. var mach = _basemachinforepository.GetSingle(x => x.MachNo == reqDto.WbCode);
  2260. if (mach == null || string.IsNullOrEmpty(mach.Station))
  2261. {
  2262. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  2263. res.ResMsg = reqDto.WbCode + "机台号没有配置AGV点位坐标";
  2264. return res;
  2265. }
  2266. var warehouse = reqDto.Grade == "A" ? _basewarehouserepository
  2267. .GetList(x =>x.TypeNum == FjLocationType.Storage || x.TypeNum == FjLocationType.Virtual).Select(x => x.Id).ToList() : _basewarehouserepository
  2268. .GetList(x => x.TypeNum == FjLocationType.Pingku).Select(x => x.Id).ToList();
  2269. //判断平库是否有该物料,如有先取平库料
  2270. var sotck1 = _billInvnowrepository.AsQueryable().With(SqlWith.NoLock).Where(x => x.WarehouseId == 1703346265607246826 && x.MatCode.Contains(reqDto.Materialcodecall) && x.InvStateCode ==
  2271. InvState.InvEcecState_In.ToString()).First();
  2272. if (sotck1 != null && _basewarecellrepository.AsQueryable().With(SqlWith.NoLock).Any(x => x.ContGrpBarCode == sotck1.ContGrpBarCode && x.IsStop == 0 && x.StateNum == FjLocationState.Full)
  2273. && reqDto.Grade == "B")
  2274. {
  2275. warehouse = _basewarehouserepository
  2276. .GetList(x => x.TypeNum == FjLocationType.Pingku).Select(x => x.Id).ToList();
  2277. }
  2278. else
  2279. {
  2280. //找到所有的立库/虚拟货位/平库货位
  2281. warehouse = _basewarehouserepository
  2282. .GetList(x =>
  2283. x.TypeNum == FjLocationType.Storage || x.TypeNum == FjLocationType.Virtual
  2284. ).Select(x => x.Id).ToList();
  2285. }
  2286. var task = _wcstaskoldrepository.AsQueryable().With(SqlWith.NoLock)
  2287. .Where(p => p.WorkBench == mach.Station && p.Status < TaskStatus.Finish)
  2288. .SplitTable(tabs => tabs.Take(2));
  2289. if (task != null && task.Any())
  2290. {
  2291. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  2292. res.ResMsg = mach.Station + "站台号存在进行中的任务,不要重复申请";
  2293. return res;
  2294. }
  2295. //获取所有的立库/虚拟有货库位信息
  2296. var wareCellList = _basewarecellrepository.Context.Queryable<BaseWarecell, BillInvnow>((loc, inv) =>
  2297. new object[] { JoinType.Inner, loc.ContGrpBarCode == inv.ContGrpBarCode })
  2298. .Where((loc, inv) => warehouse.Contains(loc.WarehouseId) &&
  2299. loc.StateNum == FjLocationState.Full &&
  2300. inv.InvStateCode == InvState.InvEcecState_In.ToString() &&
  2301. inv.MatCode.Contains(reqDto.Materialcodecall) &&
  2302. (!inv.Secondary || inv.ProductTime < DateTime.Now.AddHours(-6)))
  2303. .Where((loc, inv) => inv.IsTorsChk == true)
  2304. .Select((loc, inv) => new
  2305. {
  2306. locId = loc.Id,
  2307. loc.ContGrpBarCode,
  2308. loc.WarehouseId,
  2309. loc.WarehouseCode,
  2310. loc.Code,
  2311. loc.Row,
  2312. loc.Col,
  2313. loc.Layer,
  2314. loc.Depth,
  2315. loc.EditTime,
  2316. loc.TypeNum,
  2317. inv.MatCode,
  2318. inv.SideNum,
  2319. inv.CLBarCode,
  2320. inv.ProductTime,
  2321. invId = inv.Id
  2322. }).ToList().DistinctBy(x => x.ContGrpBarCode).ToList();
  2323. if (!wareCellList.Any())
  2324. {
  2325. res.ResCode = ResponseStatusCodeEnum.NotEnoughStock.GetHashCode();
  2326. res.ResMsg = ResponseStatusCodeEnum.NotEnoughStock.GetDescription();
  2327. return res;
  2328. }
  2329. //var warehouseCodes = new List<string>();
  2330. //switch (mach.WarehouseCode)
  2331. //{
  2332. // case "1N":
  2333. // warehouseCodes.AddRange(new List<string>() { "1N", "1S", "2N", "2S", "3N", "3S" });
  2334. // break;
  2335. // case "1S":
  2336. // warehouseCodes.AddRange(new List<string>() { "1S", "1N", "2S", "2N", "3S", "3N" });
  2337. // break;
  2338. // case "2N":
  2339. // warehouseCodes.AddRange(new List<string>() { "2N", "2S", "1N", "1S", "3N", "3S" });
  2340. // break;
  2341. // case "2S":
  2342. // warehouseCodes.AddRange(new List<string>() { "2S", "2N", "1S", "1N", "3S", "3N" });
  2343. // break;
  2344. // case "3N":
  2345. // warehouseCodes.AddRange(new List<string>() { "3N", "3S", "2N", "2S", "1N", "1S" });
  2346. // break;
  2347. // case "3S":
  2348. // warehouseCodes.AddRange(new List<string>() { "3S", "3N", "2S", "2N", "1S", "1N" });
  2349. // break;
  2350. //}
  2351. var wareCell = wareCellList.OrderBy(x => x.ProductTime).FirstOrDefault(); //按照优先级排序
  2352. try
  2353. {
  2354. //获取所有的库存信息
  2355. var sotcks = _billInvnowrepository.GetList(x => x.ContGrpBarCode == wareCell.ContGrpBarCode);
  2356. var nowTime = DateTime.Now;
  2357. //创建流水信息
  2358. var invFlowList = _mapper.Map<List<BillInvflow>>(sotcks);
  2359. foreach (var invFlow in invFlowList)
  2360. {
  2361. invFlow.InvStateCode = InvState.InvEcecState_OutGoing.ToString();
  2362. invFlow.AddTime = nowTime;
  2363. invFlow.Id = IdFactory.NewId();
  2364. }
  2365. _db.BeginTran(); //创建事务
  2366. //更新货位信息
  2367. if (!_basewarecellrepository.UpdateModelColumns(
  2368. p => new BaseWarecell { StateNum = FjLocationState.StockOut },
  2369. p => p.Id == wareCell.locId && p.StateNum == FjLocationState.Full))
  2370. {
  2371. _db.RollbackTran();
  2372. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2373. res.ResMsg = $"请重新叫料,{wareCell.Code}货位货物已被其他机台叫走!";
  2374. return res;
  2375. }
  2376. //更新库存
  2377. _billInvnowrepository.UpdateModelColumns(
  2378. p => new BillInvnow
  2379. {
  2380. InvStateCode = InvState.InvEcecState_OutGoing.ToString(),
  2381. EditTime = nowTime
  2382. }, p => p.ContGrpBarCode == wareCell.ContGrpBarCode);
  2383. //新建流水
  2384. _billInvflow.InsertRange(invFlowList);
  2385. //添加出库任务
  2386. RingCreateStockOutWcsTask(new FJCreateStockOutWcsTaskRequest
  2387. {
  2388. ContGrpBarCode = wareCell.ContGrpBarCode,
  2389. CellNo = wareCell.Code,
  2390. MatCode = wareCell.MatCode,
  2391. EquCode = wareCell.TypeNum == FjLocationType.Storage ? "1" : wareCell.Code,
  2392. Floor = 1,
  2393. Device = wareCell.WarehouseCode switch
  2394. {
  2395. "1N" => "SRM1",
  2396. "1S" => "SRM2",
  2397. "2N" => "SRM3",
  2398. "2S" => "SRM4",
  2399. "3N" => "SRM5",
  2400. "3S" => "SRM6",
  2401. "CRZP" => "CR",
  2402. _ => wareCell.WarehouseCode
  2403. },
  2404. WorkBench = mach.Station,
  2405. WarehouseCode = wareCell.TypeNum == FjLocationType.Storage
  2406. ? wareCell.WarehouseCode
  2407. : mach.WarehouseCode, //如果是芯股的话就使用叫料机台对应的仓库
  2408. BusType = FJTaskBusType.车间叫料,
  2409. LastInteractionPoint = reqDto.Type,
  2410. MesNo = reqDto.ReqId,
  2411. EmptyInventory = mach.NearestWarehouseName.IsNullOrEmpty()
  2412. ? wareCell.WarehouseCode
  2413. : mach.NearestWarehouseName
  2414. });
  2415. //如果是从芯股虚拟机台叫料的话需要记录芯股组盘机台的送空托需求
  2416. if (wareCell.TypeNum == FjLocationType.Virtual)
  2417. {
  2418. //检查对应芯股支架是否有对应的送空托任务
  2419. var taskList = _wcstaskoldrepository.AsQueryable().With(SqlWith.NoLock)
  2420. .Where(p => p.WorkBench == wareCell.Code && p.Type == TaskType.OutDepot
  2421. && p.BusType == FJTaskBusType.芯股站台送空托
  2422. .GetDescription()
  2423. && p.Status < TaskStatus.Finish)
  2424. .SplitTable(tabs => tabs.Take(2)).ToList();
  2425. if (taskList != null && taskList.Any())
  2426. {
  2427. _logger.LogInformation(wareCell.Code + "已有执行中的空托输送任务,不要重复申请");
  2428. }
  2429. else
  2430. {
  2431. //检查是否有对应配置信息
  2432. var sysConfig =
  2433. _sysconfigrepository.GetFirst(x => x.Code == $"{wareCell.Code}-EmptyPallet");
  2434. if (sysConfig == null)
  2435. {
  2436. sysConfig = new fjSysConfig
  2437. {
  2438. Code = $"{wareCell.Code}-EmptyPallet",
  2439. Name = $"芯股支架补空托-{wareCell.Code}",
  2440. SContent = "0",
  2441. SType = "1",
  2442. AddWho = "WMS",
  2443. EditWho = "WMS",
  2444. Default1 = "1",
  2445. Default2 = "2",
  2446. Default3 = "3",
  2447. Memo = "值为0表示不需要补充空托,1表示有空托需求"
  2448. };
  2449. _sysconfigrepository.Insert(sysConfig);
  2450. sysConfig = _sysconfigrepository.GetFirst(x =>
  2451. x.Code == $"{wareCell.Code}-EmptyPallet");
  2452. }
  2453. //检查当前站台是否已经有空托需求,无的话改为需要空托盘
  2454. if (sysConfig.SContent == "0")
  2455. //更新库存
  2456. _sysconfigrepository.UpdateModelColumns(
  2457. p => new fjSysConfig
  2458. {
  2459. SContent = "1",
  2460. EditTime = nowTime
  2461. }, p => p.Id == sysConfig.Id);
  2462. }
  2463. }
  2464. _db.CommitTran();
  2465. }
  2466. catch (Exception ex)
  2467. {
  2468. _db.RollbackTran();
  2469. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2470. res.ResMsg = ex.Message;
  2471. }
  2472. }
  2473. else if (reqDto.Type == "2") //单独取空
  2474. {
  2475. //获取对应机台绑定的仓库
  2476. var mach = _basemachinforepository.GetFirst(x => x.MachNo == reqDto.WbCode);
  2477. if (mach == null)
  2478. {
  2479. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2480. res.ResMsg = $"没有对应机台-{reqDto.WbCode}";
  2481. return res;
  2482. }
  2483. var taskold = _wcstaskoldrepository.AsQueryable().With(SqlWith.NoLock).Where(p =>
  2484. p.WorkBench == mach.Station && p.Type == TaskType.EnterDepot && p.Status < TaskStatus.Finish)
  2485. .SplitTable(tabs => tabs.Take(2));
  2486. if (taskold != null && taskold.Any())
  2487. {
  2488. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  2489. res.ResMsg = mach.Station + "站台号存在进行中的单独取空任务任务,不要重复申请";
  2490. return res;
  2491. }
  2492. if (string.IsNullOrEmpty(mach.Station))
  2493. {
  2494. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  2495. res.ResMsg = reqDto.WbCode + "机台号没有配置AGV点位坐标";
  2496. return res;
  2497. }
  2498. //获取对应仓库
  2499. var warehouse = _basewarehouserepository.GetFirst(x => x.Id == mach.WarehouseId);
  2500. if (warehouse == null)
  2501. {
  2502. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2503. res.ResMsg = $"当前机台没有分配对应仓库-{reqDto.WbCode}";
  2504. return res;
  2505. }
  2506. //创建入库任务
  2507. var wcstask = new WCS_TaskInfo
  2508. {
  2509. Type = TaskType.EnterDepot,
  2510. Status = TaskStatus.NewBuild,
  2511. Priority = 0,
  2512. Device = warehouse.Code switch
  2513. {
  2514. "1N" => "SRM1",
  2515. "1S" => "SRM2",
  2516. "2N" => "SRM3",
  2517. "2S" => "SRM4",
  2518. "3N" => "SRM5",
  2519. "3S" => "SRM6",
  2520. _ => "ERROR"
  2521. },
  2522. AddrFrom = reqDto.WbCode,
  2523. AddrTo = warehouse.Code switch
  2524. {
  2525. "1N" => "SRM1",
  2526. "1S" => "SRM2",
  2527. "2N" => "SRM3",
  2528. "2S" => "SRM4",
  2529. "3N" => "SRM5",
  2530. "3S" => "SRM6",
  2531. _ => "ERROR"
  2532. },
  2533. LastInteractionPoint = reqDto.Type,
  2534. BarCode = reqDto.WbCode,
  2535. Floor = 1,
  2536. Length = 1,
  2537. AddTime = DateTime.Now,
  2538. DocID = 0,
  2539. PalletType = 1,
  2540. ProdLine = 1,
  2541. FullQty = 1,
  2542. AddWho = "WMS",
  2543. WarehouseCode = warehouse.Code,
  2544. Enabled = true,
  2545. WorkBench = mach.Station,
  2546. GoodsType = 1,
  2547. BusType = FJTaskBusType.皮盘入库.GetDescription(),
  2548. MatCode = "",
  2549. MaterialCode = mach.NearestWarehouseName.IsNullOrEmpty()
  2550. ? warehouse.Code
  2551. : mach.NearestWarehouseName
  2552. };
  2553. var wcstaskhis = _mapper.Map<WCS_TaskOld>(wcstask);
  2554. try
  2555. {
  2556. var task = _taskrepository.InsertReturnEntity(wcstask);
  2557. wcstaskhis.Id = task.ID;
  2558. _wcstaskoldrepository.InsertableSplitTable(wcstaskhis);
  2559. var taskdetail = new WCS_TaskDtl
  2560. {
  2561. ID = Guid.NewGuid(),
  2562. CurPoint = reqDto.WbCode,
  2563. AddTime = DateTime.Now,
  2564. AddWho = "wms",
  2565. Enabled = true,
  2566. ParentTaskCode = task.ID,
  2567. Desc = "单独返空任务"
  2568. };
  2569. _taskdetailrepository.InsertableSplitTable(taskdetail);
  2570. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  2571. }
  2572. catch (Exception ex)
  2573. {
  2574. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  2575. res.ResMsg = ResponseStatusCodeEnum.DataSaveErr.GetDescription();
  2576. _logger.LogInformation("保存任务异常:" + ex);
  2577. return res;
  2578. }
  2579. return res;
  2580. }
  2581. else
  2582. {
  2583. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2584. res.ResMsg = $"位置业务类型-{reqDto.Type}";
  2585. }
  2586. return res;
  2587. }
  2588. /// <summary>
  2589. /// 帘线手动领料出库
  2590. /// </summary>
  2591. /// <param name="reqDto"></param>
  2592. /// <returns></returns>
  2593. public SRes ManualCurtainProductionStockOut(ManualCurtainProductionStockOut reqDto)
  2594. {
  2595. var res = new SRes();
  2596. //获取机台信息
  2597. var mach = _basemachinforepository.GetSingle(x => x.MachNo == reqDto.WbCode);
  2598. if (mach == null || string.IsNullOrEmpty(mach.Station))
  2599. {
  2600. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  2601. res.ResMsg = reqDto.WbCode + "机台号没有配置AGV点位坐标";
  2602. return res;
  2603. }
  2604. var task = _wcstaskoldrepository.AsQueryable().With(SqlWith.NoLock)
  2605. .Where(p => p.AddrTo == mach.Station && p.Status < TaskStatus.Finish).SplitTable(tabs => tabs.Take(2));
  2606. if (task != null && task.Any())
  2607. {
  2608. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  2609. res.ResMsg = mach.Station + "站台号存在进行中的任务,不要重复申请";
  2610. return res;
  2611. }
  2612. //货位信息验证
  2613. var location =
  2614. _basewarecellrepository.GetSingle(p => p.Code == reqDto.cellCode && p.WarehouseCode == reqDto.wareCode);
  2615. if (location == null)
  2616. {
  2617. res.ResCode = ResponseStatusCodeEnum.WareLocationCodeNotExist.GetHashCode();
  2618. res.ResMsg = reqDto.cellCode + ResponseStatusCodeEnum.WareLocationCodeNotExist.GetDescription();
  2619. return res;
  2620. }
  2621. if (location.StateNum != FjLocationState.Full)
  2622. {
  2623. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2624. res.ResMsg = reqDto.cellCode + ResponseStatusCodeEnum.Fail.GetDescription() + "货位状态不满足出库条件";
  2625. return res;
  2626. }
  2627. if (location.IsStop == 1)
  2628. {
  2629. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2630. res.ResMsg = ResponseStatusCodeEnum.Fail.GetDescription() + reqDto.cellCode + "被禁用";
  2631. return res;
  2632. }
  2633. //库存信息验证
  2634. var stock = _billInvnowrepository.GetFirst(p =>
  2635. p.ContGrpBarCode == location.ContGrpBarCode && p.InvStateCode == InvState.InvEcecState_In.ToString());
  2636. if (stock == null)
  2637. {
  2638. res.ResCode = ResponseStatusCodeEnum.StockNotExist.GetHashCode();
  2639. res.ResMsg = ResponseStatusCodeEnum.StockNotExist.GetDescription();
  2640. return res;
  2641. }
  2642. if (stock.InvStateCode != InvState.InvEcecState_In.ToString())
  2643. {
  2644. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2645. res.ResMsg = reqDto.cellCode + "组盘状态不是已入库";
  2646. return res;
  2647. }
  2648. try
  2649. {
  2650. //获取所有的库存信息
  2651. var sotcks = _billInvnowrepository.GetList(x => x.ContGrpBarCode == location.ContGrpBarCode);
  2652. var nowTime = DateTime.Now;
  2653. //创建流水信息
  2654. var invFlowList = _mapper.Map<List<BillInvflow>>(sotcks);
  2655. foreach (var invFlow in invFlowList)
  2656. {
  2657. invFlow.InvStateCode = InvState.InvEcecState_OutGoing.ToString();
  2658. invFlow.AddTime = nowTime;
  2659. invFlow.Id = IdFactory.NewId();
  2660. }
  2661. _db.BeginTran(); //创建事务
  2662. //更新货位信息
  2663. if (!_basewarecellrepository.UpdateModelColumns(
  2664. p => new BaseWarecell { StateNum = FjLocationState.StockOut },
  2665. p => p.Id == location.Id && p.StateNum == FjLocationState.Full))
  2666. {
  2667. _db.RollbackTran();
  2668. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2669. res.ResMsg = $"请重新叫料,{location.Code}货位货物已被其他机台叫走!";
  2670. return res;
  2671. }
  2672. //跟新库存
  2673. _billInvnowrepository.UpdateModelColumns(
  2674. p => new BillInvnow
  2675. {
  2676. InvStateCode = InvState.InvEcecState_OutGoing.ToString(),
  2677. EditTime = nowTime
  2678. }, p => p.ContGrpBarCode == location.ContGrpBarCode);
  2679. //新建流水
  2680. _billInvflow.InsertRange(invFlowList);
  2681. //添加出库任务
  2682. RingCreateStockOutWcsTask(new FJCreateStockOutWcsTaskRequest
  2683. {
  2684. ContGrpBarCode = location.ContGrpBarCode,
  2685. CellNo = location.Code,
  2686. MatCode = stock.MatCode,
  2687. EquCode = "1",
  2688. Floor = 1,
  2689. Device = location.WarehouseCode switch
  2690. {
  2691. "1N" => "SRM1",
  2692. "1S" => "SRM2",
  2693. "2N" => "SRM3",
  2694. "2S" => "SRM4",
  2695. "3N" => "SRM5",
  2696. "3S" => "SRM6",
  2697. _ => "ERROR"
  2698. },
  2699. WorkBench = mach.Station,
  2700. WarehouseCode = location.WarehouseCode,
  2701. BusType = FJTaskBusType.车间手动叫料
  2702. });
  2703. _db.CommitTran();
  2704. }
  2705. catch (Exception ex)
  2706. {
  2707. _db.RollbackTran();
  2708. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2709. res.ResMsg = ex.Message;
  2710. }
  2711. return res;
  2712. }
  2713. public SRes ProductionBack(FjProductionBackRequest reqDto)
  2714. {
  2715. var res = new SRes();
  2716. return res;
  2717. }
  2718. /// <summary>
  2719. /// 变更流向
  2720. /// </summary>
  2721. /// <param name="reqDto"></param>
  2722. /// <returns></returns>
  2723. public SRes EditorialFlow(FjEditorialFlowRequest reqDto)
  2724. {
  2725. var res = new SRes();
  2726. //获取对应任务信息
  2727. var taskInfo = _wcstaskoldrepository.AsQueryable().Where(x => x.Id == reqDto.TaskId)
  2728. .SplitTable(tabs => tabs.Take(2)).First();
  2729. if (taskInfo == null)
  2730. {
  2731. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2732. res.ResMsg = $"不存在任务{reqDto.TaskId}";
  2733. return res;
  2734. }
  2735. if (taskInfo.Status > TaskStatus.WaitingToExecute)
  2736. {
  2737. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2738. res.ResMsg = $"任务状态大于待执行{reqDto.TaskId}";
  2739. return res;
  2740. }
  2741. //库存
  2742. var stock = _billInvnowrepository.GetSingle(p => p.HWBarCode == taskInfo.BarCode);
  2743. if (stock != null)
  2744. {
  2745. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2746. res.ResMsg = "该工字轮条码号已在库中,请检查RFID号是否重复";
  2747. return res;
  2748. }
  2749. //仓库
  2750. var warehouse = _basewarehouserepository.GetSingle(p => p.Code == reqDto.WareCode);
  2751. if (stock != null)
  2752. {
  2753. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2754. res.ResMsg = "该工字轮条码号已在库中,请检查RFID号是否重复";
  2755. return res;
  2756. }
  2757. #region 变更仓库信息
  2758. try
  2759. {
  2760. _db.BeginTran();
  2761. //变更码垛信息所属仓库
  2762. _billSpoolTransrepository.UpdateModelColumns(p => new BillSpoolTrans
  2763. {
  2764. WarehouseCode = reqDto.WareCode,
  2765. WarehouseSort = int.Parse(reqDto.WareCode.Substring(0, 1)),
  2766. EditTime = DateTime.Now
  2767. }, p => p.ConBarCode == taskInfo.BarCode);
  2768. //变更条码所属仓库信息
  2769. _billInvinitrepository.UpdateModelColumns(x => new BillInvinit
  2770. {
  2771. WarehouseId = warehouse.Id
  2772. }, x => x.ContGrpBarCode == taskInfo.BarCode);
  2773. _db.CommitTran();
  2774. }
  2775. catch (Exception e)
  2776. {
  2777. _db.RollbackTran();
  2778. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2779. res.ResMsg = e.StackTrace;
  2780. }
  2781. #endregion
  2782. return res;
  2783. }
  2784. public SRes ProductionLeftFeedBack(string doccode)
  2785. {
  2786. var res = new SRes();
  2787. return res;
  2788. }
  2789. public SRes ErrorMaterialStockOut(FjErrorMaterialStockOutRequest reqDto)
  2790. {
  2791. var res = new SRes();
  2792. return res;
  2793. }
  2794. public SRes BGradeMaterialStockOut(BGradeMaterialStockOutRequest reqDto)
  2795. {
  2796. var res = new SRes();
  2797. return res;
  2798. }
  2799. public SRes StockChange(FjStockChangeRequest reqDto)
  2800. {
  2801. var res = new SRes();
  2802. return res;
  2803. }
  2804. public SRes BomInfoTrans(BomInfoTransRequest reqDto)
  2805. {
  2806. var res = new SRes();
  2807. return res;
  2808. }
  2809. public SRes FJ1NorthAutoGenerateLocation()
  2810. {
  2811. var res = new SRes();
  2812. var BaseWarearea = new BaseWarehouse
  2813. {
  2814. Id = IdFactory.NewId(),
  2815. IsStop = 0,
  2816. Code = "1N",
  2817. Name = "分拣库1北",
  2818. AddTime = DateTime.Now,
  2819. AddWho = "admin",
  2820. EditTime = DateTime.Now,
  2821. EditWho = "admin",
  2822. TypeNum = FjLocationType.Storage
  2823. };
  2824. var baseWareareaEntity = _basewarehouserepository.InsertReturnEntity(BaseWarearea);
  2825. var dbBaseWarecellLists = _basewarehouserepository.AsQueryable().ToList();
  2826. var shelfcode = "";
  2827. var list = new List<BaseWarecell>();
  2828. var codes = new List<string>();
  2829. for (var row = 1; row <= 2; row++) //行
  2830. {
  2831. var tunnel = 1;
  2832. //12行 48列9层
  2833. for (var layer = 1; layer <= 10; layer++) //层
  2834. for (var col = 1; col <= 10; col++) //列
  2835. {
  2836. var code = row.ToString().PadLeft(2, '0') + "-" + col.ToString().PadLeft(2, '0') + "-" +
  2837. layer.ToString().PadLeft(2, '0') + "-" + tunnel;
  2838. codes.Add(code);
  2839. var name = row + "行" + col + "列" + layer + "层";
  2840. list.Add(new BaseWarecell
  2841. {
  2842. Id = IdFactory.NewId(),
  2843. WarehouseId = baseWareareaEntity.Id,
  2844. WareAreaId = 1669154208777113600,
  2845. IsStop = 0,
  2846. Code = code,
  2847. Name = name,
  2848. StateNum = FjLocationState.Empty,
  2849. TypeNum = FjLocationType.Storage,
  2850. Size = 1,
  2851. Shelf = tunnel + shelfcode,
  2852. WarehouseCode = BaseWarearea.Code,
  2853. Row = row,
  2854. Col = col,
  2855. Layer = layer,
  2856. Depth = 1,
  2857. Tunnel = tunnel,
  2858. SCRel = "SRM" + tunnel.ToString().PadLeft(2, '0'),
  2859. ContGrpId = 0,
  2860. ContGrpBarCode = "",
  2861. Memo = "",
  2862. AddWho = "admin",
  2863. AddTime = DateTime.Now,
  2864. EditWho = "admin",
  2865. EditTime = DateTime.Now
  2866. });
  2867. }
  2868. }
  2869. _basewarecellrepository.InsertRange(list);
  2870. return res;
  2871. }
  2872. public SRes FJSouthAutoGenerateLocation()
  2873. {
  2874. var res = new SRes();
  2875. var BaseWarearea = new BaseWarehouse
  2876. {
  2877. Id = IdFactory.NewId(),
  2878. IsStop = 0,
  2879. Code = "1S",
  2880. Name = "分拣库1南",
  2881. AddTime = DateTime.Now,
  2882. AddWho = "admin",
  2883. EditTime = DateTime.Now,
  2884. EditWho = "admin",
  2885. TypeNum = FjLocationType.Storage
  2886. };
  2887. var baseWareareaEntity = _basewarehouserepository.InsertReturnEntity(BaseWarearea);
  2888. var dbBaseWarecellLists = _basewarehouserepository.AsQueryable().ToList();
  2889. var shelfcode = "";
  2890. var list = new List<BaseWarecell>();
  2891. var codes = new List<string>();
  2892. for (var row = 1; row <= 2; row++) //行
  2893. {
  2894. var tunnel = 1;
  2895. //12行 48列9层
  2896. for (var layer = 1; layer <= 10; layer++) //层
  2897. for (var col = 11; col <= 20; col++) //列
  2898. {
  2899. var code = row.ToString().PadLeft(2, '0') + "-" + col.ToString().PadLeft(2, '0') + "-" +
  2900. layer.ToString().PadLeft(2, '0') + "-" + tunnel;
  2901. codes.Add(code);
  2902. var name = row + "行" + col + "列" + layer + "层";
  2903. list.Add(new BaseWarecell
  2904. {
  2905. Id = IdFactory.NewId(),
  2906. WarehouseId = baseWareareaEntity.Id,
  2907. WareAreaId = 1669154208777113600,
  2908. IsStop = 0,
  2909. Code = code,
  2910. Name = name,
  2911. StateNum = FjLocationState.Empty,
  2912. TypeNum = FjLocationType.Storage,
  2913. Size = 1,
  2914. Shelf = tunnel + shelfcode,
  2915. WarehouseCode = BaseWarearea.Code,
  2916. Row = row,
  2917. Col = col,
  2918. Layer = layer,
  2919. Depth = 1,
  2920. Tunnel = tunnel,
  2921. SCRel = "SRM" + 2,
  2922. ContGrpId = 0,
  2923. ContGrpBarCode = "",
  2924. Memo = "",
  2925. AddWho = "admin",
  2926. AddTime = DateTime.Now,
  2927. EditWho = "admin",
  2928. EditTime = DateTime.Now
  2929. });
  2930. }
  2931. }
  2932. _basewarecellrepository.InsertRange(list);
  2933. return res;
  2934. }
  2935. /// <summary>
  2936. /// 获取垛型数组
  2937. /// </summary>
  2938. /// <param name="req"></param>
  2939. /// <returns></returns>
  2940. public SRes<List<BillBomsetgrp>> FjGetSetGrpList(FjGetSetGrpListRequest req)
  2941. {
  2942. var res = new SRes<List<BillBomsetgrp>>();
  2943. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  2944. res.ResMsg = "失败";
  2945. var setGrps = _BillBomsetgrpRepository.GetList(x => x.ProMaterCode == req.OutMaterialCode && x.IsStop == 0);
  2946. if (req.ListmatInfo.Any(v => v == "null"))
  2947. {
  2948. res.ResMsg = "请重新打开界面";
  2949. return res;
  2950. }
  2951. foreach (var setGrpList in req.ListmatInfo.Select(info =>
  2952. _BillBomsetgrpRepository.GetList(x =>
  2953. (x.BomCode == info || x.BomCode.Contains(info)) && x.IsStop == 0)))
  2954. setGrps.AddRange(setGrpList);
  2955. setGrps = setGrps.DistinctBy(x => x.Id).ToList();
  2956. if (setGrps != null && setGrps.Any())
  2957. {
  2958. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  2959. res.ResMsg = "成功";
  2960. res.Listinfo = setGrps;
  2961. return res;
  2962. }
  2963. res.ResMsg = $"{req}没有对应启用垛型";
  2964. return res;
  2965. }
  2966. /// <summary>
  2967. /// 分拣南环形库自动生成库位
  2968. /// </summary>
  2969. /// <returns></returns>
  2970. public SRes RingLibraryAutoGenerateLocation(string WareCode)
  2971. {
  2972. var res = new SRes();
  2973. var wareHouse = _basewarehouserepository.GetSingle(x => x.Code == WareCode);
  2974. var list = new List<BaseWarecell>();
  2975. var codes = new List<string>();
  2976. for (var row = 1; row <= 3; row++) //3行
  2977. for (var layer = 1; layer <= 7; layer++) //7层
  2978. for (var col = 1; col <= 17; col++) //17列
  2979. {
  2980. //行列层深度
  2981. var code = row.ToString().PadLeft(2, '0') + "-" + col.ToString().PadLeft(2, '0') + "-" +
  2982. layer.ToString().PadLeft(2, '0') + "-" + row.ToString().PadLeft(2, '0');
  2983. codes.Add(code);
  2984. var name = row + "行" + col + "列" + layer + "层" + row + "深";
  2985. list.Add(new BaseWarecell
  2986. {
  2987. Id = IdFactory.NewId(),
  2988. WarehouseId = wareHouse.Id,
  2989. WareAreaId = 1669154208777113600,
  2990. IsStop = 0,
  2991. Code = code,
  2992. Name = name,
  2993. StateNum = FjLocationState.Empty,
  2994. TypeNum = FjLocationType.RingLibrary,
  2995. Size = 1,
  2996. Shelf = "1",
  2997. WarehouseCode = wareHouse.Code,
  2998. Row = row,
  2999. Col = col,
  3000. Layer = layer,
  3001. Depth = row,
  3002. SCRel = "Robot" + 2,
  3003. ContGrpId = 0,
  3004. ContGrpBarCode = "",
  3005. Memo = "",
  3006. AddWho = "admin",
  3007. AddTime = DateTime.Now,
  3008. EditWho = "admin",
  3009. EditTime = DateTime.Now
  3010. });
  3011. }
  3012. _basewarecellrepository.InsertRange(list);
  3013. return res;
  3014. }
  3015. /// <summary>
  3016. /// 实时库存查询接口
  3017. /// </summary>
  3018. /// <param name="reqDto"></param>
  3019. /// <returns></returns>
  3020. public GetFJCurStockListResponse GetCurStockList(GetFJCurStockListRequest reqDto)
  3021. {
  3022. var res = new GetFJCurStockListResponse
  3023. {
  3024. ResData = new List<FJResDataItem>()
  3025. };
  3026. var totalCount = 0;
  3027. var list = _billInvnowrepository.Context.Queryable<BillInvnow>()
  3028. .Where(p => p.InvStateCode == InvState.InvEcecState_In.ToString())
  3029. .WhereIF(!string.IsNullOrEmpty(reqDto.MatCode), p => p.MatCode.Contains(reqDto.MatCode))
  3030. .WhereIF(!string.IsNullOrEmpty(reqDto.MatName), p => p.MatName.Contains(reqDto.MatName))
  3031. .ToPageList(reqDto.PageIndex, reqDto.PageSize, ref totalCount)
  3032. .Select(p => new FJResDataItem
  3033. {
  3034. MatCode = p.MatCode,
  3035. MatName = p.MatName,
  3036. MatBarCode = p.CLBarCode,
  3037. Describe = "",
  3038. LocCell = p.PutCol.ToString(),
  3039. LocLayer = p.PutLayer.ToString(),
  3040. LocRow = p.PutRow.ToString(),
  3041. LocCode = p.PutRow + p.PutCol.ToString() + p.PutLayer,
  3042. ConBarCode = p.ContGrpBarCode,
  3043. HWBarCode = p.HWBarCode,
  3044. UpdatedTime = p.EditTime
  3045. }
  3046. );
  3047. res.TotalCount = totalCount;
  3048. res.ResData = list.ToList();
  3049. return res;
  3050. }
  3051. /// <summary>
  3052. /// 创建芯股用空托入库任务
  3053. /// </summary>
  3054. /// <returns></returns>
  3055. public void CreateCoreStrandEmptyPalletEnterWarehouse()
  3056. {
  3057. //查询配置最大库存数量
  3058. var sycon = _sysconfigrepository.GetList(x => x.Code.Contains("CoreStrandEmptyPalletMaxNumber"));
  3059. foreach (var config in sycon)
  3060. {
  3061. //获取仓库编号
  3062. var warehouseCode = config.Code.Split("-")[1];
  3063. var warehouse = _basewarehouserepository.GetFirst(x => x.Code == warehouseCode);
  3064. if (warehouse == null)
  3065. {
  3066. _logger.LogInformation($"找不到仓库{warehouse}");
  3067. return;
  3068. }
  3069. //判断对应仓库中是否存在指定缓存数量的空托盘
  3070. var invnowCount = _billInvnowrepository.AsQueryable().With(SqlWith.NoLock).Count(x =>
  3071. x.ContGrpType == FJContGrpType.EmptyPal && x.InvStateCode == InvState.InvEcecState_In.ToString() &&
  3072. x.WarehouseId == warehouse.Id);
  3073. //获取正在执行中的任务
  3074. var taskInfoCount = _taskrepository.AsQueryable().With(SqlWith.NoLock).Count(x =>
  3075. x.Status < TaskStatus.Finish && x.BusType == FJTaskBusType.芯股用空托盘入库.GetDescription() &&
  3076. x.WarehouseCode == warehouse.Code);
  3077. //创建对应任务
  3078. var maxNumber = Convert.ToInt32(config.SContent);
  3079. var now = invnowCount + taskInfoCount;
  3080. if (now < maxNumber) //已有任务数量和库存数量小于最大缓存数量
  3081. {
  3082. _db.BeginTran();
  3083. //开始生成WCS
  3084. var createStockInWcsTaskReqest = new FJCreateStockInWcsTaskRequest
  3085. {
  3086. BusType = FJTaskBusType.芯股用空托盘入库.GetDescription(),
  3087. Qty = 1,
  3088. WarehouseCode = warehouse.Code,
  3089. Floor = 2,
  3090. MatCode = "",
  3091. EquCode = "",
  3092. Type = TaskType.EnterDepot,
  3093. DocCode = "",
  3094. WorkBench = ""
  3095. };
  3096. createStockInWcsTaskReqest.ContGrpBarCode = $"{createStockInWcsTaskReqest.BusType}-{warehouseCode}";
  3097. //下发wcs任务 - 分解方法
  3098. var taskRes = CreateStockInWcsTask(createStockInWcsTaskReqest);
  3099. if (taskRes.ResCode != 200)
  3100. {
  3101. _db.RollbackTran();
  3102. _logger.LogInformation($"{taskRes.ResMsg}");
  3103. }
  3104. _db.CommitTran();
  3105. }
  3106. }
  3107. }
  3108. /// <summary>
  3109. /// 创建芯股站台用的空托出库任务
  3110. /// </summary>
  3111. /// <returns></returns>
  3112. public SRes CoreStrandSupportReplenishEmptyPallet()
  3113. {
  3114. var res = new SRes
  3115. {
  3116. ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode(),
  3117. ResMsg = ResponseStatusCodeEnum.Sucess.GetDescription()
  3118. };
  3119. //芯股支架补空托,获取需要空托的支架
  3120. var sycon = _sysconfigrepository.GetList(x =>
  3121. x.Code.Contains("EmptyPallet") && x.Name.Contains("芯股支架补空托") && x.SContent == "1");
  3122. var isEnd = false;
  3123. foreach (var config in sycon)
  3124. {
  3125. if (isEnd) continue;
  3126. //获取仓库编号
  3127. var wareCellCode = config.Code.Split("-")[0];
  3128. var wareCell = _basewarecellrepository.GetFirst(x => x.Code == wareCellCode);
  3129. if (wareCell == null)
  3130. {
  3131. _logger.LogInformation($"找不到货位{wareCellCode}");
  3132. continue;
  3133. }
  3134. var taskInfo = _wcstaskoldrepository.AsQueryable().With(SqlWith.NoLock)
  3135. .Where(p => p.WorkBench == wareCell.Code && p.Type == TaskType.OutDepot
  3136. && p.BusType == FJTaskBusType.芯股站台送空托.GetDescription()
  3137. && p.Status < TaskStatus.Finish)
  3138. .SplitTable(tabs => tabs.Take(2)).First();
  3139. if (taskInfo != null)
  3140. {
  3141. _logger.LogInformation(wareCell.Code + "已有执行中的空托输送任务,不要重复申请");
  3142. continue;
  3143. }
  3144. //找到所有的立库货位
  3145. var warehouse = _basewarehouserepository.GetList(x => x.TypeNum == FjLocationType.Storage)
  3146. .Select(x => x.Id).ToList();
  3147. //获取所有的立库有货库位信息
  3148. var wareCellList = _basewarecellrepository.Context.Queryable<BaseWarecell, BillInvnow>((loc, inv) =>
  3149. new object[] { JoinType.Inner, loc.ContGrpBarCode == inv.ContGrpBarCode })
  3150. .Where((loc, inv) => warehouse.Contains(loc.WarehouseId) && loc.IsStop == 0 &&
  3151. loc.StateNum == FjLocationState.Full &&
  3152. inv.InvStateCode == InvState.InvEcecState_In.ToString())
  3153. .Where((loc, inv) => inv.ContGrpType == FJContGrpType.EmptyPal)
  3154. .Select((loc, inv) => new
  3155. {
  3156. locId = loc.Id,
  3157. loc.ContGrpBarCode,
  3158. loc.WarehouseId,
  3159. loc.WarehouseCode,
  3160. loc.Code,
  3161. loc.Row,
  3162. loc.Col,
  3163. loc.Layer,
  3164. loc.Depth,
  3165. loc.EditTime,
  3166. loc.TypeNum,
  3167. inv.MatCode,
  3168. inv.SideNum,
  3169. inv.CLBarCode,
  3170. inv.OneInTime,
  3171. invId = inv.Id
  3172. }).ToList().DistinctBy(x => x.ContGrpBarCode).ToList();
  3173. if (!wareCellList.Any())
  3174. {
  3175. res.ResCode = ResponseStatusCodeEnum.NotEnoughStock.GetHashCode();
  3176. res.ResMsg = "没有可用空托盘";
  3177. isEnd = true;
  3178. continue;
  3179. }
  3180. //TODO:暂时不按照芯股支架的位置进行空托盘的出库
  3181. var wareCellInfo = wareCellList.OrderBy(x => x.OneInTime).First();
  3182. //获取所有的库存信息
  3183. var sotcks = _billInvnowrepository.GetList(x => x.ContGrpBarCode == wareCellInfo.ContGrpBarCode);
  3184. var nowTime = DateTime.Now;
  3185. //创建流水信息
  3186. var invFlowList = _mapper.Map<List<BillInvflow>>(sotcks);
  3187. foreach (var invFlow in invFlowList)
  3188. {
  3189. invFlow.InvStateCode = InvState.InvEcecState_OutGoing.ToString();
  3190. invFlow.AddTime = nowTime;
  3191. invFlow.Id = IdFactory.NewId();
  3192. }
  3193. _db.BeginTran(); //创建事务
  3194. //更新货位信息
  3195. if (!_basewarecellrepository.UpdateModelColumns(
  3196. p => new BaseWarecell { StateNum = FjLocationState.StockOut },
  3197. p => p.Id == wareCellInfo.locId && p.StateNum == FjLocationState.Full))
  3198. {
  3199. _db.RollbackTran();
  3200. _logger.LogInformation($"请重新叫料,{wareCellInfo.Code}货位货物已被其他机台叫走!");
  3201. continue;
  3202. }
  3203. //更新库存
  3204. _billInvnowrepository.UpdateModelColumns(
  3205. p => new BillInvnow
  3206. {
  3207. InvStateCode = InvState.InvEcecState_OutGoing.ToString(),
  3208. EditTime = nowTime
  3209. }, p => p.ContGrpBarCode == wareCellInfo.ContGrpBarCode);
  3210. //新建流水
  3211. _billInvflow.InsertRange(invFlowList);
  3212. //添加出库任务
  3213. RingCreateStockOutWcsTask(new FJCreateStockOutWcsTaskRequest
  3214. {
  3215. ContGrpBarCode = wareCellInfo.ContGrpBarCode,
  3216. CellNo = wareCellInfo.Code,
  3217. MatCode = wareCellInfo.MatCode,
  3218. EquCode = wareCellInfo.TypeNum == FjLocationType.Storage ? "1" : wareCellInfo.Code,
  3219. Floor = 1,
  3220. Device = wareCellInfo.WarehouseCode switch
  3221. {
  3222. "1N" => "SRM1",
  3223. "1S" => "SRM2",
  3224. "2N" => "SRM3",
  3225. "2S" => "SRM4",
  3226. "3N" => "SRM5",
  3227. "3S" => "SRM6",
  3228. _ => wareCellInfo.WarehouseCode
  3229. },
  3230. WorkBench = wareCell.Code,
  3231. WarehouseCode = wareCellInfo.WarehouseCode, //如果是芯股的话就使用叫料机台对应的仓库
  3232. BusType = FJTaskBusType.芯股站台送空托,
  3233. LastInteractionPoint = "1"
  3234. });
  3235. _sysconfigrepository.UpdateModelColumns(
  3236. p => new fjSysConfig
  3237. {
  3238. SContent = "0",
  3239. EditTime = nowTime
  3240. }, p => p.Id == config.Id);
  3241. _db.CommitTran();
  3242. isEnd = true;
  3243. }
  3244. return res;
  3245. }
  3246. /// <summary>
  3247. /// 二次扫码分配输送地址
  3248. /// </summary>
  3249. /// <param name="reqDto"></param>
  3250. /// <returns></returns>
  3251. public SRes AllocationConveyorSort(AllocationConveyorSortRequest reqDto)
  3252. {
  3253. var res = new SRes();
  3254. var baritem = _billSpoolTransrepository.GetFirst(p => p.ConBarCode == reqDto.BarCode);
  3255. //判断当前库是否有mix垛型
  3256. //var mixrow = _billBomsetinfoRepository.AsQueryable().Where(p => p.IsMixRow == 1 && p.WarehouseCode == baritem.WarehouseCode);
  3257. //if (mixrow == null || !mixrow.Any())
  3258. //{
  3259. // var matcodelist = _billBomsetinfoRepository.AsQueryable().Where(p => p.WarehouseCode == baritem.WarehouseCode);
  3260. // var curmatrate = matcodelist.Where(p => p.MatCode == baritem.MatCode).Count() / matcodelist.Count();
  3261. // //需要的总量
  3262. //}
  3263. //else
  3264. //{
  3265. //}
  3266. //var translist = _billSpoolTransrepository.AsQueryable().Where(p => p.WarehouseCode == baritem.WarehouseCode).ToList();
  3267. //foreach (var item in translist.GroupBy(p => p.ConveyorSort))
  3268. //{
  3269. //}
  3270. return res;
  3271. }
  3272. #region 初始化仓储
  3273. private Repository<fjSysConfig> _sysconfigrepository => new Repository<fjSysConfig>();
  3274. /// <summary>
  3275. /// 容器表
  3276. /// </summary>
  3277. private Repository<BaseContinfo> _baseContinfo => new Repository<BaseContinfo>();
  3278. /// <summary>
  3279. /// 环形库码垛缓存信息
  3280. /// </summary>
  3281. private Repository<BillRingPalletizingInfo> _billRingPalletizingInfo =>
  3282. new Repository<BillRingPalletizingInfo>();
  3283. /// <summary>
  3284. /// 当前任务表
  3285. /// </summary>
  3286. private RepositoryTask<WCS_TaskInfo> _taskrepository => new RepositoryTask<WCS_TaskInfo>();
  3287. /// <summary>
  3288. /// 库存表
  3289. /// </summary>
  3290. private Repository<BillInvnow> _billInvnowrepository => new Repository<BillInvnow>();
  3291. /// <summary>
  3292. /// 条码表
  3293. /// </summary>
  3294. private Repository<BillInvinit> _billInvinitrepository => new Repository<BillInvinit>();
  3295. /// <summary>
  3296. /// 物料表
  3297. /// </summary>
  3298. private Repository<BaseMatinfo> _basematerrepository => new Repository<BaseMatinfo>();
  3299. /// <summary>
  3300. /// 码垛工字轮信息
  3301. /// </summary>
  3302. private Repository<BillSpoolTrans> _billSpoolTransrepository => new Repository<BillSpoolTrans>();
  3303. /// <summary>
  3304. /// 异常信息
  3305. /// </summary>
  3306. private RepositoryTask<BaseErrorInfo> _baseErrorInfoRepository => new RepositoryTask<BaseErrorInfo>();
  3307. private Repository<BillBominfo> _billBominfoRepository => new Repository<BillBominfo>();
  3308. /// <summary>
  3309. /// 垛形主表
  3310. /// </summary>
  3311. private Repository<BillBomsetgrp> _BillBomsetgrpRepository => new Repository<BillBomsetgrp>();
  3312. /// <summary>
  3313. /// 垛形信息
  3314. /// </summary>
  3315. private Repository<BillBomsetinfo> _billBomsetinfoRepository => new Repository<BillBomsetinfo>();
  3316. /// <summary>
  3317. /// 单据表
  3318. /// </summary>
  3319. private Repository<BillDocsinfo> _billdocrepository => new Repository<BillDocsinfo>();
  3320. /// <summary>
  3321. /// 任务历史表
  3322. /// </summary>
  3323. private RepositoryTask<WCS_TaskOld> _wcstaskoldrepository => new RepositoryTask<WCS_TaskOld>();
  3324. /// <summary>
  3325. /// agv任务表
  3326. /// </summary>
  3327. private RepositoryTask<WCS_AgvTaskInfo> _agvTaskInfoRepository => new RepositoryTask<WCS_AgvTaskInfo>();
  3328. /// <summary>
  3329. /// 流水表
  3330. /// </summary>
  3331. private Repository<BillInvflow> _billInvflow => new Repository<BillInvflow>();
  3332. /// <summary>
  3333. /// 甲方管理系统推送反馈
  3334. /// </summary>
  3335. private Repository<BillPushinfo> _billPushinforepository => new Repository<BillPushinfo>();
  3336. /// <summary>
  3337. /// 货位表
  3338. /// </summary>
  3339. private Repository<BaseWarecell> _basewarecellrepository => new Repository<BaseWarecell>();
  3340. /// <summary>
  3341. /// 仓库表
  3342. /// </summary>
  3343. private Repository<BaseWarehouse> _basewarehouserepository => new Repository<BaseWarehouse>();
  3344. private RepositoryTask<WCS_TaskDtl> _taskdetailrepository => new RepositoryTask<WCS_TaskDtl>();
  3345. /// <summary>
  3346. /// 机台表
  3347. /// </summary>
  3348. private Repository<BillMachinfo> _basemachinforepository => new Repository<BillMachinfo>();
  3349. private Repository<BillBomsetgrp> _billBomsetgrpRepository => new Repository<BillBomsetgrp>();
  3350. private Repository<fjSysJob> _jobRepository => new Repository<fjSysJob>();
  3351. private Repository<fjSysJobApiRelation> _jobApiRepository => new Repository<fjSysJobApiRelation>();
  3352. #endregion 初始化仓储
  3353. #region 湿拉工字轮/帘线芯股信息初始化
  3354. /// <summary>
  3355. /// 湿拉工字轮/帘线芯股信息初始化
  3356. /// </summary>
  3357. /// <param name="reqDto"></param>
  3358. /// <returns></returns>
  3359. public SRes SpoolMaterialInfoTrans(SpoolMaterialInfoTransRequest reqDto)
  3360. {
  3361. var res = new SRes();
  3362. var dateTime = DateTime.Now.AddHours(-12);
  3363. #region 超时判断
  3364. //获取时间
  3365. var prodate = reqDto.ProductDate.GetDateTime(_logger);
  3366. if (prodate < dateTime)
  3367. {
  3368. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  3369. res.ResMsg = $"工字轮注册时间为{reqDto.ProductDate},已超过12小时不允许创建自动化上线任务!!!";
  3370. var error = new BaseErrorInfo
  3371. {
  3372. BusName = "湿拉下盘注册",
  3373. Message = $"{res.ResMsg},[{DateTime.Now:yyyyMMddHH}]",
  3374. Count = 1,
  3375. Memo = "WCS"
  3376. };
  3377. error.UpdataErrorinfo(_baseErrorInfoRepository);
  3378. return res;
  3379. }
  3380. #endregion
  3381. //清除十二小时小时前的新建数据
  3382. if (_taskrepository.AsQueryable().With(SqlWith.NoLock).Any(x =>
  3383. x.Status == TaskStatus.NewBuild && x.Type == TaskType.SetPlate && x.AddTime < dateTime))
  3384. {
  3385. var taskIdList = _taskrepository.AsQueryable().With("WITH(READPAST,ROWLOCK)")
  3386. .Where(x => x.Status == TaskStatus.NewBuild && x.Type == TaskType.SetPlate && x.AddTime < dateTime)
  3387. .ToList();
  3388. var ids = taskIdList.Select(x => x.ID).ToList();
  3389. //有超过十二小时小时的数据,开始清除
  3390. _taskrepository.Delete(x => ids.Contains(x.ID));
  3391. _wcstaskoldrepository.UpdateSplitTableModelColumns(x => new WCS_TaskOld
  3392. {
  3393. Status = TaskStatus.Cancel,
  3394. ManualRemarks = "产品超时,自动清除任务"
  3395. }, x => ids.Contains(x.Id));
  3396. //清除相关条码、码垛信息
  3397. var barCodes = taskIdList.Select(x => x.BarCode).ToList();
  3398. _billSpoolTransrepository.Delete(x => barCodes.Contains(x.ConBarCode));
  3399. _billInvinitrepository.Delete(x => barCodes.Contains(x.HWBarCode));
  3400. }
  3401. //容器
  3402. var container = _baseContinfo.GetSingle(p => p.ContBarCode == reqDto.SpoolCode);
  3403. if (container == null)
  3404. {
  3405. var insertcon = new BaseContinfo
  3406. {
  3407. ContBarCode = reqDto.SpoolCode,
  3408. Name = reqDto.SpoolCode,
  3409. TypeCode = ContainerType.ContainerType_Spool.ToString(),
  3410. PrintQty = 1,
  3411. IsStop = 0,
  3412. WarehouseId = 0,
  3413. WeightQty = 0,
  3414. AddWho = "wms",
  3415. AddTime = DateTime.Now
  3416. };
  3417. //新加载具信息
  3418. if (!_baseContinfo.Insert(insertcon))
  3419. {
  3420. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  3421. res.ResMsg = "工字轮载具初始化失败";
  3422. var error = new BaseErrorInfo
  3423. {
  3424. BusName = "湿拉下盘注册",
  3425. Message = $"{res.ResMsg},{DateTime.Now:yyyyMMddHH}",
  3426. Count = 1,
  3427. Memo = "WCS"
  3428. };
  3429. error.UpdataErrorinfo(_baseErrorInfoRepository);
  3430. return res;
  3431. }
  3432. }
  3433. //物料
  3434. var mater = _basematerrepository.GetSingle(p => p.Code == reqDto.MatCode);
  3435. if (mater == null)
  3436. {
  3437. res.ResCode = ResponseStatusCodeEnum.MaterInfoNotExist.GetHashCode();
  3438. res.ResMsg = ResponseStatusCodeEnum.MaterInfoNotExist.GetDescription();
  3439. var error = new BaseErrorInfo
  3440. {
  3441. BusName = "湿拉下盘注册",
  3442. Message = $"{res.ResMsg},{DateTime.Now:yyyyMMddHH}",
  3443. Count = 1,
  3444. Memo = "WCS"
  3445. };
  3446. error.UpdataErrorinfo(_baseErrorInfoRepository);
  3447. return res;
  3448. }
  3449. //码垛工字轮
  3450. var billSpoolTrans = new BillSpoolTrans();
  3451. billSpoolTrans.ConBarCode = reqDto.SpoolCode;
  3452. billSpoolTrans.BillCode = reqDto.BillCode;
  3453. billSpoolTrans.WorkOrder = reqDto.WorkOrder;
  3454. billSpoolTrans.MatCode = reqDto.MatCode;
  3455. billSpoolTrans.WarehouseCode = "";
  3456. billSpoolTrans.WarehouseSort = 0;
  3457. billSpoolTrans.LocSort = 0;
  3458. billSpoolTrans.ConveyorSort = 0;
  3459. billSpoolTrans.Direct = "";
  3460. billSpoolTrans.ErrType = 0;
  3461. billSpoolTrans.AddTime = DateTime.Now;
  3462. billSpoolTrans.EditTime = DateTime.Now;
  3463. billSpoolTrans.AddWho = "wms";
  3464. billSpoolTrans.EditWho = "wms";
  3465. //库存
  3466. var stock = _billInvnowrepository.GetSingle(p => p.HWBarCode == reqDto.SpoolCode);
  3467. if (stock != null && stock.InvStateCode == InvState.InvEcecState_In.ToString())
  3468. {
  3469. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  3470. res.ResMsg = "该工字轮条码号已在库中,请检查RFID号是否重复";
  3471. return res;
  3472. }
  3473. if (stock != null && stock.InvStateCode == InvState.InvEcecState_OutGoing.ToString())
  3474. {
  3475. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  3476. res.ResMsg = "该工字轮条码号存在出库中任务,请检查上一个任务是否已经完成";
  3477. var error = new BaseErrorInfo
  3478. {
  3479. BusName = "湿拉下盘注册",
  3480. Message = $"{res.ResMsg},{DateTime.Now:yyyyMMddHH}",
  3481. Count = 1,
  3482. Memo = "WCS"
  3483. };
  3484. error.UpdataErrorinfo(_baseErrorInfoRepository);
  3485. return res;
  3486. }
  3487. //工字轮需要用到的托盘类型
  3488. var fJPalletType = FJPalletType.Pallet09;
  3489. if (reqDto.SpoolType != "WS09") fJPalletType = FJPalletType.PalletNo09;
  3490. //通过订单找到对应的机台信息
  3491. //通过投入物料找到垛型编码
  3492. var stackdetail = _billBomsetinfoRepository.GetFirst(p => p.MatCode == reqDto.MatCode && p.IsStop == 0);
  3493. if (stackdetail == null)
  3494. {
  3495. _logger.LogInformation(reqDto.SpoolCode + "没有对应的垛型信息,物料编码" + reqDto.MatCode);
  3496. _billInvinitrepository.Delete(x => x.ContGrpBarCode == billSpoolTrans.ConBarCode);
  3497. _billSpoolTransrepository.Delete(x => x.ConBarCode == billSpoolTrans.ConBarCode);
  3498. _logger.LogInformation($"找不到垛形信息时删除缓存信息{billSpoolTrans.ConBarCode}");
  3499. var task = _taskrepository.GetSingle(x => x.BarCode == billSpoolTrans.ConBarCode);
  3500. if (task != null)
  3501. {
  3502. //删除当前任务与更新历史任务
  3503. _taskrepository.Delete(x => x.ID == task.ID);
  3504. _wcstaskoldrepository.UpdateSplitTableModelColumns(x => new WCS_TaskOld
  3505. {
  3506. Status = TaskStatus.Cancel,
  3507. ManualRemarks = "产品重新投放,自动覆盖历史信息"
  3508. }, x => x.Id == task.ID);
  3509. }
  3510. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  3511. res.ResMsg = reqDto.SpoolCode + "没有对应的垛型信息,物料编码" + reqDto.MatCode;
  3512. var error = new BaseErrorInfo
  3513. {
  3514. BusName = "湿拉下盘注册",
  3515. Message = $"{res.ResMsg},{DateTime.Now:yyyyMMddHH}",
  3516. Count = 1,
  3517. Memo = "WCS"
  3518. };
  3519. error.UpdataErrorinfo(_baseErrorInfoRepository);
  3520. return res;
  3521. }
  3522. //机台垛型编码
  3523. var stack = _BillBomsetgrpRepository.GetSingle(p => p.Id == stackdetail.BomSetHdrId && p.IsStop == 0);
  3524. var macList = _basemachinforepository.GetList(p => stack.Code == p.SetGrpCode); //找到垛型对应的机台信息
  3525. //查询出来的垛型没有对应的机台,开始尝试通过产出匹配机台(适配同产出配多个垛型的情况)
  3526. if (macList.Count <= 0)
  3527. {
  3528. //查出当前这个垛型同产出对应的所有启用垛型
  3529. var stacks =
  3530. _BillBomsetgrpRepository.GetList(p => p.ProMaterCode == stack.ProMaterCode && p.IsStop == 0);
  3531. var stackCodes = stacks.Select(x => x.Code).ToList();
  3532. macList = _basemachinforepository.GetList(p => stackCodes.Contains(p.SetGrpCode));
  3533. }
  3534. //查询机台
  3535. var wareList = macList.Where(x => !x.WarehouseCode.IsNullOrEmpty()).Select(p => p.WarehouseCode).Distinct()
  3536. .OrderBy(v => v); //找到机台对应的仓库信息
  3537. if (!wareList.Any()) //当前订单没有对应仓库信息
  3538. {
  3539. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  3540. res.ResMsg = $"条码:[{reqDto.SpoolCode}]对应的垛型[{stack.Code}]没有配置机台信息";
  3541. var error = new BaseErrorInfo
  3542. {
  3543. BusName = "湿拉下盘注册",
  3544. Message = $"{res.ResMsg},{DateTime.Now:yyyyMMddHH}",
  3545. Count = 1,
  3546. Memo = "WCS"
  3547. };
  3548. error.UpdataErrorinfo(_baseErrorInfoRepository);
  3549. return res;
  3550. }
  3551. if (wareList.Count() == 1) //当前订单对应一个仓库信息
  3552. {
  3553. var sort = int.Parse(wareList.First().Substring(0, 1));
  3554. _billSpoolTransrepository.UpdateModelColumns(p => new BillSpoolTrans
  3555. {
  3556. WarehouseCode = wareList.First(),
  3557. WarehouseSort = sort,
  3558. Direct = wareList.First().Substring(1, 1),
  3559. EditTime = DateTime.Now
  3560. }, p => p.ConBarCode == billSpoolTrans.ConBarCode);
  3561. billSpoolTrans.WarehouseCode = wareList.First();
  3562. billSpoolTrans.WarehouseSort = sort;
  3563. billSpoolTrans.Direct = wareList.First().Substring(1, 1);
  3564. }
  3565. else //当前订单对应多个仓库信息
  3566. {
  3567. //先计算出当前物料在各仓库中应该的占比
  3568. var wareTempList = macList.Where(x => !x.WarehouseCode.IsNullOrEmpty())
  3569. .Select(p => new { p.WarehouseCode }).Distinct();
  3570. var statTime = DateTime.Now.AddHours(-3);
  3571. var warehouseGoods = _billSpoolTransrepository
  3572. .GetList(s => s.MatCode == reqDto.MatCode && s.AddTime > statTime).ToList();
  3573. var specificGravity = wareTempList.Select(x =>
  3574. {
  3575. decimal currentWarehouseGoodsSum = warehouseGoods.Count(s =>
  3576. s.MatCode == reqDto.MatCode && s.WarehouseCode == x.WarehouseCode);
  3577. decimal warehouseGoodsSum = warehouseGoods.Count;
  3578. var a = Convert.ToDecimal(macList.Count(m => m.WarehouseCode == x.WarehouseCode));
  3579. var b = Convert.ToDecimal(macList.Count);
  3580. var specificGravityValue = b == 0 ? 0 : a / b;
  3581. var currentSpecificGravityValue =
  3582. warehouseGoodsSum == 0 ? 0 : currentWarehouseGoodsSum / warehouseGoodsSum;
  3583. return new
  3584. {
  3585. x.WarehouseCode,
  3586. a,
  3587. b,
  3588. SpecificGravity = specificGravityValue, //预期比重
  3589. WarehouseGoods = warehouseGoodsSum, //三个分拣中心实际数量
  3590. CurrentWarehouseGoods = currentWarehouseGoodsSum, //当前分拣中心实际数量
  3591. CurrentSpecificGravity = currentSpecificGravityValue, //当前分拣库实际已有货物占比
  3592. //实际比重与预期比重差值
  3593. //实际比重大于预期比重的默认排在最后
  3594. //实际比重减去预期比重,结果值越大应优先送往
  3595. ProportionGap = currentSpecificGravityValue > specificGravityValue
  3596. ? 0
  3597. : specificGravityValue - currentSpecificGravityValue,
  3598. Direct = x.WarehouseCode.Substring(1, 1)
  3599. };
  3600. }).OrderByDescending(x => x.ProportionGap) //比差越大应当越优先送过去
  3601. .ThenByDescending(x => x.SpecificGravity); //在各库已有货物实际占比达到预期值时按照预期占比最多的优先分配
  3602. _logger.LogInformation($"SpoolMaterialInfoTrans:{JsonConvert.SerializeObject(specificGravity)}");
  3603. var sort = int.Parse(wareList.First().Substring(0, 1));
  3604. _billSpoolTransrepository.UpdateModelColumns(p => new BillSpoolTrans
  3605. {
  3606. WarehouseCode = specificGravity.FirstOrDefault().WarehouseCode,
  3607. WarehouseSort = sort,
  3608. Direct = specificGravity.FirstOrDefault().Direct,
  3609. EditTime = DateTime.Now
  3610. }, p => p.ConBarCode == billSpoolTrans.ConBarCode);
  3611. billSpoolTrans.WarehouseCode = specificGravity.FirstOrDefault().WarehouseCode;
  3612. billSpoolTrans.WarehouseSort = sort;
  3613. billSpoolTrans.Direct = specificGravity.FirstOrDefault().Direct;
  3614. }
  3615. var promat = _basematerrepository.GetSingle(p => p.Code == stack.ProMaterCode);
  3616. //创建条码
  3617. var wareHosue = _basewarehouserepository.GetSingle(p => p.Code == billSpoolTrans.WarehouseCode);
  3618. //检查条码
  3619. var barInfo = _billInvinitrepository.GetFirst(p => p.HWBarCode == reqDto.SpoolCode);
  3620. var gra = "";
  3621. if (reqDto.Grade != null && !string.IsNullOrEmpty(reqDto.Grade)) gra = reqDto.Grade;
  3622. if (barInfo == null) //当前条码无残留信息
  3623. {
  3624. var barinfo = InitInvinitInfo(reqDto, wareHosue, stack, mater, promat, fJPalletType);
  3625. try
  3626. {
  3627. _db.BeginTran();
  3628. _billInvinitrepository.InsertReturnEntity(barinfo);
  3629. _billSpoolTransrepository.InsertReturnEntity(billSpoolTrans);
  3630. //删除因异常导致残留的对应库存信息
  3631. _billInvnowrepository.Delete(x =>
  3632. x.ContGrpBarCode == billSpoolTrans.ConBarCode || x.HWBarCode == billSpoolTrans.ConBarCode);
  3633. //开始生成WCS
  3634. var createStockInWcsTaskReqest = new FJCreateStockInWcsTaskRequest
  3635. {
  3636. BusType = FJTaskBusType.二楼组盘.GetDescription(),
  3637. ContGrpBarCode = reqDto.SpoolCode,
  3638. Qty = 1,
  3639. WarehouseCode = billSpoolTrans.WarehouseCode,
  3640. Floor = 2,
  3641. MatCode = billSpoolTrans.MatCode,
  3642. EquCode = "Robot",
  3643. Type = TaskType.SetPlate,
  3644. DocCode = billSpoolTrans.WorkOrder,
  3645. WorkBench = reqDto.WbCode
  3646. };
  3647. //下发wcs任务 - 分解方法
  3648. var taskRes = CreateStockInWcsTask(createStockInWcsTaskReqest, gra, true);
  3649. if (taskRes.ResCode != 200)
  3650. {
  3651. _db.RollbackTran();
  3652. res.ResCode = taskRes.ResCode;
  3653. res.ResMsg = taskRes.ResMsg;
  3654. var error = new BaseErrorInfo
  3655. {
  3656. BusName = "湿拉下盘注册",
  3657. Message = $"{res.ResMsg},{DateTime.Now:yyyyMMddHH}",
  3658. Count = 1,
  3659. Memo = "WCS"
  3660. };
  3661. error.UpdataErrorinfo(_baseErrorInfoRepository);
  3662. return res;
  3663. }
  3664. _db.CommitTran();
  3665. RedisHelper.Set($"AllocationWarehouseSort:{reqDto.SpoolCode}", JsonConvert.SerializeObject(
  3666. new MainlineDiversion
  3667. {
  3668. TaskId = taskRes.ResData.ID,
  3669. WarehouseCode = billSpoolTrans.WarehouseCode
  3670. }));
  3671. }
  3672. catch (Exception ex)
  3673. {
  3674. _db.RollbackTran();
  3675. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  3676. res.ResMsg = ex.StackTrace;
  3677. }
  3678. }
  3679. else //有残留条码信息更新
  3680. {
  3681. try
  3682. {
  3683. //开始生成WCS
  3684. var createStockInWcsTaskReqest = new FJCreateStockInWcsTaskRequest
  3685. {
  3686. BusType = FJTaskBusType.二楼组盘.GetDescription(),
  3687. ContGrpBarCode = reqDto.SpoolCode,
  3688. Qty = 1,
  3689. WarehouseCode = billSpoolTrans.WarehouseCode,
  3690. Floor = 2,
  3691. MatCode = billSpoolTrans.MatCode,
  3692. EquCode = "Robot",
  3693. Type = TaskType.SetPlate,
  3694. DocCode = billSpoolTrans.WorkOrder,
  3695. WorkBench = reqDto.WbCode
  3696. };
  3697. var barinfo = InitInvinitInfo(reqDto, wareHosue, stack, mater, promat, fJPalletType);
  3698. _db.BeginTran();
  3699. //更新条码信息
  3700. _billInvinitrepository.Delete(x => x.Id == barInfo.Id);
  3701. _billInvinitrepository.InsertReturnEntity(barinfo);
  3702. //更新码垛信息
  3703. _billSpoolTransrepository.UpdateModelColumns(x => new BillSpoolTrans
  3704. {
  3705. ConBarCode = reqDto.SpoolCode,
  3706. BillCode = reqDto.BillCode,
  3707. WorkOrder = reqDto.WorkOrder,
  3708. MatCode = reqDto.MatCode,
  3709. WarehouseCode = billSpoolTrans.WarehouseCode,
  3710. WarehouseSort = billSpoolTrans.WarehouseSort,
  3711. LocSort = 0,
  3712. ConveyorSort = 0,
  3713. Direct = billSpoolTrans.Direct,
  3714. ErrType = 0,
  3715. EditTime = DateTime.Now,
  3716. EditWho = "wms"
  3717. }, x => x.ConBarCode == billSpoolTrans.ConBarCode);
  3718. if (!_billSpoolTransrepository.GetList(x => x.ConBarCode == billSpoolTrans.ConBarCode).Any())
  3719. _billSpoolTransrepository.InsertReturnEntity(billSpoolTrans);
  3720. //删除对应的库存信息
  3721. _billInvnowrepository.Delete(x =>
  3722. x.ContGrpBarCode == billSpoolTrans.ConBarCode || x.HWBarCode == billSpoolTrans.ConBarCode);
  3723. var taskIdList = _taskrepository.AsQueryable().With(SqlWith.NoLock)
  3724. .Where(x => x.BarCode == billSpoolTrans.ConBarCode).Select(x => x.ID).ToList();
  3725. //下发wcs任务 - 分解方法
  3726. var taskRes = CreateStockInWcsTask(createStockInWcsTaskReqest, gra, true);
  3727. if (taskRes.ResCode != 200)
  3728. {
  3729. _db.RollbackTran();
  3730. res.ResCode = taskRes.ResCode;
  3731. res.ResMsg = taskRes.ResMsg;
  3732. var error = new BaseErrorInfo
  3733. {
  3734. BusName = "湿拉下盘注册",
  3735. Message = $"{res.ResMsg},{DateTime.Now:yyyyMMddHH}",
  3736. Count = 1,
  3737. Memo = "WCS"
  3738. };
  3739. error.UpdataErrorinfo(_baseErrorInfoRepository);
  3740. return res;
  3741. }
  3742. if (taskIdList != null)
  3743. {
  3744. //删除当前任务与更新历史任务
  3745. _taskrepository.Delete(x => taskIdList.Contains(x.ID));
  3746. _wcstaskoldrepository.UpdateSplitTableModelColumns(x => new WCS_TaskOld
  3747. {
  3748. Status = TaskStatus.Cancel,
  3749. ManualRemarks = "产品重新投放,自动覆盖历史信息"
  3750. }, x => taskIdList.Contains(x.Id));
  3751. }
  3752. _db.CommitTran();
  3753. //RedisHelper.Set($"AllocationWarehouseSort:{reqDto.SpoolCode}", JsonConvert.SerializeObject(new MainlineDiversion
  3754. //{
  3755. // TaskId = taskRes.ResData.ID,
  3756. // WarehouseCode = billSpoolTrans.WarehouseCode
  3757. //}));
  3758. }
  3759. catch (Exception ex)
  3760. {
  3761. _db.RollbackTran();
  3762. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  3763. res.ResMsg = ex.StackTrace;
  3764. var error = new BaseErrorInfo
  3765. {
  3766. BusName = "湿拉下盘注册",
  3767. Message = $"{res.ResMsg},{DateTime.Now:yyyyMMddHH}",
  3768. Count = 1,
  3769. Memo = "WCS"
  3770. };
  3771. error.UpdataErrorinfo(_baseErrorInfoRepository);
  3772. }
  3773. }
  3774. return res;
  3775. }
  3776. /// <summary>
  3777. /// 生成条码信息
  3778. /// </summary>
  3779. /// <param name="reqDto">请求实体</param>
  3780. /// <param name="wareHosue">仓库信息</param>
  3781. /// <param name="stack">垛形信息</param>
  3782. /// <param name="mater">物料信息</param>
  3783. /// <param name="promat">帘线物料信息</param>
  3784. /// <param name="fJPalletType">托盘类型</param>
  3785. /// <returns></returns>
  3786. public BillInvinit InitInvinitInfo(SpoolMaterialInfoTransRequest reqDto, BaseWarehouse wareHosue,
  3787. BillBomsetgrp stack, BaseMatinfo mater, BaseMatinfo promat, FJPalletType fJPalletType)
  3788. {
  3789. var invInit = new BillInvinit();
  3790. invInit.InvBarCode = reqDto.MatBarCode;
  3791. invInit.WarehouseId = wareHosue != null ? wareHosue.Id : 0;
  3792. invInit.ExecStateCode = InvLockState.InvState_Normal.ToString();
  3793. invInit.ExecDocsNo = reqDto.WorkOrder;
  3794. invInit.ExecDocsRowNo = reqDto.MatBarCode;
  3795. invInit.ExecDocsTypeCode = DocType.DocType_FJ_WetStockIn.GetHashCode().ToString();
  3796. invInit.InvInOut = FJInvInOutType.In;
  3797. invInit.ExecWho = "MES";
  3798. invInit.EditTime = DateTime.Now;
  3799. invInit.InvStateCode = InvState.InvEcecState_BuildUp.ToString();
  3800. invInit.InDocsNo = reqDto.BillCode;
  3801. invInit.InDocsRowNo = reqDto.MatBarCode;
  3802. invInit.SuppCode = "";
  3803. invInit.BomDocsNo = stack.BomCode;
  3804. invInit.BomSetId = stack.Id;
  3805. invInit.SetGrpCode = stack.Code;
  3806. invInit.BomMatCode = promat.Code;
  3807. invInit.BomMatId = promat.Id;
  3808. invInit.BomMatName = promat.Name;
  3809. invInit.MatId = mater.Id;
  3810. invInit.MatCode = mater.Code;
  3811. invInit.MatName = mater.Name;
  3812. invInit.LengthQty = reqDto.Length;
  3813. invInit.TareWQty = reqDto.Weight;
  3814. invInit.ProductTime = DateTime.Parse(reqDto.ProductDate);
  3815. invInit.RFIDBarCode = "";
  3816. invInit.ProductLineNo = reqDto.WbCode;
  3817. invInit.Grade = reqDto.Grade;
  3818. invInit.HWBarCode = reqDto.SpoolCode;
  3819. invInit.HWTypeCode = reqDto.SpoolType; //工字轮类型
  3820. invInit.ContGrpBarCode = reqDto.SpoolCode;
  3821. invInit.ContGrpType = FJContGrpType.Material;
  3822. invInit.ContGrpId = IdFactory.NewId();
  3823. invInit.IsFast = reqDto.IsFast;
  3824. invInit.IsRework = false;
  3825. invInit.CLBarCode = reqDto.MatBarCode;
  3826. invInit.Size = 1;
  3827. invInit.AddTime = DateTime.Now;
  3828. invInit.BackReason = "";
  3829. invInit.IsBack = reqDto.IsBack;
  3830. invInit.SilkTypeCode = reqDto.SilkType;
  3831. invInit.IsCore = reqDto.BusType == 1;
  3832. invInit.PalletType = fJPalletType;
  3833. return invInit;
  3834. }
  3835. #endregion 湿拉工字轮/帘线芯股信息初始化
  3836. #region 同WCS交互部分
  3837. #region 满轮主线
  3838. /// <summary>
  3839. /// 工字轮/芯股进入主线扫码
  3840. /// </summary>
  3841. /// <returns></returns>
  3842. public SRes<SRes> EnteMainLine(FJEnteMainLineRequest reqDto)
  3843. {
  3844. var res = new SRes<SRes>();
  3845. return res;
  3846. }
  3847. /// <summary>
  3848. /// 码垛创建异常任务
  3849. /// </summary>
  3850. /// <param name="reqDto"></param>
  3851. /// <returns></returns>
  3852. public SRes PalletizingCreateseErrorTasks(PalletizingCreateseErrorTasksRequest reqDto)
  3853. {
  3854. var res = new SRes();
  3855. //异常物料的物料号使用Error + 型号组合而成
  3856. var matCode = "Error" + reqDto.Type;
  3857. //物料
  3858. var mater = _basematerrepository.GetSingle(p => p.Code == matCode);
  3859. if (mater == null)
  3860. {
  3861. res.ResCode = ResponseStatusCodeEnum.MaterInfoNotExist.GetHashCode();
  3862. res.ResMsg = ResponseStatusCodeEnum.MaterInfoNotExist.GetDescription();
  3863. return res;
  3864. }
  3865. //判断任务表中是否有相同物料号、起始地址且未结束的任务
  3866. var wcsTask = _wcstaskoldrepository.AsQueryable().With(SqlWith.NoLock)
  3867. .Where(p => p.MatCode == matCode && p.AddrFrom == reqDto.EquNo && p.Status < TaskStatus.Finish)
  3868. .SplitTable(tabs => tabs.Take(2)).First();
  3869. ;
  3870. if (wcsTask != null && wcsTask.Status < TaskStatus.FinishOfShunt) // 如果任务状态小于分流结束,表示已有任务,无需重新生成
  3871. {
  3872. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  3873. res.ResMsg = $"{reqDto.EquNo}已有新建任务,需优先处理任务{wcsTask.Id}";
  3874. return res;
  3875. }
  3876. //生成一个随机条码
  3877. var spoolCode = $"Error{reqDto.Type}{IdFactory.GetInstance().NextId()}";
  3878. //码垛工字轮
  3879. var billSpoolTrans = new BillSpoolTrans();
  3880. billSpoolTrans.ConBarCode = spoolCode;
  3881. billSpoolTrans.BillCode = "";
  3882. billSpoolTrans.WorkOrder = "";
  3883. billSpoolTrans.MatCode = matCode;
  3884. billSpoolTrans.WarehouseCode = reqDto.WarehouseCode;
  3885. billSpoolTrans.WarehouseSort = 0;
  3886. billSpoolTrans.LocSort = 0;
  3887. billSpoolTrans.ConveyorSort = 0;
  3888. billSpoolTrans.Direct = "";
  3889. billSpoolTrans.ErrType = 0;
  3890. billSpoolTrans.AddTime = DateTime.Now;
  3891. billSpoolTrans.EditTime = DateTime.Now;
  3892. billSpoolTrans.AddWho = "wms";
  3893. billSpoolTrans.EditWho = "wms";
  3894. //库存
  3895. var stock = _billInvnowrepository.GetSingle(p => p.HWBarCode == spoolCode);
  3896. if (stock != null && stock.InvStateCode == InvState.InvEcecState_In.ToString())
  3897. {
  3898. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  3899. res.ResMsg = "该工字轮条码号已在库中,请检查RFID号是否重复";
  3900. return res;
  3901. }
  3902. if (stock != null && stock.InvStateCode == InvState.InvEcecState_OutGoing.ToString())
  3903. {
  3904. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  3905. res.ResMsg = "该工字轮条码号存在出库中任务,请检查上一个任务是否已经完成";
  3906. return res;
  3907. }
  3908. //检查条码
  3909. var barstock = _billInvinitrepository.GetFirst(p => p.HWBarCode == spoolCode);
  3910. if (barstock != null)
  3911. {
  3912. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  3913. res.ResMsg = barstock.HWBarCode + "已使用请检查条码是否重复";
  3914. return res;
  3915. }
  3916. //工字轮需要用到的托盘类型
  3917. var fJPalletType = FJPalletType.Pallet09;
  3918. if (reqDto.Type != "9") fJPalletType = FJPalletType.PalletNo09;
  3919. var prodate = DateTime.Now;
  3920. //通过投入物料找到垛型编码
  3921. var stackdetail = _billBomsetinfoRepository.GetFirst(p => p.MatCode == matCode);
  3922. if (stackdetail == null)
  3923. {
  3924. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  3925. res.ResMsg = $"请配置{reqDto.Type}工字轮对应的异常垛形";
  3926. return res;
  3927. }
  3928. var stack = _BillBomsetgrpRepository.GetSingle(p => p.Id == stackdetail.BomSetHdrId);
  3929. var promat = _basematerrepository.GetSingle(p => p.Code == stack.ProMaterCode);
  3930. //创建条码
  3931. var wareHosue = _basewarehouserepository.GetSingle(p => p.Code == billSpoolTrans.WarehouseCode);
  3932. var barinfo = new BillInvinit
  3933. {
  3934. InvBarCode = "",
  3935. WarehouseId = wareHosue != null ? wareHosue.Id : 0,
  3936. ExecStateCode = InvLockState.InvState_Normal.ToString(),
  3937. ExecDocsNo = "",
  3938. ExecDocsRowNo = "",
  3939. ExecDocsTypeCode = "",
  3940. InvInOut = FJInvInOutType.In,
  3941. ExecWho = "WMS",
  3942. EditTime = DateTime.Now,
  3943. InvStateCode = InvState.InvEcecState_BuildUp.ToString(),
  3944. InDocsNo = "",
  3945. InDocsRowNo = "",
  3946. SuppCode = "",
  3947. BomDocsNo = stack.BomCode,
  3948. BomSetId = stack.Id,
  3949. SetGrpCode = stack.Code,
  3950. BomMatCode = promat.Code,
  3951. BomMatId = promat.Id,
  3952. BomMatName = promat.Name,
  3953. MatId = mater.Id,
  3954. MatCode = mater.Code,
  3955. MatName = mater.Name,
  3956. LengthQty = 0,
  3957. TareWQty = 0,
  3958. ProductTime = prodate,
  3959. RFIDBarCode = "",
  3960. ProductLineNo = reqDto.EquNo,
  3961. Grade = "",
  3962. HWBarCode = spoolCode,
  3963. HWTypeCode = reqDto.Type, //工字轮类型
  3964. ContGrpBarCode = spoolCode,
  3965. ContGrpType = FJContGrpType.Material,
  3966. ContGrpId = IdFactory.NewId(),
  3967. IsFast = false,
  3968. IsRework = false,
  3969. CLBarCode = "",
  3970. Size = 1,
  3971. AddTime = DateTime.Now,
  3972. BackReason = "",
  3973. IsBack = false,
  3974. SilkTypeCode = "",
  3975. IsCore = false,
  3976. PalletType = fJPalletType
  3977. };
  3978. try
  3979. {
  3980. //构造WCS信息
  3981. var createStockInWcsTaskReqest = new FJCreateStockInWcsTaskRequest
  3982. {
  3983. BusType = FJTaskBusType.二楼异常组盘.GetDescription(),
  3984. ContGrpBarCode = spoolCode,
  3985. Qty = 1,
  3986. WarehouseCode = billSpoolTrans.WarehouseCode,
  3987. Floor = 2,
  3988. MatCode = billSpoolTrans.MatCode,
  3989. EquCode = reqDto.EquNo,
  3990. Type = TaskType.SetPlate,
  3991. DocCode = billSpoolTrans.WorkOrder,
  3992. GoodsType = Convert.ToInt32(reqDto.Type)
  3993. };
  3994. _db.BeginTran();
  3995. _billInvinitrepository.InsertReturnEntity(barinfo);
  3996. _billSpoolTransrepository.InsertReturnEntity(billSpoolTrans);
  3997. //下发wcs任务 - 分解方法
  3998. var graMemo = "";
  3999. if (reqDto.errType == 2)
  4000. graMemo = "南北流错";
  4001. else if (reqDto.errType == 3) graMemo = "BC";
  4002. var taskRes = CreateStockInWcsTask(createStockInWcsTaskReqest, graMemo);
  4003. if (taskRes.ResCode != 200)
  4004. {
  4005. _db.RollbackTran();
  4006. res.ResCode = taskRes.ResCode;
  4007. res.ResMsg = taskRes.ResMsg;
  4008. return res;
  4009. }
  4010. _db.CommitTran();
  4011. RedisHelper.Set($"ErrorTasks:{reqDto.EquNo}:{reqDto.Type}", JsonConvert.SerializeObject(
  4012. new MainlineDiversion
  4013. {
  4014. TaskId = taskRes.ResData.ID,
  4015. WarehouseCode = billSpoolTrans.WarehouseCode
  4016. }));
  4017. }
  4018. catch (Exception ex)
  4019. {
  4020. _db.RollbackTran();
  4021. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4022. res.ResMsg = ex.ToString();
  4023. }
  4024. return res;
  4025. }
  4026. #endregion 满轮主线
  4027. #region 环形库
  4028. #region 环形库申请货位(二深)
  4029. /// <summary>
  4030. /// 环形库申请货位
  4031. /// </summary>
  4032. /// <returns></returns>
  4033. public SRes<FJApplyStockInLocResponse> RingApplyStockInLoc1(FJApplyStockInLocRequest reqEntity)
  4034. {
  4035. var res = new SRes<FJApplyStockInLocResponse>
  4036. {
  4037. ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode(),
  4038. ResMsg = ResponseStatusCodeEnum.Sucess.GetDescription(),
  4039. ResData = new FJApplyStockInLocResponse()
  4040. };
  4041. try
  4042. {
  4043. #region 任务信息是否正常
  4044. var wcsTask = _wcstaskoldrepository.AsQueryable().With("WITH(READPAST,ROWLOCK)")
  4045. .Where(p => p.Id == reqEntity.TaskNum).SplitTable(tabs => tabs.Take(2)).First();
  4046. ;
  4047. if (wcsTask == null)
  4048. {
  4049. res.ResCode = ResponseStatusCodeEnum.WcsTaskNotExist.GetHashCode();
  4050. res.ResMsg = ResponseStatusCodeEnum.WcsTaskNotExist.GetDescription();
  4051. return res;
  4052. }
  4053. if (wcsTask.Type == TaskType.OutDepot)
  4054. {
  4055. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  4056. res.ResMsg = "该任务是出库任务,不能分配货位;任务号" + wcsTask.Id;
  4057. return res;
  4058. }
  4059. if (!string.IsNullOrEmpty(wcsTask.AddrTo) && wcsTask.AddrTo != "Robot") //如果目标地址不是机器人
  4060. {
  4061. res.ResData.CellNo = wcsTask.AddrTo;
  4062. res.ResData.Row = wcsTask.AddrTo.Split('-')[0] != null
  4063. ? int.Parse(wcsTask.AddrTo.Split('-')[0])
  4064. : 0;
  4065. res.ResData.Colomn = wcsTask.AddrTo.Split('-')[1] != null
  4066. ? int.Parse(wcsTask.AddrTo.Split('-')[1])
  4067. : 0;
  4068. res.ResData.Layer = wcsTask.AddrTo.Split('-')[2] != null
  4069. ? int.Parse(wcsTask.AddrTo.Split('-')[2])
  4070. : 0;
  4071. return res;
  4072. }
  4073. #endregion 任务信息是否正常
  4074. //验证仓库信息
  4075. var wareHouse = _basewarehouserepository.GetFirst(p => p.Code == wcsTask.WarehouseCode);
  4076. if (wareHouse == null)
  4077. {
  4078. res.ResCode = ResponseStatusCodeEnum.WarehouseCodeNotExist.GetHashCode();
  4079. res.ResMsg = ResponseStatusCodeEnum.WarehouseCodeNotExist.GetDescription();
  4080. return res;
  4081. }
  4082. //验证库存
  4083. var stock = _billInvnowrepository.GetFirst(p => p.HWBarCode == wcsTask.BarCode);
  4084. if (stock == null)
  4085. {
  4086. //获取条码表相关信息
  4087. var billInvinit = _billInvinitrepository.GetList(x => x.HWBarCode == wcsTask.BarCode)
  4088. .OrderByDescending(x => x.AddTime).FirstOrDefault();
  4089. if (billInvinit == null)
  4090. {
  4091. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4092. res.ResMsg = "无条码信息";
  4093. return res;
  4094. }
  4095. //将条码表映射到库存表
  4096. stock = _mapper.Map<BillInvnow>(billInvinit);
  4097. stock.AddTime = DateTime.Now;
  4098. stock.InvStateCode = InvState.InvEcecState_BuildUp.ToString();
  4099. stock.Id = IdFactory.NewId();
  4100. if (!_billInvnowrepository.Insert(stock))
  4101. {
  4102. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  4103. res.ResMsg = "满轮库存信息存储失败";
  4104. return res;
  4105. }
  4106. }
  4107. if (stock.InvStateCode != InvState.InvEcecState_BuildUp.ToString())
  4108. {
  4109. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4110. res.ResMsg = $"工字轮{wcsTask.BarCode}库存状态异常,不是已组盘,请检查相关任务信息";
  4111. return res;
  4112. }
  4113. //获取包含当前物料、计划个数大于已有个数、未出库
  4114. var ringPalletizingInfoList = _billRingPalletizingInfo.GetList(x =>
  4115. x.WareHouseId == wareHouse.Id && x.BomCode.Contains(wcsTask.MatCode) && x.HWCountQty > x.HaveQty &&
  4116. !x.Out).OrderBy(x => x.AddTime);
  4117. BillRingPalletizingInfo ringPalletizingInfo = null;
  4118. if (ringPalletizingInfoList.Any())
  4119. foreach (var ringPalletizing in ringPalletizingInfoList)
  4120. {
  4121. if (ringPalletizingInfo != null) continue;
  4122. //取当前任务SKU在货位中已有的信息
  4123. var cells = _basewarecellrepository.Context.Queryable<BaseWarecell, BillInvnow>((loc, inv) =>
  4124. new object[]
  4125. {
  4126. JoinType.Inner, loc.ContGrpBarCode == inv.ContGrpBarCode
  4127. }).Where((loc, inv) =>
  4128. loc.GroupID == ringPalletizing.Id && (loc.StateNum == FjLocationState.Full ||
  4129. loc.StateNum == FjLocationState.StockIn))
  4130. .Select((loc, inv) => new
  4131. {
  4132. loc.GroupID,
  4133. inv.MatCode,
  4134. loc.XYNO
  4135. }).ToList().Where(x => x.MatCode == wcsTask.MatCode && x.GroupID == ringPalletizing.Id);
  4136. var bomSetInfo = _billBomsetinfoRepository.GetList(x =>
  4137. x.BomSetHdrId == ringPalletizing.BomSetGrpId && x.IsEmpty == 0 &&
  4138. x.MatCode == wcsTask.MatCode).ToList();
  4139. if (cells.Count() == bomSetInfo.Count)
  4140. {
  4141. res.Memo2 = $"[{ringPalletizing.Id}]-同规格产品已满足需求,任务[{wcsTask.Id}]创建了新的码垛信息";
  4142. ringPalletizingInfo = null;
  4143. }
  4144. else
  4145. {
  4146. ringPalletizingInfo = ringPalletizing;
  4147. }
  4148. }
  4149. if (ringPalletizingInfo != null)
  4150. {
  4151. //取当前任务SKU在货位中已有的信息
  4152. var cells = _basewarecellrepository.Context.Queryable<BaseWarecell, BillInvnow>((loc, inv) =>
  4153. new object[]
  4154. {
  4155. JoinType.Inner, loc.ContGrpBarCode == inv.ContGrpBarCode
  4156. }).Where((loc, inv) =>
  4157. loc.GroupID == ringPalletizingInfo.Id && (loc.StateNum == FjLocationState.Full ||
  4158. loc.StateNum == FjLocationState.StockIn))
  4159. .Select((loc, inv) => new
  4160. {
  4161. loc.GroupID,
  4162. inv.MatCode,
  4163. loc.XYNO
  4164. }).ToList().Where(x => x.MatCode == wcsTask.MatCode && x.GroupID == ringPalletizingInfo.Id);
  4165. var bomSetInfo = _billBomsetinfoRepository.GetList(x =>
  4166. x.BomSetHdrId == ringPalletizingInfo.BomSetGrpId && x.IsEmpty == 0 &&
  4167. x.MatCode == wcsTask.MatCode).ToList();
  4168. if (cells.Count() == bomSetInfo.Count)
  4169. {
  4170. res.Memo2 = $"[{ringPalletizingInfo.Id}]-同规格产品已满足需求,任务[{wcsTask.Id}]创建了新的码垛信息";
  4171. ringPalletizingInfo = null;
  4172. }
  4173. }
  4174. if (ringPalletizingInfo == null) //如果没有码垛信息
  4175. {
  4176. var bomsetGrp =
  4177. _billBomsetgrpRepository.GetFirst(x => x.IsStop == 0 && x.BomCode.Contains(wcsTask.MatCode));
  4178. if (bomsetGrp == null)
  4179. {
  4180. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4181. res.ResMsg = "未找到对应垛型信息,请确认是否被禁用";
  4182. return res;
  4183. }
  4184. var xyNo = _billBomsetinfoRepository.GetList(x => x.BomSetHdrId == bomsetGrp.Id && x.IsEmpty == 0)
  4185. .ToList().Select(x => Convert.ToInt32(x.XYNo)).OrderByDescending(x => x).First();
  4186. //跟据垛形信息生成
  4187. ringPalletizingInfo = new BillRingPalletizingInfo
  4188. {
  4189. Id = IdFactory.NewId(),
  4190. WareHouseId = wareHouse.Id,
  4191. BomSetGrpId = bomsetGrp.Id,
  4192. HWCountQty = bomsetGrp.HWCountQty,
  4193. BomCode = bomsetGrp.BomCode,
  4194. HaveQty = 0,
  4195. Out = false,
  4196. LastXYNO = wareHouse.Code.Contains("N") ? xyNo + 1 : 0
  4197. };
  4198. if (!_billRingPalletizingInfo.Insert(ringPalletizingInfo))
  4199. {
  4200. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  4201. res.ResMsg = "环形库满轮码垛信息存储失败";
  4202. return res;
  4203. }
  4204. res.Memo3 = $"[{wcsTask.MatCode}],任务[{wcsTask.Id}]创建了新的码垛信息";
  4205. }
  4206. //获取所有可用货位
  4207. var emptyLocList = _basewarecellrepository.Context
  4208. .Queryable<BaseWarecell, BillInvnow, BaseWarecell, BillInvnow>(
  4209. (loc1, inv1, loc2, inv2) => new object[]
  4210. {
  4211. JoinType.Left, loc1.ContGrpBarCode == inv1.ContGrpBarCode,
  4212. JoinType.Left, loc2.Col == loc1.Col && loc2.Layer == loc1.Layer,
  4213. JoinType.Left, loc2.ContGrpBarCode == inv2.ContGrpBarCode
  4214. })
  4215. .Where((loc1, inv1, loc2, inv2) =>
  4216. loc1.WarehouseId == wareHouse.Id && loc2.WarehouseId == wareHouse.Id) //保证三个深度都是同一个从仓库的
  4217. .Where((loc1, inv1, loc2, inv2) => loc1.IsStop == 0 && loc2.IsStop == 0)
  4218. .Where((loc1, inv1, loc2, inv2) => loc2.Size == loc1.Size)
  4219. .Where((loc1, inv1, loc2, inv2) =>
  4220. wcsTask.GoodsType == 34 || (wcsTask.GoodsType != 34 && loc1.Layer != 6))
  4221. .Where((loc1, inv1, loc2, inv2) => loc1.Depth == 1 && loc2.Depth == 2) //保证三个深度与字段对应
  4222. .Where((loc1, inv1, loc2, inv2) => loc2.GroupID == ringPalletizingInfo.Id) //三深货位的绑定ID是码垛缓存信息的ID
  4223. .Where((loc1, inv1, loc2, inv2) =>
  4224. (loc1.StateNum == FjLocationState.Empty && (loc2.StateNum == FjLocationState.Full ||
  4225. loc2.StateNum ==
  4226. FjLocationState.StockIn)) //1空、2有/入锁、3有
  4227. || (loc1.StateNum == FjLocationState.Empty &&
  4228. loc2.StateNum == FjLocationState.Empty) //1空、2空、3有/入锁
  4229. || (loc1.StateNum == FjLocationState.Empty && loc2.StateNum == FjLocationState.Empty)
  4230. ) //1空、2空、3空
  4231. .Where((loc1, inv1, loc2, inv2) =>
  4232. loc2.StateNum == FjLocationState.Empty ||
  4233. ((loc2.StateNum == FjLocationState.Full || loc2.StateNum == FjLocationState.StockIn) &&
  4234. inv2.MatCode == wcsTask.MatCode)
  4235. )
  4236. .Select((loc1, inv1, loc2, inv2) => new
  4237. {
  4238. Loc1Code = loc1.Code,
  4239. Loc1Id = loc1.Id,
  4240. Loc1Row = loc1.Row,
  4241. Loc1Col = loc1.Col,
  4242. Loc1Layer = loc1.Layer,
  4243. Loc1Depth = loc1.Depth,
  4244. Loc1Size = loc1.Size,
  4245. Loc1StateNum = loc1.StateNum,
  4246. Loc1ContGrpBarCode = loc1.ContGrpBarCode,
  4247. Inv1MatCode = inv1.MatCode,
  4248. Loc2Code = loc2.Code,
  4249. Loc2Id = loc2.Id,
  4250. Loc2Row = loc2.Row,
  4251. Loc2Col = loc2.Col,
  4252. Loc2Layer = loc2.Layer,
  4253. Loc2Depth = loc2.Depth,
  4254. Loc2Size = loc2.Size,
  4255. Loc2StateNum = loc2.StateNum,
  4256. Loc2ContGrpBarCode = loc2.ContGrpBarCode,
  4257. Inv2MatCode = inv2.MatCode
  4258. }).ToList();
  4259. if (emptyLocList.Any()) //有货位
  4260. {
  4261. var emptyLoc = emptyLocList.OrderByDescending(x => x.Loc2StateNum)
  4262. .ThenByDescending(x => x.Loc1StateNum)
  4263. .First();
  4264. if (emptyLoc.Loc2StateNum == FjLocationState.Empty) //次2
  4265. {
  4266. res.ResData.CellNo = emptyLoc.Loc2Code;
  4267. res.ResData.Row = emptyLoc.Loc2Row;
  4268. res.ResData.Colomn = emptyLoc.Loc2Col;
  4269. res.ResData.Layer = emptyLoc.Loc2Layer;
  4270. res.ResData.Depth = emptyLoc.Loc2Depth;
  4271. }
  4272. else if (emptyLoc.Loc1StateNum == FjLocationState.Empty) //再次1
  4273. {
  4274. res.ResData.CellNo = emptyLoc.Loc1Code;
  4275. res.ResData.Row = emptyLoc.Loc1Row;
  4276. res.ResData.Colomn = emptyLoc.Loc1Col;
  4277. res.ResData.Layer = emptyLoc.Loc1Layer;
  4278. res.ResData.Depth = emptyLoc.Loc1Depth;
  4279. }
  4280. }
  4281. else //找不到对应货位当前缓存信息对应的货位,找到三个全是同一货位的信息
  4282. {
  4283. var emptyLocList1 = _basewarecellrepository.Context
  4284. .Queryable<BaseWarecell, BaseWarecell>(
  4285. (loc1, loc2) => new object[]
  4286. {
  4287. JoinType.Left, loc2.Col == loc1.Col && loc2.Layer == loc1.Layer
  4288. })
  4289. .Where((loc1, loc2) =>
  4290. loc1.WarehouseId == wareHouse.Id && loc2.WarehouseId == wareHouse.Id) //保证三个深度都是同一个从仓库的
  4291. .Where((loc1, loc2) => loc1.IsStop == 0 && loc2.IsStop == 0)
  4292. .Where((loc1, loc2) => loc2.Size == loc1.Size)
  4293. .Where((loc1, loc2) => wcsTask.GoodsType == 34 || (wcsTask.GoodsType != 34 && loc1.Layer != 6))
  4294. .Where((loc1, loc2) => loc1.Depth == 1 && loc2.Depth == 2) //保证三个深度与字段对应
  4295. .Where((loc1, loc2) => loc1.GroupID == 0 && loc2.GroupID == 0) //获取三个货位都是没有绑定缓存信息的
  4296. .Where((loc1, loc2) =>
  4297. loc1.StateNum == FjLocationState.Empty && loc2.StateNum == FjLocationState.Empty) //1空、2空、3空
  4298. .Select((loc1, loc2) => new
  4299. {
  4300. Loc1Code = loc1.Code,
  4301. Loc1Id = loc1.Id,
  4302. Loc1Row = loc1.Row,
  4303. Loc1Col = loc1.Col,
  4304. Loc1Layer = loc1.Layer,
  4305. Loc1Depth = loc1.Depth,
  4306. Loc1Size = loc1.Size,
  4307. Loc1StateNum = loc1.StateNum,
  4308. Loc1ContGrpBarCode = loc1.ContGrpBarCode,
  4309. Loc2Code = loc2.Code,
  4310. Loc2Id = loc2.Id,
  4311. Loc2Row = loc2.Row,
  4312. Loc2Col = loc2.Col,
  4313. Loc2Layer = loc2.Layer,
  4314. Loc2Depth = loc2.Depth,
  4315. Loc2Size = loc2.Size,
  4316. Loc2StateNum = loc2.StateNum,
  4317. Loc2ContGrpBarCode = loc2.ContGrpBarCode
  4318. }).ToList();
  4319. if (emptyLocList1.Any())
  4320. {
  4321. var emptyLoc = emptyLocList1.OrderBy(x => x.Loc2Layer).ThenBy(x => x.Loc2Col).First();
  4322. res.ResData.CellNo = emptyLoc.Loc2Code;
  4323. res.ResData.Row = emptyLoc.Loc2Row;
  4324. res.ResData.Colomn = emptyLoc.Loc2Col;
  4325. res.ResData.Layer = emptyLoc.Loc2Layer;
  4326. res.ResData.Depth = emptyLoc.Loc2Depth;
  4327. }
  4328. }
  4329. if (string.IsNullOrEmpty(res.ResData.CellNo)) //没有分配货位
  4330. {
  4331. res.ResCode = ResponseStatusCodeEnum.NotEnoughLocation.GetHashCode();
  4332. res.ResMsg = "有空货位单无可用货位";
  4333. return res;
  4334. }
  4335. List<BillBomsetinfo> bomSetInfos = new List<BillBomsetinfo>();
  4336. //分配当前轮子在垛形中的位置
  4337. if (wareHouse.Code.Contains("N")) //北侧由大到小,出的时候刚好可用反过来;
  4338. {
  4339. //取当前任务SKU在货位中已有的信息
  4340. var cells = _basewarecellrepository.Context.Queryable<BaseWarecell, BillInvnow>((loc, inv) =>
  4341. new object[]
  4342. {
  4343. JoinType.Inner, loc.ContGrpBarCode == inv.ContGrpBarCode
  4344. }).Where((loc, inv) =>
  4345. loc.GroupID == ringPalletizingInfo.Id && (loc.StateNum == FjLocationState.Full ||
  4346. loc.StateNum == FjLocationState.StockIn))
  4347. .Select((loc, inv) => new
  4348. {
  4349. loc.GroupID,
  4350. inv.MatCode,
  4351. loc.XYNO
  4352. }).ToList();
  4353. if (cells.Count != ringPalletizingInfo.HaveQty)
  4354. {
  4355. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4356. res.ResMsg =
  4357. $"码垛信息组【{ringPalletizingInfo.Id}】记录已有【{ringPalletizingInfo.HaveQty}】个轮子,但对应的库存信息只有【{cells.Count}】,请在WMS检查对应的库存信息";
  4358. return res;
  4359. }
  4360. var cellMatCodeList = cells.Where(x => x.MatCode == wcsTask.MatCode);
  4361. //取当前SKU在垛形明细中所有的信息
  4362. bomSetInfos = _billBomsetinfoRepository.GetList(x =>
  4363. x.BomSetHdrId == ringPalletizingInfo.BomSetGrpId && x.IsEmpty == 0 &&
  4364. x.MatCode == wcsTask.MatCode).ToList();
  4365. //取当前SKU在垛形明细中最大的一个坐标号,初始化时默认取第一个
  4366. var lastXYNO = Convert.ToInt32(bomSetInfos.Select(x => Convert.ToInt32(x.XYNo))
  4367. .OrderByDescending(x => x).First());
  4368. if (cellMatCodeList.Any()) //货位中已有当前SKU的产品,取最小数,最小数表示最近入库的
  4369. {
  4370. lastXYNO = cellMatCodeList.OrderBy(x => x.XYNO).First().XYNO;
  4371. var xyNo = bomSetInfos.Select(x => Convert.ToInt32(x.XYNo)).Where(x => x < lastXYNO)
  4372. .OrderByDescending(x => x).First();
  4373. ringPalletizingInfo.LastXYNO = xyNo;
  4374. }
  4375. else
  4376. {
  4377. ringPalletizingInfo.LastXYNO = lastXYNO;
  4378. }
  4379. }
  4380. else //南侧小到大,出的时候刚好可用反过来;
  4381. {
  4382. //取当前任务SKU在货位中已有的信息
  4383. var cells = _basewarecellrepository.Context.Queryable<BaseWarecell, BillInvnow>((loc, inv) =>
  4384. new object[]
  4385. {
  4386. JoinType.Inner, loc.ContGrpBarCode == inv.ContGrpBarCode
  4387. }).Where((loc, inv) =>
  4388. loc.GroupID == ringPalletizingInfo.Id && (loc.StateNum == FjLocationState.Full ||
  4389. loc.StateNum == FjLocationState.StockIn))
  4390. .Select((loc, inv) => new
  4391. {
  4392. loc.GroupID,
  4393. inv.MatCode,
  4394. loc.XYNO
  4395. }).ToList();
  4396. if (cells.Count != ringPalletizingInfo.HaveQty)
  4397. {
  4398. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4399. res.ResMsg =
  4400. $"码垛信息组【{ringPalletizingInfo.Id}】记录已有【{ringPalletizingInfo.HaveQty}】个轮子,但对应的库存信息只有【{cells.Count}】,请在WMS检查对应的库存信息";
  4401. return res;
  4402. }
  4403. var cellMatCodeList = cells.Where(x => x.MatCode == wcsTask.MatCode);
  4404. //取当前SKU在垛形明细中所有的信息
  4405. bomSetInfos = _billBomsetinfoRepository.GetList(x =>
  4406. x.BomSetHdrId == ringPalletizingInfo.BomSetGrpId && x.IsEmpty == 0 &&
  4407. x.MatCode == wcsTask.MatCode).ToList();
  4408. //取当前SKU在垛形明细中最小的一个坐标号 ,初始化时默认取第一个
  4409. var lastXYNO =
  4410. Convert.ToInt32(bomSetInfos.Select(x => Convert.ToInt32(x.XYNo)).OrderBy(x => x).First());
  4411. if (cellMatCodeList.Any()) //货位中已有当前SKU的产品,取最大数 最大数表示最近入库的
  4412. {
  4413. lastXYNO = cellMatCodeList.OrderByDescending(x => x.XYNO).First().XYNO;
  4414. var xyNo = bomSetInfos.Select(x => Convert.ToInt32(x.XYNo)).Where(x => x > lastXYNO)
  4415. .OrderBy(x => x).First();
  4416. ringPalletizingInfo.LastXYNO = xyNo;
  4417. }
  4418. else
  4419. {
  4420. ringPalletizingInfo.LastXYNO = lastXYNO;
  4421. }
  4422. }
  4423. if (_basewarecellrepository.AsQueryable().With(SqlWith.NoLock).Any(x =>
  4424. x.GroupID == ringPalletizingInfo.Id && x.XYNO == ringPalletizingInfo.LastXYNO))
  4425. {
  4426. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4427. res.ResMsg = $"当前位置已经被分配过了,请检查异常码垛信息{ringPalletizingInfo.Id}-{ringPalletizingInfo.LastXYNO}";
  4428. return res;
  4429. }
  4430. try
  4431. {
  4432. _db.BeginTran();
  4433. var task = _wcstaskoldrepository.AsQueryable().With("WITH(READPAST,ROWLOCK)")
  4434. .Where(p => p.Id == reqEntity.TaskNum)
  4435. .SplitTable(x => x.Take(2)).First();
  4436. if (task == null)
  4437. {
  4438. res.ResCode = ResponseStatusCodeEnum.WcsTaskNotExist.GetHashCode();
  4439. res.ResMsg = ResponseStatusCodeEnum.WcsTaskNotExist.GetDescription();
  4440. return res;
  4441. }
  4442. if (task.Type == TaskType.OutDepot)
  4443. {
  4444. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  4445. res.ResMsg = "该任务是出库任务,不能分配货位;任务号" + task.Id;
  4446. return res;
  4447. }
  4448. var outTime = ringPalletizingInfo.AddTime;
  4449. if (stock.ProductTime < ringPalletizingInfo.AddTime) outTime = stock.ProductTime;
  4450. //更新目标缓存信息
  4451. if (!_billRingPalletizingInfo.UpdateModelColumns(
  4452. p => new BillRingPalletizingInfo
  4453. {
  4454. HaveQty = ringPalletizingInfo.HaveQty + 1, LastXYNO = ringPalletizingInfo.LastXYNO,
  4455. AddTime = outTime
  4456. }, p => p.Id == ringPalletizingInfo.Id))
  4457. {
  4458. _db.RollbackTran();
  4459. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4460. res.ResMsg = $"货位{res.ResData.CellNo}被锁定";
  4461. return res;
  4462. }
  4463. //更新目标货位
  4464. if (!_basewarecellrepository.UpdateModelColumns(
  4465. p => new BaseWarecell
  4466. {
  4467. StateNum = FjLocationState.StockIn,
  4468. ContGrpBarCode = task.BarCode,
  4469. ContGrpId = stock.ContGrpId,
  4470. GroupID = ringPalletizingInfo.Id,
  4471. EditTime = DateTime.Now,
  4472. XYNO = ringPalletizingInfo.LastXYNO
  4473. },
  4474. p => p.WarehouseId == wareHouse.Id && p.Code == res.ResData.CellNo &&
  4475. p.StateNum == FjLocationState.Empty))
  4476. {
  4477. _db.RollbackTran();
  4478. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4479. res.ResMsg = $"货位{res.ResData.CellNo}被锁定";
  4480. return res;
  4481. }
  4482. //更新货位信息至历史表,防止WCS重复请求,导致信息异常
  4483. if (!_wcstaskoldrepository.UpdateSplitTableModelColumns(x => new WCS_TaskOld
  4484. {
  4485. AddrTo = res.ResData.CellNo
  4486. }, x => x.Id == wcsTask.Id && x.AddrTo == "Robot"))
  4487. {
  4488. _db.RollbackTran();
  4489. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4490. res.ResMsg = $"货位{res.ResData.CellNo}更新货位至任务历史表失败";
  4491. return res;
  4492. }
  4493. var bomSetInfo = bomSetInfos.First(x => x.XYNo == ringPalletizingInfo.LastXYNO.ToString());
  4494. //更新库存货物大小信息
  4495. _billInvnowrepository.UpdateModelColumns(
  4496. x => new BillInvnow { Size = reqEntity.Height, SideNum = bomSetInfo.SideNum },
  4497. x => x.Id == stock.Id);
  4498. _db.CommitTran();
  4499. }
  4500. catch (Exception ex)
  4501. {
  4502. _db.RollbackTran();
  4503. _logger.LogInformation(ex.ToString());
  4504. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4505. res.ResMsg = ex.Message;
  4506. }
  4507. }
  4508. catch (Exception ex)
  4509. {
  4510. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4511. res.ResMsg = ex.Message + ex.StackTrace;
  4512. }
  4513. return res;
  4514. }
  4515. /// <summary>
  4516. /// 环形库申请货位
  4517. /// </summary>
  4518. /// <returns></returns>
  4519. public SRes<FJApplyStockInLocResponse> RingApplyStockInLoc(FJApplyStockInLocRequest reqEntity)
  4520. {
  4521. var res = new SRes<FJApplyStockInLocResponse>
  4522. {
  4523. ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode(),
  4524. ResMsg = ResponseStatusCodeEnum.Sucess.GetDescription(),
  4525. ResData = new FJApplyStockInLocResponse()
  4526. };
  4527. try
  4528. {
  4529. #region 任务信息是否正常
  4530. var wcsTask = _wcstaskoldrepository.AsQueryable().With("WITH(READPAST,ROWLOCK)")
  4531. .Where(p => p.Id == reqEntity.TaskNum).SplitTable(tabs => tabs.Take(2)).First();
  4532. ;
  4533. if (wcsTask == null)
  4534. {
  4535. res.ResCode = ResponseStatusCodeEnum.WcsTaskNotExist.GetHashCode();
  4536. res.ResMsg = ResponseStatusCodeEnum.WcsTaskNotExist.GetDescription();
  4537. return res;
  4538. }
  4539. if (wcsTask.Type == TaskType.OutDepot)
  4540. {
  4541. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  4542. res.ResMsg = "该任务是出库任务,不能分配货位;任务号" + wcsTask.Id;
  4543. return res;
  4544. }
  4545. if (!string.IsNullOrEmpty(wcsTask.AddrTo) && wcsTask.AddrTo != "Robot") //如果目标地址不是机器人
  4546. {
  4547. res.ResData.CellNo = wcsTask.AddrTo;
  4548. res.ResData.Row = wcsTask.AddrTo.Split('-')[0] != null
  4549. ? int.Parse(wcsTask.AddrTo.Split('-')[0])
  4550. : 0;
  4551. res.ResData.Colomn = wcsTask.AddrTo.Split('-')[1] != null
  4552. ? int.Parse(wcsTask.AddrTo.Split('-')[1])
  4553. : 0;
  4554. res.ResData.Layer = wcsTask.AddrTo.Split('-')[2] != null
  4555. ? int.Parse(wcsTask.AddrTo.Split('-')[2])
  4556. : 0;
  4557. return res;
  4558. }
  4559. #endregion 任务信息是否正常
  4560. //验证仓库信息
  4561. var wareHouse = _basewarehouserepository.GetFirst(p => p.Code == wcsTask.WarehouseCode);
  4562. if (wareHouse == null)
  4563. {
  4564. res.ResCode = ResponseStatusCodeEnum.WarehouseCodeNotExist.GetHashCode();
  4565. res.ResMsg = ResponseStatusCodeEnum.WarehouseCodeNotExist.GetDescription();
  4566. return res;
  4567. }
  4568. //验证库存
  4569. var stock = _billInvnowrepository.GetFirst(p => p.HWBarCode == wcsTask.BarCode);
  4570. if (stock == null)
  4571. {
  4572. //获取条码表相关信息
  4573. var billInvinit = _billInvinitrepository.GetList(x => x.HWBarCode == wcsTask.BarCode)
  4574. .OrderByDescending(x => x.AddTime).FirstOrDefault();
  4575. if (billInvinit == null)
  4576. {
  4577. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4578. res.ResMsg = "无条码信息";
  4579. return res;
  4580. }
  4581. //将条码表映射到库存表
  4582. stock = _mapper.Map<BillInvnow>(billInvinit);
  4583. stock.AddTime = DateTime.Now;
  4584. stock.InvStateCode = InvState.InvEcecState_BuildUp.ToString();
  4585. stock.Id = IdFactory.NewId();
  4586. if (!_billInvnowrepository.Insert(stock))
  4587. {
  4588. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  4589. res.ResMsg = "满轮库存信息存储失败";
  4590. return res;
  4591. }
  4592. }
  4593. if (stock.InvStateCode != InvState.InvEcecState_BuildUp.ToString())
  4594. {
  4595. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4596. res.ResMsg = $"工字轮{wcsTask.BarCode}库存状态异常,不是已组盘,请检查相关任务信息";
  4597. return res;
  4598. }
  4599. //获取包含当前物料、计划个数大于已有个数、未出库
  4600. var ringPalletizingInfoList = _billRingPalletizingInfo.GetList(x =>
  4601. x.WareHouseId == wareHouse.Id && x.BomCode.Contains(wcsTask.MatCode) && x.HWCountQty > x.HaveQty &&
  4602. !x.Out).OrderBy(x => x.AddTime);
  4603. BillRingPalletizingInfo ringPalletizingInfo = null;
  4604. if (ringPalletizingInfoList.Any())
  4605. foreach (var ringPalletizing in ringPalletizingInfoList)
  4606. {
  4607. if (ringPalletizingInfo != null) continue;
  4608. //取当前任务SKU在货位中已有的信息
  4609. var cells = _basewarecellrepository.Context.Queryable<BaseWarecell, BillInvnow>((loc, inv) =>
  4610. new object[]
  4611. {
  4612. JoinType.Inner, loc.ContGrpBarCode == inv.ContGrpBarCode
  4613. }).Where((loc, inv) =>
  4614. loc.GroupID == ringPalletizing.Id && (loc.StateNum == FjLocationState.Full ||
  4615. loc.StateNum == FjLocationState.StockIn))
  4616. .Select((loc, inv) => new
  4617. {
  4618. loc.GroupID,
  4619. inv.MatCode,
  4620. loc.XYNO
  4621. }).ToList().Where(x => x.MatCode == wcsTask.MatCode && x.GroupID == ringPalletizing.Id);
  4622. var bomSetInfo = _billBomsetinfoRepository.GetList(x =>
  4623. x.BomSetHdrId == ringPalletizing.BomSetGrpId && x.IsEmpty == 0 &&
  4624. x.MatCode == wcsTask.MatCode).ToList();
  4625. if (cells.Count() == bomSetInfo.Count)
  4626. {
  4627. res.Memo2 = $"[{ringPalletizing.Id}]-同规格产品已满足需求,任务[{wcsTask.Id}]创建了新的码垛信息";
  4628. ringPalletizingInfo = null;
  4629. }
  4630. else
  4631. {
  4632. ringPalletizingInfo = ringPalletizing;
  4633. }
  4634. }
  4635. if (ringPalletizingInfo != null)
  4636. {
  4637. //取当前任务SKU在货位中已有的信息
  4638. var cells = _basewarecellrepository.Context.Queryable<BaseWarecell, BillInvnow>((loc, inv) =>
  4639. new object[]
  4640. {
  4641. JoinType.Inner, loc.ContGrpBarCode == inv.ContGrpBarCode
  4642. }).Where((loc, inv) =>
  4643. loc.GroupID == ringPalletizingInfo.Id && (loc.StateNum == FjLocationState.Full ||
  4644. loc.StateNum == FjLocationState.StockIn))
  4645. .Select((loc, inv) => new
  4646. {
  4647. loc.GroupID,
  4648. inv.MatCode,
  4649. loc.XYNO
  4650. }).ToList().Where(x => x.MatCode == wcsTask.MatCode && x.GroupID == ringPalletizingInfo.Id);
  4651. var bomSetInfo = _billBomsetinfoRepository.GetList(x =>
  4652. x.BomSetHdrId == ringPalletizingInfo.BomSetGrpId && x.IsEmpty == 0 &&
  4653. x.MatCode == wcsTask.MatCode).ToList();
  4654. if (cells.Count() == bomSetInfo.Count)
  4655. {
  4656. res.Memo2 = $"[{ringPalletizingInfo.Id}]-同规格产品已满足需求,任务[{wcsTask.Id}]创建了新的码垛信息";
  4657. ringPalletizingInfo = null;
  4658. }
  4659. }
  4660. if (ringPalletizingInfo == null) //如果没有码垛信息
  4661. {
  4662. var bomsetGrp =
  4663. _billBomsetgrpRepository.GetFirst(x => x.IsStop == 0 && x.BomCode.Contains(wcsTask.MatCode));
  4664. if (bomsetGrp == null)
  4665. {
  4666. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4667. res.ResMsg = "未找到对应垛型信息,请确认是否被禁用";
  4668. return res;
  4669. }
  4670. var xyNo = _billBomsetinfoRepository.GetList(x => x.BomSetHdrId == bomsetGrp.Id && x.IsEmpty == 0)
  4671. .ToList().Select(x => Convert.ToInt32(x.XYNo)).OrderByDescending(x => x).First();
  4672. //跟据垛形信息生成
  4673. ringPalletizingInfo = new BillRingPalletizingInfo
  4674. {
  4675. Id = IdFactory.NewId(),
  4676. WareHouseId = wareHouse.Id,
  4677. BomSetGrpId = bomsetGrp.Id,
  4678. HWCountQty = bomsetGrp.HWCountQty,
  4679. BomCode = bomsetGrp.BomCode,
  4680. HaveQty = 0,
  4681. Out = false,
  4682. LastXYNO = wareHouse.Code.Contains("N") ? xyNo + 1 : 0
  4683. };
  4684. if (!_billRingPalletizingInfo.Insert(ringPalletizingInfo))
  4685. {
  4686. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  4687. res.ResMsg = "环形库满轮码垛信息存储失败";
  4688. return res;
  4689. }
  4690. res.Memo3 = $"[{wcsTask.MatCode}],任务[{wcsTask.Id}]创建了新的码垛信息";
  4691. }
  4692. //获取所有可用货位
  4693. var emptyLocList = _basewarecellrepository.Context
  4694. .Queryable<BaseWarecell, BillInvnow, BaseWarecell, BillInvnow, BaseWarecell, BillInvnow>(
  4695. (loc1, inv1, loc2, inv2, loc3, inv3) => new object[]
  4696. {
  4697. JoinType.Left, loc1.ContGrpBarCode == inv1.ContGrpBarCode,
  4698. JoinType.Left, loc2.Col == loc1.Col && loc2.Layer == loc1.Layer,
  4699. JoinType.Left, loc2.ContGrpBarCode == inv2.ContGrpBarCode,
  4700. JoinType.Left, loc3.Col == loc2.Col && loc3.Layer == loc2.Layer,
  4701. JoinType.Left, loc3.ContGrpBarCode == inv3.ContGrpBarCode
  4702. })
  4703. .Where((loc1, inv1, loc2, inv2, loc3, inv3) => loc1.WarehouseId == wareHouse.Id && loc2.WarehouseId == wareHouse.Id && loc3.WarehouseId == wareHouse.Id) //保证三个深度都是同一个从仓库的
  4704. .Where((loc1, inv1, loc2, inv2, loc3, inv3) => loc1.IsStop == 0 && loc2.IsStop == 0 && loc3.IsStop == 0)
  4705. .Where((loc1, inv1, loc2, inv2, loc3, inv3) => loc2.Size == loc1.Size && loc3.Size == loc1.Size)
  4706. .Where((loc1, inv1, loc2, inv2, loc3, inv3) => wcsTask.GoodsType == 34 || (wcsTask.GoodsType != 34 && loc1.Layer != 6))
  4707. .Where((loc1, inv1, loc2, inv2, loc3, inv3) => loc1.Depth == 1 && loc2.Depth == 2 && loc3.Depth == 3) //保证三个深度与字段对应
  4708. .Where((loc1, inv1, loc2, inv2, loc3, inv3) => loc3.GroupID == ringPalletizingInfo.Id) //三深货位的绑定ID是码垛缓存信息的ID
  4709. .Where((loc1, inv1, loc2, inv2, loc3, inv3) =>
  4710. (loc1.StateNum == FjLocationState.Empty && (loc2.StateNum == FjLocationState.Full || loc2.StateNum == FjLocationState.StockIn) && loc3.StateNum == FjLocationState.Full) //1空、2有/入锁、3有
  4711. || (loc1.StateNum == FjLocationState.Empty && loc2.StateNum == FjLocationState.Empty && (loc3.StateNum == FjLocationState.Full || loc3.StateNum == FjLocationState.StockIn)) //1空、2空、3有/入锁
  4712. || (loc1.StateNum == FjLocationState.Empty && loc2.StateNum == FjLocationState.Empty && loc3.StateNum == FjLocationState.Empty)
  4713. ) //1空、2空、3空
  4714. .Where((loc1, inv1, loc2, inv2, loc3, inv3) =>
  4715. loc3.StateNum == FjLocationState.Empty || ((loc3.StateNum == FjLocationState.Full || loc3.StateNum == FjLocationState.StockIn) && inv3.MatCode == wcsTask.MatCode))
  4716. .Select((loc1, inv1, loc2, inv2, loc3, inv3) => new
  4717. {
  4718. Loc1Code = loc1.Code,
  4719. Loc1Id = loc1.Id,
  4720. Loc1Row = loc1.Row,
  4721. Loc1Col = loc1.Col,
  4722. Loc1Layer = loc1.Layer,
  4723. Loc1Depth = loc1.Depth,
  4724. Loc1Size = loc1.Size,
  4725. Loc1StateNum = loc1.StateNum,
  4726. Loc1ContGrpBarCode = loc1.ContGrpBarCode,
  4727. Inv1MatCode = inv1.MatCode,
  4728. Loc2Code = loc2.Code,
  4729. Loc2Id = loc2.Id,
  4730. Loc2Row = loc2.Row,
  4731. Loc2Col = loc2.Col,
  4732. Loc2Layer = loc2.Layer,
  4733. Loc2Depth = loc2.Depth,
  4734. Loc2Size = loc2.Size,
  4735. Loc2StateNum = loc2.StateNum,
  4736. Loc2ContGrpBarCode = loc2.ContGrpBarCode,
  4737. Inv2MatCode = inv2.MatCode,
  4738. Loc3Code = loc3.Code,
  4739. Loc3Id = loc3.Id,
  4740. Loc3Row = loc3.Row,
  4741. Loc3Col = loc3.Col,
  4742. Loc3Layer = loc3.Layer,
  4743. Loc3Depth = loc3.Depth,
  4744. Loc3Size = loc3.Size,
  4745. Loc3StateNum = loc3.StateNum,
  4746. Loc3ContGrpBarCode = loc3.ContGrpBarCode,
  4747. Inv3MatCode = inv3.MatCode,
  4748. }).ToList();
  4749. if (emptyLocList.Any()) //有货位
  4750. {
  4751. var emptyLoc = emptyLocList.OrderByDescending(x => x.Loc3StateNum)
  4752. .ThenByDescending(x => x.Loc2StateNum)
  4753. .ThenByDescending(x => x.Loc1StateNum)
  4754. .First();
  4755. if (emptyLoc.Loc3StateNum == FjLocationState.Empty) //优先3
  4756. {
  4757. res.ResData.CellNo = emptyLoc.Loc3Code;
  4758. res.ResData.Row = emptyLoc.Loc3Row;
  4759. res.ResData.Colomn = emptyLoc.Loc3Col;
  4760. res.ResData.Layer = emptyLoc.Loc3Layer;
  4761. res.ResData.Depth = emptyLoc.Loc3Depth;
  4762. }
  4763. else if (emptyLoc.Loc2StateNum == FjLocationState.Empty) //次2
  4764. {
  4765. res.ResData.CellNo = emptyLoc.Loc2Code;
  4766. res.ResData.Row = emptyLoc.Loc2Row;
  4767. res.ResData.Colomn = emptyLoc.Loc2Col;
  4768. res.ResData.Layer = emptyLoc.Loc2Layer;
  4769. res.ResData.Depth = emptyLoc.Loc2Depth;
  4770. }
  4771. else if (emptyLoc.Loc1StateNum == FjLocationState.Empty) //再次1
  4772. {
  4773. res.ResData.CellNo = emptyLoc.Loc1Code;
  4774. res.ResData.Row = emptyLoc.Loc1Row;
  4775. res.ResData.Colomn = emptyLoc.Loc1Col;
  4776. res.ResData.Layer = emptyLoc.Loc1Layer;
  4777. res.ResData.Depth = emptyLoc.Loc1Depth;
  4778. }
  4779. }
  4780. else //找不到对应货位当前缓存信息对应的货位,找到三个全是同一货位的信息
  4781. {
  4782. var emptyLocList1 = _basewarecellrepository.Context
  4783. .Queryable<BaseWarecell, BaseWarecell, BaseWarecell>(
  4784. (loc1, loc2, loc3) => new object[]
  4785. {
  4786. JoinType.Left, loc2.Col == loc1.Col && loc2.Layer == loc1.Layer,
  4787. JoinType.Left, loc3.Col == loc2.Col && loc3.Layer == loc2.Layer,
  4788. })
  4789. .Where((loc1, loc2, loc3) => loc1.WarehouseId == wareHouse.Id && loc2.WarehouseId == wareHouse.Id && loc3.WarehouseId == wareHouse.Id) //保证三个深度都是同一个从仓库的
  4790. .Where((loc1, loc2, loc3) => loc1.IsStop == 0 && loc2.IsStop == 0 && loc3.IsStop == 0)
  4791. .Where((loc1, loc2, loc3) => loc2.Size == loc1.Size && loc3.Size == loc1.Size)
  4792. .Where((loc1, loc2, loc3) => wcsTask.GoodsType == 34 || (wcsTask.GoodsType != 34 && loc1.Layer != 6))
  4793. .Where((loc1, loc2, loc3) => loc1.Depth == 1 && loc2.Depth == 2 && loc3.Depth == 3) //保证三个深度与字段对应
  4794. .Where((loc1, loc2, loc3) => loc1.GroupID == 0 && loc2.GroupID == 0 && loc3.GroupID == 0) //获取三个货位都是没有绑定缓存信息的
  4795. .Where((loc1, loc2, loc3) => loc1.StateNum == FjLocationState.Empty && loc2.StateNum == FjLocationState.Empty && loc3.StateNum == FjLocationState.Empty) //1空、2空、3空
  4796. .Select((loc1, loc2, loc3) => new
  4797. {
  4798. Loc1Code = loc1.Code,
  4799. Loc1Id = loc1.Id,
  4800. Loc1Row = loc1.Row,
  4801. Loc1Col = loc1.Col,
  4802. Loc1Layer = loc1.Layer,
  4803. Loc1Depth = loc1.Depth,
  4804. Loc1Size = loc1.Size,
  4805. Loc1StateNum = loc1.StateNum,
  4806. Loc1ContGrpBarCode = loc1.ContGrpBarCode,
  4807. Loc2Code = loc2.Code,
  4808. Loc2Id = loc2.Id,
  4809. Loc2Row = loc2.Row,
  4810. Loc2Col = loc2.Col,
  4811. Loc2Layer = loc2.Layer,
  4812. Loc2Depth = loc2.Depth,
  4813. Loc2Size = loc2.Size,
  4814. Loc2StateNum = loc2.StateNum,
  4815. Loc2ContGrpBarCode = loc2.ContGrpBarCode,
  4816. Loc3Code = loc3.Code,
  4817. Loc3Id = loc3.Id,
  4818. Loc3Row = loc3.Row,
  4819. Loc3Col = loc3.Col,
  4820. Loc3Layer = loc3.Layer,
  4821. Loc3Depth = loc3.Depth,
  4822. Loc3Size = loc3.Size,
  4823. Loc3StateNum = loc3.StateNum,
  4824. Loc3ContGrpBarCode = loc3.ContGrpBarCode,
  4825. }).ToList();
  4826. if (emptyLocList1.Any())
  4827. {
  4828. var emptyLoc = emptyLocList1.OrderBy(x => x.Loc3Layer).ThenBy(x => x.Loc3Col).First();
  4829. res.ResData.CellNo = emptyLoc.Loc3Code;
  4830. res.ResData.Row = emptyLoc.Loc3Row;
  4831. res.ResData.Colomn = emptyLoc.Loc3Col;
  4832. res.ResData.Layer = emptyLoc.Loc3Layer;
  4833. res.ResData.Depth = emptyLoc.Loc3Depth;
  4834. }
  4835. }
  4836. if (string.IsNullOrEmpty(res.ResData.CellNo)) //没有分配货位
  4837. {
  4838. res.ResCode = ResponseStatusCodeEnum.NotEnoughLocation.GetHashCode();
  4839. res.ResMsg = "有空货位单无可用货位";
  4840. return res;
  4841. }
  4842. List<BillBomsetinfo> bomSetInfos = new List<BillBomsetinfo>();
  4843. //分配当前轮子在垛形中的位置
  4844. if (wareHouse.Code.Contains("N")) //北侧由大到小,出的时候刚好可用反过来;
  4845. {
  4846. //取当前任务SKU在货位中已有的信息
  4847. var cells = _basewarecellrepository.Context.Queryable<BaseWarecell, BillInvnow>((loc, inv) =>
  4848. new object[]
  4849. {
  4850. JoinType.Inner, loc.ContGrpBarCode == inv.ContGrpBarCode
  4851. }).Where((loc, inv) =>
  4852. loc.GroupID == ringPalletizingInfo.Id && (loc.StateNum == FjLocationState.Full ||
  4853. loc.StateNum == FjLocationState.StockIn))
  4854. .Select((loc, inv) => new
  4855. {
  4856. loc.GroupID,
  4857. inv.MatCode,
  4858. loc.XYNO
  4859. }).ToList();
  4860. if (cells.Count != ringPalletizingInfo.HaveQty)
  4861. {
  4862. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4863. res.ResMsg =
  4864. $"码垛信息组【{ringPalletizingInfo.Id}】记录已有【{ringPalletizingInfo.HaveQty}】个轮子,但对应的库存信息只有【{cells.Count}】,请在WMS检查对应的库存信息";
  4865. return res;
  4866. }
  4867. var cellMatCodeList = cells.Where(x => x.MatCode == wcsTask.MatCode);
  4868. //取当前SKU在垛形明细中所有的信息
  4869. bomSetInfos = _billBomsetinfoRepository.GetList(x =>
  4870. x.BomSetHdrId == ringPalletizingInfo.BomSetGrpId && x.IsEmpty == 0 &&
  4871. x.MatCode == wcsTask.MatCode).ToList();
  4872. //取当前SKU在垛形明细中最大的一个坐标号,初始化时默认取第一个
  4873. var lastXYNO = Convert.ToInt32(bomSetInfos.Select(x => Convert.ToInt32(x.XYNo))
  4874. .OrderByDescending(x => x).First());
  4875. if (cellMatCodeList.Any()) //货位中已有当前SKU的产品,取最小数,最小数表示最近入库的
  4876. {
  4877. lastXYNO = cellMatCodeList.OrderBy(x => x.XYNO).First().XYNO;
  4878. var xyNo = bomSetInfos.Select(x => Convert.ToInt32(x.XYNo)).Where(x => x < lastXYNO)
  4879. .OrderByDescending(x => x).First();
  4880. ringPalletizingInfo.LastXYNO = xyNo;
  4881. }
  4882. else
  4883. {
  4884. ringPalletizingInfo.LastXYNO = lastXYNO;
  4885. }
  4886. }
  4887. else //南侧小到大,出的时候刚好可用反过来;
  4888. {
  4889. //取当前任务SKU在货位中已有的信息
  4890. var cells = _basewarecellrepository.Context.Queryable<BaseWarecell, BillInvnow>((loc, inv) =>
  4891. new object[]
  4892. {
  4893. JoinType.Inner, loc.ContGrpBarCode == inv.ContGrpBarCode
  4894. }).Where((loc, inv) =>
  4895. loc.GroupID == ringPalletizingInfo.Id && (loc.StateNum == FjLocationState.Full ||
  4896. loc.StateNum == FjLocationState.StockIn))
  4897. .Select((loc, inv) => new
  4898. {
  4899. loc.GroupID,
  4900. inv.MatCode,
  4901. loc.XYNO
  4902. }).ToList();
  4903. if (cells.Count != ringPalletizingInfo.HaveQty)
  4904. {
  4905. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4906. res.ResMsg =
  4907. $"码垛信息组【{ringPalletizingInfo.Id}】记录已有【{ringPalletizingInfo.HaveQty}】个轮子,但对应的库存信息只有【{cells.Count}】,请在WMS检查对应的库存信息";
  4908. return res;
  4909. }
  4910. var cellMatCodeList = cells.Where(x => x.MatCode == wcsTask.MatCode);
  4911. //取当前SKU在垛形明细中所有的信息
  4912. bomSetInfos = _billBomsetinfoRepository.GetList(x =>
  4913. x.BomSetHdrId == ringPalletizingInfo.BomSetGrpId && x.IsEmpty == 0 &&
  4914. x.MatCode == wcsTask.MatCode).ToList();
  4915. //取当前SKU在垛形明细中最小的一个坐标号 ,初始化时默认取第一个
  4916. var lastXYNO =
  4917. Convert.ToInt32(bomSetInfos.Select(x => Convert.ToInt32(x.XYNo)).OrderBy(x => x).First());
  4918. if (cellMatCodeList.Any()) //货位中已有当前SKU的产品,取最大数 最大数表示最近入库的
  4919. {
  4920. lastXYNO = cellMatCodeList.OrderByDescending(x => x.XYNO).First().XYNO;
  4921. var xyNo = bomSetInfos.Select(x => Convert.ToInt32(x.XYNo)).Where(x => x > lastXYNO)
  4922. .OrderBy(x => x).First();
  4923. ringPalletizingInfo.LastXYNO = xyNo;
  4924. }
  4925. else
  4926. {
  4927. ringPalletizingInfo.LastXYNO = lastXYNO;
  4928. }
  4929. }
  4930. if (_basewarecellrepository.AsQueryable().With(SqlWith.NoLock).Any(x =>
  4931. x.GroupID == ringPalletizingInfo.Id && x.XYNO == ringPalletizingInfo.LastXYNO))
  4932. {
  4933. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4934. res.ResMsg = $"当前位置已经被分配过了,请检查异常码垛信息{ringPalletizingInfo.Id}-{ringPalletizingInfo.LastXYNO}";
  4935. return res;
  4936. }
  4937. try
  4938. {
  4939. _db.BeginTran();
  4940. var task = _wcstaskoldrepository.AsQueryable().With("WITH(READPAST,ROWLOCK)")
  4941. .Where(p => p.Id == reqEntity.TaskNum)
  4942. .SplitTable(x => x.Take(2)).First();
  4943. if (task == null)
  4944. {
  4945. res.ResCode = ResponseStatusCodeEnum.WcsTaskNotExist.GetHashCode();
  4946. res.ResMsg = ResponseStatusCodeEnum.WcsTaskNotExist.GetDescription();
  4947. return res;
  4948. }
  4949. if (task.Type == TaskType.OutDepot)
  4950. {
  4951. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  4952. res.ResMsg = "该任务是出库任务,不能分配货位;任务号" + task.Id;
  4953. return res;
  4954. }
  4955. var outTime = ringPalletizingInfo.AddTime;
  4956. if (stock.ProductTime < ringPalletizingInfo.AddTime) outTime = stock.ProductTime;
  4957. //更新目标缓存信息
  4958. if (!_billRingPalletizingInfo.UpdateModelColumns(
  4959. p => new BillRingPalletizingInfo
  4960. {
  4961. HaveQty = ringPalletizingInfo.HaveQty + 1,
  4962. LastXYNO = ringPalletizingInfo.LastXYNO,
  4963. AddTime = outTime
  4964. }, p => p.Id == ringPalletizingInfo.Id))
  4965. {
  4966. _db.RollbackTran();
  4967. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4968. res.ResMsg = $"货位{res.ResData.CellNo}被锁定";
  4969. return res;
  4970. }
  4971. //更新目标货位
  4972. if (!_basewarecellrepository.UpdateModelColumns(
  4973. p => new BaseWarecell
  4974. {
  4975. StateNum = FjLocationState.StockIn,
  4976. ContGrpBarCode = task.BarCode,
  4977. ContGrpId = stock.ContGrpId,
  4978. GroupID = ringPalletizingInfo.Id,
  4979. EditTime = DateTime.Now,
  4980. XYNO = ringPalletizingInfo.LastXYNO
  4981. },
  4982. p => p.WarehouseId == wareHouse.Id && p.Code == res.ResData.CellNo &&
  4983. p.StateNum == FjLocationState.Empty))
  4984. {
  4985. _db.RollbackTran();
  4986. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4987. res.ResMsg = $"货位{res.ResData.CellNo}被锁定";
  4988. return res;
  4989. }
  4990. //更新货位信息至历史表,防止WCS重复请求,导致信息异常
  4991. if (!_wcstaskoldrepository.UpdateSplitTableModelColumns(x => new WCS_TaskOld
  4992. {
  4993. AddrTo = res.ResData.CellNo
  4994. }, x => x.Id == wcsTask.Id && x.AddrTo == "Robot"))
  4995. {
  4996. _db.RollbackTran();
  4997. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  4998. res.ResMsg = $"货位{res.ResData.CellNo}更新货位至任务历史表失败";
  4999. return res;
  5000. }
  5001. var bomSetInfo = bomSetInfos.First(x => x.XYNo == ringPalletizingInfo.LastXYNO.ToString());
  5002. //更新库存货物大小信息
  5003. _billInvnowrepository.UpdateModelColumns(
  5004. x => new BillInvnow { Size = reqEntity.Height, SideNum = bomSetInfo.SideNum },
  5005. x => x.Id == stock.Id);
  5006. _db.CommitTran();
  5007. }
  5008. catch (Exception ex)
  5009. {
  5010. _db.RollbackTran();
  5011. _logger.LogInformation(ex.ToString());
  5012. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5013. res.ResMsg = ex.Message;
  5014. }
  5015. }
  5016. catch (Exception ex)
  5017. {
  5018. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5019. res.ResMsg = ex.Message + ex.StackTrace;
  5020. }
  5021. return res;
  5022. }
  5023. #endregion
  5024. //#region 环形库货位申请(三深)
  5025. //public SRes<FJApplyStockInLocResponse> RingApplyStockInLoc(FJApplyStockInLocRequest reqEntity)
  5026. //{
  5027. // var res = new SRes<FJApplyStockInLocResponse>()
  5028. // {
  5029. // ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode(),
  5030. // ResMsg = ResponseStatusCodeEnum.Sucess.GetDescription(),
  5031. // ResData = new FJApplyStockInLocResponse()
  5032. // };
  5033. // try
  5034. // {
  5035. // #region 任务信息是否正常
  5036. // var wcsTask = _wcstaskoldrepository.AsQueryable().With("WITH(READPAST,ROWLOCK)").Where(p => p.Id == reqEntity.TaskNum).SplitTable(tabs => tabs.Take(2)).First();
  5037. // ;
  5038. // if (wcsTask == null)
  5039. // {
  5040. // res.ResCode = ResponseStatusCodeEnum.WcsTaskNotExist.GetHashCode();
  5041. // res.ResMsg = ResponseStatusCodeEnum.WcsTaskNotExist.GetDescription();
  5042. // return res;
  5043. // }
  5044. // if (wcsTask.Type == TaskType.OutDepot)
  5045. // {
  5046. // res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  5047. // res.ResMsg = "该任务是出库任务,不能分配货位;任务号" + wcsTask.Id;
  5048. // return res;
  5049. // }
  5050. // if (!string.IsNullOrEmpty(wcsTask.AddrTo) && wcsTask.AddrTo != "Robot") //如果目标地址不是机器人
  5051. // {
  5052. // res.ResData.CellNo = wcsTask.AddrTo;
  5053. // res.ResData.Row = wcsTask.AddrTo.Split('-')[0] != null ? int.Parse(wcsTask.AddrTo.Split('-')[0]) : 0;
  5054. // res.ResData.Colomn = wcsTask.AddrTo.Split('-')[1] != null ? int.Parse(wcsTask.AddrTo.Split('-')[1]) : 0;
  5055. // res.ResData.Layer = wcsTask.AddrTo.Split('-')[2] != null ? int.Parse(wcsTask.AddrTo.Split('-')[2]) : 0;
  5056. // return res;
  5057. // }
  5058. // #endregion 任务信息是否正常
  5059. // //验证仓库信息
  5060. // var wareHouse = _basewarehouserepository.GetFirst(p => p.Code == wcsTask.WarehouseCode);
  5061. // if (wareHouse == null)
  5062. // {
  5063. // res.ResCode = ResponseStatusCodeEnum.WarehouseCodeNotExist.GetHashCode();
  5064. // res.ResMsg = ResponseStatusCodeEnum.WarehouseCodeNotExist.GetDescription();
  5065. // return res;
  5066. // }
  5067. // //验证库存
  5068. // var stock = _billInvnowrepository.GetFirst(p => p.HWBarCode == wcsTask.BarCode);
  5069. // if (stock == null)
  5070. // {
  5071. // //获取条码表相关信息
  5072. // var billInvinit = _billInvinitrepository.GetList(x => x.HWBarCode == wcsTask.BarCode).OrderByDescending(x => x.AddTime).FirstOrDefault();
  5073. // if (billInvinit == null)
  5074. // {
  5075. // res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5076. // res.ResMsg = "无条码信息";
  5077. // return res;
  5078. // }
  5079. // //将条码表映射到库存表
  5080. // stock = _mapper.Map<BillInvnow>(billInvinit);
  5081. // stock.AddTime = DateTime.Now;
  5082. // stock.InvStateCode = InvState.InvEcecState_BuildUp.ToString();
  5083. // stock.Id = IdFactory.NewId();
  5084. // if (!_billInvnowrepository.Insert(stock))
  5085. // {
  5086. // res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  5087. // res.ResMsg = "满轮库存信息存储失败";
  5088. // return res;
  5089. // }
  5090. // }
  5091. // if (stock.InvStateCode != InvState.InvEcecState_BuildUp.ToString())
  5092. // {
  5093. // res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5094. // res.ResMsg = $"工字轮{wcsTask.BarCode}库存状态异常,不是已组盘,请检查相关任务信息";
  5095. // return res;
  5096. // }
  5097. // //获取包含当前物料、计划个数大于已有个数、未出库
  5098. // var ringPalletizingInfoList = _billRingPalletizingInfo.GetList(x => x.WareHouseId == wareHouse.Id && x.BomCode.Contains(wcsTask.MatCode) && x.HWCountQty > x.HaveQty && !x.Out).OrderBy(x => x.AddTime);
  5099. // BillRingPalletizingInfo ringPalletizingInfo = null;
  5100. // if (ringPalletizingInfoList.Any())
  5101. // {
  5102. // foreach (var ringPalletizing in ringPalletizingInfoList)
  5103. // {
  5104. // if (ringPalletizingInfo != null) continue;
  5105. // //取当前任务SKU在货位中已有的信息
  5106. // var cells = _basewarecellrepository.Context.Queryable<BaseWarecell, BillInvnow>((loc, inv) =>
  5107. // new object[]
  5108. // {
  5109. // JoinType.Inner, loc.ContGrpBarCode == inv.ContGrpBarCode
  5110. // }).Where((loc, inv) => loc.GroupID == ringPalletizing.Id && (loc.StateNum == FjLocationState.Full || loc.StateNum == FjLocationState.StockIn))
  5111. // .Select((loc, inv) => new
  5112. // {
  5113. // loc.GroupID,
  5114. // inv.MatCode,
  5115. // loc.XYNO
  5116. // }).ToList().Where(x => x.MatCode == wcsTask.MatCode && x.GroupID == ringPalletizing.Id);
  5117. // var bomSetInfos = _billBomsetinfoRepository.GetList(x => x.BomSetHdrId == ringPalletizing.BomSetGrpId && x.IsEmpty == 0 && x.MatCode == wcsTask.MatCode).ToList();
  5118. // if (cells.Count() == bomSetInfos.Count)
  5119. // {
  5120. // res.Memo2 = $"[{ringPalletizing.Id}]-同规格产品已满足需求,任务[{wcsTask.Id}]创建了新的码垛信息";
  5121. // ringPalletizingInfo = null;
  5122. // }
  5123. // else ringPalletizingInfo = ringPalletizing;
  5124. // }
  5125. // }
  5126. // if (ringPalletizingInfo != null)
  5127. // {
  5128. // //取当前任务SKU在货位中已有的信息
  5129. // var cells = _basewarecellrepository.Context.Queryable<BaseWarecell, BillInvnow>((loc, inv) =>
  5130. // new object[]
  5131. // {
  5132. // JoinType.Inner, loc.ContGrpBarCode == inv.ContGrpBarCode
  5133. // }).Where((loc, inv) => loc.GroupID == ringPalletizingInfo.Id && (loc.StateNum == FjLocationState.Full || loc.StateNum == FjLocationState.StockIn))
  5134. // .Select((loc, inv) => new
  5135. // {
  5136. // loc.GroupID,
  5137. // inv.MatCode,
  5138. // loc.XYNO
  5139. // }).ToList().Where(x => x.MatCode == wcsTask.MatCode && x.GroupID == ringPalletizingInfo.Id);
  5140. // var bomSetInfos = _billBomsetinfoRepository.GetList(x => x.BomSetHdrId == ringPalletizingInfo.BomSetGrpId && x.IsEmpty == 0 && x.MatCode == wcsTask.MatCode).ToList();
  5141. // if (cells.Count() == bomSetInfos.Count)
  5142. // {
  5143. // res.Memo2 = $"[{ringPalletizingInfo.Id}]-同规格产品已满足需求,任务[{wcsTask.Id}]创建了新的码垛信息";
  5144. // ringPalletizingInfo = null;
  5145. // }
  5146. // }
  5147. // if (ringPalletizingInfo == null) //如果没有码垛信息
  5148. // {
  5149. // var bomsetGrp = _billBomsetgrpRepository.GetFirst(x => x.IsStop == 0 && x.BomCode.Contains(wcsTask.MatCode));
  5150. // var xyNo = _billBomsetinfoRepository.GetList(x => x.BomSetHdrId == bomsetGrp.Id && x.IsEmpty == 0).ToList().Select(x => Convert.ToInt32(x.XYNo)).OrderByDescending(x => x).First();
  5151. // //跟据垛形信息生成
  5152. // ringPalletizingInfo = new BillRingPalletizingInfo
  5153. // {
  5154. // Id = IdFactory.NewId(),
  5155. // WareHouseId = wareHouse.Id,
  5156. // BomSetGrpId = bomsetGrp.Id,
  5157. // HWCountQty = bomsetGrp.HWCountQty,
  5158. // BomCode = bomsetGrp.BomCode,
  5159. // HaveQty = 0,
  5160. // Out = false,
  5161. // LastXYNO = wareHouse.Code.Contains("N") ? xyNo + 1 : 0
  5162. // };
  5163. // if (!_billRingPalletizingInfo.Insert(ringPalletizingInfo))
  5164. // {
  5165. // res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  5166. // res.ResMsg = "环形库满轮码垛信息存储失败";
  5167. // return res;
  5168. // }
  5169. // res.Memo3 = $"[{wcsTask.MatCode}],任务[{wcsTask.Id}]创建了新的码垛信息";
  5170. // }
  5171. // //获取所有可用货位
  5172. // var emptyLocList = _basewarecellrepository.Context
  5173. // .Queryable<BaseWarecell, BillInvnow, BaseWarecell, BillInvnow, BaseWarecell, BillInvnow>(
  5174. // (loc1, inv1, loc2, inv2, loc3, inv3) => new object[]
  5175. // {
  5176. // JoinType.Left, loc1.ContGrpBarCode == inv1.ContGrpBarCode,
  5177. // JoinType.Left, loc2.Col == loc1.Col && loc2.Layer == loc1.Layer,
  5178. // JoinType.Left, loc2.ContGrpBarCode == inv2.ContGrpBarCode,
  5179. // JoinType.Left, loc3.Col == loc2.Col && loc3.Layer == loc2.Layer,
  5180. // JoinType.Left, loc3.ContGrpBarCode == inv3.ContGrpBarCode
  5181. // })
  5182. // .Where((loc1, inv1, loc2, inv2, loc3, inv3) => loc1.WarehouseId == wareHouse.Id && loc2.WarehouseId == wareHouse.Id && loc3.WarehouseId == wareHouse.Id) //保证三个深度都是同一个从仓库的
  5183. // .Where((loc1, inv1, loc2, inv2, loc3, inv3) => loc1.IsStop == 0 && loc2.IsStop == 0 && loc3.IsStop == 0)
  5184. // .Where((loc1, inv1, loc2, inv2, loc3, inv3) => loc2.Size == loc1.Size && loc3.Size == loc1.Size)
  5185. // .Where((loc1, inv1, loc2, inv2, loc3, inv3) => wcsTask.GoodsType == 34 || (wcsTask.GoodsType != 34 && loc1.Layer != 6))
  5186. // .Where((loc1, inv1, loc2, inv2, loc3, inv3) => loc1.Depth == 1 && loc2.Depth == 2 && loc3.Depth == 3) //保证三个深度与字段对应
  5187. // .Where((loc1, inv1, loc2, inv2, loc3, inv3) => loc3.GroupID == ringPalletizingInfo.Id) //三深货位的绑定ID是码垛缓存信息的ID
  5188. // .Where((loc1, inv1, loc2, inv2, loc3, inv3) =>
  5189. // (loc1.StateNum == FjLocationState.Empty && (loc2.StateNum == FjLocationState.Full || loc2.StateNum == FjLocationState.StockIn) && loc3.StateNum == FjLocationState.Full) //1空、2有/入锁、3有
  5190. // || (loc1.StateNum == FjLocationState.Empty && loc2.StateNum == FjLocationState.Empty && (loc3.StateNum == FjLocationState.Full || loc3.StateNum == FjLocationState.StockIn)) //1空、2空、3有/入锁
  5191. // || (loc1.StateNum == FjLocationState.Empty && loc2.StateNum == FjLocationState.Empty && loc3.StateNum == FjLocationState.Empty)
  5192. // ) //1空、2空、3空
  5193. // .Where((loc1, inv1, loc2, inv2, loc3, inv3) =>
  5194. // loc3.StateNum == FjLocationState.Empty || ((loc3.StateNum == FjLocationState.Full || loc3.StateNum == FjLocationState.StockIn) && inv3.MatCode == wcsTask.MatCode))
  5195. // .Select((loc1, inv1, loc2, inv2, loc3, inv3) => new
  5196. // {
  5197. // Loc1Code = loc1.Code,
  5198. // Loc1Id = loc1.Id,
  5199. // Loc1Row = loc1.Row,
  5200. // Loc1Col = loc1.Col,
  5201. // Loc1Layer = loc1.Layer,
  5202. // Loc1Depth = loc1.Depth,
  5203. // Loc1Size = loc1.Size,
  5204. // Loc1StateNum = loc1.StateNum,
  5205. // Loc1ContGrpBarCode = loc1.ContGrpBarCode,
  5206. // Inv1MatCode = inv1.MatCode,
  5207. // Loc2Code = loc2.Code,
  5208. // Loc2Id = loc2.Id,
  5209. // Loc2Row = loc2.Row,
  5210. // Loc2Col = loc2.Col,
  5211. // Loc2Layer = loc2.Layer,
  5212. // Loc2Depth = loc2.Depth,
  5213. // Loc2Size = loc2.Size,
  5214. // Loc2StateNum = loc2.StateNum,
  5215. // Loc2ContGrpBarCode = loc2.ContGrpBarCode,
  5216. // Inv2MatCode = inv2.MatCode,
  5217. // Loc3Code = loc3.Code,
  5218. // Loc3Id = loc3.Id,
  5219. // Loc3Row = loc3.Row,
  5220. // Loc3Col = loc3.Col,
  5221. // Loc3Layer = loc3.Layer,
  5222. // Loc3Depth = loc3.Depth,
  5223. // Loc3Size = loc3.Size,
  5224. // Loc3StateNum = loc3.StateNum,
  5225. // Loc3ContGrpBarCode = loc3.ContGrpBarCode,
  5226. // Inv3MatCode = inv3.MatCode,
  5227. // }).ToList();
  5228. // if (emptyLocList.Any()) //有货位
  5229. // {
  5230. // var emptyLoc = emptyLocList.OrderByDescending(x => x.Loc3StateNum)
  5231. // .ThenByDescending(x => x.Loc2StateNum)
  5232. // .ThenByDescending(x => x.Loc1StateNum)
  5233. // .First();
  5234. // if (emptyLoc.Loc3StateNum == FjLocationState.Empty) //优先3
  5235. // {
  5236. // res.ResData.CellNo = emptyLoc.Loc3Code;
  5237. // res.ResData.Row = emptyLoc.Loc3Row;
  5238. // res.ResData.Colomn = emptyLoc.Loc3Col;
  5239. // res.ResData.Layer = emptyLoc.Loc3Layer;
  5240. // res.ResData.Depth = emptyLoc.Loc3Depth;
  5241. // }
  5242. // else if (emptyLoc.Loc2StateNum == FjLocationState.Empty) //次2
  5243. // {
  5244. // res.ResData.CellNo = emptyLoc.Loc2Code;
  5245. // res.ResData.Row = emptyLoc.Loc2Row;
  5246. // res.ResData.Colomn = emptyLoc.Loc2Col;
  5247. // res.ResData.Layer = emptyLoc.Loc2Layer;
  5248. // res.ResData.Depth = emptyLoc.Loc2Depth;
  5249. // }
  5250. // else if (emptyLoc.Loc1StateNum == FjLocationState.Empty) //再次1
  5251. // {
  5252. // res.ResData.CellNo = emptyLoc.Loc1Code;
  5253. // res.ResData.Row = emptyLoc.Loc1Row;
  5254. // res.ResData.Colomn = emptyLoc.Loc1Col;
  5255. // res.ResData.Layer = emptyLoc.Loc1Layer;
  5256. // res.ResData.Depth = emptyLoc.Loc1Depth;
  5257. // }
  5258. // }
  5259. // else //找不到对应货位当前缓存信息对应的货位,找到三个全是同一货位的信息
  5260. // {
  5261. // var emptyLocList1 = _basewarecellrepository.Context
  5262. // .Queryable<BaseWarecell, BaseWarecell, BaseWarecell>(
  5263. // (loc1, loc2, loc3) => new object[]
  5264. // {
  5265. // JoinType.Left, loc2.Col == loc1.Col && loc2.Layer == loc1.Layer,
  5266. // JoinType.Left, loc3.Col == loc2.Col && loc3.Layer == loc2.Layer,
  5267. // })
  5268. // .Where((loc1, loc2, loc3) => loc1.WarehouseId == wareHouse.Id && loc2.WarehouseId == wareHouse.Id && loc3.WarehouseId == wareHouse.Id) //保证三个深度都是同一个从仓库的
  5269. // .Where((loc1, loc2, loc3) => loc1.IsStop == 0 && loc2.IsStop == 0 && loc3.IsStop == 0)
  5270. // .Where((loc1, loc2, loc3) => loc2.Size == loc1.Size && loc3.Size == loc1.Size)
  5271. // .Where((loc1, loc2, loc3) => wcsTask.GoodsType == 34 || (wcsTask.GoodsType != 34 && loc1.Layer != 6))
  5272. // .Where((loc1, loc2, loc3) => loc1.Depth == 1 && loc2.Depth == 2 && loc3.Depth == 3) //保证三个深度与字段对应
  5273. // .Where((loc1, loc2, loc3) => loc1.GroupID == 0 && loc2.GroupID == 0 && loc3.GroupID == 0) //获取三个货位都是没有绑定缓存信息的
  5274. // .Where((loc1, loc2, loc3) => loc1.StateNum == FjLocationState.Empty && loc2.StateNum == FjLocationState.Empty && loc3.StateNum == FjLocationState.Empty) //1空、2空、3空
  5275. // .Select((loc1, loc2, loc3) => new
  5276. // {
  5277. // Loc1Code = loc1.Code,
  5278. // Loc1Id = loc1.Id,
  5279. // Loc1Row = loc1.Row,
  5280. // Loc1Col = loc1.Col,
  5281. // Loc1Layer = loc1.Layer,
  5282. // Loc1Depth = loc1.Depth,
  5283. // Loc1Size = loc1.Size,
  5284. // Loc1StateNum = loc1.StateNum,
  5285. // Loc1ContGrpBarCode = loc1.ContGrpBarCode,
  5286. // Loc2Code = loc2.Code,
  5287. // Loc2Id = loc2.Id,
  5288. // Loc2Row = loc2.Row,
  5289. // Loc2Col = loc2.Col,
  5290. // Loc2Layer = loc2.Layer,
  5291. // Loc2Depth = loc2.Depth,
  5292. // Loc2Size = loc2.Size,
  5293. // Loc2StateNum = loc2.StateNum,
  5294. // Loc2ContGrpBarCode = loc2.ContGrpBarCode,
  5295. // Loc3Code = loc3.Code,
  5296. // Loc3Id = loc3.Id,
  5297. // Loc3Row = loc3.Row,
  5298. // Loc3Col = loc3.Col,
  5299. // Loc3Layer = loc3.Layer,
  5300. // Loc3Depth = loc3.Depth,
  5301. // Loc3Size = loc3.Size,
  5302. // Loc3StateNum = loc3.StateNum,
  5303. // Loc3ContGrpBarCode = loc3.ContGrpBarCode,
  5304. // }).ToList();
  5305. // if (emptyLocList1.Any())
  5306. // {
  5307. // var emptyLoc = emptyLocList1.OrderBy(x => x.Loc3Layer).ThenBy(x => x.Loc3Col).First();
  5308. // res.ResData.CellNo = emptyLoc.Loc3Code;
  5309. // res.ResData.Row = emptyLoc.Loc3Row;
  5310. // res.ResData.Colomn = emptyLoc.Loc3Col;
  5311. // res.ResData.Layer = emptyLoc.Loc3Layer;
  5312. // res.ResData.Depth = emptyLoc.Loc3Depth;
  5313. // }
  5314. // }
  5315. // if (string.IsNullOrEmpty(res.ResData.CellNo)) //没有分配货位
  5316. // {
  5317. // res.ResCode = ResponseStatusCodeEnum.NotEnoughLocation.GetHashCode();
  5318. // res.ResMsg = "有空货位单无可用货位";
  5319. // return res;
  5320. // }
  5321. // //分配当前轮子在垛形中的位置
  5322. // if (wareHouse.Code.Contains("N")) //北侧由大到小,出的时候刚好可用反过来;
  5323. // {
  5324. // //取当前任务SKU在货位中已有的信息
  5325. // var cells = _basewarecellrepository.Context.Queryable<BaseWarecell, BillInvnow>((loc, inv) =>
  5326. // new object[]
  5327. // {
  5328. // JoinType.Inner, loc.ContGrpBarCode == inv.ContGrpBarCode
  5329. // }).Where((loc, inv) => loc.GroupID == ringPalletizingInfo.Id && (loc.StateNum == FjLocationState.Full || loc.StateNum == FjLocationState.StockIn))
  5330. // .Select((loc, inv) => new
  5331. // {
  5332. // loc.GroupID,
  5333. // inv.MatCode,
  5334. // loc.XYNO
  5335. // }).ToList();
  5336. // if (cells.Count != ringPalletizingInfo.HaveQty)
  5337. // {
  5338. // res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5339. // res.ResMsg = $"码垛信息组【{ringPalletizingInfo.Id}】记录已有【{ringPalletizingInfo.HaveQty}】个轮子,但对应的库存信息只有【{cells.Count}】,请在WMS检查对应的库存信息";
  5340. // return res;
  5341. // }
  5342. // var cellMatCodeList = cells.Where(x => x.MatCode == wcsTask.MatCode);
  5343. // //取当前SKU在垛形明细中所有的信息
  5344. // var bomSetInfos = _billBomsetinfoRepository.GetList(x => x.BomSetHdrId == ringPalletizingInfo.BomSetGrpId && x.IsEmpty == 0 && x.MatCode == wcsTask.MatCode).ToList();
  5345. // //取当前SKU在垛形明细中最大的一个坐标号,初始化时默认取第一个
  5346. // var lastXYNO = Convert.ToInt32(bomSetInfos.Select(x => Convert.ToInt32(x.XYNo)).OrderByDescending(x => x).First());
  5347. // if (cellMatCodeList.Any()) //货位中已有当前SKU的产品,取最小数,最小数表示最近入库的
  5348. // {
  5349. // lastXYNO = cellMatCodeList.OrderBy(x => x.XYNO).First().XYNO;
  5350. // var xyNo = bomSetInfos.Select(x => Convert.ToInt32(x.XYNo)).Where(x => x < lastXYNO).OrderByDescending(x => x).First();
  5351. // ringPalletizingInfo.LastXYNO = xyNo;
  5352. // }
  5353. // else ringPalletizingInfo.LastXYNO = lastXYNO;
  5354. // }
  5355. // else //南侧小到大,出的时候刚好可用反过来;
  5356. // {
  5357. // //取当前任务SKU在货位中已有的信息
  5358. // var cells = _basewarecellrepository.Context.Queryable<BaseWarecell, BillInvnow>((loc, inv) =>
  5359. // new object[]
  5360. // {
  5361. // JoinType.Inner, loc.ContGrpBarCode == inv.ContGrpBarCode
  5362. // }).Where((loc, inv) =>
  5363. // loc.GroupID == ringPalletizingInfo.Id && (loc.StateNum == FjLocationState.Full || loc.StateNum == FjLocationState.StockIn))
  5364. // .Select((loc, inv) => new
  5365. // {
  5366. // loc.GroupID,
  5367. // inv.MatCode,
  5368. // loc.XYNO
  5369. // }).ToList();
  5370. // if (cells.Count != ringPalletizingInfo.HaveQty)
  5371. // {
  5372. // res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5373. // res.ResMsg = $"码垛信息组【{ringPalletizingInfo.Id}】记录已有【{ringPalletizingInfo.HaveQty}】个轮子,但对应的库存信息只有【{cells.Count}】,请在WMS检查对应的库存信息";
  5374. // return res;
  5375. // }
  5376. // var cellMatCodeList = cells.Where(x => x.MatCode == wcsTask.MatCode);
  5377. // //取当前SKU在垛形明细中所有的信息
  5378. // var bomSetInfos = _billBomsetinfoRepository.GetList(x => x.BomSetHdrId == ringPalletizingInfo.BomSetGrpId && x.IsEmpty == 0 && x.MatCode == wcsTask.MatCode).ToList();
  5379. // //取当前SKU在垛形明细中最小的一个坐标号 ,初始化时默认取第一个
  5380. // var lastXYNO = Convert.ToInt32(bomSetInfos.Select(x => Convert.ToInt32(x.XYNo)).OrderBy(x => x).First());
  5381. // if (cellMatCodeList.Any()) //货位中已有当前SKU的产品,取最大数 最大数表示最近入库的
  5382. // {
  5383. // lastXYNO = cellMatCodeList.OrderByDescending(x => x.XYNO).First().XYNO;
  5384. // var xyNo = bomSetInfos.Select(x => Convert.ToInt32(x.XYNo)).Where(x => x > lastXYNO).OrderBy(x => x).First();
  5385. // ringPalletizingInfo.LastXYNO = xyNo;
  5386. // }
  5387. // else ringPalletizingInfo.LastXYNO = lastXYNO;
  5388. // }
  5389. // if (_basewarecellrepository.AsQueryable().With(SqlWith.NoLock).Any(x => x.GroupID == ringPalletizingInfo.Id && x.XYNO == ringPalletizingInfo.LastXYNO))
  5390. // {
  5391. // res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5392. // res.ResMsg = $"当前位置已经被分配过了,请检查异常码垛信息{ringPalletizingInfo.Id}-{ringPalletizingInfo.LastXYNO}";
  5393. // return res;
  5394. // }
  5395. // try
  5396. // {
  5397. // _db.BeginTran();
  5398. // var task = _wcstaskoldrepository.AsQueryable().With("WITH(READPAST,ROWLOCK)").Where(p => p.Id == reqEntity.TaskNum)
  5399. // .SplitTable(x => x.Take(2)).First();
  5400. // if (task == null)
  5401. // {
  5402. // res.ResCode = ResponseStatusCodeEnum.WcsTaskNotExist.GetHashCode();
  5403. // res.ResMsg = ResponseStatusCodeEnum.WcsTaskNotExist.GetDescription();
  5404. // return res;
  5405. // }
  5406. // if (task.Type == TaskType.OutDepot)
  5407. // {
  5408. // res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  5409. // res.ResMsg = "该任务是出库任务,不能分配货位;任务号" + task.Id;
  5410. // return res;
  5411. // }
  5412. // //更新目标缓存信息
  5413. // if (!_billRingPalletizingInfo.UpdateModelColumns(p => new BillRingPalletizingInfo() { HaveQty = ringPalletizingInfo.HaveQty + 1, LastXYNO = ringPalletizingInfo.LastXYNO }, p => p.Id == ringPalletizingInfo.Id))
  5414. // {
  5415. // _db.RollbackTran();
  5416. // res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5417. // res.ResMsg = $"货位{res.ResData.CellNo}被锁定";
  5418. // return res;
  5419. // }
  5420. // //更新目标货位
  5421. // if (!_basewarecellrepository.UpdateModelColumns(
  5422. // p => new BaseWarecell()
  5423. // {
  5424. // StateNum = FjLocationState.StockIn,
  5425. // ContGrpBarCode = task.BarCode,
  5426. // ContGrpId = stock.ContGrpId,
  5427. // GroupID = ringPalletizingInfo.Id,
  5428. // EditTime = DateTime.Now,
  5429. // XYNO = ringPalletizingInfo.LastXYNO
  5430. // },
  5431. // p => p.WarehouseId == wareHouse.Id && p.Code == res.ResData.CellNo && p.StateNum == FjLocationState.Empty))
  5432. // {
  5433. // _db.RollbackTran();
  5434. // res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5435. // res.ResMsg = $"货位{res.ResData.CellNo}被锁定";
  5436. // return res;
  5437. // }
  5438. // //更新货位信息至历史表,防止WCS重复请求,导致信息异常
  5439. // if (!_wcstaskoldrepository.UpdateSplitTableModelColumns(x => new WCS_TaskOld()
  5440. // {
  5441. // AddrTo = res.ResData.CellNo
  5442. // }, x => x.Id == wcsTask.Id && x.AddrTo == "Robot"))
  5443. // {
  5444. // _db.RollbackTran();
  5445. // res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5446. // res.ResMsg = $"货位{res.ResData.CellNo}更新货位至任务历史表失败";
  5447. // return res;
  5448. // }
  5449. // //更新库存货物大小信息
  5450. // _billInvnowrepository.UpdateModelColumns(x => new BillInvnow() { Size = reqEntity.Height }, x => x.Id == stock.Id);
  5451. // _db.CommitTran();
  5452. // }
  5453. // catch (Exception ex)
  5454. // {
  5455. // _db.RollbackTran();
  5456. // _logger.LogInformation(ex.ToString());
  5457. // res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5458. // res.ResMsg = ex.Message;
  5459. // }
  5460. // }
  5461. // catch (Exception ex)
  5462. // {
  5463. // res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5464. // res.ResMsg = ex.Message + ex.StackTrace;
  5465. // }
  5466. // return res;
  5467. //}
  5468. //#endregion
  5469. /// <summary>
  5470. /// WCS申请码垛出库
  5471. /// </summary>
  5472. public SRes ApplyPalletizingStockOut(RingApplyPalletizingStockOutRequest req)
  5473. {
  5474. var res = new SRes
  5475. {
  5476. ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode(),
  5477. ResMsg = ResponseStatusCodeEnum.Sucess.GetDescription()
  5478. };
  5479. //验证仓库信息
  5480. var wareHouse = _basewarehouserepository.GetFirst(p => p.Code == req.WareHouseCode);
  5481. if (wareHouse == null)
  5482. {
  5483. res.ResCode = ResponseStatusCodeEnum.WarehouseCodeNotExist.GetHashCode();
  5484. res.ResMsg = ResponseStatusCodeEnum.WarehouseCodeNotExist.GetDescription();
  5485. return res;
  5486. }
  5487. #region 获取已经成组的码垛信息
  5488. var matInfoList = _basematerrepository.AsQueryable().With(SqlWith.NoLock).Where(x => x.TimeOut != 0)
  5489. .ToList();
  5490. var defaultOutTime = _sysconfigrepository.GetFirst(x => x.Code == "DefaultOutTime");
  5491. if (defaultOutTime == null) defaultOutTime = new fjSysConfig { SContent = "12" };
  5492. var ringPalletizingInfo = _billRingPalletizingInfo
  5493. .GetList(x => x.WareHouseId == wareHouse.Id && x.HaveQty > 0 && !x.Out).ToList().OrderBy(x => x.AddTime)
  5494. .FirstOrDefault(x =>
  5495. {
  5496. var outTime = Convert.ToInt32(defaultOutTime.SContent);
  5497. if (matInfoList.Any(m => x.BomCode.Contains(m.Code)))
  5498. outTime = matInfoList.Where(m => x.BomCode.Contains(m.Code)).Min(m => m.TimeOut);
  5499. return x.HaveQty == x.HWCountQty || x.AddTime < DateTime.Now.AddHours(-outTime);
  5500. });
  5501. if (ringPalletizingInfo == null)
  5502. {
  5503. res.ResCode = ResponseStatusCodeEnum.NotEnoughStock.GetHashCode();
  5504. res.ResMsg = "无满跺码垛信息";
  5505. return res;
  5506. }
  5507. #endregion
  5508. var wareCellList = _basewarecellrepository.Context.Queryable<BaseWarecell, BillInvnow>((loc, inv) =>
  5509. new object[] { JoinType.Inner, loc.ContGrpBarCode == inv.HWBarCode })
  5510. .Where((loc, inv) => loc.WarehouseCode == req.WareHouseCode && loc.StateNum == FjLocationState.Full &&
  5511. ringPalletizingInfo.Id == loc.GroupID)
  5512. .Select((loc, inv) => new CellInfo
  5513. {
  5514. Id = loc.Id,
  5515. ContGrpBarCode = loc.ContGrpBarCode,
  5516. WarehouseId = loc.WarehouseId,
  5517. WarehouseCode = loc.WarehouseCode,
  5518. Code = loc.Code,
  5519. Row = loc.Row,
  5520. Col = loc.Col,
  5521. Layer = loc.Layer,
  5522. Depth = loc.Depth,
  5523. EditTime = loc.EditTime,
  5524. MatCode = inv.MatCode,
  5525. SideNum = inv.SideNum,
  5526. CLBarCode = inv.CLBarCode,
  5527. XYNo = loc.XYNO,
  5528. BomDocsNo = inv.BomDocsNo
  5529. }).ToList();
  5530. if (ringPalletizingInfo.HaveQty != wareCellList.Count)
  5531. {
  5532. res.ResCode = ResponseStatusCodeEnum.NotEnoughStock.GetHashCode();
  5533. res.ResMsg = $"库存不足{ringPalletizingInfo.Id}";
  5534. return res;
  5535. }
  5536. if (ringPalletizingInfo.HaveQty != wareCellList.DistinctBy(x => x.XYNo).Count())
  5537. {
  5538. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5539. res.ResMsg = "码垛信息组XYNo存在重复情况,请查看环形库码垛信息找出是哪一个位置出现重复";
  5540. return res;
  5541. }
  5542. try
  5543. {
  5544. //找到当前库存信息中可以使用的垛形信息
  5545. var bomDocsNos = wareCellList.Select(x => x.BomDocsNo).Distinct().ToList();
  5546. var bomSetGrpList = _BillBomsetgrpRepository.GetList(x => bomDocsNos.Contains(x.BomCode));
  5547. if (!bomSetGrpList.Any())
  5548. {
  5549. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5550. res.ResMsg = $"{JsonConvert.SerializeObject(bomDocsNos.Distinct())}未找到对应的垛形信息";
  5551. return res;
  5552. }
  5553. #region 分区计算
  5554. //获取最佳码垛位
  5555. var findBestStackingPosition = FindBestStackingPosition(wareCellList);
  5556. if (findBestStackingPosition.IsNullOrEmpty())
  5557. {
  5558. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5559. res.ResMsg = "分区计算异常无对应结果";
  5560. return res;
  5561. }
  5562. if (findBestStackingPosition != req.EquCode) //当前码垛位不是最近码垛位置
  5563. {
  5564. //查看最近码垛位是否存在未结束的码垛任务
  5565. var used = _taskrepository.AsQueryable().With(SqlWith.NoLock).Any(x =>
  5566. x.AddrTo == findBestStackingPosition && x.BusType == FJTaskBusType.环形库出库码垛任务.GetDescription() &&
  5567. x.Status < TaskStatus.Finish);
  5568. //有正在执行的任务,报错返回
  5569. if (!used)
  5570. {
  5571. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5572. res.ResMsg = $"优先最近码垛位执行-{findBestStackingPosition}";
  5573. return res;
  5574. }
  5575. }
  5576. #endregion
  5577. foreach (var doc in bomSetGrpList)
  5578. {
  5579. //找到对应的垛形信息
  5580. var bomSetGrp = _BillBomsetgrpRepository.GetSingle(x => doc.Id == x.Id);
  5581. //是否可以码垛,默认可以码垛
  5582. var isPalletize = true;
  5583. if (isPalletize) //开始计算出库任务
  5584. //开始为各种物料生成对应的出库任务
  5585. try
  5586. {
  5587. //开始更新相关数据
  5588. _db.BeginTran(); //创建事务
  5589. _billRingPalletizingInfo.UpdateModelColumns(p => new BillRingPalletizingInfo { Out = true },
  5590. p => p.Id == ringPalletizingInfo.Id);
  5591. foreach (var cell in wareCellList)
  5592. {
  5593. //更新货位信息
  5594. _basewarecellrepository.UpdateModelColumns(
  5595. p => new BaseWarecell { StateNum = FjLocationState.StockOut },
  5596. p => p.Id == cell.Id && p.StateNum == FjLocationState.Full);
  5597. //更新库存信息
  5598. var sotck = _billInvnowrepository.GetSingle(x =>
  5599. x.ContGrpBarCode == cell.ContGrpBarCode && x.HWBarCode == cell.ContGrpBarCode &&
  5600. x.PutCol == cell.Col && x.PutLayer == cell.Layer && x.PutRow == cell.Row);
  5601. if (sotck == null)
  5602. {
  5603. _db.RollbackTran(); //回滚事务
  5604. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5605. res.ResMsg = $"未找到库存信息{cell.ContGrpBarCode}";
  5606. return res;
  5607. }
  5608. _billInvnowrepository.UpdateModelColumns(
  5609. p => new BillInvnow
  5610. {
  5611. InvStateCode = InvState.InvEcecState_OutGoing.ToString(),
  5612. EditTime = DateTime.Now
  5613. }, p => p.HWBarCode == cell.ContGrpBarCode);
  5614. //更新流水信息
  5615. var invFlow = _mapper.Map<BillInvflow>(sotck);
  5616. invFlow.InvStateCode = InvState.InvEcecState_OutGoing.ToString();
  5617. invFlow.AddTime = DateTime.Now;
  5618. invFlow.Id = IdFactory.NewId();
  5619. invFlow.Memo = "出库码垛";
  5620. _billInvflow.Insert(invFlow);
  5621. //添加出库任务
  5622. var task = RingCreateStockOutWcsTask(new FJCreateStockOutWcsTaskRequest
  5623. {
  5624. ContGrpBarCode = cell.ContGrpBarCode,
  5625. CellNo = cell.Code,
  5626. MatCode = cell.MatCode,
  5627. EquCode = req.EquCode,
  5628. Floor = 2,
  5629. ProdLine = Convert.ToInt16(cell.XYNo),
  5630. PalletType = bomSetGrp.ShortCode,
  5631. FullQty = (short)ringPalletizingInfo.HaveQty,
  5632. Device = req.Device,
  5633. WarehouseCode = cell.WarehouseCode,
  5634. BusType = FJTaskBusType.环形库出库码垛任务,
  5635. GoodsType = sotck.Size
  5636. });
  5637. if (task.ResCode != ResponseStatusCodeEnum.Sucess.GetHashCode())
  5638. {
  5639. _db.RollbackTran(); //回滚事务
  5640. res = task;
  5641. return res;
  5642. }
  5643. wareCellList = wareCellList.Where(x => x.Id != cell.Id).ToList();
  5644. }
  5645. _db.CommitTran(); //提交事务
  5646. break;
  5647. }
  5648. catch (Exception e)
  5649. {
  5650. _db.RollbackTran(); //回滚事务
  5651. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5652. _logger.LogInformation(e.ToString());
  5653. res.ResMsg = e.StackTrace;
  5654. }
  5655. }
  5656. }
  5657. catch (Exception e)
  5658. {
  5659. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5660. _logger.LogInformation(e.ToString());
  5661. res.ResMsg = e.Message;
  5662. }
  5663. ;
  5664. return res;
  5665. }
  5666. /// <summary>
  5667. /// 环形库创建WCS出库任务
  5668. /// </summary>
  5669. /// <param name="reqDto"></param>
  5670. /// <returns></returns>
  5671. public SRes<WCS_TaskInfo> RingCreateStockOutWcsTask(FJCreateStockOutWcsTaskRequest reqDto)
  5672. {
  5673. var res = new SRes<WCS_TaskInfo>();
  5674. var bus = reqDto.BusType.GetDescription();
  5675. var wcstask = new WCS_TaskInfo
  5676. {
  5677. Type = TaskType.OutDepot,
  5678. Status = TaskStatus.NewBuild,
  5679. Priority = 0,
  5680. Device = reqDto.Device,
  5681. SrmStation = reqDto.EquCode,
  5682. AddrFrom = reqDto.CellNo,
  5683. AddrTo = reqDto.EquCode,
  5684. LastInteractionPoint = reqDto.LastInteractionPoint,
  5685. BarCode = reqDto.ContGrpBarCode,
  5686. Floor = reqDto.Floor,
  5687. Length = reqDto.Qty,
  5688. AddTime = DateTime.Now,
  5689. DocID = 0,
  5690. PalletType = reqDto.PalletType,
  5691. ProdLine = reqDto.ProdLine,
  5692. FullQty = reqDto.FullQty,
  5693. AddWho = "WMS",
  5694. WarehouseCode = reqDto.WarehouseCode,
  5695. Enabled = true,
  5696. WorkBench = reqDto.WorkBench,
  5697. GoodsType = reqDto.GoodsType,
  5698. BusType = bus,
  5699. MatCode = reqDto.MatCode,
  5700. WorkOrder = reqDto.MesNo,
  5701. MaterialCode = reqDto.EmptyInventory
  5702. };
  5703. var wcstaskhis = _mapper.Map<WCS_TaskOld>(wcstask);
  5704. try
  5705. {
  5706. var task = _taskrepository.InsertReturnEntity(wcstask);
  5707. wcstaskhis.Id = task.ID;
  5708. _wcstaskoldrepository.InsertableSplitTable(wcstaskhis);
  5709. var taskdetail = new WCS_TaskDtl
  5710. {
  5711. ID = Guid.NewGuid(),
  5712. CurPoint = reqDto.CellNo,
  5713. AddTime = DateTime.Now,
  5714. AddWho = "wms",
  5715. Enabled = true,
  5716. ParentTaskCode = task.ID,
  5717. Desc = "创建出库任务"
  5718. };
  5719. _taskdetailrepository.InsertableSplitTable(taskdetail);
  5720. res.ResData = task;
  5721. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  5722. }
  5723. catch (Exception ex)
  5724. {
  5725. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  5726. res.ResMsg = ResponseStatusCodeEnum.DataSaveErr.GetDescription();
  5727. _logger.LogInformation("保存任务异常:" + ex);
  5728. return res;
  5729. }
  5730. return res;
  5731. }
  5732. #endregion 环形库
  5733. #region 码垛
  5734. /// <summary>
  5735. /// 生成组盘任务,空托盘
  5736. /// </summary>
  5737. /// <param name="reqDto"></param>
  5738. /// <returns></returns>
  5739. public SRes GroupTask(FJBuildEmptyPalletsStockDto reqDto)
  5740. {
  5741. var res = new SRes();
  5742. var BusType = reqDto.BusType;
  5743. //验证业务类型
  5744. if (reqDto.BusType != FJTaskBusType.组盘_托盘)
  5745. {
  5746. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  5747. res.ResMsg = "指令类型" + reqDto.BusType + ResponseStatusCodeEnum.ErrParam.GetDescription();
  5748. return res;
  5749. }
  5750. ////验证是否有空余货位
  5751. //res = _mapper.Map<CopperLineResponse>(IsThereAnySpaceVacancy());
  5752. //if (res.ResCode != ResponseStatusCodeEnum.Sucess.GetHashCode()) return res;
  5753. //检查仓库是否存在
  5754. res = _mapper.Map<CopperLineResponse>(CheckWareCode(reqDto.WareCode));
  5755. if (res.ResCode != ResponseStatusCodeEnum.Sucess.GetHashCode()) return res;
  5756. //验证容器是否存在
  5757. res = _mapper.Map<CopperLineResponse>(
  5758. CheckContinfo(reqDto.PalletCode, FJContainerType.ContainerType_Pallet));
  5759. if (res.ResCode != ResponseStatusCodeEnum.Sucess.GetHashCode()) return res;
  5760. //验证托盘是否有未结束的任务
  5761. res = _mapper.Map<CopperLineResponse>(CheckNoFinishTask(reqDto.PalletCode));
  5762. if (res.ResCode != ResponseStatusCodeEnum.Sucess.GetHashCode()) return res;
  5763. var createStockInWcsTaskReqest = new FJCreateStockInWcsTaskRequest
  5764. {
  5765. BusType = BusType.GetDescription(),
  5766. ContGrpBarCode = reqDto.PalletCode,
  5767. Qty = reqDto.PalletNum.ObjToDecimal(),
  5768. EquCode = reqDto.StartLoc,
  5769. WarehouseCode = reqDto.WareCode,
  5770. Floor = reqDto.Floor,
  5771. Type = TaskType.SetPlate
  5772. };
  5773. //下发wcs任务 - 分解方法
  5774. var taskres = CreateStockInWcsTask(createStockInWcsTaskReqest);
  5775. if (taskres.ResCode != 200)
  5776. {
  5777. res.ResCode = taskres.ResCode;
  5778. res.ResMsg = taskres.ResMsg;
  5779. return res;
  5780. }
  5781. return res;
  5782. }
  5783. /// <summary>
  5784. /// 绑定托盘与工字轮
  5785. /// </summary>
  5786. /// <param name="reqDto"></param>
  5787. /// <returns></returns>
  5788. public SRes BingPallet(FJBingPalletDto reqDto)
  5789. {
  5790. var res = new SRes();
  5791. reqDto.PalletCode = Regex.Replace(reqDto.PalletCode.Trim(), @"[\r\n]", "");
  5792. //检查仓库是否存在
  5793. res = _mapper.Map<CopperLineResponse>(CheckWareCode(reqDto.WarehouseCode));
  5794. if (res.ResCode != ResponseStatusCodeEnum.Sucess.GetHashCode()) return res;
  5795. #region 检查托盘任务是否有效
  5796. //容器信息
  5797. var palletContainer = _baseContinfo.GetSingle(x => x.ContBarCode == reqDto.PalletCode);
  5798. if (palletContainer == null)
  5799. {
  5800. //创建容器信息
  5801. var cont = new BaseContinfo
  5802. {
  5803. ContBarCode = reqDto.PalletCode,
  5804. Name = reqDto.PalletCode,
  5805. TypeCode = FJContainerType.ContainerType_Pallet.ToString(),
  5806. PrintQty = 1,
  5807. IsStop = 0,
  5808. WarehouseId = 0,
  5809. AddWho = "WMS",
  5810. AddTime = DateTime.Now
  5811. };
  5812. //加载新的容器信息
  5813. if (!_baseContinfo.Insert(cont))
  5814. {
  5815. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  5816. res.ResMsg = "载具初始化失败";
  5817. return res;
  5818. }
  5819. }
  5820. else if (palletContainer.IsStop != 0)
  5821. {
  5822. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5823. res.ResMsg = "容器已停用";
  5824. return res;
  5825. }
  5826. #endregion 检查托盘任务是否有效
  5827. if (reqDto.IsFinish)
  5828. {
  5829. if (reqDto.IsItHalf)
  5830. {
  5831. _db.BeginTran();
  5832. var invnow = _billInvnowrepository.GetList(x => reqDto.PalletCode == x.ContGrpBarCode);
  5833. var invnowIds = invnow.Select(x => x.Id);
  5834. _billInvnowrepository.UpdateModelColumns(x => new BillInvnow
  5835. {
  5836. IsFail = reqDto.IsFail,
  5837. FailReason = reqDto.FailReason,
  5838. Secondary = true
  5839. }, x => invnowIds.Contains(x.Id));
  5840. //开始生成WCS
  5841. var createStockInWcsTaskReqest = new FJCreateStockInWcsTaskRequest
  5842. {
  5843. BusType = FJTaskBusType.码垛入库.GetDescription(),
  5844. ContGrpBarCode = reqDto.PalletCode,
  5845. Qty = 1,
  5846. WarehouseCode = reqDto.WarehouseCode,
  5847. Floor = 2,
  5848. EquCode = reqDto.loc,
  5849. Height = 1, //带料托盘默认为小货位
  5850. Type = TaskType.EnterDepot
  5851. };
  5852. //下发wcs任务 - 分解方法
  5853. var taskRes = CreateStockInWcsTask(createStockInWcsTaskReqest);
  5854. if (taskRes.ResCode != ResponseStatusCodeEnum.Sucess.GetHashCode())
  5855. {
  5856. _db.RollbackTran(); //回滚事务
  5857. res = taskRes;
  5858. return res;
  5859. }
  5860. _db.CommitTran();
  5861. }
  5862. else
  5863. {
  5864. _db.BeginTran();
  5865. var invnow = _billInvnowrepository.GetList(x => reqDto.PalletCode == x.ContGrpBarCode);
  5866. if (invnow.Count <= 0)
  5867. {
  5868. _db.RollbackTran(); //回滚事务
  5869. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5870. res.ResMsg = "无法结盘,当前托盘条码无对应绑盘库存信息请检查当前码垛工位是否完成绑定动作";
  5871. return res;
  5872. }
  5873. if (!reqDto.IsFail)
  5874. if (invnow.Count != reqDto.TaskCode.Count)
  5875. {
  5876. _db.RollbackTran(); //回滚事务
  5877. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5878. res.ResMsg = $"实有库存信息数量与应有库存信息数量不匹配;实有{invnow.Count}--应有{reqDto.TaskCode.Count}";
  5879. return res;
  5880. }
  5881. var invnowIds = invnow.Select(x => x.Id);
  5882. _billInvnowrepository.UpdateModelColumns(x => new BillInvnow
  5883. {
  5884. IsFail = reqDto.IsFail,
  5885. FailReason = reqDto.FailReason,
  5886. Secondary = false
  5887. }, x => invnowIds.Contains(x.Id));
  5888. //开始生成WCS
  5889. var createStockInWcsTaskReqest = new FJCreateStockInWcsTaskRequest
  5890. {
  5891. BusType = FJTaskBusType.码垛入库.GetDescription(),
  5892. ContGrpBarCode = reqDto.PalletCode,
  5893. Qty = 1,
  5894. WarehouseCode = reqDto.WarehouseCode,
  5895. Floor = 2,
  5896. EquCode = reqDto.loc,
  5897. Height = 1, //带料托盘默认为小货位
  5898. Type = TaskType.EnterDepot
  5899. };
  5900. //下发wcs任务 - 分解方法
  5901. var taskRes = CreateStockInWcsTask(createStockInWcsTaskReqest);
  5902. if (taskRes.ResCode != ResponseStatusCodeEnum.Sucess.GetHashCode())
  5903. {
  5904. _db.RollbackTran(); //回滚事务
  5905. res = taskRes;
  5906. return res;
  5907. }
  5908. _db.CommitTran();
  5909. }
  5910. return res;
  5911. }
  5912. #region 检查工字轮任务是否有效
  5913. var wareHosue = _basewarehouserepository.GetSingle(p => p.Code == reqDto.WarehouseCode);
  5914. //无论是桁架还是环形库绑盘都要验证条码信息
  5915. foreach (var code in from code in reqDto.TaskCode
  5916. let billInvinit = _billInvinitrepository.GetFirst(x => x.HWBarCode == code)
  5917. where billInvinit == null
  5918. select code)
  5919. {
  5920. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5921. res.ResMsg = $"条码{code}无条码信息";
  5922. return res;
  5923. }
  5924. if (wareHosue.TypeNum == FjLocationType.RingLibrary) //环形库需要验证一下库存信息
  5925. foreach (var code in reqDto.TaskCode)
  5926. {
  5927. var billInvnow = _billInvnowrepository.GetSingle(x => x.HWBarCode == code);
  5928. if (billInvnow == null)
  5929. {
  5930. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5931. res.ResMsg = $"工字轮{code}无库存信息";
  5932. return res;
  5933. }
  5934. if (billInvnow.InvStateCode != FJInvState.InvEcecState_BuildUp.ToString())
  5935. {
  5936. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5937. res.ResMsg = $"工字轮{code}库存状态错误";
  5938. return res;
  5939. }
  5940. }
  5941. #endregion 检查工字轮任务是否有效
  5942. try
  5943. {
  5944. _db.BeginTran();
  5945. var contGrpId = IdFactory.NewId();
  5946. //开始更新条码信息
  5947. foreach (var code in reqDto.TaskCode)
  5948. {
  5949. //无论桁架码垛还是环形库都能找到条码信息,因上方已经验证过条码信息是否存在,所以不再二次验证
  5950. var billInv = _billInvinitrepository.GetFirst(x => x.HWBarCode == code);
  5951. if (billInv == null)
  5952. {
  5953. _db.RollbackTran();
  5954. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5955. res.ResMsg = $"{code}未找到条码信息";
  5956. return res;
  5957. }
  5958. var stock = _billInvnowrepository.GetSingle(x => x.HWBarCode == billInv.HWBarCode);
  5959. switch (wareHosue.TypeNum)
  5960. {
  5961. case FjLocationType.RingLibrary:
  5962. if (stock == null)
  5963. {
  5964. _db.RollbackTran();
  5965. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5966. res.ResMsg = $"{code}未找到库存信息";
  5967. return res;
  5968. }
  5969. //更新库存信息
  5970. _billInvnowrepository.UpdateModelColumns(
  5971. x => new BillInvnow
  5972. {
  5973. WarehouseId = wareHosue.Id,
  5974. ContGrpId = contGrpId,
  5975. ContGrpType = FJContGrpType.Material,
  5976. ContGrpBarCode = reqDto.PalletCode,
  5977. IsFail = reqDto.IsFail,
  5978. FailReason = reqDto.FailReason
  5979. },
  5980. x => x.Id == stock.Id && x.InvStateCode == FJInvState.InvEcecState_BuildUp.ToString());
  5981. break;
  5982. case FjLocationType.Storage:
  5983. if (stock != null)
  5984. {
  5985. _db.RollbackTran();
  5986. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  5987. res.ResMsg = $"{code}已有库存信息";
  5988. return res;
  5989. }
  5990. //将条码表映射到库存表
  5991. stock = _mapper.Map<BillInvnow>(billInv);
  5992. stock.AddTime = DateTime.Now;
  5993. stock.Id = IdFactory.NewId();
  5994. stock.ContGrpId = contGrpId;
  5995. stock.ContGrpType = FJContGrpType.Material;
  5996. stock.ContGrpBarCode = reqDto.PalletCode;
  5997. stock.WarehouseId = wareHosue.Id;
  5998. stock.IsFail = reqDto.IsFail;
  5999. stock.FailReason = reqDto.FailReason;
  6000. stock.InvStateCode = InvState.InvEcecState_BuildUp.ToString();
  6001. if (!_billInvnowrepository.Insert(stock))
  6002. {
  6003. _db.RollbackTran();
  6004. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  6005. res.ResMsg = "库存信息存储失败";
  6006. return res;
  6007. }
  6008. break;
  6009. case FjLocationType.Pingku:
  6010. _db.RollbackTran();
  6011. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  6012. res.ResMsg = "无效仓库类型";
  6013. return res;
  6014. case FjLocationType.Virtual:
  6015. _db.RollbackTran();
  6016. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  6017. res.ResMsg = "无效仓库类型";
  6018. return res;
  6019. default:
  6020. _db.RollbackTran();
  6021. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  6022. res.ResMsg = "无效仓库类型";
  6023. return res;
  6024. }
  6025. //增加流水信息
  6026. var depotstocklist = _billInvnowrepository.GetList(p =>
  6027. p.ContGrpBarCode == reqDto.PalletCode &&
  6028. p.InvStateCode == InvState.InvEcecState_BuildUp.ToString());
  6029. foreach (var item in depotstocklist)
  6030. {
  6031. item.Id = IdFactory.NewId();
  6032. item.AddTime = DateTime.Now;
  6033. item.Memo = "整托入库组盘";
  6034. }
  6035. _billInvflow.InsertRange(_mapper.Map<List<BillInvflow>>(depotstocklist));
  6036. }
  6037. _db.CommitTran();
  6038. }
  6039. catch (Exception e)
  6040. {
  6041. _db.RollbackTran();
  6042. ;
  6043. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  6044. res.ResMsg = e.Message;
  6045. }
  6046. return res;
  6047. }
  6048. public SRes<int> GetTwoPallet(FJGetTwoPalletDto reqDto)
  6049. {
  6050. var res = new SRes<int>();
  6051. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  6052. res.ResMsg = "暂停";
  6053. return res;
  6054. //检查仓库是否存在
  6055. var warehosue = _basewarehouserepository.GetSingle(p => p.Code == reqDto.WarehouseCode);
  6056. if (warehosue == null)
  6057. {
  6058. res.ResCode = ResponseStatusCodeEnum.WarehouseCodeNotExist.GetHashCode();
  6059. res.ResMsg = ResponseStatusCodeEnum.WarehouseCodeNotExist.GetDescription();
  6060. return res;
  6061. }
  6062. //通过任务号在历史任务中找到对应货位号
  6063. var task = _wcstaskoldrepository.AsQueryable().Where(p => p.Id == reqDto.TaskId)
  6064. .SplitTable(tabs => tabs.Take(2)).First();
  6065. if (task == null)
  6066. {
  6067. res.ResCode = ResponseStatusCodeEnum.WcsTaskNotExist.GetHashCode();
  6068. res.ResMsg = ResponseStatusCodeEnum.WcsTaskNotExist.GetDescription();
  6069. return res;
  6070. }
  6071. if (task.Type != TaskType.EnterDepot)
  6072. {
  6073. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  6074. res.ResMsg = "不是入库任务,无法获取出库货位;任务号" + task.Id;
  6075. return res;
  6076. }
  6077. var cell = _basewarecellrepository.GetSingle(x =>
  6078. x.ContGrpBarCode == task.BarCode && x.WarehouseCode == reqDto.WarehouseCode);
  6079. if (cell == null || cell.StateNum != FjLocationState.Full)
  6080. {
  6081. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  6082. res.ResMsg = "当前货物以超时出库" + task.Id;
  6083. return res;
  6084. }
  6085. try
  6086. {
  6087. _db.BeginTran();
  6088. _basewarecellrepository.UpdateModelColumns(x => new BaseWarecell
  6089. {
  6090. StateNum = FjLocationState.StockOut,
  6091. EditTime = DateTime.Now,
  6092. EditWho = "WMS"
  6093. }, x => x.Id == cell.Id);
  6094. //添加出库任务
  6095. var resTask = RingCreateStockOutWcsTask(new FJCreateStockOutWcsTaskRequest
  6096. {
  6097. ContGrpBarCode = cell.ContGrpBarCode,
  6098. CellNo = cell.Code,
  6099. EquCode = cell.WarehouseCode switch
  6100. {
  6101. "1N" => "1605",
  6102. "1S" => "1615",
  6103. "2N" => "1625",
  6104. "2S" => "1635",
  6105. "3N" => "1645",
  6106. "3S" => "1655",
  6107. _ => "ERROR"
  6108. },
  6109. Floor = 2,
  6110. Device = cell.WarehouseCode switch
  6111. {
  6112. "1N" => "SRM1",
  6113. "1S" => "SRM2",
  6114. "2N" => "SRM3",
  6115. "2S" => "SRM4",
  6116. "3N" => "SRM5",
  6117. "3S" => "SRM6",
  6118. _ => "ERROR"
  6119. },
  6120. WorkBench = "",
  6121. WarehouseCode = cell.WarehouseCode,
  6122. BusType = FJTaskBusType.二楼二次码垛出库
  6123. });
  6124. _db.CommitTran();
  6125. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  6126. res.ResMsg = "成功";
  6127. res.ResData = resTask.ResData.ID;
  6128. }
  6129. catch (Exception e)
  6130. {
  6131. _db.RollbackTran();
  6132. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  6133. res.ResMsg = e.Message;
  6134. }
  6135. return res;
  6136. }
  6137. #endregion 码垛
  6138. #region 立库
  6139. /// <summary>
  6140. /// 一楼空托盘人工入库任务创建
  6141. /// </summary>
  6142. /// <param name="reqDto"></param>
  6143. /// <returns></returns>
  6144. public SRes OneFloorWorkerBuildEmptyPalletsStock(FJBuildEmptyPalletsStockRequest reqDto)
  6145. {
  6146. var res = new SRes();
  6147. reqDto.PalletCode = Regex.Replace(reqDto.PalletCode.Trim(), @"[\r\n]", "");
  6148. ;
  6149. //判断时候存在组盘信息
  6150. var stock = _billInvnowrepository.GetSingle(p => p.ContGrpBarCode == reqDto.PalletCode);
  6151. if (stock != null && stock.InvStateCode != InvState.InvEcecState_BuildUp.ToString())
  6152. {
  6153. res.ResCode = ResponseStatusCodeEnum.StockStateFail.GetHashCode();
  6154. res.ResMsg = reqDto.PalletCode + ResponseStatusCodeEnum.StockStateFail.GetDescription();
  6155. return res;
  6156. }
  6157. if (stock == null)
  6158. {
  6159. var req = _mapper.Map<FJBuildEmptyPalletsStockDto>(reqDto);
  6160. req.Floor = 1;
  6161. req.BusType = FJTaskBusType.OneLayerManualPallets;
  6162. req.PalletType = req.PalletCode.StartsWith("TPA") ? FJPalletType.Pallet09 : FJPalletType.PalletNo09;
  6163. req.PalletNum = "5";
  6164. res = FJEmptyPalletsStockIn(req);
  6165. }
  6166. //后续补充
  6167. return res;
  6168. }
  6169. /// <summary>
  6170. /// 分拣库空托盘入库
  6171. /// </summary>
  6172. /// <param name="reqDto"></param>
  6173. /// <returns></returns>
  6174. public SRes FJEmptyPalletsStockIn(FJBuildEmptyPalletsStockDto reqDto)
  6175. {
  6176. var res = new CopperLineResponse();
  6177. var BusType = reqDto.BusType;
  6178. //验证业务类型
  6179. if (reqDto.BusType <= FJTaskBusType.def || reqDto.BusType > FJTaskBusType.OneLayerAutoPallets)
  6180. {
  6181. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  6182. res.ResMsg = "指令类型" + reqDto.BusType + ResponseStatusCodeEnum.ErrParam.GetDescription();
  6183. return res;
  6184. }
  6185. //验证是否有空余货位
  6186. res = _mapper.Map<CopperLineResponse>(IsThereAnySpaceVacancy());
  6187. if (res.ResCode != ResponseStatusCodeEnum.Sucess.GetHashCode()) return res;
  6188. //检查仓库是否存在
  6189. res = _mapper.Map<CopperLineResponse>(CheckWareCode(reqDto.WareCode));
  6190. if (res.ResCode != ResponseStatusCodeEnum.Sucess.GetHashCode()) return res;
  6191. //验证容器是否存在
  6192. res = _mapper.Map<CopperLineResponse>(
  6193. CheckContinfo(reqDto.PalletCode, FJContainerType.ContainerType_Pallet));
  6194. if (res.ResCode != ResponseStatusCodeEnum.Sucess.GetHashCode()) return res;
  6195. if (reqDto.PalletCode != "TPA" && reqDto.PalletCode != "TPB")
  6196. {
  6197. //验证托盘是否有未结束的任务
  6198. res = _mapper.Map<CopperLineResponse>(CheckNoFinishTask(reqDto.PalletCode));
  6199. if (res.ResCode != ResponseStatusCodeEnum.Sucess.GetHashCode()) return res;
  6200. //验证是否存在库存信息
  6201. res = _mapper.Map<CopperLineResponse>(CheckInvnow(reqDto.PalletCode));
  6202. if (res.ResCode != ResponseStatusCodeEnum.Sucess.GetHashCode()) return res;
  6203. }
  6204. else
  6205. {
  6206. reqDto.PalletCode = reqDto.PalletCode + IdFactory.GetInstance().NextId();
  6207. }
  6208. //保存条码信息 空托盘条码即条码表条码
  6209. var barinfo = _billInvinitrepository.GetSingle(p => p.InvBarCode == reqDto.PalletCode);
  6210. if (barinfo == null)
  6211. {
  6212. var warehosue = _basewarehouserepository.GetSingle(p => p.Code == reqDto.WareCode);
  6213. var mat = _basematerrepository.GetSingle(p => p.Code == reqDto.PalletCode.Substring(0, 3));
  6214. barinfo = new BillInvinit
  6215. {
  6216. InvBarCode = reqDto.PalletCode,
  6217. CLBarCode = reqDto.PalletCode,
  6218. WarehouseId = warehosue.Id,
  6219. ContGrpId = IdFactory.NewId(),
  6220. ContGrpBarCode = reqDto.PalletCode,
  6221. ExecStateCode = FJInvLockState.InvState_Normal.ToString(),
  6222. ExecDocsTypeCode = FJDocType.DocType_FJ_EmptyPalletsStockIn.GetHashCode().ToString(),
  6223. ContGrpType = FJContGrpType.EmptyCon,
  6224. InvInOut = FJInvInOutType.In,
  6225. ExecWho = "WCS",
  6226. EditTime = DateTime.Now,
  6227. InvStateCode = FJInvState.InvEcecState_BuildUp.ToString(),
  6228. SuppCode = "",
  6229. Size = 2,
  6230. MatCode = mat.Code,
  6231. MatId = mat.Id,
  6232. MatName = mat.Name,
  6233. AddTime = DateTime.Now,
  6234. PalletType = reqDto.PalletType
  6235. };
  6236. barinfo = _billInvinitrepository.InsertReturnEntity(barinfo);
  6237. }
  6238. try
  6239. {
  6240. _db.BeginTran();
  6241. //生成库存信息-分解方法
  6242. var createStockRes = CreateStock(new List<BillInvinit> { barinfo }, reqDto.PalletCode);
  6243. if (createStockRes.ResCode != 200)
  6244. {
  6245. _db.RollbackTran();
  6246. res.ResCode = createStockRes.ResCode;
  6247. res.ResMsg = createStockRes.ResMsg;
  6248. return res;
  6249. }
  6250. //生成流水数据-分解方法
  6251. var createInvFlowRes = CreateInvFlow(createStockRes.ResDataList);
  6252. if (createInvFlowRes.ResCode != 200)
  6253. {
  6254. _db.RollbackTran();
  6255. res.ResCode = createInvFlowRes.ResCode;
  6256. res.ResMsg = createInvFlowRes.ResMsg;
  6257. return res;
  6258. }
  6259. var createStockInWcsTaskReqest = new FJCreateStockInWcsTaskRequest
  6260. {
  6261. BusType = BusType.GetDescription(),
  6262. ContGrpBarCode = reqDto.PalletCode,
  6263. ContGrpId = createStockRes.ResDataList.First().ContGrpId,
  6264. Qty = reqDto.PalletNum.ObjToDecimal(),
  6265. EquCode = reqDto.StartLoc,
  6266. WarehouseCode = reqDto.WareCode,
  6267. Floor = reqDto.Floor,
  6268. Type = TaskType.EnterDepot
  6269. };
  6270. //下发wcs任务 - 分解方法
  6271. var taskres = CreateStockInWcsTask(createStockInWcsTaskReqest);
  6272. if (taskres.ResCode != 200)
  6273. {
  6274. _db.RollbackTran();
  6275. res.ResCode = taskres.ResCode;
  6276. res.ResMsg = taskres.ResMsg;
  6277. return res;
  6278. }
  6279. _db.CommitTran();
  6280. }
  6281. catch (Exception e)
  6282. {
  6283. _db.RollbackTran();
  6284. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  6285. res.ResMsg = e.Message;
  6286. }
  6287. return res;
  6288. }
  6289. #endregion 立库
  6290. #region 巷道及货位分配
  6291. /// <summary>
  6292. /// 获取平库可用货位
  6293. /// </summary>
  6294. /// <param name="reqEntity"></param>
  6295. /// <returns></returns>
  6296. public SRes<FJApplyStockInLocResponse> FindAvailableFlatStorageSlot(FJApplyStockInLocRequest reqEntity)
  6297. {
  6298. var res = new SRes<FJApplyStockInLocResponse>
  6299. {
  6300. ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode(),
  6301. ResMsg = ResponseStatusCodeEnum.Sucess.GetDescription(),
  6302. ResData = new FJApplyStockInLocResponse()
  6303. };
  6304. //检查任务是否异常
  6305. var wcstask = _wcstaskoldrepository.AsQueryable().With(SqlWith.NoLock).Where(p => p.Id == reqEntity.TaskNum)
  6306. .SplitTable(tabs => tabs.Take(2)).First();
  6307. ;
  6308. if (wcstask == null)
  6309. {
  6310. res.ResCode = ResponseStatusCodeEnum.WcsTaskNotExist.GetHashCode();
  6311. res.ResMsg = ResponseStatusCodeEnum.WcsTaskNotExist.GetDescription();
  6312. return res;
  6313. }
  6314. if (wcstask.Type == TaskType.OutDepot)
  6315. {
  6316. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  6317. res.ResMsg = "该任务是出库任务,不能分配货位;任务号" + wcstask.Id;
  6318. return res;
  6319. }
  6320. //验证仓库信息
  6321. var warehouse = _basewarehouserepository.GetFirst(p => p.Code == wcstask.WarehouseCode);
  6322. if (warehouse == null)
  6323. {
  6324. res.ResCode = ResponseStatusCodeEnum.WarehouseCodeNotExist.GetHashCode();
  6325. res.ResMsg = ResponseStatusCodeEnum.WarehouseCodeNotExist.GetDescription();
  6326. return res;
  6327. }
  6328. //验证库存
  6329. var stock = _billInvnowrepository.GetFirst(p =>
  6330. p.ContGrpBarCode == wcstask.BarCode.Trim() &&
  6331. p.InvStateCode == InvState.InvEcecState_BuildUp.ToString());
  6332. if (stock == null)
  6333. {
  6334. if (wcstask.BusType == FJTaskBusType.帘线退料重绕.GetDescription())
  6335. {
  6336. var nov = new BillInvnow
  6337. {
  6338. WarehouseId = warehouse.Id,
  6339. ContGrpBarCode = wcstask.BarCode,
  6340. ContGrpId = IdFactory.NewId(),
  6341. BoxBarCode = "",
  6342. InvStateCode = InvState.InvEcecState_BuildUp.ToString(),
  6343. ExecStateCode = InvLockState.InvState_Normal.ToString(),
  6344. MatId = default,
  6345. MatCode = "",
  6346. MatName = "",
  6347. RFIDBarCode = wcstask.BarCode,
  6348. HWBarCode = wcstask.BarCode,
  6349. HWTypeCode = "",
  6350. InvInOut = FJInvInOutType.In,
  6351. Size = 1,
  6352. ContGrpType = FJContGrpType.EmptyPal,
  6353. LengthQty = 0 //存放托盘数量
  6354. };
  6355. _db.BeginTran();
  6356. _billInvnowrepository.Insert(nov);
  6357. _billInvflow.Insert(_mapper.Map<BillInvflow>(nov));
  6358. _db.CommitTran();
  6359. }
  6360. else
  6361. {
  6362. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  6363. res.ResMsg = "没有库存信息";
  6364. return res;
  6365. }
  6366. }
  6367. //找到可用货位
  6368. var loc1ist = _basewarecellrepository.Context
  6369. .Queryable<BaseWarecell>()
  6370. .Where(loc1 => loc1.IsStop == 0
  6371. && loc1.StateNum == FjLocationState.Empty
  6372. && loc1.TypeNum == FjLocationType.Pingku
  6373. && loc1.Code == reqEntity.PickUpEquipmentNo
  6374. && loc1.WarehouseId == warehouse.Id
  6375. && loc1.Depth == 1)
  6376. //.Where(loc1 => loc1.Tunnel == reqEntity.TunnelNum)
  6377. .Select(loc1 => new
  6378. {
  6379. loc1.Code,
  6380. loc1.Id,
  6381. loc1.Row,
  6382. loc1.Col,
  6383. loc1.Layer,
  6384. loc1.Tunnel
  6385. }).ToList();
  6386. if (loc1ist.Any())
  6387. {
  6388. var resloc = loc1ist.ToList().OrderBy(x => x.Code).First();
  6389. res.ResData.TunnelNum = resloc.Tunnel.ToString();
  6390. res.ResData.WarehuoseId = warehouse.Id;
  6391. res.ResData.CellNo = resloc.Code;
  6392. res.ResData.Row = resloc.Row;
  6393. res.ResData.Colomn = resloc.Col;
  6394. res.ResData.Layer = resloc.Layer;
  6395. try
  6396. {
  6397. _db.BeginTran();
  6398. var task = _wcstaskoldrepository.AsQueryable().With("WITH(READPAST,ROWLOCK)")
  6399. .Where(x => x.Id == wcstask.Id).SplitTable(x => x.Take(2)).First();
  6400. //更新货位
  6401. _basewarecellrepository.UpdateModelColumns(
  6402. p => new BaseWarecell
  6403. {
  6404. StateNum = FjLocationState.StockIn,
  6405. ContGrpBarCode = "",
  6406. ContGrpId = 0,
  6407. EditTime = DateTime.Now
  6408. },
  6409. p => p.Code == res.ResData.CellNo && res.ResData.WarehuoseId == p.WarehouseId);
  6410. _wcstaskoldrepository.UpdateSplitTableModelColumns(x => new WCS_TaskOld
  6411. {
  6412. AddrTo = res.ResData.CellNo
  6413. }, x => x.Id == task.Id);
  6414. _db.CommitTran();
  6415. }
  6416. catch (Exception ex)
  6417. {
  6418. _db.RollbackTran();
  6419. _logger.LogInformation(ex.ToString());
  6420. }
  6421. return res;
  6422. }
  6423. res.ResCode = ResponseStatusCodeEnum.NotEnoughLocation.GetHashCode();
  6424. res.ResMsg = ResponseStatusCodeEnum.NotEnoughLocation.GetDescription();
  6425. return res;
  6426. }
  6427. /// <summary>
  6428. /// 分配货位
  6429. /// </summary>
  6430. /// <param name="request"></param>
  6431. /// <returns></returns>
  6432. public SRes<FJApplyStockInLocResponse> ApplyStockInLoc(FJApplyStockInLocRequest reqEntity)
  6433. {
  6434. var res = new SRes<FJApplyStockInLocResponse>
  6435. {
  6436. ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode(),
  6437. ResMsg = ResponseStatusCodeEnum.Sucess.GetDescription(),
  6438. ResData = new FJApplyStockInLocResponse()
  6439. };
  6440. res = ApplyStockInLocTemp(reqEntity);
  6441. if (string.IsNullOrEmpty(res.ResData.CellNo)) return res;
  6442. try
  6443. {
  6444. _db.BeginTran();
  6445. var task = _wcstaskoldrepository.AsQueryable().With("WITH(READPAST,ROWLOCK)")
  6446. .Where(x => x.Id == reqEntity.TaskNum).SplitTable(x => x.Take(2)).First();
  6447. if (task == null)
  6448. {
  6449. res.ResCode = ResponseStatusCodeEnum.WcsTaskNotExist.GetHashCode();
  6450. res.ResMsg = ResponseStatusCodeEnum.WcsTaskNotExist.GetDescription();
  6451. return res;
  6452. }
  6453. if (task.Type == TaskType.OutDepot)
  6454. {
  6455. res.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  6456. res.ResMsg = "该任务是出库任务,不能分配货位;任务号" + task.Id;
  6457. return res;
  6458. }
  6459. var stock = _billInvnowrepository.GetFirst(p =>
  6460. p.ContGrpBarCode == task.BarCode && p.InvStateCode == InvState.InvEcecState_BuildUp.ToString());
  6461. //更新货位
  6462. _basewarecellrepository.UpdateModelColumns(
  6463. p => new BaseWarecell
  6464. {
  6465. StateNum = FjLocationState.StockIn,
  6466. ContGrpBarCode = "",
  6467. ContGrpId = 0,
  6468. EditTime = DateTime.Now
  6469. },
  6470. p => p.Code == res.ResData.CellNo && res.ResData.WarehuoseId == p.WarehouseId);
  6471. _wcstaskoldrepository.UpdateSplitTableModelColumns(x => new WCS_TaskOld
  6472. {
  6473. AddrTo = res.ResData.CellNo
  6474. }, x => x.Id == task.Id);
  6475. _db.CommitTran();
  6476. }
  6477. catch (Exception ex)
  6478. {
  6479. _db.RollbackTran();
  6480. _logger.LogInformation(ex.ToString());
  6481. }
  6482. return res;
  6483. }
  6484. /// <summary>
  6485. /// 分配货位
  6486. /// </summary>
  6487. /// <param name="request"></param>
  6488. /// <returns></returns>
  6489. public SRes<FJApplyStockInLocResponse> ApplyStockInLocTemp(FJApplyStockInLocRequest reqEntity)
  6490. {
  6491. var result = new SRes<FJApplyStockInLocResponse>
  6492. {
  6493. ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode(),
  6494. ResMsg = ResponseStatusCodeEnum.Sucess.GetDescription(),
  6495. ResData = new FJApplyStockInLocResponse()
  6496. };
  6497. //检查任务是否异常
  6498. var wcstask = _wcstaskoldrepository.AsQueryable().With("WITH(READPAST,ROWLOCK)")
  6499. .Where(p => p.Id == reqEntity.TaskNum).SplitTable(tabs => tabs.Take(2)).First();
  6500. ;
  6501. if (wcstask == null)
  6502. {
  6503. result.ResCode = ResponseStatusCodeEnum.WcsTaskNotExist.GetHashCode();
  6504. result.ResMsg = ResponseStatusCodeEnum.WcsTaskNotExist.GetDescription();
  6505. return result;
  6506. }
  6507. if (wcstask.Type == TaskType.OutDepot)
  6508. {
  6509. result.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  6510. result.ResMsg = "该任务是出库任务,不能分配货位;任务号" + wcstask.Id;
  6511. return result;
  6512. }
  6513. if (!string.IsNullOrEmpty(wcstask.AddrTo) && wcstask.AddrTo != "SRM") //如果目标地址不是堆垛机
  6514. {
  6515. result.ResData.TunnelNum = wcstask.Tunnel;
  6516. result.ResData.CellNo = wcstask.AddrTo;
  6517. result.ResData.Row = wcstask.AddrTo.Split('-')[0] != null ? int.Parse(wcstask.AddrTo.Split('-')[0]) : 0;
  6518. result.ResData.Colomn =
  6519. wcstask.AddrTo.Split('-')[1] != null ? int.Parse(wcstask.AddrTo.Split('-')[1]) : 0;
  6520. result.ResData.Layer =
  6521. wcstask.AddrTo.Split('-')[2] != null ? int.Parse(wcstask.AddrTo.Split('-')[2]) : 0;
  6522. return result;
  6523. }
  6524. if (reqEntity.TunnelNum <= 0)
  6525. {
  6526. result.ResCode = ResponseStatusCodeEnum.NotTunnelNum.GetHashCode();
  6527. result.ResMsg = ResponseStatusCodeEnum.NotTunnelNum.GetDescription();
  6528. return result;
  6529. }
  6530. //验证仓库信息
  6531. var warehouse = _basewarehouserepository.GetFirst(p => p.Code == wcstask.WarehouseCode);
  6532. if (warehouse == null)
  6533. {
  6534. result.ResCode = ResponseStatusCodeEnum.WarehouseCodeNotExist.GetHashCode();
  6535. result.ResMsg = ResponseStatusCodeEnum.WarehouseCodeNotExist.GetDescription();
  6536. return result;
  6537. }
  6538. //验证库存
  6539. var stock = _billInvnowrepository.GetFirst(p =>
  6540. p.ContGrpBarCode == wcstask.BarCode.Trim() &&
  6541. p.InvStateCode == InvState.InvEcecState_BuildUp.ToString());
  6542. if (stock == null)
  6543. {
  6544. if (wcstask.BusType == FJTaskBusType.芯股用空托盘入库.GetDescription())
  6545. {
  6546. var nov = new BillInvnow
  6547. {
  6548. WarehouseId = warehouse.Id,
  6549. ContGrpBarCode = wcstask.BarCode,
  6550. ContGrpId = IdFactory.NewId(),
  6551. BoxBarCode = "",
  6552. InvStateCode = InvState.InvEcecState_BuildUp.ToString(),
  6553. ExecStateCode = InvLockState.InvState_Normal.ToString(),
  6554. MatId = default,
  6555. MatCode = "",
  6556. MatName = "",
  6557. RFIDBarCode = wcstask.BarCode,
  6558. HWBarCode = wcstask.BarCode,
  6559. HWTypeCode = "",
  6560. InvInOut = FJInvInOutType.In,
  6561. Size = 1,
  6562. ContGrpType = FJContGrpType.EmptyPal,
  6563. LengthQty = 1 //存放托盘数量
  6564. };
  6565. _db.BeginTran();
  6566. _billInvnowrepository.Insert(nov);
  6567. _billInvflow.Insert(_mapper.Map<BillInvflow>(nov));
  6568. _db.CommitTran();
  6569. }
  6570. result.ResCode = ResponseStatusCodeEnum.StockNotExist.GetHashCode();
  6571. result.ResMsg = ResponseStatusCodeEnum.StockNotExist.GetDescription();
  6572. return result;
  6573. }
  6574. if (reqEntity.TunnelNum <= 0)
  6575. {
  6576. result.ResCode = ResponseStatusCodeEnum.ErrParam.GetHashCode();
  6577. result.ResMsg = "没有传巷道值";
  6578. return result;
  6579. }
  6580. return ApplyLoc(new FJApplyLocRequest
  6581. {
  6582. MaterialId = stock.MatId,
  6583. MaterialCode = stock.MatCode,
  6584. Size = reqEntity.Height,
  6585. TunnelNum = reqEntity.TunnelNum,
  6586. WarehuoseId = warehouse.Id,
  6587. IsMove = wcstask.Type == TaskType.TransferDepot
  6588. });
  6589. }
  6590. /// <summary>
  6591. /// 分配货位
  6592. /// </summary>
  6593. /// <param name="reqEntity"></param>
  6594. /// <returns></returns>
  6595. public SRes<FJApplyStockInLocResponse> ApplyLoc(FJApplyLocRequest reqEntity)
  6596. {
  6597. var result = new SRes<FJApplyStockInLocResponse>
  6598. {
  6599. ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode(),
  6600. ResMsg = ResponseStatusCodeEnum.Sucess.GetDescription(),
  6601. ResData = new FJApplyStockInLocResponse()
  6602. };
  6603. //预留货位数量
  6604. var emptyLoc = _basewarecellrepository.GetList(p => p.IsStop == 0
  6605. && p.StateNum == FjLocationState.Empty
  6606. && p.TypeNum == FjLocationType.Storage
  6607. && p.Tunnel == reqEntity.TunnelNum
  6608. && p.WarehouseId == reqEntity.WarehuoseId
  6609. && p.Size == reqEntity.Size);
  6610. //判断是否移库
  6611. if (!reqEntity.IsMove && (emptyLoc == null || emptyLoc.Count < 2))
  6612. {
  6613. result.ResCode = ResponseStatusCodeEnum.NotEnoughLocation.GetHashCode();
  6614. result.ResMsg = ResponseStatusCodeEnum.NotEnoughLocation.GetDescription();
  6615. return result;
  6616. }
  6617. //找到可用货位
  6618. var loc1ist = _basewarecellrepository.Context
  6619. .Queryable<BaseWarecell>()
  6620. .Where(loc1 => loc1.IsStop == 0
  6621. && loc1.StateNum == FjLocationState.Empty
  6622. && loc1.TypeNum == FjLocationType.Storage
  6623. && loc1.Tunnel == reqEntity.TunnelNum
  6624. && loc1.WarehouseId == reqEntity.WarehuoseId
  6625. && loc1.Size == reqEntity.Size
  6626. && loc1.Depth == 1)
  6627. .Where(loc1 => loc1.Tunnel == reqEntity.TunnelNum)
  6628. .Select(loc1 => new
  6629. {
  6630. loc1.Code,
  6631. loc1.Id,
  6632. loc1.Row,
  6633. loc1.Col,
  6634. loc1.Layer,
  6635. loc1.Tunnel
  6636. }).ToList();
  6637. if (loc1ist.Any())
  6638. {
  6639. var resloc = loc1ist.ToList().OrderBy(p => p.Layer).ThenBy(p => p.Col).ThenBy(p => p.Row).First();
  6640. result.ResData.TunnelNum = resloc.Tunnel.ToString();
  6641. result.ResData.WarehuoseId = reqEntity.WarehuoseId;
  6642. result.ResData.CellNo = resloc.Code;
  6643. result.ResData.Row = resloc.Row;
  6644. result.ResData.Colomn = resloc.Col;
  6645. result.ResData.Layer = resloc.Layer;
  6646. return result;
  6647. }
  6648. result.ResCode = ResponseStatusCodeEnum.NotEnoughLocation.GetHashCode();
  6649. result.ResMsg = ResponseStatusCodeEnum.NotEnoughLocation.GetDescription();
  6650. return result;
  6651. }
  6652. #endregion 巷道及货位分配
  6653. #region 二楼申请空托盘组出库
  6654. /// <summary>
  6655. /// 申请空托盘组出库任务
  6656. /// </summary>
  6657. /// <param name="reqDto"></param>
  6658. /// <returns></returns>
  6659. public SRes ApplyEmptyPalletGroupOutStorage(FjApplyEmptyPalletGroupOutStorageRequest reqDto)
  6660. {
  6661. var res = new SRes();
  6662. ////获取所有未被禁用的巷道
  6663. //var tunnel = _sysconfigrepository.AsQueryable().Where(p => p.SType == "OutStop" && string.IsNullOrEmpty(p.SContent)).ToList();
  6664. //if (!tunnel.Any())
  6665. //{
  6666. // res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  6667. // res.ResMsg = +"没有可用巷道";
  6668. // return res;
  6669. //}
  6670. //检查对应目标地址是否有出库任务
  6671. var task = _wcstaskoldrepository.AsQueryable().With(SqlWith.NoLock)
  6672. .Where(x => x.Status < TaskStatus.Finish && x.AddrTo == reqDto.AddTo).SplitTable(v => v.Take(2));
  6673. if (task.Any())
  6674. {
  6675. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  6676. res.ResMsg = $"拆盘机{reqDto.AddTo}已存在未结束任务";
  6677. return res;
  6678. }
  6679. //计算巷道剩余空托盘数量
  6680. //TODO:跟据客户要救,暂时屏蔽调关于托盘类型的判断
  6681. var locationlist =
  6682. from loc in _basewarecellrepository.GetList(p => p.IsStop == 0 && p.StateNum == FjLocationState.Full)
  6683. join stock in _billInvnowrepository.GetList(p =>
  6684. p.ContGrpType == FJContGrpType.EmptyCon &&
  6685. p.InvStateCode == InvState.InvEcecState_In.ToString() &&
  6686. p.ExecStateCode ==
  6687. InvLockState.InvState_Normal.ToString() && /*p.PalletType == reqDto.FJPalletType &&*/
  6688. p.ContGrpType == FJContGrpType.EmptyCon)
  6689. on loc.ContGrpBarCode equals stock.ContGrpBarCode
  6690. orderby stock.AddTime
  6691. select new
  6692. {
  6693. stock.MatCode,
  6694. stock.InvBarCode,
  6695. stock.RFIDBarCode,
  6696. stock.IsFast,
  6697. stock.Grade,
  6698. stock.IsSurplus,
  6699. stock.IsRework,
  6700. stock.InvStateCode,
  6701. stock.ProductTime,
  6702. loc.Col,
  6703. loc.Layer,
  6704. loc.Shelf,
  6705. loc.Depth,
  6706. loc.Code,
  6707. loc.Tunnel,
  6708. loc.WarehouseCode,
  6709. loc.ContGrpBarCode,
  6710. loc.Id,
  6711. loc.StateNum
  6712. };
  6713. locationlist = locationlist.Where(p => p.Tunnel == reqDto.Tunnel);
  6714. if (locationlist == null || !locationlist.Any())
  6715. {
  6716. res.ResCode = ResponseStatusCodeEnum.NotEnoughStock.GetHashCode();
  6717. res.ResMsg = reqDto.FJPalletType.GetDescription() +
  6718. ResponseStatusCodeEnum.NotEnoughStock.GetDescription();
  6719. return res;
  6720. }
  6721. locationlist = locationlist.OrderBy(p => p.ProductTime);
  6722. //出库任务
  6723. var temploc = locationlist.First();
  6724. var sotck = _billInvnowrepository.GetFirst(p =>
  6725. p.ContGrpBarCode == temploc.ContGrpBarCode && p.InvStateCode == InvState.InvEcecState_In.ToString());
  6726. try
  6727. {
  6728. _db.BeginTran();
  6729. //货位表
  6730. _basewarecellrepository.UpdateModelColumns(
  6731. p => new BaseWarecell { StateNum = FjLocationState.StockOut }, p => p.Id == temploc.Id);
  6732. //库存表
  6733. _billInvnowrepository.UpdateModelColumns(
  6734. p => new BillInvnow
  6735. { InvStateCode = InvState.InvEcecState_OutGoing.ToString(), EditTime = DateTime.Now },
  6736. p => p.Id == sotck.Id);
  6737. var invflow = _mapper.Map<BillInvflow>(sotck);
  6738. invflow.InvStateCode = InvState.InvEcecState_OutGoing.ToString();
  6739. invflow.AddTime = DateTime.Now;
  6740. invflow.Id = IdFactory.NewId();
  6741. invflow.Memo = "空托出库";
  6742. _billInvflow.Insert(invflow);
  6743. //添加出库任务
  6744. CreateStockOutWcsTask(new FJCreateStockOutWcsTaskRequest
  6745. {
  6746. ContGrpBarCode = temploc.ContGrpBarCode,
  6747. CellNo = temploc.Code,
  6748. EquCode = reqDto.AddTo,
  6749. Floor = 2,
  6750. Qty = sotck.LengthQty,
  6751. Tunnel = temploc.Tunnel.ToString(),
  6752. WarehouseCode = temploc.WarehouseCode,
  6753. BusType = FJTaskBusType.二楼空托盘组出库
  6754. });
  6755. _db.CommitTran();
  6756. }
  6757. catch (Exception ex)
  6758. {
  6759. _db.RollbackTran();
  6760. _logger.LogInformation(ex.ToString());
  6761. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  6762. res.ResMsg = ResponseStatusCodeEnum.DataSaveErr.GetDescription();
  6763. return res;
  6764. }
  6765. return res;
  6766. }
  6767. /// <summary>
  6768. /// 创建WCS出库任务
  6769. /// </summary>
  6770. /// <param name="reqDto"></param>
  6771. /// <returns></returns>
  6772. public SRes<WCS_TaskInfo> CreateStockOutWcsTask(FJCreateStockOutWcsTaskRequest reqDto)
  6773. {
  6774. var res = new SRes<WCS_TaskInfo>();
  6775. var bus = reqDto.BusType.GetDescription();
  6776. var wcstask = new WCS_TaskInfo
  6777. {
  6778. Type = TaskType.OutDepot,
  6779. Status = TaskStatus.NewBuild,
  6780. Priority = 0,
  6781. Device = "SRM" + reqDto.Tunnel,
  6782. AddrFrom = reqDto.CellNo,
  6783. AddrTo = reqDto.EquCode,
  6784. LastInteractionPoint = "",
  6785. BarCode = reqDto.ContGrpBarCode,
  6786. Floor = reqDto.Floor,
  6787. Length = reqDto.Qty,
  6788. AddTime = DateTime.Now,
  6789. StartTime = DateTime.Now,
  6790. DocID = 0,
  6791. PalletType = 1,
  6792. ProdLine = 0,
  6793. AddWho = "wms",
  6794. WarehouseCode = reqDto.WarehouseCode,
  6795. Enabled = true,
  6796. WorkBench = reqDto.WorkBench,
  6797. Tunnel = reqDto.Tunnel,
  6798. BusType = bus
  6799. };
  6800. var wcstaskhis = _mapper.Map<WCS_TaskOld>(wcstask);
  6801. try
  6802. {
  6803. _db.BeginTran();
  6804. var task = _taskrepository.InsertReturnEntity(wcstask);
  6805. wcstaskhis.Id = task.ID;
  6806. _wcstaskoldrepository.InsertableSplitTable(wcstaskhis);
  6807. var taskdetail = new WCS_TaskDtl
  6808. {
  6809. ID = Guid.NewGuid(),
  6810. CurPoint = reqDto.CellNo,
  6811. AddTime = DateTime.Now,
  6812. AddWho = "wms",
  6813. Enabled = true,
  6814. ParentTaskCode = task.ID,
  6815. Desc = reqDto.EquCode + "分拣空托盘组备料"
  6816. };
  6817. _taskdetailrepository.InsertableSplitTable(taskdetail);
  6818. _db.CommitTran();
  6819. res.ResData = task;
  6820. }
  6821. catch (Exception ex)
  6822. {
  6823. _db.RollbackTran();
  6824. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  6825. res.ResMsg = ResponseStatusCodeEnum.DataSaveErr.GetDescription();
  6826. _logger.LogInformation("保存任务异常:" + ex);
  6827. return res;
  6828. }
  6829. return res;
  6830. }
  6831. #endregion 二楼申请空托盘组出库
  6832. #region 容器、物料、条码、库存检测及创建,创建流水信息
  6833. /// <summary>
  6834. /// 检查容器是否存在,不存在则创建
  6835. /// </summary>
  6836. /// <param name="contBarCode">容器条码</param>
  6837. /// <param name="fjContainerType">容器类型</param>
  6838. /// <returns></returns>
  6839. public SRes CheckContinfo(string contBarCode, FJContainerType fjContainerType)
  6840. {
  6841. var res = new SRes();
  6842. var container = _baseContinfo.GetSingle(x => x.ContBarCode == contBarCode);
  6843. if (container == null)
  6844. {
  6845. //创建容器信息
  6846. var cont = new BaseContinfo
  6847. {
  6848. ContBarCode = contBarCode,
  6849. Name = contBarCode,
  6850. TypeCode = fjContainerType.ToString(),
  6851. PrintQty = 1,
  6852. IsStop = 0,
  6853. WarehouseId = 0,
  6854. AddWho = "WMS",
  6855. AddTime = DateTime.Now
  6856. };
  6857. //加载新的容器信息
  6858. if (!_baseContinfo.Insert(cont))
  6859. {
  6860. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  6861. res.ResMsg = "托盘初始化失败";
  6862. return res;
  6863. }
  6864. }
  6865. else if (container.IsStop != 0)
  6866. {
  6867. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  6868. res.ResMsg = "容器已停用";
  6869. return res;
  6870. }
  6871. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  6872. return res;
  6873. }
  6874. /// <summary>
  6875. /// 跟据库存信息创建流水信息
  6876. /// </summary>
  6877. /// <param name="barlist">库存信息</param>
  6878. /// <returns></returns>
  6879. public SRes CreateInvFlow(List<BillInvnow> barlist)
  6880. {
  6881. var res = new SRes();
  6882. var listflow = _mapper.Map<List<BillInvflow>>(barlist);
  6883. foreach (var item in listflow)
  6884. {
  6885. item.AddTime = DateTime.Now;
  6886. item.Id = IdFactory.NewId();
  6887. }
  6888. _billInvflow.InsertRange(listflow);
  6889. return res;
  6890. }
  6891. /// <summary>
  6892. /// 跟据库存信息创建流水信息
  6893. /// </summary>
  6894. /// <param name="bar">库存信息</param>
  6895. /// <returns></returns>
  6896. public SRes CreateInvFlow(BillInvnow bar)
  6897. {
  6898. var res = new SRes();
  6899. var flow = _mapper.Map<BillInvflow>(bar);
  6900. flow.AddTime = DateTime.Now;
  6901. flow.Id = IdFactory.NewId();
  6902. _billInvflow.Insert(flow);
  6903. return res;
  6904. }
  6905. /// <summary>
  6906. /// 是否有空余货位
  6907. /// </summary>
  6908. /// <returns></returns>
  6909. public SRes IsThereAnySpaceVacancy()
  6910. {
  6911. var res = new SRes();
  6912. //验证有剩余货位
  6913. if (_basewarecellrepository
  6914. .GetList(p => p.IsStop == 0 && p.StateNum == FjLocationState.Empty && p.Size == 2).Count() < 2)
  6915. {
  6916. res.ResCode = ResponseStatusCodeEnum.NotEnoughLocation.GetHashCode();
  6917. res.ResMsg = ResponseStatusCodeEnum.NotEnoughLocation.GetDescription();
  6918. return res;
  6919. }
  6920. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  6921. return res;
  6922. }
  6923. /// <summary>
  6924. /// 检查传入的仓库是否存在
  6925. /// </summary>
  6926. /// <param name="wareCode">仓库编号</param>
  6927. /// <returns></returns>
  6928. public SRes CheckWareCode(string wareCode)
  6929. {
  6930. var res = new SRes();
  6931. //验证是否有对应仓库
  6932. var warehosue = _basewarehouserepository.GetSingle(p => p.Code == wareCode);
  6933. if (warehosue == null)
  6934. {
  6935. res.ResCode = ResponseStatusCodeEnum.WarehouseCodeNotExist.GetHashCode();
  6936. res.ResMsg = ResponseStatusCodeEnum.WarehouseCodeNotExist.GetDescription();
  6937. return res;
  6938. }
  6939. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  6940. return res;
  6941. }
  6942. /// <summary>
  6943. /// 验证空托盘是否有未结束的任务
  6944. /// </summary>
  6945. /// <param name="PalletCode"></param>
  6946. /// <returns></returns>
  6947. public SRes CheckNoFinishTask(string PalletCode)
  6948. {
  6949. var res = new SRes();
  6950. //验证当前托盘是否有未结束的任务
  6951. var task = _wcstaskoldrepository.AsQueryable().With(SqlWith.NoLock)
  6952. .Where(p => p.BarCode == PalletCode && p.Status < TaskStatus.Finish).SplitTable(p => p.Take(2)).First();
  6953. if (task != null && task.Id > 0)
  6954. switch (task.Type)
  6955. {
  6956. case TaskType.SetPlate:
  6957. res.ResCode = ResponseStatusCodeEnum.WcsTaskExist.GetHashCode();
  6958. res.ResMsg = PalletCode + "该号组盘任务还未完成,请先完成组盘任务";
  6959. return res;
  6960. case TaskType.EnterDepot:
  6961. if (task.Status > TaskStatus.WaitingToExecute && task.Status < TaskStatus.Finish)
  6962. {
  6963. res.ResCode = ResponseStatusCodeEnum.WcsTaskExist.GetHashCode();
  6964. res.ResMsg = PalletCode + "已有进行中任务,请检查托盘条码是否重复";
  6965. return res;
  6966. }
  6967. res.ResCode = ResponseStatusCodeEnum.WcsTaskExist.GetHashCode();
  6968. res.ResMsg = PalletCode + "任务已创建,请勿重复申请";
  6969. return res;
  6970. case TaskType.OutDepot:
  6971. res.ResCode = ResponseStatusCodeEnum.WcsTaskExist.GetHashCode();
  6972. res.ResMsg = PalletCode + "该号出库任务还未完成,请先完成出库任务";
  6973. return res;
  6974. case TaskType.TransferDepot:
  6975. res.ResCode = ResponseStatusCodeEnum.WcsTaskExist.GetHashCode();
  6976. res.ResMsg = PalletCode + "该号移库任务还未完成,请先完成移库任务";
  6977. return res;
  6978. case TaskType.Delivery:
  6979. res.ResCode = ResponseStatusCodeEnum.WcsTaskExist.GetHashCode();
  6980. res.ResMsg = PalletCode + "该号输送任务还未完成,请先完成输送任务";
  6981. return res;
  6982. case TaskType.EmptyInit:
  6983. res.ResCode = ResponseStatusCodeEnum.WcsTaskExist.GetHashCode();
  6984. res.ResMsg = PalletCode + "该号空轮初始化任务还未完成,请先完成空轮初始化任务";
  6985. return res;
  6986. }
  6987. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  6988. return res;
  6989. }
  6990. /// <summary>
  6991. /// 检查是否存在库存信息
  6992. /// </summary>
  6993. /// <param name="code">编码</param>
  6994. /// <returns></returns>
  6995. public SRes CheckInvnow(string code)
  6996. {
  6997. var res = new SRes();
  6998. //验证是否没有库存信息
  6999. var stock = _billInvnowrepository.GetSingle(p => p.ContGrpBarCode == code);
  7000. if (stock != null && stock.InvStateCode == FJInvState.InvEcecState_In.ToString())
  7001. {
  7002. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  7003. res.ResMsg = code + "该托盘号已在库中,请检查托盘号是否重复";
  7004. return res;
  7005. }
  7006. if (stock != null && stock.InvStateCode == InvState.InvEcecState_OutGoing.ToString())
  7007. {
  7008. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  7009. res.ResMsg = code + "该托盘号存在出库中任务,请检查上一个任务是否已经完成";
  7010. return res;
  7011. }
  7012. //else if (stock != null)
  7013. //{
  7014. // res.ResCode = ResponseStatusCodeEnum.GroupStockDetailMaterialBarCodeExist.GetHashCode();
  7015. // res.ResMsg = ResponseStatusCodeEnum.GroupStockDetailMaterialBarCodeExist.GetDescription();
  7016. // return res;
  7017. //}
  7018. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  7019. return res;
  7020. }
  7021. /// <summary>
  7022. /// 创建库存信息
  7023. /// 不验证容器是否存在
  7024. /// 不验证容器是否有未结束的任务
  7025. /// 不验条码信息是否存在
  7026. /// </summary>
  7027. /// <param name="barList">条码集合</param>
  7028. /// <param name="containerBarcode">容器编号</param>
  7029. /// <param name="containerType">容器类型</param>
  7030. /// <returns></returns>
  7031. public SRes<BillInvnow> CreateStock(List<BillInvinit> barList, string containerBarcode)
  7032. {
  7033. var res = new SRes<BillInvnow>();
  7034. if (string.IsNullOrEmpty(containerBarcode))
  7035. {
  7036. res.ResCode = ResponseStatusCodeEnum.ContainerCodeNotEmpty.GetHashCode();
  7037. res.ResMsg = ResponseStatusCodeEnum.ContainerCodeNotEmpty.GetDescription();
  7038. return res;
  7039. }
  7040. //将条码表映射到库存表
  7041. var stocklist = _mapper.Map<List<BillInvnow>>(barList);
  7042. foreach (var item in stocklist)
  7043. {
  7044. item.AddTime = DateTime.Now;
  7045. item.Id = IdFactory.NewId();
  7046. }
  7047. if (!_billInvnowrepository.InsertRange(stocklist))
  7048. {
  7049. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  7050. res.ResMsg = "托盘库存信息存储失败";
  7051. return res;
  7052. }
  7053. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  7054. res.ResDataList = stocklist;
  7055. return res;
  7056. }
  7057. /// <summary>
  7058. /// 创建WCS任务
  7059. /// </summary>
  7060. /// <param name="reqDto"></param>
  7061. /// <returns></returns>
  7062. public SRes<WCS_TaskInfo> CreateStockInWcsTask(FJCreateStockInWcsTaskRequest reqDto, string gra = "",
  7063. bool isBench = false)
  7064. {
  7065. var res = new SRes<WCS_TaskInfo>();
  7066. var wcsTask = new WCS_TaskInfo
  7067. {
  7068. Type = reqDto.Type,
  7069. Status = TaskStatus.NewBuild,
  7070. Priority = 0,
  7071. Device = "",
  7072. SrmStation = "",
  7073. AddrFrom = reqDto.EquCode,
  7074. AddrTo = "SRM",
  7075. LastInteractionPoint = "",
  7076. BarCode = reqDto.ContGrpBarCode,
  7077. Floor = reqDto.Floor,
  7078. Length = reqDto.Qty,
  7079. AddTime = DateTime.Now,
  7080. StartTime = DateTime.Now,
  7081. DocID = 0,
  7082. WorkOrder = reqDto.DocCode,
  7083. PalletType = 1,
  7084. ProdLine = 0,
  7085. AddWho = "WMS",
  7086. WarehouseCode = reqDto.WarehouseCode,
  7087. Enabled = true,
  7088. Height = reqDto.Height,
  7089. Grade = gra,
  7090. //WorkBench = reqDto.EquCode,
  7091. //MaterialCode = reqDto.MaterialCode,
  7092. MatCode = reqDto.MatCode,
  7093. BusType = reqDto.BusType,
  7094. GoodsType = reqDto.GoodsType
  7095. };
  7096. if (isBench) wcsTask.WorkBench = reqDto.EquCode;
  7097. var wcsTaskHis = _mapper.Map<WCS_TaskOld>(wcsTask);
  7098. try
  7099. {
  7100. var task = _taskrepository.InsertReturnEntity(wcsTask);
  7101. wcsTaskHis.Id = task.ID;
  7102. _wcstaskoldrepository.InsertableSplitTable(wcsTaskHis);
  7103. var taskDetail = new WCS_TaskDtl
  7104. {
  7105. ID = Guid.NewGuid(),
  7106. CurPoint = reqDto.EquCode,
  7107. AddTime = DateTime.Now,
  7108. AddWho = "WMS",
  7109. Enabled = true,
  7110. ParentTaskCode = task.ID,
  7111. Desc = reqDto.EquCode + "任务生成"
  7112. };
  7113. _taskdetailrepository.InsertableSplitTable(taskDetail);
  7114. res.ResData = task;
  7115. }
  7116. catch (Exception ex)
  7117. {
  7118. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  7119. res.ResMsg = ResponseStatusCodeEnum.DataSaveErr.GetDescription();
  7120. _logger.LogInformation("保存任务异常:" + ex);
  7121. return res;
  7122. }
  7123. return res;
  7124. }
  7125. #endregion 容器、物料、条码、库存检测及创建,创建流水信息
  7126. /// <summary>
  7127. /// 手动出库
  7128. /// </summary>
  7129. /// <param name="request"></param>
  7130. /// <returns></returns>
  7131. public string ManualTask(FJManualTaskRequest request)
  7132. {
  7133. var res = new SRes();
  7134. //必须要有货位信息
  7135. if (!request.Location.Any())
  7136. {
  7137. res.ResCode = ResponseStatusCodeEnum.ErrParamNotNull.GetHashCode();
  7138. res.ResMsg = "货位" + ResponseStatusCodeEnum.ErrParamNotNull.GetDescription();
  7139. return res.ToCamelCaseString();
  7140. }
  7141. try
  7142. {
  7143. foreach (var item in request.Location)
  7144. {
  7145. //货位信息验证
  7146. var location = _basewarecellrepository.GetSingle(p =>
  7147. p.Code == item && p.WarehouseCode == request.WarehouseCode);
  7148. if (location == null)
  7149. {
  7150. res.ResCode = ResponseStatusCodeEnum.WareLocationCodeNotExist.GetHashCode();
  7151. res.ResMsg = item + ResponseStatusCodeEnum.WareLocationCodeNotExist.GetDescription();
  7152. return res.ToCamelCaseString();
  7153. }
  7154. if (location.StateNum != FjLocationState.Full)
  7155. {
  7156. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  7157. res.ResMsg = item + ResponseStatusCodeEnum.Fail.GetDescription() + "货位状态不满足出库条件";
  7158. return res.ToCamelCaseString();
  7159. }
  7160. if (location.IsStop == 1)
  7161. {
  7162. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  7163. res.ResMsg = ResponseStatusCodeEnum.Fail.GetDescription() + item + "被禁用";
  7164. return res.ToCamelCaseString();
  7165. }
  7166. //库存信息验证
  7167. var stock = _billInvnowrepository.GetFirst(p =>
  7168. p.ContGrpBarCode == location.ContGrpBarCode &&
  7169. p.InvStateCode == InvState.InvEcecState_In.ToString());
  7170. if (stock == null)
  7171. {
  7172. res.ResCode = ResponseStatusCodeEnum.StockNotExist.GetHashCode();
  7173. res.ResMsg = ResponseStatusCodeEnum.StockNotExist.GetDescription();
  7174. return res.ToCamelCaseString();
  7175. }
  7176. if (stock.InvStateCode != InvState.InvEcecState_In.ToString())
  7177. {
  7178. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  7179. res.ResMsg = item + "组盘状态不是已入库";
  7180. return res.ToCamelCaseString();
  7181. }
  7182. var billTask = new WCS_TaskInfo();
  7183. billTask.Status = TaskStatus.NewBuild;
  7184. billTask.Type = TaskType.OutDepot;
  7185. billTask.Priority = 0;
  7186. billTask.Device = "SRM" + location.Tunnel;
  7187. billTask.AddrFrom = item;
  7188. billTask.AddrTo = request.AddTo;
  7189. billTask.BarCode = stock.ContGrpBarCode;
  7190. billTask.StartTime = DateTime.Now;
  7191. billTask.AddTime = DateTime.Now;
  7192. billTask.EditTime = DateTime.Now;
  7193. billTask.AddWho = "WMS";
  7194. billTask.WarehouseCode = location.WarehouseCode;
  7195. billTask.Enabled = true;
  7196. billTask.Floor = 2;
  7197. billTask.Tunnel = location.Tunnel.ToString();
  7198. billTask.PalletType = 1;
  7199. billTask.Length = stock.LengthQty;
  7200. billTask.MaterialCode = stock.MatCode;
  7201. billTask.OutType = OutTypeEnum.全自动手动出库任务;
  7202. billTask.BusType = FJTaskBusType.TaskBusType_FJ_ManualOut.GetDescription();
  7203. _db.BeginTran();
  7204. _basewarecellrepository.UpdateSetColumnsTrue(p => new BaseWarecell
  7205. {
  7206. StateNum = FjLocationState.StockOut,
  7207. EditTime = DateTime.Now
  7208. }, p => p.Code == item && p.WarehouseCode == request.WarehouseCode);
  7209. _billInvnowrepository.UpdateSetColumnsTrue(p => new BillInvnow
  7210. {
  7211. InvStateCode = InvState.InvEcecState_OutGoing.ToString(),
  7212. EditTime = DateTime.Now
  7213. }, p => p.ContGrpBarCode == stock.ContGrpBarCode);
  7214. var flow = _mapper.Map<BillInvflow>(stock);
  7215. flow.Id = IdFactory.NewId();
  7216. flow.InvStateCode = InvState.InvEcecState_OutGoing.ToString();
  7217. flow.EditTime = DateTime.Now;
  7218. _billInvflow.Insert(flow);
  7219. var wcs = _taskrepository.InsertReturnEntity(billTask);
  7220. var wcshistory = _mapper.Map<WCS_TaskOld>(wcs);
  7221. _wcstaskoldrepository.InsertableSplitTable(wcshistory);
  7222. var taskdetail = new WCS_TaskDtl
  7223. {
  7224. ID = Guid.NewGuid(),
  7225. CurPoint = item,
  7226. AddTime = DateTime.Now,
  7227. AddWho = "wms",
  7228. Enabled = true,
  7229. ParentTaskCode = wcs.ID,
  7230. Desc = wcs.OutType.ToString()
  7231. };
  7232. _taskdetailrepository.InsertableSplitTable(taskdetail);
  7233. _db.CommitTran();
  7234. }
  7235. }
  7236. catch (Exception ex)
  7237. {
  7238. _db.RollbackTran();
  7239. _logger.LogInformation("手动出库异常:" + ex.Message);
  7240. res.ResCode = ResponseStatusCodeEnum.DataSaveErr.GetHashCode();
  7241. res.ResMsg = ResponseStatusCodeEnum.DataSaveErr.GetDescription();
  7242. return res.ToCamelCaseString();
  7243. }
  7244. return res.ToCamelCaseString();
  7245. }
  7246. /// <summary>
  7247. /// 堆垛机出库完成
  7248. /// </summary>
  7249. /// <param name="reqDto"></param>
  7250. /// <returns></returns>
  7251. public SRes<int> SrmPickOutCompleted(SrmPickOutCompletedRequest reqDto)
  7252. {
  7253. var result = new SRes<int>
  7254. {
  7255. ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode(),
  7256. ResMsg = ResponseStatusCodeEnum.Sucess.GetDescription(),
  7257. ResData = reqDto.TaskNum
  7258. };
  7259. var wcstask = _wcstaskoldrepository.AsQueryable().With(SqlWith.NoLock).Where(p => p.Id == reqDto.TaskNum)
  7260. .SplitTable(tabs => tabs.Take(2)).First();
  7261. ;
  7262. if (wcstask == null || wcstask.Id <= 0)
  7263. {
  7264. result.ResCode = ResponseStatusCodeEnum.WcsTaskNotExist.GetHashCode();
  7265. result.ResMsg = reqDto.TaskNum + ResponseStatusCodeEnum.WcsTaskNotExist.GetDescription();
  7266. return result;
  7267. }
  7268. if (wcstask.Type != TaskType.OutDepot)
  7269. {
  7270. result.ResCode = ResponseStatusCodeEnum.OnlyStockOutAvil.GetHashCode();
  7271. result.ResMsg = reqDto.TaskNum + ResponseStatusCodeEnum.OnlyStockOutAvil.GetDescription();
  7272. return result;
  7273. }
  7274. if (wcstask.Status >= TaskStatus.Finish)
  7275. {
  7276. result.ResCode = ResponseStatusCodeEnum.StateNotUpdate.GetHashCode();
  7277. result.ResMsg = reqDto.TaskNum + ResponseStatusCodeEnum.StateNotUpdate.GetDescription();
  7278. return result;
  7279. }
  7280. try
  7281. {
  7282. var well = _basewarecellrepository.GetSingle(x =>
  7283. x.ContGrpBarCode == wcstask.BarCode && x.Code.Contains(wcstask.AddrFrom) &&
  7284. (x.WarehouseCode == wcstask.WarehouseCode || wcstask.Device == "CR"));
  7285. if (well == null)
  7286. {
  7287. result.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  7288. result.ResMsg = reqDto.TaskNum + "任务已结束";
  7289. return result;
  7290. }
  7291. var wareHouse = _basewarehouserepository.GetSingle(x => x.Id == well.WarehouseId);
  7292. _db.BeginTran();
  7293. switch (wareHouse.TypeNum)
  7294. {
  7295. case FjLocationType.Storage:
  7296. //更新库存
  7297. _billInvnowrepository.UpdateModelColumns(
  7298. p => new BillInvnow { PutRow = 0, PutCol = 0, PutLayer = 0 },
  7299. p => p.InvStateCode == InvState.InvEcecState_OutGoing.ToString() &&
  7300. p.ContGrpBarCode == wcstask.BarCode);
  7301. break;
  7302. case FjLocationType.Virtual:
  7303. //更新库存
  7304. _billInvnowrepository.UpdateModelColumns(
  7305. p => new BillInvnow { PutRow = 0, PutCol = 0, PutLayer = 0 },
  7306. p => p.InvStateCode == InvState.InvEcecState_OutGoing.ToString() &&
  7307. p.ContGrpBarCode == wcstask.BarCode);
  7308. break;
  7309. case FjLocationType.Pingku:
  7310. _billInvnowrepository.UpdateModelColumns(
  7311. p => new BillInvnow { PutRow = 0, PutCol = 0, PutLayer = 0 },
  7312. p => p.InvStateCode == InvState.InvEcecState_OutGoing.ToString() &&
  7313. p.ContGrpBarCode == wcstask.BarCode);
  7314. break;
  7315. case FjLocationType.RingLibrary:
  7316. //更新库存
  7317. _billInvnowrepository.UpdateModelColumns(
  7318. p => new BillInvnow
  7319. {
  7320. PutRow = 0, PutCol = 0, PutLayer = 0,
  7321. InvStateCode = FJInvState.InvEcecState_BuildUp.ToString()
  7322. },
  7323. p => p.InvStateCode == InvState.InvEcecState_OutGoing.ToString() &&
  7324. (p.ContGrpBarCode == wcstask.BarCode || p.HWBarCode == wcstask.BarCode));
  7325. break;
  7326. }
  7327. var stocklist = _billInvnowrepository.GetList(p =>
  7328. (p.ContGrpBarCode == wcstask.BarCode || p.HWBarCode == wcstask.BarCode) &&
  7329. (p.InvStateCode == InvState.InvEcecState_BuildUp.ToString() ||
  7330. p.InvStateCode == InvState.InvEcecState_OutGoing.ToString()));
  7331. if (stocklist == null || !stocklist.Any())
  7332. {
  7333. result.ResCode = ResponseStatusCodeEnum.StockNotExist.GetHashCode();
  7334. result.ResMsg = reqDto.TaskNum + ResponseStatusCodeEnum.StockNotExist.GetDescription();
  7335. return result;
  7336. }
  7337. var flowlist = _mapper.Map<List<BillInvflow>>(stocklist);
  7338. foreach (var item in flowlist)
  7339. {
  7340. item.Id = IdFactory.NewId();
  7341. item.AddTime = DateTime.Now;
  7342. item.Memo = "设备出库放货完成";
  7343. }
  7344. //货位
  7345. _basewarecellrepository.UpdateModelColumns(
  7346. p => new BaseWarecell
  7347. {
  7348. StateNum = FjLocationState.Empty, ContGrpBarCode = "", ContGrpId = 0, EditTime = DateTime.Now,
  7349. GroupID = 0, XYNO = 0
  7350. },
  7351. p => p.ContGrpBarCode == wcstask.BarCode && p.Code.Contains(wcstask.AddrFrom) &&
  7352. (p.WarehouseCode == wcstask.WarehouseCode || wcstask.Device == "CR"));
  7353. _billInvflow.InsertRange(flowlist);
  7354. _db.CommitTran();
  7355. }
  7356. catch (Exception ex)
  7357. {
  7358. _db.RollbackTran();
  7359. _logger.LogInformation(ex.ToString());
  7360. result.ResCode = ResponseStatusCodeEnum.InnerServerErr.GetHashCode();
  7361. result.ResMsg = wcstask.Id + "设备出库放货完成异常";
  7362. }
  7363. return result;
  7364. }
  7365. /// <summary>
  7366. /// 完成任务
  7367. /// </summary>
  7368. /// <param name="reqDto"></param>
  7369. /// <returns></returns>
  7370. public SRes<int> CompleteTask(CompleteTaskRequest reqDto)
  7371. {
  7372. var result = new SRes<int>
  7373. {
  7374. ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode(),
  7375. ResMsg = ResponseStatusCodeEnum.Sucess.GetDescription(),
  7376. ResData = reqDto.TaskNum
  7377. };
  7378. //检查历史任务表是否有任务
  7379. var task = _wcstaskoldrepository.AsQueryable().With(SqlWith.NoLock)
  7380. .Where(p => p.Id == reqDto.TaskNum).SplitTable(tabs => tabs.Take(2)).First();
  7381. var isBackRewind = _wcstaskoldrepository.AsQueryable().With(SqlWith.NoLock)
  7382. .Where(p => p.Id == reqDto.TaskNum && p.BusType == FJTaskBusType.帘线退料重绕.GetDescription()).SplitTable(tabs => tabs.Take(2)).Any();
  7383. var isRewindIn = _wcstaskoldrepository.AsQueryable().With(SqlWith.NoLock)
  7384. .Where(p => p.Id == reqDto.TaskNum && p.BusType == FJTaskBusType.重绕满托入库.GetDescription()).SplitTable(tabs => tabs.Take(2)).Any();
  7385. if (task == null)
  7386. {
  7387. result.ResMsg = reqDto.TaskNum + ResponseStatusCodeEnum.WcsTaskNotExist.GetDescription();
  7388. return result;
  7389. }
  7390. switch (task.Type)
  7391. {
  7392. case TaskType.SetPlate:
  7393. try
  7394. {
  7395. //检查库存信息是否正确
  7396. var stock = _billInvnowrepository.GetFirst(p =>
  7397. p.ContGrpBarCode == task.BarCode || p.HWBarCode == task.BarCode);
  7398. if (stock == null)
  7399. {
  7400. result.ResMsg = task.BarCode + "没有库存信息";
  7401. return result;
  7402. }
  7403. var wareCell = _basewarecellrepository.GetFirst(x =>
  7404. x.ContGrpBarCode == stock.ContGrpBarCode && x.WarehouseId == stock.WarehouseId);
  7405. if (stock.InvStateCode == InvState.InvEcecState_In.ToString() &&
  7406. wareCell.StateNum == FjLocationState.Full) //如果库存状态是入库,货位状态是有货直接返回成功,避免WCS重复调用造成出库异常
  7407. return result;
  7408. if (stock.InvStateCode != InvState.InvEcecState_BuildUp.ToString())
  7409. {
  7410. result.ResMsg = task.BarCode + $"库存状态错误{stock.InvStateCode}";
  7411. return result;
  7412. }
  7413. var warehouse = _basewarehouserepository.GetSingle(p => p.Code == task.WarehouseCode);
  7414. _db.BeginTran();
  7415. var row = int.Parse(task.AddrTo.Split('-')[0]);
  7416. var col = int.Parse(task.AddrTo.Split('-')[1]);
  7417. var layer = int.Parse(task.AddrTo.Split('-')[2]);
  7418. //更新库存
  7419. _billInvnowrepository.UpdateModelColumns(p => new BillInvnow
  7420. {
  7421. WarehouseId = warehouse.Id,
  7422. InvStateCode = InvState.InvEcecState_In.ToString(),
  7423. PutRow = row,
  7424. PutCol = col,
  7425. PutLayer = layer,
  7426. OneInTime = DateTime.Now,
  7427. EditTime = DateTime.Now
  7428. },
  7429. p => p.HWBarCode == task.BarCode &&
  7430. p.InvStateCode == InvState.InvEcecState_BuildUp.ToString());
  7431. //更新货位
  7432. _basewarecellrepository.UpdateModelColumns(p => new BaseWarecell
  7433. {
  7434. StateNum = FjLocationState.Full,
  7435. ContGrpBarCode = stock.HWBarCode,
  7436. ContGrpId = stock.ContGrpId,
  7437. EditTime = DateTime.Now
  7438. }, p => p.Code == task.AddrTo && p.WarehouseId == warehouse.Id);
  7439. //增加流水信息
  7440. var enterDepotstocklist = _billInvnowrepository.GetList(p =>
  7441. p.ContGrpBarCode == task.BarCode && p.InvStateCode == InvState.InvEcecState_In.ToString());
  7442. foreach (var item in enterDepotstocklist)
  7443. {
  7444. item.Id = IdFactory.NewId();
  7445. item.AddTime = DateTime.Now;
  7446. }
  7447. _billInvflow.InsertRange(_mapper.Map<List<BillInvflow>>(enterDepotstocklist));
  7448. _db.CommitTran();
  7449. }
  7450. catch (Exception ex)
  7451. {
  7452. _db.RollbackTran();
  7453. result.ResMsg = task.Id + "完成任务异常";
  7454. _logger.LogInformation("完成任务异常" + ex);
  7455. }
  7456. break;
  7457. case TaskType.EnterDepot:
  7458. try
  7459. {
  7460. //退料
  7461. if (isBackRewind)
  7462. {
  7463. var warehouse = _basewarehouserepository.GetSingle(p => p.Code == task.WarehouseCode);
  7464. _db.BeginTran();
  7465. if (task.AddrTo == "9001" || task.AddrTo == "9101")
  7466. {
  7467. }
  7468. else if(task.AddrTo.StartsWith("92"))//退料缓存区
  7469. {
  7470. //检查库存信息是否正确
  7471. var stock = _billInvnowrepository.GetFirst(p =>
  7472. (p.ContGrpBarCode == task.BarCode || p.HWBarCode == task.BarCode)
  7473. && p.InvStateCode == InvState.InvEcecState_BuildUp.ToString());
  7474. if (stock == null)
  7475. {
  7476. result.ResMsg = task.BarCode + "没有已组盘的信息";
  7477. return result;
  7478. }
  7479. //更新库存
  7480. _billInvnowrepository.UpdateModelColumns(p => new BillInvnow
  7481. {
  7482. InvStateCode = InvState.InvEcecState_In.ToString(),
  7483. WarehouseId = warehouse.Id,
  7484. OneInTime = DateTime.Now,
  7485. EditTime = DateTime.Now
  7486. },
  7487. p => p.ContGrpBarCode == task.BarCode &&
  7488. p.InvStateCode == InvState.InvEcecState_BuildUp.ToString());
  7489. //更新货位
  7490. _basewarecellrepository.UpdateModelColumns(p => new BaseWarecell
  7491. {
  7492. StateNum = FjLocationState.Full,
  7493. ContGrpBarCode = stock.ContGrpBarCode,
  7494. ContGrpId = stock.ContGrpId,
  7495. EditTime = DateTime.Now
  7496. }, p => p.Code.Contains(task.AddrTo) && p.WarehouseId == warehouse.Id);
  7497. }
  7498. _db.CommitTran();
  7499. }
  7500. //组盘入库
  7501. else if (isRewindIn)
  7502. {
  7503. //检查库存信息是否正确
  7504. var stock = _billInvnowrepository.GetFirst(p =>
  7505. (p.ContGrpBarCode == task.BarCode || p.HWBarCode == task.BarCode)
  7506. && p.InvStateCode == InvState.InvEcecState_BuildUp.ToString());
  7507. if (stock == null)
  7508. {
  7509. result.ResMsg = task.BarCode + "没有已组盘的信息";
  7510. return result;
  7511. }
  7512. var warehouse = _basewarehouserepository.GetSingle(p => p.Code == task.WarehouseCode);
  7513. _db.BeginTran();
  7514. //更新库存
  7515. _billInvnowrepository.UpdateModelColumns(p => new BillInvnow
  7516. {
  7517. InvStateCode = InvState.InvEcecState_In.ToString(),
  7518. WarehouseId = warehouse.Id,
  7519. OneInTime = DateTime.Now,
  7520. EditTime = DateTime.Now
  7521. },
  7522. p => p.ContGrpBarCode == task.BarCode &&
  7523. p.InvStateCode == InvState.InvEcecState_BuildUp.ToString());
  7524. //更新货位
  7525. _basewarecellrepository.UpdateModelColumns(p => new BaseWarecell
  7526. {
  7527. StateNum = FjLocationState.Full,
  7528. ContGrpBarCode = stock.ContGrpBarCode,
  7529. ContGrpId = stock.ContGrpId,
  7530. EditTime = DateTime.Now
  7531. }, p => p.Code.Contains(task.AddrTo) && p.WarehouseId == warehouse.Id);
  7532. //增加流水信息
  7533. var enterDepotstocklist = _billInvnowrepository.GetList(p =>
  7534. p.ContGrpBarCode == task.BarCode && p.InvStateCode == InvState.InvEcecState_In.ToString());
  7535. foreach (var item in enterDepotstocklist)
  7536. {
  7537. item.Id = IdFactory.NewId();
  7538. item.AddTime = DateTime.Now;
  7539. }
  7540. _billInvflow.InsertRange(_mapper.Map<List<BillInvflow>>(enterDepotstocklist));
  7541. //添加反馈信息
  7542. var pushtype = fjFackbeekType.InterfaceType_FJ_StockIn.ToString();
  7543. var list = new List<BillPushinfo>();
  7544. foreach (var item in enterDepotstocklist)
  7545. list.Add(new BillPushinfo
  7546. {
  7547. DocsNo = stock.ExecDocsNo,
  7548. TypeCode = pushtype,
  7549. RFIDBarCode = stock.ContGrpBarCode,
  7550. HWBarCode = item.HWBarCode,
  7551. CLBarCode = item.CLBarCode,
  7552. WarehouseId = warehouse.Id,
  7553. WarehouseCode = warehouse.Code,
  7554. WareCellId = 0,
  7555. WareCellCode = task.AddrTo,
  7556. MatId = item.MatId,
  7557. MatCode = item.MatCode,
  7558. MatName = item.MatName,
  7559. TolWQty = item.TolWQty,
  7560. NetWQty = item.NetWQty,
  7561. TareWQty = item.TareWQty,
  7562. ReqNo = Guid.NewGuid().ToString()
  7563. });
  7564. if (stock.ContGrpType == FJContGrpType.Material) _billPushinforepository.InsertRange(list);
  7565. _db.CommitTran();
  7566. }
  7567. else
  7568. {
  7569. //检查库存信息是否正确
  7570. var stock = _billInvnowrepository.GetFirst(p =>
  7571. (p.ContGrpBarCode == task.BarCode || p.HWBarCode == task.BarCode)
  7572. && p.InvStateCode == InvState.InvEcecState_BuildUp.ToString());
  7573. if (stock == null)
  7574. {
  7575. result.ResMsg = task.BarCode + "没有已组盘的信息";
  7576. return result;
  7577. }
  7578. var warehouse = _basewarehouserepository.GetSingle(p => p.Code == task.WarehouseCode);
  7579. _db.BeginTran();
  7580. var row = int.Parse(task.AddrTo.Split('-')[0]);
  7581. var col = int.Parse(task.AddrTo.Split('-')[1]);
  7582. var layer = int.Parse(task.AddrTo.Split('-')[2]);
  7583. //更新库存
  7584. _billInvnowrepository.UpdateModelColumns(p => new BillInvnow
  7585. {
  7586. InvStateCode = InvState.InvEcecState_In.ToString(),
  7587. WarehouseId = warehouse.Id,
  7588. PutRow = row,
  7589. PutCol = col,
  7590. PutLayer = layer,
  7591. OneInTime = DateTime.Now,
  7592. EditTime = DateTime.Now
  7593. },
  7594. p => p.ContGrpBarCode == task.BarCode &&
  7595. p.InvStateCode == InvState.InvEcecState_BuildUp.ToString());
  7596. //更新货位
  7597. _basewarecellrepository.UpdateModelColumns(p => new BaseWarecell
  7598. {
  7599. StateNum = FjLocationState.Full,
  7600. ContGrpBarCode = stock.ContGrpBarCode,
  7601. ContGrpId = stock.ContGrpId,
  7602. EditTime = DateTime.Now
  7603. }, p => p.Code.Contains(task.AddrTo) && p.WarehouseId == warehouse.Id);
  7604. //增加流水信息
  7605. var enterDepotstocklist = _billInvnowrepository.GetList(p =>
  7606. p.ContGrpBarCode == task.BarCode && p.InvStateCode == InvState.InvEcecState_In.ToString());
  7607. foreach (var item in enterDepotstocklist)
  7608. {
  7609. item.Id = IdFactory.NewId();
  7610. item.AddTime = DateTime.Now;
  7611. }
  7612. _billInvflow.InsertRange(_mapper.Map<List<BillInvflow>>(enterDepotstocklist));
  7613. //添加反馈信息
  7614. var pushtype = fjFackbeekType.InterfaceType_FJ_StockIn.ToString();
  7615. var list = new List<BillPushinfo>();
  7616. foreach (var item in enterDepotstocklist)
  7617. list.Add(new BillPushinfo
  7618. {
  7619. DocsNo = stock.ExecDocsNo,
  7620. TypeCode = pushtype,
  7621. RFIDBarCode = stock.ContGrpBarCode,
  7622. HWBarCode = item.HWBarCode,
  7623. CLBarCode = item.CLBarCode,
  7624. WarehouseId = warehouse.Id,
  7625. WarehouseCode = warehouse.Code,
  7626. WareCellId = 0,
  7627. WareCellCode = task.AddrTo,
  7628. MatId = item.MatId,
  7629. MatCode = item.MatCode,
  7630. MatName = item.MatName,
  7631. TolWQty = item.TolWQty,
  7632. NetWQty = item.NetWQty,
  7633. TareWQty = item.TareWQty,
  7634. ReqNo = Guid.NewGuid().ToString()
  7635. });
  7636. if (stock.ContGrpType == FJContGrpType.Material) _billPushinforepository.InsertRange(list);
  7637. _db.CommitTran();
  7638. }
  7639. }
  7640. catch (Exception ex)
  7641. {
  7642. _db.RollbackTran();
  7643. result.ResMsg = task.Id + "完成任务异常";
  7644. _logger.LogInformation("完成任务异常" + ex);
  7645. }
  7646. break;
  7647. case TaskType.OutDepot:
  7648. //验证库存信息
  7649. var stocklist = _billInvnowrepository.GetList(p =>
  7650. (p.ContGrpBarCode == task.BarCode || p.HWBarCode == task.BarCode) &&
  7651. (p.InvStateCode == InvState.InvEcecState_OutGoing.ToString() ||
  7652. p.InvStateCode == InvState.InvEcecState_BuildUp.ToString()));
  7653. if (stocklist == null || !stocklist.Any())
  7654. result.ResMsg = reqDto.TaskNum + ResponseStatusCodeEnum.StockNotExist.GetDescription();
  7655. var flowlist = _mapper.Map<List<BillInvflow>>(stocklist);
  7656. foreach (var item in flowlist)
  7657. {
  7658. item.Id = IdFactory.NewId();
  7659. item.InvStateCode = InvState.InvEcecState_Out.ToString();
  7660. item.AddTime = DateTime.Now;
  7661. item.Memo = "任务完成";
  7662. }
  7663. try
  7664. {
  7665. _db.BeginTran();
  7666. //删除库存及条码信息
  7667. var wareHouse = _basewarehouserepository.GetSingle(x => x.Id == stocklist.First().WarehouseId);
  7668. switch (wareHouse.TypeNum)
  7669. {
  7670. case FjLocationType.Storage: //立库出库需要删除库存信息
  7671. _billInvnowrepository.Delete(p => stocklist.Select(p => p.Id).ToList().Contains(p.Id));
  7672. var hWBarCode = stocklist.Select(p => p.HWBarCode).ToList();
  7673. _billInvinitrepository.Delete(p =>
  7674. hWBarCode.Contains(p.HWBarCode) &&
  7675. p.InvStateCode == InvState.InvEcecState_OutGoing.ToString());
  7676. var contGrpBarCode = stocklist.Select(p => p.ContGrpBarCode).ToList();
  7677. _billInvinitrepository.Delete(p =>
  7678. contGrpBarCode.Contains(p.ContGrpBarCode) &&
  7679. p.InvStateCode == InvState.InvEcecState_OutGoing.ToString());
  7680. _billSpoolTransrepository.Delete(p =>
  7681. stocklist.Select(p => p.HWBarCode).ToList().Contains(p.ConBarCode));
  7682. _logger.LogInformation(
  7683. $"删除缓存信息{JsonConvert.SerializeObject(stocklist.Select(x => x.HWBarCode).ToList())}");
  7684. //更新货位信息
  7685. _basewarecellrepository.UpdateModelColumns(p => new BaseWarecell
  7686. {
  7687. StateNum = FjLocationState.Empty,
  7688. ContGrpBarCode = "",
  7689. ContGrpId = 0,
  7690. EditTime = DateTime.Now
  7691. },
  7692. p => p.StateNum == FjLocationState.StockOut && p.ContGrpBarCode == task.BarCode &&
  7693. p.Code.Contains(task.AddrFrom) && p.WarehouseCode == task.WarehouseCode);
  7694. //更新流水信息
  7695. _billInvflow.InsertRange(flowlist);
  7696. //添加反馈信息
  7697. var pushtype = fjFackbeekType.InterfaceType_FJ_StockOut.ToString();
  7698. var list = new List<BillPushinfo>();
  7699. foreach (var item in stocklist)
  7700. list.Add(new BillPushinfo
  7701. {
  7702. DocsNo = item.ExecDocsNo,
  7703. TypeCode = pushtype,
  7704. RFIDBarCode = item.ContGrpBarCode,
  7705. HWBarCode = item.HWBarCode,
  7706. CLBarCode = item.CLBarCode,
  7707. WarehouseId = wareHouse.Id,
  7708. WarehouseCode = wareHouse.Code,
  7709. WareCellId = 0,
  7710. WareCellCode = task.AddrTo,
  7711. MatId = item.MatId,
  7712. MatCode = item.MatCode,
  7713. MatName = item.MatName,
  7714. TolWQty = item.TolWQty,
  7715. NetWQty = item.NetWQty,
  7716. TareWQty = item.TareWQty,
  7717. ReqNo = Guid.NewGuid().ToString()
  7718. });
  7719. if (stocklist.First().ContGrpType == FJContGrpType.Material)
  7720. _billPushinforepository.InsertRange(list);
  7721. _db.CommitTran();
  7722. break;
  7723. case FjLocationType.RingLibrary: //环形库的库存信息变更是在SrmPickOutCompleted
  7724. break;
  7725. case FjLocationType.Pingku:
  7726. _billInvnowrepository.Delete(p => stocklist.Select(p => p.Id).ToList().Contains(p.Id));
  7727. hWBarCode = stocklist.Select(p => p.HWBarCode).ToList();
  7728. _billInvinitrepository.Delete(p =>
  7729. hWBarCode.Contains(p.HWBarCode) &&
  7730. p.InvStateCode == InvState.InvEcecState_OutGoing.ToString());
  7731. contGrpBarCode = stocklist.Select(p => p.ContGrpBarCode).ToList();
  7732. _billInvinitrepository.Delete(p =>
  7733. contGrpBarCode.Contains(p.ContGrpBarCode) &&
  7734. p.InvStateCode == InvState.InvEcecState_OutGoing.ToString());
  7735. _billSpoolTransrepository.Delete(p =>
  7736. stocklist.Select(p => p.HWBarCode).ToList().Contains(p.ConBarCode));
  7737. _logger.LogInformation(
  7738. $"删除缓存信息{JsonConvert.SerializeObject(stocklist.Select(x => x.HWBarCode).ToList())}");
  7739. //更新货位信息
  7740. _basewarecellrepository.UpdateModelColumns(p => new BaseWarecell
  7741. {
  7742. StateNum = FjLocationState.Empty,
  7743. ContGrpBarCode = "",
  7744. ContGrpId = 0,
  7745. EditTime = DateTime.Now
  7746. },
  7747. p => p.StateNum == FjLocationState.StockOut && p.ContGrpBarCode == task.BarCode &&
  7748. p.Code.Contains(task.AddrFrom) && (p.WarehouseCode == task.WarehouseCode || task.Device == "CR"));
  7749. //更新流水信息
  7750. _billInvflow.InsertRange(flowlist);
  7751. //添加反馈信息
  7752. pushtype = fjFackbeekType.InterfaceType_FJ_StockOut.ToString();
  7753. list = new List<BillPushinfo>();
  7754. foreach (var item in stocklist)
  7755. list.Add(new BillPushinfo
  7756. {
  7757. DocsNo = item.ExecDocsNo,
  7758. TypeCode = pushtype,
  7759. RFIDBarCode = item.ContGrpBarCode,
  7760. HWBarCode = item.HWBarCode,
  7761. CLBarCode = item.CLBarCode,
  7762. WarehouseId = wareHouse.Id,
  7763. WarehouseCode = wareHouse.Code,
  7764. WareCellId = 0,
  7765. WareCellCode = task.AddrTo,
  7766. MatId = item.MatId,
  7767. MatCode = item.MatCode,
  7768. MatName = item.MatName,
  7769. TolWQty = item.TolWQty,
  7770. NetWQty = item.NetWQty,
  7771. TareWQty = item.TareWQty,
  7772. ReqNo = Guid.NewGuid().ToString()
  7773. });
  7774. if (stocklist.First().ContGrpType == FJContGrpType.Material)
  7775. _billPushinforepository.InsertRange(list);
  7776. _db.CommitTran();
  7777. break;
  7778. case FjLocationType.Virtual:
  7779. _billInvnowrepository.Delete(p => stocklist.Select(p => p.Id).ToList().Contains(p.Id));
  7780. hWBarCode = stocklist.Select(p => p.HWBarCode).ToList();
  7781. _billInvinitrepository.Delete(p =>
  7782. hWBarCode.Contains(p.HWBarCode) &&
  7783. p.InvStateCode == InvState.InvEcecState_OutGoing.ToString());
  7784. contGrpBarCode = stocklist.Select(p => p.ContGrpBarCode).ToList();
  7785. _billInvinitrepository.Delete(p =>
  7786. contGrpBarCode.Contains(p.ContGrpBarCode) &&
  7787. p.InvStateCode == InvState.InvEcecState_OutGoing.ToString());
  7788. _billSpoolTransrepository.Delete(p =>
  7789. stocklist.Select(p => p.HWBarCode).ToList().Contains(p.ConBarCode));
  7790. _logger.LogInformation(
  7791. $"删除缓存信息{JsonConvert.SerializeObject(stocklist.Select(x => x.HWBarCode).ToList())}");
  7792. if (task.BusType == FJTaskBusType.车间叫料.ToString() && task.AddrFrom.Contains("NSTJ"))
  7793. //更新货位信息
  7794. _basewarecellrepository.UpdateModelColumns(p => new BaseWarecell
  7795. {
  7796. StateNum = FjLocationState.Empty,
  7797. ContGrpBarCode = "",
  7798. ContGrpId = 0,
  7799. EditTime = DateTime.Now
  7800. },
  7801. p => p.StateNum == FjLocationState.StockOut &&
  7802. p.ContGrpBarCode == task.BarCode &&
  7803. p.Code.Contains(task.AddrFrom) && p.WarehouseCode == "FJXG");
  7804. else
  7805. //更新货位信息
  7806. _basewarecellrepository.UpdateModelColumns(p => new BaseWarecell
  7807. {
  7808. StateNum = FjLocationState.Empty,
  7809. ContGrpBarCode = "",
  7810. ContGrpId = 0,
  7811. EditTime = DateTime.Now
  7812. },
  7813. p => p.StateNum == FjLocationState.StockOut &&
  7814. p.ContGrpBarCode == task.BarCode &&
  7815. p.Code.Contains(task.AddrFrom) && p.WarehouseCode == task.WarehouseCode);
  7816. //更新流水信息
  7817. _billInvflow.InsertRange(flowlist);
  7818. //添加反馈信息
  7819. pushtype = fjFackbeekType.InterfaceType_FJ_StockOut.ToString();
  7820. list = new List<BillPushinfo>();
  7821. foreach (var item in stocklist)
  7822. list.Add(new BillPushinfo
  7823. {
  7824. DocsNo = item.ExecDocsNo,
  7825. TypeCode = pushtype,
  7826. RFIDBarCode = item.ContGrpBarCode,
  7827. HWBarCode = item.HWBarCode,
  7828. CLBarCode = item.CLBarCode,
  7829. WarehouseId = wareHouse.Id,
  7830. WarehouseCode = wareHouse.Code,
  7831. WareCellId = 0,
  7832. WareCellCode = task.AddrTo,
  7833. MatId = item.MatId,
  7834. MatCode = item.MatCode,
  7835. MatName = item.MatName,
  7836. TolWQty = item.TolWQty,
  7837. NetWQty = item.NetWQty,
  7838. TareWQty = item.TareWQty,
  7839. ReqNo = Guid.NewGuid().ToString()
  7840. });
  7841. if (stocklist.First().ContGrpType == FJContGrpType.Material)
  7842. _billPushinforepository.InsertRange(list);
  7843. _db.CommitTran();
  7844. break;
  7845. default:
  7846. throw new ArgumentOutOfRangeException();
  7847. }
  7848. }
  7849. catch (Exception ex)
  7850. {
  7851. _db.RollbackTran();
  7852. _logger.LogInformation(ex.ToString());
  7853. result.ResMsg = task.Id + "完成任务异常";
  7854. }
  7855. break;
  7856. case TaskType.TransferDepot:
  7857. var fromcell = _basewarecellrepository.GetFirst(p =>
  7858. p.Code == task.AddrFrom && task.WarehouseCode == p.WarehouseCode);
  7859. var grcontid = fromcell.ContGrpId;
  7860. var grcontcode = fromcell.ContGrpBarCode;
  7861. var fromcellno = fromcell.Code;
  7862. var tocellno = task.AddrTo;
  7863. try
  7864. {
  7865. _db.BeginTran();
  7866. //更新货位信息
  7867. //起始货位
  7868. _basewarecellrepository.UpdateModelColumns(p => new BaseWarecell
  7869. {
  7870. StateNum = FjLocationState.Empty,
  7871. ContGrpBarCode = "",
  7872. ContGrpId = 0,
  7873. EditTime = DateTime.Now
  7874. }, p => p.Code.Contains(fromcellno) && p.WarehouseCode == task.WarehouseCode);
  7875. //目标货位
  7876. _basewarecellrepository.UpdateModelColumns(p => new BaseWarecell
  7877. {
  7878. StateNum = FjLocationState.Full,
  7879. ContGrpBarCode = grcontcode,
  7880. ContGrpId = grcontid,
  7881. EditTime = DateTime.Now
  7882. }, p => p.Code.Contains(tocellno));
  7883. //更新库存信息
  7884. var row = int.Parse(tocellno.Split('-')[0]);
  7885. var col = int.Parse(tocellno.Split('-')[1]);
  7886. var layer = int.Parse(tocellno.Split('-')[2]);
  7887. _billInvnowrepository.UpdateModelColumns(p => new BillInvnow
  7888. {
  7889. PutRow = row,
  7890. PutCol = col,
  7891. PutLayer = layer
  7892. }, p => p.ContGrpId == grcontid && p.InvStateCode == InvState.InvEcecState_In.ToString());
  7893. //更新流水信息
  7894. var stock = _billInvnowrepository.GetFirst(p =>
  7895. p.ContGrpId == grcontid && p.ContGrpBarCode == grcontcode &&
  7896. p.InvStateCode == InvState.InvEcecState_In.ToString());
  7897. var flow = _mapper.Map<BillInvflow>(stock);
  7898. flow.Id = IdFactory.NewId();
  7899. flow.AddTime = DateTime.Now;
  7900. flow.Memo = grcontcode + "移库(" + fromcellno + "至" + tocellno + ")";
  7901. _billInvflow.Insert(flow);
  7902. _db.CommitTran();
  7903. }
  7904. catch (Exception ex)
  7905. {
  7906. _db.RollbackTran();
  7907. result.ResMsg = task.Id + "完成任务异常";
  7908. _logger.LogInformation("完成任务异常" + ex);
  7909. }
  7910. break;
  7911. case TaskType.Delivery:
  7912. break;
  7913. case TaskType.EmptyInit:
  7914. break;
  7915. default:
  7916. result.ResMsg = reqDto.TaskNum + ResponseStatusCodeEnum.Fail.GetDescription();
  7917. return result;
  7918. }
  7919. return result;
  7920. }
  7921. public SRes<int> CancelTask(CompleteTaskRequest reqDto)
  7922. {
  7923. var res = new SRes<int>
  7924. {
  7925. ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode(),
  7926. ResMsg = ResponseStatusCodeEnum.Sucess.GetDescription()
  7927. };
  7928. var task = _wcstaskoldrepository.AsQueryable().With("WITH(READPAST,ROWLOCK)")
  7929. .Where(p => p.Id == reqDto.TaskNum).SplitTable(tabs => tabs.Take(2)).First();
  7930. if (task == null)
  7931. {
  7932. res.ResCode = ResponseStatusCodeEnum.WcsTaskNotExist.GetHashCode();
  7933. res.ResMsg = reqDto.TaskNum + ResponseStatusCodeEnum.WcsTaskNotExist.GetDescription();
  7934. return res;
  7935. }
  7936. try
  7937. {
  7938. if (task.Type == TaskType.EnterDepot)
  7939. {
  7940. //验证组盘状态
  7941. if (task.BusType == FJTaskBusType.重绕满托入库.GetDescription())
  7942. {
  7943. //验证库存状态
  7944. var stocklist = _billInvnowrepository.GetList(p =>
  7945. (p.ContGrpBarCode == task.BarCode || p.HWBarCode == task.BarCode) &&
  7946. (p.InvStateCode == InvState.InvEcecState_OutGoing.ToString() ||
  7947. p.InvStateCode == InvState.InvEcecState_BuildUp.ToString()));
  7948. if (stocklist == null || !stocklist.Any())
  7949. {
  7950. res.ResMsg = reqDto.TaskNum + ResponseStatusCodeEnum.StockNotExist.GetDescription();
  7951. return res;
  7952. }
  7953. var wareHouse = _basewarehouserepository.GetSingle(x => x.Id == stocklist.First().WarehouseId);
  7954. if (wareHouse.TypeNum == FjLocationType.Pingku)
  7955. {
  7956. _db.BeginTran();
  7957. _billInvinitrepository.Delete(x => x.ContGrpBarCode == task.BarCode && x.InvStateCode == InvState.InvEcecState_BuildUp.ToString());
  7958. _db.CommitTran();
  7959. }
  7960. }
  7961. }
  7962. else if (task.Type == TaskType.OutDepot && (task.BusType == FJTaskBusType.车间叫料.GetDescription() || task.BusType == FJTaskBusType.芯股站台送空托.GetDescription()))
  7963. {
  7964. //验证库存信息
  7965. var stocklist = _billInvnowrepository.GetList(p =>
  7966. (p.ContGrpBarCode == task.BarCode || p.HWBarCode == task.BarCode) &&
  7967. (p.InvStateCode == InvState.InvEcecState_OutGoing.ToString() ||
  7968. p.InvStateCode == InvState.InvEcecState_BuildUp.ToString()));
  7969. if (stocklist == null || !stocklist.Any())
  7970. {
  7971. res.ResMsg = reqDto.TaskNum + ResponseStatusCodeEnum.StockNotExist.GetDescription();
  7972. return res;
  7973. }
  7974. var wareHouse = _basewarehouserepository.GetSingle(x => x.Id == stocklist.First().WarehouseId);
  7975. switch (wareHouse.TypeNum)
  7976. {
  7977. case FjLocationType.Storage:
  7978. //验证
  7979. //var stock = _billInvnowrepository.GetSingle(p => p.ContGrpBarCode == task.BarCode);
  7980. //if (stock == null)
  7981. //{
  7982. // res.ResCode = ResponseStatusCodeEnum.StockNotExist.GetHashCode();
  7983. // res.ResMsg = "库存信息不存在";//ResponseStatusCodeEnum.StockNotExist.GetDescription();
  7984. // return res;
  7985. //}
  7986. var cell = _basewarecellrepository.GetSingle(p =>
  7987. p.ContGrpBarCode == task.BarCode && p.WarehouseCode == task.WarehouseCode);
  7988. if (cell == null)
  7989. {
  7990. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  7991. res.ResMsg = task.BarCode + ResponseStatusCodeEnum.Fail.GetDescription() +
  7992. "堆垛机已放货完成,不允许取消";
  7993. return res;
  7994. }
  7995. _db.BeginTran();
  7996. _basewarecellrepository.UpdateSetColumnsTrue(p => new BaseWarecell
  7997. {
  7998. StateNum = FjLocationState.Full,
  7999. EditTime = DateTime.Now
  8000. },
  8001. p => p.ContGrpBarCode == task.BarCode && p.WarehouseCode == task.WarehouseCode &&
  8002. p.Code.Contains(task.AddrFrom) && p.StateNum == FjLocationState.StockOut);
  8003. _billInvnowrepository.UpdateSetColumnsTrue(p => new BillInvnow
  8004. {
  8005. InvStateCode = InvState.InvEcecState_In.ToString(),
  8006. EditTime = DateTime.Now
  8007. }, p => p.ContGrpBarCode == task.BarCode && p.WarehouseId == cell.WarehouseId);
  8008. _db.CommitTran();
  8009. break;
  8010. case FjLocationType.RingLibrary: //环形库的库存信息变更是在SrmPickOutCompleted
  8011. break;
  8012. case FjLocationType.Pingku:
  8013. break;
  8014. default:
  8015. throw new ArgumentOutOfRangeException();
  8016. }
  8017. }
  8018. else
  8019. {
  8020. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  8021. res.ResMsg = ResponseStatusCodeEnum.Fail.GetDescription() + "该任务类型不允许取消";
  8022. return res;
  8023. }
  8024. }
  8025. catch (Exception ex)
  8026. {
  8027. _db.RollbackTran();
  8028. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  8029. res.ResMsg = task.Id + ResponseStatusCodeEnum.Fail.GetDescription();
  8030. _logger.LogInformation("任务取消失败,任务号:" + task.Id + ex.Message);
  8031. return res;
  8032. }
  8033. return res;
  8034. }
  8035. /// <summary>
  8036. /// 查询任务 通过条码查询任务
  8037. /// </summary>
  8038. /// <param name="barCode">条码</param>
  8039. /// <returns></returns>
  8040. public SRes<WCS_TaskOld> GetTaskInfo(FJGetTaskInfoRequest dto)
  8041. {
  8042. var res = new SRes<WCS_TaskOld>();
  8043. res.ResCode = ResponseStatusCodeEnum.Sucess.GetHashCode();
  8044. var task = _wcstaskoldrepository.AsQueryable().With(SqlWith.NoLock).Where(x => x.BarCode == dto.BarCode)
  8045. .SplitTable(x => x.Take(2)).OrderByDescending(x => x.AddTime).First();
  8046. if (task == null)
  8047. {
  8048. res.ResCode = ResponseStatusCodeEnum.Fail.GetHashCode();
  8049. res.ResMsg = "当前条码不存在任务";
  8050. return res;
  8051. }
  8052. res.ResData = task;
  8053. return res;
  8054. }
  8055. /// <summary>
  8056. /// 计算最佳码垛位置
  8057. /// </summary>
  8058. /// <param name="cellInfos"></param>
  8059. /// <returns></returns>
  8060. public string FindBestStackingPosition(List<CellInfo> cellInfos)
  8061. {
  8062. //0表示1-9列任务居多,1表示10-17列任务居多
  8063. var colType = cellInfos.GroupBy(p => p.Col).OrderByDescending(p => p.Count()).First().Key > 9 ? 1 : 0;
  8064. //在cellInfos中获取一个仓库号
  8065. var warehouseCode = cellInfos.First().WarehouseCode;
  8066. return warehouseCode switch
  8067. {
  8068. "1NR" => colType == 0 ? "1666" : "1661",
  8069. "1SR" => colType == 0 ? "1681" : "1676",
  8070. "2NR" => colType == 0 ? "1696" : "1691",
  8071. "2SR" => colType == 0 ? "1711" : "1706",
  8072. "3NR" => colType == 0 ? "1726" : "1721",
  8073. "3SR" => colType == 0 ? "1741" : "1736",
  8074. _ => ""
  8075. };
  8076. //var res = new Tuple<string, string>("","");
  8077. //switch (warehouseCode)
  8078. //{
  8079. // case "1NR":
  8080. // res = colType==0 ? new Tuple<string, string>("1666", "1661") : new Tuple<string, string>("1661", "1666");
  8081. // break;
  8082. // case "1SR":
  8083. // res = colType == 0 ? new Tuple<string, string>("1681", "1679") : new Tuple<string, string>("1679", "1681");
  8084. // break;
  8085. // case "2NR":
  8086. // res = colType == 0 ? new Tuple<string, string>("1696", "1691") : new Tuple<string, string>("1691", "1696");
  8087. // break;
  8088. // case "2SR":
  8089. // res = colType == 0 ? new Tuple<string, string>("1711", "1706") : new Tuple<string, string>("1706", "1711");
  8090. // break;
  8091. // case "3NR":
  8092. // res = colType == 0 ? new Tuple<string, string>("1726", "1721") : new Tuple<string, string>("1721", "1726");
  8093. // break;
  8094. // case "3SR":
  8095. // res = colType == 0 ? new Tuple<string, string>("1741", "1736") : new Tuple<string, string>("1736", "1741");
  8096. // break;
  8097. //}
  8098. //return res;
  8099. }
  8100. }
  8101. public static class TaslEx
  8102. {
  8103. public static void UpdataErrorinfo(this BaseErrorInfo error, RepositoryTask<BaseErrorInfo> db)
  8104. {
  8105. var errorinfoWcs = db.AsQueryable().With(SqlWith.NoLock)
  8106. .Where(v => v.BusName == error.BusName && v.Message == error.Message).First();
  8107. if (errorinfoWcs != null)
  8108. {
  8109. errorinfoWcs.Count += 1;
  8110. db.Context.Updateable(errorinfoWcs).ExecuteCommand();
  8111. }
  8112. else
  8113. {
  8114. db.Context.Insertable(error).ExecuteCommand();
  8115. }
  8116. }
  8117. }
  8118. /// <summary>
  8119. /// 主线分流
  8120. /// </summary>
  8121. public class MainlineDiversion
  8122. {
  8123. /// <summary>
  8124. /// 任务号
  8125. /// </summary>
  8126. public int TaskId { get; set; }
  8127. /// <summary>
  8128. /// 仓库号
  8129. /// </summary>
  8130. public string WarehouseCode { get; set; }
  8131. }
  8132. /// <summary>
  8133. /// 申请空托盘组出库请求体
  8134. /// </summary>
  8135. public class FjApplyEmptyPalletGroupOutStorageRequest : BaseRequest
  8136. {
  8137. /// <summary>
  8138. /// 托盘类型
  8139. /// </summary>
  8140. public FJPalletType FJPalletType { get; set; }
  8141. /// <summary>
  8142. /// 巷道
  8143. /// </summary>
  8144. public int Tunnel { get; set; }
  8145. /// <summary>
  8146. /// 目标位置
  8147. /// </summary>
  8148. public string AddTo { get; set; }
  8149. }
  8150. /// <summary>
  8151. /// 创建WCS出库任务
  8152. /// </summary>
  8153. public class FJCreateStockOutWcsTaskRequest
  8154. {
  8155. /// <summary>
  8156. /// 容器条码
  8157. /// </summary>
  8158. public string ContGrpBarCode { get; set; }
  8159. /// <summary>
  8160. /// 主盘主表ID
  8161. /// </summary>
  8162. public long ContGrpId { get; set; }
  8163. /// <summary>
  8164. /// 仓库编码
  8165. /// </summary>
  8166. public string WarehouseCode { get; set; }
  8167. public decimal Qty { get; set; }
  8168. /// <summary>
  8169. /// 设备编号
  8170. /// </summary>
  8171. public string EquCode { get; set; }
  8172. /// <summary>
  8173. /// 业务类型
  8174. /// </summary>
  8175. public FJTaskBusType BusType { get; set; }
  8176. public int Floor { get; set; }
  8177. public string Tunnel { get; set; }
  8178. public string CellNo { get; set; }
  8179. public short ProdLine { get; set; }
  8180. public string WorkBench { get; set; }
  8181. public int GoodsType { get; set; }
  8182. public string Device { get; set; }
  8183. /// <summary>
  8184. /// 物料号
  8185. /// </summary>
  8186. public string MatCode { get; set; }
  8187. /// <summary>
  8188. /// 码垛托盘类型
  8189. /// </summary>
  8190. public short PalletType { get; set; }
  8191. /// <summary>
  8192. /// 满盘数量
  8193. /// </summary>
  8194. public short FullQty { get; set; }
  8195. public string LastInteractionPoint { get; set; }
  8196. /// <summary>
  8197. /// MES任务号
  8198. /// </summary>
  8199. [SugarColumn(ColumnDescription = "MES任务号")]
  8200. public string MesNo { get; set; }
  8201. /// <summary>
  8202. /// 空盘库
  8203. /// </summary>
  8204. [SugarColumn(ColumnDescription = "空盘库")]
  8205. public string EmptyInventory { get; set; }
  8206. }
  8207. public class FJBingPalletDto : BaseRequest
  8208. {
  8209. /// <summary>
  8210. /// 仓库号
  8211. /// </summary>
  8212. public string WarehouseCode { get; set; }
  8213. /// <summary>
  8214. /// 托盘条码
  8215. /// </summary>
  8216. public string PalletCode { get; set; }
  8217. /// <summary>
  8218. /// 工字轮任务号集合
  8219. /// </summary>
  8220. public List<string> TaskCode { get; set; }
  8221. /// <summary>
  8222. /// 业务类型
  8223. /// </summary>
  8224. public FJTaskBusType BusType { get; set; }
  8225. /// <summary>
  8226. /// 任务申请设备
  8227. /// </summary>
  8228. public string loc { get; set; }
  8229. /// <summary>
  8230. /// 是否异常
  8231. /// </summary>
  8232. public bool IsFail { get; set; }
  8233. /// <summary>
  8234. /// 异常原因
  8235. /// </summary>
  8236. public string FailReason { get; set; }
  8237. /// <summary>
  8238. /// 是否结束
  8239. /// </summary>
  8240. public bool IsFinish { get; set; }
  8241. /// <summary>
  8242. /// 是否为半跺入库
  8243. /// </summary>
  8244. public bool IsItHalf { get; set; }
  8245. }
  8246. public class FJGetTwoPalletDto : BaseRequest
  8247. {
  8248. /// <summary>
  8249. /// 仓库号
  8250. /// </summary>
  8251. public string WarehouseCode { get; set; }
  8252. /// <summary>
  8253. /// 仓库号
  8254. /// </summary>
  8255. public int TaskId { get; set; }
  8256. }
  8257. public class CellInfo
  8258. {
  8259. /// <summary>
  8260. /// 货位ID
  8261. /// </summary>
  8262. public long Id { get; set; }
  8263. /// <summary>
  8264. /// 组盘条码
  8265. /// </summary>
  8266. public string ContGrpBarCode { get; set; }
  8267. /// <summary>
  8268. /// 仓库ID
  8269. /// </summary>
  8270. public long WarehouseId { get; set; }
  8271. /// <summary>
  8272. /// 仓库号
  8273. /// </summary>
  8274. public string WarehouseCode { get; set; }
  8275. /// <summary>
  8276. /// 货位号
  8277. /// </summary>
  8278. public string Code { get; set; }
  8279. /// <summary>
  8280. /// 行
  8281. /// </summary>
  8282. public int Row { get; set; }
  8283. /// <summary>
  8284. /// 列
  8285. /// </summary>
  8286. public int Col { get; set; }
  8287. /// <summary>
  8288. /// 层
  8289. /// </summary>
  8290. public int Layer { get; set; }
  8291. /// <summary>
  8292. /// 深
  8293. /// </summary>
  8294. public int Depth { get; set; }
  8295. /// <summary>
  8296. /// 物料号
  8297. /// </summary>
  8298. public string MatCode { get; set; }
  8299. /// <summary>
  8300. /// 正反面
  8301. /// </summary>
  8302. public int SideNum { get; set; }
  8303. public string CLBarCode { get; set; }
  8304. /// <summary>
  8305. /// 码垛位置
  8306. /// </summary>
  8307. public int XYNo { get; set; }
  8308. /// <summary>
  8309. /// 编辑时间
  8310. /// </summary>
  8311. public DateTime EditTime { get; set; }
  8312. /// <summary>
  8313. /// Bom单号 关联投料单 帘线工序工单号 BillCode
  8314. /// </summary>
  8315. public string BomDocsNo { get; set; }
  8316. }
  8317. public class FjGetSetGrpListRequest
  8318. {
  8319. /// <summary>
  8320. /// 帘线产出物料编码
  8321. /// </summary>
  8322. public string OutMaterialCode { get; set; }
  8323. /// <summary>
  8324. /// 投入物料
  8325. /// </summary>
  8326. public List<string> ListmatInfo { get; set; }
  8327. }
  8328. }
  8329. #endregion 同WCS交互部分