MOrder.Class.php 361 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764676567666767676867696770677167726773677467756776677767786779678067816782678367846785678667876788678967906791679267936794679567966797679867996800680168026803680468056806680768086809681068116812681368146815681668176818681968206821682268236824682568266827682868296830683168326833683468356836683768386839684068416842684368446845684668476848684968506851685268536854685568566857685868596860686168626863686468656866686768686869687068716872687368746875687668776878687968806881688268836884688568866887688868896890689168926893689468956896689768986899690069016902690369046905690669076908690969106911691269136914691569166917691869196920692169226923692469256926692769286929693069316932693369346935693669376938693969406941694269436944694569466947694869496950695169526953695469556956695769586959696069616962696369646965696669676968696969706971697269736974697569766977697869796980698169826983698469856986698769886989699069916992699369946995699669976998699970007001700270037004700570067007700870097010701170127013701470157016701770187019702070217022702370247025702670277028702970307031703270337034703570367037703870397040704170427043704470457046704770487049705070517052705370547055705670577058705970607061706270637064706570667067706870697070707170727073707470757076707770787079708070817082708370847085708670877088708970907091709270937094709570967097709870997100710171027103710471057106710771087109711071117112711371147115711671177118711971207121712271237124712571267127712871297130713171327133713471357136713771387139714071417142714371447145714671477148714971507151715271537154715571567157715871597160716171627163716471657166716771687169717071717172717371747175717671777178717971807181718271837184718571867187718871897190719171927193719471957196719771987199720072017202720372047205720672077208720972107211721272137214721572167217721872197220722172227223722472257226722772287229723072317232723372347235723672377238723972407241724272437244724572467247724872497250725172527253725472557256725772587259726072617262726372647265726672677268726972707271727272737274727572767277727872797280728172827283728472857286728772887289729072917292729372947295729672977298729973007301730273037304730573067307730873097310731173127313731473157316731773187319732073217322732373247325732673277328732973307331733273337334733573367337733873397340734173427343734473457346734773487349735073517352735373547355735673577358735973607361736273637364736573667367736873697370737173727373737473757376737773787379738073817382738373847385738673877388738973907391739273937394739573967397739873997400740174027403740474057406740774087409741074117412741374147415741674177418741974207421742274237424742574267427742874297430743174327433743474357436743774387439744074417442744374447445744674477448744974507451745274537454745574567457745874597460746174627463746474657466746774687469747074717472747374747475747674777478747974807481748274837484748574867487748874897490749174927493749474957496749774987499750075017502750375047505750675077508750975107511751275137514751575167517751875197520752175227523752475257526752775287529753075317532753375347535753675377538753975407541754275437544754575467547754875497550755175527553755475557556755775587559756075617562756375647565756675677568756975707571757275737574757575767577757875797580758175827583758475857586758775887589759075917592759375947595759675977598759976007601760276037604760576067607760876097610761176127613761476157616761776187619762076217622762376247625762676277628762976307631763276337634763576367637763876397640764176427643764476457646764776487649765076517652765376547655765676577658765976607661766276637664766576667667766876697670767176727673767476757676767776787679768076817682768376847685768676877688768976907691769276937694769576967697769876997700770177027703770477057706770777087709771077117712771377147715771677177718771977207721772277237724772577267727772877297730773177327733773477357736773777387739774077417742774377447745774677477748774977507751775277537754775577567757775877597760776177627763776477657766776777687769777077717772777377747775777677777778777977807781778277837784778577867787778877897790779177927793779477957796779777987799780078017802780378047805780678077808780978107811781278137814781578167817781878197820782178227823782478257826782778287829783078317832783378347835783678377838783978407841784278437844784578467847784878497850785178527853785478557856785778587859786078617862786378647865786678677868786978707871787278737874787578767877787878797880788178827883788478857886788778887889789078917892789378947895789678977898789979007901790279037904790579067907790879097910791179127913791479157916791779187919792079217922792379247925
  1. <?php
  2. /**
  3. * 订单数据模型
  4. * Created by PhpStorm.
  5. * User: XiaoMing
  6. * Date: 2019/10/31
  7. * Time: 15:53
  8. */
  9. namespace JinDouYun\Model\Order;
  10. use JinDouYun\Controller\System\Driver;
  11. use JinDouYun\Model\System\MDriver;
  12. use Mall\Framework\Core\StatusCode;
  13. use Mall\Framework\Core\ErrorCode;
  14. use Mall\Framework\Core\ResultWrapper;
  15. use Mall\Framework\Factory;
  16. use JinDouYun\Cache\ActivityLimitCache;
  17. use JinDouYun\Cache\CustomerCache;
  18. use JinDouYun\Cache\OverviewCache;
  19. use JinDouYun\Cache\SystemCache;
  20. use JinDouYun\Cache\Stock;
  21. use JinDouYun\Cache\EnterpriseCache;
  22. use JinDouYun\Controller\Common\CloudPrint;
  23. use JinDouYun\Controller\Common\Logger;
  24. use JinDouYun\Dao\Order\DOrderReceive;
  25. use JinDouYun\Dao\Order\DOrderIndex;
  26. use JinDouYun\Dao\Order\DOrder;
  27. use JinDouYun\Dao\Order\DOrderGoods;
  28. use JinDouYun\Dao\Order\DOrderStatistics;
  29. use JinDouYun\Dao\Cashier\DCashierCustomerPrice;
  30. use JinDouYun\Dao\Customer\DCustomer;
  31. use JinDouYun\Dao\Department\DStaff;
  32. use JinDouYun\Dao\System\DCustomerSource;
  33. use JinDouYun\Dao\System\DExpressCode;
  34. use JinDouYun\Dao\UserCenter\DUserCenter;
  35. use JinDouYun\Dao\Finance\DReceivedIndex;
  36. use JinDouYun\Model\System\MBasicSetup;
  37. use JinDouYun\Model\Finance\MCustomerBalance;
  38. use JinDouYun\Model\System\MPaymentSetting;
  39. use JinDouYun\Model\Market\MUserCoupon;
  40. use JinDouYun\Model\MBaseModel;
  41. use JinDouYun\Model\Log\MOrderLog;
  42. use JinDouYun\Model\GoodsManage\MSku;
  43. use JinDouYun\Model\Shop\MShop;
  44. use JinDouYun\Model\Customer\MShippingAddress;
  45. use JinDouYun\Model\Cart\MCart;
  46. use JinDouYun\Model\Stock\MInventory;
  47. use JinDouYun\Model\Stock\MInventoryOut;
  48. use JinDouYun\Model\Stock\MWarehouse;
  49. use JinDouYun\Model\Customer\MCustomer;
  50. use JinDouYun\Model\Goods\MGoods;
  51. use JinDouYun\Model\Finance\MAccount;
  52. use JinDouYun\Model\Finance\MReceived;
  53. use JinDouYun\Model\SysAreaChina\MSysAreaChina;
  54. use JinDouYun\Model\Customer\MMemberBalanceDetail;
  55. use JinDouYun\Model\Cashier\MCashier;
  56. use JinDouYun\Model\Cashier\MCashierCart;
  57. use JinDouYun\Model\Department\MStaff;
  58. use JinDouYun\Model\Finance\MMerchantFlow;
  59. use JinDouYun\Model\Finance\MReceive;
  60. use JinDouYun\Model\Finance\MRefund;
  61. use JinDouYun\Model\System\MDeliverySetting;
  62. use JinDouYun\Model\System\MPrintNum;
  63. use JinDouYun\Model\System\MProcessSetting;
  64. use JinDouYun\Model\Order\MPay;
  65. use JinDouYun\Model\GoodsManage\MGoodsBasic;
  66. use JinDouYun\Model\Merchant\MMerchantSettlement;
  67. use JinDouYun\Model\System\MSystemPushMessage;
  68. use Util\KDNiao\KDNiaoQuery;
  69. use Util\KuaiDi100\Query;
  70. use Util\WeiXin\Pay;
  71. use Util\AliPay\Pay as aliPay;
  72. use Util\ByteDance\Pay as bytePay;
  73. //use Util\Common\PartnerTools;
  74. class MOrder extends MBaseModel
  75. {
  76. /**
  77. * @var DOrder
  78. */
  79. private $objDOrder;
  80. /**
  81. * @var int 用户id
  82. */
  83. private $onlineUserId;
  84. /**
  85. * @var int 企业id
  86. */
  87. private $onlineEnterpriseId;
  88. /**
  89. * @var int 单表数据量
  90. */
  91. private $cutTable = 500000;
  92. /**
  93. * @var DOrderIndex
  94. */
  95. private $objDOrderIndex;
  96. /**
  97. * @var DOrderGoods
  98. */
  99. private $objDOrderGoods;
  100. /**
  101. * @var DOrderStatistics
  102. */
  103. private $objDOrderStatistics;
  104. /**
  105. * @var bool
  106. */
  107. private $isFront;//是否是前台调用此Model 前台=>true
  108. /**
  109. * @var OverviewCache
  110. */
  111. private $objOverviewCache;
  112. /**
  113. * @var string
  114. */
  115. private $orderStatisticsTableName = 'order_statistics';
  116. /**
  117. * @var MAccount
  118. */
  119. private $objMAccount;
  120. /**
  121. * @var MReceived
  122. */
  123. private $objMReceived;
  124. /**
  125. * @var ActivityLimitCache
  126. */
  127. private $objActivityLimitCache;
  128. /**
  129. * @var SaleOrder 销售单
  130. */
  131. private $objSaleOrder;
  132. /**
  133. * @var bool 销售单是否打印小票
  134. */
  135. private $isEnablePrint = false;
  136. /**
  137. * @var DOrderReceive
  138. */
  139. private $objDOrderReceive;
  140. /**
  141. * @var DCustomer
  142. */
  143. private $objDCustomer;
  144. /**
  145. * @var int
  146. */
  147. private $loginUserCenterId;
  148. /**
  149. * @var array
  150. */
  151. private $expressMap = [
  152. 'express_hundred' => 'kuaidi100',
  153. 'express_bird' => 'kdniao'
  154. ];
  155. /**
  156. * @var bool
  157. */
  158. private $isCashier;
  159. /**
  160. * @var MProcessSetting
  161. */
  162. private $objMProcessSetting;
  163. use TStdOrder;
  164. /**
  165. * MOrder constructor.
  166. * @param $onlineUserId
  167. * @param $onlineEnterpriseId
  168. * @param null $loginUserCenterId
  169. * @param bool $isFront
  170. * @throws \Exception
  171. */
  172. public function __construct($onlineUserId, $onlineEnterpriseId, $loginUserCenterId = null, $isFront = false, $isCashier = false)
  173. {
  174. $this->isCashier = $isCashier;
  175. $this->isFront = $isFront;
  176. $this->onlineUserId = $onlineUserId;
  177. $this->onlineEnterpriseId = $onlineEnterpriseId;
  178. $this->loginUserCenterId = $loginUserCenterId;
  179. parent::__construct($this->onlineEnterpriseId, $loginUserCenterId);
  180. $this->objDOrder = new DOrder('default');
  181. self::orderSubTable($onlineEnterpriseId, $onlineUserId);
  182. $this->objDOrderIndex = new DOrderIndex();
  183. $this->objDOrderGoods = new DOrderGoods('default');
  184. $this->objDOrderReceive = new DOrderReceive();
  185. $this->objDOrderStatistics = new DOrderStatistics('default');
  186. $this->objMAccount = new MAccount($onlineEnterpriseId, $onlineUserId);
  187. $this->objMReceived = new MReceived($onlineEnterpriseId, $onlineUserId);
  188. $this->objDOrderIndex->setTable('qianniao_order_index_' . $this->onlineEnterpriseId);
  189. $this->objDOrderStatistics->setTable($this->objDOrderStatistics->get_Table() . '_' . $this->onlineEnterpriseId);
  190. $this->objDOrder->setSearchIndex('order_search')->setType('order');
  191. $this->objActivityLimitCache = new ActivityLimitCache($this->onlineEnterpriseId);
  192. $this->objOverviewCache = new OverviewCache();
  193. $this->objSaleOrder = new SaleOrder();
  194. $this->objDCustomer = new DCustomer();
  195. $this->objDCustomer->setTable('qianniao_customer_' . $this->onlineEnterpriseId);
  196. $this->objMProcessSetting = new MProcessSetting($this->onlineEnterpriseId);
  197. }
  198. /**
  199. * 订单分表 分表规则:企业id_(客户/200000)
  200. * @param $enterpriseId (企业id)
  201. * @param $userId (用户id)
  202. * @throws \Exception
  203. */
  204. public function orderSubTable($enterpriseId, $userId)
  205. {
  206. $tableName = $this->objDOrder->getTableName('qianniao_order_' . $enterpriseId, $userId, $this->cutTable);
  207. self::existsTable($tableName);
  208. $this->objDOrder->setTable($tableName);
  209. }
  210. /**
  211. * 获取订单表表名
  212. */
  213. public function getOrderTable($enterpriseId, $userId){
  214. return $this->objDOrder->getTableName('qianniao_order_' . $enterpriseId, $userId, $this->cutTable);
  215. }
  216. /**
  217. * 统计订单信息
  218. *
  219. * @param $data
  220. * @param $className
  221. */
  222. private static function noticeStatistics($data, $className)
  223. {
  224. $i = 1;
  225. do {
  226. $postData = [
  227. 'topicName' => 'MyJob',
  228. 'topicClass' => "Jobs\Model\MTopic\Order\\" . $className,
  229. 'topicMethon' => 'push',
  230. 'topicMethonParams' => [
  231. 'userCenterId' => $data['userCenterId'],
  232. 'enterpriseId' => $data['enterpriseId'],
  233. 'customerId' => $data['customerId'],
  234. 'no' => $data['no'],
  235. 'noticeType' => $data['noticeType'],
  236. ],
  237. ];
  238. $url = QIANNIAO_QUEUE . '/CAddJob/add';
  239. $result = request($url, $postData);
  240. $i++;
  241. } while ($result['httpcode'] != 200 && $i <= 3);
  242. }
  243. /**
  244. * 分表后缀+月日+订单id
  245. * @param $orderId
  246. * @return string
  247. */
  248. private function createVerifyCode($orderId)
  249. {
  250. $fix = ceil($this->onlineUserId / $this->cutTable);
  251. return $fix . '-' . date('nj') . '-' . $orderId;
  252. }
  253. /**
  254. * Doc: (des="")
  255. * User: XMing
  256. * Date: 2020/12/25
  257. * Time: 2:11 下午
  258. * @param $data
  259. * @return ResultWrapper
  260. */
  261. public function checkLimit($data)
  262. {
  263. foreach ($data as $goods) {
  264. if (isset($goods['activityId'])) {
  265. //获取活动商品剩余数量
  266. $surplusNum = $this->objActivityLimitCache->getLen($goods['activityId'], $goods['goodsId'], $goods['skuId']);
  267. if ($surplusNum < $goods['buyNum']) {
  268. return ResultWrapper::fail($goods['title'] . '活动剩余数量不足', ErrorCode::$paramError);
  269. }
  270. }
  271. }
  272. return ResultWrapper::success($data);
  273. }
  274. /**
  275. * Doc: (des="订单编辑")
  276. * User: XMing
  277. * Date: 2020/11/5
  278. * Time: 10:07 上午
  279. * @param array $params
  280. * @param $id
  281. * @return ResultWrapper
  282. * @throws \Exception
  283. */
  284. public function edit(array $params, $id): ResultWrapper
  285. {
  286. $orderIndex = $this->objDOrderIndex->get($id);
  287. if ($orderIndex === false) {
  288. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  289. }
  290. if (empty($orderIndex)) {
  291. return ResultWrapper::fail('未获取到指定订单', ErrorCode::$paramError);
  292. }
  293. /*if ($orderIndex['payStatus'] == StatusCode::$standard) {
  294. return ResultWrapper::fail('订单已支付,不能编辑', ErrorCode::$paramError);
  295. }
  296. if ($orderIndex['auditStatus'] != StatusCode::$auditStatus['auditing']) {
  297. return ResultWrapper::fail('订单已审核不能编辑', ErrorCode::$paramError);
  298. }*/
  299. if (
  300. in_array($orderIndex['orderStatus'], [StatusCode::$orderStatus['waitReceive'], StatusCode::$orderStatus['finish'], StatusCode::$orderStatus['close']])
  301. ) {
  302. return ResultWrapper::fail('此订单不能编辑', ErrorCode::$paramError);
  303. }
  304. $fix = ceil((empty($params['userCenterId']) ? 1 : $params['userCenterId']) / $this->cutTable);
  305. $this->objDOrderReceive->setTable('qianniao_order_receive_' . $this->onlineEnterpriseId . '_' . $fix);
  306. $this->objDOrderGoods->setTable('qianniao_order_goods_' . $this->onlineEnterpriseId . '_' . $fix);
  307. $objMCustomerBalance = new MCustomerBalance($this->onlineEnterpriseId, $this->onlineUserId);
  308. $objMOrderGoods = new MOrderGoods($this->onlineUserId, $this->onlineEnterpriseId);
  309. $customerResult = self::getCustomerInfoByUserCenterId($params['userCenterId']);
  310. if (!$customerResult->isSuccess()) {
  311. return ResultWrapper::fail($customerResult->getData(), $customerResult->getErrorCode());
  312. }
  313. $customer = $customerResult->getData();
  314. isset($customer['customerType']) && $params['customerType'] = $customer['customerType'];
  315. isset($customer['salesManId']) && $params['salesManId'] = $customer['salesManId'];
  316. isset($customer['salesManName']) && $params['salesManName'] = $customer['salesManName'];
  317. $params['customerOwe'] = $objMCustomerBalance->getCustomerBalance($customer['id']);//获取客户当前欠款
  318. $address = [];
  319. $selfRule = [];
  320. switch ($params['deliveryType']) {
  321. case StatusCode::$deliveryType['goodsDelivery']:
  322. $addressResult = self::getAddressInfo($params['addressId']);
  323. if (!$addressResult->isSuccess()) {
  324. return ResultWrapper::fail($addressResult->getData(), $addressResult->getErrorCode());
  325. }
  326. $address = $addressResult->getData();
  327. break;
  328. case StatusCode::$deliveryType['selfMention']:
  329. $selfRuleResult = self::getSelfRuleData($params['selfRuleId']);
  330. if (!$selfRuleResult->isSuccess()) {
  331. return ResultWrapper::fail($selfRuleResult->getData(), $selfRuleResult->getErrorCode());
  332. }
  333. $selfRule = $selfRuleResult->getData();
  334. break;
  335. }
  336. $status = $this->objDOrder->beginTransaction();
  337. $updateIndexResult = $this->objDOrderIndex->update(
  338. [
  339. 'userCenterId' => isset($params['userCenterId']) ? $params['userCenterId'] : 0,
  340. 'deliveryType' => isset($params['deliveryType']) ? $params['deliveryType'] : 0,
  341. 'customerId' => isset($params['customerId']) ? $params['customerId'] : 0,
  342. 'deliveryNo' => isset($params['deliveryNo']) ? $params['deliveryNo'] : '',
  343. 'expressName' => isset($params['expressName']) ? $params['expressName'] : '',
  344. 'expressId' => isset($params['expressId']) ? $params['expressId'] : 0,
  345. 'selfRuleId' => isset($params['selfRuleId']) ? $params['selfRuleId'] : 0,
  346. 'updateTime' => time(),
  347. ],
  348. $id
  349. );
  350. if ($updateIndexResult === false) {
  351. $this->objDOrder->rollBack();
  352. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  353. }
  354. $updateOrder = [
  355. 'customerName' => isset($params['customerName']) ? $params['customerName'] : '',
  356. 'customerId' => isset($params['customerId']) ? $params['customerId'] : 0,
  357. 'deliveryType' => isset($params['deliveryType']) ? $params['deliveryType'] : 0,
  358. 'remark' => isset($params['remark']) ? $params['remark'] : '',
  359. 'salesManId' => isset($params['salesManId']) ? $params['salesManId'] : 0,
  360. 'salesManName' => isset($params['salesManName']) ? $params['salesManName'] : '',
  361. 'customerType' => isset($params['customerType']) ? $params['customerType'] : 0,
  362. 'userCenterId' => isset($params['userCenterId']) ? $params['userCenterId'] : 0,
  363. 'customerOwe' => isset($params['customerOwe']) ? $params['customerOwe'] : 0,
  364. 'preferential' => isset($params['preferential']) ? $params['preferential'] : 0,
  365. 'vipDiscount' => isset($params['vipDiscount']) ? $params['vipDiscount'] : 0,
  366. 'expressMoney' => isset($params['expressMoney']) ? $params['expressMoney'] : 0,
  367. 'expressName' => isset($params['expressName']) ? $params['expressName'] : '',
  368. 'expressId' => isset($params['expressId']) ? $params['expressId'] : 0,
  369. 'deliveryNo' => isset($params['deliveryNo']) ? $params['deliveryNo'] : '',
  370. 'selfRuleId' => isset($params['selfRuleId']) ? $params['selfRuleId'] : 0,
  371. 'originPayAmount' => isset($params['originPayAmount']) ? $params['originPayAmount'] : 0,
  372. 'payAmount' => isset($params['payMoney']) ? $params['payMoney'] : 0,
  373. 'totalMoney' => isset($params['totalMoney']) ? $params['totalMoney'] : 0,
  374. 'receivedMoney' => isset($params['receivedMoney']) ? $params['receivedMoney'] : 0,
  375. "accountList" => isset($params['accountList']) ? json_encode($params['accountList']) : null,
  376. "currentAccountName" => isset($params['currentAccountName']) ? $params['currentAccountName'] : '',
  377. "totalReduceMoney" => isset($params['totalReduceMoney']) ? $params['totalReduceMoney'] : 0,
  378. "selfRuleData" => empty($selfRule) ? null : json_encode($selfRule),
  379. "updateTime" => time(),
  380. ];
  381. $updateOrderResult = $this->objDOrder->update($updateOrder, $id);
  382. if ($updateOrderResult === false) {
  383. $this->objDOrder->rollBack();
  384. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  385. }
  386. if (!empty($address)) {
  387. $updateReceiveResult = $this->objDOrderReceive->update([
  388. 'customerId' => $address['customerId'],
  389. 'customerCode' => $address['customerCode'],
  390. 'realName' => $address['name'],
  391. 'mobile' => $address['mobile'],
  392. 'address' => $address['address'],
  393. 'provinceCode' => $address['provinceCode'],
  394. 'cityCode' => $address['cityCode'],
  395. 'districtCode' => $address['districtCode'],
  396. 'updateTime' => time()
  397. ], ['orderId' => $id]);
  398. if ($updateReceiveResult === false) {
  399. $this->objDOrder->rollBack();
  400. return ResultWrapper::fail($this->objDOrderReceive->error(), ErrorCode::$dberror);
  401. }
  402. }
  403. //编辑商品
  404. if ($orderIndex['payStatus'] != StatusCode::$standard || $orderIndex['auditStatus'] != StatusCode::$auditStatus['auditPass']) {
  405. //解锁库存
  406. $objMInventory = new MInventory($this->onlineEnterpriseId, $this->onlineUserId);
  407. $unlockResult = $objMInventory->unlockInventory([$id], StatusCode::$orderType['saleOrder'], $orderIndex['createTime']);
  408. if (!$unlockResult->isSuccess()) {
  409. $this->objDOrder->rollBack();
  410. Logger::logs(E_USER_ERROR, '编辑订单,库存解锁失败', __CLASS__, __LINE__, $unlockResult->getData());
  411. return ResultWrapper::fail($unlockResult->getData(), ErrorCode::$dberror);
  412. }
  413. $editResult = $objMOrderGoods->edit($params, $id,$orderIndex['no']);
  414. if (!$editResult->isSuccess()) {
  415. $this->objDOrder->rollBack();
  416. return ResultWrapper::fail($editResult->getData(), $editResult->getErrorCode());
  417. }
  418. }
  419. /*
  420. //跟新es
  421. $_id = self::createEsDocumentId($id);
  422. $this->objDOrder->esupdateTypeFieldVaule($updateOrder, $_id);*/
  423. if ($status){
  424. $this->objDOrder->commit();
  425. }
  426. return ResultWrapper::success(true);
  427. }
  428. /**
  429. * Doc: (des="代客下单,销售订单")
  430. * User: XMing
  431. * Date: 2020/12/19
  432. * Time: 2:38 下午
  433. * @param $params
  434. * @return ResultWrapper
  435. * @throws \Exception
  436. */
  437. public function add($params): ResultWrapper
  438. {
  439. $params['orderType'] = getArrayItem($params,'orderType',StatusCode::$orderType['saleOrder']);
  440. $goodsNameStr = self::createGoodsName($params['lists']);
  441. $commonParamsResult = self::formatCommonParams($params); // 格式化订单关联数据
  442. if (!$commonParamsResult->isSuccess()){
  443. return ResultWrapper::fail($commonParamsResult->getData(),$commonParamsResult->getErrorCode());
  444. }
  445. $params = $commonParamsResult->getData();
  446. $lists = $params['lists'];
  447. unset($params['lists']);
  448. $groupShopDataResult = self::buildGoodsByShop($lists,$params);
  449. if (!$groupShopDataResult->isSuccess()){
  450. return ResultWrapper::fail($groupShopDataResult->getData(),$groupShopDataResult->getErrorCode());
  451. }
  452. $shopGoodsData = $groupShopDataResult->getData();
  453. //锁定库存 查询商铺对应的仓库
  454. $objMShop = new MShop($this->onlineEnterpriseId, $this->onlineUserId);
  455. $modelResult = $objMShop->getShopDataByShopIds(array_column($shopGoodsData, 'shopId')); // 根据shopIds获取商铺数据
  456. if (!$modelResult->isSuccess()) {
  457. return ResultWrapper::fail($modelResult->getData(), $modelResult->getErrorCode());
  458. }
  459. $shopMap = $modelResult->getData();
  460. $buildGroupResult = self::groupSupplierOrderData($shopGoodsData,$params,$shopMap); // 将商品数据按照指定的字段分组
  461. if (!$buildGroupResult->isSuccess()){
  462. return ResultWrapper::fail($buildGroupResult->getData(),$buildGroupResult->getErrorCode());
  463. }
  464. $buildGroup = $buildGroupResult->getData();
  465. $insertOrderResult = self::insertOrder($buildGroup,$params);
  466. if (!$insertOrderResult->isSuccess()){
  467. return ResultWrapper::fail($insertOrderResult->getData(),$insertOrderResult->getErrorCode());
  468. }
  469. $orderIds = $insertOrderResult->getData();
  470. /* 拣货信息 */
  471. /* 功能临时屏蔽
  472. $orderNum = 0;
  473. $notOutNum = 0;
  474. $notPickingNum = 0;
  475. $otherNum = 0;
  476. foreach ($lists as $listKey => $listValue){
  477. $notOutNum = bcadd($notOutNum,$listValue['buyNum'],4);
  478. $notPickingNum = bcadd($notPickingNum,$listValue['buyNum'],4);
  479. $otherNum = bcadd($otherNum,$listValue['otherNum']);
  480. $orderNum = bcadd($orderNum,$listValue['buyNum']);
  481. }
  482. //组装订单拣货信息
  483. $orderPickingDate = [
  484. 'orderId' => $orderIds[0],
  485. 'sort' => 0,
  486. 'outNum' => 0,
  487. 'notOutNum' => $notOutNum,
  488. 'orderNum' => $orderNum,
  489. 'notPickingNum' => $notPickingNum,
  490. 'pickingNum' => 0,
  491. 'outTime' => 0,
  492. 'otherNum' => $otherNum,
  493. 'mangeId' => getArrayItem($params,'operatorId',0),
  494. 'mangeName' => getArrayItem($params,'operatorName',''),
  495. ];
  496. $objOrderPicking = new MOrderPicking($this->onlineUserId,$this->onlineEnterpriseId);
  497. $orderPickingResult = $objOrderPicking->addOrderPick($orderPickingDate); //临时注释
  498. if(!$orderPickingResult->isSuccess()){
  499. return ResultWrapper::fail($orderPickingResult->getData(), $orderPickingResult->getErrorCode());
  500. }*/
  501. parent::sendMessage($this->onlineEnterpriseId,'NewOrder');
  502. $params['orderType'] == StatusCode::$orderType['saleOrder'] && self::runProcessNextAudit($orderIds);
  503. return ResultWrapper::success($orderIds);
  504. }
  505. /**
  506. * Doc: (des="商品名称")
  507. * User: XMing
  508. * Date: 2020/11/18
  509. * Time: 3:27 下午
  510. * @param $goods
  511. * @return string
  512. */
  513. public static function createGoodsName($goods): string
  514. {
  515. $str = '';
  516. foreach ($goods as $val){
  517. if (isset($val['goodsName']) && !empty($val['goodsName'])){
  518. $str .= (string)$val['goodsName'].' ';
  519. }
  520. }
  521. return $str;
  522. }
  523. /**
  524. * Doc: (des="执行订单的下一步操作")
  525. * User: XMing
  526. * Date: 2020/11/6
  527. * Time: 5:03 下午
  528. * @param array $ids 订单ids
  529. * @return ResultWrapper
  530. * @throws \Exception
  531. */
  532. private function runProcessNextAudit(array $ids): ResultWrapper
  533. {
  534. Logger::logs(E_USER_ERROR,'订单自动审核',__CLASS__,__LINE__,$ids);
  535. if (empty($ids)){
  536. return ResultWrapper::success(true);
  537. }
  538. $setResult = $this->objMProcessSetting->getProcessSettingByType(StatusCode::$processType['sales'],'audit');
  539. if (!$setResult->isSuccess()){
  540. Logger::logs(E_USER_ERROR,'获取流程配置出错',__CLASS__,__LINE__,$setResult->getData());
  541. return ResultWrapper::fail($setResult->getData(),$setResult->getErrorCode());
  542. }
  543. $set = $setResult->getData();
  544. if (empty($set)){
  545. Logger::logs(E_USER_ERROR,'配置为空',__CLASS__,__LINE__,'');
  546. return ResultWrapper::success(true);
  547. }
  548. if (isset($set['enableStatus']) && $set['enableStatus'] == StatusCode::$standard){
  549. Logger::logs(E_USER_ERROR,'配置',__CLASS__,__LINE__,$set);
  550. return ResultWrapper::success(true);
  551. }
  552. foreach ($ids as $id){
  553. $params = [
  554. 'id' => $id,
  555. 'audit' => '自动审核',
  556. 'auditId' => $this->onlineUserId,
  557. 'auditStatus' => StatusCode::$auditStatus['auditPass'],
  558. ];
  559. $auditResult = $this->updateAuditStatus($params);
  560. if (!$auditResult->isSuccess()){
  561. Logger::logs(E_USER_ERROR,'自动审核订单出错',__CLASS__,__LINE__,$auditResult->getData());
  562. return ResultWrapper::fail($auditResult->getData(),$auditResult->getErrorCode());
  563. }
  564. }
  565. Logger::logs(E_USER_ERROR,'自动审核订单成功',__CLASS__,__LINE__,$ids);
  566. return ResultWrapper::success(true);
  567. }
  568. /**
  569. * Doc: (des="根据客户id获取客户信息")
  570. * User: XMing
  571. * Date: 2020/11/3
  572. * Time: 2:11 下午
  573. * @param int $id
  574. * @return ResultWrapper
  575. * @throws \Exception
  576. */
  577. private function getCustomerInfoByUserCenterId(int $id): ResultWrapper
  578. {
  579. $objMCustomer = new MCustomer($this->onlineEnterpriseId, $this->onlineUserId);
  580. //获取客户信息
  581. $customerData = $objMCustomer->getCustomerInfoByUserCenterId($id);
  582. if (!$customerData->isSuccess()) {
  583. return ResultWrapper::fail($customerData->getData(), $customerData->getErrorCode());
  584. }
  585. $customerData = $customerData->getData();
  586. if (empty($customerData)) {
  587. return ResultWrapper::fail('未获取到客户信息', ErrorCode::$paramError);
  588. }
  589. return ResultWrapper::success($customerData);
  590. }
  591. /**
  592. * Doc: (des="根据id查询自提点信息")
  593. * User: XMing
  594. * Date: 2020/11/3
  595. * Time: 11:49 上午
  596. * @param int $id
  597. * @return ResultWrapper
  598. * @throws \Exception
  599. */
  600. private function getSelfRuleData(int $id): ResultWrapper
  601. {
  602. $objMDeliverySetting = new MDeliverySetting($this->onlineUserId, $this->onlineEnterpriseId);
  603. $selfRuleDataResult = $objMDeliverySetting->getSelfRuleInfo($id);
  604. if (!$selfRuleDataResult->isSuccess()) {
  605. return ResultWrapper::fail($selfRuleDataResult->getData(), $selfRuleDataResult->getErrorCode());
  606. }
  607. $selfRuleData = $selfRuleDataResult->getData();
  608. $selfRuleData = isset($selfRuleData['setData']) ? $selfRuleData['setData'] : [];
  609. return ResultWrapper::success($selfRuleData);
  610. }
  611. /**
  612. * Doc: (des="根据id获取收货地址信息")
  613. * User: XMing
  614. * Date: 2020/11/3
  615. * Time: 11:52 上午
  616. * @param int $id
  617. * @return ResultWrapper
  618. */
  619. private function getAddressInfo($id): ResultWrapper
  620. {
  621. $objMShippingAddress = new MShippingAddress($this->onlineEnterpriseId);
  622. $result = $objMShippingAddress->getShippingAddressInfo($id);
  623. if (!$result->isSuccess()) {
  624. return ResultWrapper::fail($result->getData(), ErrorCode::$dberror);
  625. }
  626. $addressData = $result->getData();
  627. if (empty($addressData)) {
  628. return ResultWrapper::fail('未获取到收货地址信息', ErrorCode::$dberror);
  629. }
  630. return ResultWrapper::success($addressData);
  631. }
  632. /**
  633. * Doc: (des="小程序下单")
  634. * User: XMing
  635. * Date: 2020/12/18
  636. * Time: 11:39 上午
  637. * @param $params
  638. * @param $ip
  639. * @param $token
  640. * @param $auth
  641. * @return ResultWrapper
  642. * @throws \Exception
  643. */
  644. public function addOrder($params, $ip, $token, $auth): ResultWrapper
  645. {
  646. $goodsData = getArrayItem($params,'goodsData',[]);
  647. unset($params['goodsData']);
  648. $shopGoodsData = getArrayItem($goodsData,'goodsData',[]);//商品数据
  649. unset($goodsData['goodsData']);
  650. $common = array_merge($params,$goodsData);
  651. $params = $common;//公共数据
  652. unset($common);
  653. $params['token'] = $token;
  654. $params['auth'] = $auth;
  655. $params['orderType'] = StatusCode::$orderType['saleOrder'];
  656. $params['userCenterId'] = $this->onlineUserId;
  657. $params['orderStatus'] = StatusCode::$orderStatus['waitPay'];
  658. // 货到付款和银行打款 修改订单状态为待发货
  659. if( in_array($params['payType'],[StatusCode::$payType['cashPay']]) ){
  660. $params['orderStatus'] = StatusCode::$orderStatus['waitDelivery'];
  661. }
  662. $tmpOuterTradeNo = 'tmp' . createOrderSn($params['source'], StatusCode::$orderType['saleOrder'], $this->onlineUserId);
  663. $params['outerTradeNo'] = $tmpOuterTradeNo;
  664. // 格式化订单关联数据
  665. $commonParamsResult = self::formatCommonParams($params);
  666. if (!$commonParamsResult->isSuccess()){
  667. return ResultWrapper::fail($commonParamsResult->getData(),$commonParamsResult->getErrorCode());
  668. }
  669. $params = $commonParamsResult->getData();
  670. //查询商铺对应的仓库
  671. $objMShop = new MShop($this->onlineEnterpriseId, $this->onlineUserId);
  672. $modelResult = $objMShop->getShopDataByShopIds(array_column($shopGoodsData, 'shopId'));
  673. if (!$modelResult->isSuccess()) {
  674. return ResultWrapper::fail($modelResult->getData(), $modelResult->getErrorCode());
  675. }
  676. $shopMap = $modelResult->getData();
  677. // 将商品数据按照指定的字段分组
  678. $buildGroupResult = self::groupSupplierOrderData($shopGoodsData,$params,$shopMap);
  679. if (!$buildGroupResult->isSuccess()){
  680. return ResultWrapper::fail($buildGroupResult->getData(),$buildGroupResult->getErrorCode());
  681. }
  682. $buildGroup = $buildGroupResult->getData();
  683. //mysql写入数据
  684. $insertOrderResult = self::insertOrder($buildGroup,$params);
  685. if (!$insertOrderResult->isSuccess()){
  686. return ResultWrapper::fail($insertOrderResult->getData(),$insertOrderResult->getErrorCode());
  687. }
  688. $orderIds = $insertOrderResult->getData();
  689. // 处理支付
  690. $payResult = self::toPay($tmpOuterTradeNo,$params,$orderIds,$ip);
  691. var_dump($payResult);
  692. if (!$payResult->isSuccess()){
  693. return ResultWrapper::fail($payResult->getData(),$payResult->getErrorCode());
  694. }
  695. // 发送新订单提醒
  696. parent::sendMessage($this->onlineEnterpriseId,'NewOrder');
  697. $params['orderType'] == StatusCode::$orderType['saleOrder'] && self::runProcessNextAudit($orderIds);
  698. $customerData = $this->objDCustomer->get($buildGroup['orderIndex'][0]['customerId']);
  699. if ($customerData === false) {
  700. return ResultWrapper::fail($this->objDCustomer->error(), ErrorCode::$dberror);
  701. }
  702. if(isset($customerData['openId']) && !empty($customerData['openId'])){
  703. $orderData = $this->objDOrder->get($orderIds);
  704. if($orderData === false){
  705. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  706. }
  707. if( empty($orderData) ){
  708. return ResultWrapper::fail('查找不到该订单数据', ErrorCode::$contentNotExists);
  709. }
  710. foreach($buildGroup['order'] as $key => $value){
  711. // 发送小程序订阅消息
  712. $sendMessageData = [
  713. 'character_string6' => [ 'value' => StatusCode::$noPrefix[1].'-'.$key ], // 订单编号
  714. 'amount10' => [ 'value' => $value['payAmount'] ], // 订单金额
  715. 'thing15' => [ 'value' => $buildGroup['orderReceive'][$key]['realName'] ], // 收货人姓名
  716. 'phone_number16' => [ 'value' => $buildGroup['orderReceive'][$key]['mobile'] ], // 收货人电话
  717. 'phrase19' => [ 'value' => $orderData['payStatus'] == StatusCode::$delete ? '待支付':'已支付'], // 支付状态
  718. ];
  719. $objMSystemPushMessage = new MSystemPushMessage($this->onlineUserId, $this->onlineEnterpriseId);
  720. $result = $objMSystemPushMessage->sendWeiXinPushMessage(1, $customerData['openId'], $sendMessageData, '/pagesT/order/orderDetail?id='.array_pop($orderIds));
  721. if(!$result->isSuccess()){
  722. file_put_contents('/www/wwwroot/logs/api.junhailan.com/phperstar.log',date('Y-m-d H:i:s').'bb'.var_export($result->getData(),true).PHP_EOL,FILE_APPEND);
  723. }
  724. }
  725. }
  726. return ResultWrapper::success($payResult->getData());
  727. }
  728. /**
  729. * Doc: (des="支付")
  730. * User: XMing
  731. * Date: 2020/12/18
  732. * Time: 4:17 下午
  733. * @param string $tmpOuterTradeNo 临时订单号
  734. * @param array $params 公共参数
  735. * @param array $orderIds 所有订单号
  736. * @param $ip
  737. * @return ResultWrapper
  738. * @throws \Exception
  739. */
  740. public function toPay($tmpOuterTradeNo,$params,$orderIds,$ip): ResultWrapper
  741. {
  742. // 获取支付金额
  743. $payMoney = getArrayItem($params,'payMoney',0);
  744. if (empty($payMoney)){
  745. return ResultWrapper::fail('支付金额异常',ErrorCode::$paramError);
  746. }
  747. // 处理支付方式
  748. $payType = explode(',', $params['payType']);
  749. rsort($payType);
  750. $objSystemCache = new SystemCache();
  751. // 后台代客下单/货到付款/银行打款不需要返回支付配置
  752. if ( $params['source'] == StatusCode::$source['manage'] || in_array(StatusCode::$payType['cashPay'], $payType) ) {
  753. return ResultWrapper::success($orderIds);
  754. }
  755. $payment = [];
  756. $payParams = '';
  757. $payStatus = StatusCode::$partion;
  758. $orderStatus = StatusCode::$orderStatus['waitPay'];
  759. $notPayMoney = $payMoney;
  760. foreach($payType as $k => $v){
  761. //判断支付状态(有银行打款是5,没有直接给3)
  762. // 除了余额支付其他方式都要获取支付配置
  763. if($v != StatusCode::$payType['balance'] && $v != StatusCode::$payType['bankLoans']){
  764. $objMPaymentSetting = new MPaymentSetting($this->onlineUserId, $this->onlineEnterpriseId);
  765. $result = $objMPaymentSetting->getPayData($v);
  766. if (!$result->isSuccess() || empty($result->getData())) {
  767. return ResultWrapper::fail('获取微信配置错误', ErrorCode::$configEroor);
  768. }
  769. $payment = $result->getData();
  770. }
  771. switch (true){
  772. case in_array(StatusCode::$payType['balance'], $payType):
  773. //减少余额()
  774. $status = $this->objDOrderIndex->beginTransaction();
  775. //新增会员流水记录
  776. $memberBalanceDetailData = [
  777. 'customerId' => $params['id'],
  778. 'type' => StatusCode::$delete,
  779. 'userCenterId' => $this->onlineUserId,
  780. 'purpose' => '创建订单消费',
  781. 'orderIds' =>implode(',',$orderIds),
  782. 'remark' => '订单id'.implode(',',$orderIds),
  783. 'financeType' => '会员余额消费'
  784. ];
  785. // 组合支付方式
  786. if( !empty($params['admixPayData']) ) {
  787. foreach ($params['admixPayData'] as $key => $value) {
  788. if ($value['payType'] == StatusCode::$payType['balance']) {
  789. // 本次混合支付余额支付金额
  790. $memberBalanceDetailData['money'] = $value['payMoney'];
  791. // 总金额 - 余额支付金额 = 剩余需要搭配支付金额
  792. $payMoney = bcsub($payMoney, $value['payMoney'], 2);
  793. $notPayMoney = $payMoney;
  794. }
  795. }
  796. }else{
  797. $orderStatus = StatusCode::$orderStatus['waitDelivery'];
  798. $payStatus = StatusCode::$standard;
  799. $memberBalanceDetailData['money'] = $payMoney;
  800. $notPayMoney = 0;
  801. }
  802. $objMMemberBalanceDetail = new MMemberBalanceDetail($this->onlineEnterpriseId,$this->onlineUserId);
  803. $memberBalanceDbResult = $objMMemberBalanceDetail->addMemberBalanceDetail($memberBalanceDetailData);
  804. if (!$memberBalanceDbResult->isSuccess()) {
  805. $this->objDOrderIndex->rollBack();
  806. return ResultWrapper::fail($memberBalanceDbResult->getData(), $memberBalanceDbResult->getErrorCode());
  807. }
  808. // 查询余额对应的银行账户
  809. $defaultAccountResult = $this->objMAccount->getDefaultAccount(StatusCode::$payType['balance']);
  810. if ($defaultAccountResult->isSuccess() == false) {
  811. $this->objDOrderIndex->rollBack();
  812. return ResultWrapper::fail($defaultAccountResult->getData(), $defaultAccountResult->getErrorCode());
  813. }
  814. if(empty($defaultAccountResult->getData())){
  815. $this->objDOrderIndex->rollBack();
  816. return ResultWrapper::fail('没有默认的'.StatusCode::$payType[$payType['balance']].'账户', ErrorCode::$notAllowAccess);
  817. }
  818. $defaultAccount = $defaultAccountResult->getData();
  819. //修改订单状态
  820. $time = time();
  821. $this->objDOrderIndex->setTable('qianniao_order_index_'.$this->onlineEnterpriseId);
  822. $fix = ceil($params['userCenterId'] / $this->cutTable);
  823. $this->objDOrder->setTable('qianniao_order_'.$this->onlineEnterpriseId.'_'.$fix);
  824. foreach ($orderIds as $orderId){
  825. $updateIndexResult = $this->objDOrderIndex->update(['payStatus' => $payStatus,'orderStatus' => $orderStatus,'updateTime' => $time],$orderId);
  826. if ($updateIndexResult === false){
  827. $this->objDOrderIndex->rollBack();
  828. return ResultWrapper::fail($this->objDOrderIndex->error(),ErrorCode::$dberror);
  829. }
  830. $updateIndex = $this->objDOrder->update(['payStatus' => $payStatus,'orderStatus' => $orderStatus,'payTime'=> $time,'updateTime' => $time,'notPayMoney'=>$notPayMoney],$orderId);
  831. if ($updateIndex === false){
  832. $this->objDOrderIndex->rollBack();
  833. return ResultWrapper::fail($this->objDOrder->error(),ErrorCode::$dberror);
  834. }
  835. $orderInfo = $this->objDOrder->get($orderId);
  836. if($orderInfo == false){
  837. $this->objDOrderIndex->rollBack();
  838. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  839. }
  840. // 生成收款单
  841. $receivedData = [
  842. 'customerId' => $orderInfo['customerId'],
  843. 'customerName' => $orderInfo['customerName'],
  844. 'currentAccountName' => $orderInfo['shopName'],
  845. 'financeType' => '销售收款',
  846. 'financeTypeId' => StatusCode::$systemFinanceType['saleReceipt'],
  847. 'shopId' => $orderInfo['shopId'],
  848. 'shopName' => $orderInfo['shopName'],
  849. 'receiptTime' => time(),
  850. 'operatorId' => $this->onlineUserId,
  851. 'originId' => $orderId,
  852. 'originNo' => $orderInfo['no'],
  853. 'sourceId' => $orderId,
  854. 'sourceNo' => $orderInfo['no'],
  855. 'sourceNoMoney' => $orderInfo['totalMoney'], //原单据订单总金额
  856. 'auditStatus' => StatusCode::$auditStatus['auditing'],
  857. 'createTime' => time(),
  858. 'updateTime' => time(),
  859. 'accountList' => [
  860. [
  861. "accountId" => isset($defaultAccount['id']) ? $defaultAccount['id'] : 0,
  862. "accountNumber" => isset($defaultAccount['accountNumber']) ? $defaultAccount['accountNumber'] : '',
  863. 'accountName' => isset($defaultAccount['name']) ? $defaultAccount['name'] : '',
  864. "money" => $memberBalanceDetailData['money'],
  865. "discountMoney" => 0,
  866. "finalMoney" => $memberBalanceDetailData['money'],
  867. "payWay" => '余额支付',
  868. "remark" => "在线余额支付自动生成收款单"
  869. ]
  870. ],
  871. ];
  872. $result = $this->objMReceived->addReceived($receivedData, true);
  873. if ($result->isSuccess() == false) {
  874. $this->objDOrderIndex->rollBack();
  875. return ResultWrapper::fail($result->getData(), $result->getErrorCode());
  876. }
  877. unset($receivedData);
  878. unset($result);
  879. }
  880. // 根据客户id (customerId) 获取 openId
  881. if(!empty($orderInfo['customerId'])){
  882. $customerId = $orderInfo['customerId'];
  883. $objDCustomer = new DCustomer('default');
  884. $objDCustomer->setTable($objDCustomer->get_Table() . '_' . $this->onlineEnterpriseId);
  885. $customerData = $objDCustomer->get($customerId);
  886. if($customerData === false){
  887. return ResultWrapper::fail($objDCustomer->error(), ErrorCode::$dberror);
  888. }
  889. if( empty($customerData) ){
  890. return ResultWrapper::fail('查找不到该客户数据', ErrorCode::$contentNotExists);
  891. }
  892. // 小程序订阅消息
  893. if (isset($customerData['openId']) && !empty($customerData['openId'])) {
  894. // 发送小程序订阅消息
  895. $sendMessageData = [
  896. 'character_string3' => ['value' => StatusCode::$noPrefix[1] . '-' . $orderInfo['no']], // 订单编号
  897. 'date10' => ['value' => date('Y-m-d H:i:s', $orderInfo['createTime'])], // 下单时间
  898. 'time4' => ['value' => date('Y-m-d H:i:s', time())], // 支付时间
  899. 'thing7' => ['value' => '余额支付'], // 支付方式
  900. 'name8' => ['value' => substr($orderInfo['shopName'],0,30)] // 商家名称
  901. ];
  902. $objMSystemPushMessage = new MSystemPushMessage($this->onlineUserId, $this->onlineEnterpriseId);
  903. $result = $objMSystemPushMessage->sendWeiXinPushMessage(3, $customerData['openId'], $sendMessageData);
  904. if (!$result->isSuccess()) {
  905. file_put_contents('/www/wwwroot/logs/api.junhailan.com/systemPushMessage.log', date('Y-m-d H:i:s') . 'bb' . var_export($result->getData(), true) . PHP_EOL, FILE_APPEND);
  906. }
  907. }
  908. }
  909. $status && $this->objDOrderIndex->commit();
  910. $payParams = ResultWrapper::success([]);
  911. break;
  912. case in_array(StatusCode::$payType['aliPay'], $payType):
  913. //ali
  914. /*********读取支付宝支付参数(原配置)*********/
  915. /**$aliPayConfigData = Factory::config()->get('alipay');
  916. * if (empty($aliPayConfigData)) {
  917. * return ResultWrapper::fail('支付宝配置错误', ErrorCode::$configEroor);
  918. * }*/
  919. $payOrderData = [
  920. 'subject' => '千鸟云商',
  921. 'out_trade_no' => $tmpOuterTradeNo,
  922. 'total_amount' => $payMoney,
  923. 'passback_params' => $this->onlineEnterpriseId . '|' . $this->onlineUserId . '|' . implode('|', $orderIds),
  924. ];
  925. $aliPayConfigData = [
  926. 'appid' => $payment['appid'],
  927. 'rsaPrivateKey' => $payment['rsaPrivateKey'],
  928. 'alipayrsaPublicKey' => $payment['alipayrsaPublicKey'],
  929. ];
  930. $objAliPay = new aliPay($aliPayConfigData['appid'], $aliPayConfigData['rsaPrivateKey'], $aliPayConfigData['alipayrsaPublicKey']);
  931. $payParams = $objAliPay->appPay($payOrderData);
  932. break;
  933. case in_array(StatusCode::$payType['wxPay'], $payType):
  934. //wx
  935. /********************生成小程序唤起支付用到的参数(原配置)*****/
  936. /**$weixinConfigData = Factory::config()->get('weixin');
  937. * if (empty($weixinConfigData)) {
  938. * return ResultWrapper::fail('微信配置错误', ErrorCode::$configEroor);
  939. * }*/
  940. // 获取当前登录企业的小程序配置
  941. $miniprogramSetting = $objSystemCache->getAppIdByEnterpriseId($this->onlineEnterpriseId);
  942. if (empty($miniprogramSetting)) {
  943. return ResultWrapper::fail('后台小程序配置项为空', ErrorCode::$configEroor);
  944. }
  945. $miniprogramSetting = json_decode($miniprogramSetting, true);//获取小程序appid
  946. // 获取配置文件微信公众号
  947. $weixinConfigData = Factory::config()->getAppoint('weixin', 'offiaccount');
  948. switch ($params['source']) {
  949. case StatusCode::$source['weiXinBrowser'];
  950. if (empty($weixinConfigData)) {
  951. return ResultWrapper::fail('微信公众号配置错误', ErrorCode::$configEroor);
  952. }
  953. $appid = $weixinConfigData['appid'];
  954. $paySource = 'weiXinBrowser';
  955. break;
  956. case StatusCode::$source['H5'];
  957. if (empty($weixinConfigData)) {
  958. return ResultWrapper::fail('微信公众号配置错误', ErrorCode::$configEroor);
  959. }
  960. $appid = $weixinConfigData['appid'];
  961. $paySource = 'H5';
  962. break;
  963. case StatusCode::$source['miniProgram'];
  964. $appid = $miniprogramSetting['appid'];
  965. $paySource = 'miniProgram';
  966. break;
  967. default :
  968. $appid = $payment['mobileAppid'];
  969. $paySource = 'APP';
  970. break;
  971. }
  972. $weixinConfigData = [
  973. 'mch_id' => $payment['mchId'],
  974. 'apiPartnerKey' => $payment['apiPartnerKey'],
  975. 'appid' => $appid
  976. ];
  977. $attach = $this->onlineEnterpriseId . '|' . $this->onlineUserId . '|' . implode('|', $orderIds);
  978. //$objPay = new Pay($appid, $weixinConfigData['pay']['mch_id'], $weixinConfigData['pay']['apiPartnerKey']);//old
  979. //判断是否是子商户,优先选择子商户
  980. if(isset($payment['sub_mch_id']) && !empty($payment['sub_mch_id']) && $payMoney['mch_type'] == 2 ){
  981. $sub_mch_id = $payment['sub_mch_id'];
  982. $sub_weixinConfigData = Factory::config()->get('weixin');
  983. if (empty($sub_weixinConfigData)) {
  984. return ResultWrapper::fail('微信配置错误', ErrorCode::$configEroor);
  985. }
  986. $objPay = new Pay($appid, $sub_weixinConfigData['service_pay']['mch_id'], $sub_weixinConfigData['service_pay']['apiPartnerKey']);
  987. $payParams = $objPay->unifiedorder($tmpOuterTradeNo,$payMoney, $ip, $paySource, '千鸟云商', $params['openId'], $attach,$sub_mch_id);
  988. break;
  989. }
  990. $objPay = new Pay($appid, $weixinConfigData['mch_id'], $weixinConfigData['apiPartnerKey']);
  991. $payParams = $objPay->unifiedorder($tmpOuterTradeNo,$payMoney, $ip, $paySource, '千鸟云商', $params['openId'], $attach);
  992. break;
  993. case in_array(StatusCode::$payType['byte'],$payType):
  994. //字节跳动
  995. $mweb_url = '';
  996. //读取缓存配置
  997. //$objSystemCache->getByteDanceSetting($this->onlineEnterpriseId);
  998. // 获取配置文件字节小程序
  999. $byteDanceConfigData = Factory::config()->getAppoint('byteDance', 'pay');
  1000. if (empty($byteDanceConfigData)) {
  1001. return ResultWrapper::fail('字节跳动配置错误', ErrorCode::$configEroor);
  1002. }
  1003. $objbytePay = new bytePay($byteDanceConfigData['appid'], $byteDanceConfigData['merchant_id'], $byteDanceConfigData['app_secret']);
  1004. unset($payParams);
  1005. $payParams = $objbytePay->pay($tmpOuterTradeNo, $payMoney, '千鸟云商', $ip, $mweb_url);
  1006. break;
  1007. case in_array(StatusCode::$payType['bankLoans'], $payType):
  1008. foreach ($orderIds as $orderId){
  1009. $orderInfo = $this->objDOrder->get($orderId);
  1010. if($orderInfo == false){
  1011. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  1012. }
  1013. }
  1014. // 根据客户id (customerId) 获取 openId
  1015. if(!empty($orderInfo['customerId'])){
  1016. $customerId = $orderInfo['customerId'];
  1017. $objDCustomer = new DCustomer('default');
  1018. $objDCustomer->setTable($objDCustomer->get_Table() . '_' . $this->onlineEnterpriseId);
  1019. $customerData = $objDCustomer->get($customerId);
  1020. if($customerData === false){
  1021. return ResultWrapper::fail($objDCustomer->error(), ErrorCode::$dberror);
  1022. }
  1023. if( empty($customerData) ){
  1024. return ResultWrapper::fail('查找不到该客户数据', ErrorCode::$contentNotExists);
  1025. }
  1026. // 小程序订阅消息
  1027. if (isset($customerData['openId']) && !empty($customerData['openId'])) {
  1028. // 发送小程序订阅消息
  1029. $sendMessageData = [
  1030. 'character_string3' => ['value' => StatusCode::$noPrefix[1] . '-' . $orderInfo['no']], // 订单编号
  1031. 'date10' => ['value' => date('Y-m-d H:i:s', $orderInfo['createTime'])], // 下单时间
  1032. 'time4' => ['value' => date('Y-m-d H:i:s', time())], // 支付时间
  1033. 'thing7' => ['value' => '银行打款'], // 支付方式
  1034. 'name8' => ['value' => substr($orderInfo['shopName'],0,30)] // 商家名称
  1035. ];
  1036. $objMSystemPushMessage = new MSystemPushMessage($this->onlineUserId, $this->onlineEnterpriseId);
  1037. $result = $objMSystemPushMessage->sendWeiXinPushMessage(3, $customerData['openId'], $sendMessageData);
  1038. if (!$result->isSuccess()) {
  1039. file_put_contents('/www/wwwroot/logs/api.junhailan.com/systemPushMessage.log', date('Y-m-d H:i:s') . 'bb' . var_export($result->getData(), true) . PHP_EOL, FILE_APPEND);
  1040. }
  1041. }
  1042. }
  1043. $payParams = ResultWrapper::success($orderIds);
  1044. break;
  1045. default:
  1046. //TODO
  1047. return ResultWrapper::fail('暂未开放的支付方式',ErrorCode::$paramError);
  1048. break;
  1049. }
  1050. unset($payType[$k]);
  1051. if (!$payParams->isSuccess()) {
  1052. return ResultWrapper::fail($payParams->getData(), $payParams->getErrorCode());
  1053. }
  1054. }
  1055. return ResultWrapper::success($payParams->getData());
  1056. }
  1057. /**
  1058. * Doc: (des="已审核未出库订单,审核驳回")
  1059. * User: XMing
  1060. * Date: 2021/2/25
  1061. * Time: 9:41 上午
  1062. * @param int $orderId
  1063. * @return ResultWrapper
  1064. * @throws \Exception
  1065. */
  1066. public function revokeAudit(int $orderId): ResultWrapper
  1067. {
  1068. $orderIndex = $this->objDOrderIndex->get($orderId);
  1069. if ($orderIndex === false) {
  1070. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  1071. }
  1072. if (empty($orderIndex)) {
  1073. return ResultWrapper::fail('未获取到指定订单', ErrorCode::$paramError);
  1074. }
  1075. $fix = ceil((empty($params['userCenterId']) ? 1 : $params['userCenterId']) / $this->cutTable);
  1076. $this->objDOrder->setTable('qianniao_order_'.$this->onlineEnterpriseId.'_'.$fix);
  1077. $orderData = $this->objDOrder->get($orderId);
  1078. if ($orderData === false){
  1079. return ResultWrapper::fail($this->objDOrder->error(),ErrorCode::$dberror);
  1080. }
  1081. if (empty($orderData)){
  1082. return ResultWrapper::fail('为获取到指定的订单信息',ErrorCode::$paramError);
  1083. }
  1084. if ($orderData['auditStatus'] != StatusCode::$auditStatus['auditPass']){
  1085. return ResultWrapper::fail('订单审核状态异常,不能驳回',ErrorCode::$paramError);
  1086. }
  1087. if ($orderData['outStatus'] != StatusCode::$delete){
  1088. return ResultWrapper::fail('订单已经出库,不能驳回',ErrorCode::$paramError);
  1089. }
  1090. if ($orderData['orderStatus'] == StatusCode::$orderStatus['close']){
  1091. return ResultWrapper::fail('订单已关闭,不嫩驳回',ErrorCode::$paramError);
  1092. }
  1093. $this->objDOrderIndex->beginTransaction();
  1094. $time = time();
  1095. //update order
  1096. $updateOrder = $this->objDOrder->update([
  1097. 'auditStatus' => StatusCode::$auditStatus['auditing'],
  1098. 'updateTime' => $time,
  1099. 'revokeTime' => $time
  1100. ],$orderId);
  1101. if ($updateOrder === false){
  1102. $this->objDOrderIndex->rollBack();
  1103. return ResultWrapper::fail($this->objDOrder->error(),ErrorCode::$dberror);
  1104. }
  1105. //update orderIndex
  1106. $updateOrderIndex = $this->objDOrderIndex->update([
  1107. 'auditStatus' => StatusCode::$auditStatus['auditing'],
  1108. 'updateTime' => $time
  1109. ],$orderId);
  1110. if ($updateOrderIndex === false){
  1111. $this->objDOrderIndex->rollBack();
  1112. return ResultWrapper::fail($this->objDOrder->error(),ErrorCode::$dberror);
  1113. }
  1114. //update stock
  1115. $objMInventoryOut = new MInventoryOut($this->onlineEnterpriseId,$this->onlineUserId);
  1116. $stockOutResult = $objMInventoryOut->delInventoryOutStatus([
  1117. 'sourceId' => $orderId,
  1118. 'type' => StatusCode::$orderType['saleOut']
  1119. ]);
  1120. if (!$stockOutResult->isSuccess()){
  1121. $this->objDOrderIndex->rollBack();
  1122. return ResultWrapper::fail($stockOutResult->getData(),$stockOutResult->getErrorCode());
  1123. }
  1124. // 删除已生成的收款单
  1125. $objDReceivedIndex = new DReceivedIndex('finance');
  1126. $objDReceivedIndex->setTable('qianniao_received_index_' . $this->onlineEnterpriseId);
  1127. $deleteReceive = $objDReceivedIndex->delete(['sourceId'=>$orderIndex['id']]);
  1128. if ($deleteReceive === false) {
  1129. return ResultWrapper::fail($objDReceivedIndex->error(), ErrorCode::$dberror);
  1130. }
  1131. /*
  1132. //update es
  1133. $_id = self::createEsDocumentId($orderId);
  1134. $this->objDOrder->esupdateTypeFieldVaule([
  1135. 'auditStatus' => StatusCode::$auditStatus['auditing'],
  1136. 'updateTime' => $time
  1137. ], $_id);*/
  1138. $this->objDOrderIndex->commit();
  1139. return ResultWrapper::success(true);
  1140. }
  1141. /**
  1142. * Doc: (des="")
  1143. * User: XMing
  1144. * Date: 2021/3/9
  1145. * Time: 5:13 下午
  1146. * @param int $orderId
  1147. * @return ResultWrapper
  1148. * @throws \Exception
  1149. */
  1150. public function reStockOut(int $orderId): ResultWrapper
  1151. {
  1152. // 获取订单索引表数据
  1153. $orderIndex = $this->objDOrderIndex->get($orderId);
  1154. if ($orderIndex === false){
  1155. return ResultWrapper::fail($this->objDOrderIndex->error(),ErrorCode::$dberror);
  1156. }
  1157. if (empty($orderIndex)){
  1158. return ResultWrapper::fail('未获取到指定地订单信息',ErrorCode::$paramError);
  1159. }
  1160. // 获取订单数据
  1161. $fix = ceil($orderIndex['userCenterId'] / $this->cutTable);
  1162. $this->objDOrder->setTable('qianniao_order_'.$this->onlineEnterpriseId.'_'.$fix);
  1163. $orderData = $this->objDOrder->get($orderId);
  1164. if ($orderData === false){
  1165. return ResultWrapper::fail($this->objDOrder->error(),ErrorCode::$dberror);
  1166. }
  1167. if (empty($orderData)){
  1168. return ResultWrapper::fail('未获取到指定的订单信息',ErrorCode::$paramError);
  1169. }
  1170. if ($orderData['outStatus'] == StatusCode::$standard){
  1171. return ResultWrapper::fail('订单已经出库,请不要重复出库',ErrorCode::$paramError);
  1172. }
  1173. // 查询销售订单是否还有未审核的出库单,必须先处理完,再生成新的出库单
  1174. $objMInventoryOut = new MInventoryOut($this->onlineEnterpriseId,$this->onlineUserId);
  1175. $condition = [
  1176. 'originId' => $orderData['id'],
  1177. 'deleteStatus' => StatusCode::$standard,
  1178. 'auditStatus' => StatusCode::$auditStatus['auditing'],
  1179. ];
  1180. $result = $objMInventoryOut->getInventoryOutData($condition);
  1181. if (!$result->isSuccess()) {
  1182. return ResultWrapper::fail($result->getData(), ErrorCode::$dberror);
  1183. }
  1184. $inventoryOutData = $result->getData();
  1185. if( !empty($inventoryOutData) ){
  1186. return ResultWrapper::fail('当前销售订单还有未审核的出库单,单号:'.StatusCode::$noPrefix[5].'-'.$inventoryOutData[0]['no'].',请先处理完成', ErrorCode::$notAllowAccess);
  1187. }
  1188. // 查询订单商品表数据
  1189. $this->objDOrderGoods->setTable('qianniao_order_goods_'.$this->onlineEnterpriseId.'_'.$fix);
  1190. $orderGoodsData = $this->objDOrderGoods->select(['orderId' => $orderId,'deleteStatus' => StatusCode::$standard]);
  1191. if ($orderGoodsData === false){
  1192. return ResultWrapper::fail($this->objDOrderGoods->error(),ErrorCode::$dberror);
  1193. }
  1194. if (empty($orderGoodsData)){
  1195. return ResultWrapper::fail('订单商品获取失败',ErrorCode::$paramError);
  1196. }
  1197. // 组装出库单数据
  1198. $saleOutData = [
  1199. 'sourceId' => $orderData['id'],
  1200. 'sourceNo' => $orderData['no'],
  1201. 'originNo' => $orderData['no'],
  1202. 'originId' => $orderData['id'],
  1203. 'shopId' => $orderData['shopId'],
  1204. 'shopName' => $orderData['shopName'],
  1205. 'amount' => $orderData['payAmount'],
  1206. 'operatorId' => $orderData['auditId'],//操作人id
  1207. 'operatorName' => $orderData['audit'],//操作人信息
  1208. 'customerId' => $orderData['customerId'],
  1209. 'customerName' => $orderData['customerName'],
  1210. 'customerCode' => createCode(StatusCode::$code['customer']['prefix'], $orderData['customerId'], StatusCode::$code['customer']['length']),
  1211. 'customerMobile' => $orderData['customerMobile'],
  1212. 'source' => StatusCode::$orderType['saleOrder'], //订单来源(出库类型)
  1213. 'type' => StatusCode::$orderType['saleOut'],
  1214. 'deliveryType' => $orderData['deliveryType'],//配送方式
  1215. 'remark' => $orderData['remark'],
  1216. ];
  1217. $saleOutData['materielNum'] = 0;
  1218. //获取sku
  1219. $objMSku = new MSku($this->onlineUserId, $this->onlineEnterpriseId);
  1220. $skuIds = array_column(array_values($orderGoodsData), 'skuId');
  1221. $modelResult = $objMSku->getSkuDataBySkuIds($skuIds);
  1222. if (!$modelResult->isSuccess()) {
  1223. return ResultWrapper::fail($modelResult->getData(), $modelResult->getErrorCode());
  1224. }
  1225. $skuData = $modelResult->getData();
  1226. unset($modelResult);
  1227. foreach ($orderGoodsData as $key => $value) {
  1228. if ($value['outOfNum'] > 0 && $value['isEq'] == StatusCode::$delete){
  1229. $saleOutData['materielNum']++;
  1230. $totalMoney = bcsub(bcsub($value['totalMoney'], $value['vipDiscount']), $value['preferential']);//销售总价 !优惠后
  1231. $saleOutData['orderGoodsData'][] = [
  1232. 'materielId' => $value['goodsBasicId'],
  1233. 'materielName' => $value['goodsName'],
  1234. 'materielCode' => createCode(StatusCode::$code['goodsBasic']['prefix'], $value['goodsBasicId'], StatusCode::$code['goodsBasic']['length']),
  1235. 'skuId' => $value['skuId'],
  1236. 'num' => $value['outOfNum'],
  1237. 'otherNum' => $value['otherNum'],
  1238. 'outNum' => 0,
  1239. 'total' => $value['outOfNum'],
  1240. 'unitName' => isset($value['unitName']) ? $value['unitName'] : '',
  1241. 'skuName' => isset($skuData[$value['skuId']]) ? $skuData[$value['skuId']]['skuName'] : '',
  1242. 'unitPrice' => $value['price'],//单价 不优惠
  1243. 'totalPrice' => $totalMoney,//销售总价 !优惠后
  1244. ];
  1245. }
  1246. }
  1247. if (empty($saleOutData['orderGoodsData'])){
  1248. return ResultWrapper::fail('此订单没有需要出库的商品',ErrorCode::$paramError);
  1249. }
  1250. // 新增出库单
  1251. $dbResult = $objMInventoryOut->addInventoryOut($saleOutData);
  1252. if (!$dbResult->isSuccess()){
  1253. return ResultWrapper::fail($dbResult->getData(),$dbResult->getErrorCode());
  1254. }
  1255. return ResultWrapper::success($dbResult->getData());
  1256. }
  1257. /**
  1258. * Doc: (des="")
  1259. * User: XMing
  1260. * Date: 2021/3/18
  1261. * Time: 6:55 下午
  1262. * @param int $orderId
  1263. * @return ResultWrapper
  1264. * @throws \Exception
  1265. */
  1266. public function retAmount(int $orderId)
  1267. {
  1268. $message = '退款成功';
  1269. // 从订单索引表查询订单数据
  1270. $orderIndex = $this->objDOrderIndex->get($orderId);
  1271. if ($orderIndex === false){
  1272. return ResultWrapper::fail($this->objDOrderIndex->error(),ErrorCode::$dberror);
  1273. }
  1274. if (empty($orderIndex)){
  1275. return ResultWrapper::fail('未获取到订单数据',ErrorCode::$paramError);
  1276. }
  1277. // 从订单和订单商品查询订单数据
  1278. $fix = ceil($orderIndex['userCenterId'] / $this->cutTable);
  1279. $this->objDOrder->setTable('qianniao_order_'.$this->onlineEnterpriseId.'_'.$fix);
  1280. $this->objDOrderGoods->setTable('qianniao_order_goods_'.$this->onlineEnterpriseId.'_'.$fix);
  1281. $order = $this->objDOrder->get($orderId);
  1282. if ($order === false){
  1283. return ResultWrapper::fail($this->objDOrder->error(),ErrorCode::$dberror);
  1284. }
  1285. if ( empty($order) ){
  1286. return ResultWrapper::fail('未获取到指定订单信息',ErrorCode::$paramError);
  1287. }
  1288. $sql = 'SELECT * FROM qianniao_order_goods_'.$this->onlineEnterpriseId.'_'.$fix.' WHERE orderId = '.$orderId.' AND deleteStatus = '.StatusCode::$standard.' AND outOfNum > 0';
  1289. $rows = $this->objDOrderGoods->query($sql);
  1290. if ($rows === false){
  1291. return ResultWrapper::fail($this->objDOrderGoods->error(),ErrorCode::$dberror);
  1292. }
  1293. if (empty($rows)){
  1294. return ResultWrapper::fail('未获取到指定订单的商品信息',ErrorCode::$paramError);
  1295. }
  1296. // 根据实际订单未出库数量计算退款金额
  1297. $receiveMoney = 0;
  1298. foreach ($rows as $row){
  1299. if ($row['outOfNum'] <= 0) continue;
  1300. $receiveMoney = bcadd($receiveMoney,bcmul($row['price'],$row['outOfNum'], 4),4);
  1301. }
  1302. // 保留4位判断金额是否异常
  1303. if ($receiveMoney <= 0){
  1304. return ResultWrapper::fail('退款金额异常',ErrorCode::$paramError);
  1305. }
  1306. $receiveMoney = bcadd($receiveMoney, '0', 2); // 实际退款保留两位
  1307. $status = $this->objDOrder->beginTransaction();
  1308. $payType = explode(',', $orderIndex['payType']);
  1309. // 未支付订单不生成退款单
  1310. if( $order['payStatus'] == StatusCode::$standard){
  1311. // 小于1分钱不做退款处理
  1312. if ($receiveMoney >= 0.01){
  1313. // 根据订单支付方式规划退款账户
  1314. $objMAccount = new MAccount($this->onlineEnterpriseId,$this->onlineUserId);
  1315. // 包含余额组合支付方式统一返回余额,其他原路返回
  1316. if( in_array(StatusCode::$payType['balance'],$payType) ){
  1317. $financeAccountData = $objMAccount->getDefaultAccount(StatusCode::$payType['balance']);
  1318. }else if( in_array(StatusCode::$payType['bankLoans'],$payType) ){
  1319. $extends = json_decode($order['extends'], true);
  1320. if( isset($extends['bankData']['id']) && !empty($extends['bankData']['id'])){
  1321. $accountId = $extends['bankData']['id'];
  1322. //获取银行打款账户信息
  1323. $financeAccountData = $objMAccount->getAccountInfo($accountId);
  1324. }else{
  1325. $financeAccountData = ResultWrapper::fail('获取打款账户错误');
  1326. }
  1327. } else{
  1328. $financeAccountData = $objMAccount->getDefaultAccount($payType);
  1329. }
  1330. if(!$financeAccountData->isSuccess()){
  1331. return ResultWrapper::fail($financeAccountData->getData(), $financeAccountData->getErrorCode());
  1332. }
  1333. $financeAccountData = $financeAccountData->getData();
  1334. //记录负应收的id
  1335. //$financeRefundData['offsetId'] = (int)$addReceiveResult->getData();
  1336. // 生成财务退款单
  1337. $financeRefundData = [
  1338. 'originId' => getArrayItem($order,'id',0),
  1339. 'originNo' => getArrayItem($order,'no',''),
  1340. 'sourceId' => getArrayItem($order,'id',0),
  1341. 'sourceNo' => getArrayItem($order,'no',''),
  1342. 'refundTime' => time(),
  1343. 'createTime' => time(),
  1344. 'unitId' => getArrayItem($order,'customerId',0),
  1345. 'unitName' => getArrayItem($order,'customerName',0),
  1346. 'currentAccountName' => getArrayItem($order,'customerName',''),
  1347. 'financeType' => '订单完结退款',
  1348. 'financeTypeId' => 1,
  1349. 'payType' =>getArrayItem($order,'payType',''),
  1350. 'shopId' => getArrayItem($order,'shopId',0),
  1351. 'shopName' => getArrayItem($order,'shopName',0),
  1352. 'money' => $receiveMoney,
  1353. 'operatorId' => $this->onlineUserId,
  1354. 'type' => StatusCode::$standard,
  1355. 'auditStatus' => StatusCode::$auditStatus['auditing'],
  1356. 'remark' => '订单一键完结,订单编号:'. getArrayItem($order,'no','').'完结后需退款金额:'.$receiveMoney
  1357. ];
  1358. $financeRefundData['accountList'] = [
  1359. [
  1360. 'accountId' => $financeAccountData['id'],
  1361. 'accountNumber' => $financeAccountData['accountNumber'],
  1362. 'accountName' => $financeAccountData['name'],
  1363. 'money' => $receiveMoney,
  1364. ]
  1365. ];
  1366. $objMRefund = new MRefund($this->onlineEnterpriseId,$this->onlineUserId);
  1367. $result = $objMRefund->addRefund($financeRefundData);
  1368. if(!$result->isSuccess()){
  1369. $this->objDOrder->rollBack();
  1370. return ResultWrapper::fail($result->getData(),$result->getErrorCode());
  1371. }
  1372. // 应收自动审核队列
  1373. //Factory::cache('finance')->zadd('salesOutReceive::'.$this->onlineEnterpriseId, time(), $addReceiveResult->getData());
  1374. }else{
  1375. $message = '退款金额少于0.01,不做退款处理,退款成功';
  1376. }
  1377. }
  1378. $updateIndexData = [
  1379. 'updateTime' => time(),
  1380. 'isRet' => StatusCode::$standard,
  1381. ];
  1382. $updateOrderIndex = $this->objDOrderIndex->update($updateIndexData, $orderId);
  1383. if ($updateOrderIndex === false){
  1384. $this->objDOrder->rollBack();
  1385. return ResultWrapper::fail($this->objDOrderIndex->error(),ErrorCode::$dberror);
  1386. }
  1387. $update = [
  1388. 'updateTime' => time(),
  1389. 'retTime' => time(),
  1390. 'retMoney' => $receiveMoney,
  1391. 'isRet' => StatusCode::$standard,
  1392. ];
  1393. $updateOrder = $this->objDOrder->update($update,$orderId);
  1394. if ($updateOrder === false){
  1395. $this->objDOrder->rollBack();
  1396. return ResultWrapper::fail($this->objDOrderIndex->error(),ErrorCode::$dberror);
  1397. }
  1398. //订单解锁
  1399. $objMInventory = new MInventory($this->onlineEnterpriseId, $this->onlineUserId);
  1400. $unlockResult = $objMInventory->unlockInventory([$orderId], StatusCode::$orderType['saleOrder'], $orderIndex['createTime']);
  1401. if (!$unlockResult->isSuccess()) {
  1402. $this->objDOrder->rollBack();
  1403. return ResultWrapper::fail($unlockResult->getData(), ErrorCode::$dberror);
  1404. }
  1405. $status && $this->objDOrder->commit();
  1406. return ResultWrapper::success($message);
  1407. }
  1408. /**
  1409. * Doc: (des="创建分销")
  1410. * User: XMing
  1411. * Date: 2020/7/29
  1412. * Time: 6:41 下午
  1413. * @param string $token
  1414. * @param string $auth
  1415. * @param int $customerId
  1416. * @param int $orderId
  1417. */
  1418. private function taskCreateCommission(string $token, string $auth, int $customerId, int $orderId)
  1419. {
  1420. $i = 1;
  1421. do {
  1422. $postData = [
  1423. 'topicName' => 'MyJob',
  1424. 'topicClass' => 'Jobs\Model\MTopic\Order\MCommissionOrder',
  1425. 'topicMethon' => 'push',
  1426. 'topicMethonParams' => [
  1427. 'Authorization' => $auth,
  1428. 'Token' => $token,
  1429. 'orderId' => $orderId,
  1430. 'customerId' => $customerId,
  1431. 'PROJECT_DOMAIN' => PROJECT_DOMAIN
  1432. ],
  1433. ];
  1434. $url = QIANNIAO_QUEUE . '/CAddJob/add';
  1435. $result = request($url, $postData);
  1436. $i++;
  1437. } while ($result['httpcode'] != 200 && $i <= 3);
  1438. Logger::logs(E_USER_ERROR, '投递任务成功', __CLASS__, __LINE__, $postData);
  1439. }
  1440. /**
  1441. * Doc: (des="修改订单的退货状态")
  1442. * User: XMing
  1443. * Date: 2020/7/14
  1444. * Time: 3:54 下午
  1445. * @param $params
  1446. * @return ResultWrapper
  1447. * @throws \Exception
  1448. */
  1449. public function editOrder($params)
  1450. {
  1451. if (empty($params['id'])) {
  1452. return ResultWrapper::fail('没有订单id', ErrorCode::$paramError);
  1453. }
  1454. $id = $params['id'];
  1455. unset($params['id']);
  1456. $this->objDOrderIndex->setTable('qianniao_order_index_' . $this->onlineEnterpriseId);
  1457. $orderIndex = $this->objDOrderIndex->get(['id' => $id], 'userCenterId');
  1458. if ($orderIndex === false) {
  1459. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  1460. }
  1461. $this->objDOrderIndex->beginTransaction();
  1462. $updateResult = $this->objDOrderIndex->update([
  1463. 'updateTime' => $params['updateTime'],
  1464. 'returnStatus' => $params['returnStatus'],
  1465. ], ['id' => $id]);
  1466. if ($updateResult === false) {
  1467. $this->objDOrderIndex->rollBack();
  1468. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  1469. }
  1470. $tableNum = ceil($orderIndex['userCenterId'] / $this->cutTable);
  1471. $this->objDOrder->setTable('qianniao_order_' . $this->onlineEnterpriseId . '_' . $tableNum);
  1472. $dbResult = $this->objDOrder->update([
  1473. 'updateTime' => $params['updateTime'],
  1474. 'returnStatus' => $params['returnStatus'],
  1475. ], $id);
  1476. if ($dbResult === false) {
  1477. $this->objDOrderIndex->rollBack();
  1478. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  1479. }
  1480. $this->objDOrderIndex->commit();
  1481. /*//修改es数据
  1482. $_id = self::createEsDocumentId($id);
  1483. $this->objDOrder->esupdateTypeFieldVaule(['returnStatus' => $params['returnStatus'], 'updateTime' => $params['updateTime']], $_id);*/
  1484. return ResultWrapper::success($dbResult);
  1485. }
  1486. /**
  1487. * 更新ES
  1488. * @param $orderId
  1489. * @param $order
  1490. * @param $addressData
  1491. * @param $addOrderGoodsName
  1492. * @param int $userCenterId
  1493. */
  1494. public function updateEsData($orderId, $order, $addressData, $addOrderGoodsName, $userCenterId = 0)
  1495. {
  1496. $orderEsData = [
  1497. /*订单表信息*/
  1498. 'id' => $orderId,//订单编号,
  1499. 'no' => $order['no'],//订单编号,
  1500. 'outerTradeNo' => '',//'外部流水号(支付宝/微信返回的流水号)'
  1501. 'shopId' => $order['shopId'],
  1502. 'shopName' => $order['shopName'],
  1503. 'enterpriseId' => $this->onlineEnterpriseId,
  1504. 'userCenterId' => $userCenterId != 0 ? $userCenterId : $this->onlineUserId,
  1505. 'totalMoney' => $order['totalMoney'],
  1506. 'payAmount' => $order['payAmount'],
  1507. 'buyTotal' => isset($order['buyTotal']) ? $order['buyTotal'] : 0,//购买总数
  1508. 'customerName' => $order['customerName'],//客户姓名
  1509. 'customerId' => $order['customerId'],//客户id
  1510. 'customerType' => isset($order['customerType']) ? $order['customerType'] : 0,//客户类型
  1511. 'payStatus' => StatusCode::$delete,//'支付状态 默认4 未支付 5已支付'
  1512. 'orderStatus' => StatusCode::$orderStatus['waitPay'],//订单状态 默认1 创建 2待支付 3代发货 4待收货 5已完成 6已关闭
  1513. 'payType' => $order['payType'],//'支付方式 1微信 2支付宝 3货到付款 4上门自提'
  1514. 'deliveryType' => $order['deliveryType'],//'配送方式 1商品配送 2上门自提'
  1515. 'source' => $order['source'],//订单来源 默认1 ios 2android 3小程序 4后台创建
  1516. 'remark' => $order['remark'],//订单备注
  1517. 'auditStatus' => $order['auditStatus'],// '审核状态 默认1 待审 2审核通过 3 审核未通过 4 审核中'
  1518. //'payTime' => '',//'付款时间'
  1519. 'createTime' => $order['createTime'],//'创建时间'
  1520. 'updateTime' => $order['updateTime'],//'修改时间',
  1521. 'salesManId' => isset($order['salesManId']) ? $order['salesManId'] : 0,
  1522. 'salesManName' => isset($order['salesManName']) ? $order['salesManName'] : '',
  1523. 'returnStatus' => StatusCode::$orderReturn['notReturn'],
  1524. 'outStatus' => StatusCode::$delete,
  1525. 'verifyCode' => $order['verifyCode'],//核销码
  1526. /*收货人信息*/
  1527. 'realName' => isset($addressData['realName']) ? $addressData['realName'] : '',//收货人姓名
  1528. 'mobile' => isset($addressData['mobile']) ? $addressData['mobile'] : '',//收货人电话
  1529. 'address' => isset($addressData['address']) ? $addressData['address'] : '',//收货详细地址
  1530. 'provinceCode' => isset($addressData['provinceCode']) ? $addressData['provinceCode'] : '',//收货人省份编码
  1531. 'cityCode' => isset($addressData['cityCode']) ? $addressData['cityCode'] : '',//收货人城市编码
  1532. 'districtCode' => isset($addressData['districtCode']) ? $addressData['districtCode'] : '',//收货人区编码
  1533. /*优惠信息*/
  1534. 'preferential' => $order['preferential'],//优惠券优惠金额
  1535. 'vipDiscount' => $order['vipDiscount'],//会员卡优惠金额
  1536. 'vipDoubleDiscount' => $order['vipDoubleDiscount'],//会员卡折上折优惠金额
  1537. /*商品信息*/
  1538. 'goodsName' => $addOrderGoodsName,
  1539. 'orderType' => isset($order['orderType']) ? $order['orderType'] : StatusCode::$orderType['salesSlip'],
  1540. ];
  1541. isset($order['salesManName']) && $orderEsData['salesManName'] = $order['salesManName'];
  1542. $_id = self::createEsDocumentId($orderId);
  1543. $result = $this->objDOrder->addUpSearchIndexDocument($orderEsData, $_id);
  1544. if (isset($result['_shards']) && isset($result['_shards']['successful']) && $result['_shards']['successful'] == 1) {
  1545. //echo "es操作成功";
  1546. //return;
  1547. }
  1548. //echo "es操作失败";
  1549. }
  1550. /**
  1551. * 创建文档id
  1552. *
  1553. * @param $orderId
  1554. * @return string
  1555. */
  1556. private function createEsDocumentId($orderId)
  1557. {
  1558. return 'EnterpriseId_' . $this->onlineEnterpriseId . '_OrderId_' . $orderId;
  1559. }
  1560. /**
  1561. * Doc: (des="获取订单创建时间,用于其它业务计算分表使用")
  1562. * User: XMing
  1563. * Date: 2020/12/25
  1564. * Time: 2:16 下午
  1565. * @param $orderId
  1566. * @return ResultWrapper
  1567. * @throws \Exception
  1568. */
  1569. public function getOrderCreateTime($orderId)
  1570. {
  1571. $this->objDOrderIndex->setTable('qianniao_order_index_' . $this->onlineEnterpriseId);
  1572. $orderIndexRes = $this->objDOrderIndex->get_by('id', $orderId);
  1573. if ($orderIndexRes === false) {
  1574. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  1575. }
  1576. if (empty($orderIndexRes)) {
  1577. return ResultWrapper::fail('未找到订单信息', ErrorCode::$paramError);
  1578. }
  1579. return ResultWrapper::success($orderIndexRes);
  1580. }
  1581. /**
  1582. * Doc: (des="获取订单详情")
  1583. * User: XMing
  1584. * Date: 2020/7/14
  1585. * Time: 6:25 下午
  1586. * @param $id
  1587. * @return ResultWrapper
  1588. * @throws \Exception
  1589. */
  1590. public function getOrderInfoById($id): ResultWrapper
  1591. {
  1592. $this->objDOrderIndex->setTable('qianniao_order_index_' . $this->onlineEnterpriseId);
  1593. $orderIndexRes = $this->objDOrderIndex->get_by('id', $id);
  1594. if ($orderIndexRes === false) {
  1595. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  1596. }
  1597. if (empty($orderIndexRes)) {
  1598. return ResultWrapper::fail('未找到订单信息', ErrorCode::$paramError);
  1599. }
  1600. //切换分表
  1601. self::orderSubTable($this->onlineEnterpriseId, $orderIndexRes['userCenterId']);
  1602. $dbResult = $this->objDOrder->get_by('id', $id);
  1603. if ($dbResult === false) {
  1604. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  1605. }
  1606. $formatData = self::format($dbResult);
  1607. if (!$formatData->isSuccess()){
  1608. return ResultWrapper::fail($formatData->getData(),$formatData->getErrorCode());
  1609. }
  1610. $dbResult = $formatData->getData();
  1611. //添加订单打印的数据
  1612. $printResult = self::printInfo($dbResult);
  1613. if (!$printResult->isSuccess()){
  1614. return ResultWrapper::fail($printResult->getData(),$printResult->getErrorCode());
  1615. }
  1616. $dbResult = $printResult->getData();
  1617. //logisticsData
  1618. $dbResult['logisticsData'] = json_decode($dbResult['logisticsData'],true);
  1619. // 查询订单退货对应退货单的状态
  1620. if($dbResult['returnStatus']){
  1621. $objMOrderReturn = new MOrderReturn($this->onlineEnterpriseId, $this->onlineUserId);
  1622. $result = $objMOrderReturn->getAuditStatusByOrderId($id);
  1623. $dbResult['returnAuditStatus'] = StatusCode::$auditStatus['auditing'];
  1624. if($result->isSuccess()){
  1625. $dbResult['returnAuditStatus'] = $result->getData();
  1626. }
  1627. }
  1628. return ResultWrapper::success($dbResult);
  1629. }
  1630. /**
  1631. * 补充打印订单字段信息
  1632. *
  1633. * @param $dbResult
  1634. * @return ResultWrapper
  1635. * @throws \Exception
  1636. */
  1637. public function printInfo($dbResult)
  1638. {
  1639. if ($dbResult['source'] == StatusCode::$source['manage']){
  1640. $dbResult['receivable'] = $dbResult['totalMoney'];//应收
  1641. }else{
  1642. $dbResult['receivable'] = $dbResult['payAmount'];//应收
  1643. }
  1644. if ($dbResult['payType'] == StatusCode::$payType['cashPay']
  1645. || $dbResult['payType'] == StatusCode::$payType['bankLoans']
  1646. ) {
  1647. //货到付款 已支付 = payAmount金额
  1648. if ($dbResult['source'] == StatusCode::$source['manage']){
  1649. $dbResult['netReceipts'] = isset($dbResult['receivedMoney']) ? $dbResult['receivedMoney'] : 0;
  1650. }else{
  1651. if ($dbResult['payStatus'] == StatusCode::$standard) {
  1652. $dbResult['netReceipts'] = $dbResult['payAmount'];//实收
  1653. } else {
  1654. $dbResult['netReceipts'] = 0;//实收
  1655. }
  1656. }
  1657. } else {
  1658. //在线支付 已支付 = payAmount金额
  1659. if ($dbResult['payStatus'] == StatusCode::$standard) {
  1660. $dbResult['netReceipts'] = $dbResult['payAmount'];//实收
  1661. } else {
  1662. $dbResult['netReceipts'] = 0;//实收
  1663. }
  1664. }
  1665. $dbResult['currentShortage'] = bcsub($dbResult['receivable'], $dbResult['netReceipts'], 2);//本单欠
  1666. $dbResult['upOwe'] = $dbResult['customerOwe'];//上欠
  1667. $dbResult['totalDeficit'] = bcadd($dbResult['currentShortage'], $dbResult['upOwe'], 2);
  1668. $objMShop = new MShop($this->onlineEnterpriseId, $this->onlineUserId);
  1669. $shopData = $objMShop->getShopInfo(['id' => $dbResult['shopId']]);
  1670. if (!$shopData->isSuccess()) {
  1671. return ResultWrapper::fail($shopData->getData(),$shopData->getErrorCode());
  1672. } else {
  1673. $shopData = $shopData->getData();
  1674. }
  1675. $dbResult['shopAddress'] = isset($shopData['area']) ? $shopData['area'] : [];
  1676. $dbResult['shopMobile'] = isset($shopData['mobile']) ? $shopData['mobile'] : '';
  1677. $dbResult['shopDescribe'] = isset($shopData['describe']) ? $shopData['describe'] : '';
  1678. $dbResult['partnerPhone'] = isset($shopData['mobile']) ? $shopData['mobile'] : '';//合伙人联系电弧
  1679. $objMAccount = new MAccount($this->onlineEnterpriseId,$this->onlineUserId);
  1680. $accountName = '';
  1681. if ($dbResult['payType'] == StatusCode::$payType['wxPay'] || $dbResult['payType'] == StatusCode::$payType['aliPay']){
  1682. $accountResult = $objMAccount->getDefaultAccount($dbResult['payType']);
  1683. if (!$accountResult->isSuccess()){
  1684. return ResultWrapper::fail($accountResult->getData(),$accountResult->getErrorCode());
  1685. }
  1686. $account = $accountResult->getData();
  1687. $accountName = isset($account['name']) ? $account['name'] : '';
  1688. }else{
  1689. $account = isset($dbResult['accountList']) ? array_shift($dbResult['accountList']) : [];
  1690. $accountName = isset($account['accountName']) ? $account['accountName'] : '';
  1691. }
  1692. $dbResult['accountName'] = $accountName;//收款账户
  1693. $pbjMPrintNum = new MPrintNum($this->onlineEnterpriseId);
  1694. $dbResult['printingNum'] = $pbjMPrintNum->getObjectPrintNum($dbResult['no'], $dbResult['orderType']);
  1695. return ResultWrapper::success($dbResult);
  1696. }
  1697. /**
  1698. * 检索导出(ES)
  1699. *
  1700. * @param $dsl
  1701. * @return ResultWrapper
  1702. * @throws \Exception
  1703. */
  1704. private function exportSearch($dsl)
  1705. {
  1706. $result = $this->objDOrder->getScrollSearchQueryDsl($dsl);
  1707. if (isset($result['status']) && $result['status'] == 400) {
  1708. return ResultWrapper::fail('获取数据失败' . $result['error']['reason'], ErrorCode::$apiNotResult);
  1709. }
  1710. if (!isset($result['hits']) && $result['hits']['total'] == 0) {
  1711. return ResultWrapper::fail('导出数据为空' . $result['error']['reason'], ErrorCode::$apiNotResult);
  1712. }
  1713. $dbResult = $result['hits']['hits'];
  1714. $list = [];
  1715. foreach ($dbResult as $key => &$value) {
  1716. $data = [];
  1717. $data = $value['_source'];
  1718. $list[] = $data;
  1719. }
  1720. self::exportOrder($list, 'es');
  1721. }
  1722. /**
  1723. * 导出方法
  1724. *
  1725. * @param $allOrderData
  1726. */
  1727. private static function export($allOrderData)
  1728. {
  1729. //导出到本地
  1730. header("Content-type:application/vnd.ms-excel");
  1731. header("Content-Disposition:filename=订单记录.csv");
  1732. header('Cache-Control: max-age=0');
  1733. $fp = fopen('php://output', 'a');
  1734. $head = ['ID', '订单编号', '下单时间', '客户名称', '收货人', '业务员', '联系电话', '订单金额', '订单状态', '收款状态', '配送方式', '订单来源', '订单审核']; //定义标题
  1735. foreach ($head as $i => $v) {
  1736. $head[$i] = mb_convert_encoding($v, 'GBK', 'utf-8'); //将中文标题转换编码,否则乱码
  1737. }
  1738. fputcsv($fp, $head);
  1739. $limit = 10000;
  1740. $num = 0;//计数器
  1741. foreach ($allOrderData as $v) {
  1742. //循环数据
  1743. $num++;
  1744. if ($num == $limit) {
  1745. ob_flush();//释放内存
  1746. flush();
  1747. }
  1748. $rows['id'] = $v['id'];
  1749. $rows['no'] = $v['no'];
  1750. $rows['createTime'] = date('Y-m-d H:i:s', $v['createTime']);
  1751. $rows['customerName'] = $v['customerName'];
  1752. $rows['realName'] = $v['realName'];
  1753. $rows['salesManName'] = $v['salesManName'];
  1754. $rows['mobile'] = $v['mobile'];
  1755. $rows['payAmount'] = $v['payAmount'];
  1756. $rows['orderStatus'] = StatusCode::$orderStatus[$v['orderStatus']];
  1757. $rows['payStatus'] = StatusCode::$standard == $v['payStatus'] ? '已支付' : '未支付';
  1758. $rows['deliveryType'] = ($v['deliveryType'] != StatusCode::$deliveryType['goodsDelivery'] && $v['deliveryType'] != StatusCode::$deliveryType['selfMention']) ? '' : StatusCode::$deliveryType[$v['deliveryType']];
  1759. $rows['source'] = StatusCode::$source[$v['source']];
  1760. $rows['auditStatus'] = StatusCode::$auditStatus[$v['auditStatus']];
  1761. foreach ($rows as $kk => $vv) {
  1762. $rs[$kk] = mb_convert_encoding($vv, 'GBK', 'utf-8'); //转译编码
  1763. }
  1764. fputcsv($fp, $rs);
  1765. $rows = [];
  1766. }
  1767. exit;
  1768. }
  1769. /**
  1770. * 导出列表(数据库)
  1771. *
  1772. * @param string $sql
  1773. * @return ResultWrapper
  1774. * @throws \Exception
  1775. */
  1776. public function exportAllOrder(string $sql)
  1777. {
  1778. $objDOrderIndex = new DOrderIndex();
  1779. $dbResult = $objDOrderIndex->query($sql);
  1780. if ($dbResult === false) {
  1781. return ResultWrapper::fail($objDOrderIndex->error(), ErrorCode::$dberror);
  1782. }
  1783. $allOrderData = [];
  1784. $allGroupData = [];
  1785. foreach ($dbResult as $key => $val) {
  1786. $tableNum = (int)ceil($val['userCenterId'] / $this->cutTable);
  1787. //这里感觉没有必要使用对主索引表的订单id进行分组,可以通过条件直接查询表下的数据
  1788. $allGroupData[$tableNum][] = $val['id'];
  1789. }
  1790. $fields = 'o.id,o.no,o.createTime,o.customerName,o.salesManName,o.payAmount,o.orderStatus,o.payStatus,o.source,o.deliveryType,o.auditStatus,r.realName,r.mobile';
  1791. foreach ($allGroupData as $k => $orderId) {
  1792. $this->objDOrder->setTable('qianniao_order_' . $this->onlineEnterpriseId . '_' . $k);
  1793. $sql = 'SELECT ' . $fields . ' FROM qianniao_order_' . $this->onlineEnterpriseId . '_' . $k . ' AS o LEFT JOIN qianniao_order_receive_' . $this->onlineEnterpriseId . '_' . $k . ' AS r ON o.id=r.orderId WHERE o.id IN(' . implode(',', $orderId) . ') ORDER BY o.createTime DESC';
  1794. $dbResult = $this->objDOrder->query($sql);
  1795. if ($dbResult === false) {
  1796. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  1797. }
  1798. $allOrderData = array_merge($dbResult, $allOrderData);
  1799. }
  1800. self::export($allOrderData);
  1801. }
  1802. /**
  1803. * Doc: (des="订单导出,构建查询数据")
  1804. * User: XMing
  1805. * Date: 2020/8/22
  1806. * Time: 10:25 上午
  1807. * @param array|string $data
  1808. * @param string $field
  1809. * @return ResultWrapper
  1810. */
  1811. private function buildSelectGroupDataByCondition($data, string $field)
  1812. {
  1813. switch ($field) {
  1814. case 'db':
  1815. $result = self::getAllOrderIdsBySql($data);
  1816. break;
  1817. case 'es':
  1818. $result = self::getAllOrderIdsBySearchResult($data);
  1819. break;
  1820. }
  1821. if (!$result->isSuccess()) {
  1822. return ResultWrapper::fail($result->getData(), $result->getErrorCode());
  1823. }
  1824. return ResultWrapper::success($result->getData());
  1825. }
  1826. /**
  1827. * Doc: (des="将es检索数据,进行数据分组转化为统一格式")
  1828. * [[表后缀]=>[订单id,]]
  1829. * User: XMing
  1830. * Date: 2020/8/22
  1831. * Time: 10:15 上午
  1832. * @param array $data
  1833. * @return ResultWrapper
  1834. */
  1835. private function getAllOrderIdsBySearchResult(array $data)
  1836. {
  1837. if (empty($data)) {
  1838. return ResultWrapper::success([]);
  1839. }
  1840. $groupMapRes = self::buildGroupMapByArray((array)$data);
  1841. if (!$groupMapRes->isSuccess()) {
  1842. return ResultWrapper::fail($groupMapRes->getData(), $groupMapRes->getErrorCode());
  1843. }
  1844. return ResultWrapper::success($groupMapRes->getData());
  1845. }
  1846. /**
  1847. * Doc: (des="")
  1848. * User: XMing
  1849. * Date: 2020/8/22
  1850. * Time: 10:18 上午
  1851. * @param array $data
  1852. * @return ResultWrapper
  1853. */
  1854. private function buildGroupMapByArray(array $data)
  1855. {
  1856. if (empty($data)) {
  1857. return ResultWrapper::success([]);
  1858. }
  1859. $allGroupMap = [];
  1860. //对所有数据进行分组,[[表后缀]=>[订单id,]]
  1861. foreach ($data as $key => $val) {
  1862. $tableNum = (int)ceil($val['userCenterId'] / $this->cutTable);
  1863. //这里感觉没有必要使用对主索引表的订单id进行分组,可以通过条件直接查询表下的数据
  1864. $allGroupMap[$tableNum][] = $val['id'];
  1865. }
  1866. return ResultWrapper::success($allGroupMap);
  1867. }
  1868. /**
  1869. * Doc: (des="通过sql,进行数据分组转化为统一格式")
  1870. * [[表后缀]=>[订单id,]]
  1871. * User: XMing
  1872. * Date: 2020/8/22
  1873. * Time: 9:55 上午
  1874. * @param string $sql
  1875. * @return ResultWrapper
  1876. */
  1877. private function getAllOrderIdsBySql(string $sql)
  1878. {
  1879. if (empty($sql)) {
  1880. return ResultWrapper::success([]);
  1881. }
  1882. $list = $this->objDOrderIndex->exportQuery($sql);
  1883. if ($list === false) {
  1884. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  1885. }
  1886. $list = self::getGeneratorData($list);
  1887. if (empty($list)) {
  1888. return ResultWrapper::success([]);
  1889. }
  1890. $groupMapRes = self::buildGroupMapByArray((array)$list);
  1891. if (!$groupMapRes->isSuccess()) {
  1892. return ResultWrapper::fail($groupMapRes->getData(), $groupMapRes->getErrorCode());
  1893. }
  1894. return ResultWrapper::success($groupMapRes->getData());
  1895. }
  1896. /**
  1897. * Doc: (des="获取export查询方法返回的数据集合")
  1898. * User: XMing
  1899. * Date: 2020/8/22
  1900. * Time: 11:42 上午
  1901. * @param $object
  1902. * @return array
  1903. */
  1904. private static function getGeneratorData($object)
  1905. {
  1906. $arrayList = [];
  1907. foreach ($object as $value) {
  1908. $arrayList[] = $value;
  1909. }
  1910. return $arrayList;
  1911. }
  1912. /**
  1913. * Doc: (des="格式化导出数据,统一根据订单id格式化数据")
  1914. * User: XMing
  1915. * Date: 2020/8/22
  1916. * Time: 9:44 上午
  1917. * @param array|string $data
  1918. * @param string $source
  1919. * @return ResultWrapper
  1920. * @throws \Exception
  1921. */
  1922. private function exportOrder($data, string $source)
  1923. {
  1924. if (empty($data)) {
  1925. return ResultWrapper::success([]);
  1926. }
  1927. $groupMapRes = self::buildSelectGroupDataByCondition($data, $source);
  1928. if (!$groupMapRes->isSuccess()) {
  1929. return ResultWrapper::fail($groupMapRes->getData(), $groupMapRes->getErrorCode());
  1930. }
  1931. $groupMap = $groupMapRes->getData();
  1932. if (empty($groupMap)) {
  1933. return ResultWrapper::fail('导出数据构建失败', ErrorCode::$paramError);
  1934. }
  1935. //查询需要导出的数据
  1936. $orderFields = '*';
  1937. $orderReceiveFields = '*';
  1938. $orderGoodsFields = '*';
  1939. $allOrderData = [];//订单集
  1940. $allOrderReceiveData = [];//订单收货地址集
  1941. $allOrderGoodsData = [];//订单商品信息
  1942. foreach ($groupMap as $k => $orderIds) {
  1943. //订单表
  1944. $this->objDOrder->setTable('qianniao_order_' . $this->onlineEnterpriseId . '_' . $k);
  1945. $orderResult = $this->objDOrder->exportSelect(['id' => $orderIds], $orderFields, 'createTime desc');//查询订单
  1946. if ($orderResult === false) {
  1947. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  1948. }
  1949. $orderResult = self::getGeneratorData($orderResult);
  1950. //订单收货表
  1951. $this->objDOrderReceive->setTable('qianniao_order_receive_' . $this->onlineEnterpriseId . '_' . $k);
  1952. $orderReceiveResult = $this->objDOrderReceive->exportSelect(['orderId' => $orderIds], $orderReceiveFields, 'createTime desc');//订单收货
  1953. if ($orderReceiveResult === false) {
  1954. return ResultWrapper::fail($this->objDOrderReceive->error(), ErrorCode::$dberror);
  1955. }
  1956. $orderReceiveResult = self::getGeneratorData($orderReceiveResult);
  1957. //订单商品表
  1958. $this->objDOrderGoods->setTable('qianniao_order_goods_' . $this->onlineEnterpriseId . '_' . $k);
  1959. $orderGoodsResult = $this->objDOrderGoods->exportSelect(['orderId' => $orderIds], $orderGoodsFields, 'createTime desc');
  1960. if ($orderGoodsResult === false) {
  1961. return ResultWrapper::fail($this->objDOrderGoods->error(), ErrorCode::$dberror);
  1962. }
  1963. $orderGoodsResult = self::getGeneratorData($orderGoodsResult);
  1964. //对数据进行合并
  1965. $allOrderData = array_merge($orderResult, $allOrderData);
  1966. $allOrderReceiveData = array_merge($orderReceiveResult, $allOrderReceiveData);
  1967. $allOrderGoodsData = array_merge($orderGoodsResult, $allOrderGoodsData);
  1968. }
  1969. $formatResult = self::formatManageOrderList($allOrderData, $allOrderReceiveData, $allOrderGoodsData);
  1970. if (!$formatResult->isSuccess()) {
  1971. return ResultWrapper::fail($formatResult->getData(), $formatResult->getErrorCode());
  1972. }
  1973. $exportData = $formatResult->getData();
  1974. if (empty($exportData)) {
  1975. return ResultWrapper::fail('构建导出数据为空', ErrorCode::$paramError);
  1976. }
  1977. //将数据导出
  1978. self::exportCsv($exportData);
  1979. }
  1980. /**
  1981. * Doc: (des="")
  1982. * User: XMing
  1983. * Date: 2020/8/22
  1984. * Time: 2:24 下午
  1985. * @param array $area
  1986. * @param string $address
  1987. * @return string
  1988. */
  1989. private static function createAddress($area, $address)
  1990. {
  1991. $str = '';
  1992. if (isset($area['provinceName']) && !empty($area['provinceName'])) {
  1993. $str .= $area['provinceName'];
  1994. }
  1995. if (isset($area['cityName']) && !empty($area['cityName'])) {
  1996. $str .= $area['cityName'];
  1997. }
  1998. if (isset($area['districtName']) && !empty($area['districtName'])) {
  1999. $str .= $area['districtName'];
  2000. }
  2001. $str .= $address;
  2002. return $str;
  2003. }
  2004. /**
  2005. * Doc: (des="生成规格名字")
  2006. * User: XMing
  2007. * Date: 2020/8/22
  2008. * Time: 2:47 下午
  2009. * @param array $specGroup
  2010. * @return string
  2011. */
  2012. private static function createSpecName($specGroup)
  2013. {
  2014. if(empty($specGroup)){
  2015. return "无";
  2016. }
  2017. $str = '';
  2018. foreach ($specGroup as $value) {
  2019. empty($str) && $str .= ' ';
  2020. $str .= $value['specName'] . ':';
  2021. $str .= $value['specValueName'];
  2022. }
  2023. return $str;
  2024. }
  2025. /**
  2026. * Doc: (des="将数据导出到表格")
  2027. * User: XMing
  2028. * Date: 2020/8/22
  2029. * Time: 11:09 上午
  2030. * @param array $data
  2031. */
  2032. private function exportCsv(array $data)
  2033. {
  2034. //导出到本地
  2035. header("Content-type:application/vnd.ms-excel");
  2036. header("Content-Disposition:filename=订单记录.csv");
  2037. header('Cache-Control: max-age=0');
  2038. $fp = fopen('php://output', 'a');
  2039. $head = ['ID', '订单编号', '订单金额', '优惠金额', '付款金额', '订单状态', '支付方式', '付款状态','配送方式','订单来源','审核状态','下单时间','客户名称','收货人','收货人电话','收货人地址','所属店铺', '业务员','件数','商品编码','商品名称','单位','属性','数量','销售单价(元)','销售总价'];//定义标题
  2040. foreach ($head as $i => $v) {
  2041. $head[$i] = mb_convert_encoding($v, 'GBK', 'utf-8'); //将中文标题转换编码,否则乱码
  2042. }
  2043. fputcsv($fp, $head);
  2044. $limit = 10000;
  2045. $num = 0;//计数器
  2046. $rows = [];
  2047. foreach ($data as $v) {
  2048. //循环数据
  2049. $num++;
  2050. if ($num == $limit) {
  2051. ob_flush();//释放内存
  2052. flush();
  2053. }
  2054. foreach ($v['goodsData'] as $index => $item) {
  2055. self::buildExportData($rows, $v, $item, $index);
  2056. foreach ($rows as $kk => $vv) {
  2057. $rs[$kk] = mb_convert_encoding($vv, 'GBK', 'utf-8'); //转译编码
  2058. }
  2059. fputcsv($fp, $rs);
  2060. $rows = [];
  2061. }
  2062. }
  2063. exit;
  2064. }
  2065. /**
  2066. * Doc: (des="")
  2067. * User: XMing
  2068. * Date: 2020/8/22
  2069. * Time: 3:28 下午
  2070. * @param array $rows
  2071. * @param array $v
  2072. * @param array $item
  2073. * @param int $index
  2074. */
  2075. private static function buildExportData(&$rows, array $v, array $item, int $index)
  2076. {
  2077. $rows['id'] = '';
  2078. $rows['no'] = '';
  2079. $rows['totalMoney'] = '';
  2080. $rows['subMoney'] = '';
  2081. $rows['payMoney'] = '';
  2082. $rows['orderMsg'] = '';
  2083. $rows['payTypeMsg'] = '';
  2084. $rows['payMsg'] = '';
  2085. $rows['deliveryMsg'] = '';
  2086. $rows['sourceMsg'] = '';
  2087. $rows['auditMsg'] = '';
  2088. $rows['createTime'] = '';
  2089. $rows['customerName'] = '';
  2090. $rows['receiveName'] = '';
  2091. $rows['receiveMobile'] = '';
  2092. $rows['receiveAddress'] = '';
  2093. $rows['shopName'] = '';
  2094. $rows['salesManName'] = '';
  2095. $rows['otherNum'] = '';
  2096. $rows['id'] = $v['id'];
  2097. $rows['no'] = $v['no'];
  2098. $rows['totalMoney'] = $v['totalMoney'];
  2099. $rows['subMoney'] = bcsub($v['payAmount'], $v['totalMoney'], 2);
  2100. $rows['payMoney'] = $v['payAmount'];
  2101. $rows['orderMsg'] = $v['orderMsg'];
  2102. $rows['payTypeMsg'] = $v['payTypeMsg'];
  2103. $rows['payMsg'] = $v['payMsg'];
  2104. $rows['deliveryMsg'] = $v['deliveryMsg'];
  2105. $rows['sourceMsg'] = $v['sourceMsg'];
  2106. $rows['auditMsg'] = $v['auditMsg'];
  2107. $rows['createTime'] = date('Y-m-d H:i:s', $v['createTime']);
  2108. $rows['customerName'] = $v['customerName'];
  2109. $rows['receiveName'] = $v['receiveData']['realName'];
  2110. $rows['receiveMobile'] = $v['receiveData']['mobile'];
  2111. $rows['receiveAddress'] = self::createAddress($v['receiveData']['area'], $v['receiveData']['address']);
  2112. $rows['shopName'] = $v['shopName'];
  2113. $rows['salesManName'] = $v['salesManName'];
  2114. $rows['goodsCode'] = $item['goodsCode'];
  2115. $rows['goodsName'] = $item['goodsName'];
  2116. $rows['unitName'] = $item['unitName'];
  2117. $rows['specName'] = self::createSpecName((isset($item['specGroup']) && !empty($item['specGroup'])) ? json_decode($item['specGroup'], true) : []);
  2118. $rows['buyNum'] = $item['buyNum'];
  2119. $rows['unitPrice'] = $item['price'];
  2120. $rows['totalPrice'] = $item['totalMoney'];
  2121. $rows['otherNum'] = $item['otherNum'];
  2122. }
  2123. /**
  2124. * 获取所有订单
  2125. *
  2126. * @param $selectParams
  2127. * @param $search
  2128. * @param bool $is_export
  2129. * @return ResultWrapper
  2130. * @throws \Exception
  2131. * @waitAudit:等待审核 orderStatus != 6 auditStatus = 1
  2132. * @waitOutStock:待出库 orderStatus != 6 auditPass = 2
  2133. * @hasOutStock:已出库 orderStatus = 4 auditPass = 2
  2134. * @finish:已完成 orderStatus = 5 auditPass 2
  2135. * @close:已关闭 orderStatus = 6
  2136. *
  2137. * 新订单列表 {"page":1,"pageSize":10,"search":{"auditStatus":1}}
  2138. * 订单查询 {"page":1,"pageSize":10,"search":{"auditStatus":2}} 订单查询:此页面只展示新订单审核后的订单,订单状态为【待出库】,订单出库后,页面会显示出【确认收货】的按钮,订单在出库管理进行出库后,订单状态为【已出库】,客户或后台操作【确认收货】后,订单状态为【已完成】。
  2139. * 自提订单 {"page":1,"pageSize":10,"search":{"deliveryType":2}}
  2140. * 取消订单 {"page":1,"pageSize":10,"search":{"orderStatus":6}}
  2141. *
  2142. */
  2143. public function getAllOrder($selectParams, $search, $is_export = false)
  2144. {
  2145. $objDOrderIndex = new DOrderIndex();
  2146. $selectParams = array_merge($selectParams, $search);
  2147. // 组装检索sql语句
  2148. $buildSql = self::setOrderStatusSqlAttr($selectParams);
  2149. $sql = $buildSql['sql'];
  2150. if ($is_export === true) self::exportOrder($sql, 'db');//导出数据
  2151. $total = $objDOrderIndex->query($buildSql['countSql']);
  2152. if (isset($selectParams['limit']) && isset($selectParams['offset'])) {
  2153. $sql .= ' limit ' . $selectParams['offset'] . ',' . $selectParams['limit'];
  2154. }
  2155. $dbResult = $objDOrderIndex->query($sql);
  2156. if ($dbResult === false) {
  2157. return ResultWrapper::fail($objDOrderIndex->error(), ErrorCode::$dberror);
  2158. }
  2159. $allOrderData = [];//订单集
  2160. $allOrderReceiveData = [];//订单收货地址集
  2161. $allGroupData = [];
  2162. if (!empty($dbResult)) {
  2163. foreach ($dbResult as $key => $val) {
  2164. $tableNum = ceil($val['userCenterId'] / $this->cutTable);
  2165. $allGroupData[$tableNum][] = $val['id'];
  2166. }
  2167. foreach ($allGroupData as $k => $orderId) {
  2168. $this->objDOrder->setTable('qianniao_order_' . $this->onlineEnterpriseId . '_' . $k);
  2169. $dbResult = $this->objDOrder->select(['id' => $orderId], '*', 'createTime desc');//查询订单
  2170. if ($dbResult === false) {
  2171. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  2172. }
  2173. //物流信息展示
  2174. if( !empty($dbResult['logisticsData']) ){
  2175. json_decode($dbResult['logisticsData'],true);
  2176. }
  2177. $this->objDOrderReceive->setTable('qianniao_order_receive_' . $this->onlineEnterpriseId . '_' . $k);
  2178. $orderReceiveResult = $this->objDOrderReceive->select(['orderId' => $orderId], '*', 'createTime desc');//订单收货
  2179. if ($orderReceiveResult === false) {
  2180. return ResultWrapper::fail($this->objDOrderReceive->error(), ErrorCode::$dberror);
  2181. }
  2182. $allOrderData = array_merge($dbResult, $allOrderData);//订单集
  2183. $allOrderReceiveData = array_merge($orderReceiveResult, $allOrderReceiveData);//订单收货地址集
  2184. }
  2185. }
  2186. // 格式化后台订单列表
  2187. $formatResult = self::formatManageOrderList($allOrderData, $allOrderReceiveData);
  2188. if (!$formatResult->isSuccess()) {
  2189. return ResultWrapper::fail($formatResult->getData(), $formatResult->getErrorCode());
  2190. }
  2191. $return = [
  2192. 'data' => $formatResult->getData(),
  2193. 'total' => isset($total[0]['total']) ? $total[0]['total'] : 0,
  2194. ];
  2195. return ResultWrapper::success($return);
  2196. }
  2197. /**
  2198. * Doc: (des="获取检索订单数据")
  2199. *订单列表搜索商品名称、商品编码、收货人、电话
  2200. * @waitAudit:等待审核 orderStatus != 6 auditStatus = 1
  2201. * @waitOutStock:待出库 orderStatus != 6 auditPass = 2
  2202. * @hasOutStock:已出库 orderStatus = 4 auditPass = 2
  2203. * @finish:已完成 orderStatus = 5 auditPass 2
  2204. * @close:已关闭 orderStatus = 6
  2205. * @param $export
  2206. * @param $selectParams
  2207. */
  2208. public function keywordSearch($selectParams,$export = '')
  2209. {
  2210. // 组装检索sql
  2211. $whereSql = '';
  2212. if(!empty($selectParams['keywordType']) && !empty($selectParams['keyword'])){
  2213. $whereSql = self::assemblySql($selectParams['keywordType'],$selectParams['keyword']);
  2214. }
  2215. $orderTab ='qianniao_order_'.$this->onlineEnterpriseId.'_'.'1';
  2216. $orderGoodsTab ='qianniao_order_goods_'.$this->onlineEnterpriseId.'_'.'1';
  2217. $orderReceive ='qianniao_order_receive_'.$this->onlineEnterpriseId.'_'.'1';
  2218. // 初始化表
  2219. $this->objDOrder->setTable($orderTab);
  2220. $this->objDOrder->setTable($orderGoodsTab);
  2221. $this->objDOrder->setTable($orderReceive);
  2222. $condition = '';
  2223. $limit = '';
  2224. if(!$export){
  2225. if (isset($selectParams['limit']) && isset($selectParams['offset'])) {
  2226. $limit .= ' limit ' . $selectParams['offset'] . ',' . $selectParams['limit'];
  2227. }
  2228. }
  2229. // 时间筛选
  2230. if (isset($selectParams['startTime']) && !empty($selectParams['startTime'])){
  2231. $condition .= ' AND o.createTime BETWEEN '.$selectParams['startTime'].' AND '.$selectParams['endTime'];
  2232. }
  2233. //userCenterId
  2234. if (isset($selectParams['userCenterId']) && !empty($selectParams['userCenterId'])) {
  2235. $condition .= ' and o.userCenterId = ' . $selectParams['userCenterId'];
  2236. }
  2237. //customerId
  2238. if (isset($selectParams['customerId']) && !empty($selectParams['customerId'])) {
  2239. $condition .= ' and o.customerId = ' . $selectParams['customerId'];
  2240. }
  2241. //shopId
  2242. if (isset($selectParams['shopId']) && !empty($selectParams['shopId'])) {
  2243. $condition .= ' and o.shopId = ' . $selectParams['shopId'];
  2244. }
  2245. // 付款状态 支付状态 默认4 未支付 5已支付
  2246. if (isset($selectParams['payStatus']) && !empty($selectParams['payStatus'])) {
  2247. $condition .= ' and o.payStatus = ' . $selectParams['payStatus'];
  2248. }
  2249. //支付方式
  2250. if (isset($selectParams['payType']) && !empty($selectParams['payType'])) {
  2251. $condition .= ' and find_in_set('.$selectParams['payType'].',o.payType) ';
  2252. }
  2253. // 客户类型
  2254. if (isset($selectParams['customerType']) && !empty($selectParams['customerType'])){
  2255. $condition .= ' AND o.customerType = '.$selectParams['customerType'];
  2256. }
  2257. // 订单来源 订单来源 默认1 ios 2android 3小程序 4后台创建
  2258. if (isset($selectParams['source']) && !empty($selectParams['source'])){
  2259. $condition .= ' AND o.source = '.$selectParams['source'];
  2260. }
  2261. //出库状态
  2262. if (isset($selectParams['outStatus']) && !empty($selectParams['outStatus'])) {
  2263. $condition .= ' and o.outStatus = ' . $selectParams['outStatus'];
  2264. }
  2265. //退货状态
  2266. if (isset($selectParams['returnStatus']) && !empty($selectParams['returnStatus'])) {
  2267. if (is_array($selectParams['returnStatus'])) {
  2268. $returnStatusStr = implode(',', $selectParams['returnStatus']);
  2269. $condition .= ' and o.returnStatus in(' . $returnStatusStr . ') ';
  2270. } else {
  2271. $condition .= ' and o.returnStatus = ' . $selectParams['returnStatus'];
  2272. }
  2273. }
  2274. //订单状态
  2275. if (isset($selectParams['state']) && !empty($selectParams['state'])) {
  2276. $condition = self::orderStateSql($condition, $selectParams['state']);
  2277. }
  2278. if($export){
  2279. $sql ='SELECT o.*,g.goodsCode,g.goodsName,g.unitName,g.specGroup,g.buyNum,g.price,g.otherNum,g.preferential,g.totalMoney,r.realName, r.mobile,r.provinceCode,r.cityCode,r.districtCode,r.address FROM '.$orderTab.' AS o LEFT JOIN '.$orderGoodsTab.' as g ON o.id =g.orderId LEFT JOIN '.$orderReceive.' AS r on o.id= r.orderId WHERE o.deleteStatus='.StatusCode::$standard.$whereSql.$condition.' order by o.id desc ';
  2280. $orderGoodsData = $this->objDOrder->exportQuery($sql);
  2281. if ($orderGoodsData === false) {
  2282. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  2283. }
  2284. $result = self::exportOrderList($orderGoodsData);
  2285. exit;
  2286. }
  2287. $sql ='SELECT o.* FROM '.$orderTab.' AS o LEFT JOIN '.$orderGoodsTab.' as g ON o.id =g.orderId LEFT JOIN '.$orderReceive.' AS r on o.id= r.orderId WHERE o.deleteStatus='.StatusCode::$standard.$whereSql.$condition.' GROUP BY o.id order by o.createTime desc '.$limit;
  2288. $dbResult = $this->objDOrder->query($sql);
  2289. if ($dbResult === false) {
  2290. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  2291. }
  2292. // 格式化后台订单列表
  2293. $formatResult = self::formatManageOrderList($dbResult,[]);
  2294. if (!$formatResult->isSuccess()) {
  2295. return ResultWrapper::fail($formatResult->getData(), $formatResult->getErrorCode());
  2296. }
  2297. $sqlTotal ='SELECT count( DISTINCT o.id) as total FROM '.$orderTab.' AS o LEFT JOIN '.$orderGoodsTab.' as g ON o.id =g.orderId LEFT JOIN '.$orderReceive.' AS r on o.id= r.orderId WHERE o.deleteStatus='.StatusCode::$standard.$whereSql.$condition;
  2298. $total = $this->objDOrder->query($sqlTotal);
  2299. if ($total === false) {
  2300. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  2301. }
  2302. $return = [
  2303. 'data' => $formatResult->getData(),
  2304. 'total' => isset($total[0]['total']) ? $total[0]['total'] : 0,
  2305. ];
  2306. return ResultWrapper::success($return);
  2307. }
  2308. /**
  2309. * 获取检索订单数据导出
  2310. * @param $orderListData
  2311. * @return ResultWrapper
  2312. */
  2313. public function exportOrderList($orderListData)
  2314. {
  2315. //导出到本地
  2316. header("Content-type:application/vnd.ms-excel");
  2317. header("Content-Disposition:filename=订单管理.csv");
  2318. header('Cache-Control: max-age=0');
  2319. $fp = fopen('php://output', 'a');
  2320. $head = ['ID', '订单编号', '订单金额', '订单金额', '付款金额', '订单状态', '支付方式', '付款状态','配送方式','订单来源','审核状态','下单时间','客户名称','收货人','收货人电话','收货人地址','所属店铺', '业务员','件数','商品编码','商品名称','单位','属性','数量','销售单价(元)','优惠金额','销售总价'];//定义标题
  2321. foreach ($head as $i => $v) {
  2322. $head[$i] = mb_convert_encoding($v, 'GBK', 'utf-8'); //将中文标题转换编码,否则乱码
  2323. }
  2324. fputcsv($fp, $head);
  2325. $limit = 10000;
  2326. $num = 0;//计数器
  2327. foreach ($orderListData as $value) {//循环数据
  2328. $orderReceiveData[]= [
  2329. 'orderId' => $value['id'],
  2330. 'provinceCode' => $value['provinceCode'],
  2331. 'cityCode' => $value['cityCode'],
  2332. 'districtCode' => $value['districtCode'],
  2333. 'allAddress' => $value['allAddress']
  2334. ];
  2335. // 格式化后台订单列表
  2336. $fromatValue = self::formatManageOrderList([$value],$orderReceiveData);
  2337. if (!$fromatValue->isSuccess()) {
  2338. echo($fromatValue->getData());
  2339. exit();
  2340. }
  2341. $fromatValue = array_pop($fromatValue->getData());
  2342. $value = array_merge($value, $fromatValue);
  2343. $num++;
  2344. if ($num == $limit) {
  2345. ob_flush();//释放内存
  2346. flush();
  2347. }
  2348. $rows['id'] = isset($value['id']) ? $value['id'] : null; // ID
  2349. $rows['no'] = isset($value['no']) ? $value['no'] : null; // 订单编号
  2350. $rows['totalMoney'] = isset($value['totalMoney']) ? $value['totalMoney'] : null; // 订单金额
  2351. $rows['subMoney'] = isset($value['payAmount']) && isset($value['totalMoney']) ? bcsub($value['payAmount'], $value['totalMoney'], 2): 0; // 订单金额
  2352. $rows['payAmount'] = isset($value['payAmount']) ? $value['payAmount'] : null; // 付款金额
  2353. $rows['orderMsg'] = isset($value['orderMsg']) ? $value['orderMsg'] : null; // 订单状态
  2354. $rows['payTypeMsg'] = isset($value['payTypeMsg']) ? $value['payTypeMsg'] : null; // 支付方式
  2355. $rows['payMsg'] = isset($value['payMsg']) ? $value['payMsg'] : null; // 付款状态
  2356. $rows['deliveryMsg'] = isset($value['deliveryMsg']) ? $value['deliveryMsg'] : null; // 配送方式
  2357. $rows['sourceMsg'] = isset($value['sourceMsg']) ? $value['sourceMsg'] : null; // 订单来源
  2358. $rows['auditMsg'] = isset($value['auditMsg']) ? $value['auditMsg'] : null; // 审核状态
  2359. $rows['createTime'] = isset( $value['createTime']) ? date('Y-m-d H:i:s', $value['createTime']) : null; // 下单时间
  2360. $rows['customerName'] = isset($value['customerName']) ? $value['customerName'] : null; // 客户名称
  2361. $rows['receiveName'] = isset($value['realName']) ? $value['realName']: null; // 收货人
  2362. $rows['receiveMobile'] = isset($value['mobile']) ? $value['mobile'] : null; // 收货人电话
  2363. $rows['receiveAddress'] = isset($value['receiveData']['allAddress']) ? $value['receiveData']['allAddress'] : null;// '收货人地址'
  2364. $rows['shopName'] = isset($value['shopName']) ? $value['shopName'] : null; // ,'所属店铺',
  2365. $rows['salesManName'] = isset($value['salesManName']) ? $value['salesManName'] : null; // '业务员'
  2366. $rows['otherNum'] = getArrayItem($value, 'otherNum', 0); //件数
  2367. $rows['goodsCode'] = getArrayItem($value, 'goodsCode'); // '商品编码'
  2368. $rows['goodsName'] = getArrayItem($value, 'goodsName'); // '商品名称
  2369. $rows['unitName'] = getArrayItem($value, 'unitName'); // 单位
  2370. $rows['specName'] = self::createSpecName((isset($value['specGroup']) && !empty($value['specGroup'])) ? json_decode($value['specGroup'], true) : []);
  2371. $rows['buyNum'] = getArrayItem($value, 'buyNum', 0);
  2372. $rows['unitPrice'] = getArrayItem($value, 'price', 0);
  2373. $rows['preferential'] = getArrayItem($value, 'preferential', 0);
  2374. $rows['totalPrice'] = getArrayItem($value, 'totalMoney', 0); // '销售单价(元)'
  2375. foreach ($rows as $kk => $vv) {
  2376. $rs[$kk] = mb_convert_encoding($vv, 'GBK', 'utf-8'); //转译编码
  2377. }
  2378. fputcsv($fp, $rs);
  2379. $rows = [];
  2380. }
  2381. }
  2382. /**
  2383. * 根据订单列表 keywordType 拼装sql
  2384. * @param $keywordType
  2385. * @param $keyword
  2386. */
  2387. public function assemblySql($keywordType,$keyword)
  2388. {
  2389. $whereSql = '';
  2390. switch ($keywordType){
  2391. case 1: // 单据编号 order
  2392. if(strpos($keyword,StatusCode::$noPrefix[1]) !== false){
  2393. $orderNo = explode('-',$keyword);
  2394. if(count($orderNo)==3){
  2395. $orderNo = $orderNo[1].'-'.$orderNo[2];
  2396. }elseif(count($orderNo)==2){
  2397. $orderNo = $orderNo[1];
  2398. }else{
  2399. $orderNo = $keyword;
  2400. }
  2401. $whereSql .= ' and o.no = "'.$orderNo.'"';
  2402. }else{
  2403. $whereSql .= ' and o.no = "'.$keyword.'"';
  2404. }
  2405. break;
  2406. case 2: // 自提码 order
  2407. $whereSql .= ' and o.verifyCode ="'.$keyword.'"';
  2408. break;
  2409. case 3: // 商品名称 order_goods
  2410. $whereSql .=' and g.goodsName LIKE "%' .$keyword. '%" ';
  2411. break;
  2412. case 4: // 商品编码 order_goods
  2413. $whereSql .=' and g.goodsCode ="'.$keyword.'"';
  2414. break;
  2415. case 5: // 收货人 order_receive
  2416. $whereSql .=' and r.realName LIKE "%' .$keyword. '%" ';
  2417. break;
  2418. case 6: // 电话 order_receive
  2419. $whereSql .=' and r.mobile ="'.$keyword.'"';
  2420. break;
  2421. case 7: // 业务员 order
  2422. $whereSql .=' and o.salesManName LIKE "%' .$keyword. '%" ';
  2423. break;
  2424. case 8: // 详细地址 order_receive
  2425. $whereSql .=' and r.address LIKE "%' .$keyword. '%" ';
  2426. }
  2427. return $whereSql;
  2428. }
  2429. /**
  2430. * Doc: (des="state标示多选sql处理")
  2431. *
  2432. */
  2433. private static function orderStateSql($sql, $states)
  2434. {
  2435. if (is_array($states)) {
  2436. if (in_array('all', $states)) {
  2437. return $sql;
  2438. }
  2439. foreach ($states as $index => $state) {
  2440. $sql .= $index == 0 ? ' and (' . self::orderstate($state) : ' or ' . self::orderstate($state);
  2441. }
  2442. $sql .= ') ';
  2443. } else {
  2444. if ($states == 'all') {
  2445. return $sql;
  2446. }
  2447. $stateSql = self::orderstate($states);
  2448. if (!empty($stateSql)) {
  2449. $sql .= ' and ' . self::orderstate($states);
  2450. }
  2451. }
  2452. return $sql;
  2453. }
  2454. /**
  2455. * Doc: (des="state标示对应sql")
  2456. */
  2457. private static function orderstate($state)
  2458. {
  2459. $sql = '';
  2460. switch ($state) {
  2461. case 'waitAudit'://待审核
  2462. $sql .= ' (o.auditStatus = ' . StatusCode::$auditStatus['auditing'] . ' and o.orderStatus != ' . StatusCode::$orderStatus['close'] . ')';
  2463. break;
  2464. case 'waitOutStock'://待出库
  2465. $sql .= ' (o.auditStatus = ' . StatusCode::$auditStatus['auditPass'] . ' and (o.orderStatus = ' . StatusCode::$orderStatus['waitPay'] . ' or orderStatus = ' . StatusCode::$orderStatus['waitDelivery'] . ')) ';
  2466. break;
  2467. case 'hasOutStock'://已出库
  2468. $sql .= ' (o.auditStatus = ' . StatusCode::$auditStatus['auditPass'] . ' and o.orderStatus = ' . StatusCode::$orderStatus['waitReceive'] . ')';
  2469. break;
  2470. case 'finish'://已完成
  2471. $sql .= ' (o.auditStatus = ' . StatusCode::$auditStatus['auditPass'] . ' and o.orderStatus = ' . StatusCode::$orderStatus['finish'] . ')';
  2472. break;
  2473. case 'close'://已关闭
  2474. $sql .= ' (o.orderStatus = ' . StatusCode::$orderStatus['close'] . ')';
  2475. break;
  2476. case 'all'://全部订单
  2477. break;
  2478. }
  2479. return $sql;
  2480. }
  2481. /**
  2482. * Doc: (des="格式化后台订单列表")
  2483. * User: XMing
  2484. * Date: 2020/7/11
  2485. * Time: 5:02 下午
  2486. * @param array $orderData
  2487. * @param array $orderReceiveData
  2488. * @param array $orderGoodsData
  2489. * @return ResultWrapper
  2490. */
  2491. public function formatManageOrderList(array $orderData, array $orderReceiveData, array $orderGoodsData = [])
  2492. {
  2493. $returnData = [];
  2494. if (empty($orderData)) {
  2495. return ResultWrapper::success($returnData);
  2496. }
  2497. $receiveMap = [];
  2498. if (!empty($orderReceiveData)) {
  2499. $orderReceiveData = self::formatSysArea($orderReceiveData);// 订单收货地址集渲染
  2500. foreach ($orderReceiveData as $key => &$item) {
  2501. $receiveMap[$item['orderId']] = [
  2502. 'customerId' => getArrayItem($item, 'customerId', 0),
  2503. 'address' => getArrayItem($item, 'address'),
  2504. 'allAddress' => $item['area']['provinceName'].$item['area']['cityName'].$item['area']['districtName'].getArrayItem($item, 'address'),
  2505. 'realName' => getArrayItem($item, 'realName'),
  2506. 'mobile' => getArrayItem($item, 'mobile'),
  2507. 'area' => getArrayItem($item, 'area', [])
  2508. ];
  2509. }
  2510. unset($item);
  2511. }
  2512. $orderData = self::formatOrderStatus($orderData); // 格式化订单状态
  2513. $goodsMap = [];
  2514. if (!empty($orderGoodsData)) {
  2515. foreach ($orderGoodsData as $key => $item) {
  2516. $goodsMap[$item['orderId']][] = $item;
  2517. }
  2518. }
  2519. unset($item);
  2520. // 映射下打印次数
  2521. $allOrderNos = [];
  2522. foreach ($orderData as $key => $value){
  2523. $allOrderNos[] = $value['no'];
  2524. }
  2525. $pbjMPrintNum = new MPrintNum($this->onlineEnterpriseId);
  2526. $printNumData = $pbjMPrintNum->getObjectPrintNumByNos($allOrderNos); // 批量获取打印次数
  2527. $orderNoBindPritNum = [];
  2528. if(!empty($printNumData)){
  2529. foreach ($printNumData as $key => $value){
  2530. $orderNoBindPritNum[$value['objectNo']] = $value['printNum'];
  2531. }
  2532. }
  2533. foreach ($orderData as $key => $datum) {
  2534. $returnData[$key] = [
  2535. 'id' => $datum['id'],
  2536. 'no' => self::formatSn($datum['no']),
  2537. 'shopId' => $datum['shopId'],
  2538. 'shopName' => isset($datum['shopName']) ? $datum['shopName'] : '',
  2539. 'customerId' => $datum['customerId'],
  2540. 'customerName' => $datum['customerName'],
  2541. 'userCenterId' => $datum['userCenterId'],
  2542. 'payAmount' => $datum['payAmount'],
  2543. 'retMoney' => $datum['retMoney'],
  2544. 'totalMoney' => $datum['totalMoney'],
  2545. 'payStatus' => $datum['payStatus'],
  2546. 'auditStatus' => $datum['auditStatus'],
  2547. 'returnStatus' => $datum['returnStatus'],
  2548. 'outStatus' => $datum['outStatus'],
  2549. 'deliveryType' => $datum['deliveryType'],
  2550. 'payType' => $datum['payType'],
  2551. 'salesManName' => empty($datum['salesManName']) ? '' : $datum['salesManName'],
  2552. 'salesman' => !isset($datum['salesman']) || is_null($datum['salesman']) ? '' : $datum['salesman'],
  2553. 'salesManId' => $datum['salesManId'],
  2554. 'createTime' => $datum['createTime'],
  2555. 'source' => $datum['source'],
  2556. 'orderStatus' => $datum['orderStatus'],
  2557. 'receiveData' => isset($receiveMap[$datum['id']]) ? $receiveMap[$datum['id']] : [],
  2558. 'orderMsg' => $datum['orderMsg'],
  2559. 'payMsg' => $datum['payMsg'],
  2560. 'deliveryMsg' => $datum['deliveryMsg'],
  2561. 'payTypeMsg' => $datum['payTypeMsg'],
  2562. 'sourceMsg' => $datum['sourceMsg'],
  2563. 'auditMsg' => $datum['auditMsg'],
  2564. 'extends' => json_decode($datum['extends'],true),
  2565. 'printingNum' => getArrayItem($orderNoBindPritNum, $datum['no'], 0),
  2566. ];
  2567. if (!empty($orderGoodsData)) {
  2568. $returnData[$key]['goodsData'] = isset($goodsMap[$datum['id']]) ? $goodsMap[$datum['id']] : [];
  2569. }
  2570. }
  2571. return ResultWrapper::success($returnData);
  2572. }
  2573. private static function formatSn($no): string
  2574. {
  2575. return StatusCode::$noPrefix[StatusCode::$orderType['saleOrder']].'-'.$no;
  2576. }
  2577. /**
  2578. * Doc: (des="订单查询index表 sql生成")
  2579. * User: XMing
  2580. * Date: 2020/7/11
  2581. * Time: 11:23 上午
  2582. * @waitAudit:等待审核 orderStatus != 6 auditStatus = 1
  2583. * @waitOutStock:待出库 orderStatus != 6 auditPass = 2
  2584. * @hasOutStock:已出库 orderStatus = 4 auditPass = 2
  2585. * @finish:已完成 orderStatus = 5 auditPass 2
  2586. * @close:已关闭 orderStatus = 6
  2587. * @param array $selectParams
  2588. * @return array
  2589. */
  2590. public function setOrderStatusSqlAttr(array $selectParams): array
  2591. {
  2592. $fields = 'id,userCenterId,no,customerId';
  2593. $countFields = ' COUNT(id) AS total ';
  2594. //订单类型
  2595. $whereSql = '';
  2596. if (isset($selectParams['orderType']) && !empty($selectParams['orderType'])) {
  2597. if (is_array($selectParams['orderType'])) {
  2598. $orderTypeStr = implode(',', $selectParams['orderType']);
  2599. $whereSql .= ' and orderType in(' . $orderTypeStr . ') ';
  2600. } else {
  2601. $whereSql .= ' and orderType = ' . $selectParams['orderType'];
  2602. }
  2603. } else {
  2604. $whereSql .= ' and orderType = ' . StatusCode::$orderType['saleOrder'];
  2605. }
  2606. if (isset($selectParams['keyword']) && !empty($selectParams['keyword'])){
  2607. if (strstr($selectParams['keyword'],StatusCode::$noPrefix['1'])){
  2608. $selectParams['keyword']= substr($selectParams['keyword'],strlen(StatusCode::$noPrefix[StatusCode::$orderType['saleOrder']])+1);
  2609. }
  2610. $keyword = '"%'.$selectParams['keyword'].'%"';
  2611. $whereSql .= ' and no LIKE '.$keyword.' or verifyCode LIKE '.$keyword;
  2612. }
  2613. if (isset($selectParams['orderType']) && $selectParams['orderType'] == StatusCode::$orderType['cashierOrder']) {
  2614. $selectParams['cashierUid'] = $this->onlineUserId;
  2615. }
  2616. if (isset($selectParams['isAll']) && $selectParams['isAll'] == StatusCode::$standard) {
  2617. unset($selectParams['cashierUid']);
  2618. }
  2619. //userCenterId
  2620. if (isset($selectParams['userCenterId']) && !empty($selectParams['userCenterId'])) {
  2621. $whereSql .= ' and userCenterId = ' . $selectParams['userCenterId'];
  2622. }
  2623. //customerId
  2624. if (isset($selectParams['customerId']) && !empty($selectParams['customerId'])) {
  2625. $whereSql .= ' and customerId = ' . $selectParams['customerId'];
  2626. }
  2627. //收银员id
  2628. if (isset($selectParams['cashierStaffId']) && !empty($selectParams['cashierStaffId'])) {
  2629. $whereSql .= ' and cashierStaffId = ' . $selectParams['cashierStaffId'];
  2630. }
  2631. //no
  2632. if (isset($selectParams['no']) && !empty($selectParams['no'])) {
  2633. $whereSql .= ' and no = "' . $selectParams['no'].'"';
  2634. }
  2635. //shopId
  2636. if (isset($selectParams['shopId']) && !empty($selectParams['shopId'])) {
  2637. $whereSql .= ' and shopId = ' . $selectParams['shopId'];
  2638. }
  2639. //收银员id
  2640. if (isset($selectParams['cashierUid']) && !empty($selectParams['cashierUid'])) {
  2641. $whereSql .= ' and cashierUid = ' . $selectParams['cashierUid'];
  2642. }
  2643. //审核状态
  2644. if (isset($selectParams['auditStatus']) && !empty($selectParams['auditStatus'])) {
  2645. $whereSql .= ' and auditStatus = ' . $selectParams['auditStatus'];
  2646. }
  2647. //出库状态
  2648. if (isset($selectParams['outStatus']) && !empty($selectParams['outStatus'])) {
  2649. $whereSql .= ' and outStatus = ' . $selectParams['outStatus'];
  2650. }
  2651. //退货状态
  2652. if (isset($selectParams['returnStatus']) && !empty($selectParams['returnStatus'])) {
  2653. if (is_array($selectParams['returnStatus'])) {
  2654. $returnStatusStr = implode(',', $selectParams['returnStatus']);
  2655. $whereSql .= ' and returnStatus in(' . $returnStatusStr . ') ';
  2656. } else {
  2657. $whereSql .= ' and returnStatus = ' . $selectParams['returnStatus'];
  2658. }
  2659. }
  2660. //配送方式
  2661. if (isset($selectParams['deliveryType']) && !empty($selectParams['deliveryType'])) {
  2662. $whereSql .= ' and deliveryType = ' . $selectParams['deliveryType'];
  2663. }
  2664. //支付方式
  2665. if (isset($selectParams['payType']) && !empty($selectParams['payType'])) {
  2666. $whereSql .= ' and find_in_set('.$selectParams['payType'].',payType) ';
  2667. }
  2668. if (isset($selectParams['startTime']) && !empty($selectParams['startTime'])){
  2669. $whereSql .= ' AND createTime BETWEEN '.$selectParams['startTime'].' AND '.$selectParams['endTime'];
  2670. }
  2671. if (isset($selectParams['source']) && !empty($selectParams['source'])){
  2672. $whereSql .= ' AND source = '.$selectParams['source'];
  2673. }
  2674. if (isset($selectParams['salesManId']) && !empty($selectParams['salesManId'])){
  2675. $whereSql .= ' AND salesManId = '.$selectParams['salesManId'];
  2676. }
  2677. if (isset($selectParams['customerType']) && !empty($selectParams['customerType'])){
  2678. $whereSql .= ' AND customerType = '.$selectParams['customerType'];
  2679. }
  2680. //订单状态
  2681. if (isset($selectParams['state']) && !empty($selectParams['state'])) {
  2682. $whereSql = self::buildStateSqlAttr($whereSql, $selectParams['state']);
  2683. }
  2684. //数据域
  2685. if (isset($selectParams['orderType']) && $selectParams['orderType'] == StatusCode::$orderType['cashierOrder'] && isset($selectParams['cashierUid']) && !empty($selectParams['cashierUid'])) {
  2686. //收银台列表
  2687. } else {
  2688. $whereSql = parent::getSalesManQueryParams($whereSql);
  2689. }
  2690. $whereSql = parent::getShopIdQueryParams($whereSql);
  2691. $whereSql .= ' order by createTime desc';
  2692. $sql = 'select ' . $fields . ' from qianniao_order_index_' . $this->onlineEnterpriseId . ' where deleteStatus = ' . StatusCode::$standard.$whereSql;
  2693. $countSql = 'select ' . $countFields . ' from qianniao_order_index_' . $this->onlineEnterpriseId . ' where deleteStatus = ' . StatusCode::$standard.$whereSql;
  2694. return [
  2695. 'sql' => $sql,
  2696. 'countSql' => $countSql
  2697. ];
  2698. }
  2699. /**
  2700. * Doc: (des="state标示多选sql处理")
  2701. * User: XMing
  2702. * Date: 2020/7/13
  2703. * Time: 9:38 上午
  2704. * @param string $sql
  2705. * @param mixed $states
  2706. * @return string
  2707. */
  2708. private static function buildStateSqlAttr(string $sql, $states)
  2709. {
  2710. if (is_array($states)) {
  2711. if (in_array('all', $states)) {
  2712. return $sql;
  2713. }
  2714. foreach ($states as $index => $state) {
  2715. $sql .= $index == 0 ? ' and (' . self::stateSql($state) : ' or ' . self::stateSql($state);
  2716. }
  2717. $sql .= ') ';
  2718. } else {
  2719. if ($states == 'all') {
  2720. return $sql;
  2721. }
  2722. $stateSql = self::stateSql($states);
  2723. if (!empty($stateSql)) {
  2724. $sql .= ' and ' . self::stateSql($states);
  2725. }
  2726. }
  2727. return $sql;
  2728. }
  2729. /**
  2730. * Doc: (des="state标示对应sql")
  2731. * User: XMing
  2732. * Date: 2020/7/13
  2733. * Time: 9:43 上午
  2734. * @param string $state
  2735. * @return string
  2736. */
  2737. private static function stateSql(string $state)
  2738. {
  2739. $sql = '';
  2740. switch ($state) {
  2741. case 'waitAudit'://待审核
  2742. $sql .= ' (auditStatus = ' . StatusCode::$auditStatus['auditing'] . ' and orderStatus != ' . StatusCode::$orderStatus['close'] . ')';
  2743. break;
  2744. case 'waitOutStock'://待出库
  2745. $sql .= ' (auditStatus = ' . StatusCode::$auditStatus['auditPass'] . ' and (orderStatus = ' . StatusCode::$orderStatus['waitPay'] . ' or orderStatus = ' . StatusCode::$orderStatus['waitDelivery'] . ')) ';
  2746. break;
  2747. case 'hasOutStock'://已出库
  2748. $sql .= ' (auditStatus = ' . StatusCode::$auditStatus['auditPass'] . ' and orderStatus = ' . StatusCode::$orderStatus['waitReceive'] . ')';
  2749. break;
  2750. case 'finish'://已完成
  2751. $sql .= ' (auditStatus = ' . StatusCode::$auditStatus['auditPass'] . ' and orderStatus = ' . StatusCode::$orderStatus['finish'] . ')';
  2752. break;
  2753. case 'close'://已关闭
  2754. $sql .= ' (orderStatus = ' . StatusCode::$orderStatus['close'] . ')';
  2755. break;
  2756. case 'all'://全部订单
  2757. break;
  2758. }
  2759. return $sql;
  2760. }
  2761. /**
  2762. * 删除订单视图
  2763. */
  2764. public function dropView()
  2765. {
  2766. $sql = 'DROP VIEW ' . $this->orderStatisticsTableName . '_' . $this->onlineEnterpriseId;
  2767. $dbResult = $this->objDOrder->query($sql);
  2768. if ($dbResult === false) {
  2769. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  2770. }
  2771. return ResultWrapper::success('删除成功');
  2772. }
  2773. /**
  2774. * 判断表是否存在
  2775. * @param $tableName
  2776. */
  2777. public function existsTable($tableName)
  2778. {
  2779. $exists = $this->objDOrder->existsTable($tableName);
  2780. if (!$exists) {
  2781. //不存在删除视图
  2782. self::dropView();
  2783. }
  2784. }
  2785. /**
  2786. * 添加银行打款数据
  2787. */
  2788. public function addOrderBankData($orderBankData)
  2789. {
  2790. //切换分表
  2791. $fix = $fix = ceil($this->onlineUserId / $this->cutTable);
  2792. $this->objDOrder->setTable('qianniao_order_' . $this->onlineEnterpriseId . '_' . $fix);
  2793. foreach ($orderBankData['orderId'] as $key => $value){
  2794. //获取订单信息
  2795. $orderData = $this->objDOrder->get(['id' => $value]);
  2796. if ($orderData === false) {
  2797. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  2798. }
  2799. if(empty($orderData)){
  2800. return ResultWrapper::fail('订单不存在', ErrorCode::$contentNotExists);
  2801. }
  2802. $orderData['extends'] = json_decode($orderData['extends'], true);
  2803. $orderData['extends']['bankData'] = $orderBankData['bankData'];
  2804. $orderData['extends'] = json_encode($orderData['extends']);
  2805. $dbReuslt = $this->objDOrder->update(['extends'=>$orderData['extends'],'updateTime'=>time()], $value);
  2806. if ($dbReuslt === false) {
  2807. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  2808. }
  2809. }
  2810. return ResultWrapper::success($dbReuslt);
  2811. }
  2812. /**
  2813. * Doc: (des="审核订单,到出库单")
  2814. * User: XMing
  2815. * Date: 2020/7/14
  2816. * Time: 6:38 下午
  2817. * @param array $params
  2818. * @return ResultWrapper
  2819. * @throws \Exception
  2820. */
  2821. public function updateAuditStatus(array $params)
  2822. {
  2823. $this->objDOrderIndex->setTable('qianniao_order_index_' . $this->onlineEnterpriseId);
  2824. $orderIndex = $this->objDOrderIndex->get(['id' => $params['id']]);
  2825. if ($orderIndex === false) {
  2826. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  2827. }
  2828. if (empty($orderIndex)) {
  2829. return ResultWrapper::fail('没有找到订单信息', ErrorCode::$paramError);
  2830. }
  2831. if ($orderIndex['auditStatus'] == StatusCode::$auditStatus['auditPass']) {
  2832. return ResultWrapper::fail('当前订单已经审核通过!', ErrorCode::$paramError);
  2833. }
  2834. if ($this->isCashier === false) {
  2835. //在线支付的订单必须是已支付才能审核
  2836. if ($orderIndex['payType'] == StatusCode::$payType['wxPay'] || $orderIndex['payType'] == StatusCode::$payType['aliPay']) {
  2837. if ($params['auditStatus'] == StatusCode::$auditStatus['auditPass'] && $orderIndex['payStatus'] == StatusCode::$delete) {
  2838. return ResultWrapper::fail('订单尚未支付,不能审核', ErrorCode::$notAllowAccess);
  2839. }
  2840. }
  2841. }
  2842. //切换分表
  2843. $fix = $fix = ceil($orderIndex['userCenterId'] / $this->cutTable);
  2844. $this->objDOrder->setTable('qianniao_order_' . $this->onlineEnterpriseId . '_' . $fix);
  2845. //获取订单信息
  2846. $orderData = $this->objDOrder->get(['id' => $params['id']]);
  2847. if ($orderData === false) {
  2848. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  2849. }
  2850. // 银行打款支付方式审核之前需要判断是否上传凭证
  2851. if( $orderData['payType'] == StatusCode::$payType['bankLoans'] ){
  2852. $extends = json_decode($orderData['extends'],true);
  2853. if (!array_key_exists('bankData',$extends)){
  2854. return ResultWrapper::fail('该订单未上传银行打款凭证', ErrorCode::$paramError);
  2855. }
  2856. $customerData = $this->objDCustomer->get(['id'=>$orderData['customerId']]);
  2857. if ($customerData === false) {
  2858. return ResultWrapper::fail($this->objDCustomer->error(), ErrorCode::$dberror);
  2859. }
  2860. if(isset($customerData['openId']) && !empty($customerData['openId'])){
  2861. // 银行打款上传凭证小程序订阅消息
  2862. $sendMessageData = [
  2863. 'date4' => [ 'value' => date('Y-m-d H:i:s',$orderData['createTime'])], // 提交时间
  2864. 'thing10' => [ 'value' => $customerData['name'] ], // 申请人
  2865. 'thing2' => [ 'value' => '银行打款凭证是否通过'], // 审核内容
  2866. 'date3' => [ 'value' => date('Y-m-d H:i:s',$orderData['updateTime']) ], // 审核时间
  2867. 'phrase1' => [ 'value' => $orderData['auditStatus'] == StatusCode::$auditStatus['auditPass'] ? '审核通过':'审核未通过'], // 审核结果
  2868. ];
  2869. $objMSystemPushMessage = new MSystemPushMessage($this->onlineUserId, $this->onlineEnterpriseId);
  2870. $result = $objMSystemPushMessage->sendWeiXinPushMessage(4, $customerData['openId'], $sendMessageData);
  2871. if(!$result->isSuccess()){
  2872. file_put_contents('/www/wwwroot/logs/api.junhailan.com/wexinPushMessage.log',date('Y-m-d H:i:s').'bb'.var_export($result->getData(),true).PHP_EOL,FILE_APPEND);
  2873. }
  2874. }
  2875. }
  2876. $this->objDOrderIndex->beginTransaction();
  2877. // 生成收款单
  2878. $receivedResult = self::createReceived($orderData);
  2879. if (!$receivedResult->isSuccess()) {
  2880. $this->objDOrderIndex->rollBack();
  2881. return ResultWrapper::fail($receivedResult->getData(), $receivedResult->getErrorCode());
  2882. }
  2883. $update = [
  2884. 'auditStatus' => $params['auditStatus'],
  2885. 'updateTime' => time(),
  2886. ];
  2887. if ( $orderData['payType'] == StatusCode::$payType['bankLoans'] ){//银行打款更新payStatus,orderStatus
  2888. $update = [
  2889. 'auditStatus' => $params['auditStatus'],
  2890. 'payStatus' => StatusCode::$standard,
  2891. 'orderStatus' => StatusCode::$orderStatus['waitDelivery'],
  2892. 'updateTime' => time(),
  2893. ];
  2894. }
  2895. //操作索引表
  2896. $orderIndexUpdate = $this->objDOrderIndex->update($update, ['id' => $params['id']]);
  2897. if ($orderIndexUpdate === false) {
  2898. $this->objDOrderIndex->rollBack();
  2899. Logger::logs(E_USER_ERROR, 'sql错误', __CLASS__, __LINE__, $this->objDOrderIndex->error());
  2900. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  2901. }
  2902. //操作订单表
  2903. $orderUpdate = $this->objDOrder->update($update, $params['id']);
  2904. if ($orderUpdate === false) {
  2905. $this->objDOrderIndex->rollBack();
  2906. Logger::logs(E_USER_ERROR, 'sql错误', __CLASS__, __LINE__, $this->objDOrder->error());
  2907. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  2908. }
  2909. //订单审核出库
  2910. $outId = 0;
  2911. if ($params['auditStatus'] == StatusCode::$auditStatus['auditPass']) {
  2912. $orderData['auditId'] = $params['auditId'];
  2913. $orderData['audit'] = $params['audit'];
  2914. $addInventoryOutResult = self::addInventoryOut($params['id'], $orderData, $orderData['userCenterId']);
  2915. if (!$addInventoryOutResult->isSuccess()) {
  2916. $this->objDOrderIndex->rollBack();
  2917. return ResultWrapper::fail($addInventoryOutResult->getData(), $addInventoryOutResult->getErrorCode());
  2918. }
  2919. $outId = $addInventoryOutResult->getData();
  2920. }
  2921. $this->objDOrderIndex->commit();
  2922. /*
  2923. //跟新es
  2924. $_id = self::createEsDocumentId($params['id']);
  2925. $this->objDOrder->esupdateTypeFieldVaule($update, $_id);*/
  2926. self::runProcessNextOut($outId,$orderData);
  2927. if ($params['auditStatus'] == StatusCode::$auditStatus['auditPass']) {
  2928. return ResultWrapper::success($outId);
  2929. }
  2930. if(isset($customerData['openId']) && !empty($customerData['openId'])){
  2931. // 订单审核通过
  2932. $sendMessageData = [
  2933. 'date4' => [ 'value' => date('Y-m-d H:i:s',$orderData['createTime'])], // 提交时间
  2934. 'thing2' => [ 'value' => '银行打款凭证是否通过'], // 审核内容
  2935. 'phrase1' => [ 'value' => $orderData['auditStatus'] == 2 ? '审核通过':'审核未通过'], // 审核结果
  2936. 'date3' => [ 'value' => date('Y-m-d H:i:s',$orderData['updateTime']) ], // 审核时间
  2937. ];
  2938. $objMSystemPushMessage = new MSystemPushMessage($this->onlineUserId, $this->onlineEnterpriseId);
  2939. $result = $objMSystemPushMessage->sendWeiXinPushMessage(6, $customerData['openId'], $sendMessageData);
  2940. if(!$result->isSuccess()){
  2941. file_put_contents('/www/wwwroot/logs/api.junhailan.com/shenhe.log',date('Y-m-d H:i:s').'bb'.var_export($result->getData(),true).PHP_EOL,FILE_APPEND);
  2942. }
  2943. }
  2944. return ResultWrapper::success('操作成功');
  2945. }
  2946. /**
  2947. * Doc: (des="step 3: 审核出库")
  2948. * User: XMing
  2949. * Date: 2020/11/9
  2950. * Time: 9:24 上午
  2951. * @param array $order
  2952. * @param int $outId
  2953. * @return ResultWrapper
  2954. * @throws \Exception
  2955. */
  2956. private function runProcessNextOut(int $outId,array $order): ResultWrapper
  2957. {
  2958. if (empty($outId)){
  2959. return ResultWrapper::success(true);
  2960. }
  2961. if ($order['orderType'] != StatusCode::$orderType['saleOrder']){
  2962. return ResultWrapper::success(true);
  2963. }
  2964. $setResult = $this->objMProcessSetting->getProcessSettingByType(StatusCode::$processType['sales'],'out');
  2965. if (!$setResult->isSuccess()){
  2966. Logger::logs(E_USER_ERROR,'获取流程配置出错',__CLASS__,__LINE__,$setResult->getData());
  2967. return ResultWrapper::fail($setResult->getData(),$setResult->getErrorCode());
  2968. }
  2969. $set = $setResult->getData();
  2970. if (empty($set)){
  2971. Logger::logs(E_USER_ERROR,'配置为空',__CLASS__,__LINE__,'');
  2972. return ResultWrapper::success(true);
  2973. }
  2974. if (isset($set['enableStatus']) && $set['enableStatus'] == StatusCode::$standard){
  2975. Logger::logs(E_USER_ERROR,'配置',__CLASS__,__LINE__,$set);
  2976. return ResultWrapper::success(true);
  2977. }
  2978. $params = [
  2979. 'id' => $outId,
  2980. 'auditId' => $this->onlineUserId,//操作人id
  2981. 'auditName' => '自动审核',//操作人姓名
  2982. ];
  2983. $objMInventoryOut = new MInventoryOut($this->onlineEnterpriseId,$this->onlineUserId);
  2984. $result = $objMInventoryOut->updateInventoryOutStatus($params);
  2985. if (!$result->isSuccess()){
  2986. Logger::logs(E_USER_ERROR,'自动审核出库单出错',__CLASS__,__LINE__,$result->getData());
  2987. return ResultWrapper::fail($result->getData(),$result->getErrorCode());
  2988. }
  2989. Logger::logs(E_USER_ERROR,'自动审核出库单成功',__CLASS__,__LINE__,$outId);
  2990. return ResultWrapper::success(true);
  2991. }
  2992. /**
  2993. * Doc: (des="后台代客下单创建收款单")
  2994. * User: XMing
  2995. * Date: 2020/11/5
  2996. * Time: 5:31 下午
  2997. * @param array $orderData
  2998. * @return ResultWrapper
  2999. * @throws \Exception
  3000. */
  3001. private function createReceived(array $orderData): ResultWrapper
  3002. {
  3003. // 银行打款
  3004. if ($orderData['payType'] == StatusCode::$payType['bankLoans']){
  3005. $orderExtendsData = json_decode($orderData['extends'], true);
  3006. // 组装收款单账户数据
  3007. $accountListData[] = [
  3008. 'discountMoney' => 0,
  3009. 'money' => $orderData['payAmount'],
  3010. 'payWay' => StatusCode::$payType[4],
  3011. 'remark' => '银行打款生成收款',
  3012. 'accountId' => ($orderExtendsData['bankData']['id']) ? : 0,
  3013. 'accountName' => ($orderExtendsData['bankData']['name']) ? : '',
  3014. 'accountNumber' => ($orderExtendsData['bankData']['accountNumber']) ? : '',
  3015. 'finalMoney' => $orderData['payAmount'],
  3016. ];
  3017. $orderData['accountList'] = json_encode($accountListData);
  3018. $orderData['currentAccountName'] = ($orderExtendsData['bankData']['name']) ? : '';
  3019. }
  3020. //生成收款单
  3021. if ( ($orderData['orderType'] == StatusCode::$orderType['saleOrder'] || $orderData['orderType'] == StatusCode::$orderType['salesSlip']) &&
  3022. $orderData['source'] == StatusCode::$source['manage'] &&
  3023. !empty($orderData['accountList']) &&
  3024. !empty(floatval($orderData['receivedMoney'])) || ( $orderData['payType'] == StatusCode::$payType['bankLoans'] )//银行打款也生成收款单
  3025. ) {
  3026. $this->objDOrderIndex->beginTransaction();
  3027. //生成收款单
  3028. $objMReceived = new MReceived($this->onlineEnterpriseId, $this->onlineUserId);
  3029. //创建收款单
  3030. $received = [
  3031. 'currentAccountName' => $orderData['currentAccountName'],
  3032. 'financeType' => '银行打款收款',
  3033. 'financeTypeId' => 2,
  3034. 'shopId' => $orderData['shopId'],
  3035. 'shopName' => $orderData['shopName'],
  3036. 'receiptTime' => time(),
  3037. 'operatorId' => $this->onlineUserId,
  3038. 'accountList' => json_decode($orderData['accountList'], true),
  3039. 'customerId' => $orderData['customerId'],
  3040. 'customerName' => $orderData['customerName'],
  3041. 'sourceNo' => $orderData['no'],
  3042. 'sourceId' => $orderData['id'],
  3043. 'originId' => $orderData['id'],
  3044. 'originNo' => $orderData['originNo'],
  3045. 'sourceNoMoney' => $orderData['receivedMoney'],
  3046. 'extends' => isset($orderExtendsData['bankData']) ? json_encode($orderExtendsData['bankData']) : '[]',
  3047. 'createTime' => time(),
  3048. 'auditStatus' => StatusCode::$auditStatus['auditing'],
  3049. 'updateTime' => time(),
  3050. ];
  3051. $receivedResult = $objMReceived->addReceived($received, true);
  3052. if (!$receivedResult->isSuccess()) {
  3053. $this->objDOrderIndex->rollBack();
  3054. return ResultWrapper::fail($receivedResult->getData(), $receivedResult->getErrorCode());
  3055. }
  3056. $up = [];
  3057. if ($orderData['receivedMoney'] >= $orderData['payAmount']) {
  3058. $up = [
  3059. 'payStatus' => StatusCode::$standard,
  3060. 'updateTime' => time(),
  3061. ];
  3062. }else{
  3063. if ($orderData['receivedMoney'] != 0){
  3064. $up = [
  3065. 'payStatus' => StatusCode::$offline,//部分收款
  3066. 'updateTime' => time(),
  3067. ];
  3068. }
  3069. }
  3070. if (!empty($up)){
  3071. $result = $this->objDOrderIndex->update($up, $orderData['id']);
  3072. if ($result === false) {
  3073. $this->objDOrderIndex->rollBack();
  3074. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  3075. }
  3076. $result = $this->objDOrder->update($up, $orderData['id']);
  3077. if ($result === false) {
  3078. $this->objDOrderIndex->rollBack();
  3079. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  3080. }
  3081. }
  3082. $this->objDOrderIndex->commit();
  3083. }
  3084. return ResultWrapper::success(true);
  3085. }
  3086. /**
  3087. * Doc: (des="订单审核出库,使用此方法一定要注意在上文获取当前订单的userCenterId用于下文切换分表")
  3088. * User: XMing
  3089. * Date: 2020/7/15
  3090. * Time: 9:48 上午
  3091. * @param array $orderData
  3092. * @param int $id
  3093. * @param int $thisOnlineUserId 当前订单的用户id,用来切换分表
  3094. * @return ResultWrapper
  3095. * @throws \Exception
  3096. */
  3097. private function addInventoryOut(int $id, array $orderData, int $thisOnlineUserId)
  3098. {
  3099. //查询订单商品表
  3100. $objMOrderGoods = new MOrderGoods($thisOnlineUserId, $this->onlineEnterpriseId);
  3101. $selectData = ['orderId' => $id];
  3102. $orderGoodsDataObj = $objMOrderGoods->getOrderGoodsByOrderIds($selectData);
  3103. if (!$orderGoodsDataObj->isSuccess()) {
  3104. return ResultWrapper::fail($orderGoodsDataObj->getData(), ErrorCode::$dberror);
  3105. }
  3106. $objMInventoryOut = new MInventoryOut($this->onlineEnterpriseId, $this->onlineUserId);
  3107. $totalResult = $objMInventoryOut->getTotalByOrderId($orderData['id']);
  3108. if (!$totalResult->isSuccess()){
  3109. return ResultWrapper::fail($totalResult->getData(),$totalResult->getErrorCode());
  3110. }
  3111. $total = (int)$totalResult->getData();
  3112. if ($total > 0){
  3113. //已经生成过出库单了
  3114. Logger::logs(E_USER_ERROR, '订单id:'.$orderData['id'].',重复生成出库单', __CLASS__, __LINE__,$orderData);
  3115. return ResultWrapper::fail('不要重复操作,避免生成成多个出库单',ErrorCode::$paramError);
  3116. }
  3117. //查询商铺id对应的仓库数据
  3118. $objMShop = new MShop($this->onlineEnterpriseId, $this->onlineUserId);
  3119. $modelResult = $objMShop->getShopDataByShopIds([$orderData['shopId']]);
  3120. if (!$modelResult->isSuccess()) {
  3121. return ResultWrapper::fail($modelResult->getData(), $modelResult->getErrorCode());
  3122. }
  3123. $shopData = $modelResult->getData();
  3124. unset($modelResult);
  3125. //获取订单收货信息
  3126. $orderReceiveDbResult = [];
  3127. if ($orderData['deliveryType'] == StatusCode::$deliveryType['goodsDelivery']) {
  3128. $fix = ceil($thisOnlineUserId / $this->cutTable);
  3129. $this->objDOrderReceive->setTable('qianniao_order_receive_' . $this->onlineEnterpriseId . '_' . $fix);
  3130. $orderReceiveDbResult = $this->objDOrderReceive->get(['orderId' => $id]);
  3131. if ($orderReceiveDbResult === false) {
  3132. return ResultWrapper::fail($this->objDOrderReceive->error(), ErrorCode::$dberror);
  3133. }
  3134. if (empty($orderReceiveDbResult)) {
  3135. return ResultWrapper::fail('订单收货地址查询失败', ErrorCode::$dberror);
  3136. }
  3137. }
  3138. $objMCustomer = new MCustomer($this->onlineEnterpriseId,$this->onlineUserId);
  3139. $customerResult = $objMCustomer->getCustomerByCustomerId($orderData['customerId']);
  3140. if (!$customerResult->isSuccess()){
  3141. return ResultWrapper::fail($customerResult->getData(),$customerResult->getErrorCode());
  3142. }
  3143. $customer = $customerResult->getData();
  3144. $orderGoodsData = $orderGoodsDataObj->getData();//订单商品数据
  3145. $saleOutData = [
  3146. 'sourceId' => $orderData['id'],
  3147. 'sourceNo' => $orderData['no'],
  3148. 'originNo' => $orderData['no'],
  3149. 'originId' => $orderData['id'],
  3150. 'shopId' => $orderData['shopId'],
  3151. 'shopName' => $orderData['shopName'],
  3152. 'amount' => $orderData['payAmount'],
  3153. 'operatorId' => $orderData['auditId'],//操作人id
  3154. 'operatorName' => $orderData['audit'],//操作人信息
  3155. 'customerId' => $orderData['customerId'],
  3156. 'customerName' => $orderData['customerName'],
  3157. 'customerCode' => createCode(StatusCode::$code['customer']['prefix'], $orderData['customerId'], StatusCode::$code['customer']['length']),
  3158. 'customerMobile' => isset($customer['mobile']) ? $customer['mobile'] : '',
  3159. 'source' => StatusCode::$orderType['saleOrder'], //订单来源(出库类型)
  3160. 'type' => StatusCode::$orderType['saleOut'],
  3161. 'deliveryType' => $orderData['deliveryType'],//配送方式
  3162. 'remark' => $orderData['remark'],
  3163. ];
  3164. $saleOutData['materielNum'] = 0;
  3165. //获取sku
  3166. $objMSku = new MSku($this->onlineUserId, $this->onlineEnterpriseId);
  3167. $skuIds = array_column(array_values($orderGoodsData), 'skuId');
  3168. $modelResult = $objMSku->getSkuDataBySkuIds($skuIds);
  3169. if (!$modelResult->isSuccess()) {
  3170. return ResultWrapper::fail($modelResult->getData(), $modelResult->getErrorCode());
  3171. }
  3172. $skuData = $modelResult->getData();
  3173. unset($modelResult);
  3174. foreach ($orderGoodsData as $key => $value) {
  3175. $saleOutData['materielNum']++;
  3176. $totalMoney = bcsub(bcsub($value['totalMoney'], $value['vipDiscount']), $value['preferential']);//销售总价 !优惠后
  3177. $saleOutData['orderGoodsData'][] = [
  3178. 'materielId' => $value['goodsBasicId'],
  3179. 'materielName' => $value['goodsName'],
  3180. 'materielCode' => createCode(StatusCode::$code['goodsBasic']['prefix'], $value['goodsBasicId'], StatusCode::$code['goodsBasic']['length']),
  3181. 'skuId' => $value['skuId'],
  3182. 'num' => $value['buyNum'],
  3183. 'otherNum' => $value['otherNum'],
  3184. 'outNum' => 0,
  3185. 'total' => $value['buyNum'],
  3186. 'unitName' => isset($value['unitName']) ? $value['unitName'] : '',
  3187. 'skuName' => isset($skuData[$value['skuId']]) ? $skuData[$value['skuId']]['skuName'] : '',
  3188. 'unitPrice' => $value['price'],//单价 不优惠
  3189. 'totalPrice' => $totalMoney,//销售总价 !优惠后
  3190. 'extend' => $value['extends'],
  3191. 'isEq' => $value['isEq'],
  3192. ];
  3193. }
  3194. $dbResult = $objMInventoryOut->addInventoryOut($saleOutData);
  3195. if (!$dbResult->isSuccess()) {
  3196. Logger::logs(E_USER_ERROR, 'sql错误', __CLASS__, __LINE__, $dbResult->getData());
  3197. return ResultWrapper::fail($dbResult->getData(), ErrorCode::$dberror);
  3198. }
  3199. self::noticeStatistics([
  3200. 'userCenterId' => $thisOnlineUserId,
  3201. 'enterpriseId' => $this->onlineEnterpriseId,
  3202. 'customerId' => $orderData['customerId'],
  3203. 'no' => $orderData['no'],
  3204. 'noticeType' => 'audit',//审核
  3205. ], 'MOrderStatistics');
  3206. //添加日志
  3207. parent::saveLog([
  3208. 'no' => $orderData['no'],
  3209. 'actionType' => '审核通过',
  3210. 'operationData' => '',
  3211. 'userCenterId' => $this->onlineUserId,
  3212. 'enterpriseId' => $this->onlineEnterpriseId,
  3213. 'createTime' => time(),
  3214. ]);
  3215. self::sendMessage($this->onlineEnterpriseId,'NewOrder','stockOut');
  3216. return ResultWrapper::success($dbResult->getData());
  3217. }
  3218. /**
  3219. * 批量审核
  3220. * @param array $params
  3221. * @return ResultWrapper
  3222. * @throws \Exception
  3223. */
  3224. public function batchUpdateAuditStatus(array $params)
  3225. {
  3226. $auditParam = [
  3227. 'audit' => $params['audit'],
  3228. 'auditId' => $params['auditId'],
  3229. 'auditStatus' => $params['auditStatus']
  3230. ];
  3231. foreach ($params['ids'] as $id) {
  3232. $auditParam['id'] = $id;
  3233. $result = self::updateAuditStatus($auditParam);
  3234. if (!$result->isSuccess()) {
  3235. return ResultWrapper::fail($result->getData(), $result->getErrorCode());
  3236. }
  3237. }
  3238. return ResultWrapper::success("审核成功");
  3239. }
  3240. /**
  3241. * Doc: (des="修改订单的状态,orderStatus")
  3242. * User: XMing
  3243. * Date: 2020/7/14
  3244. * Time: 5:25 下午
  3245. * @param $id
  3246. * @param $selectParams
  3247. * @param array $header
  3248. * @return ResultWrapper
  3249. * @throws \Exception
  3250. */
  3251. public function updateOrderStatus($id, $selectParams, array $header)
  3252. {
  3253. // 查询订单索引表数据
  3254. $this->objDOrderIndex->setTable('qianniao_order_index_' . $this->onlineEnterpriseId);
  3255. $orderIndex = $this->objDOrderIndex->get(['id' => $id], 'userCenterId,payStatus,createTime,customerId,no,updateTime');
  3256. if ($orderIndex === false) {
  3257. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  3258. }
  3259. if (empty($orderIndex)) {
  3260. return ResultWrapper::fail('订单信息不存在', ErrorCode::$paramError);
  3261. }
  3262. // 后台设置的审核通过不能取消订单
  3263. $objEnterpriseCache = new EnterpriseCache();
  3264. $enterSettingData = $objEnterpriseCache->getEnterpriseSetting($this->onlineEnterpriseId);
  3265. if(isset($enterSettingData['cancelOrder']) && $enterSettingData['cancelOrder'] == StatusCode::$delete && $orderIndex['auditStatus'] == StatusCode::$auditStatus['auditPass'] && $selectParams['orderStatus'] == StatusCode::$orderStatus['close']){
  3266. return ResultWrapper::fail('当前订单已经审核通过,暂不支持取消,请联系客服处理', ErrorCode::$notAllowAccess);
  3267. }
  3268. if ($selectParams['orderStatus'] == StatusCode::$orderStatus['close']
  3269. && isset($orderIndex['outStatus']) && $orderIndex['outStatus'] == StatusCode::$standard) {
  3270. return ResultWrapper::fail('已经发货订单不能取消', ErrorCode::$paramError);
  3271. }
  3272. // 切换订单分表,查询订单主单据数据
  3273. $fix = ceil($orderIndex['userCenterId'] / $this->cutTable);;
  3274. $this->objDOrder->setTable('qianniao_order_' . $this->onlineEnterpriseId . '_' . $fix);
  3275. $orderData = $this->objDOrder->get(['id' => $id]);
  3276. if($orderData === false) {
  3277. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  3278. }
  3279. if(empty($orderData)){
  3280. return ResultWrapper::fail('要操作的订单不存在', ErrorCode::$contentNotExists);
  3281. }
  3282. $this->objDOrderIndex->beginTransaction();
  3283. $selectParams['cancelbeforeOrderStatus'] = $orderData["orderStatus"];
  3284. // 更新订单表
  3285. $orderData['extends'] = json_decode($orderData['extends'], true);
  3286. if( !empty($selectParams['cancelReason']) ){
  3287. $orderData['extends']['cancelReason'] = $selectParams['cancelReason'];
  3288. $orderData['extends']['cancelbeforeOrderStatus'] = $selectParams['cancelbeforeOrderStatus'];
  3289. $selectParams['successFullyTime'] = time();
  3290. }
  3291. if( !empty($selectParams['cancelRejectReason']) ){
  3292. $orderData['extends']['cancelRejectReason'] = $selectParams['cancelRejectReason'];
  3293. $selectParams['orderStatus'] = $orderData['extends']['cancelbeforeOrderStatus']; // 取消被拒恢复到取消之前的订单状态
  3294. }
  3295. // 更新索引表
  3296. $orderIndexUpdate = $this->objDOrderIndex->update([
  3297. 'orderStatus' => $selectParams['orderStatus'],
  3298. 'updateTime' => time()
  3299. ], ['id' => $id]);
  3300. if ($orderIndexUpdate === false) {
  3301. $this->objDOrderIndex->rollBack();
  3302. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  3303. }
  3304. $selectParams['extends'] = json_encode($orderData['extends']);
  3305. $selectParams['updateTime'] = time();
  3306. unset($selectParams['cancelReason']);
  3307. unset($selectParams['cancelRejectReason']);
  3308. unset($selectParams['cancelbeforeOrderStatus']);
  3309. $orderUpdate = $this->objDOrder->update($selectParams, ['id' => $id]);
  3310. if ($orderUpdate === false) {
  3311. $this->objDOrderIndex->rollBack();
  3312. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  3313. }
  3314. // 取消订单
  3315. if ($selectParams['orderStatus'] == StatusCode::$orderStatus['close']) {
  3316. // 解锁库存
  3317. $unlockResult = self::unlockInventory($id, $orderData);
  3318. if (!$unlockResult->isSuccess()) {
  3319. $this->objDOrderIndex->rollBack();
  3320. return ResultWrapper::fail($unlockResult->getData(), $unlockResult->getErrorCode());
  3321. }
  3322. // 已经支付订单做自动退款处理
  3323. if($orderData['payStatus'] == StatusCode::$standard){
  3324. // 生成财务退款单
  3325. $financeRefundData = [
  3326. 'originId' => getArrayItem($orderData,'id',0),
  3327. 'originNo' => getArrayItem($orderData,'no',''),
  3328. 'sourceId' => getArrayItem($orderData,'id',0),
  3329. 'sourceNo' => getArrayItem($orderData,'no',''),
  3330. 'refundTime' => time(),
  3331. 'createTime' => time(),
  3332. 'updateTime' => time(),
  3333. 'unitId' => getArrayItem($orderData,'customerId',0),
  3334. 'unitName' => getArrayItem($orderData,'customerName',0),
  3335. 'currentAccountName' => getArrayItem($orderData,'customerName',''),
  3336. 'financeType' => '订单取消退款',
  3337. 'financeTypeId' => 1,
  3338. 'payType' =>getArrayItem($orderData,'payType',''),
  3339. 'shopId' => getArrayItem($orderData,'shopId',0),
  3340. 'shopName' => getArrayItem($orderData,'shopName',0),
  3341. 'money' => $orderData['payAmount'],
  3342. 'operatorId' => $this->onlineUserId,
  3343. 'type' => StatusCode::$standard,
  3344. 'auditStatus' => StatusCode::$auditStatus['auditing'],
  3345. 'remark' => '订单取消,订单编号:'. getArrayItem($orderData,'no','').'需退款金额:'.$orderData['payAmount'],
  3346. ];
  3347. // 根据订单支付方式规划退款账户
  3348. $objMAccount = new MAccount($this->onlineEnterpriseId,$this->onlineUserId);
  3349. $extends = is_array($orderData['extends'])?$orderData['extends']: json_decode($orderData['extends'], true);
  3350. if(isset($extends['admixPayData'])){ // 组合支付
  3351. foreach ($extends['admixPayData'] as $key => $value){
  3352. $financeAccountData = $objMAccount->getDefaultAccount($value['payType']);
  3353. if(!$financeAccountData->isSuccess()){
  3354. return ResultWrapper::fail($financeAccountData->getData(), $financeAccountData->getErrorCode());
  3355. }
  3356. $financeAccountData = $financeAccountData->getData();
  3357. $financeRefundData['accountList'][] = [
  3358. 'accountId' => $financeAccountData['id'],
  3359. 'accountNumber' => $financeAccountData['accountNumber'],
  3360. 'accountName' => $financeAccountData['name'],
  3361. 'money' => $value['payMoney'],
  3362. ];
  3363. }
  3364. }else{
  3365. $financeAccountData = $objMAccount->getDefaultAccount($orderData['payType']);
  3366. if(!$financeAccountData->isSuccess()){
  3367. return ResultWrapper::fail($financeAccountData->getData(), $financeAccountData->getErrorCode());
  3368. }
  3369. $financeAccountData = $financeAccountData->getData();
  3370. $financeRefundData['accountList'] = [
  3371. [
  3372. 'accountId' => $financeAccountData['id'],
  3373. 'accountNumber' => $financeAccountData['accountNumber'],
  3374. 'accountName' => $financeAccountData['name'],
  3375. 'money' => $orderData['payAmount'],
  3376. ]
  3377. ];
  3378. }
  3379. $objMRefund = new MRefund($this->onlineEnterpriseId,$this->onlineUserId);
  3380. $result = $objMRefund->addRefund($financeRefundData);
  3381. if(!$result->isSuccess()){
  3382. return ResultWrapper::fail($result->getData(),$result->getErrorCode());
  3383. }
  3384. // 自动审核退款单
  3385. $result = $objMRefund->updateRefundStatus(['id'=>$result->getData(),'createTime'=>time()]);
  3386. if(!$result->isSuccess()){
  3387. return ResultWrapper::fail($result->getData(),$result->getErrorCode());
  3388. }
  3389. }
  3390. // 订单审核待出库时取消订单 同步删除销售出库单
  3391. if($orderData['auditStatus'] == StatusCode::$auditStatus['auditPass']){
  3392. $objMInventoryOut = new MInventoryOut($this->onlineEnterpriseId, $this->onlineUserId);
  3393. $inventoryOutResult = $objMInventoryOut->delInventoryOutStatus(['originId' => $orderData['id']]);
  3394. if (!$inventoryOutResult->isSuccess()) {
  3395. $this->objDOrderIndex->rollBack();
  3396. return ResultWrapper::fail($inventoryOutResult->getData(), $inventoryOutResult->getErrorCode());
  3397. }
  3398. }
  3399. $customerData = $this->objDCustomer->get(['id'=>$orderData['customerId']]);
  3400. if ($customerData === false) {
  3401. return ResultWrapper::fail($this->objDCustomer->error(), ErrorCode::$dberror);
  3402. }
  3403. if(isset($customerData['openId']) && !empty($customerData['openId'])){
  3404. // 后台取消订单小程序订阅消息
  3405. $sendMessageData = [
  3406. 'character_string13' => [ 'value' => StatusCode::$noPrefix[1] . '-' . $orderData['no']], // 订单编号
  3407. 'date10' => [ 'value' => date('Y-m-d H:i:s',$orderData['createTime']) ], // 下单时间
  3408. 'thing14' => [ 'value' => substr($orderData['shopName'],0,30)], // 门店名称
  3409. 'date2' => [ 'value' => date('Y-m-d H:i:s',$orderData['updateTime']) ], // 取消时间
  3410. ];
  3411. $objMSystemPushMessage = new MSystemPushMessage($this->onlineUserId, $this->onlineEnterpriseId);
  3412. $result = $objMSystemPushMessage->sendWeiXinPushMessage(5, $customerData['openId'], $sendMessageData);
  3413. if(!$result->isSuccess()){
  3414. file_put_contents('/www/wwwroot/logs/api.junhailan.com/quxiao.log',date('Y-m-d H:i:s').'bb'.var_export($result->getData(),true).PHP_EOL,FILE_APPEND);
  3415. }
  3416. }
  3417. }
  3418. //订单完成
  3419. if ($selectParams['orderStatus'] == StatusCode::$orderStatus['finish'] && !empty($header)) {
  3420. // 计算分销订单提成
  3421. $i = 1;
  3422. do {
  3423. $postData = [
  3424. 'topicName' => 'MyJob',
  3425. 'topicClass' => 'Jobs\Model\MTopic\Order\MCommissionOrder',
  3426. 'topicMethon' => 'updateBalance',
  3427. 'topicMethonParams' => [
  3428. 'Authorization' => $header['Authorization'],
  3429. 'Token' => $header['Token'],
  3430. 'orderId' => $id,
  3431. 'PROJECT_DOMAIN' => PROJECT_DOMAIN
  3432. ],
  3433. ];
  3434. $url = QIANNIAO_QUEUE . '/CAddJob/add';
  3435. $result = request($url, $postData);
  3436. $i++;
  3437. } while ($result['httpcode'] != 200 && $i <= 3);
  3438. // 计算用户积分 start
  3439. // 查询客户信息
  3440. $customerData = $this->objDCustomer->get($orderIndex['customerId']);
  3441. if ($customerData === false) {
  3442. return ResultWrapper::fail($this->objDCustomer->error(), ErrorCode::$dberror);
  3443. }
  3444. // 查询订单商品数据
  3445. $fix = ceil($orderIndex['userCenterId'] / $this->cutTable);
  3446. $this->objDOrderGoods->setTable('qianniao_order_goods_' . $this->onlineEnterpriseId . '_' . $fix);
  3447. $orderGoodsData = $this->objDOrderGoods->select(['deleteStatus'=>StatusCode::$standard,'orderId'=>$id]);
  3448. if ($orderGoodsData === false) {
  3449. return ResultWrapper::fail($this->objDCustomer->error(), ErrorCode::$dberror);
  3450. }
  3451. // 调用计算积分方法
  3452. $objMCustomer = new MCustomer($this->onlineEnterpriseId, $this->onlineUserId);
  3453. $result = $objMCustomer->addCustomerIntegralByOrder(0, $customerData, $orderData, $orderGoodsData);
  3454. if(!$result->isSuccess()){
  3455. return ResultWrapper::fail($result->getData(), $result->getErrorCode());
  3456. }
  3457. //调用计算提成方法
  3458. $objMStaff = new MStaff($this->onlineEnterpriseId, $this->onlineUserId);
  3459. $result = $objMStaff->addStaffRewardByOrder(0, $customerData, $orderData, $orderGoodsData);
  3460. if(!$result->isSuccess()){
  3461. return ResultWrapper::fail($result->getData(), $result->getErrorCode());
  3462. }
  3463. //订单完成商户结算金额
  3464. $objMMerchantSettlement = new MMerchantSettlement($this->onlineEnterpriseId, $this->onlineUserId);
  3465. $updateMerchantSettlement = $objMMerchantSettlement->updateMerchantSettlement(['orderId'=>$orderData['id']]);
  3466. if(!$updateMerchantSettlement->isSuccess()){
  3467. return ResultWrapper::fail($updateMerchantSettlement->getData(), $updateMerchantSettlement->getErrorCode());
  3468. }
  3469. //只有小程序微信支付订单才可以计算分佣
  3470. if(!empty($orderData) && $orderData["payAmount"]>0 && $orderData["payType"]==1 && $orderData["source"]==3){
  3471. $checkData = [
  3472. "parentPath"=>$customerData["parentPath"],
  3473. "payAmount"=>$orderData["payAmount"],
  3474. ];
  3475. // PartnerTools::addTask($orderData["id"], $this->onlineEnterpriseId,$checkData);
  3476. }
  3477. }
  3478. //取消订单
  3479. if ($selectParams['orderStatus'] == StatusCode::$orderStatus['close'] && !empty($header)) {
  3480. $i = 1;
  3481. do {
  3482. $postData = [
  3483. 'topicName' => 'MyJob',
  3484. 'topicClass' => 'Jobs\Model\MTopic\Order\MCommissionOrder',
  3485. 'topicMethon' => 'cancelSubCommission',
  3486. 'topicMethonParams' => [
  3487. 'Authorization' => $header['Authorization'],
  3488. 'Token' => $header['Token'],
  3489. 'orderId' => $id,
  3490. 'PROJECT_DOMAIN' => PROJECT_DOMAIN
  3491. ],
  3492. ];
  3493. $url = QIANNIAO_QUEUE . '/CAddJob/add';
  3494. $result = request($url, $postData);
  3495. $i++;
  3496. } while ($result['httpcode'] != 200 && $i <= 3);
  3497. }
  3498. /*
  3499. //ES更新
  3500. $_id = self::createEsDocumentId($id);
  3501. $this->objDOrder->esupdateTypeFieldVaule(['orderStatus' => $selectParams['orderStatus']], $_id);*/
  3502. $this->objDOrderIndex->commit();
  3503. return ResultWrapper::success('操作成功');
  3504. }
  3505. /**
  3506. * Doc: (des="取消订单解锁库存")
  3507. * User: XMing
  3508. * Date: 2020/7/14
  3509. * Time: 5:54 下午
  3510. * @param int $id 订单id
  3511. * @param array $params 订单数据
  3512. * @return ResultWrapper
  3513. */
  3514. private function unlockInventory(int $id, array $params)
  3515. {
  3516. //解锁库存
  3517. $objMInventory = new MInventory($this->onlineEnterpriseId, $this->onlineUserId);
  3518. $unlockResult = $objMInventory->unlockInventory([$id], StatusCode::$orderType['saleOrder'], $params['createTime']);
  3519. if (!$unlockResult->isSuccess()) {
  3520. //暂时关闭,没发现有锁定的地方
  3521. // return ResultWrapper::fail($unlockResult->getData(), ErrorCode::$dberror);
  3522. }
  3523. self::noticeStatistics([
  3524. 'userCenterId' => $this->onlineUserId,
  3525. 'enterpriseId' => $this->onlineEnterpriseId,
  3526. 'customerId' => $params['customerId'],
  3527. 'no' => $params['no'],
  3528. 'data' => $params,
  3529. 'noticeType' => 'close',//取消订单
  3530. ], 'MOrderStatistics');
  3531. //记录日志
  3532. parent::saveLog([
  3533. 'no' => $params['no'],
  3534. 'actionType' => '取消订单',
  3535. 'operationData' => '',
  3536. 'userCenterId' => $this->onlineUserId,
  3537. 'enterpriseId' => $this->onlineEnterpriseId,
  3538. 'createTime' => time(),
  3539. ]);
  3540. return ResultWrapper::success($unlockResult->getData());
  3541. }
  3542. /**
  3543. * Doc: (des="订单出库状态")
  3544. * User: XMing
  3545. * Date: 2020/12/28
  3546. * Time: 10:38 上午
  3547. * @param array $params
  3548. * @param array $where
  3549. * @param array $outInventoryMap
  3550. * @return ResultWrapper
  3551. * @throws \Exception
  3552. * @oaram $outInventoryMap
  3553. */
  3554. public function updateOutStatus(array $params,array $where,array $outInventoryMap): ResultWrapper
  3555. {
  3556. if (empty($where)) {
  3557. return ResultWrapper::fail('参数为空', ErrorCode::$paramError);
  3558. }
  3559. $orderIndex = $this->objDOrderIndex->get($where);
  3560. if ($orderIndex === false){
  3561. return ResultWrapper::fail($this->objDOrderIndex->error(),ErrorCode::$dberror);
  3562. }
  3563. if (empty($orderIndex)){
  3564. return ResultWrapper::fail('未获取到指定的订单信息',ErrorCode::$paramError);
  3565. }
  3566. $orderId = getArrayItem($orderIndex,'id',0);
  3567. $fix = ceil($orderIndex['userCenterId'] / $this->cutTable);
  3568. $this->objDOrder->setTable('qianniao_order_'.$this->onlineEnterpriseId.'_'.$fix);
  3569. $this->objDOrderGoods->setTable('qianniao_order_goods_'.$this->onlineEnterpriseId.'_'.$fix);
  3570. $this->objDOrderIndex->beginTransaction();
  3571. foreach ($outInventoryMap as $skuId => $outNum){
  3572. $row = $this->objDOrderGoods->get(['orderId' => $orderId, 'skuId' => $skuId, 'deleteStatus' => StatusCode::$standard]);
  3573. if ($row === false){
  3574. $this->objDOrderIndex->rollback();
  3575. return ResultWrapper::fail($this->objDOrderGoods->error(),ErrorCode::$dberror);
  3576. }
  3577. $update = [
  3578. 'outNum' => bcadd($row['outNum'],$outNum,2),
  3579. 'outOfNum' => bcsub($row['outOfNum'],$outNum,2),
  3580. 'updateTime' => time(),
  3581. ];
  3582. if ($update['outOfNum'] < 0){
  3583. Logger::logs(E_USER_ERROR,'企业:'.$this->onlineEnterpriseId.' 订单:'.$orderId.' 出库数量异常',__CLASS__,__LINE__,$row);
  3584. $this->objDOrderIndex->rollback();
  3585. return ResultWrapper::fail('出库数量异常',ErrorCode::$paramError);
  3586. }
  3587. $updateGoodsResult = $this->objDOrderGoods->update($update,['id' => $row['id']]);
  3588. if ($updateGoodsResult === false){
  3589. Logger::logs(E_USER_ERROR,'sql error',__CLASS__,__LINE__,$this->objDOrderGoods->error());
  3590. $this->objDOrderIndex->rollback();
  3591. return ResultWrapper::fail($this->objDOrderGoods->error(),ErrorCode::$paramError);
  3592. }
  3593. }
  3594. $outStatusResult = self::checkStockOutStatus($orderId);
  3595. if (!$outStatusResult->isSuccess()){
  3596. $this->objDOrderIndex->rollback();
  3597. return ResultWrapper::fail($outStatusResult->getData(),$outStatusResult->getErrorCode());
  3598. }
  3599. $outStatus = (int)$outStatusResult->getData();
  3600. $params['outStatus'] = $outStatus;//出库状态
  3601. $updateIndex = $this->objDOrderIndex->update($params,$orderId);
  3602. if ($updateIndex === false){
  3603. $this->objDOrderIndex->rollback();
  3604. return ResultWrapper::fail($this->objDOrderIndex->error(),ErrorCode::$dberror);
  3605. }
  3606. $updateOrder = $this->objDOrder->update($params,$orderId);
  3607. if ($updateOrder === false){
  3608. $this->objDOrderIndex->rollback();
  3609. return ResultWrapper::fail($this->objDOrder->error(),ErrorCode::$dberror);
  3610. }
  3611. /*
  3612. $_id = self::createEsDocumentId($orderId);
  3613. $this->objDOrder->esupdateTypeFieldVaule($params, $_id);*/
  3614. $this->objDOrderIndex->commit();
  3615. return ResultWrapper::success($orderId);
  3616. }
  3617. /**
  3618. * Doc: (des="返回订单的出库")
  3619. * User: XMing
  3620. * Date: 2021/3/10
  3621. * Time: 10:35 上午
  3622. * @param int $orderId
  3623. * @return ResultWrapper
  3624. */
  3625. public function checkStockOutStatus(int $orderId): ResultWrapper
  3626. {
  3627. //检测是否都已经出库
  3628. $lists = $this->objDOrderGoods->select(['orderId' => $orderId,'deleteStatus' => StatusCode::$standard]);
  3629. if ($lists === false){
  3630. Logger::logs(E_USER_ERROR,'sql error',__CLASS__,__LINE__,$this->objDOrderGoods->error());
  3631. return ResultWrapper::fail($this->objDOrderGoods->error(),ErrorCode::$dberror);
  3632. }
  3633. if (empty($lists)){
  3634. return ResultWrapper::fail('订单商品获取失败',ErrorCode::$paramError);
  3635. }
  3636. foreach ($lists as $item){
  3637. if ($item['outOfNum'] > 0){
  3638. //还有未出库商品
  3639. return ResultWrapper::success(6);
  3640. }
  3641. }
  3642. return ResultWrapper::success(5);
  3643. }
  3644. /**
  3645. * Doc: (des="修改订单的支付状态")
  3646. * User: XMing
  3647. * Date: 2020/7/14
  3648. * Time: 5:18 下午
  3649. * @param $orderData
  3650. * @param $condition
  3651. * @param bool $isNotify
  3652. * @return ResultWrapper
  3653. * @throws \Exception
  3654. */
  3655. public function updateOrderPayData($orderData, $condition, $isNotify = false): ResultWrapper
  3656. {
  3657. $total_fel = 0;
  3658. if ($isNotify) {
  3659. $total_fel = $orderData['total_fel'];
  3660. unset($orderData['total_fel']);
  3661. }
  3662. if (isset($orderData['pay_way'])) {
  3663. $pay_way = $orderData['pay_way'];
  3664. unset($orderData['pay_way']);
  3665. }
  3666. // 查询订单数据
  3667. $orderInfoData = $this->objDOrder->select($condition);
  3668. if (empty($orderInfoData)) {
  3669. return ResultWrapper::fail('查询订单数据为空', ErrorCode::$paramError);
  3670. }
  3671. if ($orderInfoData === false) {
  3672. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  3673. }
  3674. // 回调通知判断订单是否已经修改过订单状态
  3675. if ($isNotify == true && $orderInfoData[0]['payStatus'] == StatusCode::$standard) {
  3676. return ResultWrapper::fail('支付状态已经修改过了', ErrorCode::$notAllowAccess);
  3677. }
  3678. $this->objDOrder->beginTransaction();
  3679. // 如果之前是组合支付方式,修改支付方式的时候不能直接修改
  3680. if( in_array(StatusCode::$payType['balance'], explode(',', $orderInfoData[0]['payType'])) ){
  3681. $orderData['payType'] = $orderData['payType'].','.StatusCode::$payType['balance'];
  3682. $orderData['notPayMoney'] = bcsub($orderData['notPayMoney'], $orderData['total_fel'], 2);
  3683. }
  3684. $dbResult = $this->objDOrder->update($orderData, $condition);
  3685. if ($dbResult === false) {
  3686. $this->objDOrder->rollBack();
  3687. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  3688. }
  3689. unset($dbResult);
  3690. if (!isset($condition['id'])) {
  3691. //查询订单id
  3692. $dbResult = $this->objDOrder->get($condition, 'id');
  3693. if ($dbResult === false) {
  3694. $this->objDOrder->rollBack();
  3695. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  3696. }
  3697. if (empty($dbResult) || !isset($dbResult['id'])) {
  3698. $this->objDOrder->rollBack();
  3699. return ResultWrapper::fail('订单数据为空', ErrorCode::$dberror);
  3700. }
  3701. $condition['id'][] = $dbResult['id'];
  3702. unset($dbResult);
  3703. }
  3704. unset($orderData['notPayMoney']);
  3705. $dbResult = self::updateOrderIndex($orderData, $condition);
  3706. if (!$dbResult->isSuccess()) {
  3707. $this->objDOrder->rollBack();
  3708. return ResultWrapper::fail($dbResult->getData(), ErrorCode::$dberror);
  3709. }
  3710. if (!is_array($condition['id'])){
  3711. $condition['id'] = [$condition['id']];
  3712. }
  3713. /*
  3714. foreach ($condition['id'] as $key => $value) {
  3715. $_id = self::createEsDocumentId($value);
  3716. $this->objDOrder->esupdateTypeFieldVaule($orderData, $_id);
  3717. }*/
  3718. //线上支付生成收款单$orderData['payStatus'] $condition['id'] 支付完成后回调这两个有值
  3719. if (isset($pay_way) && isset($orderData['payStatus']) && isset($condition['id'])) {
  3720. if ($orderData['payStatus'] == StatusCode::$standard) {
  3721. //拿到微信默认账户
  3722. $defaultAccountResult = $this->objMAccount->getDefaultAccount($pay_way);
  3723. if ($defaultAccountResult->isSuccess() == false) {
  3724. $this->objDOrder->rollBack();
  3725. return ResultWrapper::fail($defaultAccountResult->getData(), $defaultAccountResult->getErrorCode());
  3726. }
  3727. $defaultAccount = $defaultAccountResult->getData();
  3728. if(empty($defaultAccount)){
  3729. return ResultWrapper::fail('支付方式对应的银行账户为空', ErrorCode::$contentNotExists);
  3730. }
  3731. foreach ($orderInfoData as $orderInfo) {
  3732. // 组合支付,收款单金额重新计算
  3733. if( in_array(StatusCode::$payType['balance'], explode(',', $orderInfoData[0]['payType'])) ){
  3734. $orderInfo['extends'] = json_decode($orderInfo['extends'], true);
  3735. if( isset($orderInfo['extends']['admixPayData']) ){
  3736. foreach ($orderInfo['extends']['admixPayData'] as $key => $value){
  3737. if($value['payType'] == StatusCode::$payType['wxPay']){
  3738. $orderInfo['payAmount'] = $value['payMoney'];
  3739. }
  3740. }
  3741. }
  3742. }
  3743. //循环订单数据,拼接生成收款单
  3744. $receivedData = [
  3745. 'customerId' => $orderInfo['customerId'],
  3746. 'customerName' => $orderInfo['customerName'],
  3747. 'currentAccountName' => $orderInfo['shopName'],
  3748. 'financeType' => '线上支付收款',
  3749. 'financeTypeId' => StatusCode::$systemFinanceType['saleReceipt'],
  3750. 'shopId' => $orderInfo['shopId'],
  3751. 'shopName' => $orderInfo['shopName'],
  3752. 'receiptTime' => time(),
  3753. 'operatorId' => 0,
  3754. 'originId' => $orderInfo['id'],
  3755. 'originNo' => $orderInfo['no'],
  3756. 'sourceId' => $orderInfo['id'],
  3757. 'sourceNo' => $orderInfo['no'],
  3758. 'sourceNoMoney' => $orderInfo['payAmount'],
  3759. 'auditStatus' => StatusCode::$auditStatus['auditing'],
  3760. 'offsetMoney' => 0,
  3761. 'notOffsetMoney' => 0,
  3762. 'offsetStatus' => StatusCode::$delete,
  3763. 'createTime' => time(),
  3764. 'updateTime' => time(),
  3765. 'accountList' => [
  3766. [
  3767. "accountId" => isset($defaultAccount['id']) ? $defaultAccount['id'] : 0,
  3768. "accountNumber" => isset($defaultAccount['accountNumber']) ? $defaultAccount['accountNumber'] : '请设置默认的收款账户',
  3769. "money" => $orderInfo['payAmount'],
  3770. "discountMoney" => 0,
  3771. "finalMoney" => $orderInfo['payAmount'],
  3772. "payWay" => isset($pay_way) ? $pay_way . "支付" : '在线支付',
  3773. "remark" => "在线支付自动生成收款单"
  3774. ]
  3775. ],
  3776. ];
  3777. $result = $this->objMReceived->addReceived($receivedData, true);
  3778. if ($result->isSuccess() == false) {
  3779. $this->objDOrder->rollBack();
  3780. return ResultWrapper::fail($result->getData(), $result->getErrorCode());
  3781. }
  3782. // 微信生成的收款单自动审核
  3783. if( in_array(StatusCode::$payType['wxPay'], explode(',', $orderInfoData[0]['payType'])) ){
  3784. $updateReceived = $this->objMReceived->updateReceivedStatus(['id'=>$result->getData(),'createTime'=>time()]);
  3785. if (!$updateReceived->isSuccess()) {
  3786. $this->objDOrder->rollBack();
  3787. return ResultWrapper::fail($updateReceived->getData(), $updateReceived->getErrorCode());
  3788. }
  3789. }
  3790. unset($receivedData);
  3791. unset($result);
  3792. }
  3793. }
  3794. }
  3795. if ($isNotify) {
  3796. self::runProcessNextAudit($condition['id']);
  3797. $objMCustomer = new MCustomer($this->onlineEnterpriseId, $this->onlineUserId);
  3798. $customer = $objMCustomer->getCustomerInfoByUserCenterId($this->onlineUserId);
  3799. if (!$customer->isSuccess()) {
  3800. return ResultWrapper::fail($customer->getData(), $customer->getErrorCode());
  3801. }
  3802. $customer = $customer->getData();
  3803. parent::coupon([
  3804. 'userCenterId' => $this->onlineUserId,
  3805. 'enterpriseId' => $this->onlineEnterpriseId,
  3806. 'customerId' => isset($customer['id']) ? $customer['id'] : '',
  3807. 'payAmount' => isset($total_fel) ? $total_fel : 0,
  3808. ], 'MOnlinePayCoupon');
  3809. $objCustomerCache = new CustomerCache();
  3810. $objCustomerCache->delInterestCustomerAfterPay($customer['id'], $this->onlineEnterpriseId);
  3811. if (isset($customer['openId']) && !empty($customer['openId'])) {
  3812. /* $payment = '';
  3813. //判断支付方式
  3814. switch ($orderInfoData[0]['payType']) {
  3815. case StatusCode::$payType['wxPay']:
  3816. $payment = StatusCode::$payType[1];
  3817. break;
  3818. case StatusCode::$payType['balance']:
  3819. $payment = StatusCode::$payType[7];
  3820. break;
  3821. case StatusCode::$payType['cashPay']:
  3822. $payment = StatusCode::$payType[3];
  3823. break;
  3824. case StatusCode::$payType['bankLoans']:
  3825. $payment = StatusCode::$payType[4];
  3826. break;
  3827. }
  3828. $orderInfoData[0]['extends'] = json_decode($orderInfoData[0]['extends'], true);
  3829. if (isset($orderInfoData[0]['extends']['admixPayData'])) {
  3830. $payment = '组合支付';
  3831. }*/
  3832. // 发送小程序订阅消息
  3833. $sendMessageData = [
  3834. 'character_string3' => ['value' => StatusCode::$noPrefix[1] . '-' . $orderInfoData[0]['no']], // 订单编号
  3835. 'date10' => ['value' => date('Y-m-d H:i:s', $orderInfoData[0]['createTime'])], // 下单时间
  3836. 'time4' => ['value' => date('Y-m-d H:i:s', time())], // 支付时间
  3837. 'thing7' => ['value' => '微信支付'], // 支付方式
  3838. 'name8' => ['value' => substr($orderInfoData[0]['shopName'],0,30)] // 商家名称
  3839. ];
  3840. $objMSystemPushMessage = new MSystemPushMessage($this->onlineUserId, $this->onlineEnterpriseId);
  3841. $result = $objMSystemPushMessage->sendWeiXinPushMessage(3, $customer['openId'], $sendMessageData);
  3842. if (!$result->isSuccess()) {
  3843. file_put_contents('/www/wwwroot/logs/api.junhailan.com/systemPushMessage.log', date('Y-m-d H:i:s') . 'bb' . var_export($result->getData(), true) . PHP_EOL, FILE_APPEND);
  3844. }
  3845. }
  3846. }
  3847. $this->objDOrder->commit();
  3848. $objMMerchantFlow = new MMerchantFlow($this->onlineEnterpriseId,$this->onlineUserId);
  3849. if ($isNotify == true || $orderData['payStatus'] == StatusCode::$standard){
  3850. foreach ($condition['id'] as $key => $id) {
  3851. $objMMerchantFlow->calculation($id);
  3852. }
  3853. }
  3854. return ResultWrapper::success('操作成功');
  3855. }
  3856. /**
  3857. * 更新索引表订单状态,支付状态,支付方式
  3858. * @param $orderData
  3859. * @param $params
  3860. * @return ResultWrapper
  3861. * @throws \Exception
  3862. */
  3863. private function updateOrderIndex($orderData, $params)
  3864. {
  3865. $this->objDOrderIndex->setTable('qianniao_order_index_' . $this->onlineEnterpriseId);
  3866. $updateData = [];
  3867. isset($orderData['payType']) && $updateData['payType'] = $orderData['payType'];
  3868. isset($orderData['payStatus']) && $updateData['payStatus'] = $orderData['payStatus'];
  3869. isset($orderData['orderStatus']) && $updateData['orderStatus'] = $orderData['orderStatus'];
  3870. isset($orderData['outStatus']) && $updateData['outStatus'] = $orderData['outStatus'];
  3871. $where['id'] = $params['id'];
  3872. $dbResult = $this->objDOrderIndex->update($updateData, $where);
  3873. if ($dbResult === false) {
  3874. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  3875. }
  3876. return ResultWrapper::success($dbResult);
  3877. }
  3878. /**
  3879. * 格式化返回数据
  3880. * @param $data
  3881. * @return array
  3882. * @throws \Exception
  3883. * @return ResultWrapper
  3884. */
  3885. private function format($data): ResultWrapper
  3886. {
  3887. // 提取所有订单id
  3888. $allOrderIds = [];
  3889. $allShopIds = [];
  3890. $allOrderNo = [];
  3891. $customerIds = [];
  3892. $allCustomerTypeIds = [];
  3893. if (isset($data['id'])) {
  3894. $dimension = $data;
  3895. unset($data);
  3896. $data[] = $dimension;
  3897. }
  3898. foreach ($data as $key => $value) {
  3899. $allOrderNo[] = $value['no'];
  3900. $allOrderIds[] = $value['id'];
  3901. $allShopIds[] = $value['shopId'];
  3902. $allCustomerTypeIds = $value['customerType'];
  3903. $customerIds[] = $value['customerId'];
  3904. $this->onlineUserId = $value['userCenterId'];
  3905. if ($value['auditStatus'] == StatusCode::$auditStatus['auditing']) {
  3906. $data[$key]['orderMsg'] = '待审核';
  3907. }
  3908. if ($value['auditStatus'] == StatusCode::$auditStatus['auditPass']) {
  3909. $data[$key]['orderMsg'] = '待出库';
  3910. if ($value['orderStatus'] == StatusCode::$orderStatus['waitReceive']) {
  3911. $data[$key]['orderMsg'] = '已出库';
  3912. if ($value['outStatus'] == 6 && $value['isRet'] != StatusCode::$standard){
  3913. $data[$key]['orderMsg'] = '部分出库';
  3914. }
  3915. }
  3916. if ($value['orderStatus'] == StatusCode::$orderStatus['finish']) {
  3917. $data[$key]['orderMsg'] = '已完成';
  3918. }
  3919. }
  3920. switch ($value['orderStatus']){
  3921. case StatusCode::$orderStatus['close']:
  3922. $data[$key]['orderMsg'] = '已关闭';
  3923. break;
  3924. case StatusCode::$orderStatus['cancelIng'];
  3925. $data[$key]['orderMsg'] = '待取消';
  3926. break;
  3927. }
  3928. if (isset($value['payType'])) {
  3929. $data[$key]['payTypeMsg'] = isset(StatusCode::$payType[$value['payType']]) ? StatusCode::$payType[$value['payType']] : '';
  3930. }
  3931. }
  3932. //获取客户类型
  3933. $customerTypeMap = [];
  3934. if (!empty($allCustomerTypeIds)) {
  3935. $objDCustomerSource = new DCustomerSource();
  3936. $customerSourceLists = $objDCustomerSource->select(['id' => $allCustomerTypeIds], 'id,name');
  3937. if ($customerSourceLists != false) {
  3938. foreach ($customerSourceLists as $val) {
  3939. $customerTypeMap[$val['id']] = $val['name'];
  3940. }
  3941. }
  3942. }
  3943. //获取店铺信息
  3944. $objMShop = new MShop($this->onlineEnterpriseId, $this->onlineUserId);
  3945. $shopData = $objMShop->getShopName($allShopIds);
  3946. /********************************订单商品 start****************************/
  3947. $objMOrderGoods = new MOrderGoods($this->onlineUserId, $this->onlineEnterpriseId);
  3948. $dbResult = $objMOrderGoods->getOrderGoodsByOrderIds(['orderId' => $allOrderIds, 'deleteStatus' => StatusCode::$standard]);
  3949. $orderGoodsData = [];//订单商品信息
  3950. if (!$dbResult->isSuccess()) {
  3951. return ResultWrapper::fail($dbResult->getData(),$dbResult->getErrorCode());
  3952. }
  3953. $orderGoodsData = $dbResult->getData();
  3954. unset($dbResult);
  3955. //查询sku信息
  3956. $objMSku = new MSku($this->onlineUserId, $this->onlineEnterpriseId);
  3957. //查询商品数据
  3958. $allGoodsIds = array_unique(array_column($orderGoodsData, 'goodsId'));
  3959. $allGoodsBasicIds = array_unique(array_column($orderGoodsData, 'goodsBasicId'));
  3960. $objMGoods = new MGoods($this->onlineEnterpriseId, false, $this->onlineUserId);
  3961. $goodsData = $objMGoods->getGoodsNames($allGoodsIds);
  3962. //获取商品的库存
  3963. $inventorySelectParams = [];
  3964. $objMInventory = new MInventory($this->onlineEnterpriseId, '');
  3965. foreach ($orderGoodsData as $item){
  3966. $inventorySelectParams[$item['shopId']][] = $item['skuId'];
  3967. }
  3968. $inventoryMap = [];
  3969. foreach ($inventorySelectParams as $shopId => $skuIds){
  3970. $inventoryResult = $objMInventory->getInventoryByShopIdAndSkuIds($shopId,$skuIds);
  3971. if (!$inventoryResult->isSuccess()) {
  3972. return ResultWrapper::fail($inventoryResult->getData(),$inventoryResult->getErrorCode());
  3973. }
  3974. $inventoryMap[$shopId] = $inventoryResult->getData();
  3975. }
  3976. //sku信息
  3977. $skuResult = $objMSku->getSpecNameBySkuId(array_column($orderGoodsData, 'skuId'));
  3978. if (!$skuResult->isSuccess()) {
  3979. return ResultWrapper::fail($skuResult->getData(),$skuResult->getErrorCode());
  3980. }
  3981. $allSku = $skuResult->getData();
  3982. $goods = [];
  3983. $allSkuIds = [];
  3984. foreach ($orderGoodsData as $val){
  3985. if (!in_array($val['skuId'],$allSkuIds)){
  3986. $allSkuIds[] = $val['skuId'];
  3987. }
  3988. }
  3989. foreach ($orderGoodsData as $key => &$value) {
  3990. $value['isNew'] = isset($allSku[$value['skuId']]['isNew']) ? $allSku[$value['skuId']]['isNew'] : StatusCode::$delete;
  3991. $value['barCode'] = isset($allSku[$value['skuId']]['barCode']) ? $allSku[$value['skuId']]['barCode'] : '';
  3992. $value['unitName'] = isset($allSku[$value['skuId']]['unitName']) ? $allSku[$value['skuId']]['unitName'] : '';
  3993. $value['specGroup'] = isset($allSku[$value['skuId']]['specGroup']) ? $allSku[$value['skuId']]['specGroup'] : [];
  3994. $value['images'] = isset($goodsData[$value['goodsId']]['images']) ? json_decode($goodsData[$value['goodsId']]['images'], true) : '';
  3995. $value['returnPrice'] = bcdiv(bcsub(bcsub($value['totalMoney'], $value['preferential']), $value['vipDiscount']), $value['buyNum']);
  3996. $value['isMater'] = isset($allSku[$value['skuId']]['isMaster']) ? $allSku[$value['skuId']]['isMaster'] : StatusCode::$delete;
  3997. $value['conversion'] = isset($allSku[$value['skuId']]['conversion']) ? $allSku[$value['skuId']]['conversion'] : 0;
  3998. $value['inventory'] = isset($inventoryMap[$value['shopId']][$value['skuId']]['num']) ? $inventoryMap[$value['shopId']][$value['skuId']]['num'] : 0;
  3999. // 处理订单商品表扩展字段
  4000. if( !empty($value['extends']) ){
  4001. $extends = json_decode($value['extends'], true);
  4002. if(!empty($extends)){
  4003. foreach($extends as $keys => $item){
  4004. $value[$keys] = $item;
  4005. }
  4006. }
  4007. }
  4008. $allOrderGoodsData[$value['orderId']][] = $value;
  4009. if (!isset($goods[$value['orderId']]['goodsPreferential'])) {
  4010. $goods[$value['orderId']]['goodsPreferential'] = 0;
  4011. }
  4012. $goods[$value['orderId']]['goodsPreferential'] = bcadd($goods[$value['orderId']]['goodsPreferential'], bcmul($value['preferential'], $value['buyNum']), 2);
  4013. }
  4014. unset($dbResult);
  4015. /********************************收货信息 start******************************/
  4016. $objMOrderReceive = new MOrderReceive($this->onlineUserId, $this->onlineEnterpriseId);
  4017. $dbResult = $objMOrderReceive->getOrderReceiveByOrderIds(['orderId' => $allOrderIds]);
  4018. $orderReceiveData = [];//订单收货信息
  4019. if (!$dbResult->isSuccess()) {
  4020. return ResultWrapper::fail($dbResult->getData(),$dbResult->getErrorCode());
  4021. }
  4022. $orderReceiveData = self::formatSysArea($dbResult->getData());
  4023. foreach ($orderReceiveData as $key => $value) {
  4024. $allOrderReceiveData[$value['orderId']] = $value;
  4025. }
  4026. unset($dbResult);
  4027. /*********************************订单操作记录*********************************/
  4028. $objMOrderLog = new MOrderLog($this->onlineEnterpriseId);
  4029. $orderLog = $objMOrderLog->getOrderLog(['no' => $allOrderNo]);
  4030. /**********************************获取基本配置*********************************/
  4031. $objMBasicSetup = new MBasicSetup($this->onlineEnterpriseId);
  4032. $setupResult = $objMBasicSetup->getBasicField('allowReturnDay');
  4033. if (!$setupResult->isSuccess()) {
  4034. return ResultWrapper::fail($setupResult->getData(),$setupResult->getErrorCode());
  4035. }
  4036. $setupResult = $setupResult->getData();
  4037. $allowReturnDay = empty($setupResult['allowReturnDay']) ? 0 : $setupResult['allowReturnDay'];
  4038. /********************************映射数据 start******************************/
  4039. $nowTime = time();
  4040. foreach ($data as $key => $value) {
  4041. $data[$key]['no'] = StatusCode::$noPrefix[1].'-'.$value['no'];
  4042. $data[$key]['extends'] = !empty($value['extends']) ? json_decode($value['extends'], true) : (object)[];
  4043. $data[$key]['goodsData'] = isset($allOrderGoodsData[$value['id']]) ? $allOrderGoodsData[$value['id']] : [];
  4044. $data[$key]['receiveData'] = isset($allOrderReceiveData[$value['id']]) ? $allOrderReceiveData[$value['id']] : [];
  4045. $data[$key]['deliveryNo'] = isset($value['deliveryNo']) ? $value['deliveryNo'] : '';
  4046. $data[$key]['payAmount'] = bcsub($value['payAmount'],$value['retMoney'],2);
  4047. $data[$key]['expressMoney'] = isset($value['expressMoney']) ? $value['expressMoney'] : '';
  4048. $data[$key]['expressName'] = isset($value['expressName']) ? $value['expressName'] : '';
  4049. $data[$key]['deliveryName'] = isset(StatusCode::$deliveryType[$value['deliveryType']]) ? StatusCode::$deliveryType[$value['deliveryType']] : '';//配送方式名称
  4050. $data[$key]['orderPreferential'] = bcsub($data[$key]['totalMoney'], bcsub($data[$key]['payAmount'], $data[$key]['expressMoney'], 2), 2);//订单优惠
  4051. $data[$key]['goodsPreferential'] = isset($goods[$value['id']]['goodsPreferential']) ? $goods[$value['id']]['goodsPreferential'] : '';//商品优惠
  4052. $data[$key]['coupon'] = '0.00';
  4053. $data[$key]['salesman'] = $value['salesManName'];
  4054. $data[$key]['shopName'] = isset($shopData[$value['shopId']]['name']) ? $shopData[$value['shopId']]['name'] : '';
  4055. $data[$key]['shopLogo'] = isset($shopData[$value['shopId']]['logo']) ? $shopData[$value['shopId']]['logo'] : '';
  4056. $data[$key]['orderLog'] = isset($orderLog[$value['no']]) ? $orderLog[$value['no']] : [];
  4057. $data[$key]['allowReturn'] = StatusCode::$standard;//允许退货
  4058. if ($allowReturnDay == 0) {
  4059. //TODO(没有设置可退货时间,默认都可以退)
  4060. $data[$key]['allowReturn'] = StatusCode::$standard;//允许退货
  4061. } else {
  4062. $expire = ($allowReturnDay * 86400) + $value['successFullyTime'];
  4063. if ($nowTime > $expire) {
  4064. $data[$key]['allowReturn'] = StatusCode::$delete;//不允许退货
  4065. }
  4066. }
  4067. $data[$key]['allowReturnDay'] = $allowReturnDay;
  4068. if ($value['source'] == StatusCode::$source['manage']){
  4069. $data[$key]['orderPreferential'] = isset($value['totalReduceMoney']) ? $value['totalReduceMoney'] : 0;
  4070. }else{
  4071. $data[$key]['orderPreferential'] = bcsub($value['totalMoney'], bcsub($value['payAmount'], $value['expressMoney'], 2), 2);//订单总优惠
  4072. }
  4073. $data[$key]['paidAmount'] = $value['payStatus'] == StatusCode::$standard ? $value['payAmount'] : '0';//已付款金额
  4074. $data[$key]['customerTypeName'] = isset($customerTypeMap[$value['customerType']]) ? $customerTypeMap[$value['customerType']] : '';
  4075. $data[$key]['cashierName'] = $value['cashierName'];
  4076. $data[$key]['customerMobile'] = $value['customerMobile'];//客户手机号码
  4077. $data[$key]['guideName'] = $value['guideName'];
  4078. $data[$key]['changeAmount'] = $value['changeSubMoney'];
  4079. $data[$key]['accountList'] = empty($value['accountList']) ? [] : json_decode($value['accountList'], true);
  4080. $data[$key]['receivedName'] = isset($allOrderReceiveData[$value['id']]['realName']) ? $allOrderReceiveData[$value['id']]['realName'] : '';//收货人
  4081. $data[$key]['receivedMobile'] = isset($allOrderReceiveData[$value['id']]['mobile']) ? $allOrderReceiveData[$value['id']]['mobile'] : '';//收货电话
  4082. $data[$key]['reservoir'] = !empty($value['reservoir']) ? json_decode($value['reservoir'],true) : [];
  4083. //$data[$key]['selfRuleData'] = empty($value['selfRuleData']) ? (object)[] : json_decode($value['selfRuleData'],true);
  4084. }
  4085. $data = array_shift($data);
  4086. if ($this->isFront === false) {
  4087. $data['expressData'] = (object)[];
  4088. if ($data['deliveryType'] == StatusCode::$deliveryType['goodsDelivery'] && $data['deliveryNo']) {
  4089. $expressResult = self::getExpressInfoByOrderId($data['id']);
  4090. if ($expressResult->isSuccess()) {
  4091. $data['expressData'] = $expressResult->getData();
  4092. }
  4093. }
  4094. }
  4095. return ResultWrapper::success($data);
  4096. }
  4097. /**
  4098. * 地区
  4099. * @param $data
  4100. * @return mixed
  4101. */
  4102. public function formatSysArea($data)
  4103. {
  4104. if (empty($data)) {
  4105. return $data;
  4106. }
  4107. $objMSysAreaChina = new MSysAreaChina();
  4108. foreach ($data as $key => $val) {
  4109. if (isset($val['provinceCode']) && isset($val['cityCode']) && isset($val['districtCode'])) {
  4110. $areaName = $objMSysAreaChina->getNameByCode([
  4111. $val['provinceCode'],
  4112. $val['cityCode'],
  4113. $val['districtCode']
  4114. ]);
  4115. $data[$key]['area']['provinceName'] = isset($areaName[$val['provinceCode']]) ? $areaName[$val['provinceCode']] : '';
  4116. $data[$key]['area']['cityName'] = isset($areaName[$val['cityCode']]) ? $areaName[$val['cityCode']] : '';
  4117. $data[$key]['area']['districtName'] = isset($areaName[$val['districtCode']]) ? $areaName[$val['districtCode']] : '';
  4118. }
  4119. }
  4120. return $data;
  4121. }
  4122. /**
  4123. * 查询订单
  4124. * 全部 {"page": 1,"pageSize": 10,"orderStatus": 0}
  4125. * 待付款 {"page": 1,"pageSize": 10,"orderStatus": 2}
  4126. * 待发货 {"page": 1,"pageSize": 10,"orderStatus": 3}
  4127. * 待收货 {"page": 1,"pageSize": 10,"orderStatus": 4}
  4128. * @param $selectParams
  4129. * @return ResultWrapper
  4130. * @throws \Exception
  4131. */
  4132. public function getOrderSelect($selectParams)
  4133. {
  4134. $limit = $selectParams['limit'];
  4135. unset($selectParams['limit']);
  4136. $offset = $selectParams['offset'];
  4137. unset($selectParams['offset']);
  4138. unset($selectParams['page']);
  4139. unset($selectParams['pageSize']);
  4140. $objMCustomer = new MCustomer($this->onlineEnterpriseId, $this->onlineUserId);
  4141. $customerId = $objMCustomer->getCustomerIdByUserCenterId($this->onlineUserId);
  4142. if (empty($customerId)) {
  4143. return ResultWrapper::fail('没有找到客户信息', ErrorCode::$paramError);
  4144. }
  4145. $selectParams['customerId'] = $customerId;
  4146. $selectParams['deleteStatus'] = StatusCode::$standard;
  4147. $dbResult = $this->objDOrder->select($selectParams, 'id,payType,outerTradeNo,payStatus,outStatus,verifyCode,totalMoney,payAmount,notPayMoney,shopId,no,orderStatus,createTime,deliveryType,auditStatus,isRet', 'createTime DESC,updateTime DESC', $limit, $offset);
  4148. if ($dbResult === false) {
  4149. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  4150. }
  4151. $total = $this->objDOrder->count($selectParams);
  4152. $return = [
  4153. 'data' => self::formatAndGoods($dbResult),
  4154. 'total' => ($total) ? intval($total) : 0,
  4155. ];
  4156. return ResultWrapper::success($return);
  4157. }
  4158. /**
  4159. * 格式化商品数据
  4160. *
  4161. * @param $data
  4162. * @return mixed
  4163. * @throws \Exception
  4164. */
  4165. private function formatAndGoods($data)
  4166. {
  4167. $allOrderIds = [];
  4168. $allShopIds = [];
  4169. foreach ($data as $key => $value) {
  4170. $allShopIds[] = $value['shopId'];
  4171. $allOrderIds[] = $value['id'];
  4172. }
  4173. $objMOrderGoods = new MOrderGoods($this->onlineUserId, $this->onlineEnterpriseId);
  4174. $selectParams = [
  4175. 'orderId' => $allOrderIds,
  4176. 'deleteStatus' => StatusCode::$standard,
  4177. ];
  4178. $dbResult = $objMOrderGoods->getOrderGoodsByOrderIds($selectParams);
  4179. $orderGoodsData = [];//订单商品信息
  4180. if ($dbResult->isSuccess()) {
  4181. $orderGoodsData = $dbResult->getData();
  4182. }
  4183. $allGoodsIds = array_unique(array_column($orderGoodsData, 'goodsId'));
  4184. unset($dbResult);
  4185. $objMGoods = new MGoods($this->onlineEnterpriseId, false, $this->onlineUserId);
  4186. $goodsData = $objMGoods->getGoodsNames($allGoodsIds);
  4187. if (empty($goodsData)) {
  4188. return $data;
  4189. }
  4190. $allOrderGoodsData = [];
  4191. foreach ($orderGoodsData as $key => &$value) {
  4192. $value['extends'] = !empty($value['extends']) ? json_decode($value['extends'], true) : [];
  4193. $value['images'] = isset($goodsData[$value['goodsId']]['images']) ? json_decode($goodsData[$value['goodsId']]['images'], true) : '';
  4194. // 如果是抄码商品,订单商品购买数量按照件算
  4195. if( $value['isEq'] == StatusCode::$standard){
  4196. $value['buyNum'] = isset($value['extends']['u_1_buy']) ? $value['extends']['u_1_buy'] : $value['buyNum'];
  4197. }
  4198. $allOrderGoodsData[$value['orderId']][] = $value;
  4199. }
  4200. $objMShop = new MShop($this->onlineEnterpriseId, $this->onlineUserId);
  4201. $shopData = $objMShop->getShopName($allShopIds);
  4202. foreach ($data as $key => $val) {
  4203. $data[$key]['deliveryTypeMsg'] = isset(StatusCode::$deliveryType[$val['deliveryType']]) ? StatusCode::$deliveryType[$val['deliveryType']] : '';
  4204. $data[$key]['goodsNum'] = isset($allOrderGoodsData[$val['id']]) ? array_sum(array_column($allOrderGoodsData[$val['id']], 'buyNum')) : '';
  4205. $data[$key]['shopName'] = isset($shopData[$val['shopId']]['name']) ? $shopData[$val['shopId']]['name'] : '';
  4206. $data[$key]['shopLogo'] = isset($shopData[$val['shopId']]['logo']) ? $shopData[$val['shopId']]['logo'] : '';
  4207. $data[$key]['goodsData'] = isset($allOrderGoodsData[$val['id']]) ? array_values($allOrderGoodsData[$val['id']]) : '';
  4208. }
  4209. return $data;
  4210. }
  4211. /**
  4212. * Doc: (des="订单检索条件")
  4213. * User: XMing
  4214. * Date: 2020/7/11
  4215. * Time: 9:48 上午
  4216. * @param $selectParams
  4217. * @param bool $is_export
  4218. * @return ResultWrapper
  4219. * @throws \Exception
  4220. */
  4221. public function search($selectParams, $is_export = false)
  4222. {
  4223. $defaultDSL = [
  4224. 'sort' => [
  4225. 'createTime' => [
  4226. 'order' => 'desc'
  4227. ],
  4228. ],
  4229. ];
  4230. if ($is_export === false) {
  4231. $defaultDSL['from'] = $selectParams['offset'];
  4232. $defaultDSL['size'] = $selectParams['limit'];
  4233. }
  4234. $dsl = [];
  4235. $dsl['query']['bool']['must'][] = [
  4236. 'term' => ['enterpriseId' => $this->onlineEnterpriseId],
  4237. ];
  4238. //订单编号,收货人,商品名称
  4239. if (!empty($selectParams['keyword'])) {
  4240. $dsl['query']['bool']['must'][] = [
  4241. 'multi_match' => [
  4242. 'fields' => ['no', 'verifyCode', 'mobile', 'goodsName', 'salesManName', 'customerName', 'remark'],
  4243. 'query' => $selectParams['keyword'],
  4244. //'fuzziness' => 'AUTO',
  4245. "type" => "best_fields",
  4246. "tie_breaker" => 0.3,
  4247. "minimum_should_match" => "100%"
  4248. ],
  4249. ];
  4250. }
  4251. //销售单/订单
  4252. if (isset($selectParams['orderType']) && !empty($selectParams['orderType'])) {
  4253. $dsl['query']['bool']['filter'][] =
  4254. ['term' => ['orderType' => $selectParams['orderType']]];
  4255. }
  4256. //订单状态
  4257. if (isset($selectParams['orderStatus']) && !empty($selectParams['orderStatus'])) {
  4258. $dsl['query']['bool']['filter'][] =
  4259. ['term' => ['orderStatus' => $selectParams['orderStatus']]];
  4260. }
  4261. //出库状态
  4262. if (isset($selectParams['outStatus']) && !empty($selectParams['outStatus'])) {
  4263. $dsl['query']['bool']['filter'][] =
  4264. ['term' => ['outStatus' => $selectParams['outStatus']]];
  4265. }
  4266. //退货状态
  4267. if (isset($selectParams['returnStatus']) && !empty($selectParams['returnStatus'])) {
  4268. $dsl['query']['bool']['filter'][] =
  4269. ['term' => ['returnStatus' => $selectParams['returnStatus']]];
  4270. }
  4271. //配送方式
  4272. if (isset($selectParams['deliveryType']) && !empty($selectParams['deliveryType'])) {
  4273. $dsl['query']['bool']['filter'][] =
  4274. ['term' => ['deliveryType' => $selectParams['deliveryType']]];
  4275. }
  4276. //支付状态
  4277. if (isset($selectParams['payType']) && !empty($selectParams['payType'])) {
  4278. $dsl['query']['bool']['filter'][] =
  4279. ['term' => ['payType' => $selectParams['payType']]];
  4280. }
  4281. //店铺id
  4282. parent::getAccessShopIds();
  4283. if (parent::$shopIds) {
  4284. $dsl['query']['bool']['filter'][] = [
  4285. 'terms' => ['shopId' => parent::$shopIds]
  4286. ];
  4287. }
  4288. //省code
  4289. if (isset($selectParams['provinceCode']) && !empty($selectParams['provinceCode'])) {
  4290. $dsl['query']['bool']['filter'][] =
  4291. ['term' => ['provinceCode' => $selectParams['provinceCode']]];
  4292. }
  4293. //市code
  4294. if (isset($selectParams['cityCode']) && !empty($selectParams['cityCode'])) {
  4295. $dsl['query']['bool']['filter'][] =
  4296. ['term' => ['cityCode' => $selectParams['cityCode']]];
  4297. }
  4298. //区code
  4299. if (isset($selectParams['districtCode']) && !empty($selectParams['districtCode'])) {
  4300. $dsl['query']['bool']['filter'][] =
  4301. ['term' => ['districtCode' => $selectParams['districtCode']]];
  4302. }
  4303. if (!empty($selectParams['start']) && !empty($selectParams['end'])) {
  4304. $dsl['query']['bool']['must'][] = [
  4305. 'range' => [
  4306. 'createTime' => [
  4307. 'gte' => $selectParams['start'],
  4308. 'lte' => $selectParams['end'],
  4309. ]
  4310. ]
  4311. ];
  4312. } else {
  4313. if (isset($selectParams['start']) && !empty($selectParams['start'])) {
  4314. $dsl['query']['bool']['must'][] = [
  4315. 'range' => [
  4316. 'createTime' => [
  4317. 'gte' => $selectParams['start'],
  4318. ]
  4319. ]
  4320. ];
  4321. }
  4322. if (isset($selectParams['end']) && !empty($selectParams['end'])) {
  4323. $dsl['query']['bool']['must'][] = [
  4324. 'range' => [
  4325. 'createTime' => [
  4326. 'lte' => $selectParams['end'],
  4327. ]
  4328. ]
  4329. ];
  4330. }
  4331. }
  4332. //店铺id
  4333. if (isset($selectParams['shopId']) && !empty($selectParams['shopId'])) {
  4334. $dsl['query']['bool']['filter'][] =
  4335. ['term' => ['shopId' => $selectParams['shopId']]];
  4336. }
  4337. //客户id
  4338. if (isset($selectParams['customerId']) && !empty($selectParams['customerId'])) {
  4339. $dsl['query']['bool']['filter'][] =
  4340. ['term' => ['customerId' => $selectParams['customerId']]];
  4341. }
  4342. //客户类型
  4343. if (isset($selectParams['customerType']) && !empty($selectParams['customerType'])) {
  4344. $dsl['query']['bool']['filter'][] =
  4345. ['term' => ['customerType' => $selectParams['customerType']]];
  4346. }
  4347. $flag = true;
  4348. //业务员id
  4349. if (isset($selectParams['salesManId']) && !empty($selectParams['salesManId'])) {
  4350. $dsl['query']['bool']['filter'][] =
  4351. ['term' => ['salesManId' => $selectParams['salesManId']]];
  4352. }
  4353. //销售员id
  4354. parent::getAccessSalesManIds();
  4355. if (!empty(parent::$salesManIds) && empty($selectParams['salesManId'])) {
  4356. $dsl['query']['bool']['filter'][] = [
  4357. 'terms' => ['salesManId' => parent::$salesManIds]
  4358. ];
  4359. }
  4360. if (!empty(parent::$salesManIds) && !empty($selectParams['salesManId'])) {
  4361. if (!in_array($selectParams['salesManId'], parent::$salesManIds)) {
  4362. $flag = false;
  4363. }
  4364. }
  4365. //订单来源
  4366. if (isset($selectParams['source']) && !empty($selectParams['source'])) {
  4367. $dsl['query']['bool']['filter'][] =
  4368. ['term' => ['source' => $selectParams['source']]];
  4369. }
  4370. //按照标示进行检索,等级最高
  4371. if (isset($selectParams['state']) && !empty($selectParams['state'])) {
  4372. $dsl = self::setOrderStatusDslAttr($dsl, $selectParams['state']);
  4373. }
  4374. $dsl = array_merge($defaultDSL, $dsl);
  4375. //导出
  4376. if ($is_export === true) self::exportSearch($dsl);
  4377. //V($dsl);
  4378. $result = $flag ? $this->objDOrder->getSearchQueryDsl($dsl) : [];
  4379. if (isset($result['status']) && $result['status'] == 400) {
  4380. //return ResultWrapper::fail('获取数据失败' . $result['error']['reason'], ErrorCode::$apiNotResult);
  4381. return ResultWrapper::success([
  4382. 'data' => [],
  4383. 'total' => 0
  4384. ]);
  4385. }
  4386. if (!isset($result['hits']) || $result['hits']['total'] == 0) {
  4387. return ResultWrapper::success([
  4388. 'data' => [],
  4389. 'total' => 0
  4390. ]);
  4391. }
  4392. $total = $result['hits']['total'];
  4393. $dbResult = $result['hits']['hits'];
  4394. $list = [];
  4395. foreach ($dbResult as $key => &$value) {
  4396. $data = [];
  4397. $data = $value['_source'];
  4398. //$data['id'] = $value['_id'];
  4399. $data['receiveData'] = [
  4400. 'realName' => $data['realName'],
  4401. 'mobile' => $data['mobile']
  4402. ];
  4403. unset($data['realName']);
  4404. unset($data['mobile']);
  4405. $list[] = $data;
  4406. }
  4407. $buildData = self::shiftEsReceiveData($list);
  4408. $formatResult = self::formatManageOrderList($buildData['allOrderData'], $buildData['allOrderReceiveData']);
  4409. if (!$formatResult->isSuccess()) {
  4410. return ResultWrapper::fail($formatResult->getData(), $formatResult->getErrorCode());
  4411. }
  4412. $return = [
  4413. 'data' => $formatResult->getData(),
  4414. 'total' => ($total) ? intval($total) : 0,
  4415. ];
  4416. return ResultWrapper::success($return);
  4417. }
  4418. /**
  4419. * Doc: (des="将es中查询出来的数据,统一转化为标准格式进行格式化")
  4420. * User: XMing
  4421. * Date: 2020/7/11
  4422. * Time: 6:13 下午
  4423. * @param $data
  4424. * @return array
  4425. */
  4426. private static function shiftEsReceiveData($data)
  4427. {
  4428. $orderData = [];
  4429. $orderReceiveData = [];
  4430. foreach ($data as $item) {
  4431. $orderData[] = $item;
  4432. $orderReceiveData[] = [
  4433. 'orderId' => $item['id'],
  4434. 'customerId' => $item['customerId'],
  4435. 'address' => $item['address'],
  4436. 'realName' => $item['receiveData']['realName'],
  4437. 'mobile' => $item['receiveData']['mobile'],
  4438. 'provinceCode' => $item['provinceCode'],
  4439. 'cityCode' => $item['cityCode'],
  4440. 'districtCode' => $item['districtCode']
  4441. ];
  4442. }
  4443. return [
  4444. 'allOrderData' => $orderData,
  4445. 'allOrderReceiveData' => $orderReceiveData
  4446. ];
  4447. }
  4448. /**
  4449. * 格式化订单状态
  4450. * @param $data
  4451. * @return mixed
  4452. */
  4453. private static function formatOrderStatus($data)
  4454. {
  4455. if (empty($data)) return $data;
  4456. foreach ($data as $key => $value) {
  4457. if ($value['auditStatus'] == StatusCode::$auditStatus['auditing']) {
  4458. $data[$key]['orderMsg'] = '待审核';
  4459. }
  4460. if ($value['auditStatus'] == StatusCode::$auditStatus['auditPass']) {
  4461. $data[$key]['orderMsg'] = '待出库';
  4462. if ($value['orderStatus'] == StatusCode::$orderStatus['waitReceive']) {
  4463. $data[$key]['orderMsg'] = '已出库';
  4464. if ($value['outStatus'] == 6 && $value['isRet'] != StatusCode::$standard){
  4465. $data[$key]['orderMsg'] = '部分出库';
  4466. }
  4467. }
  4468. if ($value['orderStatus'] == StatusCode::$orderStatus['finish']) {
  4469. $data[$key]['orderMsg'] = '已完成';
  4470. }
  4471. }
  4472. switch ($value['orderStatus']){
  4473. case StatusCode::$orderStatus['close']:
  4474. $data[$key]['orderMsg'] = '已关闭';
  4475. break;
  4476. case StatusCode::$orderStatus['cancelIng'];
  4477. $data[$key]['orderMsg'] = '待取消';
  4478. break;
  4479. // case StatusCode::$orderStatus['waitReceive'];
  4480. // $data[$key]['orderMsg'] = '待收货';
  4481. // break;
  4482. }
  4483. if (isset($value['payStatus'])) {
  4484. $data[$key]['payMsg'] = $value['payStatus'] == StatusCode::$standard ? '已支付' : '未支付';
  4485. }
  4486. if (isset($value['deliveryType'])) {
  4487. $data[$key]['deliveryMsg'] = isset(StatusCode::$deliveryType[$value['deliveryType']]) ? StatusCode::$deliveryType[$value['deliveryType']] : '';
  4488. }
  4489. if (isset($value['payType'])) {
  4490. $payTypeMsg = '';
  4491. if( isset(StatusCode::$payType[$value['payType']]) ){
  4492. $payTypeMsg = StatusCode::$payType[$value['payType']];
  4493. }else{// 组合支付渲染金额
  4494. if($value['extends']){
  4495. $admixPayData = json_decode($value['extends'],true);
  4496. $payTypeMsg = '组合支付(';
  4497. if(!empty($admixPayData)){
  4498. foreach ($admixPayData['admixPayData'] as $admixKey => $admixValue){
  4499. $payTypeMsg .= $admixValue['title'].'支付'.$admixValue['payMoney'].',';
  4500. }
  4501. }
  4502. $payTypeMsg .= ")";
  4503. }
  4504. }
  4505. $data[$key]['payTypeMsg'] = $payTypeMsg;
  4506. //$data[$key]['payTypeMsg'] = isset(StatusCode::$payType[$value['payType']]) ? StatusCode::$payType[$value['payType']] : '组合支付';
  4507. }
  4508. if (isset($value['source'])) {
  4509. $data[$key]['sourceMsg'] = isset(StatusCode::$source[$value['source']]) ? StatusCode::$source[$value['source']] : '';
  4510. }
  4511. if (isset($value['auditStatus'])) {
  4512. $data[$key]['auditMsg'] = isset(StatusCode::$auditStatus[$value['auditStatus']]) ? StatusCode::$auditStatus[$value['auditStatus']] : '';
  4513. }
  4514. }
  4515. return $data;
  4516. }
  4517. /**
  4518. * Doc: (des="订单标示的dsl拼接")
  4519. * User: XMing
  4520. * Date: 2020/7/11
  4521. * Time: 9:15 上午
  4522. * @param array $dsl
  4523. *
  4524. * @waitAudit:等待审核 orderStatus != 6 auditStatus = 1
  4525. * @waitOutStock:待出库 orderStatus != 6 auditPass = 2
  4526. * @hasOutStock:已出库 orderStatus = 4 auditPass = 2
  4527. * @finish:已完成 orderStatus = 5 auditPass 2
  4528. * @close:已关闭 orderStatus = 6
  4529. * @param string $states
  4530. * @return array|mixed
  4531. */
  4532. public static function setOrderStatusDslAttr(array $dsl, $states)
  4533. {
  4534. if (is_array($states)) {
  4535. $allAuditStatus = [];
  4536. $allOrderStatus = [];
  4537. foreach ($states as $state) {
  4538. $auditStatus = self::auditStatusAttrDsl($state);
  4539. $orderStatus = self::orderStatusAttrDsl($state);
  4540. $allAuditStatus = array_merge($auditStatus, $allAuditStatus);
  4541. $allOrderStatus = array_merge($orderStatus, $allOrderStatus);
  4542. }
  4543. } else {
  4544. $allAuditStatus = self::auditStatusAttrDsl($states);
  4545. $allOrderStatus = self::orderStatusAttrDsl($states);
  4546. }
  4547. if (!empty($allAuditStatus)) {
  4548. $dsl['query']['bool']['filter'][] = [
  4549. 'terms' => [
  4550. 'auditStatus' => $allAuditStatus
  4551. ]
  4552. ];
  4553. }
  4554. if (!empty($allOrderStatus)) {
  4555. $dsl['query']['bool']['filter'][] = [
  4556. 'terms' => [
  4557. 'orderStatus' => $allOrderStatus
  4558. ]
  4559. ];
  4560. }
  4561. return $dsl;
  4562. }
  4563. /**
  4564. * Doc: (des="state对应审核状态映射")
  4565. * User: XMing
  4566. * Date: 2020/7/13
  4567. * Time: 10:36 上午
  4568. * @param string $state
  4569. * @return array|mixed
  4570. */
  4571. public static function auditStatusAttrDsl(string $state)
  4572. {
  4573. $map = [
  4574. 'waitAudit' => [StatusCode::$auditStatus['auditing']],
  4575. 'waitOutStock' => [StatusCode::$auditStatus['auditPass']],
  4576. 'hasOutStock' => [StatusCode::$auditStatus['auditPass']],
  4577. 'finish' => [StatusCode::$auditStatus['auditPass']],
  4578. 'close' => [],
  4579. 'all' => []
  4580. ];
  4581. return isset($map[$state]) ? $map[$state] : [];
  4582. }
  4583. /**
  4584. * Doc: (des="state对应订单状态映射")
  4585. * User: XMing
  4586. * Date: 2020/7/13
  4587. * Time: 10:43 上午
  4588. * @param string $state
  4589. * @return array|mixed
  4590. */
  4591. public static function orderStatusAttrDsl(string $state)
  4592. {
  4593. $map = [
  4594. 'waitAudit' => [StatusCode::$orderStatus['waitPay'], StatusCode::$orderStatus['waitDelivery']],
  4595. 'waitOutStock' => [StatusCode::$orderStatus['waitPay'], StatusCode::$orderStatus['waitDelivery']],
  4596. 'hasOutStock' => [StatusCode::$orderStatus['waitReceive']],
  4597. 'finish' => [StatusCode::$orderStatus['finish']],
  4598. 'close' => [StatusCode::$orderStatus['close']],
  4599. 'all' => []
  4600. ];
  4601. return isset($map[$state]) ? $map[$state] : [];
  4602. }
  4603. /**
  4604. * 再次支付
  4605. *
  4606. * @param $params
  4607. * @param $ip
  4608. * @return ResultWrapper
  4609. * @throws \Exception
  4610. */
  4611. public function payOrder($params, $ip)
  4612. {
  4613. // file_put_contents('/www/wwwroot/logs/api.junhailan.com/pay_params.log', date('Y-m-d H:i:s') . '再次支付订单数据:' . var_export($params, true) . PHP_EOL, FILE_APPEND);
  4614. //order表切表
  4615. $fix = 1;
  4616. $this->objDOrder->setTable('qianniao_order_'.$this->onlineEnterpriseId.'_'.$fix);
  4617. $this->objDOrderIndex->setTable('qianniao_order_index_'.$this->onlineEnterpriseId);
  4618. $status = $this->objDOrder->beginTransaction();
  4619. //再次支付更新extend值
  4620. $extend = [];
  4621. // 处理混合支付数据
  4622. if( !empty($params['admixPayData']) ){
  4623. $extend['admixPayData'] = $params['admixPayData'];
  4624. }
  4625. // 处理银行打款数据
  4626. if( !empty($params['bankData']) ){
  4627. $extend['bankData'] = $params['bankData'];
  4628. }
  4629. $extend = json_encode($extend);
  4630. //再次付款更新extend(付款信息)
  4631. $updateExtend = $this->objDOrder->update(['extends'=>$extend],['no' => $params['no']]);
  4632. if ($updateExtend === false) {
  4633. $this->objDOrderIndex->rollBack();
  4634. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  4635. }
  4636. if($status){
  4637. $this->objDOrder->commit();
  4638. }
  4639. $orderData = $this->objDOrder->get(['no' => $params['no']]);
  4640. if ($orderData === false) {
  4641. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  4642. }
  4643. if (empty($orderData)) {
  4644. return ResultWrapper::fail('没有找到订单', ErrorCode::$paramError);
  4645. }
  4646. $params['payType'] = explode(',', $params['payType']);
  4647. $this->objDOrder->beginTransaction();
  4648. //再次支付时订单支付方式改为了货到付款
  4649. //if ($params['payType'] == StatusCode::$payType['cashPay']) {
  4650. if ( in_array(StatusCode::$payType['cashPay'], $params['payType']) || in_array(StatusCode::$payType['bankLoans'],$params['payType'])) {
  4651. //修改订单的支付方式
  4652. if(in_array(StatusCode::$payType['cashPay'], $params['payType'])){//货到付款 订单状态为待发货
  4653. $update = [
  4654. 'payType' => StatusCode::$payType['cashPay'],
  4655. 'orderStatus' => StatusCode::$orderStatus['waitDelivery']
  4656. ];
  4657. } else{//银行打款 订单状态为代发货
  4658. $update = [
  4659. 'payType' => StatusCode::$payType['bankLoans'],
  4660. 'orderStatus' => StatusCode::$orderStatus['waitPay'],
  4661. 'payStatus' => StatusCode::$delete
  4662. ];
  4663. }
  4664. $dbResult = $this->objDOrder->update($update, ['no' => $params['no']]);
  4665. if ($dbResult === false) {
  4666. $this->objDOrderIndex->rollBack();
  4667. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  4668. }
  4669. unset($dbResult);
  4670. //修改索引表支付方式
  4671. $this->objDOrderIndex->setTable('qianniao_order_index_' . $this->onlineEnterpriseId);
  4672. $dbResult = $this->objDOrderIndex->update($update, ['id' => $orderData['id']]);
  4673. if ($dbResult === false) {
  4674. $this->objDOrderIndex->rollBack();
  4675. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  4676. }
  4677. /*
  4678. //修改ES,支付方式
  4679. $_id = self::createEsDocumentId($orderData['id']);
  4680. $this->objDOrder->esupdateTypeFieldVaule(['payType' => StatusCode::$payType['cashPay']], $_id);*/
  4681. $this->objDOrder->commit();
  4682. //订单是否自动审核
  4683. $objMBasicSetup = new MBasicSetup($this->onlineEnterpriseId);
  4684. //获取基本配置
  4685. $setupResult = $objMBasicSetup->getBasicField('autoAuditOrder');
  4686. $autoAuditOrder = [];
  4687. if ($setupResult->isSuccess()) {
  4688. $autoAuditOrder = $setupResult->getData();//自动审核配置数据
  4689. $autoAuditOrder = isset($autoAuditOrder['autoAuditOrder']) ? $autoAuditOrder['autoAuditOrder'] : [];
  4690. }
  4691. //货到付款是否开启了自动审核
  4692. $autoAudit = isset($autoAuditOrder['cashPay']) ? $autoAuditOrder['cashPay'] : StatusCode::$delete;
  4693. if ($autoAudit == StatusCode::$standard) {
  4694. //开启了自动审核,审核订单
  4695. $auditResult = self::updateAuditStatus([
  4696. 'id' => $orderData['id'],
  4697. 'audit' => '自动审核',
  4698. 'auditId' => $this->onlineUserId,
  4699. 'auditStatus' => StatusCode::$auditStatus['auditPass']
  4700. ]);
  4701. }
  4702. return ResultWrapper::success($dbResult);
  4703. }
  4704. //获取客户信息
  4705. $objMCustomer = new MCustomer($this->onlineEnterpriseId, $this->onlineUserId);
  4706. $customerData = $objMCustomer->getCustomerInfoByUserCenterId($this->onlineUserId);
  4707. if (!$customerData->isSuccess()) {
  4708. return ResultWrapper::fail($customerData->getData(), $customerData->getErrorCode());
  4709. }
  4710. $customerData = $customerData->getData();
  4711. $payType = $params['payType'];
  4712. rsort($payType);
  4713. $payment = [];
  4714. $payParams = '';
  4715. $payStatus = StatusCode::$partion;
  4716. $orderStatus = StatusCode::$orderStatus['waitPay'];
  4717. if( in_array(StatusCode::$payType['bankLoans'],$payType) ){
  4718. $payStatus = StatusCode::$delete;
  4719. $orderStatus = StatusCode::$orderStatus['waitPay'];
  4720. }
  4721. foreach($payType as $k => $v){
  4722. // 除了余额支付其他方式都要获取支付配置
  4723. if($v != StatusCode::$payType['balance']){
  4724. $objMPaymentSetting = new MPaymentSetting($this->onlineUserId, $this->onlineEnterpriseId);
  4725. $result = $objMPaymentSetting->getPayData($v);
  4726. if (!$result->isSuccess() || empty($result->getData())) {
  4727. return ResultWrapper::fail('获取微信配置错误', ErrorCode::$configEroor);
  4728. }
  4729. $payment = $result->getData();
  4730. }
  4731. switch (true){
  4732. case in_array(StatusCode::$payType['balance'], $payType):
  4733. //余额支付
  4734. //$objMCustomer = new MCustomer($this->onlineEnterpriseId,$this->onlineUserId);
  4735. //减少余额()
  4736. $status = $this->objDOrderIndex->beginTransaction();
  4737. //新增会员流水记录
  4738. $memberBalanceDetailData = [
  4739. 'customerId' => $orderData['customerId'],
  4740. 'type' => StatusCode::$delete,
  4741. 'userCenterId' => $this->onlineUserId,
  4742. 'purpose' => '创建订单消费',
  4743. 'orderIds' =>implode(',',[$orderData['id']]),
  4744. 'remark' => '订单id'.implode(',',[$orderData['id']]),
  4745. 'financeType' => '会员余额消费'
  4746. ];
  4747. // 组合支付方式
  4748. if( !empty($params['admixPayData']) ) {
  4749. foreach ($params['admixPayData'] as $key => $value) {
  4750. if ($value['payType'] == StatusCode::$payType['balance']) {
  4751. // 本次混合支付余额支付金额
  4752. $memberBalanceDetailData['money'] = $value['payMoney'];
  4753. // 总金额 - 余额支付金额 = 剩余需要搭配支付金额
  4754. $orderData['payAmount'] = bcsub($orderData['payAmount'], $value['payMoney'], 2);
  4755. }
  4756. }
  4757. }else{
  4758. $payStatus = StatusCode::$standard;
  4759. $orderStatus = StatusCode::$orderStatus['waitDelivery'];
  4760. $memberBalanceDetailData['money'] = $orderData['payAmount'];
  4761. }
  4762. $objMMemberBalanceDetail = new MMemberBalanceDetail($this->onlineEnterpriseId,$this->onlineUserId);
  4763. $memberBalanceDbResult = $objMMemberBalanceDetail->addMemberBalanceDetail($memberBalanceDetailData);
  4764. if (!$memberBalanceDbResult->isSuccess()) {
  4765. $this->objDOrderIndex->rollBack();
  4766. return ResultWrapper::fail($memberBalanceDbResult->getData(), $memberBalanceDbResult->getErrorCode());
  4767. }
  4768. //扣除失败->订单未支付
  4769. if ($memberBalanceDbResult->isSuccess()){
  4770. $time = time();
  4771. //扣除成功->订单支付成功\
  4772. foreach ([$orderData['id']] as $orderId){
  4773. $updateIndexResult = $this->objDOrderIndex->update(['payStatus' => $payStatus,'orderStatus' => $orderStatus,'updateTime' => $time],$orderId);
  4774. if ($updateIndexResult === false){
  4775. $this->objDOrderIndex->rollBack();
  4776. return ResultWrapper::fail($this->objDOrderIndex->error(),ErrorCode::$dberror);
  4777. }
  4778. $updateIndex = $this->objDOrder->update(['payStatus' => $payStatus,'orderStatus' => $orderStatus,'payTime'=> $time,'updateTime' => $time,'payAmount'=>$memberBalanceDetailData['money']],$orderId);
  4779. if ($updateIndex === false){
  4780. $this->objDOrderIndex->rollBack();
  4781. return ResultWrapper::fail($this->objDOrder->error(),ErrorCode::$dberror);
  4782. }
  4783. }
  4784. }
  4785. $status && $this->objDOrderIndex->commit();
  4786. $payParams = ResultWrapper::success([]);
  4787. break;
  4788. case in_array(StatusCode::$payType['aliPay'], $payType):
  4789. //ali
  4790. /*********读取支付宝支付参数(原配置)*********/
  4791. /**$aliPayConfigData = Factory::config()->get('alipay');
  4792. * if (empty($aliPayConfigData)) {
  4793. * return ResultWrapper::fail('支付宝配置错误', ErrorCode::$configEroor);
  4794. * }*/
  4795. $payOrderData = [
  4796. 'subject' => '千鸟云商',
  4797. 'out_trade_no' => $orderData['no'],
  4798. 'total_amount' => $orderData['payAmount'],
  4799. 'passback_params' => $this->onlineEnterpriseId . '|' . $this->onlineUserId . '|' . implode('|', [$orderData['id']]),
  4800. ];
  4801. $aliPayConfigData = [
  4802. 'appid' => $payment['appid'],
  4803. 'rsaPrivateKey' => $payment['rsaPrivateKey'],
  4804. 'alipayrsaPublicKey' => $payment['alipayrsaPublicKey'],
  4805. ];
  4806. $objAliPay = new aliPay($aliPayConfigData['appid'], $aliPayConfigData['rsaPrivateKey'], $aliPayConfigData['alipayrsaPublicKey']);
  4807. $payParams = $objAliPay->appPay($payOrderData);
  4808. break;
  4809. case in_array(StatusCode::$payType['wxPay'], $payType):
  4810. //wx
  4811. /********************生成小程序唤起支付用到的参数(原配置)*****/
  4812. /**$weixinConfigData = Factory::config()->get('weixin');
  4813. * if (empty($weixinConfigData)) {
  4814. * return ResultWrapper::fail('微信配置错误', ErrorCode::$configEroor);
  4815. * }*/
  4816. // 获取当前登录企业的小程序配置
  4817. $objSystemCache = new SystemCache();
  4818. $miniprogramSetting = $objSystemCache->getAppIdByEnterpriseId($this->onlineEnterpriseId);
  4819. if (empty($miniprogramSetting)) {
  4820. return ResultWrapper::fail('后台小程序配置项为空', ErrorCode::$configEroor);
  4821. }
  4822. $miniprogramSetting = json_decode($miniprogramSetting, true);//获取小程序appid
  4823. // 获取配置文件微信公众号
  4824. /**$weixinConfigData = Factory::config()->get('weixin');
  4825. * if (empty($weixinConfigData)) {
  4826. * return ResultWrapper::fail('微信配置错误', ErrorCode::$configEroor);
  4827. * }*/
  4828. switch ($params['source']) {
  4829. case StatusCode::$source['ByteProgram'];
  4830. //$appid = $weixinConfigData['offiaccount']['appid'];
  4831. $appid = $miniprogramSetting['appid'];
  4832. $paySource = 'byteDanceH5';
  4833. break;
  4834. case StatusCode::$source['miniProgram'];
  4835. $appid = $miniprogramSetting['appid'];
  4836. $paySource = 'miniProgram';
  4837. break;
  4838. default :
  4839. $appid = $payment['mobileAppid'];
  4840. $paySource = 'APP';
  4841. break;
  4842. }
  4843. $weixinConfigData = [
  4844. 'mch_id' => $payment['mchId'],
  4845. 'apiPartnerKey' => $payment['apiPartnerKey'],
  4846. 'appid' => $appid
  4847. ];
  4848. $attach = $this->onlineEnterpriseId . '|' . $this->onlineUserId . '|' . implode('|', [$orderData['id']]);
  4849. //$objPay = new Pay($appid, $weixinConfigData['pay']['mch_id'], $weixinConfigData['pay']['apiPartnerKey']);//old
  4850. $objPay = new Pay($appid, $weixinConfigData['mch_id'], $weixinConfigData['apiPartnerKey']);
  4851. $payParams = $objPay->unifiedorder($orderData['no'],$orderData['payAmount'], $ip, $paySource, '千鸟云商', $customerData['openId'], $attach);
  4852. break;
  4853. case in_array(StatusCode::$payType['byte'],$payType):
  4854. //字节跳动
  4855. $mweb_url = '';
  4856. //读取缓存配置
  4857. //$objSystemCache->getByteDanceSetting($this->onlineEnterpriseId);
  4858. // 获取配置文件字节小程序
  4859. $byteDanceConfigData = Factory::config()->getAppoint('byteDance', 'pay');
  4860. if (empty($byteDanceConfigData)) {
  4861. return ResultWrapper::fail('字节跳动配置错误', ErrorCode::$configEroor);
  4862. }
  4863. $objbytePay = new bytePay($byteDanceConfigData['appid'], $byteDanceConfigData['merchant_id'], $byteDanceConfigData['app_secret']);
  4864. unset($payParams);
  4865. $payParams = $objbytePay->pay($orderData['no'],$orderData['payAmount'], '千鸟云商', $ip, $mweb_url);
  4866. break;
  4867. case in_array(StatusCode::$payType['bankLoans'], $payType):
  4868. $payParams = ResultWrapper::success([$orderData['id']]);
  4869. break;
  4870. default:
  4871. //TODO
  4872. return ResultWrapper::fail('暂未开放的支付方式',ErrorCode::$paramError);
  4873. break;
  4874. }
  4875. unset($payType[$k]);
  4876. if (!$payParams->isSuccess()) {
  4877. return ResultWrapper::fail($payParams->getData(), $payParams->getErrorCode());
  4878. }
  4879. }
  4880. return ResultWrapper::success($payParams->getData());
  4881. }
  4882. /**
  4883. * 增加打印次数
  4884. * @param $id
  4885. * @return ResultWrapper
  4886. */
  4887. public function printIncr($id)
  4888. {
  4889. $dbResult = $this->objDOrder->set_inc('printingNum', ['id' => $id]);
  4890. if ($dbResult === false) {
  4891. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  4892. }
  4893. return ResultWrapper::success($dbResult);
  4894. }
  4895. /**
  4896. * todo(保存编辑(废弃))
  4897. *
  4898. * @param $params
  4899. * @return ResultWrapper
  4900. * @throws \Exception
  4901. */
  4902. public function saveEdit($params)
  4903. {
  4904. $this->objDOrderIndex->setTable('qianniao_order_index_' . $this->onlineEnterpriseId);
  4905. $objMOrderGoods = new MOrderGoods($this->onlineUserId, $this->onlineEnterpriseId);
  4906. $objMShippingAddress = new MShippingAddress($this->onlineEnterpriseId);
  4907. $objMOrderReceive = new MOrderReceive($this->onlineUserId, $this->onlineEnterpriseId);
  4908. $order = $this->objDOrder->get(['id' => $params['orderId']]);
  4909. if ($order === false) {
  4910. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  4911. }
  4912. if (empty($order)) {
  4913. return ResultWrapper::fail('订单不存在', ErrorCode::$paramError);
  4914. }
  4915. if (!isset($order['auditStatus'])
  4916. || $order['auditStatus'] == StatusCode::$auditStatus['auditPass']
  4917. || $order['payStatus'] == StatusCode::$standard
  4918. ) {
  4919. return ResultWrapper::fail('订单不能编辑', ErrorCode::$paramError);
  4920. }
  4921. //根据地址id获取地址信息
  4922. $dbResult = $objMShippingAddress->getShippingAddressInfo($params['receiveAddressId']);
  4923. if (!$dbResult->isSuccess()) {
  4924. return ResultWrapper::fail($dbResult->getData(), ErrorCode::$dberror);
  4925. }
  4926. $addressData = $dbResult->getData();
  4927. if (empty($addressData)) {
  4928. return ResultWrapper::fail('收货地址信息不存在', ErrorCode::$dberror);
  4929. }
  4930. //锁定库存 查询商铺对应的仓库
  4931. $objMWarehouse = new MWarehouse($this->onlineEnterpriseId);
  4932. $warehouseData = $objMWarehouse->getWarehouseInfo(['shopId' => $params['goodsData']['goodsData'][0]['shopId']]);
  4933. if (!$warehouseData->isSuccess()) {
  4934. return ResultWrapper::fail($params['goodsData']['goodsData'][0]['shopId'] . $warehouseData->getData(), $warehouseData->getErrorCode());
  4935. }
  4936. $warehouse = $warehouseData->getData();
  4937. $commonData = $params['goodsData'];
  4938. $this->objDOrder->beginTransaction();
  4939. //先解锁库存
  4940. // $objMInventory = new MInventory($this->onlineEnterpriseId, $this->onlineUserId);
  4941. // $unlockResult = $objMInventory->unlockInventory([$order['id']], StatusCode::$orderType['saleOrder'], $order['createTime']);
  4942. // if (!$unlockResult->isSuccess()) {
  4943. // $this->objDOrder->rollBack();
  4944. // return ResultWrapper::fail($unlockResult->getData(), ErrorCode::$dberror);
  4945. // }
  4946. $dbResult = $this->objDOrderIndex->update(['deliveryType' => $params['deliveryType']], ['id' => $params['orderId']]);
  4947. if ($dbResult === false) {
  4948. $this->objDOrder->rollBack();
  4949. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  4950. }
  4951. //修改Order表中的数据
  4952. $dbResult = $this->objDOrder->update([
  4953. 'totalMoney' => $commonData['totalMoney'],
  4954. 'payAmount' => $commonData['payMoney'],
  4955. 'deliveryType' => $params['deliveryType'],
  4956. 'buyTotal' => array_sum(array_column($commonData['goodsData'], 'buyNum'))
  4957. ], ['id' => $params['orderId']]);
  4958. if ($dbResult === false) {
  4959. $this->objDOrder->rollBack();
  4960. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  4961. }
  4962. unset($dbResult);
  4963. //修改OrderGoods表中的数据
  4964. if (!empty($params['delOrderGoodsIds'])) {
  4965. $dbResult = $objMOrderGoods->updateDetails(['deleteStatus' => StatusCode::$delete], ['id' => $params['delOrderGoodsIds']]);
  4966. if (!$dbResult->isSuccess()) {
  4967. $this->objDOrder->rollBack();
  4968. return ResultWrapper::fail($dbResult->getData(), ErrorCode::$dberror);
  4969. }
  4970. unset($dbResult);
  4971. }
  4972. //查询当前订单商品,进行比对
  4973. $dbResult = $objMOrderGoods->getDetails([
  4974. 'orderId' => $params['orderId'],
  4975. 'deleteStatus' => StatusCode::$standard,
  4976. ]);
  4977. if (!$dbResult->isSuccess()) {
  4978. $this->objDOrder->rollBack();
  4979. return ResultWrapper::fail($dbResult->getData(), ErrorCode::$dberror);
  4980. }
  4981. $oldGoodsData = $dbResult->getData();
  4982. $hash = [];
  4983. foreach ($oldGoodsData as $goods) {
  4984. $hash[] = md5($goods['goodsId'] . $goods['skuId']);
  4985. }
  4986. $lockInventoryData = [];
  4987. foreach ($commonData['goodsData'] as $value) {
  4988. foreach ($value['shopGoodsData'] as $key => $val) {
  4989. $rowHash = md5($val['goodsId'] . $val['skuId']);
  4990. if (in_array($rowHash, $hash)) {
  4991. //update
  4992. $dbResult = $objMOrderGoods->updateDetails(
  4993. [
  4994. 'buyNum' => $val['buyNum'],
  4995. 'price' => $val['price'],
  4996. 'originPrice' => $val['originPrice'],
  4997. 'totalMoney' => $val['totalMoney'],
  4998. ],
  4999. ['orderId' => $params['orderId'], 'goodsId' => $val['goodsId'], 'skuId' => $val['skuId']]
  5000. );
  5001. if (!$dbResult->isSuccess()) {
  5002. $this->objDOrder->rollBack();
  5003. return ResultWrapper::fail($dbResult->getData(), ErrorCode::$dberror);
  5004. }
  5005. } else {
  5006. //insert
  5007. $dbResult = $objMOrderGoods->addOrderGoods([
  5008. 'no' => $order['no'],
  5009. 'orderId' => $params['orderId'],
  5010. 'goodsId' => $val['goodsId'],
  5011. 'goodsName' => $val['goodsName'],
  5012. 'shopId' => $val['shopId'],//商铺id
  5013. 'shopName' => $val['shopName'],//商铺名称
  5014. 'originPrice' => $val['originPrice'],
  5015. 'price' => $val['price'],
  5016. 'buyNum' => $val['buyNum'],
  5017. 'totalMoney' => $val['totalMoney'],
  5018. 'skuId' => $val['skuId'],
  5019. 'goodsBasicId' => $val['goodsBasicId'],
  5020. 'goodsCode' => $val['goodsCode'],
  5021. 'deliverNum' => $val['buyNum'],//发货数量=购买数量
  5022. 'unitName' => $val['unitName'],//单位名称
  5023. 'conversion' => $val['conversion'],//换算比率
  5024. 'preferential' => $val['preferential'],//优惠券优惠金额
  5025. 'vipDiscount' => $val['vipDiscount'],//会员卡优惠金额
  5026. ]);
  5027. if (!$dbResult->isSuccess()) {
  5028. $this->objDOrder->rollBack();
  5029. return ResultWrapper::fail($dbResult->getData(), ErrorCode::$dberror);
  5030. }
  5031. }
  5032. //锁定库存数据
  5033. $lockInventoryData[] = [
  5034. 'warehouseId' => $warehouse['id'],
  5035. 'materielId' => $val['goodsBasicId'],
  5036. 'lockingNum' => empty((float)($val['conversion'])) ? $val['buyNum'] : bcdiv($val['buyNum'], $val['conversion']),
  5037. 'originId' => $params['orderId'],
  5038. 'originNo' => $order['no'],
  5039. 'source' => StatusCode::$orderType['saleOrder'],
  5040. 'sourceNo' => $order['no'],
  5041. 'operatorId' => $order['customerId'],
  5042. 'operatorName' => $order['customerName'],
  5043. 'skuId' => $val['skuId'],
  5044. ];
  5045. }
  5046. }
  5047. //锁定库存
  5048. // $lockInventoryResult = $objMInventory->updateLockInventory($lockInventoryData);
  5049. // if (!$lockInventoryResult->isSuccess()) {
  5050. // $this->objDOrder->rollBack();
  5051. // return ResultWrapper::fail($lockInventoryResult->getData(), $lockInventoryResult->getErrorCode());
  5052. // }
  5053. //修改收货人
  5054. $dbResult = $objMOrderReceive->updateReceive(
  5055. [
  5056. 'customerCode' => $addressData['customerCode'],//客户编码
  5057. 'realName' => $addressData['name'],//收货人姓名
  5058. 'mobile' => $addressData['mobile'],//收货人电话
  5059. 'address' => $addressData['address'],//收货人详细地址
  5060. 'provinceCode' => $addressData['provinceCode'],
  5061. 'cityCode' => $addressData['cityCode'],
  5062. 'districtCode' => $addressData['districtCode'],
  5063. ],
  5064. [
  5065. 'orderId' => $params['orderId']
  5066. ]
  5067. );
  5068. if (!$dbResult->isSuccess()) {
  5069. $this->objDOrder->rollBack();
  5070. return ResultWrapper::fail($dbResult->getData(), ErrorCode::$dberror);
  5071. }
  5072. $this->objDOrder->commit();
  5073. /*
  5074. $_id = self::createEsDocumentId($params['orderId']);
  5075. $this->objDOrder->esupdateTypeFieldVaule([
  5076. 'totalMoney' => $commonData['totalMoney'],
  5077. 'payAmount' => $commonData['payMoney'],
  5078. 'buyTotal' => array_sum(array_column($commonData['goodsData'], 'buyNum')),//购买总数
  5079. 'deliveryType' => $params['deliveryType'],
  5080. 'realName' => $addressData['name'],//收货人姓名
  5081. 'mobile' => $addressData['mobile'],//收货人电话
  5082. 'address' => $addressData['address'],//收货详细地址
  5083. 'provinceCode' => $addressData['provinceCode'],//收货人省份编码
  5084. 'cityCode' => $addressData['cityCode'],//收货人城市编码
  5085. 'districtCode' => $addressData['districtCode'],//收货人区编码
  5086. ], $_id);
  5087. //修改es中的数据*/
  5088. return ResultWrapper::success('操作成功');
  5089. }
  5090. /**
  5091. * 订单编辑(现在只能编辑订单支付金额)
  5092. * @param $params
  5093. * @return ResultWrapper
  5094. */
  5095. public function orderEdit($params)
  5096. {
  5097. $order = $this->objDOrder->get(['id' => $params['orderId']]);
  5098. if ($order === false) {
  5099. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  5100. }
  5101. if (empty($order)) {
  5102. return ResultWrapper::fail('订单不存在', ErrorCode::$paramError);
  5103. }
  5104. if (!isset($order['auditStatus'])
  5105. || $order['auditStatus'] == StatusCode::$auditStatus['auditPass']
  5106. || $order['payStatus'] == StatusCode::$standard
  5107. ) {
  5108. return ResultWrapper::fail('订单不能编辑', ErrorCode::$paramError);
  5109. }
  5110. //修改payAmount,将payAmount复制到字段originPayAmount
  5111. $update = [
  5112. 'payAmount' => sprintf("%.2f", $params['editAmount']),
  5113. 'originPayAmount' => $order['payAmount'],//原付款金额
  5114. ];
  5115. $dbResult = $this->objDOrder->update($update, ['id' => $params['orderId']]);
  5116. if ($dbResult === false) {
  5117. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  5118. }
  5119. /*
  5120. //修改es中的数据
  5121. $_id = self::createEsDocumentId($params['orderId']);
  5122. $this->objDOrder->esupdateTypeFieldVaule([
  5123. 'payAmount' => $update['payAmount'],
  5124. 'originPayAmount' => $update['originPayAmount'],//原付款金额
  5125. ], $_id);*/
  5126. return ResultWrapper::success('操作成功');
  5127. }
  5128. /**
  5129. * Doc: (des="")
  5130. * User: XMing
  5131. * Date: 2020/9/2
  5132. * Time: 9:16 上午
  5133. * @param array $params
  5134. * @return ResultWrapper
  5135. *
  5136. * @throws \Exception
  5137. */
  5138. public function cashierOrder(array $params)
  5139. {
  5140. $objMUserCoupon = new MUserCoupon($this->onlineUserId, $this->onlineEnterpriseId);
  5141. $objMCustomer = new MCustomer($this->onlineEnterpriseId, $this->onlineUserId);
  5142. $objMCustomerBalance = new MCustomerBalance($this->onlineEnterpriseId, $this->onlineUserId);
  5143. $objMCart = new MCart($this->onlineUserId, $this->onlineEnterpriseId);
  5144. $objMOrderGoods = new MOrderGoods($this->onlineUserId, $this->onlineEnterpriseId);
  5145. $objDStaff = new DStaff();
  5146. $objStockCache = new Stock($this->onlineEnterpriseId);
  5147. $objDStaff->setTable('qianniao_staff_' . $this->onlineEnterpriseId);
  5148. $this->objDOrderIndex->setTable('qianniao_order_index_' . $this->onlineEnterpriseId);
  5149. $goodsCommonData = $params['goodsData'];
  5150. //锁定库存 查询商铺对应的仓库
  5151. $objMShop = new MShop($this->onlineEnterpriseId, $this->onlineUserId);
  5152. $modelResult = $objMShop->getShopDataByShopIds(array_column($goodsCommonData['goodsData'], 'shopId'));
  5153. if (!$modelResult->isSuccess()) {
  5154. return ResultWrapper::fail($modelResult->getData(), $modelResult->getErrorCode());
  5155. }
  5156. $shopData = $modelResult->getData();
  5157. if (empty($shopData)) {
  5158. return ResultWrapper::fail('获取店铺数据失败', ErrorCode::$paramError);
  5159. }
  5160. //获取收银员信息
  5161. $allUids = [$this->loginUserCenterId];
  5162. if (isset($params['guideUids']) && !empty($params['guideUids'])) {
  5163. $ids = explode(',', $params['guideUids']);
  5164. $allUids = array_merge($allUids, $ids);
  5165. }
  5166. $userMap = [];
  5167. if (!empty($allUids)) {
  5168. $staffList = $objDStaff->select(['userCenterId' => $allUids], 'userCenterId,staffName');
  5169. if ($staffList === false) {
  5170. return ResultWrapper::fail($objDStaff->error(), ErrorCode::$dberror);
  5171. }
  5172. foreach ($staffList as $value) {
  5173. $userMap[$value['userCenterId']] = $value['staffName'];
  5174. }
  5175. }
  5176. $params['cashierName'] = isset($userMap[$this->loginUserCenterId]) ? $userMap[$this->loginUserCenterId] : '超级管理员';
  5177. $nameStr = '';
  5178. if (!empty($ids)) {
  5179. foreach ($ids as $uid) {
  5180. if (!empty($nameStr)) {
  5181. $nameStr .= ',';
  5182. }
  5183. $nameStr .= isset($userMap[$uid]) ? $userMap[$uid] : '';
  5184. }
  5185. }
  5186. $params['guideName'] = $nameStr;
  5187. $params['customerMobile'] = '';
  5188. //获取客户信息
  5189. $customerOwe = 0;
  5190. if ($this->onlineUserId == StatusCode::$noneUserCenter) {
  5191. $customerData = [
  5192. 'id' => StatusCode::$noneCustomer,
  5193. 'name' => '匿名客户'
  5194. ];
  5195. } else {
  5196. $customerDataResult = $objMCustomer->getCustomerInfoByUserCenterId($this->onlineUserId);
  5197. if (!$customerDataResult->isSuccess()) {
  5198. return ResultWrapper::fail($customerDataResult->getData(), $customerDataResult->getErrorCode());
  5199. }
  5200. $customerData = $customerDataResult->getData();
  5201. //获取客户当前欠款
  5202. if (isset($customerData['id'])) {
  5203. $customerOwe = $objMCustomerBalance->getCustomerBalance($customerData['id']);
  5204. }
  5205. //获取客户手机号
  5206. $objDUserCenter = new DUserCenter();
  5207. $userInfo = $objDUserCenter->get(['id' => $this->onlineUserId], 'mobile');
  5208. if ($userInfo === false) {
  5209. return ResultWrapper::fail($objDUserCenter->error(), ErrorCode::$dberror);
  5210. }
  5211. $params['customerMobile'] = isset($userInfo['mobile']) ? $userInfo['mobile'] : '';
  5212. }
  5213. // 生成一个临时三方流水号,用来支持多个子订单作为一个订单支付,支付成功之后更新为对应的实际外部支付流水号
  5214. $tmpOuterTradeNo = 'tmp' . createOrderSn($params['source'], StatusCode::$orderType['cashierOrder'], $this->onlineUserId);
  5215. $lockInventoryData = [];//锁定库存物料
  5216. $goodsSaleData = [];//销售数据
  5217. $allSn = [];//所有单号
  5218. $allOrderIds = [];//所有订单
  5219. $mapDetails = [];//订单商品
  5220. $createTime = time();
  5221. $allCartIds = [];
  5222. $shopName = '';
  5223. $shopId = 0;//目前只有一个
  5224. $this->objDOrder->beginTransaction();
  5225. foreach ($goodsCommonData['goodsData'] as $key => $val) {
  5226. $sn = createOrderSn($params['source'], StatusCode::$orderType['saleOrder'], $this->onlineUserId);
  5227. //将数据写入索引表
  5228. $shopId = $val['shopId'];
  5229. $orderIndexData = [
  5230. 'shopId' => $val['shopId'],
  5231. 'userCenterId' => $params['userCenterId'],
  5232. 'salesManId' => isset($customerData['salesManId']) ? $customerData['salesManId'] : 0,
  5233. 'createTime' => time(),
  5234. 'updateTime' => time(),
  5235. 'deleteStatus' => StatusCode::$standard,
  5236. 'auditStatus' => StatusCode::$auditStatus['auditing'],
  5237. 'payStatus' => StatusCode::$delete,
  5238. 'orderStatus' => StatusCode::$orderStatus['waitPay'],
  5239. 'outStatus' => StatusCode::$delete,
  5240. 'returnStatus' => StatusCode::$orderReturn['notReturn'],
  5241. 'deliveryType' => $params['deliveryType'],
  5242. 'payType' => $params['payType'],
  5243. 'customerId' => isset($customerData['id']) ? $customerData['id'] : 0,
  5244. 'no' => $sn,
  5245. 'orderType' => StatusCode::$orderType['cashierOrder'],
  5246. 'selfRuleId' => 0,
  5247. 'cashierUid' => $this->loginUserCenterId,
  5248. 'guideUids' => $params['guideUids']
  5249. ];
  5250. //1. 先写索引表
  5251. $this->objDOrderIndex->setTable('qianniao_order_index_' . $this->onlineEnterpriseId);
  5252. $orderId = $this->objDOrderIndex->insert($orderIndexData);
  5253. if ($orderId === false) {
  5254. $this->objDOrder->rollBack();
  5255. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  5256. }
  5257. //3。上门自提订单,生成核销码
  5258. $verifyCode = self::createVerifyCode($orderId);
  5259. //兼容以前代码
  5260. $updateRes = $this->objDOrderIndex->update(['verifyCode' => $verifyCode], ['id' => $orderId]);
  5261. if ($updateRes === false) {
  5262. $this->objDOrder->rollBack();
  5263. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  5264. }
  5265. //订单数据
  5266. $shopName = $val['shopName'];//现在就一个店铺
  5267. $masterOrder = [
  5268. 'id' => $orderId,//订单id
  5269. 'customerId' => isset($customerData['id']) ? $customerData['id'] : 0,
  5270. 'userCenterId' => $params['userCenterId'],
  5271. 'shopId' => $val['shopId'],
  5272. 'shopName' => $val['shopName'],
  5273. 'no' => $sn,
  5274. 'outerTradeNo' => $tmpOuterTradeNo,
  5275. 'totalMoney' => $goodsCommonData['totalMoney'],
  5276. 'payAmount' => $goodsCommonData['payMoney'],
  5277. 'customerName' => isset($customerData['name']) ? $customerData['name'] : '',
  5278. 'remark' => $params['remark'],
  5279. 'deliveryType' => $params['deliveryType'],//配送方式
  5280. 'payType' => $params['payType'],//支付方式
  5281. 'salesManId' => isset($customerData['salesManId']) ? $customerData['salesManId'] : 0,
  5282. 'salesManName' => isset($customerData['salesManName']) ? $customerData['salesManName'] : '',
  5283. 'customerType' => isset($customerData['type']) ? $customerData['type'] : 0,
  5284. 'buyTotal' => array_sum(array_column($val['shopGoodsData'], 'buyNum')),
  5285. 'source' => $params['source'],//来源
  5286. 'orderStatus' => StatusCode::$orderStatus['waitPay'],
  5287. 'returnStatus' => StatusCode::$orderReturn['notReturn'],
  5288. 'outStatus' => StatusCode::$delete,
  5289. 'createTime' => time(),
  5290. 'updateTime' => time(),
  5291. 'customerOwe' => $customerOwe,//客户当前欠款
  5292. 'auditStatus' => StatusCode::$auditStatus['auditing'],
  5293. 'preferential' => $goodsCommonData['preferential'],//优惠券优惠金额
  5294. 'vipDiscount' => isset($goodsCommonData['vipDiscount']) ? $goodsCommonData['vipDiscount'] : 0,//会员卡优惠金额
  5295. 'vipDoubleDiscount' => isset($goodsCommonData['vipDoubleDiscount']) ? $goodsCommonData['vipDoubleDiscount'] : 0,//会员卡折上折优惠金额
  5296. 'originPayAmount' => $goodsCommonData['payMoney'],//原支付金额,
  5297. 'orderType' => StatusCode::$orderType['cashierOrder'],
  5298. 'verifyCode' => $verifyCode,
  5299. 'expressMoney' => isset($goodsCommonData['expressMoney']) ? $goodsCommonData['expressMoney'] : 0,
  5300. 'cashierUid' => $this->loginUserCenterId,
  5301. 'guideUids' => $params['guideUids'],
  5302. 'cashierName' => $params['cashierName'],
  5303. 'guideName' => $params['guideName'],
  5304. 'remMoney' => isset($goodsCommonData['rem_money']) ? $goodsCommonData['rem_money'] : 0,
  5305. 'changeSubMoney' => isset($goodsCommonData['subPrice']) ? $goodsCommonData['subPrice'] : 0,
  5306. 'isNoneUser' => $this->onlineUserId == StatusCode::$noneUserCenter ? StatusCode::$standard : StatusCode::$delete,
  5307. 'customerMobile' => $params['customerMobile'],
  5308. 'serialNum' => $objStockCache->createSerialSn(0,'Order'),
  5309. 'operatorName' => isset($params['operatorName']) ? $params['operatorName'] : '',
  5310. 'operatorId' => isset($params['operatorId']) ? $params['operatorId'] : 0,
  5311. ];
  5312. $allOrderIds[] = $orderId;
  5313. //2。订单表
  5314. $orderId = $this->objDOrder->insert($masterOrder);
  5315. if ($orderId === false) {
  5316. $this->objDOrder->rollBack();
  5317. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  5318. }
  5319. $masterOrder['goodsName'] = '';
  5320. foreach ($val['shopGoodsData'] as $k => &$v) {
  5321. $addOrderGoods = [
  5322. 'no' => $sn,
  5323. 'orderId' => $orderId,
  5324. 'goodsId' => $v['goodsId'],
  5325. 'goodsName' => $v['goodsName'],
  5326. 'shopId' => $val['shopId'],//商铺id
  5327. 'shopName' => $val['shopName'],//商铺名称
  5328. 'originPrice' => $v['originPrice'],
  5329. 'price' => $v['price'],
  5330. 'buyNum' => $v['buyNum'],
  5331. 'totalMoney' => $v['totalMoney'],
  5332. 'skuId' => $v['skuId'],
  5333. 'goodsBasicId' => $v['goodsBasicId'],
  5334. 'goodsCode' => $v['goodsCode'],
  5335. 'deliverNum' => $v['buyNum'],//发货数量=购买数量
  5336. 'unitName' => $v['unitName'],//单位名称
  5337. 'conversion' => $v['conversion'],//换算比率
  5338. 'preferential' => $v['preferential'],//优惠券优惠金额
  5339. 'vipDiscount' => $v['vipDiscount'],//会员卡优惠金额
  5340. 'categoryPath' => isset($v['categoryPath']) ? $v['categoryPath'] : '',//分类路径
  5341. 'brandId' => isset($v['brandId']) ? $v['brandId'] : 0,//品牌id
  5342. 'specGroup' => isset($v['specGroup']) && !empty($v['specGroup']) ? json_encode($v['specGroup']) : NULL,
  5343. 'goodsImages' => isset($v['goodsImages']) && is_string($v['goodsImages']) ? $v['goodsImages'] : '',
  5344. 'barCode' => isset($v['barCode']) ? $v['barCode'] : '',
  5345. 'storageCode' => isset($v['storageCode']) ? $v['storageCode'] : '',
  5346. 'categoryName' => isset($v['categoryName']) ? $v['categoryName'] : '',
  5347. 'brandName' => isset($v['brandName']) ? $v['brandName'] : '',
  5348. 'expressMoney' => isset($v['expressMoney']) ? $v['expressMoney'] : 0,
  5349. 'outNum' => 0,//已出库数量
  5350. 'outOfNum' => getArrayItem($v, 'buyNum', 0),//未出库数量
  5351. 'isEq' => getArrayItem($v,'isEq',StatusCode::$delete),
  5352. 'extends' => json_encode(getArrayItem($v, 'extends', null)),
  5353. ];
  5354. $lockInventoryData[] = [
  5355. 'warehouseId' => $shopData[$v['shopId']]['warehouseId'],
  5356. 'materielId' => $v['goodsBasicId'],
  5357. 'materielCode' => $v['goodsCode'],
  5358. 'lockingNum' => $v['buyNum'],
  5359. 'originId' => $orderId,
  5360. 'originNo' => $sn,
  5361. 'source' => StatusCode::$orderType['saleOrder'],
  5362. 'sourceNo' => $sn,
  5363. 'operatorId' => $masterOrder['customerId'],
  5364. 'operatorName' => $masterOrder['customerName'],
  5365. 'skuId' => $v['skuId'],
  5366. ];
  5367. $goodsSaleData [] = [
  5368. 'goodsId' => $addOrderGoods['goodsId'],
  5369. 'skuId' => $addOrderGoods['skuId'],
  5370. 'buyNum' => $addOrderGoods['buyNum'],
  5371. ];
  5372. //活动商品数据
  5373. if ($this->isFront) {
  5374. if (isset($v['activityId']) && $v['activityId'] != 0) {
  5375. $activityData[] = [
  5376. 'goodsId' => $v['goodsId'],
  5377. 'skuId' => $v['skuId'],
  5378. 'activityId' => $v['activityId'],
  5379. 'buyNum' => $v['buyNum']
  5380. ];
  5381. }
  5382. }
  5383. $masterOrder['goodsName'] .= $v['goodsName'] . ' ';
  5384. $result = $objMOrderGoods->addOrderGoods($addOrderGoods);
  5385. if (!$result->isSuccess()) {
  5386. $this->objDOrder->rollBack();
  5387. return ResultWrapper::fail($result->getData(), ErrorCode::$dberror);
  5388. }
  5389. $allCartIds[] = $v['cartId'];
  5390. }
  5391. //存入ES
  5392. $masterOrder['verifyCode'] = isset($verifyCode) ? $verifyCode : '';
  5393. self::updateEsData($orderId, $masterOrder, [], $masterOrder['goodsName']);
  5394. $allSn[] = $sn;//所有订单号
  5395. }
  5396. $this->objDOrder->commit();
  5397. $this->objDOrder->beginTransaction();
  5398. //删除购物车内已生成订单商品
  5399. $objMCashierCart = new MCashierCart($this->onlineUserId, $this->onlineEnterpriseId, $this->loginUserCenterId);
  5400. $result = $objMCashierCart->delCart($allCartIds, true);
  5401. if (!$result->isSuccess()) {
  5402. $this->objDOrder->rollBack();
  5403. return ResultWrapper::fail($result->getData(), ErrorCode::$dberror);
  5404. }
  5405. //将优惠券改为已使用
  5406. if (isset($goodsCommonData['useCoupon']) && !empty($goodsCommonData['useCoupon'])) {
  5407. $result = $objMUserCoupon->updateIsUse(['id' => $goodsCommonData['useCoupon']['id']], ['isUse' => StatusCode::$delete, 'useTime' => time()]);
  5408. if (!$result->isSuccess()) {
  5409. $this->objDOrder->rollBack();
  5410. return ResultWrapper::fail($result->getData(), ErrorCode::$dberror);
  5411. }
  5412. }
  5413. //锁定库存商品数量
  5414. $objMInventory = new MInventory($this->onlineEnterpriseId, $this->onlineUserId);
  5415. $lockInventoryResult = $objMInventory->updateLockInventory($shopId,$lockInventoryData);
  5416. if (!$lockInventoryResult->isSuccess()) {
  5417. $this->objDOrder->rollBack();
  5418. return ResultWrapper::fail($lockInventoryResult->getData(), $lockInventoryResult->getErrorCode());
  5419. }
  5420. //增加销量
  5421. $objMGoods = new MGoods($this->onlineEnterpriseId, false, $this->onlineUserId);
  5422. if (!empty($goodsSaleData)) {
  5423. foreach ($goodsSaleData as $value) {
  5424. $res = $objMGoods->updateSalesNum($value['goodsId'], $value['skuId'], $value['buyNum']);
  5425. if ($res === false) {
  5426. Logger::logs(E_USER_ERROR, '错误', __CLASS__, __LINE__, '商品增加销量失败');
  5427. }
  5428. }
  5429. }
  5430. //file_put_contents('/www/wwwroot/logs/api.junhailan.com/MSaleOrder_error.log', date('Y-m-d H:i:s') . '数据:' . var_export($mapDetails, true) . PHP_EOL, FILE_APPEND);
  5431. $this->objSaleOrder->setGoodsDetails($mapDetails);
  5432. //统计订单信息
  5433. self::noticeStatistics([
  5434. 'userCenterId' => $params['userCenterId'],
  5435. 'enterpriseId' => $this->onlineEnterpriseId,
  5436. 'customerId' => $params['customerId'],
  5437. 'no' => $allSn,
  5438. 'noticeType' => 'create',
  5439. ], 'MOrderStatistics');
  5440. //写日志
  5441. foreach ($allSn as $sn) {
  5442. parent::saveLog([
  5443. 'no' => $sn,
  5444. 'actionType' => '创建订单',//创建订单
  5445. 'operationData' => '',
  5446. 'userCenterId' => $params['userCenterId'],
  5447. 'enterpriseId' => $this->onlineEnterpriseId,
  5448. 'createTime' => time(),
  5449. ]);
  5450. }
  5451. //自动审核订单
  5452. $objMInventoryOut = new MInventoryOut($this->onlineEnterpriseId, $this->onlineUserId);
  5453. foreach ($allOrderIds as $key => $id) {
  5454. //自动审核订单
  5455. $auditResult = self::updateAuditStatus([
  5456. 'id' => $id,
  5457. 'audit' => '自动审核',
  5458. 'auditId' => $this->onlineUserId,
  5459. 'auditStatus' => StatusCode::$auditStatus['auditPass']
  5460. ]);
  5461. if (!$auditResult->isSuccess()) {
  5462. $this->objDOrder->rollBack();
  5463. return ResultWrapper::fail($auditResult->getData(), $auditResult->getErrorCode());
  5464. }
  5465. $outId = $auditResult->getData();//出库单id
  5466. //自动出库
  5467. $dbResult = $objMInventoryOut->updateInventoryOutStatus(['id' => $outId, 'auditId' => $this->loginUserCenterId, 'auditName' => '销售自动审核']);
  5468. if (!$dbResult->isSuccess()) {
  5469. $this->objDOrder->rollBack();
  5470. return ResultWrapper::fail($dbResult->getData(), $dbResult->getErrorCode());
  5471. }
  5472. }
  5473. //确认收款
  5474. $dbResult = self::updateOrderPayData(['payStatus' => StatusCode::$standard, 'payTime' => time()], ['id' => $allOrderIds]);
  5475. if (!$dbResult->isSuccess()) {
  5476. $this->objDOrder->rollBack();
  5477. return ResultWrapper::fail($dbResult->getData(), $dbResult->getErrorCode());
  5478. }
  5479. //确认收货
  5480. foreach ($allOrderIds as $orderId) {
  5481. $dbResult = self::updateOrderStatus($orderId, ['orderStatus' => StatusCode::$orderStatus['finish']], []);
  5482. if (!$dbResult->isSuccess()) {
  5483. $this->objDOrder->rollBack();
  5484. return ResultWrapper::fail($dbResult->getData(), $dbResult->getErrorCode());
  5485. }
  5486. $objMCashier = new MCashier($this->onlineUserId, $this->onlineEnterpriseId);
  5487. $cashierResult = $objMCashier->calculatePushMoney($orderId);
  5488. if (!$cashierResult->isSuccess()) {
  5489. Logger::logs(E_USER_ERROR, '订单提成计算失败', __CLASS__, __LINE__, $cashierResult->getData());
  5490. }
  5491. }
  5492. //创建收款单
  5493. $received = [
  5494. 'currentAccountName' => $params['currentAccountName'],
  5495. 'financeType' => '销售收款',
  5496. 'financeTypeId' => 2,
  5497. 'shopId' => $shopId,
  5498. 'shopName' => $shopName,
  5499. 'receiptTime' => time(),
  5500. 'operatorId' => $this->loginUserCenterId,
  5501. 'accountList' => $params['accountList'],
  5502. 'customerId' => $customerData['id'],
  5503. 'customerName' => $customerData['name'],
  5504. 'sourceNo' => $sn,
  5505. 'sourceNoMoney' => $goodsCommonData['payMoney'],
  5506. 'createTime' => time(),
  5507. 'auditStatus' => StatusCode::$auditStatus['auditing'],
  5508. 'updateTime' => time(),
  5509. ];
  5510. $objMReceived = new MReceived($this->onlineEnterpriseId, $this->loginUserCenterId);
  5511. $receivedResult = $objMReceived->addReceived($received, true);
  5512. if (!$receivedResult->isSuccess()) {
  5513. $this->objDOrder->rollBack();
  5514. return ResultWrapper::fail($receivedResult->getData(), $receivedResult->getErrorCode());
  5515. }
  5516. $this->objDOrder->commit();
  5517. if ($this->onlineUserId == StatusCode::$noneUserCenter) {
  5518. $objDCashierCustomerPrice = new DCashierCustomerPrice();
  5519. $objDCashierCustomerPrice->setTable('qianniao_cashier_customer_price_' . $this->onlineEnterpriseId);
  5520. $objDCashierCustomerPrice->delete(['cashierUid' => $this->loginUserCenterId, 'customerUid' => StatusCode::$noneUserCenter]);
  5521. }
  5522. return ResultWrapper::success($orderId);
  5523. }
  5524. /**
  5525. * 订单打印小票
  5526. */
  5527. public function printOrder()
  5528. {
  5529. $data = [];
  5530. $goodsDetails = $this->objSaleOrder->getGoodsDetails();
  5531. foreach ($goodsDetails as $value) {
  5532. $data[$value['goodsId']]['title'] = $value['goodsName'];
  5533. $data[$value['goodsId']]['skuData'][] = [
  5534. 'skuName' => isset($value['specName']) ? $value['specName'] : '',
  5535. 'unitName' => isset($value['unitName']) ? $value['unitName'] : '',
  5536. 'unitPrice' => isset($value['unitPrice']) ? $value['unitPrice'] : 0.00,
  5537. 'num' => isset($value['buyNum']) ? $value['buyNum'] : 0,
  5538. 'amountPrice' => isset($value['totalMoney']) ? $value['totalMoney'] : 0
  5539. ];
  5540. }
  5541. $printData = [
  5542. 'createTime' => $this->objSaleOrder->getCreateTime(),
  5543. 'shopName' => $this->objSaleOrder->getShopName(),
  5544. 'title' => $this->objSaleOrder->getReceiptTitle(),
  5545. 'codeName' => $this->objSaleOrder->getCodeName(),
  5546. 'code' => $this->objSaleOrder->getNo(),
  5547. 'userName' => $this->objSaleOrder->getCustomerName(),
  5548. 'mobile' => $this->objSaleOrder->getCustomerMobile(),
  5549. 'preferential' => $this->objSaleOrder->getPreferentialAmount(), //优惠金额
  5550. 'totalMoney' => $this->objSaleOrder->getTotalAmount(),
  5551. 'payAmount' => $this->objSaleOrder->getPayAmount(),
  5552. 'address' => $this->objSaleOrder->getAddress(),
  5553. 'details' => $data
  5554. ];
  5555. $formatPrint = parent::formatMsg($printData);
  5556. $objCloudPrint = new CloudPrint();
  5557. $objCloudPrint->sendMsg($formatPrint, $this->onlineEnterpriseId);
  5558. }
  5559. /**
  5560. * 将所有商品库存转换为主单位sku
  5561. * @param $data
  5562. * @return array|ResultWrapper
  5563. * @throws \Exception
  5564. */
  5565. public function formatMerge($data)
  5566. {
  5567. //将相同的商品合并到一起并启用到主单位的
  5568. $allMapping = [];
  5569. if (empty($data)) return $data;
  5570. $allMapping = [];
  5571. $all = [];
  5572. $objMSku = new MSku($this->onlineUserId, $this->onlineEnterpriseId);
  5573. $res = $objMSku->getMaterSkuId(['goodsId' => array_values(array_unique(array_column($data, 'goodsBasicId'))), 'isMaster' => StatusCode::$standard, 'deleteStatus' => StatusCode::$standard]);
  5574. if (!$res->isSuccess()) {
  5575. return ResultWrapper::fail($res->getData(), ErrorCode::$dberror);
  5576. }
  5577. $skuData = $res->getData();
  5578. foreach ($data as &$goods) {
  5579. $goods['masterSkuId'] = $skuData[$goods['goodsBasicId']];
  5580. $allMapping[$goods['goodsId']][] = [
  5581. 'buyNum' => $goods['conversion'] == 0 ? $goods['buyNum'] : bcdiv($goods['buyNum'], $goods['conversion'], 2),
  5582. 'skuId' => $goods['skuId'],
  5583. 'conversion' => $goods['conversion'],
  5584. 'goodsId' => $goods['goodsId'],
  5585. 'masterSkuId' => $goods['masterSkuId']
  5586. ];
  5587. }
  5588. unset($goods);
  5589. foreach ($allMapping as $key => $goods) {
  5590. $all[] = [
  5591. 'buyNum' => array_sum(array_column($allMapping[$key], 'buyNum')),
  5592. 'goodsId' => $goods[0]['goodsId'],
  5593. 'skuId' => $goods[0]['masterSkuId'],//都换算成主单位的
  5594. ];
  5595. }
  5596. return ResultWrapper::success($all);
  5597. }
  5598. /**
  5599. * 确认收款检测出库状态
  5600. * @param $id
  5601. * @return ResultWrapper
  5602. */
  5603. public function checkOutOrderStatus($id)
  5604. {
  5605. $dbResult = $this->objDOrder->get_field('outStatus', ['id' => $id]);
  5606. if ($dbResult === false) {
  5607. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  5608. }
  5609. if (empty($dbResult)) {
  5610. return ResultWrapper::fail('没有找到订单信息', ErrorCode::$paramError);
  5611. }
  5612. if ($dbResult == StatusCode::$delete) {
  5613. return ResultWrapper::fail('订单未出库暂时不能确认收款', ErrorCode::$paramError);
  5614. }
  5615. return ResultWrapper::success($dbResult);
  5616. }
  5617. /**
  5618. * 销售订单毛利明细
  5619. * @param $params
  5620. * @return ResultWrapper
  5621. * @throws \Exception
  5622. */
  5623. public function getOrderProfit($params,$export = 0)
  5624. {
  5625. $limit = $params['limit'];
  5626. unset($params['limit']);
  5627. $offset = $params['offset'];
  5628. unset($params['offset']);
  5629. if($export){
  5630. $limit = 999;
  5631. $offset = 0;
  5632. }
  5633. $modelResult = self::formatOrderTableName($params);
  5634. if (!$modelResult->isSuccess()) {
  5635. return ResultWrapper::fail($modelResult->getData(), $modelResult->getErrorCode());
  5636. }
  5637. $tables = $modelResult->getData();
  5638. if (empty($tables)) {
  5639. return ResultWrapper::fail('表后缀计算失败', ErrorCode::$paramError);
  5640. }
  5641. $whereSql = ' where o.shopId = ' . $params['shopId'] . ' and g.goodsId = ' . $params['goodsId'] . ' and o.createTime between ' . $params['start'] . ' and ' . $params['end'];
  5642. if (isset($params['customerId']) && !empty($params['customerId'])) {
  5643. $whereSql .= ' and customerId = ' . $params['customerId'];
  5644. }
  5645. $field = 'o.id as orderId,o.no,o.customerId,o.customerName,o.createTime,o.shopId,o.shopName,o.orderStatus,o.outStatus,o.orderType,g.goodsId,g.goodsCode,g.goodsName,g.price,g.buyNum,(g.preferential + g.vipDiscount) as discount, g.outCostPrice,g.goodsBasicId,g.skuId,g.totalMoney';
  5646. $sql = '';
  5647. foreach ($tables as $value) {
  5648. !empty($sql) && $sql = $sql . ' union all ';
  5649. $orderTableName = 'qianniao_order_' . $this->onlineEnterpriseId . '_' . $value;
  5650. $orderGoodsTableName = 'qianniao_order_goods_' . $this->onlineEnterpriseId . '_' . $value;
  5651. $sql = '(select ' . $field . ' from ' . $orderGoodsTableName . ' g left join ' . $orderTableName . ' o on o.id = g.orderId ' . $whereSql . ')';
  5652. }
  5653. $twoField = 'orderId,no,customerId,customerName,createTime,shopId,shopName,orderStatus,outStatus,orderType,goodsId,goodsCode,goodsName,price,buyNum,discount,outCostPrice,goodsBasicId,skuId,totalMoney';
  5654. $sql = 'select ' . $twoField . ' from (' . $sql . ') as details ';
  5655. $selectSql = $sql . 'order by createTime desc limit ' . $offset . ',' . $limit;
  5656. $dbResult = $this->objDOrder->query($selectSql);
  5657. if ($dbResult === false) {
  5658. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$paramError);
  5659. }
  5660. //提取客户数据
  5661. if (empty($dbResult)) {
  5662. return ResultWrapper::fail('查询结果为空', ErrorCode::$dberror);
  5663. }
  5664. $customerData = [];
  5665. foreach ($dbResult as &$value) {
  5666. if (!isset($customerData[$value['customerId']])) {
  5667. $customerData[$value['customerId']] = [
  5668. 'id' => $value['customerId'],
  5669. 'name' => $value['customerName'],
  5670. ];
  5671. }
  5672. //销售成本
  5673. $value['saleCostAmount'] = bcmul($value['buyNum'], $value['outCostPrice'], 4);
  5674. //销售毛利
  5675. $value['saleProfitAmount'] = bcsub($value['totalMoney'], $value['saleCostAmount'], 8);
  5676. //毛利率
  5677. $value['saleProfitRate'] = "0.00";
  5678. if ($value['saleProfitAmount'] > 0 && $value['saleCostAmount'] > 0) {
  5679. $value['saleProfitRate'] = bcmul(bcdiv($value['saleProfitAmount'], $value['totalMoney'], 8), 100, 4);
  5680. }
  5681. }
  5682. unset($value);
  5683. if($export){
  5684. self::exportOrderProfit($dbResult);
  5685. exit;
  5686. }
  5687. $countSql = 'select count(orderId) as count from ( ' . $sql . ' ) as selectDetails';
  5688. $totalDbResult = $this->objDOrder->query($countSql);
  5689. if ($totalDbResult === false) {
  5690. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  5691. }
  5692. $total = array_shift($totalDbResult)['count'];
  5693. $return['data']['customerData'] = array_values($customerData);
  5694. $return['data']['data'] = $dbResult;
  5695. $return['total'] = ($total) ? intval($total) : 0;
  5696. return ResultWrapper::success($return);
  5697. }
  5698. /**
  5699. * 计算表名后缀
  5700. * @param $params
  5701. * @return ResultWrapper
  5702. * @throws \Exception
  5703. */
  5704. public function formatOrderTableName($params)
  5705. {
  5706. $whereSql = '';
  5707. if (isset($params['shopId']) && !empty($params['shopId'])) {
  5708. $whereSql = empty($whereSql) ? $whereSql . ' where ' : $whereSql . ' and ';
  5709. $whereSql .= ' shopId = ' . $params['shopId'];
  5710. }
  5711. if (isset($params['customerId']) && !empty($params['customerId'])) {
  5712. $whereSql = empty($whereSql) ? $whereSql . ' where ' : $whereSql . ' and ';
  5713. $whereSql .= ' customerId = ' . $params['customerId'];
  5714. }
  5715. if (isset($params['start']) && !empty($params['start']) && isset($params['end']) && !empty($params['end'])) {
  5716. $whereSql = empty($whereSql) ? $whereSql . ' where ' : $whereSql . ' and ';
  5717. $whereSql .= ' createTime between ' . $params['start'] . ' and ' . $params['end'];
  5718. }
  5719. $this->objDOrderIndex->setTable('qianniao_order_index_' . $this->onlineEnterpriseId);
  5720. $indexSql = 'select userCenterId from ' . $this->objDOrderIndex->get_Table() . $whereSql;
  5721. $dbResult = $this->objDOrderIndex->query($indexSql);
  5722. if ($dbResult === false) {
  5723. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$paramError);
  5724. }
  5725. if (empty($dbResult)) {
  5726. return ResultWrapper::success([]);
  5727. }
  5728. $tables = [];
  5729. foreach ($dbResult as $value) {
  5730. //格式化数据 根据userCenterId 计算所有goods表名
  5731. $num = (int)ceil($value['userCenterId'] / $this->cutTable);
  5732. $tableName = 'qianniao_order_' . $this->onlineEnterpriseId . '_' . $num;
  5733. $existsTable = $this->objDOrder->existsTable($tableName);
  5734. if ($existsTable && !in_array($num, $tables)) {
  5735. $tables[] = $num;
  5736. }
  5737. }
  5738. return ResultWrapper::success($tables);
  5739. }
  5740. /************************************************统计项 start******************************************************/
  5741. /**
  5742. * @param $key
  5743. * @param $shopId
  5744. * @return ResultWrapper
  5745. */
  5746. public function businessOverview($key, $shopId)
  5747. {
  5748. $result = $this->objOverviewCache->getBusinessOverview($this->onlineEnterpriseId, $key, $shopId);
  5749. return $result;
  5750. }
  5751. /**
  5752. * 客单价
  5753. * @param $key
  5754. * @param $shopId
  5755. * @return int|string
  5756. */
  5757. public function customerAverageMoney($key, $shopId)
  5758. {
  5759. $objCustomerCache = new CustomerCache();
  5760. $orderConfirmedMoney = $this->objOverviewCache->getBusinessOverview($this->onlineEnterpriseId, 'orderConfirmedMoney', $shopId);//营业额
  5761. $customerNum = array_sum($objCustomerCache->getTodayCustomerOrderInfo($this->onlineEnterpriseId, null, $shopId));
  5762. if ($orderConfirmedMoney == 0 || $customerNum == 0) return 0;
  5763. return bcdiv($orderConfirmedMoney, $customerNum, 2);
  5764. }
  5765. /**
  5766. * 后置操作
  5767. */
  5768. public function __destruct()
  5769. {
  5770. // TODO: Implement __destruct() method.
  5771. if ($this->isEnablePrint) self::printOrder();
  5772. }
  5773. /**
  5774. * 今日下单客户数量
  5775. * @param $shopId
  5776. * @return int
  5777. */
  5778. public function getTodayCustomerOrderNum($shopId = null)
  5779. {
  5780. $todayStart = date('Y-m-d 00:00:00', time());
  5781. $todayEnd = date('Y-m-d 23:59:59', time());
  5782. $fields = 'id';
  5783. $sql = 'SELECT ' . $fields . ' FROM qianniao_order_index_' . $this->onlineEnterpriseId . '
  5784. WHERE auditStatus = ' . StatusCode::$auditStatus['auditPass'] . ' AND
  5785. createTime BETWEEN ' . strtotime($todayStart) . ' AND ' . strtotime($todayEnd);
  5786. if (!empty($shopId)) {
  5787. $sql .= ' and shopId = ' . $shopId;
  5788. }
  5789. $sql .= ' GROUP BY customerId';
  5790. $result = $this->objDOrder->query($sql);
  5791. if ($result === false) {
  5792. Logger::logs(E_USER_ERROR, '查询错误', __CLASS__, __LINE__, $this->objDOrder->error());
  5793. return 0;
  5794. }
  5795. return count((array)$result);
  5796. }
  5797. /**
  5798. * 今日客单价
  5799. * @param null $shopId
  5800. * @return int|string|null
  5801. */
  5802. public function getTodayOrder($shopId = null)
  5803. {
  5804. $todayStart = date('Y-m-d 00:00:00', time());
  5805. $todayEnd = date('Y-m-d 23:59:59', time());
  5806. $fields = 'userCenterId';
  5807. if (!empty($shopId)) {
  5808. $shopId = ' and shopId = ' . $shopId;
  5809. }else{
  5810. $shopId = '';
  5811. }
  5812. $sql = 'select count(distinct '.$fields.') as num ,sum(payAmount) as money from qianniao_order_'. $this->onlineEnterpriseId .'_1' .
  5813. ' where auditStatus = ' . StatusCode::$auditStatus['auditPass'] .'
  5814. and createTime BETWEEN '.strtotime($todayStart). ' and '. strtotime($todayEnd).$shopId;
  5815. $result = $this->objDOrder->query($sql);
  5816. if ($result === false) {
  5817. return 0;
  5818. }
  5819. $num = $result[0]['num'];
  5820. $money = $result[0]['money'];
  5821. if (empty($money) || empty($num)) {
  5822. return 0;
  5823. }
  5824. return bcdiv($money, $num, 2);
  5825. }
  5826. /**
  5827. * Doc: (des="订单分配业务员")
  5828. * User: XMing
  5829. * Date: 2020/8/26
  5830. * Time: 3:39 下午
  5831. * @param array $params
  5832. * @return ResultWrapper
  5833. * @throws \Exception
  5834. */
  5835. public function setSalesMan(array $params)
  5836. {
  5837. //在索引表中查询订单
  5838. $orderIndex = $this->objDOrderIndex->get(['id' => $params['orderId']]);
  5839. if ($orderIndex === false) {
  5840. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  5841. }
  5842. if (empty($orderIndex)) {
  5843. return ResultWrapper::fail('未查询到指定订单', ErrorCode::$paramError);
  5844. }
  5845. if (!empty($orderIndex['salesManId'])) {
  5846. return ResultWrapper::fail('已分配过业务员', ErrorCode::$paramError);
  5847. }
  5848. $dbResult = $this->objDCustomer->get(['id' => $orderIndex['customerId']]);
  5849. if ($dbResult === false) {
  5850. return ResultWrapper::fail($this->objDCustomer->error(), ErrorCode::$dberror);
  5851. }
  5852. $customerInfo = $dbResult;
  5853. if (empty($customerInfo)) {
  5854. return ResultWrapper::fail('未查询到指定客户', ErrorCode::$dberror);
  5855. }
  5856. if($params['ifSalesMan'] == StatusCode::$delete){
  5857. if ( !empty($customerInfo['salesManId']) && $customerInfo['salesManId'] != $params['salesManId'] ) {
  5858. return ResultWrapper::fail('客户只能分配当前 -'.$customerInfo['salesManName'].' -业务员', ErrorCode::$paramError);
  5859. }
  5860. $salesManId = $params['salesManId'];
  5861. $salesManName = $params['salesManName'];
  5862. }else{
  5863. $salesManId = $customerInfo['salesManId'];
  5864. $salesManName = $customerInfo['salesManName'];
  5865. }
  5866. //更新数据
  5867. $time = time();
  5868. $beginStatus = $this->objDOrderIndex->beginTransaction();
  5869. //给客户分配业务员
  5870. if($params['ifSalesMan'] == StatusCode::$delete){
  5871. $dbResult = $this->objDCustomer->update(['salesManId' => $salesManId, 'salesManName' => $salesManName], ['id' => $orderIndex['customerId']]);
  5872. if ($dbResult === false) {
  5873. $this->objDOrderIndex->rollBack();
  5874. return ResultWrapper::fail($this->objDCustomer->error(), ErrorCode::$dberror);
  5875. }
  5876. }
  5877. //更新订单表
  5878. //只更新该订单
  5879. $dbResult = $this->objDOrderIndex->update(['salesManId' => $salesManId, 'updateTime' => $time], ['id' => $params['orderId']]);
  5880. if($dbResult === false){
  5881. $this->objDOrderIndex->rollBack();
  5882. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  5883. }
  5884. $updateData = ['salesManId' => $salesManId, 'salesManName' => $salesManName, 'updateTime' => $time];
  5885. $dbResult = $this->objDOrder->update($updateData, ['id' => $params['orderId']]);
  5886. if($dbResult === false){
  5887. $this->objDOrderIndex->rollBack();
  5888. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  5889. }
  5890. /* //获取此客户未分配业务员的订单
  5891. $orderIndexLists = $this->objDOrderIndex->select(['salesManId' => 0, 'customerId' => $orderIndex['customerId']]);
  5892. if ($orderIndexLists === false) {
  5893. $this->objDOrderIndex->rollBack();
  5894. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  5895. }
  5896. if (empty($orderIndexLists)) {
  5897. $this->objDOrderIndex->rollBack();
  5898. return ResultWrapper::fail('未查询到需要更新的数据', ErrorCode::$paramError);
  5899. }
  5900. //计算数据的分表
  5901. $updateData = ['salesManId' => $params['salesManId'], 'salesManName' => $params['salesManName'], 'updateTime' => $time];
  5902. $allGroupData = [];
  5903. $allOrderIds = [];
  5904. foreach ($orderIndexLists as $key => $val) {
  5905. $tableNum = ceil($val['userCenterId'] / $this->cutTable);
  5906. $allGroupData[$tableNum][] = $val['id'];
  5907. $allOrderIds[] = $val['id'];
  5908. }
  5909. //更新订单索引表
  5910. $updateOrderIndex = $this->objDOrderIndex->update(['salesManId' => $params['salesManId'], 'updateTime' => $time], ['id' => $allOrderIds]);
  5911. if ($updateOrderIndex === false) {
  5912. $this->objDOrderIndex->rollBack();
  5913. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  5914. }
  5915. //在对应分表中更新数据
  5916. foreach ($allGroupData as $k => $orderIds) {
  5917. $this->objDOrder->setTable('qianniao_order_' . $this->onlineEnterpriseId . '_' . $k);
  5918. $updateOrder = $this->objDOrder->update($updateData, ['id' => $orderIds]);
  5919. if ($updateOrder === false) {
  5920. $this->objDOrderIndex->rollBack();
  5921. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  5922. }
  5923. }*/
  5924. /*
  5925. //修改es
  5926. foreach ($allOrderIds as $orderId) {
  5927. $_id = self::createEsDocumentId($orderId);
  5928. $this->objDOrder->esupdateTypeFieldVaule($updateData, $_id);
  5929. }*/
  5930. $beginStatus && $this->objDOrderIndex->commit();
  5931. return ResultWrapper::success('操作成功');
  5932. }
  5933. /**
  5934. * Doc: (des="")
  5935. * User: XMing
  5936. * Date: 2020/9/4
  5937. * Time: 12:21 下午
  5938. * @param string $verifyCode
  5939. * @return ResultWrapper
  5940. * @throws \Exception
  5941. */
  5942. public function getOrderByVerifyCode(string $verifyCode)
  5943. {
  5944. $orderId = $this->objDOrderIndex->get_field('id', ['verifyCode' => $verifyCode]);
  5945. if ($orderId === false) {
  5946. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  5947. }
  5948. if (empty($orderId)) {
  5949. return ResultWrapper::fail('核销码已失效或不存在', ErrorCode::$paramError);
  5950. }
  5951. $orderInfoResult = self::getOrderInfoById($orderId);
  5952. if (!$orderInfoResult->isSuccess()) {
  5953. return ResultWrapper::fail($orderInfoResult->getData(), $orderInfoResult->getErrorCode());
  5954. }
  5955. return ResultWrapper::success($orderInfoResult->getData());
  5956. }
  5957. /**
  5958. * Doc: (des="核销订单")
  5959. * User: XMing
  5960. * Date: 2020/9/4
  5961. * Time: 2:34 下午
  5962. * @param int $id
  5963. * @param array $header
  5964. * @return ResultWrapper
  5965. * @throws \Exception
  5966. */
  5967. public function verification(int $id, $header)
  5968. {
  5969. $orderInfo = $this->objDOrderIndex->get(['id' => $id]);
  5970. if ($orderInfo === false) {
  5971. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  5972. }
  5973. if (empty($orderInfo)) {
  5974. return ResultWrapper::fail('未获取到指定订单', ErrorCode::$paramError);
  5975. }
  5976. if ($orderInfo['orderStatus'] == StatusCode::$orderStatus['close']) {
  5977. return ResultWrapper::fail('订单已取消', ErrorCode::$paramError);
  5978. }
  5979. if ($orderInfo['orderStatus'] == StatusCode::$orderStatus['finish']) {
  5980. return ResultWrapper::fail('订单已经核销过了', ErrorCode::$paramError);
  5981. }
  5982. if ($orderInfo['auditStatus'] != StatusCode::$auditStatus['auditPass']) {
  5983. return ResultWrapper::fail('订单尚未审核', ErrorCode::$paramError);
  5984. }
  5985. if ($orderInfo['outStatus'] != StatusCode::$standard) {
  5986. return ResultWrapper::fail('订单还没有出库,不能进行核销操作', ErrorCode::$paramError);
  5987. }
  5988. $orderResult = self::updateOrderStatus($id, ['orderStatus' => StatusCode::$standard], $header);
  5989. if (!$orderResult->isSuccess()) {
  5990. return ResultWrapper::fail($orderResult->getData(), $orderResult->getErrorCode());
  5991. }
  5992. return ResultWrapper::success($orderResult->getData());
  5993. }
  5994. /**
  5995. * Doc: (des="")
  5996. * User: XMing
  5997. * Date: 2020/9/8
  5998. * Time: 7:14 下午
  5999. * @param int $id
  6000. * @return ResultWrapper
  6001. */
  6002. public function getExpressInfoByOrderId(int $id)
  6003. {
  6004. $orderIndex = $this->objDOrderIndex->get(['id' => $id]);
  6005. if ($orderIndex === false) {
  6006. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  6007. }
  6008. if (empty($orderIndex)) {
  6009. return ResultWrapper::fail('为获取到指定订单', ErrorCode::$paramError);
  6010. }
  6011. if (empty($orderIndex['deliveryNo']) || empty($orderIndex['expressId'])) {
  6012. return ResultWrapper::success([]);
  6013. }
  6014. $objDExpressCode = new DExpressCode();
  6015. $expressCode = $objDExpressCode->get(['id' => $orderIndex['expressId']]);
  6016. if ($expressCode === false) {
  6017. return ResultWrapper::fail($objDExpressCode->error(), ErrorCode::$dberror);
  6018. }
  6019. if (empty($expressCode)) {
  6020. return ResultWrapper::fail('获取物流信息失败', ErrorCode::$paramError);
  6021. }
  6022. $objMBasicSetup = new MBasicSetup($this->onlineEnterpriseId);
  6023. $basicSetupResult = $objMBasicSetup->getBasicField('logistics_form');
  6024. if (!$basicSetupResult->isSuccess()) {
  6025. return ResultWrapper::fail($basicSetupResult->getData(), $basicSetupResult->getErrorCode());
  6026. }
  6027. $basicSetup = $basicSetupResult->getData();
  6028. $basicSetup = isset($basicSetup['logistics_form']) ? $basicSetup['logistics_form'] : [];
  6029. if (!isset($basicSetup['express_type']) || empty($basicSetup['express_type'])) {
  6030. return ResultWrapper::fail('未配置物流接口', ErrorCode::$paramError);
  6031. }
  6032. $map = [];
  6033. $return = [
  6034. 'list' => [],
  6035. 'stateMsg' => '',
  6036. 'nu' => $orderIndex['deliveryNo'],
  6037. 'expressName' => $expressCode['name']
  6038. ];
  6039. switch ($basicSetup['express_type']) {
  6040. case 'express_hundred':
  6041. $fix = ceil($orderIndex['userCenterId'] / $this->cutTable);
  6042. $this->objDOrderReceive->setTable('qianniao_order_receive_' . $this->onlineEnterpriseId . '_' . $fix);
  6043. $mobile = $this->objDOrderReceive->get_field('mobile', ['orderId' => $orderIndex['id']]);
  6044. if ($mobile === false) {
  6045. return ResultWrapper::fail($this->objDOrderReceive->error(), ErrorCode::$dberror);
  6046. }
  6047. if (!isset($basicSetup['express_hundred'])) {
  6048. return ResultWrapper::fail('快递100未进行配置', ErrorCode::$paramError);
  6049. }
  6050. $express_hundred = $basicSetup['express_hundred'];
  6051. if (!isset($express_hundred['customerCode']) || empty($express_hundred['customerCode']) ||
  6052. !isset($express_hundred['accessKey']) || empty($express_hundred['accessKey'])) {
  6053. return ResultWrapper::fail('快递100配置有误', ErrorCode::$paramError);
  6054. }
  6055. /*$kuaidi100Config = Factory::config()->get('kuaidi100');
  6056. if(empty($kuaidi100Config) || !isset($kuaidi100Config['customer']) || !isset($kuaidi100Config['key']) ){
  6057. return ResultWrapper::fail('快递100配置有误',ErrorCode::$paramError);
  6058. }*/
  6059. //$objQuery = new Query($kuaidi100Config['customer'], $kuaidi100Config['key']);
  6060. /*$kuaidiData = [
  6061. 'com' => 'yunda',
  6062. 'num' => '3103922659603',
  6063. 'phone' => 17600105150,
  6064. ];*/
  6065. $objQuery = new Query($express_hundred['customerCode'], $express_hundred['accessKey']);
  6066. $kuaidiData = [
  6067. 'com' => $expressCode['kuaidi100'],
  6068. 'num' => $orderIndex['deliveryNo'],
  6069. 'phone' => $mobile,
  6070. ];
  6071. $result = $objQuery->pollQuery($kuaidiData);
  6072. if (!$result->isSuccess()) {
  6073. return ResultWrapper::fail('获取物流信息失败', ErrorCode::$paramError);
  6074. }
  6075. $resultData = $result->getData();
  6076. $list = isset($resultData['data']) ? $resultData['data'] : [];
  6077. $return['stateMsg'] = $objQuery->getState(isset($resultData['state']) ? $resultData['state'] : 0);
  6078. $map = self::formatExpressList($list, 'express_hundred');
  6079. break;
  6080. case 'express_bird':
  6081. if (!isset($basicSetup['express_bird'])) {
  6082. return ResultWrapper::fail('快递鸟未进行配置', ErrorCode::$paramError);
  6083. }
  6084. $express_bird = $basicSetup['express_bird'];
  6085. if (!isset($express_bird['userId']) || empty($express_bird['userId']) ||
  6086. !isset($express_bird['apiKey']) || empty($express_bird['apiKey'])) {
  6087. return ResultWrapper::fail('快递鸟配置有误', ErrorCode::$paramError);
  6088. }
  6089. /*$kdniaoConfig = Factory::config()->get('kdniao');
  6090. if(empty($kdniaoConfig) || !isset($kdniaoConfig['EBusinessID']) || !isset($kdniaoConfig['key']) ){
  6091. return ResultWrapper::fail('快递鸟配置错误', ErrorCode::$configEroor);
  6092. }*/
  6093. //$objQuery = new KDNiaoQuery($kdniaoConfig['EBusinessID'], $kdniaoConfig['key']);
  6094. /*$kuaidiData = [
  6095. 'com' => 'HTKY',
  6096. 'num' => '557021498255630',
  6097. ];*/
  6098. $objQuery = new KDNiaoQuery($express_bird['userId'], $express_bird['apiKey']);
  6099. $kuaidiData = [
  6100. 'com' => $expressCode['kdniao'],
  6101. 'num' => $orderIndex['deliveryNo'],
  6102. ];
  6103. $result = $objQuery->EbusinessOrderHandle($kuaidiData);
  6104. if (!$result->isSuccess()) {
  6105. return ResultWrapper::fail('获取物流信息失败', ErrorCode::$paramError);
  6106. }
  6107. $resultData = $result->getData();
  6108. $list = isset($resultData['Traces']) ? $resultData['Traces'] : [];
  6109. $return['stateMsg'] = $objQuery->getState(isset($resultData['State']) ? $resultData['State'] : 0);
  6110. $map = self::formatExpressList($list, 'express_bird');
  6111. break;
  6112. }
  6113. $return['list'] = $map;
  6114. return ResultWrapper::success($return);
  6115. }
  6116. /**
  6117. * Doc: (des="修改订单的发货信息")
  6118. * User: XMing
  6119. * Date: 2020/9/9
  6120. * Time: 11:12 上午
  6121. * @param string $no
  6122. * @param array $params
  6123. * @param int $orderId
  6124. * @return ResultWrapper
  6125. * @throws \Exception
  6126. */
  6127. public function editOrderExpress(string $no, array $params, int $orderId = 0)
  6128. {
  6129. if (empty($orderId)) {
  6130. $orderIndex = $this->objDOrderIndex->get(['no' => $no]);
  6131. } else {
  6132. $orderIndex = $this->objDOrderIndex->get(['id' => $orderId]);
  6133. }
  6134. if ($orderIndex === false) {
  6135. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  6136. }
  6137. if (empty($orderIndex)) {
  6138. return ResultWrapper::fail('未获取到指定订单信息' . $no, ErrorCode::$paramError);
  6139. }
  6140. $fix = ceil($orderIndex['userCenterId'] / $this->cutTable);
  6141. $this->objDOrder->setTable('qianniao_order_' . $this->onlineEnterpriseId . '_' . $fix);
  6142. $this->objDOrderIndex->beginTransaction();
  6143. if (isset($params['deliveryType']) && $params['deliveryType'] == StatusCode::$deliveryType['logistics']){
  6144. $update = [
  6145. 'logisticsData' => json_encode($params['logisticsData']),
  6146. 'updateTime' => time(),
  6147. ];
  6148. }else{
  6149. $update = [
  6150. 'deliveryNo' => isset($params['deliveryNo']) ? $params['deliveryNo'] : '',
  6151. 'expressName' => isset($params['expressName']) ? $params['expressName'] : '',
  6152. 'expressId' => isset($params['expressId']) ? $params['expressId'] : 0,
  6153. 'updateTime' => time(),
  6154. ];
  6155. $updateIndex = $this->objDOrderIndex->update($update, ['id' => $orderIndex['id']]);
  6156. if ($updateIndex === false) {
  6157. $this->objDOrderIndex->rollBack();
  6158. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  6159. }
  6160. }
  6161. $updateOrder = $this->objDOrder->update($update, ['id' => $orderIndex['id']]);
  6162. if ($updateOrder === false) {
  6163. $this->objDOrderIndex->rollBack();
  6164. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  6165. }
  6166. //记录司机id
  6167. $driverId = isset($params['logisticsData']['id']) ? $params['logisticsData']['id'] : '';
  6168. $updatedriverId = $this->objDOrder->update(['driverId'=>$driverId],['id' => $orderIndex['id']]);
  6169. if ($updatedriverId === false) {
  6170. $this->objDOrderIndex->rollBack();
  6171. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  6172. }
  6173. /*
  6174. $_id = self::createEsDocumentId($orderIndex['id']);
  6175. $this->objDOrder->esupdateTypeFieldVaule($update, $_id);*/
  6176. $this->objDOrderIndex->commit();
  6177. return ResultWrapper::success(true);
  6178. }
  6179. /**
  6180. * Doc: (des="")
  6181. * User: XMing
  6182. * Date: 2020/9/8
  6183. * Time: 8:47 下午
  6184. * @param array $list
  6185. * @param string $type
  6186. * @return array
  6187. */
  6188. private function formatExpressList(array $list, string $type)
  6189. {
  6190. $map = [];
  6191. switch ($type) {
  6192. case 'express_hundred':
  6193. foreach ($list as $value) {
  6194. $map[] = [
  6195. 'context' => $value['context'],
  6196. 'time' => $value['time']
  6197. ];
  6198. }
  6199. break;
  6200. case 'express_bird':
  6201. foreach ($list as $value) {
  6202. $map[] = [
  6203. 'context' => $value['AcceptStation'],
  6204. 'time' => $value['AcceptTime']
  6205. ];
  6206. }
  6207. $map = array_reverse($map);
  6208. break;
  6209. }
  6210. return $map;
  6211. }
  6212. /**
  6213. * Doc: (des="")
  6214. * User: XMing
  6215. * Date: 2020/10/12
  6216. * Time: 5:31 下午
  6217. * @param array $params
  6218. * @return ResultWrapper
  6219. * @throws \Exception
  6220. */
  6221. public function create(array $params)
  6222. {
  6223. $objMUserCoupon = new MUserCoupon($this->onlineUserId, $this->onlineEnterpriseId);
  6224. $objMCustomer = new MCustomer($this->onlineEnterpriseId, $this->onlineUserId);
  6225. $objMCustomerBalance = new MCustomerBalance($this->onlineEnterpriseId, $this->onlineUserId);
  6226. $objMCart = new MCart($this->onlineUserId, $this->onlineEnterpriseId);
  6227. $objMOrderGoods = new MOrderGoods($this->onlineUserId, $this->onlineEnterpriseId);
  6228. $objDStaff = new DStaff();
  6229. $objStockCache = new Stock($this->onlineEnterpriseId);
  6230. $objDStaff->setTable('qianniao_staff_' . $this->onlineEnterpriseId);
  6231. $this->objDOrderIndex->setTable('qianniao_order_index_' . $this->onlineEnterpriseId);
  6232. $goodsCommonData = $params['goodsData'];
  6233. //锁定库存 查询商铺对应的仓库
  6234. $objMShop = new MShop($this->onlineEnterpriseId, $this->onlineUserId);
  6235. $modelResult = $objMShop->getShopDataByShopIds(array_column($goodsCommonData['goodsData'], 'shopId'));
  6236. if (!$modelResult->isSuccess()) {
  6237. return ResultWrapper::fail($modelResult->getData(), $modelResult->getErrorCode());
  6238. }
  6239. $shopData = $modelResult->getData();
  6240. if (empty($shopData)) {
  6241. return ResultWrapper::fail('获取店铺数据失败', ErrorCode::$paramError);
  6242. }
  6243. $paramsResult = self::getIdsCashierMap($params);
  6244. if (!$paramsResult->isSuccess()) {
  6245. return ResultWrapper::fail($paramsResult->getData(), $paramsResult->getErrorCode());
  6246. }
  6247. $params = $paramsResult->getData();
  6248. //获取客户信息
  6249. $customerOwe = 0;
  6250. if ($this->onlineUserId == StatusCode::$noneUserCenter) {
  6251. $customerData = [
  6252. 'id' => StatusCode::$noneCustomer,
  6253. 'name' => '匿名客户'
  6254. ];
  6255. } else {
  6256. $customerDataResult = $objMCustomer->getCustomerInfoByUserCenterId($this->onlineUserId);
  6257. if (!$customerDataResult->isSuccess()) {
  6258. return ResultWrapper::fail($customerDataResult->getData(), $customerDataResult->getErrorCode());
  6259. }
  6260. $customerData = $customerDataResult->getData();
  6261. //获取客户当前欠款
  6262. if (isset($customerData['id'])) {
  6263. $customerOwe = $objMCustomerBalance->getCustomerBalance($customerData['id']);
  6264. }
  6265. //获取客户手机号
  6266. $objDUserCenter = new DUserCenter();
  6267. $userInfo = $objDUserCenter->get(['id' => $this->onlineUserId], 'mobile');
  6268. if ($userInfo === false) {
  6269. return ResultWrapper::fail($objDUserCenter->error(), ErrorCode::$dberror);
  6270. }
  6271. $params['customerMobile'] = isset($userInfo['mobile']) ? $userInfo['mobile'] : '';
  6272. }
  6273. // 生成一个临时三方流水号,用来支持多个子订单作为一个订单支付,支付成功之后更新为对应的实际外部支付流水号
  6274. $tmpOuterTradeNo = 'tmp' . createOrderSn($params['source'], StatusCode::$orderType['cashierOrder'], $this->onlineUserId);
  6275. $lockInventoryData = [];//锁定库存物料
  6276. $goodsSaleData = [];//销售数据
  6277. $allSn = [];//所有单号
  6278. $allOrderIds = [];//所有订单
  6279. $mapDetails = [];//订单商品
  6280. $createTime = time();
  6281. $allCartIds = [];
  6282. $shopName = '';
  6283. $shopId = 0;//目前只有一个
  6284. $this->objDOrder->beginTransaction();
  6285. foreach ($goodsCommonData['goodsData'] as $key => $val) {
  6286. $sn = createOrderSn($params['source'], StatusCode::$orderType['saleOrder'], $this->onlineUserId);
  6287. //将数据写入索引表
  6288. $shopId = $val['shopId'];
  6289. $orderIndexData = [
  6290. 'shopId' => $val['shopId'],
  6291. 'userCenterId' => $params['userCenterId'],
  6292. 'salesManId' => isset($customerData['salesManId']) ? $customerData['salesManId'] : 0,
  6293. 'createTime' => time(),
  6294. 'updateTime' => time(),
  6295. 'deleteStatus' => StatusCode::$standard,
  6296. 'auditStatus' => StatusCode::$auditStatus['auditing'],
  6297. 'payStatus' => StatusCode::$delete,
  6298. 'orderStatus' => StatusCode::$orderStatus['waitPay'],
  6299. 'outStatus' => StatusCode::$delete,
  6300. 'returnStatus' => StatusCode::$orderReturn['notReturn'],
  6301. 'deliveryType' => $params['deliveryType'],
  6302. 'payType' => $params['payType'],
  6303. 'customerId' => isset($customerData['id']) ? $customerData['id'] : 0,
  6304. 'no' => $sn,
  6305. 'orderType' => StatusCode::$orderType['cashierOrder'],
  6306. 'selfRuleId' => 0,
  6307. 'cashierUid' => $this->loginUserCenterId,
  6308. 'guideUids' => isset($params['guideUids']) ? $params['guideUids'] : '',
  6309. ];
  6310. //1. 先写索引表
  6311. $this->objDOrderIndex->setTable('qianniao_order_index_' . $this->onlineEnterpriseId);
  6312. $orderId = $this->objDOrderIndex->insert($orderIndexData);
  6313. if ($orderId === false) {
  6314. $this->objDOrder->rollBack();
  6315. return ResultWrapper::fail($$this->objDOrderIndex->error(), ErrorCode::$dberror);
  6316. }
  6317. //3。上门自提订单,生成核销码
  6318. $verifyCode = self::createVerifyCode($orderId);
  6319. //兼容以前代码
  6320. $updateRes = $this->objDOrderIndex->update(['verifyCode' => $verifyCode], ['id' => $orderId]);
  6321. if ($updateRes === false) {
  6322. $this->objDOrder->rollBack();
  6323. return ResultWrapper::fail($$this->objDOrderIndex->error(), ErrorCode::$dberror);
  6324. }
  6325. //订单数据
  6326. $shopName = $val['shopName'];//现在就一个店铺
  6327. $masterOrder = [
  6328. 'id' => $orderId,//订单id
  6329. 'customerId' => isset($customerData['id']) ? $customerData['id'] : 0,
  6330. 'userCenterId' => $params['userCenterId'],
  6331. 'shopId' => $val['shopId'],
  6332. 'shopName' => $val['shopName'],
  6333. 'no' => $sn,
  6334. 'outerTradeNo' => $tmpOuterTradeNo,
  6335. 'totalMoney' => $goodsCommonData['totalMoney'],
  6336. 'payAmount' => $goodsCommonData['payMoney'],
  6337. 'customerName' => isset($customerData['name']) ? $customerData['name'] : '',
  6338. 'remark' => $params['remark'],
  6339. 'deliveryType' => $params['deliveryType'],//配送方式
  6340. 'payType' => $params['payType'],//支付方式
  6341. 'salesManId' => isset($customerData['salesManId']) ? $customerData['salesManId'] : 0,
  6342. 'salesManName' => isset($customerData['salesManName']) ? $customerData['salesManName'] : '',
  6343. 'customerType' => isset($customerData['type']) ? $customerData['type'] : 0,
  6344. 'buyTotal' => array_sum(array_column($val['shopGoodsData'], 'buyNum')),
  6345. 'source' => $params['source'],//来源
  6346. 'orderStatus' => StatusCode::$orderStatus['waitPay'],
  6347. 'returnStatus' => StatusCode::$orderReturn['notReturn'],
  6348. 'outStatus' => StatusCode::$delete,
  6349. 'createTime' => time(),
  6350. 'updateTime' => time(),
  6351. 'customerOwe' => $customerOwe,//客户当前欠款
  6352. 'auditStatus' => StatusCode::$auditStatus['auditing'],
  6353. 'preferential' => $goodsCommonData['preferential'],//优惠券优惠金额
  6354. 'vipDiscount' => isset($goodsCommonData['vipDiscount']) ? $goodsCommonData['vipDiscount'] : 0,//会员卡优惠金额
  6355. 'vipDoubleDiscount' => isset($goodsCommonData['vipDoubleDiscount']) ? $goodsCommonData['vipDoubleDiscount'] : 0,//会员卡折上折优惠金额
  6356. 'originPayAmount' => $goodsCommonData['payMoney'],//原支付金额,
  6357. 'orderType' => StatusCode::$orderType['cashierOrder'],
  6358. 'verifyCode' => $verifyCode,
  6359. 'expressMoney' => isset($goodsCommonData['expressMoney']) ? $goodsCommonData['expressMoney'] : 0,
  6360. 'cashierUid' => $this->loginUserCenterId,
  6361. 'guideUids' => isset($params['guideUids']) ? $params['guideUids'] : '',
  6362. 'cashierName' => $params['cashierName'],
  6363. 'guideName' => $params['guideName'],
  6364. 'remMoney' => isset($goodsCommonData['rem_money']) ? $goodsCommonData['rem_money'] : 0,
  6365. 'changeSubMoney' => isset($goodsCommonData['subPrice']) ? $goodsCommonData['subPrice'] : 0,
  6366. 'isNoneUser' => $this->onlineUserId == StatusCode::$noneUserCenter ? StatusCode::$standard : StatusCode::$delete,
  6367. 'customerMobile' => $params['customerMobile'],
  6368. 'serialNum' => $objStockCache->createSerialSn(0,'Order'),
  6369. 'operatorName' => isset($params['operatorName']) ? $params['operatorName'] : '',
  6370. 'operatorId' => isset($params['operatorId']) ? $params['operatorId'] : 0,
  6371. ];
  6372. $allOrderIds[] = $orderId;
  6373. //2。订单表
  6374. $orderId = $this->objDOrder->insert($masterOrder);
  6375. if ($orderId === false) {
  6376. $this->objDOrder->rollBack();
  6377. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  6378. }
  6379. $masterOrder['goodsName'] = '';
  6380. foreach ($val['shopGoodsData'] as $k => &$v) {
  6381. $addOrderGoods = [
  6382. 'no' => $sn,
  6383. 'orderId' => $orderId,
  6384. 'goodsId' => $v['goodsId'],
  6385. 'goodsName' => $v['goodsName'],
  6386. 'shopId' => $val['shopId'],//商铺id
  6387. 'shopName' => $val['shopName'],//商铺名称
  6388. 'originPrice' => $v['originPrice'],
  6389. 'price' => $v['price'],
  6390. 'buyNum' => $v['buyNum'],
  6391. 'totalMoney' => $v['totalMoney'],
  6392. 'skuId' => $v['skuId'],
  6393. 'goodsBasicId' => $v['goodsBasicId'],
  6394. 'goodsCode' => $v['goodsCode'],
  6395. 'deliverNum' => $v['buyNum'],//发货数量=购买数量
  6396. 'unitName' => $v['unitName'],//单位名称
  6397. 'conversion' => $v['conversion'],//换算比率
  6398. 'preferential' => $v['preferential'],//优惠券优惠金额
  6399. 'vipDiscount' => $v['vipDiscount'],//会员卡优惠金额
  6400. 'categoryPath' => isset($v['categoryPath']) ? $v['categoryPath'] : '',//分类路径
  6401. 'brandId' => isset($v['brandId']) ? $v['brandId'] : 0,//品牌id
  6402. 'specGroup' => isset($v['specGroup']) && !empty($v['specGroup']) ? json_encode($v['specGroup']) : NULL,
  6403. 'goodsImages' => isset($v['goodsImages']) && is_string($v['goodsImages']) ? $v['goodsImages'] : '',
  6404. 'barCode' => isset($v['barCode']) ? $v['barCode'] : '',
  6405. 'storageCode' => isset($v['storageCode']) ? $v['storageCode'] : '',
  6406. 'categoryName' => isset($v['categoryName']) ? $v['categoryName'] : '',
  6407. 'brandName' => isset($v['brandName']) ? $v['brandName'] : '',
  6408. 'expressMoney' => isset($v['expressMoney']) ? $v['expressMoney'] : 0,
  6409. ];
  6410. $lockInventoryData[] = [
  6411. 'warehouseId' => $shopData[$v['shopId']]['warehouseId'],
  6412. 'materielId' => $v['goodsBasicId'],
  6413. 'materielCode' => $v['goodsCode'],
  6414. 'lockingNum' => $v['buyNum'],
  6415. 'originId' => $orderId,
  6416. 'originNo' => $sn,
  6417. 'source' => StatusCode::$orderType['saleOrder'],
  6418. 'sourceNo' => $sn,
  6419. 'operatorId' => $masterOrder['customerId'],
  6420. 'operatorName' => $masterOrder['customerName'],
  6421. 'skuId' => $v['skuId'],
  6422. ];
  6423. $goodsSaleData [] = [
  6424. 'goodsId' => $addOrderGoods['goodsId'],
  6425. 'skuId' => $addOrderGoods['skuId'],
  6426. 'buyNum' => $addOrderGoods['buyNum'],
  6427. ];
  6428. //活动商品数据
  6429. if ($this->isFront) {
  6430. if (isset($v['activityId']) && $v['activityId'] != 0) {
  6431. $activityData[] = [
  6432. 'goodsId' => $v['goodsId'],
  6433. 'skuId' => $v['skuId'],
  6434. 'activityId' => $v['activityId'],
  6435. 'buyNum' => $v['buyNum']
  6436. ];
  6437. }
  6438. }
  6439. $masterOrder['goodsName'] .= $v['goodsName'] . ' ';
  6440. $result = $objMOrderGoods->addOrderGoods($addOrderGoods);
  6441. if (!$result->isSuccess()) {
  6442. $this->objDOrder->rollBack();
  6443. return ResultWrapper::fail($result->getData(), ErrorCode::$dberror);
  6444. }
  6445. $allCartIds[] = $v['cartId'];
  6446. }
  6447. //存入ES
  6448. $masterOrder['verifyCode'] = isset($verifyCode) ? $verifyCode : '';
  6449. self::updateEsData($orderId, $masterOrder, [], $masterOrder['goodsName']);
  6450. $allSn[] = $sn;//所有订单号
  6451. }
  6452. //将优惠券改为已使用
  6453. if (isset($goodsCommonData['useCoupon']) && !empty($goodsCommonData['useCoupon'])) {
  6454. $result = $objMUserCoupon->updateIsUse(['id' => $goodsCommonData['useCoupon']['id']], ['isUse' => StatusCode::$delete, 'useTime' => time()]);
  6455. if (!$result->isSuccess()) {
  6456. $this->objDOrder->rollBack();
  6457. return ResultWrapper::fail($result->getData(), ErrorCode::$dberror);
  6458. }
  6459. }
  6460. //锁定库存商品数量
  6461. $objMInventory = new MInventory($this->onlineEnterpriseId, $this->onlineUserId);
  6462. $lockInventoryResult = $objMInventory->updateLockInventory($lockInventoryData);
  6463. if (!$lockInventoryResult->isSuccess()) {
  6464. $this->objDOrder->rollBack();
  6465. return ResultWrapper::fail($lockInventoryResult->getData(), $lockInventoryResult->getErrorCode());
  6466. }
  6467. //增加销量
  6468. $objMGoods = new MGoods($this->onlineEnterpriseId, false, $this->onlineUserId);
  6469. if (!empty($goodsSaleData)) {
  6470. foreach ($goodsSaleData as $value) {
  6471. $res = $objMGoods->updateSalesNum($value['goodsId'], $value['skuId'], $value['buyNum']);
  6472. if ($res === false) {
  6473. Logger::logs(E_USER_ERROR, '错误', __CLASS__, __LINE__, '商品增加销量失败');
  6474. }
  6475. }
  6476. }
  6477. //file_put_contents('/www/wwwroot/logs/api.junhailan.com/MSaleOrder_error.log', date('Y-m-d H:i:s') . '数据:' . var_export($mapDetails, true) . PHP_EOL, FILE_APPEND);
  6478. $this->objSaleOrder->setGoodsDetails($mapDetails);
  6479. //统计订单信息
  6480. self::noticeStatistics([
  6481. 'userCenterId' => $params['userCenterId'],
  6482. 'enterpriseId' => $this->onlineEnterpriseId,
  6483. 'customerId' => $params['customerId'],
  6484. 'no' => $allSn,
  6485. 'noticeType' => 'create',
  6486. ], 'MOrderStatistics');
  6487. //写日志
  6488. foreach ($allSn as $sn) {
  6489. parent::saveLog([
  6490. 'no' => $sn,
  6491. 'actionType' => '创建订单',//创建订单
  6492. 'operationData' => '',
  6493. 'userCenterId' => $params['userCenterId'],
  6494. 'enterpriseId' => $this->onlineEnterpriseId,
  6495. 'createTime' => time(),
  6496. ]);
  6497. }
  6498. $this->objDOrder->commit();
  6499. return ResultWrapper::success(['orderId' => $orderId, 'shopName' => $shopName, 'out_trade_no' => $tmpOuterTradeNo, 'total_fee' => $goodsCommonData['payMoney']]);
  6500. }
  6501. /**
  6502. * Doc: (des="订单确认收款")
  6503. * User: XMing
  6504. * Date: 2020/10/12
  6505. * Time: 4:11 下午
  6506. * @param array $params
  6507. * @return ResultWrapper
  6508. * @throws \Exception
  6509. */
  6510. public function confirm(array $params)
  6511. {
  6512. $orderIndex = $this->objDOrderIndex->get(['id' => $params['orderId']]);
  6513. if ($orderIndex === false) {
  6514. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  6515. }
  6516. if (empty($orderIndex)) {
  6517. return ResultWrapper::fail('获取订单信息失败', ErrorCode::$paramError);
  6518. }
  6519. if ($orderIndex['payStatus'] != StatusCode::$delete) {
  6520. return ResultWrapper::fail('订单已付款', ErrorCode::$paramError);
  6521. }
  6522. $fix = $fix = ceil($orderIndex['userCenterId'] / $this->cutTable);;
  6523. $this->objDOrder->setTable('qianniao_order_' . $this->onlineEnterpriseId . '_' . $fix);
  6524. $orderData = $this->objDOrder->get(['id' => $params['orderId']]);
  6525. if ($orderData === false) {
  6526. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  6527. }
  6528. if (empty($orderData)) {
  6529. return ResultWrapper::fail('获取订单信息失败', ErrorCode::$paramError);
  6530. }
  6531. $paramsResult = self::getIdsCashierMap($params);
  6532. if (!$paramsResult->isSuccess()) {
  6533. return ResultWrapper::fail($paramsResult->getData(), $paramsResult->getErrorCode());
  6534. }
  6535. $params = $paramsResult->getData();
  6536. $this->objDOrderIndex->beginTransaction();
  6537. //修稿订单信息
  6538. $update = [
  6539. 'payType' => $params['payType'],
  6540. 'updateTime' => time(),
  6541. 'cashierUid' => $this->loginUserCenterId,
  6542. 'guideUids' => $params['guideUids'],
  6543. ];
  6544. $updateIndex = $this->objDOrderIndex->update($update, ['id' => $params['orderId']]);
  6545. if ($updateIndex === false) {
  6546. $this->objDOrderIndex->rollBack();
  6547. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  6548. }
  6549. $update['guideName'] = $params['guideName'];
  6550. $updateOrder = $this->objDOrder->update($update, ['id' => $params['orderId']]);
  6551. if ($updateOrder === false) {
  6552. $this->objDOrderIndex->rollBack();
  6553. return ResultWrapper::fail($this->objDOrder->error(), ErrorCode::$dberror);
  6554. }
  6555. /*
  6556. //更新es
  6557. $_id = self::createEsDocumentId($params['orderId']);
  6558. $this->objDOrder->esupdateTypeFieldVaule($update, $_id);*/
  6559. //清空此收银员的购物车
  6560. $objMCashierCart = new MCashierCart($this->onlineUserId, $this->onlineEnterpriseId, $this->loginUserCenterId);
  6561. $result = $objMCashierCart->clearCart();
  6562. if (!$result->isSuccess()) {
  6563. $this->objDOrderIndex->rollBack();
  6564. return ResultWrapper::fail($result->getData(), ErrorCode::$dberror);
  6565. }
  6566. //自动审核订单
  6567. $objMInventoryOut = new MInventoryOut($this->onlineEnterpriseId, $this->onlineUserId);
  6568. $auditResult = self::updateAuditStatus([
  6569. 'id' => $params['orderId'],
  6570. 'audit' => '自动审核',
  6571. 'auditId' => $this->onlineUserId,
  6572. 'auditStatus' => StatusCode::$auditStatus['auditPass']
  6573. ]);
  6574. if (!$auditResult->isSuccess()) {
  6575. $this->objDOrderIndex->rollBack();
  6576. return ResultWrapper::fail($auditResult->getData(), $auditResult->getErrorCode());
  6577. }
  6578. $outId = $auditResult->getData();//出库单id
  6579. //自动出库
  6580. $dbResult = $objMInventoryOut->updateInventoryOutStatus(['id' => $outId, 'auditId' => $this->loginUserCenterId, 'auditName' => '销售自动审核']);
  6581. if (!$dbResult->isSuccess()) {
  6582. $this->objDOrderIndex->rollBack();
  6583. return ResultWrapper::fail($dbResult->getData(), $dbResult->getErrorCode());
  6584. }
  6585. //确认收款
  6586. $dbResult = self::updateOrderPayData(['payStatus' => StatusCode::$standard, 'payTime' => time()], ['id' => [$params['orderId']]]);
  6587. if (!$dbResult->isSuccess()) {
  6588. $this->objDOrderIndex->rollBack();
  6589. return ResultWrapper::fail($dbResult->getData(), $dbResult->getErrorCode());
  6590. }
  6591. //确认收货
  6592. $dbResult = self::updateOrderStatus($params['orderId'], ['orderStatus' => StatusCode::$orderStatus['finish']], []);
  6593. if (!$dbResult->isSuccess()) {
  6594. $this->objDOrder->rollBack();
  6595. return ResultWrapper::fail($dbResult->getData(), $dbResult->getErrorCode());
  6596. }
  6597. $objMCashier = new MCashier($this->onlineUserId, $this->onlineEnterpriseId);
  6598. $cashierResult = $objMCashier->calculatePushMoney($params['orderId']);
  6599. if (!$cashierResult->isSuccess()) {
  6600. Logger::logs(E_USER_ERROR, '订单提成计算失败', __CLASS__, __LINE__, $cashierResult->getData());
  6601. }
  6602. //创建收款单
  6603. $received = [
  6604. 'currentAccountName' => $params['currentAccountName'],
  6605. 'financeType' => '销售收款',
  6606. 'financeTypeId' => 2,
  6607. 'shopId' => $orderData['shopId'],
  6608. 'shopName' => $orderData['shopName'],
  6609. 'receiptTime' => time(),
  6610. 'operatorId' => $this->loginUserCenterId,
  6611. 'accountList' => $params['accountList'],
  6612. 'customerId' => $orderData['customerId'],
  6613. 'customerName' => $orderData['customerName'],
  6614. 'sourceNo' => $orderData['no'],
  6615. 'sourceNoMoney' => $orderData['payAmount'],
  6616. 'createTime' => time(),
  6617. 'auditStatus' => StatusCode::$auditStatus['auditing'],
  6618. 'updateTime' => time(),
  6619. ];
  6620. $objMReceived = new MReceived($this->onlineEnterpriseId, $this->loginUserCenterId);
  6621. $receivedResult = $objMReceived->addReceived($received, true);
  6622. if (!$receivedResult->isSuccess()) {
  6623. $this->objDOrderIndex->rollBack();
  6624. return ResultWrapper::fail($receivedResult->getData(), $receivedResult->getErrorCode());
  6625. }
  6626. $this->objDOrderIndex->commit();
  6627. if ($this->onlineUserId == StatusCode::$noneUserCenter) {
  6628. $objDCashierCustomerPrice = new DCashierCustomerPrice();
  6629. $objDCashierCustomerPrice->setTable('qianniao_cashier_customer_price_' . $this->onlineEnterpriseId);
  6630. $objDCashierCustomerPrice->delete(['cashierUid' => $this->loginUserCenterId, 'customerUid' => StatusCode::$noneUserCenter]);
  6631. }
  6632. return ResultWrapper::success(true);
  6633. }
  6634. /**
  6635. * Doc: (des="获取收银员工信息")
  6636. * User: XMing
  6637. * Date: 2020/10/12
  6638. * Time: 5:50 下午
  6639. * @param array $params
  6640. * @return ResultWrapper
  6641. * @throws \Exception
  6642. */
  6643. private function getIdsCashierMap(array $params)
  6644. {
  6645. $objDStaff = new DStaff();
  6646. $objDStaff->setTable('qianniao_staff_' . $this->onlineEnterpriseId);
  6647. //获取收银员信息
  6648. $allUids = [$this->loginUserCenterId];
  6649. if (isset($params['guideUids']) && !empty($params['guideUids'])) {
  6650. $ids = explode(',', $params['guideUids']);
  6651. $allUids = array_merge($allUids, $ids);
  6652. }
  6653. $userMap = [];
  6654. if (!empty($allUids)) {
  6655. $staffList = $objDStaff->select(['userCenterId' => $allUids], 'userCenterId,staffName');
  6656. if ($staffList === false) {
  6657. return ResultWrapper::fail($objDStaff->error(), ErrorCode::$dberror);
  6658. }
  6659. foreach ($staffList as $value) {
  6660. $userMap[$value['userCenterId']] = $value['staffName'];
  6661. }
  6662. }
  6663. $params['cashierName'] = isset($userMap[$this->loginUserCenterId]) ? $userMap[$this->loginUserCenterId] : '超级管理员';
  6664. $nameStr = '';
  6665. if (!empty($ids)) {
  6666. foreach ($ids as $uid) {
  6667. if (!empty($nameStr)) {
  6668. $nameStr .= ',';
  6669. }
  6670. $nameStr .= isset($userMap[$uid]) ? $userMap[$uid] : '';
  6671. }
  6672. }
  6673. $params['guideName'] = $nameStr;
  6674. $params['customerMobile'] = '';
  6675. return ResultWrapper::success($params);
  6676. }
  6677. public function fix_ex()
  6678. {
  6679. $_id = self::createEsDocumentId(144);
  6680. $this->objDOrder->esupdateTypeFieldVaule(['salesManId' => 1, 'salesManName' => '杨明霞', 'updateTime' => time()], $_id);
  6681. }
  6682. /**
  6683. * 查询索引表信息
  6684. */
  6685. public function getOrderIndexData($where)
  6686. {
  6687. $dbResult = $this->objDOrderIndex->get($where);
  6688. if ($dbResult === false) {
  6689. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  6690. }
  6691. return ResultWrapper::success($dbResult);
  6692. }
  6693. /**
  6694. * Doc: (des="根据订单id获取订单信息")
  6695. * User: XMing
  6696. * Date: 2020/12/7
  6697. * Time: 4:05 下午
  6698. * @param int $id
  6699. * @return ResultWrapper
  6700. * @throws \Exception
  6701. */
  6702. public function getOrderByOrderId(int $id): ResultWrapper
  6703. {
  6704. $orderIndex = $this->objDOrderIndex->get($id);
  6705. if ($orderIndex === false){
  6706. return ResultWrapper::fail($this->objDOrderIndex->error,ErrorCode::$dberror);
  6707. }
  6708. if (empty($orderIndex)){
  6709. return ResultWrapper::fail('未获取到订单信息',ErrorCode::$paramError);
  6710. }
  6711. $fix = ceil($orderIndex['userCenterId'] / $this->cutTable);
  6712. $this->objDOrder->setTable('qianniao_order_'.$this->onlineEnterpriseId.'_'.$fix);
  6713. $order = $this->objDOrder->get($id);
  6714. if ($order === false){
  6715. return ResultWrapper::fail($this->objDOrder->error,ErrorCode::$paramError);
  6716. }
  6717. if (empty($order)){
  6718. return ResultWrapper::fail('未获取到订单信息',ErrorCode::$paramError);
  6719. }
  6720. return ResultWrapper::success($order);
  6721. }
  6722. /**
  6723. * Doc: (des="")
  6724. * User: XMing
  6725. * Date: 2020/12/8
  6726. * Time: 10:43 上午
  6727. * @param int $id
  6728. * @return ResultWrapper
  6729. * @throws \Exception
  6730. */
  6731. public function updateSettel(int $id): ResultWrapper
  6732. {
  6733. $orderIndex = $this->objDOrderIndex->get($id);
  6734. if ($orderIndex === false){
  6735. return ResultWrapper::fail($this->objDOrderIndex->error,ErrorCode::$dberror);
  6736. }
  6737. if (empty($orderIndex)){
  6738. return ResultWrapper::fail('未获取到订单信息',ErrorCode::$paramError);
  6739. }
  6740. $fix = ceil($orderIndex['userCenterId'] / $this->cutTable);
  6741. $this->objDOrder->setTable('qianniao_order_'.$this->onlineEnterpriseId.'_'.$fix);
  6742. $order = $this->objDOrder->update(['isSettel' => StatusCode::$standard],$id);
  6743. if ($order === false){
  6744. return ResultWrapper::fail($this->objDOrder->error,ErrorCode::$paramError);
  6745. }
  6746. return ResultWrapper::success(true);
  6747. }
  6748. /**
  6749. * Doc: (des="")
  6750. * User: XMing
  6751. * Date: 2021/2/4
  6752. * Time: 12:06 下午
  6753. * @param array $selectParams
  6754. * @return ResultWrapper
  6755. */
  6756. public function getStatistics(array $selectParams):ResultWrapper
  6757. {
  6758. //默认今日的
  6759. $todayStart = strtotime(date('Y-m-d 00:00:00', time()));
  6760. $todayEnd = strtotime(date('Y-m-d 23:59:59', time()));
  6761. if (isset($selectParams['start']) && !empty($selectParams['start'])){
  6762. $todayStart = $selectParams['start'];
  6763. }
  6764. if (isset($selectParams['end']) && !empty($selectParams['end'])){
  6765. $todayEnd = $selectParams['end'];
  6766. }
  6767. $sql = "SELECT SUM(order_view.returnTotalPrice) as returnTotalPrice,order_view.goodsId,order_view.outCostPrice,SUM(order_view.totalMoney) as totalMoney,order_view.specGroup,order_view.unitName,order_view.skuId,order_view.title,SUM(order_view.num) as rnum,SUM(order_view.o_num) as onum ,SUM(order_view.otherNum) AS otherNum, order_view.goodsBasicId FROM
  6768. (
  6769. SELECT g.goodsId,g.specGroup,g.unitName,g.goodsName as title,g.skuId,@c:=0 as num,@a:=1 as isOrder,g.buyNum as o_num,g.totalMoney,(g.outCostPrice * g.buyNum) as outCostPrice,@d:=0 as returnTotalPrice ,JSON_EXTRACT(g.extends,'$.u_1_buy') AS otherNum,g.goodsBasicId AS goodsBasicId FROM qianniao_order_".$this->onlineEnterpriseId.'_1 as o
  6770. LEFT JOIN qianniao_order_goods_'.$this->onlineEnterpriseId.'_1 as g ON g.orderId = o.id
  6771. WHERE o.outStatus in(5,6) AND g.deleteStatus = 5 AND o.createTime BETWEEN '.$todayStart.' AND '.$todayEnd.'
  6772. UNION ALL
  6773. SELECT d.goodsId,d.skuName as specGroup,d.unitName,d.goodsName as title,d.skuId,d.num as num,@a:=2 as isOrder,@b:=0 as o_num,@c:= 0 as totalMoney,@d:= 0 as outCostPrice,d.returnTotalPrice, @g:= 0 as otherNum ,@g:= 0 as goodsBasicId FROM qianniao_order_return_'.$this->onlineEnterpriseId.' as r
  6774. LEFT JOIN qianniao_order_return_details_'.$this->onlineEnterpriseId.' as d ON d.linkId=r.id
  6775. WHERE r.auditStatus = 2 AND d.deleteStatus = 5 AND r.updateTime BETWEEN '.$todayStart.' AND '. $todayEnd.'
  6776. )
  6777. AS order_view GROUP BY skuId';
  6778. $countSql = 'SELECT order_view.id as id FROM
  6779. (
  6780. SELECT o.id,g.skuId FROM qianniao_order_'.$this->onlineEnterpriseId.'_1 as o
  6781. LEFT JOIN qianniao_order_goods_'.$this->onlineEnterpriseId.'_1 as g ON g.orderId = o.id
  6782. WHERE o.outStatus in(5,6) AND g.deleteStatus = 5 AND o.createTime BETWEEN '.$todayStart.' AND '.$todayEnd.'
  6783. UNION ALL
  6784. SELECT r.id,d.skuId FROM qianniao_order_return_'.$this->onlineEnterpriseId.' as r
  6785. LEFT JOIN qianniao_order_return_details_'.$this->onlineEnterpriseId.' as d ON d.linkId=r.id
  6786. WHERE r.auditStatus = 2 AND d.deleteStatus = 5 AND r.updateTime BETWEEN '.$todayStart.' AND '. $todayEnd.'
  6787. ) AS order_view GROUP BY skuId';
  6788. $sql .= ' LIMIT '.$selectParams['offset'].','.$selectParams['limit'];
  6789. $lists = $this->objDOrderIndex->query($sql);
  6790. if ($lists === false){
  6791. return ResultWrapper::fail($this->objDOrderIndex->error(),ErrorCode::$dberror);
  6792. }
  6793. $goodsBasicDate = [];
  6794. //获取商品资料
  6795. $goodsBasicIds = array_column($lists,'goodsBasicId');
  6796. $objGoodsDate = new MGoodsBasic($this->onlineUserId,$this->onlineEnterpriseId);
  6797. $result = $objGoodsDate->getBasicGoodsFieldByIds($goodsBasicIds);
  6798. if ( !$result->isSuccess() ){
  6799. return ResultWrapper::fail($result->getData(),$result->getErrorCode());
  6800. }
  6801. $goodsBasicDate = $result->getData();
  6802. $skuIds = [];
  6803. foreach ($lists as &$list){
  6804. $list['isEq'] = isset($goodsBasicDate[$list['goodsBasicId']]['isEq']) ? $goodsBasicDate[$list['goodsBasicId']]['isEq'] : 4;
  6805. $list['specGroup'] = json_decode($list['specGroup'],true);
  6806. if (is_array($list['specGroup'])){
  6807. $arr = array_column($list['specGroup'],'specValueName');
  6808. $str = implode('_',$arr);
  6809. $list['specGroup'] = $str;
  6810. }
  6811. $list['subProMoney'] = floatval(bcsub($list['totalMoney'],$list['outCostPrice'],2));//毛利
  6812. $skuIds[] = $list['skuId'];
  6813. }
  6814. unset($list);
  6815. $thisRetMap = [];//本期
  6816. $lastRetMap = [];//上期
  6817. if (!empty($skuIds)){
  6818. $str = implode(',',$skuIds);
  6819. //本期退货数量
  6820. $fields = ' SUM(d.num) as thisRetNum,d.skuId as skuId,SUM(d.returnTotalPrice) as thisReturnTotalPrice ';
  6821. $sql = 'SELECT '.$fields.' FROM qianniao_order_' . $this->onlineEnterpriseId . '_1 AS o
  6822. LEFT JOIN qianniao_order_return_'.$this->onlineEnterpriseId.' AS r
  6823. ON r.originId = o.id LEFT JOIN qianniao_order_return_details_'.$this->onlineEnterpriseId.' AS d
  6824. ON d.linkId = r.id
  6825. WHERE r.auditStatus = 2 AND d.deleteStatus = 5 AND
  6826. o.createTime BETWEEN '.$todayStart.' AND '. $todayEnd.' AND
  6827. r.updateTime BETWEEN '.$todayStart.' AND '. $todayEnd.' AND
  6828. d.skuId IN('.$str.') GROUP BY d.skuId';
  6829. $retLists = $this->objDOrderIndex->query($sql);
  6830. if ($retLists === false){
  6831. return ResultWrapper::fail($this->objDOrderIndex->error(),ErrorCode::$dberror);
  6832. }
  6833. unset($sql);
  6834. //上期退货
  6835. $fields = ' SUM(d.num) as lastRetNum,d.skuId as skuId,SUM(d.returnTotalPrice) as lastReturnTotalPrice ';
  6836. $sql = 'SELECT '.$fields.' FROM qianniao_order_' . $this->onlineEnterpriseId . '_1 AS o
  6837. LEFT JOIN qianniao_order_return_'.$this->onlineEnterpriseId.' AS r
  6838. ON r.originId = o.id LEFT JOIN qianniao_order_return_details_'.$this->onlineEnterpriseId.' AS d
  6839. ON d.linkId = r.id
  6840. WHERE r.auditStatus = 2 AND d.deleteStatus = 5 AND
  6841. o.createTime < '.$todayStart.' AND
  6842. r.updateTime BETWEEN '.$todayStart.' AND '. $todayEnd.' AND
  6843. d.skuId IN('.$str.') GROUP BY d.skuId';
  6844. $lastRetLists = $this->objDOrderIndex->query($sql);
  6845. if ($lastRetLists === false){
  6846. return ResultWrapper::fail($this->objDOrderIndex->error(),ErrorCode::$dberror);
  6847. }
  6848. unset($sql);
  6849. foreach ($retLists as $val){
  6850. $thisRetMap[$val['skuId']] = [
  6851. 'thisRetNum' => $val['thisRetNum'],
  6852. 'thisReturnTotalPrice' => $val['thisReturnTotalPrice'],
  6853. ];
  6854. }
  6855. foreach ($lastRetLists as $val){
  6856. $lastRetMap[$val['skuId']] = [
  6857. 'lastRetNum' => $val['lastRetNum'],
  6858. 'lastReturnTotalPrice' => $val['lastReturnTotalPrice']
  6859. ];
  6860. }
  6861. }
  6862. foreach ($lists as &$item){
  6863. if (!isset($thisRetMap[$item['skuId']])){
  6864. $item['thisRetNum'] = 0;
  6865. $item['thisReturnTotalPrice'] = 0;
  6866. }else{
  6867. $item['thisRetNum'] = floatval($thisRetMap[$item['skuId']]['thisRetNum']);
  6868. $item['thisReturnTotalPrice'] = floatval($thisRetMap[$item['skuId']]['thisReturnTotalPrice']);
  6869. }
  6870. if (!isset($lastRetMap[$item['skuId']])){
  6871. $item['lastRetNum'] = 0;
  6872. $item['lastReturnTotalPrice'] = 0;
  6873. }else{
  6874. $item['lastRetNum'] = floatval($lastRetMap[$item['skuId']]['lastRetNum']);
  6875. $item['lastReturnTotalPrice'] = floatval($lastRetMap[$item['skuId']]['lastReturnTotalPrice']);
  6876. }
  6877. $item['retNum'] = bcadd($item['thisRetNum'],$item['lastRetNum'],2);
  6878. $item['returnTotalPrice'] = bcadd($item['thisReturnTotalPrice'],$item['lastReturnTotalPrice'],2);
  6879. }
  6880. unset($item);
  6881. $count = $this->objDOrderIndex->query($countSql);
  6882. if ($count === false){
  6883. return ResultWrapper::fail($this->objDOrderIndex->error(),ErrorCode::$dberror);
  6884. }
  6885. $data = [
  6886. 'total' => count($count),
  6887. 'data' => $lists
  6888. ];
  6889. return ResultWrapper::success($data);
  6890. }
  6891. /**
  6892. * Doc: (des="")
  6893. * User: XMing
  6894. * Date: 2021/3/10
  6895. * Time: 11:05 上午
  6896. * @param array $params
  6897. * @return ResultWrapper
  6898. * @throws \Exception
  6899. */
  6900. public function getGoodsListsByUserCenterId(array $params): ResultWrapper
  6901. {
  6902. $fix = 1;
  6903. if (isset($params['userCenterId']) && !empty($params['userCenterId'])){
  6904. $fix = ceil($params['userCenterId'] / $this->cutTable);
  6905. }
  6906. $this->objDOrder->setTable('qianniao_order_'.$this->onlineEnterpriseId.'_'.$fix);
  6907. $fields = ' id,customerName,customerId ';
  6908. $where = '';
  6909. if (isset($params['startTime']) && !empty($params['startTime']) && isset($params['endTime']) && !empty($params['endTime'])){
  6910. $where .= ' AND `createTime` BETWEEN '.$params['startTime'].' AND '.$params['endTime'];
  6911. }
  6912. $sql = 'SELECT '.$fields.' FROM qianniao_order_'.$this->onlineEnterpriseId.'_'.$fix.' WHERE deleteStatus = '.StatusCode::$standard.$where;
  6913. if (isset($params['userCenterId']) && !empty($params['userCenterId'])){
  6914. $sql .= ' AND userCenterId = '.$params['userCenterId'];
  6915. }
  6916. $sql .= ' order by createTime desc';
  6917. $lists = $this->objDOrder->query($sql);
  6918. if ($lists === false){
  6919. return ResultWrapper::fail($this->objDOrder->error(),ErrorCode::$dberror);
  6920. }
  6921. if (empty($lists)){
  6922. return ResultWrapper::success(['data' => [],'total' => 0]);
  6923. }
  6924. unset($sql);
  6925. unset($where);
  6926. unset($fields);
  6927. $orderIds = [];
  6928. $orderRelMap = [];
  6929. foreach ($lists as $item){
  6930. $orderIds[] = $item['id'];
  6931. $orderRelMap[$item['id']] = $item;
  6932. }
  6933. $fields = ' goodsBasicId,createTime,orderId,goodsName,goodsCode,goodsImages,unitName,specGroup,shopId,shopName,price,SUM(buyNum) AS buyNum,(price * SUM(buyNum)) AS totalMoney,categoryName,brandName,barCode,outNum ,SUM(JSON_EXTRACT(extends,"$.u_1_buy")) AS otherNum ';
  6934. $where = '';
  6935. if (!empty($orderIds)){
  6936. $str = trim(implode(',',$orderIds),',');
  6937. $where .= ' AND `orderId` IN ('.$str.')';
  6938. }
  6939. if (isset($params['categoryId']) && !empty($params['categoryId'])){
  6940. $categoryId = (int)$params['categoryId'];
  6941. $where .= ' AND FIND_IN_SET('.$categoryId.',`categoryPath`) ';
  6942. }
  6943. if (isset($params['brandId']) && !empty($params['brandId'])){
  6944. $brandId = (int)$params['brandId'];
  6945. $where .= ' AND `brandId` = '.$brandId;
  6946. }
  6947. if (isset($params['barCode']) && !empty($params['barCode'])){
  6948. $barCode = (string)$params['barCode'];
  6949. $where .= ' AND `barCode` = "'.$barCode.'"';
  6950. }
  6951. if (isset($params['shopId']) && !empty($params['shopId'])){
  6952. $shopId = (int)$params['shopId'];
  6953. $where .= ' AND `shopId` = '.$shopId;
  6954. }
  6955. if (isset($params['keyword']) && !empty($params['keyword'])){
  6956. $keyword = '"%'.$params['keyword'].'%"';
  6957. $where .= ' AND (`goodsName` LIKE '.$keyword.' OR `goodsCode` LIKE '.$keyword.') ';
  6958. }
  6959. $sql = 'SELECT '.$fields.' FROM qianniao_order_goods_'.$this->onlineEnterpriseId.'_'.$fix.'
  6960. WHERE `deleteStatus` = '.StatusCode::$standard.$where.'
  6961. GROUP BY skuId ORDER BY createTime DESC ';
  6962. $count = $this->objDOrderGoods->query($sql);
  6963. if ($count === false){
  6964. return ResultWrapper::fail($this->objDOrderGoods->error(),ErrorCode::$dberror);
  6965. }
  6966. if (isset($params['limit']) && !empty($params['limit'])){
  6967. $sql .= ' LIMIT '.$params['offset'].','.$params['limit'];
  6968. }
  6969. $lists = $this->objDOrderGoods->query($sql);
  6970. if ($lists === false){
  6971. return ResultWrapper::fail($this->objDOrderGoods->error(),ErrorCode::$dberror);
  6972. }
  6973. if (empty($lists)){
  6974. return ResultWrapper::success(['data'=>[],'total'=>0]);
  6975. }
  6976. if ($lists === false){
  6977. return ResultWrapper::fail($this->objDOrderGoods->error(),ErrorCode::$dberror);
  6978. }
  6979. $goodsBasicDate = [];
  6980. //获取商品资料
  6981. $goodsBasicIds = array_column($lists,'goodsBasicId');
  6982. $objGoodsDate = new MGoodsBasic($this->onlineUserId,$this->onlineEnterpriseId);
  6983. $result = $objGoodsDate->getBasicGoodsFieldByIds($goodsBasicIds);
  6984. if ( !$result->isSuccess() ){
  6985. return ResultWrapper::fail($result->getData(),$result->getErrorCode());
  6986. }
  6987. $goodsBasicDate = $result->getData();
  6988. foreach ($lists as &$item){
  6989. if (isset($item['specGroup']) && !empty($item['specGroup'])){
  6990. $item['specGroup'] = json_decode($item['specGroup'],true);
  6991. }
  6992. $item['customerName'] = isset($orderRelMap[$item['orderId']]) ? $orderRelMap[$item['orderId']]['customerName'] : '';
  6993. $item['customerId'] = isset($orderRelMap[$item['orderId']]) ? $orderRelMap[$item['orderId']]['customerId'] : 0;
  6994. $item['isEq'] = isset($goodsBasicDate[$item['goodsBasicId']]['isEq']) ? $goodsBasicDate[$item['goodsBasicId']]['isEq'] : 4;
  6995. }
  6996. return ResultWrapper::success([
  6997. 'data' => $lists,
  6998. 'total' => (int)count($count)
  6999. ]);
  7000. }
  7001. /**
  7002. * Doc: (des="缺货单列表")
  7003. * User: XMing
  7004. * Date: 2021/3/11
  7005. * Time: 6:44 下午
  7006. * @param array $selectParams
  7007. * @return ResultWrapper
  7008. * @throws \Exception
  7009. */
  7010. public function getDistributionAll(array $selectParams): ResultWrapper
  7011. {
  7012. //{"page":1,"pageSize":10,"search":{},"state":"all"}
  7013. $selectParams['state'] = 'state';
  7014. $selectParams['outStatus'] = 6;
  7015. $orderListsResult = self::getAllOrder($selectParams,[]);
  7016. if (!$orderListsResult->isSuccess()){
  7017. return ResultWrapper::fail($orderListsResult->getData(),$orderListsResult->getErrorCode());
  7018. }
  7019. $total = $orderListsResult->getData()['total'];
  7020. $orderLists = $orderListsResult->getData()['data'];
  7021. if (empty($orderLists)){
  7022. return ResultWrapper::success(['data' => [],'total' => 0]);
  7023. }
  7024. $arrayLists = [];
  7025. $orderIds = [];
  7026. foreach ($orderLists as $item){
  7027. $infoResult = self::getOrderInfoById($item['id']);
  7028. if (!$infoResult->isSuccess()){
  7029. return ResultWrapper::fail($infoResult->getData(),$infoResult->getErrorCode());
  7030. }
  7031. $infoResult = $infoResult->getData();
  7032. $goodsData = $infoResult['goodsData'];
  7033. foreach ($goodsData as $key => $item){
  7034. if ($item['outOfNum'] == 0){
  7035. unset($goodsData[$key]);
  7036. continue;
  7037. }
  7038. $infoResult['goodsData'] = array_values($goodsData);
  7039. }
  7040. $arrayLists[] = $infoResult;
  7041. }
  7042. return ResultWrapper::success(['data' => $arrayLists,'total' => $total]);
  7043. }
  7044. /**
  7045. * Doc: (des="业务员销售排行")
  7046. * User: XMing
  7047. * Date: 2021/3/15
  7048. * Time: 10:09 上午
  7049. * @param array $params
  7050. * @param $export
  7051. * @return ResultWrapper
  7052. */
  7053. public function salesManRank(array $params,$export = 0): ResultWrapper
  7054. {
  7055. $sortFields = ['dealCustomerNum','orderNum','dealAmount','skuNum','buyNum'];
  7056. $sort = ['ASC','DESC'];
  7057. if (!in_array($params['sortField'],$sortFields)){
  7058. return ResultWrapper::fail('sortField字段异常',ErrorCode::$paramError);
  7059. }
  7060. if (!in_array($params['sort'],$sort)){
  7061. return ResultWrapper::fail('sort字段异常',ErrorCode::$paramError);
  7062. }
  7063. $where = '';
  7064. $fields = ' o.salesManName,o.salesManId,COUNT(DISTINCT o.id) as orderNum,COUNT(DISTINCT o.customerId) as dealCustomerNum,SUM(DISTINCT o.payAmount) as dealAmount,COUNT(DISTINCT g.skuId) as skuNum,SUM(g.buyNum) as buyNum ';
  7065. if (isset($params['startTime']) && !empty($params['startTime']) && isset($params['endTime']) && !empty($params['endTime'])){
  7066. $where .= ' AND o.createTime BETWEEN '.$params['startTime'].' AND '.$params['endTime'];
  7067. }
  7068. if ( !empty($params['orderStatus'])&& isset($params['orderStatus']) ){//删选
  7069. $orderStatus = implode(',',$params['orderStatus']);
  7070. $where .= ' AND o.orderStatus IN ('.$orderStatus.')';
  7071. }
  7072. $sql = 'SELECT '.$fields.' FROM qianniao_order_'.$this->onlineEnterpriseId.'_1 as o
  7073. LEFT JOIN qianniao_order_goods_'.$this->onlineEnterpriseId.'_1 as g ON g.orderId = o.id
  7074. WHERE o.deleteStatus = 5
  7075. AND o.salesManId IS NOT NULL
  7076. AND o.salesManId != 0 '.$where;
  7077. $sql .= ' GROUP BY o.salesManName ';
  7078. if (isset($params['sortField']) && !empty($params['sortField']) && isset($params['sort']) && !empty($params['sort'])){
  7079. $sql .= ' ORDER BY '.$params['sortField'].' '.$params['sort'];
  7080. }
  7081. $count = $this->objDOrder->query($sql);
  7082. if ($count === false){
  7083. return ResultWrapper::fail($this->objDOrder->error(),ErrorCode::$dberror);
  7084. }
  7085. if (count((array)$count) == 0){
  7086. return ResultWrapper::success(['data' => [],'total' => 0]);
  7087. }
  7088. if($export){
  7089. $params['limit'] = null;
  7090. $params['offset'] = null;
  7091. }
  7092. if (isset($params['limit']) && !empty($params['limit'])){
  7093. $sql .= ' LIMIT '.$params['offset'].','.$params['limit'];
  7094. }
  7095. //导出
  7096. if($export){
  7097. $lists = $this->objDOrder->query($sql);
  7098. if ($lists === false){
  7099. return ResultWrapper::fail($this->objDOrder->error(),ErrorCode::$dberror);
  7100. }
  7101. self::exportsalesManRank($lists);
  7102. exit;
  7103. }else{
  7104. $lists = $this->objDOrder->query($sql);
  7105. if ($lists === false){
  7106. return ResultWrapper::fail($this->objDOrder->error(),ErrorCode::$dberror);
  7107. }
  7108. foreach ($lists as &$list){
  7109. $list['dealAmount'] = sprintf('%.2f', $list['dealAmount']);
  7110. }
  7111. }
  7112. return ResultWrapper::success(['data' => $lists,'total' => count($count)]);
  7113. }
  7114. /**
  7115. * Doc: (des="")
  7116. * User: XMing
  7117. * Date: 2021/3/17
  7118. * Time: 10:47 上午
  7119. * @param array $orderIds
  7120. * @param array $params
  7121. * @return ResultWrapper
  7122. * @throws \Exception
  7123. */
  7124. public function updateCostPriceBySku(array $orderIds,array $params): ResultWrapper
  7125. {
  7126. Logger::logs(E_USER_ERROR,'params',__CLASS__,__LINE__,$params);
  7127. Logger::logs(E_USER_ERROR,'orderIds',__CLASS__,__LINE__,$orderIds);
  7128. if (empty($orderIds)){
  7129. return ResultWrapper::success();
  7130. }
  7131. $lists = $this->objDOrderIndex->select($orderIds,'id,userCenterId');
  7132. if ($lists === false){
  7133. return ResultWrapper::fail($this->objDOrderIndex->error(),ErrorCode::$dberror);
  7134. }
  7135. $tables = [];
  7136. foreach ($lists as $list){
  7137. $fix = ceil($list['userCenterId'] / $this->cutTable);
  7138. $tables[$fix][] = $list['id'];
  7139. }
  7140. if (empty($tables)){
  7141. return ResultWrapper::success('没有更新的表');
  7142. }
  7143. $status = $this->objDOrderGoods->beginTransaction();
  7144. foreach ($params as $value){
  7145. $where = $value['where'];
  7146. $update = $value['update'];
  7147. foreach ($tables as $fix => $orderIds){
  7148. $this->objDOrderGoods->setTable('qianniao_order_goods_'.$this->onlineEnterpriseId.'_'.$fix);
  7149. Logger::logs(E_USER_ERROR,'update',__CLASS__,__LINE__,$update);
  7150. Logger::logs(E_USER_ERROR,'where',__CLASS__,__LINE__,$where);
  7151. $updateResult = $this->objDOrderGoods->update($update,$where);
  7152. if ($updateResult === false){
  7153. $this->objDOrderGoods->rollBack();
  7154. return ResultWrapper::fail($this->objDOrderGoods->error(),ErrorCode::$dberror);
  7155. }
  7156. }
  7157. }
  7158. $status && $this->objDOrderGoods->commit();
  7159. return ResultWrapper::success(true);
  7160. }
  7161. /*
  7162. * 设置物流信息
  7163. * */
  7164. public function addLogistics($params)
  7165. {
  7166. $logisticsData = $params['logisticsData'];
  7167. if(empty($logisticsData['id'])){
  7168. $objMDriver = new MDriver($this->onlineEnterpriseId, $this->onlineUserId);
  7169. $paramsDriver = [
  7170. 'enterpriseId'=> $this->onlineEnterpriseId,
  7171. 'driverName' => $logisticsData['name'],
  7172. 'phone' => $logisticsData['truckTel'],
  7173. 'plateNumber' => $logisticsData['truckName'],
  7174. 'remark' => $logisticsData['remark']
  7175. ];
  7176. $addDriver = $objMDriver->addDriver($paramsDriver);
  7177. if ( !$addDriver->isSuccess() ){
  7178. return ResultWrapper::fail($addDriver->getData(),$addDriver->getErrorCode());
  7179. }
  7180. $driverId = $addDriver->getData();
  7181. $params['logisticsData']['id']= $driverId;
  7182. }
  7183. //去掉订单id剩下的数据就是物流数据
  7184. $orderId = $params['orderId'];
  7185. unset($params['orderId']);
  7186. $orderNo = $params['no'];
  7187. unset($params['no']);
  7188. $updateLogistics = self::editOrderExpress($orderNo,$params,$orderId);
  7189. if (!$updateLogistics->isSuccess()){
  7190. $this->objDOrder->rollBack();
  7191. return ResultWrapper::fail($updateLogistics->getData(),$updateLogistics->getErrorCode());
  7192. }
  7193. return ResultWrapper::success($updateLogistics);
  7194. }
  7195. /**
  7196. * 业务员订单表导出方法
  7197. * @param $result
  7198. * @return void
  7199. * @throws Exception
  7200. */
  7201. public function exportsalesManRank($result)
  7202. {
  7203. //导出到本地
  7204. header("Content-type:application/vnd.ms-excel");
  7205. header("Content-Disposition:filename=业务员订单记录表.csv");
  7206. header('Cache-Control: max-age=0');
  7207. $fp = fopen('php://output', 'a');
  7208. $head = ['销售员','成交客户','sku数量','订单数','销售数量','成交金额']; //定义标题
  7209. foreach ($head as $i => $v) {
  7210. $head[$i] = mb_convert_encoding($v, 'GBK', 'utf-8'); //将中文标题转换编码,否则乱码
  7211. }
  7212. fputcsv($fp, $head);
  7213. $limit = 10000;
  7214. $num = 0; //计数器
  7215. foreach ($result as $v) { //循环数据
  7216. $num++;
  7217. if ($num == $limit) {
  7218. ob_flush(); //释放内存
  7219. flush();
  7220. }
  7221. $rows['salesManName'] = isset($v['salesManName']) ? $v['salesManName'] : '';//销售员
  7222. $rows['dealCustomerNum'] = isset($v['dealCustomerNum']) ? $v['dealCustomerNum'] : '';//成交客户
  7223. $rows['skuNum'] = isset($v['skuNum']) ? $v['skuNum'] : '';//SKU数量
  7224. $rows['orderNum'] = isset($v['orderNum']) ? $v['orderNum'] : '';//订单数
  7225. $rows['buyNum'] = isset($v['buyNum']) ? $v['buyNum'] : '';//销售数量
  7226. $rows['dealAmount'] = isset($v['dealAmount']) ? $v['dealAmount'] : '';//成交金额
  7227. foreach ($rows as $kk => $vv) {
  7228. $rs[$kk] = mb_convert_encoding($vv, 'GBK', 'utf-8'); //转译编码
  7229. }
  7230. fputcsv($fp, $rs);
  7231. $rows = [];
  7232. }
  7233. }
  7234. /**
  7235. * 导出方法
  7236. *
  7237. * @param $orderProfit
  7238. */
  7239. private static function exportOrderProfit($orderProfit)
  7240. {
  7241. //导出到本地
  7242. header("Content-type:application/vnd.ms-excel");
  7243. header("Content-Disposition:filename=销售毛利明细表记录.csv");
  7244. header('Cache-Control: max-age=0');
  7245. $fp = fopen('php://output', 'a');
  7246. $head = ['商品名','单据类型', '单据日期', '客户名', '数量','其他单位','销售价', '成本价', '销售收入','销售成本', '销售毛利', '销售毛利率']; //定义标题
  7247. foreach ($head as $i => $v) {
  7248. $head[$i] = mb_convert_encoding($v, 'GBK', 'utf-8'); //将中文标题转换编码,否则乱码
  7249. }
  7250. fputcsv($fp, $head);
  7251. $limit = 10000;
  7252. $num = 0;//计数器
  7253. foreach ($orderProfit as $v) {
  7254. //循环数据
  7255. $num++;
  7256. if ($num == $limit) {
  7257. ob_flush();//释放内存
  7258. flush();
  7259. }
  7260. $rows['goodsName'] = isset($v['goodsName']) ? $v['goodsName'] : '';//商品名
  7261. $rows['orderType'] = $v['orderType'] === 1 ? '销售订单' : '销售单';//单据类型
  7262. $rows['createTime'] = isset($v['createTime']) ? date('Y-m-d H:i:s',$v['createTime']) : '';//单据日期
  7263. $rows['customerName'] = isset($v['customerName']) ? $v['customerName'] : '';//客户名
  7264. $rows['buyNum'] = isset($v['buyNum']) ? $v['buyNum'] : '';//数量
  7265. $rows['otherNum'] = isset($v['otherNum']) ? $v['otherNum'] : 0;//其他单位
  7266. $rows['price'] = isset($v['price']) ? $v['price'] : '';//销售价
  7267. $rows['outCostPrice'] = isset($v['outCostPrice']) ? $v['outCostPrice'] : '';//成本价
  7268. $rows['totalMoney'] = isset($v['totalMoney']) ? $v['totalMoney'] : '';//销售收入
  7269. $rows['saleCostAmount'] = isset($v['saleCostAmount']) ? $v['saleCostAmount'] : '';//销售成本
  7270. $rows['saleProfitAmount'] = isset($v['saleProfitAmount']) ? $v['saleProfitAmount'] : '';//销售毛利
  7271. $rows['saleProfitRate'] = isset($v['saleProfitRate']) ? $v['saleProfitRate'].'%' : '';//销售毛利率
  7272. foreach ($rows as $kk => $vv) {
  7273. $rs[$kk] = mb_convert_encoding($vv, 'GBK', 'utf-8'); //转译编码
  7274. }
  7275. fputcsv($fp, $rs);
  7276. $rows = [];
  7277. }
  7278. exit;
  7279. }
  7280. /**
  7281. * 拣货回写订单拣货状态
  7282. */
  7283. public function updateOrderPicking($orderIds,$orderPickStatus)
  7284. {
  7285. $tableName = $this->objDOrder->getTableName('qianniao_order_' . $this->onlineEnterpriseId, $this->onlineUserId, $this->cutTable);
  7286. $this->objDOrder->setTable($tableName);
  7287. if(!empty($orderIds)){
  7288. foreach ($orderIds as $orderId){
  7289. $dbResult = $this->objDOrder->update(['pickingStatus'=>$orderPickStatus],['id'=>$orderId]);
  7290. if ($dbResult === false){
  7291. return ResultWrapper::fail($this->objDOrder->error(),ErrorCode::$dberror);
  7292. }
  7293. }
  7294. }
  7295. return ResultWrapper::success([]);
  7296. }
  7297. /**
  7298. *
  7299. *用户订单状态数量统计
  7300. */
  7301. public function getOrderStatusNum()
  7302. {
  7303. // 2待支付 3代发货 4待收货 5已完成 10退货
  7304. $returnData = [
  7305. '2' => 0,
  7306. '3' => 0,
  7307. '4' => 0,
  7308. '5' => 0,
  7309. '10' => 0
  7310. ];
  7311. // 查询订单各状态对应的总条数
  7312. $sql = 'SELECT count(orderStatus) as total,orderStatus FROM qianniao_order_index_'.$this->onlineEnterpriseId.' WHERE deleteStatus = '.StatusCode::$standard.' AND userCenterId = '.$this->onlineUserId.' GROUP BY orderStatus';
  7313. $dbResult = $this->objDOrderIndex->query($sql);
  7314. if($dbResult === false){
  7315. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  7316. }
  7317. if (!empty($dbResult)){
  7318. foreach ($dbResult as $key => $value){
  7319. $returnData[$value['orderStatus']] = $value['total'];
  7320. }
  7321. }
  7322. // 查询退货状态总条数
  7323. unset($dbResult);
  7324. $sql = 'SELECT count(id) as total FROM qianniao_order_return_'.$this->onlineEnterpriseId.' WHERE deleteStatus = '.StatusCode::$standard.' AND userCenterId = '.$this->onlineUserId;
  7325. $dbResult = $this->objDOrderIndex->query($sql);
  7326. if($dbResult === false){
  7327. return ResultWrapper::fail($this->objDOrderIndex->error(), ErrorCode::$dberror);
  7328. }
  7329. if (!empty($dbResult)){
  7330. $returnData[10] = $dbResult[0]['total'];
  7331. }
  7332. return ResultWrapper::success($returnData);
  7333. }
  7334. }