12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917 |
- <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%"
- :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="fTocorpid">
- <el-select
- v-model="form.fTocorpid"
- 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="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="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 prop="fChargedate" label="仓储费计算日期">
- <el-date-picker
- v-model="form.fChargedate"
- type="date"
- style="width: 80%"
- value-format="timestamp"
- :disabled="browseStatus"
- placeholder="仓储费计算日期"
- >
- </el-date-picker>
- </el-form-item>
- </el-col>
- <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-row>
- <el-row>
- <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="fFeetUnit">
- <el-select
- v-model="form.fFeetUnit"
- placeholder="请选择计费单位"
- clearable
- :disabled="browseStatus"
- style="width: 80%"
- >
- <el-option
- v-for="(item, index) in fFeetUnitOptions"
- :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="fTrademodeid">
- <el-select
- v-model="form.fTrademodeid"
- placeholder="请选择贸易方式"
- :disabled="browseStatus"
- clearable
- style="width: 80%"
- >
- <el-option
- v-for="(item, index) in fTrademodeidOptions"
- :key="index.dictValue"
- :label="item.dictLabel"
- :value="item.dictValue"
- />
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <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-col :span="8">
- <el-form-item label="原始入库单号" prop="fOriginalbillno">
- <el-input
- v-model="form.fOriginalbillno"
- style="width: 80%"
- placeholder="原始入库单号"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="原始入库日期" prop="orgStorageDate">
- <el-date-picker
- v-model="form.orgStorageDate"
- type="daterange"
- value-format="yyyy-MM-dd"
- range-separator="至"
- style="width: 80%"
- start-placeholder="开始日期"
- end-placeholder="结束日期"
- >
- </el-date-picker>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <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-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="制单人" prop="createBy">
- <el-input
- disabled
- v-model="form.createBy"
- style="width: 80%"
- placeholder="制单人"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <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>
- </el-form>
- <el-dialog
- title="自定义列显示"
- :visible.sync="showSetting"
- width="700px"
- v-dialogDrag
- :close-on-click-modal="false"
- >
- <template slot="title">
- <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>
- <div>配置排序列数据(拖动调整顺序)</div>
- <div style="margin-left: 17px">
- <el-checkbox
- v-model="allCheck"
- label="全选"
- @change="allChecked"
- ></el-checkbox>
- </div>
- <div style="padding: 4px; display: flex; justify-content: center">
- <draggable
- v-model="setRowList"
- group="site"
- animation="300"
- @start="onStart"
- @end="onEnd"
- handle=".indraggable"
- >
- <transition-group>
- <div
- v-for="item in setRowList"
- :key="item.surface"
- class="listStyle"
- >
- <div style="width: 500px" class="indraggable">
- <div class="progress" :style="{ width: item.width + 'px' }">
- <el-checkbox
- :label="item.name"
- v-model="item.checked"
- :true-label="0"
- :false-label="1"
- >{{ item.name }}
- </el-checkbox>
- </div>
- </div>
- <el-input-number
- v-model.number="item.width"
- controls-position="right"
- :min="1"
- :max="500"
- size="mini"
- ></el-input-number>
- </div>
- </transition-group>
- </draggable>
- </div>
- <span slot="footer" class="dialog-footer">
- <el-button @click="showSetting = false">取 消</el-button>
- <el-button @click="delRow" type="danger">重 置</el-button>
- <el-button type="primary" @click="save()">确 定</el-button>
- </span>
- </el-dialog>
- <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"
- :disabled="dataListSelection.length <= 0 || browseStatus"
- @click="creditClick"
- >货转确认
- </el-button>
- <el-button
- size="small"
- :disabled="dataWithdrawList.length <= 0 || browseStatus"
- @click.prevent="withdrawClick"
- >撤回货转
- </el-button>
- <div style="margin: 0 10px">
- <el-button
- icon="el-icon-setting"
- size="mini"
- circle
- @click="showSetting = !showSetting"
- ></el-button>
- </div>
- </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
- v-for="(item, index) in getRowList"
- :key="index"
- :label="item.name"
- :width="item.width"
- :prop="item.label"
- align="center"
- :fixed="item.fixed"
- sortable
- >
- <template slot-scope="scope">
- <span v-if="item.label == 'fBillstatus'">
- <span v-if="scope.row.fBillstatus === 6">货转</span>
- <span v-else>录入</span>
- </span>
- <span v-else-if="item.label == 'fBsdate'">
- <el-date-picker
- v-model="scope.row.fBsdate"
- style="width: 138px"
- :disabled="browseStatus || scope.row.fBillstatus == 6"
- type="date"
- value-format="timestamp"
- placeholder="货转日期"
- >
- </el-date-picker>
- </span>
- <span v-else-if="item.label == 'fBusinessType'">
- <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>
- </span>
- <span v-else-if="item.label == 'fQty'">
- <el-input
- @change="qtyChange(scope.row)"
- v-model="scope.row.fQty"
- :disabled="browseStatus || scope.row.fBillstatus == 6"
- placeholder="货转件数"
- />
- </span>
- <span v-else-if="item.label == 'fGrossweight'">
- <el-input
- :disabled="browseStatus || scope.row.fBillstatus == 6"
- v-model="scope.row.fGrossweight"
- @change="changeOutStock(scope.row)"
- placeholder="货转毛重"
- />
- </span>
- <span v-else-if="item.label == 'fNetweight'">
- <el-input
- v-model="scope.row.fNetweight"
- :disabled="browseStatus || scope.row.fBillstatus == 6"
- @change="changeOutStock(scope.row)"
- placeholder="货转净重"
- />
- </span>
- <span v-else-if="item.label == 'fCntqty'">
- <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 == 6"
- />
- </span>
- <span v-else-if="item.label == 'fPackagespecs'">
- <el-input
- v-model="scope.row.fPackagespecs"
- :disabled="browseStatus || scope.row.fBillstatus == 6"
- placeholder="包装规格"
- />
- </span>
- <span v-else-if="item.label == 'fGoodsval'">
- <el-input
- v-model="scope.row.fGoodsval"
- placeholder="货值"
- :disabled="browseStatus || scope.row.fBillstatus == 6"
- />
- </span>
- <span v-else-if="item.label == 'fLntype'">
- <el-select
- v-model="scope.row.fLntype"
- placeholder="装卸方式"
- :disabled="browseStatus || scope.row.fBillstatus == 6"
- style="width: 80%"
- >
- <el-option
- v-for="(item, index) in unloadModes"
- :key="index.dictValue"
- :label="item.dictLabel"
- :value="item.dictValue"
- />
- </el-select>
- </span>
- <span v-else-if="item.label == 'fForkliftman'">
- <el-input
- v-model="scope.row.fForkliftman"
- placeholder="叉车工"
- :disabled="browseStatus || scope.row.fBillstatus == 6"
- />
- </span>
- <span v-else-if="item.label == 'fStevedore'">
- <el-input
- v-model="scope.row.fStevedore"
- placeholder="装卸工"
- :disabled="browseStatus || scope.row.fBillstatus == 6"
- />
- </span>
- <span v-else-if="item.label == 'fLocalcntrno'">
- <el-input
- v-model="scope.row.fLocalcntrno"
- placeholder="库内箱号"
- :disabled="browseStatus || scope.row.fBillstatus == 6"
- v-Alphabet
- />
- </span>
- <span v-else-if="item.label == 'fSealno'">
- <el-input
- v-model="scope.row.fSealno"
- placeholder="封号"
- :disabled="browseStatus || scope.row.fBillstatus == 6"
- />
- </span>
- <span v-else-if="item.label == 'remark'">
- <el-input
- v-model="scope.row.remark"
- placeholder="备注"
- :disabled="browseStatus || scope.row.fBillstatus == 6"
- />
- </span>
- <span v-else>{{ scope.row[item.label] }}</span>
- </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 == 6"
- 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>
- <up-load
- :relevantAttachments="relevantAttachments"
- :createBy="form.createBy"
- :browseStatus="browseStatus"
- ></up-load>
- </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
- type="primary"
- size="small"
- :disabled="browseStatus"
- @click="saveForm"
- >保 存</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="50" align="center" fixed />
- <el-table-column
- label="序号"
- type="index"
- width="50"
- fixed
- align="center"
- />
- <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 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"
- 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="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="
- deleteRow(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="85%"
- @close="init2()"
- v-dialogDrag
- :close-on-click-modal="false"
- >
- <el-dialog
- title="自定义列显示"
- :visible.sync="showSetting2"
- width="700px"
- v-dialogDrag
- append-to-body
- :close-on-click-modal="false"
- >
- <template slot="title">
- <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>
- <div>配置排序列数据(拖动调整顺序)</div>
- <div style="margin-left: 17px">
- <el-checkbox
- v-model="allCheck2"
- label="全选"
- @change="allChecked2"
- ></el-checkbox>
- </div>
- <div style="padding: 4px; display: flex; justify-content: center">
- <draggable
- v-model="setRowList2"
- group="site"
- animation="300"
- @start="onStart"
- @end="onEnd"
- handle=".indraggable"
- >
- <transition-group>
- <div
- v-for="item in setRowList2"
- :key="item.surface"
- class="listStyle"
- >
- <div style="width: 500px" class="indraggable">
- <div class="progress" :style="{ width: item.width + 'px' }">
- <el-checkbox
- :label="item.name"
- v-model="item.checked"
- :true-label="0"
- :false-label="1"
- >{{ item.name }}
- </el-checkbox>
- </div>
- </div>
- <el-input-number
- v-model.number="item.width"
- controls-position="right"
- :min="1"
- :max="500"
- size="mini"
- ></el-input-number>
- </div>
- </transition-group>
- </draggable>
- </div>
- <span slot="footer" class="dialog-footer">
- <el-button @click="showSetting2 = false">取 消</el-button>
- <el-button @click="delRow2" type="danger">重 置</el-button>
- <el-button type="primary" @click="save2()">确 定</el-button>
- </span>
- </el-dialog>
- <el-form ref="whgenlegParams" :model="whgenlegParams">
- <el-row>
- <el-col :span="5">
- <el-form-item label="提单号" prop="fMblno" label-width="70px">
- <el-input
- v-model="whgenlegParams.fMblno"
- placeholder="请输入提单号"
- clearable
- />
- </el-form-item>
- </el-col>
- <el-col :span="5">
- <el-form-item label="箱号" prop="fCntrno" label-width="70px">
- <el-input
- v-model="whgenlegParams.fCntrno"
- placeholder="请输入箱号"
- clearable
- />
- </el-form-item>
- </el-col>
- <el-col :span="10">
- <el-form-item
- label="入库日期区间"
- prop="orgStorageDate"
- label-width="120px"
- >
- <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="getDetailsList()"
- >搜索</el-button
- >
- </el-col>
- <el-col :span="2" style="display: flex; justify-content: flex-end">
- <el-button
- icon="el-icon-setting"
- circle
- @click="showSetting2 = !showSetting2"
- ></el-button>
- </el-col>
- </el-row>
- </el-form>
- <el-table
- :data="whgenlegList"
- ref="table"
- tooltip-effect="dark"
- width="100%"
- stripe
- @selection-change="whgenlegSelectionChange"
- >
- <el-table-column type="selection" width="50"> </el-table-column>
- <el-table-column
- v-for="(item, index) in getRowList2"
- :key="index"
- :label="item.name"
- :width="item.width"
- :prop="item.label"
- align="center"
- :fixed="item.fixed"
- sortable
- >
- <template slot-scope="scope">
- <span v-if="item.label == 'fQtyblc2'">
- <el-input
- @change="qtyChange(scope.row)"
- v-model="scope.row.fQtyblc2"
- placeholder="件数"
- />
- </span>
- <span v-else-if="item.label == 'fGrossweightblc2'">
- <el-input
- v-model="scope.row.fGrossweightblc2"
- @change="changeOutStock(scope.row)"
- placeholder="毛重"
- />
- </span>
- <span v-else-if="item.label == 'fNetweightblc2'">
- <el-input
- v-model="scope.row.fNetweightblc2"
- @change="changeOutStock(scope.row)"
- placeholder="净重"
- />
- </span>
- <span v-else>{{ scope.row[item.label] }}</span>
- </template>
- </el-table-column>
- </el-table>
- <pagination
- v-show="whgenlegTotal > 0"
- :total="whgenlegTotal"
- :page.sync="whgenlegParams.pageNum"
- :limit.sync="whgenlegParams.pageSize"
- @pagination="getDetailsList"
- />
- <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
- 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,
- listGoodsTransfer,
- getGoodsTransfer,
- addGoodsTransfer,
- warehouseSubmission,
- delGoodsTransfer,
- delgoodsTransfer_s,
- exportgoodsTransfer,
- updateCredit,
- } from "@/api/warehouseBusiness/goodsTransfer";
- 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 Treeselect from "@riophae/vue-treeselect";
- import "@riophae/vue-treeselect/dist/vue-treeselect.css";
- import UploadFile from "@/components/Uploadfile";
- import Cookies from "js-cookie";
- import { addSet, select, resetModule } from "@/api/system/set";
- import draggable from "vuedraggable";
- import upLoad from "../components/upLoad";
- export default {
- name: "inStock",
- props: {
- chiId: {
- type: Number,
- required: null,
- },
- copyStatus: {
- type: Number,
- required: null,
- },
- },
- components: {
- UploadFile,
- Treeselect,
- AddOrUpdate,
- ApprovalComments,
- draggable,
- upLoad,
- },
- data() {
- return {
- pageNum: 1,
- pageSize: 10,
- dialogWhgenlegList: [],
- tasklegList: [],
- Navigation: false,
- key_id: "",
- warehousingagreements: false,
- mblnoStatus: "",
- selectloading: false,
- fMblnoOptions: [],
- warehouseDrList: [],
- relevantAttachments: [],
- warehouseCrList: [],
- fStltypeOptions: [],
- form: {},
- rules: {
- fBsdeptid: [{ required: true, message: " ", trigger: "blur" }],
- fCorpid: [{ required: true, message: " ", trigger: "blur" }],
- fBsdate: [{ required: true, message: " ", trigger: "blur" }],
- fFeetunit: [{ required: true, message: " ", trigger: "blur" }],
- fChargedate: [{ required: true, message: " ", trigger: "blur" }],
- fTrademodeid: [{ required: true, message: " ", trigger: "blur" }],
- fSbu: [{ 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",
- },
- ],
- },
- 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,
- 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,
- 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: [],
- 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: "",
- drag: false,
- tableDate: [
- {
- surface: "1",
- label: "fGoodsids",
- name: "品名",
- checked: 0,
- width: 100,
- },
- {
- surface: "2",
- label: "fBillstatus",
- name: "状态",
- checked: 0,
- width: 80,
- fixed: "left",
- },
- {
- surface: "3",
- label: "fBsdate",
- name: "货转日期",
- checked: 0,
- width: 200,
- fixed: "left",
- },
- {
- surface: "4",
- label: "fMarks",
- name: "品牌",
- checked: 0,
- width: 200,
- fixed: "left",
- },
- {
- surface: "5",
- label: "fBusinessType",
- name: "货物属性",
- checked: 0,
- width: 100,
- },
- {
- surface: "6",
- label: "fMarks",
- name: "属性详情",
- checked: 0,
- width: 100,
- },
- {
- surface: "7",
- label: "fMblno",
- name: "提单号",
- checked: 0,
- width: 100,
- },
- {
- surface: "8",
- label: "fOrgwarehouseInformation",
- name: "库位",
- checked: 0,
- width: 150,
- },
- {
- surface: "9",
- label: "fOriginalbillno",
- name: "原始入库单号",
- checked: 0,
- width: 100,
- },
- {
- surface: "10",
- label: "fPlanqty",
- name: "结余件数",
- checked: 0,
- width: 100,
- },
- {
- surface: "11",
- label: "fPlangrossweight",
- name: "库存毛重(kg)",
- checked: 0,
- width: 120,
- },
- {
- surface: "12",
- label: "fPlannetweight",
- name: "库存净重(kg)",
- checked: 0,
- width: 120,
- },
- {
- surface: "13",
- label: "fQty",
- name: "货转件数",
- checked: 0,
- width: 100,
- },
- {
- surface: "14",
- label: "fGrossweight",
- name: "货转毛重(kg)",
- checked: 0,
- width: 120,
- },
- {
- surface: "15",
- label: "fNetweight",
- name: "货转净重(kg)",
- checked: 0,
- width: 120,
- },
- {
- surface: "16",
- label: "fCntqty",
- name: "箱量",
- checked: 0,
- width: 100,
- },
- {
- surface: "17",
- label: "fCntrno",
- name: "箱号",
- checked: 0,
- width: 100,
- },
- {
- surface: "18",
- label: "fPackagespecs",
- name: "包装规格",
- checked: 0,
- width: 100,
- },
- {
- surface: "19",
- label: "fLntype",
- name: "装卸方式",
- checked: 0,
- width: 100,
- },
- {
- surface: "20",
- label: "fForkliftman",
- name: "叉车工",
- checked: 0,
- width: 100,
- },
- {
- surface: "21",
- label: "fStevedore",
- name: "装卸工",
- checked: 0,
- width: 100,
- },
- {
- surface: "22",
- label: "fLocalcntrno",
- name: "库内箱号",
- checked: 0,
- width: 100,
- },
- {
- surface: "23",
- label: "fSealno",
- name: "封号",
- checked: 0,
- width: 100,
- },
- {
- surface: "24",
- label: "fGoodsval",
- name: "货值",
- checked: 0,
- width: 100,
- },
- {
- surface: "25",
- label: "remark",
- name: "备注",
- checked: 0,
- width: 100,
- },
- ],
- setRowList: [],
- getRowList: [],
- allCheck: false,
- showSetting: false,
- tableDate2: [
- {
- surface: "1",
- label: "fMblno",
- name: "提单号",
- checked: 0,
- width: 150,
- },
- {
- surface: "2",
- label: "fOriginalbilldate",
- name: "入库日期",
- checked: 0,
- width: 100,
- },
- {
- surface: "3",
- label: "fGoodsids",
- name: "品名",
- checked: 0,
- width: 100,
- },
- {
- surface: "4",
- label: "fCntrno",
- name: "箱号",
- checked: 0,
- width: 100,
- },
- {
- surface: "5",
- label: "fQtyblc",
- name: "结余数量",
- checked: 0,
- width: 150,
- },
- {
- surface: "6",
- label: "fGrossweightblc",
- name: "结余毛重(kg)",
- checked: 0,
- width: 150,
- },
- {
- surface: "7",
- label: "fNetweightblc",
- name: "结余净重(kg)",
- checked: 0,
- width: 150,
- },
- {
- surface: "8",
- label: "fWarehouseids",
- name: "库位",
- checked: 0,
- width: 150,
- },
- {
- surface: "9",
- label: "fMarks",
- name: "品牌",
- checked: 0,
- width: 100,
- },
- {
- surface: "10",
- label: "fQtyblc2",
- name: "数量",
- checked: 0,
- width: 100,
- },
- {
- surface: "11",
- label: "fGrossweightblc2",
- name: "毛重(kg)",
- checked: 0,
- width: 100,
- },
- {
- surface: "12",
- label: "fNetweightblc2",
- name: "净重(kg)",
- checked: 0,
- width: 100,
- },
- ],
- setRowList2: [],
- getRowList2: [],
- allCheck2: false,
- showSetting2: false,
- dataListSelection: [],
- unloadModes: [],
- };
- },
- created() {
- this.setRowList = this.tableDate;
- this.getRowList = this.tableDate;
- this.setRowList2 = this.tableDate2;
- this.getRowList2 = this.tableDate2;
- this.getDicts("data_stltype_type").then((response) => {
- this.fStltypeOptions = response.data;
- });
- this.getDicts("st_goodstf_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.getDicts("unload_mode").then((response) => {
- this.unloadModes = response.data;
- });
- this.company = localStorage.getItem("companyName");
- this.queryUser();
- this.getRow();
- this.getRow2();
- },
- 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;
- },
- goodsFormat(row, goodsOptions) {
- let goods;
- goodsOptions.map((e) => {
- if (row == e.fId) {
- goods = e.fName;
- }
- });
- return goods;
- },
- },
- methods: {
- init() {
- this.approVal = false;
- this.resetForm("form");
- this.detailList = [];
- this.relevantAttachments = [];
- this.warehouseCrList = [];
- this.warehouseDrList = [];
- this.CntrTable = [];
- if (this.$route.query.id) {
- this.approVal = true;
- this.$router.push({ query: {} });
- }
- this.getForm();
- },
- init2() {
- this.whgenlegParams = {
- pageNum: 1,
- pageSize: 10,
- fCorpid: null,
- fWarehouseid: null,
- fTruckno: null,
- fCntrno: null,
- fMblno: null,
- orgStorageDate: null,
- };
- },
- //列设置全选
- allChecked() {
- if (this.allCheck == true) {
- this.setRowList.map((e) => {
- return (e.checked = 0);
- });
- } else {
- this.setRowList.map((e) => {
- return (e.checked = 1);
- });
- }
- },
- //查询列数据
- getRow() {
- let that = this;
- this.data = {
- tableName: "调拨明细",
- userId: Cookies.get("userName"),
- };
- select(this.data).then((res) => {
- if (res.data.length != 0) {
- this.getRowList = res.data.filter((e) => e.checked == 0);
- this.setRowList = res.data;
- this.setRowList = this.setRowList.reduce((res, item) => {
- res.push({
- surface: item.surface,
- label: item.label,
- name: item.name,
- checked: item.checked,
- width: item.width,
- fixed: item.fixed,
- });
- return res;
- }, []);
- }
- });
- },
- //重置列表
- delRow() {
- this.data = {
- tableName: "调拨明细",
- userId: Cookies.get("userName"),
- };
- resetModule(this.data).then((res) => {
- if (res.code == 200) {
- this.showSetting = false;
- this.setRowList = this.$options.data().tableDate;
- this.getRowList = this.$options.data().tableDate;
- }
- });
- },
- //保存列设置
- save() {
- this.showSetting = false;
- this.data = {
- tableName: "调拨明细",
- userId: Cookies.get("userName"),
- sysTableSetList: this.setRowList,
- };
- addSet(this.data).then((res) => {
- if (res.code == 200) {
- this.showSetting = false;
- this.getRowList = this.setRowList.filter((e) => e.checked == 0);
- }
- });
- },
- //列设置全选
- allChecked2() {
- if (this.allCheck2 == true) {
- this.setRowList2.map((e) => {
- return (e.checked = 0);
- });
- } else {
- this.setRowList2.map((e) => {
- return (e.checked = 1);
- });
- }
- },
- //查询列数据
- getRow2() {
- let that = this;
- this.data = {
- tableName: "调拨总账",
- userId: Cookies.get("userName"),
- };
- select(this.data).then((res) => {
- if (res.data.length != 0) {
- this.getRowList2 = res.data.filter((e) => e.checked == 0);
- this.setRowList2 = res.data;
- this.setRowList2 = this.setRowList2.reduce((res, item) => {
- res.push({
- surface: item.surface,
- label: item.label,
- name: item.name,
- checked: item.checked,
- width: item.width,
- fixed: item.fixed,
- });
- return res;
- }, []);
- }
- });
- },
- //重置列表
- delRow2() {
- this.data = {
- tableName: "调拨总账",
- userId: Cookies.get("userName"),
- };
- resetModule(this.data).then((res) => {
- if (res.code == 200) {
- this.showSetting2 = false;
- this.setRowList2 = this.$options.data().tableDate2;
- this.getRowList2 = this.$options.data().tableDate2;
- }
- });
- },
- //保存列设置
- save2() {
- this.showSetting2 = false;
- this.data = {
- tableName: "调拨总账",
- userId: Cookies.get("userName"),
- sysTableSetList: this.setRowList2,
- };
- addSet(this.data).then((res) => {
- if (res.code == 200) {
- this.showSetting2 = false;
- this.getRowList2 = this.setRowList2.filter((e) => e.checked == 0);
- }
- });
- },
- //开始拖拽事件
- onStart() {
- this.drag = true;
- },
- //拖拽结束事件
- onEnd() {
- this.drag = false;
- },
- 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;
- }
- if (row.fQtyblc2 > row.fQtyblc) {
- this.$message.error("出库件数超出结余件数!");
- this.$set(row, "fQtyblc2", 0);
- this.$set(row, "fGrossweightblc2", 0);
- this.$set(row, "fNetweightblc2", 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)
- );
- this.$set(
- row,
- "fNetweightblc2",
- parseFloat(
- (Number(row.fNetweightblc) / Number(row.fQtyblc)) *
- Number(row.fQtyblc2)
- ).toFixed(2)
- );
- this.$set(
- row,
- "fGrossweightblc2",
- parseFloat(
- (Number(row.fGrossweightblc) / Number(row.fQtyblc)) *
- Number(row.fQtyblc2)
- ).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: e.fGrossweightblc2,
- fNetweight: e.fNetweightblc2,
- fQty: e.fQtyblc2,
- 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 + "",
- 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: 130,
- 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.$router.push({ path: "/index" });
- },
- addOrUpdateHandle(form) {
- this.addOrUpdateVisible = true;
- this.$nextTick(() => {
- this.$refs.addOrUpdate.init(form.fId, 130);
- });
- },
- addOrUpdateHand(form) {
- this.addOrUpdateVisib = true;
- this.$nextTick(() => {
- this.$refs.ApprovalComments.init(form.fId, 130);
- });
- },
- changefStltype(row) {
- this.fMblnoOptions.map((e) => {
- if (row == e.fId && e.fStltypeid) {
- 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();
- }
- item.fLntype = item.fLntype ? item.fLntype.toString() : null;
- 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() {
- for (let item in this.Printinglist) {
- if (!this.Printinglist[item].fId) {
- 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();
- }
- item.fLntype = item.fLntype ? item.fLntype.toString() : null;
- 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("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", null);
- }
- });
- });
- 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;
- },
- 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() {
- getGoodsTransfer(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, "fChargedate", Date.parse(this.form.fChargedate));
- this.$set(this.form, "fFeetUnit", this.form.fFeetunit);
- this.$set(this.form, "fBusinessType", "1");
- 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();
- e.fLntype = e.fLntype ? e.fLntype.toString() : null;
- });
- 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.form.fCorpid === this.form.fTocorpid) {
- return this.$message.error("新客户不得与客户一致");
- }
- 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));
- addGoodsTransfer(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,
- "fChargedate",
- Date.parse(this.form.fChargedate)
- );
- 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();
- e.fLntype = e.fLntype ? e.fLntype.toString() : null;
- });
- 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 != 6);
- //允许撤销入库list
- this.dataWithdrawList = [];
- this.dataWithdrawList = selection.filter((e) => e.fBillstatus == 6);
- },
- // 合计
- 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);
- if (column.property === "fGrossweight") {
- sums[index] = (sums[index] / 1000).toFixed(2) + "吨";
- } else if (column.property === "fNetweight") {
- sums[index] = (sums[index] / 1000).toFixed(2) + "吨";
- } else {
- 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.getDetailsList();
- }
- });
- },
- // 查询库存总账信息
- getDetailsList() {
- this.whgenlegParams.fCorpid = this.form.fCorpid;
- this.whgenlegParams.fTrademodeid = this.form.fTrademodeid;
- this.whgenlegParams.fWarehouseid = this.form.fInwarehouseid;
- this.whgenlegParams.orgStorageDate = this.form.orgStorageDate;
- listWhgenleg(this.whgenlegParams).then((response) => {
- response.rows.map((e) => {
- e.fQtyblc2 = e.fQtyblc;
- e.fGrossweightblc2 = e.fGrossweightblc;
- e.fNetweightblc2 = e.fNetweightblc;
- });
- this.whgenlegList = response.rows;
- this.whgenlegTotal = response.total;
- });
- },
- //计算仓储费日期变更
- 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;
- }
- },
- // 收款信息新行
- 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
- );
- }
- }
- }
- },
- //获取登陆人
- 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()));
- this.$set(this.form, "fBusinessType", "1");
- }
- 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] + "…");
- }
- }
- },
- cancel() {
- if (this.$route.query.id) {
- this.$router.push({ query: {} });
- }
- 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>
|