12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930 |
- <template>
- <div>
- <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>
- <br />
- <div>
- <el-popconfirm title="是否确认离开此页面?" @confirm="changeShow">
- <el-button slot="reference" size="mini" icon="el-icon-arrow-left"
- >返回列表</el-button
- >
- </el-popconfirm>
- </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
- remote
- reserve-keyword
- placeholder="请输入关键词"
- :remote-method="corpremoteMethod"
- :loading="selectloading"
- @clear="clear('fCorpid')"
- style="width: 80%"
- >
- <el-option
- v-for="(item, index) in fMblnoOptions"
- :key="index.fId"
- :label="item.fName"
- :value="item.fId"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="结算方式" prop="fStltypeid">
- <el-select
- v-model="form.fStltypeid"
- placeholder="请选择结算方式"
- clearable
- :disabled="browseStatus || formBrowseStatus"
- style="width: 80%"
- >
- <el-option
- v-for="(item, index) in fStltypeOptions"
- :key="index.dictValue"
- :label="item.dictLabel"
- :value="item.dictValue"
- />
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="提单号" prop="fMblno">
- <el-input
- v-model="form.fMblno"
- :disabled="browseStatus || formBrowseStatus"
- style="width: 80%"
- 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 || formBrowseStatus"
- value-format="timestamp"
- placeholder="入库日期"
- @change="changeDate"
- >
- </el-date-picker>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="入库时间" prop="fBstime">
- <el-time-picker
- style="width: 80%"
- :disabled="browseStatus || formBrowseStatus"
- v-model="form.fBstime"
- :picker-options="{
- selectableRange: '00:00:00 - 23:59:59',
- }"
- value-format="timestamp"
- placeholder="任意时间点"
- >
- </el-time-picker>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item prop="fChargedate" label="仓储费计算日期">
- <el-date-picker
- v-model="form.fChargedate"
- type="date"
- style="width: 80%"
- value-format="timestamp"
- :disabled="browseStatus || formBrowseStatus"
- placeholder="仓储费计算日期"
- >
- </el-date-picker>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item prop="fGoodsid" label="品名">
- <el-select
- filterable
- v-model="form.fGoodsid"
- style="width: 80%"
- :disabled="browseStatus || formBrowseStatus"
- placeholder="请选择品名"
- >
- <el-option
- v-for="(item, index) in goodsOptions"
- :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="fWarehouseid">
- <el-select
- v-model="form.fWarehouseid"
- filterable
- :disabled="browseStatus || formBrowseStatus"
- style="width: 80%"
- @keyup.enter.native="handleQuery"
- placeholder="请选择"
- >
- <el-option
- v-for="(item, index) in warehouseOptions"
- :key="index.fId"
- :label="item.fName"
- :value="item.fId"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="仓管员" prop="fStorekeeper">
- <el-select
- v-model="form.fStorekeeper"
- filterable
- remote
- clearable
- reserve-keyword
- :disabled="browseStatus || formBrowseStatus"
- style="width: 80%"
- :remote-method="userRemoteMethod"
- placeholder="请输入模糊查找"
- :loading="selectloading"
- @clear="clear('fStorekeeper')"
- >
- <el-option
- v-for="(item, index) in userOptions"
- :key="index.userName"
- :label="item.nickName"
- :value="item.userName"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="8">
- <el-form-item label="计划件数" prop="fPlanqty">
- <el-input
- v-model.number="form.fPlanqty"
- style="width: 80%"
- maxlength="9"
- laceholder="计划件数"
- :disabled="browseStatus || current !== before"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="计划净重(kg)" prop="fPlannetweight">
- <el-input
- v-model.number="form.fPlannetweight"
- style="width: 80%"
- maxlength="9"
- v-input-limit="0"
- laceholder="计划净重"
- :disabled="browseStatus || current !== before"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="计划毛重(kg)" prop="fPlangrossweight">
- <el-input
- v-model.number="form.fPlangrossweight"
- v-input-limit="0"
- style="width: 80%"
- laceholder="计划毛重"
- maxlength="9"
- :disabled="browseStatus || current !== before"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="8">
- <el-form-item label="作业类型" prop="fBusinessType">
- <el-select
- style="width: 80%"
- v-model="form.fBusinessType"
- filterable
- :disabled="contrOl || browseStatus"
- >
- <el-option
- v-for="(item, index) in businessTypeOption"
- :key="index.dictValue"
- :label="item.dictLabel"
- :value="item.dictValue"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="劳务公司" prop="fLabour">
- <el-select
- style="width: 80%"
- v-model="form.fLabour"
- clearable
- filterable
- remote
- reserve-keyword
- placeholder="请输入关键词"
- :remote-method="flabourRemoteMethod"
- :loading="selectloading"
- @clear="clear('fLabour')"
- >
- <el-option
- v-for="(item, index) in fCompanyOptIons"
- :key="index.fId"
- :label="item.fName"
- :value="item.fId"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item
- label="车队"
- prop="fFleet"
- :rules="{
- required: isrequired === 1 ? true : false,
- message: '请选择',
- trigger: ['blur', 'change'],
- }"
- >
- <el-select
- style="width: 80%"
- v-model="form.fFleet"
- clearable
- filterable
- remote
- reserve-keyword
- placeholder="请输入关键词"
- :remote-method="fleetRemoteMethod"
- :disabled="contrOl || browseStatus"
- :loading="selectloading"
- @clear="clear('fFleet')"
- >
- <el-option
- v-for="(item, index) in fleetOptions"
- :key="index.fId"
- :label="item.fName"
- :value="item.fId"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="8">
- <el-form-item label="计费单位" prop="fFeetunit">
- <el-select
- v-model="form.fFeetunit"
- placeholder="请选择计费单位"
- clearable
- :disabled="browseStatus || formBrowseStatus"
- 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="fTruckno"
- :rules="{
- required: isrequired_s === 1 ? true : false,
- message: '请选择',
- trigger: ['blur', 'change'],
- }"
- >
- <el-input
- v-model="form.fTruckno"
- style="width: 80%"
- :disabled="browseStatus || formBrowseStatus"
- placeholder="车号"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item
- label="司机姓名"
- prop="fDriverName"
- :rules="{
- required: isrequired_s === 1 ? true : false,
- message: '请选择',
- trigger: ['blur', 'change'],
- }"
- >
- <el-input
- v-model="form.fDriverName"
- style="width: 80%"
- :disabled="browseStatus || formBrowseStatus"
- placeholder="司机姓名"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="16">
- <el-row>
- <el-col :span="12">
- <el-form-item
- label="司机身份证"
- prop="fDriverIdCar"
- :rules="{
- required: isrequired_s === 1 ? true : false,
- message: '请选择',
- trigger: ['blur', 'change'],
- }"
- >
- <el-input
- v-model="form.fDriverIdCar"
- style="width: 80%"
- :disabled="browseStatus || formBrowseStatus"
- placeholder="司机身份证"
- />
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item
- label="司机电话"
- prop="fDriverTel"
- :rules="{
- required: isrequired_s === 1 ? true : false,
- message: '请选择',
- trigger: ['blur', 'change'],
- }"
- >
- <el-input
- v-model="form.fDriverTel"
- style="width: 80%"
- :disabled="browseStatus || formBrowseStatus"
- placeholder="司机电话"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="24">
- <el-form-item label="备注" prop="remark">
- <el-input
- style="width: 91.5%"
- v-model="form.remark"
- type="textarea"
- :disabled="browseStatus"
- placeholder="请输入内容"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :offset="16" :span="2">
- <el-form-item>
- <el-button
- @click="
- detailsHidden
- ? (detailsHidden = false)
- : (detailsHidden = true)
- "
- >{{ detailsHidden ? "隐藏" : "展开" }}
- </el-button>
- </el-form-item>
- </el-col>
- </el-row>
- </el-col>
- <el-col :span="8">
- <el-form-item>
- <el-table
- :data="CntrTable"
- style="width: 80%"
- :header-cell-style="{ lineHeight: '16px' }"
- height="139"
- >
- <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 fCntridlist"
- :key="index.value"
- :label="item.label"
- :value="item.value"
- >
- </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>
- <div style="display: flex; justify-content: center; width: 80%">
- <el-tag class="tag-hover" @click="addRow"
- ><i class="el-icon-plus"></i
- ></el-tag>
- </div>
- </el-form-item>
- </el-col>
- </el-row>
- <div v-if="detailsHidden">
- <el-row style="margin-top: 30px">
- <el-col :span="8">
- <el-form-item label="仓库联系人" prop="fContacts">
- <el-input
- v-model="form.fContacts"
- style="width: 80%"
- :disabled="browseStatus || formBrowseStatus"
- placeholder="仓库联系人"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="仓库电话" prop="fTel">
- <el-input
- v-model="form.fTel"
- :disabled="browseStatus || formBrowseStatus"
- style="width: 80%"
- placeholder="请输仓库入电话"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="船名航次" prop="fVslvoy">
- <el-input
- v-model="form.fVslvoy"
- style="width: 80%"
- :disabled="browseStatus || formBrowseStatus"
- placeholder="船名航次"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="8">
- <el-form-item label="到港日期" prop="fEta">
- <el-date-picker
- v-model="form.fEta"
- style="width: 80%"
- type="date"
- :disabled="browseStatus || formBrowseStatus"
- value-format="timestamp"
- placeholder="到港日期"
- >
- </el-date-picker>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="报关单号" prop="fCustomno">
- <el-input
- v-model="form.fCustomno"
- style="width: 80%"
- :disabled="browseStatus || formBrowseStatus"
- laceholder="报关单号"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="经营单位" prop="fSbu">
- <el-select
- v-model="form.fSbu"
- clearable
- filterable
- remote
- reserve-keyword
- placeholder="请输入关键词"
- :remote-method="fSbuRemoteMethod"
- :loading="selectloading"
- @clear="clear('fSbu')"
- >
- <el-option
- v-for="(item, index) in fSbuOptions"
- :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="fBillno">
- <el-input
- v-model="form.fBillno"
- disabled
- style="width: 80%"
- placeholder="单据编号"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="贸易方式" prop="fTrademodeid">
- <el-select
- v-model="form.fTrademodeid"
- placeholder="请选择贸易方式"
- :disabled="browseStatus || formBrowseStatus"
- 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-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 label="制单部门" prop="fDeptid">
- <el-select
- v-model="form.fDeptid"
- filterable
- disabled
- style="width: 80%"
- remote
- >
- <el-option
- v-for="(item, index) in deptOptions"
- :key="index.deptId"
- :label="item.deptName"
- :value="item.deptId"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item disabled label="制单日期" prop="fbilldate">
- <el-date-picker
- v-model="form.createTime"
- size="large"
- type="date"
- disabled
- style="width: 80%"
- value-format="timestamp"
- placeholder="制单日期"
- >
- </el-date-picker>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="过磅" prop="fIfweigh">
- <el-select
- v-model="form.fIfweigh"
- placeholder="请选择是否过磅"
- clearable
- :disabled="browseStatus || formBrowseStatus"
- style="width: 80%"
- >
- <el-option
- v-for="(item, index) in fIfweighOptions"
- :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="fProductName">
- <el-input
- v-model="form.fProductName"
- style="width: 80%"
- disabled
- placeholder="品名"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="品牌">
- <el-input
- v-model="form.fMarks"
- style="width: 80%"
- disabled
- placeholder="品牌"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="存货编号" prop="fBscorpno">
- <el-input
- disabled
- v-model="form.fBscorpno"
- style="width: 80%"
- laceholder="存货编号"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="8">
- <el-form-item label="质押" prop="fIfpledge">
- <el-select
- v-model="form.fIfpledge"
- placeholder="请选择是否质押"
- clearable
- :disabled="browseStatus || formBrowseStatus"
- style="width: 80%"
- >
- <el-option
- v-for="(item, index) in fIfpledgeOptions"
- :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="fBankcorpid">
- <el-select
- v-model="form.fBankcorpid"
- filterable
- remote
- clearable
- style="width: 80%"
- :disabled="browseStatus || formBrowseStatus"
- @keyup.enter.native="handleQuery"
- :remote-method="corpsRemoteMethodd"
- placeholder="请输入关键词"
- @clear="clear('fBankcorpid')"
- >
- <el-option
- v-for="(item, index) in Pledgebank"
- :key="index.fId"
- :label="item.fName"
- :value="item.fId"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- </div>
- </el-form>
- <el-collapse v-model="collapselist">
- <el-collapse-item name="1">
- <template slot="title">
- <i class="el-icon-s-home" style="font-size: 16px"></i>
- <span style="font-size: 16px; font-weight: bolder; margin-left: 5px"
- >入库明细</span
- >
- </template>
- <div>
- <el-row
- type="flex"
- justify="space-between"
- style="margin-bottom: 10px"
- >
- <el-col>
- <el-button
- type="primary"
- :disabled="browseStatus"
- size="small"
- @click="addRelevant"
- >新行
- </el-button>
- <el-button
- :disabled="browseStatus"
- type="primary"
- size="small"
- @click="saveForm"
- >保 存</el-button
- >
- </el-col>
- <el-col style="display: flex; justify-content: flex-end">
- <el-button
- size="small"
- type="info"
- :disabled="browseStatus"
- prop="打印"
- @click="printZyd"
- >作业单
- </el-button>
- <el-button
- size="small"
- :disabled="browseStatus"
- @click="discharge"
- >叫车进场</el-button
- >
- <el-button
- size="small"
- :disabled="dataListSelection.length <= 0 || browseStatus"
- @click="creditClick"
- >入库确认
- </el-button>
- <el-button
- size="small"
- :disabled="dataWithdrawList.length <= 0 || browseStatus"
- @click.prevent="withdrawClick"
- >撤回入库
- </el-button>
- <el-dropdown @command="handleCommand" style="margin-left: 10px">
- <el-button :disabled="browseStatus" size="small" type="success">
- 打印单据<i class="el-icon-arrow-down el-icon--right"></i>
- </el-button>
- <el-dropdown-menu slot="dropdown">
- <el-dropdown-item command="a">收货单</el-dropdown-item>
- <el-dropdown-item command="b">入库单</el-dropdown-item>
- <el-dropdown-item command="c">理货单</el-dropdown-item>
- <el-dropdown-item command="d">货物确认</el-dropdown-item>
- <el-dropdown-item command="e">劳务确认</el-dropdown-item>
- <el-dropdown-item command="f">吊牌信息</el-dropdown-item>
- </el-dropdown-menu>
- </el-dropdown>
- </el-col>
- </el-row>
- <el-table
- :data="detailList"
- tooltip-effect="dark"
- stripe
- :summary-method="getSummaries"
- @selection-change="Selectinventory"
- show-summary
- >
- <el-table-column type="selection" width="55" align="center" fixed />
- <el-table-column label="序号" type="index" width="80" fixed />
- <el-table-column
- prop="fBillstatus"
- header-align="center"
- width="150px"
- align="center"
- fixed
- label="状态"
- >
- <template slot-scope="scope">
- <span v-if="scope.row.fBillstatus === 10">计划</span>
- <span v-if="scope.row.fBillstatus === 20">待入库</span>
- <span v-if="scope.row.fBillstatus === 30">入库中</span>
- <span v-if="scope.row.fBillstatus === 40">已入库</span>
- </template>
- </el-table-column>
- <el-table-column
- fixed
- prop="fBsdate"
- header-align="center"
- align="center"
- width="150px"
- label="入库日期"
- :formatter="fBsdateFormat"
- />
- <el-table-column
- prop="fMblno"
- header-align="center"
- align="center"
- width="140px"
- label="提单号"
- />
- <el-table-column
- prop="fGoodsid"
- header-align="center"
- align="center"
- width="140px"
- label="*品名"
- :formatter="goodsFormat"
- />
- <el-table-column
- prop="fBusinessType"
- header-align="center"
- width="140px"
- align="center"
- label="*货物属性"
- :formatter="fStorageTypeFormat"
- />
- <el-table-column
- prop="fMarks"
- header-align="center"
- align="center"
- width="140px"
- label="*属性详情"
- />
- <el-table-column
- prop="fWarehouseInformation"
- header-align="center"
- width="240px"
- align="center"
- label="*库区"
- />
- <el-table-column
- prop="fCntrtype"
- header-align="center"
- align="center"
- width="140px"
- label="箱型"
- />
- <el-table-column
- prop="fCntqty"
- header-align="center"
- align="center"
- width="140px"
- label="箱量"
- />
- <el-table-column
- prop="fQty"
- header-align="center"
- width="150px"
- align="center"
- label="*入库件数"
- />
- <el-table-column
- prop="fGrossweight"
- header-align="center"
- width="180px"
- align="center"
- label="*入库毛重(kg)"
- />
- <el-table-column
- prop="fNetweight"
- header-align="center"
- width="180px"
- align="center"
- label="*入库净重(kg)"
- />
- <el-table-column
- prop="fPackagespecs"
- header-align="center"
- width="150px"
- align="center"
- label="*包装规格"
- />
- <el-table-column
- prop="fTruckno"
- header-align="center"
- width="130px"
- align="center"
- label="*车号"
- />
- <el-table-column
- prop="fDriverName"
- header-align="center"
- width="130px"
- align="center"
- label="司机名"
- />
- <el-table-column
- prop="fDriverTel"
- header-align="center"
- width="200px"
- align="center"
- label="司机电话"
- />
- <el-table-column
- prop="fDriverIdCar"
- header-align="center"
- width="200px"
- align="center"
- label="司机身份证"
- />
- <el-table-column
- prop="fSerialNumber"
- header-align="center"
- width="160px"
- align="center"
- label="流水号"
- />
- <el-table-column
- prop="fCntrno"
- header-align="center"
- width="130px"
- align="center"
- label="箱号"
- />
- <el-table-column
- prop="fGoodsval"
- header-align="center"
- width="130px"
- align="center"
- label="货值"
- />
- <el-table-column
- prop="remark"
- header-align="center"
- width="130px"
- align="center"
- label="备注"
- />
- <el-table-column
- header-align="center"
- align="center"
- label="操作"
- width="130PX"
- >
- <template slot-scope="scope">
- <el-button
- :disabled="
- browseStatus ||
- scope.row.fBillstatus === 20 ||
- scope.row.fBillstatus === 30 ||
- scope.row.fBillstatus === 40
- "
- type="text"
- @click.native.prevent="fixRow(scope.row, scope.$index)"
- size="small"
- >修改</el-button
- >
- <el-button
- :disabled="
- browseStatus ||
- scope.row.fBillstatus === 20 ||
- scope.row.fBillstatus === 30 ||
- scope.row.fBillstatus === 40
- "
- type="text"
- @click.native.prevent="wDeleteRow(scope.$index, detailList)"
- size="small"
- >移除</el-button
- >
- </template>
- </el-table-column>
- </el-table>
- </div>
- </el-collapse-item>
- <el-collapse-item>
- <template slot="title">
- <i class="el-icon-s-order" style="font-size: 16px"></i>
- <span style="font-size: 16px; font-weight: bolder; margin-left: 5px"
- >附件明细</span
- >
- </template>
- </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>
- </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>
- </el-collapse-item>
- </el-collapse>
- <el-dialog
- v-dialogDrag
- :title="title"
- :visible.sync="weightList"
- width="80%"
- :close-on-click-modal="false"
- >
- <div>
- <el-form
- ref="importList"
- :model="importList"
- :rules="imporRules"
- label-width="120px"
- >
- <el-row>
- <el-col :span="8">
- <el-form-item label="入库日期" prop="fBsdate">
- <el-date-picker
- v-model="importList.fBsdate"
- type="date"
- style="width: 80%"
- value-format="timestamp"
- placeholder="入库日期"
- >
- </el-date-picker>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="品名" prop="fGoodsid">
- <el-select
- filterable
- v-model="importList.fGoodsid"
- style="width: 80%"
- placeholder="请选择品名"
- >
- <el-option
- v-for="(item, index) in goodsOptions"
- :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="fBusinessType">
- <el-select
- filterable
- v-model="importList.fBusinessType"
- style="width: 80%"
- placeholder="请选择商品属性"
- >
- <el-option
- v-for="(item, index) in fStorageTypeOptions"
- :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="fMarks">
- <el-input
- v-model="importList.fMarks"
- style="width: 80%"
- placeholder="请填写属性描述"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="库区" prop="fWarehouseInformation">
- <el-select
- filterable
- v-model="importList.fWarehouseInformation"
- style="width: 80%"
- placeholder="请选择库区"
- >
- <el-option
- v-for="(item, index) in fWarehouseidOptions"
- :key="index.id"
- :label="item.label"
- :value="item.fWarehouseInformation"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="箱型" prop="fCntrtype">
- <el-input
- v-model="importList.fCntrtype"
- style="width: 80%"
- maxlength="4"
- placeholder="箱型"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="8">
- <el-form-item label="计划件数" prop="fQty">
- <el-input
- v-input-limit="0"
- v-model.number="importList.fQty"
- style="width: 80%"
- placeholder="计划件数"
- @input="imporComputer"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="计划净重(kg)" prop="fNetweight">
- <el-input
- v-model.number="importList.fNetweight"
- v-input-limit="2"
- style="width: 80%"
- disabled
- placeholder="计划毛重"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="计划毛重(kg)" prop="fGrossweight">
- <el-input
- v-model.number="importList.fGrossweight"
- v-input-limit="2"
- style="width: 80%"
- disabled
- placeholder="计划毛重"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="8">
- <el-form-item label="箱量" prop="fCntqty">
- <el-input
- v-model="importList.fCntqty"
- style="width: 80%"
- placeholder="箱量"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="包装规格" prop="fPackagespecs">
- <el-input
- v-model="importList.fPackagespecs"
- style="width: 80%"
- placeholder="包装规格"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="车号" prop="fTruckno">
- <el-input
- v-model="importList.fTruckno"
- style="width: 80%"
- placeholder="车号"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="8">
- <el-form-item label="司机名" prop="fDriverName">
- <el-input
- v-model="importList.fDriverName"
- style="width: 80%"
- placeholder="司机名"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="司机电话" prop="fDriverTel">
- <el-input
- v-model="importList.fDriverTel"
- style="width: 80%"
- placeholder="司机电话"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="司机身份证" prop="fDriverIdCar">
- <el-input
- v-model="importList.fDriverIdCar"
- style="width: 80%"
- placeholder="司机身份证"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="8">
- <el-form-item label="流水号" prop="fSerialNumber">
- <el-input
- v-model="importList.fSerialNumber"
- style="width: 80%"
- placeholder="流水号"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="箱号" prop="fCntrno">
- <el-input
- v-model="importList.fCntrno"
- style="width: 80%"
- placeholder="箱号"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="货值" prop="fGoodsval">
- <el-input
- v-model="importList.fGoodsval"
- style="width: 80%"
- placeholder="货值"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col>
- <el-form-item label="备注" prop="remark">
- <el-input
- v-model="importList.remark"
- style="width: 95%"
- type="textarea"
- placeholder="备注"
- />
- </el-form-item>
- </el-col>
- </el-row>
- </el-form>
- </div>
- <span slot="footer" class="dialog-footer">
- <el-button v-if="fixdetaiNum == null" type="info" @click="imporTable"
- >导入库存明细</el-button
- >
- <el-button v-else type="info" @click="fiximporTable"
- >确认修改</el-button
- >
- <el-button @click="weightList = false">取 消</el-button>
- </span>
- </el-dialog>
- <el-dialog
- :visible.sync="print_zyd"
- width="70%"
- :close-on-click-modal="false"
- :modal="false"
- >
- <div id="print_area1" class="print-div">
- <div
- class="print-title"
- style="
- display: flex;
- justify-content: center;
- font-size: 24px;
- margin-bottom: 5px;
- "
- >
- {{ company }}有限公司作业单
- </div>
- <div
- style="
- display: flex;
- justify-content: center;
- font-size: 18px;
- margin-bottom: 5px;
- "
- ></div>
- <div class="print_table" style="display: flex">
- <table border="0" cellspacing="0" cellpadding="0" style="width: 100%">
- <tr>
- <td>作业类型</td>
- <td colspan="2">
- {{ form.fBusinessType | fBusinessTypeFormat }}
- </td>
- <td>入库时间</td>
- <td colspan="2"></td>
- </tr>
- <tr>
- <td>车号</td>
- <td>物品名称</td>
- <td>提单号</td>
- <td>品牌/规格/产地</td>
- <td>净重(KG)</td>
- <td>件数/规格</td>
- </tr>
- <tr v-for="(item, index) in Printinglist" :key="index">
- <td>{{ item.fTruckno }}</td>
- <td>{{ item.fGoodsids }}</td>
- <td>{{ item.fMblno }}</td>
- <td>
- {{ item.fBusinessType | fStorageFormat }}/{{ item.fMarks }}
- </td>
- <td>{{ item.fNetweight }}</td>
- <td>{{ item.fQty }}/{{ item.fPackagespecs }}</td>
- </tr>
- <tr>
- <td>备注</td>
- <td colspan="5"></td>
- </tr>
- <tr v-for="(item, index) in Collectionoptionss" :key="index">
- <td>收费</td>
- <td colspan="2">{{ item.fFeeids }}</td>
- <td colspan="3">{{ item.fAmount }} 元</td>
- </tr>
- <tr>
- <td>司机签字</td>
- <td></td>
- <td>电话</td>
- <td>{{ fDriverTel }}</td>
- <td colspan="2" rowspan="2">
- 确认货物数量无误,包装于货物完好!<br />出库盖好篷布,如有违背责任自负<br />装卸工是否收小费
- </td>
- </tr>
- <tr>
- <td>制表</td>
- <td>{{ form.createBy }}</td>
- <td>机械/人工</td>
- <td></td>
- </tr>
- <tr>
- <td>地址</td>
- <td colspan="2">{{ stockaddr }}</td>
- <td>电话</td>
- <td colspan="2">{{ form.fTel }}</td>
- </tr>
- </table>
- </div>
- </div>
- <span lot="footer" class="dialog-footer">
- <el-button
- type="primary"
- size="mini"
- :disabled="browseStatus"
- @click="addprint('zyd')"
- >打印
- </el-button>
- <el-button @click="print_zyd = false" size="mini">取消 </el-button>
- </span>
- </el-dialog>
- <el-dialog
- :visible.sync="print_shd"
- width="70%"
- :close-on-click-modal="false"
- :modal="false"
- >
- <div id="print_area1" class="print-div">
- <div
- class="print-title"
- style="
- display: flex;
- justify-content: center;
- font-size: 24px;
- margin-bottom: 5px;
- "
- >
- {{ company }}有限公司收货单
- </div>
- <div class="print_table" style="display: flex">
- <table border="0" cellspacing="0" cellpadding="0" style="width: 100%">
- <tr>
- <td>车号</td>
- <td>{{ fTruckno }}</td>
- <td>日期</td>
- <td>{{ fBsdate }}</td>
- </tr>
- <tr v-for="(item, index) in Printinglist" :key="index">
- <td>货物品名</td>
- <td>{{ item.fGoodsids }}</td>
- <td>件数</td>
- <td>{{ item.fQty }}件</td>
- </tr>
- <tr>
- <td>备注</td>
- <td colspan="3"></td>
- </tr>
- <tr>
- <td>司机签字</td>
- <td></td>
- <td>司机电话</td>
- <td>{{ fDriverTel }}</td>
- </tr>
- <tr>
- <td>制单人</td>
- <td>{{ form.createBy }}</td>
- <td>收货人</td>
- <td>{{ form.fContacts }}</td>
- </tr>
- <tr>
- <td>地址</td>
- <td>{{ stockaddr }}</td>
- <td>电话</td>
- <td>{{ form.fTel }}</td>
- </tr>
- </table>
- </div>
- </div>
- <span slot="footer" class="dialog-footer">
- <el-button type="primary" :disabled="browseStatus" @click="addprint"
- >打印
- </el-button>
- <el-button @click="print_shd = false">取消 </el-button>
- </span>
- </el-dialog>
- <el-dialog
- :visible.sync="print_rkd"
- width="70%"
- :close-on-click-modal="false"
- :modal="false"
- >
- <div id="print_area1" class="print-div">
- <div
- class="print-title"
- style="
- display: flex;
- justify-content: center;
- font-size: 24px;
- margin-bottom: 5px;
- "
- >
- {{ company }}有限公司进仓单
- </div>
- <div class="print_table" style="display: flex">
- <table border="0" cellspacing="0" cellpadding="0" style="width: 100%">
- <tr>
- <td>货权方</td>
- <td>{{ form.fCorpidName }}</td>
- <td>仓库</td>
- <td>{{ form.fWarehouseids }}</td>
- <td>地址</td>
- <td colspan="2">{{ stockaddr }}</td>
- </tr>
- <tr>
- <td>保管方</td>
- <td width="200">{{ company }}有限公司</td>
- <td>联系人</td>
- <td>{{ form.fContacts }}</td>
- <td>电话</td>
- <td colspan="2">{{ form.fTel }}</td>
- </tr>
- <tr>
- <td>提单号</td>
- <td>品名</td>
- <td>箱型</td>
- <td>品牌</td>
- <td>件数</td>
- <td>重量</td>
- <td>包装规格</td>
- </tr>
- <tr>
- <td></td>
- <td></td>
- <td></td>
- <td></td>
- <td></td>
- <td></td>
- <td></td>
- </tr>
- <tr>
- <td>序号</td>
- <td>入货日期</td>
- <td>箱量(20GP)</td>
- <td>重量</td>
- <td>件数</td>
- <td>入库重量</td>
- <td>入库件数</td>
- </tr>
- <tr v-for="(item, index) in Printinglist" :key="index">
- <td>{{ index + 1 }}</td>
- <td>{{ item.fBsdate }}</td>
- <td>{{ item.fCntqty }}</td>
- <td v-if="item.fGrossweight">
- {{ (item.fGrossweight / 1000).toFixed(2) }}
- </td>
- <td v-else></td>
- <td>{{ item.fPlanqty }}</td>
- <td v-if="item.fNetweight">
- {{ (item.fNetweight / 1000).toFixed(2) }}
- </td>
- <td v-else></td>
- <td>{{ item.fQty }}</td>
- </tr>
- <tr>
- <td colspan="2">合计</td>
- <td>{{ allfCntqty }}</td>
- <td>{{ (allfGrossweight / 1000).toFixed(2) }}</td>
- <td>{{ allfPlanqty }}</td>
- <td>{{ (allfNetweight / 1000).toFixed(2) }}</td>
- <td>{{ allfQty }}</td>
- </tr>
- <tr>
- <td>备注</td>
- <td colspan="6"></td>
- </tr>
- <tr>
- <td colspan="7">
- 本进仓单经仓管员签字并经保管方盖章后即专项作为货物所有人的货权证明,本单据不得转让。
- </td>
- </tr>
- </table>
- </div>
- <div
- style="display: flex; justify-content: space-between; font-size: 12px"
- >
- <div>开单员:</div>
- <div style="width: 150px">仓管员:</div>
- </div>
- <div
- style="display: flex; justify-content: space-between; font-size: 12px"
- >
- <div>开单时间:</div>
- <div style="width: 150px">(盖章)</div>
- </div>
- </div>
- <span slot="footer" class="dialog-footer">
- <el-button type="primary" :disabled="browseStatus" @click="addprint"
- >打印
- </el-button>
- <el-button @click="print_rkd = false">取消 </el-button>
- </span>
- </el-dialog>
- <el-dialog
- :visible.sync="print_lhd"
- width="70%"
- :close-on-click-modal="false"
- :modal="false"
- >
- <div id="print_area1" class="print-div">
- <div
- class="print-title"
- style="
- display: flex;
- justify-content: center;
- font-size: 24px;
- margin-bottom: 5px;
- "
- >
- {{ company }}有限公司
- </div>
- <div
- style="
- display: flex;
- justify-content: center;
- font-size: 18px;
- margin-bottom: 5px;
- "
- >
- <div>入 库 计 划 单</div>
- </div>
- <div
- style="
- display: flex;
- justify-content: space-between;
- margin-bottom: 5px;
- "
- class="print_form"
- >
- <div>
- <div>提单号:{{ form.fMblno }}</div>
- <div>客户名称:{{ form.fCorpidName }}</div>
- <div>货物名称:{{ form.fProductName }}</div>
- <div>预计净重:{{ form.fPlannetweight }}</div>
- </div>
- <div>
- <div>入库计划单号:{{ form.fBillno }}</div>
- <div>计划入库日期:{{ form.fBstime }}</div>
- <div>制单日期:{{ form.createTime }}</div>
- <div>实际毛重:</div>
- </div>
- <div>
- <div>清单号:{{ form.fCustomno }}</div>
- <div>存放仓库:{{ stockName }}</div>
- <div>预计毛重:{{ form.fPlangrossweight }}</div>
- <div>实际净重:</div>
- </div>
- </div>
- <div class="print_table" style="display: flex">
- <table border="0" cellspacing="0" cellpadding="0" style="width: 100%">
- <tr>
- <td>箱号</td>
- <td>铅封号</td>
- <td>预计件数</td>
- <td>实际件数</td>
- <td>垛位</td>
- <td>实际入库日期</td>
- <td>送货车号</td>
- <td>送货司机</td>
- <td>备注</td>
- </tr>
- <tr v-for="(item, index) in Printinglist" :key="index">
- <td>{{ item.fCntrno }}</td>
- <td></td>
- <td>{{ item.fQty }}</td>
- <td></td>
- <td>{{ item.fWarehouseInformation }}</td>
- <td>{{ item.fChargedate }}</td>
- <td>{{ item.fTruckno }}</td>
- <td>{{ item.fDriverName }}</td>
- <td>{{ item.remark }}</td>
- </tr>
- <tr>
- <td colspan="2">合计:</td>
- <td>{{ allfQty }}</td>
- <td></td>
- <td></td>
- <td></td>
- <td></td>
- <td></td>
- <td></td>
- </tr>
- </table>
- </div>
- <div
- style="display: flex; justify-content: space-between; font-size: 12px"
- >
- <div>操作:{{ form.createBy }}</div>
- <div>库管:{{ form.fContacts }}</div>
- <div style="width: 100px">叉车:</div>
- </div>
- </div>
- <span slot="footer" class="dialog-footer">
- <el-button type="primary" :disabled="browseStatus" @click="addprint"
- >打印
- </el-button>
- <el-button @click="print_lhd = false">取消 </el-button>
- </span>
- </el-dialog>
- <el-dialog
- :visible.sync="print_hwqr"
- width="70%"
- :close-on-click-modal="false"
- :modal="false"
- >
- <div id="print_area1" class="print-div">
- <div
- class="print-title"
- style="
- display: flex;
- justify-content: center;
- font-size: 24px;
- margin-bottom: 5px;
- "
- >
- {{ company }}有限公司
- </div>
- <div
- style="
- display: flex;
- justify-content: center;
- font-size: 18px;
- margin-bottom: 5px;
- "
- >
- <div>入 库 单</div>
- </div>
- <div style="margin-bottom: 5px" class="print_form">
- <div>客户名称:{{ form.fCorpidName }}</div>
- </div>
- <div class="print_table" style="display: flex">
- <table border="0" cellspacing="0" cellpadding="0" style="width: 100%">
- <tr>
- <td>序号</td>
- <td>实际入库日期</td>
- <td>商品名称</td>
- <td>提单号</td>
- <td>箱号</td>
- <td>件数</td>
- <td>毛重</td>
- <td>净重</td>
- <td>备注</td>
- </tr>
- <tr v-for="(item, index) in Printinglist" :key="index">
- <td>{{ index + 1 }}</td>
- <td>{{ item.fChargedate }}</td>
- <td>{{ item.fGoodsids }}</td>
- <td>{{ item.fMblno }}</td>
- <td>{{ item.fCntrno }}</td>
- <td>{{ item.fQty }}</td>
- <td>{{ item.fGrossweight }}</td>
- <td>{{ item.fNetweight }}</td>
- <td>{{ item.remark }}</td>
- </tr>
- <tr>
- <td colspan="5">合计:</td>
- <td>{{ allfQty }}</td>
- <td>{{ allfGrossweight }}</td>
- <td>{{ allfNetweight }}</td>
- <td></td>
- </tr>
- </table>
- </div>
- <div
- style="display: flex; justify-content: space-between; font-size: 12px"
- >
- <div>制单人:{{ form.createBy }}</div>
- <div style="width: 100px">审核人:</div>
- </div>
- </div>
- <span slot="footer" class="dialog-footer">
- <el-button type="primary" :disabled="browseStatus" @click="addprint"
- >打印
- </el-button>
- <el-button @click="print_hwqr = false">取消 </el-button>
- </span>
- </el-dialog>
- <el-dialog
- :visible.sync="print_lwqr"
- width="70%"
- :close-on-click-modal="false"
- :modal="false"
- >
- <div id="print_area1" class="print-div">
- <div
- class="print-title"
- style="
- display: flex;
- justify-content: center;
- font-size: 24px;
- margin-bottom: 5px;
- "
- >
- {{ company }}有限公司
- </div>
- <div
- style="
- display: flex;
- justify-content: center;
- font-size: 18px;
- margin-bottom: 5px;
- "
- >
- <div>入 库 单</div>
- </div>
- <div style="display: flex; margin-bottom: 5px">
- <div>
- <div>报关单号:{{ form.fCustomno }}</div>
- <div>存货地点:</div>
- </div>
- </div>
- <div class="print_table" style="display: flex">
- <table border="0" cellspacing="0" cellpadding="0" style="width: 100%">
- <tr>
- <td>品名</td>
- <td colspan="3">{{ form.fProductName }}</td>
- <td colspan="3">清单号</td>
- <td colspan="2">{{ form.fCustomno }}</td>
- </tr>
- <tr>
- <td>提单号</td>
- <td colspan="8">{{ form.fMblno }}</td>
- </tr>
- <tr>
- <td>入库日期</td>
- <td>箱号</td>
- <td>铅封号</td>
- <td>预计件数</td>
- <td>垛位</td>
- <td>实收件数</td>
- <td>实收净重(吨)</td>
- <td>毛重(吨)</td>
- <td>备注</td>
- </tr>
- <tr v-for="(item, index) in Printinglist" :key="index">
- <td>{{ item.fChargedate }}</td>
- <td>{{ item.fCntrno }}</td>
- <td></td>
- <td>{{ item.fQty }}</td>
- <td>{{ item.fWarehouseInformation }}</td>
- <td></td>
- <td></td>
- <td></td>
- <td>{{ item.remark }}</td>
- </tr>
- </table>
- </div>
- <div
- style="display: flex; justify-content: space-between; font-size: 12px"
- >
- <div>库管:{{ form.fContacts }}</div>
- <div style="width: 100px">叉车:</div>
- </div>
- </div>
- <span slot="footer" class="dialog-footer">
- <el-button type="primary" :disabled="browseStatus" @click="addprint"
- >打印
- </el-button>
- <el-button @click="print_lwqr = false">取消 </el-button>
- </span>
- </el-dialog>
- <el-dialog
- :visible.sync="print_dpxx"
- width="70%"
- :close-on-click-modal="false"
- :modal="false"
- >
- <div id="print_area1" class="print-div">
- <div
- class="print-title"
- style="
- display: flex;
- justify-content: center;
- font-size: 24px;
- margin-bottom: 5px;
- "
- >
- {{ company }}有限公司货物标识卡
- </div>
- <div
- style="
- display: flex;
- justify-content: center;
- font-size: 18px;
- margin-bottom: 5px;
- "
- >
- <div>入 库 计 划 单</div>
- </div>
- <div class="print_table" style="display: flex">
- <table border="0" cellspacing="0" cellpadding="0" style="width: 100%">
- <tr>
- <td>货物名称</td>
- <td colspan="2">{{ form.fProductName }}</td>
- <td>库位</td>
- <td colspan="2">{{ stockName }}</td>
- </tr>
- <tr>
- <td>提单号</td>
- <td colspan="2">{{ form.fMblno }}</td>
- <td>清单号</td>
- <td colspan="2">{{ form.fCustomno }}</td>
- </tr>
- <tr>
- <td>箱号</td>
- <td colspan="2"></td>
- <td>总箱量</td>
- <td colspan="2"></td>
- </tr>
- <tr>
- <td>总件数</td>
- <td colspan="2">{{ form.fPlanqty }}</td>
- <td>总净重</td>
- <td colspan="2">{{ form.fPlannetweight }}</td>
- </tr>
- <tr>
- <td>总毛重</td>
- <td colspan="2">{{ form.fPlangrossweight }}</td>
- <td>本垛件数</td>
- <td colspan="2">{{ allfQty }}</td>
- </tr>
- <tr>
- <td>本垛净重</td>
- <td colspan="2">{{ allfGrossweight }}</td>
- <td>本垛毛重</td>
- <td colspan="2">{{ allfNetweight }}</td>
- </tr>
- <tr>
- <td>入库日期</td>
- <td colspan="2">{{ form.fBstime }}</td>
- <td>仓管员</td>
- <td colspan="2">{{ form.fContacts }}</td>
- </tr>
- <tr>
- <td>出库日期</td>
- <td>出库件数</td>
- <td>剩余件数</td>
- <td>出库仓管员</td>
- <td>盘点日期</td>
- <td>盘点人</td>
- </tr>
- <tr style="height: 17.8px" v-for="(item, index) in 10" :key="index">
- <td></td>
- <td></td>
- <td></td>
- <td></td>
- <td></td>
- <td></td>
- </tr>
- <tr style="height: 50px">
- <td>备注</td>
- <td colspan="5"></td>
- </tr>
- </table>
- </div>
- </div>
- <span slot="footer" class="dialog-footer">
- <el-button type="primary" :disabled="browseStatus" @click="addprint"
- >打印
- </el-button>
- <el-button @click="print_dpxx = false">取消 </el-button>
- </span>
- </el-dialog>
- </div>
- </template>
- <script>
- import print from "print-js";
- import {
- addWhgenleg,
- addJoblist,
- disChargelist,
- updateCredit,
- listWarehousebills,
- getWarehousebills,
- delWarehousebills,
- addWarehousebills,
- addWarehouse,
- exportWarehousebills,
- revoke,
- revokeTwo,
- delinStock_s,
- } from "@/api/warehouseBusiness/warehouseInStock";
- 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 { listUser, queryUserVal } from "@/api/system/user";
- import ApprovalComments from "@/views/startApproval";
- import AddOrUpdate from "@/views/viewApproval";
- import Global from "@/layout/components/global";
- import Treeselect from "@riophae/vue-treeselect";
- import "@riophae/vue-treeselect/dist/vue-treeselect.css";
- import UploadFile from "@/components/Uploadfile";
- import Cookies from "js-cookie";
- import { getToken } from "@/utils/auth";
- export default {
- name: "inStock",
- props: {
- chiId: {
- type: Number,
- required: null,
- },
- },
- components: {
- UploadFile,
- },
- data() {
- return {
- mblnoStatus: "",
- selectloading: false,
- fMblnoOptions: [],
- warehouseDrList: [],
- relevantAttachments: [],
- warehouseCrList: [],
- fStltypeOptions: [],
- form: {},
- rules: {
- fDeptid: [{ required: true, message: " ", trigger: "blur" }],
- fMblno: [{ required: true, message: " ", trigger: "blur" }],
- fBsdeptid: [{ required: true, message: " ", trigger: "blur" }],
- fCorpid: [{ required: true, message: " ", trigger: "blur" }],
- fFeetunit: [{ required: true, message: " ", trigger: "blur" }],
- fPlanqty: [{ required: true, message: " ", trigger: "blur" }],
- fPlangrossweight: [{ required: true, message: " ", trigger: "blur" }],
- fPlannetweight: [{ required: true, message: " ", trigger: "blur" }],
- fChargedate: [{ required: true, message: " ", trigger: "blur" }],
- fMarks: [{ required: true, message: " ", trigger: "blur" }],
- fBsdate: [{ required: true, message: " ", trigger: "blur" }],
- fTrademodeid: [{ required: true, message: " ", trigger: "blur" }],
- fSbu: [{ required: true, message: " ", trigger: "blur" }],
- fBusinessType: [{ required: true, message: " ", trigger: "blur" }],
- fStorekeeper: { required: true, message: " ", trigger: "blur" },
- fWarehouseid: [{ required: true, message: " ", trigger: "blur" }],
- fbillingway: [{ required: true, message: " ", trigger: "blur" }],
- fTocorpid: [{ required: true, message: " ", trigger: "blur" }],
- fGoodsid: [{ required: true, message: " ", trigger: "blur" }],
- },
- imporRules: {
- fQty: [{ required: true, message: " ", trigger: "blur" }],
- fGoodsid: [{ required: true, message: " ", trigger: "blur" }],
- fBusinessType: [{ required: true, message: " ", trigger: "blur" }],
- fMarks: [{ required: true, message: " ", trigger: "blur" }],
- fWarehouseInformation: [
- { required: true, message: " ", trigger: "blur" },
- ],
- fPackagespecs: [{ required: true, message: " ", trigger: "blur" }],
- fTruckno: [{ required: true, message: " ", trigger: "blur" }],
- fDriverName: [{ required: true, message: " ", trigger: "blur" }],
- fDriverTel: [{ required: true, message: " ", trigger: "blur" }],
- fDriverIdCar: [{ required: true, message: " ", trigger: "blur" }],
- fCntrno: [{ required: true, message: " ", trigger: "blur" }],
- },
- browseStatus: false,
- formBrowseStatus: false,
- goodsOptions: [],
- warehouseOptions: [],
- userOptions: [],
- businessTypeOption: [],
- fCompanyOptIons: [],
- fleetOptions: [],
- fFeetunitOptions: [],
- current: "",
- before: "",
- contrOl: false,
- isrequired: 2,
- isrequired_s: 2,
- detailsHidden: false,
- CntrTable: [{}],
- fCntridlist: [],
- fTrademodeidOptions: [],
- fIfweighOptions: [],
- fIfpledgeOptions: [],
- fSbuOptions: [],
- Pledgebank: [],
- collapselist: ["1"],
- fStorageTypeOptions: [],
- weightList: false,
- importList: {},
- headers: {
- Authorization: "Bearer " + getToken(),
- },
- sumMum: 0,
- allfPlanqty: 0,
- detailList: [],
- fWarehouseidOptions: [],
- print_zyd: false,
- print_shd: false,
- print_rkd: false,
- print_lhd: false,
- print_hwqr: false,
- print_lwqr: false,
- print_dpxx: false,
- company: "",
- Printinglist: [],
- //库位
- stockName: "",
- //库位地址
- stockaddr: "",
- Collectionoptionss: [],
- fDriverTel: "",
- fBsdate: "",
- fTruckno: "",
- allfCntqty: 0,
- allfGrossweight: 0,
- allfPlanqty: 0,
- allfNetweight: 0,
- allfQty: 0,
- fixdetaiNum: null,
- dataListSelection: [],
- dataWithdrawList: [],
- title: "",
- fWarehouselocid: null,
- };
- },
- created() {
- this.getDicts("data_stltype_type").then((response) => {
- this.fStltypeOptions = response.data;
- });
- this.getDicts("st_in_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;
- });
- listGoods({ fStatus: 0, delFlag: 0 }).then((response) => {
- this.goodsOptions = response.rows;
- });
- this.getDicts("data_ifpledge_status").then((response) => {
- this.fIfpledgeOptions = response.data;
- });
- this.getDicts("storage_type").then((response) => {
- this.fStorageTypeOptions = response.data;
- localStorage.setItem("fStorageTypeList", JSON.stringify(response.data));
- });
- listWarehousesss({ fStatus: 0, delFlag: 0 }).then((response) => {
- this.warehouseOptions = response.rows;
- });
- this.company = localStorage.getItem("companyName");
- this.queryUser();
- },
- filters: {
- fStorageFormat(row) {
- let name;
- for (const item of JSON.parse(localStorage.getItem("fStorageTypeList"))) {
- if (row == item.dictValue) {
- name = item.dictLabel;
- }
- }
- return name;
- },
- fBusinessTypeFormat(row) {
- let name;
- for (const item of JSON.parse(localStorage.getItem("businessTypeList"))) {
- if (row == item.dictValue) {
- name = item.dictLabel;
- }
- }
- return name;
- },
- },
- methods: {
- init() {
- this.resetForm("form");
- this.resetForm("importList");
- this.detailList = [];
- this.getForm();
- },
- reset() {
- this.importList = {
- fBillstatus: null,
- fMblno: null,
- fQty: null,
- fNetweight: null,
- fGrossweight: null,
- fBsdate: null,
- fGoodsid: null,
- fBusinessType: null,
- fMarks: null,
- fWarehouselocid: null,
- fWarehouseInformation: null,
- fCntrtype: null,
- fCntqty: null,
- fPackagespecs: null,
- fTruckno: null,
- fDriverName: null,
- fDriverTel: null,
- fDriverIdCar: null,
- fSerialNumber: null,
- fCntrno: null,
- fGoodsval: null,
- remark: 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.Printinglist[item].ifCntrno == 1 &&
- !this.Printinglist[item].fCntrno
- ) {
- return this.$message.error(
- "请输入第" + (Number(item) + 1) + "行的箱号"
- );
- }
- }
- let formData = new window.FormData();
- 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)
- );
- disChargelist(formData).then((response) => {
- if ((response.code = 200)) {
- this.detailList.map((e, index) => {
- response.data.warehousebillsitems.map((item) => {
- if (e.fId == item.fId) {
- e = item;
- this.$set(this.detailList, index, e);
- }
- });
- });
- this.msgSuccess("卸货成功");
- }
- });
- } else {
- this.$message.error("请选择需要卸货的明细!");
- }
- },
- creditClick() {
- 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("请存在未卸货的数据");
- }
- }
- 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("whgenleg", JSON.stringify(this.relevantAttachments));
- addWhgenleg(formData).then((response) => {
- if ((response.code = 200)) {
- this.detailList.map((e, index) => {
- response.data.warehousebillsitems.map((item) => {
- if (e.fId == item.fId) {
- e = item;
- this.$set(this.detailList, index, e);
- }
- });
- });
- this.msgSuccess("入库成功");
- }
- });
- },
- // 撤回入账
- 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("请存在未入库的数据");
- }
- }
- // 撤回入库
- 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));
- updateCredit(formData).then((response) => {
- this.Printinglist.map((e) => {
- this.detailList.map((item, index) => {
- if (e.fId == item.fId) {
- this.$set(this.detailList[index], "fBillstatus", 10);
- }
- });
- });
- this.msgSuccess("撤回成功");
- });
- },
- fStorageTypeFormat(row) {
- let fStorageType;
- this.fStorageTypeOptions.map((e) => {
- if (row.fBusinessType == e.dictValue) {
- fStorageType = e.dictLabel;
- }
- });
- return fStorageType;
- },
- goodsFormat(row) {
- let goods;
- this.goodsOptions.map((e) => {
- if (row.fGoodsid == e.fId) {
- goods = e.fName;
- }
- });
- return goods;
- },
- fBsdateFormat(row) {
- const dateMat = new Date(row.fBsdate);
- const year = dateMat.getFullYear();
- const month = dateMat.getMonth() + 1;
- const day = dateMat.getDate();
- const timeFormat = year + "-" + month + "-" + day;
- return timeFormat;
- },
- getForm() {
- getWarehousebills(this.chiId).then((response) => {
- this.form = response.data.warehousebills;
- this.$set(this.form, "fEta", Date.parse(this.form.fEta));
- this.$set(this.form, "fBsdate", Date.parse(this.form.fBsdate));
- this.$set(this.form, "createTime", Date.parse(this.form.createTime));
- this.$set(this.form, "fChargedate", Date.parse(this.form.fChargedate));
- if (this.form.fTrademodeid) {
- this.$set(
- this.form,
- "fTrademodeid",
- this.form.fTrademodeid.toString()
- );
- }
- if (this.form.fStltypeid) {
- this.$set(this.form, "fStltypeid", this.form.fStltypeid.toString());
- }
- if (response.data.corps) {
- this.fMblnoOptions = response.data.corps;
- this.KHblnoOptions = response.data.corps;
- this.fCompanyOptIons = response.data.corps;
- this.fSbuOptions = response.data.corps;
- }
- this.detailList = response.data.warehouseBillsItem;
- });
- },
- saveForm() {
- this.$refs["form"].validate((valid) => {
- if (valid) {
- if (this.detailList.length > 0) {
- let formDatae = new window.FormData();
- // 附件数据
- this.form.fBillingway = this.form.fFeetunit;
- // this.form.fBstime = JSON.stringify(this.form.fBstime)
- formDatae.append("tWarehouseBills", JSON.stringify(this.form));
- // 库存明细
- formDatae.append(
- "tWarehousebillsitems",
- JSON.stringify(this.detailList)
- );
- // 附件数据
- formDatae.append(
- "tEnclosure",
- JSON.stringify(this.relevantAttachments)
- );
- // 费用明细付款
- formDatae.append(
- "tWarehousebillsfeesCr",
- JSON.stringify(this.warehouseCrList)
- );
- // 收款
- formDatae.append(
- "tWarehousebillsfeesDr",
- JSON.stringify(this.warehouseDrList)
- );
- formDatae.append("mblnoStatus", this.mblnoStatus);
- addWarehousebills(formDatae).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 {
- this.mblnoStatus = "";
- this.form = response.data.warehouseBills;
- this.detailList = response.data.warehousebillsitems;
- this.msgSuccess("保存成功");
- }
- });
- } else {
- this.$message.error("至少添加一条入库明细");
- }
- }
- });
- },
- imporTable() {
- this.$refs["importList"].validate((valid) => {
- if (valid) {
- let obj = {};
- this.fWarehouselocid = null;
- this.fWarehouseidOptions.map((e) => {
- if (
- e.fWarehouseInformation == this.importList.fWarehouseInformation
- ) {
- this.fWarehouselocid = e.id;
- }
- });
- this.detailList.push({
- fBillstatus: 10,
- fMblno: this.form.fMblno,
- fQty: this.importList.fQty,
- fNetweight: this.importList.fNetweight,
- fGrossweight: this.importList.fGrossweight,
- fBsdate: this.importList.fBsdate,
- fGoodsid: this.importList.fGoodsid,
- fBusinessType: this.importList.fBusinessType,
- fMarks: this.importList.fMarks,
- fWarehouselocid: this.fWarehouselocid,
- fWarehouseInformation: this.importList.fWarehouseInformation,
- fCntrtype: this.importList.fCntrtype,
- fCntqty: this.importList.fCntqty,
- fPackagespecs: this.importList.fPackagespecs,
- fTruckno: this.importList.fTruckno,
- fDriverName: this.importList.fDriverName,
- fDriverTel: this.importList.fDriverTel,
- fDriverIdCar: this.importList.fDriverIdCar,
- fSerialNumber: this.importList.fSerialNumber,
- fCntrno: this.importList.fCntrno,
- fGoodsval: this.importList.fGoodsval,
- remark: this.importList.remark,
- });
- this.weightList = false;
- }
- });
- },
- fiximporTable() {
- this.detailList[this.fixdetaiNum] = this.importList;
- this.weightList = false;
- },
- // 库存明细多选
- Selectinventory(selection) {
- this.Printinglist = selection;
- //允许确认入库list
- this.dataListSelection = [];
- this.dataListSelection = selection.filter((e) => e.fBillstatus == 30);
- //允许撤销入库list
- this.dataWithdrawList = [];
- this.dataWithdrawList = selection.filter((e) => e.fBillstatus == 40);
- console.log("ruku");
- console.log(this.dataListSelection);
- console.log("chexiao");
- console.log(this.dataWithdrawList);
- },
- // 合计
- 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 === "fGrossweight" ||
- column.property === "fNetweight" ||
- column.property === "fQty"
- ) {
- sums[index] = values.reduce((prev, curr) => {
- const value = Number(curr);
- if (!isNaN(value)) {
- if (column.property === "fQty") {
- this.sumMum = prev + curr;
- }
- return prev + curr;
- } else {
- return prev;
- }
- }, 0);
- sums[index] = sums[index].toFixed(2);
- }
- });
- this.sums = sums;
- return sums;
- },
- playcomputer() {
- let Num1 = this.form.fPlannetweight / this.form.fPlanqty;
- let Num2 = this.form.fPlangrossweight / this.form.fPlanqty;
- this.importList.fNetweight = Number(
- (this.importList.fQty * Num1).toFixed(2)
- );
- this.importList.fGrossweight = Number(
- (this.importList.fQty * Num2).toFixed(2)
- );
- },
- imporComputer() {
- if (this.importList.fQty > this.allfPlanqty) {
- return this.$alert("计划件数不能超过" + this.allfPlanqty, "提示", {
- confirmButtonText: "确定",
- type: "warning",
- callback: (action) => {
- this.importList.fQty = this.allfPlanqty;
- this.playcomputer();
- },
- });
- } else {
- this.playcomputer();
- }
- },
- // 入库明细新增list
- addRelevant() {
- this.$refs["form"].validate((valid) => {
- if (valid) {
- this.title = "新增";
- this.reset();
- this.fixdetaiNum = null;
- if (
- !this.form.fPlannetweight ||
- !this.form.fPlangrossweight ||
- !this.form.fPlanqty
- ) {
- return this.$message({
- message: "请维护计划净重(kg),计划毛重(kg),计划件数",
- type: "warning",
- });
- }
- this.importList.fQty = Number(
- (this.form.fPlanqty - this.sumMum).toFixed(2)
- );
- if (this.form.fTruckno) {
- this.importList.fTruckno = this.form.fTruckno;
- }
- if (this.form.fDriverTel) {
- this.importList.fDriverTel = this.form.fDriverTel;
- }
- if (this.form.fDriverName) {
- this.importList.fDriverName = this.form.fDriverName;
- }
- if (this.form.fDriverIdCar) {
- this.importList.fDriverIdCar = this.form.fDriverIdCar;
- }
- this.allfPlanqty = this.importList.fQty;
- this.importList.fBsdate = this.form.fBsdate;
- this.importList.fGoodsid = this.form.fGoodsid;
- this.playcomputer();
- treeselect(this.form.fWarehouseid).then((response) => {
- this.fWarehouseidOptions = response.data;
- });
- this.weightList = true;
- }
- });
- },
- printZyd() {
- if (this.Printinglist.length > 0) {
- for (let item in this.Printinglist) {
- if (!this.Printinglist[item].fId) {
- return this.$message.error("请先保存!");
- }
- if (
- this.Printinglist[item].fTruckno !== this.Printinglist[0].fTruckno
- ) {
- return this.$message.error("请选择车相同车号");
- }
- }
- this.print_zyd = true;
- this.warehouseOptions.map((e) => {
- if (e.fId == this.form.fWarehouseid) {
- this.stockaddr = e.fAddr;
- }
- });
- this.fDriverTel = this.Printinglist[0].fDriverTel;
- } else {
- this.$message.error("请选择需要打印的明细!");
- }
- },
- handleCommand(command) {
- if (this.Printinglist.length > 0) {
- this.$refs["form"].validate((valid) => {
- if (valid) {
- for (let corp in this.fMblnoOptions) {
- if (this.form.fCorpid === this.fMblnoOptions[corp].fId) {
- this.$set(
- this.form,
- "fCorpidName",
- this.fMblnoOptions[corp].fName
- );
- }
- }
- this.warehouseOptions.map((e) => {
- if (e.fId == this.form.fWarehouseid) {
- this.stockName = e.fName;
- this.stockaddr = e.fAddr;
- }
- });
- this.fDriverTel = this.Printinglist[0].fDriverTel;
- this.fBsdate = this.Printinglist[0].fBsdate;
- this.fTruckno = this.Printinglist[0].fTruckno;
- this.allfCntqty = 0;
- this.allfGrossweight = 0;
- this.allfPlanqty = 0;
- this.allfNetweight = 0;
- this.allfQty = 0;
- this.Printinglist.map((e) => {
- if (e.fCntqty) {
- this.allfCntqty += e.fCntqty;
- }
- if (e.fGrossweight) {
- this.allfGrossweight += e.fGrossweight;
- }
- if (e.fPlanqty) {
- this.allfPlanqty += e.fPlanqty;
- }
- if (e.fNetweight) {
- this.allfNetweight += e.fNetweight;
- }
- if (e.fQty) {
- this.allfQty += e.fQty;
- }
- });
- if (command == "a") {
- this.print_shd = true;
- } else if (command == "b") {
- this.print_rkd = true;
- } else if (command == "c") {
- this.print_lhd = true;
- } else if (command == "d") {
- this.print_hwqr = true;
- } else if (command == "e") {
- this.print_lwqr = true;
- } else if (command == "f") {
- this.print_dpxx = true;
- }
- }
- });
- } else {
- this.$message.error("请选择需要打印的明细!");
- }
- },
- //计算仓储费日期变更
- changeDate() {
- this.$set(this.form, "fChargedate", this.form.fBsdate);
- },
- addRow() {
- var obj = {};
- this.CntrTable.push(obj);
- },
- fixRow(row, index) {
- this.title = "修改";
- this.reset();
- this.fixdetaiNum = null;
- this.fixdetaiNum = index;
- row.fBsdate = new Date(row.fBsdate).getTime();
- this.importList = row;
- this.weightList = true;
- },
- 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;
- }
- });
- },
- //获取登陆人
- 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()));
- }
- 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.isrequired_s = 2;
- } else if (
- this.form.fBusinessType === "3" ||
- this.form.fBusinessType === "4"
- ) {
- this.isrequired_s = 1;
- this.isrequired = 2;
- } else {
- this.isrequired = 2;
- this.isrequired_s = 2;
- }
- },
- userRemoteMethod(query) {
- if (query !== "") {
- this.selectloading = true;
- setTimeout(() => {
- listUser({ userName: query }).then((response) => {
- this.selectloading = false;
- this.userOptions = response.rows;
- });
- }, 200);
- } else {
- this.userOptions = [];
- }
- },
- corpremoteMethod(query) {
- if (query !== "") {
- this.selectloading = true;
- setTimeout(() => {
- listCorps({ fName: query, type: 1 }).then((response) => {
- this.selectloading = false;
- this.fMblnoOptions = response.rows;
- });
- }, 200);
- } else {
- this.fMblnoOptions = [];
- }
- },
- flabourRemoteMethod(query) {
- if (query !== "") {
- this.selectloading = true;
- setTimeout(() => {
- listCorps({ fName: query, fTypeid: 6 }).then((response) => {
- this.selectloading = false;
- this.fCompanyOptIons = response.rows;
- });
- }, 200);
- } else {
- this.fCompanyOptIons = [];
- }
- },
- fleetRemoteMethod(query) {
- if (query !== "") {
- this.selectloading = true;
- setTimeout(() => {
- listCorps({ fName: query, fTypeid: 2 }).then((response) => {
- this.selectloading = false;
- this.fleetOptions = response.rows;
- });
- }, 200);
- } else {
- this.fleetOptions = [];
- }
- },
- corpsRemoteMethodd(query) {
- if (query !== "") {
- this.selectloading = true;
- setTimeout(() => {
- listCorps({ fName: query, type: 5 }).then((response) => {
- this.selectloading = false;
- this.Pledgebank = response.rows;
- });
- }, 200);
- } else {
- this.Pledgebank = [];
- }
- },
- fSbuRemoteMethod(query) {
- if (query !== "") {
- this.selectloading = true;
- setTimeout(() => {
- listCorps({ fName: query }).then((response) => {
- this.selectloading = false;
- this.fSbuOptions = response.rows;
- });
- }, 200);
- } else {
- this.fSbuOptions = [];
- }
- },
- clear(e) {
- if (e == "fCorpid") {
- this.fMblnoOptions = [];
- }
- if (e == "fStorekeeper") {
- this.userOptions = [];
- }
- if (e == "fLabour") {
- this.fCompanyOptIons = [];
- }
- if (e == "fFleet") {
- this.fleetOptions = [];
- }
- if (e == "fBankcorpid") {
- this.Pledgebank = [];
- }
- if (e == "fSbu") {
- this.fSbuOptions = [];
- }
- },
- //打印
- addprint(status) {
- if (status == "zyd") {
- 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));
- addJoblist(formData).then((response) => {
- this.detailList.map((e, index) => {
- response.data.warehousebillsitems.map((item) => {
- if (e.fId == item.fId) {
- e = item;
- this.$set(this.detailList, index, e);
- }
- });
- });
- });
- }
- const style =
- "@page { } " +
- "@media print { .print-div{ padding:8px;background-color:#cccccc;} .print-title{display:flex;justify-content: center;font-size:24px} .print_form{font-size:12px} .print_table table {border-right: 1px solid #000;border-bottom: 1px solid #000;font-size:12px} .print_table table td {border-left: 1px solid #000;border-top: 1px solid #000;padding:2px;vertical-align:middle;text-align: center;}";
- print({
- printable: "print_area1",
- type: "html",
- style: style, // 亦可使用引入的外部css;
- scanStyles: false,
- });
- },
- changeShow(status) {
- if (status == "save") {
- this.saveForm();
- }
- this.resetForm("form");
- this.resetForm("importList");
- this.detailList = [];
- this.$emit("changeShow", "true");
- },
- },
- 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-top-right-radius: 0;
- height: 15px;
- padding: 0px 4px;
- 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>
|