12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457 |
- <template>
- <div>
- <div style="display: flex; align-items: center">
- <el-breadcrumb separator="/">
- <el-breadcrumb-item
- ><span style="font-weight: 700">调拨</span></el-breadcrumb-item
- >
- <el-breadcrumb-item
- ><span style="font-weight: 700">调拨详情页</span></el-breadcrumb-item
- >
- </el-breadcrumb>
- <el-button
- style="margin-left: 10px"
- size="mini"
- icon="el-icon-arrow-left"
- @click="goBack"
- >返回列表</el-button
- >
- </div>
- <br />
- <el-form ref="form" :model="form" :rules="rules" label-width="120px">
- <el-row>
- <el-col :span="8">
- <el-form-item label="客户" prop="fCorpid">
- <el-select
- v-model="form.fCorpid"
- clearable
- filterable
- placeholder="请输入关键词"
- style="width: 80%"
- @change="changefStltype"
- :disabled="detailList.length > 0"
- >
- <el-option
- v-for="(item, index) in fMblnoOptions"
- :key="index.fId"
- :label="item.fName"
- :value="item.fId"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="结算方式" prop="fStltypeid">
- <el-select
- v-model="form.fStltypeid"
- placeholder="请选择结算方式"
- clearable
- :disabled="browseStatus"
- style="width: 80%"
- >
- <el-option
- v-for="(item, index) in fStltypeOptions"
- :key="index.dictValue"
- :label="item.dictLabel"
- :value="item.dictValue"
- />
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="提单号" prop="fMblno">
- <el-input
- v-model="form.fMblno"
- style="width: 80%"
- placeholder="请输入提单号"
- disabled
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="8">
- <el-form-item label="业务日期" prop="fBsdate">
- <el-date-picker
- v-model="form.fBsdate"
- style="width: 80%"
- type="date"
- :disabled="browseStatus"
- value-format="timestamp"
- placeholder="业务日期"
- @change="changeDate"
- >
- </el-date-picker>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="业务时间" prop="fBstime">
- <el-time-picker
- style="width: 80%"
- :disabled="browseStatus"
- v-model="form.fBstime"
- :picker-options="{
- selectableRange: '00:00:00 - 23:59:59',
- }"
- value-format="timestamp"
- placeholder="任意时间点"
- >
- </el-time-picker>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="仓管员" prop="fStorekeeper">
- <el-select
- v-model="form.fStorekeeper"
- filterable
- clearable
- :disabled="browseStatus"
- style="width: 80%"
- placeholder="请输入模糊查找"
- >
- <el-option
- v-for="(item, index) in userOptions"
- :key="index.userName"
- :label="item.nickName"
- :value="item.userName"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="8">
- <el-form-item label="调入仓库" prop="fWarehouseid">
- <el-select
- v-model="form.fWarehouseid"
- filterable
- :disabled="browseStatus || detailList.length > 0"
- style="width: 80%"
- placeholder="请选择"
- >
- <el-option
- v-for="(item, index) in warehouseOptions"
- :key="index.fId"
- :label="item.fName"
- :value="item.fId"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="调出仓库" prop="fInwarehouseid">
- <el-select
- v-model="form.fInwarehouseid"
- filterable
- :disabled="browseStatus || detailList.length > 0"
- style="width: 80%"
- placeholder="请选择"
- >
- <el-option
- v-for="(item, index) in warehouseOptions"
- :key="index.fId"
- :label="item.fName"
- :value="item.fId"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="单据编号" prop="fBillno">
- <el-input
- v-model="form.fBillno"
- style="width: 80%"
- disabled
- placeholder="单据编号"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="8">
- <el-form-item label="计划调拨件数" prop="fPlanqty">
- <el-input
- v-model.number="form.fPlanqty"
- style="width: 80%"
- maxlength="9"
- laceholder="计划件数"
- :disabled="browseStatus || current !== before"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="计划调拨净重(kg)" prop="fPlannetweight">
- <el-input
- v-model="form.fPlannetweight"
- style="width: 80%"
- maxlength="9"
- v-input-limit="2"
- laceholder="计划净重"
- :disabled="browseStatus || current !== before"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="计划调拨毛重(kg)" prop="fPlangrossweight">
- <el-input
- v-model="form.fPlangrossweight"
- v-input-limit="2"
- style="width: 80%"
- laceholder="计划毛重"
- maxlength="9"
- :disabled="browseStatus || current !== before"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="8">
- <el-form-item label="作业类型" prop="fBusinessType">
- <el-select
- style="width: 80%"
- v-model="form.fBusinessType"
- filterable
- @change="educationChange"
- :disabled="
- contrOl ||
- browseStatus ||
- warehouseDrList.length > 0 ||
- warehouseCrList.length > 0
- "
- >
- <el-option
- v-for="(item, index) in businessTypeOption"
- :key="index.dictValue"
- :label="item.dictLabel"
- :value="item.dictValue"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="劳务公司" prop="fLabour">
- <el-select
- style="width: 80%"
- v-model="form.fLabour"
- clearable
- filterable
- placeholder="请输入关键词"
- :disabled="contrOl || browseStatus"
- >
- <el-option
- v-for="(item, index) in fCompanyOptIons"
- :key="index.fId"
- :label="item.fName"
- :value="item.fId"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item
- label="车队"
- prop="fFleet"
- :rules="{
- required: isrequired === 1 ? true : false,
- message: '请选择',
- trigger: ['blur', 'change'],
- }"
- >
- <el-select
- style="width: 80%"
- v-model="form.fFleet"
- clearable
- filterable
- placeholder="请输入关键词"
- :disabled="contrOl || browseStatus"
- >
- <el-option
- v-for="(item, index) in fleetOptions"
- :key="index.fId"
- :label="item.fName"
- :value="item.fId"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="8">
- <el-form-item
- label="车号"
- prop="fTruckno"
- :rules="{
- required: isrequired2 === 1 ? true : false,
- message: '请选择',
- trigger: ['blur', 'change'],
- }"
- >
- <el-input
- v-model="form.fTruckno"
- style="width: 80%"
- :disabled="browseStatus"
- placeholder="车号"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item
- label="司机姓名"
- prop="fDriverName"
- :rules="{
- required: isrequired2 === 1 ? true : false,
- message: '请选择',
- trigger: ['blur', 'change'],
- }"
- >
- <el-input
- v-model="form.fDriverName"
- style="width: 80%"
- :disabled="browseStatus"
- placeholder="司机姓名"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item
- label="司机电话"
- prop="fDriverTel"
- :rules="{
- required: isrequired2 === 1 ? true : false,
- message: '请选择',
- trigger: ['blur', 'change'],
- }"
- >
- <el-input
- v-model="form.fDriverTel"
- style="width: 80%"
- :disabled="browseStatus"
- placeholder="司机电话"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="16">
- <el-row>
- <el-col :span="12">
- <el-form-item
- label="司机身份证"
- prop="fDriverIdCar"
- :rules="{
- required: isrequired2 === 1 ? true : false,
- message: '请选择',
- trigger: ['blur', 'change'],
- }"
- >
- <el-input
- v-model="form.fDriverIdCar"
- style="width: 80%"
- :disabled="browseStatus"
- placeholder="司机身份证"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="24">
- <el-form-item label="备注" prop="remark">
- <el-input
- style="width: 91.5%"
- v-model="form.remark"
- type="textarea"
- :disabled="browseStatus"
- placeholder="请输入内容"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :offset="16" :span="2">
- <el-form-item>
- <el-button
- @click="
- detailsHidden
- ? (detailsHidden = false)
- : (detailsHidden = true)
- "
- >{{ detailsHidden ? "隐藏" : "展开" }}
- </el-button>
- </el-form-item>
- </el-col>
- </el-row>
- </el-col>
- <el-col :span="8">
- <el-form-item>
- <div style="display: flex; align-items: center">
- <el-table
- :data="CntrTable"
- style="width: 80%"
- :header-cell-style="{ lineHeight: '16px' }"
- >
- <el-table-column
- prop="fCntrid "
- label="箱型"
- header-align="center"
- align="center"
- >
- <template slot-scope="scope">
- <el-select
- placeholder="请选择箱型"
- v-model="scope.row.fCntrid"
- size="mini"
- >
- <el-option
- v-for="(item, index) in cntrList"
- :key="index.fId"
- :label="item.fName"
- :value="item.fId"
- >
- </el-option>
- </el-select>
- </template>
- </el-table-column>
- <el-table-column
- prop="fCntrcount"
- label="箱量"
- header-align="center"
- align="center"
- >
- <template slot-scope="scope">
- <el-input
- placeholder="请输入箱量"
- v-model="scope.row.fCntrcount"
- size="mini"
- >
- </el-input>
- </template>
- </el-table-column>
- <el-table-column
- prop="fCntrcount"
- label="操作"
- header-align="center"
- align="center"
- width="50"
- >
- <template slot-scope="scope">
- <el-button
- size="mini"
- type="text"
- @click.native.prevent="deleteRow(scope.$index, CntrTable)"
- icon="el-icon-delete"
- ></el-button>
- </template>
- </el-table-column>
- </el-table>
- <el-tag class="tag-hover" @click="addRow"
- ><i class="el-icon-plus"></i
- ></el-tag>
- </div>
- </el-form-item>
- </el-col>
- </el-row>
- <div v-if="detailsHidden">
- <el-row style="margin-top: 30px">
- <el-col :span="8">
- <el-form-item label="仓库联系人" prop="fContacts">
- <el-input
- v-model="form.fContacts"
- style="width: 80%"
- :disabled="browseStatus"
- placeholder="仓库联系人"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="仓库电话" prop="fTel">
- <el-input
- v-model="form.fTel"
- :disabled="browseStatus"
- style="width: 80%"
- placeholder="请输仓库入电话"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="8">
- <el-form-item label="制单人" prop="createBy">
- <el-input
- disabled
- v-model="form.createBy"
- style="width: 80%"
- placeholder="制单人"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="制单部门" prop="fDeptid">
- <el-select
- v-model="form.fDeptid"
- filterable
- disabled
- style="width: 80%"
- remote
- >
- <el-option
- v-for="(item, index) in deptOptions"
- :key="index.deptId"
- :label="item.deptName"
- :value="item.deptId"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item disabled label="制单日期" prop="createTime">
- <el-date-picker
- v-model="form.createTime"
- size="large"
- type="date"
- disabled
- style="width: 80%"
- value-format="timestamp"
- placeholder="制单日期"
- >
- </el-date-picker>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="8">
- <el-form-item label="品名" prop="fProductName">
- <el-input
- v-model="form.fProductName"
- style="width: 80%"
- disabled
- placeholder="品名"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="品牌">
- <el-input
- v-model="form.fMarks"
- style="width: 80%"
- disabled
- placeholder="品牌"
- />
- </el-form-item>
- </el-col>
- </el-row>
- </div>
- </el-form>
- <el-collapse v-model="collapselist">
- <el-collapse-item name="1">
- <template slot="title">
- <i class="el-icon-s-home" style="font-size: 16px"></i>
- <span style="font-size: 16px; font-weight: bolder; margin-left: 5px"
- >调拨明细</span
- >
- </template>
- <div>
- <el-row
- type="flex"
- justify="space-between"
- style="margin-bottom: 10px"
- >
- <el-col>
- <el-button
- type="primary"
- :disabled="browseStatus"
- size="small"
- @click="addRelevant"
- >导入库存
- </el-button>
- <el-button
- :disabled="browseStatus"
- type="primary"
- size="small"
- @click="saveForm"
- >保 存</el-button
- >
- </el-col>
- <el-col style="display: flex; justify-content: flex-end">
- <el-button
- size="small"
- type="info"
- :disabled="browseStatus"
- prop="打印"
- @click="printZyd"
- >作业单
- </el-button>
- <el-button
- size="small"
- :disabled="browseStatus"
- @click="discharge"
- >叫车进场</el-button
- >
- <el-button
- size="small"
- :disabled="dataListSelection.length <= 0 || browseStatus"
- @click="creditClick"
- >调拨确认
- </el-button>
- <el-button
- size="small"
- :disabled="dataWithdrawList.length <= 0 || browseStatus"
- @click.prevent="withdrawClick"
- >撤回调拨
- </el-button>
- <el-dropdown @command="handleCommand" style="margin-left: 10px">
- <el-button :disabled="browseStatus" size="small" type="success">
- 打印单据<i class="el-icon-arrow-down el-icon--right"></i>
- </el-button>
- <el-dropdown-menu slot="dropdown">
- <el-dropdown-item command="a">收货单</el-dropdown-item>
- <el-dropdown-item command="b">入库单</el-dropdown-item>
- <el-dropdown-item command="c">移库单</el-dropdown-item>
- </el-dropdown-menu>
- </el-dropdown>
- </el-col>
- </el-row>
- <el-table
- :data="detailList"
- tooltip-effect="dark"
- stripe
- :summary-method="getSummaries"
- @selection-change="Selectinventory"
- show-summary
- >
- <el-table-column type="selection" width="55" align="center" fixed />
- <el-table-column label="序号" type="index" width="80" fixed />
- <el-table-column
- prop="fBillstatus"
- header-align="center"
- width="150px"
- align="center"
- fixed
- label="状态"
- >
- <template slot-scope="scope">
- <span v-if="scope.row.fBillstatus === 10">计划</span>
- <span v-if="scope.row.fBillstatus === 20">待调拨</span>
- <span v-if="scope.row.fBillstatus === 30">调拨中</span>
- <span v-if="scope.row.fBillstatus === 40">已调拨</span>
- </template>
- </el-table-column>
- <el-table-column
- prop="fBsdate"
- header-align="center"
- align="center"
- fixed
- width="150px"
- label="调拨日期"
- >
- <template slot-scope="scope">
- <el-date-picker
- v-model="scope.row.fBsdate"
- style="width: 138px"
- :disabled="browseStatus || scope.row.fBillstatus >= 20"
- type="date"
- value-format="timestamp"
- placeholder="业务日期"
- >
- </el-date-picker>
- </template>
- </el-table-column>
- <el-table-column
- prop="fMblno"
- header-align="center"
- align="center"
- width="140px"
- label="提单号"
- />
- <el-table-column
- prop="fGoodsid"
- header-align="center"
- align="center"
- width="140px"
- label="*品名"
- :formatter="goodsFormat"
- />
- <el-table-column
- prop="fBusinessType"
- header-align="center"
- width="140px"
- align="center"
- label="*货物属性"
- >
- <template slot-scope="scope">
- <el-select
- v-model="scope.row.fBusinessType"
- filterable
- disabled
- placeholder="请选择商品属性"
- >
- <el-option
- v-for="(item, index) in fStorageTypeOptions"
- :key="index.dictValue"
- :label="item.dictLabel"
- :value="item.dictValue"
- />
- </el-select>
- </template>
- </el-table-column>
- <el-table-column
- prop="fMarks"
- header-align="center"
- align="center"
- width="140px"
- label="*属性详情"
- />
- <el-table-column
- prop="fOrgwarehouseInformation"
- header-align="center"
- align="center"
- label="库位"
- />
- <el-table-column
- prop="fTransferWarehouselocid"
- header-align="center"
- width="240px"
- align="center"
- label="*调入库位"
- >
- <template slot-scope="scope">
- <el-input
- placeholder="请选择"
- :disabled="
- !form.fWarehouseid ||
- browseStatus ||
- scope.row.fBillstatus >= 20
- "
- v-model="scope.row.fWarehouseInformation"
- @focus="getTreeselect(scope)"
- >
- </el-input>
- </template>
- </el-table-column>
- <el-table-column
- prop="fPlanqty"
- header-align="center"
- align="center"
- width="180px"
- label="*结余库存"
- />
- <el-table-column
- prop="fPlangrossweight"
- header-align="center"
- align="center"
- width="180px"
- label="*结余毛重(kg)"
- />
- <el-table-column
- prop="fPlannetweight"
- header-align="center"
- align="center"
- width="180px"
- label="*结余净重(kg)"
- />
- <el-table-column
- prop="fQty"
- header-align="center"
- width="180px"
- align="center"
- label="*调拨件数"
- >
- <template slot-scope="scope">
- <el-input
- @change="qtyChange(scope.row)"
- v-model="scope.row.fQty"
- :disabled="browseStatus || scope.row.fBillstatus == 40"
- placeholder="调拨件数"
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fGrossweight"
- header-align="center"
- width="180px"
- align="center"
- label="*调拨毛重(kg)"
- >
- <template slot-scope="scope">
- <el-input
- :disabled="browseStatus || scope.row.fBillstatus == 40"
- v-model="scope.row.fGrossweight"
- @change="changeStock(scope.row)"
- placeholder="调拨毛重"
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fNetweight"
- header-align="center"
- width="180px"
- align="center"
- label="*调拨净重(kg)"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fNetweight"
- :disabled="browseStatus || scope.row.fBillstatus == 40"
- @change="changeStock(scope.row)"
- placeholder="调拨净重"
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fPackagespecs"
- header-align="center"
- width="180px"
- align="center"
- label="*包装规格"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fPackagespecs"
- :disabled="browseStatus || scope.row.fBillstatus >= 20"
- placeholder="包装规格"
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fTruckno"
- header-align="center"
- width="150px"
- align="center"
- label="*车号"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fTruckno"
- placeholder="车号"
- :disabled="browseStatus || scope.row.fBillstatus >= 40"
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fDriverName"
- header-align="center"
- width="130px"
- align="center"
- label="司机名"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fDriverName"
- placeholder="司机名"
- :disabled="browseStatus || scope.row.fBillstatus >= 20"
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fDriverTel"
- header-align="center"
- width="130px"
- align="center"
- label="司机电话"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fDriverName"
- placeholder="司机电话"
- :disabled="browseStatus || scope.row.fBillstatus >= 20"
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fDriverIdCar"
- header-align="center"
- width="200px"
- align="center"
- label="司机身份证"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fDriverIdCar"
- placeholder="司机身份证"
- :disabled="browseStatus || scope.row.fBillstatus >= 20"
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fCntrtype"
- header-align="center"
- align="center"
- width="140px"
- label="箱型"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fCntrtype"
- :disabled="browseStatus || scope.row.fBillstatus >= 20"
- placeholder="箱型"
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fCntqty"
- header-align="center"
- align="center"
- width="140px"
- label="箱量"
- >
- <template slot-scope="scope">
- <el-input
- oninput='this.value=this.value.replace(/[^\-?\d.]/g,"").replace(/^(\-)*(\d+)\.(\d\d).*$/, "$1$2.$3")'
- v-model="scope.row.fCntqty"
- placeholder="箱量"
- :disabled="browseStatus || scope.row.fBillstatus >= 20"
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fCntrno"
- header-align="center"
- width="150px"
- align="center"
- label="箱号"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fCntrno"
- placeholder="箱号"
- :disabled="browseStatus || scope.row.fBillstatus >= 20"
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fGoodsval"
- header-align="center"
- width="150px"
- align="center"
- label="货值"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fGoodsval"
- placeholder="货值"
- :disabled="browseStatus || scope.row.fBillstatus >= 20"
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fSerialNumber"
- header-align="center"
- width="160px"
- align="center"
- label="流水号"
- >
- </el-table-column>
- <el-table-column
- prop="remark"
- header-align="center"
- width="150px"
- align="center"
- label="备注"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.remark"
- placeholder="备注"
- :disabled="browseStatus"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- header-align="center"
- align="center"
- label="操作"
- width="130px"
- fixed="right"
- >
- <template slot-scope="scope">
- <el-button
- :disabled="
- browseStatus ||
- scope.row.fBillstatus === 20 ||
- scope.row.fBillstatus === 30 ||
- scope.row.fBillstatus === 40
- "
- type="text"
- @click.native.prevent="wDeleteRow(scope.$index, detailList)"
- size="small"
- >移除</el-button
- >
- </template>
- </el-table-column>
- </el-table>
- </div>
- </el-collapse-item>
- <el-collapse-item>
- <template slot="title">
- <i class="el-icon-s-order" style="font-size: 16px"></i>
- <span style="font-size: 16px; font-weight: bolder; margin-left: 5px"
- >附件明细</span
- >
- </template>
- <div
- class="dialogTableTitle flex a-center jlr"
- style="
- display: flex;
- justify-content: space-between;
- align-items: center;
- margin: 10px 0;
- "
- >
- <div>
- <el-button
- size="small"
- type="primary"
- :disabled="browseStatus"
- @click.prevent="addRelevt()"
- >新行
- </el-button>
- </div>
- </div>
- <el-table
- :data="relevantAttachments"
- ref="table"
- tooltip-effect="dark"
- border
- stripe
- style="width: 100%"
- height="150"
- >
- <el-table-column label="序号" type="index" width="80">
- </el-table-column>
- <el-table-column
- prop="fName"
- header-align="center"
- align="center"
- width="250px"
- label="附件名称"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fName"
- :disabled="browseStatus"
- placeholder="附件名称"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="createBy"
- header-align="center"
- align="center"
- width="250px"
- label="上传人"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.createBy"
- disabled
- placeholder="上传人"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="createTime"
- header-align="center"
- align="center"
- label="上传时间"
- >
- <template slot-scope="scope">
- <el-date-picker
- v-model="scope.row.createTime"
- type="date"
- disabled
- placeholder="上传时间"
- format="yyyy-MM-dd HH:mm"
- value-format="timestamp"
- ></el-date-picker>
- </template>
- </el-table-column>
- <el-table-column
- prop="fUrl"
- header-align="center"
- align="center"
- width="300px"
- label="上传附件"
- >
- <template slot-scope="scope">
- <div style="display: flex; justify-content: center">
- <el-upload
- class="upload-demo"
- :action="uploadImgUrl"
- :on-success="
- (res, file) => {
- handleSucces(scope, res, file);
- }
- "
- :headers="headers"
- :disabled="browseStatus"
- :show-file-list="false"
- :limit="1"
- >
- <el-button size="small" type="text" :disabled="browseStatus"
- >点击上传</el-button
- >
- </el-upload>
- <el-button size="small" type="text" @click="checkFile(scope)"
- >查看</el-button
- >
- <el-button
- size="small"
- type="text"
- :disabled="browseStatus"
- @click="deleteFile(scope)"
- >删除</el-button
- >
- </div>
- </template>
- </el-table-column>
- <el-table-column
- header-align="center"
- align="center"
- label="操作"
- width="130PX"
- >
- <template slot-scope="scope">
- <el-button
- @click.native.prevent="
- deleteRow(scope.$index, relevantAttachments)
- "
- :disabled="browseStatus"
- size="small"
- type="text"
- >删除
- </el-button>
- </template>
- </el-table-column>
- </el-table>
- </el-collapse-item>
- <el-collapse-item>
- <template slot="title">
- <i class="el-icon-circle-plus" style="font-size: 16px"></i>
- <span style="font-size: 16px; font-weight: bolder; margin-left: 5px"
- >收款信息</span
- >
- </template>
- <div
- class="dialogTableTitle flex a-center jlr"
- style="
- display: flex;
- justify-content: space-between;
- align-items: center;
- margin: 10px 0;
- "
- >
- <div>
- <el-button
- size="small"
- type="primary"
- :disabled="browseStatus"
- @click.prevent="addCollection()"
- >新行
- </el-button>
- <!-- <el-button :disabled="browseStatus" @click.prevent="deleteRow(warehouseDrList)"
- >删除
- </el-button> -->
- <el-button
- type="primary"
- size="small"
- :disabled="browseStatus"
- @click="saveForm"
- >保 存</el-button
- >
- <!-- <el-button @click.prevent="addAgreement()" type="warning">仓储费协议</el-button> -->
- <el-button
- size="small"
- @click.prevent="handleSelect(3)"
- :disabled="browseStatus"
- type="danger"
- >作业费协议</el-button
- >
- </div>
- </div>
- <el-table
- :data="warehouseDrList"
- ref="table"
- tooltip-effect="dark"
- border
- stripe
- show-summary
- @selection-change="Collectionoptions"
- :summary-method="warehouseDrSummaries"
- >
- <el-table-column type="selection" width="55" align="center" />
- <el-table-column label="序号" type="index" width="80">
- </el-table-column>
- <el-table-column
- prop="fCorpid"
- header-align="center"
- align="center"
- width="180px"
- label="客户名称"
- >
- <template slot-scope="scope">
- <el-select
- v-model="scope.row.fCorpid"
- filterable
- clearable
- placeholder="客户名称"
- :disabled="browseStatus"
- >
- <el-option
- v-for="(item, index) in fMblnoOptions"
- :key="index.fId"
- :label="item.fName"
- :value="item.fId"
- ></el-option>
- </el-select>
- </template>
- </el-table-column>
- <el-table-column
- prop="fFeeid"
- header-align="center"
- align="center"
- width="180px"
- label="费用名称"
- >
- <template slot-scope="scope">
- <el-select
- v-model="scope.row.fFeeid"
- clearable
- placeholder="费用名称"
- :disabled="browseStatus"
- >
- <el-option
- v-for="(item, index) in fDNameOptions"
- :key="index.fId"
- :label="item.fName"
- :value="item.fId"
- ></el-option>
- </el-select>
- </template>
- </el-table-column>
- <el-table-column
- prop="fBusinessType"
- header-align="center"
- align="center"
- width="180px"
- label="作业类型"
- >
- <template slot-scope="scope">
- <el-select
- style="width: 80%"
- v-model="scope.row.fBusinessType"
- filterable
- disabled
- >
- <el-option
- v-for="(item, index) in businessTypeOption"
- :key="index.dictValue"
- :label="item.dictLabel"
- :value="item.dictValue"
- ></el-option>
- </el-select>
- </template>
- </el-table-column>
- <el-table-column
- prop="fFeeUnitid"
- header-align="center"
- align="center"
- width="180px"
- label="计价单位"
- >
- <template slot-scope="scope">
- <el-select
- v-model="scope.row.fFeeUnitid"
- placeholder="请选择计价单位"
- clearable
- :disabled="browseStatus"
- @change="changeFeeUnit(scope.row)"
- >
- <el-option
- v-for="(item, index) in fFeetUnitOptions"
- :key="index.dictValue"
- :label="item.dictLabel"
- :value="item.dictValue"
- />
- </el-select>
- </template>
- </el-table-column>
- <el-table-column
- prop="fQty"
- header-align="center"
- align="center"
- width="130px"
- label="数量"
- >
- <template slot-scope="scope">
- <el-input
- oninput='this.value=this.value.replace(/[^\-?\d.]/g,"").replace(/^(\-)*(\d+)\.(\d\d).*$/, "$1$2.$3")'
- v-model="scope.row.fQty"
- placeholder="数量"
- :disabled="browseStatus"
- @change="changeContractAmt(scope.row)"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fUnitprice"
- header-align="center"
- align="center"
- width="130px"
- label="单价"
- >
- <template slot-scope="scope">
- <el-input
- oninput='this.value=this.value.replace(/[^\-?\d.]/g,"").replace(/^(\-)*(\d+)\.(\d\d).*$/, "$1$2.$3")'
- v-model="scope.row.fUnitprice"
- placeholder="单价"
- :disabled="browseStatus || scope.row.fSrcTypeId !== 0"
- @change="changeContractAmt(scope.row)"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fAmount"
- header-align="center"
- align="center"
- width="130px"
- label="金额"
- >
- <template slot-scope="scope">
- <el-input
- disabled
- oninput='this.value=this.value.replace(/[^\-?\d.]/g,"").replace(/^(\-)*(\d+)\.(\d\d).*$/, "$1$2.$3")'
- v-model="scope.row.fAmount"
- placeholder="金额"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fStltypeid"
- header-align="center"
- align="center"
- width="130px"
- label="结算方式"
- >
- <template slot-scope="scope">
- <el-select
- v-model="scope.row.fStltypeid"
- placeholder="请选择结算表票结、月结"
- :disabled="browseStatus"
- >
- <el-option
- v-for="(item, index) in fStltypeOptions"
- :key="index.dictValue"
- :label="item.dictLabel"
- :value="item.dictValue"
- ></el-option>
- </el-select>
- </template>
- </el-table-column>
- <el-table-column
- prop="fCurrency"
- header-align="center"
- align="center"
- width="130px"
- label="币别"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fCurrency"
- :disabled="browseStatus"
- placeholder="币别"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fExrate"
- header-align="center"
- align="center"
- width="130px"
- label="汇率"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fExrate"
- :disabled="browseStatus"
- placeholder="汇率"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fTaxrate"
- header-align="center"
- align="center"
- width="130px"
- label="税率"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fTaxrate"
- :disabled="browseStatus"
- placeholder="税率"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fMblno"
- header-align="center"
- align="center"
- width="130px"
- label="提单号"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fMblno"
- :disabled="browseStatus"
- placeholder="提单号"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fProductName"
- header-align="center"
- align="center"
- width="140px"
- label="品名"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fProductName"
- :disabled="browseStatus"
- placeholder="品名"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fMarks"
- header-align="center"
- align="center"
- width="130px"
- label="品牌"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fMarks"
- :disabled="browseStatus"
- placeholder="品牌"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fSrcTypeId"
- header-align="center"
- align="center"
- width="130px"
- label="来源"
- >
- <template slot-scope="scope">
- <span v-if="scope.row.fSrcTypeId === 0">录入</span>
- <span v-if="scope.row.fSrcTypeId !== 0">协议</span>
- </template>
- </el-table-column>
- <el-table-column
- prop="remarks"
- header-align="center"
- align="center"
- width="150px"
- label="备注"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.Remarks"
- :disabled="browseStatus"
- placeholder="备注"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- header-align="center"
- align="center"
- label="操作"
- width="200px"
- >
- <template slot-scope="scope">
- <el-button
- @click.native.prevent="deleteRow(scope.$index, warehouseDrList)"
- size="small"
- :disabled="browseStatus"
- >移除</el-button
- >
- </template>
- </el-table-column>
- </el-table>
- </el-collapse-item>
- <el-collapse-item>
- <template slot="title">
- <i class="el-icon-remove" style="font-size: 16px"></i>
- <span style="font-size: 16px; font-weight: bolder; margin-left: 5px"
- >付款信息</span
- >
- </template>
- <div
- class="dialogTableTitle flex a-center jlr"
- style="
- display: flex;
- justify-content: space-between;
- align-items: center;
- margin: 10px 0;
- "
- >
- <div>
- <el-button
- type="primary"
- :disabled="browseStatus"
- @click.prevent="addpayment()"
- size="small"
- >新行
- </el-button>
- <el-button
- type="primary"
- size="small"
- @click="saveForm"
- :disabled="browseStatus"
- >保 存</el-button
- >
- <el-button
- type="danger"
- size="small"
- @click.prevent="handleSelect(1)"
- :disabled="browseStatus"
- >作业费协议</el-button
- >
- </div>
- </div>
- <el-table
- :data="warehouseCrList"
- ref="table"
- tooltip-effect="dark"
- border
- stripe
- show-summary
- :summary-method="warehouseDrSummaries"
- >
- <el-table-column type="selection" width="55" align="center" />
- <el-table-column label="序号" type="index" width="80">
- </el-table-column>
- <el-table-column
- prop="fCorpid"
- header-align="center"
- align="center"
- width="180px"
- label="客户名称"
- :disabled="browseStatus"
- >
- <template slot-scope="scope">
- <el-select
- v-model="scope.row.fCorpid"
- filterable
- remote
- clearable
- :remote-method="corpremoteMethod2"
- placeholder="客户名称"
- >
- <el-option
- v-for="(item, index) in fMblnoOptions"
- :key="index.fId"
- :label="item.fName"
- :value="item.fId"
- ></el-option>
- </el-select>
- </template>
- </el-table-column>
- <el-table-column
- prop="fFeeid"
- header-align="center"
- align="center"
- width="180px"
- label="费用名称"
- >
- <template slot-scope="scope">
- <el-select
- v-model="scope.row.fFeeid"
- clearable
- placeholder="费用名称"
- :disabled="browseStatus"
- >
- <el-option
- v-for="(item, index) in fCNameOptions"
- :key="index.fId"
- :label="item.fName"
- :value="item.fId"
- ></el-option>
- </el-select>
- </template>
- </el-table-column>
- <el-table-column
- prop="fBusinessType"
- header-align="center"
- align="center"
- width="180px"
- label="作业类型"
- >
- <template slot-scope="scope">
- <el-select
- style="width: 80%"
- v-model="scope.row.fBusinessType"
- filterable
- disabled
- >
- <el-option
- v-for="(item, index) in businessTypeOption"
- :key="index.dictValue"
- :label="item.dictLabel"
- :value="item.dictValue"
- ></el-option>
- </el-select>
- </template>
- </el-table-column>
- <el-table-column
- prop="fFeeUnitid"
- header-align="center"
- align="center"
- width="180px"
- label="计价单位"
- >
- <template slot-scope="scope">
- <el-select
- v-model="scope.row.fFeeUnitid"
- filterable
- remote
- :disabled="browseStatus"
- :remote-method="corpsRemoteMethod"
- placeholder="计价单位"
- @change="changeFeeUnit(scope.row)"
- >
- <el-option
- v-for="(item, index) in fFeetUnitOptions"
- :key="index.dictValue"
- :label="item.dictLabel"
- :value="item.dictValue"
- ></el-option>
- </el-select>
- </template>
- </el-table-column>
- <el-table-column
- prop="fQty"
- header-align="center"
- align="center"
- width="150px"
- label="数量"
- >
- <template slot-scope="scope">
- <el-input
- oninput='this.value=this.value.replace(/[^\-?\d.]/g,"").replace(/^(\-)*(\d+)\.(\d\d\d\d).*$/, "$1$2.$3")'
- v-model="scope.row.fQty"
- :disabled="browseStatus"
- @change="changeContractAmt(scope.row)"
- placeholder="数量"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fUnitprice"
- header-align="center"
- align="center"
- width="150px"
- label="单价"
- >
- <template slot-scope="scope">
- <el-input
- oninput='this.value=this.value.replace(/[^\-?\d.]/g,"").replace(/^(\-)*(\d+)\.(\d\d).*$/, "$1$2.$3")'
- v-model="scope.row.fUnitprice"
- :disabled="browseStatus || scope.row.fSrcTypeId !== 0"
- @change="changeContractAmt(scope.row)"
- placeholder="单价"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fAmount"
- header-align="center"
- align="center"
- width="150px"
- label="金额"
- >
- <template slot-scope="scope">
- <el-input
- disabled
- oninput='this.value=this.value.replace(/[^\-?\d.]/g,"").replace(/^(\-)*(\d+)\.(\d\d).*$/, "$1$2.$3")'
- v-model="scope.row.fAmount"
- placeholder="金额"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fStltypeid"
- header-align="center"
- align="center"
- width="130px"
- label="结算方式"
- >
- <template slot-scope="scope">
- <el-select
- v-model="scope.row.fStltypeid"
- placeholder="请选择结算表票结、月结"
- :disabled="browseStatus"
- >
- <el-option
- v-for="(item, index) in fStltypeOptions"
- :key="index.dictValue"
- :label="item.dictLabel"
- :value="item.dictValue"
- ></el-option>
- </el-select>
- </template>
- </el-table-column>
- <el-table-column
- prop="fCurrency"
- header-align="center"
- align="center"
- width="150px"
- label="币别"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fCurrency"
- :disabled="browseStatus"
- placeholder="币别"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fExrate"
- header-align="center"
- align="center"
- width="150px"
- label="汇率"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fExrate"
- :disabled="browseStatus"
- placeholder="汇率"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fTaxrate"
- header-align="center"
- align="center"
- width="150px"
- label="税率"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fTaxrate"
- :disabled="browseStatus"
- placeholder="税率"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fMblno"
- header-align="center"
- align="center"
- width="130px"
- label="提单号"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fMblno"
- :disabled="browseStatus"
- placeholder="提单号"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fProductName"
- header-align="center"
- align="center"
- width="140px"
- label="品名"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fProductName"
- :disabled="browseStatus"
- placeholder="品名"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fMarks"
- header-align="center"
- align="center"
- width="130px"
- label="品牌"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.fMarks"
- :disabled="browseStatus"
- placeholder="品牌"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- prop="fSrcTypeId"
- header-align="center"
- align="center"
- width="130px"
- label="来源"
- >
- <template slot-scope="scope">
- <span v-if="scope.row.fSrcTypeId === 0">录入</span>
- <span v-if="scope.row.fSrcTypeId !== 0">协议</span>
- </template>
- </el-table-column>
- <el-table-column
- prop="remarks"
- header-align="center"
- align="center"
- width="150px"
- label="备注"
- >
- <template slot-scope="scope">
- <el-input
- v-model="scope.row.remarks"
- :disabled="browseStatus"
- placeholder="备注"
- show-word-limit
- />
- </template>
- </el-table-column>
- <el-table-column
- header-align="center"
- align="center"
- width="200px"
- label="操作"
- >
- <template slot-scope="scope">
- <!-- <el-button size="small">审核费用</el-button> -->
- <el-button
- @click.native.prevent="
- deleteRoww(scope.$index, warehouseCrList)
- "
- size="small"
- :disabled="browseStatus"
- >移除</el-button
- >
- </template>
- </el-table-column>
- </el-table>
- </el-collapse-item>
- </el-collapse>
- <el-dialog
- title="在库物资"
- :modal="false"
- style="box-shadow: 0 1px 3px rgba(0, 0, 0, 0) !important"
- :visible.sync="whgenlegVisible"
- width="70%"
- @close="init2()"
- >
- <el-form
- ref="whgenlegParams"
- :model="whgenlegParams"
- label-width="120px"
- >
- <el-row>
- <el-col :span="6">
- <el-form-item label="箱号" prop="fCntrno">
- <el-input
- v-model="whgenlegParams.fCntrno"
- placeholder="请输入箱号"
- clearable
- style="width: 80%"
- />
- </el-form-item>
- </el-col>
- <el-col :span="10">
- <el-form-item label="入库日期区间" prop="orgStorageDate">
- <el-date-picker
- style="width: 80%"
- v-model="whgenlegParams.orgStorageDate"
- type="daterange"
- start-placeholder="开始日期"
- end-placeholder="结束日期"
- value-format="yyyy-MM-dd HH:mm:ss"
- :default-time="['00:00:00', '23:59:59']"
- >
- </el-date-picker>
- </el-form-item>
- </el-col>
- <el-col :span="2">
- <el-button
- type="cyan"
- icon="el-icon-search"
- @click="getWhgenlegList()"
- >搜索</el-button
- >
- </el-col>
- </el-row>
- </el-form>
- <el-table
- :data="whgenlegList"
- ref="table"
- tooltip-effect="dark"
- width="100%"
- border
- stripe
- @selection-change="whgenlegSelectionChange"
- >
- <el-table-column type="selection" width="55"> </el-table-column>
- <el-table-column
- prop="fMblno"
- header-align="center"
- align="center"
- label="提单号"
- >
- </el-table-column>
- <el-table-column
- prop="fOriginalbilldate"
- header-align="center"
- align="center"
- width="180px"
- label="入库日期"
- >
- </el-table-column>
- <el-table-column
- prop="fGoodsids"
- header-align="center"
- align="center"
- label="品名"
- >
- </el-table-column>
- <el-table-column
- prop="fCntrno"
- header-align="center"
- align="center"
- label="箱号"
- />
- <el-table-column
- prop="fGrossweightblc"
- header-align="center"
- align="center"
- label="毛重"
- />
- <el-table-column
- prop="fNetweightblc"
- header-align="center"
- align="center"
- label="净重"
- />
- <el-table-column
- prop="fQtyblc"
- header-align="center"
- align="center"
- label="结余数量"
- >
- </el-table-column>
- <el-table-column
- prop="fWarehouseids"
- header-align="center"
- align="center"
- label="库位"
- >
- </el-table-column>
- <el-table-column
- prop="fMarks"
- header-align="center"
- align="center"
- label="品牌"
- >
- </el-table-column>
- </el-table>
- <pagination
- v-show="whgenlegTotal > 0"
- :total="whgenlegTotal"
- :page.sync="whgenlegParams.pageNum"
- :limit.sync="whgenlegParams.pageSize"
- @pagination="getWhgenlegList"
- />
- <div slot="footer" class="dialog-footer">
- <el-button type="primary" @click="whgenlegData">导入库存总账</el-button>
- <el-button @click="whgenlegVisible = false">取 消</el-button>
- </div>
- </el-dialog>
- <el-dialog
- :visible.sync="print_zyd"
- width="70%"
- :close-on-click-modal="false"
- :modal="false"
- >
- <div id="print_area1" class="print-div">
- <div
- class="print-title"
- style="
- display: flex;
- justify-content: center;
- font-size: 24px;
- margin-bottom: 5px;
- "
- >
- {{ company }}有限公司作业单
- </div>
- <div
- style="
- display: flex;
- justify-content: center;
- font-size: 18px;
- margin-bottom: 5px;
- "
- ></div>
- <div class="print_table" style="display: flex">
- <table border="0" cellspacing="0" cellpadding="0" style="width: 100%">
- <tr>
- <td>作业类型</td>
- <td colspan="2">
- {{ form.fBusinessType | fBusinessTypeFormat }}
- </td>
- <td>入库时间</td>
- <td colspan="2"></td>
- </tr>
- <tr>
- <td>车号</td>
- <td>物品名称</td>
- <td>提单号</td>
- <td>品牌/规格/产地</td>
- <td>净重(KG)</td>
- <td>件数/规格</td>
- </tr>
- <tr v-for="(item, index) in Printinglist" :key="index">
- <td>{{ item.fTruckno }}</td>
- <td>{{ item.fGoodsids }}</td>
- <td>{{ item.fMblno }}</td>
- <td>
- {{ item.fBusinessType | fStorageFormat }}/{{ item.fMarks }}
- </td>
- <td>{{ item.fNetweight }}</td>
- <td>{{ item.fQty }}/{{ item.fPackagespecs }}</td>
- </tr>
- <tr>
- <td>备注</td>
- <td colspan="5"></td>
- </tr>
- <tr v-for="(item, index) in Collectionoptionss" :key="index">
- <td>收费</td>
- <td colspan="2">{{ item.fFeeids }}</td>
- <td colspan="3">{{ item.fAmount }} 元</td>
- </tr>
- <tr>
- <td>司机签字</td>
- <td></td>
- <td>电话</td>
- <td>{{ fDriverTel }}</td>
- <td colspan="2" rowspan="2">
- 确认货物数量无误,包装于货物完好!<br />出库盖好篷布,如有违背责任自负<br />装卸工是否收小费
- </td>
- </tr>
- <tr>
- <td>制表</td>
- <td>{{ form.createBy }}</td>
- <td>机械/人工</td>
- <td></td>
- </tr>
- <tr>
- <td>地址</td>
- <td colspan="2">{{ stockaddr }}</td>
- <td>电话</td>
- <td colspan="2">{{ form.fTel }}</td>
- </tr>
- </table>
- </div>
- </div>
- <span lot="footer" class="dialog-footer">
- <el-button
- type="primary"
- size="mini"
- :disabled="browseStatus"
- @click="
- print_zyd = false;
- addprint('zyd');
- "
- >打印
- </el-button>
- <el-button @click="print_zyd = false" size="mini">取消 </el-button>
- </span>
- </el-dialog>
- <el-dialog
- :visible.sync="print_rkd"
- width="70%"
- :close-on-click-modal="false"
- :modal="false"
- >
- <div id="print_area1" class="print-div">
- <div
- class="print-title"
- style="
- display: flex;
- justify-content: center;
- font-size: 24px;
- margin-bottom: 5px;
- "
- >
- {{ company }}有限公司进仓单
- </div>
- <div class="print_table" style="display: flex">
- <table border="0" cellspacing="0" cellpadding="0" style="width: 100%">
- <tr>
- <td>客户</td>
- <td>{{ form.fCorpidName }}</td>
- <td>仓库</td>
- <td>{{ form.fWarehouseids }}</td>
- <td>地址</td>
- <td colspan="2">{{ stockaddr }}</td>
- </tr>
- <tr>
- <td>保管方</td>
- <td width="200">{{ company }}有限公司</td>
- <td>联系人</td>
- <td>{{ form.fContacts }}</td>
- <td>电话</td>
- <td colspan="2">{{ form.fTel }}</td>
- </tr>
- <tr>
- <td>提单号</td>
- <td>品名</td>
- <td>箱型</td>
- <td>品牌</td>
- <td>件数</td>
- <td>重量</td>
- <td>包装规格</td>
- </tr>
- <tr>
- <td></td>
- <td></td>
- <td></td>
- <td></td>
- <td></td>
- <td></td>
- <td></td>
- </tr>
- <tr>
- <td>序号</td>
- <td>入货日期</td>
- <td>箱量(20GP)</td>
- <td>重量</td>
- <td>件数</td>
- <td>入库重量</td>
- <td>入库件数</td>
- </tr>
- <tr v-for="(item, index) in Printinglist" :key="index">
- <td>{{ index + 1 }}</td>
- <td>{{ item.fBsdate }}</td>
- <td>{{ item.fCntqty }}</td>
- <td v-if="item.fGrossweight">
- {{ (item.fGrossweight / 1000).toFixed(2) }}
- </td>
- <td v-else></td>
- <td>{{ item.fPlanqty }}</td>
- <td v-if="item.fNetweight">
- {{ (item.fNetweight / 1000).toFixed(2) }}
- </td>
- <td v-else></td>
- <td>{{ item.fQty }}</td>
- </tr>
- <tr>
- <td colspan="2">合计</td>
- <td>{{ allfCntqty }}</td>
- <td>{{ (allfGrossweight / 1000).toFixed(2) }}</td>
- <td>{{ allfPlanqty }}</td>
- <td>{{ (allfNetweight / 1000).toFixed(2) }}</td>
- <td>{{ allfQty }}</td>
- </tr>
- <tr>
- <td>备注</td>
- <td colspan="6"></td>
- </tr>
- <tr>
- <td colspan="7">
- 本进仓单经仓管员签字并经保管方盖章后即专项作为货物所有人的货权证明,本单据不得转让。
- </td>
- </tr>
- </table>
- </div>
- <div
- style="display: flex; justify-content: space-between; font-size: 12px"
- >
- <div>开单员:</div>
- <div style="width: 150px">仓管员:</div>
- </div>
- <div
- style="display: flex; justify-content: space-between; font-size: 12px"
- >
- <div>开单时间:</div>
- <div style="width: 150px">(盖章)</div>
- </div>
- </div>
- <span slot="footer" class="dialog-footer">
- <el-button
- type="primary"
- :disabled="browseStatus"
- @click="
- print_rkd = false;
- addprint();
- "
- >打印
- </el-button>
- <el-button @click="print_rkd = false">取消 </el-button>
- </span>
- </el-dialog>
- <el-dialog
- :visible.sync="print_shd"
- width="70%"
- :close-on-click-modal="false"
- :modal="false"
- >
- <div id="print_area1" class="print-div">
- <div
- class="print-title"
- style="
- display: flex;
- justify-content: center;
- font-size: 24px;
- margin-bottom: 5px;
- "
- >
- {{ company }}有限公司收货单
- </div>
- <div class="print_table" style="display: flex">
- <table border="0" cellspacing="0" cellpadding="0" style="width: 100%">
- <tr>
- <td>车号</td>
- <td>{{ fTruckno }}</td>
- <td>日期</td>
- <td>{{ fBsdate }}</td>
- </tr>
- <tr v-for="(item, index) in Printinglist" :key="index">
- <td>货物品名</td>
- <td>{{ item.fGoodsids }}</td>
- <td>件数</td>
- <td>{{ item.fQty }}件</td>
- </tr>
- <tr>
- <td>备注</td>
- <td colspan="3"></td>
- </tr>
- <tr>
- <td>司机签字</td>
- <td></td>
- <td>司机电话</td>
- <td>{{ fDriverTel }}</td>
- </tr>
- <tr>
- <td>制单人</td>
- <td>{{ form.createBy }}</td>
- <td>收货人</td>
- <td>{{ form.fContacts }}</td>
- </tr>
- <tr>
- <td>地址</td>
- <td>{{ stockaddr }}</td>
- <td>电话</td>
- <td>{{ form.fTel }}</td>
- </tr>
- </table>
- </div>
- </div>
- <span slot="footer" class="dialog-footer">
- <el-button
- type="primary"
- :disabled="browseStatus"
- @click="
- addprint();
- print_shd = false;
- "
- >打印
- </el-button>
- <el-button @click="print_shd = false">取消 </el-button>
- </span>
- </el-dialog>
- <el-dialog
- :visible.sync="print_ykd"
- width="70%"
- :close-on-click-modal="false"
- :modal="false"
- >
- <div id="print_area1" class="print-div">
- <div
- class="print-title"
- style="
- display: flex;
- justify-content: center;
- font-size: 24px;
- margin-bottom: 5px;
- "
- >
- {{ company }}有限公司
- </div>
- <div
- style="
- display: flex;
- justify-content: center;
- font-size: 18px;
- margin-bottom: 5px;
- "
- >
- <div>移 库 单</div>
- </div>
- <div
- style="
- display: flex;
- justify-content: space-between;
- margin-bottom: 5px;
- "
- class="print_form"
- >
- <div>
- <div>业务编号:{{ form.fCustomno }}</div>
- <div>调拨日期:{{ form.fChargedate }}</div>
- </div>
- <div>
- <div>客户名称:{{ form.fCorpidName }}</div>
- <div>提单号:{{ form.fMblno }}</div>
- </div>
- <div>
- <div>存放地址:{{ stockName }}</div>
- <div>调拨:</div>
- </div>
- </div>
- <div class="print_table" style="display: flex">
- <table border="0" cellspacing="0" cellpadding="0" style="width: 100%">
- <tr>
- <td>箱号</td>
- <td>现存库区</td>
- <td>件数</td>
- <td>毛重</td>
- <td>净重</td>
- <td>移入库区</td>
- </tr>
- <tr v-for="(item, index) in Printinglist" :key="index">
- <td>{{ item.fCntrno }}</td>
- <td>{{ item.fOrgwarehouseInformation }}</td>
- <td>{{ item.fQty }}</td>
- <td>{{ item.fGrossweight }}</td>
- <td>{{ item.fNetweight }}</td>
- <td>{{ item.fWarehouseInformation }}</td>
- </tr>
- </table>
- </div>
- <div
- style="display: flex; justify-content: space-between; font-size: 12px"
- >
- <div>库管:{{ form.fContacts }}</div>
- <div style="width: 100px">叉车:</div>
- </div>
- </div>
- <span slot="footer" class="dialog-footer">
- <el-button
- type="primary"
- :disabled="browseStatus"
- @click="
- addprint();
- print_ykd = false;
- "
- >打印
- </el-button>
- <el-button @click="print_ykd = false">取消 </el-button>
- </span>
- </el-dialog>
- <!-- 选择作业费协议数据 -->
- <el-dialog
- v-dialogDrag
- title="作业费协议"
- :close-on-click-modal="false"
- :modal="false"
- style="box-shadow: 0 1px 3px rgba(0, 0, 0, 0) !important"
- :visible.sync="warehousingagreements"
- width="70%"
- >
- <template slot="作业费协议">
- <div class="avue-crud__dialog__header">
- <span class="el-dialog__title">
- <span
- style="
- display: inline-block;
- width: 3px;
- height: 20px;
- margin-right: 5px;
- float: left;
- margin-top: 2px;
- "
- ></span>
- </span>
- </div>
- </template>
- <el-menu
- :default-active="activeIndex"
- v-if="Navigation === true"
- class="el-menu-demo"
- mode="horizontal"
- @select="handleSelect"
- >
- <el-menu-item index="1">车队作业费</el-menu-item>
- <el-menu-item index="2">劳务作业费</el-menu-item>
- </el-menu>
- <el-table
- :data="tasklegList"
- ref="table"
- tooltip-effect="dark"
- width="100%"
- border
- stripe
- @selection-change="whgenlegSelectionChange"
- >
- <el-table-column type="selection" width="55"> </el-table-column>
- <el-table-column label="行号" type="index" width="80">
- </el-table-column>
- <el-table-column
- prop="fCorpname"
- header-align="center"
- align="center"
- label="客户名称"
- />
- <el-table-column
- prop="fName"
- header-align="center"
- align="center"
- label="费用名称"
- />
- <el-table-column
- prop="fFeeUnitid"
- header-align="center"
- align="center"
- width="180px"
- label="计价单位"
- >
- <template slot-scope="scope">
- <el-select
- v-model="scope.row.fFeeUnitid"
- placeholder="请选择计价单位"
- @change="changeFeeUnit(scope.row)"
- disabled
- clearable
- >
- <el-option
- v-for="(dict, index) in fFeetUnitOptions"
- :key="index.dictValue"
- :label="dict.dictLabel"
- :value="dict.dictValue"
- />
- </el-select>
- </template>
- </el-table-column>
- <el-table-column
- prop="fPrice"
- header-align="center"
- align="center"
- label="单价"
- />
- </el-table>
- <pagination
- v-show="whgenlegTotal > 0"
- :total="whgenlegTotal"
- :page.sync="pageNum"
- :limit.sync="pageSize"
- @pagination="getWhgenlegList"
- />
- <div slot="footer" class="dialog-footer">
- <el-button type="primary" @click="zhgenlegData">导 入</el-button>
- <el-button
- @click="
- warehousingagreements = false;
- Navigation = false;
- "
- >取 消</el-button
- >
- </div>
- </el-dialog>
- <el-dialog
- title="选择库位"
- :data="treeselectList"
- :visible.sync="choiceWarehouse"
- width="30%"
- :before-close="hanDleclose"
- >
- <treeselect
- v-model="treeselectList.fWarehouselocid"
- @select="getAlltree"
- :options="fWarehouseidOptions"
- :show-count="true"
- :disable-branch-nodes="true"
- placeholder="请选择归属库区"
- />
- <span slot="footer" class="dialog-footer">
- <el-button @click="choiceWarehouse = false">取 消</el-button>
- <el-button type="primary" @click="confirm">确 定</el-button>
- </span>
- </el-dialog>
- <div style="display: flex; justify-content: flex-end; margin-top: 10px">
- <!-- 弹窗, 新增 / 修改 -->
- <add-or-update
- v-if="addOrUpdateVisible"
- ref="addOrUpdate"
- @refreshDataList="getDataList"
- ></add-or-update>
- <approval-comments
- v-if="addOrUpdateVisib"
- ref="ApprovalComments"
- @refreshDataList="returnData"
- ></approval-comments>
- <el-button
- type="primary"
- :disabled="approvalStatus"
- v-if="form.fBillstatus > 3"
- @click="addOrUpdateHandle(form)"
- >查看审批</el-button
- >
- <el-button
- type="primary"
- v-if="approVal === true"
- @click="addOrUpdateHand(form)"
- >审批</el-button
- >
- <el-button :disabled="browseStatus" type="primary" @click="saveForm()"
- >保 存</el-button
- >
- <el-button
- :disabled="browseStatus"
- style="background-color: #008000; color: #fff"
- @click="submitForm()"
- >请核</el-button
- >
- <el-button type="danger" v-if="form.fBillstatus === 6" @click="revoke"
- >撤销请核</el-button
- >
- <el-button
- type="danger"
- v-if="form.fBillstatus === 4 && current == before"
- :disabled="doNot"
- @click="revokeTwo"
- >撤销审批</el-button
- >
- <el-button @click="cancel">取 消</el-button>
- </div>
- </div>
- </template>
- <script>
- import print from "print-js";
- import {
- backFee,
- RevocationApproval,
- addWhgenleg,
- getStockTransferList,
- getStockTransfer,
- delStockTransfer,
- updateCredit,
- addJoblist,
- disChargelist,
- addStockTransfer,
- warehouseSubmission,
- updateStockTransfer,
- exportStockTransfer,
- delstockTransfer_s,
- serialNumber,
- } from "@/api/warehouseBusiness/stockTransfer";
- import { operationAgreement } from "@/api/agreement/agreement";
- import { listCorps } from "@/api/basicdata/corps";
- import { listFees, getFees } from "@/api/basicdata/fees";
- import {
- listWarehouse,
- treeselect,
- listWarehousesss,
- } from "@/api/basicdata/warehouse";
- import { listGoods } from "@/api/basicdata/goods";
- import { listCntrs } from "@/api/basicdata/cntr";
- import { listUser, queryUserVal } from "@/api/system/user";
- import { listWhgenleg } from "@/api/reportManagement/whgenleg";
- import ApprovalComments from "@/views/startApproval";
- import AddOrUpdate from "@/views/viewApproval";
- import Global from "@/layout/components/global";
- import Treeselect from "@riophae/vue-treeselect";
- import "@riophae/vue-treeselect/dist/vue-treeselect.css";
- import UploadFile from "@/components/Uploadfile";
- import Cookies from "js-cookie";
- import { getToken } from "@/utils/auth";
- export default {
- name: "inStock",
- props: {
- chiId: {
- type: Number,
- required: null,
- },
- copyStatus: {
- type: Number,
- required: null,
- },
- },
- components: {
- UploadFile,
- Treeselect,
- AddOrUpdate,
- ApprovalComments,
- },
- data() {
- return {
- pageNum: 1,
- pageSize: 10,
- dialogWhgenlegList: [],
- tasklegList: [],
- Navigation: false,
- key_id: "",
- warehousingagreements: false,
- mblnoStatus: "",
- selectloading: false,
- fMblnoOptions: [],
- warehouseDrList: [],
- relevantAttachments: [],
- warehouseCrList: [],
- fStltypeOptions: [],
- form: {},
- rules: {
- fDeptid: [{ required: true, message: " ", trigger: "blur" }],
- fBsdeptid: [{ required: true, message: " ", trigger: "blur" }],
- fCorpid: [{ required: true, message: " ", trigger: "blur" }],
- fChargedate: [{ required: true, message: " ", trigger: "blur" }],
- fMarks: [{ required: true, message: " ", trigger: "blur" }],
- fBsdate: [{ required: true, message: " ", trigger: "blur" }],
- fTrademodeid: [{ required: true, message: " ", trigger: "blur" }],
- fSbu: [{ required: true, message: " ", trigger: "blur" }],
- fBusinessType: [{ required: true, message: " ", trigger: "blur" }],
- fStorekeeper: { required: true, message: " ", trigger: "blur" },
- fWarehouseid: [{ required: true, message: " ", trigger: "blur" }],
- fbillingway: [{ required: true, message: " ", trigger: "blur" }],
- fTocorpid: [{ required: true, message: " ", trigger: "blur" }],
- fFeetUnit: [{ required: true, message: " ", trigger: "blur" }],
- },
- browseStatus: false,
- goodsOptions: [],
- warehouseOptions: [],
- userOptions: [],
- businessTypeOption: [],
- fCompanyOptIons: [],
- fleetOptions: [],
- fFeetUnitOptions: [],
- current: "",
- before: "",
- contrOl: false,
- isrequired: 2,
- isrequired2: 2,
- detailsHidden: false,
- CntrTable: [],
- cntrList: [],
- fTrademodeidOptions: [],
- fIfweighOptions: [],
- fSbuOptions: [],
- collapselist: ["1"],
- fStorageTypeOptions: [],
- weightList: false,
- headers: {
- Authorization: "Bearer " + getToken(),
- },
- uploadImgUrl: process.env.VUE_APP_BASE_API + "/common/upload", // 上传的图片服务器地址
- sumMum: 0,
- allfPlanqty: 0,
- detailList: [],
- fWarehouseidOptions: [],
- print_zyd: false,
- print_shd: false,
- print_rkd: false,
- print_ykd: false,
- company: "",
- Printinglist: [],
- //库位
- stockName: "",
- //库位地址
- stockaddr: "",
- Collectionoptionss: [],
- fDriverTel: "",
- fBsdate: "",
- fTruckno: "",
- allfCntqty: 0,
- allfGrossweight: 0,
- allfPlanqty: 0,
- allfNetweight: 0,
- allfQty: 0,
- fixdetaiNum: null,
- dataListSelection: [],
- dataWithdrawList: [],
- title: "",
- fCNameOptions: [],
- fDNameOptions: [],
- whgenlegTotal: 0,
- fGrossweight: 0,
- fQty: 0,
- fNetweight: 0,
- fCntqty: 0,
- activeIndex: "1",
- ifCntrnoStatus: null,
- addOrUpdateVisible: false,
- addOrUpdateVisib: false,
- approVal: false,
- approvalStatus: false,
- doNot: false,
- fCartypeOptions: [],
- fIfdamageOptions: [],
- whgenlegList: [],
- releaseList: [
- { dictLabel: "已放行", dictValue: "T" },
- { dictLabel: "未放行", dictValue: "F" },
- ],
- whgenlegVisible: false,
- whgenlegParams: {
- pageNum: 1,
- pageSize: 10,
- fCorpid: null,
- fWarehouseid: null,
- fTruckno: null,
- fCntrno: null,
- fMblno: null,
- orgStorageDate: null,
- },
- choiceWarehouse: false,
- treeselectList: {
- fWarehouselocid: null,
- },
- TreeIndex: "",
- };
- },
- created() {
- this.getDicts("data_stltype_type").then((response) => {
- this.fStltypeOptions = response.data;
- });
- this.getDicts("st_trans_type").then((response) => {
- this.businessTypeOption = response.data;
- localStorage.setItem("businessTypeList", JSON.stringify(response.data));
- });
- this.getDicts("data_unitfees").then((response) => {
- this.fFeetUnitOptions = response.data;
- });
- this.getDicts("data_trademodes").then((response) => {
- this.fTrademodeidOptions = response.data;
- });
- this.getDicts("data_ifweigh_status").then((response) => {
- this.fIfweighOptions = response.data;
- });
- this.getDicts("storage_type").then((response) => {
- this.fStorageTypeOptions = response.data;
- localStorage.setItem("fStorageTypeList", JSON.stringify(response.data));
- });
- this.getDicts("sys_car_type").then((response) => {
- this.fCartypeOptions = response.data;
- });
- this.getDicts("data_ifdamage_status").then((response) => {
- this.fIfdamageOptions = response.data;
- });
- listWarehousesss({ fStatus: 0, delFlag: 0 }).then((response) => {
- this.warehouseOptions = response.rows;
- });
- listFees({ fDc: "C" }).then((response) => {
- this.fCNameOptions = response.rows;
- });
- listFees({ fDc: "D" }).then((response) => {
- this.fDNameOptions = response.rows;
- });
- listCorps({ type: 1 }).then((response) => {
- this.fMblnoOptions = response.rows;
- });
- listCorps().then((response) => {
- this.fSbuOptions = response.rows;
- });
- listUser().then((response) => {
- this.userOptions = response.rows;
- });
- listGoods({ fStatus: 0, delFlag: 0 }).then((response) => {
- this.goodsOptions = response.rows;
- });
- listCntrs({ fStatus: "T" }).then((response) => {
- this.cntrList = response.rows;
- });
- listCorps({ fTypeid: 6 }).then((response) => {
- this.fCompanyOptIons = response.rows;
- });
- listCorps({ fTypeid: 2 }).then((response) => {
- this.fleetOptions = response.rows;
- });
- this.company = localStorage.getItem("companyName");
- this.queryUser();
- },
- filters: {
- fStorageFormat(row) {
- let name;
- for (const item of JSON.parse(localStorage.getItem("fStorageTypeList"))) {
- if (row == item.dictValue) {
- name = item.dictLabel;
- }
- }
- return name;
- },
- fBusinessTypeFormat(row) {
- let name;
- for (const item of JSON.parse(localStorage.getItem("businessTypeList"))) {
- if (row == item.dictValue) {
- name = item.dictLabel;
- }
- }
- return name;
- },
- },
- methods: {
- init() {
- this.resetForm("form");
- this.detailList = [];
- this.relevantAttachments = [];
- this.warehouseCrList = [];
- this.warehouseDrList = [];
- this.CntrTable = [];
- this.getForm();
- },
- init2() {
- this.whgenlegParams = {
- pageNum: 1,
- pageSize: 10,
- fCorpid: null,
- fWarehouseid: null,
- fTruckno: null,
- fCntrno: null,
- fMblno: null,
- orgStorageDate: null,
- };
- },
- changeStock(row) {
- let fNetweight = 0;
- let fGrossweight = 0;
- if (row.fNetweight) {
- fNetweight = row.fNetweight;
- }
- if (row.fGrossweight) {
- fGrossweight = row.fGrossweight;
- }
- if (row.fPlannetweight < fNetweight) {
- this.$message({ message: "调拨净重超出结余净重", type: "warning" });
- return false;
- }
- if (row.fPlangrossweight < fGrossweight) {
- this.$message({ message: "调拨毛重超出结余毛重", type: "warning" });
- return false;
- }
- },
- // 出库件数的计算
- qtyChange(row) {
- if (!row.fQty || row.fQty === "") {
- this.$set(row, "fNetweight", 0);
- this.$set(row, "fGrossweight", 0);
- return false;
- }
- if (row.fPlanqty < row.fQty) {
- this.$message.error("出库件数超出结余件数!");
- this.$set(row, "fQty", 0);
- this.$set(row, "fNetweight", 0);
- this.$set(row, "fGrossweight", 0);
- return false;
- }
- this.$set(
- row,
- "fNetweight",
- parseFloat(
- (Number(row.fPlannetweight) / Number(row.fPlanqty)) * Number(row.fQty)
- ).toFixed(2)
- );
- this.$set(
- row,
- "fGrossweight",
- parseFloat(
- (Number(row.fPlangrossweight) / Number(row.fPlanqty)) *
- Number(row.fQty)
- ).toFixed(2)
- );
- },
- whgenlegData() {
- if (this.dialogWhgenlegList.length === 0) {
- this.$message({ message: "未勾选信息", type: "warning" });
- return false;
- }
- let fTruckno = null;
- let fDriverTel = null;
- let fDriverName = null;
- let fDriverIdCar = null;
- if (this.form.fTruckno) {
- fTruckno = this.form.fTruckno;
- }
- if (this.form.fDriverTel) {
- fDriverTel = this.form.fDriverTel;
- }
- if (this.form.fDriverName) {
- fDriverName = this.form.fDriverName;
- }
- if (this.form.fDriverIdCar) {
- fDriverIdCar = this.form.fDriverIdCar;
- }
- this.dialogWhgenlegList.map((e) => {
- this.detailList.push({
- fBsdate: this.form.fBsdate,
- fId: null,
- fCntrtype: null,
- fGrossweight: 0,
- fNetweight: 0,
- fQty: 0,
- fCntqty: 1,
- fIsPass: "F",
- fGoodsval: null,
- fBillstatus: 10,
- fTruckno: this.form.fTruckno ? this.form.fTruckno : null,
- fDriverName: this.form.fDriverName ? this.form.fDriverName : null,
- fDriverTel: this.form.fDriverTel ? this.form.fDriverTel : null,
- fDriverIdCar: this.form.fDriverIdCar ? this.form.fDriverIdCar : null,
- fMblno: e.fMblno,
- fMarks: e.fMarks,
- fCntrno: e.fCntrno,
- fPlanqty: e.fQtyblc,
- fGoodsid: e.fGoodsid,
- fVolumn: e.fVolumn,
- fGoodsids: e.fGoodsids,
- fBillingway: e.fBillingway,
- fChargedate: e.fChargedate,
- fOrgwarehouseInformation: e.fWarehouseids,
- fPackagespecs: e.fPackagespecs,
- fPlannetweight: e.fNetweightblc,
- fOriginalbillno: e.fOriginalbillno,
- fBusinessType: e.fBusinessType.toString(),
- fPlangrossweight: e.fGrossweightblc,
- fOriginalbilldate: e.fOriginalbilldate,
- fWarehouselocid: e.fWarehouseLocationid,
- fWarehouselocids: e.fWarehouseLocationids,
- fWarehouseLocationids: e.fWarehouseLocationids,
- fTransferWarehouselocid: null,
- remark: null,
- });
- });
- this.whgenlegVisible = false;
- },
- //撤销审批
- revokeTwo() {
- let data = {
- actId: 140,
- billId: this.form.fId,
- id: this.form.fId,
- };
- RevocationApproval(data).then((data) => {
- if (data.code === 200) {
- this.browseStatus = false;
- this.msgSuccess("撤销成功");
- }
- });
- },
- // 查看审批流
- getDataList() {
- this.addOrUpdateVisible = false;
- },
- returnData() {
- this.addOrUpdateVisib = false;
- this.open = false;
- this.cancelTwo();
- },
- addOrUpdateHandle(form) {
- this.addOrUpdateVisible = true;
- this.$nextTick(() => {
- this.$refs.addOrUpdate.init(form.fId, 140);
- });
- },
- addOrUpdateHand(form) {
- this.addOrUpdateVisib = true;
- this.$nextTick(() => {
- this.$refs.ApprovalComments.init(form.fId, 110);
- });
- },
- changefStltype(row) {
- this.fMblnoOptions.map((e) => {
- if (row == e.fId) {
- this.$set(this.form, "fStltypeid", e.fStltypeid.toString());
- }
- });
- },
- changeGoods(row) {
- this.goodsOptions.map((e) => {
- if (row == e.fId) {
- if (e.ifCntrno == "1") {
- this.ifCntrnoStatus = 1;
- } else {
- this.ifCntrnoStatus = null;
- }
- }
- });
- },
- discharge() {
- if (this.Printinglist.length > 0) {
- for (let item in this.Printinglist) {
- if (this.Printinglist[item].fBillstatus === 10) {
- return this.$message.error("请先打印作业单");
- }
- if (this.Printinglist[item].fBillstatus >= 30) {
- return this.$message.error("请勿重复卸货");
- }
- }
- if (this.CntrTable.length > 0) {
- let arr = [];
- this.CntrTable.map((e) => {
- this.cntrList.map((item) => {
- if (item.fId == e.fCntrid) {
- arr.push(item.fName + "X" + e.fCntrcount);
- }
- });
- });
- arr = [...new Set(arr)];
- this.form.fCntval = arr.join(",");
- } else {
- this.form.fCntval = null;
- }
- if (this.detailList.length > 0) {
- let arr = [];
- this.detailList.map((e) => {
- this.goodsOptions.map((item) => {
- if (e.fGoodsid == item.fId) {
- arr.push(item.fName);
- }
- });
- });
- arr = [...new Set(arr)];
- this.form.fProductName = arr.join(",");
- } else {
- this.form.fProductName = "";
- }
- if (this.detailList.length > 0) {
- let arr = [];
- this.detailList.map((e) => {
- arr.push(e.fMarks);
- });
- arr = [...new Set(arr)];
- this.form.fMarks = arr.join(",");
- } else {
- this.form.fMarks = "";
- }
- if (this.detailList.length == 0) {
- this.form.fNetweight = 0;
- this.form.fPlanvolumn = 0;
- this.form.fGrossweight = 0;
- } else {
- this.form.fNetweight = this.fNetweight;
- this.form.fPlanvolumn = this.fPlanvolumn;
- this.form.fGrossweight = this.fGrossweight;
- }
- let formData = new window.FormData();
- formData.append("type", "1");
- formData.append("warehouseBills", JSON.stringify(this.form));
- formData.append("tEnclosure", JSON.stringify(this.relevantAttachments));
- formData.append(
- "warehousebillsitems",
- JSON.stringify(this.Printinglist)
- );
- formData.append(
- "warehousebillsfeesDr",
- JSON.stringify(this.warehouseDrList)
- );
- formData.append(
- "warehousebillsfeesCr",
- JSON.stringify(this.warehouseCrList)
- );
- formData.append("tCntr", JSON.stringify(this.CntrTable));
- disChargelist(formData).then((response) => {
- if ((response.code = 200)) {
- this.detailList.map((e, index) => {
- response.data.warehousebillsitems.map((item) => {
- item.fBsdate = Date.parse(new Date(item.fBsdate));
- if (item.fBusinessType) {
- item.fBusinessType = item.fBusinessType.toString();
- }
- if (e.fId == item.fId) {
- e = item;
- this.$set(this.detailList, index, e);
- }
- });
- });
- this.msgSuccess("卸货成功");
- this.$set(this.form, "fItemsStatus", 3);
- }
- });
- } else {
- this.$message.error("请选择需要卸货的明细!");
- }
- },
- creditClick() {
- console.log(this.Printinglist);
- for (let item in this.Printinglist) {
- if (!this.Printinglist[item].fId) {
- return this.$message.error("请存在未保存的数据");
- }
- if (this.Printinglist[item].fBillstatus == 10) {
- return this.$message.error("请存在未打印的作业单");
- }
- if (!this.Printinglist[item].fTruckno) {
- return this.$message.error("车号不能为空");
- }
- }
- if (this.CntrTable.length > 0) {
- let arr = [];
- this.CntrTable.map((e) => {
- this.cntrList.map((item) => {
- if (item.fId == e.fCntrid) {
- arr.push(item.fName + "X" + e.fCntrcount);
- }
- });
- });
- arr = [...new Set(arr)];
- this.form.fCntval = arr.join(",");
- } else {
- this.form.fCntval = null;
- }
- if (this.detailList.length > 0) {
- let arr = [];
- this.detailList.map((e) => {
- this.goodsOptions.map((item) => {
- if (e.fGoodsid == item.fId) {
- arr.push(item.fName);
- }
- });
- });
- arr = [...new Set(arr)];
- this.form.fProductName = arr.join(",");
- } else {
- this.form.fProductName = "";
- }
- if (this.detailList.length > 0) {
- let arr = [];
- this.detailList.map((e) => {
- arr.push(e.fMarks);
- });
- arr = [...new Set(arr)];
- this.form.fMarks = arr.join(",");
- } else {
- this.form.fMarks = "";
- }
- if (this.detailList.length == 0) {
- this.form.fNetweight = 0;
- this.form.fPlanvolumn = 0;
- this.form.fGrossweight = 0;
- } else {
- this.form.fNetweight = this.fNetweight;
- this.form.fPlanvolumn = this.fPlanvolumn;
- this.form.fGrossweight = this.fGrossweight;
- }
- let formData = new window.FormData();
- formData.append("type", "1");
- formData.append("warehouseBills", JSON.stringify(this.form));
- formData.append("warehousebillsitems", JSON.stringify(this.Printinglist));
- formData.append(
- "warehousebillsfeesDr",
- JSON.stringify(this.warehouseDrList)
- );
- formData.append(
- "warehousebillsfeesCr",
- JSON.stringify(this.warehouseCrList)
- );
- formData.append("tEnclosure", JSON.stringify(this.relevantAttachments));
- formData.append("whgenleg", JSON.stringify(this.relevantAttachments));
- formData.append("tCntr", JSON.stringify(this.CntrTable));
- addWhgenleg(formData).then((response) => {
- if ((response.code = 200)) {
- this.detailList.map((e, index) => {
- response.data.warehouseItem.map((item) => {
- item.fBsdate = Date.parse(new Date(item.fBsdate));
- if (item.fBusinessType) {
- item.fBusinessType = item.fBusinessType.toString();
- }
- if (e.fId == item.fId) {
- e = item;
- this.$set(this.detailList, index, e);
- }
- });
- });
- this.msgSuccess("调拨成功");
- this.$set(this.form, "fItemsStatus", 4);
- }
- });
- },
- getAlltree(tree) {
- this.information = tree.fWarehouseInformation;
- this.informationId = tree.id;
- },
- //树状库位下拉关闭询问
- hanDleclose(done) {
- this.$confirm("确认关闭?")
- .then((_) => {
- done();
- })
- .catch((_) => {});
- },
- getTreeselect(row) {
- this.treeselectList.fWarehouselocid = null;
- this.TreeIndex = row.$index;
- this.choiceWarehouse = true;
- treeselect(this.form.fWarehouseid).then((response) => {
- this.fWarehouseidOptions = response.data;
- });
- },
- confirm() {
- this.$set(
- this.detailList[this.TreeIndex],
- "fWarehouseInformation",
- this.information
- );
- this.$set(
- this.detailList[this.TreeIndex],
- "fTransferWarehouselocid",
- this.informationId
- );
- this.choiceWarehouse = false;
- this.detailList.fTransferWarehouselocid = this.informationId;
- },
- // 撤回入账
- withdrawClick() {
- for (let item in this.Printinglist) {
- if (!this.Printinglist[item].fId) {
- return this.$message.error("请存在未保存的数据");
- }
- if (this.Printinglist[item].fBillstatus == 10) {
- return this.$message.error("请存在未打印的作业单");
- }
- if (this.Printinglist[item].fBillstatus == 20) {
- return this.$message.error("请存在未卸货的数据");
- }
- if (this.Printinglist[item].fBillstatus == 30) {
- return this.$message.error("请存在未出库的数据");
- }
- }
- if (this.CntrTable.length > 0) {
- let arr = [];
- this.CntrTable.map((e) => {
- this.cntrList.map((item) => {
- if (item.fId == e.fCntrid) {
- arr.push(item.fName + "X" + e.fCntrcount);
- }
- });
- });
- arr = [...new Set(arr)];
- this.form.fCntval = arr.join(",");
- } else {
- this.form.fCntval = null;
- }
- if (this.detailList.length > 0) {
- let arr = [];
- this.detailList.map((e) => {
- this.goodsOptions.map((item) => {
- if (e.fGoodsid == item.fId) {
- arr.push(item.fName);
- }
- });
- });
- arr = [...new Set(arr)];
- this.form.fProductName = arr.join(",");
- } else {
- this.form.fProductName = "";
- }
- if (this.detailList.length > 0) {
- let arr = [];
- this.detailList.map((e) => {
- arr.push(e.fMarks);
- });
- arr = [...new Set(arr)];
- this.form.fMarks = arr.join(",");
- } else {
- this.form.fMarks = "";
- }
- if (this.detailList.length == 0) {
- this.form.fNetweight = 0;
- this.form.fPlanvolumn = 0;
- this.form.fGrossweight = 0;
- } else {
- this.form.fNetweight = this.fNetweight;
- this.form.fPlanvolumn = this.fPlanvolumn;
- this.form.fGrossweight = this.fGrossweight;
- }
- // 撤回入库
- let formData = new window.FormData();
- formData.append("type", "1");
- formData.append("warehouseBills", JSON.stringify(this.form));
- formData.append("warehousebillsitems", JSON.stringify(this.Printinglist));
- formData.append(
- "warehousebillsfeesDr",
- JSON.stringify(this.warehouseDrList)
- );
- formData.append(
- "warehousebillsfeesCr",
- JSON.stringify(this.warehouseCrList)
- );
- formData.append("tEnclosure", JSON.stringify(this.relevantAttachments));
- formData.append("tCntr", JSON.stringify(this.CntrTable));
- updateCredit(formData).then((response) => {
- this.Printinglist.map((e) => {
- this.detailList.map((item, index) => {
- if (e.fId == item.fId) {
- this.$set(this.detailList[index], "fBillstatus", 10);
- }
- });
- });
- this.msgSuccess("撤回成功");
- this.$set(this.form, "fItemsStatus", 1);
- });
- },
- fStorageTypeFormat(row) {
- let fStorageType;
- this.fStorageTypeOptions.map((e) => {
- if (row.fBusinessType == e.dictValue) {
- fStorageType = e.dictLabel;
- }
- });
- return fStorageType;
- },
- fCntrtypeFormat(row) {
- let fCntrtype;
- this.cntrList.map((e) => {
- if (row.fCntrtype == e.fId) {
- fCntrtype = e.fName;
- }
- });
- return fCntrtype;
- },
- goodsFormat(row) {
- let goods;
- this.goodsOptions.map((e) => {
- if (row.fGoodsid == e.fId) {
- goods = e.fName;
- }
- });
- return goods;
- },
- fBsdateFormat(row) {
- const dateMat = new Date(row.fBsdate);
- const year = dateMat.getFullYear();
- const month = dateMat.getMonth() + 1;
- const day = dateMat.getDate();
- const timeFormat = year + "-" + month + "-" + day;
- return timeFormat;
- },
- getForm() {
- getStockTransfer(this.chiId).then((response) => {
- this.form = response.data.warehousebills;
- if (this.form.fBillstatus > 2) {
- this.approvalStatus = false;
- this.browseStatus = true;
- } else {
- this.approvalStatus = true;
- this.browseStatus = false;
- }
- this.$set(this.form, "fBsdate", Date.parse(this.form.fBsdate));
- this.$set(this.form, "fBstifime", Date.parse(this.form.fBstime));
- this.$set(this.form, "createTime", Date.parse(this.form.createTime));
- this.$set(this.form, "fFeetUnit", this.form.fFeetunit);
- if (this.form.fCartype || this.form.fCartype == 0) {
- this.$set(this.form, "fCartype", this.form.fCartype.toString());
- }
- if (this.form.fStltypeid || this.form.fStltypeid == 0) {
- this.$set(this.form, "fStltypeid", this.form.fStltypeid.toString());
- }
- if (this.form.fTrademodeid) {
- this.$set(
- this.form,
- "fTrademodeid",
- this.form.fTrademodeid.toString()
- );
- }
- treeselect(this.form.fWarehouseid).then((response) => {
- this.fWarehouseidOptions = response.data;
- });
- if (!this.copyStatus) {
- if (response.data.warehouseBillsItem) {
- response.data.warehouseBillsItem.map((e) => {
- e.fBsdate = Date.parse(e.fBsdate);
- e.fBusinessType = e.fBusinessType.toString();
- });
- this.detailList = response.data.warehouseBillsItem;
- } else {
- this.detailList = [];
- }
- response.data.warehousebillsfeesCr.map((e) => {
- if (e.fFeeunitid) {
- e.fFeeUnitid = e.fFeeunitid.toString();
- }
- if (e.fStltypeid || e.fStltypeid == 0) {
- e.fStltypeid = e.fStltypeid.toString();
- }
- });
- this.warehouseCrList = response.data.warehousebillsfeesCr;
- response.data.warehousebillsfeesDr.map((e) => {
- if (e.fFeeunitid) {
- e.fFeeUnitid = e.fFeeunitid.toString();
- }
- if (e.fStltypeid || e.fStltypeid == 0) {
- e.fStltypeid = e.fStltypeid.toString();
- }
- });
- this.warehouseDrList = response.data.warehousebillsfeesDr;
- if (response.data.tCntrList) {
- this.CntrTable = response.data.tCntrList;
- } else {
- this.CntrTable = [];
- }
- if (response.data.enclosures) {
- this.relevantAttachments = response.data.enclosures;
- }
- } else {
- this.$set(this.form, "fId", null);
- this.$set(this.form, "fMblno", null);
- this.$set(this.form, "fMarks", null);
- this.$set(this.form, "fProductName", null);
- this.$set(this.form, "fNetweight", 0);
- this.$set(this.form, "fPlanvolumn", 0);
- this.$set(this.form, "fGrossweight", 0);
- }
- });
- },
- submitForm() {
- this.$refs["form"].validate((valid) => {
- if (valid) {
- if (this.detailList.length === 0) {
- return this.$message.error("请新增库存明细!");
- }
- this.updateDeduplication();
- for (let item in this.warehouseDrList) {
- if (!this.warehouseDrList[item].fCorpid) {
- if (item === "fBusinessType") {
- } else {
- this.$message.error(
- "请维护收款信息第" + (Number(item) + 1) + "行客户名称"
- );
- return false;
- }
- }
- if (!this.warehouseDrList[item].fFeeid) {
- if (item === "fBusinessType") {
- } else {
- this.$message.error(
- "请维护收款信息第" + (Number(item) + 1) + "行费用名称"
- );
- return false;
- }
- }
- if (!this.warehouseDrList[item].fFeeUnitid) {
- if (item === "fBusinessType") {
- } else {
- this.$message.error(
- "请维护收款信息第" + (Number(item) + 1) + "行计价单位"
- );
- return false;
- }
- }
- }
- for (let item in this.warehouseCrList) {
- if (!this.warehouseCrList[item].fCorpid) {
- if (item === "fBusinessType") {
- } else {
- this.$message.error(
- "请维护付款信息第" + (Number(item) + 1) + "行客户名称"
- );
- return false;
- }
- }
- if (!this.warehouseCrList[item].fFeeid) {
- if (item === "fBusinessType") {
- } else {
- this.$message.error(
- "请维护付款信息第" + (Number(item) + 1) + "行费用名称"
- );
- return false;
- }
- }
- if (!this.warehouseCrList[item].fFeeUnitid) {
- if (item === "fBusinessType") {
- } else {
- this.$message.error(
- "请维护付款信息第" + (Number(item) + 1) + "行计价单位"
- );
- return false;
- }
- }
- }
- // 附件数据
- this.form.fBillingway = this.form.fFeetUnit;
- if (this.detailList.length == 0) {
- this.form.fNetweight = 0;
- this.form.fPlanvolumn = 0;
- this.form.fGrossweight = 0;
- } else {
- this.form.fNetweight = this.fNetweight;
- this.form.fPlanvolumn = this.fPlanvolumn;
- this.form.fGrossweight = this.fGrossweight;
- }
- if (this.CntrTable.length > 0) {
- let arr = [];
- this.CntrTable.map((e) => {
- this.cntrList.map((item) => {
- if (item.fId == e.fCntrid) {
- arr.push(item.fName + "X" + e.fCntrcount);
- }
- });
- });
- arr = [...new Set(arr)];
- this.form.fCntval = arr.join(",");
- } else {
- this.form.fCntval = null;
- }
- if (this.detailList.length > 0) {
- let arr = [];
- this.detailList.map((e) => {
- this.goodsOptions.map((item) => {
- if (e.fGoodsid == item.fId) {
- arr.push(item.fName);
- }
- });
- });
- arr = [...new Set(arr)];
- this.form.fProductName = arr.join(",");
- } else {
- this.form.fProductName = "";
- }
- if (this.detailList.length > 0) {
- let arr = [];
- this.detailList.map((e) => {
- arr.push(e.fMarks);
- });
- arr = [...new Set(arr)];
- this.form.fMarks = arr.join(",");
- } else {
- this.form.fMarks = "";
- }
- let formData = new window.FormData();
- formData.append("type", "1");
- formData.append("warehouseBills", JSON.stringify(this.form));
- // 库存明细
- formData.append(
- "warehousebillsitems",
- JSON.stringify(this.detailList)
- );
- // 附件数据
- formData.append(
- "tEnclosure",
- JSON.stringify(this.relevantAttachments)
- );
- // 费用明细付款
- formData.append(
- "warehousebillsfeesCr",
- JSON.stringify(this.warehouseCrList)
- );
- // 收款
- formData.append(
- "warehousebillsfeesDr",
- JSON.stringify(this.warehouseDrList)
- );
- formData.append("mblnoStatus", JSON.stringify(this.mblnoStatus));
- formData.append("tCntr", JSON.stringify(this.CntrTable));
- warehouseSubmission(formData).then((response) => {
- if (response.code == 200) {
- this.msgSuccess("提交成功");
- setTimeout(() => {
- this.cancel();
- }, 200);
- }
- });
- }
- });
- },
- saveForm(status) {
- this.$refs["form"].validate((valid) => {
- if (valid) {
- this.updateDeduplication();
- this.form.fBillingway = this.form.fFeetUnit;
- this.form.fFeetunit = this.form.fFeetUnit;
- if (this.detailList.length == 0) {
- this.form.fNetweight = 0;
- this.form.fPlanvolumn = 0;
- this.form.fGrossweight = 0;
- } else {
- this.form.fNetweight = this.fNetweight;
- this.form.fPlanvolumn = this.fPlanvolumn;
- this.form.fGrossweight = this.fGrossweight;
- }
- // 附件数据
- this.form.fQty = this.fQty;
- if (this.CntrTable.length > 0) {
- let arr = [];
- this.CntrTable.map((e) => {
- this.cntrList.map((item) => {
- if (item.fId == e.fCntrid) {
- arr.push(item.fName + "X" + e.fCntrcount);
- }
- });
- });
- arr = [...new Set(arr)];
- this.form.fCntval = arr.join(",");
- } else {
- this.form.fCntval = null;
- }
- if (this.detailList.length > 0) {
- let arr = [];
- this.detailList.map((e) => {
- this.goodsOptions.map((item) => {
- if (e.fGoodsid == item.fId) {
- arr.push(item.fName);
- }
- });
- });
- arr = [...new Set(arr)];
- this.form.fProductName = arr.join(",");
- } else {
- this.form.fProductName = "";
- }
- if (this.detailList.length > 0) {
- let arr = [];
- this.detailList.map((e) => {
- arr.push(e.fMarks);
- });
- arr = [...new Set(arr)];
- this.form.fMarks = arr.join(",");
- } else {
- this.form.fMarks = "";
- }
- this.form.fBillstatus = 2;
- let formData = new window.FormData();
- formData.append("type", "1");
- formData.append("warehouseBills", JSON.stringify(this.form));
- // 库存明细
- formData.append(
- "warehousebillsitems",
- JSON.stringify(this.detailList)
- );
- // 附件数据
- formData.append(
- "tEnclosure",
- JSON.stringify(this.relevantAttachments)
- );
- // 费用明细付款
- formData.append(
- "warehousebillsfeesCr",
- JSON.stringify(this.warehouseCrList)
- );
- // 收款
- formData.append(
- "warehousebillsfeesDr",
- JSON.stringify(this.warehouseDrList)
- );
- formData.append("mblnoStatus", JSON.stringify(this.mblnoStatus));
- formData.append("tCntr", JSON.stringify(this.CntrTable));
- addStockTransfer(formData).then((response) => {
- if (response.data == false) {
- this.$confirm(response.msg, "提示", {
- confirmButtonText: "确定",
- cancelButtonText: "取消",
- type: "warning",
- })
- .then(() => {
- this.mblnoStatus = true;
- this.saveForm();
- })
- .catch(() => {
- this.$message({
- type: "info",
- message: "已取消",
- });
- });
- } else {
- if ((response.code = 200)) {
- this.mblnoStatus = "";
- this.form = response.data.warehouseBills;
- this.$set(this.form, "fBsdate", Date.parse(this.form.fBsdate));
- this.$set(this.form, "fBstime", Date.parse(this.form.fBstime));
- this.$set(
- this.form,
- "createTime",
- Date.parse(this.form.createTime)
- );
- if (this.form.fStltypeid || this.form.fStltypeid == 0) {
- this.$set(
- this.form,
- "fStltypeid",
- this.form.fStltypeid.toString()
- );
- }
- this.$set(this.form, "fFeetUnit", this.form.fFeetunit);
- if (this.form.fCartype || this.form.fCartype == 0) {
- this.$set(
- this.form,
- "fCartype",
- this.form.fCartype.toString()
- );
- }
- if (this.form.fTrademodeid) {
- this.$set(
- this.form,
- "fTrademodeid",
- this.form.fTrademodeid.toString()
- );
- }
- response.data.warehousebillsitems.map((e) => {
- e.fBsdate = Date.parse(e.fBsdate);
- e.fBusinessType = e.fBusinessType.toString();
- });
- this.detailList = response.data.warehousebillsitems;
- this.msgSuccess("保存成功");
- if (status == "goBack") {
- this.cancel();
- }
- }
- }
- });
- }
- });
- },
- // 库存明细多选
- Selectinventory(selection) {
- this.Printinglist = selection;
- //允许确认入库list
- this.dataListSelection = [];
- this.dataListSelection = selection.filter((e) => e.fBillstatus == 30);
- //允许撤销入库list
- this.dataWithdrawList = [];
- this.dataWithdrawList = selection.filter((e) => e.fBillstatus == 40);
- },
- // 合计
- getSummaries(param) {
- const { columns, data } = param;
- const sums = [];
- var values = [];
- columns.forEach((column, index) => {
- if (index === 0) {
- sums[index] = "";
- return;
- }
- if (column.property === "fGrossweight") {
- values = data.map((item) => Number(item["fGrossweight"]));
- }
- if (column.property === "fNetweight") {
- values = data.map((item) => Number(item["fNetweight"]));
- }
- if (column.property === "fQty") {
- values = data.map((item) => Number(item["fQty"]));
- }
- if (column.property === "fCntqty") {
- values = data.map((item) => Number(item["fCntqty"]));
- }
- if (
- column.property === "fGrossweight" ||
- column.property === "fNetweight" ||
- column.property === "fQty" ||
- column.property === "fCntqty"
- ) {
- sums[index] = values.reduce((prev, curr) => {
- const value = Number(curr);
- if (!isNaN(value)) {
- if (column.property === "fGrossweight") {
- this.fGrossweight = prev + curr;
- }
- if (column.property === "fNetweight") {
- this.fNetweight = prev + curr;
- }
- if (column.property === "fQty") {
- this.fQty = prev + curr;
- this.sumMum = prev + curr;
- }
- if (column.property === "fCntqty") {
- this.fCntqty = prev + curr;
- }
- return prev + curr;
- } else {
- return prev;
- }
- }, 0);
- sums[index] = sums[index].toFixed(2);
- }
- });
- this.sums = sums;
- return sums;
- },
- // 付款合计
- warehouseDrSummaries(param) {
- const { columns, data } = param;
- const sums = [];
- columns.forEach((column, index) => {
- if (index === 0) {
- sums[index] = "合计";
- return;
- }
- const values = data.map((item) => Number(item[column.property]));
- if (
- column.property === "fUnitprice" ||
- column.property === "fAmount" ||
- column.property === "fQty" ||
- column.property === "fQty"
- ) {
- sums[index] = values.reduce((prev, curr) => {
- const value = Number(curr);
- if (!isNaN(value)) {
- return prev + curr;
- } else {
- return prev;
- }
- }, 0);
- sums[index] = sums[index].toFixed(2);
- }
- });
- return sums;
- },
- // 库存总账多选框
- whgenlegSelectionChange(selection) {
- this.dialogWhgenlegList = selection;
- },
- handleSelect(key) {
- if (!this.form.fCorpid) {
- this.$message({
- message: "请维护客户",
- type: "warning",
- });
- } else if (this.form.fProductName == undefined) {
- this.$message({
- message: "请维护入库明细品名",
- type: "warning",
- });
- } else {
- this.dialogWhgenlegList = [];
- this.whgenlegTotal = 0;
- this.warehousingagreements = true;
- this.getWhgenlegList(key);
- }
- },
- // 查询作业费信息
- getWhgenlegList(key) {
- let data = {};
- if (key == 2) {
- this.key_id = key;
- this.Navigation = true;
- data = {
- pageNum: 1,
- pageSize: 10,
- fTaskType: key,
- fLabour: this.form.fLabour,
- };
- } else if (key == 1) {
- this.key_id = key;
- this.Navigation = true;
- data = {
- pageNum: 1,
- pageSize: 10,
- fTaskType: key,
- fFleet: this.form.fFleet,
- };
- } else {
- this.Navigation = false;
- this.key_id = key;
- data = {
- pageNum: 1,
- pageSize: 10,
- fCorpid: this.form.fCorpid,
- };
- }
- operationAgreement(data).then((response) => {
- response.rows.map((e) => {
- if (e.fFeeUnitid) {
- e.fFeeUnitid = e.fFeeUnitid.toString();
- }
- });
- this.tasklegList = response.rows;
- this.whgenlegTotal = response.total;
- });
- },
- // 入库明细新增list
- addRelevant() {
- this.$refs["form"].validate((valid) => {
- if (valid) {
- this.whgenlegList = [];
- this.dialogWhgenlegList = [];
- this.whgenlegTotal = 0;
- this.whgenlegVisible = true;
- this.getWhgenlegList();
- }
- });
- },
- // 查询库存总账信息
- getWhgenlegList() {
- this.whgenlegParams.fMblno = this.form.fMblno;
- this.whgenlegParams.fCorpid = this.form.fCorpid;
- this.whgenlegParams.fTrademodeid = this.form.fTrademodeid;
- this.whgenlegParams.fWarehouseid = this.form.fInwarehouseid;
- listWhgenleg(this.whgenlegParams).then((response) => {
- this.whgenlegList = response.rows;
- this.whgenlegTotal = response.total;
- });
- },
- printZyd() {
- if (this.Printinglist.length > 0) {
- for (let item in this.Printinglist) {
- if (!this.Printinglist[item].fId) {
- return this.$message.error("请先保存!");
- }
- if (
- this.Printinglist[item].fTruckno !== this.Printinglist[0].fTruckno
- ) {
- return this.$message.error("请选择车相同车号");
- }
- }
- this.print_zyd = true;
- this.warehouseOptions.map((e) => {
- if (e.fId == this.form.fWarehouseid) {
- this.stockaddr = e.fAddr;
- }
- });
- this.fDriverTel = this.Printinglist[0].fDriverTel;
- } else {
- this.$message.error("请选择需要打印的明细!");
- }
- },
- handleCommand(command) {
- if (this.Printinglist.length > 0) {
- this.$refs["form"].validate((valid) => {
- if (valid) {
- for (let corp in this.fMblnoOptions) {
- if (this.form.fCorpid === this.fMblnoOptions[corp].fId) {
- this.$set(
- this.form,
- "fCorpidName",
- this.fMblnoOptions[corp].fName
- );
- }
- }
- this.warehouseOptions.map((e) => {
- if (e.fId == this.form.fWarehouseid) {
- this.stockName = e.fName;
- this.stockaddr = e.fAddr;
- }
- });
- this.fDriverTel = this.Printinglist[0].fDriverTel;
- this.fBsdate = this.Printinglist[0].fBsdate;
- this.fTruckno = this.Printinglist[0].fTruckno;
- this.allfCntqty = 0;
- this.allfGrossweight = 0;
- this.allfPlanqty = 0;
- this.allfNetweight = 0;
- this.allfQty = 0;
- this.Printinglist.map((e) => {
- if (e.fCntqty) {
- this.allfCntqty += e.fCntqty;
- }
- if (e.fGrossweight) {
- this.allfGrossweight += e.fGrossweight;
- }
- if (e.fPlanqty) {
- this.allfPlanqty += e.fPlanqty;
- }
- if (e.fNetweight) {
- this.allfNetweight += e.fNetweight;
- }
- if (e.fQty) {
- this.allfQty += e.fQty;
- }
- });
- if (command == "a") {
- this.print_shd = true;
- } else if (command == "b") {
- this.print_rkd = true;
- } else if (command == "c") {
- this.print_ykd = true;
- }
- }
- });
- } else {
- this.$message.error("请选择需要打印的明细!");
- }
- },
- //计算仓储费日期变更
- changeDate() {
- this.$set(this.form, "fChargedate", this.form.fBsdate);
- },
- addRow() {
- var obj = {};
- this.CntrTable.push(obj);
- },
- deleteRow(index, rows) {
- rows.splice(index, 1);
- },
- wDeleteRow(index, rows) {
- rows.splice(index, 1);
- this.sumMum = 0;
- this.detailList.map((e) => {
- if (e.fQty) {
- this.sumMum += e.fQty;
- }
- });
- if (this.detailList.length == 0) {
- this.form.fProductName = "";
- this.form.fMarks = "";
- this.form.fNetweight = 0;
- this.form.fPlanvolumn = 0;
- this.form.fGrossweight = 0;
- }
- },
- // 新增附件上传
- addRelevt() {
- this.relevantAttachments.push({
- fUrl: null,
- fName: null,
- createBy: this.form.createBy,
- createTime: Date.parse(new Date()),
- });
- },
- // 收款信息新行
- addCollection() {
- this.$refs["form"].validate((valid) => {
- if (valid) {
- if (this.form.fBusinessType == null) {
- this.$message.error("请维护作业类型");
- return false;
- } else {
- this.warehouseDrList.push({
- fCorpid: null,
- fFeeid: null,
- fFeeUnitid: "",
- fQty: null,
- fUnitprice: null,
- fAmount: null,
- fCurrency: "RMB",
- fExrate: "1",
- fTaxrate: this.fTaxrate,
- fCxrate: null,
- fRate: null,
- remarks: null,
- fMblno: this.form.fMblno,
- fProductName: this.form.fProductName,
- fMarks: this.form.fMarks,
- fBusinessType: this.form.fBusinessType,
- fSrcTypeId: 0,
- });
- this.fWbuOptions = [];
- let queryParams = { pageNum: 1, fDc: "D" };
- listFees(queryParams).then((response) => {
- this.fDNameOptions = response.rows;
- });
- }
- }
- });
- },
- //付款信息新行
- addpayment() {
- this.$refs["form"].validate((valid) => {
- if (valid) {
- if (this.form.fBusinessType == null) {
- return this.$message.error("请维护作业类型");
- } else {
- this.warehouseCrList.push({
- fCorpid: null,
- fFeeid: null,
- fFeeUnitid: "",
- fQty: null,
- fUnitprice: null,
- fAmount: null,
- fCurrency: "RMB",
- fExrate: "1",
- fTaxrate: this.fTaxrate,
- fCxrate: null,
- fRate: null,
- remarks: null,
- fMblno: this.form.fMblno,
- fProductName: this.form.fProductName,
- fMarks: this.form.fMarks,
- fBusinessType: this.form.fBusinessType,
- fSrcTypeId: 0,
- });
- this.fWbuOptions = [];
- let queryParams = { pageNum: 1, fDc: "C" };
- listFees(queryParams).then((response) => {
- this.fCNameOptions = response.rows;
- });
- }
- }
- });
- },
- //导入收付款信息明细
- zhgenlegData() {
- if (this.dialogWhgenlegList.length === 0) {
- this.$message({
- message: "请选择需要导入的数据",
- type: "warning",
- });
- } else {
- this.dialogWhgenlegList.map((e) => {
- let qty = 1;
- if (e.fFeeUnitid == 1) {
- qty = this.fQty;
- } else if (e.fFeeUnitid == 2) {
- qty = (this.fGrossweight / 1000).toFixed(2);
- } else if (e.fFeeUnitid == 3) {
- qty = (this.fNetweight / 1000).toFixed(2);
- } else if (e.fFeeUnitid == 7) {
- qty = this.fCntqty;
- }
- let fAmount = 0;
- fAmount = e.fPrice * qty;
- console.log(this.key_id);
- if (this.key_id == 3) {
- this.warehouseDrList.push({
- fQty: qty,
- fCorpid: e.fCorpid,
- fFeeid: e.feeFId,
- fFeeUnitid: e.fFeeUnitid,
- fUnitprice: e.fPrice,
- fCurrency: "RMB",
- fExrate: 1,
- fAmount: fAmount,
- fTaxrate: this.fTaxrate,
- fMblno: this.form.fMblno,
- fProductName: this.form.fProductName,
- fMarks: this.form.fMarks,
- fBusinessType: this.form.fBusinessType,
- fSrcTypeId: e.fId,
- });
- } else {
- this.warehouseCrList.push({
- fQty: qty,
- fCorpid: e.fCorpid,
- fFeeid: e.feeId,
- fFeeUnitid: e.fFeeUnitid,
- fUnitprice: e.fPrice,
- fCurrency: "RMB",
- fExrate: 1,
- fAmount: fAmount,
- fTaxrate: this.fTaxrate,
- fMblno: this.form.fMblno,
- fProductName: this.form.fProductName,
- fMarks: this.form.fMarks,
- fBusinessType: this.form.fBusinessType,
- fSrcTypeId: e.fId,
- });
- }
- });
- this.warehousingagreements = false;
- }
- },
- // 收款选
- Collectionoptions(selection) {
- this.Collectionoptionss = selection;
- for (let item in this.fWbuOptions) {
- for (let li in this.Collectionoptionss) {
- if (
- this.fWbuOptions[item].fId === this.Collectionoptionss[li].fFeeid
- ) {
- this.$set(
- this.Collectionoptionss[li],
- "fFeeids",
- this.fWbuOptions[item].fName
- );
- }
- }
- }
- },
- //附件上传
- handleSucces(scope, res, file) {
- this.relevantAttachments[scope.$index].fName = res.fileName;
- this.relevantAttachments[scope.$index].fUrl = res.url;
- if (this.relevantAttachments[scope.$index].fUrl === "") {
- this.$message.error("上传失败");
- } else {
- this.$message.success("上传成功");
- }
- },
- //获取登陆人
- queryUser() {
- queryUserVal().then((response) => {
- if (response.user !== null) {
- this.userVal = response.user;
- this.$set(this.form, "fDeptid", this.userVal.deptId);
- this.$set(this.form, "createBy", this.userVal.userName);
- this.$set(this.form, "fStorekeeper", this.userVal.nickName);
- this.$set(this.form, "fIfdamage", "1");
- this.$set(this.form, "fIfweigh", "1");
- this.$set(this.form, "fTrademodeid", "1");
- this.$set(this.form, "createTime", Date.parse(new Date()));
- this.$set(this.form, "fBstime", Date.parse(new Date()));
- }
- if (response.dept !== null) {
- this.deptOptions = [];
- this.deptOptions.push(response.dept);
- }
- });
- },
- //作业类型校验
- educationChange() {
- if (this.form.fBusinessType === "1" || this.form.fBusinessType === "2") {
- this.isrequired = 1;
- this.isrequired2 = 2;
- } else if (
- this.form.fBusinessType === "3" ||
- this.form.fBusinessType === "4"
- ) {
- this.isrequired2 = 1;
- this.isrequired = 2;
- } else {
- this.isrequired = 2;
- this.isrequired2 = 2;
- }
- },
- // 数量计算
- changeContractAmt(row) {
- let fQty = 0;
- let fUnitprice = 0;
- if (row.fUnitprice) {
- fUnitprice = row.fUnitprice;
- }
- if (row.fQty) {
- fQty = row.fQty;
- }
- this.$set(row, "fAmount", Number(fUnitprice) * Number(fQty)).toFixed(2);
- },
- // 变更计价单位
- changeFeeUnit(row) {
- if (!row.fFeeUnitid) {
- return false;
- }
- if (row.fFeeUnitid === "2") {
- this.$set(row, "fQty", (this.fGrossweight / 1000).toFixed(2));
- } else if (row.fFeeUnitid === "1") {
- this.$set(row, "fQty", this.fQty.toFixed(2));
- } else if (row.fFeeUnitid === "3") {
- this.$set(row, "fQty", (this.fNetweight / 1000).toFixed(2));
- } else if (row.fFeeUnitid === "7") {
- this.$set(row, "fQty", this.fCntqty);
- } else {
- this.$set(row, "fQty", 0);
- }
- if (row.fUnitprice) {
- this.$set(
- row,
- "fAmount",
- parseFloat(Number(row.fUnitprice) * Number(row.fQty)).toFixed(2)
- );
- }
- },
- updateDeduplication() {
- if (this.detailList.length) {
- let fMarks = [];
- let fProductName = [];
- let fMblno = [];
- this.detailList.map((e) => {
- if (e.fMarks) {
- fMarks.push(e.fMarks);
- }
- if (e.fGoodsids) {
- fProductName.push(e.fGoodsids);
- }
- if (e.fMblno) {
- fMblno.push(e.fMblno);
- }
- });
- this.$set(this.form, "fMarks", [...new Set(fMarks)].join(","));
- this.$set(
- this.form,
- "fProductName",
- [...new Set(fProductName)].join(",")
- );
- fMblno = [...new Set(fMblno)];
- if (fMblno.length <= 2) {
- this.$set(this.form, "fMblno", [...new Set(fMblno)].join(","));
- } else {
- this.$set(this.form, "fMblno", fMblno[0] + "," + fMblno[1] + "…");
- }
- }
- },
- //打印
- addprint(status) {
- if (status == "zyd") {
- if (this.CntrTable.length > 0) {
- let arr = [];
- this.CntrTable.map((e) => {
- this.cntrList.map((item) => {
- if (item.fId == e.fCntrid) {
- arr.push(item.fName + "X" + e.fCntrcount);
- }
- });
- });
- arr = [...new Set(arr)];
- this.form.fCntval = arr.join(",");
- } else {
- this.form.fCntval = null;
- }
- if (this.detailList.length > 0) {
- let arr = [];
- this.detailList.map((e) => {
- this.goodsOptions.map((item) => {
- if (e.fGoodsid == item.fId) {
- arr.push(item.fName);
- }
- });
- });
- arr = [...new Set(arr)];
- this.form.fProductName = arr.join(",");
- } else {
- this.form.fProductName = "";
- }
- if (this.detailList.length > 0) {
- let arr = [];
- this.detailList.map((e) => {
- arr.push(e.fMarks);
- });
- arr = [...new Set(arr)];
- this.form.fMarks = arr.join(",");
- } else {
- this.form.fMarks = "";
- }
- this.form.fBillingway = this.form.fFeetUnit;
- if (this.detailList.length == 0) {
- this.form.fNetweight = 0;
- this.form.fPlanvolumn = 0;
- this.form.fGrossweight = 0;
- } else {
- this.form.fNetweight = this.fNetweight;
- this.form.fPlanvolumn = this.fPlanvolumn;
- this.form.fGrossweight = this.fGrossweight;
- }
- let formData = new window.FormData();
- formData.append("type", "1");
- formData.append("warehouseBills", JSON.stringify(this.form));
- formData.append(
- "warehousebillsitems",
- JSON.stringify(this.Printinglist)
- );
- formData.append(
- "warehousebillsfeesDr",
- JSON.stringify(this.warehouseDrList)
- );
- formData.append(
- "warehousebillsfeesCr",
- JSON.stringify(this.warehouseCrList)
- );
- formData.append("tEnclosure", JSON.stringify(this.relevantAttachments));
- formData.append("tCntr", JSON.stringify(this.CntrTable));
- addJoblist(formData).then((response) => {
- if (response.code == 200) {
- this.detailList.map((e, index) => {
- response.data.warehousebillsitems.map((item) => {
- item.fBsdate = Date.parse(new Date(item.fBsdate));
- if (item.fBusinessType) {
- item.fBusinessType = item.fBusinessType.toString();
- }
- if (e.fId == item.fId) {
- this.$set(this.detailList, index, item);
- }
- });
- });
- this.$set(this.form, "fItemsStatus", 2);
- }
- });
- }
- const style =
- "@page { } " +
- "@media print { .print-div{ padding:8px;background-color:#cccccc;} .print-title{display:flex;justify-content: center;font-size:24px} .print_form{font-size:12px} .print_table table {border-right: 1px solid #000;border-bottom: 1px solid #000;font-size:12px} .print_table table td {border-left: 1px solid #000;border-top: 1px solid #000;padding:2px;vertical-align:middle;text-align: center;}";
- print({
- printable: "print_area1",
- type: "html",
- style: style, // 亦可使用引入的外部css;
- scanStyles: false,
- });
- },
- cancel() {
- this.resetForm("form");
- this.detailList = [];
- this.relevantAttachments = [];
- this.warehouseCrList = [];
- this.warehouseDrList = [];
- this.CntrTable = [];
- this.$emit("changeShow", "true");
- },
- goBack() {
- this.$confirm("是否确定返回列表?", "提示", {
- confirmButtonText: "保存",
- cancelButtonText: "取消",
- type: "warning",
- })
- .then(() => {
- this.saveForm("goBack");
- })
- .catch(() => {
- this.cancel();
- });
- },
- },
- watch: {
- // 监听 addOrUpdateVisible 改变
- addOrUpdateVisible(oldVal, newVal) {
- this.showDialog = this.addOrUpdateVisible;
- },
- },
- };
- </script>
- <style lang="scss" scoped>
- .tag-hover:hover {
- background-color: #d9ebfb;
- }
- .tag-hover {
- border-top-left-radius: 0;
- border-bottom-left-radius: 0;
- height: 15px;
- padding: 0px 1px;
- line-height: 12px;
- }
- .print-div {
- color: #000;
- }
- .print_table {
- table {
- border-right: 1px solid #000;
- border-bottom: 1px solid #000;
- font-size: 12px;
- margin-bottom: 5px;
- }
- table td {
- border-left: 1px solid #000;
- border-top: 1px solid #000;
- vertical-align: middle;
- padding: 2px;
- text-align: center;
- }
- }
- .print_form {
- font-size: 12px;
- }
- </style>
|